From 1fb1cfa97860889e382cb2ae653ded0ba67cca96 Mon Sep 17 00:00:00 2001 From: Jeremy Shipman Date: Sun, 29 Jul 2007 22:56:16 +0000 Subject: [PATCH] Adding in the beginnins of spam protection tools. git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/cms/trunk@39379 467b73ca-7a2a-4603-9d3b-597d59a354a9 --- code/sitefeatures/MathSpamProtection.php | 59 ++++++++++++++++++++++ code/sitefeatures/PageCommentInterface.php | 34 +++++++++++-- 2 files changed, 88 insertions(+), 5 deletions(-) create mode 100644 code/sitefeatures/MathSpamProtection.php diff --git a/code/sitefeatures/MathSpamProtection.php b/code/sitefeatures/MathSpamProtection.php new file mode 100644 index 00000000..50a9e9a4 --- /dev/null +++ b/code/sitefeatures/MathSpamProtection.php @@ -0,0 +1,59 @@ + diff --git a/code/sitefeatures/PageCommentInterface.php b/code/sitefeatures/PageCommentInterface.php index d386f23b..5ebbb20c 100755 --- a/code/sitefeatures/PageCommentInterface.php +++ b/code/sitefeatures/PageCommentInterface.php @@ -30,12 +30,22 @@ class PageCommentInterface extends ViewableData { Requirements::javascript('jsparty/scriptaculous/effects.js'); Requirements::javascript('cms/javascript/PageCommentInterface.js'); - $form = new PageCommentInterface_Form($this->controller, $this->methodName . ".PostCommentForm", new FieldSet( - new HiddenField("ParentID", "ParentID", $this->page->ID), - new TextField("Name", "Your name"), - new TextareaField("Comment", "Comments") - ), new FieldSet( + $fields = new FieldSet( + new HiddenField("ParentID", "ParentID", $this->page->ID), + new TextField("Name", "Your name") + ); + if(MathSpamProtection::isEnabled()){ + $fields->push(new TextField("Math","Spam protection question: ".MathSpamProtection::getMathQuestion())); + } + + if(CaptchaSpamProtection::isEnabled()){ + $fields->push(new TextField("Captcha",CaptchaSpamProtection::getImage()."

Please copy down the text from the image above")); + } + + $fields->push(new TextareaField("Comment", "Comments")); + + $form = new PageCommentInterface_Form($this->controller, $this->methodName . ".PostCommentForm",$fields, new FieldSet( new FormAction("postcomment", "Post") )); @@ -102,6 +112,20 @@ class PageCommentInterface_Form extends Form { } } + //check if spam question was right. + if(MathSpamProtection::isEnabled()){ + if(!MathSpamProtection::correctAnswer($data['Math'])){ + echo "

You got the spam protection question wrong.

"; + return; + } + } + + if(CaptchaSpamProtection::isEnabled()){ + if(!CaptchaSpamProtection::correctAnswer($data['Captcha'])){ + echo "

You got the captcha protection question wrong.

"; + return; + } + } Cookie::set("PageCommentInterface_Name", $data['Name']);