Class: OpenapiFirst::Failure

Inherits:
Object
  • Object
show all
Defined in:
lib/openapi_first/failure.rb

Overview

A failure object returned when validation or parsing of a request or response has failed. This returned in ValidatedRequest#error and ValidatedResponse#error.

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.fail!(type, message: nil, errors: nil) ⇒ Object

Parameters:



25
26
27
28
29
30
31
# File 'lib/openapi_first/failure.rb', line 25

def self.fail!(type, message: nil, errors: nil)
  throw FAILURE, new(
    type,
    message:,
    errors:
  )
end

.new(type, message: nil, errors: nil) ⇒ Object

Parameters:



36
37
38
39
40
41
42
# File 'lib/openapi_first/failure.rb', line 36

def self.new(type, message: nil, errors: nil)
  unless TYPES.key?(type)
    raise ArgumentError,
          "type must be one of #{TYPES.keys} but was #{type.inspect}"
  end
  super(type:, message:, errors:)
end

Instance Method Details

#errors([Array<OpenapiFirst: :Schema::ValidationError>, nil]) ⇒ Object



49
# File 'lib/openapi_first/failure.rb', line 49

alias original_message message

#exception(context = nil) ⇒ Object



57
58
59
# File 'lib/openapi_first/failure.rb', line 57

def exception(context = nil)
  TYPES.fetch(type).first.new(exception_message, context)
end

#exception_messageObject



61
62
63
64
65
# File 'lib/openapi_first/failure.rb', line 61

def exception_message
  _, message_prefix = TYPES.fetch(type)

  [message_prefix, original_message || generate_message].compact.join(' ')
end

#messageObject

A generic error message



53
54
55
# File 'lib/openapi_first/failure.rb', line 53

def message
  original_message || exception_message
end

#type([Symbol]) ⇒ Object

Example: :invalid_body



# File 'lib/openapi_first/failure.rb', line 44