From fe168c63bb3147365358f7b19ddd68e448b3537d Mon Sep 17 00:00:00 2001 From: JChris246 Date: Tue, 30 Jun 2020 00:36:00 -0400 Subject: [PATCH] [sexlikereal] Add new extractor --- youtube_dl/extractor/extractors.py | 1 + youtube_dl/extractor/sexlikereal.py | 61 +++++++++++++++++++++++++++++ 2 files changed, 62 insertions(+) create mode 100644 youtube_dl/extractor/sexlikereal.py diff --git a/youtube_dl/extractor/extractors.py b/youtube_dl/extractor/extractors.py index 4b3092028..efa4595c4 100644 --- a/youtube_dl/extractor/extractors.py +++ b/youtube_dl/extractor/extractors.py @@ -989,6 +989,7 @@ from .senateisvp import SenateISVPIE from .sendtonews import SendtoNewsIE from .servus import ServusIE from .sevenplus import SevenPlusIE +from .sexlikereal import SexLikeRealIE from .sexu import SexuIE from .seznamzpravy import ( SeznamZpravyIE, diff --git a/youtube_dl/extractor/sexlikereal.py b/youtube_dl/extractor/sexlikereal.py new file mode 100644 index 000000000..ada2721dc --- /dev/null +++ b/youtube_dl/extractor/sexlikereal.py @@ -0,0 +1,61 @@ +# coding: utf-8 +from __future__ import unicode_literals + +import re + +from .common import InfoExtractor +from ..utils import ( + determine_ext, + js_to_json, +) + + +class SexLikeRealIE(InfoExtractor): + _VALID_URL = r'https?://(?:www\.)?sexlikereal\.com/scenes/(?P[^/]*)-(?P\d+)' + _TEST = { + 'url': 'https://www.sexlikereal.com/scenes/wet-college-student-7208', + 'md5': '48e3ac422b783ececec418b12e2ccb56', + 'info_dict': { + 'id': '7208', + 'ext': 'mp4', + 'title': 'Wet College Student', + 'thumbnail': 'https://cdn-vr.sexlikereal.com/images/7208/vr-porn-Wet-College-Student-cover-app.jpg', + 'display_id': "wet-college-student", + 'duration': 122, + } + } + + def _real_extract(self, url): + video_id = self._match_id(url) + + mobj = re.match(self._VALID_URL, url) + display_id = mobj.group('display_id') + webpage = self._download_webpage(url, video_id) + + # TODO more code goes here, for example ... + + video_data = self._parse_json( + self._search_regex( + r'window\.vrPlayerSettings\s*=\s*({[^;]+});', + webpage, 'video_data'), + video_id, transform_source=js_to_json)["videoData"] + + title = video_data.get("title") + + formats = [] + for quality in video_data['src']: + formats.append({ + 'url': quality['url'], + 'ext': determine_ext(quality['mimeType'], 'mp4'), + 'format_id': quality['quality'] + }) + + return { + 'id': video_id, + 'display_id': display_id, + 'title': title, + 'thumbnail': video_data.get('posterURL'), + 'like_count': video_data.get('likes'), + 'duration': video_data.get('duration'), + 'formats': formats, + }