mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-03 17:44:29 +00:00
92db317e06
Observer crawls the Ethereum network and collects information about the nodes.
109 lines
2.8 KiB
Go
109 lines
2.8 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"fmt"
|
|
"github.com/ledgerwatch/erigon-lib/common"
|
|
"github.com/ledgerwatch/erigon/cmd/observer/database"
|
|
"github.com/ledgerwatch/erigon/cmd/observer/observer"
|
|
"github.com/ledgerwatch/erigon/cmd/observer/reports"
|
|
"github.com/ledgerwatch/erigon/cmd/utils"
|
|
"github.com/ledgerwatch/erigon/params"
|
|
"github.com/ledgerwatch/log/v3"
|
|
"path/filepath"
|
|
)
|
|
|
|
func mainWithFlags(ctx context.Context, flags observer.CommandFlags) error {
|
|
server, err := observer.NewServer(flags)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
db, err := database.NewDBSQLite(filepath.Join(flags.DataDir, "observer.sqlite"))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() { _ = db.Close() }()
|
|
|
|
discV4, err := server.Listen(ctx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
networkID := uint(params.NetworkIDByChainName(flags.Chain))
|
|
go observer.StatusLoggerLoop(ctx, db, networkID, flags.StatusLogPeriod, log.Root())
|
|
|
|
crawlerConfig := observer.CrawlerConfig{
|
|
Chain: flags.Chain,
|
|
Bootnodes: server.Bootnodes(),
|
|
PrivateKey: server.PrivateKey(),
|
|
ConcurrencyLimit: flags.CrawlerConcurrency,
|
|
RefreshTimeout: flags.RefreshTimeout,
|
|
MaxPingTries: flags.MaxPingTries,
|
|
StatusLogPeriod: flags.StatusLogPeriod,
|
|
|
|
HandshakeRefreshTimeout: flags.HandshakeRefreshTimeout,
|
|
HandshakeRetryDelay: flags.HandshakeRetryDelay,
|
|
HandshakeMaxTries: flags.HandshakeMaxTries,
|
|
|
|
KeygenTimeout: flags.KeygenTimeout,
|
|
KeygenConcurrency: flags.KeygenConcurrency,
|
|
}
|
|
|
|
crawler, err := observer.NewCrawler(discV4, db, crawlerConfig, log.Root())
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return crawler.Run(ctx)
|
|
}
|
|
|
|
func reportWithFlags(ctx context.Context, flags reports.CommandFlags) error {
|
|
db, err := database.NewDBSQLite(filepath.Join(flags.DataDir, "observer.sqlite"))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() { _ = db.Close() }()
|
|
|
|
networkID := uint(params.NetworkIDByChainName(flags.Chain))
|
|
|
|
if flags.Estimate {
|
|
report, err := reports.CreateClientsEstimateReport(ctx, db, flags.ClientsLimit, flags.MaxPingTries, networkID)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
fmt.Println(report)
|
|
return nil
|
|
}
|
|
|
|
statusReport, err := reports.CreateStatusReport(ctx, db, flags.MaxPingTries, networkID)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
clientsReport, err := reports.CreateClientsReport(ctx, db, flags.ClientsLimit, flags.MaxPingTries, networkID)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
fmt.Println(statusReport)
|
|
fmt.Println(clientsReport)
|
|
return nil
|
|
}
|
|
|
|
func main() {
|
|
ctx, cancel := common.RootContext()
|
|
defer cancel()
|
|
|
|
command := observer.NewCommand()
|
|
|
|
reportCommand := reports.NewCommand()
|
|
reportCommand.OnRun(reportWithFlags)
|
|
command.AddSubCommand(reportCommand.RawCommand())
|
|
|
|
err := command.ExecuteContext(ctx, mainWithFlags)
|
|
if (err != nil) && !errors.Is(err, context.Canceled) {
|
|
utils.Fatalf("%v", err)
|
|
}
|
|
}
|