commit: 449c66577640a0c3f0b383204a1e7284429a61c3
parent 23aec3d623146d06535a4f5388693c1e9a2bbfde
Author: james <jrabblac@gmail.com>
Date: Sat, 17 Jun 2017 17:15:41 +0200
[raiplay:live] Add extractor
Diffstat:
2 files changed, 19 insertions(+), 1 deletion(-)
diff --git a/youtube_dl/extractor/extractors.py b/youtube_dl/extractor/extractors.py
@@ -824,6 +824,7 @@ from .radiobremen import RadioBremenIE
from .radiofrance import RadioFranceIE
from .rai import (
RaiPlayIE,
+ RaiPlayLiveIE,
RaiIE,
)
from .rbmaradio import RBMARadioIE
diff --git a/youtube_dl/extractor/rai.py b/youtube_dl/extractor/rai.py
@@ -208,10 +208,27 @@ class RaiPlayIE(RaiBaseIE):
}
info.update(relinker_info)
-
return info
+class RaiPlayLiveIE(RaiBaseIE):
+ _VALID_URL = r'https?://(?:www\.)?raiplay\.it/dirette/(?P<id>\w*)'
+ _TEST = {
+ 'url': 'http://www.raiplay.it/dirette/rai3',
+ 'only_matching': True,
+ }
+
+ def _real_extract(self, url):
+ channel = self._match_id(url)
+
+ webpage = self._download_webpage(url, channel)
+ re_id = r'<div([^>]*)data-uniquename=(["\'])[\w-]*(?P<id>%s)(\2)([^>]*?)>' % RaiBaseIE._UUID_RE
+ video_id = self._html_search_regex(re_id, webpage, 'livestream-id', group='id')
+
+ return self.url_result('http://www.raiplay.it/dirette/ContentItem-%s.html' % video_id,
+ RaiPlayIE.ie_key(), video_id)
+
+
class RaiIE(RaiBaseIE):
_VALID_URL = r'https?://[^/]+\.(?:rai\.(?:it|tv)|rainews\.it)/dl/.+?-(?P<id>%s)(?:-.+?)?\.html' % RaiBaseIE._UUID_RE
_TESTS = [{