Files
gitlab-foss/lib/gitlab/graphql/authorize/object_authorization.rb
2024-09-09 12:12:45 +00:00

46 lines
1.1 KiB
Ruby

# frozen_string_literal: true
module Gitlab
module Graphql
module Authorize
class ObjectAuthorization
include ::Gitlab::Allowable
attr_reader :abilities, :permitted_scopes
def initialize(abilities, scopes = %i[api read_api])
@abilities = Array.wrap(abilities).flatten
@permitted_scopes = Array.wrap(scopes)
end
def none?
abilities.empty?
end
def any?
abilities.present?
end
def ok?(object, current_user, scope_validator:, skip_abilities: nil)
scopes_ok?(scope_validator) && abilities_ok?(object, current_user, skip_abilities: skip_abilities)
end
private
def abilities_ok?(object, current_user, skip_abilities: nil)
return true if none?
subject = object.try(:declarative_policy_subject) || object
can_all?(current_user, abilities - Array.wrap(skip_abilities).flatten, subject)
end
def scopes_ok?(validator)
return true unless validator.present?
validator.valid_for?(permitted_scopes)
end
end
end
end
end