2018-04-03 20:46:07 -07:00
|
|
|
package cache
|
|
|
|
|
2018-04-16 12:06:08 +02:00
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2018-04-17 18:42:49 -05:00
|
|
|
// Request is a cacheable request.
|
2018-04-03 20:46:07 -07:00
|
|
|
//
|
|
|
|
// This interface is typically implemented by request structures in
|
|
|
|
// the agent/structs package.
|
2022-07-05 16:57:15 -05:00
|
|
|
//go:generate mockery --name Request --inpackage
|
2018-04-03 20:46:07 -07:00
|
|
|
type Request interface {
|
2018-04-08 15:08:34 +01:00
|
|
|
// CacheInfo returns information used for caching this request.
|
|
|
|
CacheInfo() RequestInfo
|
|
|
|
}
|
|
|
|
|
|
|
|
// RequestInfo represents cache information for a request. The caching
|
|
|
|
// framework uses this to control the behavior of caching and to determine
|
|
|
|
// cacheability.
|
peering: initial sync (#12842)
- Add endpoints related to peering: read, list, generate token, initiate peering
- Update node/service/check table indexing to account for peers
- Foundational changes for pushing service updates to a peer
- Plumb peer name through Health.ServiceNodes path
see: ENT-1765, ENT-1280, ENT-1283, ENT-1283, ENT-1756, ENT-1739, ENT-1750, ENT-1679,
ENT-1709, ENT-1704, ENT-1690, ENT-1689, ENT-1702, ENT-1701, ENT-1683, ENT-1663,
ENT-1650, ENT-1678, ENT-1628, ENT-1658, ENT-1640, ENT-1637, ENT-1597, ENT-1634,
ENT-1613, ENT-1616, ENT-1617, ENT-1591, ENT-1588, ENT-1596, ENT-1572, ENT-1555
Co-authored-by: R.B. Boyer <rb@hashicorp.com>
Co-authored-by: freddygv <freddy@hashicorp.com>
Co-authored-by: Chris S. Kim <ckim@hashicorp.com>
Co-authored-by: Evan Culver <eculver@hashicorp.com>
Co-authored-by: Nitya Dhanushkodi <nitya@hashicorp.com>
2022-04-21 17:34:40 -05:00
|
|
|
//
|
|
|
|
// TODO(peering): finish ensuring everything that sets a Datacenter sets or doesn't set PeerName.
|
|
|
|
// TODO(peering): also make sure the peer name is present in the cache key likely in lieu of the datacenter somehow.
|
2018-04-08 15:08:34 +01:00
|
|
|
type RequestInfo struct {
|
|
|
|
// Key is a unique cache key for this request. This key should
|
2018-04-22 13:52:48 -07:00
|
|
|
// be globally unique to identify this request, since any conflicting
|
2018-04-03 20:46:07 -07:00
|
|
|
// cache keys could result in invalid data being returned from the cache.
|
2018-04-17 18:42:49 -05:00
|
|
|
// The Key does not need to include ACL or DC information, since the
|
|
|
|
// cache already partitions by these values prior to using this key.
|
2018-04-08 15:08:34 +01:00
|
|
|
Key string
|
|
|
|
|
|
|
|
// Token is the ACL token associated with this request.
|
|
|
|
//
|
|
|
|
// Datacenter is the datacenter that the request is targeting.
|
|
|
|
//
|
peering: initial sync (#12842)
- Add endpoints related to peering: read, list, generate token, initiate peering
- Update node/service/check table indexing to account for peers
- Foundational changes for pushing service updates to a peer
- Plumb peer name through Health.ServiceNodes path
see: ENT-1765, ENT-1280, ENT-1283, ENT-1283, ENT-1756, ENT-1739, ENT-1750, ENT-1679,
ENT-1709, ENT-1704, ENT-1690, ENT-1689, ENT-1702, ENT-1701, ENT-1683, ENT-1663,
ENT-1650, ENT-1678, ENT-1628, ENT-1658, ENT-1640, ENT-1637, ENT-1597, ENT-1634,
ENT-1613, ENT-1616, ENT-1617, ENT-1591, ENT-1588, ENT-1596, ENT-1572, ENT-1555
Co-authored-by: R.B. Boyer <rb@hashicorp.com>
Co-authored-by: freddygv <freddy@hashicorp.com>
Co-authored-by: Chris S. Kim <ckim@hashicorp.com>
Co-authored-by: Evan Culver <eculver@hashicorp.com>
Co-authored-by: Nitya Dhanushkodi <nitya@hashicorp.com>
2022-04-21 17:34:40 -05:00
|
|
|
// PeerName is the peer that the request is targeting.
|
|
|
|
//
|
|
|
|
// All of these values are used to partition the cache. The cache framework
|
2018-04-08 15:08:34 +01:00
|
|
|
// today partitions data on these values to simplify behavior: by
|
|
|
|
// partitioning ACL tokens, the cache doesn't need to be smart about
|
peering: initial sync (#12842)
- Add endpoints related to peering: read, list, generate token, initiate peering
- Update node/service/check table indexing to account for peers
- Foundational changes for pushing service updates to a peer
- Plumb peer name through Health.ServiceNodes path
see: ENT-1765, ENT-1280, ENT-1283, ENT-1283, ENT-1756, ENT-1739, ENT-1750, ENT-1679,
ENT-1709, ENT-1704, ENT-1690, ENT-1689, ENT-1702, ENT-1701, ENT-1683, ENT-1663,
ENT-1650, ENT-1678, ENT-1628, ENT-1658, ENT-1640, ENT-1637, ENT-1597, ENT-1634,
ENT-1613, ENT-1616, ENT-1617, ENT-1591, ENT-1588, ENT-1596, ENT-1572, ENT-1555
Co-authored-by: R.B. Boyer <rb@hashicorp.com>
Co-authored-by: freddygv <freddy@hashicorp.com>
Co-authored-by: Chris S. Kim <ckim@hashicorp.com>
Co-authored-by: Evan Culver <eculver@hashicorp.com>
Co-authored-by: Nitya Dhanushkodi <nitya@hashicorp.com>
2022-04-21 17:34:40 -05:00
|
|
|
// filtering results. By filtering datacenter/peer results, the cache can
|
|
|
|
// service the multi-DC/multi-peer nature of Consul. This comes at the expense of
|
2018-04-08 15:08:34 +01:00
|
|
|
// working set size, but in general the effect is minimal.
|
|
|
|
Token string
|
|
|
|
Datacenter string
|
peering: initial sync (#12842)
- Add endpoints related to peering: read, list, generate token, initiate peering
- Update node/service/check table indexing to account for peers
- Foundational changes for pushing service updates to a peer
- Plumb peer name through Health.ServiceNodes path
see: ENT-1765, ENT-1280, ENT-1283, ENT-1283, ENT-1756, ENT-1739, ENT-1750, ENT-1679,
ENT-1709, ENT-1704, ENT-1690, ENT-1689, ENT-1702, ENT-1701, ENT-1683, ENT-1663,
ENT-1650, ENT-1678, ENT-1628, ENT-1658, ENT-1640, ENT-1637, ENT-1597, ENT-1634,
ENT-1613, ENT-1616, ENT-1617, ENT-1591, ENT-1588, ENT-1596, ENT-1572, ENT-1555
Co-authored-by: R.B. Boyer <rb@hashicorp.com>
Co-authored-by: freddygv <freddy@hashicorp.com>
Co-authored-by: Chris S. Kim <ckim@hashicorp.com>
Co-authored-by: Evan Culver <eculver@hashicorp.com>
Co-authored-by: Nitya Dhanushkodi <nitya@hashicorp.com>
2022-04-21 17:34:40 -05:00
|
|
|
PeerName string
|
2018-04-03 20:46:07 -07:00
|
|
|
|
2018-04-08 15:08:34 +01:00
|
|
|
// MinIndex is the minimum index being queried. This is used to
|
2018-04-03 20:46:07 -07:00
|
|
|
// determine if we already have data satisfying the query or if we need
|
2018-04-08 15:08:34 +01:00
|
|
|
// to block until new data is available. If no index is available, the
|
|
|
|
// default value (zero) is acceptable.
|
|
|
|
MinIndex uint64
|
2018-04-16 12:06:08 +02:00
|
|
|
|
|
|
|
// Timeout is the timeout for waiting on a blocking query. When the
|
|
|
|
// timeout is reached, the last known value is returned (or maybe nil
|
2018-04-17 18:42:49 -05:00
|
|
|
// if there was no prior value). This "last known value" behavior matches
|
|
|
|
// normal Consul blocking queries.
|
2018-04-16 12:06:08 +02:00
|
|
|
Timeout time.Duration
|
2018-09-06 11:34:28 +01:00
|
|
|
|
|
|
|
// MaxAge if set limits how stale a cache entry can be. If it is non-zero and
|
|
|
|
// there is an entry in cache that is older than specified, it is treated as a
|
|
|
|
// cache miss and re-fetched. It is ignored for cachetypes with Refresh =
|
|
|
|
// true.
|
|
|
|
MaxAge time.Duration
|
|
|
|
|
|
|
|
// MustRevalidate forces a new lookup of the cache even if there is an
|
|
|
|
// existing one that has not expired. It is implied by HTTP requests with
|
|
|
|
// `Cache-Control: max-age=0` but we can't distinguish that case from the
|
|
|
|
// unset case for MaxAge. Later we may support revalidating the index without
|
|
|
|
// a full re-fetch but for now the only option is to refetch. It is ignored
|
|
|
|
// for cachetypes with Refresh = true.
|
|
|
|
MustRevalidate bool
|
2018-04-03 20:46:07 -07:00
|
|
|
}
|