Skip to content

Commit 1bcd6bf

Browse files
nkryuchkovmoshe-blox
andauthoredOct 3, 2023
Message validation (#1066)
* Fix issues in tests * Fix linter * Fix TestSSVMapping * Attempt to fix fetchLogsInBatches * Revert "Attempt to fix fetchLogsInBatches" This reverts commit 96006c2. * Attempt to fix fetchLogsInBatches * Revert "Attempt to fix fetchLogsInBatches" This reverts commit 5a3d9de. * Revert "Fix TestSSVMapping" This reverts commit c3263c1. * Revert "Fix linter" This reverts commit 8f72bb2. * Revert "Fix issues in tests" This reverts commit 0720abb. * Change batch verifier params * Disable signature check * Revert "Disable signature check" This reverts commit 311c722. * Batch size 10 * Disable signature check * Use BLSU for signature verification * BLSU aggregate * Disable partial signature check * Disable consensus signature check * Fix linter * Revert "BLSU aggregate" * Revert "Use BLSU for signature verification" This reverts commit 6d4c15f. * AggregateVerify for partial signature * Simplify duplicated signer check * Fix error text * Fix check order * Fix issues in tests * Revert "Fix issues in tests" This reverts commit b40355c. * Move deployment to 5-8 * Fix some tests * Fix data race * Revert "Fix data race" This reverts commit e3596a2. * Attempt to fix data race * Revert "Attempt to fix data race" This reverts commit 38cce5f. * Attempt to fix data race [2] * Fix spec tests * Fix a data race * Fix a data race in tests bootstrapper * Fix differ config * Change message size metric to histogram * Fix some tests * Fix linter * Fix unit tests * More tests * Improve tests * More tests * More tests [2] * More tests [3] * Fix incorrect usage of errors.As in tests * More tests * Deploy to 1-4 instead of 5-8 * Add logs with message processing duration * Fix message validation duration buckets * Add logs/metrics with signature check duration * Disable duration logs * Use single verification * Revert "Use single verification" This reverts commit cae01d2. * More tests * Fix max duties check * More tests * Fix duty count validation * More tests * More tests * Fix duty count bug * Add message queue metrics * Fix a typo * Revert "Fix message validation duration buckets" This reverts commit 269340b. * Fix validation duration buckets * Cache serialized signature * Fix variable name * Revert "Fix variable name" This reverts commit 15345a2. * Revert "Cache serialized signature" This reverts commit 20245e2. * Queue len/cap as gauge * Add message validation dashboard * Enable signature checks * Disable signature verification for non-committee non-decided * Fix bug with committee check * Verify partial signatures only if in committee * Fix check * Simplify code * Add metrics if in committee * Fix value of InvalidMessageDeliveriesWeight * Deploy to 5-8 instead of 1-4 * Implement duty fetcher for message validation * Get rid of optsTemplate in validatorsMap * Make validators map exported and pass it to duty fetcher * Fix panic due to context passing * Simplify saving validators * Debug panic * Revert "Debug panic" This reverts commit 76c273f. * Revert "Simplify saving validators" This reverts commit b24d704. * Revert "Fix panic due to context passing" This reverts commit 44b47f3. * Revert "Make validators map exported and pass it to duty fetcher" This reverts commit 82ee64d. * Revert "Get rid of optsTemplate in validatorsMap" This reverts commit 20cc1b7. * Revert "Implement duty fetcher for message validation" This reverts commit dabc10a. * Implement duty fetcher for message validation * Fix context panic * Fix signature in message validation tests * Get rid of optsTemplate in validatorsMap * Fix condition * Make validators map exported and pass it to duty fetcher * Revert "Make validators map exported and pass it to duty fetcher" This reverts commit 65729f3. * Fix logic of validating beacon duty, add test * Make validators map exported and pass it to duty fetcher * Start duty fetcher * Revert "Start duty fetcher" This reverts commit cf3f51f. * Revert "Make validators map exported and pass it to duty fetcher" This reverts commit 563143c. * Start duty fetcher * Attempt to make validators map exported * Move ActiveValidatorIndices to ValidatorsMap * Use logger in DutyFetcher * Pass validators map from node to validator controller * Enable duty fetcher * Revert "Enable duty fetcher" This reverts commit 3648788. * Extract validator creation logic from validators map * Simplify creating validator * Delete redundant comment * Fix linter * Init and start duty fetcher but don't pass to message validator * Fix fetcher bug * Use fetcher * go mod tidy * Duty fetcher tests * Remove redundant file * Fix imports * Disable deployment * Enable signature check for all messages * Fix issues after merging * Fix .gitlab-ci.yml * Enable message validation in sync * Revert "Enable signature check for all messages" This reverts commit 8c692b9. * Deploy to 5-8 * Try blst verify * Try to fix error * Enable signature check for all messages * Revert "Enable signature check for all messages" This reverts commit b0849c8. * Revert "Try to fix error" This reverts commit 0c9d35f. * Revert "Try blst verify" This reverts commit 38bbe35. * Flag for signature verification in message validation * Optimization for SingleVerifyByOperators * Remove outdated comment * Delete unused errors * Try to fix bug with ErrTooManyDutiesPerEpoch * Code review requests * Try to fix bug with ErrTooManyDuties * Delete ErrUnexpectedMessageOrder * Delete ErrDecidedSignersSequence * Try RSA verification instead of BLS in most places * Enable signature check in message validation * Revert "Enable signature check in message validation" This reverts commit ef1a05c. * Revert "Try RSA verification instead of BLS in most places" This reverts commit 0e16b11. * Don't check for signature check flag in protocol * Revert "Don't check for signature check flag in protocol" This reverts commit 9f46933. * Add logs for config * Debugging * Debugging [2] * Debugging [3] * Debugging [4] * Debugging [5] * Debugging [6] * Add passing signature check for non-committee validators * Revert "Debugging [6]" This reverts commit d4d99d0. * Revert "Debugging [5]" This reverts commit 425f30b. * Revert "Debugging [4]" This reverts commit a5ade77. * Revert "Debugging [3]" This reverts commit 97398bc. * Revert "Debugging [2]" This reverts commit 91b4507. * Revert "Debugging" This reverts commit adb769f. * Revert "Add logs for config" This reverts commit f016ace. * Try RSA verification instead of BLS in most places * Enable signature check in message validation * Revert "Try RSA verification instead of BLS in most places" This reverts commit 29a196e. * Revert "Enable signature check in message validation" This reverts commit 080d876. * Try to fix bug with ErrTooManyDutiesPerEpoch * fetch metadata for all validators * LA Audit (#1136) * Audits Directory * add to README * Update dashboard * Revert "fetch metadata for all validators" This reverts commit 68df177. * fetch metadata for all validators * Fix differ * Attempt to fix duty fetcher * Fix panic * Fix duty fetcher tests * Fix event handler tests * Add ErrNoShareMetadata * Add test for ErrNoShareMetadata * Revert differ change * Get rid of type assertions/switches * Extract duty storage from duty scheduler * Fetch all duties, process only committee duties for proposer * Fetch all duties, process only committee duties for sync committee * Deploy to 1-4 as well * Fix potential nil ptr dereference * Forbid consensus message with validator registration role * Revert message queue changes * Check message counts for partial signature messages * Add role and round to metrics * Update Grafana * Update Grafana * WIP on rejection/banning test * rename `dutystorage` to `dutystore` * refactor * refator MessageValidator to an interface * update Grafana dashboard * Don't start validator registration duty if not attesting * Test improvements from Andrew * Fix docker build * Update bind-tools * Cleanup * rename `CheckSignature` to `VerifySignatures` * Enable nil config checks * Create qbft config in message validation * Revert "Enable nil config checks" This reverts commit 5b547d9. * Fix panic * Fix panic [2] * Add signature check option * Add godoc * Disable deployment * Reset epoch/period for previous one instead of current one * Revert "Disable deployment" This reverts commit cb585d3. * Fix duplication bug * keep old duties * Revert "Reset epoch/period for previous one instead of current one" This reverts commit 0a803a0. * Disable deployment * Revert "Disable deployment" This reverts commit cfd23f8. * Cleanup a TODO * Disable deployment * Revert "Disable deployment" This reverts commit cc0ab52. * Pass context instead of logger to message router * Add a test for GetSlotEndTime * performance optimization * change YAML representation of msg validation sig flag & add log * extract batch verifier to separate file * approve spec alignment * fix test * Delete debug.log * Disable deployment * Disable batch verifier * Fix compilation * Delete batch verifier * Simplify GetSignerState * Add a note about NTP * go mod tidy --------- Co-authored-by: moshe-blox <[email protected]> Co-authored-by: moshe-blox <[email protected]>
1 parent 131a2f2 commit 1bcd6bf

File tree

98 files changed

+7618
-1172
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

98 files changed

+7618
-1172
lines changed
 

‎Dockerfile

+1-2
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,6 @@ RUN apt-get update && \
99
git=1:2.39.2-1.1 \
1010
zip=3.0-13 \
1111
unzip=6.0-28 \
12-
wget=1.21.3-1+b2 \
1312
g++=4:12.2.0-3 \
1413
gcc-aarch64-linux-gnu=4:12.2.0-3 \
1514
bzip2=1.0.8-5+b1 \
@@ -61,7 +60,7 @@ RUN apk -v --update add \
6160
ca-certificates=20230506-r0 \
6261
bash=5.2.15-r5 \
6362
make=4.4.1-r1 \
64-
bind-tools=9.18.16-r0 && \
63+
bind-tools=9.18.19-r0 && \
6564
rm /var/cache/apk/*
6665

6766
COPY --from=builder /go/bin/ssvnode /go/bin/ssvnode

‎cli/operator/node.go

+50-27
Original file line numberDiff line numberDiff line change
@@ -19,7 +19,6 @@ import (
1919

2020
"github.com/bloxapp/ssv/api/handlers"
2121
apiserver "github.com/bloxapp/ssv/api/server"
22-
2322
"github.com/bloxapp/ssv/beacon/goclient"
2423
global_config "github.com/bloxapp/ssv/cli/config"
2524
"github.com/bloxapp/ssv/ekm"
@@ -34,6 +33,7 @@ import (
3433
ssv_identity "github.com/bloxapp/ssv/identity"
3534
"github.com/bloxapp/ssv/logging"
3635
"github.com/bloxapp/ssv/logging/fields"
36+
"github.com/bloxapp/ssv/message/validation"
3737
"github.com/bloxapp/ssv/migrations"
3838
"github.com/bloxapp/ssv/monitoring/metrics"
3939
"github.com/bloxapp/ssv/monitoring/metricsreporter"
@@ -42,9 +42,11 @@ import (
4242
"github.com/bloxapp/ssv/networkconfig"
4343
"github.com/bloxapp/ssv/nodeprobe"
4444
"github.com/bloxapp/ssv/operator"
45+
"github.com/bloxapp/ssv/operator/duties/dutystore"
4546
"github.com/bloxapp/ssv/operator/slot_ticker"
4647
operatorstorage "github.com/bloxapp/ssv/operator/storage"
4748
"github.com/bloxapp/ssv/operator/validator"
49+
"github.com/bloxapp/ssv/operator/validatorsmap"
4850
beaconprotocol "github.com/bloxapp/ssv/protocol/v2/blockchain/beacon"
4951
"github.com/bloxapp/ssv/protocol/v2/types"
5052
registrystorage "github.com/bloxapp/ssv/registry/storage"
@@ -60,6 +62,10 @@ type KeyStore struct {
6062
PasswordFile string `yaml:"PasswordFile" env:"PASSWORD_FILE" env-description:"Password for operator private key file decryption"`
6163
}
6264

65+
type MessageValidation struct {
66+
VerifySignatures bool `yaml:"VerifySignatures" env:"MESSAGE_VALIDATION_VERIFY_SIGNATURES" env-default:"false" env-description:"Experimental feature to verify signatures in pubsub's message validation instead of in consensus protocol."`
67+
}
68+
6369
type config struct {
6470
global_config.GlobalConfig `yaml:"global"`
6571
DBOptions basedb.Options `yaml:"db"`
@@ -72,13 +78,11 @@ type config struct {
7278
MetricsAPIPort int `yaml:"MetricsAPIPort" env:"METRICS_API_PORT" env-description:"Port to listen on for the metrics API."`
7379
EnableProfile bool `yaml:"EnableProfile" env:"ENABLE_PROFILE" env-description:"flag that indicates whether go profiling tools are enabled"`
7480
NetworkPrivateKey string `yaml:"NetworkPrivateKey" env:"NETWORK_PRIVATE_KEY" env-description:"private key for network identity"`
75-
76-
WsAPIPort int `yaml:"WebSocketAPIPort" env:"WS_API_PORT" env-description:"Port to listen on for the websocket API."`
77-
WithPing bool `yaml:"WithPing" env:"WITH_PING" env-description:"Whether to send websocket ping messages'"`
78-
79-
SSVAPIPort int `yaml:"SSVAPIPort" env:"SSV_API_PORT" env-description:"Port to listen on for the SSV API."`
80-
81-
LocalEventsPath string `yaml:"LocalEventsPath" env:"EVENTS_PATH" env-description:"path to local events"`
81+
WsAPIPort int `yaml:"WebSocketAPIPort" env:"WS_API_PORT" env-description:"Port to listen on for the websocket API."`
82+
WithPing bool `yaml:"WithPing" env:"WITH_PING" env-description:"Whether to send websocket ping messages'"`
83+
SSVAPIPort int `yaml:"SSVAPIPort" env:"SSV_API_PORT" env-description:"Port to listen on for the SSV API."`
84+
LocalEventsPath string `yaml:"LocalEventsPath" env:"EVENTS_PATH" env-description:"path to local events"`
85+
MessageValidation MessageValidation `yaml:"MessageValidation"`
8286
}
8387

8488
var cfg config
@@ -97,6 +101,11 @@ var StartNodeCmd = &cobra.Command{
97101
log.Fatal("could not create logger", err)
98102
}
99103
defer logging.CapturePanic(logger)
104+
105+
metricsReporter := metricsreporter.New(
106+
metricsreporter.WithLogger(logger),
107+
)
108+
100109
networkConfig, err := setupSSVNetwork(logger)
101110
if err != nil {
102111
logger.Fatal("could not setup network", zap.Error(err))
@@ -128,23 +137,9 @@ var StartNodeCmd = &cobra.Command{
128137
return currentEpoch >= cfg.P2pNetworkConfig.PermissionedActivateEpoch && currentEpoch < cfg.P2pNetworkConfig.PermissionedDeactivateEpoch
129138
}
130139

131-
cfg.P2pNetworkConfig.Permissioned = permissioned
132-
cfg.P2pNetworkConfig.WhitelistedOperatorKeys = append(cfg.P2pNetworkConfig.WhitelistedOperatorKeys, networkConfig.WhitelistedOperatorKeys...)
133-
cfg.P2pNetworkConfig.NodeStorage = nodeStorage
134-
cfg.P2pNetworkConfig.OperatorID = format.OperatorID(operatorData.PublicKey)
135-
cfg.P2pNetworkConfig.FullNode = cfg.SSVOptions.ValidatorOptions.FullNode
136-
cfg.P2pNetworkConfig.Network = networkConfig
137-
138-
p2pNetwork := setupP2P(logger, db)
139-
140140
slotTicker := slot_ticker.NewTicker(cmd.Context(), networkConfig)
141141

142-
metricsReporter := metricsreporter.New(
143-
metricsreporter.WithLogger(logger),
144-
)
145-
146142
cfg.ConsensusClient.Context = cmd.Context()
147-
148143
cfg.ConsensusClient.Graffiti = []byte("SSV.Network")
149144
cfg.ConsensusClient.GasLimit = spectypes.DefaultGasLimit
150145
cfg.ConsensusClient.Network = networkConfig.Beacon.GetNetwork()
@@ -166,6 +161,36 @@ var StartNodeCmd = &cobra.Command{
166161
logger.Fatal("could not connect to execution client", zap.Error(err))
167162
}
168163

164+
cfg.P2pNetworkConfig.Permissioned = permissioned
165+
cfg.P2pNetworkConfig.WhitelistedOperatorKeys = append(cfg.P2pNetworkConfig.WhitelistedOperatorKeys, networkConfig.WhitelistedOperatorKeys...)
166+
cfg.P2pNetworkConfig.NodeStorage = nodeStorage
167+
cfg.P2pNetworkConfig.OperatorID = format.OperatorID(operatorData.PublicKey)
168+
cfg.P2pNetworkConfig.FullNode = cfg.SSVOptions.ValidatorOptions.FullNode
169+
cfg.P2pNetworkConfig.Network = networkConfig
170+
171+
validatorsMap := validatorsmap.New(cmd.Context())
172+
173+
dutyStore := dutystore.New()
174+
cfg.SSVOptions.DutyStore = dutyStore
175+
176+
messageValidator := validation.NewMessageValidator(
177+
networkConfig,
178+
validation.WithShareStorage(nodeStorage.Shares()),
179+
validation.WithLogger(logger),
180+
validation.WithMetrics(metricsReporter),
181+
validation.WithDutyStore(dutyStore),
182+
validation.WithOwnOperatorID(operatorData.ID),
183+
validation.WithSignatureVerification(cfg.MessageValidation.VerifySignatures),
184+
)
185+
186+
cfg.P2pNetworkConfig.Metrics = metricsReporter
187+
cfg.P2pNetworkConfig.MessageValidator = messageValidator
188+
cfg.SSVOptions.ValidatorOptions.MessageValidator = messageValidator
189+
// if signature check is enabled in message validation then it's disabled in validator controller and vice versa
190+
cfg.SSVOptions.ValidatorOptions.VerifySignatures = !cfg.MessageValidation.VerifySignatures
191+
192+
p2pNetwork := setupP2P(logger, db)
193+
169194
cfg.SSVOptions.Context = cmd.Context()
170195
cfg.SSVOptions.DB = db
171196
cfg.SSVOptions.BeaconNode = consensusClient
@@ -178,6 +203,7 @@ var StartNodeCmd = &cobra.Command{
178203
cfg.SSVOptions.ValidatorOptions.Network = p2pNetwork
179204
cfg.SSVOptions.ValidatorOptions.Beacon = consensusClient
180205
cfg.SSVOptions.ValidatorOptions.KeyManager = keyManager
206+
cfg.SSVOptions.ValidatorOptions.ValidatorsMap = validatorsMap
181207

182208
cfg.SSVOptions.ValidatorOptions.ShareEncryptionKeyProvider = nodeStorage.GetPrivateKey
183209
cfg.SSVOptions.ValidatorOptions.OperatorData = operatorData
@@ -209,10 +235,10 @@ var StartNodeCmd = &cobra.Command{
209235

210236
cfg.SSVOptions.ValidatorOptions.StorageMap = storageMap
211237
cfg.SSVOptions.ValidatorOptions.Metrics = metricsReporter
238+
cfg.SSVOptions.Metrics = metricsReporter
212239

213240
validatorCtrl := validator.NewController(logger, cfg.SSVOptions.ValidatorOptions)
214241
cfg.SSVOptions.ValidatorController = validatorCtrl
215-
cfg.SSVOptions.Metrics = metricsReporter
216242

217243
operatorNode = operator.New(logger, cfg.SSVOptions, slotTicker)
218244

@@ -477,10 +503,7 @@ func setupSSVNetwork(logger *zap.Logger) (networkconfig.NetworkConfig, error) {
477503
return networkConfig, nil
478504
}
479505

480-
func setupP2P(
481-
logger *zap.Logger,
482-
db basedb.Database,
483-
) network.P2PNetwork {
506+
func setupP2P(logger *zap.Logger, db basedb.Database) network.P2PNetwork {
484507
istore := ssv_identity.NewIdentityStore(db)
485508
netPrivKey, err := istore.SetupNetworkKey(logger, cfg.NetworkPrivateKey)
486509
if err != nil {

0 commit comments

Comments
 (0)