diff options
| -rw-r--r-- | youtube_dl/extractor/cbs.py | 84 | ||||
| -rw-r--r-- | youtube_dl/extractor/cbsnews.py | 31 | ||||
| -rw-r--r-- | youtube_dl/extractor/cbssports.py | 40 | 
3 files changed, 44 insertions, 111 deletions
diff --git a/youtube_dl/extractor/cbs.py b/youtube_dl/extractor/cbs.py index ac2c7dced..030eeaa65 100644 --- a/youtube_dl/extractor/cbs.py +++ b/youtube_dl/extractor/cbs.py @@ -2,16 +2,14 @@ from __future__ import unicode_literals  import re -from .theplatform import ThePlatformIE +from .theplatform import ThePlatformFeedIE  from ..utils import ( -    xpath_text, -    xpath_element,      int_or_none,      find_xpath_attr,  ) -class CBSBaseIE(ThePlatformIE): +class CBSBaseIE(ThePlatformFeedIE):      def _parse_smil_subtitles(self, smil, namespace=None, subtitles_lang='en'):          closed_caption_e = find_xpath_attr(smil, self._xpath_ns('.//param', namespace), 'name', 'ClosedCaptionURL')          return { @@ -21,9 +19,22 @@ class CBSBaseIE(ThePlatformIE):              }]          } if closed_caption_e is not None and closed_caption_e.attrib.get('value') else [] +    def _extract_video_info(self, filter_query, video_id): +        return self._extract_feed_info( +            'dJ5BDC', 'VxxJg8Ymh8sE', filter_query, video_id, lambda entry: { +                'series': entry.get('cbs$SeriesTitle'), +                'season_number': int_or_none(entry.get('cbs$SeasonNumber')), +                'episode': entry.get('cbs$EpisodeTitle'), +                'episode_number': int_or_none(entry.get('cbs$EpisodeNumber')), +            }, { +                'StreamPack': { +                    'manifest': 'm3u', +                } +            }) +  class CBSIE(CBSBaseIE): -    _VALID_URL = r'(?:cbs:(?P<content_id>\w+)|https?://(?:www\.)?(?:cbs\.com/shows/[^/]+/(?:video|artist)|colbertlateshow\.com/(?:video|podcasts))/[^/]+/(?P<display_id>[^/]+))' +    _VALID_URL = r'(?:cbs|https?://(?:www\.)?(?:cbs\.com/shows/[^/]+/video|colbertlateshow\.com/(?:video|podcasts))/)(?P<id>[\w-]+)'      _TESTS = [{          'url': 'http://www.cbs.com/shows/garth-brooks/video/_u7W953k6la293J7EPTd9oHkSPs6Xn6_/connect-chat-feat-garth-brooks/', @@ -38,25 +49,7 @@ class CBSIE(CBSBaseIE):              'upload_date': '20131127',              'uploader': 'CBSI-NEW',          }, -        'params': { -            # rtmp download -            'skip_download': True, -        }, -        '_skip': 'Blocked outside the US', -    }, { -        'url': 'http://www.cbs.com/shows/liveonletterman/artist/221752/st-vincent/', -        'info_dict': { -            'id': 'WWF_5KqY3PK1', -            'display_id': 'st-vincent', -            'ext': 'flv', -            'title': 'Live on Letterman - St. Vincent', -            'description': 'Live On Letterman: St. Vincent in concert from New York\'s Ed Sullivan Theater on Tuesday, July 16, 2014.', -            'duration': 3221, -        }, -        'params': { -            # rtmp download -            'skip_download': True, -        }, +        'expected_warnings': ['Failed to download m3u8 information'],          '_skip': 'Blocked outside the US',      }, {          'url': 'http://colbertlateshow.com/video/8GmB0oY0McANFvp2aEffk9jZZZ2YyXxy/the-colbeard/', @@ -68,44 +61,5 @@ class CBSIE(CBSBaseIE):      TP_RELEASE_URL_TEMPLATE = 'http://link.theplatform.com/s/dJ5BDC/%s?mbr=true'      def _real_extract(self, url): -        content_id, display_id = re.match(self._VALID_URL, url).groups() -        if not content_id: -            webpage = self._download_webpage(url, display_id) -            content_id = self._search_regex( -                [r"video\.settings\.content_id\s*=\s*'([^']+)';", r"cbsplayer\.contentId\s*=\s*'([^']+)';"], -                webpage, 'content id') -        items_data = self._download_xml( -            'http://can.cbs.com/thunder/player/videoPlayerService.php', -            content_id, query={'partner': 'cbs', 'contentId': content_id}) -        video_data = xpath_element(items_data, './/item') -        title = xpath_text(video_data, 'videoTitle', 'title', True) - -        subtitles = {} -        formats = [] -        for item in items_data.findall('.//item'): -            pid = xpath_text(item, 'pid') -            if not pid: -                continue -            tp_release_url = self.TP_RELEASE_URL_TEMPLATE % pid -            if '.m3u8' in xpath_text(item, 'contentUrl', default=''): -                tp_release_url += '&manifest=m3u' -            tp_formats, tp_subtitles = self._extract_theplatform_smil( -                tp_release_url, content_id, 'Downloading %s SMIL data' % pid) -            formats.extend(tp_formats) -            subtitles = self._merge_subtitles(subtitles, tp_subtitles) -        self._sort_formats(formats) - -        info = self.get_metadata('dJ5BDC/media/guid/2198311517/%s' % content_id, content_id) -        info.update({ -            'id': content_id, -            'display_id': display_id, -            'title': title, -            'series': xpath_text(video_data, 'seriesTitle'), -            'season_number': int_or_none(xpath_text(video_data, 'seasonNumber')), -            'episode_number': int_or_none(xpath_text(video_data, 'episodeNumber')), -            'duration': int_or_none(xpath_text(video_data, 'videoLength'), 1000), -            'thumbnail': xpath_text(video_data, 'previewImageURL'), -            'formats': formats, -            'subtitles': subtitles, -        }) -        return info +        content_id = self._match_id(url) +        return self._extract_video_info('byGuid=%s' % content_id, content_id) diff --git a/youtube_dl/extractor/cbsnews.py b/youtube_dl/extractor/cbsnews.py index 79ddc20a0..387537e76 100644 --- a/youtube_dl/extractor/cbsnews.py +++ b/youtube_dl/extractor/cbsnews.py @@ -30,9 +30,12 @@ class CBSNewsIE(CBSBaseIE):          {              'url': 'http://www.cbsnews.com/videos/fort-hood-shooting-army-downplays-mental-illness-as-cause-of-attack/',              'info_dict': { -                'id': 'fort-hood-shooting-army-downplays-mental-illness-as-cause-of-attack', +                'id': 'SNJBOYzXiWBOvaLsdzwH8fmtP1SCd91Y',                  'ext': 'mp4',                  'title': 'Fort Hood shooting: Army downplays mental illness as cause of attack', +                'description': 'md5:4a6983e480542d8b333a947bfc64ddc7', +                'upload_date': '19700101', +                'uploader': 'CBSI-NEW',                  'thumbnail': 're:^https?://.*\.jpg$',                  'duration': 205,                  'subtitles': { @@ -58,30 +61,8 @@ class CBSNewsIE(CBSBaseIE):              webpage, 'video JSON info'), video_id)          item = video_info['item'] if 'item' in video_info else video_info -        title = item.get('articleTitle') or item.get('hed') -        duration = item.get('duration') -        thumbnail = item.get('mediaImage') or item.get('thumbnail') - -        subtitles = {} -        formats = [] -        for format_id in ['RtmpMobileLow', 'RtmpMobileHigh', 'Hls', 'RtmpDesktop']: -            pid = item.get('media' + format_id) -            if not pid: -                continue -            release_url = 'http://link.theplatform.com/s/dJ5BDC/%s?mbr=true' % pid -            tp_formats, tp_subtitles = self._extract_theplatform_smil(release_url, video_id, 'Downloading %s SMIL data' % pid) -            formats.extend(tp_formats) -            subtitles = self._merge_subtitles(subtitles, tp_subtitles) -        self._sort_formats(formats) - -        return { -            'id': video_id, -            'title': title, -            'thumbnail': thumbnail, -            'duration': duration, -            'formats': formats, -            'subtitles': subtitles, -        } +        guid = item['mpxRefId'] +        return self._extract_video_info('byGuid=%s' % guid, guid)  class CBSNewsLiveVideoIE(InfoExtractor): diff --git a/youtube_dl/extractor/cbssports.py b/youtube_dl/extractor/cbssports.py index 549ae32f3..78ca44b02 100644 --- a/youtube_dl/extractor/cbssports.py +++ b/youtube_dl/extractor/cbssports.py @@ -1,30 +1,28 @@  from __future__ import unicode_literals -import re +from .cbs import CBSBaseIE -from .common import InfoExtractor +class CBSSportsIE(CBSBaseIE): +    _VALID_URL = r'https?://www\.cbssports\.com/video/player/[^/]+/(?P<id>\d+)' -class CBSSportsIE(InfoExtractor): -    _VALID_URL = r'https?://www\.cbssports\.com/video/player/(?P<section>[^/]+)/(?P<id>[^/]+)' - -    _TEST = { -        'url': 'http://www.cbssports.com/video/player/tennis/318462531970/0/us-open-flashbacks-1990s', +    _TESTS = [{ +        'url': 'http://www.cbssports.com/video/player/videos/708337219968/0/ben-simmons-the-next-lebron?-not-so-fast',          'info_dict': { -            'id': '_d5_GbO8p1sT', -            'ext': 'flv', -            'title': 'US Open flashbacks: 1990s', -            'description': 'Bill Macatee relives the best moments in US Open history from the 1990s.', +            'id': '708337219968', +            'ext': 'mp4', +            'title': 'Ben Simmons the next LeBron? Not so fast', +            'description': 'md5:854294f627921baba1f4b9a990d87197', +            'timestamp': 1466293740, +            'upload_date': '20160618', +            'uploader': 'CBSI-NEW',          }, -    } +        'params': { +            # m3u8 download +            'skip_download': True, +        } +    }]      def _real_extract(self, url): -        mobj = re.match(self._VALID_URL, url) -        section = mobj.group('section') -        video_id = mobj.group('id') -        all_videos = self._download_json( -            'http://www.cbssports.com/data/video/player/getVideos/%s?as=json' % section, -            video_id) -        # The json file contains the info of all the videos in the section -        video_info = next(v for v in all_videos if v['pcid'] == video_id) -        return self.url_result('theplatform:%s' % video_info['pid'], 'ThePlatform') +        video_id = self._match_id(url) +        return self._extract_video_info('byId=%s' % video_id, video_id)  | 
