5828ff1204
This is an implementation of a slasher that lives inside the BN and can be enabled via `lighthouse bn --slasher`. Features included in this PR: - [x] Detection of attester slashing conditions (double votes, surrounds existing, surrounded by existing) - [x] Integration into Lighthouse's attestation verification flow - [x] Detection of proposer slashing conditions - [x] Extraction of attestations from blocks as they are verified - [x] Compression of chunks - [x] Configurable history length - [x] Pruning of old attestations and blocks - [x] More tests Future work: * Focus on a slice of history separate from the most recent N epochs (e.g. epochs `current - K` to `current - M`) * Run out-of-process * Ingest attestations from the chain without a resync Design notes are here https://hackmd.io/@sproul/HJSEklmPL
34 lines
722 B
TOML
34 lines
722 B
TOML
[package]
|
|
name = "store"
|
|
version = "0.2.0"
|
|
authors = ["Paul Hauner <paul@paulhauner.com>"]
|
|
edition = "2018"
|
|
|
|
[[bench]]
|
|
name = "benches"
|
|
harness = false
|
|
|
|
[dev-dependencies]
|
|
tempfile = "3.1.0"
|
|
criterion = "0.3.3"
|
|
rayon = "1.4.1"
|
|
|
|
[dependencies]
|
|
db-key = "0.0.5"
|
|
leveldb = "0.8.6"
|
|
parking_lot = "0.11.0"
|
|
itertools = "0.9.0"
|
|
eth2_ssz = "0.1.2"
|
|
eth2_ssz_derive = "0.1.0"
|
|
tree_hash = "0.1.1"
|
|
types = { path = "../../consensus/types" }
|
|
state_processing = { path = "../../consensus/state_processing" }
|
|
slog = "2.5.2"
|
|
serde = "1.0.116"
|
|
serde_derive = "1.0.116"
|
|
lazy_static = "1.4.0"
|
|
lighthouse_metrics = { path = "../../common/lighthouse_metrics" }
|
|
lru = "0.6.0"
|
|
sloggers = "1.0.1"
|
|
directory = { path = "../../common/directory" }
|