if (!empty($opts['send-to'])) {
$this->send_to = $opts['send-to'];
}
-
+
+ $w = DB_DataObject::factory('core_notify_recur');
+ $w->generateNotifications();
+
//DB_DataObject::debugLevel(1);
$w = DB_DataObject::factory($this->table);
$php = $_SERVER["_"];
$sn = $_SERVER["SCRIPT_NAME"];
- $cwd = $sn[0] == '/' ? dirname($sn) : dirname(realpath(getcwd() . $sn)); // same as run on.. (so script should end up being same relatively..)
+ $cwd = $sn[0] == '/' ? dirname($sn) : dirname(realpath(getcwd() . '/'. $sn)); // same as run on.. (so script should end up being same relatively..)
$app = $cwd . '/' . basename($_SERVER["SCRIPT_NAME"]) . ' ' . $this->target . '/'. $id;
if ($this->force) {
$app .= ' -f';
if (!empty($this->send_to)) {
$app .= ' --sent-to='.escapeshellarg($this->send_to);
}
- $cmd = $php . ' ' . $app. ' &';
+ $cmd = $php . ' ' . $app; //. ' &';
$pipe = array();
+ echo "call proc_open $cmd\n";
$p = proc_open($cmd, $descriptorspec, $pipes, $cwd );
$info = proc_get_status($p);
$this->pool[] = array(
'out' => $tn,
'cmd' => $cmd,
'email' => $email,
- 'pipes' => $pipes
+ 'pipes' => $pipes,
+ 'started' => time()
);
{
$pool = array();
clearstatcache();
+ $maxruntime = 2 * 60; // 2 minutes.. ?? should be long enoguh
+
foreach($this->pool as $p) {
//echo "CHECK PID: " . $p['pid'] . "\n";
if ($info['running']) {
- //if (file_exists('/proc/'.$p['pid'])) {
+ //if (file_exists('/proc/'.$p['pid'])) {
+ $runtime = time() - $p['started'];
+ //echo "RUNTIME ({$p['pid']}): $runtime\n";
+ if ($runtime > $maxruntime) {
+
+ proc_terminate($p['proc'], 9);
+ //fclose($p['pipes'][1]);
+ fclose($p['pipes'][0]);
+ fclose($p['pipes'][2]);
+ echo "TERMINATING: ({$p['pid']}) " . $p['cmd'] . " : " . file_get_contents($p['out']) . "\n";
+ @unlink($p['out']);
+
+ continue;
+ }
+
$pool[] = $p;
continue;
}
-
- echo "CLOSING: ({$p['pid']}) " . $p['cmd'] . " : " . file_get_contents($p['out']) . "\n";
- //fclose($p['pipes'][1]);
fclose($p['pipes'][0]);
fclose($p['pipes'][2]);
+ //echo "CLOSING: ({$p['pid']}) " . $p['cmd'] . " : " . file_get_contents($p['out']) . "\n";
+ //fclose($p['pipes'][1]);
+
proc_close($p['proc']);
- clearstatcache();
- if (file_exists('/proc/'.$p['pid'])) {
- $pool[] = $p;
- continue;
- }
+ //clearstatcache();
+ //if (file_exists('/proc/'.$p['pid'])) {
+ // $pool[] = $p;
+ // continue;
+ //}
echo "ENDED: ({$p['pid']}) " . $p['cmd'] . " : " . file_get_contents($p['out']) . "\n";
-
+ @unlink($p['out']);
//unlink($p['out']);
}
echo "POOL SIZE: ". count($pool) ."\n";