mirror of
https://github.com/pezkuwichain/pez-minimal-template.git
synced 2026-04-22 14:57:56 +00:00
2094b221cc
- node/src/* guncelendi - runtime/src/lib.rs guncelendi (pezsp_keyring import fix) - pezpallets/template/src/* guncelendi
144 lines
4.2 KiB
Rust
144 lines
4.2 KiB
Rust
// This file is part of Bizinikiwi.
|
|
|
|
// Copyright (C) Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
use crate::{
|
|
chain_spec,
|
|
cli::{Cli, Subcommand},
|
|
service,
|
|
};
|
|
use pezkuwi_sdk::{pezsc_cli::BizinikiwiCli, pezsc_service::PartialComponents, *};
|
|
|
|
impl BizinikiwiCli for Cli {
|
|
fn impl_name() -> String {
|
|
"Bizinikiwi Node".into()
|
|
}
|
|
|
|
fn impl_version() -> String {
|
|
env!("BIZINIKIWI_CLI_IMPL_VERSION").into()
|
|
}
|
|
|
|
fn description() -> String {
|
|
env!("CARGO_PKG_DESCRIPTION").into()
|
|
}
|
|
|
|
fn author() -> String {
|
|
env!("CARGO_PKG_AUTHORS").into()
|
|
}
|
|
|
|
fn support_url() -> String {
|
|
"support.anonymous.an".into()
|
|
}
|
|
|
|
fn copyright_start_year() -> i32 {
|
|
2017
|
|
}
|
|
|
|
fn load_spec(&self, id: &str) -> Result<Box<dyn pezsc_service::ChainSpec>, String> {
|
|
Ok(match id {
|
|
"dev" => Box::new(chain_spec::development_chain_spec()?),
|
|
path => {
|
|
Box::new(chain_spec::ChainSpec::from_json_file(std::path::PathBuf::from(path))?)
|
|
},
|
|
})
|
|
}
|
|
}
|
|
|
|
/// Parse and run command line arguments
|
|
pub fn run() -> pezsc_cli::Result<()> {
|
|
let cli = Cli::from_args();
|
|
|
|
match &cli.subcommand {
|
|
Some(Subcommand::Key(cmd)) => cmd.run(&cli),
|
|
#[allow(deprecated)]
|
|
Some(Subcommand::BuildSpec(cmd)) => {
|
|
let runner = cli.create_runner(cmd)?;
|
|
runner.sync_run(|config| cmd.run(config.chain_spec, config.network))
|
|
},
|
|
Some(Subcommand::CheckBlock(cmd)) => {
|
|
let runner = cli.create_runner(cmd)?;
|
|
runner.async_run(|config| {
|
|
let PartialComponents { client, task_manager, import_queue, .. } =
|
|
service::new_partial(&config)?;
|
|
Ok((cmd.run(client, import_queue), task_manager))
|
|
})
|
|
},
|
|
Some(Subcommand::ExportChainSpec(cmd)) => {
|
|
let chain_spec = cli.load_spec(&cmd.chain)?;
|
|
cmd.run(chain_spec)
|
|
},
|
|
Some(Subcommand::ExportBlocks(cmd)) => {
|
|
let runner = cli.create_runner(cmd)?;
|
|
runner.async_run(|config| {
|
|
let PartialComponents { client, task_manager, .. } = service::new_partial(&config)?;
|
|
Ok((cmd.run(client, config.database), task_manager))
|
|
})
|
|
},
|
|
Some(Subcommand::ExportState(cmd)) => {
|
|
let runner = cli.create_runner(cmd)?;
|
|
runner.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)) => {
|
|
let runner = cli.create_runner(cmd)?;
|
|
runner.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)) => {
|
|
let runner = cli.create_runner(cmd)?;
|
|
runner.sync_run(|config| cmd.run(config.database))
|
|
},
|
|
Some(Subcommand::Revert(cmd)) => {
|
|
let runner = cli.create_runner(cmd)?;
|
|
runner.async_run(|config| {
|
|
let PartialComponents { client, task_manager, backend, .. } =
|
|
service::new_partial(&config)?;
|
|
Ok((cmd.run(client, backend, None), task_manager))
|
|
})
|
|
},
|
|
Some(Subcommand::ChainInfo(cmd)) => {
|
|
let runner = cli.create_runner(cmd)?;
|
|
runner.sync_run(|config| {
|
|
cmd.run::<pez_minimal_template_runtime::interface::OpaqueBlock>(&config)
|
|
})
|
|
},
|
|
None => {
|
|
let runner = cli.create_runner(&cli.run)?;
|
|
runner.run_node_until_exit(|config| async move {
|
|
match config.network.network_backend {
|
|
pezsc_network::config::NetworkBackendType::Libp2p => service::new_full::<
|
|
pezsc_network::NetworkWorker<_, _>,
|
|
>(
|
|
config, cli.consensus
|
|
)
|
|
.map_err(pezsc_cli::Error::Service),
|
|
pezsc_network::config::NetworkBackendType::Litep2p => service::new_full::<
|
|
pezsc_network::Litep2pNetworkBackend,
|
|
>(
|
|
config, cli.consensus
|
|
)
|
|
.map_err(pezsc_cli::Error::Service),
|
|
}
|
|
})
|
|
},
|
|
}
|
|
}
|