mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-29 20:47:25 +00:00
b8867d71bc
* malicious reputation cost is fatal * make ReportBad a malicious cost * futures control-flow for cleaning up inactive collator peers * guide: network bridge updates * add `PeerDisconnected` message * guide: update * reverse order * remember to match * implement disconnect peer in network bridge * implement disconnect_inactive_peers * test * remove println * don't hardcore policy * add fuse outside of loop * use default eviction policy
66 lines
2.1 KiB
Rust
66 lines
2.1 KiB
Rust
pub use sc_network::ReputationChange;
|
|
|
|
/// Unified annoyance cost and good behavior benefits.
|
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
|
#[allow(missing_docs)]
|
|
pub enum UnifiedReputationChange {
|
|
CostMajor(&'static str),
|
|
CostMinor(&'static str),
|
|
CostMajorRepeated(&'static str),
|
|
CostMinorRepeated(&'static str),
|
|
Malicious(&'static str),
|
|
BenefitMinorFirst(&'static str),
|
|
BenefitMinor(&'static str),
|
|
BenefitMajorFirst(&'static str),
|
|
BenefitMajor(&'static str),
|
|
}
|
|
|
|
impl UnifiedReputationChange {
|
|
/// Obtain the cost or benefit associated with
|
|
/// the enum variant.
|
|
///
|
|
/// Order of magnitude rationale:
|
|
///
|
|
/// * the peerset will not connect to a peer whose reputation is below a fixed value
|
|
/// * `max(2% *$rep, 1)` is the delta of convergence towards a reputation of 0
|
|
///
|
|
/// The whole range of an `i32` should be used, so order of magnitude of
|
|
/// something malicious should be `1<<20` (give or take).
|
|
const fn cost_or_benefit(&self) -> i32 {
|
|
match self {
|
|
Self::CostMinor(_) => -100_000,
|
|
Self::CostMajor(_) => -300_000,
|
|
Self::CostMinorRepeated(_) => -200_000,
|
|
Self::CostMajorRepeated(_) => -600_000,
|
|
Self::Malicious(_) => i32::min_value(),
|
|
Self::BenefitMajorFirst(_) => 300_000,
|
|
Self::BenefitMajor(_) => 200_000,
|
|
Self::BenefitMinorFirst(_) => 15_000,
|
|
Self::BenefitMinor(_) => 10_000,
|
|
}
|
|
}
|
|
|
|
/// Extract the static description.
|
|
pub const fn description(&self) -> &'static str {
|
|
match self {
|
|
Self::CostMinor(description) => description,
|
|
Self::CostMajor(description) => description,
|
|
Self::CostMinorRepeated(description) => description,
|
|
Self::CostMajorRepeated(description) => description,
|
|
Self::Malicious(description) => description,
|
|
Self::BenefitMajorFirst(description) => description,
|
|
Self::BenefitMajor(description) => description,
|
|
Self::BenefitMinorFirst(description) => description,
|
|
Self::BenefitMinor(description) => description,
|
|
}
|
|
}
|
|
|
|
/// Convert into a base reputation as used with substrate.
|
|
pub const fn into_base_rep(self) -> ReputationChange {
|
|
ReputationChange::new(
|
|
self.cost_or_benefit(),
|
|
self.description()
|
|
)
|
|
}
|
|
}
|