diff options
| -rw-r--r-- | youtube_dl/downloader/f4m.py | 9 | ||||
| -rw-r--r-- | youtube_dl/extractor/__init__.py | 1 | ||||
| -rw-r--r-- | youtube_dl/extractor/auengine.py | 3 | ||||
| -rw-r--r-- | youtube_dl/extractor/laola1tv.py | 77 | 
4 files changed, 87 insertions, 3 deletions
| diff --git a/youtube_dl/downloader/f4m.py b/youtube_dl/downloader/f4m.py index b3be16ff1..b607f6485 100644 --- a/youtube_dl/downloader/f4m.py +++ b/youtube_dl/downloader/f4m.py @@ -244,9 +244,16 @@ class F4mFD(FileDownloader):                  lambda f: int(f[0]) == requested_bitrate, formats))[0]          base_url = compat_urlparse.urljoin(man_url, media.attrib['url']) -        bootstrap = base64.b64decode(doc.find(_add_ns('bootstrapInfo')).text) +        bootstrap_node = doc.find(_add_ns('bootstrapInfo')) +        if bootstrap_node.text is None: +            bootstrap_url = compat_urlparse.urljoin( +                base_url, bootstrap_node.attrib['url']) +            bootstrap = self.ydl.urlopen(bootstrap_url).read() +        else: +            bootstrap = base64.b64decode(bootstrap_node.text)          metadata = base64.b64decode(media.find(_add_ns('metadata')).text)          boot_info = read_bootstrap_info(bootstrap) +          fragments_list = build_fragments_list(boot_info)          if self.params.get('test', False):              # We only download the first fragment diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index c3799da67..615018c09 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -189,6 +189,7 @@ from .kontrtube import KontrTubeIE  from .krasview import KrasViewIE  from .ku6 import Ku6IE  from .la7 import LA7IE +from .laola1tv import Laola1TvIE  from .lifenews import LifeNewsIE  from .liveleak import LiveLeakIE  from .livestream import ( diff --git a/youtube_dl/extractor/auengine.py b/youtube_dl/extractor/auengine.py index 20bf12550..1c765532a 100644 --- a/youtube_dl/extractor/auengine.py +++ b/youtube_dl/extractor/auengine.py @@ -24,8 +24,7 @@ class AUEngineIE(InfoExtractor):      }      def _real_extract(self, url): -        mobj = re.match(self._VALID_URL, url) -        video_id = mobj.group('id') +        video_id = self._match_id(url)          webpage = self._download_webpage(url, video_id)          title = self._html_search_regex(r'<title>(?P<title>.+?)</title>', webpage, 'title') diff --git a/youtube_dl/extractor/laola1tv.py b/youtube_dl/extractor/laola1tv.py new file mode 100644 index 000000000..263f68773 --- /dev/null +++ b/youtube_dl/extractor/laola1tv.py @@ -0,0 +1,77 @@ +from __future__ import unicode_literals + +import random +import re + +from .common import InfoExtractor + + +class Laola1TvIE(InfoExtractor): +    _VALID_URL = r'https?://(?:www\.)?laola1\.tv/(?P<lang>[a-z]+)-(?P<portal>[a-z]+)/.*?/(?P<id>[0-9]+)\.html' +    _TEST = { +        'url': 'http://www.laola1.tv/de-de/live/bwf-bitburger-open-grand-prix-gold-court-1/250019.html', +        'info_dict': { +            'id': '250019', +            'ext': 'mp4', +            'title': 'Bitburger Open Grand Prix Gold - Court 1', +            'categories': ['Badminton'], +            'uploader': 'BWF - Badminton World Federation', +            'is_live': True, +        }, +        'params': { +            'skip_download': True, +        } +    } + +    _BROKEN = True  # Not really - extractor works fine, but f4m downloader does not support live streams yet. + +    def _real_extract(self, url): +        mobj = re.match(self._VALID_URL, url) +        video_id = mobj.group('id') +        lang = mobj.group('lang') +        portal = mobj.group('portal') + +        webpage = self._download_webpage(url, video_id) +        iframe_url = self._search_regex( +            r'<iframe[^>]*?class="main_tv_player"[^>]*?src="([^"]+)"', +            webpage, 'iframe URL') + +        iframe = self._download_webpage( +            iframe_url, video_id, note='Downloading iframe') +        flashvars_m = re.findall( +            r'flashvars\.([_a-zA-Z0-9]+)\s*=\s*"([^"]*)";', iframe) +        flashvars = dict((m[0], m[1]) for m in flashvars_m) + +        xml_url = ('http://www.laola1.tv/server/hd_video.php?' + +                   'play=%s&partner=1&portal=%s&v5ident=&lang=%s' % ( +                       video_id, portal, lang)) +        hd_doc = self._download_xml(xml_url, video_id) + +        title = hd_doc.find('.//video/title').text +        flash_url = hd_doc.find('.//video/url').text +        categories = hd_doc.find('.//video/meta_sports').text.split(',') +        uploader = hd_doc.find('.//video/meta_organistation').text + +        ident = random.randint(10000000, 99999999) +        token_url = '%s&ident=%s&klub=0&unikey=0×tamp=%s&auth=%s' % ( +            flash_url, ident, flashvars['timestamp'], flashvars['auth']) + +        token_doc = self._download_xml( +            token_url, video_id, note='Downloading token') +        token_attrib = token_doc.find('.//token').attrib +        if token_attrib.get('auth') == 'blocked': +            raise ExtractorError('Token error: ' % token_attrib.get('comment')) + +        video_url = '%s?hdnea=%s&hdcore=3.2.0' % ( +            token_attrib['url'], token_attrib['auth']) + +        return { +            'id': video_id, +            'is_live': True, +            'title': title, +            'url': video_url, +            'uploader': uploader, +            'categories': categories, +            'ext': 'mp4', +        } + | 
