2 from __future__ import unicode_literals
6 from .common import InfoExtractor
13 class VestiIE(InfoExtractor):
16 _VALID_URL = r'http://(?:.+?\.)?(?:vesti\.ru|russia\.tv)/(?P<id>.+)'
20 'url': 'http://www.vesti.ru/videos?vid=575582&cid=1',
24 'title': 'Вести.net: биткоины в России не являются законными',
25 'description': 'md5:d4bb3859dc1177b28a94c5014c35a36b',
30 'skip_download': True,
34 'url': 'http://www.vesti.ru/doc.html?id=1349233',
38 'title': 'Участники митинга штурмуют Донецкую областную администрацию',
39 'description': 'md5:1a160e98b3195379b4c849f2f4958009',
44 'skip_download': True,
48 'url': 'http://www.vesti.ru/only_video.html?vid=576180',
52 'title': 'США заморозило, Британию затопило',
53 'description': 'md5:f0ed0695ec05aed27c56a70a58dc4cc1',
58 'skip_download': True,
62 'url': 'http://hitech.vesti.ru/news/view/id/4000',
66 'title': 'Вести.net: интернет-гиганты начали перетягивание программных "одеял"',
67 'description': 'md5:65ddd47f9830c4f42ed6475f8730c995',
72 'skip_download': True,
76 'url': 'http://russia.tv/video/show/brand_id/5169/episode_id/970443/video_id/975648',
80 'title': 'Прямой эфир. Жертвы загадочной болезни: смерть от старости в 17 лет',
81 'description': 'md5:b81c8c55247a4bd996b43ce17395b2d8',
86 'skip_download': True,
90 'url': 'http://russia.tv/brand/show/brand_id/57638',
94 'title': 'Чужой в семье Сталина',
100 'skip_download': True,
104 'url': 'http://sochi2014.vesti.ru/video/index/video_id/766403',
108 'title': 'XXII зимние Олимпийские игры. Российские хоккеисты стартовали на Олимпиаде с победы',
109 'description': 'md5:55805dfd35763a890ff50fa9e35e31b3',
114 'skip_download': True,
116 'skip': 'Blocked outside Russia'
119 'url': 'http://sochi2014.vesti.ru/live/play/live_id/301',
123 'title': 'Сочи-2014. Биатлон. Индивидуальная гонка. Мужчины ',
124 'description': 'md5:9e0ed5c9d2fa1efbfdfed90c9a6d179c',
128 'skip_download': True,
130 'skip': 'Translation has finished'
134 def _real_extract(self, url):
135 mobj = re.match(self._VALID_URL, url)
136 video_id = mobj.group('id')
138 page = self._download_webpage(url, video_id, 'Downloading page')
141 r'<meta property="og:video" content="http://www\.vesti\.ru/i/flvplayer_videoHost\.swf\?vid=(?P<id>\d+)',
144 video_id = mobj.group('id')
145 page = self._download_webpage('http://www.vesti.ru/only_video.html?vid=%s' % video_id, video_id,
146 'Downloading video page')
149 r'<meta property="og:video" content="http://player\.rutv\.ru/flash2v/container\.swf\?id=(?P<id>\d+)', page)
152 video_id = mobj.group('id')
155 r'<iframe.+?src="http://player\.rutv\.ru/iframe/(?P<type>[^/]+)/id/(?P<id>\d+)[^"]*".*?></iframe>',
159 raise ExtractorError('No media found', expected=True)
161 video_type = mobj.group('type')
162 video_id = mobj.group('id')
164 json_data = self._download_json(
165 'http://player.rutv.ru/iframe/%splay/id/%s' % ('live-' if video_type == 'live' else '', video_id),
166 video_id, 'Downloading JSON')
168 if json_data['errors']:
169 raise ExtractorError('vesti returned error: %s' % json_data['errors'], expected=True)
171 playlist = json_data['data']['playlist']
172 medialist = playlist['medialist']
176 raise ExtractorError('vesti returned error: %s' % media['errors'], expected=True)
178 view_count = playlist.get('count_views')
179 priority_transport = playlist['priority_transport']
181 thumbnail = media['picture']
182 width = int_or_none(media['width'])
183 height = int_or_none(media['height'])
184 description = media['anons']
185 title = media['title']
186 duration = int_or_none(media.get('duration'))
190 for transport, links in media['sources'].items():
191 for quality, url in links.items():
192 if transport == 'rtmp':
193 mobj = re.search(r'^(?P<url>rtmp://[^/]+/(?P<app>.+))/(?P<playpath>.+)$', url)
197 'url': mobj.group('url'),
198 'play_path': mobj.group('playpath'),
199 'app': mobj.group('app'),
200 'page_url': 'http://player.rutv.ru',
201 'player_url': 'http://player.rutv.ru/flash2v/osmf.swf?i=22',
206 elif transport == 'm3u8':
218 'format_id': '%s-%s' % (transport, quality),
219 'preference': -1 if priority_transport == transport else -2,
224 raise ExtractorError('No media links available for %s' % video_id)
226 self._sort_formats(formats)
231 'description': description,
232 'thumbnail': thumbnail,
233 'view_count': view_count,
234 'duration': duration,