mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2025-01-25 10:47:02 -05:00
e897bd8292
Authored by: bashonly, seproDev, Grub4K Co-authored-by: bashonly <88596187+bashonly@users.noreply.github.com> Co-authored-by: sepro <4618135+seproDev@users.noreply.github.com>
33 lines
1.1 KiB
Python
33 lines
1.1 KiB
Python
from .common import InfoExtractor
|
|
from ..utils import float_or_none, xpath_text
|
|
|
|
|
|
class NuevoBaseIE(InfoExtractor):
|
|
def _extract_nuevo(self, config_url, video_id, headers={}):
|
|
config = self._download_xml(
|
|
config_url, video_id, transform_source=lambda s: s.strip(),
|
|
headers=headers)
|
|
|
|
title = xpath_text(config, './title', 'title', fatal=True).strip()
|
|
video_id = xpath_text(config, './mediaid', default=video_id)
|
|
thumbnail = xpath_text(config, ['./image', './thumb'])
|
|
duration = float_or_none(xpath_text(config, './duration'))
|
|
|
|
formats = []
|
|
for element_name, format_id in (('file', 'sd'), ('filehd', 'hd')):
|
|
video_url = xpath_text(config, element_name)
|
|
if video_url:
|
|
formats.append({
|
|
'url': video_url,
|
|
'format_id': format_id,
|
|
})
|
|
self._check_formats(formats, video_id)
|
|
|
|
return {
|
|
'id': video_id,
|
|
'title': title,
|
|
'thumbnail': thumbnail,
|
|
'duration': duration,
|
|
'formats': formats
|
|
}
|