An open API service indexing awesome lists of open source software.

https://github.com/sile/jsonlrpc

A JSON-RPC 2.0 library that streams JSON objects in JSON Lines format.
https://github.com/sile/jsonlrpc

jsonl jsonrpc rust

Last synced: 16 days ago
JSON representation

A JSON-RPC 2.0 library that streams JSON objects in JSON Lines format.

Awesome Lists containing this project

README

        

jsonlrpc
========

[![jsonlrpc](https://img.shields.io/crates/v/jsonlrpc.svg)](https://crates.io/crates/jsonlrpc)
[![Documentation](https://docs.rs/jsonlrpc/badge.svg)](https://docs.rs/jsonlrpc)
[![Actions Status](https://github.com/sile/jsonlrpc/workflows/CI/badge.svg)](https://github.com/sile/jsonlrpc/actions)
![License](https://img.shields.io/crates/l/jsonlrpc)

A [JSON-RPC 2.0] library that streams JSON objects in [JSON Lines] format.

[JSON-RPC 2.0]: https://www.jsonrpc.org/specification
[JSON Lines]: https://jsonlines.org/

Examples
--------

RPC client:
```rust
use std::net::TcpStream;
use jsonlrpc::{RpcClient, RequestId, RequestObject, ResponseObject, JsonRpcVersion};

// Connect to a JSON-RPC server.
let server_addr = spawn_rpc_server_thread(); // See below
let socket = TcpStream::connect(server_addr).expect("failed to connect to server");
let mut client = RpcClient::new(socket);

// Send a request to the server.
let request = RequestObject {
jsonrpc: JsonRpcVersion::V2,
id: Some(RequestId::Number(1)),
method: "foo".to_string(),
params: None,
};
let response = client.call(&request).expect("failed to RPC call");

// Check the response.
let Some(ResponseObject::Ok { result, id, .. }) = response else {
panic!("expected ok response, got notification or err response")
};
assert_eq!(id, RequestId::Number(1));
```

RPC server:
```rust
use std::net::{SocketAddr, TcpListener};
use jsonlrpc::{JsonlStream, JsonRpcVersion, RequestObject, ResponseObject};

fn spawn_server_thread() -> SocketAddr {
let listener = TcpListener::bind("127.0.0.1:0").expect("failed to bind to address");
let addr = listener.local_addr().expect("failed to get local address");

std::thread::spawn(move || {
for stream in listener.incoming() {
let stream = stream.expect("failed to accept incoming connection");
let mut stream = JsonlStream::new(stream);
std::thread::spawn(move || {
let request: RequestObject = stream.read_value().expect("failed to read request");
let response = ResponseObject::Ok {
jsonrpc: JsonRpcVersion::V2,
id: request.id.expect("expected request id"),
result: serde_json::Value::String(request.method),
};
stream.write_value(&response).expect("failed to write response");
});
}
});

addr
}
```