aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCasperMcFadden95 <145611964+CasperMcFadden95@users.noreply.github.com>2025-04-03 19:02:24 +0000
committerGitHub <noreply@github.com>2025-04-03 21:02:24 +0200
commite1847535e28788414a25546a45bebcada2f34558 (patch)
tree4972fdfc06193c7070e8a371d42fafeaea20e516
parent5361a7c6e2933c919716e0cb1e3116c28c40419f (diff)
[ie/RoyaLive] Add extractor (#12817)
Authored by: CasperMcFadden95
-rw-r--r--yt_dlp/extractor/_extractors.py1
-rw-r--r--yt_dlp/extractor/roya.py43
2 files changed, 44 insertions, 0 deletions
diff --git a/yt_dlp/extractor/_extractors.py b/yt_dlp/extractor/_extractors.py
index 679a0a6a6..9fc891365 100644
--- a/yt_dlp/extractor/_extractors.py
+++ b/yt_dlp/extractor/_extractors.py
@@ -1739,6 +1739,7 @@ from .roosterteeth import (
RoosterTeethSeriesIE,
)
from .rottentomatoes import RottenTomatoesIE
+from .roya import RoyaLiveIE
from .rozhlas import (
MujRozhlasIE,
RozhlasIE,
diff --git a/yt_dlp/extractor/roya.py b/yt_dlp/extractor/roya.py
new file mode 100644
index 000000000..e9fe304ee
--- /dev/null
+++ b/yt_dlp/extractor/roya.py
@@ -0,0 +1,43 @@
+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,
+ }