The queuehandler sends messages to the user. If the user replies, the messages are typically sent directly to the queuehandler (including resource), not the default bot JID. We add a little code for the xmppqueuehandler to periodically service its queue of received messages. Received messages are forwarded to the listener to deal with. We use XEP 33, 'addresses', to note the original sender. The xmppdaemon checks to see if the 'from' on a message is the daemon address. If so, it looks for a XEP 33 'addresses' stanza, with an 'ofrom' address, which shows who it was originally is from. This should let us send from one resource ID and still process incoming messages in a different connection. darcs-hash:20080830040717-84dde-59c75bfb107a1dd5fd531106751b4544bfd15656.gz
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env php
 | |
| <?php
 | |
| /*
 | |
|  * Laconica - a distributed open-source microblogging tool
 | |
|  * Copyright (C) 2008, Controlez-Vous, Inc.
 | |
|  *
 | |
|  * This program is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Affero General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU Affero General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Affero General Public License
 | |
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| # Abort if called from a web server
 | |
| if (isset($_SERVER) && array_key_exists('REQUEST_METHOD', $_SERVER)) {
 | |
| 	print "This script must be run from the command line\n";
 | |
| 	exit();
 | |
| }
 | |
| 
 | |
| define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
 | |
| define('LACONICA', true);
 | |
| 
 | |
| require_once(INSTALLDIR . '/lib/common.php');
 | |
| require_once(INSTALLDIR . '/lib/jabber.php');
 | |
| require_once(INSTALLDIR . '/lib/queuehandler.php');
 | |
| 
 | |
| set_error_handler('common_error_handler');
 | |
| 
 | |
| class XmppQueueHandler extends QueueHandler {
 | |
| 
 | |
| 	var $conn = NULL;
 | |
| 
 | |
| 	function transport() {
 | |
| 		return 'jabber';
 | |
| 	}
 | |
| 
 | |
| 	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_broadcast_notice($notice);
 | |
| 	}
 | |
| 
 | |
| 	function idle() {
 | |
| 		# Process the queue for a second
 | |
| 		$this->conn->processTime(1);
 | |
| 	}
 | |
| 
 | |
| 	function finish() {
 | |
| 	}
 | |
| 
 | |
| 	function forward_message(&$pl) {
 | |
| 		$listener = $this->listener();
 | |
| 		$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';
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| mb_internal_encoding('UTF-8');
 | |
| 
 | |
| $resource = ($argc > 1) ? $argv[1] : (common_config('xmpp','resource') . '-queuehandler');
 | |
| 
 | |
| $handler = new XmppQueueHandler($resource);
 | |
| 
 | |
| if ($handler->start()) {
 | |
| 	$handler->handle_queue();
 | |
| }
 | |
| 
 | |
| $handler->finish();
 |