Merge branch '0.8.x' into testing

This commit is contained in:
Evan Prodromou 2009-08-26 10:27:53 -04:00
commit c5cf2c4c94
2 changed files with 20 additions and 5 deletions

View File

@ -75,6 +75,7 @@ class QueueHandler extends Daemon
function run() function run()
{ {
if (!$this->start()) { if (!$this->start()) {
$this->log(LOG_WARNING, 'failed to start');
return false; return false;
} }
@ -87,9 +88,15 @@ class QueueHandler extends Daemon
$qm->service($queue, $this); $qm->service($queue, $this);
$this->log(LOG_INFO, 'finished servicing the queue');
if (!$this->finish()) { if (!$this->finish()) {
$this->log(LOG_WARNING, 'failed to clean up');
return false; return false;
} }
$this->log(LOG_INFO, 'terminating normally');
return true; return true;
} }

View File

@ -38,14 +38,20 @@ class XmppQueueHandler extends QueueHandler
function start() function start()
{ {
# Low priority; we don't want to receive messages # Low priority; we don't want to receive messages
$this->log(LOG_INFO, "INITIALIZE"); $this->log(LOG_INFO, "INITIALIZE");
$this->conn = jabber_connect($this->_id.$this->transport()); $this->conn = jabber_connect($this->_id.$this->transport());
if ($this->conn) {
$this->conn->addEventHandler('message', 'forward_message', $this); if (empty($this->conn)) {
$this->conn->addEventHandler('reconnect', 'handle_reconnect', $this); $this->log(LOG_ERR, "Couldn't connect to server.");
$this->conn->setReconnectTimeout(600); return false;
jabber_send_presence("Send me a message to post a notice", 'available', null, 'available', -1);
} }
$this->conn->addEventHandler('message', 'forward_message', $this);
$this->conn->addEventHandler('reconnect', 'handle_reconnect', $this);
$this->conn->setReconnectTimeout(600);
jabber_send_presence("Send me a message to post a notice", 'available', null, 'available', -1);
return !is_null($this->conn); return !is_null($this->conn);
} }
@ -56,6 +62,8 @@ class XmppQueueHandler extends QueueHandler
function handle_reconnect(&$pl) function handle_reconnect(&$pl)
{ {
$this->log(LOG_NOTICE, 'reconnected');
$this->conn->processUntil('session_start'); $this->conn->processUntil('session_start');
$this->conn->presence(null, 'available', null, 'available', -1); $this->conn->presence(null, 'available', null, 'available', -1);
} }