influxdb/models/consistency.go

49 lines
1.3 KiB
Go
Raw Normal View History

package models
import (
"errors"
"strings"
)
// ConsistencyLevel represent a required replication criteria before a write can
2016-12-30 19:56:58 +00:00
// be returned as successful.
//
// The consistency level is handled in open-source InfluxDB but only applicable to clusters.
type ConsistencyLevel int
const (
2016-12-30 19:56:58 +00:00
// ConsistencyLevelAny allows for hinted handoff, potentially no write happened yet.
ConsistencyLevelAny ConsistencyLevel = iota
2016-12-30 19:56:58 +00:00
// ConsistencyLevelOne requires at least one data node acknowledged a write.
ConsistencyLevelOne
2016-12-30 19:56:58 +00:00
// ConsistencyLevelQuorum requires a quorum of data nodes to acknowledge a write.
ConsistencyLevelQuorum
2016-12-30 19:56:58 +00:00
// ConsistencyLevelAll requires all data nodes to acknowledge a write.
ConsistencyLevelAll
)
var (
// ErrInvalidConsistencyLevel is returned when parsing the string version
// of a consistency level.
ErrInvalidConsistencyLevel = errors.New("invalid consistency level")
)
2016-12-30 19:56:58 +00:00
// ParseConsistencyLevel converts a consistency level string to the corresponding ConsistencyLevel const.
func ParseConsistencyLevel(level string) (ConsistencyLevel, error) {
switch strings.ToLower(level) {
case "any":
return ConsistencyLevelAny, nil
case "one":
return ConsistencyLevelOne, nil
case "quorum":
return ConsistencyLevelQuorum, nil
case "all":
return ConsistencyLevelAll, nil
default:
return 0, ErrInvalidConsistencyLevel
}
}