diff --git a/lib/jabber.php b/lib/jabber.php index 2e67706515..7e33b8e399 100644 --- a/lib/jabber.php +++ b/lib/jabber.php @@ -37,7 +37,7 @@ function jabber_normalize_jid($jid) { } } -function jabber_connect($resource=NULL, $status=NULL) { +function jabber_connect($resource=NULL) { static $conn = NULL; if (!$conn) { $conn = new XMPP(common_config('xmpp', 'host') ? @@ -53,14 +53,11 @@ function jabber_connect($resource=NULL, $status=NULL) { if (!$conn) { return false; } - $conn->connect(true); # try to get a persistent connection + $conn->connect(true); # true = persistent connection if ($conn->disconnected) { return false; } - $conn->processUntil('session_start'); - if ($status) { - $conn->presence($status); - } + $conn->processUntil('session_start'); } return $conn; } @@ -74,7 +71,7 @@ function jabber_send_message($to, $body, $type='chat', $subject=NULL) { return true; } -function jabber_send_presence($status=Null, $show='available', $to=Null) { +function jabber_send_presence($status, $show='available', $to=Null) { $conn = jabber_connect(); if (!$conn) { return false; diff --git a/xmppdaemon.php b/xmppdaemon.php old mode 100644 new mode 100755 index ac3ab8acab..c8204ba0e7 --- a/xmppdaemon.php +++ b/xmppdaemon.php @@ -1,3 +1,4 @@ +#!/usr/bin/env php resource = $resource; + } else { + $this->resource = common_config('xmpp', 'resource') . 'daemon'; } + + $this->log(LOG_INFO, "{$this->user}@{$this->server}/{$this->resource}"); } function connect() { - $this->conn = jabber_connect($this->resource, - "Send me a message to post a notice"); + $connect_to = ($this->host) ? $this->host : $this->server; + + $this->log(LOG_INFO, "Connecting to $connect_to on port $this->port"); + + $this->conn = jabber_connect($this->resource); + if (!$this->conn) { return false; } @@ -189,30 +197,20 @@ class XMPPDaemon { } function subscribed($to) { - $this->special_presence('subscribed', $to); + jabber_special_presence('subscribed', $to); } - function special_presence($type, $to=NULL, $show=NULL, $status=NULL) { - $to = htmlspecialchars($to); - $status = htmlspecialchars($status); - $out = "conn->send($out); + function set_status($status) { + jabber_send_presence($status); } } -$daemon = new XMPPDaemon(); +$resource = ($argc > 1) ? $argv[1] : NULL; + +$daemon = new XMPPDaemon($resource); if ($daemon->connect()) { + $daemon->set_status("Send me a message to post a notice"); $daemon->handle(); } ?>