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

chore: set default spec.serverHostname in CRD KonnectExtension #947

Merged
merged 1 commit into from
Dec 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
6 changes: 6 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,12 @@

## Unreleased

### Changed

- `KonnectExtension` does not require `spec.serverHostname` to be set by a user
anymore - default is set to `konghq.com`.
[#947](https://github.com/Kong/gateway-operator/pull/947)

## [v1.4.1]

> Release date: 2024-11-28
Expand Down
11 changes: 6 additions & 5 deletions api/v1alpha1/konnect_extension_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ const (
// +kubebuilder:subresource:status

// KonnectExtension is the Schema for the KonnectExtension API,
// and is intended to be referenced as extension by the dataplane API.
// and is intended to be referenced as extension by the DataPlane API.
// If a DataPlane successfully refers a KonnectExtension, the DataPlane
// deployment spec gets customized to include the konnect-related configuration.
// +kubebuilder:validation:XValidation:rule="oldSelf.spec.controlPlaneRef == self.spec.controlPlaneRef", message="spec.controlPlaneRef is immutable."
Expand Down Expand Up @@ -74,15 +74,16 @@ type KonnectExtensionSpec struct {
// +kubebuilder:validation:Required
ControlPlaneRegion string `json:"controlPlaneRegion"`

// ServerHostname is the fully qualified domain name of the konnect server. This
// matches the RFC 1123 definition of a hostname with 1 notable exception that
// numeric IP addresses are not allowed.
// ServerHostname is the fully qualified domain name of the Konnect server.
// For typical operation a default value doesn't need to be adjusted.
// It matches the RFC 1123 definition of a hostname with 1 notable exception
// that numeric IP addresses are not allowed.
//
// Note that as per RFC1035 and RFC1123, a *label* must consist of lower case
// alphanumeric characters or '-', and must start and end with an alphanumeric
// character. No other punctuation is allowed.
//
// +kubebuilder:example:=foo.example.com
// +kubebuilder:default:=konghq.com
// +kubebuilder:validation:MinLength=1
// +kubebuilder:validation:MaxLength=253
// +kubebuilder:validation:Pattern=`^[a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$`
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ spec:
openAPIV3Schema:
description: |-
KonnectExtension is the Schema for the KonnectExtension API,
and is intended to be referenced as extension by the dataplane API.
and is intended to be referenced as extension by the DataPlane API.
If a DataPlane successfully refers a KonnectExtension, the DataPlane
deployment spec gets customized to include the konnect-related configuration.
properties:
Expand Down Expand Up @@ -145,15 +145,16 @@ spec:
- clusterCertificateSecretRef
type: object
serverHostname:
default: konghq.com
description: |-
ServerHostname is the fully qualified domain name of the konnect server. This
matches the RFC 1123 definition of a hostname with 1 notable exception that
numeric IP addresses are not allowed.
ServerHostname is the fully qualified domain name of the Konnect server.
For typical operation a default value doesn't need to be adjusted.
It matches the RFC 1123 definition of a hostname with 1 notable exception
that numeric IP addresses are not allowed.

Note that as per RFC1035 and RFC1123, a *label* must consist of lower case
alphanumeric characters or '-', and must start and end with an alphanumeric
character. No other punctuation is allowed.
example: foo.example.com
maxLength: 253
minLength: 1
pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$
Expand Down
1 change: 0 additions & 1 deletion config/samples/dataplane-konnect-extension.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@ spec:
controlPlaneRef:
type: konnectID
konnectID: <YOUR-CP-KONNECT-ID>
serverHostname: your.konnect.server
controlPlaneRegion: eu
konnectControlPlaneAPIAuthConfiguration:
clusterCertificateSecretRef:
Expand Down
22 changes: 11 additions & 11 deletions controller/dataplane/konnectextension_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,14 +30,14 @@ func TestApplyKonnectExtension(t *testing.T) {

tests := []struct {
name string
dataplane *operatorv1beta1.DataPlane
dataPlane *operatorv1beta1.DataPlane
konnectExt *operatorv1alpha1.KonnectExtension
secret *corev1.Secret
expectedError error
}{
{
name: "no extensions",
dataplane: &operatorv1beta1.DataPlane{
dataPlane: &operatorv1beta1.DataPlane{
Spec: operatorv1beta1.DataPlaneSpec{
DataPlaneOptions: operatorv1beta1.DataPlaneOptions{
Extensions: []operatorv1alpha1.ExtensionRef{},
Expand All @@ -47,7 +47,7 @@ func TestApplyKonnectExtension(t *testing.T) {
},
{
name: "cross-namespace reference",
dataplane: &operatorv1beta1.DataPlane{
dataPlane: &operatorv1beta1.DataPlane{
ObjectMeta: metav1.ObjectMeta{
Namespace: "default",
},
Expand Down Expand Up @@ -93,7 +93,7 @@ func TestApplyKonnectExtension(t *testing.T) {
},
{
name: "Extension not found",
dataplane: &operatorv1beta1.DataPlane{
dataPlane: &operatorv1beta1.DataPlane{
ObjectMeta: metav1.ObjectMeta{
Namespace: "default",
},
Expand All @@ -120,7 +120,7 @@ func TestApplyKonnectExtension(t *testing.T) {
},
{
name: "Extension properly referenced, secret not found",
dataplane: &operatorv1beta1.DataPlane{
dataPlane: &operatorv1beta1.DataPlane{
ObjectMeta: metav1.ObjectMeta{
Namespace: "default",
},
Expand Down Expand Up @@ -165,7 +165,7 @@ func TestApplyKonnectExtension(t *testing.T) {
},
{
name: "Extension properly referenced, no deployment Options set.",
dataplane: &operatorv1beta1.DataPlane{
dataPlane: &operatorv1beta1.DataPlane{
ObjectMeta: metav1.ObjectMeta{
Namespace: "default",
},
Expand Down Expand Up @@ -215,7 +215,7 @@ func TestApplyKonnectExtension(t *testing.T) {
},
{
name: "Extension properly referenced, with deployment Options set.",
dataplane: &operatorv1beta1.DataPlane{
dataPlane: &operatorv1beta1.DataPlane{
ObjectMeta: metav1.ObjectMeta{
Namespace: "default",
},
Expand Down Expand Up @@ -281,7 +281,7 @@ func TestApplyKonnectExtension(t *testing.T) {

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
objs := []runtime.Object{tt.dataplane}
objs := []runtime.Object{tt.dataPlane}
if tt.konnectExt != nil {
objs = append(objs, tt.konnectExt)
}
Expand All @@ -290,15 +290,15 @@ func TestApplyKonnectExtension(t *testing.T) {
}
cl := fake.NewClientBuilder().WithScheme(s).WithRuntimeObjects(objs...).Build()

dataplane := tt.dataplane.DeepCopy()
dataplane := tt.dataPlane.DeepCopy()
err := applyKonnectExtension(context.Background(), cl, dataplane)
if tt.expectedError != nil {
require.ErrorIs(t, err, tt.expectedError)
} else {
require.NoError(t, err)
requiredEnv := []corev1.EnvVar{}
if tt.dataplane.Spec.Deployment.PodTemplateSpec != nil {
if container := k8sutils.GetPodContainerByName(&tt.dataplane.Spec.Deployment.PodTemplateSpec.Spec, consts.DataPlaneProxyContainerName); container != nil {
if tt.dataPlane.Spec.Deployment.PodTemplateSpec != nil {
if container := k8sutils.GetPodContainerByName(&tt.dataPlane.Spec.Deployment.PodTemplateSpec.Spec, consts.DataPlaneProxyContainerName); container != nil {
requiredEnv = container.Env
}
}
Expand Down
2 changes: 1 addition & 1 deletion debug.Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
# Debug image
# ------------------------------------------------------------------------------

FROM --platform=$BUILDPLATFORM golang:1.23.4 as debug
FROM --platform=$BUILDPLATFORM golang:1.23.4 AS debug

ARG GOPATH
ARG GOCACHE
Expand Down
4 changes: 2 additions & 2 deletions docs/api-reference.md
Original file line number Diff line number Diff line change
Expand Up @@ -1824,7 +1824,7 @@ and configured with KongPlugin CRD.


KonnectExtension is the Schema for the KonnectExtension API,
and is intended to be referenced as extension by the dataplane API.
and is intended to be referenced as extension by the DataPlane API.
If a DataPlane successfully refers a KonnectExtension, the DataPlane
deployment spec gets customized to include the konnect-related configuration.

Expand Down Expand Up @@ -2107,7 +2107,7 @@ KonnectExtensionSpec defines the desired state of KonnectExtension.
| --- | --- |
| `controlPlaneRef` _[ControlPlaneRef](#controlplaneref)_ | ControlPlaneRef is a reference to a ControlPlane this KonnectExtension is associated with. |
| `controlPlaneRegion` _string_ | ControlPlaneRegion is the region of the Konnect Control Plane. |
| `serverHostname` _string_ | ServerHostname is the fully qualified domain name of the konnect server. This matches the RFC 1123 definition of a hostname with 1 notable exception that numeric IP addresses are not allowed.<br /><br /> Note that as per RFC1035 and RFC1123, a *label* must consist of lower case alphanumeric characters or '-', and must start and end with an alphanumeric character. No other punctuation is allowed. |
| `serverHostname` _string_ | ServerHostname is the fully qualified domain name of the Konnect server. For typical operation a default value doesn't need to be adjusted. It matches the RFC 1123 definition of a hostname with 1 notable exception that numeric IP addresses are not allowed.<br /><br /> Note that as per RFC1035 and RFC1123, a *label* must consist of lower case alphanumeric characters or '-', and must start and end with an alphanumeric character. No other punctuation is allowed. |
| `konnectControlPlaneAPIAuthConfiguration` _[KonnectControlPlaneAPIAuthConfiguration](#konnectcontrolplaneapiauthconfiguration)_ | AuthConfiguration must be used to configure the Konnect API authentication. |
| `clusterDataPlaneLabels` _object (keys:string, values:string)_ | ClusterDataPlaneLabels is a set of labels that will be applied to the Konnect DataPlane. |

Expand Down
2 changes: 1 addition & 1 deletion internal/utils/dataplane/env.go
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ type KongInKonnectParams struct {
Server string
}

// KongInKonnectDefaults returnes the map of Konnect-related env vars properly configured.
// KongInKonnectDefaults returns the map of Konnect-related env vars properly configured.
func KongInKonnectDefaults(params KongInKonnectParams) map[string]string {
newEnvSet := make(map[string]string, len(kongInKonnectDefaultsTemplate))
for k, v := range kongInKonnectDefaultsTemplate {
Expand Down
Loading