2023-08-15 11:57:07 -07:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
2023-08-17 12:43:21 -06:00
|
|
|
// SPDX-License-Identifier: BUSL-1.1
|
2023-08-15 11:57:07 -07:00
|
|
|
|
|
|
|
package xdsv2
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
pbmesh "github.com/hashicorp/consul/proto-public/pbmesh/v1alpha1"
|
|
|
|
"github.com/hashicorp/go-hclog"
|
|
|
|
"google.golang.org/protobuf/proto"
|
|
|
|
|
|
|
|
"github.com/hashicorp/consul/envoyextensions/xdscommon"
|
|
|
|
)
|
|
|
|
|
|
|
|
// ResourceGenerator is associated with a single gRPC stream and creates xDS
|
|
|
|
// resources for a single client.
|
|
|
|
type ResourceGenerator struct {
|
|
|
|
Logger hclog.Logger
|
|
|
|
ProxyFeatures xdscommon.SupportedProxyFeatures
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewResourceGenerator(
|
|
|
|
logger hclog.Logger,
|
|
|
|
) *ResourceGenerator {
|
|
|
|
return &ResourceGenerator{
|
|
|
|
Logger: logger,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type ProxyResources struct {
|
|
|
|
proxyState *pbmesh.ProxyState
|
|
|
|
envoyResources map[string][]proto.Message
|
|
|
|
}
|
|
|
|
|
|
|
|
func (g *ResourceGenerator) AllResourcesFromIR(proxyState *pbmesh.ProxyState) (map[string][]proto.Message, error) {
|
|
|
|
pr := &ProxyResources{
|
|
|
|
proxyState: proxyState,
|
|
|
|
envoyResources: make(map[string][]proto.Message),
|
|
|
|
}
|
|
|
|
err := pr.generateXDSResources()
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("failed to generate xDS resources for ProxyState: %v", err)
|
|
|
|
}
|
|
|
|
return pr.envoyResources, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (pr *ProxyResources) generateXDSResources() error {
|
|
|
|
listeners := make([]proto.Message, 0)
|
|
|
|
routes := make([]proto.Message, 0)
|
|
|
|
|
|
|
|
for _, l := range pr.proxyState.Listeners {
|
|
|
|
protoListener, err := pr.makeListener(l)
|
|
|
|
// TODO: aggregate errors for listeners and still return any properly formed listeners.
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
listeners = append(listeners, protoListener)
|
|
|
|
}
|
|
|
|
|
2023-08-17 13:55:54 -06:00
|
|
|
pr.envoyResources[xdscommon.ListenerType] = listeners
|
|
|
|
|
2023-08-17 12:43:21 -06:00
|
|
|
clusters, err := pr.makeXDSClusters()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-08-15 11:57:07 -07:00
|
|
|
pr.envoyResources[xdscommon.ClusterType] = clusters
|
2023-08-17 13:55:54 -06:00
|
|
|
|
|
|
|
endpoints, err := pr.makeXDSEndpoints()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-08-15 11:57:07 -07:00
|
|
|
pr.envoyResources[xdscommon.EndpointType] = endpoints
|
|
|
|
|
2023-08-17 13:55:54 -06:00
|
|
|
pr.envoyResources[xdscommon.RouteType] = routes
|
|
|
|
|
2023-08-15 11:57:07 -07:00
|
|
|
return nil
|
|
|
|
}
|