]>
Raphaël G. Git Repositories - youtubedl/blob - youtube_dl/extractor/vk.py
   2 from __future__ 
import unicode_literals
 
   7 from .common 
import InfoExtractor
 
  10     compat_urllib_request
, 
  17 class VKIE(InfoExtractor
): 
  19     _VALID_URL 
= r
'https?://vk\.com/(?:videos.*?\?.*?z=)?video(?P<id>.*?)(?:\?|%2F|$)' 
  24             'url': 'http://vk.com/videos-77521?z=video-77521_162222515%2Fclub77521', 
  25             'md5': '0deae91935c54e00003c2a00646315f0', 
  29                 'title': 'ProtivoGunz - Хуёвая песня', 
  30                 'uploader': 'Noize MC', 
  35             'url': 'http://vk.com/video4643923_163339118', 
  36             'md5': 'f79bccb5cd182b1f43502ca5685b2b36', 
  40                 'uploader': 'Elvira Dzhonik', 
  41                 'title': 'Dream Theater - Hollow Years Live at Budokan 720*', 
  46             'url': 'http://vk.com/video-8871596_164049491', 
  47             'md5': 'a590bcaf3d543576c9bd162812387666', 
  48             'note': 'Only available for registered users', 
  52                 'uploader': 'Триллеры', 
  53                 'title': '► Бойцовский клуб / Fight Club 1999 [HD 720]\u00a0', 
  56             'skip': 'Requires vk account credentials', 
  61         (username
, password
) = self
._get
_login
_info
() 
  73         request 
= compat_urllib_request
.Request('https://login.vk.com/?act=login', 
  74             compat_urllib_parse
.urlencode(login_form
).encode('utf-8')) 
  75         login_page 
= self
._download
_webpage
(request
, None, note
='Logging in as %s' % username
) 
  77         if re
.search(r
'onLoginFailed', login_page
): 
  78             raise ExtractorError('Unable to login, incorrect username and/or password', expected
=True) 
  80     def _real_initialize(self
): 
  83     def _real_extract(self
, url
): 
  84         mobj 
= re
.match(self
._VALID
_URL
, url
) 
  85         video_id 
= mobj
.group('id') 
  87         info_url 
= 'http://vk.com/al_video.php?act=show&al=1&video=%s' % video_id
 
  88         info_page 
= self
._download
_webpage
(info_url
, video_id
) 
  90         if re
.search(r
'<!>Please log in or <', info_page
): 
  91             raise ExtractorError('This video is only available for registered users, ' 
  92                 'use --username and --password options to provide account credentials.', expected
=True) 
  94         m_yt 
= re
.search(r
'src="(http://www.youtube.com/.*?)"', info_page
) 
  96             self
.to_screen(u
'Youtube video detected') 
  97             return self
.url_result(m_yt
.group(1), 'Youtube') 
  98         data_json 
= self
._search
_regex
(r
'var vars = ({.*?});', info_page
, 'vars') 
  99         data 
= json
.loads(data_json
) 
 104             'width': int(k
[len('url'):]), 
 105         } for k
, v 
in data
.items() 
 106             if k
.startswith('url')] 
 107         self
._sort
_formats
(formats
) 
 110             'id': compat_str(data
['vid']), 
 112             'title': unescapeHTML(data
['md_title']), 
 113             'thumbnail': data
.get('jpg'), 
 114             'uploader': data
.get('md_author'), 
 115             'duration': data
.get('duration')