1
0
Fork 0
mirror of https://github.com/mastodon/mastodon.git synced 2024-08-20 21:08:15 -07:00

Compare commits

...

6 commits

Author SHA1 Message Date
Matt Jankowski
c5bd8c09cd
Merge e95899fa83 into 549ab089ee 2024-07-31 11:06:48 +00:00
Matt Jankowski
e95899fa83 Handle destroyed records in action log 2024-07-18 09:32:37 -04:00
Matt Jankowski
3835f8286a Restore action log specs 2024-07-18 09:32:37 -04:00
Matt Jankowski
1a66aaaeb6 Only log admin actions when change actually happened 2024-07-18 09:32:37 -04:00
Matt Jankowski
71918091e6 Dont expect log when rejecting 2024-07-18 09:32:37 -04:00
Matt Jankowski
32cb060652 Log action after updating records 2024-07-18 09:32:37 -04:00
3 changed files with 24 additions and 8 deletions

View file

@ -4,6 +4,8 @@ module AccountableConcern
extend ActiveSupport::Concern extend ActiveSupport::Concern
def log_action(action, target) def log_action(action, target)
return unless target.previous_changes.any? || target.destroyed?
Admin::ActionLog.create( Admin::ActionLog.create(
account: current_account, account: current_account,
action: action, action: action,

View file

@ -124,26 +124,26 @@ class Admin::AccountAction
def handle_disable! def handle_disable!
authorize(target_account.user, :disable?) authorize(target_account.user, :disable?)
log_action(:disable, target_account.user)
target_account.user&.disable! target_account.user&.disable!
log_action(:disable, target_account.user)
end end
def handle_sensitive! def handle_sensitive!
authorize(target_account, :sensitive?) authorize(target_account, :sensitive?)
log_action(:sensitive, target_account)
target_account.sensitize! target_account.sensitize!
log_action(:sensitive, target_account)
end end
def handle_silence! def handle_silence!
authorize(target_account, :silence?) authorize(target_account, :silence?)
log_action(:silence, target_account)
target_account.silence! target_account.silence!
log_action(:silence, target_account)
end end
def handle_suspend! def handle_suspend!
authorize(target_account, :suspend?) authorize(target_account, :suspend?)
log_action(:suspend, target_account)
target_account.suspend!(origin: :local) target_account.suspend!(origin: :local)
log_action(:suspend, target_account)
end end
def text_for_warning def text_for_warning

View file

@ -19,10 +19,24 @@ RSpec.describe AccountableConcern do
let(:hoge) { hoge_class.new(user) } let(:hoge) { hoge_class.new(user) }
describe '#log_action' do describe '#log_action' do
it 'creates Admin::ActionLog' do subject { hoge.log_action(:create, target) }
expect do
hoge.log_action(:create, target) before { target.reload } # Ensure changes from creation cleared
end.to change(Admin::ActionLog, :count).by(1)
context 'when target has changed' do
before { target.update!(username: 'new_value') }
it 'creates Admin::ActionLog' do
expect { subject }
.to change(Admin::ActionLog, :count).by(1)
end
end
context 'when target has not changed' do
it 'does not create Admin::ActionLog' do
expect { subject }
.to_not change(Admin::ActionLog, :count)
end
end end
end end
end end