battlmonstr 0c5d1d64a3
observer: sentry candidates intake (#4321)
* sentry client: log connected peer info

* observer: unseen sentry peers report

* observer: refactoring node.go to node_utils

* observer: sentry candidates intake
2022-06-01 22:48:24 +01:00

78 lines
3.1 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
FindClientID(ctx context.Context, id NodeID) (*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)
UpdateSentryCandidatesLastEventTime(ctx context.Context, value time.Time) error
FindSentryCandidatesLastEventTime(ctx context.Context) (*time.Time, 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
}