. */ if (!defined('STATUSNET') && !defined('LACONICA')) { exit(1); } /** * Base class for queue handlers. * * As extensions of the Daemon class, each queue handler has the ability * to launch itself in the background, at which point it'll pass control * to the configured QueueManager class to poll for updates. * * Subclasses must override at least the following methods: * - transport * - handle_notice */ class DistribQueueHandler { /** * Return transport keyword which identifies items this queue handler * services; must be defined for all subclasses. * * Must be 8 characters or less to fit in the queue_item database. * ex "email", "jabber", "sms", "irc", ... * * @return string */ function transport() { return 'distrib'; } /** * Handle distribution of a notice after we've saved it: * @li add to local recipient inboxes * @li send email notifications to local @-reply targets * @li run final EndNoticeSave plugin events * @li put any remaining post-processing into the queues * * If this function indicates failure, a warning will be logged * and the item is placed back in the queue to be re-run. * * @fixme addToInboxes is known to fail sometimes with large recipient sets * * @param Notice $notice * @return boolean true on success, false on failure */ function handle($notice) { try { $notice->addToInboxes(); } catch (Exception $e) { $this->logit($notice, $e); } try { $notice->sendReplyNotifications(); } catch (Exception $e) { $this->logit($notice, $e); } try { Event::handle('EndNoticeSave', array($notice)); // Enqueue for other handlers } catch (Exception $e) { $this->logit($notice, $e); } try { common_enqueue_notice($notice); } catch (Exception $e) { $this->logit($notice, $e); } return true; } protected function logit($notice, $e) { common_log(LOG_ERR, "Distrib queue exception saving notice $notice->id: " . $e->getMessage() . ' ' . str_replace("\n", " ", $e->getTraceAsString())); // We'll still return true so we don't get stuck in a loop // trying to run a bad insert over and over... } }