2 // $Id: spam_pickup.php,v 1.40 2007/02/19 12:54:25 henoheno Exp $
3 // Concept-work of spam-uri metrics
4 // Copyright (C) 2006-2007 PukiWiki Developers Team
5 // License: GPL v2 or (at your option) any later version
7 error_reporting(E_ALL); // Debug purpose
11 // Recursive array_map()
12 // e.g. Sanitilze ALL values (Debug purpose): var_dump(recursive_map('htmlspecialchars', $array));
13 function recursive_map($func, $array)
15 if (is_array($array)) {
16 if (! empty($array)) {
17 $array = array_map('recursive_map',
18 array_fill(0, count($array), $func), $array);
21 $array = $func($array);
26 function show_form($string, $asap = FALSE, $progress = TRUE, $pickup = TRUE)
28 $string = htmlspecialchars($string);
29 $asap = $asap ? ' checked' : '';
30 $progress = $progress ? ' checked' : '';
31 $pickup = $pickup ? ' checked' : '';
32 $base = basename(__FILE__);
35 <form action="$base" method="post">
37 <textarea name="msg" rows="8" cols="80">$string</textarea><br />
39 <input type="checkbox" name="asap" id="asap" value="on"$asap>
40 <label for="asap">asap</label><br />
42 <input type="checkbox" name="progress" id="progress" value="on"$progress>
43 <label for="progress">Show \$progress</label><br />
45 <input type="checkbox" name="pickup" id="pickup" value="on"$pickup>
46 <label for="pickup">Show pickuped URIs</label><br />
48 <input type="submit" name="write" value="Submit" />
56 // ---- Show form and result
57 echo basename(__FILE__) . '<br />';
59 $msg = isset($_POST['msg']) ? $_POST['msg'] : '';
60 $asap = isset($_POST['asap']) ? TRUE : FALSE;
61 $prog = isset($_POST['progress']) ? TRUE : FALSE;
62 $pickup = isset($_POST['pickup']) ? TRUE : FALSE;
64 echo show_form($msg, $asap, $prog, $pickup);
70 // -----------------------------------------------------
73 // Threshold and rules for insertion (default)
74 $spam['method']['_default'] = array(
75 '_comment' => '_default',
83 //'asap' => TRUE, // Stop as soon as possible (quick but less-info)
88 // Any thresholds may LOCK your contents by
89 // "posting one URL" many times.
90 // Any rules will lock contents that have NG things already.
91 $spam['method']['edit'] = array(
92 // Supposed_by_you(n) * Edit_form_spec(2) * Margin(1.5)
94 //'quantity' => 60 * 3,
95 //'non_uniquri' => 5 * 3,
96 //'non_uniqhost' => 50 * 3,
97 //'area_anchor' => 30 * 3,
98 //'area_bbcode' => 15 * 3,
105 $method = & $spam['method']['_default'];
106 //$method = & $spam['method']['edit'];
107 //$method = check_uri_spam_method();
109 // -----------------------------------------------------
111 if ($asap) $method['asap'] = TRUE;
113 $progress = check_uri_spam(
115 'a http://foobaA.example.com',
117 'b http://foobarB.example.com'
120 if (! empty($progress)) {
123 if (empty($progress['is_spam'])) {
124 var_dump('ACTION: Seems not a spam');
126 var_dump('ACTION: Blocked by ' . summarize_spam_progress($progress, TRUE));
128 if (! $asap) var_dump('METRICS: ' . summarize_spam_progress($progress));
130 $action = 'Blocked by: ' . summarize_spam_progress($progress, TRUE);
131 if (isset($progress['is_spam']['badhost'])) {
133 foreach($progress['is_spam']['badhost'] as $glob=>$number) {
134 $badhost[] = $glob . '(' . $number . ')';
136 var_dump('DETAIL_BADHOST: ' . implode(', ', $badhost));
137 //var_dump($progress['is_spam']['badhost']);
141 if (isset($progress['remains']['badhost'])) {
142 $count = count($progress['remains']['badhost']);
143 var_dump('DETAIL_NEUTRAL_HOST: ' . $count .
146 '/[^, a-z0-9.-]/i', '',
147 implode(', ', array_keys($progress['remains']['badhost']))
153 if ($prog) var_dump($progress);
157 $results = spam_uri_pickup($msg);
158 $results = uri_array_normalize($results, TRUE);
159 var_dump('$results', $results);