forked from extern/egroupware
Implement google recaptcha for sitemanager forms
This commit is contained in:
parent
9be947e49b
commit
3905891e7b
@ -69,7 +69,9 @@ class addressbook_contactform
|
|||||||
// check if submitted
|
// check if submitted
|
||||||
if (is_array($content))
|
if (is_array($content))
|
||||||
{
|
{
|
||||||
if ((isset($content['captcha_result']) && $content['captcha'] != $content['captcha_result']) || // no correct captcha OR
|
if (isset($_POST['g-recaptcha-response'])) $recaptcha = sitemgr_module::verify_recaptcha ($_POST['g-recaptcha-response']);
|
||||||
|
$captcha = (isset($content['captcha_result']) && $content['captcha'] != $content['captcha_result']) || ($recaptcha && $recaptcha->success == false);
|
||||||
|
if ($captcha || // no correct captcha OR
|
||||||
(time() - $content['start_time'] < 10 && // bot indicator (less then 10 sec to fill out the form and
|
(time() - $content['start_time'] < 10 && // bot indicator (less then 10 sec to fill out the form and
|
||||||
!$GLOBALS['egw_info']['etemplate']['java_script'])) // javascript disabled)
|
!$GLOBALS['egw_info']['etemplate']['java_script'])) // javascript disabled)
|
||||||
{
|
{
|
||||||
@ -202,20 +204,28 @@ class addressbook_contactform
|
|||||||
|
|
||||||
if ($addressbook) $preserv['owner'] = $addressbook;
|
if ($addressbook) $preserv['owner'] = $addressbook;
|
||||||
if ($msg) $preserv['msg'] = $msg;
|
if ($msg) $preserv['msg'] = $msg;
|
||||||
|
if (!sitemgr_module::get_recaptcha())
|
||||||
// a simple calculation captcha
|
|
||||||
$num1 = rand(1,99);
|
|
||||||
$num2 = rand(1,99);
|
|
||||||
if ($num2 > $num1) // keep the result positive
|
|
||||||
{
|
{
|
||||||
$n = $num1; $num1 = $num2; $num2 = $n;
|
// a simple calculation captcha
|
||||||
|
$num1 = rand(1,99);
|
||||||
|
$num2 = rand(1,99);
|
||||||
|
if ($num2 > $num1) // keep the result positive
|
||||||
|
{
|
||||||
|
$n = $num1; $num1 = $num2; $num2 = $n;
|
||||||
|
}
|
||||||
|
if (in_array('captcha',$fields))
|
||||||
|
{
|
||||||
|
$content['captcha_task'] = sprintf('%d - %d =',$num1,$num2);
|
||||||
|
$preserv['captcha_result'] = $num1-$num2;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (in_array('captcha',$fields))
|
else
|
||||||
{
|
{
|
||||||
$content['captcha_task'] = sprintf('%d - %d =',$num1,$num2);
|
$content['show']['captcha'] = false;
|
||||||
$preserv['captcha_result'] = $num1-$num2;
|
$content['show']['recaptcha'] = true;
|
||||||
|
$recaptcha = sitemgr_module::get_recaptcha();
|
||||||
|
$content['recaptcha'] = '<div class="g-recaptcha" data-sitekey="'.$recaptcha['site'].'"></div>';
|
||||||
}
|
}
|
||||||
|
|
||||||
// allow to preset variables via get parameters
|
// allow to preset variables via get parameters
|
||||||
if ($_SERVER['REQUEST_METHOD'] == 'GET')
|
if ($_SERVER['REQUEST_METHOD'] == 'GET')
|
||||||
{
|
{
|
||||||
|
@ -34,6 +34,20 @@ class module_addressbook_contactform extends sitemgr_module
|
|||||||
$this->etemplate_method = 'addressbook.addressbook_contactform.display';
|
$this->etemplate_method = 'addressbook.addressbook_contactform.display';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function get_content (&$arguments,$properties)
|
||||||
|
{
|
||||||
|
$parent = parent::get_content($arguments, $properties);
|
||||||
|
|
||||||
|
//Make sure that recaptcha keys are set before include it
|
||||||
|
if (($recaptcha = sitemgr_module::get_recaptcha()))
|
||||||
|
{
|
||||||
|
$extra .= '<script src="https://www.google.com/recaptcha/api.js" type="text/javascript"></script>'."\n";
|
||||||
|
return $extra.$parent;
|
||||||
|
}
|
||||||
|
// fallback to basic captcha
|
||||||
|
return $parent;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Reimplemented to add the addressbook translations and fetch the addressbooks only if needed for the user-interface
|
* Reimplemented to add the addressbook translations and fetch the addressbooks only if needed for the user-interface
|
||||||
*
|
*
|
||||||
|
@ -129,6 +129,11 @@
|
|||||||
<row disabled="!@show[sep5]">
|
<row disabled="!@show[sep5]">
|
||||||
<hrule span="all"/>
|
<hrule span="all"/>
|
||||||
</row>
|
</row>
|
||||||
|
<row disabled="!@show[recaptcha]">
|
||||||
|
<description span="2"/>
|
||||||
|
<html id="recaptcha"/>
|
||||||
|
<description/>
|
||||||
|
</row>
|
||||||
<row disabled="!@show[captcha]">
|
<row disabled="!@show[captcha]">
|
||||||
<image src="private.png"/>
|
<image src="private.png"/>
|
||||||
<description value="Verification"/>
|
<description value="Verification"/>
|
||||||
|
@ -250,6 +250,23 @@
|
|||||||
<!-- no more dynamic minifying: option value="debug">Debug</option -->
|
<!-- no more dynamic minifying: option value="debug">Debug</option -->
|
||||||
</select>
|
</select>
|
||||||
</row>
|
</row>
|
||||||
|
<row>
|
||||||
|
<description value="Google recaptcha" span="all" class="subHeader"/>
|
||||||
|
</row>
|
||||||
|
<row>
|
||||||
|
<vbox>
|
||||||
|
<description value="Google recaptcha secret key" label="%s:"/>
|
||||||
|
<description value="This secret key used for communication between your site and Google. Be sure to keep it a secret."/>
|
||||||
|
</vbox>
|
||||||
|
<textbox id="newsettings[recaptcha_secret]" size="60"/>
|
||||||
|
</row>
|
||||||
|
<row>
|
||||||
|
<vbox>
|
||||||
|
<description value="Google recaptcha site key" label="%s:"/>
|
||||||
|
<description value="This key used in the HTML code your site serves to users." />
|
||||||
|
</vbox>
|
||||||
|
<textbox id="newsettings[recaptcha_site]" size="60"/>
|
||||||
|
</row>
|
||||||
</rows>
|
</rows>
|
||||||
</grid>
|
</grid>
|
||||||
</template>
|
</template>
|
||||||
|
Loading…
Reference in New Issue
Block a user