From 3b246d643df52f38e3854ba34fe0cabd1b6de5c8 Mon Sep 17 00:00:00 2001 From: Evan Prodromou Date: Mon, 11 Jul 2011 09:16:16 -0400 Subject: [PATCH] use Realtime_channel to target channels to users --- plugins/Realtime/RealtimePlugin.php | 70 +++++++++++++++++++-------- plugins/Realtime/Realtime_channel.php | 35 +++++++++++++- 2 files changed, 83 insertions(+), 22 deletions(-) diff --git a/plugins/Realtime/RealtimePlugin.php b/plugins/Realtime/RealtimePlugin.php index 68dc374f8c..a7750e005e 100644 --- a/plugins/Realtime/RealtimePlugin.php +++ b/plugins/Realtime/RealtimePlugin.php @@ -147,14 +147,14 @@ class RealtimePlugin extends Plugin $user = User::staticGet('id', $notice->profile_id); if (!empty($user)) { - $paths[] = array('showstream', $user->nickname); + $paths[] = array('showstream', $user->nickname, null); } // Add to the public timeline if ($notice->is_local == Notice::LOCAL_PUBLIC || ($notice->is_local == Notice::REMOTE_OMB && !common_config('public', 'localonly'))) { - $paths[] = array('public'); + $paths[] = array('public', null, null); } // Add to the tags timeline @@ -163,7 +163,7 @@ class RealtimePlugin extends Plugin if (!empty($tags)) { foreach ($tags as $tag) { - $paths[] = array('tag', $tag); + $paths[] = array('tag', $tag, null); } } @@ -174,7 +174,7 @@ class RealtimePlugin extends Plugin foreach (array_keys($ni) as $user_id) { $user = User::staticGet('id', $user_id); - $paths[] = array('all', $user->nickname); + $paths[] = array('all', $user->nickname, null); } // Add to the replies timeline @@ -186,7 +186,7 @@ class RealtimePlugin extends Plugin while ($reply->fetch()) { $user = User::staticGet('id', $reply->profile_id); if (!empty($user)) { - $paths[] = array('replies', $user->nickname); + $paths[] = array('replies', $user->nickname, null); } } } @@ -200,7 +200,7 @@ class RealtimePlugin extends Plugin if ($gi->find()) { while ($gi->fetch()) { $ug = User_group::staticGet('id', $gi->group_id); - $paths[] = array('showgroup', $ug->nickname); + $paths[] = array('showgroup', $ug->nickname, null); } } @@ -211,8 +211,22 @@ class RealtimePlugin extends Plugin $this->_connect(); foreach ($paths as $path) { - $timeline = $this->_pathToChannel($path); - $this->_publish($timeline, $json); + + list($action, $arg1, $arg2) = $path; + + $channels = Realtime_channel::getAllChannels($action, $arg1, $arg2); + + foreach ($channels as $channel) { + if (is_null($channel->user_id)) { + $profile = null; + } else { + $profile = Profile::staticGet('id', $channel->user_id); + } + if ($notice->inScope($profile)) { + $timeline = $this->_pathToChannel(array($channel->channel_key)); + $this->_publish($timeline, $json); + } + } } $this->_disconnect(); @@ -393,23 +407,27 @@ class RealtimePlugin extends Plugin function _getTimeline($action) { - $path = null; $timeline = null; - + $arg1 = null; + $arg2 = null; + $action_name = $action->trimmed('action'); // FIXME: lists // FIXME: search (!) - // FIXME: + // FIXME: profile + tag switch ($action_name) { case 'public': - $path = array('public'); + // no arguments break; case 'tag': $tag = $action->trimmed('tag'); - if (!empty($tag)) { - $path = array('tag', $tag); + if (empty($tag)) { + $arg1 = $tag; + } else { + $this->log(LOG_NOTICE, "Unexpected 'tag' action without tag argument"); + return null; } break; case 'showstream': @@ -418,17 +436,29 @@ class RealtimePlugin extends Plugin case 'showgroup': $nickname = common_canonical_nickname($action->trimmed('nickname')); if (!empty($nickname)) { - $path = array($action_name, $nickname); + $arg1 = $nickname; + } else { + $this->log(LOG_NOTICE, "Unexpected $action_name action without nickname argument."); + return null; } break; default: - break; - } - - if (!empty($path)) { - $timeline = $this->_pathToChannel($path); + return null; } + $user = common_current_user(); + + $user_id = (!empty($user)) ? $user->id : null; + + $channel = Realtime_channel::getChannel($user_id, + $action_name, + $arg1, + $arg2); + + if (!empty($channel)) { + $timeline = $this->_pathToChannel(array($channel->channel_key)); + } + return $timeline; } } diff --git a/plugins/Realtime/Realtime_channel.php b/plugins/Realtime/Realtime_channel.php index a0afd2cd6b..17d8504c05 100644 --- a/plugins/Realtime/Realtime_channel.php +++ b/plugins/Realtime/Realtime_channel.php @@ -137,8 +137,6 @@ class Realtime_channel extends Managed_DataObject static function saveNew($user_id, $action, $arg1, $arg2) { - $channel = self::getChannel($user_id, $action, $arg1, $arg2); - $channel = new Realtime_channel(); $channel->user_id = $user_id; @@ -173,6 +171,39 @@ class Realtime_channel extends Managed_DataObject } } + if (empty($channel)) { + $channel = self::saveNew($user_id, $action, $arg1, $arg2); + } + return $channel; } + + static function getAllChannels($action, $arg1, $arg2) + { + $channel = new Realtime_channel(); + + $channel->action = $action; + + if (is_null($arg1)) { + $channel->whereAdd('arg1 is null'); + } else { + $channel->arg1 = $arg1; + } + + if (is_null($arg2)) { + $channel->whereAdd('arg2 is null'); + } else { + $channel->arg2 = $arg2; + } + + $channel->whereAdd('modified > "' . common_sql_time(time() - self::TIMEOUT) . '"'); + + $channels = array(); + + if ($channel->find()) { + $channels = $channel->fetchAll(); + } + + return $channels; + } } \ No newline at end of file -- 2.39.5