Class: Otto::Security::Authentication::RouteAuthWrapperComponents::ResponseBuilder
- Inherits:
-
Object
- Object
- Otto::Security::Authentication::RouteAuthWrapperComponents::ResponseBuilder
- Defined in:
- lib/otto/security/authentication/route_auth_wrapper/response_builder.rb
Overview
Builds HTTP error responses for authentication/authorization failures
Handles content negotiation (JSON vs HTML) and applies security headers. Route’s declared response_type takes precedence over Accept header.
Instance Method Summary collapse
-
#auth_failure(env, result) ⇒ Array
Generate response for authentication failure.
-
#forbidden(env, message) ⇒ Array
Generate 403 Forbidden response.
-
#initialize(route_definition, auth_config, security_config = nil) ⇒ ResponseBuilder
constructor
A new instance of ResponseBuilder.
-
#unauthorized(env, message) ⇒ Array
Generate 401 Unauthorized response.
Constructor Details
#initialize(route_definition, auth_config, security_config = nil) ⇒ ResponseBuilder
Returns a new instance of ResponseBuilder.
22 23 24 25 26 |
# File 'lib/otto/security/authentication/route_auth_wrapper/response_builder.rb', line 22 def initialize(route_definition, auth_config, security_config = nil) @route_definition = route_definition @auth_config = auth_config @security_config = security_config end |
Instance Method Details
#auth_failure(env, result) ⇒ Array
Generate response for authentication failure
33 34 35 |
# File 'lib/otto/security/authentication/route_auth_wrapper/response_builder.rb', line 33 def auth_failure(env, result) wants_json?(env) ? json_auth_error(result) : html_auth_error(result) end |
#forbidden(env, message) ⇒ Array
Generate 403 Forbidden response
55 56 57 58 59 60 61 |
# File 'lib/otto/security/authentication/route_auth_wrapper/response_builder.rb', line 55 def forbidden(env, ) if wants_json?(env) json_response(403, error: 'Forbidden', message: ) else text_response(403, ) end end |
#unauthorized(env, message) ⇒ Array
Generate 401 Unauthorized response
42 43 44 45 46 47 48 |
# File 'lib/otto/security/authentication/route_auth_wrapper/response_builder.rb', line 42 def (env, ) if wants_json?(env) json_response(401, error: ) else text_response(401, ) end end |