discourse/app/services/group_action_logger.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

82 lines
1.9 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
2016-12-11 10:36:15 -05:00
class GroupActionLogger
2017-01-04 08:23:21 -05:00
def initialize(acting_user, group, opts = {})
2016-12-11 10:36:15 -05:00
@acting_user = acting_user
@group = group
@opts = opts
2016-12-11 10:36:15 -05:00
end
def log_make_user_group_owner(target_user)
can_edit?
GroupHistory.create!(default_params.merge(
action: GroupHistory.actions[:make_user_group_owner],
target_user: target_user
))
end
def log_remove_user_as_group_owner(target_user)
can_edit?
GroupHistory.create!(default_params.merge(
action: GroupHistory.actions[:remove_user_as_group_owner],
target_user: target_user
))
end
def log_add_user_to_group(target_user)
(target_user == @acting_user && @group.public_admission) || can_edit?
2016-12-11 10:36:15 -05:00
GroupHistory.create!(default_params.merge(
action: GroupHistory.actions[:add_user_to_group],
target_user: target_user
))
end
def log_remove_user_from_group(target_user)
(target_user == @acting_user && @group.public_exit) || can_edit?
2016-12-11 10:36:15 -05:00
GroupHistory.create!(default_params.merge(
action: GroupHistory.actions[:remove_user_from_group],
target_user: target_user
))
end
def log_change_group_settings
@opts[:skip_guardian] || can_edit?
2016-12-11 10:36:15 -05:00
@group.previous_changes.except(*excluded_attributes).each do |attribute_name, value|
next if value[0].blank? && value[1].blank?
GroupHistory.create!(default_params.merge(
action: GroupHistory.actions[:change_group_setting],
subject: attribute_name,
prev_value: value[0],
new_value: value[1]
))
end
end
private
2017-01-04 08:23:21 -05:00
def excluded_attributes
[
:bio_cooked,
:updated_at,
:created_at,
:user_count
]
end
2016-12-11 10:36:15 -05:00
2017-01-04 08:23:21 -05:00
def default_params
{ group: @group, acting_user: @acting_user }
end
2016-12-11 10:36:15 -05:00
2017-01-04 08:23:21 -05:00
def can_edit?
raise Discourse::InvalidParameters.new unless Guardian.new(@acting_user).can_log_group_changes?(@group)
2016-12-11 10:36:15 -05:00
end
2017-01-04 08:23:21 -05:00
2016-12-11 10:36:15 -05:00
end