mirror of
https://github.com/status-im/consul.git
synced 2025-01-12 14:55:02 +00:00
69f40df548
* feat(ingress gateway: support configuring limits in ingress-gateway config entry - a new Defaults field with max_connections, max_pending_connections, max_requests is added to ingress gateway config entry - new field max_connections, max_pending_connections, max_requests in individual services to overwrite the value in Default - added unit test and integration test - updated doc Co-authored-by: Chris S. Kim <ckim@hashicorp.com> Co-authored-by: Jeff Boruszak <104028618+boruszak@users.noreply.github.com> Co-authored-by: Dan Stough <dan.stough@hashicorp.com>
837 lines
21 KiB
Go
837 lines
21 KiB
Go
// Code generated by mog. DO NOT EDIT.
|
|
|
|
package pbconfigentry
|
|
|
|
import "github.com/hashicorp/consul/agent/structs"
|
|
|
|
func CookieConfigToStructs(s *CookieConfig, t *structs.CookieConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Session = s.Session
|
|
t.TTL = structs.DurationFromProto(s.TTL)
|
|
t.Path = s.Path
|
|
}
|
|
func CookieConfigFromStructs(t *structs.CookieConfig, s *CookieConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Session = t.Session
|
|
s.TTL = structs.DurationToProto(t.TTL)
|
|
s.Path = t.Path
|
|
}
|
|
func GatewayServiceTLSConfigToStructs(s *GatewayServiceTLSConfig, t *structs.GatewayServiceTLSConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
if s.SDS != nil {
|
|
var x structs.GatewayTLSSDSConfig
|
|
GatewayTLSSDSConfigToStructs(s.SDS, &x)
|
|
t.SDS = &x
|
|
}
|
|
}
|
|
func GatewayServiceTLSConfigFromStructs(t *structs.GatewayServiceTLSConfig, s *GatewayServiceTLSConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
if t.SDS != nil {
|
|
var x GatewayTLSSDSConfig
|
|
GatewayTLSSDSConfigFromStructs(t.SDS, &x)
|
|
s.SDS = &x
|
|
}
|
|
}
|
|
func GatewayTLSConfigToStructs(s *GatewayTLSConfig, t *structs.GatewayTLSConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Enabled = s.Enabled
|
|
if s.SDS != nil {
|
|
var x structs.GatewayTLSSDSConfig
|
|
GatewayTLSSDSConfigToStructs(s.SDS, &x)
|
|
t.SDS = &x
|
|
}
|
|
t.TLSMinVersion = tlsVersionToStructs(s.TLSMinVersion)
|
|
t.TLSMaxVersion = tlsVersionToStructs(s.TLSMaxVersion)
|
|
t.CipherSuites = cipherSuitesToStructs(s.CipherSuites)
|
|
}
|
|
func GatewayTLSConfigFromStructs(t *structs.GatewayTLSConfig, s *GatewayTLSConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Enabled = t.Enabled
|
|
if t.SDS != nil {
|
|
var x GatewayTLSSDSConfig
|
|
GatewayTLSSDSConfigFromStructs(t.SDS, &x)
|
|
s.SDS = &x
|
|
}
|
|
s.TLSMinVersion = tlsVersionFromStructs(t.TLSMinVersion)
|
|
s.TLSMaxVersion = tlsVersionFromStructs(t.TLSMaxVersion)
|
|
s.CipherSuites = cipherSuitesFromStructs(t.CipherSuites)
|
|
}
|
|
func GatewayTLSSDSConfigToStructs(s *GatewayTLSSDSConfig, t *structs.GatewayTLSSDSConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.ClusterName = s.ClusterName
|
|
t.CertResource = s.CertResource
|
|
}
|
|
func GatewayTLSSDSConfigFromStructs(t *structs.GatewayTLSSDSConfig, s *GatewayTLSSDSConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.ClusterName = t.ClusterName
|
|
s.CertResource = t.CertResource
|
|
}
|
|
func HTTPHeaderModifiersToStructs(s *HTTPHeaderModifiers, t *structs.HTTPHeaderModifiers) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Add = s.Add
|
|
t.Set = s.Set
|
|
t.Remove = s.Remove
|
|
}
|
|
func HTTPHeaderModifiersFromStructs(t *structs.HTTPHeaderModifiers, s *HTTPHeaderModifiers) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Add = t.Add
|
|
s.Set = t.Set
|
|
s.Remove = t.Remove
|
|
}
|
|
func HashPolicyToStructs(s *HashPolicy, t *structs.HashPolicy) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Field = s.Field
|
|
t.FieldValue = s.FieldValue
|
|
if s.CookieConfig != nil {
|
|
var x structs.CookieConfig
|
|
CookieConfigToStructs(s.CookieConfig, &x)
|
|
t.CookieConfig = &x
|
|
}
|
|
t.SourceIP = s.SourceIP
|
|
t.Terminal = s.Terminal
|
|
}
|
|
func HashPolicyFromStructs(t *structs.HashPolicy, s *HashPolicy) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Field = t.Field
|
|
s.FieldValue = t.FieldValue
|
|
if t.CookieConfig != nil {
|
|
var x CookieConfig
|
|
CookieConfigFromStructs(t.CookieConfig, &x)
|
|
s.CookieConfig = &x
|
|
}
|
|
s.SourceIP = t.SourceIP
|
|
s.Terminal = t.Terminal
|
|
}
|
|
func IngressGatewayToStructs(s *IngressGateway, t *structs.IngressGatewayConfigEntry) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
if s.TLS != nil {
|
|
GatewayTLSConfigToStructs(s.TLS, &t.TLS)
|
|
}
|
|
{
|
|
t.Listeners = make([]structs.IngressListener, len(s.Listeners))
|
|
for i := range s.Listeners {
|
|
if s.Listeners[i] != nil {
|
|
IngressListenerToStructs(s.Listeners[i], &t.Listeners[i])
|
|
}
|
|
}
|
|
}
|
|
if s.Defaults != nil {
|
|
var x structs.IngressServiceConfig
|
|
IngressServiceConfigToStructs(s.Defaults, &x)
|
|
t.Defaults = &x
|
|
}
|
|
t.Meta = s.Meta
|
|
}
|
|
func IngressGatewayFromStructs(t *structs.IngressGatewayConfigEntry, s *IngressGateway) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
{
|
|
var x GatewayTLSConfig
|
|
GatewayTLSConfigFromStructs(&t.TLS, &x)
|
|
s.TLS = &x
|
|
}
|
|
{
|
|
s.Listeners = make([]*IngressListener, len(t.Listeners))
|
|
for i := range t.Listeners {
|
|
{
|
|
var x IngressListener
|
|
IngressListenerFromStructs(&t.Listeners[i], &x)
|
|
s.Listeners[i] = &x
|
|
}
|
|
}
|
|
}
|
|
if t.Defaults != nil {
|
|
var x IngressServiceConfig
|
|
IngressServiceConfigFromStructs(t.Defaults, &x)
|
|
s.Defaults = &x
|
|
}
|
|
s.Meta = t.Meta
|
|
}
|
|
func IngressListenerToStructs(s *IngressListener, t *structs.IngressListener) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Port = int(s.Port)
|
|
t.Protocol = s.Protocol
|
|
if s.TLS != nil {
|
|
var x structs.GatewayTLSConfig
|
|
GatewayTLSConfigToStructs(s.TLS, &x)
|
|
t.TLS = &x
|
|
}
|
|
{
|
|
t.Services = make([]structs.IngressService, len(s.Services))
|
|
for i := range s.Services {
|
|
if s.Services[i] != nil {
|
|
IngressServiceToStructs(s.Services[i], &t.Services[i])
|
|
}
|
|
}
|
|
}
|
|
}
|
|
func IngressListenerFromStructs(t *structs.IngressListener, s *IngressListener) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Port = int32(t.Port)
|
|
s.Protocol = t.Protocol
|
|
if t.TLS != nil {
|
|
var x GatewayTLSConfig
|
|
GatewayTLSConfigFromStructs(t.TLS, &x)
|
|
s.TLS = &x
|
|
}
|
|
{
|
|
s.Services = make([]*IngressService, len(t.Services))
|
|
for i := range t.Services {
|
|
{
|
|
var x IngressService
|
|
IngressServiceFromStructs(&t.Services[i], &x)
|
|
s.Services[i] = &x
|
|
}
|
|
}
|
|
}
|
|
}
|
|
func IngressServiceToStructs(s *IngressService, t *structs.IngressService) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Name = s.Name
|
|
t.Hosts = s.Hosts
|
|
if s.TLS != nil {
|
|
var x structs.GatewayServiceTLSConfig
|
|
GatewayServiceTLSConfigToStructs(s.TLS, &x)
|
|
t.TLS = &x
|
|
}
|
|
if s.RequestHeaders != nil {
|
|
var x structs.HTTPHeaderModifiers
|
|
HTTPHeaderModifiersToStructs(s.RequestHeaders, &x)
|
|
t.RequestHeaders = &x
|
|
}
|
|
if s.ResponseHeaders != nil {
|
|
var x structs.HTTPHeaderModifiers
|
|
HTTPHeaderModifiersToStructs(s.ResponseHeaders, &x)
|
|
t.ResponseHeaders = &x
|
|
}
|
|
t.MaxConnections = s.MaxConnections
|
|
t.MaxPendingRequests = s.MaxPendingRequests
|
|
t.MaxConcurrentRequests = s.MaxConcurrentRequests
|
|
t.Meta = s.Meta
|
|
t.EnterpriseMeta = enterpriseMetaToStructs(s.EnterpriseMeta)
|
|
}
|
|
func IngressServiceFromStructs(t *structs.IngressService, s *IngressService) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Name = t.Name
|
|
s.Hosts = t.Hosts
|
|
if t.TLS != nil {
|
|
var x GatewayServiceTLSConfig
|
|
GatewayServiceTLSConfigFromStructs(t.TLS, &x)
|
|
s.TLS = &x
|
|
}
|
|
if t.RequestHeaders != nil {
|
|
var x HTTPHeaderModifiers
|
|
HTTPHeaderModifiersFromStructs(t.RequestHeaders, &x)
|
|
s.RequestHeaders = &x
|
|
}
|
|
if t.ResponseHeaders != nil {
|
|
var x HTTPHeaderModifiers
|
|
HTTPHeaderModifiersFromStructs(t.ResponseHeaders, &x)
|
|
s.ResponseHeaders = &x
|
|
}
|
|
s.MaxConnections = t.MaxConnections
|
|
s.MaxPendingRequests = t.MaxPendingRequests
|
|
s.MaxConcurrentRequests = t.MaxConcurrentRequests
|
|
s.Meta = t.Meta
|
|
s.EnterpriseMeta = enterpriseMetaFromStructs(t.EnterpriseMeta)
|
|
}
|
|
func IngressServiceConfigToStructs(s *IngressServiceConfig, t *structs.IngressServiceConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.MaxConnections = s.MaxConnections
|
|
t.MaxPendingRequests = s.MaxPendingRequests
|
|
t.MaxConcurrentRequests = s.MaxConcurrentRequests
|
|
}
|
|
func IngressServiceConfigFromStructs(t *structs.IngressServiceConfig, s *IngressServiceConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.MaxConnections = t.MaxConnections
|
|
s.MaxPendingRequests = t.MaxPendingRequests
|
|
s.MaxConcurrentRequests = t.MaxConcurrentRequests
|
|
}
|
|
func IntentionHTTPHeaderPermissionToStructs(s *IntentionHTTPHeaderPermission, t *structs.IntentionHTTPHeaderPermission) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Name = s.Name
|
|
t.Present = s.Present
|
|
t.Exact = s.Exact
|
|
t.Prefix = s.Prefix
|
|
t.Suffix = s.Suffix
|
|
t.Regex = s.Regex
|
|
t.Invert = s.Invert
|
|
}
|
|
func IntentionHTTPHeaderPermissionFromStructs(t *structs.IntentionHTTPHeaderPermission, s *IntentionHTTPHeaderPermission) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Name = t.Name
|
|
s.Present = t.Present
|
|
s.Exact = t.Exact
|
|
s.Prefix = t.Prefix
|
|
s.Suffix = t.Suffix
|
|
s.Regex = t.Regex
|
|
s.Invert = t.Invert
|
|
}
|
|
func IntentionHTTPPermissionToStructs(s *IntentionHTTPPermission, t *structs.IntentionHTTPPermission) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.PathExact = s.PathExact
|
|
t.PathPrefix = s.PathPrefix
|
|
t.PathRegex = s.PathRegex
|
|
{
|
|
t.Header = make([]structs.IntentionHTTPHeaderPermission, len(s.Header))
|
|
for i := range s.Header {
|
|
if s.Header[i] != nil {
|
|
IntentionHTTPHeaderPermissionToStructs(s.Header[i], &t.Header[i])
|
|
}
|
|
}
|
|
}
|
|
t.Methods = s.Methods
|
|
}
|
|
func IntentionHTTPPermissionFromStructs(t *structs.IntentionHTTPPermission, s *IntentionHTTPPermission) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.PathExact = t.PathExact
|
|
s.PathPrefix = t.PathPrefix
|
|
s.PathRegex = t.PathRegex
|
|
{
|
|
s.Header = make([]*IntentionHTTPHeaderPermission, len(t.Header))
|
|
for i := range t.Header {
|
|
{
|
|
var x IntentionHTTPHeaderPermission
|
|
IntentionHTTPHeaderPermissionFromStructs(&t.Header[i], &x)
|
|
s.Header[i] = &x
|
|
}
|
|
}
|
|
}
|
|
s.Methods = t.Methods
|
|
}
|
|
func IntentionPermissionToStructs(s *IntentionPermission, t *structs.IntentionPermission) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Action = intentionActionToStructs(s.Action)
|
|
if s.HTTP != nil {
|
|
var x structs.IntentionHTTPPermission
|
|
IntentionHTTPPermissionToStructs(s.HTTP, &x)
|
|
t.HTTP = &x
|
|
}
|
|
}
|
|
func IntentionPermissionFromStructs(t *structs.IntentionPermission, s *IntentionPermission) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Action = intentionActionFromStructs(t.Action)
|
|
if t.HTTP != nil {
|
|
var x IntentionHTTPPermission
|
|
IntentionHTTPPermissionFromStructs(t.HTTP, &x)
|
|
s.HTTP = &x
|
|
}
|
|
}
|
|
func LeastRequestConfigToStructs(s *LeastRequestConfig, t *structs.LeastRequestConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.ChoiceCount = s.ChoiceCount
|
|
}
|
|
func LeastRequestConfigFromStructs(t *structs.LeastRequestConfig, s *LeastRequestConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.ChoiceCount = t.ChoiceCount
|
|
}
|
|
func LoadBalancerToStructs(s *LoadBalancer, t *structs.LoadBalancer) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Policy = s.Policy
|
|
if s.RingHashConfig != nil {
|
|
var x structs.RingHashConfig
|
|
RingHashConfigToStructs(s.RingHashConfig, &x)
|
|
t.RingHashConfig = &x
|
|
}
|
|
if s.LeastRequestConfig != nil {
|
|
var x structs.LeastRequestConfig
|
|
LeastRequestConfigToStructs(s.LeastRequestConfig, &x)
|
|
t.LeastRequestConfig = &x
|
|
}
|
|
{
|
|
t.HashPolicies = make([]structs.HashPolicy, len(s.HashPolicies))
|
|
for i := range s.HashPolicies {
|
|
if s.HashPolicies[i] != nil {
|
|
HashPolicyToStructs(s.HashPolicies[i], &t.HashPolicies[i])
|
|
}
|
|
}
|
|
}
|
|
}
|
|
func LoadBalancerFromStructs(t *structs.LoadBalancer, s *LoadBalancer) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Policy = t.Policy
|
|
if t.RingHashConfig != nil {
|
|
var x RingHashConfig
|
|
RingHashConfigFromStructs(t.RingHashConfig, &x)
|
|
s.RingHashConfig = &x
|
|
}
|
|
if t.LeastRequestConfig != nil {
|
|
var x LeastRequestConfig
|
|
LeastRequestConfigFromStructs(t.LeastRequestConfig, &x)
|
|
s.LeastRequestConfig = &x
|
|
}
|
|
{
|
|
s.HashPolicies = make([]*HashPolicy, len(t.HashPolicies))
|
|
for i := range t.HashPolicies {
|
|
{
|
|
var x HashPolicy
|
|
HashPolicyFromStructs(&t.HashPolicies[i], &x)
|
|
s.HashPolicies[i] = &x
|
|
}
|
|
}
|
|
}
|
|
}
|
|
func MeshConfigToStructs(s *MeshConfig, t *structs.MeshConfigEntry) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
if s.TransparentProxy != nil {
|
|
TransparentProxyMeshConfigToStructs(s.TransparentProxy, &t.TransparentProxy)
|
|
}
|
|
if s.TLS != nil {
|
|
var x structs.MeshTLSConfig
|
|
MeshTLSConfigToStructs(s.TLS, &x)
|
|
t.TLS = &x
|
|
}
|
|
if s.HTTP != nil {
|
|
var x structs.MeshHTTPConfig
|
|
MeshHTTPConfigToStructs(s.HTTP, &x)
|
|
t.HTTP = &x
|
|
}
|
|
if s.Peering != nil {
|
|
var x structs.PeeringMeshConfig
|
|
PeeringMeshConfigToStructs(s.Peering, &x)
|
|
t.Peering = &x
|
|
}
|
|
t.Meta = s.Meta
|
|
}
|
|
func MeshConfigFromStructs(t *structs.MeshConfigEntry, s *MeshConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
{
|
|
var x TransparentProxyMeshConfig
|
|
TransparentProxyMeshConfigFromStructs(&t.TransparentProxy, &x)
|
|
s.TransparentProxy = &x
|
|
}
|
|
if t.TLS != nil {
|
|
var x MeshTLSConfig
|
|
MeshTLSConfigFromStructs(t.TLS, &x)
|
|
s.TLS = &x
|
|
}
|
|
if t.HTTP != nil {
|
|
var x MeshHTTPConfig
|
|
MeshHTTPConfigFromStructs(t.HTTP, &x)
|
|
s.HTTP = &x
|
|
}
|
|
if t.Peering != nil {
|
|
var x PeeringMeshConfig
|
|
PeeringMeshConfigFromStructs(t.Peering, &x)
|
|
s.Peering = &x
|
|
}
|
|
s.Meta = t.Meta
|
|
}
|
|
func MeshDirectionalTLSConfigToStructs(s *MeshDirectionalTLSConfig, t *structs.MeshDirectionalTLSConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.TLSMinVersion = tlsVersionToStructs(s.TLSMinVersion)
|
|
t.TLSMaxVersion = tlsVersionToStructs(s.TLSMaxVersion)
|
|
t.CipherSuites = cipherSuitesToStructs(s.CipherSuites)
|
|
}
|
|
func MeshDirectionalTLSConfigFromStructs(t *structs.MeshDirectionalTLSConfig, s *MeshDirectionalTLSConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.TLSMinVersion = tlsVersionFromStructs(t.TLSMinVersion)
|
|
s.TLSMaxVersion = tlsVersionFromStructs(t.TLSMaxVersion)
|
|
s.CipherSuites = cipherSuitesFromStructs(t.CipherSuites)
|
|
}
|
|
func MeshHTTPConfigToStructs(s *MeshHTTPConfig, t *structs.MeshHTTPConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.SanitizeXForwardedClientCert = s.SanitizeXForwardedClientCert
|
|
}
|
|
func MeshHTTPConfigFromStructs(t *structs.MeshHTTPConfig, s *MeshHTTPConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.SanitizeXForwardedClientCert = t.SanitizeXForwardedClientCert
|
|
}
|
|
func MeshTLSConfigToStructs(s *MeshTLSConfig, t *structs.MeshTLSConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
if s.Incoming != nil {
|
|
var x structs.MeshDirectionalTLSConfig
|
|
MeshDirectionalTLSConfigToStructs(s.Incoming, &x)
|
|
t.Incoming = &x
|
|
}
|
|
if s.Outgoing != nil {
|
|
var x structs.MeshDirectionalTLSConfig
|
|
MeshDirectionalTLSConfigToStructs(s.Outgoing, &x)
|
|
t.Outgoing = &x
|
|
}
|
|
}
|
|
func MeshTLSConfigFromStructs(t *structs.MeshTLSConfig, s *MeshTLSConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
if t.Incoming != nil {
|
|
var x MeshDirectionalTLSConfig
|
|
MeshDirectionalTLSConfigFromStructs(t.Incoming, &x)
|
|
s.Incoming = &x
|
|
}
|
|
if t.Outgoing != nil {
|
|
var x MeshDirectionalTLSConfig
|
|
MeshDirectionalTLSConfigFromStructs(t.Outgoing, &x)
|
|
s.Outgoing = &x
|
|
}
|
|
}
|
|
func PeeringMeshConfigToStructs(s *PeeringMeshConfig, t *structs.PeeringMeshConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.PeerThroughMeshGateways = s.PeerThroughMeshGateways
|
|
}
|
|
func PeeringMeshConfigFromStructs(t *structs.PeeringMeshConfig, s *PeeringMeshConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.PeerThroughMeshGateways = t.PeerThroughMeshGateways
|
|
}
|
|
func RingHashConfigToStructs(s *RingHashConfig, t *structs.RingHashConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.MinimumRingSize = s.MinimumRingSize
|
|
t.MaximumRingSize = s.MaximumRingSize
|
|
}
|
|
func RingHashConfigFromStructs(t *structs.RingHashConfig, s *RingHashConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.MinimumRingSize = t.MinimumRingSize
|
|
s.MaximumRingSize = t.MaximumRingSize
|
|
}
|
|
func ServiceIntentionsToStructs(s *ServiceIntentions, t *structs.ServiceIntentionsConfigEntry) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
{
|
|
t.Sources = make([]*structs.SourceIntention, len(s.Sources))
|
|
for i := range s.Sources {
|
|
if s.Sources[i] != nil {
|
|
var x structs.SourceIntention
|
|
SourceIntentionToStructs(s.Sources[i], &x)
|
|
t.Sources[i] = &x
|
|
}
|
|
}
|
|
}
|
|
t.Meta = s.Meta
|
|
}
|
|
func ServiceIntentionsFromStructs(t *structs.ServiceIntentionsConfigEntry, s *ServiceIntentions) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
{
|
|
s.Sources = make([]*SourceIntention, len(t.Sources))
|
|
for i := range t.Sources {
|
|
if t.Sources[i] != nil {
|
|
var x SourceIntention
|
|
SourceIntentionFromStructs(t.Sources[i], &x)
|
|
s.Sources[i] = &x
|
|
}
|
|
}
|
|
}
|
|
s.Meta = t.Meta
|
|
}
|
|
func ServiceResolverToStructs(s *ServiceResolver, t *structs.ServiceResolverConfigEntry) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.DefaultSubset = s.DefaultSubset
|
|
{
|
|
t.Subsets = make(map[string]structs.ServiceResolverSubset, len(s.Subsets))
|
|
for k, v := range s.Subsets {
|
|
var y structs.ServiceResolverSubset
|
|
if v != nil {
|
|
ServiceResolverSubsetToStructs(v, &y)
|
|
}
|
|
t.Subsets[k] = y
|
|
}
|
|
}
|
|
if s.Redirect != nil {
|
|
var x structs.ServiceResolverRedirect
|
|
ServiceResolverRedirectToStructs(s.Redirect, &x)
|
|
t.Redirect = &x
|
|
}
|
|
{
|
|
t.Failover = make(map[string]structs.ServiceResolverFailover, len(s.Failover))
|
|
for k, v := range s.Failover {
|
|
var y structs.ServiceResolverFailover
|
|
if v != nil {
|
|
ServiceResolverFailoverToStructs(v, &y)
|
|
}
|
|
t.Failover[k] = y
|
|
}
|
|
}
|
|
t.ConnectTimeout = structs.DurationFromProto(s.ConnectTimeout)
|
|
if s.LoadBalancer != nil {
|
|
var x structs.LoadBalancer
|
|
LoadBalancerToStructs(s.LoadBalancer, &x)
|
|
t.LoadBalancer = &x
|
|
}
|
|
t.Meta = s.Meta
|
|
}
|
|
func ServiceResolverFromStructs(t *structs.ServiceResolverConfigEntry, s *ServiceResolver) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.DefaultSubset = t.DefaultSubset
|
|
{
|
|
s.Subsets = make(map[string]*ServiceResolverSubset, len(t.Subsets))
|
|
for k, v := range t.Subsets {
|
|
var y *ServiceResolverSubset
|
|
{
|
|
var x ServiceResolverSubset
|
|
ServiceResolverSubsetFromStructs(&v, &x)
|
|
y = &x
|
|
}
|
|
s.Subsets[k] = y
|
|
}
|
|
}
|
|
if t.Redirect != nil {
|
|
var x ServiceResolverRedirect
|
|
ServiceResolverRedirectFromStructs(t.Redirect, &x)
|
|
s.Redirect = &x
|
|
}
|
|
{
|
|
s.Failover = make(map[string]*ServiceResolverFailover, len(t.Failover))
|
|
for k, v := range t.Failover {
|
|
var y *ServiceResolverFailover
|
|
{
|
|
var x ServiceResolverFailover
|
|
ServiceResolverFailoverFromStructs(&v, &x)
|
|
y = &x
|
|
}
|
|
s.Failover[k] = y
|
|
}
|
|
}
|
|
s.ConnectTimeout = structs.DurationToProto(t.ConnectTimeout)
|
|
if t.LoadBalancer != nil {
|
|
var x LoadBalancer
|
|
LoadBalancerFromStructs(t.LoadBalancer, &x)
|
|
s.LoadBalancer = &x
|
|
}
|
|
s.Meta = t.Meta
|
|
}
|
|
func ServiceResolverFailoverToStructs(s *ServiceResolverFailover, t *structs.ServiceResolverFailover) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Service = s.Service
|
|
t.ServiceSubset = s.ServiceSubset
|
|
t.Namespace = s.Namespace
|
|
t.Datacenters = s.Datacenters
|
|
{
|
|
t.Targets = make([]structs.ServiceResolverFailoverTarget, len(s.Targets))
|
|
for i := range s.Targets {
|
|
if s.Targets[i] != nil {
|
|
ServiceResolverFailoverTargetToStructs(s.Targets[i], &t.Targets[i])
|
|
}
|
|
}
|
|
}
|
|
}
|
|
func ServiceResolverFailoverFromStructs(t *structs.ServiceResolverFailover, s *ServiceResolverFailover) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Service = t.Service
|
|
s.ServiceSubset = t.ServiceSubset
|
|
s.Namespace = t.Namespace
|
|
s.Datacenters = t.Datacenters
|
|
{
|
|
s.Targets = make([]*ServiceResolverFailoverTarget, len(t.Targets))
|
|
for i := range t.Targets {
|
|
{
|
|
var x ServiceResolverFailoverTarget
|
|
ServiceResolverFailoverTargetFromStructs(&t.Targets[i], &x)
|
|
s.Targets[i] = &x
|
|
}
|
|
}
|
|
}
|
|
}
|
|
func ServiceResolverFailoverTargetToStructs(s *ServiceResolverFailoverTarget, t *structs.ServiceResolverFailoverTarget) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Service = s.Service
|
|
t.ServiceSubset = s.ServiceSubset
|
|
t.Partition = s.Partition
|
|
t.Namespace = s.Namespace
|
|
t.Datacenter = s.Datacenter
|
|
t.Peer = s.Peer
|
|
}
|
|
func ServiceResolverFailoverTargetFromStructs(t *structs.ServiceResolverFailoverTarget, s *ServiceResolverFailoverTarget) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Service = t.Service
|
|
s.ServiceSubset = t.ServiceSubset
|
|
s.Partition = t.Partition
|
|
s.Namespace = t.Namespace
|
|
s.Datacenter = t.Datacenter
|
|
s.Peer = t.Peer
|
|
}
|
|
func ServiceResolverRedirectToStructs(s *ServiceResolverRedirect, t *structs.ServiceResolverRedirect) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Service = s.Service
|
|
t.ServiceSubset = s.ServiceSubset
|
|
t.Namespace = s.Namespace
|
|
t.Partition = s.Partition
|
|
t.Datacenter = s.Datacenter
|
|
t.Peer = s.Peer
|
|
}
|
|
func ServiceResolverRedirectFromStructs(t *structs.ServiceResolverRedirect, s *ServiceResolverRedirect) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Service = t.Service
|
|
s.ServiceSubset = t.ServiceSubset
|
|
s.Namespace = t.Namespace
|
|
s.Partition = t.Partition
|
|
s.Datacenter = t.Datacenter
|
|
s.Peer = t.Peer
|
|
}
|
|
func ServiceResolverSubsetToStructs(s *ServiceResolverSubset, t *structs.ServiceResolverSubset) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Filter = s.Filter
|
|
t.OnlyPassing = s.OnlyPassing
|
|
}
|
|
func ServiceResolverSubsetFromStructs(t *structs.ServiceResolverSubset, s *ServiceResolverSubset) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Filter = t.Filter
|
|
s.OnlyPassing = t.OnlyPassing
|
|
}
|
|
func SourceIntentionToStructs(s *SourceIntention, t *structs.SourceIntention) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.Name = s.Name
|
|
t.Action = intentionActionToStructs(s.Action)
|
|
{
|
|
t.Permissions = make([]*structs.IntentionPermission, len(s.Permissions))
|
|
for i := range s.Permissions {
|
|
if s.Permissions[i] != nil {
|
|
var x structs.IntentionPermission
|
|
IntentionPermissionToStructs(s.Permissions[i], &x)
|
|
t.Permissions[i] = &x
|
|
}
|
|
}
|
|
}
|
|
t.Precedence = int(s.Precedence)
|
|
t.LegacyID = s.LegacyID
|
|
t.Type = intentionSourceTypeToStructs(s.Type)
|
|
t.Description = s.Description
|
|
t.LegacyMeta = s.LegacyMeta
|
|
t.LegacyCreateTime = timeToStructs(s.LegacyCreateTime)
|
|
t.LegacyUpdateTime = timeToStructs(s.LegacyUpdateTime)
|
|
t.EnterpriseMeta = enterpriseMetaToStructs(s.EnterpriseMeta)
|
|
t.Peer = s.Peer
|
|
}
|
|
func SourceIntentionFromStructs(t *structs.SourceIntention, s *SourceIntention) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.Name = t.Name
|
|
s.Action = intentionActionFromStructs(t.Action)
|
|
{
|
|
s.Permissions = make([]*IntentionPermission, len(t.Permissions))
|
|
for i := range t.Permissions {
|
|
if t.Permissions[i] != nil {
|
|
var x IntentionPermission
|
|
IntentionPermissionFromStructs(t.Permissions[i], &x)
|
|
s.Permissions[i] = &x
|
|
}
|
|
}
|
|
}
|
|
s.Precedence = int32(t.Precedence)
|
|
s.LegacyID = t.LegacyID
|
|
s.Type = intentionSourceTypeFromStructs(t.Type)
|
|
s.Description = t.Description
|
|
s.LegacyMeta = t.LegacyMeta
|
|
s.LegacyCreateTime = timeFromStructs(t.LegacyCreateTime)
|
|
s.LegacyUpdateTime = timeFromStructs(t.LegacyUpdateTime)
|
|
s.EnterpriseMeta = enterpriseMetaFromStructs(t.EnterpriseMeta)
|
|
s.Peer = t.Peer
|
|
}
|
|
func TransparentProxyMeshConfigToStructs(s *TransparentProxyMeshConfig, t *structs.TransparentProxyMeshConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
t.MeshDestinationsOnly = s.MeshDestinationsOnly
|
|
}
|
|
func TransparentProxyMeshConfigFromStructs(t *structs.TransparentProxyMeshConfig, s *TransparentProxyMeshConfig) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
s.MeshDestinationsOnly = t.MeshDestinationsOnly
|
|
}
|