Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andogq/qubit
Seamless RPC for Rust & TypeScript
https://github.com/andogq/qubit
api jsonrpc portfolio rpc-framework rust serde subscriptions trpc trpc-rs ts ts-rs
Last synced: 3 months ago
JSON representation
Seamless RPC for Rust & TypeScript
- Host: GitHub
- URL: https://github.com/andogq/qubit
- Owner: andogq
- License: mit
- Created: 2024-01-29T11:32:29.000Z (12 months ago)
- Default Branch: main
- Last Pushed: 2024-06-06T13:23:49.000Z (8 months ago)
- Last Synced: 2024-06-06T15:13:09.646Z (8 months ago)
- Topics: api, jsonrpc, portfolio, rpc-framework, rust, serde, subscriptions, trpc, trpc-rs, ts, ts-rs
- Language: Rust
- Homepage:
- Size: 481 KB
- Stars: 6
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
Tired of wrestling with RPC boilerplate? Qubit simplifies communication between your Rust services
and TypeScript clients, offering a type-safe and feature-rich development experience, so you can
focus on building amazing applications.## Features:
- **Generated Type-Safe Clients**: Say goodbye to manual type definitions, Qubit automatically
generates TypeScript clients based on your Rust API, ensuring a smooth development experience.- **Subscriptions**: Build real-time, data-driven applications with subscriptions, allowing for
your Rust server to push data directly to connected TypeScript clients.- **Build Modular APIs**: Organise your API handlers into nested routers, ensuring simplicity and
maintainability as your service grows.- **Serde Compatibility**: Leverage Serde for seamless data serialisation and deserialisation
between Rust and TypeScript.- **Built on JSONRPC 2.0**: Need a non-TypeScript client? Use any JSONRPC client in any language
over WebSockets or HTTP.- **Proven Base**: Built on established libraries like
[`ts-rs`](https://github.com/Aleph-Alpha/ts-rs) for type generation and
[`jsonrpsee`](https://github.com/paritytech/jsonrpsee) as the JSONRPC implementation.## Getting Started
1. Add the required dependencies
```toml
# Cargo.toml
[dependencies]
qubit = "0.6.1"ts-rs = "8.1.0" # Required to generate TS types
serde = { version = "1.0", features = ["derive"] } # Required for serialisable types
futures = "0.3.30" # Required for streaming functionalitytokio = { version = "1.38", features = ["full"] }
axum = "0.7"
hyper = { version = "1.0", features = ["server"] }
``````bash
pnpm i @qubit-rs/client@latest
```2. Setup a Qubit router, and save the generated types
```rs
#[handler(query)]
async fn hello_world() -> String {
"Hello, world!".to_string()
}let router = Router::new()
.handler(hello_world);router.write_bindings_to_dir("./bindings");
```3. Attach the Qubit router to an Axum router, and start it
```rs
// Create a service and handle
let (qubit_service, qubit_handle) = router.to_service(());// Nest into an Axum router
let axum_router = axum::Router::<()>::new()
.nest_service("/rpc", qubit_service);// Start a Hyper server
axum::serve(
tokio::net::TcpListener::bind(&SocketAddr::from(([127, 0, 0, 1], 9944)))
.await
.unwrap(),
axum_router,
)
.await
.unwrap();qubit_handle.stop().unwrap();
```4. Make requests from the TypeScript client
```ts
// Import transport from client, and generated server type
import { build_client, http } from "@qubit-rs/client";
import type { QubitServer } from "./bindings";// Connect with the API
const api = build_client(http("http://localhost:9944/rpc"));// Call the handlers
const message = await api.hello_world.query();
console.log("received from server:", message);
```## Examples
Checkout all the examples in the [`examples`](./examples) directory.
## FAQs
### Qubit?
The term "Qubit" refers to the fundamental unit of quantum information. Just as a qubit can exist
in a superposition of states, Qubit bridges the gap between Rust and TypeScript, empowering
developers to create truly exceptional applications.## Prior Art
- [`rspc`](https://github.com/oscartbeaumont/rspc): Similar concept, however uses a bespoke
solution for generating TypeScript types from Rust structs, which isn't completely compatible with
all of Serde's features for serialising and deserialising structs.- [`trpc`](https://github.com/trpc/trpc): Needs no introduction, however it being restricted to
TypeScript backends makes it relatively useless for Rust developers.