2014-12-29 13:43:56 +00:00
|
|
|
package queue
|
|
|
|
|
2015-03-31 03:04:32 +00:00
|
|
|
import peer "github.com/ipfs/go-ipfs/p2p/peer"
|
2014-12-29 13:43:56 +00:00
|
|
|
|
|
|
|
// PeerQueue maintains a set of peers ordered according to a metric.
|
|
|
|
// Implementations of PeerQueue could order peers based on distances along
|
|
|
|
// a KeySpace, latency measurements, trustworthiness, reputation, etc.
|
|
|
|
type PeerQueue interface {
|
|
|
|
|
|
|
|
// Len returns the number of items in PeerQueue
|
|
|
|
Len() int
|
|
|
|
|
|
|
|
// Enqueue adds this node to the queue.
|
|
|
|
Enqueue(peer.ID)
|
|
|
|
|
|
|
|
// Dequeue retrieves the highest (smallest int) priority node
|
|
|
|
Dequeue() peer.ID
|
|
|
|
}
|