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

Can't fetch any data #217

Open
AdrianVovk opened this issue Nov 13, 2024 · 10 comments
Open

Can't fetch any data #217

AdrianVovk opened this issue Nov 13, 2024 · 10 comments

Comments

@AdrianVovk
Copy link

App doesn't seem to be able to load any content anymore. I deleted the app's data dir and recreated it to try and work around the problem, signed in again, but the problem still persists. Any page I try to open in the app leads to the same error message:

MuseError: Can't fetch data
{
  "error": {
    "code": 400,
    "message": "Request contains an invalid argument.",
    "errors": [
      {
        "message": "Request contains an invalid argument.",
        "domain": "global",
        "reason": "badRequest"
      }
    ],
    "status": "INVALID_ARGUMENT"
  }
}

    MuseError@resource:///com/vixalien/muzika/js/main.js:9737:5
    request@resource:///com/vixalien/muzika/js/main.js:11274:15
    async*request_json@resource:///com/vixalien/muzika/js/main.js:11282:26
    get_home@resource:///com/vixalien/muzika/js/main.js:11309:24
    load@resource:///com/vixalien/muzika/js/main.js:19286:12
    load@resource:///com/vixalien/muzika/js/main.js:24757:38
    reload@resource:///com/vixalien/muzika/js/main.js:24787:17
    reload@resource:///com/vixalien/muzika/js/main.js:24916:17
    activate@resource:///com/vixalien/muzika/js/main.js:24897:16
    main@resource:///com/vixalien/muzika/js/main.js:32528:14
    run@resource:///org/gnome/gjs/modules/script/package.js:207:19
    @file:///app/bin/com.vixalien.muzika.Devel:22:40
    @file:///app/bin/com.vixalien.muzika.Devel:28:6

The app also logs the following to the terminal:

Gjs-Console-Message: 21:43:55.533: caching soup requests at /var/home/adrian/.var/app/com.vixalien.muzika.Devel/cache/com.vixalien.muzika.Devel/soup-cache
MESA-INTEL: warning: ../src/intel/vulkan/anv_formats.c:763: FINISHME: support YUV colorspace with DRM format modifiers
MESA-INTEL: warning: ../src/intel/vulkan/anv_formats.c:794: FINISHME: support more multi-planar formats with DRM modifiers

(com.vixalien.muzika.Devel:2): Gjs-Console-CRITICAL **: 21:43:56.236: Couldn't get logged in user

(com.vixalien.muzika.Devel:2): Gjs-WARNING **: 21:43:56.238: Unhandled promise rejection. To suppress this warning, add an error handler to your promise chain with .catch() or a try-catch block around your await expression. Stack trace of the failed promise:
main@resource:///com/vixalien/muzika/js/main.js:32528:14
run@resource:///org/gnome/gjs/modules/script/package.js:207:19
@file:///app/bin/com.vixalien.muzika.Devel:22:40
@file:///app/bin/com.vixalien.muzika.Devel:28:6

Troubleshooting information:

{
  "argv": [
    "/app/bin/com.vixalien.muzika.Devel"
  ],
  "version": "nightly-67afe41",
  "uri": "library:playlists",
  "logged_in": true,
  "language": "English (US) - en"
}
@vixalien
Copy link
Owner

vixalien commented Nov 13, 2024 via email

@alvaroburns
Copy link

Same error here.

@vixalien
Copy link
Owner

This is due to a change on how YouTube handles authentication. Sadly, I don't know of any methods to use the new authentication scheme, but it seems they now use an Authorization Header with SAPISIDHASH hash instead of the older Bearer token.

Someone needs to reverse engineer this hash, but it's different from the old SAPISIDHASHs because the current ones all end with _u.

@vixalien
Copy link
Owner

Furthermore, YTM now requires you to be logged in before playing anything on iOS and Android, meaning our old method to play songs while not logged in won't work, i.e. unless we figure out how to decipher the streams YTM sends on browser (signatureCipher)

@dmnmsc
Copy link

dmnmsc commented Nov 23, 2024

I don't know if it's related bu spotify_to_ytmusic is using browser auth instead of oauth. Is this helpful?

sigma67/spotify_to_ytmusic#117

@dmnmsc
Copy link

dmnmsc commented Nov 24, 2024

Same with youtui. They are switching to browser auth nick42d/youtui@b206a8e

@yashoswalyo
Copy link

is there any update on this?

@Henry-Hiles
Copy link
Contributor

Monophony seems to work despite having no login, FWIW.

@Henry-Hiles
Copy link
Contributor

is there any update on this?

is there any update on this?

I think vixalien has stopped maintaining. It would be great if someone could fork, as it doesn't look too hard: https://mas.to/@vixalientoots/113555145244776471

@lovegaoshi
Copy link

very sad to see this go. I have some suggestions to chip in:

muse itself needs to work with browser cookie based auth, or a free/paid? google oauth app. https://github.com/sigma67/ytmusicapi (where muse was adapted from) has figured this out. I personally fixed part of muse's login problem here. now I'm stuck at fetching the streaming urls, as using constants_ng_js_1.default.{ANDROID/IOS}.DATA in get_song all returns an error 400, and constants_ng_js_1.default.DATA does not return the url itself but everything else - suggesting the auth tokens has to be put somewhere as well. its not hard work but im not incentivized to work on it either.

changing the backend is also an option - https://github.com/LuanRT/YouTube.js can still fetch without login.

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

No branches or pull requests

7 participants