|
|
@ -4,16 +4,12 @@ from __future__ import unicode_literals |
|
|
|
import random |
|
|
|
|
|
|
|
from .common import InfoExtractor |
|
|
|
from ..compat import compat_urllib_parse_urlencode |
|
|
|
from ..utils import ( |
|
|
|
sanitized_Request, |
|
|
|
xpath_text, |
|
|
|
) |
|
|
|
from ..utils import xpath_text |
|
|
|
|
|
|
|
|
|
|
|
class MatchTVIE(InfoExtractor): |
|
|
|
_VALID_URL = r'https?://matchtv\.ru/?#live-player' |
|
|
|
_TEST = { |
|
|
|
_VALID_URL = r'https?://matchtv\.ru(?:/on-air|/?#live-player)' |
|
|
|
_TESTS = [{ |
|
|
|
'url': 'http://matchtv.ru/#live-player', |
|
|
|
'info_dict': { |
|
|
|
'id': 'matchtv-live', |
|
|
@ -24,12 +20,16 @@ class MatchTVIE(InfoExtractor): |
|
|
|
'params': { |
|
|
|
'skip_download': True, |
|
|
|
}, |
|
|
|
} |
|
|
|
}, { |
|
|
|
'url': 'http://matchtv.ru/on-air/', |
|
|
|
'only_matching': True, |
|
|
|
}] |
|
|
|
|
|
|
|
def _real_extract(self, url): |
|
|
|
video_id = 'matchtv-live' |
|
|
|
request = sanitized_Request( |
|
|
|
'http://player.matchtv.ntvplus.tv/player/smil?%s' % compat_urllib_parse_urlencode({ |
|
|
|
video_url = self._download_json( |
|
|
|
'http://player.matchtv.ntvplus.tv/player/smil', video_id, |
|
|
|
query={ |
|
|
|
'ts': '', |
|
|
|
'quality': 'SD', |
|
|
|
'contentId': '561d2c0df7159b37178b4567', |
|
|
@ -40,11 +40,10 @@ class MatchTVIE(InfoExtractor): |
|
|
|
'contentType': 'channel', |
|
|
|
'timeShift': '0', |
|
|
|
'platform': 'portal', |
|
|
|
}), |
|
|
|
}, |
|
|
|
headers={ |
|
|
|
'Referer': 'http://player.matchtv.ntvplus.tv/embed-player/NTVEmbedPlayer.swf', |
|
|
|
}) |
|
|
|
video_url = self._download_json(request, video_id)['data']['videoUrl'] |
|
|
|
})['data']['videoUrl'] |
|
|
|
f4m_url = xpath_text(self._download_xml(video_url, video_id), './to') |
|
|
|
formats = self._extract_f4m_formats(f4m_url, video_id) |
|
|
|
self._sort_formats(formats) |
|
|
|