Documentation ¶
Index ¶
- type DuplicateChecker
- type PeerManager
- type PeerManagerImpl
- func (a *PeerManagerImpl) AddAddress(ctx context.Context, addr proto.TCPAddr) error
- func (a *PeerManagerImpl) AddConnected(peer peer.Peer)
- func (a *PeerManagerImpl) AskPeers()
- func (a *PeerManagerImpl) ClearSuspended(now time.Time)
- func (a *PeerManagerImpl) Close()
- func (a *PeerManagerImpl) Connect(ctx context.Context, addr proto.TCPAddr) error
- func (a *PeerManagerImpl) Connected(p peer.Peer) (peer.Peer, bool)
- func (a *PeerManagerImpl) ConnectedCount() int
- func (a *PeerManagerImpl) Disconnect(p peer.Peer)
- func (a *PeerManagerImpl) EachConnected(f func(peer peer.Peer, score *big.Int))
- func (a *PeerManagerImpl) InOutCount() (in int, out int)
- func (a *PeerManagerImpl) IsSuspended(p peer.Peer) bool
- func (a *PeerManagerImpl) KnownPeers() []storage.KnownPeer
- func (a *PeerManagerImpl) NewConnection(p peer.Peer) error
- func (a *PeerManagerImpl) PeerWithHighestScore() (peer.Peer, *big.Int, bool)
- func (a *PeerManagerImpl) RemoveSpawned(addr proto.TCPAddr)
- func (a *PeerManagerImpl) Run(ctx context.Context)
- func (a *PeerManagerImpl) Score(p peer.Peer) (*proto.Score, error)
- func (a *PeerManagerImpl) SetConnectPeers(connect bool)
- func (a *PeerManagerImpl) SpawnIncomingConnection(ctx context.Context, conn net.Conn) error
- func (a *PeerManagerImpl) SpawnOutgoingConnections(ctx context.Context)
- func (a *PeerManagerImpl) Spawned() []proto.IpPort
- func (a *PeerManagerImpl) Suspend(p peer.Peer, suspendTime time.Time, reason string)
- func (a *PeerManagerImpl) Suspended() []storage.SuspendedPeer
- func (a *PeerManagerImpl) UpdateKnownPeers(known []storage.KnownPeer) error
- func (a *PeerManagerImpl) UpdateScore(p peer.Peer, score *big.Int) error
- type PeerSpawner
- type PeerSpawnerImpl
- type PeerStorage
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type DuplicateChecker ¶ added in v0.8.1
type PeerManager ¶
type PeerManager interface { Connected(peer.Peer) (peer.Peer, bool) NewConnection(peer.Peer) error ConnectedCount() int InOutCount() (in int, out int) EachConnected(func(peer.Peer, *proto.Score)) IsSuspended(peer.Peer) bool Suspend(peer peer.Peer, suspendTime time.Time, reason string) Suspended() []storage.SuspendedPeer AddConnected(peer.Peer) PeerWithHighestScore() (peer.Peer, *big.Int, bool) UpdateScore(p peer.Peer, score *proto.Score) error UpdateKnownPeers([]storage.KnownPeer) error KnownPeers() []storage.KnownPeer Close() SpawnOutgoingConnections(context.Context) SpawnIncomingConnection(ctx context.Context, conn net.Conn) error Spawned() []proto.IpPort Connect(context.Context, proto.TCPAddr) error Score(p peer.Peer) (*proto.Score, error) // AskPeers sends GetPeersMessage message to all connected nodes. AskPeers() Disconnect(peer.Peer) }
type PeerManagerImpl ¶
type PeerManagerImpl struct {
// contains filtered or unexported fields
}
func NewPeerManager ¶
func NewPeerManager(spawner PeerSpawner, storage PeerStorage, limitConnections int, version proto.Version) *PeerManagerImpl
func (*PeerManagerImpl) AddAddress ¶
func (*PeerManagerImpl) AddConnected ¶
func (a *PeerManagerImpl) AddConnected(peer peer.Peer)
func (*PeerManagerImpl) AskPeers ¶
func (a *PeerManagerImpl) AskPeers()
func (*PeerManagerImpl) ClearSuspended ¶ added in v0.9.0
func (a *PeerManagerImpl) ClearSuspended(now time.Time)
func (*PeerManagerImpl) Close ¶
func (a *PeerManagerImpl) Close()
func (*PeerManagerImpl) ConnectedCount ¶ added in v0.5.0
func (a *PeerManagerImpl) ConnectedCount() int
func (*PeerManagerImpl) Disconnect ¶
func (a *PeerManagerImpl) Disconnect(p peer.Peer)
func (*PeerManagerImpl) EachConnected ¶
func (a *PeerManagerImpl) EachConnected(f func(peer peer.Peer, score *big.Int))
func (*PeerManagerImpl) InOutCount ¶ added in v0.5.0
func (a *PeerManagerImpl) InOutCount() (in int, out int)
InOutCount counts connected peers, in - incoming connections out - outgoing connections
func (*PeerManagerImpl) IsSuspended ¶
func (a *PeerManagerImpl) IsSuspended(p peer.Peer) bool
func (*PeerManagerImpl) KnownPeers ¶
func (a *PeerManagerImpl) KnownPeers() []storage.KnownPeer
func (*PeerManagerImpl) NewConnection ¶ added in v0.5.0
func (a *PeerManagerImpl) NewConnection(p peer.Peer) error
func (*PeerManagerImpl) PeerWithHighestScore ¶
func (*PeerManagerImpl) RemoveSpawned ¶
func (a *PeerManagerImpl) RemoveSpawned(addr proto.TCPAddr)
func (*PeerManagerImpl) Run ¶
func (a *PeerManagerImpl) Run(ctx context.Context)
func (*PeerManagerImpl) SetConnectPeers ¶ added in v0.5.0
func (a *PeerManagerImpl) SetConnectPeers(connect bool)
func (*PeerManagerImpl) SpawnIncomingConnection ¶
func (*PeerManagerImpl) SpawnOutgoingConnections ¶
func (a *PeerManagerImpl) SpawnOutgoingConnections(ctx context.Context)
func (*PeerManagerImpl) Spawned ¶
func (a *PeerManagerImpl) Spawned() []proto.IpPort
func (*PeerManagerImpl) Suspended ¶
func (a *PeerManagerImpl) Suspended() []storage.SuspendedPeer
func (*PeerManagerImpl) UpdateKnownPeers ¶
func (a *PeerManagerImpl) UpdateKnownPeers(known []storage.KnownPeer) error
func (*PeerManagerImpl) UpdateScore ¶
type PeerSpawner ¶
type PeerSpawnerImpl ¶
type PeerSpawnerImpl struct { DuplicateChecker DuplicateChecker // contains filtered or unexported fields }
func NewPeerSpawner ¶
func (*PeerSpawnerImpl) SpawnIncoming ¶
func (*PeerSpawnerImpl) SpawnOutgoing ¶
type PeerStorage ¶
type PeerStorage interface { Known() []storage.KnownPeer AddKnown(known []storage.KnownPeer) error DeleteKnown(known []storage.KnownPeer) error DropKnown() error Suspended(now time.Time) []storage.SuspendedPeer AddSuspended(suspended []storage.SuspendedPeer) error IsSuspendedIP(ip storage.IP, now time.Time) bool IsSuspendedIPs(ips []storage.IP, now time.Time) []bool DeleteSuspendedByIP(suspended []storage.SuspendedPeer) error RefreshSuspended(now time.Time) error DropSuspended() error DropStorage() error }
Click to show internal directories.
Click to hide internal directories.