2016-01-27 17:08:59 +01:00
|
|
|
//! Ethcore rpc.
|
|
|
|
#![warn(missing_docs)]
|
2016-01-26 13:14:22 +01:00
|
|
|
#![feature(custom_derive, custom_attribute, plugin)]
|
|
|
|
#![plugin(serde_macros)]
|
2016-01-27 17:08:59 +01:00
|
|
|
#![plugin(clippy)]
|
2016-01-26 13:14:22 +01:00
|
|
|
|
|
|
|
extern crate serde;
|
2016-01-26 19:24:33 +01:00
|
|
|
extern crate serde_json;
|
2016-01-21 01:19:29 +01:00
|
|
|
extern crate jsonrpc_core;
|
|
|
|
extern crate jsonrpc_http_server;
|
2016-01-26 13:14:22 +01:00
|
|
|
extern crate ethcore_util as util;
|
|
|
|
extern crate ethcore;
|
2016-01-21 01:19:29 +01:00
|
|
|
|
|
|
|
use self::jsonrpc_core::{IoHandler, IoDelegate};
|
|
|
|
|
2016-01-27 17:14:41 +01:00
|
|
|
pub mod v1;
|
2016-01-21 01:19:29 +01:00
|
|
|
|
2016-01-27 17:08:59 +01:00
|
|
|
/// Http server.
|
2016-01-21 01:19:29 +01:00
|
|
|
pub struct HttpServer {
|
|
|
|
handler: IoHandler,
|
|
|
|
threads: usize
|
|
|
|
}
|
|
|
|
|
|
|
|
impl HttpServer {
|
2016-01-27 17:08:59 +01:00
|
|
|
/// Construct new http server object with given number of threads.
|
2016-01-21 01:19:29 +01:00
|
|
|
pub fn new(threads: usize) -> HttpServer {
|
|
|
|
HttpServer {
|
|
|
|
handler: IoHandler::new(),
|
|
|
|
threads: threads
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-27 17:08:59 +01:00
|
|
|
/// Add io delegate.
|
2016-01-21 01:19:29 +01:00
|
|
|
pub fn add_delegate<D>(&mut self, delegate: IoDelegate<D>) where D: Send + Sync + 'static {
|
|
|
|
self.handler.add_delegate(delegate);
|
|
|
|
}
|
|
|
|
|
2016-01-27 17:08:59 +01:00
|
|
|
/// Start server asynchronously in new thread
|
2016-01-21 01:19:29 +01:00
|
|
|
pub fn start_async(self, addr: &str) {
|
|
|
|
let server = jsonrpc_http_server::Server::new(self.handler, self.threads);
|
|
|
|
server.start_async(addr)
|
|
|
|
}
|
|
|
|
}
|