mirror of
https://github.com/status-im/consul.git
synced 2025-01-22 11:40:06 +00:00
150 lines
5.2 KiB
Go
150 lines
5.2 KiB
Go
|
package configentry
|
||
|
|
||
|
import (
|
||
|
"github.com/hashicorp/consul/agent/structs"
|
||
|
)
|
||
|
|
||
|
// DiscoveryChainSet is a wrapped set of raw cross-referenced config entries
|
||
|
// necessary for the DiscoveryChain.Get RPC process.
|
||
|
//
|
||
|
// None of these are defaulted.
|
||
|
type DiscoveryChainSet struct {
|
||
|
Routers map[structs.ServiceID]*structs.ServiceRouterConfigEntry
|
||
|
Splitters map[structs.ServiceID]*structs.ServiceSplitterConfigEntry
|
||
|
Resolvers map[structs.ServiceID]*structs.ServiceResolverConfigEntry
|
||
|
Services map[structs.ServiceID]*structs.ServiceConfigEntry
|
||
|
ProxyDefaults map[string]*structs.ProxyConfigEntry
|
||
|
}
|
||
|
|
||
|
func NewDiscoveryChainSet() *DiscoveryChainSet {
|
||
|
return &DiscoveryChainSet{
|
||
|
Routers: make(map[structs.ServiceID]*structs.ServiceRouterConfigEntry),
|
||
|
Splitters: make(map[structs.ServiceID]*structs.ServiceSplitterConfigEntry),
|
||
|
Resolvers: make(map[structs.ServiceID]*structs.ServiceResolverConfigEntry),
|
||
|
Services: make(map[structs.ServiceID]*structs.ServiceConfigEntry),
|
||
|
ProxyDefaults: make(map[string]*structs.ProxyConfigEntry),
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (e *DiscoveryChainSet) GetRouter(sid structs.ServiceID) *structs.ServiceRouterConfigEntry {
|
||
|
if e.Routers != nil {
|
||
|
return e.Routers[sid]
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (e *DiscoveryChainSet) GetSplitter(sid structs.ServiceID) *structs.ServiceSplitterConfigEntry {
|
||
|
if e.Splitters != nil {
|
||
|
return e.Splitters[sid]
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (e *DiscoveryChainSet) GetResolver(sid structs.ServiceID) *structs.ServiceResolverConfigEntry {
|
||
|
if e.Resolvers != nil {
|
||
|
return e.Resolvers[sid]
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (e *DiscoveryChainSet) GetService(sid structs.ServiceID) *structs.ServiceConfigEntry {
|
||
|
if e.Services != nil {
|
||
|
return e.Services[sid]
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (e *DiscoveryChainSet) GetProxyDefaults(partition string) *structs.ProxyConfigEntry {
|
||
|
if e.ProxyDefaults != nil {
|
||
|
return e.ProxyDefaults[partition]
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
// AddRouters adds router configs. Convenience function for testing.
|
||
|
func (e *DiscoveryChainSet) AddRouters(entries ...*structs.ServiceRouterConfigEntry) {
|
||
|
if e.Routers == nil {
|
||
|
e.Routers = make(map[structs.ServiceID]*structs.ServiceRouterConfigEntry)
|
||
|
}
|
||
|
for _, entry := range entries {
|
||
|
e.Routers[structs.NewServiceID(entry.Name, &entry.EnterpriseMeta)] = entry
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// AddSplitters adds splitter configs. Convenience function for testing.
|
||
|
func (e *DiscoveryChainSet) AddSplitters(entries ...*structs.ServiceSplitterConfigEntry) {
|
||
|
if e.Splitters == nil {
|
||
|
e.Splitters = make(map[structs.ServiceID]*structs.ServiceSplitterConfigEntry)
|
||
|
}
|
||
|
for _, entry := range entries {
|
||
|
e.Splitters[structs.NewServiceID(entry.Name, entry.GetEnterpriseMeta())] = entry
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// AddResolvers adds resolver configs. Convenience function for testing.
|
||
|
func (e *DiscoveryChainSet) AddResolvers(entries ...*structs.ServiceResolverConfigEntry) {
|
||
|
if e.Resolvers == nil {
|
||
|
e.Resolvers = make(map[structs.ServiceID]*structs.ServiceResolverConfigEntry)
|
||
|
}
|
||
|
for _, entry := range entries {
|
||
|
e.Resolvers[structs.NewServiceID(entry.Name, entry.GetEnterpriseMeta())] = entry
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// AddServices adds service configs. Convenience function for testing.
|
||
|
func (e *DiscoveryChainSet) AddServices(entries ...*structs.ServiceConfigEntry) {
|
||
|
if e.Services == nil {
|
||
|
e.Services = make(map[structs.ServiceID]*structs.ServiceConfigEntry)
|
||
|
}
|
||
|
for _, entry := range entries {
|
||
|
e.Services[structs.NewServiceID(entry.Name, entry.GetEnterpriseMeta())] = entry
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// AddProxyDefaults adds proxy-defaults configs. Convenience function for testing.
|
||
|
func (e *DiscoveryChainSet) AddProxyDefaults(entries ...*structs.ProxyConfigEntry) {
|
||
|
if e.ProxyDefaults == nil {
|
||
|
e.ProxyDefaults = make(map[string]*structs.ProxyConfigEntry)
|
||
|
}
|
||
|
for _, entry := range entries {
|
||
|
e.ProxyDefaults[entry.PartitionOrDefault()] = entry
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// AddEntries adds generic configs. Convenience function for testing. Panics on
|
||
|
// operator error.
|
||
|
func (e *DiscoveryChainSet) AddEntries(entries ...structs.ConfigEntry) {
|
||
|
for _, entry := range entries {
|
||
|
switch entry.GetKind() {
|
||
|
case structs.ServiceRouter:
|
||
|
e.AddRouters(entry.(*structs.ServiceRouterConfigEntry))
|
||
|
case structs.ServiceSplitter:
|
||
|
e.AddSplitters(entry.(*structs.ServiceSplitterConfigEntry))
|
||
|
case structs.ServiceResolver:
|
||
|
e.AddResolvers(entry.(*structs.ServiceResolverConfigEntry))
|
||
|
case structs.ServiceDefaults:
|
||
|
e.AddServices(entry.(*structs.ServiceConfigEntry))
|
||
|
case structs.ProxyDefaults:
|
||
|
if entry.GetName() != structs.ProxyConfigGlobal {
|
||
|
panic("the only supported proxy-defaults name is '" + structs.ProxyConfigGlobal + "'")
|
||
|
}
|
||
|
e.AddProxyDefaults(entry.(*structs.ProxyConfigEntry))
|
||
|
default:
|
||
|
panic("unhandled config entry kind: " + entry.GetKind())
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// IsEmpty returns true if there are no config entries at all in the response.
|
||
|
// You should prefer this over IsChainEmpty() in most cases.
|
||
|
func (e *DiscoveryChainSet) IsEmpty() bool {
|
||
|
return e.IsChainEmpty() && len(e.Services) == 0 && len(e.ProxyDefaults) == 0
|
||
|
}
|
||
|
|
||
|
// IsChainEmpty returns true if there are no service-routers,
|
||
|
// service-splitters, or service-resolvers that are present. These config
|
||
|
// entries are the primary parts of the discovery chain.
|
||
|
func (e *DiscoveryChainSet) IsChainEmpty() bool {
|
||
|
return len(e.Routers) == 0 && len(e.Splitters) == 0 && len(e.Resolvers) == 0
|
||
|
}
|