use futures::FutureExt; use http::HeaderValue; use hyper::header::HeaderMap; use rpc_toolkit::hyper::http::Error as HttpError; use rpc_toolkit::hyper::{Body, Method, Request, Response}; use rpc_toolkit::rpc_server_helpers::{ DynMiddlewareStage2, DynMiddlewareStage3, DynMiddlewareStage4, }; use rpc_toolkit::Metadata; fn get_cors_headers(req: &Request
) -> HeaderMap { let mut res = HeaderMap::new(); if let Some(origin) = req.headers().get("Origin") { res.insert("Access-Control-Allow-Origin", origin.clone()); } if let Some(method) = req.headers().get("Access-Control-Request-Method") { res.insert("Access-Control-Allow-Methods", method.clone()); } if let Some(headers) = req.headers().get("Access-Control-Request-Headers") { res.insert("Access-Control-Allow-Headers", headers.clone()); } res.insert( "Access-Control-Allow-Credentials", HeaderValue::from_static("true"), ); res } pub async fn cors