authors | state |
---|---|
Zac Bergquist ([email protected]) |
implemented |
This RFD defines the high-level goals and architecture for supporting copy and paste between a Teleport user's workstation and a remote Windows Desktop.
The primary goal of this RFD is to support basic copy paste of small amounts of text between a Teleport user's workstation and a remote desktop. For example, copying shell commands, URLs, snippets of log files, etc.
The following are all considered out of scope for this RFD:
- large (greater than a few MB) amounts of data
- file transfer (this is a high priority feature but will implemented separately in order to keep scope reasonable)
An RDP connection contains a number of "virtual channels" that provide separate logical streams of data. Today, we use the global channel for desktop data, and the device redirection ("RDPDR") channel to implement a smart card emulator.
Clipboard support for RDP is implemented as a series of messages sent over a dedicated virtual channel called "CLIPRDR". The details of the protocol are specified in MS-RDPECLIP.
The spec often refers to the two clipboards as the shared clipboard and the local clipboard. The terminology can be confusing, but you can think of the shared clipboard as the location that is copied from, and the local clipboard as the location that is pasted to. For example, if a Teleport user copies text from their workstation and wants to paste it in a remote Windows Desktop, then the user is the shared clipboard owner and the desktop is the local clipboard owner. The roles are reversed for the other direction. When text is copied from the remote desktop and pasted on a user's workstation, the Windows Desktop is the shared clipboard owner and the Teleport user is the local clipboard owner.
RDP supports several different types of clipboard data:
- Generic: opaque data, not manipulated in any way
- Palette: a series of RGB-tuples, specially encoded for transport on the wire
- Metafile: an application-independent vector format for image transfers
- File List: a list of files to be transferred
- File Stream: the contents of a file, allowing transfer of specific chunks
Initially, Teleport will only support option 1 - generic clipboard data. Options 2 and 3 are specialized encodings that we don't need at this point, and options 4 and 5 will be useful for file transfer but are out of scope for this RFD.
In order to minimize the amount of network bandwidth required, RDP implements a principle called delayed rendering. In short, when data is copied to the shared clipboard, the shared clipboard owner notifies the other end that there is new data available. This notification includes the type of the data that was copied, but not the actual data. At some point later in time, when a paste operation is attempted on the local clipboard, the local clipboard owner makes a request to the shared clipboard owner for the data, and the shared clipboard owner responds with the actual data. This approach ensures that a copy operation that copies a large amount of data uses very little network bandwidth if that data is never pasted on the other end of the connection.
+-------------------+ +-----------------+
| shared_clipboard | | local_clipboard |
+-------------------+ +-----------------+
-------\ | |
| Copy |-| |
|------| | |
| |
| Format List PDU |
| (clipboard data not sent) |
|----------------------------------->|
| |
| | Updates local clipboard IDs
| |----------------------------
| | |
| |<---------------------------
| |
| Format List Response PDU |
|<-----------------------------------|
| |
| |
| |
| |
| | --------\
| |-| Paste |
| | |-------|
| |
| Format Data Request PDU |
| (request for data) |
|<-----------------------------------|
| |
| Format Data Response PDU |
| (clipboard data returned) |
|----------------------------------->|
| |
This approach differs from protocols like Remote Frame Buffer (VNC) or Teleport Desktop Protocol, where the clipboard data is sent along with the notification that there was an update.
The sharing of a clipboard between two machines requires a high level of trust. An untrusted peer or misbehaving RDP server can:
- monitor all clipboard activity on the other end of the connection by requesting a "paste" any time it receives a notification of a clipboard update
- replace or alter clipboard data before sending it to the remote machine to be pasted
These are features of RDP - clipboard sharing wouldn't work without them, though it highlights the importance of trusting the other end of the connection.
For these reasons, clipboard access will be enabled via the desktop_clipboard
role option as specified in RFD 33. This option will
default to true
, but the presence of a single role that disables the clipboard
will turn it off. When clipboard access is not enabled, Teleport will not
respond to any clipboard messages received by either the browser or the RDP
server.
The desktop access client runs in a web browser, which provides limited access to the system clipboard. The asynchronous clipboard API provides read and write access to the system clipboard, and is an obvious candidate for Teleport. Unfortunately, this API is relatively new and browser support varies widely. Access to this clipboard API is meant to be protected by the permissions API. At the time of this writing:
- The Firefox permissions API does not support the
clipboard-read
orclipboard-write
permissions. - Safari does not support the permissions API at all, and instead implements its own restrictions on the clipboard API. Most importantly, the system clipboard can only be read from or written to in response to a user gesture.
Fortunately, Chrome does provide enough support in both the permissions and clipboard APIs to implement clipboard sharing in a way that is natural to users and won't require them to change their behavior.
Since Chrome has the largest market share of any browser, we will officially support clipboard sharing in Chrome. For other browsers, desktop access will continue to function as it does today, without clipboard support.
If clipboard support is disabled due to an incompatible browser, the Teleport UI will present a clear warning and recommend the use of a Chrome-based browser. We will extend support for other browsers if and when they support the required APIs.
Since the TDP protocol does not implement the delayed rendering approach used by RDP, the Windows Desktop Service will be responsible for storing and synchronizing the state of the clipboard between the local workstation and the remote Windows desktop.
There are two scenarios to consider.
In this scenario, a user copies text on their local workstation running the Teleport UI. The web UI must detect a change to the local clipboard and notify the Teleport backend of the latest data. The general sequence of operations is:
- When a desktop session is initiated, the web UI uses the permissions API to request access to the clipboard. The user is presented with a dialog asking whether Teleport should be allowed access. The user grants access.
- The Web UI reads clipboard state on every
mouseenter
event. This approach is more efficient than polling the local clipboard, and works because in order to copy data from the local system and then paste it, they need to leave the Teleport UI and eventually re-enter the canvas. - If the web UI detects that the clipboard state has changed, it sends a clipboard data TDP message to the Teleport backend, which contains the new copied text.
- The Windows Desktop Service handling the RDP connection caches the clipboard text and notifies the Windows Desktop that new clipboard data is available. Remember, the actual contents of the clipboard data are not sent yet due to delayed rendering.
- The user executes a paste operation in the remote Windows Desktop. The RDP server on the Windows Desktop requests the clipboard data, and the Windows Desktop Service responds with the cached data.
In this scenario, the user copies text in the remote Windows Desktop, and expects that data to end up on their system clipboard. The sequence is:
- The Windows Desktop sends a notification to the Windows Desktop Service that new data has been copied to the clipboard.
- The Teleport Windows Desktop Service fakes a "paste" operation by immediately responding with a request for the clipboard data.
- The Windows Desktop Service receives the clipboard data from the Windows desktop, and sends it to the user's browser in a clipboard data message. It also updates its local cache of the clipboard data. This is necessary in case the user decides to paste the text they just copied back in the remote session rather than on their local workstation.
- The Teleport UI running in the browser unpacks this data and places it on the system clipboard.