diff options
author | Philipp Hagemeister <phihag@phihag.de> | 2012-09-27 18:55:56 +0200 |
---|---|---|
committer | Philipp Hagemeister <phihag@phihag.de> | 2012-09-27 18:55:56 +0200 |
commit | ebe3f89ea45dc74bbadab10acc27ebf91ddbb736 (patch) | |
tree | f7b4703a7ef73c1d4812c0fb2fa4ee398e5bde7b /youtube_dl/InfoExtractors.py | |
parent | b5de8af234789e3a202de30a6d9b05c95fe82910 (diff) | |
parent | 154b55dae3e611e05b9ae1762f59467d753338c4 (diff) |
Merge xnxx.com Support (NSFW). Test URL (SFW): http://video.xnxx.com/video1443330/youtube-dl_testvid_a_and_9829_._and_amp_and_38_
Diffstat (limited to 'youtube_dl/InfoExtractors.py')
-rw-r--r-- | youtube_dl/InfoExtractors.py | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/youtube_dl/InfoExtractors.py b/youtube_dl/InfoExtractors.py index 8dd1c0b07..56003df26 100644 --- a/youtube_dl/InfoExtractors.py +++ b/youtube_dl/InfoExtractors.py @@ -2955,3 +2955,73 @@ class MTVIE(InfoExtractor): } return [info] + +class XNXXIE(InfoExtractor): + """Information extractor for xnxx.com""" + + _VALID_URL = r'^http://video\.xnxx\.com/video([0-9]+)/(.*)' + IE_NAME = u'xnxx' + VIDEO_URL_RE = r'flv_url=(.*?)&' + VIDEO_TITLE_RE = r'<title>(.*?)\s+-\s+XNXX.COM' + VIDEO_THUMB_RE = r'url_bigthumb=(.*?)&' + + def report_webpage(self, video_id): + """Report information extraction""" + self._downloader.to_screen(u'[%s] %s: Downloading webpage' % (self.IE_NAME, video_id)) + + def report_extraction(self, video_id): + """Report information extraction""" + self._downloader.to_screen(u'[%s] %s: Extracting information' % (self.IE_NAME, video_id)) + + def extract_video_url(self, webpage): + "Extract the url for the video from the webpage" + + result = re.search(self.VIDEO_URL_RE, webpage) + if result is None: + self._downloader.trouble(u'ERROR: unable to extract video url') + return urllib.unquote(result.group(1).decode('utf-8')) + + def extract_video_title(self, webpage): + "Extract the title for the video from the webpage" + + result = re.search(self.VIDEO_TITLE_RE, webpage) + if result is None: + self._downloader.trouble(u'ERROR: unable to extract video title') + return result.group(1).decode('utf-8') + + def extract_video_thumbnail(self, webpage): + "Extract the thumbnail for the video from the webpage" + + result = re.search(self.VIDEO_THUMB_RE, webpage) + if result is None: + self._downloader.trouble(u'ERROR: unable to extract video thumbnail') + return result.group(1).decode('utf-8') + + def _real_extract(self, url): + mobj = re.match(self._VALID_URL, url) + if mobj is None: + self._downloader.trouble(u'ERROR: invalid URL: %s' % url) + return + video_id = mobj.group(1).decode('utf-8') + + self.report_webpage(video_id) + + # Get webpage content + try: + webpage = urllib2.urlopen(url).read() + except (urllib2.URLError, httplib.HTTPException, socket.error), err: + self._downloader.trouble(u'ERROR: unable to download video webpage: %s' % err) + return + + info = {'id': video_id, + 'url': self.extract_video_url(webpage), + 'uploader': None, + 'upload_date': None, + 'title': self.extract_video_title(webpage), + 'ext': 'flv', + 'format': 'flv', + 'thumbnail': self.extract_video_thumbnail(webpage), + 'description': None, + 'player_url': None} + + return [info] |