2020-11-29 01:55:31 +01:00
|
|
|
<?php
|
|
|
|
// This file runs maintenance scripts and should be executed by cron regularly
|
|
|
|
include "config.inc.php";
|
|
|
|
|
|
|
|
$menulist = file($config_dir."menu.conf", FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
|
|
|
|
|
|
|
|
# Start or verify NNTP server
|
|
|
|
if(isset($CONFIG['enable_nntp']) && $CONFIG['enable_nntp'] == true) {
|
|
|
|
# Create group list for nntp.php
|
|
|
|
$fp1=fopen($spooldir."/".$config_name."/groups.txt", 'w');
|
|
|
|
foreach($menulist as $menu) {
|
|
|
|
if(($menu[0] == '#') || trim($menu) == "") {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$menuitem=explode(':', $menu);
|
|
|
|
if($menuitem[2] == '1') {
|
|
|
|
$in_gl = file($config_dir.$menuitem[0]."/groups.txt");
|
|
|
|
foreach($in_gl as $ok_group) {
|
|
|
|
if(($ok_group[0] == ':') || (trim($ok_group) == "")) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if(strpos($ok_group, "\t") == false) {
|
|
|
|
$ok_group=preg_replace('/ /', "\t", $ok_group, 1);
|
|
|
|
}
|
|
|
|
fputs($fp1, $ok_group);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fclose($fp1);
|
|
|
|
exec($CONFIG['php_exec']." ".$config_dir."scripts/nntp.php > /dev/null 2>&1");
|
|
|
|
if(is_numeric($CONFIG['local_ssl_port'])) {
|
|
|
|
exec($CONFIG['php_exec']." ".$config_dir."scripts/nntp-ssl.php > /dev/null 2>&1");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* Change to non root user */
|
|
|
|
$uinfo=posix_getpwnam($CONFIG['webserver_user']);
|
|
|
|
change_identity($uinfo["uid"],$uinfo["gid"]);
|
|
|
|
/* Everything below runs as $CONFIG['webserver_user'] */
|
|
|
|
|
|
|
|
@mkdir($spooldir."/log/",0755,'recursive');
|
|
|
|
|
|
|
|
if(isset($CONFIG['enable_nocem']) && $CONFIG['enable_nocem'] == true) {
|
|
|
|
@mkdir($spooldir."nocem",0755,'recursive');
|
|
|
|
exec($CONFIG['php_exec']." ".$config_dir."scripts/nocem.php");
|
|
|
|
}
|
|
|
|
|
|
|
|
reset($menulist);
|
|
|
|
foreach($menulist as $menu) {
|
|
|
|
if(($menu[0] == '#') || (trim($menu) == "")) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$menuitem=explode(':', $menu);
|
|
|
|
chdir("../".$menuitem[0]);
|
|
|
|
# Send articles
|
|
|
|
echo "Sending articles\n";
|
|
|
|
echo exec($CONFIG['php_exec']." ".$config_dir."scripts/send.php");
|
|
|
|
# Refresh spool
|
|
|
|
if(isset($spoolnews) && ($spoolnews == true)) {
|
|
|
|
exec($CONFIG['php_exec']." ".$config_dir."scripts/spoolnews.php");
|
|
|
|
echo "Refreshed spoolnews\n";
|
|
|
|
}
|
|
|
|
# Expire articles
|
|
|
|
exec($CONFIG['php_exec']." ".$config_dir."scripts/expire.php");
|
|
|
|
echo "Expired articles\n";
|
|
|
|
}
|
|
|
|
# Rotate log files
|
|
|
|
log_rotate();
|
|
|
|
echo "Log files rotated\n";
|
|
|
|
|
|
|
|
function log_rotate() {
|
|
|
|
global $logdir;
|
|
|
|
$rotate = filemtime($logdir.'/rotate');
|
|
|
|
if((time() - $rotate) > 86400) {
|
2020-12-25 09:46:13 +01:00
|
|
|
$log_files = array('nntp.log', 'spoolnews.log', 'nocem.log', 'newsportal.log', 'expire.log');
|
2020-11-29 01:55:31 +01:00
|
|
|
foreach($log_files as $logfile) {
|
|
|
|
$logfile=$logdir.'/'.$logfile;
|
|
|
|
if(!is_file($logfile)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
@unlink($logfile.'.5');
|
|
|
|
@rename($logfile.'.4', $logfile.'.5');
|
|
|
|
@rename($logfile.'.3', $logfile.'.4');
|
|
|
|
@rename($logfile.'.2', $logfile.'.3');
|
|
|
|
@rename($logfile.'.1', $logfile.'.2');
|
|
|
|
@rename($logfile, $logfile.'.1');
|
|
|
|
echo 'Rotated: '.$logfile."\n";
|
|
|
|
}
|
|
|
|
unlink($logdir.'/rotate');
|
|
|
|
touch($logdir.'/rotate');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function change_identity( $uid, $gid )
|
|
|
|
{
|
|
|
|
if( !posix_setgid( $gid ) )
|
|
|
|
{
|
|
|
|
print "Unable to setgid to " . $gid . "!\n";
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( !posix_setuid( $uid ) )
|
|
|
|
{
|
|
|
|
print "Unable to setuid to " . $uid . "!\n";
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|