Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var StartExporterNodeCmd = &cobra.Command{ Use: "start-exporter", Short: "Starts exporter node", Run: func(cmd *cobra.Command, args []string) { if err := cleanenv.ReadConfig(globalArgs.ConfigPath, &cfg); err != nil { log.Fatal(err) } if globalArgs.ShareConfigPath != "" { if err := cleanenv.ReadConfig(globalArgs.ShareConfigPath, &cfg); err != nil { log.Fatal(err) } } commons.SetBuildData(cmd.Parent().Short, cmd.Parent().Version) log.Printf("starting %s", commons.GetBuildData()) loggerLevel, errLogLevel := logex.GetLoggerLevelValue(cfg.LogLevel) Logger := logex.Build(commons.GetBuildData(), loggerLevel, &logex.EncodingConfig{ Format: cfg.GlobalConfig.LogFormat, LevelEncoder: logex.LevelEncoder([]byte(cfg.LogLevelFormat)), }) if errLogLevel != nil { Logger.Warn(fmt.Sprintf("Default log level set to %s", loggerLevel), zap.Error(errLogLevel)) } cfg.DBOptions.Logger = Logger cfg.DBOptions.Ctx = cmd.Context() ok, err := migrationutils.Migrate(cfg.DBOptions.Path) if err != nil { Logger.Fatal("failed during migration check", zap.Error(err)) } else if ok { Logger.Info("migration is required", zap.Error(err)) cfg.ETH1Options.CleanRegistryData = true } db, err := storage.GetStorageFactory(cfg.DBOptions) if err != nil { Logger.Fatal("failed to create db!", zap.Error(err)) } cfg.P2pNetworkConfig.NetworkPrivateKey, err = utils.ECDSAPrivateKey(Logger.With(zap.String("who", "p2pNetworkPrivateKey")), cfg.NetworkPrivateKey) if err != nil { log.Fatal("Failed to get p2p privateKey", zap.Error(err)) } cfg.P2pNetworkConfig.ReportLastMsg = true cfg.P2pNetworkConfig.Fork = networkForkV0.New() cfg.P2pNetworkConfig.NodeType = p2p.Exporter network, err := p2p.New(cmd.Context(), Logger, &cfg.P2pNetworkConfig) if err != nil { Logger.Fatal("failed to create network", zap.Error(err)) } Logger.Info("using registry contract address", zap.String("addr", cfg.ETH1Options.RegistryContractAddr), zap.String("abiVersion", cfg.ETH1Options.AbiVersion.String())) if len(cfg.ETH1Options.RegistryContractABI) > 0 { Logger.Info("using registry contract abi", zap.String("abi", cfg.ETH1Options.RegistryContractABI)) if err = eth1.LoadABI(cfg.ETH1Options.RegistryContractABI); err != nil { Logger.Fatal("failed to load ABI JSON", zap.Error(err)) } } eth1Client, err := goeth.NewEth1Client(goeth.ClientOptions{ Ctx: cmd.Context(), Logger: Logger, NodeAddr: cfg.ETH1Options.ETH1Addr, ContractABI: eth1.ContractABI(cfg.ETH1Options.AbiVersion), ConnectionTimeout: cfg.ETH1Options.ETH1ConnectionTimeout, RegistryContractAddr: cfg.ETH1Options.RegistryContractAddr, ShareEncryptionKeyProvider: func() (*rsa.PrivateKey, bool, error) { return nil, true, nil }, AbiVersion: cfg.ETH1Options.AbiVersion, }) if err != nil { Logger.Fatal("failed to create eth1 client", zap.Error(err)) } cfg.ETH2Options.Context = cmd.Context() cfg.ETH2Options.Logger = Logger cfg.ETH2Options.Graffiti = []byte("SSV.Network") cfg.ETH2Options.DB = db beaconClient, err := goclient.New(cfg.ETH2Options) if err != nil { Logger.Fatal("failed to create beacon go-client", zap.Error(err)) } exporterOptions := new(exporter.Options) exporterOptions.Eth1Client = eth1Client exporterOptions.Beacon = beaconClient exporterOptions.Logger = Logger exporterOptions.Network = network exporterOptions.DB = db exporterOptions.Ctx = cmd.Context() exporterOptions.WS = api.NewWsServer(cmd.Context(), Logger, nil, http.NewServeMux()) exporterOptions.WsAPIPort = cfg.WsAPIPort exporterOptions.IbftSyncEnabled = cfg.IbftSyncEnabled exporterOptions.CleanRegistryData = cfg.ETH1Options.CleanRegistryData exporterOptions.ValidatorMetaDataUpdateInterval = cfg.ValidatorMetaDataUpdateInterval exporterNode = exporter.New(*exporterOptions) if cfg.MetricsAPIPort > 0 { go startMetricsHandler(cmd.Context(), Logger, cfg.MetricsAPIPort, cfg.EnableProfile) } metrics.WaitUntilHealthy(Logger, eth1Client, "eth1 node") metrics.WaitUntilHealthy(Logger, beaconClient, "beacon node") if err := exporterNode.StartEth1(eth1.HexStringToSyncOffset(cfg.ETH1Options.ETH1SyncOffset)); err != nil { Logger.Fatal("failed to start eth1", zap.Error(err)) } if err := exporterNode.Start(); err != nil { Logger.Fatal("failed to start exporter", zap.Error(err)) } }, }
StartExporterNodeCmd is the command to start SSV boot node
Functions ¶
This section is empty.
Types ¶
This section is empty.
Click to show internal directories.
Click to hide internal directories.