summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/jabber.php11
-rwxr-xr-x[-rw-r--r--]xmppdaemon.php40
2 files changed, 23 insertions, 28 deletions
diff --git a/lib/jabber.php b/lib/jabber.php
index 2e6770651..7e33b8e39 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
index ac3ab8aca..c8204ba0e 100644..100755
--- a/xmppdaemon.php
+++ b/xmppdaemon.php
@@ -1,3 +1,4 @@
+#!/usr/bin/env php
<?php
/*
* Laconica - a distributed open-source microblogging tool
@@ -32,8 +33,7 @@ require_once(INSTALLDIR . '/lib/jabber.php');
class XMPPDaemon {
function XMPPDaemon($resource=NULL) {
- static $attrs = array('server', 'port', 'user', 'password',
- 'resource', 'host');
+ static $attrs = array('server', 'port', 'user', 'password', 'host');
foreach ($attrs as $attr)
{
@@ -42,12 +42,20 @@ class XMPPDaemon {
if ($resource) {
$this->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 = "<presence";
- if($to) $out .= " to='$to'";
- if($type) $out .= " type='$type'";
- if($show == 'available' and !$status) {
- $out .= "/>";
- } else {
- $out .= ">";
- if($show && ($show != 'available')) $out .= "<show>$show</show>";
- if($status) $out .= "<status>$status</status>";
- $out .= "</presence>";
- }
- $this->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();
}
?>