mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-31 14:45:14 +00:00 
			
		
		
		
	| @@ -337,6 +337,7 @@ from .cbc import ( | |||||||
|     CBCGemIE, |     CBCGemIE, | ||||||
|     CBCGemLiveIE, |     CBCGemLiveIE, | ||||||
|     CBCGemPlaylistIE, |     CBCGemPlaylistIE, | ||||||
|  |     CBCListenIE, | ||||||
|     CBCPlayerIE, |     CBCPlayerIE, | ||||||
|     CBCPlayerPlaylistIE, |     CBCPlayerPlaylistIE, | ||||||
| ) | ) | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ from ..utils.traversal import require, traverse_obj, trim_str | |||||||
| 
 | 
 | ||||||
| class CBCIE(InfoExtractor): | class CBCIE(InfoExtractor): | ||||||
|     IE_NAME = 'cbc.ca' |     IE_NAME = 'cbc.ca' | ||||||
|     _VALID_URL = r'https?://(?:www\.)?cbc\.ca/(?!player/)(?:[^/]+/)+(?P<id>[^/?#]+)' |     _VALID_URL = r'https?://(?:www\.)?cbc\.ca/(?!player/|listen/|i/caffeine/syndicate/)(?:[^/?#]+/)+(?P<id>[^/?#]+)' | ||||||
|     _TESTS = [{ |     _TESTS = [{ | ||||||
|         # with mediaId |         # with mediaId | ||||||
|         'url': 'http://www.cbc.ca/22minutes/videos/clips-season-23/don-cherry-play-offs', |         'url': 'http://www.cbc.ca/22minutes/videos/clips-season-23/don-cherry-play-offs', | ||||||
| @@ -112,10 +112,6 @@ class CBCIE(InfoExtractor): | |||||||
|         'playlist_mincount': 6, |         'playlist_mincount': 6, | ||||||
|     }] |     }] | ||||||
| 
 | 
 | ||||||
|     @classmethod |  | ||||||
|     def suitable(cls, url): |  | ||||||
|         return False if CBCPlayerIE.suitable(url) else super().suitable(url) |  | ||||||
| 
 |  | ||||||
|     def _extract_player_init(self, player_init, display_id): |     def _extract_player_init(self, player_init, display_id): | ||||||
|         player_info = self._parse_json(player_init, display_id, js_to_json) |         player_info = self._parse_json(player_init, display_id, js_to_json) | ||||||
|         media_id = player_info.get('mediaId') |         media_id = player_info.get('mediaId') | ||||||
| @@ -913,3 +909,63 @@ class CBCGemLiveIE(InfoExtractor): | |||||||
|                 'thumbnail': ('images', 'card', 'url'), |                 'thumbnail': ('images', 'card', 'url'), | ||||||
|             }), |             }), | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | class CBCListenIE(InfoExtractor): | ||||||
|  |     IE_NAME = 'cbc.ca:listen' | ||||||
|  |     _VALID_URL = r'https?://(?:www\.)?cbc\.ca/listen/(?:cbc-podcasts|live-radio)/[\w-]+/[\w-]+/(?P<id>\d+)' | ||||||
|  |     _TESTS = [{ | ||||||
|  |         'url': 'https://www.cbc.ca/listen/cbc-podcasts/1353-the-naked-emperor/episode/16142603-introducing-understood-who-broke-the-internet', | ||||||
|  |         'info_dict': { | ||||||
|  |             'id': '16142603', | ||||||
|  |             'title': 'Introducing Understood: Who Broke the Internet?', | ||||||
|  |             'ext': 'mp3', | ||||||
|  |             'description': 'md5:c605117500084e43f08a950adc6a708c', | ||||||
|  |             'duration': 229, | ||||||
|  |             'timestamp': 1745812800, | ||||||
|  |             'release_timestamp': 1745827200, | ||||||
|  |             'release_date': '20250428', | ||||||
|  |             'upload_date': '20250428', | ||||||
|  |         }, | ||||||
|  |     }, { | ||||||
|  |         'url': 'https://www.cbc.ca/listen/live-radio/1-64-the-house/clip/16170773-should-canada-suck-stand-donald-trump', | ||||||
|  |         'info_dict': { | ||||||
|  |             'id': '16170773', | ||||||
|  |             'title': 'Should Canada suck up or stand up to Donald Trump?', | ||||||
|  |             'ext': 'mp3', | ||||||
|  |             'description': 'md5:7385194f1cdda8df27ba3764b35e7976', | ||||||
|  |             'duration': 3159, | ||||||
|  |             'timestamp': 1758340800, | ||||||
|  |             'release_timestamp': 1758254400, | ||||||
|  |             'release_date': '20250919', | ||||||
|  |             'upload_date': '20250920', | ||||||
|  |         }, | ||||||
|  |     }] | ||||||
|  | 
 | ||||||
|  |     def _real_extract(self, url): | ||||||
|  |         video_id = self._match_id(url) | ||||||
|  | 
 | ||||||
|  |         response = self._download_json( | ||||||
|  |             f'https://www.cbc.ca/listen/api/v1/clips/{video_id}', video_id, fatal=False) | ||||||
|  |         data = traverse_obj(response, ('data', {dict})) | ||||||
|  |         if not data: | ||||||
|  |             self.report_warning('API failed to return data. Falling back to webpage parsing') | ||||||
|  |             webpage = self._download_webpage(url, video_id) | ||||||
|  |             preloaded_state = self._search_json( | ||||||
|  |                 r'window\.__PRELOADED_STATE__\s*=', webpage, 'preloaded state', | ||||||
|  |                 video_id, transform_source=js_to_json) | ||||||
|  |             data = traverse_obj(preloaded_state, ( | ||||||
|  |                 ('podcastDetailData', 'showDetailData'), ..., 'episodes', | ||||||
|  |                 lambda _, v: str(v['clipID']) == video_id, any, {require('episode data')})) | ||||||
|  | 
 | ||||||
|  |         return { | ||||||
|  |             'id': video_id, | ||||||
|  |             **traverse_obj(data, { | ||||||
|  |                 'url': (('src', 'url'), {url_or_none}, any), | ||||||
|  |                 'title': ('title', {str}), | ||||||
|  |                 'description': ('description', {str}), | ||||||
|  |                 'release_timestamp': ('releasedAt', {int_or_none(scale=1000)}), | ||||||
|  |                 'timestamp': ('airdate', {int_or_none(scale=1000)}), | ||||||
|  |                 'duration': ('duration', {int_or_none}), | ||||||
|  |             }), | ||||||
|  |         } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 uoag
					uoag