debian-mirror-gitlab/app/services/issues/build_service.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

115 lines
3.8 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
2017-08-17 22:00:37 +05:30
module Issues
class BuildService < Issues::BaseService
include ResolveDiscussions
def execute
filter_resolve_discussion_params
2021-11-11 11:23:49 +05:30
2022-03-02 08:16:31 +05:30
@issue = model_klass.new(issue_params.merge(project: project)).tap do |issue|
2019-03-13 22:55:13 +05:30
ensure_milestone_available(issue)
end
2017-08-17 22:00:37 +05:30
end
def issue_params_with_info_from_discussions
return {} unless merge_request_to_resolve_discussions_of
{ title: title_from_merge_request, description: description_for_discussions }
end
def title_from_merge_request
"Follow-up from \"#{merge_request_to_resolve_discussions_of.title}\""
end
def description_for_discussions
if discussions_to_resolve.empty?
return "There are no unresolved discussions. "\
"Review the conversation in #{merge_request_to_resolve_discussions_of.to_reference}"
end
description = "The following #{'discussion'.pluralize(discussions_to_resolve.size)} "\
"from #{merge_request_to_resolve_discussions_of.to_reference} "\
"should be addressed:"
[description, *items_for_discussions].join("\n\n")
end
def items_for_discussions
discussions_to_resolve.map { |discussion| item_for_discussion(discussion) }
end
def item_for_discussion(discussion)
first_note_to_resolve = discussion.first_note_to_resolve || discussion.first_note
is_very_first_note = first_note_to_resolve == discussion.first_note
action = is_very_first_note ? "started" : "commented on"
note_url = Gitlab::UrlBuilder.build(first_note_to_resolve)
other_note_count = discussion.notes.size - 1
2018-11-18 11:00:15 +05:30
discussion_info = ["- [ ] #{first_note_to_resolve.author.to_reference} #{action} a [discussion](#{note_url}): "]
discussion_info << "(+#{other_note_count} #{'comment'.pluralize(other_note_count)})" if other_note_count > 0
2017-08-17 22:00:37 +05:30
note_without_block_quotes = Banzai::Filter::BlockquoteFenceFilter.new(first_note_to_resolve.note).call
spaces = ' ' * 4
quote = note_without_block_quotes.lines.map { |line| "#{spaces}> #{line}" }.join
2018-11-18 11:00:15 +05:30
[discussion_info.join(' '), quote].join("\n\n")
2017-08-17 22:00:37 +05:30
end
def issue_params
2019-07-07 11:18:12 +05:30
@issue_params ||= build_issue_params
2021-11-11 11:23:49 +05:30
2022-03-02 08:16:31 +05:30
if @issue_params[:work_item_type].present?
@issue_params[:issue_type] = @issue_params[:work_item_type].base_type
else
# If :issue_type is nil then params[:issue_type] was either nil
# or not permitted. Either way, the :issue_type will default
# to the column default of `issue`. And that means we need to
# ensure the work_item_type_id is set
@issue_params[:work_item_type_id] = get_work_item_type_id(@issue_params[:issue_type])
end
2021-11-11 11:23:49 +05:30
@issue_params
2017-08-17 22:00:37 +05:30
end
2019-07-07 11:18:12 +05:30
private
2022-03-02 08:16:31 +05:30
def model_klass
::Issue
end
2022-08-13 15:12:31 +05:30
def public_params
# Additional params may be assigned later (in a CreateService for example)
public_issue_params = [
2021-06-08 01:23:25 +05:30
:title,
:description,
:confidential
]
2021-01-03 14:25:43 +05:30
2022-03-02 08:16:31 +05:30
params[:work_item_type] = WorkItems::Type.find_by(id: params[:work_item_type_id]) if params[:work_item_type_id].present? # rubocop: disable CodeReuse/ActiveRecord
2022-08-13 15:12:31 +05:30
public_issue_params << :milestone_id if can?(current_user, :admin_issue, project)
public_issue_params << :issue_type if create_issue_type_allowed?(project, params[:issue_type])
public_issue_params << :work_item_type if create_issue_type_allowed?(project, params[:work_item_type]&.base_type)
2020-05-24 23:13:21 +05:30
2022-08-13 15:12:31 +05:30
params.slice(*public_issue_params)
2017-08-17 22:00:37 +05:30
end
2019-07-07 11:18:12 +05:30
def build_issue_params
2021-01-03 14:25:43 +05:30
{ author: current_user }
.merge(issue_params_with_info_from_discussions)
2022-08-13 15:12:31 +05:30
.merge(public_params)
2021-11-11 11:23:49 +05:30
.with_indifferent_access
end
def get_work_item_type_id(issue_type = :issue)
find_work_item_type_id(issue_type)
2019-07-07 11:18:12 +05:30
end
2017-08-17 22:00:37 +05:30
end
end
2019-12-04 20:38:33 +05:30
2021-06-08 01:23:25 +05:30
Issues::BuildService.prepend_mod_with('Issues::BuildService')