-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathconstants.rs
130 lines (109 loc) · 4.83 KB
/
constants.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
//! A set of constant values used in humanode runtime.
// We allow math related clippy lints as all constants here have been checked manually.
#![allow(
clippy::cast_possible_truncation,
clippy::cast_precision_loss,
clippy::cast_sign_loss,
clippy::arithmetic_side_effects
)]
/// Block related time.
pub mod block_time {
use crate::BlockNumber;
// NOTE: Currently it is not possible to change the slot duration after the chain has started.
// Attempting to do so will brick block production.
pub const MILLISECS_PER_BLOCK: u64 = 6000;
pub const SECS_PER_BLOCK: u64 = MILLISECS_PER_BLOCK / 1000;
// These time units are defined in number of blocks.
pub const MINUTES: BlockNumber = 60 / (SECS_PER_BLOCK as BlockNumber);
pub const HOURS: BlockNumber = MINUTES * 60;
}
/// Timestamp related time.
pub mod timestamp {
use crate::UnixMilliseconds;
pub const TIMESTAMP_SECOND: UnixMilliseconds = 1000;
pub const TIMESTAMP_MINUTE: UnixMilliseconds = 60 * TIMESTAMP_SECOND;
pub const TIMESTAMP_HOUR: UnixMilliseconds = 60 * TIMESTAMP_MINUTE;
pub const TIMESTAMP_DAY: UnixMilliseconds = 24 * TIMESTAMP_HOUR;
}
/// Bioath constants.
pub mod bioauth {
use crate::UnixMilliseconds;
pub const MAX_AUTHENTICATIONS: u32 = 3 * 1024;
pub const MAX_NONCES: u32 = 10000 * MAX_AUTHENTICATIONS;
pub const AUTHENTICATIONS_EXPIRE_AFTER: UnixMilliseconds = 7 * super::timestamp::TIMESTAMP_DAY;
}
/// Babe constants.
pub mod babe {
use crate::BlockNumber;
// 1 in 4 blocks (on average, not counting collisions) will be primary BABE blocks.
pub const PRIMARY_PROBABILITY: (u64, u64) = (1, 4);
/// The BABE epoch configuration at genesis.
pub const BABE_GENESIS_EPOCH_CONFIG: sp_consensus_babe::BabeEpochConfiguration =
sp_consensus_babe::BabeEpochConfiguration {
c: PRIMARY_PROBABILITY,
allowed_slots: sp_consensus_babe::AllowedSlots::PrimaryAndSecondaryVRFSlots,
};
pub const SLOT_DURATION: u64 = super::block_time::MILLISECS_PER_BLOCK;
pub const EPOCH_DURATION_IN_BLOCKS: BlockNumber = 4 * super::block_time::HOURS;
// NOTE: Currently it is not possible to change the epoch duration after the chain has started.
// Attempting to do so will brick block production.
pub const EPOCH_DURATION_IN_SLOTS: u64 = {
const SLOT_FILL_RATE: f64 =
super::block_time::MILLISECS_PER_BLOCK as f64 / SLOT_DURATION as f64;
(EPOCH_DURATION_IN_BLOCKS as f64 * SLOT_FILL_RATE) as u64
};
pub const MAX_AUTHORITIES: u32 = super::bioauth::MAX_AUTHENTICATIONS;
}
/// `ImOnline` constants.
pub mod im_online {
// TODO(#311): set proper values
pub const MAX_KEYS: u32 = 10 * 1024;
pub const MAX_PEER_IN_HEARTBEATS: u32 = 3 * MAX_KEYS;
pub const MAX_PEER_DATA_ENCODING_SIZE: u32 = 1_000;
}
/// Equivocation constants.
pub mod equivocation {
pub const REPORT_LONGEVITY: u64 = 3 * super::babe::EPOCH_DURATION_IN_BLOCKS as u64;
}
// Constants conditions.
static_assertions::const_assert!(im_online::MAX_KEYS >= bioauth::MAX_AUTHENTICATIONS);
static_assertions::const_assert!(
im_online::MAX_PEER_IN_HEARTBEATS >= 3 * bioauth::MAX_AUTHENTICATIONS
);
/// Fees related constants.
pub mod fees {
use crate::Balance;
/// The multiplier to get the fee from weight.
///
/// We compute the fee to weight multiplier based on the weight of the `balances.transfer` call,
/// and try to fit the fee such that a single transfer call costs ~0.1 HMND.
pub const WEIGHT_TO_FEE: Balance = 382_000_000;
/// The multiplier to get the fee from length.
pub const LENGTH_TO_FEE: Balance = 1;
}
/// EVM fees related constants.
pub mod evm_fees {
/// The max amount of gas per block.
/// Set to the value that fits our fee requirements.
/// Ref: <https://ethereum.org/en/developers/docs/gas/#block-size>
pub const BLOCK_GAS_LIMIT: u64 = 60_000_000;
/// The amount of fee per gas unit.
/// Comes from the following rationale:
/// - a simple transfer costs 21000 gas
/// - we want the cost of this transfer to be around ~0.2 HMND
/// - so we must charge about 0.2 * 10^18 / 21000 fee per a unit of gas
/// The value below is a nice round number that fits the requirements outlined above.
pub const FEE_PER_GAS: u128 = 10_000_000_000_000;
/// The max proof size ratio per block.
/// Set to the zero as humanode is solo chain. Otherwise, additional used gas has
/// been added to transactions cost.
/// Ref: <https://github.com/paritytech/frontier/pull/1039>
pub const GAS_LIMIT_POV_SIZE_RATIO: u64 = 0;
}
/// Ethereum related constants.
pub mod ethereum {
/// The maximum length of the extra data in the executed event.
///
/// Current value has been taken based on moonbeam runtime ethereum pallet configuration.
pub const EXTRA_DATA_LENGTH: u32 = 30;
}