mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 08:07:58 +00:00
7b56ab15b4
* Run cargo fmt on the whole code base * Second run * Add CI check * Fix compilation * More unnecessary braces * Handle weights * Use --all * Use correct attributes... * Fix UI tests * AHHHHHHHHH * 🤦 * Docs * Fix compilation * 🤷 * Please stop * 🤦 x 2 * More * make rustfmt.toml consistent with polkadot Co-authored-by: André Silva <andrerfosilva@gmail.com>
75 lines
2.7 KiB
Rust
75 lines
2.7 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) 2020-2021 Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: GPL-3.0-or-later WITH Classpath-exception-2.0
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
use crate::error;
|
|
use sc_service::{KeepBlocks, PruningMode, Role};
|
|
use structopt::StructOpt;
|
|
|
|
/// Parameters to define the pruning mode
|
|
#[derive(Debug, StructOpt, Clone)]
|
|
pub struct PruningParams {
|
|
/// Specify the state pruning mode, a number of blocks to keep or 'archive'.
|
|
///
|
|
/// Default is to keep all block states if the node is running as a
|
|
/// validator (i.e. 'archive'), otherwise state is only kept for the last
|
|
/// 256 blocks.
|
|
#[structopt(long = "pruning", value_name = "PRUNING_MODE")]
|
|
pub pruning: Option<String>,
|
|
/// Specify the number of finalized blocks to keep in the database.
|
|
///
|
|
/// Default is to keep all blocks.
|
|
#[structopt(long, value_name = "COUNT")]
|
|
pub keep_blocks: Option<u32>,
|
|
}
|
|
|
|
impl PruningParams {
|
|
/// Get the pruning value from the parameters
|
|
pub fn state_pruning(&self, unsafe_pruning: bool, role: &Role) -> error::Result<PruningMode> {
|
|
// by default we disable pruning if the node is an authority (i.e.
|
|
// `ArchiveAll`), otherwise we keep state for the last 256 blocks. if the
|
|
// node is an authority and pruning is enabled explicitly, then we error
|
|
// unless `unsafe_pruning` is set.
|
|
Ok(match &self.pruning {
|
|
Some(ref s) if s == "archive" => PruningMode::ArchiveAll,
|
|
None if role.is_authority() => PruningMode::ArchiveAll,
|
|
None => PruningMode::default(),
|
|
Some(s) => {
|
|
if role.is_authority() && !unsafe_pruning {
|
|
return Err(error::Error::Input(
|
|
"Validators should run with state pruning disabled (i.e. archive). \
|
|
You can ignore this check with `--unsafe-pruning`."
|
|
.to_string(),
|
|
))
|
|
}
|
|
|
|
PruningMode::keep_blocks(s.parse().map_err(|_| {
|
|
error::Error::Input("Invalid pruning mode specified".to_string())
|
|
})?)
|
|
},
|
|
})
|
|
}
|
|
|
|
/// Get the block pruning value from the parameters
|
|
pub fn keep_blocks(&self) -> error::Result<KeepBlocks> {
|
|
Ok(match self.keep_blocks {
|
|
Some(n) => KeepBlocks::Some(n),
|
|
None => KeepBlocks::All,
|
|
})
|
|
}
|
|
}
|