Move derive_mortal_period to metadata with crate viz

This commit is contained in:
emostov
2020-12-21 18:19:16 -08:00
parent f09adc1875
commit cde38ca9b7
4 changed files with 38 additions and 61 deletions
-2
View File
@@ -17,7 +17,6 @@
//! Create signed or unsigned extrinsics.
mod extra;
mod mortal_period;
mod signer;
pub use self::{
@@ -26,7 +25,6 @@ pub use self::{
Extra,
SignedExtra,
},
mortal_period::derive_mortal_period,
signer::{
PairSigner,
Signer,
-55
View File
@@ -1,55 +0,0 @@
// Copyright 2019-2020 Parity Technologies (UK) Ltd.
// This file is part of substrate-subxt.
//
// subxt 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.
//
// subxt 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 substrate-subxt. If not, see <http://www.gnu.org/licenses/>.
use crate::{
Error,
Metadata,
};
/// 5 min `mortal_period` in milliseconds, to be adjusted based on expected block time
pub const BASELINE_MORTAL_PERIOD: u64 = 5 * 60 * 1000;
/// Fallback `BlockHashCount` of 2,400 blocks
pub const FALLBACK_BLOCK_HASH_COUNT: u64 = 2_400;
/// Fallback expected block time of 6,000 milliseconds
pub const FALLBACK_EXPECTED_BLOCK_TIME: u64 = 6_000;
/// Derive a default mortal period based on a chain's metadata
pub fn derive_mortal_period(metadata: &Metadata) -> Result<u64, Error> {
let block_hash_count = if let Ok(system_meta) = metadata.module("System") {
if let Ok(count) = system_meta.constant("BlockHashCount") {
count.value::<u32>()?.into()
} else {
FALLBACK_BLOCK_HASH_COUNT
}
} else {
FALLBACK_BLOCK_HASH_COUNT
};
let block_time = if let Ok(babe_meta) = metadata.module("Babe") {
if let Ok(milliseconds) = babe_meta.constant("ExpectedBlockTime") {
milliseconds.value::<u64>()?
} else {
FALLBACK_EXPECTED_BLOCK_TIME
}
} else {
FALLBACK_EXPECTED_BLOCK_TIME
};
Ok((BASELINE_MORTAL_PERIOD / block_time)
.next_power_of_two()
.min(block_hash_count.next_power_of_two()))
}
+2 -3
View File
@@ -89,7 +89,6 @@ pub use crate::{
RawEvent,
},
extrinsic::{
derive_mortal_period,
PairSigner,
SignedExtra,
Signer,
@@ -180,8 +179,8 @@ impl<T: Runtime> ClientBuilder<T> {
rpc.system_properties(),
)
.await;
let metadata = metadata?;
let mortal_period = derive_mortal_period(&metadata).ok();
let metadata = metadata?;
let mortal_period = Some(metadata.derive_mortal_period()?);
Ok(Client {
rpc,
genesis_hash: genesis_hash?,
+36 -1
View File
@@ -40,6 +40,15 @@ use sp_core::storage::StorageKey;
use crate::Encoded;
/// 5 min `mortal_period`in milliseconds, to be adjusted based on expected block time
pub const BASELINE_MORTAL_PERIOD: u64 = 5 * 60 * 1000;
/// Fallback `BlockHashCount`
pub const FALLBACK_BLOCK_HASH_COUNT: u64 = 2_400;
/// Fallback expected block time in milliseconds
pub const FALLBACK_EXPECTED_BLOCK_TIME: u64 = 6_000;
/// Metadata error.
#[derive(Debug, thiserror::Error)]
pub enum MetadataError {
@@ -164,7 +173,33 @@ impl Metadata {
}
}
string
}
}
/// Derive a default mortal period
pub(crate) fn derive_mortal_period(&self) -> Result<u64, MetadataError> {
let block_hash_count = if let Ok(system_meta) = self.module("System") {
if let Ok(count) = system_meta.constant("BlockHashCount") {
count.value::<u32>()?.into()
} else {
FALLBACK_BLOCK_HASH_COUNT
}
} else {
FALLBACK_BLOCK_HASH_COUNT
};
let block_time = if let Ok(babe_meta) = self.module("Babe") {
if let Ok(milliseconds) = babe_meta.constant("ExpectedBlockTime") {
milliseconds.value::<u64>()?
} else {
FALLBACK_EXPECTED_BLOCK_TIME
}
} else {
FALLBACK_EXPECTED_BLOCK_TIME
};
Ok((BASELINE_MORTAL_PERIOD / block_time)
.next_power_of_two()
.min(block_hash_count.next_power_of_two()))
}
}
#[derive(Clone, Debug)]