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

Convert the desktop session player to the new player API #34070

Merged
merged 3 commits into from
Nov 10, 2023

Conversation

zmb3
Copy link
Collaborator

@zmb3 zmb3 commented Oct 31, 2023

This makes a few changes to the player API (from #31754) to ensure that errors are correctly propagated.

While this change doesn't introduce any new functionality, it enables us to actually implement seeking during desktop playback.

@zmb3 zmb3 added desktop-access no-changelog Indicates that a PR does not require a changelog entry labels Oct 31, 2023
@zmb3 zmb3 requested review from Tener and ibeckermayer October 31, 2023 14:31
@github-actions github-actions bot requested a review from probakowski October 31, 2023 14:31
@github-actions github-actions bot added audit-log Issues related to Teleports Audit Log size/sm labels Oct 31, 2023
Copy link
Contributor

@Tener Tener left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The code looks fine; I haven't tried running it, but I assume this was tested manually already and will get more complete coverage before the next major release.

@zmb3 zmb3 force-pushed the zmb3/desktop-player-api-2 branch 2 times, most recently from 052cd8e to 824ca7a Compare October 31, 2023 18:52
lib/web/desktop_playback.go Outdated Show resolved Hide resolved
lib/web/desktop_playback.go Show resolved Hide resolved
lib/web/desktop/playback.go Outdated Show resolved Hide resolved
@zmb3 zmb3 force-pushed the zmb3/desktop-player-api-2 branch from 824ca7a to 301c078 Compare November 5, 2023 20:55
@zmb3
Copy link
Collaborator Author

zmb3 commented Nov 5, 2023

Thanks for the suggestions @ibeckermayer - I think it looks better now.

}()

go func() {
defer cancel()
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This ensures that the other loop (in ReceivePlaybackActions) always breaks if this goroutine returns.

Suggested change
defer cancel()
defer cancel()
defer ws.Close()

This makes a few changes to the player API to ensure that errors
are correctly propagated.
@zmb3 zmb3 force-pushed the zmb3/desktop-player-api-2 branch from 301c078 to ec58b51 Compare November 9, 2023 19:58
@zmb3 zmb3 enabled auto-merge November 9, 2023 20:50
@zmb3 zmb3 added this pull request to the merge queue Nov 9, 2023
@github-merge-queue github-merge-queue bot removed this pull request from the merge queue due to failed status checks Nov 9, 2023
@zmb3 zmb3 added this pull request to the merge queue Nov 9, 2023
Merged via the queue into master with commit 3a5ae50 Nov 10, 2023
32 checks passed
@zmb3 zmb3 deleted the zmb3/desktop-player-api-2 branch November 10, 2023 00:04
ibeckermayer pushed a commit that referenced this pull request Feb 10, 2024
This makes a few changes to the player API to ensure that errors
are correctly propagated.
lxea pushed a commit that referenced this pull request Feb 13, 2024
This makes a few changes to the player API to ensure that errors
are correctly propagated.
github-merge-queue bot pushed a commit that referenced this pull request Feb 13, 2024
* Introduce a new streaming player API (#31754)

This new API can be used to play back sessions of any type.
The player accepts a session ID and a streamer, and provides
the caller with an API for playback controls (speed, play/pause,
seek, etc) as well as a channel that receives events with the
proper timing delay applied.

The design for this change is discussed in RFD 91.

Updates #10578
Updates #10579
Updates gravitational/teleport-private#665
Updates gravitational/teleport-private#1024

* Convert the desktop sesssion player to the new player API (#34070)

This makes a few changes to the player API to ensure that errors
are correctly propagated.

* Switch desktop playback to gorilla/websocket (#36405)

We use gorilla/websocket throughout the app, but desktop playback
leveraged x/net/websocket instead. Convert to gorilla so that we
are consistent and use the same library everywhere websockets are
used.

* Read the bearer token over websocket endpoints instead of query parameter (#37520)

* Read the bearer token over WS endpoints

use the request context, not session

Dont pass websocket by context

lint

resolve some comments

Add TestWSAuthenticateRequest

Close ws in handler

deprecation notices, doc

resolve comments

resolve comments

give a longer read/write deadline

dont set write deadline, ws endpoints never did before and it breaks things

convert frontend to use ws access token

Resolove comments, move to using an explicit state

fix ci

reset read deadline

prettier

* update connectToHost

* linter

* read errors from websocket

* missing /ws on ttyWsAddr and fix wrong onmessage

* fix race in test

* lint

* skip TestTerminal as it takes 11 seconds to run

* dont skip the test

* resolve apiserver comments

* Add an AuthenticatedWebSocket class

* convert other clients to use AuthenticatedWebSocket

* Converts `AuthenticatedWebSocket` into drop-in replacement for `WebSocket` (#37699)

* Converts `AuthenticatedWebSocket` into drop-in replacement for `WebSocket`
that automatically goes through Teleport's custom authentication process
before facilitating any caller-defined communication.

This also reverts previous-`WebSocket` users to their original state
(sans the code for passing the bearer token in the query string),
swapping in `AuthenticatedWebSocket` in place of `WebSocket`.

* Create a single authnWsUpgrader with a comment justifying why we turn off CORS

* recieving to receiving

* resolve comments

---------

Co-authored-by: Isaiah Becker-Mayer <[email protected]>

* Updates `desktopPlaybackHandle` to new ws paradigm (#37981)

* Updates `desktopPlaybackHandle` to new ws paradigm

This was mistakenly left out of #37520.
This commit also refactors `WithClusterAuthWebSocket` slightly for easier
comprehension, and updates the vite config to facilitate the new websocket
endpoints in development mode.

* Update lib/web/apiserver.go

Co-authored-by: Zac Bergquist <[email protected]>

---------

Co-authored-by: Zac Bergquist <[email protected]>

* polishing off merge errors

* fixes Path in makeTerminal to reflect new /ws suffix

---------

Co-authored-by: Zac Bergquist <[email protected]>
Co-authored-by: Alex McGrath <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
audit-log Issues related to Teleports Audit Log desktop-access no-changelog Indicates that a PR does not require a changelog entry size/sm
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants