mirror of
https://github.com/yt-dlp/yt-dlp
synced 2025-04-05 14:38:10 -05:00
44 lines
1.4 KiB
Python
44 lines
1.4 KiB
Python
from .common import InfoExtractor
|
|
from ..utils.traversal import traverse_obj
|
|
|
|
|
|
class RoyaLiveIE(InfoExtractor):
|
|
_VALID_URL = r'https?://roya\.tv/live-stream/(?P<id>\d+)'
|
|
_TESTS = [{
|
|
'url': 'https://roya.tv/live-stream/1',
|
|
'info_dict': {
|
|
'id': '1',
|
|
'title': r're:Roya TV \d{4}-\d{2}-\d{2} \d{2}:\d{2}',
|
|
'ext': 'mp4',
|
|
'live_status': 'is_live',
|
|
},
|
|
}, {
|
|
'url': 'https://roya.tv/live-stream/21',
|
|
'info_dict': {
|
|
'id': '21',
|
|
'title': r're:Roya News \d{4}-\d{2}-\d{2} \d{2}:\d{2}',
|
|
'ext': 'mp4',
|
|
'live_status': 'is_live',
|
|
},
|
|
}, {
|
|
'url': 'https://roya.tv/live-stream/10000',
|
|
'only_matching': True,
|
|
}]
|
|
|
|
def _real_extract(self, url):
|
|
media_id = self._match_id(url)
|
|
|
|
stream_url = self._download_json(
|
|
f'https://ticket.roya-tv.com/api/v5/fastchannel/{media_id}', media_id)['data']['secured_url']
|
|
|
|
title = traverse_obj(
|
|
self._download_json('https://backend.roya.tv/api/v01/channels/schedule-pagination', media_id, fatal=False),
|
|
('data', 0, 'channel', lambda _, v: str(v['id']) == media_id, 'title', {str}, any))
|
|
|
|
return {
|
|
'id': media_id,
|
|
'formats': self._extract_m3u8_formats(stream_url, media_id, 'mp4', m3u8_id='hls', live=True),
|
|
'title': title,
|
|
'is_live': True,
|
|
}
|