]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - lib/jabber.php
add a bit of instructions
[quix0rs-gnu-social.git] / lib / jabber.php
index bf0d7cf3166b9c88e9595dc0b54f1f5d64837514..2e136cd74874ae7091b4b9b9b416dddff11e8ca7 100644 (file)
@@ -27,31 +27,41 @@ function jabber_valid_base_jid($jid) {
 }
 
 function jabber_normalize_jid($jid) {
-       preg_match("/(?:([^\@]+)\@)?([^\/]+)(?:\/(.*))?$/", $jid, $matches);
-       $node = $matches[1];
-       $server = $matches[2];
-       $resource = $matches[3];
-       return strtolower($node.'@'.$server);
+       if (preg_match("/(?:([^\@]+)\@)?([^\/]+)(?:\/(.*))?$/", $jid, $matches)) {
+               $node = $matches[1];
+               $server = $matches[2];
+               $resource = $matches[3];
+               return strtolower($node.'@'.$server);
+       } else {
+               return NULL;
+       }
+}
+
+function jabber_daemon_address() {
+       return common_config('xmpp', 'user') . '@' . common_config('xmpp', 'server');
 }
 
 function jabber_connect($resource=NULL) {
        static $conn = NULL;
        if (!$conn) {
-               $conn = new XMPP(common_config('xmpp', 'server'),
-                                            common_config('xmpp', 'port'),
+               $conn = new XMPP(common_config('xmpp', 'host') ?
+                                        common_config('xmpp', 'host') :
+                                        common_config('xmpp', 'server'),
+                                        common_config('xmpp', 'port'),
                                             common_config('xmpp', 'user'),
                                             common_config('xmpp', 'password'),
-                                        ($resource) ? $resource : 
-                                               common_config('xmpp', 'resource'));
-                                       
+                                        ($resource) ? $resource :
+                                               common_config('xmpp', 'resource'),
+                                        common_config('xmpp', 'server'));
+
                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');
+       $conn->processUntil('session_start');
        }
        return $conn;
 }
@@ -65,7 +75,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;
@@ -75,30 +85,36 @@ function jabber_send_presence($status=Null, $show='available', $to=Null) {
 }
 
 function jabber_confirm_address($code, $nickname, $address) {
-
-       # FIXME: do we have to request presence first?
-       
-       $body = "Hey, $nickname.";
-       $body .= "\n\n";
-       $body .= 'Someone just entered this IM address on ';
-       $body .= common_config('site', 'name') . '.';
-       $body .= "\n\n";
-       $body .= 'If it was you, and you want to confirm your entry, ';
-       $body .= 'use the URL below:';
-       $body .= "\n\n";
-       $body .= "\t".common_local_url('confirmaddress',
-                                                                  array('code' => $code));
-       $body .= "\n\n";
-       $body .= 'If not, just ignore this message.';
-       $body .= "\n\n";
-       $body .= 'Thanks for your time, ';
-       $body .= "\n";
-       $body .= common_config('site', 'name');
-       $body .= "\n";
+       $body = 'User "' . $nickname . '" on ' . common_config('site', 'name') . ' ' .
+                       'has said that your Jabber ID belongs to them. ' .
+           'If that\'s true, you can confirm by clicking on this URL: ' .
+               common_local_url('confirmaddress', array('code' => $code)) .
+               ' . (If you cannot click it, copy-and-paste it into the ' .
+               'address bar of your browser). If that user isn\'t you, ' .
+               'or if you didn\'t request this confirmation, just ignore this message.';
 
        jabber_send_message($address, $body);
 }
-       
+
+function jabber_special_presence($type, $to=NULL, $show=NULL, $status=NULL) {
+       $conn = jabber_connect();
+
+       $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>";
+       }
+       $conn->send($out);
+}
+
 function jabber_broadcast_notice($notice) {
        # First, get users subscribed to this profile
        # XXX: use a join here rather than looping through results
@@ -124,5 +140,5 @@ function jabber_broadcast_notice($notice) {
 }
 
 function jabber_format_notice(&$profile, &$notice) {
-       return $profile->nickname . ': ' . $notice->content;
+       return $profile->nickname . ': ' . $notice->content;
 }