mirror of
https://github.com/tauri-apps/plugins-workspace.git
synced 2026-05-29 13:31:27 +02:00
aba07c27b8
Co-authored-by: Fabian-Lars <fabianlars@fabianlars.de> Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: FabianLars <fabianlars@fabianlars.de> Co-authored-by: FabianLars <FabianLars@users.noreply.github.com> Co-authored-by: Alexandre Dang <124160233+vdang-crabnebula@users.noreply.github.com> Co-authored-by: Ludea <ludovicw35@hotmail.com> Co-authored-by: Amr Bashir <amr.bashir2015@gmail.com> Co-authored-by: Duke Jones <104690+dukejones@users.noreply.github.com> Co-authored-by: NaokiM03 <37442712+NaokiM03@users.noreply.github.com> Co-authored-by: Thibault <thibault_poisson@orange.fr> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: David Blythe <49919035+writeDavid@users.noreply.github.com> Co-authored-by: Lucas Nogueira <lucas@tauri.studio> fix(stronghold): change wrong argument name for `remove` (#422) fix(window-state): correctly set decoration state if no saved state exists, fixes #421 (#424) fix(stronghold): return null if there is no record (#129) fix(window-state): propagate promise (#435) closes #432 fix(window-state): manual default implentation (#425) fix(window-state): manual default implentation, closes #421 fix(deps): update rust crate iota-crypto to 0.21 (#438) fix readme example (#447) fix: handle recursive directory correctly (#455) fix(deps): update rust crate sqlx to 0.7. plugin-sql msrv is now 1.65 (#464) fix(persisted-scope): separately save asset protocol patterns (#459) fix(deps): update rust crate iota-crypto to 0.22 (#475) fix(deps): update tauri monorepo to v1.4.0 (#482) resolve to v15.1.0 (#489) fix(deps): update rust crate iota-crypto to 0.23 (#495)
63 lines
1.4 KiB
TypeScript
63 lines
1.4 KiB
TypeScript
// Copyright 2019-2023 Tauri Programme within The Commons Conservancy
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
import { invoke, Channel } from "@tauri-apps/api/tauri";
|
|
|
|
interface CheckOptions {
|
|
/**
|
|
* Request headers
|
|
*/
|
|
headers?: Record<string, unknown>;
|
|
/**
|
|
* Timeout in seconds
|
|
*/
|
|
timeout?: number;
|
|
/**
|
|
* Target identifier for the running application. This is sent to the backend.
|
|
*/
|
|
target?: string;
|
|
}
|
|
|
|
interface UpdateResponse {
|
|
available: boolean;
|
|
currentVersion: string;
|
|
latestVersion: string;
|
|
date?: string;
|
|
body?: string;
|
|
}
|
|
|
|
type DownloadEvent =
|
|
| { event: "Started"; data: { contentLength?: number } }
|
|
| { event: "Progress"; data: { chunkLength: number } }
|
|
| { event: "Finished" };
|
|
|
|
class Update {
|
|
response: UpdateResponse;
|
|
|
|
constructor(response: UpdateResponse) {
|
|
this.response = response;
|
|
}
|
|
|
|
async downloadAndInstall(
|
|
onEvent?: (progress: DownloadEvent) => void,
|
|
): Promise<void> {
|
|
const channel = new Channel<DownloadEvent>();
|
|
if (onEvent != null) {
|
|
channel.onmessage = onEvent;
|
|
}
|
|
return invoke("plugin:updater|download_and_install", {
|
|
onEvent: channel,
|
|
});
|
|
}
|
|
}
|
|
|
|
async function check(options?: CheckOptions): Promise<Update> {
|
|
return invoke<UpdateResponse>("plugin:updater|check", { ...options }).then(
|
|
(response) => new Update(response),
|
|
);
|
|
}
|
|
|
|
export type { CheckOptions, UpdateResponse, DownloadEvent };
|
|
export { check, Update };
|