1
0
mirror of https://github.com/l1ving/youtube-dl synced 2024-11-23 01:12:52 +08:00
youtube-dl/youtube_dl/extractor/videopremium.py

46 lines
1.5 KiB
Python
Raw Normal View History

2013-10-14 13:32:47 +08:00
import re
import random
from .common import InfoExtractor
class VideoPremiumIE(InfoExtractor):
2013-11-27 09:54:51 +08:00
_VALID_URL = r'(?:https?://)?(?:www\.)?videopremium\.(?:tv|me)/(?P<id>\w+)(?:/.*)?'
2013-10-14 13:32:47 +08:00
_TEST = {
u'url': u'http://videopremium.tv/4w7oadjsf156',
u'file': u'4w7oadjsf156.f4v',
u'info_dict': {
u"title": u"youtube-dl_test_video____a_________-BaW_jenozKc.mp4.mp4"
},
u'params': {
u'skip_download': True,
},
2013-12-16 21:42:07 +08:00
u'skip': u'Test file has been deleted.',
2013-10-14 13:32:47 +08:00
}
def _real_extract(self, url):
mobj = re.match(self._VALID_URL, url)
video_id = mobj.group('id')
webpage_url = 'http://videopremium.tv/' + video_id
webpage = self._download_webpage(webpage_url, video_id)
if re.match(r"^<html><head><script[^>]*>window.location\s*=", webpage):
# Download again, we need a cookie
webpage = self._download_webpage(
webpage_url, video_id,
note=u'Downloading webpage again (with cookie)')
2013-10-14 13:32:47 +08:00
video_title = self._html_search_regex(
r'<h2(?:.*?)>\s*(.+?)\s*<', webpage, u'video title')
2013-10-14 13:32:47 +08:00
return {
2013-10-14 13:32:47 +08:00
'id': video_id,
'url': "rtmp://e%d.md.iplay.md/play" % random.randint(1, 16),
'play_path': "mp4:%s.f4v" % video_id,
'page_url': "http://videopremium.tv/" + video_id,
'player_url': "http://videopremium.tv/uplayer/uppod.swf",
'ext': 'f4v',
'title': video_title,
2013-11-27 09:54:51 +08:00
}