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

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

67 lines
1.7 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
2018-11-08 19:23:39 +05:30
class MergeRequestDiffEntity < Grape::Entity
include Gitlab::Routing
include GitHelper
include MergeRequestsHelper
expose :version_index do |merge_request_diff|
2021-09-04 01:27:46 +05:30
merge_request_diffs = options[:merge_request_diffs]
2018-11-08 19:23:39 +05:30
diff = options[:merge_request_diff]
2021-09-04 01:27:46 +05:30
next unless merge_request_diffs.include?(diff)
next unless merge_request_diffs.size > 1
2018-11-08 19:23:39 +05:30
2021-09-04 01:27:46 +05:30
merge_request_diffs.size - merge_request_diffs.index(merge_request_diff)
2018-11-08 19:23:39 +05:30
end
expose :created_at
expose :commits_count
expose :latest?, as: :latest
expose :short_commit_sha do |merge_request_diff|
2019-12-26 22:10:19 +05:30
next unless merge_request_diff.head_commit_sha
2018-11-08 19:23:39 +05:30
short_sha(merge_request_diff.head_commit_sha)
end
2019-03-02 22:35:43 +05:30
expose :base_version_path do |merge_request_diff|
project = merge_request.target_project
next unless project
merge_request_version_path(project, merge_request, merge_request_diff)
end
2020-03-13 15:44:24 +05:30
expose :head_version_path do |merge_request_diff|
project = merge_request.target_project
next unless project && merge_request.diffable_merge_ref?
diffs_project_merge_request_path(project, merge_request, diff_head: true)
end
2018-11-08 19:23:39 +05:30
expose :version_path do |merge_request_diff|
start_sha = options[:start_sha]
project = merge_request.target_project
next unless project
merge_request_version_path(project, merge_request, merge_request_diff, start_sha)
end
expose :compare_path do |merge_request_diff|
project = merge_request.target_project
diff = options[:merge_request_diff]
if project && diff
merge_request_version_path(project, merge_request, diff, merge_request_diff.head_commit_sha)
end
end
def merge_request
options[:merge_request]
end
end