diff options
| author | dirkf <fieldhouse@gmx.net> | 2022-06-12 14:10:38 +0100 | 
|---|---|---|
| committer | dirkf <fieldhouse@gmx.net> | 2022-06-12 14:10:38 +0100 | 
| commit | cc179df346abf34c8f77dbb221b839092007f20c (patch) | |
| tree | 19bb67ebf3cfe1aab7de97472cb7736618798c2d /youtube_dl/extractor/xhamster.py | |
| parent | 0700fde6403aa9eec1ff02bff7323696a205900c (diff) | |
[XHamster] Support xhday.com alias, extract `uploader_id`
* support xhday.com alias for xhamster.com (resolves #31023)
  Authored by: dirkf
* extract `uploader_id`:
  from https://github.com/yt-dlp/yt-dlp/commit/908b56eaf7872149706dbd7fa071f838d0c786b7
  (PR https://github.com/yt-dlp/yt-dlp/pull/844)
  Authored by: octotherp
Diffstat (limited to 'youtube_dl/extractor/xhamster.py')
| -rw-r--r-- | youtube_dl/extractor/xhamster.py | 19 | 
1 files changed, 16 insertions, 3 deletions
| diff --git a/youtube_dl/extractor/xhamster.py b/youtube_dl/extractor/xhamster.py index f73b9778f..f764021ba 100644 --- a/youtube_dl/extractor/xhamster.py +++ b/youtube_dl/extractor/xhamster.py @@ -1,3 +1,4 @@ +# coding: utf-8  from __future__ import unicode_literals  import itertools @@ -23,7 +24,7 @@ from ..utils import (  class XHamsterIE(InfoExtractor): -    _DOMAINS = r'(?:xhamster\.(?:com|one|desi)|xhms\.pro|xhamster\d+\.com)' +    _DOMAINS = r'(?:xhamster\.(?:com|one|desi)|xhms\.pro|xhamster\d+\.com|xhday\.com)'      _VALID_URL = r'''(?x)                      https?://                          (?:.+?\.)?%s/ @@ -34,7 +35,7 @@ class XHamsterIE(InfoExtractor):                      ''' % _DOMAINS      _TESTS = [{          'url': 'https://xhamster.com/videos/femaleagent-shy-beauty-takes-the-bait-1509445', -        'md5': '98b4687efb1ffd331c4197854dc09e8f', +        'md5': '34e1ab926db5dc2750fed9e1f34304bb',          'info_dict': {              'id': '1509445',              'display_id': 'femaleagent-shy-beauty-takes-the-bait', @@ -43,6 +44,7 @@ class XHamsterIE(InfoExtractor):              'timestamp': 1350194821,              'upload_date': '20121014',              'uploader': 'Ruseful2011', +            'uploader_id': 'ruseful2011',              'duration': 893,              'age_limit': 18,          }, @@ -72,6 +74,7 @@ class XHamsterIE(InfoExtractor):              'timestamp': 1454948101,              'upload_date': '20160208',              'uploader': 'parejafree', +            'uploader_id': 'parejafree',              'duration': 72,              'age_limit': 18,          }, @@ -117,6 +120,9 @@ class XHamsterIE(InfoExtractor):      }, {          'url': 'http://de.xhamster.com/videos/skinny-girl-fucks-herself-hard-in-the-forest-xhnBJZx',          'only_matching': True, +    }, { +        'url': 'https://xhday.com/videos/strapless-threesome-xhh7yVf', +        'only_matching': True,      }]      def _real_extract(self, url): @@ -245,6 +251,7 @@ class XHamsterIE(InfoExtractor):              else:                  categories = None +            uploader_url = url_or_none(try_get(video, lambda x: x['author']['pageURL']))              return {                  'id': video_id,                  'display_id': display_id, @@ -253,6 +260,8 @@ class XHamsterIE(InfoExtractor):                  'timestamp': int_or_none(video.get('created')),                  'uploader': try_get(                      video, lambda x: x['author']['name'], compat_str), +                'uploader_url': uploader_url, +                'uploader_id': uploader_url.split('/')[-1] if uploader_url else None,                  'thumbnail': video.get('thumbURL'),                  'duration': int_or_none(video.get('duration')),                  'view_count': int_or_none(video.get('views')), @@ -261,7 +270,7 @@ class XHamsterIE(InfoExtractor):                  'dislike_count': int_or_none(try_get(                      video, lambda x: x['rating']['dislikes'], int)),                  'comment_count': int_or_none(video.get('views')), -                'age_limit': age_limit, +                'age_limit': age_limit if age_limit is not None else 18,                  'categories': categories,                  'formats': formats,              } @@ -352,6 +361,7 @@ class XHamsterIE(InfoExtractor):              'description': description,              'upload_date': upload_date,              'uploader': uploader, +            'uploader_id': uploader.lower() if uploader else None,              'thumbnail': thumbnail,              'duration': duration,              'view_count': view_count, @@ -420,6 +430,9 @@ class XHamsterUserIE(InfoExtractor):              'id': 'firatkaan',          },          'playlist_mincount': 1, +    }, { +        'url': 'https://xhday.com/users/mobhunter', +        'only_matching': True,      }]      def _entries(self, user_id): | 
