Compare commits
	
		
			13 Commits
		
	
	
		
			wip-debug-
			...
			0e8514d906
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 0e8514d906 | ||
|   | 86a6d2b9d3 | ||
|   | 18758ff2fe | ||
|   | 1f57b70cef | ||
|   | 83cee11e65 | ||
| b1cafda669 | |||
| d370a9b85d | |||
| 83b2f7358d | |||
| 8ef713ccf2 | |||
| 4162e55b83 | |||
| d9cedca335 | |||
| 820d76d0f5 | |||
| 6409e3eedf | 
| @@ -1,3 +0,0 @@ | ||||
| SESAM_FSV_VERSION=1.40.13 | ||||
| SESAM_FSV_LIB_PATH=/opt/santesocial/fsv/${SESAM_FSV_VERSION}/lib | ||||
| SESAM_FSV_SSVLIB=ssvlux64 | ||||
| @@ -1,3 +0,0 @@ | ||||
| SESAM_FSV_VERSION=1.40.13 | ||||
| SESAM_FSV_LIB_PATH="C:/Program Files/santesocial/fsv/${SESAM_FSV_VERSION}/lib" | ||||
| SESAM_FSV_SSVLIB=ssvw64 | ||||
| @@ -1,2 +0,0 @@ | ||||
| SESAM_FSV_VERSION=1.40.13 | ||||
| SESAM_INI_PATH=/etc/opt/santesocial/fsv/${SESAM_FSV_VERSION}/conf/sesam.ini | ||||
| @@ -1,2 +0,0 @@ | ||||
| SESAM_FSV_VERSION=1.40.13 | ||||
| SESAM_INI_PATH=${ALLUSERSPROFILE}\\santesocial\\fsv\\${SESAM_FSV_VERSION}\\conf\\sesam.ini | ||||
							
								
								
									
										27
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,6 +1,23 @@ | ||||
| # Ignore Rust target directory | ||||
| /target | ||||
| # ---> Rust | ||||
| # Generated by Cargo | ||||
| # will have compiled files and executables | ||||
| debug/ | ||||
| target/ | ||||
|  | ||||
| # These are backup files generated by rustfmt | ||||
| **/*.rs.bk | ||||
|  | ||||
| # MSVC Windows builds of rustc generate these, which store debugging information | ||||
| *.pdb | ||||
|  | ||||
| # Editor directories and files | ||||
| .vscode/* | ||||
| !.vscode/extensions.json | ||||
| .idea | ||||
| .DS_Store | ||||
| *.suo | ||||
| *.ntvs* | ||||
| *.njsproj | ||||
| *.sln | ||||
| *.sw? | ||||
|  | ||||
| # Ignore .env files | ||||
| .env | ||||
| .env.build | ||||
							
								
								
									
										4505
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
							
								
								
									
										18
									
								
								Cargo.toml
									
									
									
									
									
								
							
							
						
						| @@ -1,12 +1,6 @@ | ||||
| [package] | ||||
| name = "utils-debug-c-lib" | ||||
| version = "0.1.0" | ||||
| edition = "2021" | ||||
| build = "build.rs" | ||||
|  | ||||
| [dependencies] | ||||
| dotenv = "0.15" | ||||
| libc = "0.2" | ||||
|  | ||||
| [build-dependencies] | ||||
| dotenv = "0.15" | ||||
| [workspace] | ||||
| resolver = "2" | ||||
| members = [ | ||||
|     "crates/clego", | ||||
|     "crates/tauri" | ||||
| ] | ||||
|   | ||||
							
								
								
									
										56
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -1,46 +1,34 @@ | ||||
| ## Requirements | ||||
| # Krys4lide | ||||
|  | ||||
| - Installer le [package FSV](https://industriels.sesam-vitale.fr/group/fournitures-sesam-vitale) | ||||
|     - Les librairies dynamiques (.lib, .dll, ...) fournies ne sont pas installés dans les emplacements standard du système, il faudra donc configurer leur chemin d'installation dans le fichier de configuration `.env.build` (voir ci-dessous) | ||||
|         - Le détail des chemins d'installation est donné dans la documentation du package FSV `fsv-mi-004_pack-FSV1.40.14_V2.3.pdf` | ||||
|             - Linux - par défaut : `/opt/santesocial/fsv/1.40.13/lib` | ||||
|             - Windows - par défaut : `C:\Program Files\santesocial\santesocial\fsv\1.40.14\lib` (ou dans Program Files (x86) si c'est le package 32bits qui a été installé) | ||||
| Logiciel de Pharmacie libre et open-source. | ||||
|  | ||||
| - Installer la [CryptolibCPS](https://industriels.sesam-vitale.fr/group/galss-cryptolib-cps) | ||||
|     - Ce package fourni également l'utilitaire "CPS Gestion" pour obtenir des informations sur le lecteur de carte, etc. | ||||
|         - Linux : `cpgeslux` | ||||
|         - Windows : `...` | ||||
| ## Crates | ||||
|  | ||||
| ## Setup | ||||
| - `clego`: Axum backend lib for tauri client. Can be used as a lib or started as a web server. | ||||
| - `tauri`: Tauri app for desktop client. | ||||
|  | ||||
| - Créer et éditer le fichier de configuration de build `.env.build` en s'inspirant d'un des fichiers d'exemple (`.env.build.linux.example`, `.env.build.win.example`...) | ||||
|     - Ce fichier est nécessaire pour le build du package Rust | ||||
| - Créer et éditer le fichier de configuration de l'exécution `.env` en s'inspirant d'un des fichiers d'exemple (`.env.linux.example`, `.env.win.example`...) | ||||
|     - Ce fichier est nécessaire pour l'exécution du package Rust compilé, et doit donc être présent aux côtés de l'exécutable généré, le cas échéant | ||||
| ## Development | ||||
|  | ||||
| ## Build | ||||
| Install | ||||
|  | ||||
| ### Compilation C | ||||
| ```bash | ||||
| cargo install tauri-cli | ||||
| ``` | ||||
|  | ||||
| Ce package s'appuie sur deux librairies : | ||||
| - Une librairie statique, compilée à partir des sources (`*.c`, `*.h`) fournies dans le dossier `./src` | ||||
| - Une librairie dynamique, fournie par le package FSV | ||||
|     - Windows : on fournit les headers, non présents dans la `.dll` en compilant les fichiers `src/*.def` en leur version binaire `lib/*.lib` | ||||
| Run desktop client app | ||||
|  | ||||
| Pour compiler les fichiers de librairie : | ||||
| ```bash | ||||
| cargo tauri dev | ||||
| ``` | ||||
|  | ||||
| - Windows : `.\make.bat` | ||||
| - Linux : `make` | ||||
| Run clego endpoint | ||||
|  | ||||
| Pour nettoyer le dossier `./lib` : | ||||
| ```bash | ||||
| cargo run --bin clego | ||||
| ``` | ||||
|  | ||||
| - Windows : `.\make.bat /clean` | ||||
| - Linux : `make clean` | ||||
| Bundle desktop client app | ||||
|  | ||||
| ### Compilation Rust | ||||
|  | ||||
| `cargo build` | ||||
|  | ||||
| ## Run | ||||
|  | ||||
| `cargo run` | ||||
| ```bash | ||||
| cargo tauri build | ||||
| ``` | ||||
|   | ||||
							
								
								
									
										26
									
								
								build.rs
									
									
									
									
									
								
							
							
						
						| @@ -1,26 +0,0 @@ | ||||
| extern crate dotenv; | ||||
|  | ||||
| use std::env; | ||||
| use std::path::PathBuf; | ||||
|  | ||||
| fn main() { | ||||
|     dotenv::from_filename(".env.build").ok(); | ||||
|     println!("cargo::rerun-if-changed=.env.build"); | ||||
|  | ||||
|     let manifest_dir = env::var("CARGO_MANIFEST_DIR").unwrap(); | ||||
|  | ||||
|     let static_lib_path = PathBuf::from(manifest_dir).join("lib"); | ||||
|     println!("cargo::rustc-link-search=native={}", static_lib_path.display()); | ||||
|     println!("cargo::rustc-link-lib=static=p4pillondebuglib"); | ||||
|  | ||||
|     let fsv_lib_path = PathBuf::from(env::var("SESAM_FSV_LIB_PATH").unwrap()); | ||||
|     println!("cargo::rustc-link-search=native={}", fsv_lib_path.display()); | ||||
|     println!("cargo::rustc-link-lib=dylib={}", env::var("SESAM_FSV_SSVLIB").unwrap()); | ||||
|  | ||||
|     if cfg!(target_os = "windows") { | ||||
|         let path = env::var("PATH").unwrap_or(String::new()); | ||||
|         println!("cargo:rustc-env=PATH={};{}", fsv_lib_path.display(), path); | ||||
|     } else if cfg!(target_os = "linux") { | ||||
|         println!("cargo:rustc-env=LD_LIBRARY_PATH={}", fsv_lib_path.display()); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										1
									
								
								crates/clego/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| /target | ||||
							
								
								
									
										12
									
								
								crates/clego/Cargo.toml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,12 @@ | ||||
| [package] | ||||
| name = "clego" | ||||
| version = "0.1.0" | ||||
| edition = "2021" | ||||
|  | ||||
| [dependencies] | ||||
| askama = "0.12.1" | ||||
| askama_axum = "0.4.0" | ||||
| axum = "0.7.5" | ||||
| tokio = { version = "1.39.1", features = ["macros", "rt-multi-thread"] } | ||||
| tower-http = { version = "0.5.2", features = ["fs"] } | ||||
|  | ||||
							
								
								
									
										1
									
								
								crates/clego/assets/js/htmx.min.js.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										27
									
								
								crates/clego/src/lib.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,27 @@ | ||||
| mod templates; | ||||
|  | ||||
| use std::path::Path; | ||||
|  | ||||
| use askama_axum::IntoResponse; | ||||
| use templates::{hello::HelloResponse, index::GetIndexResponse}; | ||||
| use tower_http::services::ServeDir; | ||||
|  | ||||
| async fn root() -> impl IntoResponse { | ||||
|     return GetIndexResponse {}.into_response(); | ||||
| } | ||||
|  | ||||
| async fn hello() -> impl IntoResponse { | ||||
|     return HelloResponse { | ||||
|         name: "Theo".to_string(), | ||||
|     } | ||||
|     .into_response(); | ||||
| } | ||||
|  | ||||
| pub fn get_router(assets_path: &Path) -> axum::Router { | ||||
|     let router = axum::Router::new() | ||||
|         .nest_service("/assets", ServeDir::new(assets_path)) | ||||
|         .route("/", axum::routing::get(root)) | ||||
|         .route("/hello", axum::routing::get(hello)); | ||||
|  | ||||
|     router | ||||
| } | ||||
							
								
								
									
										11
									
								
								crates/clego/src/main.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,11 @@ | ||||
| use ::clego::get_router; | ||||
| use std::path::Path; | ||||
|  | ||||
| #[tokio::main] | ||||
| async fn main() { | ||||
|     let router = get_router(Path::new("/assets")); | ||||
|  | ||||
|     // TODO: select port based on available port (or ask in CLI) | ||||
|     let listener = tokio::net::TcpListener::bind("0.0.0.0:3000").await.unwrap(); | ||||
|     axum::serve(listener, router).await.unwrap(); | ||||
| } | ||||
							
								
								
									
										7
									
								
								crates/clego/src/templates/hello.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,7 @@ | ||||
| use askama::Template; | ||||
|  | ||||
| #[derive(Template)] | ||||
| #[template(path = "hello.html")] | ||||
| pub struct HelloResponse { | ||||
|     pub name: String, | ||||
| } | ||||
							
								
								
									
										5
									
								
								crates/clego/src/templates/index.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,5 @@ | ||||
| use askama::Template; | ||||
|  | ||||
| #[derive(Template)] | ||||
| #[template(path = "index.html")] | ||||
| pub struct GetIndexResponse; | ||||
							
								
								
									
										2
									
								
								crates/clego/src/templates/mod.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,2 @@ | ||||
| pub mod index; | ||||
| pub mod hello; | ||||
							
								
								
									
										13
									
								
								crates/clego/templates/base.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,13 @@ | ||||
| <!doctype html> | ||||
| <html lang="en"> | ||||
|   <head> | ||||
|     <title>{% block title %}{{ title }}{% endblock %}</title> | ||||
|  | ||||
|     <script src="/assets/js/htmx.min.js.js"></script> | ||||
|  | ||||
|     {% block head %}{% endblock %} | ||||
|   </head> | ||||
|   <body> | ||||
|     {% block body %}{% endblock %} | ||||
|   </body> | ||||
| </html> | ||||
							
								
								
									
										1
									
								
								crates/clego/templates/hello.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| <div>Hello {{name}}!</div> | ||||
							
								
								
									
										23
									
								
								crates/clego/templates/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,23 @@ | ||||
| {% extends "base.html" %} | ||||
|   | ||||
| {% block title %}Phrama Libre{% endblock %} | ||||
|   | ||||
| {% block body %} | ||||
|  | ||||
| <div> | ||||
|   <header> | ||||
|     <h1>Pharma Libre</h1> | ||||
|   </header> | ||||
|   <main> | ||||
|     <div | ||||
|       id="hello" | ||||
|       hx-get="/hello" | ||||
|       hx-target="this" | ||||
|       hx-trigger="load" | ||||
|       hx-swap="outerHTML" | ||||
|     > | ||||
|       Loading... | ||||
|     </div> | ||||
|   </main> | ||||
| </div> | ||||
| {% endblock %} | ||||
							
								
								
									
										7
									
								
								crates/tauri/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,7 @@ | ||||
| # Generated by Cargo | ||||
| # will have compiled files and executables | ||||
| /target/ | ||||
|  | ||||
| # Generated by Tauri | ||||
| # will have schema files for capabilities auto-completion | ||||
| /gen/schemas | ||||
							
								
								
									
										22
									
								
								crates/tauri/Cargo.toml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,22 @@ | ||||
| [package] | ||||
| name = "tauri-clego" | ||||
| version = "0.1.0" | ||||
| description = "Un logiciel de pharmacie libre et open-source." | ||||
| authors = ["p4pillon"] | ||||
| edition = "2021" | ||||
|  | ||||
| [lib] | ||||
| name = "clego_lib" | ||||
| crate-type = ["lib", "cdylib", "staticlib"] | ||||
|  | ||||
| [build-dependencies] | ||||
| tauri-build = { version = "2.0.0-beta", features = [] } | ||||
|  | ||||
| [dependencies] | ||||
| axum = "0.7.5" | ||||
| tauri = { version = "2.0.0-beta", features = ["devtools"] } | ||||
| tower = "0.4.13" | ||||
|  | ||||
| clego = { path = "../clego" } | ||||
| tokio = "1.39.1" | ||||
|  | ||||
							
								
								
									
										3
									
								
								crates/tauri/build.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,3 @@ | ||||
| fn main() { | ||||
|     tauri_build::build() | ||||
| } | ||||
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/128x128.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.4 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/128x128@2x.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/32x32.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 974 B | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/Square107x107Logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/Square142x142Logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/Square150x150Logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.9 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/Square284x284Logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 7.6 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/Square30x30Logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 903 B | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/Square310x310Logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 8.4 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/Square44x44Logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.3 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/Square71x71Logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.0 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/Square89x89Logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 2.4 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/StoreLogo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.5 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/icon.icns
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/icon.ico
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 85 KiB | 
							
								
								
									
										
											BIN
										
									
								
								crates/tauri/icons/icon.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 14 KiB | 
							
								
								
									
										62
									
								
								crates/tauri/src/lib.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,62 @@ | ||||
| use core::panic; | ||||
| use std::sync::Arc; | ||||
|  | ||||
| use tauri::{path::BaseDirectory, Manager}; | ||||
| use tokio::sync::Mutex; | ||||
| 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); | ||||
|  | ||||
| let request = axum::extract::Request::from_parts(parts, body); | ||||
|  | ||||
| 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 { | ||||
|     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 { | ||||
|     Ok(bytes) => bytes.to_vec(), | ||||
|     Err(_error) => panic!("Problem converting response body to bytes."), | ||||
| }; | ||||
|  | ||||
| let response = tauri::http::Response::from_parts(parts, body); | ||||
| } | ||||
|  | ||||
| #[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) | ||||
|                 .expect("Path should be resolvable"); | ||||
|  | ||||
|             let router = Arc::new(Mutex::new( | ||||
|                 clego::get_router(resource_path_buf.as_path()).clone(), | ||||
|             )); | ||||
|  | ||||
|             app.manage(router); | ||||
|  | ||||
|             Ok(()) | ||||
|         }) | ||||
|         .register_asynchronous_uri_scheme_protocol("axum", move |app, request, responder| { | ||||
|             let router = Arc::clone(&app.state::<Arc<Mutex<axum::Router>>>()); | ||||
|  | ||||
|             tauri::async_runtime::spawn(async move { | ||||
|                 let mut router = router.lock().await; | ||||
|                 responder.respond(response); | ||||
|             }); | ||||
|         }) | ||||
|         .run(tauri::generate_context!()) | ||||
|         .expect("error while running tauri application"); | ||||
| } | ||||
							
								
								
									
										6
									
								
								crates/tauri/src/main.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,6 @@ | ||||
| // Prevents additional console window on Windows in release, DO NOT REMOVE!! | ||||
| #![cfg_attr(not(debug_assertions), windows_subsystem = "windows")] | ||||
|  | ||||
| fn main() { | ||||
|     clego_lib::run() | ||||
| } | ||||
							
								
								
									
										41
									
								
								crates/tauri/tauri.conf.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,41 @@ | ||||
| { | ||||
|   "productName": "clego-clean", | ||||
|   "version": "0.0.1", | ||||
|   "identifier": "clego.pharma.libre", | ||||
|   "build": { | ||||
|     "beforeDevCommand": { | ||||
|         "script": "cargo run",  | ||||
|         "cwd": "../clego" | ||||
|     }, | ||||
|     "devUrl": "http://localhost:3000", | ||||
|     "frontendDist": "axum://place.holder/" | ||||
|   }, | ||||
|   "app": { | ||||
|     "withGlobalTauri": true, | ||||
|     "windows": [ | ||||
|       { | ||||
|         "title": "clego-clean", | ||||
|         "width": 800, | ||||
|         "height": 600 | ||||
|       } | ||||
|     ], | ||||
|     "security": { | ||||
|       "csp": null | ||||
|     } | ||||
|   }, | ||||
|   "bundle": { | ||||
|     "active": true, | ||||
|     "resources": { | ||||
|         "../clego/assets/": "./assets/" | ||||
|     }, | ||||
|     "targets": "all", | ||||
|     "icon": [ | ||||
|       "icons/32x32.png", | ||||
|       "icons/128x128.png", | ||||
|       "icons/128x128@2x.png", | ||||
|       "icons/icon.icns", | ||||
|       "icons/icon.ico" | ||||
|     ] | ||||
|   } | ||||
|                  | ||||
| } | ||||
							
								
								
									
										
											BIN
										
									
								
								lib/ssvw64.exp
									
									
									
									
									
								
							
							
						
						
							
								
								
									
										
											BIN
										
									
								
								lib/ssvw64.lib
									
									
									
									
									
								
							
							
						
						
							
								
								
									
										36
									
								
								make.bat
									
									
									
									
									
								
							
							
						
						| @@ -1,36 +0,0 @@ | ||||
| @echo off | ||||
| rem Set variables | ||||
| set SRC_DIR=src | ||||
| set LIB_DIR=lib | ||||
|  | ||||
| rem Create the %LIB_DIR% directory if it does not exist | ||||
| if not exist %LIB_DIR% mkdir %LIB_DIR% | ||||
|  | ||||
| if "%1"=="/clean" ( | ||||
|     goto clean | ||||
| ) | ||||
|  | ||||
| rem Configure the environment for Visual Studio | ||||
| call "C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build\vcvarsall.bat" x64 | ||||
|  | ||||
| rem Build %SRC_DIR%\*.c files | ||||
| cl /c /Fd:%LIB_DIR%\ /Fo:%LIB_DIR%\ /Iinclude\ /I%SRC_DIR%\ %SRC_DIR%\*.c | ||||
|  | ||||
| rem Link the object files into a static library | ||||
| lib %LIB_DIR%\*.obj | ||||
|  | ||||
| rem Create a ssvw64.lib file from a ssvw64.def file | ||||
| lib /def:%SRC_DIR%\ssvw64.def /out:%LIB_DIR%\ssvw64.lib /machine:x64 | ||||
|  | ||||
| rem Build complete | ||||
| pause | ||||
| exit /b 0 | ||||
|  | ||||
| :clean | ||||
| del %LIB_DIR%\*.obj | ||||
| del %LIB_DIR%\*.lib | ||||
| del %LIB_DIR%\*.exp | ||||
|  | ||||
| rem Clean complete | ||||
| pause | ||||
| exit /b 0 | ||||
							
								
								
									
										32
									
								
								makefile
									
									
									
									
									
								
							
							
						
						| @@ -1,32 +0,0 @@ | ||||
| # Detect the operating system | ||||
| ifeq ($(OS),Windows_NT) | ||||
|     MKDIR = if not exist $(LIB_DIR) mkdir $(LIB_DIR) | ||||
|     RM = del | ||||
| else | ||||
|     MKDIR = mkdir -p $(LIB_DIR) | ||||
|     RM = rm -f | ||||
| endif | ||||
|  | ||||
| CC = gcc | ||||
| AR = ar | ||||
| CFLAGS = -Wall -fPIC | ||||
| SRC_DIR = src | ||||
| LIB_DIR = lib | ||||
| SRC_FILES = $(wildcard $(SRC_DIR)/*.c) | ||||
| OBJ_FILES = $(SRC_FILES:$(SRC_DIR)/%.c=$(LIB_DIR)/%.o) | ||||
| STATIC_LIB = $(LIB_DIR)/libp4pillondebuglib.a | ||||
|  | ||||
| all: $(STATIC_LIB) | ||||
|  | ||||
| $(STATIC_LIB): $(OBJ_FILES) | ||||
| 	$(MKDIR) | ||||
| 	$(AR) rcs $@ $^ | ||||
|  | ||||
| $(LIB_DIR)/%.o: $(SRC_DIR)/%.c | ||||
| 	$(MKDIR) | ||||
| 	$(CC) $(CFLAGS) -c $< -o $@ | ||||
|  | ||||
| clean: | ||||
| 	$(RM) $(OBJ_FILES) $(STATIC_LIB) | ||||
|  | ||||
| .PHONY: all clean | ||||
							
								
								
									
										0
									
								
								scripts/.gitkeep
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -1,7 +0,0 @@ | ||||
| mod p4pillondebuglib_demo; | ||||
| mod ssvlib_demo; | ||||
|  | ||||
| fn main() { | ||||
|     p4pillondebuglib_demo::demo(); | ||||
|     ssvlib_demo::demo(); | ||||
| } | ||||
| @@ -1,57 +0,0 @@ | ||||
| // mylib.c | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
|  | ||||
| char* hello() { | ||||
|     return "Hello, World!"; | ||||
| } | ||||
|  | ||||
| char* helloName(const char *name) { | ||||
|     char *result = (char *)malloc(strlen(name) + 9); | ||||
|     if (result) { | ||||
|         sprintf(result, "Hello, %s!", name); | ||||
|     } | ||||
|     return result; | ||||
| } | ||||
|  | ||||
| void helloPtr(char *result) { | ||||
|     sprintf(result, "Hello, World!"); | ||||
| } | ||||
|  | ||||
| void helloPtrPtr(char **result, size_t *size) { | ||||
|     const char *message = "Hello, World!"; | ||||
|     *size = strlen(message) + 1; // +1 for null terminator | ||||
|     *result = (char *)malloc(*size); | ||||
|     if (*result) { | ||||
|         strcpy(*result, message); | ||||
|     } | ||||
| } | ||||
|  | ||||
| void helloVoidPtrPtr(void **result, size_t *size) { | ||||
|     const char *message = "Hello, World!"; | ||||
|     *size = strlen(message) + 1; // +1 for null terminator | ||||
|     *result = malloc(*size); | ||||
|     if (*result != NULL) { | ||||
|         strcpy((char *)*result, message); | ||||
|     } | ||||
| } | ||||
|  | ||||
| int add(int a, int b) { | ||||
|     return a + b; | ||||
| } | ||||
|  | ||||
| // Add function returning result in a pointer | ||||
| void addPtr(int a, int b, int *result) { | ||||
|     *result = a + b; | ||||
| } | ||||
|  | ||||
| void fillHexValues(void **result, size_t *size) { | ||||
|     unsigned char values[5] = {0x05, 0xE7, 0x02, 0x00, 0x00}; | ||||
|  | ||||
|     *size = sizeof(values); | ||||
|     *result = malloc(*size); | ||||
|     if (*result != NULL) { | ||||
|         memcpy(*result, values, *size); | ||||
|     } | ||||
| } | ||||
| @@ -1,15 +0,0 @@ | ||||
| #ifndef P4PILLONDEBUGLIB_H | ||||
| #define P4PILLONDEBUGLIB_H | ||||
|  | ||||
| #include <stddef.h> | ||||
|  | ||||
| char* hello(); | ||||
| char* helloName(const char *name); | ||||
| void helloPtr(char *result); | ||||
| void helloPtrPtr(char **result, size_t *size); | ||||
| void helloVoidPtrPtr(void **result, size_t *size); | ||||
| int add(int a, int b); | ||||
| void addPtr(int a, int b, int *result); | ||||
| void fillHexValues(void **result, size_t *size); | ||||
|  | ||||
| #endif // P4PILLONDEBUGLIB_H | ||||
| @@ -1,101 +0,0 @@ | ||||
| extern crate libc; | ||||
|  | ||||
| use libc::{ c_char, c_int, c_void, size_t }; | ||||
| use std::ffi::{ CStr, CString }; | ||||
| use std::ptr; | ||||
|  | ||||
| #[link(name = "p4pillondebuglib")] | ||||
| extern "C" { | ||||
|     fn hello() -> *const c_char; | ||||
|     fn helloName(name: *const c_char) -> *const c_char; | ||||
|     fn helloPtr(result: *mut c_char); | ||||
|     fn helloPtrPtr(result: *mut *mut c_char, size: *mut size_t); | ||||
|     fn helloVoidPtrPtr(result: *mut *mut c_void, size: *mut size_t); | ||||
|     fn add(a: c_int, b: c_int) -> c_int; | ||||
|     fn addPtr(a: c_int, b: c_int, result: *mut c_int); | ||||
|     fn fillHexValues(result: *mut *mut c_void, size: *mut size_t); | ||||
| } | ||||
|  | ||||
| pub fn demo() { | ||||
|     println!("------- Demo for the P4PillonDebugLib ---"); | ||||
|      | ||||
|     unsafe { | ||||
|         let c_str = hello(); | ||||
|         let r_str: &str = CStr::from_ptr(c_str).to_str().unwrap(); | ||||
|         println!("{} from C", r_str); | ||||
|     } | ||||
|  | ||||
|     let name = CString::new("John").expect("CString::new failed"); | ||||
|     unsafe { | ||||
|         let c_str = helloName(name.as_ptr()); | ||||
|         let r_str = CStr::from_ptr(c_str).to_str().expect("Conversion failed"); | ||||
|         println!("{} from C with name", r_str); | ||||
|  | ||||
|         libc::free(c_str as *mut c_void); | ||||
|     } | ||||
|  | ||||
|     let mut buffer: [c_char; 50] = [0; 50]; | ||||
|     unsafe { | ||||
|         helloPtr(buffer.as_mut_ptr()); | ||||
|         let c_str = CStr::from_ptr(buffer.as_ptr()); | ||||
|         let r_str = c_str.to_str().unwrap(); | ||||
|         println!("{} from C Ptr", r_str); | ||||
|     } | ||||
|  | ||||
|     let mut buffer: *mut c_char = ptr::null_mut(); | ||||
|     let mut size: size_t = 0; | ||||
|     unsafe { | ||||
|         helloPtrPtr(&mut buffer, &mut size); | ||||
|          | ||||
|         if !buffer.is_null() { | ||||
|             let c_str = CStr::from_ptr(buffer); | ||||
|             let r_str = c_str.to_str().unwrap(); | ||||
|             println!("{} from C Ptr Ptr (size: {})", r_str, size); | ||||
|  | ||||
|             libc::free(buffer as *mut c_void); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     let mut buffer: *mut c_void = ptr::null_mut(); | ||||
|     let mut size: size_t = 0; | ||||
|     unsafe { | ||||
|         helloVoidPtrPtr(&mut buffer, &mut size); | ||||
|          | ||||
|         if !buffer.is_null() { | ||||
|             let c_str = CStr::from_ptr(buffer as *const c_char); | ||||
|             let r_str = c_str.to_str().unwrap(); | ||||
|             println!("{} from C Void Ptr Ptr (size: {})", r_str, size); | ||||
|  | ||||
|             libc::free(buffer); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     unsafe { | ||||
|         let result = add(1, 2); | ||||
|         println!("Result of 1 + 2 = {}", result); | ||||
|     } | ||||
|  | ||||
|     unsafe { | ||||
|         let mut result = 0; | ||||
|         addPtr(1, 2, &mut result); | ||||
|         println!("Result Ptr of 1 + 2 = {}", result); | ||||
|     } | ||||
|  | ||||
|     let mut buffer: *mut c_void = ptr::null_mut(); | ||||
|     let mut size: size_t = 0; | ||||
|     unsafe { | ||||
|         fillHexValues(&mut buffer, &mut size); | ||||
|          | ||||
|         if !buffer.is_null() { | ||||
|             let hex_values = std::slice::from_raw_parts(buffer as *const u8, size); | ||||
|             for &byte in hex_values { | ||||
|                 print!("{:02X} ", byte); | ||||
|             } | ||||
|             println!(); | ||||
|  | ||||
|             libc::free(buffer); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     println!("-----------------------------------------"); | ||||
| } | ||||
| @@ -1,84 +0,0 @@ | ||||
| extern crate libc; | ||||
| extern crate dotenv; | ||||
|  | ||||
| use libc::{ c_char, c_void, c_ushort, size_t }; | ||||
| use std::ffi::CString; | ||||
| use std::ptr; | ||||
|  | ||||
| use dotenv::dotenv; | ||||
| use std::env; | ||||
|  | ||||
| extern "C" { | ||||
|     fn SSV_InitLIB2(pcRepSesamIni: *const c_char) -> c_ushort; | ||||
|     fn SSV_LireCartePS(NomRessourcePS: *const c_char, NomRessourceLecteur: *const c_char, CodePorteurPS: *const c_char, ZDonneesSortie: *mut *mut c_void, TTailleDonneesSortie: *mut size_t) -> c_ushort; | ||||
|     fn SSV_LireConfig(ZDonneesSortie: *mut *mut c_void, TTailleDonneesSortie: *mut size_t) -> c_ushort; | ||||
| } | ||||
|  | ||||
| fn ssv_init_lib_2() { | ||||
|     let ini_str = env::var("SESAM_INI_PATH").expect("SESAM_INI_PATH must be set"); | ||||
|     let ini = CString::new(ini_str).expect("CString::new failed"); | ||||
|     unsafe { | ||||
|         let result = SSV_InitLIB2(ini.as_ptr()); | ||||
|         println!("SSV_InitLIB2 result: {}", result); | ||||
|     } | ||||
| } | ||||
|  | ||||
| fn ssv_lire_carte_ps() { | ||||
|     let resource_ps = CString::new("PS").expect("CString::new failed"); | ||||
|     let resource_reader = CString::new("TRANSPA1").expect("CString::new failed"); | ||||
|     let card_number = CString::new("1234567890").expect("CString::new failed"); | ||||
|  | ||||
|     let mut buffer: *mut c_void = ptr::null_mut(); | ||||
|     let mut size: size_t = 0; | ||||
|     unsafe { | ||||
|         let result = SSV_LireCartePS( | ||||
|             resource_ps.as_ptr(), | ||||
|             resource_reader.as_ptr(), | ||||
|             card_number.as_ptr(), | ||||
|             &mut buffer, | ||||
|             &mut size | ||||
|         ); | ||||
|         println!("SSV_LireCartePS result: {}", result); | ||||
|  | ||||
|         if !buffer.is_null() { | ||||
|             let hex_values = std::slice::from_raw_parts(buffer as *const u8, size); | ||||
|             for &byte in hex_values { | ||||
|                 print!("{:02X} ", byte); | ||||
|             } | ||||
|             println!(); | ||||
|  | ||||
|             libc::free(buffer); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| fn ssv_lire_config() { | ||||
|     let mut buffer: *mut c_void = ptr::null_mut(); | ||||
|     let mut size: size_t = 0; | ||||
|     unsafe { | ||||
|         let result = SSV_LireConfig(&mut buffer, &mut size); | ||||
|         println!("SSV_LireConfig result: {}", result); | ||||
|  | ||||
|         if !buffer.is_null() { | ||||
|             let hex_values = std::slice::from_raw_parts(buffer as *const u8, size); | ||||
|             for &byte in hex_values { | ||||
|                 print!("{:02X} ", byte); | ||||
|             } | ||||
|             println!(); | ||||
|  | ||||
|             libc::free(buffer); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| pub fn demo() { | ||||
|     dotenv().ok(); | ||||
|  | ||||
|     println!("------- Demo for the SSV library --------"); | ||||
|  | ||||
|     ssv_init_lib_2(); | ||||
|     ssv_lire_carte_ps(); | ||||
|     ssv_lire_config(); | ||||
|  | ||||
|     println!("-----------------------------------------"); | ||||
| } | ||||
| @@ -1,5 +0,0 @@ | ||||
| LIBRARY "ssvw64" | ||||
| EXPORTS | ||||
|     SSV_InitLIB2 | ||||
|     SSV_LireCartePS | ||||
|     SSV_LireConfig | ||||