-
Notifications
You must be signed in to change notification settings - Fork 0
/
spamhoneypot.plugin.php
67 lines (57 loc) · 1.75 KB
/
spamhoneypot.plugin.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<?php
/**
* SpamHoneyPot Class
*
* This plugin entraps the spammer by supplying a hidden, second textarea that
* if filled, auto-qualifies the comment as spam.
*/
class SpamHoneyPot extends Plugin
{
/**
* Register the new textarea template
*
*/
public function action_init() {
$this->add_template( 'honeypot_text', dirname(__FILE__) . '/templates/honeypot_text.php' );
}
/**
* Create additional textarea
* ...
* @return the form
*/
public function action_form_comment( $form, $context = 'public' ) {
$second_textarea = $form->append( 'text','more_content','null:null', _t( 'stuff here' ) );
$second_textarea->template = 'honeypot_text';
return $form;
}
/**
* Check comment for honeypot field and qualify as spam accordingly
*
* @param float $spam_rating The spamminess of the comment as detected by other plugins
* @param Comment $comment The submitted comment object
* @param array $handlervars An array of handlervars passed in via the comment submission URL
* @param array $extra An array of all fields passed to the comment form
* @return float The original spam rating
*/
function filter_spam_filter( $spam_rating, $comment, $handlervars, $extra )
{
// This plugin ignores non-comments
if( $comment->type != Comment::COMMENT ) {
return $spam_rating;
}
$spamcheck = [];
if( !empty( $extra[ 'more_content' ]) ) {
$comment->status = Comment::STATUS_SPAM;
$spamcheck[] = _t('Caught by the honeypot');
}
// store spamcheck reason
if ( isset( $comment->info->spamcheck ) && is_array( $comment->info->spamcheck ) ) {
$comment->info->spamcheck = array_unique( array_merge( $comment->info->spamcheck, $spamcheck ) );
}
else {
$comment->info->spamcheck = $spamcheck;
}
return $spam_rating;
}
}
?>