diff --git a/yt_dlp/extractor/_extractors.py b/yt_dlp/extractor/_extractors.py index 9b96bd5b45..94369ca66f 100644 --- a/yt_dlp/extractor/_extractors.py +++ b/yt_dlp/extractor/_extractors.py @@ -1590,6 +1590,7 @@ from .restudy import RestudyIE from .reuters import ReutersIE from .reverbnation import ReverbNationIE from .rheinmaintv import RheinMainTVIE +from .rinsefm import RinseFMIE from .rmcdecouverte import RMCDecouverteIE from .rockstargames import RockstarGamesIE from .rokfin import ( diff --git a/yt_dlp/extractor/rinsefm.py b/yt_dlp/extractor/rinsefm.py new file mode 100644 index 0000000000..760adf0eba --- /dev/null +++ b/yt_dlp/extractor/rinsefm.py @@ -0,0 +1,33 @@ +from .common import InfoExtractor +from ..utils import format_field, parse_iso8601 + + +class RinseFMIE(InfoExtractor): + _VALID_URL = r'https?://(?:www\.)?rinse\.fm/episodes/(?P[^/?#]+)' + _TESTS = [{ + 'url': 'https://rinse.fm/episodes/club-glow-15-12-2023-2000/', + 'md5': '76ee0b719315617df42e15e710f46c7b', + 'info_dict': { + 'id': '1536535', + 'ext': 'mp3', + 'title': 'Club Glow - 15/12/2023 - 20:00', + 'thumbnail': r're:^https://.+\.(?:jpg|JPG)$', + 'release_timestamp': 1702598400, + 'release_date': '20231215' + } + }] + + def _real_extract(self, url): + display_id = self._match_id(url) + webpage = self._download_webpage(url, display_id) + entry = self._search_nextjs_data(webpage, display_id)['props']['pageProps']['entry'] + + return { + 'id': entry['id'], + 'title': entry.get('title'), + 'url': entry['fileUrl'], + 'vcodec': 'none', + 'release_timestamp': parse_iso8601(entry.get('episodeDate')), + 'thumbnail': format_field( + entry, [('featuredImage', 0, 'filename')], 'https://rinse.imgix.net/media/%s', default=None), + }