2024-01-03 10:24:52 +00:00
|
|
|
#[macro_use]
|
|
|
|
extern crate tracing;
|
|
|
|
|
|
|
|
extern crate miner as zgs_miner;
|
|
|
|
|
|
|
|
mod admin;
|
|
|
|
mod config;
|
|
|
|
mod error;
|
|
|
|
mod miner;
|
|
|
|
mod types;
|
2024-01-19 02:56:59 +00:00
|
|
|
mod zgs;
|
2024-01-03 10:24:52 +00:00
|
|
|
|
|
|
|
use crate::miner::RpcServer as MinerRpcServer;
|
|
|
|
use admin::RpcServer as AdminRpcServer;
|
|
|
|
use chunk_pool::MemoryChunkPool;
|
|
|
|
use futures::channel::mpsc::Sender;
|
|
|
|
use jsonrpsee::core::RpcResult;
|
|
|
|
use jsonrpsee::http_server::{HttpServerBuilder, HttpServerHandle};
|
|
|
|
use network::NetworkGlobals;
|
|
|
|
use network::NetworkMessage;
|
|
|
|
use std::error::Error;
|
|
|
|
use std::sync::Arc;
|
|
|
|
use storage_async::Store;
|
|
|
|
use sync::{SyncRequest, SyncResponse, SyncSender};
|
|
|
|
use task_executor::ShutdownReason;
|
|
|
|
use tokio::sync::broadcast;
|
|
|
|
use tokio::sync::mpsc::UnboundedSender;
|
2024-01-19 02:56:59 +00:00
|
|
|
use zgs::RpcServer as ZgsRpcServer;
|
|
|
|
use zgs_miner::MinerMessage;
|
2024-01-03 10:24:52 +00:00
|
|
|
|
|
|
|
pub use config::Config as RPCConfig;
|
|
|
|
|
|
|
|
/// A wrapper around all the items required to spawn the HTTP server.
|
|
|
|
///
|
|
|
|
/// The server will gracefully handle the case where any fields are `None`.
|
|
|
|
#[derive(Clone)]
|
|
|
|
pub struct Context {
|
|
|
|
pub config: RPCConfig,
|
|
|
|
pub network_globals: Arc<NetworkGlobals>,
|
|
|
|
pub network_send: UnboundedSender<NetworkMessage>,
|
|
|
|
pub sync_send: SyncSender,
|
|
|
|
pub chunk_pool: Arc<MemoryChunkPool>,
|
|
|
|
pub log_store: Store,
|
|
|
|
pub shutdown_sender: Sender<ShutdownReason>,
|
|
|
|
pub mine_service_sender: Option<broadcast::Sender<MinerMessage>>,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Context {
|
|
|
|
pub fn send_network(&self, msg: NetworkMessage) -> RpcResult<()> {
|
|
|
|
self.network_send
|
|
|
|
.send(msg)
|
|
|
|
.map_err(|e| error::internal_error(format!("Failed to send network message: {:?}", e)))
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn request_sync(&self, request: SyncRequest) -> RpcResult<SyncResponse> {
|
|
|
|
self.sync_send
|
|
|
|
.request(request)
|
|
|
|
.await
|
|
|
|
.map_err(|e| error::internal_error(format!("Failed to send sync request: {:?}", e)))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn run_server(ctx: Context) -> Result<HttpServerHandle, Box<dyn Error>> {
|
|
|
|
let server = HttpServerBuilder::default()
|
|
|
|
.build(ctx.config.listen_address)
|
|
|
|
.await?;
|
|
|
|
|
|
|
|
let mut zgs = (zgs::RpcServerImpl { ctx: ctx.clone() }).into_rpc();
|
|
|
|
let admin = (admin::RpcServerImpl { ctx: ctx.clone() }).into_rpc();
|
|
|
|
zgs.merge(admin)?;
|
|
|
|
|
|
|
|
if ctx.mine_service_sender.is_some() {
|
|
|
|
let mine = (miner::RpcServerImpl { ctx }).into_rpc();
|
|
|
|
zgs.merge(mine)?;
|
|
|
|
}
|
|
|
|
|
|
|
|
let addr = server.local_addr()?;
|
|
|
|
let handle = server.start(zgs)?;
|
|
|
|
info!("Server started http://{}", addr);
|
|
|
|
|
|
|
|
Ok(handle)
|
|
|
|
}
|