]> jfr.im git - yt-dlp.git/blame - yt_dlp/extractor/tele5.py
[ie/orf:on] Improve extraction (#9677)
[yt-dlp.git] / yt_dlp / extractor / tele5.py
CommitLineData
50e93e03 1from .dplay import DPlayIE
2from ..compat import compat_urlparse
a5b6102e 3from ..utils import (
50e93e03 4 ExtractorError,
5 extract_attributes,
a5b6102e 6)
d0de6a28
JR
7
8
6368e2e6 9class Tele5IE(DPlayIE): # XXX: Do not subclass from concrete IE
df773c3d 10 _WORKING = False
0e0bfd33 11 _VALID_URL = r'https?://(?:www\.)?tele5\.de/(?:[^/]+/)*(?P<id>[^/?#&]+)'
a5b6102e 12 _GEO_COUNTRIES = ['DE']
d0de6a28 13 _TESTS = [{
ae2384ff 14 'url': 'https://www.tele5.de/mediathek/filme-online/videos?vid=1549416',
d0de6a28 15 'info_dict': {
ae2384ff 16 'id': '1549416',
d0de6a28 17 'ext': 'mp4',
ae2384ff
S
18 'upload_date': '20180814',
19 'timestamp': 1534290623,
20 'title': 'Pandorum',
21 },
22 'params': {
23 'skip_download': True,
24 },
50e93e03 25 'skip': 'No longer available: "404 Seite nicht gefunden"',
0b1eaec3
S
26 }, {
27 # jwplatform, nexx unavailable
28 'url': 'https://www.tele5.de/filme/ghoul-das-geheimnis-des-friedhofmonsters/',
29 'info_dict': {
30 'id': 'WJuiOlUp',
31 'ext': 'mp4',
32 'upload_date': '20200603',
33 'timestamp': 1591214400,
34 'title': 'Ghoul - Das Geheimnis des Friedhofmonsters',
35 'description': 'md5:42002af1d887ff3d5b2b3ca1f8137d97',
36 },
37 'params': {
38 'skip_download': True,
39 },
50e93e03 40 'skip': 'No longer available, redirects to Filme page',
41 }, {
42 'url': 'https://tele5.de/mediathek/angel-of-mine/',
43 'info_dict': {
44 'id': '1252360',
45 'ext': 'mp4',
46 'upload_date': '20220109',
47 'timestamp': 1641762000,
48 'title': 'Angel of Mine',
49 'description': 'md5:a72546a175e1286eb3251843a52d1ad7',
50 },
51 'params': {
52 'format': 'bestvideo',
53 },
ae2384ff 54 }, {
0e0bfd33 55 'url': 'https://www.tele5.de/kalkofes-mattscheibe/video-clips/politik-und-gesellschaft?ve_id=1551191',
ae2384ff 56 'only_matching': True,
d0de6a28 57 }, {
0e0bfd33
S
58 'url': 'https://www.tele5.de/video-clip/?ve_id=1609440',
59 'only_matching': True,
60 }, {
61 'url': 'https://www.tele5.de/filme/schlefaz-dragon-crusaders/',
62 'only_matching': True,
63 }, {
64 'url': 'https://www.tele5.de/filme/making-of/avengers-endgame/',
65 'only_matching': True,
66 }, {
67 'url': 'https://www.tele5.de/star-trek/raumschiff-voyager/ganze-folge/das-vinculum/',
68 'only_matching': True,
69 }, {
70 'url': 'https://www.tele5.de/anders-ist-sevda/',
d0de6a28
JR
71 'only_matching': True,
72 }]
73
74 def _real_extract(self, url):
50e93e03 75 video_id = self._match_id(url)
76 webpage = self._download_webpage(url, video_id)
77 player_element = self._search_regex(r'(<hyoga-player\b[^>]+?>)', webpage, 'video player')
78 player_info = extract_attributes(player_element)
79 asset_id, country, realm = (player_info[x] for x in ('assetid', 'locale', 'realm', ))
80 endpoint = compat_urlparse.urlparse(player_info['endpoint']).hostname
81 source_type = player_info.get('sourcetype')
82 if source_type:
83 endpoint = '%s-%s' % (source_type, endpoint)
84 try:
85 return self._get_disco_api_info(url, asset_id, endpoint, realm, country)
86 except ExtractorError as e:
87 if getattr(e, 'message', '') == 'Missing deviceId in context':
88 self.report_drm(video_id)
89 raise