First mods for php8.2.

This commit is contained in:
Retro_Guy 2023-04-13 18:52:30 -07:00
parent 832316a13e
commit 0683f8ddd0
22 changed files with 189 additions and 192 deletions

View File

@ -1,11 +1,11 @@
<html>
<head>
<title><?php echo htmlspecialchars($title); ?></title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<META HTTP-EQUIV="Content-type" CONTENT="text/html; charset=<?=$www_charset?>">
<?php <?php
include "config.inc.php"; include "config.inc.php";
echo '<html>';
echo '<head>';
echo '<title>'.htmlspecialchars($title).'</title>';
echo '<meta name="viewport" content="width=device-width, initial-scale=1.0">';
echo '<META HTTP-EQUIV="Content-type" CONTENT="text/html; charset=<?=$www_charset?>">';
if(file_exists($config_dir.'/googleanalytics.conf')) { if(file_exists($config_dir.'/googleanalytics.conf')) {
include $config_dir.'/googleanalytics.conf'; include $config_dir.'/googleanalytics.conf';
} }

View File

@ -32,7 +32,7 @@ if(!isset($_SESSION['theme']) && file_exists($config_dir.'/userconfig/'.$user.'.
} }
if(trim($_SESSION['theme']) !== '') { if(trim($_SESSION['theme']) !== '') {
echo '<link rel="stylesheet" type="text/css" href="../common/themes/'.$_SESSION[theme].'/style.css">'; echo '<link rel="stylesheet" type="text/css" href="../common/themes/'.$_SESSION['theme'].'/style.css">';
} else { } else {
echo '<link rel="stylesheet" type="text/css" href="'.$rootdir.'common/themes/Default Theme/style.css">'; echo '<link rel="stylesheet" type="text/css" href="'.$rootdir.'common/themes/Default Theme/style.css">';
} }

View File

@ -12,13 +12,12 @@ echo '<br />';
echo '<b>novaBBS:</b><br /><a href="https://www.novabbs.com">www.novabbs.com</a><br />'; echo '<b>novaBBS:</b><br /><a href="https://www.novabbs.com">www.novabbs.com</a><br />';
echo '<br />'; echo '<br />';
echo "Newsreader Access (most text newsgroups available, use 'list'):<br />"; echo 'Newsreader Access:<br />';
echo 'v77lu6t26velvaddm4gibyzd5sogskuczp7vwoc4vxmukvvaucva.b32.i2p<br />'; echo 'v77lu6t26velvaddm4gibyzd5sogskuczp7vwoc4vxmukvvaucva.b32.i2p<br />';
echo 'zkcvkb5xprurx5dvpanhyivneuzah6k6xayxgxd4h2ekklxgoi2x5aad.onion:119<br />'; echo 'zkcvkb5xprurx5dvpanhyivneuzah6k6xayxgxd4h2ekklxgoi2x5aad.onion:119<br />';
echo 'news.novabbs.org:119 or 563<br />'; echo 'news.novabbs.org:119 or 563<br />';
echo '<br />'; echo '<br />';
echo 'Create NNTP Account: Use one of the <i>Rocksolid Light</i> links above to create account.<br />'; echo 'Create NNTP Account: Use one of the <i>Rocksolid Light</i> links above to create account.<br />';
echo 'Log into NNTP server with your username/password to post<br />';
echo 'NNTP Peering also available in i2p/tor/clearnet<br />'; echo 'NNTP Peering also available in i2p/tor/clearnet<br />';
echo '<br />'; echo '<br />';
echo 'Rocksolid is also available from any usenet news provider carrying the rocksolid.* hierarchy<br />'; echo 'Rocksolid is also available from any usenet news provider carrying the rocksolid.* hierarchy<br />';

View File

