Compare commits
	
		
			2 Commits
		
	
	
		
			0e8514d906
			...
			d8f3c276c0
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | d8f3c276c0 | ||
|   | c2b4264f32 | 
							
								
								
									
										24
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										24
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -2161,6 +2161,18 @@ version = "2.3.1" | ||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | ||||
| checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e" | ||||
|  | ||||
| [[package]] | ||||
| name = "pharmacie-desktop" | ||||
| version = "0.1.0" | ||||
| dependencies = [ | ||||
|  "axum", | ||||
|  "clego", | ||||
|  "tauri", | ||||
|  "tauri-build", | ||||
|  "tokio", | ||||
|  "tower", | ||||
| ] | ||||
|  | ||||
| [[package]] | ||||
| name = "phf" | ||||
| version = "0.8.0" | ||||
| @@ -3245,18 +3257,6 @@ dependencies = [ | ||||
|  "walkdir", | ||||
| ] | ||||
|  | ||||
| [[package]] | ||||
| name = "tauri-clego" | ||||
| version = "0.1.0" | ||||
| dependencies = [ | ||||
|  "axum", | ||||
|  "clego", | ||||
|  "tauri", | ||||
|  "tauri-build", | ||||
|  "tokio", | ||||
|  "tower", | ||||
| ] | ||||
|  | ||||
| [[package]] | ||||
| name = "tauri-codegen" | ||||
| version = "2.0.0-beta.19" | ||||
|   | ||||
| @@ -1,12 +1,12 @@ | ||||
| [package] | ||||
| name = "tauri-clego" | ||||
| name = "pharmacie-desktop" | ||||
| version = "0.1.0" | ||||
| description = "Un logiciel de pharmacie libre et open-source." | ||||
| authors = ["p4pillon"] | ||||
| edition = "2021" | ||||
|  | ||||
| [lib] | ||||
| name = "clego_lib" | ||||
| name = "pharmacie_desktop_lib" | ||||
| crate-type = ["lib", "cdylib", "staticlib"] | ||||
|  | ||||
| [build-dependencies] | ||||
|   | ||||
| @@ -2,40 +2,43 @@ use core::panic; | ||||
| use std::sync::Arc; | ||||
|  | ||||
| use tauri::{path::BaseDirectory, Manager}; | ||||
| use tokio::sync::Mutex; | ||||
| use tokio::sync::{Mutex, MutexGuard}; | ||||
| use tower::{Service, ServiceExt}; | ||||
|  | ||||
| async fn process_tauri_request(request: tauri::http::Request<>, router: axum:Router ){ | ||||
| let (parts, body) = request.into_parts(); | ||||
| let body = axum::body::Body::from(body); | ||||
| async fn process_tauri_request( | ||||
|     request: tauri::http::Request<Vec<u8>>, | ||||
|     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, | ||||
|         Err(_error) => panic!("Failed to get ready service"), | ||||
| }; | ||||
|     }; | ||||
|  | ||||
| let response = match response { | ||||
|     let response = match response { | ||||
|         Ok(response) => response, | ||||
|         Err(_error) => panic!("Problem getting response from request."), | ||||
| }; | ||||
|     }; | ||||
|  | ||||
| let (parts, body) = response.into_parts(); | ||||
| let body = match axum::body::to_bytes(body, usize::MAX).await { | ||||
|     let (parts, body) = response.into_parts(); | ||||
|     let body = match axum::body::to_bytes(body, usize::MAX).await { | ||||
|         Ok(bytes) => bytes.to_vec(), | ||||
|         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)] | ||||
| pub fn run() { | ||||
|     tauri::Builder::default() | ||||
|         .setup(|app| { | ||||
|             // Create a router and adds it the the app state | ||||
|              | ||||
|             let resource_path_buf = app | ||||
|                 .path() | ||||
|                 .resolve("assets", BaseDirectory::Resource) | ||||
| @@ -45,6 +48,8 @@ pub fn run() { | ||||
|                 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); | ||||
|  | ||||
|             Ok(()) | ||||
| @@ -53,7 +58,10 @@ pub fn run() { | ||||
|             let router = Arc::clone(&app.state::<Arc<Mutex<axum::Router>>>()); | ||||
|  | ||||
|             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); | ||||
|             }); | ||||
|         }) | ||||
|   | ||||
| @@ -2,5 +2,5 @@ | ||||
| #![cfg_attr(not(debug_assertions), windows_subsystem = "windows")] | ||||
|  | ||||
| fn main() { | ||||
|     clego_lib::run() | ||||
|     pharmacie_desktop_lib::run() | ||||
| } | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| { | ||||
|   "productName": "clego-clean", | ||||
|   "productName": "Logiciel Pharma", | ||||
|   "version": "0.0.1", | ||||
|   "identifier": "clego.pharma.libre", | ||||
|   "identifier": "p4pillon.pharma.desktop", | ||||
|   "build": { | ||||
|     "beforeDevCommand": { | ||||
|         "script": "cargo run",  | ||||
| @@ -14,7 +14,7 @@ | ||||
|     "withGlobalTauri": true, | ||||
|     "windows": [ | ||||
|       { | ||||
|         "title": "clego-clean", | ||||
|         "title": "Logiciel Pharma", | ||||
|         "width": 800, | ||||
|         "height": 600 | ||||
|       } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user