mirror of
https://github.com/tauri-apps/tauri-plugin-http.git
synced 2026-01-31 00:45:17 +01:00
* fix(shell): fix schema requiring `sidecar` property even though it is optional * fix clippy * make `cmd` and `sidecar` exclusive * make args optional * cleanup --------- Co-authored-by: Lucas Nogueira <lucas@tauri.app> Committed via a GitHub action: https://github.com/tauri-apps/plugins-workspace/actions/runs/11126148459 Co-authored-by: lucasfernog <lucasfernog@users.noreply.github.com>
68 lines
2.5 KiB
Rust
68 lines
2.5 KiB
Rust
// Copyright 2019-2023 Tauri Programme within The Commons Conservancy
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
#[path = "src/scope.rs"]
|
|
#[allow(dead_code)]
|
|
mod scope;
|
|
|
|
const COMMANDS: &[&str] = &["fetch", "fetch_cancel", "fetch_send", "fetch_read_body"];
|
|
|
|
/// HTTP scope entry.
|
|
#[derive(schemars::JsonSchema)]
|
|
#[serde(untagged)]
|
|
#[allow(unused)]
|
|
enum HttpScopeEntry {
|
|
/// A URL that can be accessed by the webview when using the HTTP APIs.
|
|
/// Wildcards can be used following the URL pattern standard.
|
|
///
|
|
/// See [the URL Pattern spec](https://urlpattern.spec.whatwg.org/) for more information.
|
|
///
|
|
/// Examples:
|
|
///
|
|
/// - "https://*" : allows all HTTPS origin on port 443
|
|
///
|
|
/// - "https://*:*" : allows all HTTPS origin on any port
|
|
///
|
|
/// - "https://*.github.com/tauri-apps/tauri": allows any subdomain of "github.com" with the "tauri-apps/api" path
|
|
///
|
|
/// - "https://myapi.service.com/users/*": allows access to any URLs that begins with "https://myapi.service.com/users/"
|
|
Value(String),
|
|
Object {
|
|
/// A URL that can be accessed by the webview when using the HTTP APIs.
|
|
/// Wildcards can be used following the URL pattern standard.
|
|
///
|
|
/// See [the URL Pattern spec](https://urlpattern.spec.whatwg.org/) for more information.
|
|
///
|
|
/// Examples:
|
|
///
|
|
/// - "https://*" : allows all HTTPS origin on port 443
|
|
///
|
|
/// - "https://*:*" : allows all HTTPS origin on any port
|
|
///
|
|
/// - "https://*.github.com/tauri-apps/tauri": allows any subdomain of "github.com" with the "tauri-apps/api" path
|
|
///
|
|
/// - "https://myapi.service.com/users/*": allows access to any URLs that begins with "https://myapi.service.com/users/"
|
|
url: String,
|
|
},
|
|
}
|
|
|
|
// Ensure `HttpScopeEntry` and `scope::EntryRaw` is kept in sync
|
|
fn _f() {
|
|
match scope::EntryRaw::Value(String::new()) {
|
|
scope::EntryRaw::Value(url) => HttpScopeEntry::Value(url),
|
|
scope::EntryRaw::Object { url } => HttpScopeEntry::Object { url },
|
|
};
|
|
match HttpScopeEntry::Value(String::new()) {
|
|
HttpScopeEntry::Value(url) => scope::EntryRaw::Value(url),
|
|
HttpScopeEntry::Object { url } => scope::EntryRaw::Object { url },
|
|
};
|
|
}
|
|
|
|
fn main() {
|
|
tauri_plugin::Builder::new(COMMANDS)
|
|
.global_api_script_path("./api-iife.js")
|
|
.global_scope_schema(schemars::schema_for!(HttpScopeEntry))
|
|
.build();
|
|
}
|