2020-09-07 06:03:12 +00:00
|
|
|
package commands
|
|
|
|
|
|
|
|
import (
|
2021-04-25 08:29:39 +00:00
|
|
|
"path"
|
|
|
|
|
2020-09-07 06:03:12 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/cmd/headers/download"
|
2021-04-25 08:29:39 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/common/etl"
|
2021-04-25 04:20:50 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/turbo/node"
|
2020-09-07 06:03:12 +00:00
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2021-03-19 21:24:49 +00:00
|
|
|
combined bool // Whether downloader also includes sentry
|
|
|
|
timeout int // Timeout for delivery requests
|
|
|
|
window int // Size of sliding window for downloading block bodies
|
|
|
|
chain string // Name of the network to connect to
|
2020-09-07 06:03:12 +00:00
|
|
|
)
|
|
|
|
|
2021-04-25 04:20:50 +00:00
|
|
|
var (
|
|
|
|
// gitCommit is injected through the build flags (see Makefile)
|
|
|
|
gitCommit string
|
|
|
|
gitBranch string
|
|
|
|
)
|
|
|
|
|
2020-09-07 06:03:12 +00:00
|
|
|
func init() {
|
2021-04-07 08:54:25 +00:00
|
|
|
downloadCmd.Flags().StringSliceVar(&sentryAddrs, "sentry.api.addr", []string{"localhost:9091"}, "comma separated sentry addresses '<host>:<port>,<host>:<port>'")
|
2021-01-15 10:58:04 +00:00
|
|
|
downloadCmd.Flags().BoolVar(&combined, "combined", false, "run downloader and sentry in the same process")
|
2021-02-22 21:59:23 +00:00
|
|
|
downloadCmd.Flags().IntVar(&timeout, "timeout", 30, "timeout for devp2p delivery requests, in seconds")
|
|
|
|
downloadCmd.Flags().IntVar(&window, "window", 65536, "size of sliding window for downloading block bodies, block")
|
2021-03-19 21:24:49 +00:00
|
|
|
downloadCmd.Flags().StringVar(&chain, "chain", "mainnet", "Name of the network (mainnet, testnets) to connect to")
|
2021-01-15 10:58:04 +00:00
|
|
|
|
|
|
|
// Options below are only used in the combined mode
|
|
|
|
downloadCmd.Flags().StringVar(&natSetting, "nat", "any", "NAT port mapping mechanism (any|none|upnp|pmp|extip:<IP>)")
|
|
|
|
downloadCmd.Flags().IntVar(&port, "port", 30303, "p2p port number")
|
2021-04-07 08:54:25 +00:00
|
|
|
downloadCmd.Flags().StringSliceVar(&staticPeers, "staticpeers", []string{}, "static peer list [enode]")
|
2021-01-15 10:58:04 +00:00
|
|
|
downloadCmd.Flags().BoolVar(&discovery, "discovery", true, "discovery mode")
|
|
|
|
downloadCmd.Flags().StringVar(&netRestrict, "netrestrict", "", "CIDR range to accept peers from <CIDR>")
|
|
|
|
|
2021-04-19 07:25:26 +00:00
|
|
|
withDatadir(downloadCmd)
|
2020-09-07 06:03:12 +00:00
|
|
|
rootCmd.AddCommand(downloadCmd)
|
|
|
|
}
|
|
|
|
|
|
|
|
var downloadCmd = &cobra.Command{
|
|
|
|
Use: "download",
|
|
|
|
Short: "Download headers backwards",
|
|
|
|
RunE: func(cmd *cobra.Command, args []string) error {
|
2020-11-02 21:09:12 +00:00
|
|
|
db := openDatabase(chaindata)
|
|
|
|
defer db.Close()
|
2021-04-25 04:20:50 +00:00
|
|
|
nodeConfig := node.NewNodeConfig(node.Params{GitCommit: gitCommit, GitBranch: gitBranch})
|
|
|
|
nodeName := nodeConfig.NodeName()
|
2021-04-25 08:29:39 +00:00
|
|
|
tmpdir := path.Join(nodeConfig.DataDir, etl.TmpDirName)
|
2021-04-25 04:20:50 +00:00
|
|
|
|
2021-01-15 10:58:04 +00:00
|
|
|
if combined {
|
2021-05-12 21:37:43 +00:00
|
|
|
return download.Combined(nodeConfig.DataDir, natSetting, port, staticPeers, discovery, netRestrict, db, timeout, window, chain, nodeName, tmpdir)
|
2021-01-15 10:58:04 +00:00
|
|
|
}
|
2021-04-07 08:54:25 +00:00
|
|
|
|
2021-04-25 08:29:39 +00:00
|
|
|
return download.Download(sentryAddrs, db, timeout, window, chain, nodeName, tmpdir)
|
2020-09-07 06:03:12 +00:00
|
|
|
},
|
|
|
|
}
|