. */ if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } /** * IKM background connection manager for IM-using queue handlers, * allowing them to send outgoing messages on the right connection. * * In a multi-site queuedaemon.php run, one connection will be instantiated * for each site being handled by the current process that has IM enabled. * * Implementations that extend this class will likely want to: * 1) override start() with their connection process. * 2) override handleInput() with what to do when data is waiting on * one of the sockets * 3) override idle($timeout) to do keepalives (if necessary) * 4) implement send_raw_message() to send raw data that ImPlugin::enqueue_outgoing_raw * enqueued */ abstract class ImManager extends IoManager { abstract function send_raw_message($data); function __construct($imPlugin) { $this->plugin = $imPlugin; //TODO We only really want to register this event if this is the thread that runs the ImManager Event::addHandler('EndInitializeQueueManager', array($this, 'onEndInitializeQueueManager')); } /** * Fetch the singleton manager for the current site. * @return mixed ImManager, or false if unneeded */ public static function get() { throw new Exception('ImManager should be created using it\'s constructor, not the static get method'); } /** * Register notice queue handler * * @param QueueManager $manager * * @return boolean hook return */ function onEndInitializeQueueManager($manager) { $manager->connect($this->plugin->transport . '-out', new ImSenderQueueHandler($this->plugin, $this), 'imdaemon'); return true; } }