aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--README.txt10
-rw-r--r--service.rb25
2 files changed, 32 insertions, 3 deletions
diff --git a/README.txt b/README.txt
index 9daac40..12fdd37 100644
--- a/README.txt
+++ b/README.txt
@@ -133,7 +133,12 @@ twitter-event-stream opens two endpoints for a client:
:\r\n\r\n
-twitter-event-stream uses "OAuth Echo"[3] to authenticate a client, meaning
+In both endpoints, the Tweet object structure BASICALLY follows the
+"Compatibility with additional extended_tweet in payload" mode[3]. Each Tweet
+object has `extended_tweet` object containing `full_text` key.
+
+
+twitter-event-stream uses "OAuth Echo"[4] to authenticate a client, meaning
an application must provide the following HTTP headers:
- `x-auth-service-provider`
@@ -147,7 +152,8 @@ an application must provide the following HTTP headers:
normally send when calling the account/verify_credentials API.
[2] https://developer.twitter.com/en/docs/basics/authentication/overview/oauth-echo.html
-[3] https://developer.twitter.com/en/docs/accounts-and-users/subscribe-account-activity/guides/account-activity-data-objects
+[3] https://developer.twitter.com/en/docs/tweets/tweet-updates.html
+[4] https://developer.twitter.com/en/docs/accounts-and-users/subscribe-account-activity/guides/account-activity-data-objects
License
-------
diff --git a/service.rb b/service.rb
index c997409..915241a 100644
--- a/service.rb
+++ b/service.rb
@@ -187,7 +187,11 @@ class Service
last_max = nil
while true
t = Time.now
- opts = { "count" => 200, "since_id" => last_max ? last_max - 1 : 1 }
+ opts = {
+ "tweet_mode" => "extended",
+ "count" => 200,
+ "since_id" => last_max ? last_max - 1 : 1
+ }
ret = twitter_get("/1.1/statuses/home_timeline.json", opts)
unless ret.empty?
@@ -200,6 +204,25 @@ class Service
end
end
+ # Fix Tweet object structure so it follows "Compatibility with
+ # additional extended_tweet in payload" mode.
+ # https://developer.twitter.com/en/docs/tweets/tweet-updates.html
+ ret.each { |tweet|
+ tweet["extended_tweet"] = {
+ "full_text" => tweet["full_text"],
+ "display_text_range" => tweet["display_text_range"],
+ "entities" => tweet["entities"],
+ "extended_entities" => tweet["extended_entities"],
+ }
+ tweet["text"] = tweet["full_text"]
+
+ # NOTE: full_text should be removed from tweet, and then
+ # truncated, entities, extended_entities, and display_text_range
+ # should be modified according to the length of full_text. But
+ # this is probably not worth doing as clients will anyway process
+ # extended_tweet only so it can support >140 characters tweets.
+ }
+
unless ret.empty?
emit("twitter_event_stream_home_timeline", ret)
last_max = ret.first["id"]