This commit is contained in:
DataGhost 2024-08-21 22:32:46 -04:00 committed by GitHub
commit d02c3ecaa5
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -3,13 +3,14 @@ from __future__ import unicode_literals
from .common import InfoExtractor from .common import InfoExtractor
from ..utils import ( from ..utils import (
determine_ext,
int_or_none, int_or_none,
qualities, qualities,
) )
class DumpertIE(InfoExtractor): class DumpertIE(InfoExtractor):
_VALID_URL = r'(?P<protocol>https?)://(?:(?:www|legacy)\.)?dumpert\.nl/(?:mediabase|embed|item)/(?P<id>[0-9]+[/_][0-9a-zA-Z]+)' _VALID_URL = r'(?P<protocol>https?)://(?:(?:www|legacy)\.)?dumpert\.nl(?:/(?:mediabase|embed|item)/|(?:/toppers|/latest)?/?\?selectedId=)(?P<id>[0-9]+[/_][0-9a-zA-Z]+)'
_TESTS = [{ _TESTS = [{
'url': 'https://www.dumpert.nl/item/6646981_951bc60f', 'url': 'https://www.dumpert.nl/item/6646981_951bc60f',
'md5': '1b9318d7d5054e7dcb9dc7654f21d643', 'md5': '1b9318d7d5054e7dcb9dc7654f21d643',
@ -29,6 +30,25 @@ class DumpertIE(InfoExtractor):
}, { }, {
'url': 'http://legacy.dumpert.nl/embed/6675421/dc440fe7', 'url': 'http://legacy.dumpert.nl/embed/6675421/dc440fe7',
'only_matching': True, 'only_matching': True,
}, {
'url': 'https://www.dumpert.nl/item/100031688_b317a185',
'md5': '34a0c10c91d281141b959b27ee862b8f',
'info_dict': {
'id': '100031688/b317a185',
'ext': 'mp4',
'title': 'Epic schijnbeweging',
'description': '<p>Die zag je niet eh</p>',
'thumbnail': r're:^https?://.*\.(?:jpg|png)$',
},
}, {
'url': 'https://www.dumpert.nl/toppers?selectedId=100031688_b317a185',
'only_matching': True,
}, {
'url': 'https://www.dumpert.nl/latest?selectedId=100031688_b317a185',
'only_matching': True,
}, {
'url': 'https://www.dumpert.nl/?selectedId=100031688_b317a185',
'only_matching': True,
}] }]
def _real_extract(self, url): def _real_extract(self, url):
@ -39,17 +59,24 @@ class DumpertIE(InfoExtractor):
title = item['title'] title = item['title']
media = next(m for m in item['media'] if m.get('mediatype') == 'VIDEO') media = next(m for m in item['media'] if m.get('mediatype') == 'VIDEO')
quality = qualities(['flv', 'mobile', 'tablet', '720p']) quality = qualities(['flv', 'mobile', 'tablet', '720p', '1080p'])
formats = [] formats = []
for variant in media.get('variants', []): for variant in media.get('variants', []):
uri = variant.get('uri') uri = variant.get('uri')
if not uri: if not uri:
continue continue
version = variant.get('version') version = variant.get('version')
preference = quality(version)
ext = determine_ext(uri)
if ext == 'm3u8':
formats.extend(self._extract_m3u8_formats(
uri, video_id, ext='mp4', entry_protocol='m3u8_native',
preference=preference))
else:
formats.append({ formats.append({
'url': uri, 'url': uri,
'format_id': version, 'format_id': version,
'quality': quality(version), 'preference': preference,
}) })
self._sort_formats(formats) self._sort_formats(formats)