mirror of
https://github.com/yt-dlp/yt-dlp
synced 2025-01-15 03:41:33 +01:00
86e5f3ed2e
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
37 lines
1.3 KiB
Python
37 lines
1.3 KiB
Python
from .common import InfoExtractor
|
|
from ..utils import unified_strdate
|
|
|
|
|
|
class CozyTVIE(InfoExtractor):
|
|
_VALID_URL = r'https?://(?:www\.)?cozy\.tv/(?P<uploader>[^/]+)/replays/(?P<id>[^/$#&?]+)'
|
|
|
|
_TESTS = [{
|
|
'url': 'https://cozy.tv/beardson/replays/2021-11-19_1',
|
|
'info_dict': {
|
|
'id': 'beardson-2021-11-19_1',
|
|
'ext': 'mp4',
|
|
'title': 'pokemon pt2',
|
|
'uploader': 'beardson',
|
|
'upload_date': '20211119',
|
|
'was_live': True,
|
|
'duration': 7981,
|
|
},
|
|
'params': {'skip_download': True}
|
|
}]
|
|
|
|
def _real_extract(self, url):
|
|
uploader, date = self._match_valid_url(url).groups()
|
|
id = f'{uploader}-{date}'
|
|
data_json = self._download_json(f'https://api.cozy.tv/cache/{uploader}/replay/{date}', id)
|
|
formats, subtitles = self._extract_m3u8_formats_and_subtitles(
|
|
f'https://cozycdn.foxtrotstream.xyz/replays/{uploader}/{date}/index.m3u8', id, ext='mp4')
|
|
return {
|
|
'id': id,
|
|
'title': data_json.get('title'),
|
|
'uploader': data_json.get('user') or uploader,
|
|
'upload_date': unified_strdate(data_json.get('date')),
|
|
'was_live': True,
|
|
'duration': data_json.get('duration'),
|
|
'formats': formats,
|
|
'subtitles': subtitles,
|
|
}
|