yt-dlp/youtube_dl/extractor/wimp.py

34 lines
1.3 KiB
Python
Raw Normal View History

2013-06-26 04:25:53 -06:00
import re
import base64
2013-06-26 04:25:53 -06:00
from .common import InfoExtractor
class WimpIE(InfoExtractor):
_VALID_URL = r'(?:http://)?(?:www\.)?wimp\.com/([^/]+)/'
2013-06-27 12:46:46 -06:00
_TEST = {
u'url': u'http://www.wimp.com/deerfence/',
u'file': u'deerfence.flv',
u'md5': u'8b215e2e0168c6081a1cf84b2846a2b5',
u'info_dict': {
2013-12-07 23:22:19 -07:00
u"title": u"Watch Till End: Herd of deer jump over a fence.",
u"description": u"These deer look as fluid as running water when they jump over this fence as a herd. This video is one that needs to be watched until the very end for the true majesty to be witnessed, but once it comes, it's sure to take your breath away.",
2013-06-27 12:46:46 -06:00
}
}
2013-06-26 04:25:53 -06:00
def _real_extract(self, url):
mobj = re.match(self._VALID_URL, url)
video_id = mobj.group(1)
webpage = self._download_webpage(url, video_id)
googleString = self._search_regex("googleCode = '(.*?)'", webpage, 'file url')
2013-06-26 08:41:55 -06:00
googleString = base64.b64decode(googleString).decode('ascii')
2013-12-08 20:53:23 -07:00
final_url = self._search_regex('","(.*?)"', googleString, u'final video url')
2013-12-07 23:22:19 -07:00
return {
'id': video_id,
'url': final_url,
'title': self._og_search_title(webpage),
'thumbnail': self._og_search_thumbnail(webpage),
'description': self._og_search_description(webpage),
}