Crate jsonrpc_core
source ·Expand description
Transport agnostic jsonrpc library.
Right now it supports only server side handling requests.
extern crate jsonrpc_core;
use jsonrpc_core::*;
use jsonrpc_core::futures::Future;
fn main() {
let mut io = IoHandler::new();
io.add_method("say_hello", |_| {
Ok(Value::String("Hello World!".into()))
});
let request = r#"{"jsonrpc": "2.0", "method": "say_hello", "params": [42, 23], "id": 1}"#;
let response = r#"{"jsonrpc":"2.0","result":"Hello World!","id":1}"#;
assert_eq!(io.handle_request(request).wait().unwrap(), Some(response.to_string()));
}
Re-exports
pub extern crate futures;
pub use middleware::Middleware;
pub use middleware::Noop as NoopMiddleware;
pub use types::*;
Modules
IoHandler
middlewaresJSON-RPC types
Structs
Simplified
IoHandler
with no Metadata
associated with each request.Request handler
Enums
IoHandler
json-rpc protocol compatibilityPossible Remote Procedures with Metadata
Traits
Metadata trait
Asynchronous Method with Metadata
Asynchronous Method
Notification with Metadata
Notification
Type Definitions
A
Future
trait object.A type representing middleware or RPC call output.
A type representing middleware or RPC response before serialization.
A type representing future string response.
A type representing an optional
Response
for RPC Request
.A Result type.