aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/yt_dlp_plugins/extractor
diff options
context:
space:
mode:
Diffstat (limited to 'yt_dlp_plugins/extractor')
-rw-r--r--yt_dlp_plugins/extractor/radiko.py38
1 files changed, 38 insertions, 0 deletions
diff --git a/yt_dlp_plugins/extractor/radiko.py b/yt_dlp_plugins/extractor/radiko.py
index 024d9a6..a9f53f5 100644
--- a/yt_dlp_plugins/extractor/radiko.py
+++ b/yt_dlp_plugins/extractor/radiko.py
@@ -681,3 +681,41 @@ class RadikoStationButtonIE(InfoExtractor):
station = traverse_obj(queries, ("station_id", 0))
return self.url_result(f"https://radiko.jp/#!/live/{station}", RadikoLiveIE)
+
+
+class RadikoPersonIE(InfoExtractor):
+ _VALID_URL = r"https?://(?:www\.)?radiko\.jp/persons/(?P<id>\d+)"
+
+ def _real_extract(self, url):
+ person_id = self._match_id(url)
+
+ now = rtime.RadikoTime.now(tz=rtime.JST)
+
+ min_start = (now - datetime.timedelta(days=7)).broadcast_day_start()
+ # we set the earliest time as the earliest we can get,
+ # so, the start of the broadcast day 1 week ago
+ # that way we can get everything we can actually download, including stuff that aired at eg "26:00"
+
+ person_api_url = update_url_query("https://api.radiko.jp/program/api/v1/programs", {
+ "person_id": person_id,
+ "start_at_gte": min_start.isoformat(),
+ "end_at_lt": now.isoformat(),
+ })
+ person_api = self._download_json(person_api_url, person_id)
+
+ def entries():
+ for episode in person_api.get("data"):
+
+ share_url = traverse_obj(episode, ("radiko_url", ("pc", "sp", "android", "ios", "app"),
+ {url_or_none}), get_all=False)
+ # they're all identical share links at the moment (5th aug 2024) but they might not be in the future
+
+ # predictions:
+ # pc will probably stay the same
+ # don't know what sp is, possibly "SmartPhone"?, anyway seems reasonably generic
+ # android is easier for me to reverse-engineer than ios (no ithing)
+ # i assume "app" would be some internal tell-it-to-do-something link, not a regular web link
+
+ yield self.url_result(share_url, ie=RadikoShareIE, video_title=episode.get("title"))
+
+ return self.playlist_result(entries(), playlist_id=join_nonempty("person", person_id))