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 middlewares
JSON-RPC types

Structs

Simplified IoHandler with no Metadata associated with each request.
Request handler

Enums

IoHandler json-rpc protocol compatibility
Possible Remote Procedures with Metadata

Traits

Metadata trait
Asynchronous Method with Metadata
Asynchronous Method
Notification with Metadata

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.