2020-07-19 03:45:08 +00:00
|
|
|
package peers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"sync"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/p2p/enr"
|
|
|
|
"github.com/libp2p/go-libp2p-core/network"
|
|
|
|
"github.com/libp2p/go-libp2p-core/peer"
|
|
|
|
ma "github.com/multiformats/go-multiaddr"
|
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
|
|
|
)
|
|
|
|
|
|
|
|
// peerDataStore is a container for various peer related data (both protocol and app level).
|
|
|
|
// Container implements RWMutex, so data access can be restricted on the container level. This allows
|
|
|
|
// different components rely on the very same peer map container.
|
|
|
|
type peerDataStore struct {
|
|
|
|
sync.RWMutex
|
|
|
|
ctx context.Context
|
|
|
|
config *peerDataStoreConfig
|
|
|
|
peers map[peer.ID]*peerData
|
|
|
|
}
|
|
|
|
|
|
|
|
// peerDataStoreConfig holds peer store parameters.
|
|
|
|
type peerDataStoreConfig struct {
|
|
|
|
maxPeers int
|
|
|
|
}
|
|
|
|
|
|
|
|
// peerData aggregates protocol and application level info about a single peer.
|
|
|
|
type peerData struct {
|
|
|
|
address ma.Multiaddr
|
|
|
|
direction network.Direction
|
|
|
|
connState PeerConnectionState
|
|
|
|
chainState *pb.Status
|
|
|
|
enr *enr.Record
|
|
|
|
metaData *pb.MetaData
|
|
|
|
chainStateLastUpdated time.Time
|
2020-07-29 09:26:46 +00:00
|
|
|
badResponses int
|
2020-08-01 09:20:05 +00:00
|
|
|
processedBlocks uint64
|
2020-08-09 20:26:09 +00:00
|
|
|
blockProviderUpdated time.Time
|
2020-07-19 03:45:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// newPeerDataStore creates peer store.
|
|
|
|
func newPeerDataStore(ctx context.Context, config *peerDataStoreConfig) *peerDataStore {
|
|
|
|
return &peerDataStore{
|
|
|
|
ctx: ctx,
|
|
|
|
config: config,
|
|
|
|
peers: make(map[peer.ID]*peerData),
|
|
|
|
}
|
|
|
|
}
|