|
|
@ -32,7 +32,10 @@ class XFileShareIE(InfoExtractor): |
|
|
|
_VALID_URL = (r'https?://(?P<host>(?:www\.)?(?:%s))/(?:embed-)?(?P<id>[0-9a-zA-Z]+)' |
|
|
|
% '|'.join(re.escape(site) for site in list(zip(*_SITES))[0])) |
|
|
|
|
|
|
|
_FILE_NOT_FOUND_REGEX = r'>(?:404 - )?File Not Found<' |
|
|
|
_FILE_NOT_FOUND_REGEXES = ( |
|
|
|
r'>(?:404 - )?File Not Found<', |
|
|
|
r'>The file was removed by administrator<', |
|
|
|
) |
|
|
|
|
|
|
|
_TESTS = [{ |
|
|
|
'url': 'http://gorillavid.in/06y9juieqpmi', |
|
|
@ -88,6 +91,10 @@ class XFileShareIE(InfoExtractor): |
|
|
|
'ext': 'mp4', |
|
|
|
'title': 'Chucky Prank 2015.mp4', |
|
|
|
}, |
|
|
|
}, { |
|
|
|
# removed by administrator |
|
|
|
'url': 'http://xvidstage.com/amfy7atlkx25', |
|
|
|
'only_matching': True, |
|
|
|
}] |
|
|
|
|
|
|
|
def _real_extract(self, url): |
|
|
@ -97,7 +104,7 @@ class XFileShareIE(InfoExtractor): |
|
|
|
url = 'http://%s/%s' % (mobj.group('host'), video_id) |
|
|
|
webpage = self._download_webpage(url, video_id) |
|
|
|
|
|
|
|
if re.search(self._FILE_NOT_FOUND_REGEX, webpage) is not None: |
|
|
|
if any(re.search(p, webpage) for p in self._FILE_NOT_FOUND_REGEXES): |
|
|
|
raise ExtractorError('Video %s does not exist' % video_id, expected=True) |
|
|
|
|
|
|
|
fields = self._hidden_inputs(webpage) |
|
|
|