[theplatform] Add support for referer protected videos wuth explicit SMIL
authorSergey M․ <dstftw@gmail.com>
Tue, 8 Dec 2015 15:15:45 +0000 (21:15 +0600)
committerSergey M․ <dstftw@gmail.com>
Tue, 8 Dec 2015 15:15:45 +0000 (21:15 +0600)
youtube_dl/extractor/theplatform.py

index 1555aa77cac30c18de3f0c2db9e13ea00cc569f6..0bf6726b53641734fd0fcafb73a76d8c3621b302 100644 (file)
@@ -16,11 +16,12 @@ from ..compat import (
 from ..utils import (
     determine_ext,
     ExtractorError,
-    xpath_with_ns,
-    unsmuggle_url,
+    float_or_none,
     int_or_none,
+    sanitized_Request,
+    unsmuggle_url,
     url_basename,
-    float_or_none,
+    xpath_with_ns,
 )
 
 default_ns = 'http://www.w3.org/2005/SMIL21/Language'
@@ -204,7 +205,12 @@ class ThePlatformIE(ThePlatformBaseIE):
             smil_url = url
         # Explicitly specified SMIL (see https://github.com/rg3/youtube-dl/issues/7385)
         elif '/guid/' in url:
-            webpage = self._download_webpage(url, video_id)
+            headers = {}
+            source_url = smuggled_data.get('source_url')
+            if source_url:
+                headers['Referer'] = source_url
+            request = sanitized_Request(url, headers=headers)
+            webpage = self._download_webpage(request, video_id)
             smil_url = self._search_regex(
                 r'<link[^>]+href=(["\'])(?P<url>.+?)\1[^>]+type=["\']application/smil\+xml',
                 webpage, 'smil url', group='url')