First mods for php8.2.
This commit is contained in:
parent
832316a13e
commit
0683f8ddd0
|
@ -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';
|
||||||
}
|
}
|
||||||
|
|
|
@ -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">';
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 />';
|
||||||
|
|
|
@ -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>';
|
||||||
|
|
|
@ -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';
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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">';
|
||||||
?>
|
|
||||||
|
|
|
@ -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'])) {
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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).")",
|
||||||
|
|
|
@ -41,7 +41,7 @@ include "head.inc";
|
||||||
} else {
|
} else {
|
||||||
echo '<td>Search Poster: ';
|
echo '<td>Search Poster: ';
|
||||||
}
|
}
|
||||||
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();
|
||||||
|
|
|
@ -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>';
|
||||||
}
|
}
|
||||||
|
|
|
@ -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';
|
||||||
|
|
|
@ -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");
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
?>
|
?>
|
||||||
|
|
|
@ -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"]);
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)',
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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>';
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue