Skip to content

Commit

Permalink
Remove default_scope from Admin::ActionLog (mastodon#28026)
Browse files Browse the repository at this point in the history
  • Loading branch information
mjankowski authored Nov 29, 2023
1 parent 291dc04 commit e48ecd2
Show file tree
Hide file tree
Showing 6 changed files with 20 additions and 16 deletions.
2 changes: 1 addition & 1 deletion app/controllers/admin/action_logs_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ class ActionLogsController < BaseController

def index
authorize :audit_log, :index?
@auditable_accounts = Account.where(id: Admin::ActionLog.reorder(nil).select('distinct account_id')).select(:id, :username)
@auditable_accounts = Account.where(id: Admin::ActionLog.select('distinct account_id')).select(:id, :username)
end

private
Expand Down
4 changes: 2 additions & 2 deletions app/models/admin/action_log.rb
Original file line number Diff line number Diff line change
Expand Up @@ -24,12 +24,12 @@ class Admin::ActionLog < ApplicationRecord
belongs_to :account
belongs_to :target, polymorphic: true, optional: true

default_scope -> { order('id desc') }

before_validation :set_human_identifier
before_validation :set_route_param
before_validation :set_permalink

scope :latest, -> { order(id: :desc) }

def action
super.to_sym
end
Expand Down
12 changes: 8 additions & 4 deletions app/models/admin/action_log_filter.rb
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ def initialize(params)
end

def results
scope = Admin::ActionLog.includes(:target)
scope = latest_action_logs.includes(:target)

params.each do |key, value|
next if key.to_s == 'page'
Expand All @@ -88,14 +88,18 @@ def results
def scope_for(key, value)
case key
when 'action_type'
Admin::ActionLog.where(ACTION_TYPE_MAP[value.to_sym])
latest_action_logs.where(ACTION_TYPE_MAP[value.to_sym])
when 'account_id'
Admin::ActionLog.where(account_id: value)
latest_action_logs.where(account_id: value)
when 'target_account_id'
account = Account.find_or_initialize_by(id: value)
Admin::ActionLog.where(target: [account, account.user].compact)
latest_action_logs.where(target: [account, account.user].compact)
else
raise Mastodon::InvalidParameterError, "Unknown filter: #{key}"
end
end

def latest_action_logs
Admin::ActionLog.latest
end
end
10 changes: 5 additions & 5 deletions app/models/report.rb
Original file line number Diff line number Diff line change
Expand Up @@ -131,25 +131,25 @@ def history
Admin::ActionLog.where(
target_type: 'Report',
target_id: id
).unscope(:order).arel,
).arel,

Admin::ActionLog.where(
target_type: 'Account',
target_id: target_account_id
).unscope(:order).arel,
).arel,

Admin::ActionLog.where(
target_type: 'Status',
target_id: status_ids
).unscope(:order).arel,
).arel,

Admin::ActionLog.where(
target_type: 'AccountWarning',
target_id: AccountWarning.where(report_id: id).select(:id)
).unscope(:order).arel,
).arel,
].reduce { |union, query| Arel::Nodes::UnionAll.new(union, query) }

Admin::ActionLog.from(Arel::Nodes::As.new(subquery, Admin::ActionLog.arel_table))
Admin::ActionLog.latest.from(Arel::Nodes::As.new(subquery, Admin::ActionLog.arel_table))
end

private
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# frozen_string_literal: true

Fabricator('Admin::ActionLog') do
Fabricator(:action_log, from: Admin::ActionLog) do
account { Fabricate.build(:account) }
action 'MyString'
target nil
Expand Down
6 changes: 3 additions & 3 deletions spec/models/report_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -110,9 +110,9 @@
let(:status) { Fabricate(:status) }

before do
Fabricate('Admin::ActionLog', target_type: 'Report', account_id: target_account.id, target_id: report.id, created_at: 2.days.ago)
Fabricate('Admin::ActionLog', target_type: 'Account', account_id: target_account.id, target_id: report.target_account_id, created_at: 2.days.ago)
Fabricate('Admin::ActionLog', target_type: 'Status', account_id: target_account.id, target_id: status.id, created_at: 2.days.ago)
Fabricate(:action_log, target_type: 'Report', account_id: target_account.id, target_id: report.id, created_at: 2.days.ago)
Fabricate(:action_log, target_type: 'Account', account_id: target_account.id, target_id: report.target_account_id, created_at: 2.days.ago)
Fabricate(:action_log, target_type: 'Status', account_id: target_account.id, target_id: status.id, created_at: 2.days.ago)
end

it 'returns right logs' do
Expand Down

0 comments on commit e48ecd2

Please sign in to comment.