mirror of
https://github.com/LucBerge/yt-dlp.git
synced 2025-03-17 19:57:52 +03:00
Using https://github.com/asottile/pyupgrade 1. `__future__` imports and `coding: utf-8` were removed 2. Files were rewritten with `pyupgrade --py36-plus --keep-percent-format` 3. f-strings were cherry-picked from `pyupgrade --py36-plus` Extractors are left untouched (except removing header) to avoid unnecessary merge conflicts
52 lines
1.7 KiB
Python
52 lines
1.7 KiB
Python
import random
|
|
|
|
from .common import InfoExtractor
|
|
from ..utils import xpath_text
|
|
|
|
|
|
class MatchTVIE(InfoExtractor):
|
|
_VALID_URL = r'https?://matchtv\.ru(?:/on-air|/?#live-player)'
|
|
_TESTS = [{
|
|
'url': 'http://matchtv.ru/#live-player',
|
|
'info_dict': {
|
|
'id': 'matchtv-live',
|
|
'ext': 'flv',
|
|
'title': r're:^Матч ТВ - Прямой эфир \d{4}-\d{2}-\d{2} \d{2}:\d{2}$',
|
|
'is_live': True,
|
|
},
|
|
'params': {
|
|
'skip_download': True,
|
|
},
|
|
}, {
|
|
'url': 'http://matchtv.ru/on-air/',
|
|
'only_matching': True,
|
|
}]
|
|
|
|
def _real_extract(self, url):
|
|
video_id = 'matchtv-live'
|
|
video_url = self._download_json(
|
|
'http://player.matchtv.ntvplus.tv/player/smil', video_id,
|
|
query={
|
|
'ts': '',
|
|
'quality': 'SD',
|
|
'contentId': '561d2c0df7159b37178b4567',
|
|
'sign': '',
|
|
'includeHighlights': '0',
|
|
'userId': '',
|
|
'sessionId': random.randint(1, 1000000000),
|
|
'contentType': 'channel',
|
|
'timeShift': '0',
|
|
'platform': 'portal',
|
|
},
|
|
headers={
|
|
'Referer': 'http://player.matchtv.ntvplus.tv/embed-player/NTVEmbedPlayer.swf',
|
|
})['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)
|
|
return {
|
|
'id': video_id,
|
|
'title': 'Матч ТВ - Прямой эфир',
|
|
'is_live': True,
|
|
'formats': formats,
|
|
}
|