diff options
author | Luke Shumaker <LukeShu@sbcglobal.net> | 2011-09-22 23:26:59 -0400 |
---|---|---|
committer | Luke Shumaker <LukeShu@sbcglobal.net> | 2011-09-22 23:26:59 -0400 |
commit | db3cb85d0992dd49ca2fdf33ea35c0cad60e312f (patch) | |
tree | cc93adcf6708dca02e02b4e4acb2aa654d073eca /src/plugins/ReCaptcha.class.php | |
parent | fef0de218e9485ea3db394f3e173b3c64a0463a8 (diff) |
Implement ReCaptcha entirely as a plugin, remove all of the ugliness
from my old implementation.
Diffstat (limited to 'src/plugins/ReCaptcha.class.php')
-rw-r--r-- | src/plugins/ReCaptcha.class.php | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/src/plugins/ReCaptcha.class.php b/src/plugins/ReCaptcha.class.php index c25147f..165493b 100644 --- a/src/plugins/ReCaptcha.class.php +++ b/src/plugins/ReCaptcha.class.php @@ -1,4 +1,6 @@ <?php +// We only include the recaptchalib.php file when we use it because we don't +// want it polluting the global namespace thing. class ReCaptcha extends Plugin { protected $config = array('public_key'=>'', @@ -11,4 +13,35 @@ class ReCaptcha extends Plugin { 'private_key'=>'text'); } public function init() {} + + private $resp = null; + private function getResp() { + if ($this->resp===null) { + require_once('recaptchalib.php'); + @$response = $_POST['recaptcha_response_field']; + @$challenge = $_POST['recaptcha_challenge_field']; + $this->resp = recaptcha_check_answer($this->config['private_key'], + $_SERVER['REMOTE_ADDR'], + $challenge, + $response); + } + return $this->resp; + } + + private function getError() { + if ($_POST["recaptcha_response_field"] && !$this->antispam_verify()) { + return $this->getResp()->error; + } else { + return false; + } + } + + public function antispam_verify() { + return $this->getResp()->is_valid; + } + + public function antispam_html() { + require_once('recaptchalib.php'); + return recaptcha_get_html($this->config['public_key'], $this->getError()); + } } |