mirror of
https://github.com/status-im/consul.git
synced 2025-01-10 13:55:55 +00:00
e6b55d1d81
Replaces the reflection-based implementation of proxycfg's ConfigSnapshot.Clone with code generated by deep-copy. While load testing server-based xDS (for consul-dataplane) we discovered this method is extremely expensive. The ConfigSnapshot struct, directly or indirectly, contains a copy of many of the structs in the agent/structs package, which creates a large graph for copystructure.Copy to traverse at runtime, on every proxy reconfiguration.
839 lines
24 KiB
Go
839 lines
24 KiB
Go
// generated by deep-copy -pointer-receiver -o ./structs.deepcopy.go -type CARoot -type CheckServiceNode -type CheckType -type CompiledDiscoveryChain -type ConnectProxyConfig -type DiscoveryFailover -type DiscoveryGraphNode -type DiscoveryResolver -type DiscoveryRoute -type DiscoverySplit -type ExposeConfig -type GatewayService -type GatewayServiceTLSConfig -type HTTPHeaderModifiers -type HashPolicy -type HealthCheck -type IndexedCARoots -type IngressListener -type Intention -type IntentionPermission -type LoadBalancer -type MeshConfigEntry -type MeshDirectionalTLSConfig -type MeshTLSConfig -type Node -type NodeService -type PeeringServiceMeta -type ServiceConfigEntry -type ServiceConfigResponse -type ServiceConnect -type ServiceDefinition -type ServiceResolverConfigEntry -type ServiceResolverFailover -type ServiceRoute -type ServiceRouteDestination -type ServiceRouteMatch -type Upstream -type UpstreamConfiguration ./; DO NOT EDIT.
|
|
|
|
package structs
|
|
|
|
import (
|
|
"github.com/hashicorp/consul/types"
|
|
)
|
|
|
|
// DeepCopy generates a deep copy of *CARoot
|
|
func (o *CARoot) DeepCopy() *CARoot {
|
|
var cp CARoot = *o
|
|
if o.IntermediateCerts != nil {
|
|
cp.IntermediateCerts = make([]string, len(o.IntermediateCerts))
|
|
copy(cp.IntermediateCerts, o.IntermediateCerts)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *CheckServiceNode
|
|
func (o *CheckServiceNode) DeepCopy() *CheckServiceNode {
|
|
var cp CheckServiceNode = *o
|
|
if o.Node != nil {
|
|
cp.Node = o.Node.DeepCopy()
|
|
}
|
|
if o.Service != nil {
|
|
cp.Service = o.Service.DeepCopy()
|
|
}
|
|
if o.Checks != nil {
|
|
cp.Checks = make([]*HealthCheck, len(o.Checks))
|
|
copy(cp.Checks, o.Checks)
|
|
for i2 := range o.Checks {
|
|
if o.Checks[i2] != nil {
|
|
cp.Checks[i2] = o.Checks[i2].DeepCopy()
|
|
}
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *CheckType
|
|
func (o *CheckType) DeepCopy() *CheckType {
|
|
var cp CheckType = *o
|
|
if o.ScriptArgs != nil {
|
|
cp.ScriptArgs = make([]string, len(o.ScriptArgs))
|
|
copy(cp.ScriptArgs, o.ScriptArgs)
|
|
}
|
|
if o.Header != nil {
|
|
cp.Header = make(map[string][]string, len(o.Header))
|
|
for k2, v2 := range o.Header {
|
|
var cp_Header_v2 []string
|
|
if v2 != nil {
|
|
cp_Header_v2 = make([]string, len(v2))
|
|
copy(cp_Header_v2, v2)
|
|
}
|
|
cp.Header[k2] = cp_Header_v2
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *CompiledDiscoveryChain
|
|
func (o *CompiledDiscoveryChain) DeepCopy() *CompiledDiscoveryChain {
|
|
var cp CompiledDiscoveryChain = *o
|
|
if o.ServiceMeta != nil {
|
|
cp.ServiceMeta = make(map[string]string, len(o.ServiceMeta))
|
|
for k2, v2 := range o.ServiceMeta {
|
|
cp.ServiceMeta[k2] = v2
|
|
}
|
|
}
|
|
if o.Nodes != nil {
|
|
cp.Nodes = make(map[string]*DiscoveryGraphNode, len(o.Nodes))
|
|
for k2, v2 := range o.Nodes {
|
|
var cp_Nodes_v2 *DiscoveryGraphNode
|
|
if v2 != nil {
|
|
cp_Nodes_v2 = v2.DeepCopy()
|
|
}
|
|
cp.Nodes[k2] = cp_Nodes_v2
|
|
}
|
|
}
|
|
if o.Targets != nil {
|
|
cp.Targets = make(map[string]*DiscoveryTarget, len(o.Targets))
|
|
for k2, v2 := range o.Targets {
|
|
var cp_Targets_v2 *DiscoveryTarget
|
|
if v2 != nil {
|
|
cp_Targets_v2 = new(DiscoveryTarget)
|
|
*cp_Targets_v2 = *v2
|
|
}
|
|
cp.Targets[k2] = cp_Targets_v2
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ConnectProxyConfig
|
|
func (o *ConnectProxyConfig) DeepCopy() *ConnectProxyConfig {
|
|
var cp ConnectProxyConfig = *o
|
|
if o.Config != nil {
|
|
cp.Config = make(map[string]interface{}, len(o.Config))
|
|
for k2, v2 := range o.Config {
|
|
cp.Config[k2] = v2
|
|
}
|
|
}
|
|
if o.Upstreams != nil {
|
|
cp.Upstreams = make([]Upstream, len(o.Upstreams))
|
|
copy(cp.Upstreams, o.Upstreams)
|
|
for i2 := range o.Upstreams {
|
|
{
|
|
retV := o.Upstreams[i2].DeepCopy()
|
|
cp.Upstreams[i2] = *retV
|
|
}
|
|
}
|
|
}
|
|
{
|
|
retV := o.Expose.DeepCopy()
|
|
cp.Expose = *retV
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *DiscoveryFailover
|
|
func (o *DiscoveryFailover) DeepCopy() *DiscoveryFailover {
|
|
var cp DiscoveryFailover = *o
|
|
if o.Targets != nil {
|
|
cp.Targets = make([]string, len(o.Targets))
|
|
copy(cp.Targets, o.Targets)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *DiscoveryGraphNode
|
|
func (o *DiscoveryGraphNode) DeepCopy() *DiscoveryGraphNode {
|
|
var cp DiscoveryGraphNode = *o
|
|
if o.Routes != nil {
|
|
cp.Routes = make([]*DiscoveryRoute, len(o.Routes))
|
|
copy(cp.Routes, o.Routes)
|
|
for i2 := range o.Routes {
|
|
if o.Routes[i2] != nil {
|
|
cp.Routes[i2] = o.Routes[i2].DeepCopy()
|
|
}
|
|
}
|
|
}
|
|
if o.Splits != nil {
|
|
cp.Splits = make([]*DiscoverySplit, len(o.Splits))
|
|
copy(cp.Splits, o.Splits)
|
|
for i2 := range o.Splits {
|
|
if o.Splits[i2] != nil {
|
|
cp.Splits[i2] = o.Splits[i2].DeepCopy()
|
|
}
|
|
}
|
|
}
|
|
if o.Resolver != nil {
|
|
cp.Resolver = o.Resolver.DeepCopy()
|
|
}
|
|
if o.LoadBalancer != nil {
|
|
cp.LoadBalancer = o.LoadBalancer.DeepCopy()
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *DiscoveryResolver
|
|
func (o *DiscoveryResolver) DeepCopy() *DiscoveryResolver {
|
|
var cp DiscoveryResolver = *o
|
|
if o.Failover != nil {
|
|
cp.Failover = o.Failover.DeepCopy()
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *DiscoveryRoute
|
|
func (o *DiscoveryRoute) DeepCopy() *DiscoveryRoute {
|
|
var cp DiscoveryRoute = *o
|
|
if o.Definition != nil {
|
|
cp.Definition = o.Definition.DeepCopy()
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *DiscoverySplit
|
|
func (o *DiscoverySplit) DeepCopy() *DiscoverySplit {
|
|
var cp DiscoverySplit = *o
|
|
if o.Definition != nil {
|
|
cp.Definition = new(ServiceSplit)
|
|
*cp.Definition = *o.Definition
|
|
if o.Definition.RequestHeaders != nil {
|
|
cp.Definition.RequestHeaders = o.Definition.RequestHeaders.DeepCopy()
|
|
}
|
|
if o.Definition.ResponseHeaders != nil {
|
|
cp.Definition.ResponseHeaders = o.Definition.ResponseHeaders.DeepCopy()
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ExposeConfig
|
|
func (o *ExposeConfig) DeepCopy() *ExposeConfig {
|
|
var cp ExposeConfig = *o
|
|
if o.Paths != nil {
|
|
cp.Paths = make([]ExposePath, len(o.Paths))
|
|
copy(cp.Paths, o.Paths)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *GatewayService
|
|
func (o *GatewayService) DeepCopy() *GatewayService {
|
|
var cp GatewayService = *o
|
|
if o.Hosts != nil {
|
|
cp.Hosts = make([]string, len(o.Hosts))
|
|
copy(cp.Hosts, o.Hosts)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *GatewayServiceTLSConfig
|
|
func (o *GatewayServiceTLSConfig) DeepCopy() *GatewayServiceTLSConfig {
|
|
var cp GatewayServiceTLSConfig = *o
|
|
if o.SDS != nil {
|
|
cp.SDS = new(GatewayTLSSDSConfig)
|
|
*cp.SDS = *o.SDS
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *HTTPHeaderModifiers
|
|
func (o *HTTPHeaderModifiers) DeepCopy() *HTTPHeaderModifiers {
|
|
var cp HTTPHeaderModifiers = *o
|
|
if o.Add != nil {
|
|
cp.Add = make(map[string]string, len(o.Add))
|
|
for k2, v2 := range o.Add {
|
|
cp.Add[k2] = v2
|
|
}
|
|
}
|
|
if o.Set != nil {
|
|
cp.Set = make(map[string]string, len(o.Set))
|
|
for k2, v2 := range o.Set {
|
|
cp.Set[k2] = v2
|
|
}
|
|
}
|
|
if o.Remove != nil {
|
|
cp.Remove = make([]string, len(o.Remove))
|
|
copy(cp.Remove, o.Remove)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *HashPolicy
|
|
func (o *HashPolicy) DeepCopy() *HashPolicy {
|
|
var cp HashPolicy = *o
|
|
if o.CookieConfig != nil {
|
|
cp.CookieConfig = new(CookieConfig)
|
|
*cp.CookieConfig = *o.CookieConfig
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *HealthCheck
|
|
func (o *HealthCheck) DeepCopy() *HealthCheck {
|
|
var cp HealthCheck = *o
|
|
if o.ServiceTags != nil {
|
|
cp.ServiceTags = make([]string, len(o.ServiceTags))
|
|
copy(cp.ServiceTags, o.ServiceTags)
|
|
}
|
|
if o.Definition.Header != nil {
|
|
cp.Definition.Header = make(map[string][]string, len(o.Definition.Header))
|
|
for k3, v3 := range o.Definition.Header {
|
|
var cp_Definition_Header_v3 []string
|
|
if v3 != nil {
|
|
cp_Definition_Header_v3 = make([]string, len(v3))
|
|
copy(cp_Definition_Header_v3, v3)
|
|
}
|
|
cp.Definition.Header[k3] = cp_Definition_Header_v3
|
|
}
|
|
}
|
|
if o.Definition.ScriptArgs != nil {
|
|
cp.Definition.ScriptArgs = make([]string, len(o.Definition.ScriptArgs))
|
|
copy(cp.Definition.ScriptArgs, o.Definition.ScriptArgs)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *IndexedCARoots
|
|
func (o *IndexedCARoots) DeepCopy() *IndexedCARoots {
|
|
var cp IndexedCARoots = *o
|
|
if o.Roots != nil {
|
|
cp.Roots = make([]*CARoot, len(o.Roots))
|
|
copy(cp.Roots, o.Roots)
|
|
for i2 := range o.Roots {
|
|
if o.Roots[i2] != nil {
|
|
cp.Roots[i2] = o.Roots[i2].DeepCopy()
|
|
}
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *IngressListener
|
|
func (o *IngressListener) DeepCopy() *IngressListener {
|
|
var cp IngressListener = *o
|
|
if o.TLS != nil {
|
|
cp.TLS = new(GatewayTLSConfig)
|
|
*cp.TLS = *o.TLS
|
|
if o.TLS.SDS != nil {
|
|
cp.TLS.SDS = new(GatewayTLSSDSConfig)
|
|
*cp.TLS.SDS = *o.TLS.SDS
|
|
}
|
|
if o.TLS.CipherSuites != nil {
|
|
cp.TLS.CipherSuites = make([]types.TLSCipherSuite, len(o.TLS.CipherSuites))
|
|
copy(cp.TLS.CipherSuites, o.TLS.CipherSuites)
|
|
}
|
|
}
|
|
if o.Services != nil {
|
|
cp.Services = make([]IngressService, len(o.Services))
|
|
copy(cp.Services, o.Services)
|
|
for i2 := range o.Services {
|
|
if o.Services[i2].Hosts != nil {
|
|
cp.Services[i2].Hosts = make([]string, len(o.Services[i2].Hosts))
|
|
copy(cp.Services[i2].Hosts, o.Services[i2].Hosts)
|
|
}
|
|
if o.Services[i2].TLS != nil {
|
|
cp.Services[i2].TLS = o.Services[i2].TLS.DeepCopy()
|
|
}
|
|
if o.Services[i2].RequestHeaders != nil {
|
|
cp.Services[i2].RequestHeaders = o.Services[i2].RequestHeaders.DeepCopy()
|
|
}
|
|
if o.Services[i2].ResponseHeaders != nil {
|
|
cp.Services[i2].ResponseHeaders = o.Services[i2].ResponseHeaders.DeepCopy()
|
|
}
|
|
if o.Services[i2].Meta != nil {
|
|
cp.Services[i2].Meta = make(map[string]string, len(o.Services[i2].Meta))
|
|
for k4, v4 := range o.Services[i2].Meta {
|
|
cp.Services[i2].Meta[k4] = v4
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *Intention
|
|
func (o *Intention) DeepCopy() *Intention {
|
|
var cp Intention = *o
|
|
if o.Permissions != nil {
|
|
cp.Permissions = make([]*IntentionPermission, len(o.Permissions))
|
|
copy(cp.Permissions, o.Permissions)
|
|
for i2 := range o.Permissions {
|
|
if o.Permissions[i2] != nil {
|
|
cp.Permissions[i2] = o.Permissions[i2].DeepCopy()
|
|
}
|
|
}
|
|
}
|
|
if o.Meta != nil {
|
|
cp.Meta = make(map[string]string, len(o.Meta))
|
|
for k2, v2 := range o.Meta {
|
|
cp.Meta[k2] = v2
|
|
}
|
|
}
|
|
if o.Hash != nil {
|
|
cp.Hash = make([]byte, len(o.Hash))
|
|
copy(cp.Hash, o.Hash)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *IntentionPermission
|
|
func (o *IntentionPermission) DeepCopy() *IntentionPermission {
|
|
var cp IntentionPermission = *o
|
|
if o.HTTP != nil {
|
|
cp.HTTP = new(IntentionHTTPPermission)
|
|
*cp.HTTP = *o.HTTP
|
|
if o.HTTP.Header != nil {
|
|
cp.HTTP.Header = make([]IntentionHTTPHeaderPermission, len(o.HTTP.Header))
|
|
copy(cp.HTTP.Header, o.HTTP.Header)
|
|
}
|
|
if o.HTTP.Methods != nil {
|
|
cp.HTTP.Methods = make([]string, len(o.HTTP.Methods))
|
|
copy(cp.HTTP.Methods, o.HTTP.Methods)
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *LoadBalancer
|
|
func (o *LoadBalancer) DeepCopy() *LoadBalancer {
|
|
var cp LoadBalancer = *o
|
|
if o.RingHashConfig != nil {
|
|
cp.RingHashConfig = new(RingHashConfig)
|
|
*cp.RingHashConfig = *o.RingHashConfig
|
|
}
|
|
if o.LeastRequestConfig != nil {
|
|
cp.LeastRequestConfig = new(LeastRequestConfig)
|
|
*cp.LeastRequestConfig = *o.LeastRequestConfig
|
|
}
|
|
if o.HashPolicies != nil {
|
|
cp.HashPolicies = make([]HashPolicy, len(o.HashPolicies))
|
|
copy(cp.HashPolicies, o.HashPolicies)
|
|
for i2 := range o.HashPolicies {
|
|
{
|
|
retV := o.HashPolicies[i2].DeepCopy()
|
|
cp.HashPolicies[i2] = *retV
|
|
}
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *MeshConfigEntry
|
|
func (o *MeshConfigEntry) DeepCopy() *MeshConfigEntry {
|
|
var cp MeshConfigEntry = *o
|
|
if o.TLS != nil {
|
|
cp.TLS = o.TLS.DeepCopy()
|
|
}
|
|
if o.HTTP != nil {
|
|
cp.HTTP = new(MeshHTTPConfig)
|
|
*cp.HTTP = *o.HTTP
|
|
}
|
|
if o.Peering != nil {
|
|
cp.Peering = new(PeeringMeshConfig)
|
|
*cp.Peering = *o.Peering
|
|
}
|
|
if o.Meta != nil {
|
|
cp.Meta = make(map[string]string, len(o.Meta))
|
|
for k2, v2 := range o.Meta {
|
|
cp.Meta[k2] = v2
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *MeshDirectionalTLSConfig
|
|
func (o *MeshDirectionalTLSConfig) DeepCopy() *MeshDirectionalTLSConfig {
|
|
var cp MeshDirectionalTLSConfig = *o
|
|
if o.CipherSuites != nil {
|
|
cp.CipherSuites = make([]types.TLSCipherSuite, len(o.CipherSuites))
|
|
copy(cp.CipherSuites, o.CipherSuites)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *MeshTLSConfig
|
|
func (o *MeshTLSConfig) DeepCopy() *MeshTLSConfig {
|
|
var cp MeshTLSConfig = *o
|
|
if o.Incoming != nil {
|
|
cp.Incoming = o.Incoming.DeepCopy()
|
|
}
|
|
if o.Outgoing != nil {
|
|
cp.Outgoing = o.Outgoing.DeepCopy()
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *Node
|
|
func (o *Node) DeepCopy() *Node {
|
|
var cp Node = *o
|
|
if o.TaggedAddresses != nil {
|
|
cp.TaggedAddresses = make(map[string]string, len(o.TaggedAddresses))
|
|
for k2, v2 := range o.TaggedAddresses {
|
|
cp.TaggedAddresses[k2] = v2
|
|
}
|
|
}
|
|
if o.Meta != nil {
|
|
cp.Meta = make(map[string]string, len(o.Meta))
|
|
for k2, v2 := range o.Meta {
|
|
cp.Meta[k2] = v2
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *NodeService
|
|
func (o *NodeService) DeepCopy() *NodeService {
|
|
var cp NodeService = *o
|
|
if o.Tags != nil {
|
|
cp.Tags = make([]string, len(o.Tags))
|
|
copy(cp.Tags, o.Tags)
|
|
}
|
|
if o.TaggedAddresses != nil {
|
|
cp.TaggedAddresses = make(map[string]ServiceAddress, len(o.TaggedAddresses))
|
|
for k2, v2 := range o.TaggedAddresses {
|
|
cp.TaggedAddresses[k2] = v2
|
|
}
|
|
}
|
|
if o.Meta != nil {
|
|
cp.Meta = make(map[string]string, len(o.Meta))
|
|
for k2, v2 := range o.Meta {
|
|
cp.Meta[k2] = v2
|
|
}
|
|
}
|
|
if o.Weights != nil {
|
|
cp.Weights = new(Weights)
|
|
*cp.Weights = *o.Weights
|
|
}
|
|
{
|
|
retV := o.Proxy.DeepCopy()
|
|
cp.Proxy = *retV
|
|
}
|
|
{
|
|
retV := o.Connect.DeepCopy()
|
|
cp.Connect = *retV
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *PeeringServiceMeta
|
|
func (o *PeeringServiceMeta) DeepCopy() *PeeringServiceMeta {
|
|
var cp PeeringServiceMeta = *o
|
|
if o.SNI != nil {
|
|
cp.SNI = make([]string, len(o.SNI))
|
|
copy(cp.SNI, o.SNI)
|
|
}
|
|
if o.SpiffeID != nil {
|
|
cp.SpiffeID = make([]string, len(o.SpiffeID))
|
|
copy(cp.SpiffeID, o.SpiffeID)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ServiceConfigEntry
|
|
func (o *ServiceConfigEntry) DeepCopy() *ServiceConfigEntry {
|
|
var cp ServiceConfigEntry = *o
|
|
{
|
|
retV := o.Expose.DeepCopy()
|
|
cp.Expose = *retV
|
|
}
|
|
if o.UpstreamConfig != nil {
|
|
cp.UpstreamConfig = o.UpstreamConfig.DeepCopy()
|
|
}
|
|
if o.Destination != nil {
|
|
cp.Destination = new(DestinationConfig)
|
|
*cp.Destination = *o.Destination
|
|
if o.Destination.Addresses != nil {
|
|
cp.Destination.Addresses = make([]string, len(o.Destination.Addresses))
|
|
copy(cp.Destination.Addresses, o.Destination.Addresses)
|
|
}
|
|
}
|
|
if o.Meta != nil {
|
|
cp.Meta = make(map[string]string, len(o.Meta))
|
|
for k2, v2 := range o.Meta {
|
|
cp.Meta[k2] = v2
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ServiceConfigResponse
|
|
func (o *ServiceConfigResponse) DeepCopy() *ServiceConfigResponse {
|
|
var cp ServiceConfigResponse = *o
|
|
if o.ProxyConfig != nil {
|
|
cp.ProxyConfig = make(map[string]interface{}, len(o.ProxyConfig))
|
|
for k2, v2 := range o.ProxyConfig {
|
|
cp.ProxyConfig[k2] = v2
|
|
}
|
|
}
|
|
if o.UpstreamConfigs != nil {
|
|
cp.UpstreamConfigs = make(map[string]map[string]interface{}, len(o.UpstreamConfigs))
|
|
for k2, v2 := range o.UpstreamConfigs {
|
|
var cp_UpstreamConfigs_v2 map[string]interface{}
|
|
if v2 != nil {
|
|
cp_UpstreamConfigs_v2 = make(map[string]interface{}, len(v2))
|
|
for k3, v3 := range v2 {
|
|
cp_UpstreamConfigs_v2[k3] = v3
|
|
}
|
|
}
|
|
cp.UpstreamConfigs[k2] = cp_UpstreamConfigs_v2
|
|
}
|
|
}
|
|
if o.UpstreamIDConfigs != nil {
|
|
cp.UpstreamIDConfigs = make([]OpaqueUpstreamConfig, len(o.UpstreamIDConfigs))
|
|
copy(cp.UpstreamIDConfigs, o.UpstreamIDConfigs)
|
|
for i2 := range o.UpstreamIDConfigs {
|
|
if o.UpstreamIDConfigs[i2].Config != nil {
|
|
cp.UpstreamIDConfigs[i2].Config = make(map[string]interface{}, len(o.UpstreamIDConfigs[i2].Config))
|
|
for k4, v4 := range o.UpstreamIDConfigs[i2].Config {
|
|
cp.UpstreamIDConfigs[i2].Config[k4] = v4
|
|
}
|
|
}
|
|
}
|
|
}
|
|
{
|
|
retV := o.Expose.DeepCopy()
|
|
cp.Expose = *retV
|
|
}
|
|
if o.Destination.Addresses != nil {
|
|
cp.Destination.Addresses = make([]string, len(o.Destination.Addresses))
|
|
copy(cp.Destination.Addresses, o.Destination.Addresses)
|
|
}
|
|
if o.Meta != nil {
|
|
cp.Meta = make(map[string]string, len(o.Meta))
|
|
for k2, v2 := range o.Meta {
|
|
cp.Meta[k2] = v2
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ServiceConnect
|
|
func (o *ServiceConnect) DeepCopy() *ServiceConnect {
|
|
var cp ServiceConnect = *o
|
|
if o.SidecarService != nil {
|
|
cp.SidecarService = o.SidecarService.DeepCopy()
|
|
}
|
|
if o.PeerMeta != nil {
|
|
cp.PeerMeta = o.PeerMeta.DeepCopy()
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ServiceDefinition
|
|
func (o *ServiceDefinition) DeepCopy() *ServiceDefinition {
|
|
var cp ServiceDefinition = *o
|
|
if o.Tags != nil {
|
|
cp.Tags = make([]string, len(o.Tags))
|
|
copy(cp.Tags, o.Tags)
|
|
}
|
|
if o.TaggedAddresses != nil {
|
|
cp.TaggedAddresses = make(map[string]ServiceAddress, len(o.TaggedAddresses))
|
|
for k2, v2 := range o.TaggedAddresses {
|
|
cp.TaggedAddresses[k2] = v2
|
|
}
|
|
}
|
|
if o.Meta != nil {
|
|
cp.Meta = make(map[string]string, len(o.Meta))
|
|
for k2, v2 := range o.Meta {
|
|
cp.Meta[k2] = v2
|
|
}
|
|
}
|
|
{
|
|
retV := o.Check.DeepCopy()
|
|
cp.Check = *retV
|
|
}
|
|
if o.Checks != nil {
|
|
cp.Checks = make([]*CheckType, len(o.Checks))
|
|
copy(cp.Checks, o.Checks)
|
|
for i2 := range o.Checks {
|
|
if o.Checks[i2] != nil {
|
|
cp.Checks[i2] = o.Checks[i2].DeepCopy()
|
|
}
|
|
}
|
|
}
|
|
if o.Weights != nil {
|
|
cp.Weights = new(Weights)
|
|
*cp.Weights = *o.Weights
|
|
}
|
|
if o.Proxy != nil {
|
|
cp.Proxy = o.Proxy.DeepCopy()
|
|
}
|
|
if o.Connect != nil {
|
|
cp.Connect = o.Connect.DeepCopy()
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ServiceResolverConfigEntry
|
|
func (o *ServiceResolverConfigEntry) DeepCopy() *ServiceResolverConfigEntry {
|
|
var cp ServiceResolverConfigEntry = *o
|
|
if o.Subsets != nil {
|
|
cp.Subsets = make(map[string]ServiceResolverSubset, len(o.Subsets))
|
|
for k2, v2 := range o.Subsets {
|
|
cp.Subsets[k2] = v2
|
|
}
|
|
}
|
|
if o.Redirect != nil {
|
|
cp.Redirect = new(ServiceResolverRedirect)
|
|
*cp.Redirect = *o.Redirect
|
|
}
|
|
if o.Failover != nil {
|
|
cp.Failover = make(map[string]ServiceResolverFailover, len(o.Failover))
|
|
for k2, v2 := range o.Failover {
|
|
var cp_Failover_v2 ServiceResolverFailover
|
|
{
|
|
retV := v2.DeepCopy()
|
|
cp_Failover_v2 = *retV
|
|
}
|
|
cp.Failover[k2] = cp_Failover_v2
|
|
}
|
|
}
|
|
if o.LoadBalancer != nil {
|
|
cp.LoadBalancer = o.LoadBalancer.DeepCopy()
|
|
}
|
|
if o.Meta != nil {
|
|
cp.Meta = make(map[string]string, len(o.Meta))
|
|
for k2, v2 := range o.Meta {
|
|
cp.Meta[k2] = v2
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ServiceResolverFailover
|
|
func (o *ServiceResolverFailover) DeepCopy() *ServiceResolverFailover {
|
|
var cp ServiceResolverFailover = *o
|
|
if o.Datacenters != nil {
|
|
cp.Datacenters = make([]string, len(o.Datacenters))
|
|
copy(cp.Datacenters, o.Datacenters)
|
|
}
|
|
if o.Targets != nil {
|
|
cp.Targets = make([]ServiceResolverFailoverTarget, len(o.Targets))
|
|
copy(cp.Targets, o.Targets)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ServiceRoute
|
|
func (o *ServiceRoute) DeepCopy() *ServiceRoute {
|
|
var cp ServiceRoute = *o
|
|
if o.Match != nil {
|
|
cp.Match = o.Match.DeepCopy()
|
|
}
|
|
if o.Destination != nil {
|
|
cp.Destination = o.Destination.DeepCopy()
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ServiceRouteDestination
|
|
func (o *ServiceRouteDestination) DeepCopy() *ServiceRouteDestination {
|
|
var cp ServiceRouteDestination = *o
|
|
if o.RetryOn != nil {
|
|
cp.RetryOn = make([]string, len(o.RetryOn))
|
|
copy(cp.RetryOn, o.RetryOn)
|
|
}
|
|
if o.RetryOnStatusCodes != nil {
|
|
cp.RetryOnStatusCodes = make([]uint32, len(o.RetryOnStatusCodes))
|
|
copy(cp.RetryOnStatusCodes, o.RetryOnStatusCodes)
|
|
}
|
|
if o.RequestHeaders != nil {
|
|
cp.RequestHeaders = o.RequestHeaders.DeepCopy()
|
|
}
|
|
if o.ResponseHeaders != nil {
|
|
cp.ResponseHeaders = o.ResponseHeaders.DeepCopy()
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *ServiceRouteMatch
|
|
func (o *ServiceRouteMatch) DeepCopy() *ServiceRouteMatch {
|
|
var cp ServiceRouteMatch = *o
|
|
if o.HTTP != nil {
|
|
cp.HTTP = new(ServiceRouteHTTPMatch)
|
|
*cp.HTTP = *o.HTTP
|
|
if o.HTTP.Header != nil {
|
|
cp.HTTP.Header = make([]ServiceRouteHTTPMatchHeader, len(o.HTTP.Header))
|
|
copy(cp.HTTP.Header, o.HTTP.Header)
|
|
}
|
|
if o.HTTP.QueryParam != nil {
|
|
cp.HTTP.QueryParam = make([]ServiceRouteHTTPMatchQueryParam, len(o.HTTP.QueryParam))
|
|
copy(cp.HTTP.QueryParam, o.HTTP.QueryParam)
|
|
}
|
|
if o.HTTP.Methods != nil {
|
|
cp.HTTP.Methods = make([]string, len(o.HTTP.Methods))
|
|
copy(cp.HTTP.Methods, o.HTTP.Methods)
|
|
}
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *Upstream
|
|
func (o *Upstream) DeepCopy() *Upstream {
|
|
var cp Upstream = *o
|
|
if o.Config != nil {
|
|
cp.Config = make(map[string]interface{}, len(o.Config))
|
|
for k2, v2 := range o.Config {
|
|
cp.Config[k2] = v2
|
|
}
|
|
}
|
|
if o.IngressHosts != nil {
|
|
cp.IngressHosts = make([]string, len(o.IngressHosts))
|
|
copy(cp.IngressHosts, o.IngressHosts)
|
|
}
|
|
return &cp
|
|
}
|
|
|
|
// DeepCopy generates a deep copy of *UpstreamConfiguration
|
|
func (o *UpstreamConfiguration) DeepCopy() *UpstreamConfiguration {
|
|
var cp UpstreamConfiguration = *o
|
|
if o.Overrides != nil {
|
|
cp.Overrides = make([]*UpstreamConfig, len(o.Overrides))
|
|
copy(cp.Overrides, o.Overrides)
|
|
for i2 := range o.Overrides {
|
|
if o.Overrides[i2] != nil {
|
|
cp.Overrides[i2] = new(UpstreamConfig)
|
|
*cp.Overrides[i2] = *o.Overrides[i2]
|
|
if o.Overrides[i2].Limits != nil {
|
|
cp.Overrides[i2].Limits = new(UpstreamLimits)
|
|
*cp.Overrides[i2].Limits = *o.Overrides[i2].Limits
|
|
if o.Overrides[i2].Limits.MaxConnections != nil {
|
|
cp.Overrides[i2].Limits.MaxConnections = new(int)
|
|
*cp.Overrides[i2].Limits.MaxConnections = *o.Overrides[i2].Limits.MaxConnections
|
|
}
|
|
if o.Overrides[i2].Limits.MaxPendingRequests != nil {
|
|
cp.Overrides[i2].Limits.MaxPendingRequests = new(int)
|
|
*cp.Overrides[i2].Limits.MaxPendingRequests = *o.Overrides[i2].Limits.MaxPendingRequests
|
|
}
|
|
if o.Overrides[i2].Limits.MaxConcurrentRequests != nil {
|
|
cp.Overrides[i2].Limits.MaxConcurrentRequests = new(int)
|
|
*cp.Overrides[i2].Limits.MaxConcurrentRequests = *o.Overrides[i2].Limits.MaxConcurrentRequests
|
|
}
|
|
}
|
|
if o.Overrides[i2].PassiveHealthCheck != nil {
|
|
cp.Overrides[i2].PassiveHealthCheck = new(PassiveHealthCheck)
|
|
*cp.Overrides[i2].PassiveHealthCheck = *o.Overrides[i2].PassiveHealthCheck
|
|
if o.Overrides[i2].PassiveHealthCheck.EnforcingConsecutive5xx != nil {
|
|
cp.Overrides[i2].PassiveHealthCheck.EnforcingConsecutive5xx = new(uint32)
|
|
*cp.Overrides[i2].PassiveHealthCheck.EnforcingConsecutive5xx = *o.Overrides[i2].PassiveHealthCheck.EnforcingConsecutive5xx
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if o.Defaults != nil {
|
|
cp.Defaults = new(UpstreamConfig)
|
|
*cp.Defaults = *o.Defaults
|
|
if o.Defaults.Limits != nil {
|
|
cp.Defaults.Limits = new(UpstreamLimits)
|
|
*cp.Defaults.Limits = *o.Defaults.Limits
|
|
if o.Defaults.Limits.MaxConnections != nil {
|
|
cp.Defaults.Limits.MaxConnections = new(int)
|
|
*cp.Defaults.Limits.MaxConnections = *o.Defaults.Limits.MaxConnections
|
|
}
|
|
if o.Defaults.Limits.MaxPendingRequests != nil {
|
|
cp.Defaults.Limits.MaxPendingRequests = new(int)
|
|
*cp.Defaults.Limits.MaxPendingRequests = *o.Defaults.Limits.MaxPendingRequests
|
|
}
|
|
if o.Defaults.Limits.MaxConcurrentRequests != nil {
|
|
cp.Defaults.Limits.MaxConcurrentRequests = new(int)
|
|
*cp.Defaults.Limits.MaxConcurrentRequests = *o.Defaults.Limits.MaxConcurrentRequests
|
|
}
|
|
}
|
|
if o.Defaults.PassiveHealthCheck != nil {
|
|
cp.Defaults.PassiveHealthCheck = new(PassiveHealthCheck)
|
|
*cp.Defaults.PassiveHealthCheck = *o.Defaults.PassiveHealthCheck
|
|
if o.Defaults.PassiveHealthCheck.EnforcingConsecutive5xx != nil {
|
|
cp.Defaults.PassiveHealthCheck.EnforcingConsecutive5xx = new(uint32)
|
|
*cp.Defaults.PassiveHealthCheck.EnforcingConsecutive5xx = *o.Defaults.PassiveHealthCheck.EnforcingConsecutive5xx
|
|
}
|
|
}
|
|
}
|
|
return &cp
|
|
}
|