erigon-pulse/turbo/snapshotsync/server.go

82 lines
2.0 KiB
Go

package snapshotsync
import (
"context"
"errors"
"fmt"
"github.com/anacrolix/torrent"
"github.com/golang/protobuf/ptypes/empty"
"github.com/ledgerwatch/erigon/common/dbutils"
"github.com/ledgerwatch/erigon/ethdb"
"github.com/ledgerwatch/erigon/ethdb/kv"
)
var (
ErrNotSupportedNetworkID = errors.New("not supported network id")
ErrNotSupportedSnapshot = errors.New("not supported snapshot for this network id")
)
var (
_ DownloaderServer = &SNDownloaderServer{}
)
func NewServer(dir string, seeding bool) (*SNDownloaderServer, error) {
db := kv.MustOpen(dir + "/db")
peerID, err := db.Get(dbutils.BittorrentInfoBucket, []byte(dbutils.BittorrentPeerID))
if err != nil && !errors.Is(err, ethdb.ErrKeyNotFound) {
return nil, fmt.Errorf("get peer id: %w", err)
}
downloader, err := New(dir, seeding, string(peerID))
if err != nil {
return nil, err
}
if len(peerID) == 0 {
err = downloader.SavePeerID(db)
if err != nil {
return nil, fmt.Errorf("save peer id: %w", err)
}
}
return &SNDownloaderServer{
t: downloader,
db: db,
}, nil
}
type SNDownloaderServer struct {
DownloaderServer
t *Client
db ethdb.Database
}
func (S *SNDownloaderServer) Download(ctx context.Context, request *DownloadSnapshotRequest) (*empty.Empty, error) {
err := S.t.AddSnapshotsTorrents(ctx, S.db, request.NetworkId, FromSnapshotTypes(request.Type))
if err != nil {
return nil, err
}
return &empty.Empty{}, nil
}
func (S *SNDownloaderServer) Load() error {
return S.t.Load(S.db)
}
func (S *SNDownloaderServer) Snapshots(ctx context.Context, request *SnapshotsRequest) (*SnapshotsInfoReply, error) {
reply := SnapshotsInfoReply{}
resp, err := S.t.GetSnapshots(S.db, request.NetworkId)
if err != nil {
return nil, err
}
for i := range resp {
reply.Info = append(reply.Info, resp[i])
}
return &reply, nil
}
func (S *SNDownloaderServer) Stats(ctx context.Context) map[string]torrent.TorrentStats {
stats := map[string]torrent.TorrentStats{}
torrents := S.t.Cli.Torrents()
for _, t := range torrents {
stats[t.Name()] = t.Stats()
}
return stats
}