]> git.mxchange.org Git - quix0rs-gnu-social.git/blobdiff - scripts/publicqueuehandler.php
add SUP link to User RSS
[quix0rs-gnu-social.git] / scripts / publicqueuehandler.php
index eb18d2c347b754ec4a957b1b6bc0b06dd727bf3f..b1ae1d581dbcdda2ec57039183a264d4bbd3d5ac 100755 (executable)
@@ -29,77 +29,33 @@ define('LACONICA', true);
 
 require_once(INSTALLDIR . '/lib/common.php');
 require_once(INSTALLDIR . '/lib/jabber.php');
-require_once(INSTALLDIR . '/lib/queuehandler.php');
+require_once(INSTALLDIR . '/lib/xmppqueuehandler.php');
 
 set_error_handler('common_error_handler');
 
-class PublicQueueHandler extends QueueHandler {
+class PublicQueueHandler extends XmppQueueHandler {
        
        function transport() {
                return 'public';
        }
        
-       function start() {
-               # Low priority; we don't want to receive messages
-               $this->conn = jabber_connect($this->_id, NULL, -1);
-               $this->conn->addEventHandler('message', 'forward_message', $this);
-               return !is_null($this->conn);
-       }
-
        function handle_notice($notice) {
-               return jabber_public_notice($notice);
-       }
-       
-       function idle() {
-           $this->log(LOG_DEBUG, 'Checking the incoming message queue.');
-               # Process the queue for a second
-               if ($this->conn->readyToProcess()) {
-                       $this->log(LOG_DEBUG, 'Something in the incoming message queue; processing it.');
-                       $this->conn->processTime(1);
-                       $this->log(LOG_DEBUG, 'Done processing incoming message queue.');
-               } else {
-                       $this->log(LOG_DEBUG, 'Nothing in the incoming message queue; skipping it.');
-               }
-       }
-
-       function forward_message(&$pl) {
-               if ($pl['type'] != 'chat') {
-                   $this->log(LOG_DEBUG, 'Ignoring message of type ' . $pl['type'] . ' from ' . $pl['from']);
-                       return;
-               }
-               $listener = $this->listener();
-               if (strtolower($listener) == strtolower($pl['from'])) {
-                       $this->log(LOG_WARNING, 'Ignoring loop message.');
-                       return;
-               }
-               $this->log(LOG_INFO, 'Forwarding message from ' . $pl['from'] . ' to ' . $listener);
-               $this->conn->message($this->listener(), $pl['body'], 'chat', NULL, $this->ofrom($pl['from']));
-       }
-
-       function ofrom($from) {
-               $address = "<addresses xmlns='http://jabber.org/protocol/address'>\n";
-               $address .= "<address type='ofrom' jid='$from' />\n";
-               $address .= "</addresses>\n";
-               return $address;
-       }
-
-       function listener() {
-               if (common_config('xmpp', 'listener')) {
-                       return common_config('xmpp', 'listener');
-               } else {
-                       return jabber_daemon_address() . '/' . common_config('xmpp','resource') . '-listener';
+               try {
+                       return jabber_public_notice($notice);
+               } catch (XMPPHP_Exception $e) {
+                       $this->log(LOG_ERR, "Got an XMPPHP_Exception: " . $e->getMessage());
+                       die($e->getMessage());
                }
        }
 }
 
+ini_set("max_execution_time", "0");
+ini_set("max_input_time", "0");
+set_time_limit(0);
 mb_internal_encoding('UTF-8');
 
 $resource = ($argc > 1) ? $argv[1] : (common_config('xmpp','resource') . '-public');
 
 $handler = new PublicQueueHandler($resource);
 
-if ($handler->start()) {
-       $handler->handle_queue();
-}
-
-$handler->finish();
+$handler->runOnce();