NAME
Dancer::Plugin::reCAPTCHA - Easily integrate reCAPTCHA into your Dancer applications
VERSION
version 0.10
SYNOPSIS
# In your config.yml
plugins:
reCAPTCHA:
public_key: "public key goes here"
private_key: "private key goes here"
theme: "dark"
type: "image"
size: "normal"
# In your Dancer app...
use Dancer::Plugin::reCAPTCHA;
# In your form display route...
return template 'accounts/create', {
recaptcha => recaptcha_display(),
};
# In your template (TT2)
[% recaptcha %]
# In your validation code....
my $response = param( 'recaptcha_response_field' );
my $result = recaptcha_check( $response );
die "User didn't match the CAPTCHA" unless $result->{ success };
METHODS
recaptcha_display()
Generates the HTML needed to display the CAPTCHA. This HTML is returned as a scalar value, and can easily be plugged into the template system of your choice.
Using Template Toolkit as an example, this might look like:
# Code
return template 'accounts/create', {
recaptcha => recaptcha_display(),
};
# In your accounts/create template
[% recaptcha %]
recaptcha_check()
Verify that the value the user entered matches what's in the CAPTCHA. This methods takes an argument that is the response string. These are returned to your Dancer application as the parameter g-recaptcha-response .
For example:
my $response = param( 'g-recaptcha-response' );
my $result = recaptcha_check( $response );
die "User didn't match the CAPTCHA" unless $result->{ success };
See Captcha::reCAPTCHA::V2 for a description of the result hash.
TODO
Add a real test suite.
CREDITS
The following people have contributes to Dancer::Plugin::reCAPTCHA
in some way, either through bug reports, code, suggestions, or moral support:
Mohammad S Anwar Shawn Sorichetti
SEE ALSO
AUTHOR
Jason A. Crome <cromedome@gmail.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 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.