debian-mirror-gitlab/app/serializers/diff_file_base_entity.rb

119 lines
3.2 KiB
Ruby
Raw Normal View History

2019-02-15 15:39:39 +05:30
# frozen_string_literal: true
class DiffFileBaseEntity < Grape::Entity
include RequestAwareEntity
include BlobHelper
include DiffHelper
include TreeHelper
include ChecksCollaboration
include Gitlab::Utils::StrongMemoize
expose :content_sha
expose :submodule?, as: :submodule
2019-09-30 21:07:59 +05:30
expose :submodule_link do |diff_file, options|
memoized_submodule_links(diff_file, options).first
2019-02-15 15:39:39 +05:30
end
expose :submodule_tree_url do |diff_file|
2019-09-30 21:07:59 +05:30
memoized_submodule_links(diff_file, options).last
2019-02-15 15:39:39 +05:30
end
expose :edit_path, if: -> (_, options) { options[:merge_request] } do |diff_file|
merge_request = options[:merge_request]
2020-05-24 23:13:21 +05:30
next unless merge_request.merged? || merge_request.source_branch_exists?
2019-02-15 15:39:39 +05:30
2020-05-24 23:13:21 +05:30
target_project, target_branch = edit_project_branch_options(merge_request)
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
options = merge_request.persisted? && merge_request.source_branch_exists? && !merge_request.merged? ? { from_merge_request_iid: merge_request.iid } : {}
2020-05-24 23:13:21 +05:30
2020-07-28 23:09:34 +05:30
project_edit_blob_path(target_project, tree_join(target_branch, diff_file.new_path), options)
2019-02-15 15:39:39 +05:30
end
expose :old_path_html do |diff_file|
old_path, _ = mark_inline_diffs(diff_file.old_path, diff_file.new_path)
old_path
end
expose :new_path_html do |diff_file|
_, new_path = mark_inline_diffs(diff_file.old_path, diff_file.new_path)
new_path
end
expose :formatted_external_url, if: -> (_, options) { options[:environment] } do |diff_file|
options[:environment].formatted_external_url
end
expose :external_url, if: -> (_, options) { options[:environment] } do |diff_file|
options[:environment].external_url_for(diff_file.new_path, diff_file.content_sha)
end
expose :blob, using: BlobEntity
expose :can_modify_blob do |diff_file|
merge_request = options[:merge_request]
next unless diff_file.blob
if merge_request&.source_project && current_user
2020-05-24 23:13:21 +05:30
can_modify_blob?(diff_file.blob, merge_request.source_project, merge_request.source_branch_exists? ? merge_request.source_branch : merge_request.target_branch)
2019-02-15 15:39:39 +05:30
else
false
end
end
2020-06-23 00:09:42 +05:30
expose :file_identifier_hash
expose :file_hash
2019-02-15 15:39:39 +05:30
expose :file_path
expose :old_path
expose :new_path
expose :new_file?, as: :new_file
2019-07-07 11:18:12 +05:30
expose :renamed_file?, as: :renamed_file
expose :deleted_file?, as: :deleted_file
2019-02-15 15:39:39 +05:30
expose :diff_refs
2019-07-07 11:18:12 +05:30
2019-02-15 15:39:39 +05:30
expose :stored_externally?, as: :stored_externally
expose :external_storage
2019-07-07 11:18:12 +05:30
2019-02-15 15:39:39 +05:30
expose :mode_changed?, as: :mode_changed
expose :a_mode
expose :b_mode
2019-07-07 11:18:12 +05:30
expose :viewer, using: DiffViewerEntity
2020-05-24 23:13:21 +05:30
expose :alternate_viewer, using: DiffViewerEntity
2019-07-07 11:18:12 +05:30
2019-12-26 22:10:19 +05:30
expose :old_size do |diff_file|
diff_file.old_blob&.raw_size
end
expose :new_size do |diff_file|
diff_file.new_blob&.raw_size
end
2019-02-15 15:39:39 +05:30
private
2019-09-30 21:07:59 +05:30
def memoized_submodule_links(diff_file, options)
2019-02-15 15:39:39 +05:30
strong_memoize(:submodule_links) do
if diff_file.submodule?
2019-09-30 21:07:59 +05:30
options[:submodule_links].for(diff_file.blob, diff_file.content_sha)
2019-02-15 15:39:39 +05:30
else
[]
end
end
end
def current_user
request.current_user
end
2020-05-24 23:13:21 +05:30
def edit_project_branch_options(merge_request)
if merge_request.source_branch_exists? && !merge_request.merged?
[merge_request.source_project, merge_request.source_branch]
else
[merge_request.target_project, merge_request.target_branch]
end
end
2019-02-15 15:39:39 +05:30
end