2017-08-17 22:00:37 +05:30
|
|
|
class DeleteMergedBranchesService < BaseService
|
|
|
|
def async_execute
|
|
|
|
DeleteMergedBranchesWorker.perform_async(project.id, current_user.id)
|
|
|
|
end
|
|
|
|
|
|
|
|
def execute
|
|
|
|
raise Gitlab::Access::AccessDeniedError unless can?(current_user, :push_code, project)
|
|
|
|
|
2018-03-27 19:54:05 +05:30
|
|
|
branches = project.repository.merged_branch_names
|
|
|
|
# Prevent deletion of branches relevant to open merge requests
|
|
|
|
branches -= merge_request_branch_names
|
|
|
|
# Prevent deletion of protected branches
|
|
|
|
branches = branches.reject { |branch| ProtectedBranch.protected?(project, branch) }
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2018-03-27 19:54:05 +05:30
|
|
|
branches.each do |branch|
|
|
|
|
DeleteBranchService.new(project, current_user).execute(branch)
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def merge_request_branch_names
|
|
|
|
# reorder(nil) is necessary for SELECT DISTINCT because default scope adds an ORDER BY
|
|
|
|
source_names = project.origin_merge_requests.opened.reorder(nil).uniq.pluck(:source_branch)
|
|
|
|
target_names = project.merge_requests.opened.reorder(nil).uniq.pluck(:target_branch)
|
|
|
|
(source_names + target_names).uniq
|
|
|
|
end
|
|
|
|
end
|