erigon-pulse/cmd/lightclient/main.go
Giulio rebuffo 0fb982bfeb
Added p2p connection and libp2p host to Erigon Lightclient (#5500)
* added p2p connection and libp2p host

* added p2p connection and libp2p host

* oooops

Co-authored-by: giuliorebuffo <giuliorebuffo@system76-pc.localdomain>
2022-09-24 20:48:56 +02:00

54 lines
1.2 KiB
Go

package main
import (
"context"
"crypto/ecdsa"
"fmt"
"time"
"github.com/ledgerwatch/erigon/cmd/lightclient/clparams"
"github.com/ledgerwatch/erigon/cmd/lightclient/sentinel"
"github.com/ledgerwatch/erigon/crypto"
"github.com/ledgerwatch/log/v3"
)
func generateKey() (*ecdsa.PrivateKey, error) {
key, err := crypto.GenerateKey()
if err != nil {
err = fmt.Errorf("failed to generate node key: %w", err)
}
return key, err
}
func main() {
log.Root().SetHandler(log.LvlFilterHandler(log.LvlTrace, log.StderrHandler))
discCfg, err := clparams.GetDefaultDiscoveryConfig(clparams.Mainnet)
if err != nil {
log.Error("error", "err", err)
return
}
sent, err := sentinel.New(context.Background(), sentinel.SentinelConfig{
IpAddr: "127.0.0.1",
Port: 8080,
TCPPort: 9000,
DiscoverConfig: *discCfg,
})
if err != nil {
log.Error("error", "err", err)
return
}
if err := sent.Start(); err != nil {
log.Error("error", "err", err)
return
}
logInterval := time.NewTicker(5 * time.Second)
for {
select {
case <-logInterval.C:
log.Info("DEBUG", "peers", sent.PeersCount())
default:
time.Sleep(100 * time.Millisecond)
}
}
}