Skip to content

Commit

Permalink
fix: cleanup runtime default properties on first reconcile, fixes RHO…
Browse files Browse the repository at this point in the history
…AIENG-15033

Signed-off-by: Dhiraj Bokde <[email protected]>
  • Loading branch information
dhirajsb committed Nov 7, 2024
1 parent 74dec25 commit 8fcfb7e
Showing 1 changed file with 90 additions and 1 deletion.
91 changes: 90 additions & 1 deletion api/v1alpha1/modelregistry_webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,14 @@ import (
"k8s.io/apimachinery/pkg/api/errors"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/util/validation/field"
"maps"
ctrl "sigs.k8s.io/controller-runtime"
"sigs.k8s.io/controller-runtime/pkg/client"
logf "sigs.k8s.io/controller-runtime/pkg/log"
"sigs.k8s.io/controller-runtime/pkg/webhook"
"sigs.k8s.io/controller-runtime/pkg/webhook/admission"
"slices"
"strings"
)

// log is for logging in this package.
Expand All @@ -41,6 +44,9 @@ const (
DefaultTlsMode = IstioMutualTlsMode
IstioMutualTlsMode = "ISTIO_MUTUAL"
DefaultIstioGateway = "ingressgateway"

tagSeparator = ":"
emptyValue = ""
)

func (r *ModelRegistry) SetupWebhookWithManager(mgr ctrl.Manager) error {
Expand All @@ -63,7 +69,7 @@ var (

// Default implements webhook.Defaulter so a webhook will be registered for the type
func (r *ModelRegistry) Default() {
modelregistrylog.Info("default", "name", r.Name)
modelregistrylog.Info("default", "name", r.Name, "status.specDefaults", r.Status.SpecDefaults)

// handle annotation mutations
r.HandleAnnotations()
Expand Down Expand Up @@ -117,6 +123,89 @@ func (r *ModelRegistry) Default() {
}
}
}

// handle runtime default properties for https://issues.redhat.com/browse/RHOAIENG-15033
r.cleanupRuntimeDefaults()
}

// cleanupRuntimeDefaults removes runtime defaults on first reconcile, when specDefaults is empty,
// also including model registries reconciled by older operator versions before adding specDefaults support.
// It removes images if they are the same as the operator defaults (ignoring version tag),
// and it removes default runtime values that match default runtime properties set in the operator
// since they are redundant as custom property values.
func (r *ModelRegistry) cleanupRuntimeDefaults() {
if len(r.Status.SpecDefaults) != 0 {
// nothing to do as model registries with specDefaults set
// will only have custom properties set by users
return
}

// check grpc image against operator default grpc image repo
if len(r.Spec.Grpc.Image) != 0 {
defaultGrpcImage := config.GetStringConfigWithDefault(config.GrpcImage, config.DefaultGrpcImage)
defaultGrpcImageRepo := strings.Split(defaultGrpcImage, tagSeparator)[0]

grpcImageRepo := strings.Split(r.Spec.Grpc.Image, tagSeparator)[0]
if grpcImageRepo == defaultGrpcImageRepo {
modelregistrylog.V(4).Info("reset image", "grpc repo", grpcImageRepo)
// remove image altogether as the MR repo matches operator repo,
// so that future operator version upgrades don't have to handle a hardcoded default
r.Spec.Grpc.Image = emptyValue

// also reset resource requirements
r.Spec.Grpc.Resources = nil
}
}

// check rest image against operator default rest image repo
if len(r.Spec.Rest.Image) != 0 {
defaultRestImage := config.GetStringConfigWithDefault(config.RestImage, config.DefaultRestImage)
defaultRestImageRepo := strings.Split(defaultRestImage, tagSeparator)[0]

restImageRepo := strings.Split(r.Spec.Rest.Image, tagSeparator)[0]
if restImageRepo == defaultRestImageRepo {
modelregistrylog.V(4).Info("reset image", "rest repo", restImageRepo)
// remove image altogether as the MR repo matches operator repo,
// so that future operator version upgrades don't have to handle a hardcoded default
r.Spec.Rest.Image = emptyValue

// also reset resource requirements
r.Spec.Rest.Resources = nil
}
}

// reset istio defaults
if r.Spec.Istio != nil {
// reset default audiences
if len(r.Spec.Istio.Audiences) != 0 && slices.Equal(r.Spec.Istio.Audiences, config.GetDefaultAudiences()) {
r.Spec.Istio.Audiences = make([]string, 0)
}
// reset default authprovider
if r.Spec.Istio.AuthProvider == config.GetDefaultAuthProvider() {
r.Spec.Istio.AuthProvider = emptyValue
}
// reset default authconfig labels
if len(r.Spec.Istio.AuthConfigLabels) != 0 && maps.Equal(r.Spec.Istio.AuthConfigLabels, config.GetDefaultAuthConfigLabels()) {
r.Spec.Istio.AuthConfigLabels = make(map[string]string)
}

if r.Spec.Istio.Gateway != nil {
// reset default domain
if r.Spec.Istio.Gateway.Domain == config.GetDefaultDomain() {
r.Spec.Istio.Gateway.Domain = emptyValue
}

// reset default cert
if r.Spec.Istio.Gateway.Rest.TLS != nil && r.Spec.Istio.Gateway.Rest.TLS.Mode != DefaultTlsMode &&
(r.Spec.Istio.Gateway.Rest.TLS.CredentialName != nil && *r.Spec.Istio.Gateway.Rest.TLS.CredentialName == config.GetDefaultCert()) {
r.Spec.Istio.Gateway.Rest.TLS.CredentialName = nil
}
if r.Spec.Istio.Gateway.Grpc.TLS != nil && r.Spec.Istio.Gateway.Grpc.TLS.Mode != DefaultTlsMode &&
(r.Spec.Istio.Gateway.Grpc.TLS.CredentialName != nil && *r.Spec.Istio.Gateway.Grpc.TLS.CredentialName == config.GetDefaultCert()) {
r.Spec.Istio.Gateway.Grpc.TLS.CredentialName = nil
}
}
}
}

// RuntimeDefaults sets default values from the operator environment, which could change at runtime
Expand Down

0 comments on commit 8fcfb7e

Please sign in to comment.