val create : peer_id_size:int -> ip_size:int -> ip_cleanup_delay:Tezos_base.TzPervasives.Time.System.Span.t -> t
create ~peer_id_size ~ip_size is a set of four ACLs (see above) with the peer_id greylist being a LRU cache of size
peer_id_size and the IP address greylist a bloom filter of size
ip_size (expressed in KiB). Elements are (probabilistically) kept in the bloom filter for
ip_cleanup_delay, the cleanup happens in a discrete way in sixteen steps.
banned_addr t addr is
addr is blacklisted or greylisted.
unban_addr t addr remove the address from both the blacklist of banned addresses and the greylist of addresses
banned_peer t peer_id is
true if peer with id
peer_id is blacklisted or greylisted.
unban_peer t peer remove the peer from both the blacklist of banned peers and the greylist of peers
val clear : t -> unit
clear t clears all four ACLs.
module IPGreylist : sig ... end
module IPBlacklist : sig ... end
module PeerBlacklist : sig ... end
module PeerGreylist : sig ... end
A Mutable structure akin to a set, but with a size bound. Note that, different caches have different policies towards the size bounds: some uphold the bound strictly, some treat the bound as a suggestion. In addition, some caches count their elements somewhat sloppily.