2019-04-18 12:39:37 +00:00
|
|
|
package pubsub
|
|
|
|
|
|
|
|
import (
|
|
|
|
lru "github.com/hashicorp/golang-lru"
|
2019-06-12 17:36:56 +00:00
|
|
|
"github.com/libp2p/go-libp2p-core/peer"
|
2019-04-18 12:39:37 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// Blacklist is an interface for peer blacklisting.
|
|
|
|
type Blacklist interface {
|
|
|
|
Add(peer.ID)
|
|
|
|
Contains(peer.ID) bool
|
|
|
|
}
|
|
|
|
|
|
|
|
// MapBlacklist is a blacklist implementation using a perfect map
|
|
|
|
type MapBlacklist map[peer.ID]struct{}
|
|
|
|
|
|
|
|
// NewMapBlacklist creates a new MapBlacklist
|
|
|
|
func NewMapBlacklist() Blacklist {
|
|
|
|
return MapBlacklist(make(map[peer.ID]struct{}))
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b MapBlacklist) Add(p peer.ID) {
|
|
|
|
b[p] = struct{}{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b MapBlacklist) Contains(p peer.ID) bool {
|
|
|
|
_, ok := b[p]
|
|
|
|
return ok
|
|
|
|
}
|
|
|
|
|
|
|
|
// LRUBlacklist is a blacklist implementation using an LRU cache
|
|
|
|
type LRUBlacklist struct {
|
|
|
|
lru *lru.Cache
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewLRUBlacklist creates a new LRUBlacklist with capacity cap
|
|
|
|
func NewLRUBlacklist(cap int) (Blacklist, error) {
|
|
|
|
c, err := lru.New(cap)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
b := &LRUBlacklist{lru: c}
|
|
|
|
return b, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b LRUBlacklist) Add(p peer.ID) {
|
|
|
|
b.lru.Add(p, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b LRUBlacklist) Contains(p peer.ID) bool {
|
|
|
|
return b.lru.Contains(p)
|
|
|
|
}
|