diff options
Diffstat (limited to 'youtube_dl/extractor/xnxx.py')
-rw-r--r-- | youtube_dl/extractor/xnxx.py | 84 |
1 files changed, 0 insertions, 84 deletions
diff --git a/youtube_dl/extractor/xnxx.py b/youtube_dl/extractor/xnxx.py deleted file mode 100644 index ac1ccc404..000000000 --- a/youtube_dl/extractor/xnxx.py +++ /dev/null @@ -1,84 +0,0 @@ -# coding: utf-8 -from __future__ import unicode_literals - -import re - -from .common import InfoExtractor -from ..utils import ( - determine_ext, - int_or_none, - NO_DEFAULT, - str_to_int, -) - - -class XNXXIE(InfoExtractor): - _VALID_URL = r'https?://(?:video|www)\.xnxx\.com/video-?(?P<id>[0-9a-z]+)/' - _TESTS = [{ - 'url': 'http://www.xnxx.com/video-55awb78/skyrim_test_video', - 'md5': '7583e96c15c0f21e9da3453d9920fbba', - 'info_dict': { - 'id': '55awb78', - 'ext': 'mp4', - 'title': 'Skyrim Test Video', - 'thumbnail': r're:^https?://.*\.jpg', - 'duration': 469, - 'view_count': int, - 'age_limit': 18, - }, - }, { - 'url': 'http://video.xnxx.com/video1135332/lida_naked_funny_actress_5_', - 'only_matching': True, - }, { - 'url': 'http://www.xnxx.com/video-55awb78/', - 'only_matching': True, - }] - - def _real_extract(self, url): - video_id = self._match_id(url) - - webpage = self._download_webpage(url, video_id) - - def get(meta, default=NO_DEFAULT, fatal=True): - return self._search_regex( - r'set%s\s*\(\s*(["\'])(?P<value>(?:(?!\1).)+)\1' % meta, - webpage, meta, default=default, fatal=fatal, group='value') - - title = self._og_search_title( - webpage, default=None) or get('VideoTitle') - - formats = [] - for mobj in re.finditer( - r'setVideo(?:Url(?P<id>Low|High)|HLS)\s*\(\s*(?P<q>["\'])(?P<url>(?:https?:)?//.+?)(?P=q)', webpage): - format_url = mobj.group('url') - if determine_ext(format_url) == 'm3u8': - formats.extend(self._extract_m3u8_formats( - format_url, video_id, 'mp4', entry_protocol='m3u8_native', - preference=1, m3u8_id='hls', fatal=False)) - else: - format_id = mobj.group('id') - if format_id: - format_id = format_id.lower() - formats.append({ - 'url': format_url, - 'format_id': format_id, - 'quality': -1 if format_id == 'low' else 0, - }) - self._sort_formats(formats) - - thumbnail = self._og_search_thumbnail(webpage, default=None) or get( - 'ThumbUrl', fatal=False) or get('ThumbUrl169', fatal=False) - duration = int_or_none(self._og_search_property('duration', webpage)) - view_count = str_to_int(self._search_regex( - r'id=["\']nb-views-number[^>]+>([\d,.]+)', webpage, 'view count', - default=None)) - - return { - 'id': video_id, - 'title': title, - 'thumbnail': thumbnail, - 'duration': duration, - 'view_count': view_count, - 'age_limit': 18, - 'formats': formats, - } |