authorized_destroy_service.rb 1.3 KB
Newer Older
1 2 3 4 5 6 7 8 9
module Members
  class AuthorizedDestroyService < BaseService
    attr_accessor :member, :user

    def initialize(member, user = nil)
      @member, @user = member, user
    end

    def execute
10 11
      return false if member.is_a?(GroupMember) && member.source.last_owner?(member.user)

12 13 14 15 16
      Member.transaction do
        unassign_issues_and_merge_requests(member)

        member.destroy
      end
17 18 19 20

      if member.request? && member.user != user
        notification_service.decline_access_request(member)
      end
21 22

      member
23
    end
24 25 26 27 28

    private

    def unassign_issues_and_merge_requests(member)
      if member.is_a?(GroupMember)
29 30 31 32 33
        issue_ids = IssuesFinder.new(user, group_id: member.source_id, assignee_id: member.user_id).
          execute.pluck(:id)

        IssueAssignee.destroy_all(issue_id: issue_ids, user_id: member.user_id)

34 35 36 37 38
        MergeRequestsFinder.new(user, group_id: member.source_id, assignee_id: member.user_id).
          execute.
          update_all(assignee_id: nil)
      else
        project = member.source
39 40 41 42 43 44

        IssueAssignee.destroy_all(
          user_id: member.user_id,
          issue_id: project.issues.opened.assigned_to(member.user).select(:id)
        )

45 46
        project.merge_requests.opened.assigned_to(member.user).update_all(assignee_id: nil)
      end
47 48

      member.user.invalidate_cache_counts
49
    end
50 51
  end
end