use serde::de::DeserializeOwned;
use tauri::{
AppHandle, ResourceId, Runtime,
plugin::{PluginApi, PluginHandle},
};
use crate::Error;
use crate::models::*;
#[cfg(target_os = "ios")]
tauri::ios_plugin_binding!(init_plugin_permission_flow);
pub fn init<R: Runtime, C: DeserializeOwned>(
_app: &AppHandle<R>,
api: PluginApi<R, C>,
) -> crate::Result<PermissionFlowPlugin<R>> {
#[cfg(target_os = "android")]
let handle = api.register_android_plugin("", "PermissionFlowPlugin")?;
#[cfg(target_os = "ios")]
let handle = api.register_ios_plugin(init_plugin_permission_flow)?;
Ok(PermissionFlowPlugin(handle))
}
pub struct PermissionFlowPlugin<R: Runtime>(PluginHandle<R>);
impl<R: Runtime> PermissionFlowPlugin<R> {
pub fn create(&self) -> crate::Result<ResourceId> {
Err(Error::UnsupportedPlatform)
}
pub fn start_flow(&self, controller_id: u64, payload: StartFlowRequest) -> crate::Result<()> {
let _ = controller_id;
self.0
.run_mobile_plugin("start_flow", payload)
.map_err(Into::into)
}
pub fn stop_current_flow(&self, controller_id: u64) -> crate::Result<()> {
let _ = controller_id;
self.0
.run_mobile_plugin("stop_current_flow", ())
.map_err(Into::into)
}
pub fn authorization_state(
&self,
permission: Permission,
) -> crate::Result<PermissionAuthorizationState> {
let _ = permission;
Err(Error::UnsupportedPlatform)
}
pub fn suggested_host_app_path(&self) -> crate::Result<Option<String>> {
Ok(None)
}
}