2021-05-31 10:20:56 +00:00
|
|
|
package commands
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
|
|
|
|
"github.com/ledgerwatch/erigon/cmd/sentry/download"
|
|
|
|
"github.com/ledgerwatch/erigon/cmd/utils"
|
|
|
|
"github.com/ledgerwatch/erigon/common/paths"
|
|
|
|
"github.com/ledgerwatch/erigon/eth/protocols/eth"
|
|
|
|
"github.com/ledgerwatch/erigon/internal/debug"
|
2021-06-11 08:34:37 +00:00
|
|
|
node2 "github.com/ledgerwatch/erigon/turbo/node"
|
2021-05-31 10:20:56 +00:00
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
sentryAddr string // Address of the sentry <host>:<port>
|
|
|
|
chaindata string // Path to chaindata
|
|
|
|
datadir string // Path to td working dir
|
|
|
|
|
|
|
|
natSetting string // NAT setting
|
|
|
|
port int // Listening port
|
|
|
|
staticPeers []string // static peers
|
2021-11-14 11:44:44 +00:00
|
|
|
trustedPeers []string // trusted peers
|
2021-05-31 10:20:56 +00:00
|
|
|
discoveryDNS []string
|
|
|
|
nodiscover bool // disable sentry's discovery mechanism
|
|
|
|
protocol string
|
|
|
|
netRestrict string // CIDR to restrict peering to
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
utils.CobraFlags(rootCmd, append(debug.Flags, utils.MetricFlags...))
|
|
|
|
|
|
|
|
rootCmd.Flags().StringVar(&natSetting, "nat", "", `NAT port mapping mechanism (any|none|upnp|pmp|extip:<IP>)
|
|
|
|
"" or "none" default - do not nat
|
|
|
|
"extip:77.12.33.4" will assume the local machine is reachable on the given IP
|
|
|
|
"any" uses the first auto-detected mechanism
|
|
|
|
"upnp" uses the Universal Plug and Play protocol
|
|
|
|
"pmp" uses NAT-PMP with an auto-detected gateway address
|
|
|
|
"pmp:192.168.0.1" uses NAT-PMP with the given gateway address
|
|
|
|
`)
|
|
|
|
rootCmd.Flags().IntVar(&port, "port", 30303, "p2p port number")
|
2021-08-14 13:47:11 +00:00
|
|
|
rootCmd.Flags().StringVar(&sentryAddr, "sentry.api.addr", "localhost:9091", "grpc addresses")
|
2021-11-07 21:16:49 +00:00
|
|
|
rootCmd.Flags().StringVar(&protocol, "p2p.protocol", "eth66", "eth66")
|
2021-05-31 10:20:56 +00:00
|
|
|
rootCmd.Flags().StringSliceVar(&staticPeers, "staticpeers", []string{}, "static peer list [enode]")
|
2021-11-14 11:44:44 +00:00
|
|
|
rootCmd.Flags().StringSliceVar(&trustedPeers, "trustedpeers", []string{}, "trusted peer list [enode]")
|
2021-05-31 10:20:56 +00:00
|
|
|
rootCmd.Flags().StringSliceVar(&discoveryDNS, utils.DNSDiscoveryFlag.Name, []string{}, utils.DNSDiscoveryFlag.Usage)
|
|
|
|
rootCmd.Flags().BoolVar(&nodiscover, utils.NoDiscoverFlag.Name, false, utils.NoDiscoverFlag.Usage)
|
|
|
|
rootCmd.Flags().StringVar(&netRestrict, "netrestrict", "", "CIDR range to accept peers from <CIDR>")
|
|
|
|
rootCmd.Flags().StringVar(&datadir, utils.DataDirFlag.Name, paths.DefaultDataDir(), utils.DataDirFlag.Usage)
|
|
|
|
if err := rootCmd.MarkFlagDirname(utils.DataDirFlag.Name); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
var rootCmd = &cobra.Command{
|
|
|
|
Use: "sentry",
|
|
|
|
Short: "Run p2p sentry",
|
|
|
|
PersistentPreRun: func(cmd *cobra.Command, args []string) {
|
|
|
|
if err := debug.SetupCobra(cmd); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
if chaindata == "" {
|
2021-08-18 09:24:03 +00:00
|
|
|
chaindata = path.Join(datadir, "chaindata")
|
2021-05-31 10:20:56 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
PersistentPostRun: func(cmd *cobra.Command, args []string) {
|
|
|
|
debug.Exit()
|
|
|
|
},
|
|
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
|
|
|
p := eth.ETH66
|
|
|
|
|
2021-06-11 08:34:37 +00:00
|
|
|
nodeConfig := node2.NewNodeConfig()
|
2021-11-14 11:44:44 +00:00
|
|
|
p2pConfig, err := utils.NewP2PConfig(nodiscover, datadir, netRestrict, natSetting, nodeConfig.NodeName(), staticPeers, trustedPeers, uint(port), uint(p))
|
2021-06-11 08:34:37 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return download.Sentry(datadir, sentryAddr, discoveryDNS, p2pConfig, uint(p))
|
2021-05-31 10:20:56 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func Execute() {
|
|
|
|
ctx, cancel := utils.RootContext()
|
|
|
|
defer cancel()
|
|
|
|
if err := rootCmd.ExecuteContext(ctx); err != nil {
|
|
|
|
fmt.Println(err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
}
|