Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

kusama: enable dispute slashes #5974

Merged
merged 107 commits into from
Mar 21, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
107 commits
Select commit Hold shift + click to select a range
d6a2eb2
disputes: runtime part of slashing
ordian May 6, 2022
fd2194a
disputes: reward winners
ordian May 9, 2022
9f8daef
disputes/slashing: validate_unsigned impl
ordian May 11, 2022
ee46d14
fmt
ordian May 11, 2022
7b158f6
disputes/slashing: report_dispute_lost_unsigned
ordian May 11, 2022
60a82a4
disputes/slashing: separate winners from losers and report winners
ordian May 13, 2022
b303ee4
disputes/slashing: refactoring
ordian May 13, 2022
6f1d724
impl HandleReports
ordian May 16, 2022
4a55be9
enable on Wenstend
ordian May 16, 2022
1941543
fmt
ordian May 16, 2022
04ad120
add slashing pallet to the mock and test runtimes
ordian May 16, 2022
3784591
fix a bug in report_dispute_lost_unsigned
ordian May 16, 2022
f49b55f
fmt
ordian May 16, 2022
cbcf176
disputes: remove new_participants from summary
ordian May 17, 2022
7b82f0d
disputes: remove punish_inconclusive
ordian May 17, 2022
f863baf
impl SlashingHandler for Pallet for type-safety
ordian May 17, 2022
b4fa682
do not impl slashing::Config on mainnets yet
ordian May 17, 2022
2739900
teach spellcheck deduplication
ordian May 17, 2022
62ff14f
simplify interfaces and resolve some TODOs
ordian May 17, 2022
4db3ab8
resolve some more TODOs
ordian May 17, 2022
02c069d
minor typos
ordian May 17, 2022
6fc8f5f
move slashing into a folder
ordian May 18, 2022
7f3ae20
remove unnecessary clone
ordian May 18, 2022
13c7c84
fix validator_set_count calculation
ordian May 18, 2022
5c98289
introduce ValidatorSetCount
ordian May 18, 2022
8263d16
store ValidatorSetCount
ordian May 18, 2022
c073e08
fmt
ordian May 18, 2022
dc3b6de
add the benchmark
ordian Jun 14, 2022
75f256d
fmt
ordian Jun 14, 2022
65851ad
unflatten slashing
ordian Jun 14, 2022
2210bad
post-rebase fixes
ordian Jun 14, 2022
6ab6b48
remove winners eagerly
ordian Jun 14, 2022
6a0ddfc
use real slashing weights for westend
ordian Jun 14, 2022
29376b1
remove bench test suite
ordian Jun 17, 2022
f76a697
Merge branch 'master' into ao-disputes-offences-runtime
ordian Jun 17, 2022
4800be1
zombinet: modify disputes test to check for an offence report
ordian Jun 17, 2022
4c0f83e
zombinet: add a timeout
ordian Jun 17, 2022
3086e26
add slashing pallet to Rococo
ordian Jun 20, 2022
677a262
zombienet: revert back to rococo-local
ordian Jun 20, 2022
e1ff282
Merge branch 'master' into ao-disputes-offences-runtime
ordian Jun 20, 2022
fe7495e
fmt
ordian Jun 20, 2022
461f37f
remove TODOs
ordian Jun 20, 2022
bae9912
revert some accidental changes
ordian Jun 20, 2022
15fcf48
slashing is submodule of disputes
ordian Jun 21, 2022
097d6c1
Merge branch 'master' into ao-disputes-offences-runtime
ordian Jun 21, 2022
65146ca
Merge branch 'master' into ao-disputes-offences-runtime
ordian Jun 28, 2022
650eb19
Merge branch 'master' into ao-disputes-offences-runtime
ordian Jul 5, 2022
95cd87d
Merge branch 'master' into ao-disputes-offences-runtime
ordian Jul 28, 2022
760bdc7
Change the log target
ordian Jul 30, 2022
d3405cc
Merge branch 'master' into ao-disputes-offences-runtime
ordian Aug 1, 2022
d5b3324
Merge branch 'ao-disputes-offences-runtime' of github.com:paritytech/…
ordian Aug 1, 2022
f50aa7d
wrap comments with rustfmt, more docs, constants
ordian Aug 1, 2022
248baa5
use Defensive trait
ordian Aug 3, 2022
b02bcef
cargo update -p sp-io
ordian Aug 3, 2022
e1c87c4
merge offence types, remove rewards for now
ordian Aug 3, 2022
37f9cd7
Merge branch 'master' into ao-disputes-offences-runtime
ordian Aug 3, 2022
b531490
cargo update -p sp-io
ordian Aug 3, 2022
454874f
benchmark fixes
ordian Aug 3, 2022
c0db743
fmt
ordian Aug 3, 2022
9fb1e38
unused var
ordian Aug 3, 2022
9c84b22
fix block_author impl
ordian Aug 3, 2022
19b7c6b
ressurect RewardValidators trait
ordian Aug 3, 2022
784e65e
remove outdated comment
ordian Aug 3, 2022
0c2559c
Merge branch 'master' into ao-disputes-offences-runtime
ordian Aug 4, 2022
3a2858d
Merge branch 'master' into ao-disputes-offences-runtime
ordian Aug 4, 2022
c22a943
more module docs
ordian Aug 5, 2022
884d9d8
introduce BenchmarkingConfig
ordian Aug 5, 2022
df81683
Merge branch 'master' into ao-disputes-offences-runtime
ordian Aug 5, 2022
7101379
typo fix
ordian Aug 5, 2022
ce879df
teach spellcheck unapplied
ordian Aug 5, 2022
b070f34
Merge branch 'master' into ao-disputes-offences-runtime
ordian Aug 31, 2022
563995b
Merge branch 'master' into ao-disputes-offences-runtime
ordian Aug 31, 2022
7d5171c
use Weight::new()
ordian Aug 31, 2022
b436249
fix mocking rewards
ordian Aug 31, 2022
397046e
use RefTimeWeight
ordian Aug 31, 2022
18965e3
".git/.scripts/bench-bot.sh" runtime westend-dev runtime_parachains::…
Aug 31, 2022
7269e18
refactor maybe_identify_validators
ordian Aug 31, 2022
399e0e6
no more ticket in disguise
ordian Aug 31, 2022
89fb5ed
remove outdated comments
ordian Aug 31, 2022
4f34bd7
lower against valid to 0.1%
ordian Sep 1, 2022
0d99787
bump zombienet version for debug
pepoviola Sep 1, 2022
9223d71
use from_perthousand
ordian Sep 1, 2022
c48aa45
Merge branch 'master' into ao-disputes-offences-runtime
ordian Sep 1, 2022
655fe98
post-merge fixes
ordian Sep 1, 2022
81578ff
Merge branch 'master' into ao-disputes-offences-runtime
ordian Sep 2, 2022
c5472c9
another day, another Weight changes
ordian Sep 2, 2022
6e5f372
Revert "bump zombienet version for debug"
ordian Sep 2, 2022
7bf295a
do not reward block authors
ordian Sep 5, 2022
8309493
Merge branch 'master' into ao-disputes-offences-runtime
ordian Sep 5, 2022
cd9aeb8
fix outdated comment
ordian Sep 6, 2022
3fe81e9
merge master once again
ordian Sep 6, 2022
e87cc9c
merge master once again II
ordian Sep 8, 2022
918b4ca
Merge branch 'master' into ao-disputes-offences-runtime
ordian Sep 19, 2022
b453b1a
use Pays from frame_support::dispatch::Pays
pepoviola Sep 19, 2022
77e5813
kusama: enable dispute slashing
ordian Sep 6, 2022
65cfe84
".git/.scripts/bench-bot.sh" runtime kusama-dev runtime_parachains::d…
Sep 6, 2022
83ade0e
Merge branch 'master' into ao-kusama-enable-dispute-slashes
ordian Sep 20, 2022
9fe7529
Merge branch 'master' into ao-kusama-enable-dispute-slashes
ordian Sep 20, 2022
cabc605
Merge branch 'master' into ao-kusama-enable-dispute-slashes
ordian Jan 5, 2023
ff64f05
post merge fixes
ordian Jan 5, 2023
a9bd663
Merge branch 'master' into ao-kusama-enable-dispute-slashes
ordian Jan 16, 2023
31eb7af
".git/.scripts/commands/bench/bench.sh" runtime kusama-dev runtime_pa…
Jan 16, 2023
7785be8
Merge branch 'master' into ao-kusama-enable-dispute-slashes
ordian Feb 27, 2023
56ac4f0
Merge remote-tracking branch 'origin/master' into ao-kusama-enable-di…
Feb 28, 2023
05dc083
Merge branch 'master' into ao-kusama-enable-dispute-slashes
ordian Mar 16, 2023
d86d16e
Merge branch 'ao-kusama-enable-dispute-slashes' of github.com:parityt…
ordian Mar 16, 2023
188afb0
".git/.scripts/commands/bench/bench.sh" runtime kusama runtime_parach…
Mar 16, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
simplify interfaces and resolve some TODOs
  • Loading branch information
