. */ if (!defined('LACONICA')) { exit(1); } require_once(INSTALLDIR.'/lib/daemon.php'); require_once(INSTALLDIR.'/classes/Queue_item.php'); require_once(INSTALLDIR.'/classes/Notice.php'); define('CLAIM_TIMEOUT', 1200); define('QUEUE_HANDLER_MISS_IDLE', 10); define('QUEUE_HANDLER_HIT_IDLE', 10); class QueueHandler extends Daemon { var $_id = 'generic'; function __construct($id=null, $daemonize=true) { parent::__construct($daemonize); if ($id) { $this->set_id($id); } } function timeout() { return null; } function class_name() { return ucfirst($this->transport()) . 'Handler'; } function name() { return strtolower($this->class_name().'.'.$this->get_id()); } function get_id() { return $this->_id; } function set_id($id) { $this->_id = $id; } function transport() { return null; } function start() { } function finish() { } function handle_notice($notice) { return true; } function run() { if (!$this->start()) { return false; } $this->log(LOG_INFO, 'checking for queued notices'); $queue = $this->transport(); $timeout = $this->timeout(); $qm = QueueManager::get(); while (true) { $this->log(LOG_DEBUG, 'Checking for notices...'); $notice = $qm->nextItem($queue, $timeout); if (empty($notice)) { $this->log(LOG_DEBUG, 'No notices waiting; idling.'); // Nothing in the queue. Do you // have other tasks, like servicing your // XMPP connection, to do? $this->idle(QUEUE_HANDLER_MISS_IDLE); } else { $this->log(LOG_INFO, 'Got notice '. $notice->id); // Yay! Got one! if ($this->handle_notice($notice)) { $this->log(LOG_INFO, 'Successfully handled notice '. $notice->id); $qm->done($notice, $queue); } else { $this->log(LOG_INFO, 'Failed to handle notice '. $notice->id); $qm->fail($notice, $queue); } // Chance to e.g. service your XMPP connection $this->log(LOG_DEBUG, 'Idling after success.'); $this->idle(QUEUE_HANDLER_HIT_IDLE); } // XXX: when do we give up? } if (!$this->finish()) { return false; } return true; } function idle($timeout=0) { if ($timeout > 0) { sleep($timeout); } } function log($level, $msg) { common_log($level, $this->class_name() . ' ('. $this->get_id() .'): '.$msg); } }