mirror of
https://github.com/fluencelabs/go-libp2p-kad-dht
synced 2025-04-24 22:32:13 +00:00
31 lines
734 B
Go
31 lines
734 B
Go
package dht
|
|
|
|
import "github.com/libp2p/go-libp2p-core/routing"
|
|
|
|
type quorumOptionKey struct{}
|
|
|
|
const defaultQuorum = 0
|
|
|
|
// Quorum is a DHT option that tells the DHT how many peers it needs to get
|
|
// values from before returning the best one. Zero means the DHT query
|
|
// should complete instead of returning early.
|
|
//
|
|
// Default: 0
|
|
func Quorum(n int) routing.Option {
|
|
return func(opts *routing.Options) error {
|
|
if opts.Other == nil {
|
|
opts.Other = make(map[interface{}]interface{}, 1)
|
|
}
|
|
opts.Other[quorumOptionKey{}] = n
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func getQuorum(opts *routing.Options, ndefault int) int {
|
|
responsesNeeded, ok := opts.Other[quorumOptionKey{}].(int)
|
|
if !ok {
|
|
responsesNeeded = ndefault
|
|
}
|
|
return responsesNeeded
|
|
}
|