24个稳定版本 (10个主要版本)
18.0.0 | 2021年7月20日 |
---|---|
17.1.0 | 2021年6月7日 |
17.0.0 | 2021年1月20日 |
16.0.0 | 2020年12月14日 |
8.0.0 | 2017年11月21日 |
#104 in 测试
每月 91 次下载
在 snarkos-rpc 中使用
120KB
3K SLoC
Parity JSON-RPC
注意:此crate不再积极开发;如果您正在寻找积极维护的JSON RPC实现,请查看我们的 jsonrpsee crate。
Rust实现的JSON-RPC 2.0规范。支持传输无关的core
和传输服务器,用于http
、ipc
、websockets
和tcp
。
新功能! 支持客户端。
子项目
- jsonrpc-core
- jsonrpc-core-client
- jsonrpc-http-server
- jsonrpc-ipc-server
- jsonrpc-tcp-server
- jsonrpc-ws-server
- jsonrpc-stdio-server
- jsonrpc-derive
- jsonrpc-server-utils
- jsonrpc-pubsub
示例
基本用法(使用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();
}
使用派生的基本用法
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, a: u64, b: 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::{BoxFuture, IoHandler, Result};
use jsonrpc_core::futures::{self, future, TryFutureExt};
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) -> BoxFuture<Result<String>>;
}
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) -> BoxFuture<Result<String>> {
Box::pin(future::ready(Ok("OK".to_owned())))
}
}
fn main() {
let mut io = IoHandler::new();
io.extend_with(RpcImpl.to_delegate());
let (client, server) = local::connect::<gen_client::Client, _, _>(io);
let fut = client.add(5, 6).map_ok(|res| println!("5 + 6 = {}", res));
futures::executor::block_on(async move { futures::join!(fut, server) })
.0
.unwrap();
}
lib.rs
:
一个用于测试基于jsonrpc-core项目的实用工具包。
use jsonrpc_derive::rpc;
use jsonrpc_test as test;
use jsonrpc_core::{Result, Error, IoHandler};
#[rpc]
pub trait Test {
#[rpc(name = "rpc_some_method")]
fn some_method(&self, a: u64) -> Result<u64>;
}
struct Dummy;
impl Test for Dummy {
fn some_method(&self, x: u64) -> Result<u64> {
Ok(x * 2)
}
}
fn main() {
// Initialize new instance of test environment
let rpc = test::Rpc::new(Dummy.to_delegate());
// make a request and verify the response as a pretty-printed string
assert_eq!(rpc.request("rpc_some_method", &[5]), r#"10"#);
// You can also test RPC created without macros:
let rpc = {
let mut io = IoHandler::new();
io.add_sync_method("rpc_test_method", |_| {
Err(Error::internal_error())
});
test::Rpc::from(io)
};
assert_eq!(rpc.request("rpc_test_method", &()), r#"{
"code": -32603,
"message": "Internal error"
}"#);
}
依赖关系
~3.5–5MB
~125K SLoC