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

move CastPlayer re-initialization to correct method #4862

Closed
wants to merge 2 commits into from

Conversation

Sky-High
Copy link
Contributor

@Sky-High Sky-High commented Oct 9, 2023

Move the re-initialization call of the CastPlayer to the Cast button handler, as currently it is called too late.

Changes
The CastPlayer class is the interface of the Jellyfin ChromecastPlayer to the Google Cast SDK. The CastPlayer instance is created and initialized during startup of jellyfin-web. See

this.initializeCastPlayer();

Also when a new media is played CastPlayer is re-initialized. See:

instance._castPlayer.initializeCastPlayer();
The first initialization is in a very early stage, where the user is not logged on yet. As a consequence, user specific settings like setting the cast receiver ApplicationID. See:
let applicationID = userSettings.chromecastVersion();
will not be applied. Still, this early initialization is needed in the special case where jellyfin-web is restarted by for instance a browser page refresh and the connection with the jellyfin-server and current media session is automatically re-established.

The second CastPlayer initialization when starting to play a new media on the other hand is actually too late. It is triggered by the acknowledgement event 'playbackstart' of the jellyfin-chromecast cast receiver app when the media has started to play properly. So at this moment the media is already being played, and initialization therefore is 'after the fact'.

Therefore, this second initialization is moved the moment where the user selects and connects the cast receiver by means of the Cast button. See


At this point the user is logged on, so the user specific settings are available. And it is also before a media is played, so initialization precedes the actual play of a media, as it should.

@Sky-High Sky-High requested a review from a team as a code owner October 9, 2023 08:50
@nielsvanvelzen
Copy link
Member

I believe this is also fixed in #4843

@Sky-High
Copy link
Contributor Author

Sky-High commented Oct 9, 2023

Ah, ok. You attach the initialization to the login event, so that is probably ok.
I am not sure how this works after a browser page refresh, where an automatic reconnect is expected I guess.
But with your fix I am happy to withdraw my PR of course.

@nielsvanvelzen
Copy link
Member

My changes were primarily focusing on jellyfin/jellyfin-meta#45, I had to move the initialization because I needed the user settings. I chose to do it when a user is logged in because that way the data is already loaded when opening the "play to" menu. I'm not sure if it's the best way and honestly I'm too unfamiliar with the jellyfin-web code to think of one.

@Sky-High
Copy link
Contributor Author

Sky-High commented Oct 9, 2023

I am not very familiar with Jellyfin in general, but learning as we go. At this moment I try to be useful for chromecast functionality.

As to this PR, I attached the initialization to the Cast button, which is the tryPair method. This is also rather arbitrary, I guess.

The ChromecastPlayer class apparently implements the Jellyfin notion of a player, while the CastPlayer class implements the Google CastSDK notion of a player. The functions in between aim at relaying between both classes.

Initializing of the Google CastSDK seems quite tricky to me. It is performed by CastPlayer initializeCastPlayer, after loading the Google CastSDK library in ChromecastPlayer constructor with CastSenderApi().load(). I assume that the latter should be done at a fairly early stage of starting jellyfin-web, a may only be performed once. Calling CastPlayer.initializeCastPlayer probably is less demanding.

Another issue to consider is that the jellifin-web code is also used in jellyfin-android. But you of course know better than me what that means with respect to calling CastSDK functionality.

And by the way: design documentation is very scarce. Are there guidelines for where to store documentation? In the source code? Or in the PR's?

@sonarqubecloud
Copy link

Kudos, SonarCloud Quality Gate passed!    Quality Gate passed

Bug A 0 Bugs
Vulnerability A 0 Vulnerabilities
Security Hotspot A 0 Security Hotspots
Code Smell A 0 Code Smells

No Coverage information No Coverage information
0.0% 0.0% Duplication

@Sky-High Sky-High closed this Oct 13, 2023
@Sky-High Sky-High deleted the fix-castplayer-init branch October 13, 2023 10:30
@jellyfin-bot
Copy link
Collaborator

Cloudflare Pages deployment

Latest commit 9f61c91
Status ✅ Deployed!
Preview URL https://33c64cb0.jellyfin-web.pages.dev
Type 🔀 Preview

View build logs
View bot logs

@thornbill
Copy link
Member

Hey @Sky-High sorry I am a bit behind on reviews since we have had a lot come in in the past couple weeks now. Unfortunately there isn't a lot available in terms of documentation. There has been some discussions about having a developer focused documentation website but it doesn't exist yet. If you have any ideas on how to improve this or have any questions, I am almost always available on the matrix/discord.

@Sky-High
Copy link
Contributor Author

Sky-High commented Oct 16, 2023

@thornbill , thanks!
It was just a question. Jellyfin has a rich history of clever idea's, and it's a pity if that knowledge fades away because there is no way to store that knowledge.

Setting up a full fledged documentation process is a lot of work (my experience is that proper documentation takes more effort than writing code itself), but it would already help if there is at least some place where one can just leave pieces of documentation for others to browse. Something like a blog, or may be something like jellyfin-meta would already help.

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.

4 participants