YoutubeExplode icon indicating copy to clipboard operation
YoutubeExplode copied to clipboard

Occasionally streams are very slow to download (`n`-sig deciphering)

Open Tyrrrz opened this issue 2 years ago • 3 comments

Version

v6.2.13 / master

Details

When using the TVHTML5_SIMPLY_EMBEDDED_PLAYER client (or any other JS-enabled client, but this is the one we're using), occasionally YouTube may return a stream that has the n parameter. This parameter is an encrypted signature, similar to sig, but is responsible for rate throttling.

It also incorporates much more complicated cipher functions, so the existing deciphering code will not be enough to tackle it.

Currently, these kinds of streams are not too common, but I assume they will become more prolific as time goes on. It's not a huge issue now as the TVHTML5_SIMPLY_EMBEDDED_PLAYER client is only used for age-restricted videos.

Steps to reproduce

  • Use the Demo.Gui project
  • Resolve stream manifest for any age-restricted video: https://github.com/Tyrrrz/YoutubeExplode/blob/a8318c0d304c1cac1465b1b92ac3de99af6e246c/YoutubeExplode.Tests/TestData/VideoIds.cs#L11-L13
  • Try to download any stream and observe very low download speed
  • If the issue doesn't happen, retry from the beginning again (this can take several attempts)

Updated, much more consistent steps to reproduce that require a VPN:

  • Use the Demo.Gui project
  • VPN to US
  • Resolve stream manifest for https://www.youtube.com/watch?v=BJhIIOyUd9k (or any other "free with ads movie" video)
  • Try to download any stream and observe very low download speed

Tyrrrz avatar May 02 '23 14:05 Tyrrrz

I wonder if using the base.js functions could be a solution for the TVHTML5_SIMPLY_EMBEDDED_PLAYER. Maybe this PR could be used as start point https://github.com/Tyrrrz/YoutubeExplode/pull/601 but it would be needed to add a js interpreter

xBaank avatar May 18 '23 10:05 xBaank

i have same issue :C

Mrgaton avatar Oct 10 '23 15:10 Mrgaton

As Tyrrrz suspected, this is causing problems for more and more videos. I am using the library for Realtime playback (WInui 3) and on some videos, I can't even play smoothly. Link generated by ytdlp seems to be working though.

sakib1361 avatar Nov 16 '23 05:11 sakib1361