summary refs log tree commit diff
diff options
context:
space:
mode:
authorSergey M․ <dstftw@gmail.com>2017-07-07 22:22:29 +0700
committerSergey M․ <dstftw@gmail.com>2017-07-07 22:27:34 +0700
commit00e5c363159f7771dc3a2e33b1a38af520782372 (patch)
tree4b31ba1aa7556a2e532c771fc33da8e520200123
parent8a04ade86bf3a7f0a321232850a2d03a52c47819 (diff)
downloadyoutube-dl-00e5c363159f7771dc3a2e33b1a38af520782372.tar.gz
youtube-dl-00e5c363159f7771dc3a2e33b1a38af520782372.tar.xz
youtube-dl-00e5c363159f7771dc3a2e33b1a38af520782372.zip
[xhamster] Add support for new URL schema (closes #13593)
-rw-r--r--youtube_dl/extractor/xhamster.py23
1 files changed, 17 insertions, 6 deletions
diff --git a/youtube_dl/extractor/xhamster.py b/youtube_dl/extractor/xhamster.py
index 6987b2e3a..de9ec9b9e 100644
--- a/youtube_dl/extractor/xhamster.py
+++ b/youtube_dl/extractor/xhamster.py
@@ -14,7 +14,15 @@ from ..utils import (
 
 
 class XHamsterIE(InfoExtractor):
-    _VALID_URL = r'(?P<proto>https?)://(?:.+?\.)?xhamster\.com/movies/(?P<id>[0-9]+)/(?P<seo>.*?)\.html(?:\?.*)?'
+    _VALID_URL = r'''(?x)
+                    https?://
+                        (?:.+?\.)?xhamster\.com/
+                        (?:
+                            movies/(?P<id>\d+)/(?P<display_id>[^/]*)\.html|
+                            videos/(?P<display_id_2>[^/]*)-(?P<id_2>\d+)
+                        )
+                    '''
+
     _TESTS = [{
         'url': 'http://xhamster.com/movies/1509445/femaleagent_shy_beauty_takes_the_bait.html',
         'md5': '8281348b8d3c53d39fffb377d24eac4e',
@@ -66,6 +74,10 @@ class XHamsterIE(InfoExtractor):
         # This video is visible for marcoalfa123456's friends only
         'url': 'https://it.xhamster.com/movies/7263980/la_mia_vicina.html',
         'only_matching': True,
+    }, {
+        # new URL schema
+        'url': 'https://pt.xhamster.com/videos/euro-pedal-pumping-7937821',
+        'only_matching': True,
     }]
 
     def _real_extract(self, url):
@@ -81,11 +93,10 @@ class XHamsterIE(InfoExtractor):
 
         mobj = re.match(self._VALID_URL, url)
 
-        video_id = mobj.group('id')
-        seo = mobj.group('seo')
-        proto = mobj.group('proto')
-        mrss_url = '%s://xhamster.com/movies/%s/%s.html' % (proto, video_id, seo)
-        webpage = self._download_webpage(mrss_url, video_id)
+        video_id = mobj.group('id') or mobj.group('id_2')
+        display_id = mobj.group('display_id') or mobj.group('display_id_2')
+
+        webpage = self._download_webpage(url, video_id)
 
         error = self._html_search_regex(
             r'<div[^>]+id=["\']videoClosed["\'][^>]*>(.+?)</div>',