blob: 1949fb67e833d527825df3a03d15475311ab6374 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
# frozen_string_literal: true
module Projects
class DeleteBranchWorker
include ApplicationWorker
data_consistency :always
feature_category :source_code_management
urgency :high
idempotent!
def perform(project_id, user_id, branch_name)
project = Project.find_by_id(project_id)
user = User.find_by_id(user_id)
return unless project.present? && user.present?
return unless project.repository.branch_exists?(branch_name)
delete_service_result = ::Branches::DeleteService.new(project, user)
.execute(branch_name)
return unless Feature.enabled?(:track_and_raise_delete_source_errors, project)
# Only want to raise on 400 to avoid permission and non existant branch error
return unless delete_service_result[:http_status] == 400
delete_service_result.track_and_raise_exception
end
end
end
|