aboutsummaryrefslogtreecommitdiffstats
path: root/yt_dlp/extractor/mediaset.py
diff options
context:
space:
mode:
Diffstat (limited to 'yt_dlp/extractor/mediaset.py')
-rw-r--r--yt_dlp/extractor/mediaset.py28
1 files changed, 12 insertions, 16 deletions
diff --git a/yt_dlp/extractor/mediaset.py b/yt_dlp/extractor/mediaset.py
index f396c1bd3..61bdb2a3f 100644
--- a/yt_dlp/extractor/mediaset.py
+++ b/yt_dlp/extractor/mediaset.py
@@ -142,6 +142,10 @@ class MediasetIE(ThePlatformBaseIE):
'url': 'https://static3.mediasetplay.mediaset.it/player/index.html?appKey=5ad3966b1de1c4000d5cec48&programGuid=FAFU000000665104&id=665104',
'only_matching': True,
}, {
+ # embedUrl (from https://www.wittytv.it/amici/est-ce-que-tu-maimes-gabriele-5-dicembre-copia/)
+ 'url': 'https://static3.mediasetplay.mediaset.it/player/v2/index.html?partnerId=wittytv&configId=&programGuid=FD00000000153323&autoplay=true&purl=http://www.wittytv.it/amici/est-ce-que-tu-maimes-gabriele-5-dicembre-copia/',
+ 'only_matching': True,
+ }, {
'url': 'mediaset:FAFU000000665924',
'only_matching': True,
}, {
@@ -167,34 +171,28 @@ class MediasetIE(ThePlatformBaseIE):
'only_matching': True,
}]
- @staticmethod
- def _extract_urls(ie, webpage):
- def _qs(url):
- return parse_qs(url)
-
+ def _extract_from_webpage(self, url, webpage):
def _program_guid(qs):
return qs.get('programGuid', [None])[0]
- entries = []
for mobj in re.finditer(
r'<iframe\b[^>]+\bsrc=(["\'])(?P<url>(?:https?:)?//(?:www\.)?video\.mediaset\.it/player/playerIFrame(?:Twitter)?\.shtml.*?)\1',
webpage):
embed_url = mobj.group('url')
- embed_qs = _qs(embed_url)
+ embed_qs = parse_qs(embed_url)
program_guid = _program_guid(embed_qs)
if program_guid:
- entries.append(embed_url)
+ yield self.url_result(embed_url)
continue
+
video_id = embed_qs.get('id', [None])[0]
if not video_id:
continue
- urlh = ie._request_webpage(
- embed_url, video_id, note='Following embed URL redirect')
+ urlh = self._request_webpage(embed_url, video_id, note='Following embed URL redirect')
embed_url = urlh.geturl()
- program_guid = _program_guid(_qs(embed_url))
+ program_guid = _program_guid(parse_qs(embed_url))
if program_guid:
- entries.append(embed_url)
- return entries
+ yield self.url_result(embed_url)
def _parse_smil_formats(self, smil, smil_url, video_id, namespace=None, f4m_params=None, transform_rtmp_url=None):
for video in smil.findall(self._xpath_ns('.//video', namespace)):
@@ -249,8 +247,6 @@ class MediasetIE(ThePlatformBaseIE):
if (first_e or geo_e) and not formats:
raise geo_e or first_e
- self._sort_formats(formats)
-
feed_data = self._download_json(
'https://feed.entertainment.tv.theplatform.eu/f/PR1GhC/mediaset-prod-all-programs-v2/guid/-/' + guid,
guid, fatal=False)
@@ -288,7 +284,7 @@ class MediasetIE(ThePlatformBaseIE):
return info
-class MediasetShowIE(MediasetIE):
+class MediasetShowIE(MediasetIE): # XXX: Do not subclass from concrete IE
_VALID_URL = r'''(?x)
(?:
https?://