diff options
| author | Remita Amine <remitamine@gmail.com> | 2019-10-17 13:21:44 +0100 | 
|---|---|---|
| committer | Remita Amine <remitamine@gmail.com> | 2019-10-17 13:21:44 +0100 | 
| commit | 755541a4c8ac3dd4e8b9abd0c7df95182a1f3fd4 (patch) | |
| tree | 33763c40eb2894ceb62fb15aae8ea15dc92d476f | |
| parent | 86f63633c8e7c62ce245d1352d4d381efb614466 (diff) | |
[mangomolo] fix video format extraction and add support for player URLs
| -rw-r--r-- | youtube_dl/extractor/generic.py | 8 | ||||
| -rw-r--r-- | youtube_dl/extractor/mangomolo.py | 17 | 
2 files changed, 17 insertions, 8 deletions
| diff --git a/youtube_dl/extractor/generic.py b/youtube_dl/extractor/generic.py index ec43c5ae4..5ed952b29 100644 --- a/youtube_dl/extractor/generic.py +++ b/youtube_dl/extractor/generic.py @@ -2962,10 +2962,14 @@ class GenericIE(InfoExtractor):          # Look for Mangomolo embeds          mobj = re.search( -            r'''(?x)<iframe[^>]+src=(["\'])(?P<url>(?:https?:)?//(?:www\.)?admin\.mangomolo\.com/analytics/index\.php/customers/embed/ +            r'''(?x)<iframe[^>]+src=(["\'])(?P<url>(?:https?:)?// +                (?: +                    admin\.mangomolo\.com/analytics/index\.php/customers/embed| +                    player\.mangomolo\.com/v1 +                )/                  (?:                      video\?.*?\bid=(?P<video_id>\d+)| -                    index\?.*?\bchannelid=(?P<channel_id>(?:[A-Za-z0-9+/=]|%2B|%2F|%3D)+) +                    (?:index|live)\?.*?\bchannelid=(?P<channel_id>(?:[A-Za-z0-9+/=]|%2B|%2F|%3D)+)                  ).+?)\1''', webpage)          if mobj is not None:              info = { diff --git a/youtube_dl/extractor/mangomolo.py b/youtube_dl/extractor/mangomolo.py index 482175a34..acee370e9 100644 --- a/youtube_dl/extractor/mangomolo.py +++ b/youtube_dl/extractor/mangomolo.py @@ -10,18 +10,21 @@ from ..utils import int_or_none  class MangomoloBaseIE(InfoExtractor): +    _BASE_REGEX = r'https?://(?:admin\.mangomolo\.com/analytics/index\.php/customers/embed/|player\.mangomolo\.com/v1/)' +      def _get_real_id(self, page_id):          return page_id      def _real_extract(self, url):          page_id = self._get_real_id(self._match_id(url)) -        webpage = self._download_webpage(url, page_id) +        webpage = self._download_webpage( +            'https://player.mangomolo.com/v1/%s?%s' % (self._TYPE, url.split('?')[1]), page_id)          hidden_inputs = self._hidden_inputs(webpage)          m3u8_entry_protocol = 'm3u8' if self._IS_LIVE else 'm3u8_native'          format_url = self._html_search_regex(              [ -                r'file\s*:\s*"(https?://[^"]+?/playlist\.m3u8)', +                r'(?:file|src)\s*:\s*"(https?://[^"]+?/playlist\.m3u8)',                  r'<a[^>]+href="(rtsp://[^"]+)"'              ], webpage, 'format url')          formats = self._extract_wowza_formats( @@ -39,14 +42,16 @@ class MangomoloBaseIE(InfoExtractor):  class MangomoloVideoIE(MangomoloBaseIE): -    IE_NAME = 'mangomolo:video' -    _VALID_URL = r'https?://admin\.mangomolo\.com/analytics/index\.php/customers/embed/video\?.*?\bid=(?P<id>\d+)' +    _TYPE = 'video' +    IE_NAME = 'mangomolo:' + _TYPE +    _VALID_URL = MangomoloBaseIE._BASE_REGEX + r'video\?.*?\bid=(?P<id>\d+)'      _IS_LIVE = False  class MangomoloLiveIE(MangomoloBaseIE): -    IE_NAME = 'mangomolo:live' -    _VALID_URL = r'https?://admin\.mangomolo\.com/analytics/index\.php/customers/embed/index\?.*?\bchannelid=(?P<id>(?:[A-Za-z0-9+/=]|%2B|%2F|%3D)+)' +    _TYPE = 'live' +    IE_NAME = 'mangomolo:' + _TYPE +    _VALID_URL = MangomoloBaseIE._BASE_REGEX + r'(live|index)\?.*?\bchannelid=(?P<id>(?:[A-Za-z0-9+/=]|%2B|%2F|%3D)+)'      _IS_LIVE = True      def _get_real_id(self, page_id): | 
