File: merge_request_user_entity.rb

package info (click to toggle)
gitlab 17.6.5-19
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 629,368 kB
  • sloc: ruby: 1,915,304; javascript: 557,307; sql: 60,639; xml: 6,509; sh: 4,567; makefile: 1,239; python: 406
file content (34 lines) | stat: -rw-r--r-- 1,131 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
# frozen_string_literal: true

class MergeRequestUserEntity < ::API::Entities::UserBasic
  include UserStatusTooltip
  include RequestAwareEntity

  def self.satisfies(*methods)
    ->(_, options) { methods.all? { |m| options[:merge_request].try(m) } }
  end

  expose :can_merge do |reviewer, options|
    options[:merge_request]&.can_be_merged_by?(reviewer)
  end

  expose :can_update_merge_request do |reviewer, options|
    request.current_user&.can?(:update_merge_request, options[:merge_request])
  end

  expose :reviewed, if: satisfies(:present?, :allows_reviewers?) do |user, options|
    options[:merge_request].find_reviewer(user)&.reviewed?
  end

  expose :approved, if: satisfies(:present?) do |user, options|
    # This approach is preferred over MergeRequest#approved_by? since this
    # makes one query per merge request, whereas #approved_by? makes one per user
    options[:merge_request].approvals.any? { |app| app.user_id == user.id }
  end

  expose :suggested, if: satisfies(:present?) do |user, options|
    options[:suggested]
  end
end

MergeRequestUserEntity.prepend_mod_with('MergeRequestUserEntity')