use super::{success_response, ApiResult}; use crate::helpers::*; use crate::ApiError; use beacon_chain::BeaconChainTypes; use eth2_config::Eth2Config; use hyper::{Body, Request}; use std::sync::Arc; use types::EthSpec; /// HTTP handler to return the full spec object. pub fn get_spec(req: Request) -> ApiResult { let beacon_chain = get_beacon_chain_from_request::(&req)?; let json: String = serde_json::to_string(&beacon_chain.spec) .map_err(|e| ApiError::ServerError(format!("Unable to serialize spec: {:?}", e)))?; Ok(success_response(Body::from(json))) } /// HTTP handler to return the full Eth2Config object. pub fn get_eth2_config(req: Request) -> ApiResult { let eth2_config = req .extensions() .get::>() .ok_or_else(|| ApiError::ServerError("Eth2Config extension missing".to_string()))?; let json: String = serde_json::to_string(eth2_config.as_ref()) .map_err(|e| ApiError::ServerError(format!("Unable to serialize Eth2Config: {:?}", e)))?; Ok(success_response(Body::from(json))) } /// HTTP handler to return the full spec object. pub fn get_slots_per_epoch(_req: Request) -> ApiResult { let json: String = serde_json::to_string(&T::EthSpec::slots_per_epoch()) .map_err(|e| ApiError::ServerError(format!("Unable to serialize epoch: {:?}", e)))?; Ok(success_response(Body::from(json))) }