Add files via upload

This commit is contained in:
horny-is-back 2024-08-29 16:20:32 +02:00 committed by GitHub
parent 07cc6d2828
commit 935a5eee82
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -4,112 +4,111 @@ 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'
    _USERTOKEN = None
    _TESTS = [
        {
            '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/',
            'md5': 'eebd569dfea62c398947dbdc422ae0f0',
            'info_dict': {
                'id': '852931',
                'ext': 'mp4',
                'duration': 60,
                'age_limit': 18,
                'title': 'What A Feelin',
                'display_id': 'what-a-fellin',
            },
        },
    ]
_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/',
'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/',
'md5': 'eebd569dfea62c398947dbdc422ae0f0',
'info_dict': {
'id': '852931',
'ext': 'mp4',
'duration': 60,
'age_limit': 18,
'title': 'What A Feelin',
'display_id': 'what-a-fellin',
},
},
]
    def _perform_login(self, username, password):
        user_data = self._download_json(
            self._LOGIN_URL,
            None,
            note='Logging in',
            data=json.dumps(
                {
                    'login': username,
                    'password': password,
                },
            ).encode(),
            headers={
                'Content-Type': 'application/json',
            },
        )
        self._USERTOKEN = user_data['data']['access_token']
def _perform_login(self, username, password):
user_data = self._download_json(
self._LOGIN_URL,
None,
note='Logging in',
data=json.dumps(
{
'login': username,
'password': password,
},
).encode(),
headers={
'Content-Type': 'application/json',
},
)
self._USERTOKEN = user_data['data']['access_token']
    def _real_extract(self, url):
        mobj = self._match_valid_url(url)
        display_id = mobj.group('display_id')
def _real_extract(self, url):
mobj = self._match_valid_url(url)
display_id = mobj.group('display_id')
        webpage, _ = self._download_webpage_handle(url, 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',
        )
video_id = self._search_regex(
r"shortlink.+href=[\'\"]https://vrporn\.com/\?p=([0-9]+)[\'\"]",
webpage,
'id',
)
        headers = {
            'Content-Type': 'application/json',
        }
        if self._USERTOKEN:
            headers.update(
                {
                    'Authorization': f'Bearer {self._USERTOKEN}',
                },
            )
headers = {
'Content-Type': 'application/json',
}
if self._USERTOKEN:
headers.update(
{
'Authorization': f'Bearer {self._USERTOKEN}',
},
)
        video_data = self._download_json(
            self._SINGLE_VIDEO_URL + video_id,
            None,
            query={'asd': 'asd'},
            note='fetching formats',
            headers=headers,
        )
video_data = self._download_json(
self._SINGLE_VIDEO_URL + video_id,
None,
query={'asd': 'asd'},
note='fetching formats',
headers=headers,
)
        title = video_data['data']['title']
title = video_data['data']['title']
        formats = []
formats = []
        duration = ''
duration = ''
        for detail in video_data['data']['details']:
            video_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']:
                    formats.append(
                        {
                            '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,
        }
for link in detail['links']:
if link['is_download']:
formats.append(
{
'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,
}