2018-11-18 11:00:15 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
module MergeRequests
|
|
|
|
module Conflicts
|
|
|
|
class ListService < MergeRequests::Conflicts::BaseService
|
|
|
|
delegate :file_for_path, :to_json, to: :conflicts
|
|
|
|
|
|
|
|
def can_be_resolved_by?(user)
|
|
|
|
return false unless merge_request.source_project
|
|
|
|
|
2020-10-24 23:57:45 +05:30
|
|
|
access = ::Gitlab::UserAccess.new(user, container: merge_request.source_project)
|
2017-08-17 22:00:37 +05:30
|
|
|
access.can_push_to_branch?(merge_request.source_branch)
|
|
|
|
end
|
|
|
|
|
|
|
|
def can_be_resolved_in_ui?
|
|
|
|
return @conflicts_can_be_resolved_in_ui if defined?(@conflicts_can_be_resolved_in_ui)
|
|
|
|
|
|
|
|
return @conflicts_can_be_resolved_in_ui = false unless merge_request.cannot_be_merged?
|
|
|
|
return @conflicts_can_be_resolved_in_ui = false unless merge_request.has_complete_diff_refs?
|
|
|
|
return @conflicts_can_be_resolved_in_ui = false if merge_request.branch_missing?
|
|
|
|
|
2018-03-27 19:54:05 +05:30
|
|
|
@conflicts_can_be_resolved_in_ui = conflicts.can_be_resolved_in_ui?
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
def conflicts
|
2018-03-17 18:26:18 +05:30
|
|
|
@conflicts ||= Gitlab::Conflict::FileCollection.new(merge_request)
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|