Skip to content

Commit dbfd397

Browse files
ryanschneiderfjl
andauthored
cmd/geth: rename --whitelist to --eth.requiredblocks (ethereum#24505)
* cmd, eth: Rename whitelist argument to peer.requiredblocks * eth/ethconfig: document PeerRequiredBlocks better * cmd/utils: rename new flag to --eth.requiredblocks Co-authored-by: Felix Lange <fjl@twurst.com>
1 parent 6cd7266 commit dbfd397

File tree

7 files changed

+68
-52
lines changed

7 files changed

+68
-52
lines changed

cmd/geth/main.go

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -107,7 +107,8 @@ var (
107107
utils.UltraLightFractionFlag,
108108
utils.UltraLightOnlyAnnounceFlag,
109109
utils.LightNoSyncServeFlag,
110-
utils.WhitelistFlag,
110+
utils.EthPeerRequiredBlocksFlag,
111+
utils.LegacyWhitelistFlag,
111112
utils.BloomFilterSizeFlag,
112113
utils.CacheFlag,
113114
utils.CacheDatabaseFlag,

cmd/geth/usage.go

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -53,7 +53,7 @@ var AppHelpFlagGroups = []flags.FlagGroup{
5353
utils.EthStatsURLFlag,
5454
utils.IdentityFlag,
5555
utils.LightKDFFlag,
56-
utils.WhitelistFlag,
56+
utils.EthPeerRequiredBlocksFlag,
5757
},
5858
},
5959
{
@@ -225,6 +225,7 @@ var AppHelpFlagGroups = []flags.FlagGroup{
225225
Name: "ALIASED (deprecated)",
226226
Flags: []cli.Flag{
227227
utils.NoUSBFlag,
228+
utils.LegacyWhitelistFlag,
228229
},
229230
},
230231
{

cmd/utils/flags.go

Lines changed: 24 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -237,9 +237,13 @@ var (
237237
Name: "lightkdf",
238238
Usage: "Reduce key-derivation RAM & CPU usage at some expense of KDF strength",
239239
}
240-
WhitelistFlag = cli.StringFlag{
240+
EthPeerRequiredBlocksFlag = cli.StringFlag{
241+
Name: "eth.requiredblocks",
242+
Usage: "Comma separated block number-to-hash mappings to require for peering (<number>=<hash>)",
243+
}
244+
LegacyWhitelistFlag = cli.StringFlag{
241245
Name: "whitelist",
242-
Usage: "Comma separated block number-to-hash mappings to enforce (<number>=<hash>)",
246+
Usage: "Comma separated block number-to-hash mappings to enforce (<number>=<hash>) (deprecated in favor of --peer.requiredblocks)",
243247
}
244248
BloomFilterSizeFlag = cli.Uint64Flag{
245249
Name: "bloomfilter.size",
@@ -1447,26 +1451,33 @@ func setMiner(ctx *cli.Context, cfg *miner.Config) {
14471451
}
14481452
}
14491453

1450-
func setWhitelist(ctx *cli.Context, cfg *ethconfig.Config) {
1451-
whitelist := ctx.GlobalString(WhitelistFlag.Name)
1452-
if whitelist == "" {
1453-
return
1454+
func setPeerRequiredBlocks(ctx *cli.Context, cfg *ethconfig.Config) {
1455+
peerRequiredBlocks := ctx.GlobalString(EthPeerRequiredBlocksFlag.Name)
1456+
1457+
if peerRequiredBlocks == "" {
1458+
if ctx.GlobalIsSet(LegacyWhitelistFlag.Name) {
1459+
log.Warn("The flag --rpc is deprecated and will be removed, please use --peer.requiredblocks")
1460+
peerRequiredBlocks = ctx.GlobalString(LegacyWhitelistFlag.Name)
1461+
} else {
1462+
return
1463+
}
14541464
}
1455-
cfg.Whitelist = make(map[uint64]common.Hash)
1456-
for _, entry := range strings.Split(whitelist, ",") {
1465+
1466+
cfg.PeerRequiredBlocks = make(map[uint64]common.Hash)
1467+
for _, entry := range strings.Split(peerRequiredBlocks, ",") {
14571468
parts := strings.Split(entry, "=")
14581469
if len(parts) != 2 {
1459-
Fatalf("Invalid whitelist entry: %s", entry)
1470+
Fatalf("Invalid peer required block entry: %s", entry)
14601471
}
14611472
number, err := strconv.ParseUint(parts[0], 0, 64)
14621473
if err != nil {
1463-
Fatalf("Invalid whitelist block number %s: %v", parts[0], err)
1474+
Fatalf("Invalid peer required block number %s: %v", parts[0], err)
14641475
}
14651476
var hash common.Hash
14661477
if err = hash.UnmarshalText([]byte(parts[1])); err != nil {
1467-
Fatalf("Invalid whitelist hash %s: %v", parts[1], err)
1478+
Fatalf("Invalid peer required block hash %s: %v", parts[1], err)
14681479
}
1469-
cfg.Whitelist[number] = hash
1480+
cfg.PeerRequiredBlocks[number] = hash
14701481
}
14711482
}
14721483

@@ -1533,7 +1544,7 @@ func SetEthConfig(ctx *cli.Context, stack *node.Node, cfg *ethconfig.Config) {
15331544
setTxPool(ctx, &cfg.TxPool)
15341545
setEthash(ctx, cfg)
15351546
setMiner(ctx, &cfg.Miner)
1536-
setWhitelist(ctx, cfg)
1547+
setPeerRequiredBlocks(ctx, cfg)
15371548
setLes(ctx, cfg)
15381549

15391550
// Cap the cache allowance and tune the garbage collector

eth/backend.go

Lines changed: 10 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -220,16 +220,16 @@ func New(stack *node.Node, config *ethconfig.Config) (*Ethereum, error) {
220220
checkpoint = params.TrustedCheckpoints[genesisHash]
221221
}
222222
if eth.handler, err = newHandler(&handlerConfig{
223-
Database: chainDb,
224-
Chain: eth.blockchain,
225-
TxPool: eth.txPool,
226-
Merger: merger,
227-
Network: config.NetworkId,
228-
Sync: config.SyncMode,
229-
BloomCache: uint64(cacheLimit),
230-
EventMux: eth.eventMux,
231-
Checkpoint: checkpoint,
232-
Whitelist: config.Whitelist,
223+
Database: chainDb,
224+
Chain: eth.blockchain,
225+
TxPool: eth.txPool,
226+
Merger: merger,
227+
Network: config.NetworkId,
228+
Sync: config.SyncMode,
229+
BloomCache: uint64(cacheLimit),
230+
EventMux: eth.eventMux,
231+
Checkpoint: checkpoint,
232+
PeerRequiredBlocks: config.PeerRequiredBlocks,
233233
}); err != nil {
234234
return nil, err
235235
}

eth/ethconfig/config.go

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -138,8 +138,10 @@ type Config struct {
138138

139139
TxLookupLimit uint64 `toml:",omitempty"` // The maximum number of blocks from head whose tx indices are reserved.
140140

141-
// Whitelist of required block number -> hash values to accept
142-
Whitelist map[uint64]common.Hash `toml:"-"`
141+
// PeerRequiredBlocks is a set of block number -> hash mappings which must be in the
142+
// canonical chain of all remote peers. Setting the option makes geth verify the
143+
// presence of these blocks for every new peer connection.
144+
PeerRequiredBlocks map[uint64]common.Hash `toml:"-"`
143145

144146
// Light client options
145147
LightServ int `toml:",omitempty"` // Maximum percentage of time allowed for serving LES requests

eth/ethconfig/gen_config.go

Lines changed: 5 additions & 5 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

eth/handler.go

Lines changed: 21 additions & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -86,7 +86,8 @@ type handlerConfig struct {
8686
BloomCache uint64 // Megabytes to alloc for snap sync bloom
8787
EventMux *event.TypeMux // Legacy event mux, deprecate for `feed`
8888
Checkpoint *params.TrustedCheckpoint // Hard coded checkpoint for sync challenges
89-
Whitelist map[uint64]common.Hash // Hard coded whitelist for sync challenged
89+
90+
PeerRequiredBlocks map[uint64]common.Hash // Hard coded map of required block hashes for sync challenges
9091
}
9192

9293
type handler struct {
@@ -115,7 +116,7 @@ type handler struct {
115116
txsSub event.Subscription
116117
minedBlockSub *event.TypeMuxSubscription
117118

118-
whitelist map[uint64]common.Hash
119+
peerRequiredBlocks map[uint64]common.Hash
119120

120121
// channels for fetcher, syncer, txsyncLoop
121122
quitSync chan struct{}
@@ -132,16 +133,16 @@ func newHandler(config *handlerConfig) (*handler, error) {
132133
config.EventMux = new(event.TypeMux) // Nicety initialization for tests
133134
}
134135
h := &handler{
135-
networkID: config.Network,
136-
forkFilter: forkid.NewFilter(config.Chain),
137-
eventMux: config.EventMux,
138-
database: config.Database,
139-
txpool: config.TxPool,
140-
chain: config.Chain,
141-
peers: newPeerSet(),
142-
merger: config.Merger,
143-
whitelist: config.Whitelist,
144-
quitSync: make(chan struct{}),
136+
networkID: config.Network,
137+
forkFilter: forkid.NewFilter(config.Chain),
138+
eventMux: config.EventMux,
139+
database: config.Database,
140+
txpool: config.TxPool,
141+
chain: config.Chain,
142+
peers: newPeerSet(),
143+
merger: config.Merger,
144+
peerRequiredBlocks: config.PeerRequiredBlocks,
145+
quitSync: make(chan struct{}),
145146
}
146147
if config.Sync == downloader.FullSync {
147148
// The database seems empty as the current block is the genesis. Yet the snap
@@ -423,8 +424,8 @@ func (h *handler) runEthPeer(peer *eth.Peer, handler eth.Handler) error {
423424
}
424425
}()
425426
}
426-
// If we have any explicit whitelist block hashes, request them
427-
for number, hash := range h.whitelist {
427+
// If we have any explicit peer required block hashes, request them
428+
for number := range h.peerRequiredBlocks {
428429
resCh := make(chan *eth.Response)
429430
if _, err := peer.RequestHeadersByNumber(number, 1, 0, false, resCh); err != nil {
430431
return err
@@ -437,25 +438,25 @@ func (h *handler) runEthPeer(peer *eth.Peer, handler eth.Handler) error {
437438
case res := <-resCh:
438439
headers := ([]*types.Header)(*res.Res.(*eth.BlockHeadersPacket))
439440
if len(headers) == 0 {
440-
// Whitelisted blocks are allowed to be missing if the remote
441+
// Required blocks are allowed to be missing if the remote
441442
// node is not yet synced
442443
res.Done <- nil
443444
return
444445
}
445446
// Validate the header and either drop the peer or continue
446447
if len(headers) > 1 {
447-
res.Done <- errors.New("too many headers in whitelist response")
448+
res.Done <- errors.New("too many headers in required block response")
448449
return
449450
}
450451
if headers[0].Number.Uint64() != number || headers[0].Hash() != hash {
451-
peer.Log().Info("Whitelist mismatch, dropping peer", "number", number, "hash", headers[0].Hash(), "want", hash)
452-
res.Done <- errors.New("whitelist block mismatch")
452+
peer.Log().Info("Required block mismatch, dropping peer", "number", number, "hash", headers[0].Hash(), "want", hash)
453+
res.Done <- errors.New("required block mismatch")
453454
return
454455
}
455-
peer.Log().Debug("Whitelist block verified", "number", number, "hash", hash)
456+
peer.Log().Debug("Peer required block verified", "number", number, "hash", hash)
456457
res.Done <- nil
457458
case <-timeout.C:
458-
peer.Log().Warn("Whitelist challenge timed out, dropping", "addr", peer.RemoteAddr(), "type", peer.Name())
459+
peer.Log().Warn("Required block challenge timed out, dropping", "addr", peer.RemoteAddr(), "type", peer.Name())
459460
h.removePeer(peer.ID())
460461
}
461462
}(number, hash)

0 commit comments

Comments
 (0)