我想使用hyper创建多个RPC方法。 This is their example code。如何添加多个方法并启动返回BoxFuture
的服务?
在下面,我有两种方法,如何合并这两种方法并创建服务?
use hyper::service::{make_service_fn, service_fn};
use hyper::{Body, Request, Response, Server};
use std::{convert::Infallible, net::SocketAddr};
async fn gas_Price(_: Request<Body>) -> Result<Response<Body>, Infallible> {
Ok(Response::new(Body::from("{id:1,jsonrpc:2.0,result:0x0}")))
}
async fn eth_Transaction(_: Request<Body>) -> Result<Response<Body>, Infallible> {
Ok(Response::new(Body::from("eth_Transcation!")))
}
#[tokio::main]
pub async fn Start() {
let addr = SocketAddr::from(([127, 0, 0, 1], 3030));
let make_svc = make_service_fn(|_conn| async { Ok::<_, Infallible>(service_fn(gas_Price)) });
let server = Server::bind(&addr).serve(gas_Price);
if let Err(e) = server.await {
eprintln!("server error: {}", e);
}
}
最佳答案
我过去采用的一种方法是使一种服务充当路由表。
我编写的服务只包含匹配路径和http方法的匹配项,然后在每个分支中调用适当的函数。
例如:
pub async fn route(req: Request<Body>) -> Result<Response<Body>, hyper::Error> {
let mut response = Response::new(Body::empty());
let method = req.method().clone();
let uri = req.uri().clone();
let path = uri.path();
let full_body = hyper::body::to_bytes(req.into_body()).await?;
let val = serde_json::from_slice::<Value>(&full_body)?;
match (method, path) {
(Method::POST, "/some-enpoint") => {
let new_body = appropriate_function(&val);
*response.body_mut() = Body::from(new_body);
},
(_method, _path) => {
*response.status_mut() = StatusCode::NOT_FOUND;
}
}
Ok(response)
}
我不知道这是否是处理Hyper中问题的推荐方法,但它对我构建的事情效果很好。
关于rust - 如何使用hyper添加多个RPC端点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60180283/