#json-rpc #rpc #json-rpc-client #json #serde

tetsy-jsonrpc-core-client

Tetsy 不可知传输 JSON-RPC 2.0 客户端实现

显示crate…

3个稳定版本

15.1.0 2021年3月13日
14.2.1 2021年3月1日

#35 in #jsonrpc

Download history 51/week @ 2024-03-11 59/week @ 2024-03-18 98/week @ 2024-03-25 126/week @ 2024-04-01 50/week @ 2024-04-08 48/week @ 2024-04-15 57/week @ 2024-04-22 53/week @ 2024-04-29 55/week @ 2024-05-06 67/week @ 2024-05-13 40/week @ 2024-05-20 56/week @ 2024-05-27 48/week @ 2024-06-03 46/week @ 2024-06-10 41/week @ 2024-06-17 59/week @ 2024-06-24

195 个月下载量
用于 37 个crate(11个直接使用)

MIT 许可证

61KB
1.5K SLoC

Parity JSON-RPC

Rust实现JSON-RPC 2.0规范。支持core和传输服务器,包括httpipcwebsocketstcp

新功能! 支持客户端。

文档

子项目

示例

基本用法(使用HTTP传输)

use jsonrpc_http_server::jsonrpc_core::{IoHandler, Value, Params};
use jsonrpc_http_server::ServerBuilder;

fn main() {
	let mut io = IoHandler::default();
	io.add_method("say_hello", |_params: Params| async {
		Ok(Value::String("hello".to_owned()))
	});

	let server = ServerBuilder::new(io)
		.threads(3)
		.start_http(&"127.0.0.1:3030".parse().unwrap())
		.unwrap();

	server.wait();
}

使用derive的基本用法

use jsonrpc_core::Result;
use jsonrpc_derive::rpc;

#[rpc]
pub trait Rpc {
	/// Adds two numbers and returns a result
	#[rpc(name = "add")]
	fn add(&self, u64, u64) -> Result<u64>;
}

pub struct RpcImpl;
impl Rpc for RpcImpl {
	fn add(&self, a: u64, b: u64) -> Result<u64> {
		Ok(a + b)
	}
}

fn main() {
	let mut io = jsonrpc_core::IoHandler::new();
	io.extend_with(RpcImpl.to_delegate())
}

客户端支持

use jsonrpc_core_client::transports::local;
use jsonrpc_core::{Error, IoHandler, Result};
use jsonrpc_derive::rpc;

/// Rpc trait
#[rpc]
pub trait Rpc {
	/// Returns a protocol version
	#[rpc(name = "protocolVersion")]
	fn protocol_version(&self) -> Result<String>;

	/// Adds two numbers and returns a result
	#[rpc(name = "add", alias("callAsyncMetaAlias"))]
	fn add(&self, a: u64, b: u64) -> Result<u64>;

	/// Performs asynchronous operation
	#[rpc(name = "callAsync")]
	fn call(&self, a: u64) -> FutureResult<String, Error>;
}

struct RpcImpl;

impl Rpc for RpcImpl {
	fn protocol_version(&self) -> Result<String> {
		Ok("version1".into())
	}

	fn add(&self, a: u64, b: u64) -> Result<u64> {
		Ok(a + b)
	}

	fn call(&self, _: u64) -> FutureResult<String, Error> {
		future::ok("OK".to_owned())
	}
}

fn main() {
	let mut io = IoHandler::new();
	io.extend_with(RpcImpl.to_delegate());

	let fut = {
		let (client, server) = local::connect::<gen_client::Client, _, _>(io);
		client.add(5, 6).map(|res| println!("5 + 6 = {}", res)).join(server)
	};
	fut.wait().unwrap();
}

依赖

~3–16MB
~233K SLoC