2020-09-06 11:35:32 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2020-10-06 19:25:01 +00:00
|
|
|
"net"
|
2020-09-06 11:35:32 +00:00
|
|
|
"os"
|
2020-11-28 15:08:02 +00:00
|
|
|
"unsafe"
|
2020-09-06 11:35:32 +00:00
|
|
|
|
2020-10-06 19:25:01 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/cmd/utils"
|
2020-09-06 11:35:32 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/eth/stagedsync"
|
|
|
|
"github.com/ledgerwatch/turbo-geth/log"
|
2020-10-04 16:18:06 +00:00
|
|
|
turbocli "github.com/ledgerwatch/turbo-geth/turbo/cli"
|
2020-10-06 19:25:01 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/turbo/node"
|
2020-11-28 15:08:02 +00:00
|
|
|
"github.com/ledgerwatch/turbo-geth/turbo/silkworm"
|
2020-09-06 11:35:32 +00:00
|
|
|
"github.com/urfave/cli"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2020-09-21 14:10:25 +00:00
|
|
|
// gitCommit is injected through the build flags (see Makefile)
|
2020-09-11 16:42:33 +00:00
|
|
|
gitCommit string
|
2021-03-01 04:02:06 +00:00
|
|
|
gitBranch string
|
2020-09-06 11:35:32 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2020-09-21 14:10:25 +00:00
|
|
|
// creating a turbo-api app with all defaults
|
2020-09-06 11:35:32 +00:00
|
|
|
app := turbocli.MakeApp(runTurboGeth, turbocli.DefaultFlags)
|
|
|
|
if err := app.Run(os.Args); err != nil {
|
|
|
|
fmt.Fprintln(os.Stderr, err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
}
|
2020-10-06 19:25:01 +00:00
|
|
|
|
|
|
|
func runTurboGeth(cliCtx *cli.Context) {
|
2020-11-28 15:08:02 +00:00
|
|
|
silkwormPath := cliCtx.String(turbocli.SilkwormFlag.Name)
|
|
|
|
var silkwormExecutionFunc unsafe.Pointer
|
|
|
|
if silkwormPath != "" {
|
|
|
|
var err error
|
|
|
|
silkwormExecutionFunc, err = silkworm.LoadExecutionFunctionPointer(silkwormPath)
|
|
|
|
if err != nil {
|
|
|
|
panic(fmt.Errorf("failed to load Silkworm dynamic library: %v", err))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-08 08:45:40 +00:00
|
|
|
var sync *stagedsync.StagedSync
|
|
|
|
if cliCtx.Bool(turbocli.SnapshotDatabaseLayoutFlag.Name) {
|
|
|
|
sync = stagedsync.New(
|
|
|
|
stagedsync.WithSnapshotsStages(),
|
|
|
|
stagedsync.UnwindOrderWithSnapshots(),
|
|
|
|
stagedsync.OptionalParameters{SilkwormExecutionFunc: silkwormExecutionFunc},
|
|
|
|
)
|
|
|
|
} else {
|
|
|
|
// creating staged sync with all default parameters
|
|
|
|
sync = stagedsync.New(
|
|
|
|
stagedsync.DefaultStages(),
|
|
|
|
stagedsync.DefaultUnwindOrder(),
|
|
|
|
stagedsync.OptionalParameters{SilkwormExecutionFunc: silkwormExecutionFunc},
|
|
|
|
)
|
|
|
|
}
|
2020-09-06 11:35:32 +00:00
|
|
|
|
2021-04-26 12:39:34 +00:00
|
|
|
ctx, _ := utils.RootContext()
|
2020-10-06 19:25:01 +00:00
|
|
|
|
2020-09-21 14:10:25 +00:00
|
|
|
// initializing the node and providing the current git commit there
|
2021-03-01 04:02:06 +00:00
|
|
|
log.Info("Build info", "git_branch", gitBranch, "git_commit", gitCommit)
|
|
|
|
tg := node.New(cliCtx, sync, node.Params{GitCommit: gitCommit, GitBranch: gitBranch})
|
2020-10-06 19:25:01 +00:00
|
|
|
tg.SetP2PListenFunc(func(network, addr string) (net.Listener, error) {
|
|
|
|
var lc net.ListenConfig
|
|
|
|
return lc.Listen(ctx, network, addr)
|
|
|
|
})
|
2020-09-21 14:10:25 +00:00
|
|
|
// running the node
|
2020-09-06 11:35:32 +00:00
|
|
|
err := tg.Serve()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
log.Error("error while serving a turbo-geth node", "err", err)
|
|
|
|
}
|
|
|
|
}
|