Skip to content

class Athena::Framework::Request
inherits Reference #

Wraps an HTTP::Request instance to provide additional functionality.

Forwards all additional methods to the wrapped HTTP::Request instance.

Constants#

FORMATS = {"atom" => Set {"application/atom+xml"}, "css" => Set {"text/css"}, "csv" => Set {"text/csv"}, "form" => Set {"application/x-www-form-urlencoded", "multipart/form-data"}, "html" => Set {"text/html", "application/xhtml+xml"}, "js" => Set {"application/javascript", "application/x-javascript", "text/javascript"}, "json" => Set {"application/json", "application/x-json"}, "jsonld" => Set {"application/ld+json"}, "rdf" => Set {"application/rdf+xml"}, "rss" => Set {"application/rss+xml"}, "txt" => Set {"text/plain"}, "xml" => Set {"text/xml", "application/xml", "application/x-xml"}}#

Represents the supported built in formats; mapping the format name to its valid MIME type(s).

Additional formats may be registered via .register_format.

Constructors#

.new(method : String, path : String, headers : HTTP::Headers | Nil = nil, body : String | Bytes | IO | Nil = nil, version : String = "HTTP/1.1") : self#

.new(request : self) : self#

.new(request : HTTP::Request)#

Class methods#

.mime_types(format : String) : Set(String)#

Returns the MIME types for the provided format.

ATH::Request.mime_types "txt" # => Set{"text/plain"}

.override_trusted_header(header : ATH::Request::ProxyHeader, name : String) : Nil#

Allows overriding the header name to look for off the request for a given ATH::Request::ProxyHeader. In some cases a proxy might not use the exact x-forwarded-* header name.

See the external documentation for more information.

.register_format(format : String, mime_types : Indexable(String)) : Nil#

Registers the provided format with the provided mime_types. Can also be used to change the mime_types supported for an existing format.

ATH::Request.register_format "some_format", {"some/mimetype"}

.set_trusted_hosts(host_patterns : Array(Regex)) : Nil#

Allows setting a list of host_patterns used to whitelist the allowed hostnames of requests. If there is at least one pattern defined, requests whose hostname does NOT match any of the patterns, will receive a 400 response.

See ATH::Bundle:Schema#trusted_hosts for more information.

.set_trusted_proxies(trusted_proxies : Enumerable(String), trusted_header_set : ATH::Request::ProxyHeader) : Nil#

Allows setting a list of trusted_proxies, and which ATH::Request::ProxyHeader should be whitelisted. The provided proxies are expected to be either IPv4 and/or IPv6 addresses. The special "REMOTE_ADDRESS" string is also supported that will map to the current request's remote address.

See the external documentation for more information.

.trusted_header_set : ATH::Request::ProxyHeader#

Returns which ATH::Request::ProxyHeaders have been whitelisted by the application as set via .set_trusted_proxies, defaulting to all of them.

.trusted_host_patterns : Array(Regex)#

Returns the list of trusted host patterns set via .set_trusted_hosts.

.trusted_proxies : Array(String)#

Returns the list of trusted proxy IP addresses as set via .set_trusted_proxies.

Methods#

#action : ATH::ActionBase#

The ATH::Action object associated with this request.

Will only be set if a route was able to be resolved as part of ATH::Listeners::Routing.

#action? : ATH::ActionBase | ::Nil#

The ATH::Action object associated with this request.

Will only be set if a route was able to be resolved as part of ATH::Listeners::Routing.

#attributes : ATH::ParameterBag#

#content_type_format : String | ::Nil#

Returns the Format of the request based on its content-type header, or nil if the header is missing.

#format(mime_type : String) : String | Nil#

Returns the format for the provided mime_type.

request.format "text/plain" # => "txt"

#from_trusted_proxy? : Bool#

Returns true if this request originated from a trusted proxy.

See the external documentation for more information.

#host : String | ::Nil#

Returns the host name the request originated from.

Supports reading from ATH::Request::ProxyHeader::FORWARDED_HOST, falling back on the "host" header.

See the external documentation for more information.

#mime_type(format : String) : String | Nil#

Returns the first MIME type for the provided format if defined, otherwise returns nil.

request.mime_type "txt" # => "text/plain"

#port : Int32#

Returns the port on which the request is made.

Supports reading from both ATH::Request::ProxyHeader::FORWARDED_PORT and ATH::Request::ProxyHeader::FORWARDED_HOST, falling back on the "host" header, then #scheme.

See the external documentation for more information.

ameba:disable Metrics/CyclomaticComplexity

#request : HTTP::Request#

Returns the raw wrapped HTTP::Request instance.

#request_data#

Returns an HTTP::Params instance based on this request's form data body.

#request_format(default : String | Nil = "json") : String | Nil#

Returns the format for this request.

First checks if a format was explicitly set via #request_format=. Next, will check for the _format request #attributes, finally falling back on the provided default.

#request_format=(request_format : String | Nil)#

Sets the #request_format to the explicitly passed format.

#safe? : Bool#

Returns true if this request's #method is safe. Otherwise returns false.

#scheme : String#

Returns the scheme of this request.

#secure? : Bool#

Returns true the request was made over HTTPS, otherwise returns false.

Supports reading from ATH::Request::ProxyHeader::FORWARDED_PROTO.

See the external documentation for more information.