Browse Source

[carambatv] Fix extraction

The video requested in #9815 now has videomore embeds.
Yen Chi Hsuan 9 years ago
parent
commit
62a0b86e4f
2 changed files with 20 additions and 5 deletions
  1. 1 0
      ChangeLog
  2. 19 5
      youtube_dl/extractor/carambatv.py

+ 1 - 0
ChangeLog

@@ -1,6 +1,7 @@
 version <unreleased>
 version <unreleased>
 
 
 Extractors
 Extractors
+* [charambatv] Fix extraction
 * [canalplus] Fix extraction for some videos
 * [canalplus] Fix extraction for some videos
 * [cbsinteractive] Fix extraction for cnet.com
 * [cbsinteractive] Fix extraction for cnet.com
 * [parliamentliveuk] Lower case URLs are now recognized (#10912)
 * [parliamentliveuk] Lower case URLs are now recognized (#10912)

+ 19 - 5
youtube_dl/extractor/carambatv.py

@@ -9,6 +9,8 @@ from ..utils import (
     try_get,
     try_get,
 )
 )
 
 
+from .videomore import VideomoreIE
+
 
 
 class CarambaTVIE(InfoExtractor):
 class CarambaTVIE(InfoExtractor):
     _VALID_URL = r'(?:carambatv:|https?://video1\.carambatv\.ru/v/)(?P<id>\d+)'
     _VALID_URL = r'(?:carambatv:|https?://video1\.carambatv\.ru/v/)(?P<id>\d+)'
@@ -62,14 +64,16 @@ class CarambaTVPageIE(InfoExtractor):
     _VALID_URL = r'https?://carambatv\.ru/(?:[^/]+/)+(?P<id>[^/?#&]+)'
     _VALID_URL = r'https?://carambatv\.ru/(?:[^/]+/)+(?P<id>[^/?#&]+)'
     _TEST = {
     _TEST = {
         'url': 'http://carambatv.ru/movie/bad-comedian/razborka-v-manile/',
         'url': 'http://carambatv.ru/movie/bad-comedian/razborka-v-manile/',
-        'md5': '',
+        'md5': 'a49fb0ec2ad66503eeb46aac237d3c86',
         'info_dict': {
         'info_dict': {
-            'id': '191910501',
-            'ext': 'mp4',
+            'id': '475222',
+            'ext': 'flv',
             'title': '[BadComedian] - Разборка в Маниле (Абсолютный обзор)',
             'title': '[BadComedian] - Разборка в Маниле (Абсолютный обзор)',
-            'thumbnail': 're:^https?://.*\.jpg$',
-            'duration': 2678.31,
+            'thumbnail': 're:^https?://.*\.jpg',
+            # duration reported by videomore is incorrect
+            'duration': int,
         },
         },
+        'add_ie': [VideomoreIE.ie_key()],
     }
     }
 
 
     def _real_extract(self, url):
     def _real_extract(self, url):
@@ -77,6 +81,16 @@ class CarambaTVPageIE(InfoExtractor):
 
 
         webpage = self._download_webpage(url, video_id)
         webpage = self._download_webpage(url, video_id)
 
 
+        videomore_url = VideomoreIE._extract_url(webpage)
+        if videomore_url:
+            title = self._og_search_title(webpage)
+            return {
+                '_type': 'url_transparent',
+                'url': videomore_url,
+                'ie_key': VideomoreIE.ie_key(),
+                'title': title,
+            }
+
         video_url = self._og_search_property('video:iframe', webpage, default=None)
         video_url = self._og_search_property('video:iframe', webpage, default=None)
 
 
         if not video_url:
         if not video_url: