debian-mirror-gitlab/app/services/concerns/issues/resolve_discussions.rb

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

44 lines
1.6 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
module ResolveDiscussions
2018-03-17 18:26:18 +05:30
include Gitlab::Utils::StrongMemoize
2017-08-17 22:00:37 +05:30
attr_reader :merge_request_to_resolve_discussions_of_iid, :discussion_to_resolve_id
2018-03-17 18:26:18 +05:30
# rubocop:disable Gitlab/ModuleWithInstanceVariables
2017-08-17 22:00:37 +05:30
def filter_resolve_discussion_params
@merge_request_to_resolve_discussions_of_iid ||= params.delete(:merge_request_to_resolve_discussions_of)
@discussion_to_resolve_id ||= params.delete(:discussion_to_resolve)
end
2018-03-17 18:26:18 +05:30
# rubocop:enable Gitlab/ModuleWithInstanceVariables
2017-08-17 22:00:37 +05:30
2018-12-05 23:21:45 +05:30
# rubocop: disable CodeReuse/ActiveRecord
2017-08-17 22:00:37 +05:30
def merge_request_to_resolve_discussions_of
2018-03-17 18:26:18 +05:30
strong_memoize(:merge_request_to_resolve_discussions_of) do
2023-06-20 00:43:36 +05:30
# sometimes this will be a Group, when work item is created at group level.
# Not sure if we will need to handle resolving an MR with an issue at group level?
next unless container.is_a?(Project)
MergeRequestsFinder.new(current_user, project_id: container.id)
2018-03-17 18:26:18 +05:30
.find_by(iid: merge_request_to_resolve_discussions_of_iid)
end
2017-08-17 22:00:37 +05:30
end
2018-12-05 23:21:45 +05:30
# rubocop: enable CodeReuse/ActiveRecord
2017-08-17 22:00:37 +05:30
def discussions_to_resolve
return [] unless merge_request_to_resolve_discussions_of
2018-03-17 18:26:18 +05:30
@discussions_to_resolve ||= # rubocop:disable Gitlab/ModuleWithInstanceVariables
2017-08-17 22:00:37 +05:30
if discussion_to_resolve_id
discussion_or_nil = merge_request_to_resolve_discussions_of
.find_discussion(discussion_to_resolve_id)
Array(discussion_or_nil)
else
merge_request_to_resolve_discussions_of
.discussions_to_be_resolved
end
end
end
end