Uses old Rust 2015
0.4.0 |
|
---|---|
0.3.0 |
|
0.2.0 |
|
0.1.2 |
|
0.1.1 |
|
#57 in #jsonrpc
Used in 6 crates
49KB
1K
SLoC
jsonrpc-core
Transport agnostic rust implementation of JSON-RPC 2.0 Specification.
- - server side
- - client side
Example
Cargo.toml
[dependencies]
jsonrpc-core = "4.0"
main.rs
extern crate jsonrpc_core;
use 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()));
}
Asynchronous responses
main.rs
extern crate jsonrpc_core;
use jsonrpc_core::*;
use 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()));
}
Publish-Subscribe
See examples directory.
Dependencies
~0.8–1.7MB
~37K SLoC