1
0
mirror of https://github.com/ytdl-org/youtube-dl.git synced 2024-11-25 00:00:43 +01:00

[francetv] Add support for embeds and clean up _VALID_URL

This commit is contained in:
Sergey M․ 2015-07-18 22:41:34 +06:00
parent e58066e244
commit 3f5c6d0c1b

View File

@ -160,11 +160,19 @@ class FranceTvInfoIE(FranceTVBaseInfoExtractor):
class FranceTVIE(FranceTVBaseInfoExtractor): class FranceTVIE(FranceTVBaseInfoExtractor):
IE_NAME = 'francetv' IE_NAME = 'francetv'
IE_DESC = 'France 2, 3, 4, 5 and Ô' IE_DESC = 'France 2, 3, 4, 5 and Ô'
_VALID_URL = r'''(?x)https?://www\.france[2345o]\.fr/ _VALID_URL = r'''(?x)
(?: https?://
emissions/.*?/(videos|emissions)/(?P<id>[^/?]+) (?:
| (emissions?|jt)/(?P<key>[^/?]+) (?:www\.)?france[2345o]\.fr/
)''' (?:
emissions/[^/]+/(?:videos|diffusions)?|
videos
)
/|
embed\.francetv\.fr/\?ue=
)
(?P<id>[^/?]+)
'''
_TESTS = [ _TESTS = [
# france2 # france2
@ -232,13 +240,33 @@ class FranceTVIE(FranceTVBaseInfoExtractor):
'timestamp': 1410822000, 'timestamp': 1410822000,
}, },
}, },
{
# francetv embed
'url': 'http://embed.francetv.fr/?ue=8d7d3da1e3047c42ade5a5d7dfd3fc87',
'info_dict': {
'id': 'EV_30231',
'ext': 'flv',
'title': 'Alcaline, le concert avec Calogero',
'description': 'md5:',
'upload_date': '20150226',
'timestamp': 1424989860,
},
},
{
'url': 'http://www.france4.fr/emission/highlander/diffusion-du-17-07-2015-04h05',
'only_matching': True,
},
{
'url': 'http://www.franceo.fr/videos/125377617',
'only_matching': True,
}
] ]
def _real_extract(self, url): def _real_extract(self, url):
mobj = re.match(self._VALID_URL, url) video_id = self._match_id(url)
webpage = self._download_webpage(url, mobj.group('key') or mobj.group('id')) webpage = self._download_webpage(url, video_id)
video_id, catalogue = self._html_search_regex( video_id, catalogue = self._html_search_regex(
r'href="http://videos\.francetv\.fr/video/([^@]+@[^"]+)"', r'href="http://videos?\.francetv\.fr/video/([^@]+@[^"]+)"',
webpage, 'video ID').split('@') webpage, 'video ID').split('@')
return self._extract_video(video_id, catalogue) return self._extract_video(video_id, catalogue)