/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"); } } # Generate user count file (must be root) exec($CONFIG['php_exec']." ".$config_dir."/scripts/count_users.php"); echo "Updated user count\n"; /* 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) { $log_files = array('nntp.log', 'spoolnews.log', 'nocem.log', 'newsportal.log', 'expire.log'); 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; } } ?>