Skip to content

Commit

Permalink
Add support for overrides for generated pods
Browse files Browse the repository at this point in the history
This change adds a new field Overrides to both Ironic and
IronicDatabase. This field allows advanced operators and downstream
consumers to inject containers, annotations, labels and environment
variables into the generated deployments/daemon sets.

A new feature gate Overrides is added to protect this feature.

Signed-off-by: Dmitry Tantsur <[email protected]>
  • Loading branch information
dtantsur committed Dec 2, 2024
1 parent 1eb3d68 commit 8cd24ee
Show file tree
Hide file tree
Showing 15 changed files with 6,510 additions and 9 deletions.
43 changes: 43 additions & 0 deletions api/v1alpha1/common.go
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
package v1alpha1

import (
corev1 "k8s.io/api/core/v1"
)

type IronicStatusConditionType string

const (
Expand All @@ -12,3 +16,42 @@ const (

IronicOperatorLabel = "metal3.io/ironic-standalone-operator"
)

type Overrides struct {
// Extra annotations to add to each container.
// +optional
Annotations map[string]string `json:"annotations,omitempty"`

// Extra containers to add to the deployment or daemon set.
// +optional
// +patchMergeKey=name
// +patchStrategy=merge
// +listType=map
// +listMapKey=name
Containers []corev1.Container `json:"containers,omitempty"`

// Extra environment variables to add to each container.
// +optional
// +patchMergeKey=name
// +patchStrategy=merge
// +listType=map
// +listMapKey=name
Env []corev1.EnvVar `json:"env,omitempty"`

// Extra environment variables (with sources) to add to each container.
// +optional
// +listType=atomic
EnvFrom []corev1.EnvFromSource `json:"envFrom,omitempty"`

// Extra init containers to add to the deployment or daemon set.
// +optional
// +patchMergeKey=name
// +patchStrategy=merge
// +listType=map
// +listMapKey=name
InitContainers []corev1.Container `json:"initContainers,omitempty"`

// Extra labels to add to each container.
// +optional
Labels map[string]string `json:"labels,omitempty"`
}
2 changes: 2 additions & 0 deletions api/v1alpha1/features.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,13 @@ import (

const (
FeatureHighAvailability featuregate.Feature = "HighAvailability"
FeatureOverrides featuregate.Feature = "Overrides"
)

var (
availableFeatures = map[featuregate.Feature]featuregate.FeatureSpec{
FeatureHighAvailability: {Default: false, PreRelease: featuregate.Alpha},
FeatureOverrides: {Default: false, PreRelease: featuregate.Beta},
}

CurrentFeatureGate = featuregate.NewFeatureGate()
Expand Down
5 changes: 5 additions & 0 deletions api/v1alpha1/ironic_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -202,6 +202,11 @@ type IronicSpec struct {
// +optional
NodeSelector map[string]string `json:"nodeSelector,omitempty"`

// Overrides for the generated Deployment or Daemon Set.
// EXPERIMENTAL: requires feature gate Overrides.
// +optional
Overrides *Overrides `json:"overrides,omitempty"`

// TLSRef is a reference to the secret with the database TLS certificate.
// +optional
TLSRef corev1.LocalObjectReference `json:"tlsRef,omitempty"`
Expand Down
4 changes: 4 additions & 0 deletions api/v1alpha1/ironic_webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -218,5 +218,9 @@ func ValidateIronic(ironic *IronicSpec, old *IronicSpec) error {
return errors.New("highly available architecture is disabled via feature gate")
}

if ironic.Overrides != nil && !CurrentFeatureGate.Enabled(FeatureOverrides) {
return errors.New("overrides are disabled via feature gate")
}

return nil
}
5 changes: 5 additions & 0 deletions api/v1alpha1/ironicdatabase_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,11 @@ type IronicDatabaseSpec struct {
// +optional
Image string `json:"image,omitempty"`

// Overrides for the generated Deployment or Daemon Set.
// EXPERIMENTAL: requires feature gate Overrides.
// +optional
Overrides *Overrides `json:"overrides,omitempty"`

// TLSSecretName is a reference to the secret with the database TLS certificate.
// +optional
TLSRef corev1.LocalObjectReference `json:"tlsRef,omitempty"`
Expand Down
6 changes: 6 additions & 0 deletions api/v1alpha1/ironicdatabase_webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ limitations under the License.
package v1alpha1

import (
"errors"

"k8s.io/apimachinery/pkg/runtime"
ctrl "sigs.k8s.io/controller-runtime"
logf "sigs.k8s.io/controller-runtime/pkg/log"
Expand Down Expand Up @@ -62,5 +64,9 @@ func (r *IronicDatabase) ValidateDelete() (warnings admission.Warnings, err erro
}

func validateDatabase(db *IronicDatabaseSpec, old *IronicDatabaseSpec) error {
if db.Overrides != nil && !CurrentFeatureGate.Enabled(FeatureOverrides) {
return errors.New("overrides are disabled via feature gate")
}

return nil
}
76 changes: 72 additions & 4 deletions api/v1alpha1/zz_generated.deepcopy.go

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

Loading

0 comments on commit 8cd24ee

Please sign in to comment.