cmd/devp2p: add more nodekey commands (#26129)

This adds new commands to turn a node key file into signed ENR / node ID.
This commit is contained in:
Felix Lange 2022-11-08 12:15:32 +01:00 committed by GitHub
parent a609e7b81f
commit 913973436b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -22,6 +22,7 @@ import (
"github.com/ethereum/go-ethereum/crypto" "github.com/ethereum/go-ethereum/crypto"
"github.com/ethereum/go-ethereum/p2p/enode" "github.com/ethereum/go-ethereum/p2p/enode"
"github.com/ethereum/go-ethereum/p2p/enr"
"github.com/urfave/cli/v2" "github.com/urfave/cli/v2"
) )
@ -31,7 +32,9 @@ var (
Usage: "Operations on node keys", Usage: "Operations on node keys",
Subcommands: []*cli.Command{ Subcommands: []*cli.Command{
keyGenerateCommand, keyGenerateCommand,
keyToIDCommand,
keyToNodeCommand, keyToNodeCommand,
keyToRecordCommand,
}, },
} }
keyGenerateCommand = &cli.Command{ keyGenerateCommand = &cli.Command{
@ -40,6 +43,13 @@ var (
ArgsUsage: "keyfile", ArgsUsage: "keyfile",
Action: genkey, Action: genkey,
} }
keyToIDCommand = &cli.Command{
Name: "to-id",
Usage: "Creates a node ID from a node key file",
ArgsUsage: "keyfile",
Action: keyToID,
Flags: []cli.Flag{},
}
keyToNodeCommand = &cli.Command{ keyToNodeCommand = &cli.Command{
Name: "to-enode", Name: "to-enode",
Usage: "Creates an enode URL from a node key file", Usage: "Creates an enode URL from a node key file",
@ -47,6 +57,13 @@ var (
Action: keyToURL, Action: keyToURL,
Flags: []cli.Flag{hostFlag, tcpPortFlag, udpPortFlag}, Flags: []cli.Flag{hostFlag, tcpPortFlag, udpPortFlag},
} }
keyToRecordCommand = &cli.Command{
Name: "to-enr",
Usage: "Creates an ENR from a node key file",
ArgsUsage: "keyfile",
Action: keyToRecord,
Flags: []cli.Flag{hostFlag, tcpPortFlag, udpPortFlag},
}
) )
var ( var (
@ -80,9 +97,36 @@ func genkey(ctx *cli.Context) error {
return crypto.SaveECDSA(file, key) return crypto.SaveECDSA(file, key)
} }
func keyToID(ctx *cli.Context) error {
n, err := makeRecord(ctx)
if err != nil {
return err
}
fmt.Println(n.ID())
return nil
}
func keyToURL(ctx *cli.Context) error { func keyToURL(ctx *cli.Context) error {
n, err := makeRecord(ctx)
if err != nil {
return err
}
fmt.Println(n.URLv4())
return nil
}
func keyToRecord(ctx *cli.Context) error {
n, err := makeRecord(ctx)
if err != nil {
return err
}
fmt.Println(n.String())
return nil
}
func makeRecord(ctx *cli.Context) (*enode.Node, error) {
if ctx.NArg() != 1 { if ctx.NArg() != 1 {
return fmt.Errorf("need key file as argument") return nil, fmt.Errorf("need key file as argument")
} }
var ( var (
@ -93,13 +137,26 @@ func keyToURL(ctx *cli.Context) error {
) )
key, err := crypto.LoadECDSA(file) key, err := crypto.LoadECDSA(file)
if err != nil { if err != nil {
return err return nil, err
} }
ip := net.ParseIP(host)
if ip == nil { var r enr.Record
return fmt.Errorf("invalid IP address %q", host) if host != "" {
ip := net.ParseIP(host)
if ip == nil {
return nil, fmt.Errorf("invalid IP address %q", host)
}
r.Set(enr.IP(ip))
} }
node := enode.NewV4(&key.PublicKey, ip, tcp, udp) if udp != 0 {
fmt.Println(node.URLv4()) r.Set(enr.UDP(udp))
return nil }
if tcp != 0 {
r.Set(enr.TCP(tcp))
}
if err := enode.SignV4(&r, key); err != nil {
return nil, err
}
return enode.New(enode.ValidSchemes, &r)
} }