2020-07-23 15:24:20 +00:00
|
|
|
package pbcommon
|
2019-09-20 18:37:22 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
2021-06-28 20:25:49 +00:00
|
|
|
|
|
|
|
"github.com/hashicorp/consul/agent/structs"
|
2019-09-20 18:37:22 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// IsRead is always true for QueryOption
|
|
|
|
func (q *QueryOptions) IsRead() bool {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
// AllowStaleRead returns whether a stale read should be allowed
|
|
|
|
func (q *QueryOptions) AllowStaleRead() bool {
|
|
|
|
return q.AllowStale
|
|
|
|
}
|
|
|
|
|
|
|
|
func (q *QueryOptions) TokenSecret() string {
|
|
|
|
return q.Token
|
|
|
|
}
|
|
|
|
|
2020-03-10 16:15:22 +00:00
|
|
|
func (q *QueryOptions) SetTokenSecret(s string) {
|
|
|
|
q.Token = s
|
|
|
|
}
|
|
|
|
|
2019-09-26 13:55:02 +00:00
|
|
|
// SetToken is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetToken(token string) {
|
|
|
|
q.Token = token
|
2019-09-20 18:37:22 +00:00
|
|
|
}
|
|
|
|
|
2019-09-26 13:55:02 +00:00
|
|
|
// SetMinQueryIndex is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetMinQueryIndex(minQueryIndex uint64) {
|
|
|
|
q.MinQueryIndex = minQueryIndex
|
2019-09-20 18:37:22 +00:00
|
|
|
}
|
|
|
|
|
2019-09-26 13:55:02 +00:00
|
|
|
// SetMaxQueryTime is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetMaxQueryTime(maxQueryTime time.Duration) {
|
|
|
|
q.MaxQueryTime = maxQueryTime
|
2019-09-20 18:37:22 +00:00
|
|
|
}
|
|
|
|
|
2019-09-26 13:55:02 +00:00
|
|
|
// SetAllowStale is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetAllowStale(allowStale bool) {
|
|
|
|
q.AllowStale = allowStale
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetRequireConsistent is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetRequireConsistent(requireConsistent bool) {
|
|
|
|
q.RequireConsistent = requireConsistent
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetUseCache is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetUseCache(useCache bool) {
|
|
|
|
q.UseCache = useCache
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetMaxStaleDuration is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetMaxStaleDuration(maxStaleDuration time.Duration) {
|
|
|
|
q.MaxStaleDuration = maxStaleDuration
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetMaxAge is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetMaxAge(maxAge time.Duration) {
|
|
|
|
q.MaxAge = maxAge
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetMustRevalidate is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetMustRevalidate(mustRevalidate bool) {
|
|
|
|
q.MustRevalidate = mustRevalidate
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetStaleIfError is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetStaleIfError(staleIfError time.Duration) {
|
|
|
|
q.StaleIfError = staleIfError
|
|
|
|
}
|
|
|
|
|
2021-07-22 18:58:08 +00:00
|
|
|
func (q QueryOptions) HasTimedOut(start time.Time, rpcHoldTimeout, maxQueryTime, defaultQueryTime time.Duration) bool {
|
|
|
|
o := structs.QueryOptions{
|
|
|
|
MaxQueryTime: q.MaxQueryTime,
|
|
|
|
MinQueryIndex: q.MinQueryIndex,
|
|
|
|
}
|
|
|
|
return o.HasTimedOut(start, rpcHoldTimeout, maxQueryTime, defaultQueryTime)
|
|
|
|
}
|
|
|
|
|
2019-09-26 13:55:02 +00:00
|
|
|
// SetFilter is needed to implement the structs.QueryOptionsCompat interface
|
|
|
|
func (q *QueryOptions) SetFilter(filter string) {
|
|
|
|
q.Filter = filter
|
|
|
|
}
|
|
|
|
|
2022-03-11 17:00:16 +00:00
|
|
|
// GetMaxQueryTime is required to implement blockingQueryOptions
|
|
|
|
func (q *QueryOptions) GetMaxQueryTime() time.Duration {
|
|
|
|
if q != nil {
|
|
|
|
return q.MaxQueryTime
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetMinQueryIndex is required to implement blockingQueryOptions
|
|
|
|
func (q *QueryOptions) GetMinQueryIndex() uint64 {
|
|
|
|
if q != nil {
|
|
|
|
return q.MinQueryIndex
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetRequireConsistent is required to implement blockingQueryOptions
|
|
|
|
func (q *QueryOptions) GetRequireConsistent() bool {
|
|
|
|
if q != nil {
|
|
|
|
return q.RequireConsistent
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetToken is required to implement blockingQueryOptions
|
|
|
|
func (q *QueryOptions) GetToken() string {
|
|
|
|
if q != nil {
|
|
|
|
return q.Token
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetAllowStale is required to implement structs.QueryOptionsCompat
|
|
|
|
func (q *QueryOptions) GetAllowStale() bool {
|
|
|
|
if q != nil {
|
|
|
|
return q.AllowStale
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetFilter is required to implement structs.QueryOptionsCompat
|
|
|
|
func (q *QueryOptions) GetFilter() string {
|
|
|
|
if q != nil {
|
|
|
|
return q.Filter
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetMaxAge is required to implement structs.QueryOptionsCompat
|
|
|
|
func (q *QueryOptions) GetMaxAge() time.Duration {
|
|
|
|
if q != nil {
|
|
|
|
return q.MaxAge
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetMaxStaleDuration is required to implement structs.QueryOptionsCompat
|
|
|
|
func (q *QueryOptions) GetMaxStaleDuration() time.Duration {
|
|
|
|
if q != nil {
|
|
|
|
return q.MaxStaleDuration
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetMustRevalidate is required to implement structs.QueryOptionsCompat
|
|
|
|
func (q *QueryOptions) GetMustRevalidate() bool {
|
|
|
|
if q != nil {
|
|
|
|
return q.MustRevalidate
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetStaleIfError is required to implement structs.QueryOptionsCompat
|
|
|
|
func (q *QueryOptions) GetStaleIfError() time.Duration {
|
|
|
|
if q != nil {
|
|
|
|
return q.StaleIfError
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetUseCache is required to implement structs.QueryOptionsCompat
|
|
|
|
func (q *QueryOptions) GetUseCache() bool {
|
|
|
|
if q != nil {
|
|
|
|
return q.UseCache
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2019-09-26 13:55:02 +00:00
|
|
|
// SetLastContact is needed to implement the structs.QueryMetaCompat interface
|
2019-09-20 18:37:22 +00:00
|
|
|
func (q *QueryMeta) SetLastContact(lastContact time.Duration) {
|
|
|
|
q.LastContact = lastContact
|
|
|
|
}
|
|
|
|
|
2019-09-26 13:55:02 +00:00
|
|
|
// SetKnownLeader is needed to implement the structs.QueryMetaCompat interface
|
2019-09-20 18:37:22 +00:00
|
|
|
func (q *QueryMeta) SetKnownLeader(knownLeader bool) {
|
|
|
|
q.KnownLeader = knownLeader
|
|
|
|
}
|
|
|
|
|
2019-09-26 13:55:02 +00:00
|
|
|
// SetIndex is needed to implement the structs.QueryMetaCompat interface
|
2019-09-20 18:37:22 +00:00
|
|
|
func (q *QueryMeta) SetIndex(index uint64) {
|
|
|
|
q.Index = index
|
|
|
|
}
|
|
|
|
|
2019-09-26 13:55:02 +00:00
|
|
|
// SetConsistencyLevel is needed to implement the structs.QueryMetaCompat interface
|
|
|
|
func (q *QueryMeta) SetConsistencyLevel(consistencyLevel string) {
|
|
|
|
q.ConsistencyLevel = consistencyLevel
|
|
|
|
}
|
|
|
|
|
2021-06-28 20:25:49 +00:00
|
|
|
func (q *QueryMeta) GetBackend() structs.QueryBackend {
|
|
|
|
return structs.QueryBackend(0)
|
|
|
|
}
|
|
|
|
|
2022-03-11 17:00:16 +00:00
|
|
|
// SetResultsFilteredByACLs is needed to implement the structs.QueryMetaCompat interface
|
|
|
|
func (q *QueryMeta) SetResultsFilteredByACLs(v bool) {
|
|
|
|
q.ResultsFilteredByACLs = v
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetIndex is required to implement blockingQueryResponseMeta
|
|
|
|
func (q *QueryMeta) GetIndex() uint64 {
|
|
|
|
if q != nil {
|
|
|
|
return q.Index
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetConsistencyLevel is required to implement structs.QueryMetaCompat
|
|
|
|
func (q *QueryMeta) GetConsistencyLevel() string {
|
|
|
|
if q != nil {
|
|
|
|
return q.ConsistencyLevel
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetKnownLeader is required to implement structs.QueryMetaCompat
|
|
|
|
func (q *QueryMeta) GetKnownLeader() bool {
|
|
|
|
if q != nil {
|
|
|
|
return q.KnownLeader
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetLastContact is required to implement structs.QueryMetaCompat
|
|
|
|
func (q *QueryMeta) GetLastContact() time.Duration {
|
|
|
|
if q != nil {
|
|
|
|
return q.LastContact
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetResultsFilteredByACLs is required to implement structs.QueryMetaCompat
|
|
|
|
func (q *QueryMeta) GetResultsFilteredByACLs() bool {
|
|
|
|
if q != nil {
|
|
|
|
return q.ResultsFilteredByACLs
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2019-09-20 18:37:22 +00:00
|
|
|
// WriteRequest only applies to writes, always false
|
2021-09-22 18:14:26 +00:00
|
|
|
//
|
|
|
|
// IsRead implements structs.RPCInfo
|
2019-09-20 18:37:22 +00:00
|
|
|
func (w WriteRequest) IsRead() bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2021-09-22 18:14:26 +00:00
|
|
|
// SetTokenSecret implements structs.RPCInfo
|
2019-09-26 13:55:02 +00:00
|
|
|
func (w WriteRequest) TokenSecret() string {
|
|
|
|
return w.Token
|
|
|
|
}
|
|
|
|
|
2021-09-22 18:14:26 +00:00
|
|
|
// SetTokenSecret implements structs.RPCInfo
|
2020-03-10 16:15:22 +00:00
|
|
|
func (w *WriteRequest) SetTokenSecret(s string) {
|
|
|
|
w.Token = s
|
|
|
|
}
|
|
|
|
|
2019-09-20 18:37:22 +00:00
|
|
|
// AllowStaleRead returns whether a stale read should be allowed
|
2021-09-22 18:14:26 +00:00
|
|
|
//
|
|
|
|
// AllowStaleRead implements structs.RPCInfo
|
2019-09-20 18:37:22 +00:00
|
|
|
func (w WriteRequest) AllowStaleRead() bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2021-09-22 18:14:26 +00:00
|
|
|
// HasTimedOut implements structs.RPCInfo
|
2021-07-22 18:58:08 +00:00
|
|
|
func (w WriteRequest) HasTimedOut(start time.Time, rpcHoldTimeout, _, _ time.Duration) bool {
|
|
|
|
return time.Since(start) > rpcHoldTimeout
|
|
|
|
}
|
|
|
|
|
2021-09-22 18:14:26 +00:00
|
|
|
// IsRead implements structs.RPCInfo
|
|
|
|
func (r *ReadRequest) IsRead() bool {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
// AllowStaleRead implements structs.RPCInfo
|
|
|
|
func (r *ReadRequest) AllowStaleRead() bool {
|
|
|
|
// TODO(partitions): plumb this?
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
// TokenSecret implements structs.RPCInfo
|
|
|
|
func (r *ReadRequest) TokenSecret() string {
|
|
|
|
return r.Token
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetTokenSecret implements structs.RPCInfo
|
|
|
|
func (r *ReadRequest) SetTokenSecret(token string) {
|
|
|
|
r.Token = token
|
|
|
|
}
|
|
|
|
|
|
|
|
// HasTimedOut implements structs.RPCInfo
|
|
|
|
func (r *ReadRequest) HasTimedOut(start time.Time, rpcHoldTimeout, maxQueryTime, defaultQueryTime time.Duration) bool {
|
|
|
|
return time.Since(start) > rpcHoldTimeout
|
|
|
|
}
|
|
|
|
|
|
|
|
// RequestDatacenter implements structs.RPCInfo
|
2019-09-20 18:37:22 +00:00
|
|
|
func (td TargetDatacenter) RequestDatacenter() string {
|
|
|
|
return td.Datacenter
|
|
|
|
}
|