Added optional captcha

This commit is contained in:
Flavio Copes 2015-10-07 20:18:44 +02:00
parent d3438f190f
commit c0a003ccda
3 changed files with 55 additions and 2 deletions

View File

@ -68,6 +68,21 @@ class CommentsPlugin extends Plugin
$email = filter_var(urldecode($post['email']), FILTER_SANITIZE_STRING);
$title = filter_var(urldecode($post['title']), FILTER_SANITIZE_STRING);
if ($this->config->get('plugins.comments.use_captcha')) {
//Validate the captcha
$recaptchaResponse = filter_var(urldecode($post['recaptchaResponse']), FILTER_SANITIZE_STRING);
$url = 'https://www.google.com/recaptcha/api/siteverify?secret=';
$url .= $this->config->get('plugins.comments.recatpcha_secret');
$url .= '&response=' . $recaptchaResponse;
$response = json_decode(file_get_contents($url), true);
if ($response['success'] == false) {
throw new \RuntimeException('Error validating the Captcha');
}
}
$filename = DATA_DIR . 'comments';
$filename .= ($lang ? '/' . $lang : '');
$filename .= $path . '.yaml';

View File

@ -1 +1,4 @@
enabled: true
use_captcha: true
recatpcha_site_key: '6Lde4gwTAAAAAAZuv4z2AgVU6Xamn5twDYzQr8hv'
recatpcha_secret: '6Lde4gwTAAAAAPpwVKuaYm53n2bWfFfxcDxSlI54'

View File

@ -1,3 +1,5 @@
{% set use_captcha = grav.config.plugins.comments.use_captcha %}
<h3>Add a Comment</h3>
<script>
@ -12,6 +14,7 @@ jQuery(document).on('click tap', '.js__add-new-comment', function(event) {
var text = $('.js__new-comment-text').val();
var name = $('.js__new-comment-name').val();
var email = $('.js__new-comment-email').val();
var captcha = $('#g-recaptcha-response').val();
if (text.length == 0 || email.length == 0 || name.length == 0) {
alert('Please fill all the fields');
@ -23,6 +26,13 @@ jQuery(document).on('click tap', '.js__add-new-comment', function(event) {
return;
}
{% if use_captcha %}
if (!captcha) {
alert("Error validating the security code");
return;
}
{% endif %}
jQuery.ajax({
url: "{{ grav.uri.rootUrl }}/add-comment",
data: {
@ -31,7 +41,8 @@ jQuery(document).on('click tap', '.js__add-new-comment', function(event) {
email: $('.js__new-comment-email').val(),
title: "{{ grav.page.header.title }}",
lang: "{{ grav.language.getActive }}",
path: "{{ grav.uri.path }}"
path: "{{ grav.uri.path }}",
{% if use_captcha %}recaptchaResponse: captcha{% endif %}
},
type: 'POST'
})
@ -39,15 +50,39 @@ jQuery(document).on('click tap', '.js__add-new-comment', function(event) {
window.location.reload();
})
.error(function() {
alert("Error while posting the comment");
});
});
</script>
{% if use_captcha %}
<script src="https://www.google.com/recaptcha/api.js?onload=captchaOnloadCallback&render=explicit" async defer></script>
<script>
var captchaOnloadCallback = function captchaOnloadCallback() {
grecaptcha.render('g-recaptcha', {
'sitekey': "{{grav.config.plugins.comments.recatpcha_site_key}}",
'callback': captchaValidatedCallback,
'expired-callback': captchaExpiredCallback
});
}
var captchaValidatedCallback = function captchaValidatedCallback() {
};
var captchaExpiredCallback = function captchaExpiredCallback() {
grecaptcha.reset();
};
</script>
{% endif %}
<form>
<textarea class="js__new-comment-text"></textarea>
Name: <input type="text" class="js__new-comment-name" />
Email: <input type="email" class="js__new-comment-email" />
{% if use_captcha %}
<div class="g-recaptcha" id="g-recaptcha"></div>
{% endif %}
<input type="submit" class="js__add-new-comment" />
</form>