]>
Commit | Line | Data |
---|---|---|
1 | from .common import InfoExtractor | |
2 | ||
3 | ||
4 | class GlideIE(InfoExtractor): | |
5 | IE_DESC = 'Glide mobile video messages (glide.me)' | |
6 | _VALID_URL = r'https?://share\.glide\.me/(?P<id>[A-Za-z0-9\-=_+]+)' | |
7 | _TEST = { | |
8 | 'url': 'http://share.glide.me/UZF8zlmuQbe4mr+7dCiQ0w==', | |
9 | 'md5': '4466372687352851af2d131cfaa8a4c7', | |
10 | 'info_dict': { | |
11 | 'id': 'UZF8zlmuQbe4mr+7dCiQ0w==', | |
12 | 'ext': 'mp4', | |
13 | 'title': "Damon's Glide message", | |
14 | 'thumbnail': r're:^https?://.*?\.cloudfront\.net/.*\.jpg$', | |
15 | } | |
16 | } | |
17 | ||
18 | def _real_extract(self, url): | |
19 | video_id = self._match_id(url) | |
20 | ||
21 | webpage = self._download_webpage(url, video_id) | |
22 | ||
23 | title = self._html_extract_title(webpage, default=None) or self._og_search_title(webpage) | |
24 | video_url = self._proto_relative_url(self._search_regex( | |
25 | r'<source[^>]+src=(["\'])(?P<url>.+?)\1', | |
26 | webpage, 'video URL', default=None, | |
27 | group='url')) or self._og_search_video_url(webpage) | |
28 | thumbnail = self._proto_relative_url(self._search_regex( | |
29 | r'<img[^>]+id=["\']video-thumbnail["\'][^>]+src=(["\'])(?P<url>.+?)\1', | |
30 | webpage, 'thumbnail url', default=None, | |
31 | group='url')) or self._og_search_thumbnail(webpage) | |
32 | ||
33 | return { | |
34 | 'id': video_id, | |
35 | 'title': title, | |
36 | 'url': video_url, | |
37 | 'thumbnail': thumbnail, | |
38 | } |