[twitter] add option to download all media from a conversation

(fixes #1319)
pull/1352/head
Mike Fährmann 4 years ago
parent cf5fa75d4c
commit 5d69e437d0
No known key found for this signature in database
GPG Key ID: 5680CA389D365A88

@ -1593,6 +1593,17 @@ Description
Fetch media from `Cards <https://developer.twitter.com/en/docs/twitter-for-websites/cards/overview/abouts-cards>`__.
extractor.twitter.conversations
-------------------------------
Type
``bool``
Default
``false``
Description
Fetch media from all Tweets and replies in a `conversation
<https://help.twitter.com/en/using-twitter/twitter-conversations>`__.
extractor.twitter.quoted
------------------------
Type

@ -468,6 +468,11 @@ class TwitterTweetExtractor(TwitterExtractor):
"date" : "dt:2020-08-20 04:00:28",
},
}),
# all Tweets from a conversation (#1319)
("https://twitter.com/BlankArts_/status/1323314488611872769", {
"options": (("conversations", True),),
"count": ">= 50",
}),
)
def __init__(self, match):
@ -475,6 +480,8 @@ class TwitterTweetExtractor(TwitterExtractor):
self.tweet_id = match.group(2)
def tweets(self):
if self.config("conversations", False):
return TwitterAPI(self).conversation(self.tweet_id)
return TwitterAPI(self).tweet(self.tweet_id)
@ -554,6 +561,10 @@ class TwitterAPI():
break
return tweets
def conversation(self, conversation_id):
endpoint = "/2/timeline/conversation/{}.json".format(conversation_id)
return self._pagination(endpoint)
def timeline_profile(self, screen_name):
user_id = self._user_id_by_screen_name(screen_name)
endpoint = "/2/timeline/profile/{}.json".format(user_id)
@ -723,6 +734,13 @@ class TwitterAPI():
tweet = True
cursor = cursor["value"]
elif entry_startswith("conversationThread-"):
tweet_ids.extend(
item["entryId"][6:]
for item in entry["content"]["timelineModule"]["items"]
if item["entryId"].startswith("tweet-")
)
# process tweets
for tweet_id in tweet_ids:
try:

Loading…
Cancel
Save