Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/dev' into refactor/remove-invoke…
Browse files Browse the repository at this point in the history
…-system-responder
  • Loading branch information
lucasfernog committed Sep 16, 2024
2 parents 36c4c9b + e7fd676 commit 7795806
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 4 deletions.
5 changes: 5 additions & 0 deletions .changes/custom-invoke-system-invoke-key.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"tauri": patch:enhance
---

Inject `__INVOKE_KEY__` into custom invoke systems so their implementations can properly construct `tauri::webview::InvokeRequest`.
17 changes: 16 additions & 1 deletion crates/tauri/src/app.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1309,9 +1309,24 @@ impl<R: Runtime> Builder<R> {
///
/// The `initialization_script` is a script that initializes `window.__TAURI_INTERNALS__.postMessage`.
/// That function must take the `(message: object, options: object)` arguments and send it to the backend.
///
/// Additionally, the script must include a `__INVOKE_KEY__` token that is replaced with a value that must be sent with the IPC payload
/// to check the integrity of the message by the [`crate::WebviewWindow::on_message`] API, e.g.
///
/// ```js
/// const invokeKey = __INVOKE_KEY__;
/// fetch('my-impl://command', {
/// headers: {
/// 'Tauri-Invoke-Key': invokeKey,
/// }
/// })
/// ```
///
/// Note that the implementation details is up to your implementation.
#[must_use]
pub fn invoke_system(mut self, initialization_script: String) -> Self {
self.invoke_initialization_script = initialization_script;
self.invoke_initialization_script =
initialization_script.replace("__INVOKE_KEY__", &format!("\"{}\"", self.invoke_key));
self
}

Expand Down
4 changes: 1 addition & 3 deletions crates/tauri/src/webview/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -115,10 +115,8 @@ impl<'a> PageLoadPayload<'a> {
/// # Stability
///
/// This struct is **NOT** part of the public stable API and is only meant to be used
/// by internal code and external testing/fuzzing tools. If not used with feature `unstable`, this
/// struct is marked `#[non_exhaustive]` and is non-constructable externally.
/// by internal code and external testing/fuzzing tools or custom invoke systems.
#[derive(Debug)]
#[cfg_attr(not(feature = "test"), non_exhaustive)]
pub struct InvokeRequest {
/// The invoke command.
pub cmd: String,
Expand Down

0 comments on commit 7795806

Please sign in to comment.