mirror of
https://github.com/mikf/gallery-dl.git
synced 2024-11-25 12:12:34 +01:00
[twitter] implement 'users' option (#1337)
This commit is contained in:
parent
847e9b0ed7
commit
3378b39719
@ -1650,6 +1650,20 @@ Description
|
||||
Extract `TwitPic <https://twitpic.com/>`__ embeds.
|
||||
|
||||
|
||||
extractor.twitter.users
|
||||
-----------------------
|
||||
Type
|
||||
``string``
|
||||
Default
|
||||
``"timeline"``
|
||||
Description
|
||||
Output format for user results from
|
||||
``following`` and ``list-members`` queries.
|
||||
|
||||
* ``"timeline"``: ``https://twitter.com/i/user/USERID``
|
||||
* ``"media"``: ``https://twitter.com/id:USERID/media``
|
||||
|
||||
|
||||
extractor.twitter.videos
|
||||
------------------------
|
||||
Type
|
||||
|
@ -254,6 +254,7 @@
|
||||
"replies": true,
|
||||
"retweets": true,
|
||||
"twitpic": false,
|
||||
"users": "timeline",
|
||||
"videos": true
|
||||
},
|
||||
"unsplash":
|
||||
|
@ -224,6 +224,18 @@ class TwitterExtractor(Extractor):
|
||||
}
|
||||
return cache[uid]
|
||||
|
||||
def _users_result(self, users):
|
||||
if self.config("users") == "media":
|
||||
cls = TwitterMediaExtractor
|
||||
fmt = "{}/id:{}/media".format
|
||||
else:
|
||||
cls = TwitterTimelineExtractor
|
||||
fmt = "{}/i/user/{}".format
|
||||
|
||||
for user in users:
|
||||
user["_extractor"] = cls
|
||||
yield Message.Queue, fmt(self.root, user["rest_id"]), user
|
||||
|
||||
def metadata(self):
|
||||
"""Return general metadata"""
|
||||
return {}
|
||||
@ -356,10 +368,7 @@ class TwitterListMembersExtractor(TwitterExtractor):
|
||||
|
||||
def items(self):
|
||||
self.login()
|
||||
for user in TwitterAPI(self).list_members(self.user):
|
||||
user["_extractor"] = TwitterTimelineExtractor
|
||||
url = "{}/i/user/{}".format(self.root, user["rest_id"])
|
||||
yield Message.Queue, url, user
|
||||
return self._users_result(TwitterAPI(self).list_members(self.user))
|
||||
|
||||
|
||||
class TwitterFollowingExtractor(TwitterExtractor):
|
||||
@ -373,10 +382,7 @@ class TwitterFollowingExtractor(TwitterExtractor):
|
||||
|
||||
def items(self):
|
||||
self.login()
|
||||
for user in TwitterAPI(self).user_following(self.user):
|
||||
user["_extractor"] = TwitterTimelineExtractor
|
||||
url = "{}/i/user/{}".format(self.root, user["rest_id"])
|
||||
yield Message.Queue, url, user
|
||||
return self._users_result(TwitterAPI(self).user_following(self.user))
|
||||
|
||||
|
||||
class TwitterSearchExtractor(TwitterExtractor):
|
||||
|
Loading…
Reference in New Issue
Block a user