3 from .common
import InfoExtractor
4 from .rutv
import RUTVIE
5 from ..utils
import ExtractorError
8 class VestiIE(InfoExtractor
):
11 _VALID_URL
= r
'https?://(?:.+?\.)?vesti\.ru/(?P<id>.+)'
15 'url': 'http://www.vesti.ru/videos?vid=575582&cid=1',
19 'title': 'Вести.net: биткоины в России не являются законными',
20 'description': 'md5:d4bb3859dc1177b28a94c5014c35a36b',
25 'skip_download': True,
29 'url': 'http://www.vesti.ru/doc.html?id=1349233',
33 'title': 'Участники митинга штурмуют Донецкую областную администрацию',
34 'description': 'md5:1a160e98b3195379b4c849f2f4958009',
39 'skip_download': True,
43 'url': 'http://www.vesti.ru/only_video.html?vid=576180',
47 'title': 'США заморозило, Британию затопило',
48 'description': 'md5:f0ed0695ec05aed27c56a70a58dc4cc1',
53 'skip_download': True,
57 'url': 'http://hitech.vesti.ru/news/view/id/4000',
61 'title': 'Вести.net: интернет-гиганты начали перетягивание программных "одеял"',
62 'description': 'md5:65ddd47f9830c4f42ed6475f8730c995',
67 'skip_download': True,
71 'url': 'http://sochi2014.vesti.ru/video/index/video_id/766403',
75 'title': 'XXII зимние Олимпийские игры. Российские хоккеисты стартовали на Олимпиаде с победы',
76 'description': 'md5:55805dfd35763a890ff50fa9e35e31b3',
81 'skip_download': True,
83 'skip': 'Blocked outside Russia',
86 'url': 'http://sochi2014.vesti.ru/live/play/live_id/301',
90 'title': 'Сочи-2014. Биатлон. Индивидуальная гонка. Мужчины ',
91 'description': 'md5:9e0ed5c9d2fa1efbfdfed90c9a6d179c',
95 'skip_download': True,
97 'skip': 'Translation has finished',
101 def _real_extract(self
, url
):
102 mobj
= self
._match
_valid
_url
(url
)
103 video_id
= mobj
.group('id')
105 page
= self
._download
_webpage
(url
, video_id
, 'Downloading page')
108 r
'<meta[^>]+?property="og:video"[^>]+?content="http://www\.vesti\.ru/i/flvplayer_videoHost\.swf\?vid=(?P<id>\d+)',
111 video_id
= mobj
.group('id')
112 page
= self
._download
_webpage
(f
'http://www.vesti.ru/only_video.html?vid={video_id}', video_id
,
113 'Downloading video page')
115 rutv_url
= RUTVIE
._extract
_url
(page
)
117 return self
.url_result(rutv_url
, 'RUTV')
119 raise ExtractorError('No video found', expected
=True)