|
@ -4,10 +4,14 @@ import re |
|
|
|
|
|
|
|
|
from .common import InfoExtractor |
|
|
from .common import InfoExtractor |
|
|
from ..compat import ( |
|
|
from ..compat import ( |
|
|
|
|
|
compat_urllib_request, |
|
|
compat_urlparse, |
|
|
compat_urlparse, |
|
|
) |
|
|
) |
|
|
from ..utils import ( |
|
|
from ..utils import ( |
|
|
ExtractorError, |
|
|
ExtractorError, |
|
|
|
|
|
NO_DEFAULT, |
|
|
|
|
|
encode_dict, |
|
|
|
|
|
urlencode_postdata, |
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -41,16 +45,38 @@ class NovaMovIE(InfoExtractor): |
|
|
mobj = re.match(self._VALID_URL, url) |
|
|
mobj = re.match(self._VALID_URL, url) |
|
|
video_id = mobj.group('id') |
|
|
video_id = mobj.group('id') |
|
|
|
|
|
|
|
|
page = self._download_webpage( |
|
|
|
|
|
'http://%s/video/%s' % (self._HOST, video_id), video_id, 'Downloading video page') |
|
|
|
|
|
|
|
|
url = 'http://%s/video/%s' % (self._HOST, video_id) |
|
|
|
|
|
|
|
|
if re.search(self._FILE_DELETED_REGEX, page) is not None: |
|
|
|
|
|
raise ExtractorError('Video %s does not exist' % video_id, expected=True) |
|
|
|
|
|
|
|
|
webpage = self._download_webpage( |
|
|
|
|
|
url, video_id, 'Downloading video page') |
|
|
|
|
|
|
|
|
filekey = self._search_regex(self._FILEKEY_REGEX, page, 'filekey') |
|
|
|
|
|
|
|
|
if re.search(self._FILE_DELETED_REGEX, webpage) is not None: |
|
|
|
|
|
raise ExtractorError('Video %s does not exist' % video_id, expected=True) |
|
|
|
|
|
|
|
|
title = self._html_search_regex(self._TITLE_REGEX, page, 'title', fatal=False) |
|
|
|
|
|
description = self._html_search_regex(self._DESCRIPTION_REGEX, page, 'description', default='', fatal=False) |
|
|
|
|
|
|
|
|
def extract_filekey(default=NO_DEFAULT): |
|
|
|
|
|
return self._search_regex( |
|
|
|
|
|
self._FILEKEY_REGEX, webpage, 'filekey', default=default) |
|
|
|
|
|
|
|
|
|
|
|
filekey = extract_filekey(default=None) |
|
|
|
|
|
|
|
|
|
|
|
if not filekey: |
|
|
|
|
|
fields = self._hidden_inputs(webpage) |
|
|
|
|
|
post_url = self._search_regex( |
|
|
|
|
|
r'<form[^>]+action=(["\'])(?P<url>.+?)\1', webpage, |
|
|
|
|
|
'post url', default=url, group='url') |
|
|
|
|
|
if not post_url.startswith('http'): |
|
|
|
|
|
post_url = compat_urlparse.urljoin(url, post_url) |
|
|
|
|
|
request = compat_urllib_request.Request( |
|
|
|
|
|
post_url, urlencode_postdata(encode_dict(fields))) |
|
|
|
|
|
request.add_header('Content-Type', 'application/x-www-form-urlencoded') |
|
|
|
|
|
request.add_header('Referer', post_url) |
|
|
|
|
|
webpage = self._download_webpage( |
|
|
|
|
|
request, video_id, 'Downloading continue to the video page') |
|
|
|
|
|
|
|
|
|
|
|
filekey = extract_filekey() |
|
|
|
|
|
|
|
|
|
|
|
title = self._html_search_regex(self._TITLE_REGEX, webpage, 'title', fatal=False) |
|
|
|
|
|
description = self._html_search_regex(self._DESCRIPTION_REGEX, webpage, 'description', default='', fatal=False) |
|
|
|
|
|
|
|
|
api_response = self._download_webpage( |
|
|
api_response = self._download_webpage( |
|
|
'http://%s/api/player.api.php?key=%s&file=%s' % (self._HOST, filekey, video_id), video_id, |
|
|
'http://%s/api/player.api.php?key=%s&file=%s' % (self._HOST, filekey, video_id), video_id, |
|
|