NAME
HTTP::Router - Yet Another Path Router for HTTP
SYNOPSIS
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; # '/'
DESCRIPTION
HTTP::Router provides a way of constructing routing tables.
If you are interested in a Merb-like constructing way, please check HTTP::Router::Declare.
METHODS
new
Returns a HTTP::Router object.
add_route($route)
add_route($path, %args)
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' },
));
routes
Returns registered routes.
reset
Clears registered routes.
freeze
Creates inline matcher using registered routes.
thaw
Clears inline matcher.
is_frozen
Returns true if inline matcher is defined.
match($req)
Returns a HTTP::Router::Match object that matches a given request. If no routes match, it returns undef
.
route_for($req)
Returns a HTTP::Router::Route object that matches a given request. If no routes match, it returns undef
.
AUTHOR
NAKAGAWA Masaki <masaki@cpan.org>
Takatoshi Kitano <kitano.tk@gmail.com>
LICENSE
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
SEE ALSO
HTTP::Router::Declare, HTTP::Router::Route, HTTP::Router::Match,
MojoX::Routes, http://merbivore.com/, HTTPx::Dispatcher, Path::Router, Path::Dispatcher