2016-09-26 16:10:54 -04:00
|
|
|
# Labels::TransferService class
|
|
|
|
#
|
|
|
|
# User for recreate the missing group labels at project level
|
|
|
|
#
|
|
|
|
module Labels
|
|
|
|
class TransferService
|
2016-10-19 12:47:17 -04:00
|
|
|
def initialize(current_user, old_group, project)
|
2016-09-26 16:10:54 -04:00
|
|
|
@current_user = current_user
|
2016-10-19 12:47:17 -04:00
|
|
|
@old_group = old_group
|
2016-09-26 16:10:54 -04:00
|
|
|
@project = project
|
|
|
|
end
|
|
|
|
|
|
|
|
def execute
|
2016-10-19 12:47:17 -04:00
|
|
|
return unless old_group.present?
|
2016-09-26 16:10:54 -04:00
|
|
|
|
|
|
|
Label.transaction do
|
|
|
|
labels_to_transfer.find_each do |label|
|
|
|
|
new_label_id = find_or_create_label!(label)
|
|
|
|
|
2016-10-13 16:25:25 -04:00
|
|
|
next if new_label_id == label.id
|
|
|
|
|
2016-10-19 12:47:17 -04:00
|
|
|
update_label_links(group_labels_applied_to_issues, old_label_id: label.id, new_label_id: new_label_id)
|
|
|
|
update_label_links(group_labels_applied_to_merge_requests, old_label_id: label.id, new_label_id: new_label_id)
|
|
|
|
update_label_priorities(old_label_id: label.id, new_label_id: new_label_id)
|
2016-09-26 16:10:54 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2016-10-19 12:47:17 -04:00
|
|
|
attr_reader :current_user, :old_group, :project
|
|
|
|
|
|
|
|
def labels_to_transfer
|
|
|
|
label_ids = []
|
|
|
|
label_ids << group_labels_applied_to_issues.select(:id)
|
|
|
|
label_ids << group_labels_applied_to_merge_requests.select(:id)
|
2016-09-26 16:10:54 -04:00
|
|
|
|
2016-10-19 12:47:17 -04:00
|
|
|
union = Gitlab::SQL::Union.new(label_ids)
|
2016-09-26 16:10:54 -04:00
|
|
|
|
2017-08-03 22:20:34 -04:00
|
|
|
Label.where("labels.id IN (#{union.to_sql})").reorder(nil).uniq # rubocop:disable GitlabSecurity/SqlInjection
|
2016-10-19 12:47:17 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def group_labels_applied_to_issues
|
2017-06-21 09:48:12 -04:00
|
|
|
Label.joins(:issues)
|
|
|
|
.where(
|
2016-10-19 12:47:17 -04:00
|
|
|
issues: { project_id: project.id },
|
|
|
|
labels: { type: 'GroupLabel', group_id: old_group.id }
|
|
|
|
)
|
|
|
|
end
|
2016-09-26 16:10:54 -04:00
|
|
|
|
2016-10-19 12:47:17 -04:00
|
|
|
def group_labels_applied_to_merge_requests
|
2017-06-21 09:48:12 -04:00
|
|
|
Label.joins(:merge_requests)
|
|
|
|
.where(
|
2016-10-19 12:47:17 -04:00
|
|
|
merge_requests: { target_project_id: project.id },
|
|
|
|
labels: { type: 'GroupLabel', group_id: old_group.id }
|
|
|
|
)
|
2016-09-26 16:10:54 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def find_or_create_label!(label)
|
2016-10-19 12:47:17 -04:00
|
|
|
params = label.attributes.slice('title', 'description', 'color')
|
2016-10-19 09:53:31 -04:00
|
|
|
new_label = FindOrCreateService.new(current_user, project, params).execute
|
2016-09-26 16:10:54 -04:00
|
|
|
|
|
|
|
new_label.id
|
|
|
|
end
|
2016-10-19 12:47:17 -04:00
|
|
|
|
|
|
|
def update_label_links(labels, old_label_id:, new_label_id:)
|
2017-06-21 09:48:12 -04:00
|
|
|
LabelLink.joins(:label)
|
|
|
|
.merge(labels)
|
|
|
|
.where(label_id: old_label_id)
|
|
|
|
.update_all(label_id: new_label_id)
|
2016-10-19 12:47:17 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def update_label_priorities(old_label_id:, new_label_id:)
|
2017-06-21 09:48:12 -04:00
|
|
|
LabelPriority.where(project_id: project.id, label_id: old_label_id)
|
|
|
|
.update_all(label_id: new_label_id)
|
2016-10-19 12:47:17 -04:00
|
|
|
end
|
2016-09-26 16:10:54 -04:00
|
|
|
end
|
|
|
|
end
|