about summary refs log tree commit diff
path: root/youtube_dl/extractor/krasview.py
diff options
context:
space:
mode:
authorSergey M․ <dstftw@gmail.com>2015-01-25 05:21:39 +0600
committerSergey M․ <dstftw@gmail.com>2015-01-25 05:21:39 +0600
commit1e108029907ca28b75f37d2cf0bf25bcabbfbdac (patch)
tree8fdecfcd49ca5e5f4a154a4a0cbc42d70730beb5 /youtube_dl/extractor/krasview.py
parent1070711d6003e6750b8cf803c3926b2e273a9e85 (diff)
downloadyoutube-dl-1e108029907ca28b75f37d2cf0bf25bcabbfbdac.tar.gz
youtube-dl-1e108029907ca28b75f37d2cf0bf25bcabbfbdac.tar.xz
youtube-dl-1e108029907ca28b75f37d2cf0bf25bcabbfbdac.zip
[krasview] Fix extraction
Diffstat (limited to 'youtube_dl/extractor/krasview.py')
-rw-r--r--youtube_dl/extractor/krasview.py22
1 files changed, 9 insertions, 13 deletions
diff --git a/youtube_dl/extractor/krasview.py b/youtube_dl/extractor/krasview.py
index 6f3d2345b..e46954b47 100644
--- a/youtube_dl/extractor/krasview.py
+++ b/youtube_dl/extractor/krasview.py
@@ -2,18 +2,17 @@
 from __future__ import unicode_literals
 
 import json
-import re
 
 from .common import InfoExtractor
 from ..utils import (
     int_or_none,
-    unescapeHTML,
+    js_to_json,
 )
 
 
 class KrasViewIE(InfoExtractor):
     IE_DESC = 'Красвью'
-    _VALID_URL = r'https?://krasview\.ru/video/(?P<id>\d+)'
+    _VALID_URL = r'https?://krasview\.ru/(?:video|embed)/(?P<id>\d+)'
 
     _TEST = {
         'url': 'http://krasview.ru/video/512228',
@@ -29,20 +28,18 @@ class KrasViewIE(InfoExtractor):
     }
 
     def _real_extract(self, url):
-        mobj = re.match(self._VALID_URL, url)
-        video_id = mobj.group('id')
+        video_id = self._match_id(url)
 
         webpage = self._download_webpage(url, video_id)
 
-        flashvars = json.loads(self._search_regex(
-            r'flashvars\s*:\s*({.+?})\s*}\);', webpage, 'flashvars'))
+        flashvars = json.loads(js_to_json(self._search_regex(
+            r'video_Init\(({.+?})', webpage, 'flashvars')))
 
         video_url = flashvars['url']
-        title = unescapeHTML(flashvars['title'])
-        description = unescapeHTML(flashvars.get('subtitle') or self._og_search_description(webpage, default=None))
-        thumbnail = flashvars['image']
-        duration = int(flashvars['duration'])
-        filesize = int(flashvars['size'])
+        title = self._og_search_title(webpage)
+        description = self._og_search_description(webpage, default=None)
+        thumbnail = flashvars.get('image') or self._og_search_thumbnail(webpage)
+        duration = int_or_none(flashvars.get('duration'))
         width = int_or_none(self._og_search_property('video:width', webpage, 'video width'))
         height = int_or_none(self._og_search_property('video:height', webpage, 'video height'))
 
@@ -53,7 +50,6 @@ class KrasViewIE(InfoExtractor):
             'description': description,
             'thumbnail': thumbnail,
             'duration': duration,
-            'filesize': filesize,
             'width': width,
             'height': height,
         }