use std::sync::Arc; use serai_runtime::Block; use sc_service::{PruningMode, PartialComponents}; use sc_cli::SubstrateCli; use crate::{ chain_spec, cli::{Cli, Subcommand}, service::{self, FullClient}, }; impl SubstrateCli for Cli { fn impl_name() -> String { "Serai Node".into() } fn impl_version() -> String { env!("SUBSTRATE_CLI_IMPL_VERSION").to_string() } fn description() -> String { env!("CARGO_PKG_DESCRIPTION").to_string() } fn author() -> String { env!("CARGO_PKG_AUTHORS").to_string() } fn support_url() -> String { "https://github.com/serai-dex/serai/issues/new".to_string() } fn copyright_start_year() -> i32 { 2022 } fn load_spec(&self, id: &str) -> Result, String> { match id { "dev" | "devnet" => Ok(Box::new(chain_spec::development_config()?)), "local" => Ok(Box::new(chain_spec::testnet_config()?)), _ => panic!("Unknown network ID"), } } } pub fn run() -> sc_cli::Result<()> { let cli = Cli::from_args(); match &cli.subcommand { Some(Subcommand::Key(cmd)) => cmd.run(&cli), Some(Subcommand::BuildSpec(cmd)) => { cli.create_runner(cmd)?.sync_run(|config| cmd.run(config.chain_spec, config.network)) } Some(Subcommand::CheckBlock(cmd)) => cli.create_runner(cmd)?.async_run(|config| { let PartialComponents { client, task_manager, import_queue, .. } = service::new_partial(&config)?; Ok((cmd.run(client, import_queue), task_manager)) }), Some(Subcommand::ExportBlocks(cmd)) => cli.create_runner(cmd)?.async_run(|config| { let PartialComponents { client, task_manager, .. } = service::new_partial(&config)?; Ok((cmd.run(client, config.database), task_manager)) }), Some(Subcommand::ExportState(cmd)) => cli.create_runner(cmd)?.async_run(|config| { let PartialComponents { client, task_manager, .. } = service::new_partial(&config)?; Ok((cmd.run(client, config.chain_spec), task_manager)) }), Some(Subcommand::ImportBlocks(cmd)) => cli.create_runner(cmd)?.async_run(|config| { let PartialComponents { client, task_manager, import_queue, .. } = service::new_partial(&config)?; Ok((cmd.run(client, import_queue), task_manager)) }), Some(Subcommand::PurgeChain(cmd)) => { cli.create_runner(cmd)?.sync_run(|config| cmd.run(config.database)) } Some(Subcommand::Revert(cmd)) => cli.create_runner(cmd)?.async_run(|config| { let PartialComponents { client, task_manager, backend, .. } = service::new_partial(&config)?; let aux_revert = Box::new(|client: Arc, backend, blocks| { sc_consensus_babe::revert(client.clone(), backend, blocks)?; sc_consensus_grandpa::revert(client, blocks)?; Ok(()) }); Ok((cmd.run(client, backend, Some(aux_revert)), task_manager)) }), Some(Subcommand::ChainInfo(cmd)) => { cli.create_runner(cmd)?.sync_run(|config| cmd.run::(&config)) } None => cli.create_runner(&cli.run)?.run_node_until_exit(|mut config| async { if config.role.is_authority() { config.state_pruning = Some(PruningMode::ArchiveAll); } service::new_full(config).await.map_err(sc_cli::Error::Service) }), } }