65eca13f7b
some changes introduced by4daa6da540
,26b6e299e1
,17898ce021
were regressed during today's merge conflict resolution of !11573. This commit serves to reapply those changes. /cc: @rspeicher @stanhu @mikegreiling
28 lines
784 B
Ruby
28 lines
784 B
Ruby
module Milestones
|
|
class DestroyService < Milestones::BaseService
|
|
def execute(milestone)
|
|
return unless milestone.is_project_milestone?
|
|
|
|
Milestone.transaction do
|
|
update_params = { milestone: nil }
|
|
|
|
milestone.issues.each do |issue|
|
|
Issues::UpdateService.new(parent, current_user, update_params).execute(issue)
|
|
end
|
|
|
|
milestone.merge_requests.each do |merge_request|
|
|
MergeRequests::UpdateService.new(parent, current_user, update_params).execute(merge_request)
|
|
end
|
|
|
|
event_service.destroy_milestone(milestone, current_user)
|
|
|
|
Event.for_milestone_id(milestone.id).each do |event|
|
|
event.target_id = nil
|
|
event.save
|
|
end
|
|
|
|
milestone.destroy
|
|
end
|
|
end
|
|
end
|
|
end
|