Crates.io | ripsy |
lib.rs | ripsy |
version | 0.1.0 |
source | src |
created_at | 2023-09-07 23:05:17.769726 |
updated_at | 2023-09-07 23:05:17.769726 |
description | RPC between Server/Client written in Rust |
homepage | |
repository | https://github.com/hamza1311/ripsy |
max_upload_size | |
id | 966689 |
size | 22,207 |
RPC between Server/Client written in Rust
RRPC (Rust Remote Procedure Call) is pronounced as ripsy, thus the name of this crate.
client/main.rs
use shared::add;
#[tokio::main]
async fn main() {
ripsy::client::init("http://localhost:3000");
let r: Result<String, String> = add(2).await.unwrap();
println!("{r:?}"); // Ok("2")
}
server/main.rs
use axum::routing::post;
use ripsy::Bincode;
use shared::add;
#[tokio::main]
async fn main() {
let app = ripsy::ripsy!(add,);
axum::Server::bind(&"0.0.0.0:3000".parse().unwrap())
.serve(app.into_make_service())
.await
.unwrap();
}
shared/lib.rs
use ripsy::endpoint;
#[endpoint(mutation)]
pub async fn add(n: u32) -> Result<String, String> {
if false {
work()?; // ? works fine
}
Ok(n.to_string())
}
fn work() -> Result<(), String> { Err("err".to_string()) }