summaryrefslogtreecommitdiff
path: root/plugins/TwitterBridge
diff options
context:
space:
mode:
authorBrion Vibber <brion@pobox.com>2010-10-05 17:08:04 -0700
committerBrion Vibber <brion@pobox.com>2010-10-05 17:08:04 -0700
commit9c3fd10257703d821891c25b56dcb13b255aa903 (patch)
treee1965032990bc279c8613c7f493c00082207ab29 /plugins/TwitterBridge
parent408483f7718a2c81c37eb5f387130381a4a188c8 (diff)
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. :)
Diffstat (limited to 'plugins/TwitterBridge')
-rw-r--r--plugins/TwitterBridge/scripts/streamtest.php58
-rw-r--r--plugins/TwitterBridge/twitterstreamreader.php2
2 files changed, 46 insertions, 14 deletions
diff --git a/plugins/TwitterBridge/scripts/streamtest.php b/plugins/TwitterBridge/scripts/streamtest.php
index 1cec451c8..a175c1efa 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 = <<<ENDOFHELP
USAGE: streamtest.php -n <username>
- -n --nick <username> Local user whose Twitter timeline to watch
+ -n --nick=<username> 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 3a3c8f5e6..5b0613bc4 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);
}