From 77fad77a9efe33c279cd9ca9f1e39a33f0cea2ab Mon Sep 17 00:00:00 2001 From: Ramon de Klein Date: Tue, 15 Oct 2024 20:42:22 +0200 Subject: [PATCH] never propagate labels/annotations --- docs/tenant_crd.adoc | 74 ++++++++++------- .../templates/minio.min.io_tenants.yaml | 30 ++++--- pkg/apis/minio.min.io/v2/helper.go | 14 ---- pkg/apis/minio.min.io/v2/types.go | 22 +++-- .../minio.min.io/v2/zz_generated.deepcopy.go | 80 +++++++++++-------- ...tatefulsetmetadata.go => poolsmetadata.go} | 14 ++-- .../minio.min.io/v2/servicemetadata.go | 30 +++++++ .../minio.min.io/v2/tenantspec.go | 10 +-- pkg/client/applyconfiguration/utils.go | 4 +- pkg/resources/services/service.go | 47 ++++------- .../statefulsets/minio-statefulset.go | 67 ++++------------ pkg/utils/utils.go | 11 +++ resources/base/crds/minio.min.io_tenants.yaml | 30 ++++--- 13 files changed, 229 insertions(+), 204 deletions(-) rename pkg/client/applyconfiguration/minio.min.io/v2/{statefulsetmetadata.go => poolsmetadata.go} (75%) diff --git a/docs/tenant_crd.adoc b/docs/tenant_crd.adoc index ed5d37f680a..e01e63ed310 100644 --- a/docs/tenant_crd.adoc +++ b/docs/tenant_crd.adoc @@ -689,6 +689,35 @@ Security Context |=== +[id="{anchor_prefix}-github-com-minio-operator-pkg-apis-minio-min-io-v2-poolsmetadata"] +==== PoolsMetadata + +PoolsMetadata (`poolsMetadata`) defines custom labels and annotations for the MinIO pool stateful sets / pods. + + +.Appears In: +**** +- xref:{anchor_prefix}-github-com-minio-operator-pkg-apis-minio-min-io-v2-tenantspec[$$TenantSpec$$] +**** + +[cols="25a,75a", options="header"] +|=== +| Field | Description + +|*`labels`* __object (keys:string, values:string)__ +|*Optional* + + + +If provided, append these labels to the MinIO statefulset / pods + +|*`annotations`* __object (keys:string, values:string)__ +|*Optional* + + + +If provided, append these annotations to the MinIO statefulset / pods + +|=== + + [id="{anchor_prefix}-github-com-minio-operator-pkg-apis-minio-min-io-v2-servicemetadata"] ==== ServiceMetadata @@ -727,6 +756,18 @@ If provided, append these labels to the Console service If provided, append these annotations to the Console service +|*`kesServiceLabels`* __object (keys:string, values:string)__ +|*Optional* + + + +If provided, append these labels to the KES service + +|*`kesServiceAnnotations`* __object (keys:string, values:string)__ +|*Optional* + + + +If provided, append these annotations to the KES service + |=== @@ -777,35 +818,6 @@ sidecar's Resource, initcontainer will use that if set. |=== -[id="{anchor_prefix}-github-com-minio-operator-pkg-apis-minio-min-io-v2-statefulsetmetadata"] -==== StatefulSetMetadata - -StatefulSetMetadata (`statefulSetMetadata`) defines custom labels and annotations for the MinIO stateful sets. + - -.Appears In: -**** -- xref:{anchor_prefix}-github-com-minio-operator-pkg-apis-minio-min-io-v2-tenantspec[$$TenantSpec$$] -**** - -[cols="25a,75a", options="header"] -|=== -| Field | Description - -|*`labels`* __object (keys:string, values:string)__ -|*Optional* + - - -If provided, append these labels to the MinIO statefulset - -|*`annotations`* __object (keys:string, values:string)__ -|*Optional* + - - -If provided, append these annotations to the MinIO statefulset - -|=== - - [id="{anchor_prefix}-github-com-minio-operator-pkg-apis-minio-min-io-v2-tenant"] ==== Tenant @@ -1183,11 +1195,11 @@ Directs the Operator to expose the MinIO and/or Console services. + Specify custom labels and annotations to append to the MinIO service and/or Console service. -|*`statefulSetMetadata`* __xref:{anchor_prefix}-github-com-minio-operator-pkg-apis-minio-min-io-v2-statefulsetmetadata[$$StatefulSetMetadata$$]__ +|*`poolsMetadata`* __xref:{anchor_prefix}-github-com-minio-operator-pkg-apis-minio-min-io-v2-poolsmetadata[$$PoolsMetadata$$]__ |*Optional* + -Specify custom labels and annotations to append to the MinIO statefulsets. +Specify custom labels and annotations to append to all pool statefulsets and pods. |*`users`* __link:https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.23/#localobjectreference-v1-core[$$LocalObjectReference$$] array__ |*Optional* + diff --git a/helm/operator/templates/minio.min.io_tenants.yaml b/helm/operator/templates/minio.min.io_tenants.yaml index 46e8f6f8cb2..e295126ce51 100644 --- a/helm/operator/templates/minio.min.io_tenants.yaml +++ b/helm/operator/templates/minio.min.io_tenants.yaml @@ -3638,6 +3638,17 @@ spec: x-kubernetes-list-map-keys: - name x-kubernetes-list-type: map + poolsMetadata: + properties: + annotations: + additionalProperties: + type: string + type: object + labels: + additionalProperties: + type: string + type: object + type: object priorityClassName: type: string prometheusOperator: @@ -3736,6 +3747,14 @@ spec: additionalProperties: type: string type: object + kesServiceAnnotations: + additionalProperties: + type: string + type: object + kesServiceLabels: + additionalProperties: + type: string + type: object minioServiceAnnotations: additionalProperties: type: string @@ -5500,17 +5519,6 @@ spec: format: int32 type: integer type: object - statefulSetMetadata: - properties: - annotations: - additionalProperties: - type: string - type: object - labels: - additionalProperties: - type: string - type: object - type: object subPath: type: string users: diff --git a/pkg/apis/minio.min.io/v2/helper.go b/pkg/apis/minio.min.io/v2/helper.go index 22927919d58..c86a66552ac 100644 --- a/pkg/apis/minio.min.io/v2/helper.go +++ b/pkg/apis/minio.min.io/v2/helper.go @@ -878,20 +878,6 @@ func GetClusterDomain() string { return k8sClusterDomain } -// MergeMaps merges two maps and returns the union -func MergeMaps(a, b map[string]string) map[string]string { - if a == nil { - a = map[string]string{} - } - if b == nil { - b = map[string]string{} - } - for k, v := range b { - a[k] = v - } - return a -} - // ToMap converts a slice of env vars to a map of Name and value func ToMap(envs []corev1.EnvVar) map[string]string { newMap := make(map[string]string) diff --git a/pkg/apis/minio.min.io/v2/types.go b/pkg/apis/minio.min.io/v2/types.go index ce0003518c8..4644f72a58a 100644 --- a/pkg/apis/minio.min.io/v2/types.go +++ b/pkg/apis/minio.min.io/v2/types.go @@ -318,9 +318,9 @@ type TenantSpec struct { ServiceMetadata *ServiceMetadata `json:"serviceMetadata,omitempty"` // *Optional* + // - // Specify custom labels and annotations to append to the MinIO statefulsets. + // Specify custom labels and annotations to append to all pool statefulsets and pods. // +optional - StatefulSetMetadata *StatefulSetMetadata `json:"statefulSetMetadata,omitempty"` + PoolsMetadata *PoolsMetadata `json:"poolsMetadata,omitempty"` // *Optional* + // // An array of https://kubernetes.io/docs/concepts/configuration/secret/[Kubernetes opaque secrets] to use for generating MinIO users during tenant provisioning. + @@ -400,18 +400,28 @@ type ServiceMetadata struct { // If provided, append these annotations to the Console service // +optional ConsoleServiceAnnotations map[string]string `json:"consoleServiceAnnotations,omitempty"` + // *Optional* + + // + // If provided, append these labels to the KES service + // +optional + KESServiceLabels map[string]string `json:"kesServiceLabels,omitempty"` + // *Optional* + + // + // If provided, append these annotations to the KES service + // +optional + KESServiceAnnotations map[string]string `json:"kesServiceAnnotations,omitempty"` } -// StatefulSetMetadata (`statefulSetMetadata`) defines custom labels and annotations for the MinIO stateful sets. + -type StatefulSetMetadata struct { +// PoolsMetadata (`poolsMetadata`) defines custom labels and annotations for the MinIO pool stateful sets / pods. + +type PoolsMetadata struct { // *Optional* + // - // If provided, append these labels to the MinIO statefulset + // If provided, append these labels to the MinIO statefulset / pods // +optional Labels map[string]string `json:"labels,omitempty"` // *Optional* + // - // If provided, append these annotations to the MinIO statefulset + // If provided, append these annotations to the MinIO statefulset / pods // +optional Annotations map[string]string `json:"annotations,omitempty"` } diff --git a/pkg/apis/minio.min.io/v2/zz_generated.deepcopy.go b/pkg/apis/minio.min.io/v2/zz_generated.deepcopy.go index 2200c1e8aef..cec7292ab06 100644 --- a/pkg/apis/minio.min.io/v2/zz_generated.deepcopy.go +++ b/pkg/apis/minio.min.io/v2/zz_generated.deepcopy.go @@ -441,6 +441,36 @@ func (in *PoolStatus) DeepCopy() *PoolStatus { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *PoolsMetadata) DeepCopyInto(out *PoolsMetadata) { + *out = *in + if in.Labels != nil { + in, out := &in.Labels, &out.Labels + *out = make(map[string]string, len(*in)) + for key, val := range *in { + (*out)[key] = val + } + } + if in.Annotations != nil { + in, out := &in.Annotations, &out.Annotations + *out = make(map[string]string, len(*in)) + for key, val := range *in { + (*out)[key] = val + } + } + return +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new PoolsMetadata. +func (in *PoolsMetadata) DeepCopy() *PoolsMetadata { + if in == nil { + return nil + } + out := new(PoolsMetadata) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *ServiceMetadata) DeepCopyInto(out *ServiceMetadata) { *out = *in @@ -472,6 +502,20 @@ func (in *ServiceMetadata) DeepCopyInto(out *ServiceMetadata) { (*out)[key] = val } } + if in.KESServiceLabels != nil { + in, out := &in.KESServiceLabels, &out.KESServiceLabels + *out = make(map[string]string, len(*in)) + for key, val := range *in { + (*out)[key] = val + } + } + if in.KESServiceAnnotations != nil { + in, out := &in.KESServiceAnnotations, &out.KESServiceAnnotations + *out = make(map[string]string, len(*in)) + for key, val := range *in { + (*out)[key] = val + } + } return } @@ -527,36 +571,6 @@ func (in *SideCars) DeepCopy() *SideCars { return out } -// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. -func (in *StatefulSetMetadata) DeepCopyInto(out *StatefulSetMetadata) { - *out = *in - if in.Labels != nil { - in, out := &in.Labels, &out.Labels - *out = make(map[string]string, len(*in)) - for key, val := range *in { - (*out)[key] = val - } - } - if in.Annotations != nil { - in, out := &in.Annotations, &out.Annotations - *out = make(map[string]string, len(*in)) - for key, val := range *in { - (*out)[key] = val - } - } - return -} - -// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new StatefulSetMetadata. -func (in *StatefulSetMetadata) DeepCopy() *StatefulSetMetadata { - if in == nil { - return nil - } - out := new(StatefulSetMetadata) - in.DeepCopyInto(out) - return out -} - // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *Tenant) DeepCopyInto(out *Tenant) { *out = *in @@ -772,9 +786,9 @@ func (in *TenantSpec) DeepCopyInto(out *TenantSpec) { *out = new(ServiceMetadata) (*in).DeepCopyInto(*out) } - if in.StatefulSetMetadata != nil { - in, out := &in.StatefulSetMetadata, &out.StatefulSetMetadata - *out = new(StatefulSetMetadata) + if in.PoolsMetadata != nil { + in, out := &in.PoolsMetadata, &out.PoolsMetadata + *out = new(PoolsMetadata) (*in).DeepCopyInto(*out) } if in.Users != nil { diff --git a/pkg/client/applyconfiguration/minio.min.io/v2/statefulsetmetadata.go b/pkg/client/applyconfiguration/minio.min.io/v2/poolsmetadata.go similarity index 75% rename from pkg/client/applyconfiguration/minio.min.io/v2/statefulsetmetadata.go rename to pkg/client/applyconfiguration/minio.min.io/v2/poolsmetadata.go index ab7ecca5fef..613013e8ce5 100644 --- a/pkg/client/applyconfiguration/minio.min.io/v2/statefulsetmetadata.go +++ b/pkg/client/applyconfiguration/minio.min.io/v2/poolsmetadata.go @@ -18,24 +18,24 @@ package v2 -// StatefulSetMetadataApplyConfiguration represents an declarative configuration of the StatefulSetMetadata type for use +// PoolsMetadataApplyConfiguration represents an declarative configuration of the PoolsMetadata type for use // with apply. -type StatefulSetMetadataApplyConfiguration struct { +type PoolsMetadataApplyConfiguration struct { Labels map[string]string `json:"labels,omitempty"` Annotations map[string]string `json:"annotations,omitempty"` } -// StatefulSetMetadataApplyConfiguration constructs an declarative configuration of the StatefulSetMetadata type for use with +// PoolsMetadataApplyConfiguration constructs an declarative configuration of the PoolsMetadata type for use with // apply. -func StatefulSetMetadata() *StatefulSetMetadataApplyConfiguration { - return &StatefulSetMetadataApplyConfiguration{} +func PoolsMetadata() *PoolsMetadataApplyConfiguration { + return &PoolsMetadataApplyConfiguration{} } // WithLabels puts the entries into the Labels field in the declarative configuration // and returns the receiver, so that objects can be build by chaining "With" function invocations. // If called multiple times, the entries provided by each call will be put on the Labels field, // overwriting an existing map entries in Labels field with the same key. -func (b *StatefulSetMetadataApplyConfiguration) WithLabels(entries map[string]string) *StatefulSetMetadataApplyConfiguration { +func (b *PoolsMetadataApplyConfiguration) WithLabels(entries map[string]string) *PoolsMetadataApplyConfiguration { if b.Labels == nil && len(entries) > 0 { b.Labels = make(map[string]string, len(entries)) } @@ -49,7 +49,7 @@ func (b *StatefulSetMetadataApplyConfiguration) WithLabels(entries map[string]st // and returns the receiver, so that objects can be build by chaining "With" function invocations. // If called multiple times, the entries provided by each call will be put on the Annotations field, // overwriting an existing map entries in Annotations field with the same key. -func (b *StatefulSetMetadataApplyConfiguration) WithAnnotations(entries map[string]string) *StatefulSetMetadataApplyConfiguration { +func (b *PoolsMetadataApplyConfiguration) WithAnnotations(entries map[string]string) *PoolsMetadataApplyConfiguration { if b.Annotations == nil && len(entries) > 0 { b.Annotations = make(map[string]string, len(entries)) } diff --git a/pkg/client/applyconfiguration/minio.min.io/v2/servicemetadata.go b/pkg/client/applyconfiguration/minio.min.io/v2/servicemetadata.go index c1a30275ee4..4e766e0d4e2 100644 --- a/pkg/client/applyconfiguration/minio.min.io/v2/servicemetadata.go +++ b/pkg/client/applyconfiguration/minio.min.io/v2/servicemetadata.go @@ -25,6 +25,8 @@ type ServiceMetadataApplyConfiguration struct { MinIOServiceAnnotations map[string]string `json:"minioServiceAnnotations,omitempty"` ConsoleServiceLabels map[string]string `json:"consoleServiceLabels,omitempty"` ConsoleServiceAnnotations map[string]string `json:"consoleServiceAnnotations,omitempty"` + KESServiceLabels map[string]string `json:"kesServiceLabels,omitempty"` + KESServiceAnnotations map[string]string `json:"kesServiceAnnotations,omitempty"` } // ServiceMetadataApplyConfiguration constructs an declarative configuration of the ServiceMetadata type for use with @@ -88,3 +90,31 @@ func (b *ServiceMetadataApplyConfiguration) WithConsoleServiceAnnotations(entrie } return b } + +// WithKESServiceLabels puts the entries into the KESServiceLabels field in the declarative configuration +// and returns the receiver, so that objects can be build by chaining "With" function invocations. +// If called multiple times, the entries provided by each call will be put on the KESServiceLabels field, +// overwriting an existing map entries in KESServiceLabels field with the same key. +func (b *ServiceMetadataApplyConfiguration) WithKESServiceLabels(entries map[string]string) *ServiceMetadataApplyConfiguration { + if b.KESServiceLabels == nil && len(entries) > 0 { + b.KESServiceLabels = make(map[string]string, len(entries)) + } + for k, v := range entries { + b.KESServiceLabels[k] = v + } + return b +} + +// WithKESServiceAnnotations puts the entries into the KESServiceAnnotations field in the declarative configuration +// and returns the receiver, so that objects can be build by chaining "With" function invocations. +// If called multiple times, the entries provided by each call will be put on the KESServiceAnnotations field, +// overwriting an existing map entries in KESServiceAnnotations field with the same key. +func (b *ServiceMetadataApplyConfiguration) WithKESServiceAnnotations(entries map[string]string) *ServiceMetadataApplyConfiguration { + if b.KESServiceAnnotations == nil && len(entries) > 0 { + b.KESServiceAnnotations = make(map[string]string, len(entries)) + } + for k, v := range entries { + b.KESServiceAnnotations[k] = v + } + return b +} diff --git a/pkg/client/applyconfiguration/minio.min.io/v2/tenantspec.go b/pkg/client/applyconfiguration/minio.min.io/v2/tenantspec.go index b03415b2c73..eab5c3b353d 100644 --- a/pkg/client/applyconfiguration/minio.min.io/v2/tenantspec.go +++ b/pkg/client/applyconfiguration/minio.min.io/v2/tenantspec.go @@ -54,7 +54,7 @@ type TenantSpecApplyConfiguration struct { SideCars *SideCarsApplyConfiguration `json:"sideCars,omitempty"` ExposeServices *ExposeServicesApplyConfiguration `json:"exposeServices,omitempty"` ServiceMetadata *ServiceMetadataApplyConfiguration `json:"serviceMetadata,omitempty"` - StatefulSetMetadata *StatefulSetMetadataApplyConfiguration `json:"statefulSetMetadata,omitempty"` + PoolsMetadata *PoolsMetadataApplyConfiguration `json:"poolsMetadata,omitempty"` Users []v1.LocalObjectReference `json:"users,omitempty"` Buckets []BucketApplyConfiguration `json:"buckets,omitempty"` Logging *LoggingApplyConfiguration `json:"logging,omitempty"` @@ -308,11 +308,11 @@ func (b *TenantSpecApplyConfiguration) WithServiceMetadata(value *ServiceMetadat return b } -// WithStatefulSetMetadata sets the StatefulSetMetadata field in the declarative configuration to the given value +// WithPoolsMetadata sets the PoolsMetadata field in the declarative configuration to the given value // and returns the receiver, so that objects can be built by chaining "With" function invocations. -// If called multiple times, the StatefulSetMetadata field is set to the value of the last call. -func (b *TenantSpecApplyConfiguration) WithStatefulSetMetadata(value *StatefulSetMetadataApplyConfiguration) *TenantSpecApplyConfiguration { - b.StatefulSetMetadata = value +// If called multiple times, the PoolsMetadata field is set to the value of the last call. +func (b *TenantSpecApplyConfiguration) WithPoolsMetadata(value *PoolsMetadataApplyConfiguration) *TenantSpecApplyConfiguration { + b.PoolsMetadata = value return b } diff --git a/pkg/client/applyconfiguration/utils.go b/pkg/client/applyconfiguration/utils.go index 0a9251057fb..60ab5675922 100644 --- a/pkg/client/applyconfiguration/utils.go +++ b/pkg/client/applyconfiguration/utils.go @@ -71,14 +71,14 @@ func ForKind(kind schema.GroupVersionKind) interface{} { return &miniominiov2.LoggingApplyConfiguration{} case v2.SchemeGroupVersion.WithKind("Pool"): return &miniominiov2.PoolApplyConfiguration{} + case v2.SchemeGroupVersion.WithKind("PoolsMetadata"): + return &miniominiov2.PoolsMetadataApplyConfiguration{} case v2.SchemeGroupVersion.WithKind("PoolStatus"): return &miniominiov2.PoolStatusApplyConfiguration{} case v2.SchemeGroupVersion.WithKind("ServiceMetadata"): return &miniominiov2.ServiceMetadataApplyConfiguration{} case v2.SchemeGroupVersion.WithKind("SideCars"): return &miniominiov2.SideCarsApplyConfiguration{} - case v2.SchemeGroupVersion.WithKind("StatefulSetMetadata"): - return &miniominiov2.StatefulSetMetadataApplyConfiguration{} case v2.SchemeGroupVersion.WithKind("Tenant"): return &miniominiov2.TenantApplyConfiguration{} case v2.SchemeGroupVersion.WithKind("TenantDomains"): diff --git a/pkg/resources/services/service.go b/pkg/resources/services/service.go index 2a7a6021e7c..b5960f628ac 100644 --- a/pkg/resources/services/service.go +++ b/pkg/resources/services/service.go @@ -30,18 +30,6 @@ func NewClusterIPForMinIO(t *miniov2.Tenant) *corev1.Service { port = miniov2.MinIOTLSPortLoadBalancerSVC name = miniov2.MinIOServiceHTTPSPortName } - var internalLabels, labels, annotations map[string]string - - internalLabels = t.MinIOPodLabels() - if t.Spec.ServiceMetadata != nil && t.Spec.ServiceMetadata.MinIOServiceLabels != nil { - labels = miniov2.MergeMaps(internalLabels, t.Spec.ServiceMetadata.MinIOServiceLabels) - } else { - labels = internalLabels - } - - if t.Spec.ServiceMetadata != nil && t.Spec.ServiceMetadata.MinIOServiceAnnotations != nil { - annotations = t.Spec.ServiceMetadata.MinIOServiceAnnotations - } minioPort := corev1.ServicePort{ Port: port, @@ -51,11 +39,9 @@ func NewClusterIPForMinIO(t *miniov2.Tenant) *corev1.Service { svc := &corev1.Service{ ObjectMeta: metav1.ObjectMeta{ - Labels: labels, Name: t.MinIOCIServiceName(), Namespace: t.Namespace, OwnerReferences: t.OwnerRef(), - Annotations: annotations, }, Spec: corev1.ServiceSpec{ Ports: []corev1.ServicePort{minioPort}, @@ -64,6 +50,12 @@ func NewClusterIPForMinIO(t *miniov2.Tenant) *corev1.Service { PublishNotReadyAddresses: false, }, } + + if t.Spec.ServiceMetadata != nil { + svc.Labels = t.Spec.ServiceMetadata.MinIOServiceLabels + svc.Annotations = t.Spec.ServiceMetadata.MinIOServiceAnnotations + } + // check if the service is meant to be exposed if t.Spec.ExposeServices != nil && t.Spec.ExposeServices.MinIO { svc.Spec.Type = corev1.ServiceTypeLoadBalancer @@ -73,9 +65,6 @@ func NewClusterIPForMinIO(t *miniov2.Tenant) *corev1.Service { // NewClusterIPForConsole will return a new cluster IP service for Console Deployment func NewClusterIPForConsole(t *miniov2.Tenant) *corev1.Service { - var internalLabels, labels, annotations map[string]string - internalLabels = t.ConsolePodLabels() - consolePort := corev1.ServicePort{ Port: miniov2.ConsolePort, TargetPort: intstr.FromInt(miniov2.ConsolePort), @@ -88,23 +77,12 @@ func NewClusterIPForConsole(t *miniov2.Tenant) *corev1.Service { Name: miniov2.ConsoleServiceTLSPortName, } } - if t.Spec.ServiceMetadata != nil && t.Spec.ServiceMetadata.ConsoleServiceLabels != nil { - labels = miniov2.MergeMaps(internalLabels, t.Spec.ServiceMetadata.ConsoleServiceLabels) - } else { - labels = internalLabels - } - - if t.Spec.ServiceMetadata != nil && t.Spec.ServiceMetadata.ConsoleServiceAnnotations != nil { - annotations = t.Spec.ServiceMetadata.ConsoleServiceAnnotations - } svc := &corev1.Service{ ObjectMeta: metav1.ObjectMeta{ - Labels: labels, Name: t.ConsoleCIServiceName(), Namespace: t.Namespace, OwnerReferences: t.OwnerRef(), - Annotations: annotations, }, Spec: corev1.ServiceSpec{ Ports: []corev1.ServicePort{ @@ -114,6 +92,12 @@ func NewClusterIPForConsole(t *miniov2.Tenant) *corev1.Service { Type: corev1.ServiceTypeClusterIP, }, } + + if t.Spec.ServiceMetadata != nil { + svc.Labels = t.Spec.ServiceMetadata.ConsoleServiceLabels + svc.Annotations = t.Spec.ServiceMetadata.ConsoleServiceAnnotations + } + // check if the service is meant to be exposed if t.Spec.ExposeServices != nil && t.Spec.ExposeServices.Console { svc.Spec.Type = corev1.ServiceTypeLoadBalancer @@ -166,7 +150,6 @@ func NewHeadlessForMinIO(t *miniov2.Tenant) *corev1.Service { svc := &corev1.Service{ ObjectMeta: metav1.ObjectMeta{ - Labels: t.MinIOPodLabels(), Name: t.MinIOHLServiceName(), Namespace: t.Namespace, OwnerReferences: t.OwnerRef(), @@ -188,7 +171,6 @@ func NewHeadlessForKES(t *miniov2.Tenant) *corev1.Service { kesPort := corev1.ServicePort{Port: miniov2.KESPort, Name: miniov2.KESServicePortName} svc := &corev1.Service{ ObjectMeta: metav1.ObjectMeta{ - Labels: t.KESPodLabels(), Name: t.KESHLServiceName(), Namespace: t.Namespace, OwnerReferences: t.OwnerRef(), @@ -200,6 +182,9 @@ func NewHeadlessForKES(t *miniov2.Tenant) *corev1.Service { ClusterIP: corev1.ClusterIPNone, }, } - + if t.Spec.ServiceMetadata != nil { + svc.Labels = t.Spec.ServiceMetadata.KESServiceLabels + svc.Annotations = t.Spec.ServiceMetadata.KESServiceAnnotations + } return svc } diff --git a/pkg/resources/statefulsets/minio-statefulset.go b/pkg/resources/statefulsets/minio-statefulset.go index c45d5716d90..6d222fbbe00 100644 --- a/pkg/resources/statefulsets/minio-statefulset.go +++ b/pkg/resources/statefulsets/minio-statefulset.go @@ -24,6 +24,7 @@ import ( miniov2 "github.com/minio/operator/pkg/apis/minio.min.io/v2" "github.com/minio/operator/pkg/certs" + "github.com/minio/operator/pkg/utils" appsv1 "k8s.io/api/apps/v1" corev1 "k8s.io/api/core/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" @@ -60,49 +61,21 @@ func minioEnvironmentVars(t *miniov2.Tenant, skipEnvVars map[string][]byte) []co // PodMetadata Returns the MinIO pods metadata set in configuration. // If a user specifies metadata in the spec we return that metadata. func PodMetadata(t *miniov2.Tenant, pool *miniov2.Pool) metav1.ObjectMeta { - meta := metav1.ObjectMeta{} - // Copy Labels and Annotations from Tenant - labels := t.ObjectMeta.Labels - annotations := t.ObjectMeta.Annotations - - if annotations == nil { - annotations = make(map[string]string) - } - - annotations[miniov2.Revision] = fmt.Sprintf("%d", t.Status.Revision) - - if labels == nil { - labels = make(map[string]string) - } - // Add the additional label used by StatefulSet spec selector - for k, v := range t.MinIOPodLabels() { - labels[k] = v - } - // Add information labels, such as which pool we are building this pod about - labels[miniov2.PoolLabel] = pool.Name - // Add the additional label used by Console spec selector - for k, v := range t.ConsolePodLabels() { - labels[k] = v - } - - // Add user specific annotations - if pool.Annotations != nil { - annotations = miniov2.MergeMaps(annotations, pool.Annotations) - } - - if pool.Labels != nil { - labels = miniov2.MergeMaps(labels, pool.Labels) + meta := metav1.ObjectMeta{ + Labels: utils.MergeMaps(t.Spec.PoolsMetadata.Labels, pool.Labels, t.MinIOPodLabels(), t.ConsolePodLabels()), + Annotations: utils.MergeMaps(t.Spec.PoolsMetadata.Annotations, pool.Annotations), } - meta.Labels = labels - meta.Annotations = annotations + // Set specific information + meta.Labels[miniov2.PoolLabel] = pool.Name + meta.Annotations[miniov2.Revision] = fmt.Sprintf("%d", t.Status.Revision) return meta } // ContainerMatchLabels Returns the labels that match the Pods in the statefulset func ContainerMatchLabels(t *miniov2.Tenant, pool *miniov2.Pool) *metav1.LabelSelector { - labels := miniov2.MergeMaps(t.MinIOPodLabels(), t.ConsolePodLabels()) + labels := utils.MergeMaps(t.MinIOPodLabels(), t.ConsolePodLabels()) // Add pool information so it's passed down to the underlying PVCs labels[miniov2.PoolLabel] = pool.Name return &metav1.LabelSelector{ @@ -630,31 +603,19 @@ func NewPool(args *NewPoolArgs) *appsv1.StatefulSet { // Copy labels and annotations from the Tenant.Spec.Metadata // unless `StatefulSetMetadata` is defined, then we'll copy it // from there. - if t.Spec.StatefulSetMetadata != nil { - ssMeta.Labels = t.Spec.StatefulSetMetadata.Labels - ssMeta.Annotations = t.Spec.StatefulSetMetadata.Annotations - } else { - ssMeta.Labels = t.ObjectMeta.Labels - ssMeta.Annotations = t.ObjectMeta.Annotations + if t.Spec.PoolsMetadata != nil { + ssMeta.Labels = t.Spec.PoolsMetadata.Labels + ssMeta.Annotations = t.Spec.PoolsMetadata.Annotations } - if ssMeta.Labels == nil { - ssMeta.Labels = make(map[string]string) - } + // Add pool specific annotations + ssMeta.Annotations = utils.MergeMaps(ssMeta.Annotations, pool.Annotations) + ssMeta.Labels = utils.MergeMaps(ssMeta.Labels, pool.Labels) // Add information labels, such as which pool we are building this pod about ssMeta.Labels[miniov2.PoolLabel] = pool.Name ssMeta.Labels[miniov2.TenantLabel] = t.Name - // Add user specific annotations - if pool.Annotations != nil { - ssMeta.Annotations = miniov2.MergeMaps(ssMeta.Annotations, pool.Annotations) - } - - if pool.Labels != nil { - ssMeta.Labels = miniov2.MergeMaps(ssMeta.Labels, pool.Labels) - } - containers := []corev1.Container{ poolMinioServerContainer(t, skipEnvVars, pool, certVolumeSources), getSideCarContainer(t, pool), diff --git a/pkg/utils/utils.go b/pkg/utils/utils.go index f9e86bc64c1..b2e724bd19b 100644 --- a/pkg/utils/utils.go +++ b/pkg/utils/utils.go @@ -70,3 +70,14 @@ func CastObjectToMetaV1(obj interface{}) (metav1.Object, error) { } return object, nil } + +// MergeMaps merges maps and returns the union +func MergeMaps(maps ...map[string]string) map[string]string { + dest := map[string]string{} + for _, m := range maps { + for k, v := range m { + dest[k] = v + } + } + return dest +} diff --git a/resources/base/crds/minio.min.io_tenants.yaml b/resources/base/crds/minio.min.io_tenants.yaml index 46e8f6f8cb2..e295126ce51 100644 --- a/resources/base/crds/minio.min.io_tenants.yaml +++ b/resources/base/crds/minio.min.io_tenants.yaml @@ -3638,6 +3638,17 @@ spec: x-kubernetes-list-map-keys: - name x-kubernetes-list-type: map + poolsMetadata: + properties: + annotations: + additionalProperties: + type: string + type: object + labels: + additionalProperties: + type: string + type: object + type: object priorityClassName: type: string prometheusOperator: @@ -3736,6 +3747,14 @@ spec: additionalProperties: type: string type: object + kesServiceAnnotations: + additionalProperties: + type: string + type: object + kesServiceLabels: + additionalProperties: + type: string + type: object minioServiceAnnotations: additionalProperties: type: string @@ -5500,17 +5519,6 @@ spec: format: int32 type: integer type: object - statefulSetMetadata: - properties: - annotations: - additionalProperties: - type: string - type: object - labels: - additionalProperties: - type: string - type: object - type: object subPath: type: string users: