mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2026-05-26 17:22:44 +00:00
Create vrporn.py
This commit is contained in:
parent
4f8448896e
commit
5c7adfdc52
100
yt_dlp/extractor/vrporn.py
Normal file
100
yt_dlp/extractor/vrporn.py
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
import json
|
||||||
|
|
||||||
|
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/",
|
||||||
|
"only_matching": True,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"url": "https://vrporn.com/what-a-fellin/",
|
||||||
|
"only_matching": True,
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
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")
|
||||||
|
|
||||||
|
webpage, _ = self._download_webpage_handle(url, display_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}",
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
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"]
|
||||||
|
|
||||||
|
formats = []
|
||||||
|
|
||||||
|
duration = ""
|
||||||
|
|
||||||
|
for detail in video_data["data"]["details"]:
|
||||||
|
type = detail["type"]
|
||||||
|
duration = detail["duration_seconds"]
|
||||||
|
|
||||||
|
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"],
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
return {
|
||||||
|
"id": video_id,
|
||||||
|
"display_id": display_id,
|
||||||
|
"title": title,
|
||||||
|
"duration": duration,
|
||||||
|
"formats": formats,
|
||||||
|
"age_limit": 18,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
Loading…
x
Reference in New Issue
Block a user