-
Notifications
You must be signed in to change notification settings - Fork 1.8k
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
SetInformation
#35092
SetInformation
#35092
Conversation
1. **Cargo.toml**: - Updated IronRDP dependencies to a new revision (`fed6a3173e83834e1b32b745f1ea3eed66e7f11f`). - Commented out the local path dependencies for IronRDP crates. 2. **client.rs**: - Added a new asynchronous function `handle_tdp_sd_list_response` to handle `SharedDirectoryListResponse`. - Added `ClientFunction::HandleTdpSdListResponse` enum variant and integrated it into the client's message handling. 3. **lib.rs**: - Updated `client_handle_tdp_sd_list_response` function to handle `SharedDirectoryListResponse` from TDP (Teleport Desktop Protocol). 4. **rdpdr.rs**: - Added a new method `handle_tdp_sd_list_response` in `TeleportRdpdrBackend` to handle shared directory list responses. - Integrated this method into the main RDPDR (Remote Desktop Protocol: Device Redirection) backend. 5. **filesystem.rs**: - Added logic to handle `ServerDriveQueryDirectoryRequest` for querying directory information. This includes sending a list request to the client and handling the response. - Added a new `pending_sd_list_resp_handlers` cache to store handlers for pending shared directory list responses. - Implemented logic to send and handle `SharedDirectoryListResponse` from the client. - Updated various methods to handle directory query responses and errors. 6. **tdp.rs**: - Added a new structure `SharedDirectoryListRequest` with methods to convert it into its CGO (C-Go) representation. - Added a new `TdpErrCode` enum variant to represent specific error codes. These changes enhance the RDP client's ability to handle directory listing requests and responses, integrating new functionality related to shared directory operations in the context of remote desktop sessions. The updates to dependencies and the integration of new request and response types indicate a focus on expanding the capabilities of the client in handling file system interactions over RDP.
…eInformationResponse` This commit introduces new functionality to handle volume information queries in the RDP client's filesystem module. Key Changes: 1. Enhanced `FilesystemBackend` to process `ServerDriveQueryVolumeInformationRequest`: - Added a case in the `FilesystemBackend` implementation to handle `ServerDriveQueryVolumeInformationRequest` from the RDP server. 2. Implemented `handle_query_volume_req` method: - This method processes various volume information queries by checking the requested information class level and generating the appropriate response. - Supported information classes include `FILE_FS_VOLUME_INFORMATION`, `FILE_FS_ATTRIBUTE_INFORMATION`, `FILE_FS_FULL_SIZE_INFORMATION`, `FILE_FS_DEVICE_INFORMATION`, and `FILE_FS_SIZE_INFORMATION`. - The method utilizes default fallback values where specific data is not available, following the pattern used in FreeRDP. 3. Added `send_query_vol_info_response` method: - This method is responsible for sending the `ClientDriveQueryVolumeInformationResponse` back to the RDP server with the generated volume information. This update significantly enhances the RDP client's file system capabilities, allowing it to respond more effectively to the server's volume information requests. The implementation follows established practices from FreeRDP, ensuring compatibility and reliability.
The PR changelog entry failed validation: Changelog entry not found in the PR body. Please add a "no-changelog" label to the PR, or changelog lines starting with |
The PR changelog entry failed validation: Changelog entry not found in the PR body. Please add a "no-changelog" label to the PR, or changelog lines starting with |
878100b
to
f575702
Compare
The PR changelog entry failed validation: Changelog entry not found in the PR body. Please add a "no-changelog" label to the PR, or changelog lines starting with |
- Added support for `efs::DeviceControlRequest` in `FilesystemBackend` with `handle_device_control_req` method. - Introduced `send_device_control_response` method for handling device control responses. - Updated `ScardBackend` to align with new optional `output_buffer` in `DeviceControlResponse`.
…ion handling - Introduce 'tdp_sd_move_request' handling in FilesystemBackend for file move operations. This includes the implementation of 'tdp_sd_move' and 'send_tdp_sd_move_request' methods, along with the necessary SharedDirectoryMoveRequest and SharedDirectoryMoveResponse structures. - Implement support for handling unsupported minor functions in ServerDriveIoRequest. This is done by adding 'handle_unsupported_minor_fn' method which handles specific cases like NotifyChangeDirectory and others. - Refactor 'pending_tdp_sd_info_resp_handlers' to 'pending_sd_info_resp_handlers' for consistency. - Add 'pending_sd_move_resp_handlers' to handle responses for move operations. - Extend 'handle_set_information_req' method to support file rename and deletion operations, responding appropriately based on file cache state and operation requirements. - Implement a 'send_set_info_response' method to facilitate sending responses for set information requests.
- Added functionality to handle Shared Directory Read Requests and Responses in RDP client. - Extended `FilesystemBackend` to process `DeviceReadRequest` from RDP server. - Implemented `handle_device_read_req` and `tdp_sd_read` methods for reading directory contents. - Integrated Shared Directory Read handling in the main client logic. - Updated relevant data structures and methods to support reading from shared directories.
- Implemented `handle_tdp_sd_write_response` in the RDP client to manage SharedDirectoryWriteResponses. - Added handling for TDP Shared Directory Write Responses in `ClientFunction`. - Integrated write response processing in `TeleportRdpdrBackend` and `FilesystemBackend`. - Extended `tdp` module to support SharedDirectoryWriteRequest conversion and handling.
- Replace the handling of UnsupportedMinorFunctionRequest with a specific implementation for ServerDriveNotifyChangeDirectoryRequest in FilesystemBackend. - Implement `handle_notify_change_directory_req` method to specifically handle NotifyChangeDirectory requests. Currently, this method simply logs the receipt of such requests and returns successfully without further processing. - Remove the previous generic handling of unsupported minor functions, as specific implementations for all valid minor function cases are now in place.
f575702
to
74eb327
Compare
The PR changelog entry failed validation: Changelog entry not found in the PR body. Please add a "no-changelog" label to the PR, or changelog lines starting with |
1. **Cargo.toml**: - Updated IronRDP dependencies to a new revision (`fed6a3173e83834e1b32b745f1ea3eed66e7f11f`). - Commented out the local path dependencies for IronRDP crates. 2. **client.rs**: - Added a new asynchronous function `handle_tdp_sd_list_response` to handle `SharedDirectoryListResponse`. - Added `ClientFunction::HandleTdpSdListResponse` enum variant and integrated it into the client's message handling. 3. **lib.rs**: - Updated `client_handle_tdp_sd_list_response` function to handle `SharedDirectoryListResponse` from TDP (Teleport Desktop Protocol). 4. **rdpdr.rs**: - Added a new method `handle_tdp_sd_list_response` in `TeleportRdpdrBackend` to handle shared directory list responses. - Integrated this method into the main RDPDR (Remote Desktop Protocol: Device Redirection) backend. 5. **filesystem.rs**: - Added logic to handle `ServerDriveQueryDirectoryRequest` for querying directory information. This includes sending a list request to the client and handling the response. - Added a new `pending_sd_list_resp_handlers` cache to store handlers for pending shared directory list responses. - Implemented logic to send and handle `SharedDirectoryListResponse` from the client. - Updated various methods to handle directory query responses and errors. 6. **tdp.rs**: - Added a new structure `SharedDirectoryListRequest` with methods to convert it into its CGO (C-Go) representation. - Added a new `TdpErrCode` enum variant to represent specific error codes. These changes enhance the RDP client's ability to handle directory listing requests and responses, integrating new functionality related to shared directory operations in the context of remote desktop sessions. The updates to dependencies and the integration of new request and response types indicate a focus on expanding the capabilities of the client in handling file system interactions over RDP.
…redDirectoryWriteRequest so that this data sticks around long enough to be copied over the Go boundary
…eInformationResponse` This commit introduces new functionality to handle volume information queries in the RDP client's filesystem module. Key Changes: 1. Enhanced `FilesystemBackend` to process `ServerDriveQueryVolumeInformationRequest`: - Added a case in the `FilesystemBackend` implementation to handle `ServerDriveQueryVolumeInformationRequest` from the RDP server. 2. Implemented `handle_query_volume_req` method: - This method processes various volume information queries by checking the requested information class level and generating the appropriate response. - Supported information classes include `FILE_FS_VOLUME_INFORMATION`, `FILE_FS_ATTRIBUTE_INFORMATION`, `FILE_FS_FULL_SIZE_INFORMATION`, `FILE_FS_DEVICE_INFORMATION`, and `FILE_FS_SIZE_INFORMATION`. - The method utilizes default fallback values where specific data is not available, following the pattern used in FreeRDP. 3. Added `send_query_vol_info_response` method: - This method is responsible for sending the `ClientDriveQueryVolumeInformationResponse` back to the RDP server with the generated volume information. This update significantly enhances the RDP client's file system capabilities, allowing it to respond more effectively to the server's volume information requests. The implementation follows established practices from FreeRDP, ensuring compatibility and reliability.
1. **Cargo.toml**: - Updated IronRDP dependencies to a new revision (`fed6a3173e83834e1b32b745f1ea3eed66e7f11f`). - Commented out the local path dependencies for IronRDP crates. 2. **client.rs**: - Added a new asynchronous function `handle_tdp_sd_list_response` to handle `SharedDirectoryListResponse`. - Added `ClientFunction::HandleTdpSdListResponse` enum variant and integrated it into the client's message handling. 3. **lib.rs**: - Updated `client_handle_tdp_sd_list_response` function to handle `SharedDirectoryListResponse` from TDP (Teleport Desktop Protocol). 4. **rdpdr.rs**: - Added a new method `handle_tdp_sd_list_response` in `TeleportRdpdrBackend` to handle shared directory list responses. - Integrated this method into the main RDPDR (Remote Desktop Protocol: Device Redirection) backend. 5. **filesystem.rs**: - Added logic to handle `ServerDriveQueryDirectoryRequest` for querying directory information. This includes sending a list request to the client and handling the response. - Added a new `pending_sd_list_resp_handlers` cache to store handlers for pending shared directory list responses. - Implemented logic to send and handle `SharedDirectoryListResponse` from the client. - Updated various methods to handle directory query responses and errors. 6. **tdp.rs**: - Added a new structure `SharedDirectoryListRequest` with methods to convert it into its CGO (C-Go) representation. - Added a new `TdpErrCode` enum variant to represent specific error codes. These changes enhance the RDP client's ability to handle directory listing requests and responses, integrating new functionality related to shared directory operations in the context of remote desktop sessions. The updates to dependencies and the integration of new request and response types indicate a focus on expanding the capabilities of the client in handling file system interactions over RDP.
- Added support for `efs::DeviceControlRequest` in `FilesystemBackend` with `handle_device_control_req` method. - Introduced `send_device_control_response` method for handling device control responses. - Updated `ScardBackend` to align with new optional `output_buffer` in `DeviceControlResponse`.
SetInformation
and minor function handlingSetInformation
* adds ironrdp client and has it connect, alongside rdp-rs * Integrates IronRDP client into the TDP png-response system. Instead of sending back chunks of the screen, its sends the full screen every time, and this is my running hypothesis for the current sticking point: a "Maximum call stack size exceeded" from the tdp client in the react app * Changes arrayBufferToBase64 to use reduce, which fixes the "Maximum call stack size exceeded" bug * removes convert_bgra_to_rgba which isn't needed with the bitmaps being produced by IronRDP * Adds support for updating only a specific image region * removes mistaken read_rdp_output_inner call from connect_rdp_inner * Adds support for mouse input. I believe this code has race conditions for client.write_frame though this requires more research. * Patches things up with the new IronRDP structure Requires some modifications to IronRDP, see the corresponding commit hash for IronRDP in lib/srv/desktop/rdp/rdpclient/Cargo.toml. Started getting call stack overflows when manual testing again, but I'm going to ignore those for now and focus on the version of this architecture that passes the remoteFX encoded messages over TDP. * Adds RemoteFX Frame to the backend * Proof of concept for integrating a wasm module into the frontend Building the wasm module still needs to be done manually, this was just to get to a point where tools are configured and it can be successfully called in both dev and prod modes. Required that I comment out "default-src 'self'" in the CSP, this will need to be figured out later. We're also using a package called vite-plugin-wasm-pack whereas ironrdp uses vite-plugin-wasm. I'm not sure why, I'm going to look into this and swap out to vite-plugin-wasm if possible. * Swaps out vite-plugin-wasm-pack for vite-plugin-wasm and adds build-wasm script to the teleport package.json. vite-plugin-wasm-pack looks relatively unmaintained in comparison to vite-plugin-wasm-pack. build-wasm script is needed to build the wasm binary before calling vite [build] * Adds backend structure for RPC PoC Untested as of yet and it isn't pretty, but this more or less imitates the RPC approach we have for directory sharing. * hack solution which calls everything 'static. THIS IS VERY UNSAFE, WE SHOULD DO SOMETHING ELSE * Gets the full display working end to end with a particular commit of IronRDP. Unfortunately this commit is now well out of date, and IronRDP had some bugs that were preventing RemoteFX frames from being sent back. * Full display working end to end with the updated IronRDP * updates init_wasm_log to enable logging in the console * updates hardcoded io_channel_id and user_channel_id * Uses specific IronRDP sub-crates (i.e. ironrdp-session, ironrdp-tokio, etc.) rather than relying on whatever is re-exported from the ironrdp sub-crate itself * Gets FastPathFrameResponse up to speed and the PoC is now working * deletes all the rpc stuff which it turns out we don't need * more cleanup including consolidating the FastPathFrame message between wasm and js, adding some comments * Updates the documentation string for top level Client in lib.rs * Removes hardcoded rdp server address, screen size, and username * Swaps to online IronRDP repo * Updates the TDP RFD with new messages renaming them to be precise. * remove hardcoded ip * creates asRustBackedSlice * removing some old todos * Add cleanup for wasm-pack build artifacts to make clean * Fix wasm in production builds (#27428) * Converts the default Content-Security-Policy representation to a map which makes it easier to programmatically add-to/overwrite the defaults for special cases. Also adds tests for the various custom CSPs. * Alphabetize CSP directives for ease of testing/debugging in the future * makes maps more easily composable * removes commented code, and topLevelAwait() which was causing production builds to break * Adds 'wasm-unsafe-eval' to the script-src section of the Content-Security-Policy when a desktop session's url is detected. The app already enforces no caching via the Cache-Control, Pragma, and Expires headers (SetNoCacheHeaders), which means that any time the app is requested in a new tab, the browser will always request a new index.html which can be sent back with a new Content-Security-Policy header. Since the only way to get to a desktop session is to either click a link in the app which opens a new tab, or to open a new tab and navigate to the url manually (this differs from most components, which can be navigated to without a page reload using React Router), we can reliably check each index.html request for a characteristic desktop session url path, and only include the 'wasm-unsafe-eval' directive when strictly necessary (in the spirit of the principle of least privilege). * Removes vite-plugin-top-level-await from package.json * moves regex to global so that it only need be compiled once * CR fixes updates Cargo.lock removes commented feature flag removes -framework SystemConfiguration fixes makefile comment * unsafe.SliceData * fixes phrasing * changes to docstring * changes handle_tdp_fast_path_response to handle_tdp_rdp_response_pdu so that its name is in line with its definition in RFD 0037 and adds a more descriptive docstring. * small fixes to comments * preallocate RDPFastPathPDU Encode buffer * updating comments * Adds a detailed discussion of the Go/Rust Interface to the README (#29762) * Aligns the codebase with the Go/Rust interface principles in the README (#29764) * Move client functionality into Client (#29765) * Adds the RDP Channel IDs TDP message (#27514) * Refactoring `rdpclient` (#29766) * Ironrdp recording playback (#28228) * httplib.SetIndexContentSecurityPolicyWithWasm for recordings as well as desktop sessions so that the ironrdp wasm client can be used for recording playback * Adds desktopplayback path to websocket proxy definitions so that it can be used with the dev server * adds tdp.TypeRDPFastPathPDU as a tdp message to be recorded * With this commit, recordings can be played back with the FastPathProcessor Refactors tdp Client and subclass PlayerClient such that now the classes are always constructed the same way, and the internal representation of the screen size (the FastPathProcessor) is either: 1. Created upon the call to Client.connect(spec) when spec is !undefined. This is the case when the Client is being used for a desktop session. 2. Created when a client screen spec is received from the server. This is the case when PlayerClient is being used for playback. * Switches from sending the width/height via ur parameter string to sending it via the client screen spec tdp message. * changes tdpCli* to client* and adds a canvas* to the canvas related functions * Static tokio (#30066) * Beginnings of RdpdrBackend integration (#32814) * Adds handling for the EstablishContextCall (#32971) * Adds support for `ListReadersCall` and `ListReadersReturn` (#33004) * Adds support for `GetStatusChangeCall`/`GetStatusChangeReturn` (#33056) * Adds support for ConnectCall and ConnectReturn (#33136) * Better error handling (#32925) This change removes couple of unwrap that could cause panics on the Rust side and prevents panics from invalid cgo handle on the Go side. It also sends error message from IronRDP to UI and cleans up a little final sequence of closing various goroutines in case of error or sessions end. * Adds support for `HCardAndDispositionCall` with `ScardIoCtlCode::BeginTransaction` (#33192) * `TransmitCall` and `TransmitReturn` (#33282) * `StatusCall` and `StatusReturn` (#33284) * `ReleaseContext` and refactor `handle_scard_call` (#33434) * IronRDP clipboard sharing (#33335) This change adds clipboard sharing to our IronRDP migration using ironrdp_cliprdr crate with out TDP-based backend (reused from rdp-rs times) * Adds EndTransaction, Disconnect, Cancel, and IsValidContext (#33612) * Adds support for `GetDeviceTypeId` (#33613) * Adds support for `ReadCacheW` (#33618) * `WriteCacheW` (#33620) * Smartcard Login (#33712) * `GetReaderIcon` (#33779) * Update to IronRDP latest commit * Removes a bunch of old deprecated code (including `rdp-rs`) (#33786) * Pipes in `SharedDirectoryAnnounce` (#33911) * Use tokio-boring for TLS upgrade (#33900) This change switches TLS upgrade in our new RDP approach to tokio-boring in FIPS-compliant builds. It also adds runtime check for FIPS mode. Tested locally in custom Docker image. * Update sspi (#34558) * Break up rdpdr.rs, add support for the first directory sharing pdus (#34009) * Adds support for `SharedDirectoryCreateRequest` and `SharedDirectoryCreateResponse`. (#34011) * `SharedDirectoryDeleteRequest` and `SharedDirectoryDeleteResponse` (#34051) * remove leftover code * Server drive query information request (#34082) * Rdp client refactor (#34122) * Add handling for `DeviceCloseRequest` (#34139) * Updates to `IronRDP` latest (#34744) * Updates to IronRDP latest with a slightly different API * remove defunct comment * `ServerDriveQueryDirectoryRequest` and `SharedDirectoryListRequest/Response` (#34746) * `ServerDriveQueryVolumeInformationRequest` and `ClientDriveQueryVolumeInformationResponse` (#34871) * `DeviceControlRequest` (#34898) * `Read` (#34914) * `Write` (#34919) * `SetInformation` (#35092) * `LockControl` (#35146) * Stack pr feedback and other cleanup (#35306) * Adds desktop access websocket pattern to vite config * Updates IronRDP to latest, removes manual context strings in favor of automatically generated (by this latest IronRDP commit) (#35392) * Small line fixes, comment removal, changing license to AGPL * Update Go/Rust interface section of README (#35590) * Ironrdp manual docs (#35455) * Remove unnecessary whitespace * Refactor navigation paths in Active Directory documentation for clarity Replaced textual descriptions with formatted paths using `>` symbols for better readability. Having been subject to going through many such tutorials myself, I find this to be a more user-friendly way of presenting the information. It's very common to need to go back and forth between the documentation and the group policy manager, and having these paths in a format that can catch the eye quickly is a big help. This also appears to be common practice e.g. - https://softwarekeep.com/help-center/how-to-enable-remote-desktop-on-windows - https://www.helpwire.app/blog/remote-desktop-group-policy/ * Add instructions for enabling RemoteFX * Add an optional step to the end of each GPO update subsection This lets us point users to subsections individually without worrying about reminding them that they need to run a `gpupdate /force` each time (because its already right there in the subsection). * lowercase "open" * Updates configuration script to enable RemoteFX (#35461) * Restructure Cargo workspace (#35591) * Update `IronRDP` to latest, fix key log leak (#35707) Updates IronRDP to latest with the changes necessary to keep up with the changes in Devolutions/IronRDP#328. We select the `"rustls"` feature explicitly now, this is in line with our implicit choice of it as [the default](https://github.com/Devolutions/IronRDP/pull/325/files#diff-1f64036f3e460819b2b1e954803b7f266feca0e2787ca0614ae1253323944f59L19) before these latest changes. Also creates a custom debug for `ScardBackend` so as to not leak `key_der` in the logs. * Don't leak pin in the logs * Updates CI to fix broken checks and builds caused by WASM introduction (#35401) * removes SystemConfiguration framework (not sure why it was there). * Updates cspell * fixes TestSetRedirectPageContentSecurityPolicy * Updates e ref to a currently-draft-PR ref. * Fix per session mfa (#35902) * Updating e-ref to tip of `master` * dependency-review: Ignore cargo dependencies with invalid license specifications * Updates OSS build-macos.yaml to support wasm-pack --------- Co-authored-by: Przemko Robakowski <przemko.robakowski@goteleport.com> Co-authored-by: Mike Jensen <mike.jensen@goteleport.com>
* adds ironrdp client and has it connect, alongside rdp-rs * Integrates IronRDP client into the TDP png-response system. Instead of sending back chunks of the screen, its sends the full screen every time, and this is my running hypothesis for the current sticking point: a "Maximum call stack size exceeded" from the tdp client in the react app * Changes arrayBufferToBase64 to use reduce, which fixes the "Maximum call stack size exceeded" bug * removes convert_bgra_to_rgba which isn't needed with the bitmaps being produced by IronRDP * Adds support for updating only a specific image region * removes mistaken read_rdp_output_inner call from connect_rdp_inner * Adds support for mouse input. I believe this code has race conditions for client.write_frame though this requires more research. * Patches things up with the new IronRDP structure Requires some modifications to IronRDP, see the corresponding commit hash for IronRDP in lib/srv/desktop/rdp/rdpclient/Cargo.toml. Started getting call stack overflows when manual testing again, but I'm going to ignore those for now and focus on the version of this architecture that passes the remoteFX encoded messages over TDP. * Adds RemoteFX Frame to the backend * Proof of concept for integrating a wasm module into the frontend Building the wasm module still needs to be done manually, this was just to get to a point where tools are configured and it can be successfully called in both dev and prod modes. Required that I comment out "default-src 'self'" in the CSP, this will need to be figured out later. We're also using a package called vite-plugin-wasm-pack whereas ironrdp uses vite-plugin-wasm. I'm not sure why, I'm going to look into this and swap out to vite-plugin-wasm if possible. * Swaps out vite-plugin-wasm-pack for vite-plugin-wasm and adds build-wasm script to the teleport package.json. vite-plugin-wasm-pack looks relatively unmaintained in comparison to vite-plugin-wasm-pack. build-wasm script is needed to build the wasm binary before calling vite [build] * Adds backend structure for RPC PoC Untested as of yet and it isn't pretty, but this more or less imitates the RPC approach we have for directory sharing. * hack solution which calls everything 'static. THIS IS VERY UNSAFE, WE SHOULD DO SOMETHING ELSE * Gets the full display working end to end with a particular commit of IronRDP. Unfortunately this commit is now well out of date, and IronRDP had some bugs that were preventing RemoteFX frames from being sent back. * Full display working end to end with the updated IronRDP * updates init_wasm_log to enable logging in the console * updates hardcoded io_channel_id and user_channel_id * Uses specific IronRDP sub-crates (i.e. ironrdp-session, ironrdp-tokio, etc.) rather than relying on whatever is re-exported from the ironrdp sub-crate itself * Gets FastPathFrameResponse up to speed and the PoC is now working * deletes all the rpc stuff which it turns out we don't need * more cleanup including consolidating the FastPathFrame message between wasm and js, adding some comments * Updates the documentation string for top level Client in lib.rs * Removes hardcoded rdp server address, screen size, and username * Swaps to online IronRDP repo * Updates the TDP RFD with new messages renaming them to be precise. * remove hardcoded ip * creates asRustBackedSlice * removing some old todos * Add cleanup for wasm-pack build artifacts to make clean * Fix wasm in production builds (#27428) * Converts the default Content-Security-Policy representation to a map which makes it easier to programmatically add-to/overwrite the defaults for special cases. Also adds tests for the various custom CSPs. * Alphabetize CSP directives for ease of testing/debugging in the future * makes maps more easily composable * removes commented code, and topLevelAwait() which was causing production builds to break * Adds 'wasm-unsafe-eval' to the script-src section of the Content-Security-Policy when a desktop session's url is detected. The app already enforces no caching via the Cache-Control, Pragma, and Expires headers (SetNoCacheHeaders), which means that any time the app is requested in a new tab, the browser will always request a new index.html which can be sent back with a new Content-Security-Policy header. Since the only way to get to a desktop session is to either click a link in the app which opens a new tab, or to open a new tab and navigate to the url manually (this differs from most components, which can be navigated to without a page reload using React Router), we can reliably check each index.html request for a characteristic desktop session url path, and only include the 'wasm-unsafe-eval' directive when strictly necessary (in the spirit of the principle of least privilege). * Removes vite-plugin-top-level-await from package.json * moves regex to global so that it only need be compiled once * CR fixes updates Cargo.lock removes commented feature flag removes -framework SystemConfiguration fixes makefile comment * unsafe.SliceData * fixes phrasing * changes to docstring * changes handle_tdp_fast_path_response to handle_tdp_rdp_response_pdu so that its name is in line with its definition in RFD 0037 and adds a more descriptive docstring. * small fixes to comments * preallocate RDPFastPathPDU Encode buffer * updating comments * Adds a detailed discussion of the Go/Rust Interface to the README (#29762) * Aligns the codebase with the Go/Rust interface principles in the README (#29764) * Move client functionality into Client (#29765) * Adds the RDP Channel IDs TDP message (#27514) * Refactoring `rdpclient` (#29766) * Ironrdp recording playback (#28228) * httplib.SetIndexContentSecurityPolicyWithWasm for recordings as well as desktop sessions so that the ironrdp wasm client can be used for recording playback * Adds desktopplayback path to websocket proxy definitions so that it can be used with the dev server * adds tdp.TypeRDPFastPathPDU as a tdp message to be recorded * With this commit, recordings can be played back with the FastPathProcessor Refactors tdp Client and subclass PlayerClient such that now the classes are always constructed the same way, and the internal representation of the screen size (the FastPathProcessor) is either: 1. Created upon the call to Client.connect(spec) when spec is !undefined. This is the case when the Client is being used for a desktop session. 2. Created when a client screen spec is received from the server. This is the case when PlayerClient is being used for playback. * Switches from sending the width/height via ur parameter string to sending it via the client screen spec tdp message. * changes tdpCli* to client* and adds a canvas* to the canvas related functions * Static tokio (#30066) * Beginnings of RdpdrBackend integration (#32814) * Adds handling for the EstablishContextCall (#32971) * Adds support for `ListReadersCall` and `ListReadersReturn` (#33004) * Adds support for `GetStatusChangeCall`/`GetStatusChangeReturn` (#33056) * Adds support for ConnectCall and ConnectReturn (#33136) * Better error handling (#32925) This change removes couple of unwrap that could cause panics on the Rust side and prevents panics from invalid cgo handle on the Go side. It also sends error message from IronRDP to UI and cleans up a little final sequence of closing various goroutines in case of error or sessions end. * Adds support for `HCardAndDispositionCall` with `ScardIoCtlCode::BeginTransaction` (#33192) * `TransmitCall` and `TransmitReturn` (#33282) * `StatusCall` and `StatusReturn` (#33284) * `ReleaseContext` and refactor `handle_scard_call` (#33434) * IronRDP clipboard sharing (#33335) This change adds clipboard sharing to our IronRDP migration using ironrdp_cliprdr crate with out TDP-based backend (reused from rdp-rs times) * Adds EndTransaction, Disconnect, Cancel, and IsValidContext (#33612) * Adds support for `GetDeviceTypeId` (#33613) * Adds support for `ReadCacheW` (#33618) * `WriteCacheW` (#33620) * Smartcard Login (#33712) * `GetReaderIcon` (#33779) * Update to IronRDP latest commit * Removes a bunch of old deprecated code (including `rdp-rs`) (#33786) * Pipes in `SharedDirectoryAnnounce` (#33911) * Use tokio-boring for TLS upgrade (#33900) This change switches TLS upgrade in our new RDP approach to tokio-boring in FIPS-compliant builds. It also adds runtime check for FIPS mode. Tested locally in custom Docker image. * Update sspi (#34558) * Break up rdpdr.rs, add support for the first directory sharing pdus (#34009) * Adds support for `SharedDirectoryCreateRequest` and `SharedDirectoryCreateResponse`. (#34011) * `SharedDirectoryDeleteRequest` and `SharedDirectoryDeleteResponse` (#34051) * remove leftover code * Server drive query information request (#34082) * Rdp client refactor (#34122) * Add handling for `DeviceCloseRequest` (#34139) * Updates to `IronRDP` latest (#34744) * Updates to IronRDP latest with a slightly different API * remove defunct comment * `ServerDriveQueryDirectoryRequest` and `SharedDirectoryListRequest/Response` (#34746) * `ServerDriveQueryVolumeInformationRequest` and `ClientDriveQueryVolumeInformationResponse` (#34871) * `DeviceControlRequest` (#34898) * `Read` (#34914) * `Write` (#34919) * `SetInformation` (#35092) * `LockControl` (#35146) * Stack pr feedback and other cleanup (#35306) * Adds desktop access websocket pattern to vite config * Updates IronRDP to latest, removes manual context strings in favor of automatically generated (by this latest IronRDP commit) (#35392) * Small line fixes, comment removal, changing license to AGPL * Update Go/Rust interface section of README (#35590) * Ironrdp manual docs (#35455) * Remove unnecessary whitespace * Refactor navigation paths in Active Directory documentation for clarity Replaced textual descriptions with formatted paths using `>` symbols for better readability. Having been subject to going through many such tutorials myself, I find this to be a more user-friendly way of presenting the information. It's very common to need to go back and forth between the documentation and the group policy manager, and having these paths in a format that can catch the eye quickly is a big help. This also appears to be common practice e.g. - https://softwarekeep.com/help-center/how-to-enable-remote-desktop-on-windows - https://www.helpwire.app/blog/remote-desktop-group-policy/ * Add instructions for enabling RemoteFX * Add an optional step to the end of each GPO update subsection This lets us point users to subsections individually without worrying about reminding them that they need to run a `gpupdate /force` each time (because its already right there in the subsection). * lowercase "open" * Updates configuration script to enable RemoteFX (#35461) * Restructure Cargo workspace (#35591) * Update `IronRDP` to latest, fix key log leak (#35707) Updates IronRDP to latest with the changes necessary to keep up with the changes in Devolutions/IronRDP#328. We select the `"rustls"` feature explicitly now, this is in line with our implicit choice of it as [the default](https://github.com/Devolutions/IronRDP/pull/325/files#diff-1f64036f3e460819b2b1e954803b7f266feca0e2787ca0614ae1253323944f59L19) before these latest changes. Also creates a custom debug for `ScardBackend` so as to not leak `key_der` in the logs. * Don't leak pin in the logs * Show clear error when export can't be done * Show url of recording in webui * patching up merge mistake * use EndTime and StartTime to calculate duration --------- Co-authored-by: Isaiah Becker-Mayer <isaiah@goteleport.com>
Corresponds to Devolutions/IronRDP#312