mirror of
https://github.com/status-im/consul.git
synced 2025-01-18 17:52:17 +00:00
af3439b53d
This PR fixes an issue where upstreams did not correctly inherit the proper namespace / partition from the parent service when attempting to fetch the upstream protocol due to inconsistent normalization. Some of the merge-service-configuration logic would normalize to default, while some of the proxycfg logic would normalize to match the parent service. Due to this mismatch in logic, an incorrect service-defaults configuration entry would be fetched and have its protocol applied to the upstream.
78 lines
2.0 KiB
Go
78 lines
2.0 KiB
Go
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: BUSL-1.1
|
|
|
|
//go:build !consulent
|
|
// +build !consulent
|
|
|
|
package structs
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
|
|
"github.com/hashicorp/go-multierror"
|
|
|
|
"github.com/hashicorp/consul/acl"
|
|
)
|
|
|
|
func (e *ProxyConfigEntry) validateEnterpriseMeta() error {
|
|
return nil
|
|
}
|
|
|
|
func validateUnusedKeys(unused []string) error {
|
|
var err error
|
|
|
|
for _, k := range unused {
|
|
switch {
|
|
case k == "CreateIndex" || k == "ModifyIndex":
|
|
case k == "kind" || k == "Kind":
|
|
// The kind field is used to determine the target, but doesn't need
|
|
// to exist on the target.
|
|
case strings.HasSuffix(strings.ToLower(k), "namespace"):
|
|
err = multierror.Append(err, fmt.Errorf("invalid config key %q, namespaces are a consul enterprise feature", k))
|
|
case strings.Contains(strings.ToLower(k), "jwt"):
|
|
err = multierror.Append(err, fmt.Errorf("invalid config key %q, api-gateway jwt validation is a consul enterprise feature", k))
|
|
default:
|
|
err = multierror.Append(err, fmt.Errorf("invalid config key %q", k))
|
|
}
|
|
}
|
|
return err
|
|
}
|
|
|
|
func validateInnerEnterpriseMeta(_, _ *acl.EnterpriseMeta) error {
|
|
return nil
|
|
}
|
|
|
|
func validateExportedServicesName(name string) error {
|
|
if name != "default" {
|
|
return fmt.Errorf(`exported-services Name must be "default"`)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func makeEnterpriseConfigEntry(kind, name string) ConfigEntry {
|
|
return nil
|
|
}
|
|
|
|
func validateRatelimit(rl *RateLimits) error {
|
|
if rl != nil {
|
|
return fmt.Errorf("invalid rate_limits config. Rate limiting is a consul enterprise feature")
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (rl RateLimits) ToEnvoyExtension() *EnvoyExtension { return nil }
|
|
|
|
// GetLocalUpstreamIDs returns the list of non-peer service ids for upstreams defined on this request.
|
|
// This is often used for fetching service-defaults config entries.
|
|
func (s *ServiceConfigRequest) GetLocalUpstreamIDs() []ServiceID {
|
|
var upstreams []ServiceID
|
|
for _, u := range s.UpstreamServiceNames {
|
|
if u.Peer != "" {
|
|
continue
|
|
}
|
|
upstreams = append(upstreams, u.ServiceName.ToServiceID())
|
|
}
|
|
return upstreams
|
|
}
|