Skip to main content

tauri_plugin_httpd/
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::Httpd;
21#[cfg(mobile)]
22use mobile::Httpd;
23
24/// Extensions to [`tauri::App`], [`tauri::AppHandle`] and [`tauri::Window`] to access the httpd APIs.
25pub trait HttpdExt<R: Runtime> {
26  fn httpd(&self) -> &Httpd<R>;
27}
28
29impl<R: Runtime, T: Manager<R>> crate::HttpdExt<R> for T {
30  fn httpd(&self) -> &Httpd<R> {
31    self.state::<Httpd<R>>().inner()
32  }
33}
34
35/// Initializes the plugin.
36pub fn init<R: Runtime>() -> TauriPlugin<R> {
37  Builder::new("httpd")
38    .invoke_handler(tauri::generate_handler![commands::get_services, commands::stop_service, commands::listen_static])
39    .setup(|app, api| {
40      #[cfg(mobile)]
41      let httpd = mobile::init(app, api)?;
42      #[cfg(desktop)]
43      let httpd = desktop::init(app, api)?;
44      app.manage(httpd);
45      Ok(())
46    })
47    .build()
48}