mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-19 17:10:53 +00:00
74 lines
2.9 KiB
Go
74 lines
2.9 KiB
Go
|
package database
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"io"
|
||
|
"net"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
type NodeID string
|
||
|
|
||
|
type NodeAddr1 struct {
|
||
|
IP net.IP
|
||
|
PortDisc uint16
|
||
|
PortRLPx uint16
|
||
|
}
|
||
|
|
||
|
type NodeAddr struct {
|
||
|
NodeAddr1
|
||
|
IPv6 NodeAddr1
|
||
|
}
|
||
|
|
||
|
type HandshakeError struct {
|
||
|
StringCode string
|
||
|
Time time.Time
|
||
|
}
|
||
|
|
||
|
type DB interface {
|
||
|
io.Closer
|
||
|
|
||
|
UpsertNodeAddr(ctx context.Context, id NodeID, addr NodeAddr) error
|
||
|
FindNodeAddr(ctx context.Context, id NodeID) (*NodeAddr, error)
|
||
|
|
||
|
ResetPingError(ctx context.Context, id NodeID) error
|
||
|
UpdatePingError(ctx context.Context, id NodeID) error
|
||
|
CountPingErrors(ctx context.Context, id NodeID) (*uint, error)
|
||
|
|
||
|
UpdateClientID(ctx context.Context, id NodeID, clientID string) error
|
||
|
UpdateNetworkID(ctx context.Context, id NodeID, networkID uint) error
|
||
|
UpdateEthVersion(ctx context.Context, id NodeID, ethVersion uint) error
|
||
|
UpdateHandshakeTransientError(ctx context.Context, id NodeID, hasTransientErr bool) error
|
||
|
InsertHandshakeError(ctx context.Context, id NodeID, handshakeErr string) error
|
||
|
DeleteHandshakeErrors(ctx context.Context, id NodeID) error
|
||
|
FindHandshakeLastErrors(ctx context.Context, id NodeID, limit uint) ([]HandshakeError, error)
|
||
|
UpdateHandshakeRetryTime(ctx context.Context, id NodeID, retryTime time.Time) error
|
||
|
FindHandshakeRetryTime(ctx context.Context, id NodeID) (*time.Time, error)
|
||
|
CountHandshakeCandidates(ctx context.Context) (uint, error)
|
||
|
FindHandshakeCandidates(ctx context.Context, limit uint) ([]NodeID, error)
|
||
|
MarkTakenHandshakeCandidates(ctx context.Context, nodes []NodeID) error
|
||
|
// TakeHandshakeCandidates runs FindHandshakeCandidates + MarkTakenHandshakeCandidates in a transaction.
|
||
|
TakeHandshakeCandidates(ctx context.Context, limit uint) ([]NodeID, error)
|
||
|
|
||
|
UpdateForkCompatibility(ctx context.Context, id NodeID, isCompatFork bool) error
|
||
|
|
||
|
UpdateNeighborBucketKeys(ctx context.Context, id NodeID, keys []string) error
|
||
|
FindNeighborBucketKeys(ctx context.Context, id NodeID) ([]string, error)
|
||
|
|
||
|
UpdateCrawlRetryTime(ctx context.Context, id NodeID, retryTime time.Time) error
|
||
|
CountCandidates(ctx context.Context) (uint, error)
|
||
|
FindCandidates(ctx context.Context, limit uint) ([]NodeID, error)
|
||
|
MarkTakenNodes(ctx context.Context, nodes []NodeID) error
|
||
|
// TakeCandidates runs FindCandidates + MarkTakenNodes in a transaction.
|
||
|
TakeCandidates(ctx context.Context, limit uint) ([]NodeID, error)
|
||
|
|
||
|
IsConflictError(err error) bool
|
||
|
|
||
|
CountNodes(ctx context.Context, maxPingTries uint, networkID uint) (uint, error)
|
||
|
CountIPs(ctx context.Context, maxPingTries uint, networkID uint) (uint, error)
|
||
|
CountClients(ctx context.Context, clientIDPrefix string, maxPingTries uint, networkID uint) (uint, error)
|
||
|
CountClientsWithNetworkID(ctx context.Context, clientIDPrefix string, maxPingTries uint) (uint, error)
|
||
|
CountClientsWithHandshakeTransientError(ctx context.Context, clientIDPrefix string, maxPingTries uint) (uint, error)
|
||
|
EnumerateClientIDs(ctx context.Context, maxPingTries uint, networkID uint, enumFunc func(clientID *string)) error
|
||
|
}
|