ordian committed Jun 14, 2022
commit 62ff14f1e5688c2925c7362544fbe1addb8a0198
192 changes: 59 additions & 133 deletions runtime/parachains/src/disputes/slashing.rs
Original file line number Diff line number Diff line change
Expand Up @@ -159,18 +159,42 @@ where
}
}

impl<KeyOwnerIdentification> ForInvalidOffence<KeyOwnerIdentification> {
fn new(
session_index: SessionIndex,
candidate_hash: CandidateHash,
validator_set_count: u32,
offender: KeyOwnerIdentification,
) -> Self {
let time_slot = DisputesTimeSlot::new(session_index, candidate_hash);
Self { time_slot, validator_set_count, offenders: vec![offender] }
}
}

impl<KeyOwnerIdentification> AgainstValidOffence<KeyOwnerIdentification> {
fn new(
session_index: SessionIndex,
candidate_hash: CandidateHash,
validator_set_count: u32,
offender: KeyOwnerIdentification,
) -> Self {
let time_slot = DisputesTimeSlot::new(session_index, candidate_hash);
Self { time_slot, validator_set_count, offenders: vec![offender] }
}
}

/// This type implements `PunishValidators`.
pub struct SlashValidatorsForDisputes<C, R> {
_phantom: sp_std::marker::PhantomData<(C, R)>,
pub struct SlashValidatorsForDisputes<C> {
_phantom: sp_std::marker::PhantomData<C>,
}

impl<C, R> Default for SlashValidatorsForDisputes<C, R> {
impl<C> Default for SlashValidatorsForDisputes<C> {
fn default() -> Self {
Self { _phantom: Default::default() }
}
}

impl<T, R> SlashValidatorsForDisputes<Pallet<T>, R>
impl<T> SlashValidatorsForDisputes<Pallet<T>>
where
T: Config + crate::session_info::Config,
{
Expand Down Expand Up @@ -203,19 +227,9 @@ where
}
}

impl<T, R> super::SlashingHandler<T::BlockNumber> for SlashValidatorsForDisputes<Pallet<T>, R>
impl<T> super::SlashingHandler<T::BlockNumber> for SlashValidatorsForDisputes<Pallet<T>>
where
T: Config + crate::session_info::Config,
// TODO: use HandleReports instead?
R: ReportOffence<
AccountId<T>,
IdentificationTuple<T>,
ForInvalidOffence<IdentificationTuple<T>>,
> + ReportOffence<
AccountId<T>,
IdentificationTuple<T>,
AgainstValidOffence<IdentificationTuple<T>>,
>,
T: Config<KeyOwnerIdentification = IdentificationTuple<T>> + crate::session_info::Config,
{
fn punish_for_invalid(
session_index: SessionIndex,
Expand All @@ -231,10 +245,7 @@ where
let account_keys = crate::session_info::Pallet::<T>::account_keys(session_index);
let account_ids = match account_keys {
Some(account_keys) => account_keys,
None => {
// TODO: warn
return
},
None => return, // can not really happen
};
let winners: Winners<T> = winners
.into_iter()
Expand All @@ -245,8 +256,9 @@ where
if let Some((offenders, validator_set_count)) = maybe {
let time_slot = DisputesTimeSlot::new(session_index, candidate_hash);
let offence = ForInvalidOffence { validator_set_count, time_slot, offenders };
// TODO: log error?
let _ = R::report_offence(winners, offence);
// This is the first time we report an offence for this dispute,
// so it is not a duplicate
let _ = T::HandleReports::report_for_invalid_offence(winners, offence);
return
}

Expand All @@ -268,10 +280,7 @@ where
let account_keys = crate::session_info::Pallet::<T>::account_keys(session_index);
let account_ids = match account_keys {
Some(account_keys) => account_keys,
None => {
// TODO: warn
return
},
None => return, // can not really happen
};
let winners: Winners<T> = winners
.into_iter()
Expand All @@ -282,8 +291,9 @@ where
if let Some((offenders, validator_set_count)) = maybe {
let time_slot = DisputesTimeSlot::new(session_index, candidate_hash);
let offence = AgainstValidOffence { validator_set_count, time_slot, offenders };
// TODO: log error?
let _ = R::report_offence(winners, offence);
// This is the first time we report an offence for this dispute,
// so it is not a duplicate
let _ = T::HandleReports::report_against_valid_offence(winners, offence);
return
}

Expand Down Expand Up @@ -330,96 +340,34 @@ pub struct DisputeProof {
pub type Losers = BTreeSet<ValidatorIndex>;
pub type Winners<T> = Vec<AccountId<T>>;

pub trait SlashingOffence<KeyOwnerIdentification>: Offence<KeyOwnerIdentification> {
/// Create a new dispute offence using the given details.
fn new(
session_index: SessionIndex,
candidate_hash: CandidateHash,
validator_set_count: u32,
offender: KeyOwnerIdentification,
) -> Self;

/// Create a new dispute offence time slot.
fn new_time_slot(session_index: SessionIndex, candidate_hash: CandidateHash) -> Self::TimeSlot;
}

impl<KeyOwnerIdentification> SlashingOffence<KeyOwnerIdentification>
for ForInvalidOffence<KeyOwnerIdentification>
where
KeyOwnerIdentification: Clone,
{
fn new(
session_index: SessionIndex,
candidate_hash: CandidateHash,
validator_set_count: u32,
offender: KeyOwnerIdentification,
) -> Self {
let time_slot = Self::new_time_slot(session_index, candidate_hash);
Self { time_slot, validator_set_count, offenders: vec![offender] }
}

fn new_time_slot(session_index: SessionIndex, candidate_hash: CandidateHash) -> Self::TimeSlot {
DisputesTimeSlot { session_index, candidate_hash }
}
}

impl<KeyOwnerIdentification> SlashingOffence<KeyOwnerIdentification>
for AgainstValidOffence<KeyOwnerIdentification>
where
KeyOwnerIdentification: Clone,
{
fn new(
session_index: SessionIndex,
candidate_hash: CandidateHash,
validator_set_count: u32,
offender: KeyOwnerIdentification,
) -> Self {
let time_slot = Self::new_time_slot(session_index, candidate_hash);
Self { time_slot, validator_set_count, offenders: vec![offender] }
}

fn new_time_slot(session_index: SessionIndex, candidate_hash: CandidateHash) -> Self::TimeSlot {
DisputesTimeSlot { session_index, candidate_hash }
}
}

// TODO: does it need to be that generic?
// TODO: docs
pub trait HandleReports<T: Config> {
/// The offence type used for reporting offences on valid reports for disputes
/// lost about a valid candidate.
type OffenceForInvalid: SlashingOffence<T::KeyOwnerIdentification>;

/// The offence type used for reporting offences on valid reports for disputes
/// lost about an invalid candidate.
type OffenceAgainstValid: SlashingOffence<T::KeyOwnerIdentification>;

/// The longevity, in blocks, that the offence report is valid for. When using the staking
/// pallet this should be equal to the bonding duration (in blocks, not eras).
type ReportLongevity: Get<u64>;

/// Report a for valid offence.
// TODO: generic over reporter type?
/// Report a `for valid` offence.
fn report_for_invalid_offence(
reporters: Vec<AccountId<T>>,
offence: Self::OffenceForInvalid,
offence: ForInvalidOffence<T::KeyOwnerIdentification>,
) -> Result<(), OffenceError>;

/// Report an against invalid offence.
fn report_against_valid_offence(
reporters: Vec<AccountId<T>>,
offence: Self::OffenceAgainstValid,
offence: AgainstValidOffence<T::KeyOwnerIdentification>,
) -> Result<(), OffenceError>;

/// Returns true if the offenders at the given time slot has already been reported.
fn is_known_for_invalid_offence(
offenders: &[T::KeyOwnerIdentification],
time_slot: &<Self::OffenceForInvalid as Offence<T::KeyOwnerIdentification>>::TimeSlot,
time_slot: &DisputesTimeSlot,
) -> bool;

/// Returns true if the offenders at the given time slot has already been reported.
fn is_known_against_valid_offence(
offenders: &[T::KeyOwnerIdentification],
time_slot: &<Self::OffenceAgainstValid as Offence<T::KeyOwnerIdentification>>::TimeSlot,
time_slot: &DisputesTimeSlot,
) -> bool;

/// Create and dispatch a slashing report extrinsic.
Expand All @@ -431,34 +379,32 @@ pub trait HandleReports<T: Config> {
}

impl<T: Config> HandleReports<T> for () {
type OffenceForInvalid = ForInvalidOffence<T::KeyOwnerIdentification>;
type OffenceAgainstValid = AgainstValidOffence<T::KeyOwnerIdentification>;
type ReportLongevity = ();

fn report_for_invalid_offence(
_reporters: Vec<AccountId<T>>,
_offence: Self::OffenceForInvalid,
_offence: ForInvalidOffence<T::KeyOwnerIdentification>,
) -> Result<(), OffenceError> {
Ok(())
}

fn report_against_valid_offence(
_reporters: Vec<AccountId<T>>,
_offence: Self::OffenceAgainstValid,
_offence: AgainstValidOffence<T::KeyOwnerIdentification>,
) -> Result<(), OffenceError> {
Ok(())
}

fn is_known_for_invalid_offence(
_offenders: &[T::KeyOwnerIdentification],
_time_slot: &<Self::OffenceForInvalid as Offence<T::KeyOwnerIdentification>>::TimeSlot,
_time_slot: &DisputesTimeSlot,
) -> bool {
true
}

fn is_known_against_valid_offence(
_offenders: &[T::KeyOwnerIdentification],
_time_slot: &<Self::OffenceAgainstValid as Offence<T::KeyOwnerIdentification>>::TimeSlot,
_time_slot: &DisputesTimeSlot,
) -> bool {
true
}
Expand Down Expand Up @@ -491,11 +437,9 @@ pub mod pallet {

#[pallet::config]
pub trait Config: frame_system::Config + crate::disputes::Config {
// type Event: From<Event<Self>> + IsType<<Self as frame_system::Config>::Event>;

/// The proof of key ownership, used for validating slashing reports.
/// The proof must include the session index and validator count of the
/// session at which the equivocation occurred.
/// session at which the offence occurred.
type KeyOwnerProof: Parameter + GetSessionNumber + GetValidatorCount;

/// The identification of a key owner, used when reporting slashes.
Expand Down Expand Up @@ -634,7 +578,7 @@ pub mod pallet {
let winners = <ForInvalidWinners<T>>::get(&session_index, &candidate_hash)
.unwrap_or_default();

let offence = <T::HandleReports as HandleReports<T>>::OffenceForInvalid::new(
let offence = ForInvalidOffence::new(
session_index,
candidate_hash,
validator_set_count,
Expand All @@ -659,7 +603,7 @@ pub mod pallet {
.unwrap_or_default();

// submit an offence report
let offence = <T::HandleReports as HandleReports<T>>::OffenceAgainstValid::new(
let offence = AgainstValidOffence::new(
session_index,
candidate_hash,
validator_set_count,
Expand Down Expand Up @@ -783,30 +727,16 @@ fn is_known_offence<T: Config>(
// check if the offence has already been reported,
// and if so then we can discard the report.
let is_known_offence = match dispute_proof.kind {
SlashingOffenceKind::ForInvalid => {
let time_slot =
<T::HandleReports as HandleReports<T>>::OffenceForInvalid::new_time_slot(
dispute_proof.time_slot.session_index,
dispute_proof.time_slot.candidate_hash,
);

SlashingOffenceKind::ForInvalid =>
<T::HandleReports as HandleReports<T>>::is_known_for_invalid_offence(
&[offender],
&time_slot,
)
},
SlashingOffenceKind::AgainstValid => {
let time_slot =
<T::HandleReports as HandleReports<T>>::OffenceAgainstValid::new_time_slot(
dispute_proof.time_slot.session_index,
dispute_proof.time_slot.candidate_hash,
);

&dispute_proof.time_slot,
),
SlashingOffenceKind::AgainstValid =>
<T::HandleReports as HandleReports<T>>::is_known_against_valid_offence(
&[offender],
&time_slot,
)
},
&dispute_proof.time_slot,
),
};

if is_known_offence {
Expand Down Expand Up @@ -841,22 +771,18 @@ where
>,
L: Get<u64>,
{
type OffenceForInvalid = ForInvalidOffence<T::KeyOwnerIdentification>;

type OffenceAgainstValid = AgainstValidOffence<T::KeyOwnerIdentification>;

type ReportLongevity = L;

fn report_for_invalid_offence(
reporters: Vec<AccountId<T>>,
offence: Self::OffenceForInvalid,
offence: ForInvalidOffence<T::KeyOwnerIdentification>,
) -> Result<(), OffenceError> {
R::report_offence(reporters, offence)
}

fn report_against_valid_offence(
reporters: Vec<AccountId<T>>,
offence: Self::OffenceAgainstValid,
offence: AgainstValidOffence<T::KeyOwnerIdentification>,
) -> Result<(), OffenceError> {
R::report_offence(reporters, offence)
}
Expand Down
2 changes: 1 addition & 1 deletion runtime/westend/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -941,7 +941,7 @@ impl assigned_slots::Config for Runtime {

impl parachains_disputes::Config for Runtime {
type Event = Event;
type SlashingHandler = parachains_slashing::SlashValidatorsForDisputes<ParasSlashing, Offences>;
type SlashingHandler = parachains_slashing::SlashValidatorsForDisputes<ParasSlashing>;
type WeightInfo = weights::runtime_parachains_disputes::WeightInfo<Runtime>;
}

Expand Down