Add blocklist support to overboard.
This commit is contained in:
parent
0c6129af53
commit
62486e4c9a
|
@ -259,7 +259,7 @@ function expire_overboard($cachefile)
|
||||||
|
|
||||||
function display_threads($threads, $oldest)
|
function display_threads($threads, $oldest)
|
||||||
{
|
{
|
||||||
global $CONFIG, $OVERRIDES, $thissite, $logfile, $config_name, $config_dir, $snippetlength, $maxdisplay, $this_overboard, $article_age;
|
global $CONFIG, $OVERRIDES, $thissite, $logfile, $config_name, $spooldir, $config_dir, $snippetlength, $maxdisplay, $this_overboard, $article_age;
|
||||||
$expireme = time() - ($article_age * 86400);
|
$expireme = time() - ($article_age * 86400);
|
||||||
$display = '<table cellspacing="0" width="100%" class="np_results_table">';
|
$display = '<table cellspacing="0" width="100%" class="np_results_table">';
|
||||||
if (! isset($threads)) {
|
if (! isset($threads)) {
|
||||||
|
@ -272,6 +272,12 @@ function display_threads($threads, $oldest)
|
||||||
if ($userdata = get_user_mail_auth_data($_COOKIE['mail_name'])) {
|
if ($userdata = get_user_mail_auth_data($_COOKIE['mail_name'])) {
|
||||||
$userfile = $spooldir . '/' . strtolower($_COOKIE['mail_name']) . '-articleviews.dat';
|
$userfile = $spooldir . '/' . strtolower($_COOKIE['mail_name']) . '-articleviews.dat';
|
||||||
$user_config = unserialize(file_get_contents($config_dir . '/userconfig/' . strtolower($_COOKIE['mail_name']) . '.config'));
|
$user_config = unserialize(file_get_contents($config_dir . '/userconfig/' . strtolower($_COOKIE['mail_name']) . '.config'));
|
||||||
|
$userfile = $spooldir . '/' . strtolower($_COOKIE['mail_name']) . '-blocked_posters.dat';
|
||||||
|
if (file_exists($userfile)) {
|
||||||
|
$blocked_user_config = unserialize(file_get_contents($userfile));
|
||||||
|
} else {
|
||||||
|
$blocked_user_config = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! isset($user_config['hide_unsub'])) {
|
if (! isset($user_config['hide_unsub'])) {
|
||||||
|
@ -331,16 +337,40 @@ function display_threads($threads, $oldest)
|
||||||
$display .= '<tr class="np_result_line1"><td class="np_result_line1" style="word-wrap:break-word";>';
|
$display .= '<tr class="np_result_line1"><td class="np_result_line1" style="word-wrap:break-word";>';
|
||||||
}
|
}
|
||||||
$display .= '<center>';
|
$display .= '<center>';
|
||||||
|
// Check user blocklist
|
||||||
|
$block = false;
|
||||||
|
foreach ($blocked_user_config as $key => $value) {
|
||||||
|
$blockme = '/' . addslashes($key) . '/';
|
||||||
|
if (preg_match($blockme, $target_head['name'])) {
|
||||||
|
$block = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($block) {}
|
||||||
$url = $thissite . "/article-flat.php?id=" . $target_head['number'] . "&group=" . _rawurlencode($target_head['newsgroup']) . "#" . $target_head['number'];
|
$url = $thissite . "/article-flat.php?id=" . $target_head['number'] . "&group=" . _rawurlencode($target_head['newsgroup']) . "#" . $target_head['number'];
|
||||||
$display .= '<p class=np_ob_subject>';
|
$display .= '<p class=np_ob_subject>';
|
||||||
$display .= '<b><a href="' . $url . '"><span>' . headerDecode($target_head['subject']) . '</span></a></b></p>';
|
$display .= '<b><a href="' . $url . '"><span>' . headerDecode($target_head['subject']) . '</span></a></b></p>';
|
||||||
$display .= '<a href="thread.php?group=' . _rawurlencode($target_head['newsgroup']) . '">' . $target_head['newsgroup'] . '</a>';
|
$display .= '<a href="thread.php?group=' . _rawurlencode($target_head['newsgroup']) . '">' . $target_head['newsgroup'] . '</a>';
|
||||||
if ($result_count > 1 && isset($target_head['date'])) {
|
if ($result_count > 1 && isset($target_head['date'])) {
|
||||||
$poster = get_poster_name(mb_decode_mimeheader($target_head['name']));
|
$poster = get_poster_name(mb_decode_mimeheader($target_head['name']));
|
||||||
$display .= '<p class=np_ob_posted_date>Posted: ' . get_date_interval(date("D, j M Y H:i T", $target_head['date'])) . ' by: ' . create_name_link($poster['name'], $poster['from']) . '</p>';
|
$block = false;
|
||||||
if ($CONFIG['article_database'] == '1') {
|
foreach ($blocked_user_config as $key => $value) {
|
||||||
$article = get_db_data_from_msgid($target_head['msgid'], $target_head['newsgroup'], 1);
|
$blockme = '/' . addslashes($key) . '/';
|
||||||
$display .= wordwrap(substr($article['search_snippet'], 0, $snippetlength), ($snippetlength / 2), "<br />\n", true);
|
if (preg_match($blockme, $target_head['name'])) {
|
||||||
|
$block = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($block) {
|
||||||
|
$display .= '<br /><br />';
|
||||||
|
$display .= '<p class=np_ob_subject>';
|
||||||
|
$display .= '<b><span>(message #' . $target_head['number'] . ' hidden by your blocklist)</span></a></b>';
|
||||||
|
} else {
|
||||||
|
$display .= '<p class=np_ob_posted_date>Posted: ' . get_date_interval(date("D, j M Y H:i T", $target_head['date'])) . ' by: ' . create_name_link($poster['name'], $poster['from']) . '</p>';
|
||||||
|
if ($CONFIG['article_database'] == '1') {
|
||||||
|
$article = get_db_data_from_msgid($target_head['msgid'], $target_head['newsgroup'], 1);
|
||||||
|
$display .= wordwrap(substr($article['search_snippet'], 0, $snippetlength), ($snippetlength / 2), "<br />\n", true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$skip = $target_head['number'];
|
$skip = $target_head['number'];
|
||||||
}
|
}
|
||||||
|
@ -350,26 +380,40 @@ function display_threads($threads, $oldest)
|
||||||
}
|
}
|
||||||
if ($skip != $target['number']) {
|
if ($skip != $target['number']) {
|
||||||
$poster = get_poster_name(mb_decode_mimeheader($target['name']));
|
$poster = get_poster_name(mb_decode_mimeheader($target['name']));
|
||||||
$groupurl = $thissite . "/thread.php?group=" . _rawurlencode($target['newsgroup']);
|
$block = false;
|
||||||
$url = $thissite . "/article-flat.php?id=" . $target['number'] . "&group=" . _rawurlencode($target['newsgroup']) . "#" . $target['number'];
|
foreach ($blocked_user_config as $key => $value) {
|
||||||
$display .= '<br /><br />';
|
$blockme = '/' . addslashes($key) . '/';
|
||||||
$display .= '<p class=np_ob_subject>';
|
if (preg_match($blockme, $target['name'])) {
|
||||||
$display .= '<b><a href="' . $url . '"><span>' . headerDecode($target['subject']) . '</span></a></b>';
|
$block = true;
|
||||||
|
break;
|
||||||
$display .= '</p>';
|
}
|
||||||
$display .= '<p class=np_ob_body>';
|
|
||||||
$display .= 'by: <b><i><span class="visited">' . create_name_link($poster['name'], $poster['from']) . '</span></i></b>';
|
|
||||||
|
|
||||||
$display .= '</p>';
|
|
||||||
$display .= '<p class=np_ob_posted_date>Posted: ' . get_date_interval(date("D, j M Y H:i T", $target['date'])) . ' in: <a href="' . $groupurl . '"><span class="visited">' . $target['newsgroup'] . '</span></a></p>';
|
|
||||||
if ($CONFIG['article_database'] == '1') {
|
|
||||||
$article = get_db_data_from_msgid($target['msgid'], $target['newsgroup'], 1);
|
|
||||||
$display .= htmlentities(substr($article['search_snippet'], 0, $snippetlength));
|
|
||||||
}
|
}
|
||||||
if ($target['date'] < $expireme) {
|
if ($block) {
|
||||||
unset($this_overboard['threads'][$target['date']]);
|
$display .= '<br /><br />';
|
||||||
unset($this_overboard['threadlink'][$new]);
|
$display .= '<p class=np_ob_subject>';
|
||||||
file_put_contents($logfile, "\n" . format_log_date() . " " . $config_name . " Pruning: " . $target['newsgroup'] . ":" . $target['number'], FILE_APPEND);
|
$display .= '<b><span>(message #' . $target['number'] . ' hidden by your blocklist)</span></a></b>';
|
||||||
|
} else {
|
||||||
|
$groupurl = $thissite . "/thread.php?group=" . _rawurlencode($target['newsgroup']);
|
||||||
|
$url = $thissite . "/article-flat.php?id=" . $target['number'] . "&group=" . _rawurlencode($target['newsgroup']) . "#" . $target['number'];
|
||||||
|
$display .= '<br /><br />';
|
||||||
|
$display .= '<p class=np_ob_subject>';
|
||||||
|
$display .= '<b><a href="' . $url . '"><span>' . headerDecode($target['subject']) . '</span></a></b>';
|
||||||
|
|
||||||
|
$display .= '</p>';
|
||||||
|
$display .= '<p class=np_ob_body>';
|
||||||
|
$display .= 'by: <b><i><span class="visited">' . create_name_link($poster['name'], $poster['from']) . '</span></i></b>';
|
||||||
|
|
||||||
|
$display .= '</p>';
|
||||||
|
$display .= '<p class=np_ob_posted_date>Posted: ' . get_date_interval(date("D, j M Y H:i T", $target['date'])) . ' in: <a href="' . $groupurl . '"><span class="visited">' . $target['newsgroup'] . '</span></a></p>';
|
||||||
|
if ($CONFIG['article_database'] == '1') {
|
||||||
|
$article = get_db_data_from_msgid($target['msgid'], $target['newsgroup'], 1);
|
||||||
|
$display .= htmlentities(substr($article['search_snippet'], 0, $snippetlength));
|
||||||
|
}
|
||||||
|
if ($target['date'] < $expireme) {
|
||||||
|
unset($this_overboard['threads'][$target['date']]);
|
||||||
|
unset($this_overboard['threadlink'][$new]);
|
||||||
|
file_put_contents($logfile, "\n" . format_log_date() . " " . $config_name . " Pruning: " . $target['newsgroup'] . ":" . $target['number'], FILE_APPEND);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -383,7 +427,7 @@ function display_threads($threads, $oldest)
|
||||||
|
|
||||||
function display_flat($threads, $oldest)
|
function display_flat($threads, $oldest)
|
||||||
{
|
{
|
||||||
global $CONFIG, $OVERRIDES, $thissite, $logfile, $config_name, $config_dir, $snippetlength, $maxdisplay, $this_overboard, $article_age;
|
global $CONFIG, $OVERRIDES, $thissite, $logfile, $spooldir, $config_name, $config_dir, $snippetlength, $maxdisplay, $this_overboard, $article_age;
|
||||||
$expireme = time() - ($article_age * 86400);
|
$expireme = time() - ($article_age * 86400);
|
||||||
$display = '<table cellspacing="0" width="100%" class="np_results_table">';
|
$display = '<table cellspacing="0" width="100%" class="np_results_table">';
|
||||||
if (! isset($threads)) {
|
if (! isset($threads)) {
|
||||||
|
@ -397,6 +441,12 @@ function display_flat($threads, $oldest)
|
||||||
$userfile = $spooldir . '/' . strtolower($_COOKIE['mail_name']) . '-articleviews.dat';
|
$userfile = $spooldir . '/' . strtolower($_COOKIE['mail_name']) . '-articleviews.dat';
|
||||||
$user_config = unserialize(file_get_contents($config_dir . '/userconfig/' . strtolower($_COOKIE['mail_name']) . '.config'));
|
$user_config = unserialize(file_get_contents($config_dir . '/userconfig/' . strtolower($_COOKIE['mail_name']) . '.config'));
|
||||||
}
|
}
|
||||||
|
$userfile = $spooldir . '/' . strtolower($_COOKIE['mail_name']) . '-blocked_posters.dat';
|
||||||
|
if (file_exists($userfile)) {
|
||||||
|
$blocked_user_config = unserialize(file_get_contents($userfile));
|
||||||
|
} else {
|
||||||
|
$blocked_user_config = null;
|
||||||
|
}
|
||||||
|
|
||||||
if (! isset($user_config['hide_unsub'])) {
|
if (! isset($user_config['hide_unsub'])) {
|
||||||
if (isset($OVERRIDES['hide_unsub'])) {
|
if (isset($OVERRIDES['hide_unsub'])) {
|
||||||
|
@ -433,26 +483,39 @@ function display_flat($threads, $oldest)
|
||||||
} else {
|
} else {
|
||||||
$display .= '<tr class="np_result_line1"><td class="np_result_line1" style="word-wrap:break-word";>';
|
$display .= '<tr class="np_result_line1"><td class="np_result_line1" style="word-wrap:break-word";>';
|
||||||
}
|
}
|
||||||
$url = $thissite . "/article-flat.php?id=" . $target['number'] . "&group=" . _rawurlencode($target['newsgroup']) . "#" . $target['number'];
|
$block = false;
|
||||||
$display .= '<p class=np_ob_subject>';
|
foreach ($blocked_user_config as $key => $value) {
|
||||||
$display .= '<b><a href="' . $url . '"><span>' . headerDecode($target['subject']) . '</span></a></b>';
|
$blockme = '/' . addslashes($key) . '/';
|
||||||
|
if (preg_match($blockme, $target['name'])) {
|
||||||
// link for (thread), if possible
|
$block = true;
|
||||||
if (isset($this_overboard['threadlink'][$value])) {
|
break;
|
||||||
$thread = get_data_from_msgid($this_overboard['threadlink'][$value], $target['newsgroup']);
|
|
||||||
if ($thread !== false) {
|
|
||||||
$display .= '<font class="np_ob_group"><a href="article-flat.php?id=' . $thread['number'] . '&group=' . rawurlencode($thread['newsgroup']) . '#' . $thread['number'] . '"> (thread)</a></font>';
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if ($block) {
|
||||||
|
// $display .= '<br /><br />';
|
||||||
|
$display .= '<p class=np_ob_subject>';
|
||||||
|
$display .= '<b><span>(message #' . $target['number'] . ' hidden by your blocklist)</span></a></b>';
|
||||||
|
} else {
|
||||||
|
$url = $thissite . "/article-flat.php?id=" . $target['number'] . "&group=" . _rawurlencode($target['newsgroup']) . "#" . $target['number'];
|
||||||
|
$display .= '<p class=np_ob_subject>';
|
||||||
|
$display .= '<b><a href="' . $url . '"><span>' . headerDecode($target['subject']) . '</span></a></b>';
|
||||||
|
|
||||||
$display .= '</p>';
|
// link for (thread), if possible
|
||||||
$display .= '</p><p class=np_ob_group>';
|
if (isset($this_overboard['threadlink'][$value])) {
|
||||||
$display .= '<a href="' . $groupurl . '"><span class="visited">' . $target['newsgroup'] . '</span></a>';
|
$thread = get_data_from_msgid($this_overboard['threadlink'][$value], $target['newsgroup']);
|
||||||
$display .= '</p>';
|
if ($thread !== false) {
|
||||||
$display .= '<p class=np_ob_posted_date>Posted: ' . get_date_interval(date("D, j M Y H:i T", $target['date'])) . ' by: ' . create_name_link($poster['name'], $poster['from']) . '</p>';
|
$display .= '<font class="np_ob_group"><a href="article-flat.php?id=' . $thread['number'] . '&group=' . rawurlencode($thread['newsgroup']) . '#' . $thread['number'] . '"> (thread)</a></font>';
|
||||||
if ($CONFIG['article_database'] == '1') {
|
}
|
||||||
$article = get_db_data_from_msgid($target['msgid'], $target['newsgroup'], 1);
|
}
|
||||||
$display .= htmlentities(substr($article['search_snippet'], 0, $snippetlength));
|
$display .= '</p>';
|
||||||
|
$display .= '</p><p class=np_ob_group>';
|
||||||
|
$display .= '<a href="' . $groupurl . '"><span class="visited">' . $target['newsgroup'] . '</span></a>';
|
||||||
|
$display .= '</p>';
|
||||||
|
$display .= '<p class=np_ob_posted_date>Posted: ' . get_date_interval(date("D, j M Y H:i T", $target['date'])) . ' by: ' . create_name_link($poster['name'], $poster['from']) . '</p>';
|
||||||
|
if ($CONFIG['article_database'] == '1') {
|
||||||
|
$article = get_db_data_from_msgid($target['msgid'], $target['newsgroup'], 1);
|
||||||
|
$display .= htmlentities(substr($article['search_snippet'], 0, $snippetlength));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$results ++;
|
$results ++;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue