|  | @@ -4,10 +4,14 @@ import re
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  from .common import InfoExtractor
 | 
	
		
			
				|  |  |  from ..compat import (
 | 
	
		
			
				|  |  | +    compat_urllib_request,
 | 
	
		
			
				|  |  |      compat_urlparse,
 | 
	
		
			
				|  |  |  )
 | 
	
		
			
				|  |  |  from ..utils import (
 | 
	
		
			
				|  |  |      ExtractorError,
 | 
	
		
			
				|  |  | +    NO_DEFAULT,
 | 
	
		
			
				|  |  | +    encode_dict,
 | 
	
		
			
				|  |  | +    urlencode_postdata,
 | 
	
		
			
				|  |  |  )
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -41,16 +45,38 @@ class NovaMovIE(InfoExtractor):
 | 
	
		
			
				|  |  |          mobj = re.match(self._VALID_URL, url)
 | 
	
		
			
				|  |  |          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(
 | 
	
		
			
				|  |  |              'http://%s/api/player.api.php?key=%s&file=%s' % (self._HOST, filekey, video_id), video_id,
 |