diff options
Diffstat (limited to 'youtube_dl/extractor/mangomolo.py')
-rw-r--r-- | youtube_dl/extractor/mangomolo.py | 58 |
1 files changed, 0 insertions, 58 deletions
diff --git a/youtube_dl/extractor/mangomolo.py b/youtube_dl/extractor/mangomolo.py deleted file mode 100644 index acee370e9..000000000 --- a/youtube_dl/extractor/mangomolo.py +++ /dev/null @@ -1,58 +0,0 @@ -# coding: utf-8 -from __future__ import unicode_literals - -from .common import InfoExtractor -from ..compat import ( - compat_b64decode, - compat_urllib_parse_unquote, -) -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( - '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|src)\s*:\s*"(https?://[^"]+?/playlist\.m3u8)', - r'<a[^>]+href="(rtsp://[^"]+)"' - ], webpage, 'format url') - formats = self._extract_wowza_formats( - format_url, page_id, m3u8_entry_protocol, ['smil']) - self._sort_formats(formats) - - return { - 'id': page_id, - 'title': self._live_title(page_id) if self._IS_LIVE else page_id, - 'uploader_id': hidden_inputs.get('userid'), - 'duration': int_or_none(hidden_inputs.get('duration')), - 'is_live': self._IS_LIVE, - 'formats': formats, - } - - -class MangomoloVideoIE(MangomoloBaseIE): - _TYPE = 'video' - IE_NAME = 'mangomolo:' + _TYPE - _VALID_URL = MangomoloBaseIE._BASE_REGEX + r'video\?.*?\bid=(?P<id>\d+)' - _IS_LIVE = False - - -class MangomoloLiveIE(MangomoloBaseIE): - _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): - return compat_b64decode(compat_urllib_parse_unquote(page_id)).decode() |