[twitch] Add support for bookmarks
This commit is contained in:
		| @@ -467,6 +467,7 @@ from .twitch import ( | |||||||
|     TwitchVodIE, |     TwitchVodIE, | ||||||
|     TwitchProfileIE, |     TwitchProfileIE, | ||||||
|     TwitchPastBroadcastsIE, |     TwitchPastBroadcastsIE, | ||||||
|  |     TwitchBookmarksIE, | ||||||
|     TwitchStreamIE, |     TwitchStreamIE, | ||||||
| ) | ) | ||||||
| from .ubu import UbuIE | from .ubu import UbuIE | ||||||
|   | |||||||
| @@ -220,12 +220,18 @@ class TwitchPlaylistBaseIE(TwitchBaseIE): | |||||||
|             response = self._download_json( |             response = self._download_json( | ||||||
|                 self._PLAYLIST_URL % (channel_id, offset, limit), |                 self._PLAYLIST_URL % (channel_id, offset, limit), | ||||||
|                 channel_id, 'Downloading %s videos JSON page %d' % (self._PLAYLIST_TYPE, counter)) |                 channel_id, 'Downloading %s videos JSON page %d' % (self._PLAYLIST_TYPE, counter)) | ||||||
|             videos = response['videos'] |             page_entries = self._extract_playlist_page(response) | ||||||
|             if not videos: |             if not page_entries: | ||||||
|                 break |                 break | ||||||
|             entries.extend([self.url_result(video['url']) for video in videos]) |             entries.extend(page_entries) | ||||||
|             offset += limit |             offset += limit | ||||||
|         return self.playlist_result(entries, channel_id, channel_name) |         return self.playlist_result( | ||||||
|  |             [self.url_result(entry) for entry in set(entries)], | ||||||
|  |             channel_id, channel_name) | ||||||
|  |  | ||||||
|  |     def _extract_playlist_page(self, response): | ||||||
|  |         videos = response.get('videos') | ||||||
|  |         return [video['url'] for video in videos] if videos else [] | ||||||
|  |  | ||||||
|     def _real_extract(self, url): |     def _real_extract(self, url): | ||||||
|         return self._extract_playlist(self._match_id(url)) |         return self._extract_playlist(self._match_id(url)) | ||||||
| @@ -262,6 +268,31 @@ class TwitchPastBroadcastsIE(TwitchPlaylistBaseIE): | |||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class TwitchBookmarksIE(TwitchPlaylistBaseIE): | ||||||
|  |     IE_NAME = 'twitch:bookmarks' | ||||||
|  |     _VALID_URL = r'%s/(?P<id>[^/]+)/profile/bookmarks/?(?:\#.*)?$' % TwitchBaseIE._VALID_URL_BASE | ||||||
|  |     _PLAYLIST_URL = '%s/api/bookmark/?user=%%s&offset=%%d&limit=%%d' % TwitchBaseIE._API_BASE | ||||||
|  |     _PLAYLIST_TYPE = 'bookmarks' | ||||||
|  |  | ||||||
|  |     _TEST = { | ||||||
|  |         'url': 'http://www.twitch.tv/ognos/profile/bookmarks', | ||||||
|  |         'info_dict': { | ||||||
|  |             'id': 'ognos', | ||||||
|  |             'title': 'Ognos', | ||||||
|  |         }, | ||||||
|  |         'playlist_mincount': 3, | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     def _extract_playlist_page(self, response): | ||||||
|  |         entries = [] | ||||||
|  |         for bookmark in response.get('bookmarks', []): | ||||||
|  |             video = bookmark.get('video') | ||||||
|  |             if not video: | ||||||
|  |                 continue | ||||||
|  |             entries.append(video['url']) | ||||||
|  |         return entries | ||||||
|  |  | ||||||
|  |  | ||||||
| class TwitchStreamIE(TwitchBaseIE): | class TwitchStreamIE(TwitchBaseIE): | ||||||
|     IE_NAME = 'twitch:stream' |     IE_NAME = 'twitch:stream' | ||||||
|     _VALID_URL = r'%s/(?P<id>[^/]+)/?(?:\#.*)?$' % TwitchBaseIE._VALID_URL_BASE |     _VALID_URL = r'%s/(?P<id>[^/]+)/?(?:\#.*)?$' % TwitchBaseIE._VALID_URL_BASE | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user