diff options
Diffstat (limited to 'youtube_dl/extractor/theplatform.py')
| -rw-r--r-- | youtube_dl/extractor/theplatform.py | 34 | 
1 files changed, 18 insertions, 16 deletions
| diff --git a/youtube_dl/extractor/theplatform.py b/youtube_dl/extractor/theplatform.py index 0be793b1c..a04925633 100644 --- a/youtube_dl/extractor/theplatform.py +++ b/youtube_dl/extractor/theplatform.py @@ -6,6 +6,7 @@ import json  from .common import InfoExtractor  from ..utils import (      compat_str, +    determine_ext,      ExtractorError,      xpath_with_ns,  ) @@ -34,10 +35,21 @@ class ThePlatformIE(InfoExtractor):              'skip_download': True,          },      } +    def _real_extract(self, url): +        mobj = re.match(self._VALID_URL, url) +        video_id = mobj.group('id') +        if mobj.group('config'): +            config_url = url+ '&form=json' +            config_url = config_url.replace('swf/', 'config/') +            config_url = config_url.replace('onsite/', 'onsite/config/') +            config = self._download_json(config_url, video_id, 'Downloading config') +            smil_url = config['releaseUrl'] + '&format=SMIL&formats=MPEG4&manifest=f4m' +        else: +            smil_url = ('http://link.theplatform.com/s/dJ5BDC/{0}/meta.smil?' +                'format=smil&mbr=true'.format(video_id)) -    def _get_info(self, video_id, smil_url): -        meta = self._download_xml(smil_url, video_id) +        meta = self._download_xml(smil_url, video_id)          try:              error_msg = next(                  n.attrib['abstract'] @@ -89,10 +101,14 @@ class ThePlatformIE(InfoExtractor):                  for f in switch.findall(_x('smil:video')):                      attr = f.attrib                      vbr = int(attr['system-bitrate']) // 1000 +                    ext = determine_ext(attr['src']) +                    if ext == 'once': +                        ext = 'mp4'                      formats.append({                          'format_id': compat_str(vbr),                          'url': attr['src'],                          'vbr': vbr, +                        'ext': ext,                      })              self._sort_formats(formats) @@ -104,17 +120,3 @@ class ThePlatformIE(InfoExtractor):              'thumbnail': info['defaultThumbnailUrl'],              'duration': info['duration']//1000,          } -         -    def _real_extract(self, url): -        mobj = re.match(self._VALID_URL, url) -        video_id = mobj.group('id') -        if mobj.group('config'): -            config_url = url+ '&form=json' -            config_url = config_url.replace('swf/', 'config/') -            config_url = config_url.replace('onsite/', 'onsite/config/') -            config = self._download_json(config_url, video_id, 'Downloading config') -            smil_url = config['releaseUrl'] + '&format=SMIL&formats=MPEG4&manifest=f4m' -        else: -            smil_url = ('http://link.theplatform.com/s/dJ5BDC/{0}/meta.smil?' -                'format=smil&mbr=true'.format(video_id)) -        return self._get_info(video_id, smil_url) | 
