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: do not allow kic ControlPlane ref type for types unsupported by KIC #161

Merged
merged 2 commits into from
Nov 20, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
5 changes: 4 additions & 1 deletion api/configuration/v1alpha1/kong_ca_certificate.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,10 +32,13 @@ type KongCACertificate struct {
}

// KongCACertificateSpec contains the specification for the KongCACertificate.
// +kubebuilder:validation:XValidation:rule="!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type != 'kic'", message="KIC is not supported as control plane"
// +apireference:kgo:include
type KongCACertificateSpec struct {
// ControlPlaneRef references the Konnect Control Plane that this KongCACertificate should be created in.
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef,omitempty"`
// +kubebuilder:validation:Required
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef"`

KongCACertificateAPISpec `json:",inline"`
}

Expand Down
5 changes: 4 additions & 1 deletion api/configuration/v1alpha1/kong_certificate.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,10 +32,13 @@ type KongCertificate struct {
}

// KongCertificateSpec contains the specification for the KongCertificate.
// +kubebuilder:validation:XValidation:rule="!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type != 'kic'", message="KIC is not supported as control plane"
// +apireference:kgo:include
type KongCertificateSpec struct {
// ControlPlaneRef references the Konnect Control Plane that this KongCertificate should be created in.
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef,omitempty"`
// +kubebuilder:validation:Required
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef"`

KongCertificateAPISpec `json:",inline"`
}

Expand Down
3 changes: 1 addition & 2 deletions api/configuration/v1alpha1/kong_target_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,7 @@ type KongTarget struct {
Status KongTargetStatus `json:"status,omitempty"`
}

// KongTargetSpec defines the specification of a Kong Target.
// KongTargetSpec defines the desired state of KongTarget.
// KongTargetSpec defines the spec of KongTarget.
// +apireference:kgo:include
type KongTargetSpec struct {
// UpstreamRef is a reference to a KongUpstream this KongTarget is attached to.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,11 +48,12 @@ type KongDataPlaneClientCertificate struct {
}

