tests + `hatch fmt --check` passing

This commit is contained in:
horny-is-back 2024-07-10 15:02:39 +02:00 committed by GitHub
parent ac857fd120
commit 07cc6d2828
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 55 additions and 40 deletions

View File

@ -4,19 +4,35 @@ from .common import InfoExtractor
class VRPornIE(InfoExtractor):
    _VALID_URL = r"https?://(?:www\.)?vrporn\.com/(?P<display_id>.+)/"
    _LOGIN_URL = "https://vrporn.com/api/playa/v2/auth/sign-in-password"
    _SINGLE_VIDEO_URL = "https://vrporn.com/api/playa/v2/video/"
    _NETRC_MACHINE = "vrporn"
    _VALID_URL = r'https?://(?:www\.)?vrporn\.com/(?P<display_id>.+)/'
    _LOGIN_URL = 'https://vrporn.com/api/playa/v2/auth/sign-in-password'
    _SINGLE_VIDEO_URL = 'https://vrporn.com/api/playa/v2/video/'
    _NETRC_MACHINE = 'vrporn'
    _USERTOKEN = None
    _TESTS = [
        {
            "url": "https://vrporn.com/milkmans-diaries/",
            "only_matching": True,
            'url': 'https://vrporn.com/milkmans-diaries/',
            'md5': 'd50ab6c2b4adbe4fcd3f46e40984c7c8',
            'info_dict': {
                'id': '865690',
                'ext': 'mp4',
                'duration': 60,
                'age_limit': 18,
                'title': "Milkman's Diaries",
                'display_id': 'milkmans-diaries',
            },
        },
        {
            "url": "https://vrporn.com/what-a-fellin/",
            "only_matching": True,
            'url': 'https://vrporn.com/what-a-fellin/',
            'md5': 'eebd569dfea62c398947dbdc422ae0f0',
            'info_dict': {
                'id': '852931',
                'ext': 'mp4',
                'duration': 60,
                'age_limit': 18,
                'title': 'What A Feelin',
                'display_id': 'what-a-fellin',
            },
        },
    ]
@ -24,77 +40,76 @@ class VRPornIE(InfoExtractor):
        user_data = self._download_json(
            self._LOGIN_URL,
            None,
            note="Logging in",
            note='Logging in',
            data=json.dumps(
                {
                    "login": username,
                    "password": password,
                }
                    'login': username,
                    'password': password,
                },
            ).encode(),
            headers={
                "Content-Type": "application/json",
                'Content-Type': 'application/json',
            },
        )
        self._USERTOKEN = user_data["data"]["access_token"]
        self._USERTOKEN = user_data['data']['access_token']
    def _real_extract(self, url):
        mobj = self._match_valid_url(url)
        display_id = mobj.group("display_id")
        display_id = mobj.group('display_id')
        webpage, _ = self._download_webpage_handle(url, display_id)
        video_id = self._search_regex(
            r"shortlink.+href=[\'\"]https://vrporn\.com/\?p=([0-9]+)[\'\"]",
            webpage,
            "id",
            'id',
        )
        headers = {
            "Content-Type": "application/json",
            'Content-Type': 'application/json',
        }
        if self._USERTOKEN:
            headers.update(
                {
                    "Authorization": f"Bearer {self._USERTOKEN}",
                }
                    'Authorization': f'Bearer {self._USERTOKEN}',
                },
            )
        video_data = self._download_json(
            self._SINGLE_VIDEO_URL + video_id,
            None,
            query={"asd": "asd"},
            note="fetching formats",
            query={'asd': 'asd'},
            note='fetching formats',
            headers=headers,
        )
        title = video_data["data"]["title"]
        title = video_data['data']['title']
        formats = []
        duration = ""
        duration = ''
        for detail in video_data["data"]["details"]:
            type = detail["type"]
            duration = detail["duration_seconds"]
        for detail in video_data['data']['details']:
            video_type = detail['type']
            duration = detail['duration_seconds']
            for link in detail["links"]:
                if link["is_download"]:
            for link in detail['links']:
                if link['is_download']:
                    formats.append(
                        {
                            "url": link["url"],
                            "format_id": f'{type}-{link["quality_name"]}-{link["stereo"]}-{link["projection"]}',
                            "quality": link["quality_name"],
                            "resolution": link["quality_name"],
                        }
                            'url': link['url'],
                            'format_id': f'{video_type}-{link["quality_name"]}-{link["stereo"]}-{link["projection"]}',
                            'quality': link['quality_name'],
                            'resolution': link['quality_name'],
                        },
                    )
        return {
            "id": video_id,
            "display_id": display_id,
            "title": title,
            "duration": duration,
            "formats": formats,
            "age_limit": 18,
            'id': video_id,
            'display_id': display_id,
            'title': title,
            'duration': duration,
            'formats': formats,
            'age_limit': 18,
        }