diff options
Diffstat (limited to 'yt_dlp/extractor/krasview.py')
-rw-r--r-- | yt_dlp/extractor/krasview.py | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/yt_dlp/extractor/krasview.py b/yt_dlp/extractor/krasview.py new file mode 100644 index 0000000..4323aa4 --- /dev/null +++ b/yt_dlp/extractor/krasview.py @@ -0,0 +1,57 @@ +import json + +from .common import InfoExtractor +from ..utils import ( + int_or_none, + js_to_json, +) + + +class KrasViewIE(InfoExtractor): + IE_DESC = 'Красвью' + _VALID_URL = r'https?://krasview\.ru/(?:video|embed)/(?P<id>\d+)' + + _TEST = { + 'url': 'http://krasview.ru/video/512228', + 'md5': '3b91003cf85fc5db277870c8ebd98eae', + 'info_dict': { + 'id': '512228', + 'ext': 'mp4', + 'title': 'Снег, лёд, заносы', + 'description': 'Снято в городе Нягань, в Ханты-Мансийском автономном округе.', + 'duration': 27, + 'thumbnail': r're:^https?://.*\.jpg', + }, + 'params': { + 'skip_download': 'Not accessible from Travis CI server', + }, + } + + def _real_extract(self, url): + video_id = self._match_id(url) + + webpage = self._download_webpage(url, video_id) + + flashvars = json.loads(js_to_json(self._search_regex( + r'video_Init\(({.+?})', webpage, 'flashvars'))) + + video_url = flashvars['url'] + 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', default=None)) + height = int_or_none(self._og_search_property( + 'video:height', webpage, 'video height', default=None)) + + return { + 'id': video_id, + 'url': video_url, + 'title': title, + 'description': description, + 'thumbnail': thumbnail, + 'duration': duration, + 'width': width, + 'height': height, + } |