2023-05-08 15:36:35 -04:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
2023-08-11 09:12:13 -04:00
|
|
|
// SPDX-License-Identifier: BUSL-1.1
|
2023-05-08 15:36:35 -04:00
|
|
|
|
|
|
|
package catalog
|
|
|
|
|
|
|
|
import (
|
2023-05-15 09:55:03 -04:00
|
|
|
"github.com/hashicorp/consul/internal/catalog/internal/controllers"
|
2023-06-16 12:58:53 -04:00
|
|
|
"github.com/hashicorp/consul/internal/catalog/internal/controllers/endpoints"
|
2023-08-09 11:02:17 -05:00
|
|
|
"github.com/hashicorp/consul/internal/catalog/internal/controllers/failover"
|
2023-06-16 12:58:53 -04:00
|
|
|
"github.com/hashicorp/consul/internal/catalog/internal/controllers/nodehealth"
|
|
|
|
"github.com/hashicorp/consul/internal/catalog/internal/controllers/workloadhealth"
|
2023-05-08 15:36:35 -04:00
|
|
|
"github.com/hashicorp/consul/internal/catalog/internal/types"
|
2023-05-15 09:55:03 -04:00
|
|
|
"github.com/hashicorp/consul/internal/controller"
|
2023-05-08 15:36:35 -04:00
|
|
|
"github.com/hashicorp/consul/internal/resource"
|
2023-09-22 10:51:15 -06:00
|
|
|
pbcatalog "github.com/hashicorp/consul/proto-public/pbcatalog/v2beta1"
|
2023-08-09 11:02:17 -05:00
|
|
|
"github.com/hashicorp/consul/proto-public/pbresource"
|
2023-05-08 15:36:35 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2023-06-16 12:58:53 -04:00
|
|
|
// Controller Statuses
|
|
|
|
NodeHealthStatusKey = nodehealth.StatusKey
|
|
|
|
NodeHealthStatusConditionHealthy = nodehealth.StatusConditionHealthy
|
|
|
|
NodeHealthConditions = nodehealth.Conditions
|
|
|
|
|
2024-01-18 16:30:11 -05:00
|
|
|
WorkloadHealthStatusKey = workloadhealth.ControllerID
|
2023-06-16 12:58:53 -04:00
|
|
|
WorkloadHealthStatusConditionHealthy = workloadhealth.StatusConditionHealthy
|
|
|
|
WorkloadHealthConditions = workloadhealth.WorkloadConditions
|
|
|
|
WorkloadAndNodeHealthConditions = workloadhealth.NodeAndWorkloadConditions
|
|
|
|
|
2024-01-18 17:52:52 -05:00
|
|
|
EndpointsStatusKey = endpoints.ControllerID
|
2023-06-16 12:58:53 -04:00
|
|
|
EndpointsStatusConditionEndpointsManaged = endpoints.StatusConditionEndpointsManaged
|
|
|
|
EndpointsStatusConditionManaged = endpoints.ConditionManaged
|
|
|
|
EndpointsStatusConditionUnmanaged = endpoints.ConditionUnmanaged
|
2023-10-12 13:20:13 -06:00
|
|
|
StatusConditionBoundIdentities = endpoints.StatusConditionBoundIdentities
|
|
|
|
StatusReasonWorkloadIdentitiesFound = endpoints.StatusReasonWorkloadIdentitiesFound
|
|
|
|
StatusReasonNoWorkloadIdentitiesFound = endpoints.StatusReasonNoWorkloadIdentitiesFound
|
2023-08-09 11:02:17 -05:00
|
|
|
|
2024-01-19 09:35:34 -05:00
|
|
|
FailoverStatusKey = failover.ControllerID
|
2023-08-09 11:02:17 -05:00
|
|
|
FailoverStatusConditionAccepted = failover.StatusConditionAccepted
|
|
|
|
FailoverStatusConditionAcceptedOKReason = failover.OKReason
|
|
|
|
FailoverStatusConditionAcceptedMissingServiceReason = failover.MissingServiceReason
|
|
|
|
FailoverStatusConditionAcceptedUnknownPortReason = failover.UnknownPortReason
|
|
|
|
FailoverStatusConditionAcceptedMissingDestinationServiceReason = failover.MissingDestinationServiceReason
|
|
|
|
FailoverStatusConditionAcceptedUnknownDestinationPortReason = failover.UnknownDestinationPortReason
|
|
|
|
FailoverStatusConditionAcceptedUsingMeshDestinationPortReason = failover.UsingMeshDestinationPortReason
|
2023-05-08 15:36:35 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
// RegisterTypes adds all resource types within the "catalog" API group
|
|
|
|
// to the given type registry
|
|
|
|
func RegisterTypes(r resource.Registry) {
|
|
|
|
types.Register(r)
|
|
|
|
}
|
2023-05-15 09:55:03 -04:00
|
|
|
|
|
|
|
// RegisterControllers registers controllers for the catalog types with
|
|
|
|
// the given controller Manager.
|
2024-01-19 09:35:34 -05:00
|
|
|
func RegisterControllers(mgr *controller.Manager) {
|
|
|
|
controllers.Register(mgr)
|
2023-05-15 09:55:03 -04:00
|
|
|
}
|
2023-08-08 14:42:43 -05:00
|
|
|
|
|
|
|
// SimplifyFailoverPolicy fully populates the PortConfigs map and clears the
|
|
|
|
// Configs map using the provided Service.
|
|
|
|
func SimplifyFailoverPolicy(svc *pbcatalog.Service, failover *pbcatalog.FailoverPolicy) *pbcatalog.FailoverPolicy {
|
|
|
|
return types.SimplifyFailoverPolicy(svc, failover)
|
|
|
|
}
|
2023-08-09 11:02:17 -05:00
|
|
|
|
2023-09-18 14:59:08 -05:00
|
|
|
// ValidateLocalServiceRefNoSection ensures the following:
|
|
|
|
//
|
|
|
|
// - ref is non-nil
|
|
|
|
// - type is ServiceType
|
|
|
|
// - section is empty
|
|
|
|
// - tenancy is set and partition/namespace are both non-empty
|
|
|
|
// - peer_name must be "local"
|
|
|
|
//
|
|
|
|
// Each possible validation error is wrapped in the wrapErr function before
|
|
|
|
// being collected in a multierror.Error.
|
|
|
|
func ValidateLocalServiceRefNoSection(ref *pbresource.Reference, wrapErr func(error) error) error {
|
|
|
|
return types.ValidateLocalServiceRefNoSection(ref, wrapErr)
|
|
|
|
}
|
2023-10-13 13:37:42 -05:00
|
|
|
|
|
|
|
// ValidateSelector ensures that the selector has at least one exact or prefix
|
|
|
|
// match constraint, and that if a filter is present it is valid.
|
|
|
|
//
|
|
|
|
// The selector can be nil, and have zero exact/prefix matches if allowEmpty is
|
|
|
|
// set to true.
|
|
|
|
func ValidateSelector(sel *pbcatalog.WorkloadSelector, allowEmpty bool) error {
|
|
|
|
return types.ValidateSelector(sel, allowEmpty)
|
|
|
|
}
|
2023-10-13 16:52:20 -06:00
|
|
|
|
2024-01-29 10:43:41 -08:00
|
|
|
func ValidateServicePortID(id string) error {
|
|
|
|
return types.ValidateServicePortID(id)
|
2023-10-13 16:52:20 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
func IsValidUnixSocketPath(host string) bool {
|
|
|
|
return types.IsValidUnixSocketPath(host)
|
|
|
|
}
|
2023-10-25 13:43:58 -04:00
|
|
|
|
|
|
|
func ValidateProtocol(protocol pbcatalog.Protocol) error {
|
|
|
|
return types.ValidateProtocol(protocol)
|
|
|
|
}
|