thelia / re-captcha-module
This module allows you to add easily a reCAPTCHA to your form
Installs: 20 362
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 6
Forks: 8
Open Issues: 1
Type:thelia-module
Requires
- thelia/installer: ~1.1
README
This module allows you to add easily a reCAPTCHA to your form
Installation
Composer
Add it in your main thelia composer.json file
composer require thelia/re-captcha-module:~2.0.0
Usage
Before using this module you have to create google api key here http://www.google.com/recaptcha/admin
next configure your reCAPTCHA access here http://your_site.com/admin/module/ReCaptcha
with keys you obtained in Google's page
and choose which style of captcha you want :
Then you'll need help from a developer to add some hooks in template and dispatch the check events, see details below.
Hook
First if you don't have {hook name="main.head-top"}
hook in your template you have to put this hook {hook name="recaptcha.js"}
in the top of your head
Then add this hook {hook name="recaptcha.check"}
in every form where you want to check if the user is human,
be careful if you want to use the invisible captcha this hook must be placed directly in the form tag like this :
<form id="form-contact" action="{url path="/contact"}" method="post">
{hook name="recaptcha.check"}
// End of the form
</form>
Event
To check in server-side if the captcha is valid you have to dispatch the "CHECK_CAPTCHA_EVENT" like this :
$checkCaptchaEvent = new ReCaptchaCheckEvent();
$eventDispatcher->dispatch($checkCaptchaEvent, ReCaptchaEvents::CHECK_CAPTCHA_EVENT);
Then the result of check is available in $checkCaptchaEvent->isHuman()
as boolean so you can do a test like this :
if ($checkCaptchaEvent->isHuman() == false) {
throw new \Exception('Invalid captcha');
}
Don't forget to add this use at the top of your class :
use ReCaptcha\Event\ReCaptchaCheckEvent;
use ReCaptcha\Event\ReCaptchaEvents;