Sha256: 2d329e7f37b3500f28e126b931e0ec91342b34a6090171a336693d7449eb93ae

Contents?: true

Size: 1.05 KB

Versions: 7

Compression:

Stored size: 1.05 KB

Contents

# frozen_string_literal: true
module GraphQL
  # When an `authorized?` hook returns false, this error is used to communicate the failure.
  # It's passed to {Schema.unauthorized_object}.
  #
  # Alternatively, custom code in `authorized?` may raise this error. It will be routed the same way.
  class UnauthorizedError < GraphQL::Error
    # @return [Object] the application object that failed the authorization check
    attr_reader :object

    # @return [Class] the GraphQL object type whose `.authorized?` method was called (and returned false)
    attr_reader :type

    # @return [GraphQL::Query::Context] the context for the current query
    attr_reader :context

    def initialize(message = nil, object: nil, type: nil, context: nil)
      if message.nil? && object.nil?
        raise ArgumentError, "#{self.class.name} requires either a message or keywords"
      end

      @object = object
      @type = type
      @context = context
      message ||= "An instance of #{object.class} failed #{type.name}'s authorization check"
      super(message)
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
graphql-1.9.2 lib/graphql/unauthorized_error.rb
graphql-1.9.1 lib/graphql/unauthorized_error.rb
graphql-1.9.0 lib/graphql/unauthorized_error.rb
graphql-1.9.0.pre4 lib/graphql/unauthorized_error.rb
graphql-1.9.0.pre3 lib/graphql/unauthorized_error.rb
graphql-1.9.0.pre2 lib/graphql/unauthorized_error.rb
graphql-1.9.0.pre1 lib/graphql/unauthorized_error.rb