#json-rpc #rpc #json #serde

rs-jsonrpc-core

JSON-RPC 2.0规范的无传输实现Rust

1 个稳定版本

使用旧Rust 2015

8.0.0 2019年5月14日

#17#jsonrpc

24 每月下载
5 个crate中使用

MIT 许可证

49KB
1K SLoC

rs-jsonrpc-core

JSON-RPC 2.0规范的无传输实现Rust。

文档

  • - 服务器端
  • - 客户端

示例

Cargo.toml

[dependencies]
rs-jsonrpc-core = "4.0"

main.rs

extern crate rs_jsonrpc_core;

use rs_jsonrpc_core::*;

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

	let request = r#"{"jsonrpc": "2.0", "method": "say_hello", "params": [42, 23], "id": 1}"#;
	let response = r#"{"jsonrpc":"2.0","result":"hello","id":1}"#;

	assert_eq!(io.handle_request_sync(request), Some(response.to_owned()));
}

异步响应

main.rs

extern crate rs_jsonrpc_core;

use rs_jsonrpc_core::*;
use rs_jsonrpc_core::futures::Future;

fn main() {
	let io = IoHandler::new();
	io.add_async_method("say_hello", |_params: Params| {
		futures::finished(Value::String("hello".into()))
	});

	let request = r#"{"jsonrpc": "2.0", "method": "say_hello", "params": [42, 23], "id": 1}"#;
	let response = r#"{"jsonrpc":"2.0","result":"hello","id":1}"#;

	assert_eq!(io.handle_request(request).wait().unwrap(), Some(response.to_owned()));
}

发布-订阅

查看示例目录。

依赖

~1–1.9MB
~40K SLoC