struct Athena::Framework::Controller::ValueResolvers::QueryParameter
inherits Struct
#
Attempts to resolve the value from the request's query parameters for any parameter with the ATHA::MapQueryParameter
annotation.
Supports most primitive types, as well as arrays of most primitive types, and enums.
The name of the query parameter is assumed to be the same as the controller action parameter's name.
This can be customized via the name
field on the annotation.
If the controller action parameter is not-nilable nor has a default value and is missing, an ATH::Exception::NotFound
exception will be raised by default.
Similarly, an exception will be raised if the value fails to be converted to the expected type.
The specific type of exception can be customized via the validation_failed_status
field on the annotation.
require "athena"
enum Color
Red
Green
Blue
end
class ExampleController < ATH::Controller
@[ARTA::Get("/")]
def index(
@[ATHA::MapQueryParameter] ids : Array(Int32),
@[ATHA::MapQueryParameter(name: "firstName")] first_name : String,
@[ATHA::MapQueryParameter] required : Bool,
@[ATHA::MapQueryParameter] age : Int32,
@[ATHA::MapQueryParameter] color : Color,
@[ATHA::MapQueryParameter] category : String = "",
@[ATHA::MapQueryParameter] theme : String? = nil,
) : Nil
ids # => [1, 2]
first_name # => "Jon"
required # => false
age # => 123
color # => Color::Blue
category # => ""
theme # => nil
end
end
ATH.run
# GET /?ids=1&ids=2&firstName=Jon&required=false&age=123&color=blue
Included modules
Athena::Framework::Controller::ValueResolvers::Interface
Constructors#
.new
#
Methods#
#initialize
#
#resolve(request : ATH::Request, parameter : ATH::Controller::ParameterMetadata)
#
Returns a value resolved from the provided request and parameter if possible, otherwise returns nil
if no parameter could be resolved.