-
Notifications
You must be signed in to change notification settings - Fork 248
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Introduce the intentional malicious operator #2302
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Overall looks good. Will do another pass before approavl
crates/subspace-malicious-operator/src/bin/subspace-malicious-operator.rs
Outdated
Show resolved
Hide resolved
crates/subspace-malicious-operator/src/malicious_bundle_producer.rs
Outdated
Show resolved
Hide resolved
… as argument So the DomainBundleProducer can be reused to produce bundle for different operator when different operator ID is pass Signed-off-by: linning <[email protected]>
This commit add some domain runtime API that required by the upcoming intentional malicious operator Signed-off-by: linning <[email protected]>
…alicious operator Signed-off-by: linning <[email protected]>
This crate contains the minimal required infra for setup an operator node, most of the code are ported from subspace-node, it will be used as the base of the malicious operator Signed-off-by: linning <[email protected]>
It is will be used within the malicious operator to randomly temper normal bundle to be invalid bundle and/or contains bad ER with probability Signed-off-by: linning <[email protected]>
The MaliciousBundleProducer act similar as the normal bundle producer except it may randomly temper the bundle into a invalid bundle and/or contains bad ER with probability before submitting it to the consensus chain Signed-off-by: linning <[email protected]>
…perator when it is slashed This commit also enforce epoch transition immediately to accelerate the onboard of the new malicious operator, also it increase the endowed balance of the sudo account to ensure it always have enough balance to register operator Signed-off-by: linning <[email protected]>
Signed-off-by: linning <[email protected]>
Signed-off-by: linning <[email protected]>
24160c0
to
44ee11f
Compare
:( you rebased all commits. would have preffered merging instead if there were conflicts |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Make sense! But some non-blocking comments
- I think we would also need to introduce bundle equivocation
- Would be nice to reduce the duplicated code in to common crate that can be used across or else we have to worry about updating multiple different places
Yeah, the malicious operator will support more misbehavior in the future, including bundle equivocation and invalid fraud proof, I will create a fraud proof to track this.
Ideally, we should reduce the duplicated code in |
This PR introduces the intentional malicious operator, which is used for testing purposes only to test the network's capability of handling malicious participants.
Please refer to README for how it works and how to use.
Code contributor checklist: