Skip to content

struct Athena::Framework::Controller::ValueResolvers::Time
inherits Struct #

Attempts to parse a date(time) string into a ::Time instance.

Optionally allows specifying the format and location to use when parsing the string via the ATHA::MapTime annotation. If no format is specified, defaults to RFC 3339. Defaults to UTC if no location is specified with the annotation.

Raises an ATH::Exception::BadRequest if the date(time) string could not be parsed.

Tip

The format can be anything supported via Time::Format.

require "athena"

class ExampleController < ATH::Controller
  @[ARTA::Get(path: "/event/{start_time}/{end_time}")]
  def event(
    @[ATHA::MapTime("%F", location: Time::Location.load("Europe/Berlin"))]
    start_time : Time,
    end_time : Time,
  ) : Nil
    start_time # => 2020-04-07 00:00:00.0 +02:00 Europe/Berlin
    end_time   # => 2020-04-08 12:34:56.0 UTC
  end
end

ATH.run

# GET /event/2020-04-07/2020-04-08T12:34:56Z

Included modules

Athena::Framework::Controller::ValueResolvers::Interface

Constructors#

.new#

Methods#

#initialize#

#resolve(request : ATH::Request, parameter : ATH::Controller::ParameterMetadata) : ::Time | Nil#

Returns a value resolved from the provided request and parameter if possible, otherwise returns nil if no parameter could be resolved.