-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathspamspan.plugin.php
192 lines (156 loc) · 7 KB
/
spamspan.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
<?php if ( !defined( 'HABARI_PATH' ) ) { die( 'No direct access' ); }
/**
* Spamspan habari plugin
* Protect your habari blog from spambots that collects email for spam concerns
**/
class Spamspan extends Plugin
{
public $emailreg = "([-\.\~\'\!\#\$\%\&\+\/\*\=\?\^\_\`\{\|\}\w\+^@]+) # Group 1 - Match the name part - dash, dot or
#special characters.
@ # @
((?: # Group 2
[-\w]+\. # one or more letters or dashes followed by a dot.
)+ # The whole thing one or more times
[A-Z]{2,6} # with between two and six letters at the end (NB
# .museum)
)";
public $graphical_at = '';
/**
* function action_plugin_activation
* adds the optional options to configure Spamspan
**/
public function action_plugin_activation( $file )
{
if ( realpath( $file ) == __FILE__ ) {
Options::set( 'spamspan__at', '[@]' );
Options::set( 'spamspan__graphics', 0 );
}
}
/**
* Add the configuration option to Spamspan
*/
public function filter_plugin_config( $actions, $plugin_id )
{
if ( $plugin_id == $this->plugin_id() ) {
$actions[]= _t( 'Configure' );
}
return $actions;
}
/**
* Add Spamspan Configuration user interface
*/
public function action_plugin_ui( $plugin_id, $action )
{
if ( $plugin_id == $this->plugin_id() ) {
switch ( $action ) {
case _t( 'Configure' ):
$ui = new FormUI( strtolower( get_class( $this ) ) );
$ui->append( 'text', 'custom_at', 'spamspan__at', _t( 'Custom replacement for "@"' ) );
$ui->append( 'checkbox', 'enable_graphics', 'spamspan__graphics', _t( 'Use a graphical replacement for "@"' ) );
$ui->append( 'submit', 'save', _t( 'Save' ) );
$ui->on_success( array( $this, 'updated_config' ) );
$ui->out();
break;
}
}
}
public function updated_config( $ui )
{
$ui->save();
return false;
}
/**
* Add required Javascript and, for now, CSS.
*/
public function action_template_header_10()
{
Stack::add( 'template_header_javascript', $this->get_url('/assets/js/spamspan.js') , 'spamspan' );
}
/**
* Add Spamspan's main hook, it includes the filters' calls, and also the customized regular expressions
*/
function spamspan_hook( $return ){
$emailpattern = "!" . $this->emailreg . "!ix";
$emailpattern_with_options = "!" . $this->emailreg . "[\|](.*) !ix";
$mailtopattern = "!<a\s+ # opening <a and spaces
(?:(?:\w+\s*=\s*)(?:\w+|\"[^\"]*\"|'[^']*'))*? # any attributes
\s* # whitespace
href\s*=\s*(['\"])(mailto:" # the href attribute
. $this->emailreg . # The email address
"(?:\?[A-Za-z0-9_= %\.\-\~\_\&]*)?)" . # an optional ? followed
# by a query string. NB
# we allow spaces here,
# even though strictly
# they should be URL
# encoded
"\\1 # the relevant quote
# character
(?:(?:\s+\w+\s*=\s*)(?:\w+|\"[^\"]*\"|'[^']*'))*? # any more attributes
> # end of the first tag
(.*?) # tag contents. NB this
# will not work properly
# if there is a nested
# <a>, but this is not
# valid xhtml anyway.
</a> # closing tag
!ix";
// Now we can convert all mailto URLs
$text = preg_replace_callback( $mailtopattern, array($this, 'spamspan_mailto_callback'), $return );
// all bare email addresses with optional formatting information
$text = preg_replace_callback( $emailpattern_with_options, array($this, 'spamspan_formatted_callback'), $text );
// and finally, all bare email addresses
$text = preg_replace_callback( $emailpattern, array($this, 'spamspan_simple_callback'), $text );
return $text;
}
/**
* Set an alias for Spamspan
*/
function alias()
{
return array(
'spamspan_hook' => array( 'filter_post_content_out', 'filter_post_content_excerpt', 'filter_post_content_summary' ),
);
}
/**
* Filter emails within "a" tags, which includes mailto protocol
*/
public function spamspan_mailto_callback( $matches ) {
$headers = preg_split( '/[&;]/', parse_url($matches[2], PHP_URL_QUERY) );
if ($headers[0] == '') {
$headers = array();
}
return $this->output( $matches[3], $matches[4] );
}
/**
* Filter emails within the content
*/
public function spamspan_simple_callback( $matches ){
if( strpos( $matches[0], '=' ) !== false ){
$onlink = true;
}else{
$onlink = false;
}
return $this->output( $matches[1], $matches[2], $onlink );
}
/**
* Filter emails with optional formatting informations
*/
public function spamspan_formatted_callback( $matches ){
// if( !isset( $matches[3] ) ) { $matches[3] = ""; }
return $this->output( $matches[1], $matches[2] );
}
/**
* Output the filtered emails with spamspan's structure
*/
public function output( $name, $domain, $onlink = false ) {
if( $onlink == false ){
$at = ( Options::get('spamspan__graphics') == '1' )? '<img class="spam-span-image" src="'. $this->graphical_at .'" alt="" />' : Options::get('spamspan__at');
$output = '<span class="u">' . $name . '</span>' . $at . '<span class="d">' . $domain . '</span>';
$output = '<span class="spamspan">' . $output . '</span>';
}else{
$output = false;
}
return $output;
}
}
?>