Skip to content

Commit

Permalink
Add ytInitialPlayerResponse checker to let user easily know problem
Browse files Browse the repository at this point in the history
  • Loading branch information
DGideas authored Jul 25, 2024
1 parent 899e2b6 commit 4ab0221
Showing 1 changed file with 11 additions and 0 deletions.
11 changes: 11 additions & 0 deletions src/you_get/extractors/youtube.py
Original file line number Diff line number Diff line change
Expand Up @@ -175,6 +175,16 @@ def download_playlist_by_url(self, url, **kwargs):
pass
# FIXME: show DASH stream sizes (by default) for playlist videos

def check_playability_response(self, ytInitialPlayerResponse):
STATUS_OK = "OK"

playerResponseStatus = ytInitialPlayerResponse["playabilityStatus"]["status"]
if playerResponseStatus != STATUS_OK:
reason = ytInitialPlayerResponse["playabilityStatus"].get("reason", "")
raise AssertionError(
f"Server refused to provide video details. Returned status: {playerResponseStatus}, reason: {reason}."
)

def prepare(self, **kwargs):
assert self.url or self.vid

Expand Down Expand Up @@ -202,6 +212,7 @@ def prepare(self, **kwargs):

logging.debug('Loading ytInitialPlayerResponse...')
ytInitialPlayerResponse = json.loads(re.search('ytInitialPlayerResponse\s*=\s*([^\n]+?});(\n|</script>|var )', video_page).group(1))
self.check_playability_response(ytInitialPlayerResponse)

# Get the video title
self.title = ytInitialPlayerResponse["videoDetails"]["title"]
Expand Down

0 comments on commit 4ab0221

Please sign in to comment.