NAME
OX::Application::Role::Request - application role to allow the use of request and response objects
VERSION
version 0.12
SYNOPSIS
package MyApp;
use Moose;
extends 'OX::Application';
with 'OX::Application::Role::Request';
sub build_app {
my $self = shift;
return sub {
my $env = shift;
my $r = $self->new_request($env);
return $self->handle_response(
MyApp::Controller->new->do_action($r), $r
);
};
}
DESCRIPTION
This role provides some helper methods for handling request and response objects in your application.
METHODS
request_class
This method can be overridden to provide your own custom request class. Defaults to OX::Request.
This request class is expected to provide a new_response
method, so overriding the response class to use can be done by overriding this method in your request class.
new_request($env)
Creates a new instance of the request class for the given PSGI environment.
handle_response($response, $request)
Takes a response provided by the application and turns it into a proper PSGI response arrayref. The default implementation of this method handles bare strings (turns them into a response with a code of 200 and a Content-Type
header of text/html
) and anything which can be provided to the new_response
method of the request object. $request
must be passed in addition to the actual response that was received in order to be able to call new_response
.
AUTHORS
Stevan Little <stevan.little@iinteractive.com>
Jesse Luehrs <doy@tozt.net>
COPYRIGHT AND LICENSE
This software is copyright (c) 2013 by Infinity Interactive.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.