summary refs log tree commit diff
diff options
context:
space:
mode:
authorSergey M․ <dstftw@gmail.com>2016-06-13 01:19:54 +0700
committerSergey M․ <dstftw@gmail.com>2016-06-13 01:19:54 +0700
commit33b72ce64e8705a71f8ab0e6a322e5f9f3b99276 (patch)
tree5c2e6b6abf982371c540a1065bd4b1d9f5a97c86
parentcf2bf840bac1742cb422549a5491a30f70d1abb0 (diff)
downloadyoutube-dl-33b72ce64e8705a71f8ab0e6a322e5f9f3b99276.tar.gz
youtube-dl-33b72ce64e8705a71f8ab0e6a322e5f9f3b99276.tar.xz
youtube-dl-33b72ce64e8705a71f8ab0e6a322e5f9f3b99276.zip
[xfileshare] Improve removed videos detection
-rw-r--r--youtube_dl/extractor/xfileshare.py11
1 files changed, 9 insertions, 2 deletions
diff --git a/youtube_dl/extractor/xfileshare.py b/youtube_dl/extractor/xfileshare.py
index 0f8ccf430..995aada0d 100644
--- a/youtube_dl/extractor/xfileshare.py
+++ b/youtube_dl/extractor/xfileshare.py
@@ -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)