// KongDataPlaneClientCertificateSpec defines the spec for a KongDataPlaneClientCertificate.
// +kubebuilder:validation:XValidation:rule="!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type != 'kic'", message="KIC is not supported as control plane"
// +apireference:kgo:include
type KongDataPlaneClientCertificateSpec struct {
// ControlPlaneRef is a reference to a Konnect ControlPlane this KongDataPlaneClientCertificate is associated with.
// +optional
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef,omitempty"`
// +kubebuilder:validation:Required
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef"`

// KongDataPlaneClientCertificateAPISpec are the attributes of the KongDataPlaneClientCertificate itself.
KongDataPlaneClientCertificateAPISpec `json:",inline"`
Expand Down
1 change: 1 addition & 0 deletions api/configuration/v1alpha1/kongkey_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ type KongKey struct {
}

// KongKeySpec defines the spec for a KongKey.
// +kubebuilder:validation:XValidation:rule="!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type != 'kic'", message="KIC is not supported as control plane"
// +apireference:kgo:include
type KongKeySpec struct {
// ControlPlaneRef is a reference to a Konnect ControlPlane this KongKey is associated with.
Expand Down
5 changes: 3 additions & 2 deletions api/configuration/v1alpha1/kongkeyset_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,11 +47,12 @@ type KongKeySet struct {
}

// KongKeySetSpec defines the spec for a KongKeySet.
// +kubebuilder:validation:XValidation:rule="!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type != 'kic'", message="KIC is not supported as control plane"
// +apireference:kgo:include
type KongKeySetSpec struct {
// ControlPlaneRef is a reference to a Konnect ControlPlane with which KongKeySet is associated.
// +optional
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef,omitempty"`
// +kubebuilder:validation:Required
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef"`

// KongKeySetAPISpec are the attributes of the KongKeySet itself.
KongKeySetAPISpec `json:",inline"`
Expand Down
5 changes: 3 additions & 2 deletions api/configuration/v1alpha1/kongroute_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ import (
// +kubebuilder:printcolumn:name="Programmed",description="The Resource is Programmed on Konnect",type=string,JSONPath=`.status.conditions[?(@.type=='Programmed')].status`
// +kubebuilder:validation:XValidation:rule="!has(oldSelf.spec.serviceRef) || has(self.spec.serviceRef)", message="serviceRef is required once set"
// +kubebuilder:validation:XValidation:rule="has(self.spec.protocols) && self.spec.protocols.exists(p, p == 'http') ? (has(self.spec.hosts) || has(self.spec.methods) || has(self.spec.paths) || has(self.spec.paths) || has(self.spec.paths) || has(self.spec.headers) ) : true", message="If protocols has 'http', at least one of 'hosts', 'methods', 'paths' or 'headers' must be set"
// +kubebuilder:validation:XValidation:rule="!has(self.spec.controlPlaneRef) && !has(self.spec.serviceRef) || has(self.spec.controlPlaneRef) && !has(self.spec.serviceRef) || !has(self.spec.controlPlaneRef) && has(self.spec.serviceRef)", message="Cannot set both controlPlaneRef or serviceRef at the same time"
// +kubebuilder:validation:XValidation:rule="has(self.spec.controlPlaneRef) && !has(self.spec.serviceRef) || !has(self.spec.controlPlaneRef) && has(self.spec.serviceRef)", message="Has to set either controlPlaneRef or serviceRef"
// +kubebuilder:validation:XValidation:rule="(!has(self.spec.controlPlaneRef) || !has(self.spec.controlPlaneRef.konnectNamespacedRef)) ? true : !has(self.spec.controlPlaneRef.konnectNamespacedRef.__namespace__)", message="spec.controlPlaneRef cannot specify namespace for namespaced resource"
// +kubebuilder:validation:XValidation:rule="!has(self.spec.serviceRef) ? true : (!self.status.conditions.exists(c, c.type == 'Programmed' && c.status == 'True')) ? true : oldSelf.spec.serviceRef == self.spec.serviceRef", message="spec.serviceRef is immutable when an entity is already Programmed"
// +kubebuilder:validation:XValidation:rule="!has(self.spec.controlPlaneRef) ? true :(!self.status.conditions.exists(c, c.type == 'Programmed' && c.status == 'True')) ? true : oldSelf.spec.controlPlaneRef == self.spec.controlPlaneRef", message="spec.controlPlaneRef is immutable when an entity is already Programmed"
Expand All @@ -55,7 +55,8 @@ type KongRoute struct {
Status KongRouteStatus `json:"status,omitempty"`
}

// KongRouteSpec defines specification of a Kong Route.
// KongRouteSpec defines spec of a Kong Route.
// +kubebuilder:validation:XValidation:rule="!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type != 'kic'", message="KIC is not supported as control plane"
// +apireference:kgo:include
type KongRouteSpec struct {
// ControlPlaneRef is a reference to a ControlPlane this KongRoute is associated with.
Expand Down
7 changes: 4 additions & 3 deletions api/configuration/v1alpha1/kongservice_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,16 +52,17 @@ type KongService struct {
}

// KongServiceSpec defines specification of a Kong Route.
// +kubebuilder:validation:XValidation:rule="!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type != 'kic'", message="KIC is not supported as control plane"
// +apireference:kgo:include
type KongServiceSpec struct {
// ControlPlaneRef is a reference to a ControlPlane this KongService is associated with.
// +optional
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef,omitempty"`
// +kubebuilder:validation:Required
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef"`

KongServiceAPISpec `json:",inline"`
}

// KongServiceAPISpec defines specification of a Kong Service.
// KongServiceAPISpec defines the specification of a Kong Service.
// +apireference:kgo:include
type KongServiceAPISpec struct {
// TODO(pmalek): client certificate implement ref
Expand Down
2 changes: 1 addition & 1 deletion api/configuration/v1alpha1/kongsni_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ type KongSNI struct {
Status KongSNIStatus `json:"status,omitempty"`
}

// KongSNIAPISpec defines specification of an SNI.
// KongSNIAPISpec defines the spec of an SNI.
// +apireference:kgo:include
type KongSNIAPISpec struct {
// Name is the name of the SNI. Required and must be a host or wildcard host.
Expand Down
7 changes: 4 additions & 3 deletions api/configuration/v1alpha1/kongupstream_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,12 +49,13 @@ type KongUpstream struct {
Status KongUpstreamStatus `json:"status,omitempty"`
}

// KongUpstreamSpec defines specification of a Kong Upstream.
// KongUpstreamSpec defines the spec of Kong Upstream.
// +kubebuilder:validation:XValidation:rule="!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type != 'kic'", message="KIC is not supported as control plane"
// +apireference:kgo:include
type KongUpstreamSpec struct {
// ControlPlaneRef is a reference to a ControlPlane this KongUpstream is associated with.
// +optional
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef,omitempty"`
// +kubebuilder:validation:Required
ControlPlaneRef *ControlPlaneRef `json:"controlPlaneRef"`

KongUpstreamAPISpec `json:",inline"`
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,12 @@ spec:
rule: self.all(tag, size(tag) >= 1 && size(tag) <= 128)
required:
- cert
- controlPlaneRef
type: object
x-kubernetes-validations:
- message: KIC is not supported as control plane
rule: '!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type
!= ''kic'''
status:
default:
conditions:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -143,8 +143,13 @@ spec:
rule: self.all(tag, size(tag) >= 1 && size(tag) <= 128)
required:
- cert
- controlPlaneRef
- key
type: object
x-kubernetes-validations:
- message: KIC is not supported as control plane
rule: '!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type
!= ''kic'''
status:
default:
conditions:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,12 @@ spec:
rule: '!has(self.type) ? !has(self.konnectNamespacedRef) : true'
required:
- cert
- controlPlaneRef
type: object
x-kubernetes-validations:
- message: KIC is not supported as control plane
rule: '!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type
!= ''kic'''
status:
default:
conditions:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -199,6 +199,9 @@ spec:
- kid
type: object
x-kubernetes-validations:
- message: KIC is not supported as control plane
rule: '!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type
!= ''kic'''
- message: Either 'jwk' or 'pem' must be set
rule: has(self.jwk) || has(self.pem)
status:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -127,8 +127,13 @@ spec:
- message: tags entries must not be longer than 128 characters
rule: self.all(tag, size(tag) >= 1 && size(tag) <= 128)
required:
- controlPlaneRef
- name
type: object
x-kubernetes-validations:
- message: KIC is not supported as control plane
rule: '!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type
!= ''kic'''
status:
default:
conditions:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ spec:
metadata:
type: object
spec:
description: KongRouteSpec defines specification of a Kong Route.
description: KongRouteSpec defines spec of a Kong Route.
properties:
controlPlaneRef:
description: |-
Expand Down Expand Up @@ -266,6 +266,10 @@ spec:
- message: tags entries must not be longer than 128 characters
rule: self.all(tag, size(tag) >= 1 && size(tag) <= 128)
type: object
x-kubernetes-validations:
- message: KIC is not supported as control plane
rule: '!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type
!= ''kic'''
status:
default:
conditions:
Expand Down Expand Up @@ -377,10 +381,9 @@ spec:
? (has(self.spec.hosts) || has(self.spec.methods) || has(self.spec.paths)
|| has(self.spec.paths) || has(self.spec.paths) || has(self.spec.headers)
) : true'
- message: Cannot set both controlPlaneRef or serviceRef at the same time
rule: '!has(self.spec.controlPlaneRef) && !has(self.spec.serviceRef) ||
has(self.spec.controlPlaneRef) && !has(self.spec.serviceRef) || !has(self.spec.controlPlaneRef)
&& has(self.spec.serviceRef)'
- message: Has to set either controlPlaneRef or serviceRef
rule: has(self.spec.controlPlaneRef) && !has(self.spec.serviceRef) || !has(self.spec.controlPlaneRef)
&& has(self.spec.serviceRef)
- message: spec.controlPlaneRef cannot specify namespace for namespaced resource
rule: '(!has(self.spec.controlPlaneRef) || !has(self.spec.controlPlaneRef.konnectNamespacedRef))
? true : !has(self.spec.controlPlaneRef.konnectNamespacedRef.__namespace__)'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -185,8 +185,13 @@ spec:
format: int64
type: integer
required:
- controlPlaneRef
- host
type: object
x-kubernetes-validations:
- message: KIC is not supported as control plane
rule: '!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type
!= ''kic'''
status:
default:
conditions:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,9 +43,7 @@ spec:
metadata:
type: object
spec:
description: |-
KongTargetSpec defines the specification of a Kong Target.
KongTargetSpec defines the desired state of KongTarget.
description: KongTargetSpec defines the spec of KongTarget.
properties:
tags:
description: Tags is an optional set of strings associated with the
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ spec:
metadata:
type: object
spec:
description: KongUpstreamSpec defines specification of a Kong Upstream.
description: KongUpstreamSpec defines the spec of Kong Upstream.
properties:
algorithm:
description: Which load balancing algorithm to use.
Expand Down Expand Up @@ -288,8 +288,13 @@ spec:
description: If set, the balancer will use SRV hostname(if DNS Answer
has SRV record) as the proxy upstream `Host`.
type: boolean
required:
- controlPlaneRef
type: object
x-kubernetes-validations:
- message: KIC is not supported as control plane
rule: '!has(self.controlPlaneRef) ? true : self.controlPlaneRef.type
!= ''kic'''
- message: hash_fallback_header is required when `hash_fallback` is set
to `header`.
rule: '!has(self.hash_fallback) || (self.hash_fallback != ''header''
Expand Down
11 changes: 5 additions & 6 deletions docs/api-reference.md
Original file line number Diff line number Diff line change
Expand Up @@ -1314,7 +1314,7 @@ _Appears in:_
#### KongRouteSpec


KongRouteSpec defines specification of a Kong Route.
KongRouteSpec defines spec of a Kong Route.



Expand Down Expand Up @@ -1349,7 +1349,7 @@ _Appears in:_
#### KongSNIAPISpec


KongSNIAPISpec defines specification of an SNI.
KongSNIAPISpec defines the spec of an SNI.



Expand Down Expand Up @@ -1384,7 +1384,7 @@ _Appears in:_
#### KongServiceAPISpec


KongServiceAPISpec defines specification of a Kong Service.
KongServiceAPISpec defines the specification of a Kong Service.



Expand Down Expand Up @@ -1460,8 +1460,7 @@ _Appears in:_
#### KongTargetSpec


KongTargetSpec defines the specification of a Kong Target.
KongTargetSpec defines the desired state of KongTarget.
KongTargetSpec defines the spec of KongTarget.



Expand Down Expand Up @@ -1513,7 +1512,7 @@ _Appears in:_
#### KongUpstreamSpec


KongUpstreamSpec defines specification of a Kong Upstream.
KongUpstreamSpec defines the spec of Kong Upstream.



Expand Down
2 changes: 1 addition & 1 deletion scripts/crds-generator/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -162,7 +162,7 @@ type ChannelsMarker []string

// ApplyToCRD applies the channels marker to the given CRD by adding the channels annotation.
// It implements the Marker interface.
func (m ChannelsMarker) ApplyToCRD(crd *apiext.CustomResourceDefinition, _ string) error { // nolint:unparam
func (m ChannelsMarker) ApplyToCRD(crd *apiext.CustomResourceDefinition, _ string) error { //nolint:unparam
if crd.Annotations == nil {
crd.Annotations = map[string]string{}
}
Expand Down
2 changes: 1 addition & 1 deletion test/crdsvalidation/kongcacertificate_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,6 @@ func TestKongCACertificate(t *testing.T) {
},
}

NewCRDValidationTestCasesGroupCPRefChange(t, obj).Run(t)
NewCRDValidationTestCasesGroupCPRefChange(t, obj, NotSupportedByKIC).Run(t)
})
}
4 changes: 2 additions & 2 deletions test/crdsvalidation/kongcertificate_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@ import (
"testing"

"github.com/samber/lo"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"

configurationv1alpha1 "github.com/kong/kubernetes-configuration/api/configuration/v1alpha1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)

func TestKongCertificate(t *testing.T) {
Expand All @@ -26,7 +26,7 @@ func TestKongCertificate(t *testing.T) {
},
}

NewCRDValidationTestCasesGroupCPRefChange(t, obj).Run(t)
NewCRDValidationTestCasesGroupCPRefChange(t, obj, NotSupportedByKIC).Run(t)
})

t.Run("required fields", func(t *testing.T) {
Expand Down
2 changes: 1 addition & 1 deletion test/crdsvalidation/kongconsumer_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ func TestKongConsumer(t *testing.T) {
Username: "username-1",
}

NewCRDValidationTestCasesGroupCPRefChange(t, obj).Run(t)
NewCRDValidationTestCasesGroupCPRefChange(t, obj, SupportedByKIC).Run(t)
})

t.Run("required fields", func(t *testing.T) {
Expand Down
2 changes: 1 addition & 1 deletion test/crdsvalidation/kongconsumergroup_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ func TestKongConsumerGroup(t *testing.T) {
},
}

NewCRDValidationTestCasesGroupCPRefChange(t, obj).Run(t)
NewCRDValidationTestCasesGroupCPRefChange(t, obj, NotSupportedByKIC).Run(t)
})

t.Run("cp ref update", func(t *testing.T) {
Expand Down
Loading