Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add yt-dlp fallback for stream extraction #1768

Closed
wants to merge 5 commits into from
Closed

Conversation

gechoto
Copy link
Contributor

@gechoto gechoto commented Dec 21, 2024

This should fix the current playback issues: #1748

This is not a perfect solution:

  • it increases the apk size by a lot (includes python)
  • it is slow
  • is increases data usage (downloads the player js again and again for every stream)

But in my testing so far it works.
If you have a better idea feel free to share.

I tried to counter the slowness by only using this as a fallback for now.
In the long term it might be more reliable to offload more to yt-dlp.

I know the code is not the best. We can improve on that later.
However it should be fine for now as a quick fix.

Needs more testing.

TODO - before release:
- disable sending login info when using IOS client (it does not support login anymore but results in an error) DONE

TODO - for later:

  • maybe build split apks to decrease apk size
  • see if there is a way to cache the player js to decrease data usage
  • maybe update yt-dlp less often (daily + manual?) (currently every app start)
  • check if the secure flag in the cookies file can be enabled
  • maybe rename and optimize some stuff
  • check if api_key can be removed from clients (it doesn't seem to be used anyone in recent clients?)
  • check if TVHTML5 client can be removed

Note: This also contains a temporary change to set the cookie value to null if the user is logged out (because only null is considered logged-out). It can be removed after #1694 is done.

Copy link

gitguardian bot commented Dec 21, 2024

⚠️ GitGuardian has uncovered 1 secret following the scan of your pull request.

Please consider investigating the findings and remediating the incidents. Failure to do so may lead to compromising the associated services or software components.

Since your pull request originates from a forked repository, GitGuardian is not able to associate the secrets uncovered with secret incidents on your GitGuardian dashboard.
Skipping this check run and merging your pull request will create secret incidents on your GitGuardian dashboard.

🔎 Detected hardcoded secret in your pull request
GitGuardian id GitGuardian status Secret Commit Filename
14305798 Triggered Google API Key 35653ef innertube/src/main/java/com/zionhuang/innertube/models/YouTubeClient.kt View secret
🛠 Guidelines to remediate hardcoded secrets
  1. Understand the implications of revoking this secret by investigating where it is used in your code.
  2. Replace and store your secret safely. Learn here the best practices.
  3. Revoke and rotate this secret.
  4. If possible, rewrite git history. Rewriting git history is not a trivial act. You might completely break other contributing developers' workflow and you risk accidentally deleting legitimate data.

To avoid such incidents in the future consider


🦉 GitGuardian detects secrets in your source code to help developers and security teams secure the modern development process. You are seeing this because you or someone else with access to this repository has authorized GitGuardian to scan your pull request.

@gechoto gechoto marked this pull request as draft December 23, 2024 01:41
@fishmodem
Copy link

Tried it and it works for non-age-restricted videos whether logged in or out, but it doesn't work for age restricted videos when logged in (or out, naturally). Gives "Unknown error." Unsure if it's the same error, i'll see if I can log it when I get home.

Unrelated to this, but making the app actually display the error message instead of not giving any info would be great for an app that is subject to the whims of the yt api. I'll look into implementing a "See error details" button or something once this wave of blockage is resolved.

@gechoto
Copy link
Contributor Author

gechoto commented Dec 24, 2024

it doesn't work for age restricted videos when logged in

hm it should work

  • which video are you testing with?
  • does it work in the browser with the same account?

making the app actually display the error message instead of not giving any info would be great

I agree the error messages should be improved at some point. I already added a TODO in the code for this.

@ThatOneCalculator
Copy link

Seems like #1772 may be a cleaner solution, especially in regards to the APK size

@gechoto
Copy link
Contributor Author

gechoto commented Dec 24, 2024

Seems like #1772 may be a cleaner solution, especially in regards to the APK size

I know about this PR and would prefer it. The problem is that it doesn't support login and things like volume normalization due to missing metadata.

To solve this I created a new PR which still supports login, has all metadata and keeps the app small and fast:
#1774

@gechoto
Copy link
Contributor Author

gechoto commented Dec 29, 2024

closing in favor of #1774

@gechoto gechoto closed this Dec 29, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants