diff options
| author | Philipp Hagemeister <phihag@phihag.de> | 2015-01-23 17:22:45 +0100 | 
|---|---|---|
| committer | Philipp Hagemeister <phihag@phihag.de> | 2015-01-23 17:22:45 +0100 | 
| commit | d229ee70da4fbfa25a02c75f02a8c39abadbe970 (patch) | |
| tree | 54ffa4cd99473bb4eb15473643998b99e8d605b9 | |
| parent | 26e274666d285026dfb6033cdad74cc2a108e2bc (diff) | |
| parent | ebd46aed5119899826629cf751ba5abe7a65d50b (diff) | |
Merge remote-tracking branch 'origin/master'
| -rw-r--r-- | youtube_dl/downloader/f4m.py | 9 | ||||
| -rw-r--r-- | youtube_dl/extractor/__init__.py | 1 | ||||
| -rw-r--r-- | youtube_dl/extractor/atresplayer.py | 15 | ||||
| -rw-r--r-- | youtube_dl/extractor/twitch.py | 41 | 
4 files changed, 53 insertions, 13 deletions
diff --git a/youtube_dl/downloader/f4m.py b/youtube_dl/downloader/f4m.py index c460c167a..c68b2c303 100644 --- a/youtube_dl/downloader/f4m.py +++ b/youtube_dl/downloader/f4m.py @@ -177,13 +177,12 @@ def build_fragments_list(boot_info):      """ Return a list of (segment, fragment) for each fragment in the video """      res = []      segment_run_table = boot_info['segments'][0] -    # I've only found videos with one segment -    segment_run_entry = segment_run_table['segment_run'][0] -    n_frags = segment_run_entry[1]      fragment_run_entry_table = boot_info['fragments'][0]['fragments']      first_frag_number = fragment_run_entry_table[0]['first'] -    for (i, frag_number) in zip(range(1, n_frags + 1), itertools.count(first_frag_number)): -        res.append((1, frag_number)) +    fragments_counter = itertools.count(first_frag_number) +    for segment, fragments_count in segment_run_table['segment_run']: +        for _ in range(fragments_count): +            res.append((segment, next(fragments_counter)))      return res diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index 9ab90ac62..9e1ce5db3 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -467,6 +467,7 @@ from .twitch import (      TwitchVodIE,      TwitchProfileIE,      TwitchPastBroadcastsIE, +    TwitchBookmarksIE,      TwitchStreamIE,  )  from .ubu import UbuIE diff --git a/youtube_dl/extractor/atresplayer.py b/youtube_dl/extractor/atresplayer.py index 5db1941b3..8fd69b971 100644 --- a/youtube_dl/extractor/atresplayer.py +++ b/youtube_dl/extractor/atresplayer.py @@ -105,13 +105,22 @@ class AtresPlayerIE(InfoExtractor):                  raise ExtractorError(                      '%s returned error: %s' % (self.IE_NAME, result), expected=True) -            for _, video_url in fmt_json['resultObject'].items(): +            for format_id, video_url in fmt_json['resultObject'].items(): +                if format_id == 'token' or not video_url.startswith('http'): +                    continue                  if video_url.endswith('/Manifest'): -                    formats.extend(self._extract_f4m_formats(video_url[:-9] + '/manifest.f4m', video_id)) +                    if 'geodeswowsmpra3player' in video_url: +                        f4m_path = video_url.split('smil:', 1)[-1].split('free_', 1)[0] +                        f4m_url = 'http://drg.antena3.com/{0}hds/es/sd.f4m'.format(f4m_path) +                        # this videos are protected by DRM, the f4m downloader doesn't support them +                        continue +                    else: +                        f4m_url = video_url[:-9] + '/manifest.f4m' +                    formats.extend(self._extract_f4m_formats(f4m_url, video_id))                  else:                      formats.append({                          'url': video_url, -                        'format_id': 'android', +                        'format_id': 'android-%s' % format_id,                          'preference': 1,                      })          self._sort_formats(formats) diff --git a/youtube_dl/extractor/twitch.py b/youtube_dl/extractor/twitch.py index 340cadcf5..741df7cbc 100644 --- a/youtube_dl/extractor/twitch.py +++ b/youtube_dl/extractor/twitch.py @@ -220,12 +220,18 @@ class TwitchPlaylistBaseIE(TwitchBaseIE):              response = self._download_json(                  self._PLAYLIST_URL % (channel_id, offset, limit),                  channel_id, 'Downloading %s videos JSON page %d' % (self._PLAYLIST_TYPE, counter)) -            videos = response['videos'] -            if not videos: +            page_entries = self._extract_playlist_page(response) +            if not page_entries:                  break -            entries.extend([self.url_result(video['url']) for video in videos]) +            entries.extend(page_entries)              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):          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):      IE_NAME = 'twitch:stream'      _VALID_URL = r'%s/(?P<id>[^/]+)/?(?:\#.*)?$' % TwitchBaseIE._VALID_URL_BASE @@ -348,4 +379,4 @@ class TwitchStreamIE(TwitchBaseIE):              'view_count': view_count,              'formats': formats,              'is_live': True, -        } +        }
\ No newline at end of file  | 
