tauri_plugin_secure_storage/
lib.rs

1use tauri::{
2  plugin::{Builder, TauriPlugin},
3  Manager, Runtime,
4};
5
6pub use models::*;
7
8#[cfg(desktop)]
9mod desktop;
10#[cfg(mobile)]
11mod mobile;
12
13mod commands;
14mod error;
15mod models;
16
17pub use error::{Error, Result};
18
19#[cfg(desktop)]
20use desktop::SecureStorage;
21#[cfg(mobile)]
22use mobile::SecureStorage;
23
24/// Extensions to [`tauri::App`], [`tauri::AppHandle`] and [`tauri::Window`] to access the secure-storage APIs.
25pub trait SecureStorageExt<R: Runtime> {
26  fn secure_storage(&self) -> &SecureStorage<R>;
27}
28
29impl<R: Runtime, T: Manager<R>> crate::SecureStorageExt<R> for T {
30  fn secure_storage(&self) -> &SecureStorage<R> {
31    self.state::<SecureStorage<R>>().inner()
32  }
33}
34
35/// Initializes the plugin.
36pub fn init<R: Runtime>() -> TauriPlugin<R> {
37  Builder::new("secure-storage")
38    .invoke_handler(tauri::generate_handler![commands::get_item, commands::set_item])
39    .setup(|app, api| {
40      #[cfg(mobile)]
41      let secure_storage = mobile::init(app, api)?;
42      #[cfg(desktop)]
43      let secure_storage = desktop::init(app, api)?;
44      app.manage(secure_storage);
45      Ok(())
46    })
47    .build()
48}