NAME
OX::RouteBuilder::REST - OX::RouteBuilder which routes to an action method in a controller class based on HTTP verbs
VERSION
version 0.001
SYNOPSIS
package MyApp;
use OX;
use OX::RouteBuilder::REST;
has thing => (
is => 'ro',
isa => 'MyApp::Controller::Thing',
);
router [map {'OX::RouteBuilder::'.$_} qw(ControllerAction Code HTTPMethod REST )] => as {
route '/thing' => 'REST.thing.root';
route '/thing/:id' => 'REST.thing.item';
};
package MyApp::Controller::Thing;
use Moose;
sub root_GET {
my ($self, $req) = @_;
... # return a list if things
}
sub root_PUT {
my ($self, $req) = @_;
... # create a new thing
}
sub item_GET {
my ($self, $req, $id) = @_;
... # view a thing
}
sub item_POST {
my ($self, $req, $id) = @_;
... # update a thing
}
DESCRIPTION
This is an OX::RouteBuilder which routes to an action method in a controller class based on HTTP verbs. It's a bit of a mixture between OX::RouteBuilder::ControllerAction and OX::RouteBuilder::HTTPMethod.
The action_spec
should be a string in the form "REST.$controller.$action"
, where $controller
is the name of a service which provides a controller instance. For each HTTP verb you want to support you will need to set up an action with the name $action_$verb
(e.g. $action_GET
, $action_PUT
, etc). If no matching action-verb-method is found, a 404 error will be returned.
controller
and action
will also be automatically added as defaults for the route, as well as name
(which will be set to "REST.$controller.$action"
).
To generate a link to an action, use uri_for
with either the name (eg "REST.$controller.$action"
), or by passing a HashRef { controller =
$controller, action => $action }>. See t/test.t for some examples.
Please note that due to some constrains how OX::RouteBuilder are loaded in OX
, you have to manually load all relevant RouteBuilders
when specifiying the routes
:
router [ map
{'OX::RouteBuilder::'.$_}
qw(ControllerAction Code HTTPMethod REST )
] => as {
route '/thing' => 'REST.thing.root';
};
AUTHORS
Thomas Klausner <domm@cpan.org>
Validad GmbH http://validad.com
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Thomas Klausner.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.