From: Brion Vibber Date: Wed, 6 Oct 2010 00:08:04 +0000 (-0700) Subject: Prelim --all mode on streamtest.php to use site streams; doesn't use the destination... X-Git-Url: https://git.mxchange.org/?a=commitdiff_plain;h=9c3fd10257703d821891c25b56dcb13b255aa903;p=quix0rs-gnu-social.git Prelim --all mode on streamtest.php to use site streams; doesn't use the destination user for import yet, and not actually tested yet until I'm whitelisted for the beta. :) --- diff --git a/plugins/TwitterBridge/scripts/streamtest.php b/plugins/TwitterBridge/scripts/streamtest.php index 1cec451c8c..a175c1efa5 100644 --- a/plugins/TwitterBridge/scripts/streamtest.php +++ b/plugins/TwitterBridge/scripts/streamtest.php @@ -28,13 +28,14 @@ define('INSTALLDIR', realpath(dirname(__FILE__) . '/../../..')); $shortoptions = 'n:'; -$longoptions = array('nick=','import'); +$longoptions = array('nick=','import','all'); $helptext = << - -n --nick Local user whose Twitter timeline to watch + -n --nick= Local user whose Twitter timeline to watch --import Experimental: run incoming messages through import + --all Experimental: run multiuser; requires nick be the app owner Attempts a User Stream connection to Twitter as the given user, dumping data as it comes. @@ -81,49 +82,80 @@ function homeStreamForUser(User $user) return new TwitterUserStream($auth); } +function siteStreamForOwner(User $user) +{ + // The user we auth as must be the owner of the application. + $auth = twitterAuthForUser($user); + $stream = new TwitterSiteStream($auth); + + // Pull Twitter user IDs for all users we want to pull data for + $userIds = array(); + + $flink = new Foreign_link(); + $flink->service = TWITTER_SERVICE; + $flink->find(); + + while ($flink->fetch()) { + if (($flink->noticesync & FOREIGN_NOTICE_RECV) == + FOREIGN_NOTICE_RECV) { + $userIds[] = $flink->foreign_id; + } + } + + $stream->followUsers($userIds); + return $stream; +} + + $user = User::staticGet('nickname', $nickname); global $myuser; $myuser = $user; -$stream = homeStreamForUser($user); -$stream->hookEvent('raw', function($data) { - common_log(LOG_INFO, json_encode($data)); +if (have_option('all')) { + $stream = siteStreamForOwner($user); +} else { + $stream = homeStreamForUser($user); +} + + +$stream->hookEvent('raw', function($data, $context) { + common_log(LOG_INFO, json_encode($data) . ' for ' . json_encode($context)); }); -$stream->hookEvent('friends', function($data) { +$stream->hookEvent('friends', function($data, $context) { printf("Friend list: %s\n", implode(', ', $data->friends)); }); -$stream->hookEvent('favorite', function($data) { +$stream->hookEvent('favorite', function($data, $context) { printf("%s favorited %s's notice: %s\n", $data->source->screen_name, $data->target->screen_name, $data->target_object->text); }); -$stream->hookEvent('unfavorite', function($data) { +$stream->hookEvent('unfavorite', function($data, $context) { printf("%s unfavorited %s's notice: %s\n", $data->source->screen_name, $data->target->screen_name, $data->target_object->text); }); -$stream->hookEvent('follow', function($data) { +$stream->hookEvent('follow', function($data, $context) { printf("%s friended %s\n", $data->source->screen_name, $data->target->screen_name); }); -$stream->hookEvent('unfollow', function($data) { +$stream->hookEvent('unfollow', function($data, $context) { printf("%s unfriended %s\n", $data->source->screen_name, $data->target->screen_name); }); -$stream->hookEvent('delete', function($data) { +$stream->hookEvent('delete', function($data, $context) { printf("Deleted status notification: %s\n", $data->status->id); }); -$stream->hookEvent('scrub_geo', function($data) { +$stream->hookEvent('scrub_geo', function($data, $context) { printf("Req to scrub geo data for user id %s up to status ID %s\n", $data->user_id, $data->up_to_status_id); }); -$stream->hookEvent('status', function($data) { +$stream->hookEvent('status', function($data, $context) { printf("Received status update from %s: %s\n", $data->user->screen_name, $data->text); diff --git a/plugins/TwitterBridge/twitterstreamreader.php b/plugins/TwitterBridge/twitterstreamreader.php index 3a3c8f5e66..5b0613bc40 100644 --- a/plugins/TwitterBridge/twitterstreamreader.php +++ b/plugins/TwitterBridge/twitterstreamreader.php @@ -208,7 +208,7 @@ class TwitterSiteStream extends TwitterStreamReader { protected $userIds; - public function __construct(TwitterOAuthClient $auth, $baseUrl='https://stream.twitter.com') + public function __construct(TwitterOAuthClient $auth, $baseUrl='http://betastream.twitter.com') { parent::__construct($auth, $baseUrl); }