mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2025-10-24 03:08:34 +00:00

Using https://github.com/asottile/pyupgrade 1. `__future__` imports and `coding: utf-8` were removed 2. Files were rewritten with `pyupgrade --py36-plus --keep-percent-format` 3. f-strings were cherry-picked from `pyupgrade --py36-plus` Extractors are left untouched (except removing header) to avoid unnecessary merge conflicts
57 lines
2.2 KiB
Python
57 lines
2.2 KiB
Python
from .ard import ARDMediathekBaseIE
|
|
from ..utils import (
|
|
ExtractorError,
|
|
get_element_by_attribute,
|
|
)
|
|
|
|
|
|
class SRMediathekIE(ARDMediathekBaseIE):
|
|
IE_NAME = 'sr:mediathek'
|
|
IE_DESC = 'Saarländischer Rundfunk'
|
|
_VALID_URL = r'https?://sr-mediathek(?:\.sr-online)?\.de/index\.php\?.*?&id=(?P<id>[0-9]+)'
|
|
|
|
_TESTS = [{
|
|
'url': 'http://sr-mediathek.sr-online.de/index.php?seite=7&id=28455',
|
|
'info_dict': {
|
|
'id': '28455',
|
|
'ext': 'mp4',
|
|
'title': 'sportarena (26.10.2014)',
|
|
'description': 'Ringen: KSV Köllerbach gegen Aachen-Walheim; Frauen-Fußball: 1. FC Saarbrücken gegen Sindelfingen; Motorsport: Rallye in Losheim; dazu: Interview mit Timo Bernhard; Turnen: TG Saar; Reitsport: Deutscher Voltigier-Pokal; Badminton: Interview mit Michael Fuchs ',
|
|
'thumbnail': r're:^https?://.*\.jpg$',
|
|
},
|
|
'skip': 'no longer available',
|
|
}, {
|
|
'url': 'http://sr-mediathek.sr-online.de/index.php?seite=7&id=37682',
|
|
'info_dict': {
|
|
'id': '37682',
|
|
'ext': 'mp4',
|
|
'title': 'Love, Cakes and Rock\'n\'Roll',
|
|
'description': 'md5:18bf9763631c7d326c22603681e1123d',
|
|
},
|
|
'params': {
|
|
# m3u8 download
|
|
'skip_download': True,
|
|
},
|
|
}, {
|
|
'url': 'http://sr-mediathek.de/index.php?seite=7&id=7480',
|
|
'only_matching': True,
|
|
}]
|
|
|
|
def _real_extract(self, url):
|
|
video_id = self._match_id(url)
|
|
webpage = self._download_webpage(url, video_id)
|
|
|
|
if '>Der gewünschte Beitrag ist leider nicht mehr verfügbar.<' in webpage:
|
|
raise ExtractorError('Video %s is no longer available' % video_id, expected=True)
|
|
|
|
media_collection_url = self._search_regex(
|
|
r'data-mediacollection-ardplayer="([^"]+)"', webpage, 'media collection url')
|
|
info = self._extract_media_info(media_collection_url, webpage, video_id)
|
|
info.update({
|
|
'id': video_id,
|
|
'title': get_element_by_attribute('class', 'ardplayer-title', webpage),
|
|
'description': self._og_search_description(webpage),
|
|
'thumbnail': self._og_search_thumbnail(webpage),
|
|
})
|
|
return info
|