123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- # frozen_string_literal: true
- module Admin
- class AccountsController < BaseController
- before_action :set_account, except: [:index, :batch]
- 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])
- @form = Form::AccountBatch.new
- end
- def batch
- authorize :account, :index?
- @form = Form::AccountBatch.new(form_account_batch_params)
- @form.current_account = current_account
- @form.action = action_from_button
- @form.select_all_matching = params[:select_all_matching]
- @form.query = filtered_accounts
- @form.save
- rescue ActionController::ParameterMissing
- flash[:alert] = I18n.t('admin.accounts.no_account_selected')
- ensure
- redirect_to admin_accounts_path(filter_params)
- end
- def show
- authorize @account, :show?
- @deletion_request = @account.deletion_request
- @account_moderation_note = current_account.account_moderation_notes.new(target_account: @account)
- @moderation_notes = @account.targeted_moderation_notes.latest
- @warnings = @account.strikes.includes(:target_account, :account, :appeal).latest
- @domain_block = DomainBlock.rule_for(@account.domain)
- end
- def memorialize
- authorize @account, :memorialize?
- @account.memorialize!
- log_action :memorialize, @account
- redirect_to admin_account_path(@account.id), notice: I18n.t('admin.accounts.memorialized_msg', username: @account.acct)
- end
- def enable
- authorize @account.user, :enable?
- @account.user.enable!
- log_action :enable, @account.user
- redirect_to admin_account_path(@account.id), notice: I18n.t('admin.accounts.enabled_msg', username: @account.acct)
- end
- def approve
- authorize @account.user, :approve?
- @account.user.approve!
- redirect_to admin_accounts_path(status: 'pending'), notice: I18n.t('admin.accounts.approved_msg', username: @account.acct)
- end
- def reject
- authorize @account.user, :reject?
- DeleteAccountService.new.call(@account, reserve_email: false, reserve_username: false)
- redirect_to admin_accounts_path(status: 'pending'), notice: I18n.t('admin.accounts.rejected_msg', username: @account.acct)
- end
- def destroy
- authorize @account, :destroy?
- Admin::AccountDeletionWorker.perform_async(@account.id)
- redirect_to admin_account_path(@account.id), notice: I18n.t('admin.accounts.destroyed_msg', username: @account.acct)
- end
- def unsensitive
- authorize @account, :unsensitive?
- @account.unsensitize!
- log_action :unsensitive, @account
- redirect_to admin_account_path(@account.id)
- end
- def unsilence
- authorize @account, :unsilence?
- @account.unsilence!
- log_action :unsilence, @account
- redirect_to admin_account_path(@account.id), notice: I18n.t('admin.accounts.unsilenced_msg', username: @account.acct)
- end
- def unsuspend
- authorize @account, :unsuspend?
- @account.unsuspend!
- Admin::UnsuspensionWorker.perform_async(@account.id)
- log_action :unsuspend, @account
- redirect_to admin_account_path(@account.id), notice: I18n.t('admin.accounts.unsuspended_msg', username: @account.acct)
- end
- def redownload
- authorize @account, :redownload?
- @account.update!(last_webfingered_at: nil)
- ResolveAccountService.new.call(@account)
- redirect_to admin_account_path(@account.id), notice: I18n.t('admin.accounts.redownloaded_msg', username: @account.acct)
- 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), notice: I18n.t('admin.accounts.removed_avatar_msg', username: @account.acct)
- 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), notice: I18n.t('admin.accounts.removed_header_msg', username: @account.acct)
- end
- def unblock_email
- authorize @account, :unblock_email?
- CanonicalEmailBlock.where(reference_account: @account).delete_all
- log_action :unblock_email, @account
- redirect_to admin_account_path(@account.id), notice: I18n.t('admin.accounts.unblocked_email_msg', username: @account.acct)
- 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.with_defaults(order: 'recent')).results
- end
- def filter_params
- params.slice(:page, *AccountFilter::KEYS).permit(:page, *AccountFilter::KEYS)
- end
- def form_account_batch_params
- params.require(:form_account_batch).permit(:action, account_ids: [])
- end
- def action_from_button
- if params[:suspend]
- 'suspend'
- elsif params[:approve]
- 'approve'
- elsif params[:reject]
- 'reject'
- end
- end
- end
- end
|