# NAME Dancer::Plugin::Chain - Chained actions for Dancer # VERSION version 0.1.1 # SYNOPSIS ```perl use Dancer; use Dancer::Plugin::Chain; my $country = chain '/country/:country' => sub { # silly example. Typically much more work would # go on in here var 'site' => param('country'); }; my $event = chain '/event/:event' => sub { var 'event' => param('event'); }; # will match /country/usa/event/yapc get chain $country, $event, '/schedule' => sub { return sprintf "schedule of %s in %s\n", map { var $_ } qw/ event site /; }; my $continent = chain '/continent/:continent' => sub { var 'site' => param('continent'); }; my $continent_event = chain $continent, $event; # will match /continent/europe/event/yapc get chain $continent_event, '/schedule' => sub { return sprintf "schedule of %s in %s\n", map { var $_ } qw/ event site /; }; # will match /continent/asia/country/japan/event/yapc # and will do special munging in-between! get chain $continent, sub { var temp => var 'site' }, $country, sub { var 'site' => join ', ', map { var $_ } qw/ site temp / }, $event, '/schedule' => sub { return sprintf "schedule of %s in %s\n", map { var $_ } qw/ event site /; }; ``` # DESCRIPTION Implementation of Catalyst-like chained routes. This kind of behavior can usually be fulfilled by judicious uses of `prefix`. But hey, diversity is the spice of life, so there you go. The plugin exports a single keyword, `chain`, which creates the chained routes. ## KNOWN CAVEATS The plugin only support string-based urls for now (so no regexes). # EXPORTED FUNCTIONS ## chain @chain\_items, $coderef Create a chain out of the items provided, and assign it the final action coderef. Each chain item can be a string representing a path segment, a previously defined chain or an anonymous function. The chain's final path and action will be the aggregate of its parts. For example, the final route declaration of the SYNOPSIS, ```perl get chain $continent, sub { var temp => var 'site' }, $country, sub { var 'site' => join ', ', map { var $_ } qw/ site temp / }, $event, '/schedule' => sub { return sprintf "schedule of %s in %s\n", map { var $_ } qw/ event site /; }; ``` would be is equivalent to ```perl get '/continent/:continent/country/:country/event/:event/schedule' => sub { var 'site' => param('continent'); var temp => var 'site'; var 'site' => param('country'); var 'site' => join ', ', map { var $_ } qw/ site temp / var 'event' => param('event'); return sprintf "schedule of %s in %s\n", map { var $_ } qw/ event site /; } ``` In scalar context, `chain` returns its underlying object. In list context, it returns a route / action pair of values (). That's how it can work transparently with `get`, `post` and friends. ```perl # returns the object, that can be used to forge longer chains. my $foo_chain = chain '/foo', sub { ... }; # returns the pair that makes 'get' happy get chain $foo_chain; ``` # SEE ALSO - Original blog entry: [http://techblog.babyl.ca/entry/dancer-in-chains](http://techblog.babyl.ca/entry/dancer-in-chains) - [Dancer-Plugin-Dispatcher](https://metacpan.org/pod/Dancer-Plugin-Dispatcher) # AUTHOR Yanick Champoux <yanick@cpan.org> [![endorse](http://api.coderwall.com/yanick/endorsecount.png)](http://coderwall.com/yanick) # COPYRIGHT AND LICENSE This software is copyright (c) 2017, 2014 by Yanick Champoux. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.