debian-mirror-gitlab/app/services/notes/create_service.rb

108 lines
3.5 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
2014-09-02 18:07:02 +05:30
module Notes
2018-12-13 13:39:08 +05:30
class CreateService < ::Notes::BaseService
2014-09-02 18:07:02 +05:30
def execute
2020-03-13 15:44:24 +05:30
note = Notes::BuildService.new(project, current_user, params.except(:merge_request_diff_head_sha)).execute
2018-03-17 18:26:18 +05:30
2019-12-04 20:38:33 +05:30
# n+1: https://gitlab.com/gitlab-org/gitlab-foss/issues/37440
2018-03-17 18:26:18 +05:30
note_valid = Gitlab::GitalyClient.allow_n_plus_1_calls do
2020-01-01 13:55:28 +05:30
# We may set errors manually in Notes::BuildService for this reason
# we also need to check for already existing errors.
note.errors.empty? && note.valid?
2018-03-17 18:26:18 +05:30
end
return note unless note_valid
2016-06-02 11:05:42 +05:30
2016-09-13 17:45:13 +05:30
# We execute commands (extracted from `params[:note]`) on the noteable
# **before** we save the note because if the note consists of commands
# only, there is no need be create a note!
2020-04-22 19:07:51 +05:30
execute_quick_actions(note) do |only_commands|
note.run_after_commit do
# Finish the harder work in the background
NewNoteWorker.perform_async(note.id)
end
2016-09-13 17:45:13 +05:30
2020-04-22 19:07:51 +05:30
note_saved = note.with_transaction_returning_status do
!only_commands && note.save
end
2016-09-13 17:45:13 +05:30
2020-04-22 19:07:51 +05:30
when_saved(note) if note_saved
2016-09-13 17:45:13 +05:30
end
2020-04-22 19:07:51 +05:30
note
end
2017-08-17 22:00:37 +05:30
2020-04-22 19:07:51 +05:30
private
2020-01-01 13:55:28 +05:30
2020-04-22 19:07:51 +05:30
def execute_quick_actions(note)
return yield(false) unless quick_actions_service.supported?(note)
2019-03-02 22:35:43 +05:30
2020-04-22 19:07:51 +05:30
content, update_params, message = quick_actions_service.execute(note, quick_action_options)
only_commands = content.empty?
note.note = content
2019-12-26 22:10:19 +05:30
2020-04-22 19:07:51 +05:30
yield(only_commands)
do_commands(note, update_params, message, only_commands)
end
def quick_actions_service
@quick_actions_service ||= QuickActionsService.new(project, current_user)
end
def when_saved(note)
if note.part_of_discussion? && note.discussion.can_convert_to_discussion?
note.discussion.convert_to_discussion!(save: true)
2016-09-13 17:45:13 +05:30
end
2020-04-22 19:07:51 +05:30
todo_service.new_note(note, current_user)
clear_noteable_diffs_cache(note)
Suggestions::CreateService.new(note).execute
increment_usage_counter(note)
2016-09-13 17:45:13 +05:30
2020-04-22 19:07:51 +05:30
if Feature.enabled?(:notes_create_service_tracking, project)
Gitlab::Tracking.event('Notes::CreateService', 'execute', tracking_data_for(note))
2014-09-02 18:07:02 +05:30
end
2020-04-22 19:07:51 +05:30
if Feature.enabled?(:merge_ref_head_comments, project) && note.for_merge_request? && note.diff_note? && note.start_of_discussion?
Discussions::CaptureDiffNotePositionService.new(note.noteable, note.diff_file&.paths).execute(note.discussion)
end
2014-09-02 18:07:02 +05:30
end
2019-12-26 22:10:19 +05:30
2020-04-22 19:07:51 +05:30
def do_commands(note, update_params, message, only_commands)
return if quick_actions_service.commands_executed_count.to_i.zero?
if update_params.present?
quick_actions_service.apply_updates(update_params, note)
note.commands_changes = update_params
end
# We must add the error after we call #save because errors are reset
# when #save is called
if only_commands
note.errors.add(:commands_only, message.presence || _('Failed to apply commands.'))
# Allow consumers to detect problems applying commands
note.errors.add(:commands, _('Failed to apply commands.')) unless message.present?
end
end
2019-12-26 22:10:19 +05:30
2020-03-13 15:44:24 +05:30
def quick_action_options
2020-06-23 00:09:42 +05:30
{
merge_request_diff_head_sha: params[:merge_request_diff_head_sha],
review_id: params[:review_id]
}
2020-03-13 15:44:24 +05:30
end
2019-12-26 22:10:19 +05:30
def tracking_data_for(note)
label = Gitlab.ee? && note.author == User.visual_review_bot ? 'anonymous_visual_review_note' : 'note'
{
label: label,
value: note.id
}
end
2014-09-02 18:07:02 +05:30
end
end