Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add file resource provider for EG standalone mode #3159

Merged
merged 23 commits into from
Sep 11, 2024
Merged
Show file tree
Hide file tree
Changes from 19 commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
93e4dd3
add validations for envoy-gateway file resource type
shawnh2 Apr 1, 2024
3956911
improve eg validation and add resource provider interface for various…
shawnh2 Apr 2, 2024
9acf325
Merge branch 'main' of github.com:envoyproxy/gateway into host-file-p…
shawnh2 Apr 2, 2024
7de91b3
extract common gatewayapi layer translate logic in egctl translate
shawnh2 Apr 3, 2024
3419af6
add notifier support
shawnh2 Apr 10, 2024
e709eae
fix lint and move read yaml bytes function back to translate
shawnh2 Apr 10, 2024
6f3b400
add resources store support
shawnh2 Apr 18, 2024
739c8dc
Merge branch 'main' of github.com:envoyproxy/gateway into host-file-p…
shawnh2 Apr 18, 2024
5726ee5
fix lint
shawnh2 Apr 18, 2024
9460667
resolve conflicts
shawnh2 Aug 13, 2024
2e1db1b
fix ci
shawnh2 Aug 13, 2024
55de67f
resolve conflicts
shawnh2 Aug 16, 2024
5fe295f
update infra provider api and address comments
shawnh2 Aug 16, 2024
21353e2
update custom provider comments and validate method test
shawnh2 Aug 24, 2024
59e9c59
restore extension manager and add health probe server for file provider
shawnh2 Aug 24, 2024
be44b88
update envoy gateway helper functions
shawnh2 Aug 24, 2024
ec357fa
add some unit tests
shawnh2 Aug 25, 2024
4052618
properly handle the remove event for the file provider
shawnh2 Aug 25, 2024
381efd6
fix lint
shawnh2 Aug 25, 2024
a30b1ea
no default to k8s for infra provider
shawnh2 Sep 8, 2024
a635d03
fix runner
shawnh2 Sep 8, 2024
61638ee
Merge branch 'main' of github.com:envoyproxy/gateway into host-file-p…
shawnh2 Sep 8, 2024
3c5d0f1
Merge branch 'main' into host-file-provider
Xunzhuo Sep 11, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 10 additions & 3 deletions api/v1alpha1/envoygateway_helpers.go
Original file line number Diff line number Diff line change
Expand Up @@ -209,10 +209,9 @@ func DefaultEnvoyGatewayAdminAddress() *EnvoyGatewayAdminAddress {
}

