diff options
Diffstat (limited to 'yt_dlp_plugins/extractor/radiko.py')
-rw-r--r-- | yt_dlp_plugins/extractor/radiko.py | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/yt_dlp_plugins/extractor/radiko.py b/yt_dlp_plugins/extractor/radiko.py index 8ab8cad..0458b92 100644 --- a/yt_dlp_plugins/extractor/radiko.py +++ b/yt_dlp_plugins/extractor/radiko.py @@ -390,6 +390,9 @@ class _RadikoBaseIE(InfoExtractor): _APP_VERSIONS = ["7.5.0", "7.4.17", "7.4.16", "7.4.15", "7.4.14", "7.4.13", "7.4.12", "7.4.11", "7.4.10", "7.4.9", "7.4.8", "7.4.7", "7.4.6", "7.4.5", "7.4.4", "7.4.3", "7.4.2", "7.4.1", "7.4.0", "7.3.8", "7.3.7", "7.3.6", "7.3.1", "7.3.0", "7.2.11", "7.2.10"] + _TF_DELIVERED_ONDEMAND = ('radiko.jp',) + _TF_DOESNT_WORK_WITH_FFMPEG = ('tf-f-rpaa-radiko.smartstream.ne.jp',) + _region = None _user = None @@ -550,6 +553,13 @@ class _RadikoBaseIE(InfoExtractor): "lsid": self._user, "type": "b", # it is a mystery }) + + # defaults + delivered_live = True + preference = -1 + entry_protocol = 'm3u8' + + domain = urllib.parse.urlparse(playlist_url).netloc if timefree: playlist_url = update_url_query(playlist_url, { "start_at": start_at.timestring(), @@ -557,9 +567,18 @@ class _RadikoBaseIE(InfoExtractor): "end_at": end_at.timestring(), "to": end_at.timestring(), }) - domain = urllib.parse.urlparse(playlist_url).netloc + if domain in self._TF_DOESNT_WORK_WITH_FFMPEG: + self.write_debug(f"skipping {domain} (known not working)") + continue + elif domain in self._TF_DELIVERED_ONDEMAND: + # override the defaults for delivered as on-demand + delivered_live = False + preference = 1 + entry_protocol = None + formats += self._extract_m3u8_formats( playlist_url, station, m3u8_id=domain, fatal=False, headers=auth_data, + live=delivered_live, preference=preference, entry_protocol=entry_protocol, note=f"Downloading m3u8 information from {domain}") return formats |