Continue with feature to hide unsubscribed groups. Add default and also option in overrides.inc.php.
This commit is contained in:
parent
09d69ab2de
commit
fd5285ba88
|
@ -4,7 +4,7 @@ $title .= ' - Available Newsgroups';
|
||||||
include "head.inc";
|
include "head.inc";
|
||||||
|
|
||||||
$cache_filename = $spooldir . '/grouplist-cache.txt';
|
$cache_filename = $spooldir . '/grouplist-cache.txt';
|
||||||
|
echo '<center>';
|
||||||
echo '<h3>List of Available Newsgroups:</h3>';
|
echo '<h3>List of Available Newsgroups:</h3>';
|
||||||
// Use cache if new enough
|
// Use cache if new enough
|
||||||
if (filemtime($cache_filename) > (time() - 3600)) {
|
if (filemtime($cache_filename) > (time() - 3600)) {
|
||||||
|
@ -61,8 +61,8 @@ foreach ($groups_array as $thisgroup) {
|
||||||
}
|
}
|
||||||
|
|
||||||
echo '</table>';
|
echo '</table>';
|
||||||
// echo ob_get_contents();
|
echo '</center>';
|
||||||
file_put_contents($cache_filename, ob_get_contents());
|
include "tail.inc";
|
||||||
ob_end_flush();
|
|
||||||
echo '</body></html>';
|
echo '</body></html>';
|
||||||
?>
|
file_put_contents($cache_filename, ob_get_contents());
|
||||||
|
ob_end_flush();
|
|
@ -595,7 +595,7 @@ function groups_read($server, $port, $load = 0, $force_reload = false)
|
||||||
|
|
||||||
function groups_show($gruppen)
|
function groups_show($gruppen)
|
||||||
{
|
{
|
||||||
global $gl_age, $frame, $spooldir, $logdir, $CONFIG, $spoolnews;
|
global $gl_age, $frame, $spooldir, $config_dir, $logdir, $CONFIG, $OVERRIDES, $spoolnews;
|
||||||
if ($gruppen == false)
|
if ($gruppen == false)
|
||||||
return;
|
return;
|
||||||
global $file_thread, $text_groups;
|
global $file_thread, $text_groups;
|
||||||
|
@ -607,9 +607,19 @@ function groups_show($gruppen)
|
||||||
$subs = array();
|
$subs = array();
|
||||||
$nonsubs = array();
|
$nonsubs = array();
|
||||||
$user = null;
|
$user = null;
|
||||||
|
// Get registered user settings
|
||||||
if (isset($_COOKIE['mail_name'])) {
|
if (isset($_COOKIE['mail_name'])) {
|
||||||
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'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! isset($user_config['hide_unsub'])) {
|
||||||
|
if (isset($OVERRIDES['hide_unsub'])) {
|
||||||
|
$user_config['hide_unsub'] = $OVERRIDES['hide_unsub'];
|
||||||
|
} else {
|
||||||
|
$user_config['hide_unsub'] = 'hide';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for ($i = 0; $i < $c; $i ++) {
|
for ($i = 0; $i < $c; $i ++) {
|
||||||
|
@ -683,6 +693,10 @@ function groups_show($gruppen)
|
||||||
$groupdisplay .= ' <a href="overboard.php?thisgroup=' . urlencode($g->name) . '&time=' . $userdata[$g->name] . '"><b>(new)</b></a> ';
|
$groupdisplay .= ' <a href="overboard.php?thisgroup=' . urlencode($g->name) . '&time=' . $userdata[$g->name] . '"><b>(new)</b></a> ';
|
||||||
}
|
}
|
||||||
$groupdisplay .= '</p';
|
$groupdisplay .= '</p';
|
||||||
|
} else {
|
||||||
|
if (isset($user_config['hide_unsub']) && $user_config['hide_unsub'] == 'hide') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
/* Display article count */
|
/* Display article count */
|
||||||
$groupdisplay .= '</td><td class="' . $lineclass . '">';
|
$groupdisplay .= '</td><td class="' . $lineclass . '">';
|
||||||
|
@ -733,6 +747,10 @@ function groups_show($gruppen)
|
||||||
echo $nonsub;
|
echo $nonsub;
|
||||||
}
|
}
|
||||||
echo "</td></div></table>\n";
|
echo "</td></div></table>\n";
|
||||||
|
if (isset($user_config['hide_unsub']) && $user_config['hide_unsub'] == 'hide') {
|
||||||
|
echo '<font class="np_last_posted_date"> Unsubscribed groups are HIDDEN. Visit <a href="/spoolnews/user.php">User/Configuration</a> to change<br />';
|
||||||
|
echo ' or select groups from <a href="/common/grouplist.php">Grouplist</a> to add groups</font>';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1772,13 +1790,13 @@ function get_poster_name($name)
|
||||||
* This function returns false on success
|
* This function returns false on success
|
||||||
* or return value contains error info
|
* or return value contains error info
|
||||||
* 'added' etc.
|
* 'added' etc.
|
||||||
*/
|
*/
|
||||||
function save_config_value($configfile, $name, $value, $value_unique = false)
|
function save_config_value($configfile, $name, $value, $value_unique = false)
|
||||||
{
|
{
|
||||||
global $spooldir;
|
global $spooldir;
|
||||||
$return_val = false;
|
$return_val = false;
|
||||||
$tempfile = tempnam($spooldir, 'rslight-');
|
$tempfile = tempnam($spooldir, 'rslight-');
|
||||||
if(file_exists($tempfile)) {
|
if (file_exists($tempfile)) {
|
||||||
unlink($tempfile);
|
unlink($tempfile);
|
||||||
}
|
}
|
||||||
$lines = file($configfile, FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
|
$lines = file($configfile, FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
|
||||||
|
@ -1787,7 +1805,7 @@ function save_config_value($configfile, $name, $value, $value_unique = false)
|
||||||
$current = explode(':', $line);
|
$current = explode(':', $line);
|
||||||
if ($value_unique && (strcmp($current[1], $value) == 0)) {
|
if ($value_unique && (strcmp($current[1], $value) == 0)) {
|
||||||
// Found value. Write once
|
// Found value. Write once
|
||||||
if(!$found) {
|
if (! $found) {
|
||||||
file_put_contents($tempfile, $name . ":" . $value . "\n", FILE_APPEND);
|
file_put_contents($tempfile, $name . ":" . $value . "\n", FILE_APPEND);
|
||||||
}
|
}
|
||||||
$found = true;
|
$found = true;
|
||||||
|
@ -1802,7 +1820,7 @@ function save_config_value($configfile, $name, $value, $value_unique = false)
|
||||||
file_put_contents($tempfile, $line . "\n", FILE_APPEND);
|
file_put_contents($tempfile, $line . "\n", FILE_APPEND);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(!$found) {
|
if (! $found) {
|
||||||
// $name not found in options. Add to file.
|
// $name not found in options. Add to file.
|
||||||
file_put_contents($tempfile, $name . ":" . $value . "\n", FILE_APPEND);
|
file_put_contents($tempfile, $name . ":" . $value . "\n", FILE_APPEND);
|
||||||
}
|
}
|
||||||
|
@ -1949,7 +1967,7 @@ function get_user_mail_auth_data($user)
|
||||||
$userfile = $spooldir . '/' . $user . '-articleviews.dat';
|
$userfile = $spooldir . '/' . $user . '-articleviews.dat';
|
||||||
if (is_file($userfile)) {
|
if (is_file($userfile)) {
|
||||||
$userdata = unserialize(file_get_contents($userfile));
|
$userdata = unserialize(file_get_contents($userfile));
|
||||||
if(!is_array($userdata)) {
|
if (! $userdata['DO.NOT.DELETE']) {
|
||||||
$userdata['DO.NOT.DELETE'] = time();
|
$userdata['DO.NOT.DELETE'] = time();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -2285,94 +2303,95 @@ function send_admin_message($admin, $from, $subject, $message)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function delete_message($messageid, $group=null, $overview_dbh=null)
|
function delete_message($messageid, $group = null, $overview_dbh = null)
|
||||||
{
|
{
|
||||||
global $logfile, $config_dir, $spooldir, $CONFIG, $webserver_group;
|
global $logfile, $config_dir, $spooldir, $CONFIG, $webserver_group;
|
||||||
if($group == null) {
|
if ($group == null) {
|
||||||
$message = get_data_from_msgid($messageid);
|
$message = get_data_from_msgid($messageid);
|
||||||
$groups = $message['newsgroup'];
|
$groups = $message['newsgroup'];
|
||||||
$grouplist = preg_split("/( |\,)/", $groups);
|
$grouplist = preg_split("/( |\,)/", $groups);
|
||||||
} else {
|
} else {
|
||||||
$grouplist[0] = $group;
|
$grouplist[0] = $group;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Find section */
|
/* Find section */
|
||||||
$menulist = file($config_dir . "menu.conf", FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
|
$menulist = file($config_dir . "menu.conf", FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
|
||||||
foreach($grouplist as $group) {
|
foreach ($grouplist as $group) {
|
||||||
foreach ($menulist as $menu) {
|
foreach ($menulist as $menu) {
|
||||||
if ($menu[0] == '#') {
|
if ($menu[0] == '#') {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$menuitem = explode(':', $menu);
|
$menuitem = explode(':', $menu);
|
||||||
$glfp = fopen($config_dir . $menuitem[0] . "/groups.txt", 'r');
|
$glfp = fopen($config_dir . $menuitem[0] . "/groups.txt", 'r');
|
||||||
while ($gl = fgets($glfp)) {
|
while ($gl = fgets($glfp)) {
|
||||||
$group_name = preg_split("/( |\t)/", $gl, 2);
|
$group_name = preg_split("/( |\t)/", $gl, 2);
|
||||||
if (strtolower(trim($group)) == strtolower(trim($group_name[0]))) {
|
if (strtolower(trim($group)) == strtolower(trim($group_name[0]))) {
|
||||||
$config_name = $menuitem[0];
|
$config_name = $menuitem[0];
|
||||||
// echo "\nFOUND: " . $group . " IN: " . $config_name;
|
// echo "\nFOUND: " . $group . " IN: " . $config_name;
|
||||||
file_put_contents($logfile, "\n" . format_log_date() . " " . $config_name . " FOUND: " . $group . " IN: " . $config_name, FILE_APPEND);
|
file_put_contents($logfile, "\n" . format_log_date() . " " . $config_name . " FOUND: " . $group . " IN: " . $config_name, FILE_APPEND);
|
||||||
break 2;
|
break 2;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
if ($CONFIG['article_database'] == '1') {
|
||||||
if ($CONFIG['article_database'] == '1') {
|
$database = $spooldir . '/' . $group . '-articles.db3';
|
||||||
$database = $spooldir . '/' . $group . '-articles.db3';
|
if (is_file($database)) {
|
||||||
if (is_file($database)) {
|
$articles_dbh = article_db_open($database);
|
||||||
$articles_dbh = article_db_open($database);
|
$articles_stmt = $articles_dbh->prepare('DELETE FROM articles WHERE msgid=:messageid');
|
||||||
$articles_stmt = $articles_dbh->prepare('DELETE FROM articles WHERE msgid=:messageid');
|
$articles_stmt->execute([
|
||||||
$articles_stmt->execute([
|
'messageid' => $messageid
|
||||||
'messageid' => $messageid
|
]);
|
||||||
]);
|
$articles_dbh = null;
|
||||||
$articles_dbh = null;
|
}
|
||||||
}
|
}
|
||||||
}
|
// Handle overview and history
|
||||||
// Handle overview and history
|
if ($overview_dbh == null) {
|
||||||
if($overview_dbh == null) {
|
$database = $spooldir . '/articles-overview.db3';
|
||||||
$database = $spooldir . '/articles-overview.db3';
|
$overview_dbh = overview_db_open($database);
|
||||||
$overview_dbh = overview_db_open($database);
|
if (! $overview_dbh) {
|
||||||
if(!$overview_dbh) {
|
file_put_contents($logfile, "\n" . format_log_date() . " " . $config_name . " FAILED opening " . $database, FILE_APPEND);
|
||||||
file_put_contents($logfile, "\n" . format_log_date() . " " . $config_name . " FAILED opening " . $database, FILE_APPEND);
|
return;
|
||||||
return;
|
}
|
||||||
|
$close_ovdb = true;
|
||||||
}
|
}
|
||||||
$close_ovdb = true;
|
$overview_stmt_del = $overview_dbh->prepare('DELETE FROM overview WHERE newsgroup=:newsgroup AND msgid=:msgid');
|
||||||
}
|
$overview_query = $overview_dbh->prepare('SELECT * FROM overview WHERE newsgroup=:newsgroup AND msgid=:msgid');
|
||||||
$overview_stmt_del = $overview_dbh->prepare('DELETE FROM overview WHERE newsgroup=:newsgroup AND msgid=:msgid');
|
$overview_query->execute([
|
||||||
$overview_query = $overview_dbh->prepare('SELECT * FROM overview WHERE newsgroup=:newsgroup AND msgid=:msgid');
|
|
||||||
$overview_query->execute([
|
|
||||||
':newsgroup' => $group,
|
|
||||||
':msgid' => $messageid
|
|
||||||
]);
|
|
||||||
$grouppath = preg_replace('/\./', '/', $group);
|
|
||||||
$status = "deleted";
|
|
||||||
$statusdate = time();
|
|
||||||
$statusreason = "nocem";
|
|
||||||
$statusnotes = null;
|
|
||||||
while ($row = $overview_query->fetch()) {
|
|
||||||
if (isset($row['number'])) {
|
|
||||||
// echo "\nFOUND: " . $messageid . " IN: " . $group;
|
|
||||||
file_put_contents($logfile, "\n" . format_log_date() . " " . $config_name . " DELETING: " . $messageid . " IN: " . $group, FILE_APPEND);
|
|
||||||
}
|
|
||||||
if (is_file($spooldir . '/articles/' . $grouppath . '/' . $row['number'])) {
|
|
||||||
unlink($spooldir . '/articles/' . $grouppath . '/' . $row['number']);
|
|
||||||
}
|
|
||||||
delete_message_from_overboard($config_name, $group, $messageid);
|
|
||||||
add_to_history($group, $row['number'], $row['msgid'], $status, $statusdate, $statusreason, $statusnotes);
|
|
||||||
thread_cache_removearticle($group, $row['number']);
|
|
||||||
$overview_stmt_del->execute([
|
|
||||||
':newsgroup' => $group,
|
':newsgroup' => $group,
|
||||||
':msgid' => $messageid
|
':msgid' => $messageid
|
||||||
]);
|
]);
|
||||||
|
$grouppath = preg_replace('/\./', '/', $group);
|
||||||
|
$status = "deleted";
|
||||||
|
$statusdate = time();
|
||||||
|
$statusreason = "nocem";
|
||||||
|
$statusnotes = null;
|
||||||
|
while ($row = $overview_query->fetch()) {
|
||||||
|
if (isset($row['number'])) {
|
||||||
|
// echo "\nFOUND: " . $messageid . " IN: " . $group;
|
||||||
|
file_put_contents($logfile, "\n" . format_log_date() . " " . $config_name . " DELETING: " . $messageid . " IN: " . $group, FILE_APPEND);
|
||||||
|
}
|
||||||
|
if (is_file($spooldir . '/articles/' . $grouppath . '/' . $row['number'])) {
|
||||||
|
unlink($spooldir . '/articles/' . $grouppath . '/' . $row['number']);
|
||||||
|
}
|
||||||
|
delete_message_from_overboard($config_name, $group, $messageid);
|
||||||
|
add_to_history($group, $row['number'], $row['msgid'], $status, $statusdate, $statusreason, $statusnotes);
|
||||||
|
thread_cache_removearticle($group, $row['number']);
|
||||||
|
$overview_stmt_del->execute([
|
||||||
|
':newsgroup' => $group,
|
||||||
|
':msgid' => $messageid
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($close_ovdb) {
|
||||||
|
$overview_dbh = null;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
if($close_ovdb) {
|
|
||||||
$overview_dbh = null;
|
|
||||||
}
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// This function returns FALSE if article is OK
|
// This function returns FALSE if article is OK
|
||||||
// Else returns a string with reason for failure
|
// Else returns a string with reason for failure
|
||||||
function check_article_integrity($rawmessage) {
|
function check_article_integrity($rawmessage)
|
||||||
|
{
|
||||||
global $CONFIG, $logfile;
|
global $CONFIG, $logfile;
|
||||||
$returnval = false;
|
$returnval = false;
|
||||||
$count_rawmessage = count($rawmessage);
|
$count_rawmessage = count($rawmessage);
|
||||||
|
@ -2394,7 +2413,7 @@ function check_article_integrity($rawmessage) {
|
||||||
// lets find the first part
|
// lets find the first part
|
||||||
while ($rawmessage[$i] != $boundary) {
|
while ($rawmessage[$i] != $boundary) {
|
||||||
$i ++;
|
$i ++;
|
||||||
if($i > $count_rawmessage) {
|
if ($i > $count_rawmessage) {
|
||||||
$returnval = " Skipping malformed message: " . $message->header->id;
|
$returnval = " Skipping malformed message: " . $message->header->id;
|
||||||
return $returnval;
|
return $returnval;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,11 @@ return [
|
||||||
// Disable Message-ID search in header
|
// Disable Message-ID search in header
|
||||||
'disable_msgid_search' => false,
|
'disable_msgid_search' => false,
|
||||||
|
|
||||||
|
// Set default for new registered users to 'show' or 'hide'
|
||||||
|
// Unsubscribed groups (else default is 'hide')
|
||||||
|
// Must be 'show' or 'hide'
|
||||||
|
'hide_unsub' => 'hide',
|
||||||
|
|
||||||
// Reserved aliases
|
// Reserved aliases
|
||||||
'reserved_names' => array("admin", "sysop", "rslight"),
|
'reserved_names' => array("admin", "sysop", "rslight"),
|
||||||
|
|
||||||
|
|
|
@ -294,6 +294,7 @@ if (isset($_POST['command']) && $_POST['command'] == 'SaveConfig') {
|
||||||
$user_config['xface'] = $_POST['xface'];
|
$user_config['xface'] = $_POST['xface'];
|
||||||
$user_config['timezone'] = $_POST['timezone'];
|
$user_config['timezone'] = $_POST['timezone'];
|
||||||
$user_config['theme'] = $_POST['listbox'];
|
$user_config['theme'] = $_POST['listbox'];
|
||||||
|
$user_config['hide_unsub'] = $_POST['hide_unsub'];
|
||||||
file_put_contents($config_dir . '/userconfig/' . $user . '.config', serialize($user_config));
|
file_put_contents($config_dir . '/userconfig/' . $user . '.config', serialize($user_config));
|
||||||
$_SESSION['theme'] = $user_config['theme'];
|
$_SESSION['theme'] = $user_config['theme'];
|
||||||
$mysubs = explode("\n", $_POST['subscribed']);
|
$mysubs = explode("\n", $_POST['subscribed']);
|
||||||
|
@ -392,7 +393,27 @@ if (isset($_POST['command']) && $_POST['command'] == 'Configuration') {
|
||||||
echo '</td>';
|
echo '</td>';
|
||||||
echo '</tr>';
|
echo '</tr>';
|
||||||
// Subscriptions
|
// Subscriptions
|
||||||
|
if(!isset($user_config['hide_unsub'])) {
|
||||||
|
$user_config['hide_unsub'] = 'show';
|
||||||
|
}
|
||||||
echo '<td class="np_result_line1" style="word-wrap:break-word";><h3>Subscribed:</h3></td>';
|
echo '<td class="np_result_line1" style="word-wrap:break-word";><h3>Subscribed:</h3></td>';
|
||||||
|
echo '<tr><td class="np_result_line1" style="word-wrap:break-word";>';
|
||||||
|
|
||||||
|
if($user_config['hide_unsub'] == 'hide') {
|
||||||
|
echo '<input type="radio" name="hide_unsub" id="hide" value="hide" checked="checked">';
|
||||||
|
} else {
|
||||||
|
echo '<input type="radio" name="hide_unsub" id="hide" value="hide">';
|
||||||
|
}
|
||||||
|
echo '<label for="hide_unsub"> Hide Unsubscribed Groups</label><br />';
|
||||||
|
|
||||||
|
if($user_config['hide_unsub'] == 'show') {
|
||||||
|
echo '<input type="radio" name="hide_unsub" id="show" value="show" checked="checked">';
|
||||||
|
} else {
|
||||||
|
echo '<input type="radio" name="hide_unsub" id="show" value="show">';
|
||||||
|
}
|
||||||
|
echo '<label for="hide_unsub"> Show All Groups</label>';
|
||||||
|
echo '</td></tr>';
|
||||||
|
|
||||||
echo '</tr><tr><td class="np_result_line1" style="word-wrap:break-word";><textarea class="configuration" id="subscribed" name="subscribed" rows="10" cols="40">';
|
echo '</tr><tr><td class="np_result_line1" style="word-wrap:break-word";><textarea class="configuration" id="subscribed" name="subscribed" rows="10" cols="40">';
|
||||||
foreach ($userdata as $key => $value) {
|
foreach ($userdata as $key => $value) {
|
||||||
if($key == "DO.NOT.DELETE") {
|
if($key == "DO.NOT.DELETE") {
|
||||||
|
|
Loading…
Reference in New Issue