Compare commits

...

2 Commits

Author SHA1 Message Date
theo
d8f3c276c0
feat: remove reference to clego inside tauri app 2024-07-24 15:00:14 +02:00
theo
c2b4264f32
extract protocol logic to external function 2024-07-24 14:21:37 +02:00
5 changed files with 48 additions and 40 deletions

24
Cargo.lock generated
View File

@ -2161,6 +2161,18 @@ version = "2.3.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e" checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e"
[[package]]
name = "pharmacie-desktop"
version = "0.1.0"
dependencies = [
"axum",
"clego",
"tauri",
"tauri-build",
"tokio",
"tower",
]
[[package]] [[package]]
name = "phf" name = "phf"
version = "0.8.0" version = "0.8.0"
@ -3245,18 +3257,6 @@ dependencies = [
"walkdir", "walkdir",
] ]
[[package]]
name = "tauri-clego"
version = "0.1.0"
dependencies = [
"axum",
"clego",
"tauri",
"tauri-build",
"tokio",
"tower",
]
[[package]] [[package]]
name = "tauri-codegen" name = "tauri-codegen"
version = "2.0.0-beta.19" version = "2.0.0-beta.19"

View File

@ -1,12 +1,12 @@
[package] [package]
name = "tauri-clego" name = "pharmacie-desktop"
version = "0.1.0" version = "0.1.0"
description = "Un logiciel de pharmacie libre et open-source." description = "Un logiciel de pharmacie libre et open-source."
authors = ["p4pillon"] authors = ["p4pillon"]
edition = "2021" edition = "2021"
[lib] [lib]
name = "clego_lib" name = "pharmacie_desktop_lib"
crate-type = ["lib", "cdylib", "staticlib"] crate-type = ["lib", "cdylib", "staticlib"]
[build-dependencies] [build-dependencies]

View File

@ -2,40 +2,43 @@ use core::panic;
use std::sync::Arc; use std::sync::Arc;
use tauri::{path::BaseDirectory, Manager}; use tauri::{path::BaseDirectory, Manager};
use tokio::sync::Mutex; use tokio::sync::{Mutex, MutexGuard};
use tower::{Service, ServiceExt}; use tower::{Service, ServiceExt};
async fn process_tauri_request(request: tauri::http::Request<>, router: axum:Router ){ async fn process_tauri_request(
let (parts, body) = request.into_parts(); request: tauri::http::Request<Vec<u8>>,
let body = axum::body::Body::from(body); mut router: MutexGuard<'_, axum::Router>,
) -> tauri::http::Response<Vec<u8>> {
let (parts, body) = request.into_parts();
let body = axum::body::Body::from(body);
let request = axum::extract::Request::from_parts(parts, body); let request = axum::extract::Request::from_parts(parts, body);
let response = match router.as_service().ready().await { let response = match router.as_service().ready().await {
Ok(ready_service) => ready_service.call(request).await, Ok(ready_service) => ready_service.call(request).await,
Err(_error) => panic!("Failed to get ready service"), Err(_error) => panic!("Failed to get ready service"),
}; };
let response = match response { let response = match response {
Ok(response) => response, Ok(response) => response,
Err(_error) => panic!("Problem getting response from request."), Err(_error) => panic!("Problem getting response from request."),
}; };
let (parts, body) = response.into_parts(); let (parts, body) = response.into_parts();
let body = match axum::body::to_bytes(body, usize::MAX).await { let body = match axum::body::to_bytes(body, usize::MAX).await {
Ok(bytes) => bytes.to_vec(), Ok(bytes) => bytes.to_vec(),
Err(_error) => panic!("Problem converting response body to bytes."), Err(_error) => panic!("Problem converting response body to bytes."),
}; };
let response = tauri::http::Response::from_parts(parts, body); let response = tauri::http::Response::from_parts(parts, body);
response
} }
#[cfg_attr(mobile, tauri::mobile_entry_point)] #[cfg_attr(mobile, tauri::mobile_entry_point)]
pub fn run() { pub fn run() {
tauri::Builder::default() tauri::Builder::default()
.setup(|app| { .setup(|app| {
// Create a router and adds it the the app state
let resource_path_buf = app let resource_path_buf = app
.path() .path()
.resolve("assets", BaseDirectory::Resource) .resolve("assets", BaseDirectory::Resource)
@ -45,6 +48,8 @@ pub fn run() {
clego::get_router(resource_path_buf.as_path()).clone(), clego::get_router(resource_path_buf.as_path()).clone(),
)); ));
// Adds the router to the application state
// This makes it so we can retrieve it from any app instance (see bellow)
app.manage(router); app.manage(router);
Ok(()) Ok(())
@ -53,7 +58,10 @@ pub fn run() {
let router = Arc::clone(&app.state::<Arc<Mutex<axum::Router>>>()); let router = Arc::clone(&app.state::<Arc<Mutex<axum::Router>>>());
tauri::async_runtime::spawn(async move { tauri::async_runtime::spawn(async move {
let mut router = router.lock().await; let router = router.lock().await;
let response = process_tauri_request(request, router).await;
responder.respond(response); responder.respond(response);
}); });
}) })

View File

@ -2,5 +2,5 @@
#![cfg_attr(not(debug_assertions), windows_subsystem = "windows")] #![cfg_attr(not(debug_assertions), windows_subsystem = "windows")]
fn main() { fn main() {
clego_lib::run() pharmacie_desktop_lib::run()
} }

View File

@ -1,7 +1,7 @@
{ {
"productName": "clego-clean", "productName": "Logiciel Pharma",
"version": "0.0.1", "version": "0.0.1",
"identifier": "clego.pharma.libre", "identifier": "p4pillon.pharma.desktop",
"build": { "build": {
"beforeDevCommand": { "beforeDevCommand": {
"script": "cargo run", "script": "cargo run",
@ -14,7 +14,7 @@
"withGlobalTauri": true, "withGlobalTauri": true,
"windows": [ "windows": [
{ {
"title": "clego-clean", "title": "Logiciel Pharma",
"width": 800, "width": 800,
"height": 600 "height": 600
} }