# frozen_string_literal: true module Admin class AccountsController < BaseController before_action :set_account, only: [:show, :redownload, :remove_avatar, :remove_header, :enable, :unsilence, :unsuspend, :memorialize, :approve, :reject, :verify, :unverify, :add_donor_badge, :remove_donor_badge, :add_investor_badge, :remove_investor_badge, :edit_pro, :save_pro, :edit, :update, :reset_spam] before_action :require_remote_account!, only: [:redownload] before_action :require_local_account!, only: [:enable, :memorialize, :approve, :reject] def index authorize :account, :index? @accounts = filtered_accounts.page(params[:page]) end def show authorize @account, :show? @account_moderation_note = current_account.account_moderation_notes.new(target_account: @account) @moderation_notes = @account.targeted_moderation_notes.latest @warnings = @account.targeted_account_warnings.latest.custom end def memorialize authorize @account, :memorialize? @account.memorialize! log_action :memorialize, @account redirect_to admin_account_path(@account.id) end def enable authorize @account.user, :enable? @account.user.enable! log_action :enable, @account.user redirect_to admin_account_path(@account.id) end def approve authorize @account.user, :approve? @account.user.approve! redirect_to admin_accounts_path(pending: '1') end def reject authorize @account.user, :reject? SuspendAccountService.new.call(@account, including_user: true, destroy: true, skip_distribution: true) redirect_to admin_accounts_path(pending: '1') end def unsilence authorize @account, :unsilence? @account.unsilence! log_action :unsilence, @account redirect_to admin_account_path(@account.id) end def unsuspend authorize @account, :unsuspend? @account.unsuspend! log_action :unsuspend, @account redirect_to admin_account_path(@account.id) end def verify authorize @account, :verify? @account.is_verified = true @account.save! log_action :verify_account, @account.user redirect_to admin_account_path(@account.id) end def unverify authorize @account, :verify? @account.is_verified = false @account.save! log_action :unverify_account, @account.user redirect_to admin_account_path(@account.id) end def add_donor_badge authorize @account, :update_badges? @account.is_donor = true @account.save! log_action :add_donor_badge, @account.user redirect_to admin_account_path(@account.id) end def remove_donor_badge authorize @account, :update_badges? @account.is_donor = false @account.save! log_action :remove_donor_badge, @account.user redirect_to admin_account_path(@account.id) end def add_investor_badge authorize @account, :update_badges? @account.is_investor = true @account.save! log_action :add_investor_badge, @account.user redirect_to admin_account_path(@account.id) end def remove_investor_badge authorize @account, :update_badges? @account.is_investor = false @account.save! log_action :remove_investor_badge, @account.user redirect_to admin_account_path(@account.id) end def redownload authorize @account, :redownload? redirect_to admin_account_path(@account.id) end def remove_avatar authorize @account, :remove_avatar? @account.avatar = nil @account.save! log_action :remove_avatar, @account.user redirect_to admin_account_path(@account.id) end def remove_header authorize @account, :remove_header? @account.header = nil @account.save! log_action :remove_header, @account.user redirect_to admin_account_path(@account.id) end def edit_pro authorize @account, :edit_pro? end def save_pro authorize @account, :edit_pro? @account.update!(pro_params) redirect_to edit_pro_admin_account_path(@account.id) end def edit redirect_to admin_account_path(@account.id) unless @account.local? @user = @account.user end def update redirect_to admin_account_path(@account.id) unless @account.local? @user = @account.user if @user.update(credentials_params) redirect_to admin_account_path(@account.id), notice: I18n.t('generic.changes_saved_msg') else render action: :edit end end def reset_spam @account.spam_flag = Account::SPAM_FLAG_CLASS_MAP[:safe] @account.save! redirect_to admin_account_path(@account.id) end private def set_account @account = Account.find(params[:id]) end def require_remote_account! redirect_to admin_account_path(@account.id) if @account.local? end def require_local_account! redirect_to admin_account_path(@account.id) unless @account.local? && @account.user.present? end def filtered_accounts AccountFilter.new(filter_params).results end def filter_params params.permit( :local, :remote, :by_domain, :active, :pending, :silenced, :suspended, :spam, :username, :display_name, :email, :ip, :staff, :note, :status_count_gte, :sign_up_date_gte, :is_pro, :is_investor, :is_verified, :is_donor, ) end def pro_params params.require(:account).permit(:is_pro, :pro_expires_at) end def credentials_params new_params = params.require(:user).permit(:email, :password, :password_confirmation) if new_params[:password].blank? && new_params[:password_confirmation].blank? new_params.delete(:password) new_params.delete(:password_confirmation) end new_params end end end