NAME

Dancer2::Plugin::Syntax::ParamKeywords - Parameter keywords for the lazy

VERSION

version 0.1.0

SYNOPSIS

use Dancer2::Plugin::Syntax::ParamKeywords;

# Sample URL: http://localhost:3000/my_route/baz/blah
get '/my_route/:foo/:bar' => sub {
    my $params = route_params; # Hash::MultiValue object

    # This will show in your app log
    debug "We got us some foo!" if route_param( 'foo' ) eq 'baz';
};

# Sample URL: http://localhost:3000/my_other_route?foo=baz&bar=blah&bar=bah
get '/my_other_route' => sub {
    my $params = query_params; # Hash::MultiValue object

    # This will show in your app log
    debug "We got us some foo!" if query_param( 'foo' ) eq 'baz';

    return join( ',', sort query_params( 'bar' ) ); # returns 'bah, blah'
};

# Sample URL: http://localhost:3000/my_post_route
# Posted data: foo => 'bar', bar => 'baz', bar => 'quux'
post '/my_last_route' => sub {
    my $params = body_params; # Hash::MultiValue object

    # This will show in your app log
    debug "We got us some foo!" if body_param( 'foo' ) eq 'bar';

    return join( ',', sort body_params( 'bar' ) ); # returns 'baz, quux'
};

DESCRIPTION

Let's face it: Dancer2's parameter-fetching keywords take so much typing to use! Why can't they be shorter? Well now, dear reader, they are!

This module provides a little syntactic sugar to make getting query, route, and body parameters just a little bit quicker. Instead of writing these:

query_parameters->get( ... );
query_parameters->get_all( ... );
query_parameters
body_parameters->get( ... );
body_parameters->get_all( ... );
body_parameters
route_parameters->get( ... );
route_parameters

You can write just these:

query_param( ... );
query_params( ... );
query_params
body_param( ... );
body_params( ... );
body_params
route_param( ... );
route_params

That's about 25-50% less typing in many cases. You're welcome.

KEYWORDS

query_param

This is the same as calling query_parameters->get. You must pass a parameter name to get the value of.

query_params

If called without a parameter name, this is just like calling query_parameters. It will return a Hash::MultiValue object containing all of the query parameters that were passed.

When called with a parameter name, this is the same as calling query_parameters->get_all.

body_param

This is the equivalent of body_parameters->get. You must pass a parameter name to get the value of.

body_params

When called without a parameter name, this is the same as calling body_parameters. It will return a Hash::MultiValue object containing all of the body parameters that were posted to your route.

When called with a parameter name, this acts the same as calling body_parameters->get_all.

route_param

This is the equivalent of route_parameters->get. You must pass a parameter name to get.

route_params

When called without a parameter name, this is the equivalent of calling route_parameters. It will return a Hash::MultiValue object containing all of the route parameters that were passed.

Unlike query_params and body_params, you cannot assign multiple values to a single named parameter through route parameters in Dancer2. As such, you cannot pass a parameter to route_params as you can with the other two methods - the underlying get_all functionality for route parameters does not exist.

SEE ALSO

AUTHOR

Jason A. Crome <cromedome@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2021 by Jason A. Crome.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.