HTTP::Router - Yet Another Path Router for HTTP
use HTTP::Router;
my $router = HTTP::Router->new;
my $route = HTTP::Router::Route->new(
path => '/',
conditions => { method => 'GET' },
params => { controller => 'Root', action => 'index' },
);
$router->add_route($route);
# or
$router->add_route('/' => (
conditions => { method => 'GET' },
params => { controller => 'Root', action => 'index' },
));
# GET /
my $match = $router->match($req);
$match->params; # { controller => 'Root', action => 'index' }
$match->uri_for; # '/'
HTTP::Router provides a way of constructing routing tables.
If you are interested in a Merb-like constructing way, please check HTTP::Router::Declare.
Returns a HTTP::Router object.
Adds a new route. You can specify HTTP::Router::Route object, or path string and options pair.
example:
my $route = HTTP::Router::Route->new(
path => '/',
conditions => { method => 'GET' },
params => { controller => 'Root', action => 'index' },
);
$router->add_route($route);
equals to:
$router->add_route('/' => (
conditions => { method => 'GET' },
params => { controller => 'Root', action => 'index' },
));
Returns registered routes.
Clears registered routes.
Creates inline matcher using registered routes.
Clears inline matcher.
Returns true if inline matcher is defined.
Returns a HTTP::Router::Match object that matches a given request. If no routes match, it returns undef
.
Returns a HTTP::Router::Route object that matches a given request. If no routes match, it returns undef
.
NAKAGAWA Masaki <[email protected]>
Takatoshi Kitano <[email protected]>
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
HTTP::Router::Declare, HTTP::Router::Route, HTTP::Router::Match,
MojoX::Routes, http://merbivore.com/, HTTPx::Dispatcher, Path::Router, Path::Dispatcher