// GetEnvoyGatewayKubeProvider returns the EnvoyGatewayKubernetesProvider of Provider or
// a default EnvoyGatewayKubernetesProvider if unspecified. If EnvoyGatewayProvider is not of
// type "Kubernetes", a nil EnvoyGatewayKubernetesProvider is returned.
// a default EnvoyGatewayKubernetesProvider if its Infrastructure provider is Kubernetes.
func (r *EnvoyGatewayProvider) GetEnvoyGatewayKubeProvider() *EnvoyGatewayKubernetesProvider {
if r.Type != ProviderTypeKubernetes {
if !r.CanRunKubernetesInfraProvider() {
return nil
}

Expand All @@ -237,9 +236,17 @@ func (r *EnvoyGatewayProvider) GetEnvoyGatewayKubeProvider() *EnvoyGatewayKubern
if r.Kubernetes.ShutdownManager == nil {
r.Kubernetes.ShutdownManager = &ShutdownManager{Image: ptr.To(DefaultShutdownManagerImage)}
}

return r.Kubernetes
}

// CanRunKubernetesInfraProvider returns true if the resource provider is "Kubernetes"
// or "Custom" (but with unspecific infrastructure provider).
func (r *EnvoyGatewayProvider) CanRunKubernetesInfraProvider() bool {
return r.Type == ProviderTypeKubernetes ||
(r.Type == ProviderTypeCustom && r.Custom.Infrastructure == nil)
}

// DefaultEnvoyGatewayLoggingLevel returns a new EnvoyGatewayLogging with default configuration parameters.
// When v1alpha1.LogComponentGatewayDefault specified, all other logging components are ignored.
func (logging *EnvoyGatewayLogging) DefaultEnvoyGatewayLoggingLevel(level LogLevel) LogLevel {
Expand Down
12 changes: 8 additions & 4 deletions api/v1alpha1/envoygateway_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -174,7 +174,7 @@ type ExtensionAPISettings struct {
// EnvoyGatewayProvider defines the desired configuration of a provider.
// +union
type EnvoyGatewayProvider struct {
// Type is the type of provider to use. Supported types are "Kubernetes".
// Type is the type of provider to use. Supported types are "Kubernetes", "Custom".
//
// +unionDiscriminator
Type ProviderType `json:"type"`
Expand All @@ -186,7 +186,7 @@ type EnvoyGatewayProvider struct {
Kubernetes *EnvoyGatewayKubernetesProvider `json:"kubernetes,omitempty"`

// Custom defines the configuration for the Custom provider. This provider
// allows you to define a specific resource provider and a infrastructure
// allows you to define a specific resource provider and an infrastructure
// provider.
//
// +optional
Expand Down Expand Up @@ -271,7 +271,11 @@ type EnvoyGatewayCustomProvider struct {
// This provider is used to specify the provider to be used
// to provide an environment to deploy the out resources like
// the Envoy Proxy data plane.
Infrastructure EnvoyGatewayInfrastructureProvider `json:"infrastructure"`
//
// Infrastructure is optional, if no provider is set,
// The Kubernetes will be used as the default infrastructure provider.
shawnh2 marked this conversation as resolved.
Show resolved Hide resolved
// +optional
Infrastructure *EnvoyGatewayInfrastructureProvider `json:"infrastructure,omitempty"`
}

// ResourceProviderType defines the types of custom resource providers supported by Envoy Gateway.
Expand Down Expand Up @@ -300,7 +304,7 @@ type EnvoyGatewayResourceProvider struct {
// EnvoyGatewayFileResourceProvider defines configuration for the File Resource provider.
type EnvoyGatewayFileResourceProvider struct {
// Paths are the paths to a directory or file containing the resource configuration.
// Recursive sub directories are not currently supported.
// Recursive subdirectories are not currently supported.
Paths []string `json:"paths"`
}

Expand Down
7 changes: 3 additions & 4 deletions api/v1alpha1/shared_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,16 +47,15 @@ type GroupVersionKind struct {

// ProviderType defines the types of providers supported by Envoy Gateway.
//
// +kubebuilder:validation:Enum=Kubernetes
// +kubebuilder:validation:Enum=Kubernetes;Custom
type ProviderType string

const (
// ProviderTypeKubernetes defines the "Kubernetes" provider.
ProviderTypeKubernetes ProviderType = "Kubernetes"

// ProviderTypeFile defines the "File" provider. This type is not implemented
// until https://github.com/envoyproxy/gateway/issues/1001 is fixed.
ProviderTypeFile ProviderType = "File"
// ProviderTypeCustom defines the "Custom" provider.
ProviderTypeCustom ProviderType = "Custom"
)

// KubernetesDeploymentSpec defines the desired state of the Kubernetes deployment resource.
Expand Down
52 changes: 52 additions & 0 deletions api/v1alpha1/validation/envoygateway_validate.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,10 @@ func ValidateEnvoyGateway(eg *egv1a1.EnvoyGateway) error {
if err := validateEnvoyGatewayKubernetesProvider(eg.Provider.Kubernetes); err != nil {
return err
}
case egv1a1.ProviderTypeCustom:
if err := validateEnvoyGatewayCustomProvider(eg.Provider.Custom); err != nil {
return err
}
default:
return fmt.Errorf("unsupported provider type")
}
Expand Down Expand Up @@ -79,6 +83,54 @@ func validateEnvoyGatewayKubernetesProvider(provider *egv1a1.EnvoyGatewayKuberne
return nil
}

func validateEnvoyGatewayCustomProvider(provider *egv1a1.EnvoyGatewayCustomProvider) error {
if provider == nil {
return fmt.Errorf("empty custom provider settings for file provider")
}

if err := validateEnvoyGatewayCustomResourceProvider(provider.Resource); err != nil {
return err
}

if err := validateEnvoyGatewayCustomInfrastructureProvider(provider.Infrastructure); err != nil {
return err
}

return nil
}

func validateEnvoyGatewayCustomResourceProvider(resource egv1a1.EnvoyGatewayResourceProvider) error {
switch resource.Type {
case egv1a1.ResourceProviderTypeFile:
if resource.File == nil {
return fmt.Errorf("field 'file' should be specified when resource type is 'File'")
}

if len(resource.File.Paths) == 0 {
return fmt.Errorf("no paths were assigned for file resource provider to watch")
}
default:
return fmt.Errorf("unsupported resource provider: %s", resource.Type)
}
return nil
}

func validateEnvoyGatewayCustomInfrastructureProvider(infra *egv1a1.EnvoyGatewayInfrastructureProvider) error {
if infra == nil {
return nil
}

switch infra.Type {
case egv1a1.InfrastructureProviderTypeHost:
if infra.Host == nil {
return fmt.Errorf("field 'host' should be specified when infrastructure type is 'Host'")
}
default:
return fmt.Errorf("unsupported infrastructure provdier: %s", infra.Type)
}
return nil
}

func validateEnvoyGatewayLogging(logging *egv1a1.EnvoyGatewayLogging) error {
if logging == nil || len(logging.Level) == 0 {
return nil
Expand Down
168 changes: 165 additions & 3 deletions api/v1alpha1/validation/envoygateway_validate_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -68,11 +68,173 @@ func TestValidateEnvoyGateway(t *testing.T) {
expect: false,
},
{
name: "unsupported provider",
name: "nil custom provider",
eg: &egv1a1.EnvoyGateway{
EnvoyGatewaySpec: egv1a1.EnvoyGatewaySpec{
Gateway: egv1a1.DefaultGateway(),
Provider: &egv1a1.EnvoyGatewayProvider{Type: egv1a1.ProviderTypeFile},
Gateway: egv1a1.DefaultGateway(),
Provider: &egv1a1.EnvoyGatewayProvider{
Type: egv1a1.ProviderTypeCustom,
Custom: nil,
},
},
},
expect: false,
},
{
name: "empty custom provider",
eg: &egv1a1.EnvoyGateway{
EnvoyGatewaySpec: egv1a1.EnvoyGatewaySpec{
Gateway: egv1a1.DefaultGateway(),
Provider: &egv1a1.EnvoyGatewayProvider{
Type: egv1a1.ProviderTypeCustom,
Custom: &egv1a1.EnvoyGatewayCustomProvider{},
},
},
},
expect: false,
},
{
name: "custom provider with file resource provider and host infra provider",
eg: &egv1a1.EnvoyGateway{
EnvoyGatewaySpec: egv1a1.EnvoyGatewaySpec{
Gateway: egv1a1.DefaultGateway(),
Provider: &egv1a1.EnvoyGatewayProvider{
Type: egv1a1.ProviderTypeCustom,
Custom: &egv1a1.EnvoyGatewayCustomProvider{
Resource: egv1a1.EnvoyGatewayResourceProvider{
Type: egv1a1.ResourceProviderTypeFile,
File: &egv1a1.EnvoyGatewayFileResourceProvider{
Paths: []string{"foo", "bar"},
},
},
Infrastructure: &egv1a1.EnvoyGatewayInfrastructureProvider{
Type: egv1a1.InfrastructureProviderTypeHost,
Host: &egv1a1.EnvoyGatewayHostInfrastructureProvider{},
},
},
},
},
},
expect: true,
},
{
name: "custom provider with file provider and k8s infra provider",
eg: &egv1a1.EnvoyGateway{
EnvoyGatewaySpec: egv1a1.EnvoyGatewaySpec{
Gateway: egv1a1.DefaultGateway(),
Provider: &egv1a1.EnvoyGatewayProvider{
Type: egv1a1.ProviderTypeCustom,
Custom: &egv1a1.EnvoyGatewayCustomProvider{
Resource: egv1a1.EnvoyGatewayResourceProvider{
Type: egv1a1.ResourceProviderTypeFile,
File: &egv1a1.EnvoyGatewayFileResourceProvider{
Paths: []string{"foo", "bar"},
},
},
},
},
},
},
expect: true,
},
{
name: "custom provider with unsupported resource provider",
eg: &egv1a1.EnvoyGateway{
EnvoyGatewaySpec: egv1a1.EnvoyGatewaySpec{
Gateway: egv1a1.DefaultGateway(),
Provider: &egv1a1.EnvoyGatewayProvider{
Type: egv1a1.ProviderTypeCustom,
Custom: &egv1a1.EnvoyGatewayCustomProvider{
Resource: egv1a1.EnvoyGatewayResourceProvider{
Type: "foobar",
},
},
},
},
},
expect: false,
},
{
name: "custom provider with file provider but no file struct",
eg: &egv1a1.EnvoyGateway{
EnvoyGatewaySpec: egv1a1.EnvoyGatewaySpec{
Gateway: egv1a1.DefaultGateway(),
Provider: &egv1a1.EnvoyGatewayProvider{
Type: egv1a1.ProviderTypeCustom,
Custom: &egv1a1.EnvoyGatewayCustomProvider{
Resource: egv1a1.EnvoyGatewayResourceProvider{
Type: egv1a1.ResourceProviderTypeFile,
},
},
},
},
},
expect: false,
},
{
name: "custom provider with file provider and host infra provider but no host struct",
eg: &egv1a1.EnvoyGateway{
EnvoyGatewaySpec: egv1a1.EnvoyGatewaySpec{
Gateway: egv1a1.DefaultGateway(),
Provider: &egv1a1.EnvoyGatewayProvider{
Type: egv1a1.ProviderTypeCustom,
Custom: &egv1a1.EnvoyGatewayCustomProvider{
Resource: egv1a1.EnvoyGatewayResourceProvider{
Type: egv1a1.ResourceProviderTypeFile,
File: &egv1a1.EnvoyGatewayFileResourceProvider{
Paths: []string{"a", "b"},
},
},
Infrastructure: &egv1a1.EnvoyGatewayInfrastructureProvider{
Type: egv1a1.InfrastructureProviderTypeHost,
},
},
},
},
},
expect: false,
},
{
name: "custom provider with file provider and unsupported infra provider",
eg: &egv1a1.EnvoyGateway{
EnvoyGatewaySpec: egv1a1.EnvoyGatewaySpec{
Gateway: egv1a1.DefaultGateway(),
Provider: &egv1a1.EnvoyGatewayProvider{
Type: egv1a1.ProviderTypeCustom,
Custom: &egv1a1.EnvoyGatewayCustomProvider{
Resource: egv1a1.EnvoyGatewayResourceProvider{
Type: egv1a1.ResourceProviderTypeFile,
File: &egv1a1.EnvoyGatewayFileResourceProvider{
Paths: []string{"a", "b"},
},
},
Infrastructure: &egv1a1.EnvoyGatewayInfrastructureProvider{
Type: "foobar",
},
},
},
},
},
expect: false,
},
{
name: "custom provider with file provider and host infra provider but no paths assign in resource",
eg: &egv1a1.EnvoyGateway{
EnvoyGatewaySpec: egv1a1.EnvoyGatewaySpec{
Gateway: egv1a1.DefaultGateway(),
Provider: &egv1a1.EnvoyGatewayProvider{
Type: egv1a1.ProviderTypeCustom,
Custom: &egv1a1.EnvoyGatewayCustomProvider{
Resource: egv1a1.EnvoyGatewayResourceProvider{
Type: egv1a1.ResourceProviderTypeFile,
File: &egv1a1.EnvoyGatewayFileResourceProvider{},
},
Infrastructure: &egv1a1.EnvoyGatewayInfrastructureProvider{
Type: egv1a1.InfrastructureProviderTypeHost,
Host: &egv1a1.EnvoyGatewayHostInfrastructureProvider{},
},
},
},
},
},
expect: false,
Expand Down
2 changes: 1 addition & 1 deletion api/v1alpha1/validation/envoyproxy_validate_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,7 @@ func TestValidateEnvoyProxy(t *testing.T) {
},
Spec: egv1a1.EnvoyProxySpec{
Provider: &egv1a1.EnvoyProxyProvider{
Type: egv1a1.ProviderTypeFile,
Type: egv1a1.ProviderTypeCustom,
},
},
},
Expand Down
6 changes: 5 additions & 1 deletion api/v1alpha1/zz_generated.deepcopy.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -10213,6 +10213,7 @@ spec:
optional auxiliary control planes. Supported types are "Kubernetes".
enum:
- Kubernetes
- Custom
type: string
required:
- type
Expand Down
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -230,7 +230,7 @@ require (
github.com/envoyproxy/protoc-gen-validate v1.0.4 // indirect
github.com/evanphx/json-patch v5.9.0+incompatible
github.com/exponent-io/jsonpath v0.0.0-20210407135951-1de76d718b3f // indirect
github.com/fsnotify/fsnotify v1.7.0 // indirect
github.com/fsnotify/fsnotify v1.7.0
github.com/go-asn1-ber/asn1-ber v1.5.5 // indirect
github.com/go-errors/errors v1.5.1 // indirect
github.com/go-logr/stdr v1.2.2 // indirect
Expand Down
2 changes: 1 addition & 1 deletion internal/cmd/server.go
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ func setupRunners(cfg *config.Server) error {
pResources := new(message.ProviderResources)
// Start the Provider Service
// It fetches the resources from the configured provider type
// and publishes it
// and publishes it.
// It also subscribes to status resources and once it receives
// a status resource back, it writes it out.
providerRunner := providerrunner.New(&providerrunner.Config{
Expand Down
Loading