use std::sync::Arc; use sc_service::PartialComponents; use frame_benchmarking_cli::{BenchmarkCmd, SUBSTRATE_REFERENCE_HARDWARE}; use sc_cli::{ChainSpec, RuntimeVersion, SubstrateCli}; use serai_runtime::Block; use crate::{ chain_spec, cli::{Cli, Subcommand}, command_helper::{BenchmarkExtrinsicBuilder, inherent_benchmark_data}, service }; 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 { "serai.exchange".to_string() } fn copyright_start_year() -> i32 { 2022 } fn load_spec(&self, id: &str) -> Result, String> { match id { "dev" => Ok(Box::new(chain_spec::development_config()?)), _ => panic!("Unknown network ID") } } fn native_runtime_version(_: &Box) -> &'static RuntimeVersion { &serai_runtime::VERSION } } 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)?; Ok((cmd.run(client, backend, None), task_manager)) }) }, Some(Subcommand::Benchmark(cmd)) => { cli.create_runner(cmd)?.sync_run(|config| { match cmd { BenchmarkCmd::Pallet(cmd) => { cmd.run::(config) }, BenchmarkCmd::Block(cmd) => { cmd.run(service::new_partial(&config)?.client) }, BenchmarkCmd::Storage(cmd) => { let PartialComponents { client, backend, .. } = service::new_partial(&config)?; cmd.run(config, client, backend.expose_db(), backend.expose_storage()) }, BenchmarkCmd::Overhead(cmd) => { let client = service::new_partial(&config)?.client; cmd.run( config, client.clone(), inherent_benchmark_data()?, Arc::new(BenchmarkExtrinsicBuilder::new(client)) ) }, BenchmarkCmd::Machine(cmd) => cmd.run(&config, SUBSTRATE_REFERENCE_HARDWARE.clone()) } }) }, #[cfg(feature = "try-runtime")] Some(Subcommand::TryRuntime(cmd)) => { cli.create_runner(cmd)?.async_run(|config| { Ok( ( cmd.run::(config), sc_service::TaskManager::new( config.tokio_handle.clone(), config.prometheus_config.as_ref().map(|cfg| &cfg.registry) ).map_err(|e| sc_cli::Error::Service(sc_service::Error::Prometheus(e)))? ) ) }) }, #[cfg(not(feature = "try-runtime"))] Some(Subcommand::TryRuntime) => Err("TryRuntime wasn't enabled when building the node".into()), Some(Subcommand::ChainInfo(cmd)) => { cli.create_runner(cmd)?.sync_run(|config| cmd.run::(&config)) }, None => { cli.create_runner(&cli.run)?.run_node_until_exit(|config| async { service::new_full(config).map_err(sc_cli::Error::Service) }) } } }