@ -34,10 +34,10 @@ if (isset($_COOKIE["ts_limit"])) {
echo '<td><strong>Register Username </strong></td>'; echo '<td><strong>Register Username </strong></td>';
echo '</tr><tr>'; echo '</tr><tr>';
echo '<td>Username:</td>'; echo '<td>Username:</td>';
echo '<td><input name="username" type="text" id="username"value="'.$_POST[username].'"></td>'; echo '<td><input name="username" type="text" id="username"value="'.$_POST['username'].'"></td>';
echo '</tr><tr>'; echo '</tr><tr>';
echo '<td>Email:</td>'; echo '<td>Email:</td>';
echo '<td><input name="user_email" type="text" id="user_email" value="'.$_POST[user_email].'"></td>'; echo '<td><input name="user_email" type="text" id="user_email" value="'.$_POST['user_email'].'"></td>';
echo '</tr><tr>'; echo '</tr><tr>';
echo '<td>Password:</td>'; echo '<td>Password:</td>';
echo '<td><input name="password" type="password" id="password"></td>'; echo '<td><input name="password" type="password" id="password"></td>';

View File

@ -21,13 +21,19 @@
$id=$_REQUEST["id"]; $id=$_REQUEST["id"];
$group=_rawurldecode($_REQUEST["group"]); $group=_rawurldecode($_REQUEST["group"]);
// Switch to correct section in case group has been moved and link is to old section
$findsection = get_section_by_group($group); $findsection = get_section_by_group($group);
if(trim($findsection) !== $config_name) { if(trim($findsection) !== $config_name) {
$newurl = preg_replace("|/$config_name/|", "/$findsection/", $_SERVER['REQUEST_URI']); if (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] === 'on')
header("Location: $newurl"); $link = "https";
die(); else $link = "http";
$link .= "://";
$link .= $_SERVER['HTTP_HOST'];
$link .= $_SERVER['REQUEST_URI'];
$newurl = preg_replace("|/$config_name/|", "/$findsection/", $link);
header("Location:$newurl");
die();
} }
if(strpos($id, '@') !== false) { if(strpos($id, '@') !== false) {
if($CONFIG['article_database'] == '1') { if($CONFIG['article_database'] == '1') {
$database = $spooldir.'/articles-overview.db3'; $database = $spooldir.'/articles-overview.db3';

View File

@ -29,12 +29,10 @@ $CONFIG = include($config_file);
$logdir=$spooldir.'/log'; $logdir=$spooldir.'/log';
$lockdir=$spooldir.'/lock'; $lockdir=$spooldir.'/lock';
$ssldir=$config_dir.'/ssl';
if(!file_exists($config_dir.'/debug')) { if(!file_exists($config_dir.'/debug')) {
ini_set('error_reporting', E_ERROR ); ini_set('error_reporting', E_ERROR );
} }
/* Permanent configuration changes */ /* Permanent configuration changes */
@mkdir($logdir,0755,'recursive'); @mkdir($logdir,0755,'recursive');
@mkdir($spooldir.'/upload',0755,'recursive'); @mkdir($spooldir.'/upload',0755,'recursive');

View File

@ -1,9 +1,9 @@
<?php <?php
include "config.inc.php";
echo '<html><head>'; echo '<html><head>';
echo '<title>'.htmlspecialchars($title).'</title>'; echo '<title>'.htmlspecialchars($title).'</title>';
echo '<meta name="viewport" content="width=device-width, initial-scale=1.0">'; echo '<meta name="viewport" content="width=device-width, initial-scale=1.0">';
echo '<META HTTP-EQUIV="Content-type" CONTENT="text/html; charset=<?=$www_charset?>">'; echo '<META HTTP-EQUIV="Content-type" CONTENT="text/html; charset=<?=$www_charset?>">';
include "config.inc.php";
if(file_exists($config_dir.'/googleanalytics.conf')) { if(file_exists($config_dir.'/googleanalytics.conf')) {
include $config_dir.'/googleanalytics.conf'; include $config_dir.'/googleanalytics.conf';
@ -18,4 +18,3 @@ if(isset($frames_on) && $frames_on === false) {
} }
echo '<hr></head>'; echo '<hr></head>';
echo '<body textcolor="black" bgcolor="white">'; echo '<body textcolor="black" bgcolor="white">';
?>

View File

@ -88,6 +88,7 @@ function nntp_open($nserver=0,$nport=0) {
function nntp2_open($nserver=0,$nport=0) { function nntp2_open($nserver=0,$nport=0) {
global $text_error,$CONFIG; global $text_error,$CONFIG;
// echo "<br>NNTP OPEN<br>"; // echo "<br>NNTP OPEN<br>";
echo "NS: ".$nserver." PORT: ".$nport;
$authorize=((isset($CONFIG['remote_auth_user'])) && (isset($CONFIG['remote_auth_pass'])) && $authorize=((isset($CONFIG['remote_auth_user'])) && (isset($CONFIG['remote_auth_pass'])) &&
($CONFIG['remote_auth_user'] != "")); ($CONFIG['remote_auth_user'] != ""));
if ($nserver==0) $nserver=$CONFIG['remote_server']; if ($nserver==0) $nserver=$CONFIG['remote_server'];
@ -350,18 +351,15 @@ function get_section_by_group($groupname) {
continue; continue;
} }
$section = ""; $section = "";
$glfp=fopen($config_dir.$menuitem[0]."/groups.txt", 'r'); $gldata = file($config_dir.$menuitem[0]."/groups.txt");
while($gl=fgets($glfp)) { foreach($gldata as $gl) {
$group_name = preg_split("/( |\t)/", $gl, 2); $group_name = preg_split("/( |\t)/", $gl, 2);
if(strtolower(trim($groupname)) == strtolower(trim($group_name[0]))) { if(strtolower(trim($groupname)) == strtolower(trim($group_name[0]))) {
fclose($glfp);
$section=$menuitem[0]; $section=$menuitem[0];
fclose($glfp);
return $section; return $section;
} }
} }
} }
fclose($glfp);
return false; return false;
} }
@ -475,13 +473,14 @@ function groups_read($server,$port,$load=0) {
} else { } else {
$ns=nntp_open($server,$port); $ns=nntp_open($server,$port);
if ($ns == false) return false; if ($ns == false) return false;
$gf=fopen($file_groups,"r"); // $gf=fopen($file_groups,"r");
$gfdata = file($file_groups);
// if we want to mark groups with new articles with colors, wie will later // if we want to mark groups with new articles with colors, wie will later
// need the format of the overview // need the format of the overview
$overviewformat=thread_overview_read($ns); $overviewformat=thread_overview_read($ns);
while (!feof($gf)) { foreach($gfdata as $gf) {
$gruppe=new newsgroupType; $gruppe=new newsgroupType;
$tmp=trim(line_read($gf)); $tmp=trim($gf);
$tmp=preg_replace('/\t/', ' ', $tmp); $tmp=preg_replace('/\t/', ' ', $tmp);
if(substr($tmp,0,1)==":") { if(substr($tmp,0,1)==":") {
$gruppe->text=substr($tmp,1); $gruppe->text=substr($tmp,1);
@ -502,6 +501,7 @@ function groups_read($server,$port,$load=0) {
$neu=line_read($ns); $neu=line_read($ns);
do { do {
$response=$neu; $response=$neu;
echo $response;
if ($neu != ".") $neu=line_read($ns); if ($neu != ".") $neu=line_read($ns);
} while ($neu != "."); } while ($neu != ".");
$desc=strrchr($response,"\t"); $desc=strrchr($response,"\t");
@ -550,12 +550,9 @@ function groups_read($server,$port,$load=0) {
$newsgroups[]=$gruppe; $newsgroups[]=$gruppe;
} }
} }
fclose($gf);
nntp_close($ns); nntp_close($ns);
// write the data to the cachefile // write the data to the cachefile
$file=fopen($cachefile,"w"); file_put_contents($cachefile, serialize($newsgroups));
fputs($file,serialize($newsgroups));
fclose($file);
} }
if ($load == 0) { if ($load == 0) {
return $newsgroups; return $newsgroups;
@ -618,11 +615,10 @@ function groups_show($gruppen) {
$groupdisplay.='</span><br><p class="np_group_desc">'.$g->description.'</p>'; $groupdisplay.='</span><br><p class="np_group_desc">'.$g->description.'</p>';
// Subscribed features // Subscribed features
$filename = $spooldir."/".$g->name."-lastarticleinfo.dat"; $filename = $spooldir."/".$g->name."-lastarticleinfo.dat";
if($file=@fopen($filename,"r")) { if(is_file($filename)) {
$lastarticleinfo=unserialize(fread($file,filesize($filename))); $lastarticleinfo = unserialize(file_get_contents($filename));
fclose($file);
} else { } else {
$lastarticleinfo->date = 0; $lastarticleinfo['date'] = 0;
} }
if(isset($userdata[$g->name])) { if(isset($userdata[$g->name])) {
$groupdisplay.='</span><p class="np_group_desc">'; $groupdisplay.='</span><p class="np_group_desc">';
@ -660,7 +656,7 @@ function groups_show($gruppen) {
} }
$dbh = null; $dbh = null;
if($found) { if($found) {
$lastarticleinfo->date = $row['date']; $lastarticleinfo['date'] = $row['date'];
// Put this in a function already! // Put this in a function already!
$fromoutput = explode("<", html_entity_decode($row['name'])); $fromoutput = explode("<", html_entity_decode($row['name']));
// Just an email address? // Just an email address?
@ -673,16 +669,16 @@ function groups_show($gruppen) {
$fromoutput[0] = $fromaddress[1]; $fromoutput[0] = $fromaddress[1];
} }
if((isset($CONFIG['hide_email']) && $CONFIG['hide_email'] == true) && (strpos($fromoutput[0], '@') !== false)) { if((isset($CONFIG['hide_email']) && $CONFIG['hide_email'] == true) && (strpos($fromoutput[0], '@') !== false)) {
$lastarticleinfo->name = truncate_email($fromoutput[0]); $lastarticleinfo['name'] = truncate_email($fromoutput[0]);
} else { } else {
$lastarticleinfo->name = $fromoutput[0]; $lastarticleinfo['name'] = $fromoutput[0];
} }
} }
} }
$groupdisplay.=get_date_interval(date("D, j M Y H:i T",$lastarticleinfo->date)); $groupdisplay.=get_date_interval(date("D, j M Y H:i T",$lastarticleinfo['date']));
$groupdisplay.='<table><tr><td>'; $groupdisplay.='<table><tr><td>';
$groupdisplay.='<font class="np_last_posted_date">by: '; $groupdisplay.='<font class="np_last_posted_date">by: ';
$groupdisplay.=create_name_link($lastarticleinfo->name, $lastarticleinfo->from); $groupdisplay.=create_name_link(mb_decode_mimeheader($lastarticleinfo['name']), $lastarticleinfo['from']);
$groupdisplay.='</td></tr></table>'; $groupdisplay.='</td></tr></table>';
} }
$groupdisplay.="\n"; $groupdisplay.="\n";
@ -752,7 +748,7 @@ function groups_show_frames($gruppen) {
} }
/* /*
* gets a list of aviable articles in the group $groupname * gets a list of available articles in the group $groupname
*/ */
/* /*
function getArticleList(&$ns,$groupname) { function getArticleList(&$ns,$groupname) {
@ -903,9 +899,9 @@ function recode_charset($text,$source=false,$dest=false) {
global $iconv_enable,$www_charset; global $iconv_enable,$www_charset;
if($dest==false) if($dest==false)
$dest=$www_charset; $dest=$www_charset;
if($iconv_enable) { if(($iconv_enable) && ($source!=false)) {
$return=iconv($source, $return=iconv($source,
$dest."//TRANSLIT//IGNORE",$text); $dest."//TRANSLIT",$text);
if($return!="") if($return!="")
return $return; return $return;
else else
@ -1100,7 +1096,7 @@ function check_bbs_auth($username, $password) {
// Create accounts for $anonymous and $CONFIG['server_auth_user'] if not exist // Create accounts for $anonymous and $CONFIG['server_auth_user'] if not exist
if($username == strtolower($CONFIG['anonusername'])) { if($username == strtolower($CONFIG['anonusername'])) {
if(filemtime($config_dir."rslight.inc.php") > filemtime($userFilename)) { if(filemtime($config_dir."rslight.inc.php") > filemtime($userFilename)) {
if ($userFileHandle = @fopen($userFilename, 'w+')) if ($userFileHandle = fopen($userFilename, 'w+'))
{ {
fwrite($userFileHandle, password_hash($CONFIG['anonuserpass'], PASSWORD_DEFAULT)); fwrite($userFileHandle, password_hash($CONFIG['anonuserpass'], PASSWORD_DEFAULT));
fclose($userFileHandle); fclose($userFileHandle);
@ -1109,7 +1105,7 @@ function check_bbs_auth($username, $password) {
} }
if($username == strtolower($CONFIG['server_auth_user'])) { if($username == strtolower($CONFIG['server_auth_user'])) {
if(filemtime($config_dir."rslight.inc.php") > filemtime($userFilename)) { if(filemtime($config_dir."rslight.inc.php") > filemtime($userFilename)) {
if ($userFileHandle = @fopen($userFilename, 'w+')) if ($userFileHandle = fopen($userFilename, 'w+'))
{ {
fwrite($userFileHandle, password_hash($CONFIG['server_auth_pass'], PASSWORD_DEFAULT)); fwrite($userFileHandle, password_hash($CONFIG['server_auth_pass'], PASSWORD_DEFAULT));
fclose($userFileHandle); fclose($userFileHandle);
@ -1121,7 +1117,7 @@ function check_bbs_auth($username, $password) {
return FALSE; return FALSE;
} }
if ($userFileHandle = @fopen($userFilename, 'r')) if ($userFileHandle = fopen($userFilename, 'r'))
{ {
$userFileInfo = fread($userFileHandle, filesize($userFilename)); $userFileInfo = fread($userFileHandle, filesize($userFilename));
fclose($userFileHandle); fclose($userFileHandle);
@ -1171,7 +1167,7 @@ function check_encryption_groups($request) {
return TRUE; return TRUE;
} }
} }
fclose($userFileHandle); fclose($groupsFileHandle);
} else { } else {
return FALSE; return FALSE;
} }
@ -1602,7 +1598,7 @@ $logfile=$logdir.'/newsportal.log';
// $loadrate = allowed article request per second // $loadrate = allowed article request per second
$loadrate = .15; $loadrate = .15;
$rate = ($_SESSION['views'] / (time() - $_SESSION['starttime'])); $rate = fdiv($_SESSION['views'], (time() - $_SESSION['starttime']));
if (($rate > $loadrate) && ($_SESSION['views'] > 5)) { if (($rate > $loadrate) && ($_SESSION['views'] > 5)) {
header("HTTP/1.0 429 Too Many Requests"); header("HTTP/1.0 429 Too Many Requests");
if(!isset($_SESSION['throttled'])) { if(!isset($_SESSION['throttled'])) {

View File

@ -210,9 +210,9 @@ foreach($files as $article) {
$ref = preg_split("/[\s]+/", $getrefs[1]); $ref = preg_split("/[\s]+/", $getrefs[1]);
if($getrefs[1] && $refid = get_data_from_msgid($ref[0])) { if($getrefs[1] && $refid = get_data_from_msgid($ref[0])) {
// Check that article to link is new enough for newsportal to display // Check that article to link is new enough for newsportal to display
$groupinfo = file($spooldir.'/'.$refid[newsgroup].'-info.txt'); $groupinfo = file($spooldir.'/'.$refid["newsgroup"].'-info.txt');
$range = explode(' ', $groupinfo[1]); $range = explode(' ', $groupinfo[1]);
if($refid[number] > ($range[0] - 1)) { if($refid['number'] > (intval($range[0]) - 1)) {
$threadref = $ref[0]; $threadref = $ref[0];
} else { } else {
$threadref = false; $threadref = false;
@ -274,6 +274,9 @@ function expire_overboard($cachefile) {
function display_threads($threads, $oldest) { function display_threads($threads, $oldest) {
global $thissite, $logfile, $config_name, $snippetlength, $maxdisplay, $prune, $this_overboard; global $thissite, $logfile, $config_name, $snippetlength, $maxdisplay, $prune, $this_overboard;
echo '<table cellspacing="0" width="100%" class="np_results_table">'; echo '<table cellspacing="0" width="100%" class="np_results_table">';
if(!isset($threads)) {
$threads = (object)[];
}
krsort($threads); krsort($threads);
$results = 0; $results = 0;
foreach($threads as $key => $value) { foreach($threads as $key => $value) {
@ -303,7 +306,7 @@ function display_threads($threads, $oldest) {
echo '<b><a href="'.$url.'"><span>'.mb_decode_mimeheader($target['subject']).'</span></a></b>'; echo '<b><a href="'.$url.'"><span>'.mb_decode_mimeheader($target['subject']).'</span></a></b>';
if(isset($this_overboard['threadlink'][$value])) { if(isset($this_overboard['threadlink'][$value])) {
$thread = get_data_from_msgid($this_overboard['threadlink'][$value]); $thread = get_data_from_msgid($this_overboard['threadlink'][$value]);
echo '<font class="np_ob_group"><a href="article-flat.php?id='.$thread[number].'&group='.rawurlencode($thread[newsgroup]).'#'.$thread[number].'"> (thread)</a></font>'; echo '<font class="np_ob_group"><a href="article-flat.php?id='.$thread['number'].'&group='.rawurlencode($thread['newsgroup']).'#'.$thread['number'].'"> (thread)</a></font>';
} }
echo '</p>'; echo '</p>';
echo '</p><p class=np_ob_group>'; echo '</p><p class=np_ob_group>';
@ -323,7 +326,7 @@ function show_overboard_header($grouplist) {
if (isset($_GET['thisgroup'])) { if (isset($_GET['thisgroup'])) {
echo '<h1 class="np_thread_headline">'; echo '<h1 class="np_thread_headline">';
echo '<a href="'.$file_index.'" target='.$frame['menu'].'>'.basename(getcwd()).'</a> / '; echo '<a href="'.$file_index.'" target='.$frame['menu'].'>'.basename(getcwd()).'</a> / ';
echo '<a href="'.$file_thread.'?group='.rawurlencode($grouplist[0]).'" target='.$frame[content].'>'.htmlspecialchars(group_displaY_name($grouplist[0])).'</a> / '; echo '<a href="'.$file_thread.'?group='.rawurlencode($grouplist[0]).'" target='.$frame["content"].'>'.htmlspecialchars(group_displaY_name($grouplist[0])).'</a> / ';
if (isset($user_time)) { if (isset($user_time)) {
echo ' new messages</h1>'; echo ' new messages</h1>';
} else { } else {
@ -382,7 +385,7 @@ if (isset($_GET['thisgroup'])) {
} }
function show_overboard_footer($stats, $results, $iscached) { function show_overboard_footer($stats, $results, $iscached) {
global $CONFIG,$user_time,$rslight_version; global $user_time,$rslight_version;
if(isset($user_time)) { if(isset($user_time)) {
$recent = 'new'; $recent = 'new';
} else { } else {

View File

@ -37,9 +37,6 @@ $CONFIG = include($config_file);
@$abspeichern=$_REQUEST["abspeichern"]; @$abspeichern=$_REQUEST["abspeichern"];
@$references=$_REQUEST["references"]; @$references=$_REQUEST["references"];
@$id=$_REQUEST["id"]; @$id=$_REQUEST["id"];
$name = trim($name);
if (!isset($group)) $group=$newsgroups; if (!isset($group)) $group=$newsgroups;
include "auth.inc"; include "auth.inc";
@ -56,14 +53,6 @@ if ((isset($post_port)) && ($post_port!=""))
$port=$post_port; $port=$post_port;
include $file_newsportal; include $file_newsportal;
$findsection = get_section_by_group($_REQUEST["group"]);
if(trim($findsection) !== $config_name) {
$newurl = preg_replace("|/$config_name/|", "/$findsection/", $_SERVER['REQUEST_URI']);
header("Location: $newurl");
die();
}
include "head.inc"; include "head.inc";
global $synchro_user,$synchro_pass; global $synchro_user,$synchro_pass;
// check to which groups the user is allowed to post to // check to which groups the user is allowed to post to
@ -105,9 +94,11 @@ $returngroup = preg_split("/( |\,)/", $newsgroups, 2);
echo '</td>'; echo '</td>';
} }
// Pages // Pages
/*
echo '<td class="np_pages" width="100%" align="right">'; echo '<td class="np_pages" width="100%" align="right">';
echo articleflat_pageselect($thisgroup,$id,count($subthread),$first); echo articleflat_pageselect($thisgroup,$id,count($subthread),$first);
echo '</td></tr></table>'; echo '</td></tr></table>';
*/
// has the user write-rights on the newsgroups? // has the user write-rights on the newsgroups?
if((function_exists("npreg_group_has_read_access") && if((function_exists("npreg_group_has_read_access") &&
!npreg_group_has_read_access($newsgroups)) || !npreg_group_has_read_access($newsgroups)) ||
@ -207,7 +198,6 @@ if ($type=="post") {
$error=$text_post["captchafail"]; $error=$text_post["captchafail"];
} }
if ($type=="post") { if ($type=="post") {
if (!$CONFIG['readonly']) { if (!$CONFIG['readonly']) {
// post article to the newsserver // post article to the newsserver
@ -231,9 +221,9 @@ if ($type=="post") {
echo '<p><a href="'.$file_thread.'?group='.urlencode($returngroup[0]).'">'.$text_post["button_back"].'</a> '.$text_post["button_back2"].' '.group_display_name($returngroup[0]).'</p>'; echo '<p><a href="'.$file_thread.'?group='.urlencode($returngroup[0]).'">'.$text_post["button_back"].'</a> '.$text_post["button_back2"].' '.group_display_name($returngroup[0]).'</p>';
return; return;
} }
} }
if(isset($_FILES["photo"]) && $_FILES["photo"]["error"] == 0) { if(isset($_FILES["photo"]) && $_FILES["photo"]["error"] == 0) {
$_FILES[photo][name] = preg_replace('/[^a-zA-Z0-9\.]/', '_', $_FILES[photo][name]); $_FILES['photo']['name'] = preg_replace('/[^a-zA-Z0-9\.]/', '_', $_FILES['photo']['name']);
// There is an attachment to handle // There is an attachment to handle
$message=message_post_with_attachment(quoted_printable_encode($subject), $message=message_post_with_attachment(quoted_printable_encode($subject),
$nemail." (".quoted_printable_encode($name).")", $nemail." (".quoted_printable_encode($name).")",

View File

@ -41,7 +41,7 @@ include "head.inc";
} else { } else {
echo '<td>Search Poster:&nbsp'; echo '<td>Search Poster:&nbsp';
} }
echo '<input name="terms" type="text" id="terms" value="'.$_GET[terms].'"></td>'; echo '<input name="terms" type="text" id="terms" value="'.$_GET['terms'].'"></td>';
echo '</tr><tr></tr><tr><td>'; echo '</tr><tr></tr><tr><td>';
if ($_GET['searchpoint'] == 'Poster') { if ($_GET['searchpoint'] == 'Poster') {
@ -97,7 +97,7 @@ $thissite = '.';
$groupconfig=$config_path."/groups.txt"; $groupconfig=$config_path."/groups.txt";
$title.=' - search results for: '.$_POST[terms]; $title.=' - search results for: '.$_POST['terms'];
include "head.inc"; include "head.inc";
ob_start(); ob_start();

View File

@ -3,7 +3,7 @@ echo '<center>';
$pubkeyfile = getcwd().'/../tmp/pubkey.txt'; $pubkeyfile = getcwd().'/../tmp/pubkey.txt';
if(is_file($pubkeyfile) && (isset($CONFIG['site_shortname']) && $CONFIG['site_shortname'] != '')) { if(is_file($pubkeyfile) && (isset($CONFIG['site_shortname']) && $CONFIG['site_shortname'] != '')) {
echo '<font size="1.5em">'; echo '<font size="1.5em">';
echo '<a href="/tmp/pubkey.txt" target=_blank>'.$CONFIG[site_shortname].'</a>'; echo '<a href="/tmp/pubkey.txt" target=_blank>'.$CONFIG['site_shortname'].'</a>';
echo '<br />'; echo '<br />';
echo '</font>'; echo '</font>';
} }

View File

@ -19,14 +19,19 @@ if(isset($_REQUEST["first"]))
$first=intval($_REQUEST["first"]); $first=intval($_REQUEST["first"]);
if(isset($_REQUEST["last"])) if(isset($_REQUEST["last"]))
$last=intval($_REQUEST["last"]); $last=intval($_REQUEST["last"]);
// Switch to correct section in case group has been moved and link is to old section
$findsection = get_section_by_group($group); $findsection = get_section_by_group($group);
if(trim($findsection) !== $config_name) { if(trim($findsection) !== $config_name) {
$newurl = preg_replace("|/$config_name/|", "/$findsection/", $_SERVER['REQUEST_URI']); if (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] === 'on')
header("Location: $newurl"); $link = "https";
die(); else $link = "http";
$link .= "://";
$link .= $_SERVER['HTTP_HOST'];
$link .= $_SERVER['REQUEST_URI'];
$newurl = preg_replace("|/$config_name/|", "/$findsection/", $link);
header("Location:$newurl");
die();
} }
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';

View File

@ -8,7 +8,9 @@
# Start or verify NNTP server # Start or verify NNTP server
if(isset($CONFIG['enable_nntp']) && $CONFIG['enable_nntp'] == true) { if(isset($CONFIG['enable_nntp']) && $CONFIG['enable_nntp'] == true) {
# Create group list for nntp.php # Create group list for nntp.php
$fp1=fopen($spooldir."/".$config_name."/groups.txt", 'w'); $fp1=$spooldir."/".$config_name."/groups.txt";
unlink($fp1);
touch($fp1);
foreach($menulist as $menu) { foreach($menulist as $menu) {
if(($menu[0] == '#') || trim($menu) == "") { if(($menu[0] == '#') || trim($menu) == "") {
continue; continue;
@ -21,11 +23,10 @@
continue; continue;
} }
$ok_group = preg_split("/( |\t)/", trim($ok_group), 2); $ok_group = preg_split("/( |\t)/", trim($ok_group), 2);
fputs($fp1, $ok_group[0]."\r\n"); file_put_contents($fp1, $ok_group[0]."\r\n", FILE_APPEND);
} }
} }
} }
fclose($fp1);
exec($CONFIG['php_exec']." ".$config_dir."/scripts/nntp.php > /dev/null 2>&1"); exec($CONFIG['php_exec']." ".$config_dir."/scripts/nntp.php > /dev/null 2>&1");
if(is_numeric($CONFIG['local_ssl_port'])) { if(is_numeric($CONFIG['local_ssl_port'])) {
exec($CONFIG['php_exec']." ".$config_dir."/scripts/nntp-ssl.php > /dev/null 2>&1"); exec($CONFIG['php_exec']." ".$config_dir."/scripts/nntp-ssl.php > /dev/null 2>&1");

View File

@ -57,7 +57,7 @@
{ {
GLOBAL $__server_listening; GLOBAL $__server_listening;
GLOBAL GLOBAL
$CONFIG,$logdir,$lockdir,$ssldir,$webserver_uid,$webserver_gid,$installed_path, $CONFIG,$logdir,$lockdir,$webserver_uid,$webserver_gid,$installed_path,
$config_path,$groupconfig,$workpath,$path,$spooldir,$nntp_group,$auth_ok; $config_path,$groupconfig,$workpath,$path,$spooldir,$nntp_group,$auth_ok;
$logfile=$logdir.'/nntp.log'; $logfile=$logdir.'/nntp.log';
$lockfile = $lockdir . '/rslight-nntp-ssl.lock'; $lockfile = $lockdir . '/rslight-nntp-ssl.lock';
@ -73,10 +73,10 @@ $config_path,$groupconfig,$workpath,$path,$spooldir,$nntp_group,$auth_ok;
$auth_ok = 0; $auth_ok = 0;
$user = ""; $user = "";
$pass = ""; $pass = "";
$pemfile = $spooldir.'/server.pem';
$pemfile = $ssldir.'/server.pem'; if(!is_file($pemfile)) {
create_node_ssl_cert($pemfile); create_certificate($pemfile);
}
$context = stream_context_create(); $context = stream_context_create();
stream_context_set_option($context, 'ssl', 'local_cert', $pemfile); stream_context_set_option($context, 'ssl', 'local_cert', $pemfile);
stream_context_set_option($context, 'ssl', 'allow_self_signed', true); stream_context_set_option($context, 'ssl', 'allow_self_signed', true);
@ -159,4 +159,32 @@ $config_path,$groupconfig,$workpath,$path,$spooldir,$nntp_group,$auth_ok;
fclose($csock); fclose($csock);
} }
} }
function create_certificate($pemfile) {
global $CONFIG;
$certificateData = array(
"countryName" => "US",
"stateOrProvinceName" => "New York",
"localityName" => "New York City",
"organizationName" => "Rocksolid",
"organizationalUnitName" => "Rocksolid Light",
"commonName" => $CONFIG['organization'],
"emailAddress" => "rocksolid@example.com"
);
// Generate certificate
$privateKey = openssl_pkey_new();
$certificate = openssl_csr_new($certificateData, $privateKey);
$certificate = openssl_csr_sign($certificate, null, $privateKey, 365);
// Generate PEM file
$pem_passphrase = null; // empty for no passphrase
$pem = array();
openssl_x509_export($certificate, $pem[0]);
openssl_pkey_export($privateKey, $pem[1], $pem_passphrase);
$pem = implode($pem);
// Save PEM file
file_put_contents($pemfile, $pem);
}
?> ?>

View File

@ -216,7 +216,7 @@ set_time_limit(0);
if ($command[0] == 'quit') { if ($command[0] == 'quit') {
$msg = "205 closing connection - goodbye!\r\n"; $msg = "205 closing connection - goodbye!\r\n";
fwrite($msgsock, $msg, strlen($msg)); fwrite($msgsock, $msg, strlen($msg));
socket_close($msgsock); // socket_close($msgsock);
exit(0); exit(0);
} }
file_put_contents($logfile, "\n".format_log_date()." Syntax error: ".$buf, FILE_APPEND); file_put_contents($logfile, "\n".format_log_date()." Syntax error: ".$buf, FILE_APPEND);
@ -353,7 +353,7 @@ function process_post($message, $group) {
} }
} }
} }
rewind($message); // rewind($message);
/* /*
* SPAM CHECK * SPAM CHECK
*/ */
@ -599,11 +599,11 @@ function get_title($mode) {
$msg="481 descriptions unavailable\r\n"; $msg="481 descriptions unavailable\r\n";
return $msg; return $msg;
} }
$title = file_get_contents($spooldir."/".$mode."-title", IGNORE_NEW_LINES); $title = file_get_contents($spooldir."/".$mode."-title");
$msg="282 list of group and description follows\r\n"; $msg="282 list of group and description follows\r\n";
$msg.=$title; $msg.=$title;
$msg.=".\r\n"; $msg.="\r\n.\r\n";
return $msg; return $msg;
} }
@ -1073,13 +1073,6 @@ $date_i,$mid_i,$references_i,$bytes_i,$lines_i,$xref_i,$body) {
} }
$nocem_check="@@NCM"; $nocem_check="@@NCM";
$article_date=strtotime($date_i); $article_date=strtotime($date_i);
# Check if group exists. Open it if it does
fputs($ns, "group ".$nntp_group."\r\n");
$response = line_read($ns);
if (strcmp(substr($response,0,3),"411") == 0) {
unlink($sn_lockfile);
return(1);
}
$grouplist = file($local_groupfile, FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES); $grouplist = file($local_groupfile, FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
foreach($grouplist as $findgroup) { foreach($grouplist as $findgroup) {
$name = explode(':', $findgroup); $name = explode(':', $findgroup);
@ -1218,7 +1211,7 @@ function create_node_ssl_cert($pemfile) {
$uinfo=posix_getpwnam($CONFIG['webserver_user']); $uinfo=posix_getpwnam($CONFIG['webserver_user']);
$pubkeyfile = $ssldir.'/pubkey.pem'; $pubkeyfile = $ssldir.'/pubkey.pem';
$pubkeytxtfile = $webtmp.'/pubkey.txt'; $pubkeytxtfile = $webtmp.'/pubkey.txt';
$ssltime = filectime($letsencrypt['path'])."fullchain.pem"; $ssltime = filectime($letsencrypt['path'])."fullchain.pem";
if(isset($letsencrypt['path'])) { if(isset($letsencrypt['path'])) {
if($ssltime > filectime($pemfile)) { if($ssltime > filectime($pemfile)) {
touch($config_dir.'/ssl.reload'); touch($config_dir.'/ssl.reload');
@ -1226,53 +1219,53 @@ function create_node_ssl_cert($pemfile) {
} }
if(!file_exists($config_dir.'/ssl.reload')) { if(!file_exists($config_dir.'/ssl.reload')) {
if((is_file($pemfile)) && (is_file($pubkeyfile)) && (is_file($pubkeytxtfile))) { if((is_file($pemfile)) && (is_file($pubkeyfile)) && (is_file($pubkeytxtfile))) {
if(md5_file($pubkeyfile) == md5_file($pubkeytxtfile)) { if(md5_file($pubkeyfile) == md5_file($pubkeytxtfile)) {
return; return;
} }
} }
} }
@unlink($config_dir.'/ssl.reload'); @unlink($config_dir.'/ssl.reload');
unlink($pemfile); unlink($pemfile);
unlink($pubkeyfile); unlink($pubkeyfile);
unlink($pubkeytxtfile); unlink($pubkeytxtfile);
/* Use letsencrypt */ /* Use letsencrypt */
if((isset($letsencrypt['server.pem'])) && (isset($letsencrypt['pubkey.pem']))) { if((isset($letsencrypt['server.pem'])) && (isset($letsencrypt['pubkey.pem']))) {
file_put_contents($pemfile, $letsencrypt['server.pem'].$letsencrypt['privkey']); file_put_contents($pemfile, $letsencrypt['server.pem'].$letsencrypt['privkey']);
file_put_contents($pubkeyfile, $letsencrypt['pubkey.pem']); file_put_contents($pubkeyfile, $letsencrypt['pubkey.pem']);
file_put_contents($pubkeytxtfile, $letsencrypt['pubkey.pem']); file_put_contents($pubkeytxtfile, $letsencrypt['pubkey.pem']);
touch($pemfile, $ssltime); touch($pemfile, $ssltime);
touch($pubkeyfile, $ssltime); touch($pubkeyfile, $ssltime);
touch($pubkeytxtfile, $ssltime); touch($pubkeytxtfile, $ssltime);
} else { } else {
/* Create self signed cert */ /* Create self signed cert */
$certificateData = array( $certificateData = array(
"countryName" => "US", "countryName" => "US",
"stateOrProvinceName" => "New York", "stateOrProvinceName" => "New York",
"localityName" => "New York City", "localityName" => "New York City",
"organizationName" => "Rocksolid", "organizationName" => "Rocksolid",
"organizationalUnitName" => "Rocksolid Light", "organizationalUnitName" => "Rocksolid Light",
"commonName" => $CONFIG['organization'], "commonName" => $CONFIG['organization'],
"emailAddress" => "rocksolid@example.com" "emailAddress" => "rocksolid@example.com"
); );
// Generate certificate // Generate certificate
$privateKey = openssl_pkey_new(); $privateKey = openssl_pkey_new();
$certificate = openssl_csr_new($certificateData, $privateKey); $certificate = openssl_csr_new($certificateData, $privateKey);
$certificate = openssl_csr_sign($certificate, null, $privateKey, 365); $certificate = openssl_csr_sign($certificate, null, $privateKey, 365);
// Generate PEM file // Generate PEM file
$pem_passphrase = null; // empty for no passphrase $pem_passphrase = null; // empty for no passphrase
$pem = array(); $pem = array();
openssl_x509_export($certificate, $pem[0]); openssl_x509_export($certificate, $pem[0]);
openssl_pkey_export($privateKey, $pem[1], $pem_passphrase); openssl_pkey_export($privateKey, $pem[1], $pem_passphrase);
$pem = implode($pem); $pem = implode($pem);
$pubkey=openssl_pkey_get_details($privateKey); $pubkey=openssl_pkey_get_details($privateKey);
// Save PEM file // Save PEM file
file_put_contents($pemfile, $pem); file_put_contents($pemfile, $pem);
file_put_contents($pubkeyfile, $pubkey['key']); file_put_contents($pubkeyfile, $pubkey['key']);
file_put_contents($pubkeytxtfile, $pubkey['key']); file_put_contents($pubkeytxtfile, $pubkey['key']);
} }
chown($pemfile, $uinfo["uid"]); chown($pemfile, $uinfo["uid"]);
chown($pubkeyfile, $uinfo["uid"]); chown($pubkeyfile, $uinfo["uid"]);

View File

@ -32,13 +32,11 @@ $logfile=$logdir.'/spoolnews.log';
$lockfile = $lockdir . '/rslight-send.lock'; $lockfile = $lockdir . '/rslight-send.lock';
$pid = file_get_contents($lockfile); $pid = file_get_contents($lockfile);
if (posix_getsid($pid) === false || !is_file($lockfile)) { if (posix_getsid($pid) === false || !is_file($lockfile)) {
file_put_contents($logfile, "\n".format_log_date()." ".$config_name." Starting Send...", FILE_APPEND);
print "Starting Send...\n"; print "Starting Send...\n";
file_put_contents($lockfile, getmypid()); // create lockfile file_put_contents($lockfile, getmypid()); // create lockfile
} else { } else {
file_put_contents($logfile, "\n".format_log_date()." ".$config_name." Send currently running...", FILE_APPEND); print "Send currently running\n";
print "Send currently running\n"; exit;
exit;
} }
$ns=nntp2_open($CONFIG['remote_server'], $CONFIG['remote_port']); $ns=nntp2_open($CONFIG['remote_server'], $CONFIG['remote_port']);
if($ns == false) { if($ns == false) {
@ -49,24 +47,19 @@ echo "\nPosting articles\r\n";
post_articles($ns, $spooldir); post_articles($ns, $spooldir);
nntp_close($ns); nntp_close($ns);
unlink($lockfile); unlink($lockfile);
file_put_contents($logfile, "\n".format_log_date()." ".$config_name." Exiting Send...", FILE_APPEND);
echo "\nSend Done\r\n"; echo "\nSend Done\r\n";
function post_articles($ns, $spooldir) { function post_articles($ns, $spooldir) {
global $logfile,$config_name; global $logfile,$config_name;
if(!is_dir($spooldir."/".$config_name."/outgoing/")) { if(!is_dir($spooldir."/".$config_name."/outgoing/")) {
file_put_contents($logfile, "\n".format_log_date()." ".$config_name." No messages to send", FILE_APPEND); return "No messages to send\r\n";
return "No messages to send\r\n";
} }
$outgoing_dir = $spooldir."/".$config_name."/outgoing/"; $outgoing_dir = $spooldir."/".$config_name."/outgoing/";
$failed_dir = $outgoing_dir.'/failed';
@mkdir($failed_dir);
$messages = scandir($outgoing_dir); $messages = scandir($outgoing_dir);
foreach($messages as $message) { foreach($messages as $message) {
if(!is_file($outgoing_dir.$message)) { if(!is_file($outgoing_dir.$message)) {
continue; continue;
} }
file_put_contents($logfile, "\n".format_log_date()." ".$config_name." Sending: ".$outgoing_dir.$message, FILE_APPEND);
echo "Sending: ".$outgoing_dir.$message."\r\n"; echo "Sending: ".$outgoing_dir.$message."\r\n";
fputs($ns, "MODE READER\r\n"); fputs($ns, "MODE READER\r\n");
$response = line_read($ns); $response = line_read($ns);
@ -92,7 +85,6 @@ function post_articles($ns, $spooldir) {
file_put_contents($logfile, "\n".format_log_date()." ".$config_name." Posted: ".$message.": ".$response, FILE_APPEND); file_put_contents($logfile, "\n".format_log_date()." ".$config_name." Posted: ".$message.": ".$response, FILE_APPEND);
} else { } else {
file_put_contents($logfile, "\n".format_log_date()." ".$config_name." Failed to POST: ".$message.": ".$response, FILE_APPEND); file_put_contents($logfile, "\n".format_log_date()." ".$config_name." Failed to POST: ".$message.": ".$response, FILE_APPEND);
rename($outgoing_dir.$message, $failed_dir.'/'.$message);
continue; continue;
} }
} }

View File

@ -24,7 +24,6 @@ return [
'server_auth_pass' => 'The password for the local server user', 'server_auth_pass' => 'The password for the local server user',
# Site configuration # Site configuration
'site_shortname' => 'Must be unique from other rslight sites. Blank to disable',
'rslight_title' => 'The tagline at the top of the web page', 'rslight_title' => 'The tagline at the top of the web page',
'title_full' => 'The site title in the client browser bar', 'title_full' => 'The site title in the client browser bar',
'hide_email' => 'Truncate email addresses in From header (1=true, blank=false)', 'hide_email' => 'Truncate email addresses in From header (1=true, blank=false)',

View File

@ -23,8 +23,6 @@
include "config.inc.php"; include "config.inc.php";
include ("$file_newsportal"); include ("$file_newsportal");
set_time_limit(900);
$remote_groupfile=$spooldir."/".$config_name."/".$CONFIG['remote_server'].":".$CONFIG['remote_port'].".txt"; $remote_groupfile=$spooldir."/".$config_name."/".$CONFIG['remote_server'].":".$CONFIG['remote_port'].".txt";
$file_groups=$config_path."groups.txt"; $file_groups=$config_path."groups.txt";
$local_groupfile=$spooldir."/".$config_name."/local_groups.txt"; $local_groupfile=$spooldir."/".$config_name."/local_groups.txt";
@ -57,21 +55,18 @@ if (posix_getsid($pid) === false || !is_file($lockfile)) {
print "Spoolnews currently running\n"; print "Spoolnews currently running\n";
exit; exit;
} }
$sem = $spooldir."/".$config_name.".reload"; $sem = $spooldir."/".$config_name.".reload";
if(is_file($sem)) { if(is_file($sem)) {
unlink($remote_groupfile); unlink($remote_groupfile);
unlink($sem); unlink($sem);
$maxfirstrequest = 20; $maxfirstrequest = 20;
} }
if(filemtime($spooldir.'/'.$config_name.'-thread-timer')+600 < time()) { if(filemtime($spooldir.'/'.$config_name.'-thread-timer')+600 < time()) {
$timer=true; $timer=true;
touch($spooldir.'/'.$config_name.'-thread-timer'); touch($spooldir.'/'.$config_name.'-thread-timer');
} else { } else {
$timer=false; $timer=false;
} }
# Check for groups file, create if necessary # Check for groups file, create if necessary
create_spool_groups($file_groups, $remote_groupfile); create_spool_groups($file_groups, $remote_groupfile);
create_spool_groups($file_groups, $local_groupfile); create_spool_groups($file_groups, $local_groupfile);
@ -195,7 +190,6 @@ function get_articles($ns, $group) {
# Pull articles and save them in our spool # Pull articles and save them in our spool
@mkdir($grouppath,0755,'recursive'); @mkdir($grouppath,0755,'recursive');
$i=0; $i=0;
$nsfail=0;
while ($article <= $detail[3]) { while ($article <= $detail[3]) {
if(!is_numeric($article)) { if(!is_numeric($article)) {
file_put_contents($logfile, "\n".format_log_date()." ".$config_name." DEBUG This should show server group:article number: ".$CONFIG['remote_server']." ".$group.":".$article, FILE_APPEND); file_put_contents($logfile, "\n".format_log_date()." ".$config_name." DEBUG This should show server group:article number: ".$CONFIG['remote_server']." ".$group.":".$article, FILE_APPEND);
@ -209,8 +203,9 @@ function get_articles($ns, $group) {
fputs($ns, "stat ".$article."\r\n"); fputs($ns, "stat ".$article."\r\n");
$response = line_read($ns); $response = line_read($ns);
$this_msgid = explode(' ', $response); $this_msgid = explode(' ', $response);
$group_overviewfp=fopen($spooldir."/".$group."-overview", 'r'); $group_overviewfile = $spooldir."/".$group."-overview";
while($group_overview=fgets($group_overviewfp, 2048)) { $gover = file($group_overviewfile);
foreach($gover as $group_overview) {
$overview_msgid = explode("\t", $group_overview); $overview_msgid = explode("\t", $group_overview);
if(strpos($overview_msgid[4], $this_msgid[2]) !== false) { if(strpos($overview_msgid[4], $this_msgid[2]) !== false) {
echo "\nDuplicate Message-ID for: ".$CONFIG['remote_server']." ".$group.":".$article."\n"; echo "\nDuplicate Message-ID for: ".$CONFIG['remote_server']." ".$group.":".$article."\n";
@ -220,7 +215,6 @@ function get_articles($ns, $group) {
break; break;
} }
} }
fclose($group_overviewfp);
if($duplicate == 1) { if($duplicate == 1) {
continue; continue;
} }
@ -314,12 +308,7 @@ function get_articles($ns, $group) {
file_put_contents($logfile, "\n".format_log_date()." ".$config_name." Lost connection to ".$CONFIG['remote_server'].":".$CONFIG['remote_port']." retrieving article ".$article, FILE_APPEND); file_put_contents($logfile, "\n".format_log_date()." ".$config_name." Lost connection to ".$CONFIG['remote_server'].":".$CONFIG['remote_port']." retrieving article ".$article, FILE_APPEND);
@fclose($articleHandle); @fclose($articleHandle);
unlink($grouppath."/".$local); unlink($grouppath."/".$local);
$nsfail++; continue;
if($nsfail > 3){
break;
} else {
continue;
}
} }
$response=str_replace("\n","",str_replace("\r","",$response)); $response=str_replace("\n","",str_replace("\r","",$response));
} }
@ -375,14 +364,13 @@ function get_articles($ns, $group) {
fputs($ns, "XGTITLE ".$group."\r\n"); fputs($ns, "XGTITLE ".$group."\r\n");
$response = line_read($ns); $response = line_read($ns);
if (strcmp(substr($response,0,3),"282") == 0) { if (strcmp(substr($response,0,3),"282") == 0) {
$overviewHandle = fopen($workpath.$group."-title", 'w'); $titlefile = $workpath.$group."-title";
$response = line_read($ns); $response = line_read($ns);
while(strcmp($response,".") != 0) while(strcmp($response,".") != 0)
{ {
fputs($overviewHandle, $response."\r\n"); file_put_contents($titlefile, $response);
$response = line_read($ns); $response = line_read($ns);
} }
@fclose($overviewHandle);
} }
} }
# Save config # Save config
@ -463,15 +451,15 @@ function get_high_watermark($group) {
function get_article_list($thisgroup) { function get_article_list($thisgroup) {
global $spooldir; global $spooldir;
$group_overviewfp=fopen($spooldir."/".$thisgroup."-overview", 'r'); $group_overview_file = $spooldir."/".$thisgroup."-overview";
$ok_article=array(); $ok_article=array();
while($line = fgets($group_overviewfp)) { $getline = file($group_overview_file);
foreach($getline as $line) {
$art=explode("\t", $line); $art=explode("\t", $line);
if(is_numeric($art[0])) { if(is_numeric($art[0])) {
$ok_article[] = $art[0]; $ok_article[] = $art[0];
} }
} }
fclose($group_overviewfp);
return($ok_article); return($ok_article);
} }

View File

@ -16,14 +16,13 @@ include "newsportal.php";
$getfh = fopen($getfilename, "rb"); $getfh = fopen($getfilename, "rb");
$getfile = fread($getfh, filesize($getfilename)); $getfile = fread($getfh, filesize($getfilename));
fclose($getfh); fclose($getfh);
header('Content-type: '.$_REQUEST[contenttype]); header('Content-type: '.$_REQUEST['contenttype']);
header('Content-disposition: filename="'.$_REQUEST[showfilename].'"'); header('Content-disposition: filename="'.$_REQUEST['showfilename'].'"');
file_put_contents($logfile, "\n".format_log_date()." Requesting: ".$_REQUEST['showfile'], FILE_APPEND); file_put_contents($logfile, "\n".format_log_date()." Requesting: ".$_REQUEST['showfile'], FILE_APPEND);
echo $getfile; echo $getfile;
exit(0); exit(0);
} }
$title.=' - Browse files'; $title.=' - Browse files';
include "head.inc"; include "head.inc";
echo '<table cellpadding="0" cellspacing="0" class="np_buttonbar"><tr>'; echo '<table cellpadding="0" cellspacing="0" class="np_buttonbar"><tr>';

View File

@ -43,24 +43,24 @@ include "head.inc";
echo '<hr>'; echo '<hr>';
if(isset($_FILES)) { if(isset($_FILES)) {
$_FILES[photo][name] = preg_replace('/[^a-zA-Z0-9\.]/', '_', $_FILES[photo][name]); $_FILES['photo']['name'] = preg_replace('/[^a-zA-Z0-9\.]/', '_', $_FILES['photo']['name']);
// Check auth here // Check auth here
if(isset($_POST['key']) && password_verify($CONFIG['thissitekey'].$_POST['username'], $_POST['key'])) { if(isset($_POST['key']) && password_verify($CONFIG['thissitekey'].$_POST['username'], $_POST['key'])) {
if(check_bbs_auth($_POST['username'], $_POST['password'])) { if(check_bbs_auth($_POST['username'], $_POST['password'])) {
$userdir = $spooldir.'/upload/'.strtolower($_POST[username]); $userdir = $spooldir.'/upload/'.strtolower($_POST['username']);
$upload_to = $userdir.'/'.$_FILES[photo][name]; $upload_to = $userdir.'/'.$_FILES['photo']['name'];
if(is_file($upload_to)) { if(is_file($upload_to)) {
echo $_FILES[photo][name].' already exists in your folder'; echo $_FILES['photo']['name'].' already exists in your folder';
} else { } else {
if(!is_dir($userdir)) { if(!is_dir($userdir)) {
mkdir($userdir); mkdir($userdir);
} }
$success = move_uploaded_file($_FILES[photo][tmp_name], $upload_to); $success = move_uploaded_file($_FILES['photo']['tmp_name'], $upload_to);
if ($success) { if ($success) {
file_put_contents($logfile, "\n".format_log_date()." Saved: ".strtolower($_POST['username'])."/".$_FILES[photo][name], FILE_APPEND); file_put_contents($logfile, "\n".format_log_date()." Saved: ".strtolower($_POST['username'])."/".$_FILES['photo']['name'], FILE_APPEND);
echo 'Saved '.$_FILES[photo][name].' to your files folder'; echo 'Saved '.$_FILES['photo']['name'].' to your files folder';
} else { } else {
echo 'There was an error saving '.$_FILES[photo][name]; echo 'There was an error saving '.$_FILES['photo']['name'];
} }
} }
$authkey = password_hash($_POST['username'].$keys[0].get_user_config($_POST['username'],'encryptionkey'), PASSWORD_DEFAULT); $authkey = password_hash($_POST['username'].$keys[0].get_user_config($_POST['username'],'encryptionkey'), PASSWORD_DEFAULT);

View File

@ -124,9 +124,10 @@ echo '</table>';
$_SESSION['username'] = $user; $_SESSION['username'] = $user;
unset($user_config); unset($user_config);
$userfile=$spooldir.'/'.$user.'-articleviews.dat'; $userfile=$spooldir.'/'.$user.'-articleviews.dat';
$userdata = unserialize(file_get_contents($userfile)); if(is_file($userfile)) {
ksort($userdata); $userdata = unserialize(file_get_contents($userfile));
ksort($userdata);
}
// Apply Config // Apply Config
if(isset($_POST['command']) && $_POST['command'] == 'SaveConfig') { if(isset($_POST['command']) && $_POST['command'] == 'SaveConfig') {
$user_config['signature'] = $_POST['signature']; $user_config['signature'] = $_POST['signature'];
@ -149,7 +150,7 @@ echo '</table>';
file_put_contents($spooldir.'/'.$user.'-articleviews.dat', serialize($newsubs)); file_put_contents($spooldir.'/'.$user.'-articleviews.dat', serialize($newsubs));
$userdata = unserialize(file_get_contents($userfile)); $userdata = unserialize(file_get_contents($userfile));
ksort($userdata); ksort($userdata);
echo 'Configuration Saved for '.$_POST[username]; echo 'Configuration Saved for '.$_POST['username'];
} else { } else {
$user_config = unserialize(file_get_contents($config_dir.'/userconfig/'.$user.'.config')); $user_config = unserialize(file_get_contents($config_dir.'/userconfig/'.$user.'.config'));
} }
@ -163,7 +164,7 @@ echo '</table>';
} }
$themes[] = $theme_dir; $themes[] = $theme_dir;
} }
closedir($theme_dir); closedir($theme_list);
} }
} }
sort($themes); sort($themes);
@ -171,17 +172,17 @@ echo '</table>';
// Show Config // Show Config
echo '<hr><h1 class="np_thread_headline">Configuration:</h1>'; echo '<hr><h1 class="np_thread_headline">Configuration:</h1>';
echo '<table cellspacing="0" width="100%" class="np_results_table">'; echo '<table cellspacing="0" width="100%" class="np_results_table">';
echo '<tr class="np_thread_head"><td class="np_thread_head">Settings for '.$_POST[username].' (leave blank for none):</td></tr>'; echo '<tr class="np_thread_head"><td class="np_thread_head">Settings for '.$_POST['username'].' (leave blank for none):</td></tr>';
echo '<form method="post" action="user.php">'; echo '<form method="post" action="user.php">';
echo '<tr class="np_result_line1">'; echo '<tr class="np_result_line1">';
// Signature // Signature
echo '<td class="np_result_line1" style="word-wrap:break-word";>Signature:</td>'; echo '<td class="np_result_line1" style="word-wrap:break-word";>Signature:</td>';
echo '</tr><tr><td class="np_result_line1" style="word-wrap:break-word";><textarea class="configuration" id="signature" name="signature" rows="6" cols="70">'.$user_config[signature]; echo '</tr><tr><td class="np_result_line1" style="word-wrap:break-word";><textarea class="configuration" id="signature" name="signature" rows="6" cols="70">'.$user_config['signature'];
echo '</textarea></td>'; echo '</textarea></td>';
echo '</tr>'; echo '</tr>';
// X-Face // X-Face
echo '<td class="np_result_line1" style="word-wrap:break-word";>X-Face:</td>'; echo '<td class="np_result_line1" style="word-wrap:break-word";>X-Face:</td>';
echo '</tr><tr><td class="np_result_line1" style="word-wrap:break-word";><textarea class="configuration" id="xface" name="xface" rows="4" cols="80">'.$user_config[xface]; echo '</tr><tr><td class="np_result_line1" style="word-wrap:break-word";><textarea class="configuration" id="xface" name="xface" rows="4" cols="80">'.$user_config['xface'];
echo '</textarea></td>'; echo '</textarea></td>';
echo '</tr>'; echo '</tr>';
// Theme // Theme