. */ if (!defined('GNUSOCIAL') && !defined('STATUSNET')) { 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 */ public 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. * * @param Notice $notice * @return boolean true on success, false on failure */ public function handle(Notice $notice) { // We have to manually add attentions to non-profile subs and non-mentions $ptAtts = $notice->getAttentionsFromProfileTags(); foreach (array_keys($ptAtts) as $profile_id) { $profile = Profile::getKV('id', $profile_id); if ($profile instanceof Profile) { try { common_debug('Adding Attention for '.$notice->getID().' profile '.$profile->getID()); Attention::saveNew($notice, $profile); } catch (Exception $e) { $this->logit($notice, $e); } } } try { $notice->sendReplyNotifications(); } catch (Exception $e) { $this->logit($notice, $e); } try { Event::handle('EndNoticeDistribute', array($notice)); } catch (Exception $e) { $this->logit($notice, $e); } try { Event::handle('EndNoticeSave', array($notice)); } catch (Exception $e) { $this->logit($notice, $e); } try { // Enqueue for other handlers 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... } }