From 9b23a43a76da26e455c65562049b38bc4b640187 Mon Sep 17 00:00:00 2001 From: Pavel Zbitskiy Date: Tue, 23 Jul 2024 14:53:17 -0400 Subject: [PATCH 1/5] cmd: Add a simple cli util to generate peer private key and print out peer ID --- cmd/p2pid/main.go | 65 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 cmd/p2pid/main.go diff --git a/cmd/p2pid/main.go b/cmd/p2pid/main.go new file mode 100644 index 0000000000..f0f83b373c --- /dev/null +++ b/cmd/p2pid/main.go @@ -0,0 +1,65 @@ +// Copyright (C) 2019-2024 Algorand, Inc. +// This file is part of go-algorand +// +// go-algorand is free software: you can redistribute it and/or modify +// it under the terms of the GNU Affero General Public License as +// published by the Free Software Foundation, either version 3 of the +// License, or (at your option) any later version. +// +// go-algorand is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU Affero General Public License for more details. +// +// You should have received a copy of the GNU Affero General Public License +// along with go-algorand. If not, see . + +// generate a new p2p private key and print out peerID to stdout + +package main + +import ( + "flag" + "fmt" + "os" + "path" + + "github.com/algorand/go-algorand/config" + "github.com/algorand/go-algorand/network/p2p" + "github.com/algorand/go-algorand/util" + "github.com/libp2p/go-libp2p/core/peer" +) + +var dataDirectory = flag.String("d", "", "Root Algorand daemon data path or a path to a directory where the private key will be stored. If not provided, the current directory will be used.") + +func main() { + flag.Parse() + dataDir := *dataDirectory + if dataDir == "" { + dataDir = "." + } + + exist := false + privKeyPath := path.Join(dataDir, p2p.DefaultPrivKeyPath) + if util.FileExists(privKeyPath) { + exist = true + } + + peerKey, err := p2p.GetPrivKey(config.Local{P2PPersistPeerID: true}, dataDir) + if err != nil { + fmt.Fprintf(os.Stderr, "Error obtaining private key: %v\n", err) + os.Exit(1) + } + peerID, err := peer.IDFromPublicKey(peerKey.GetPublic()) + if err != nil { + fmt.Fprintf(os.Stderr, "Error obtaining peerID from a key: %v\n", err) + os.Exit(1) + } + + fmt.Printf("PeerID: %s\n", peerID.String()) + if !exist { + fmt.Printf("Private key saved to %s\n", privKeyPath) + } else { + fmt.Printf("Used existing key from path %s\n", privKeyPath) + } +} From 6e9406771abdecd044789878006b16f2e58a9c76 Mon Sep 17 00:00:00 2001 From: Pavel Zbitskiy Date: Wed, 24 Jul 2024 10:54:59 -0400 Subject: [PATCH 2/5] update help string --- cmd/p2pid/main.go | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/cmd/p2pid/main.go b/cmd/p2pid/main.go index f0f83b373c..1bd6ab01f2 100644 --- a/cmd/p2pid/main.go +++ b/cmd/p2pid/main.go @@ -30,7 +30,11 @@ import ( "github.com/libp2p/go-libp2p/core/peer" ) -var dataDirectory = flag.String("d", "", "Root Algorand daemon data path or a path to a directory where the private key will be stored. If not provided, the current directory will be used.") +var dataDirectory = flag.String( + "d", "", + "Optional root Algorand data path or a path to a directory where the private key will be stored.\n"+ + "Default directory is the current directory. Private key name is '"+p2p.DefaultPrivKeyPath+"'", +) func main() { flag.Parse() @@ -60,6 +64,6 @@ func main() { if !exist { fmt.Printf("Private key saved to %s\n", privKeyPath) } else { - fmt.Printf("Used existing key from path %s\n", privKeyPath) + fmt.Printf("Used existing key %s\n", privKeyPath) } } From dc8b3e0b25f5c8033b989a8cafcc2e29e1e7959b Mon Sep 17 00:00:00 2001 From: Pavel Zbitskiy Date: Mon, 29 Jul 2024 13:41:01 -0400 Subject: [PATCH 3/5] move to `goal node generate-p2pid` subcommand --- cmd/goal/node.go | 1 + cmd/goal/p2pid.go | 66 +++++++++++++++++++++++++++++++++++++++++++++ cmd/p2pid/main.go | 69 ----------------------------------------------- 3 files changed, 67 insertions(+), 69 deletions(-) create mode 100644 cmd/goal/p2pid.go delete mode 100644 cmd/p2pid/main.go diff --git a/cmd/goal/node.go b/cmd/goal/node.go index 2db08fd4e5..8bb103115b 100644 --- a/cmd/goal/node.go +++ b/cmd/goal/node.go @@ -79,6 +79,7 @@ func init() { nodeCmd.AddCommand(catchupCmd) // Once the server-side implementation of the shutdown command is ready, we should enable this one. //nodeCmd.AddCommand(shutdownCmd) + nodeCmd.AddCommand(p2pID) startCmd.Flags().StringVarP(&peerDial, "peer", "p", "", "Peer address to dial for initial connection") startCmd.Flags().StringVarP(&listenIP, "listen", "l", "", "Endpoint / REST address to listen on") diff --git a/cmd/goal/p2pid.go b/cmd/goal/p2pid.go new file mode 100644 index 0000000000..48914bde91 --- /dev/null +++ b/cmd/goal/p2pid.go @@ -0,0 +1,66 @@ +// Copyright (C) 2019-2024 Algorand, Inc. +// This file is part of go-algorand +// +// go-algorand is free software: you can redistribute it and/or modify +// it under the terms of the GNU Affero General Public License as +// published by the Free Software Foundation, either version 3 of the +// License, or (at your option) any later version. +// +// go-algorand is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU Affero General Public License for more details. +// +// You should have received a copy of the GNU Affero General Public License +// along with go-algorand. If not, see . + +// generate a new p2p private key and print out peerID to stdout + +package main + +import ( + "fmt" + "os" + "path" + + "github.com/algorand/go-algorand/cmd/util/datadir" + "github.com/algorand/go-algorand/config" + "github.com/algorand/go-algorand/network/p2p" + "github.com/algorand/go-algorand/util" + "github.com/libp2p/go-libp2p/core/peer" + "github.com/spf13/cobra" +) + +var p2pID = &cobra.Command{ + Use: "generate-p2pid", + Short: "Generate a new p2p private key", + Long: "Generate a new p2p private key (saved to " + p2p.DefaultPrivKeyPath + ") and print out peerID to stdout", + Args: validateNoPosArgsFn, + Run: func(cmd *cobra.Command, args []string) { + exist := false + datadir.OnDataDirs(func(dataDir string) { + privKeyPath := path.Join(dataDir, p2p.DefaultPrivKeyPath) + if util.FileExists(privKeyPath) { + exist = true + } + + peerKey, err := p2p.GetPrivKey(config.Local{P2PPersistPeerID: true}, dataDir) + if err != nil { + fmt.Fprintf(os.Stderr, "Error obtaining private key: %v\n", err) + os.Exit(1) + } + peerID, err := peer.IDFromPublicKey(peerKey.GetPublic()) + if err != nil { + fmt.Fprintf(os.Stderr, "Error obtaining peerID from a key: %v\n", err) + os.Exit(1) + } + + fmt.Printf("PeerID: %s\n", peerID.String()) + if !exist { + fmt.Printf("Private key saved to %s\n", privKeyPath) + } else { + fmt.Printf("Used existing key %s\n", privKeyPath) + } + }) + }, +} diff --git a/cmd/p2pid/main.go b/cmd/p2pid/main.go deleted file mode 100644 index 1bd6ab01f2..0000000000 --- a/cmd/p2pid/main.go +++ /dev/null @@ -1,69 +0,0 @@ -// Copyright (C) 2019-2024 Algorand, Inc. -// This file is part of go-algorand -// -// go-algorand is free software: you can redistribute it and/or modify -// it under the terms of the GNU Affero General Public License as -// published by the Free Software Foundation, either version 3 of the -// License, or (at your option) any later version. -// -// go-algorand is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -// GNU Affero General Public License for more details. -// -// You should have received a copy of the GNU Affero General Public License -// along with go-algorand. If not, see . - -// generate a new p2p private key and print out peerID to stdout - -package main - -import ( - "flag" - "fmt" - "os" - "path" - - "github.com/algorand/go-algorand/config" - "github.com/algorand/go-algorand/network/p2p" - "github.com/algorand/go-algorand/util" - "github.com/libp2p/go-libp2p/core/peer" -) - -var dataDirectory = flag.String( - "d", "", - "Optional root Algorand data path or a path to a directory where the private key will be stored.\n"+ - "Default directory is the current directory. Private key name is '"+p2p.DefaultPrivKeyPath+"'", -) - -func main() { - flag.Parse() - dataDir := *dataDirectory - if dataDir == "" { - dataDir = "." - } - - exist := false - privKeyPath := path.Join(dataDir, p2p.DefaultPrivKeyPath) - if util.FileExists(privKeyPath) { - exist = true - } - - peerKey, err := p2p.GetPrivKey(config.Local{P2PPersistPeerID: true}, dataDir) - if err != nil { - fmt.Fprintf(os.Stderr, "Error obtaining private key: %v\n", err) - os.Exit(1) - } - peerID, err := peer.IDFromPublicKey(peerKey.GetPublic()) - if err != nil { - fmt.Fprintf(os.Stderr, "Error obtaining peerID from a key: %v\n", err) - os.Exit(1) - } - - fmt.Printf("PeerID: %s\n", peerID.String()) - if !exist { - fmt.Printf("Private key saved to %s\n", privKeyPath) - } else { - fmt.Printf("Used existing key %s\n", privKeyPath) - } -} From 6f3b9ba757eade3c96de6d463c62e1f68a8a2ed7 Mon Sep 17 00:00:00 2001 From: Pavel Zbitskiy Date: Tue, 30 Jul 2024 15:30:03 -0400 Subject: [PATCH 4/5] properly support multuple data dirs --- cmd/goal/p2pid.go | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/cmd/goal/p2pid.go b/cmd/goal/p2pid.go index 48914bde91..23bed2de86 100644 --- a/cmd/goal/p2pid.go +++ b/cmd/goal/p2pid.go @@ -37,8 +37,8 @@ var p2pID = &cobra.Command{ Long: "Generate a new p2p private key (saved to " + p2p.DefaultPrivKeyPath + ") and print out peerID to stdout", Args: validateNoPosArgsFn, Run: func(cmd *cobra.Command, args []string) { - exist := false datadir.OnDataDirs(func(dataDir string) { + exist := false privKeyPath := path.Join(dataDir, p2p.DefaultPrivKeyPath) if util.FileExists(privKeyPath) { exist = true @@ -47,12 +47,12 @@ var p2pID = &cobra.Command{ peerKey, err := p2p.GetPrivKey(config.Local{P2PPersistPeerID: true}, dataDir) if err != nil { fmt.Fprintf(os.Stderr, "Error obtaining private key: %v\n", err) - os.Exit(1) + return } peerID, err := peer.IDFromPublicKey(peerKey.GetPublic()) if err != nil { fmt.Fprintf(os.Stderr, "Error obtaining peerID from a key: %v\n", err) - os.Exit(1) + return } fmt.Printf("PeerID: %s\n", peerID.String()) From 375efad4abd2bfffb8aaa48e5d90da87d1a47f9d Mon Sep 17 00:00:00 2001 From: Pavel Zbitskiy Date: Tue, 30 Jul 2024 16:02:11 -0400 Subject: [PATCH 5/5] use anyError --- cmd/goal/p2pid.go | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/cmd/goal/p2pid.go b/cmd/goal/p2pid.go index 23bed2de86..b35a946432 100644 --- a/cmd/goal/p2pid.go +++ b/cmd/goal/p2pid.go @@ -37,6 +37,7 @@ var p2pID = &cobra.Command{ Long: "Generate a new p2p private key (saved to " + p2p.DefaultPrivKeyPath + ") and print out peerID to stdout", Args: validateNoPosArgsFn, Run: func(cmd *cobra.Command, args []string) { + anyError := false datadir.OnDataDirs(func(dataDir string) { exist := false privKeyPath := path.Join(dataDir, p2p.DefaultPrivKeyPath) @@ -47,11 +48,13 @@ var p2pID = &cobra.Command{ peerKey, err := p2p.GetPrivKey(config.Local{P2PPersistPeerID: true}, dataDir) if err != nil { fmt.Fprintf(os.Stderr, "Error obtaining private key: %v\n", err) + anyError = true return } peerID, err := peer.IDFromPublicKey(peerKey.GetPublic()) if err != nil { fmt.Fprintf(os.Stderr, "Error obtaining peerID from a key: %v\n", err) + anyError = true return } @@ -62,5 +65,8 @@ var p2pID = &cobra.Command{ fmt.Printf("Used existing key %s\n", privKeyPath) } }) + if anyError { + os.Exit(1) + } }, }