1
0
Fork 0
mirror of https://github.com/ytdl-org/youtube-dl.git synced 2024-06-02 10:29:28 +00:00

[rtve]: Switch audio extractor to thumbnail parsing so all urls are supported

This commit is contained in:
Raúl Sánchez Siles 2021-10-12 22:20:11 +02:00
parent 894578ee74
commit df4e6b21fa

View file

@ -204,14 +204,52 @@ class RTVEAudioIE(RTVEALaCartaIE):
'thumbnail': r're:https?://.+/1613243011863.jpg',
'duration': 3559.559,
},
}, {
'url': 'https://www.rtve.es/play/audios/frankenstein-o-el-moderno-prometeo/capitulo-26-ultimo-muerte-victor-juan-jose-plans-mary-shelley/6082623/',
'md5': '0eadab248cc8dd193fa5765712e84d5c',
'info_dict': {
'id': '6082623',
'ext': 'mp3',
'title': 'Capítulo 26 y último: La muerte de Victor',
'thumbnail': r're:https?://.+/1632147445707.jpg',
'duration': 3174.086,
},
}]
def _extract_png_formats(self, audio_id):
print(__name__, self._manager, audio_id)
png = self._download_webpage(
'http://www.rtve.es/ztnr/movil/thumbnail/%s/audios/%s.png' %
(self._manager, audio_id),
audio_id, 'Downloading url information', query={'q': 'v2'})
q = qualities(['Media', 'Alta', 'HQ', 'HD_READY', 'HD_FULL'])
formats = []
for quality, audio_url in self._decrypt_url(png):
ext = determine_ext(audio_url)
print(quality, audio_url, ext)
if ext == 'm3u8':
formats.extend(self._extract_m3u8_formats(
audio_url, audio_id, 'mp4', 'm3u8_native',
m3u8_id='hls', fatal=False))
elif ext == 'mpd':
formats.extend(self._extract_mpd_formats(
audio_url, audio_id, 'dash', fatal=False))
else:
formats.append({
'format_id': quality,
'quality': q(quality),
'url': audio_url,
})
self._sort_formats(formats)
return formats
def _real_extract(self, url):
audio_id = self._match_id(url)
info = self._download_json(
'https://www.rtve.es/api/audios/%s.json' % audio_id,
audio_id)['page']['items'][0]
title = info['title'].strip()
formats = self._extract_png_formats(audio_id)
return {
'id': audio_id,
@ -219,7 +257,7 @@ class RTVEAudioIE(RTVEALaCartaIE):
'thumbnail': info.get('thumbnail'),
'duration': float_or_none(info.get('duration'), 1000),
'series': info.get('programInfo').get('title'),
'url': info.get('qualities')[0].get('filePath'),
'formats': formats,
}