1
0
mirror of https://github.com/ytdl-org/youtube-dl.git synced 2024-12-23 08:26:50 +00:00

Merge branch 'parler' of github.com:palewire/youtube-dl into parler

This commit is contained in:
palewire 2022-08-08 11:02:09 -07:00
commit 027ba18bf4
No known key found for this signature in database
GPG Key ID: A5AD4A9AD42D69AB

View File

@ -5,13 +5,19 @@ from urllib import parse
from .common import InfoExtractor from .common import InfoExtractor
from ..utils import clean_html, unified_timestamp from ..utils import (
clean_html,
strip_or_none,
unified_timestamp,
urlencode_postdata,
)
class ParlerIE(InfoExtractor): class ParlerIE(InfoExtractor):
"""Extract videos from posts on Parler.""" """Extract videos from posts on Parler."""
_VALID_URL = r"https://parler\.com/feed/(?P<id>[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12})" _UUID_RE = r'[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}'
_VALID_URL = r'https://parler\.com/feed/(?P<id>%s)' % (_UUID_RE, )
_TESTS = [ _TESTS = [
{ {
'url': 'https://parler.com/feed/df79fdba-07cc-48fe-b085-3293897520d7', 'url': 'https://parler.com/feed/df79fdba-07cc-48fe-b085-3293897520d7',
@ -45,14 +51,14 @@ class ParlerIE(InfoExtractor):
video_id = self._match_id(url) video_id = self._match_id(url)
# Get data from API # Get data from API
api_url = "https://parler.com/open-api/ParleyDetailEndpoint.php" api_url = 'https://parler.com/open-api/ParleyDetailEndpoint.php'
payload = parse.urlencode({"uuid": video_id}).encode() payload = parse.urlencode({"uuid": video_id}).encode()
status = self._download_json(api_url, video_id, data=payload) status = self._download_json(api_url, video_id, data=payload)
# Pull out video # Pull out video
data = status["data"][0]["primary"] url = status['data'][0]['primary']['video_data']['videoSrc']
video = data["video_data"] # now we know this exists and is a dict
url = video["videoSrc"] data = status['data'][0]['primary']
# Pull out metadata # Pull out metadata
title = clean_html(data.get("full_body")).replace("\n", "") title = clean_html(data.get("full_body")).replace("\n", "")