17 releases (5 breaking)
new 0.6.3 | Dec 3, 2024 |
---|---|
0.6.2 | Dec 1, 2024 |
0.5.5 | Dec 1, 2024 |
0.4.1 | Nov 30, 2024 |
0.1.0 | Nov 26, 2024 |
#201 in Embedded development
615 downloads per month
50KB
878 lines
embedded-jsonrpc
A JSON-RPC 2.0 server implementation for embedded systems.
lib.rs
:
JSON-RPC for Embedded Systems
This crate provides a JSON-RPC server implementation for embedded systems.
Features
#![no_std]
Support: Fully compatible with environments lacking a standard library.- Predictable Memory Usage: Zero dynamic allocation with statically sized buffers.
- Async: Non-blocking I/O with
embedded-io-async
. - Client Compatibility: Uses LSP style framing for JSON-RPC messages.
- Error Handling: Adheres to JSON-RPC standards with robust error reporting.
Example Usage
Create an RPC Server
use embedded_jsonrpc::{RpcError, RpcResponse, RpcServer, RpcHandler, JSONRPC_VERSION, DEFAULT_STACK_SIZE};
use embedded_jsonrpc::stackfuture::StackFuture;
struct MyHandler;
impl RpcHandler for MyHandler {
fn handle<'a>(&self, id: Option<u64>, _method: &'a str, _request_json: &'a [u8], response_json: &'a mut [u8]) -> StackFuture<'a, Result<usize, RpcError>, DEFAULT_STACK_SIZE> {
StackFuture::from(async move {
let response: RpcResponse<'static, ()> = RpcResponse {
jsonrpc: JSONRPC_VERSION,
error: None,
result: None,
id,
};
Ok(serde_json_core::to_slice(&response, response_json).unwrap())
})
}
}
let mut server: RpcServer<'_> = RpcServer::new();
server.register_method("echo", &MyHandler);
Serve Requests
let mut stream: YourAsyncStream = YourAsyncStream::new();
server.serve(&mut stream).await.unwrap();
License
This crate is licensed under the Mozilla Public License 2.0 (MPL-2.0). See the LICENSE file for more details.
References
Dependencies
~2.2–3MB
~62K SLoC