2020-07-28 23:09:34 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module MergeRequests
|
|
|
|
class RemoveApprovalService < MergeRequests::BaseService
|
|
|
|
# rubocop: disable CodeReuse/ActiveRecord
|
|
|
|
def execute(merge_request)
|
|
|
|
return unless merge_request.approved_by?(current_user)
|
|
|
|
|
|
|
|
# paranoid protection against running wrong deletes
|
|
|
|
return unless merge_request.id && current_user.id
|
|
|
|
|
|
|
|
approval = merge_request.approvals.where(user: current_user)
|
|
|
|
|
|
|
|
trigger_approval_hooks(merge_request) do
|
|
|
|
next unless approval.destroy_all # rubocop: disable Cop/DestroyAll
|
|
|
|
|
|
|
|
reset_approvals_cache(merge_request)
|
|
|
|
create_note(merge_request)
|
2021-03-11 19:13:27 +05:30
|
|
|
merge_request_activity_counter.track_unapprove_mr_action(user: current_user)
|
2020-07-28 23:09:34 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
success
|
|
|
|
end
|
|
|
|
# rubocop: enable CodeReuse/ActiveRecord
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def reset_approvals_cache(merge_request)
|
|
|
|
merge_request.approvals.reset
|
|
|
|
end
|
|
|
|
|
|
|
|
def trigger_approval_hooks(merge_request)
|
|
|
|
yield
|
|
|
|
|
|
|
|
execute_hooks(merge_request, 'unapproved')
|
|
|
|
end
|
|
|
|
|
|
|
|
def create_note(merge_request)
|
|
|
|
SystemNoteService.unapprove_mr(merge_request, current_user)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
MergeRequests::RemoveApprovalService.prepend_if_ee('EE::MergeRequests::RemoveApprovalService')
|