cmd/swarm, p2p, swarm: Enable ENR in binary/execadapter (#19309)
* cmd/swarm, p2p, swarm: Enable ENR in binary/execadapter * cmd/p2p/swarm: Remove comments + config.Enode nomarshal * p2p/simulations: Remove superfluous error check * p2p/simulation: Move init enode comment * swarm/api: Check error in config test * swarm, p2p/simulations, cmd/swarm: Use nodekey in binary record sign * cmd/swarm: Make nodekey available for swarm api config
This commit is contained in:
@@ -7,6 +7,7 @@ import (
|
||||
|
||||
"github.com/ethereum/go-ethereum/crypto"
|
||||
"github.com/ethereum/go-ethereum/p2p/enode"
|
||||
"github.com/ethereum/go-ethereum/p2p/enr"
|
||||
)
|
||||
|
||||
// BzzAddr implements the PeerAddr interface
|
||||
@@ -68,3 +69,37 @@ func PrivateKeyToBzzKey(prvKey *ecdsa.PrivateKey) []byte {
|
||||
pubkeyBytes := crypto.FromECDSAPub(&prvKey.PublicKey)
|
||||
return crypto.Keccak256Hash(pubkeyBytes).Bytes()
|
||||
}
|
||||
|
||||
type EnodeParams struct {
|
||||
PrivateKey *ecdsa.PrivateKey
|
||||
EnodeKey *ecdsa.PrivateKey
|
||||
Lightnode bool
|
||||
Bootnode bool
|
||||
}
|
||||
|
||||
func NewEnodeRecord(params *EnodeParams) (*enr.Record, error) {
|
||||
|
||||
if params.PrivateKey == nil {
|
||||
return nil, fmt.Errorf("all param private keys must be defined")
|
||||
}
|
||||
|
||||
bzzkeybytes := PrivateKeyToBzzKey(params.PrivateKey)
|
||||
|
||||
var record enr.Record
|
||||
record.Set(NewENRAddrEntry(bzzkeybytes))
|
||||
record.Set(ENRLightNodeEntry(params.Lightnode))
|
||||
record.Set(ENRBootNodeEntry(params.Bootnode))
|
||||
return &record, nil
|
||||
}
|
||||
|
||||
func NewEnode(params *EnodeParams) (*enode.Node, error) {
|
||||
record, err := NewEnodeRecord(params)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
err = enode.SignV4(record, params.EnodeKey)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("ENR create fail: %v", err)
|
||||
}
|
||||
return enode.New(enode.V4ID{}, record)
|
||||
}
|
||||
|
@@ -102,16 +102,16 @@ func (s *Simulation) AddNode(opts ...AddNodeOption) (id enode.ID, err error) {
|
||||
// most importantly the bzz overlay address
|
||||
//
|
||||
// for now we have no way of setting bootnodes or lightnodes in sims
|
||||
// so we just set them as false
|
||||
// so we just let them be set to false
|
||||
// they should perhaps be possible to override them with AddNodeOption
|
||||
bzzKey := network.PrivateKeyToBzzKey(conf.PrivateKey)
|
||||
bzzAddr := network.NewENRAddrEntry(bzzKey)
|
||||
|
||||
var lightnode network.ENRLightNodeEntry
|
||||
var bootnode network.ENRBootNodeEntry
|
||||
conf.Record.Set(bzzAddr)
|
||||
conf.Record.Set(&lightnode)
|
||||
conf.Record.Set(&bootnode)
|
||||
enodeParams := &network.EnodeParams{
|
||||
PrivateKey: conf.PrivateKey,
|
||||
}
|
||||
record, err := network.NewEnodeRecord(enodeParams)
|
||||
if err != nil {
|
||||
return enode.ID{}, err
|
||||
}
|
||||
conf.Record = *record
|
||||
|
||||
// Add the bzz address to the node config
|
||||
node, err := s.Net.NewNodeWithConfig(conf)
|
||||
|
Reference in New Issue
Block a user