diff --git a/.secrets.baseline b/.secrets.baseline index fdc5c9870..510c5ca8e 100644 --- a/.secrets.baseline +++ b/.secrets.baseline @@ -390,7 +390,7 @@ "filename": "apis/clusters/v1beta1/zz_generated.deepcopy.go", "hashed_secret": "44e17306b837162269a410204daaa5ecee4ec22c", "is_verified": false, - "line_number": 2223 + "line_number": 2323 } ], "apis/kafkamanagement/v1beta1/kafkauser_types.go": [ @@ -1130,5 +1130,5 @@ } ] }, - "generated_at": "2024-02-08T08:15:55Z" + "generated_at": "2024-02-09T12:49:33Z" } diff --git a/apis/clusters/v1beta1/generic_spec.go b/apis/clusters/v1beta1/generic_spec.go index be7024be2..66be95994 100644 --- a/apis/clusters/v1beta1/generic_spec.go +++ b/apis/clusters/v1beta1/generic_spec.go @@ -99,13 +99,13 @@ func (s *GenericClusterSpec) ClusterSettingsUpdateToInstAPI() *models.ClusterSet } type GenericDataCentreSpec struct { - Name string `json:"name,omitempty"` - Region string `json:"region"` - CloudProvider string `json:"cloudProvider"` - ProviderAccountName string `json:"accountName,omitempty"` - Network string `json:"network"` - Tags map[string]string `json:"tags,omitempty"` - CloudProviderSettings []*CloudProviderSettings `json:"cloudProviderSettings,omitempty"` + Name string `json:"name,omitempty"` + Region string `json:"region"` + CloudProvider string `json:"cloudProvider"` + ProviderAccountName string `json:"accountName,omitempty"` + Network string `json:"network"` + Tags map[string]string `json:"tags,omitempty"` + CloudProviderSettings CloudProviderOptions `json:"cloudProviderSettings,omitempty"` } func (s *GenericDataCentreSpec) Equals(o *GenericDataCentreSpec) bool { @@ -115,7 +115,7 @@ func (s *GenericDataCentreSpec) Equals(o *GenericDataCentreSpec) bool { s.ProviderAccountName == o.ProviderAccountName && s.Network == o.Network && areTagsEqual(s.Tags, o.Tags) && - slices.EqualsPtr(s.CloudProviderSettings, o.CloudProviderSettings) + s.CloudProviderSettings.Equal(o.CloudProviderSettings) } func (s *GenericDataCentreSpec) FromInstAPI(model *models.GenericDataCentreFields) { @@ -125,29 +125,29 @@ func (s *GenericDataCentreSpec) FromInstAPI(model *models.GenericDataCentreField s.ProviderAccountName = model.ProviderAccountName s.Network = model.Network s.Tags = tagsFromInstAPI(model.Tags) - s.CloudProviderSettings = cloudProviderSettingsFromInstAPI(model) + s.CloudProviderSettings.FromInstAPI(&model.CloudProviderSettings) } -func (dc *GenericDataCentreSpec) CloudProviderSettingsToInstAPI() models.CloudProviderSettings { - instaModel := models.CloudProviderSettings{} - - switch dc.CloudProvider { - case models.AWSVPC: - for _, providerSettings := range dc.CloudProviderSettings { - instaModel.AWSSettings = append(instaModel.AWSSettings, providerSettings.AWSToInstAPI()) - } - case models.AZUREAZ: - for _, providerSettings := range dc.CloudProviderSettings { - instaModel.AzureSettings = append(instaModel.AzureSettings, providerSettings.AzureToInstAPI()) - } - case models.GCP: - for _, providerSettings := range dc.CloudProviderSettings { - instaModel.GCPSettings = append(instaModel.GCPSettings, providerSettings.GCPToInstAPI()) - } - } - - return instaModel -} +//func (dc *GenericDataCentreSpec) CloudProviderSettingsToInstAPI() models.CloudProviderSettings { +// instaModel := models.CloudProviderSettings{} +// +// switch dc.CloudProvider { +// case models.AWSVPC: +// for _, providerSettings := range dc.CloudProviderSettings { +// instaModel.AWSSettings = append(instaModel.AWSSettings, providerSettings.AWSToInstAPI()) +// } +// case models.AZUREAZ: +// for _, providerSettings := range dc.CloudProviderSettings { +// instaModel.AzureSettings = append(instaModel.AzureSettings, providerSettings.AzureToInstAPI()) +// } +// case models.GCP: +// for _, providerSettings := range dc.CloudProviderSettings { +// instaModel.GCPSettings = append(instaModel.GCPSettings, providerSettings.GCPToInstAPI()) +// } +// } +// +// return instaModel +//} func (s *GenericDataCentreSpec) ToInstAPI() models.GenericDataCentreFields { return models.GenericDataCentreFields{ @@ -157,6 +157,6 @@ func (s *GenericDataCentreSpec) ToInstAPI() models.GenericDataCentreFields { Region: s.Region, ProviderAccountName: s.ProviderAccountName, Tags: tagsToInstAPI(s.Tags), - CloudProviderSettings: s.CloudProviderSettingsToInstAPI(), + CloudProviderSettings: s.CloudProviderSettings.ToInstAPI(), } } diff --git a/apis/clusters/v1beta1/kafka_webhook_test.go b/apis/clusters/v1beta1/kafka_webhook_test.go index ecf1a74d8..0c35bf399 100644 --- a/apis/clusters/v1beta1/kafka_webhook_test.go +++ b/apis/clusters/v1beta1/kafka_webhook_test.go @@ -195,7 +195,7 @@ var _ = Describe("Kafka Controller", Ordered, func() { testKafkaManifest.Spec.DataCentres[0].Network = prevStringField prevCloudProviderSettings := kafkaManifest.Spec.DataCentres[0].CloudProviderSettings - testKafkaManifest.Spec.DataCentres[0].CloudProviderSettings = []*CloudProviderSettings{prevCloudProviderSettings[0], prevCloudProviderSettings[0]} + testKafkaManifest.Spec.DataCentres[0].CloudProviderSettings = CloudProviderOptions{prevCloudProviderSettings[0], prevCloudProviderSettings[0]} Expect(k8sClient.Patch(ctx, &testKafkaManifest, patch)).ShouldNot(Succeed()) testKafkaManifest.Spec.DataCentres[0].CloudProviderSettings = prevCloudProviderSettings diff --git a/apis/clusters/v1beta1/opensearch_types.go b/apis/clusters/v1beta1/opensearch_types.go index 300e783aa..f43470f79 100644 --- a/apis/clusters/v1beta1/opensearch_types.go +++ b/apis/clusters/v1beta1/opensearch_types.go @@ -293,34 +293,6 @@ func tagsFromInstAPI(iTags []*models.Tag) map[string]string { return newTags } -func cloudProviderSettingsFromInstAPI(iDC *models.GenericDataCentreFields) (settings []*CloudProviderSettings) { - switch iDC.CloudProvider { - case models.AWSVPC: - for _, awsSetting := range iDC.AWSSettings { - settings = append(settings, &CloudProviderSettings{ - CustomVirtualNetworkID: awsSetting.CustomVirtualNetworkID, - DiskEncryptionKey: awsSetting.EBSEncryptionKey, - BackupBucket: awsSetting.BackupBucket, - }) - } - case models.GCP: - for _, gcpSetting := range iDC.GCPSettings { - settings = append(settings, &CloudProviderSettings{ - CustomVirtualNetworkID: gcpSetting.CustomVirtualNetworkID, - DisableSnapshotAutoExpiry: gcpSetting.DisableSnapshotAutoExpiry, - }) - } - case models.AZUREAZ: - for _, azureSetting := range iDC.AzureSettings { - settings = append(settings, &CloudProviderSettings{ - ResourceGroup: azureSetting.ResourceGroup, - }) - } - } - - return settings -} - func (c *OpenSearch) GetSpec() OpenSearchSpec { return c.Spec } func (c *OpenSearch) IsSpecEqual(spec OpenSearchSpec) bool { diff --git a/apis/clusters/v1beta1/structs.go b/apis/clusters/v1beta1/structs.go index 8dfe8199f..64acc3059 100644 --- a/apis/clusters/v1beta1/structs.go +++ b/apis/clusters/v1beta1/structs.go @@ -18,6 +18,7 @@ package v1beta1 import ( "encoding/json" + "errors" "net" clusterresource "github.com/instaclustr/operator/apis/clusterresources/v1beta1" @@ -820,3 +821,129 @@ func (g GenericResizeSettings) Equal(o GenericResizeSettings) bool { return true } + +type AWSSettings struct { + EncryptionKey string `json:"encryptionKey,omitempty"` + CustomVirtualNetworkID string `json:"customVirtualNetworkID,omitempty"` + BackupBucket string `json:"backupBucket,omitempty"` +} + +type GCPSettings struct { + CustomVirtualNetworkID string `json:"customVirtualNetworkID,omitempty"` + DisableSnapshotAutoExpiry string `json:"disableSnapshotAutoExpiry,omitempty"` +} + +type AzureSettings struct { + ResourceGroup string `json:"resourceGroup,omitempty"` + CustomVirtualNetworkID string `json:"customVirtualNetworkID,omitempty"` + StorageNetwork string `json:"storageNetwork,omitempty"` +} + +type CloudProviderOpts struct { + AWSSettings *AWSSettings `json:"awsSettings,omitempty"` + GCPSettings *GCPSettings `json:"gcpSettings,omitempty"` + AzureSettings *AzureSettings `json:"azureSettings,omitempty"` +} + +type CloudProviderOptions []*CloudProviderOpts + +func (c *CloudProviderOptions) FromInstAPI(instaModel *models.CloudProviderSettings) { + s := CloudProviderOpts{} + *c = append(*c, &s) + + switch { + case len(instaModel.AWSSettings) > 0: + s.AWSSettings = &AWSSettings{ + EncryptionKey: instaModel.AWSSettings[0].EBSEncryptionKey, + CustomVirtualNetworkID: instaModel.AWSSettings[0].CustomVirtualNetworkID, + BackupBucket: instaModel.AWSSettings[0].BackupBucket, + } + case len(instaModel.GCPSettings) > 0: + s.GCPSettings = &GCPSettings{ + CustomVirtualNetworkID: instaModel.GCPSettings[0].CustomVirtualNetworkID, + DisableSnapshotAutoExpiry: instaModel.GCPSettings[0].DisableSnapshotAutoExpiry, + } + case len(instaModel.AzureSettings) > 0: + s.AzureSettings = &AzureSettings{ + ResourceGroup: instaModel.AzureSettings[0].ResourceGroup, + CustomVirtualNetworkID: instaModel.AzureSettings[0].CustomVirtualNetworkID, + StorageNetwork: instaModel.AzureSettings[0].StorageNetwork, + } + } +} + +func (c *CloudProviderOptions) ToInstAPI() models.CloudProviderSettings { + if len(*c) == 0 { + return models.CloudProviderSettings{} + } + + var instaModel models.CloudProviderSettings + + s := (*c)[0] + + switch { + case s.AWSSettings != nil: + instaModel.AWSSettings = append(instaModel.AWSSettings, &models.AWSSetting{ + EBSEncryptionKey: s.AWSSettings.EncryptionKey, + CustomVirtualNetworkID: s.AWSSettings.CustomVirtualNetworkID, + BackupBucket: s.AWSSettings.BackupBucket, + }) + case s.GCPSettings != nil: + instaModel.GCPSettings = append(instaModel.GCPSettings, &models.GCPSetting{ + CustomVirtualNetworkID: s.GCPSettings.CustomVirtualNetworkID, + DisableSnapshotAutoExpiry: s.GCPSettings.DisableSnapshotAutoExpiry, + }) + case s.AzureSettings != nil: + instaModel.AzureSettings = append(instaModel.AzureSettings, &models.AzureSetting{ + ResourceGroup: s.AzureSettings.ResourceGroup, + CustomVirtualNetworkID: s.AzureSettings.CustomVirtualNetworkID, + StorageNetwork: s.AzureSettings.StorageNetwork, + }) + } + + return instaModel +} + +func (c CloudProviderOptions) Equal(o CloudProviderOptions) bool { + if len(c) != len(o) { + return false + } + + for i := range c { + switch { + case c[i].AWSSettings != nil: + if *c[i].AWSSettings != *o[i].AWSSettings { + return false + } + case c[i].GCPSettings != nil: + if *c[i].GCPSettings != *o[i].GCPSettings { + return false + } + case c[i].AzureSettings != nil: + if *c[i].AzureSettings != *o[i].AzureSettings { + return false + } + } + } + + return true +} + +func (c *CloudProviderOpts) validateCreation() error { + fieldSet := 0 + if c.AWSSettings != nil { + fieldSet++ + } + if c.AzureSettings != nil { + fieldSet++ + } + if c.GCPSettings != nil { + fieldSet++ + } + + if fieldSet > 1 { + return errors.New("only one of [awsSettings, gcpSetting, azureSettings] should be set") + } + + return nil +} diff --git a/apis/clusters/v1beta1/validation.go b/apis/clusters/v1beta1/validation.go index a9b200a74..67119704e 100644 --- a/apis/clusters/v1beta1/validation.go +++ b/apis/clusters/v1beta1/validation.go @@ -27,7 +27,6 @@ import ( "sigs.k8s.io/controller-runtime/pkg/client" "github.com/instaclustr/operator/pkg/models" - "github.com/instaclustr/operator/pkg/utils/slices" "github.com/instaclustr/operator/pkg/validation" ) @@ -381,7 +380,7 @@ func (s *GenericDataCentreSpec) validateCreation() error { } for _, cp := range s.CloudProviderSettings { - err := cp.ValidateCreation() + err := cp.validateCreation() if err != nil { return err } @@ -408,8 +407,8 @@ func (s *GenericDataCentreSpec) ValidateOnPremisesCreation() error { return nil } -func (s *GenericDataCentreSpec) validateImmutableCloudProviderSettingsUpdate(oldSettings []*CloudProviderSettings) error { - if !slices.EqualsPtr(s.CloudProviderSettings, oldSettings) { +func (s *GenericDataCentreSpec) validateImmutableCloudProviderSettingsUpdate(oldSettings CloudProviderOptions) error { + if !s.CloudProviderSettings.Equal(oldSettings) { return models.ErrImmutableCloudProviderSettings } diff --git a/apis/clusters/v1beta1/zz_generated.deepcopy.go b/apis/clusters/v1beta1/zz_generated.deepcopy.go index 2f3ac5970..d20acb345 100644 --- a/apis/clusters/v1beta1/zz_generated.deepcopy.go +++ b/apis/clusters/v1beta1/zz_generated.deepcopy.go @@ -58,6 +58,21 @@ func (in *AWSConnectorSettings) DeepCopy() *AWSConnectorSettings { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *AWSSettings) DeepCopyInto(out *AWSSettings) { + *out = *in +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new AWSSettings. +func (in *AWSSettings) DeepCopy() *AWSSettings { + if in == nil { + return nil + } + out := new(AWSSettings) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *AdvancedVisibility) DeepCopyInto(out *AdvancedVisibility) { *out = *in @@ -98,6 +113,21 @@ func (in *AzureConnectorSettings) DeepCopy() *AzureConnectorSettings { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *AzureSettings) DeepCopyInto(out *AzureSettings) { + *out = *in +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new AzureSettings. +func (in *AzureSettings) DeepCopy() *AzureSettings { + if in == nil { + return nil + } + out := new(AzureSettings) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *BundledCassandraSpec) DeepCopyInto(out *BundledCassandraSpec) { *out = *in @@ -601,6 +631,61 @@ func (in *CassandraStatus) DeepCopy() *CassandraStatus { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in CloudProviderOptions) DeepCopyInto(out *CloudProviderOptions) { + { + in := &in + *out = make(CloudProviderOptions, len(*in)) + for i := range *in { + if (*in)[i] != nil { + in, out := &(*in)[i], &(*out)[i] + *out = new(CloudProviderOpts) + (*in).DeepCopyInto(*out) + } + } + } +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CloudProviderOptions. +func (in CloudProviderOptions) DeepCopy() CloudProviderOptions { + if in == nil { + return nil + } + out := new(CloudProviderOptions) + in.DeepCopyInto(out) + return *out +} + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *CloudProviderOpts) DeepCopyInto(out *CloudProviderOpts) { + *out = *in + if in.AWSSettings != nil { + in, out := &in.AWSSettings, &out.AWSSettings + *out = new(AWSSettings) + **out = **in + } + if in.GCPSettings != nil { + in, out := &in.GCPSettings, &out.GCPSettings + *out = new(GCPSettings) + **out = **in + } + if in.AzureSettings != nil { + in, out := &in.AzureSettings, &out.AzureSettings + *out = new(AzureSettings) + **out = **in + } +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new CloudProviderOpts. +func (in *CloudProviderOpts) DeepCopy() *CloudProviderOpts { + if in == nil { + return nil + } + out := new(CloudProviderOpts) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *CloudProviderSettings) DeepCopyInto(out *CloudProviderSettings) { *out = *in @@ -941,6 +1026,21 @@ func (in *GCPConnectorSettings) DeepCopy() *GCPConnectorSettings { return out } +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *GCPSettings) DeepCopyInto(out *GCPSettings) { + *out = *in +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new GCPSettings. +func (in *GCPSettings) DeepCopy() *GCPSettings { + if in == nil { + return nil + } + out := new(GCPSettings) + in.DeepCopyInto(out) + return out +} + // DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. func (in *GenericClusterSpec) DeepCopyInto(out *GenericClusterSpec) { *out = *in @@ -979,12 +1079,12 @@ func (in *GenericDataCentreSpec) DeepCopyInto(out *GenericDataCentreSpec) { } if in.CloudProviderSettings != nil { in, out := &in.CloudProviderSettings, &out.CloudProviderSettings - *out = make([]*CloudProviderSettings, len(*in)) + *out = make(CloudProviderOptions, len(*in)) for i := range *in { if (*in)[i] != nil { in, out := &(*in)[i], &(*out)[i] - *out = new(CloudProviderSettings) - **out = **in + *out = new(CloudProviderOpts) + (*in).DeepCopyInto(*out) } } } diff --git a/config/crd/bases/clusters.instaclustr.com_cassandras.yaml b/config/crd/bases/clusters.instaclustr.com_cassandras.yaml index 6ef467df0..68da01f9f 100644 --- a/config/crd/bases/clusters.instaclustr.com_cassandras.yaml +++ b/config/crd/bases/clusters.instaclustr.com_cassandras.yaml @@ -62,16 +62,31 @@ spec: cloudProviderSettings: items: properties: - backupBucket: - type: string - customVirtualNetworkId: - type: string - disableSnapshotAutoExpiry: - type: string - diskEncryptionKey: - type: string - resourceGroup: - type: string + awsSettings: + properties: + backupBucket: + type: string + customVirtualNetworkID: + type: string + encryptionKey: + type: string + type: object + azureSettings: + properties: + customVirtualNetworkID: + type: string + resourceGroup: + type: string + storageNetwork: + type: string + type: object + gcpSettings: + properties: + customVirtualNetworkID: + type: string + disableSnapshotAutoExpiry: + type: string + type: object type: object type: array continuousBackup: diff --git a/config/crd/bases/clusters.instaclustr.com_kafkas.yaml b/config/crd/bases/clusters.instaclustr.com_kafkas.yaml index d388fdb3f..0e0b509ab 100644 --- a/config/crd/bases/clusters.instaclustr.com_kafkas.yaml +++ b/config/crd/bases/clusters.instaclustr.com_kafkas.yaml @@ -68,16 +68,31 @@ spec: cloudProviderSettings: items: properties: - backupBucket: - type: string - customVirtualNetworkId: - type: string - disableSnapshotAutoExpiry: - type: string - diskEncryptionKey: - type: string - resourceGroup: - type: string + awsSettings: + properties: + backupBucket: + type: string + customVirtualNetworkID: + type: string + encryptionKey: + type: string + type: object + azureSettings: + properties: + customVirtualNetworkID: + type: string + resourceGroup: + type: string + storageNetwork: + type: string + type: object + gcpSettings: + properties: + customVirtualNetworkID: + type: string + disableSnapshotAutoExpiry: + type: string + type: object type: object type: array name: diff --git a/config/crd/bases/clusters.instaclustr.com_opensearches.yaml b/config/crd/bases/clusters.instaclustr.com_opensearches.yaml index 3825b9146..e52aa4b1b 100644 --- a/config/crd/bases/clusters.instaclustr.com_opensearches.yaml +++ b/config/crd/bases/clusters.instaclustr.com_opensearches.yaml @@ -78,16 +78,31 @@ spec: cloudProviderSettings: items: properties: - backupBucket: - type: string - customVirtualNetworkId: - type: string - disableSnapshotAutoExpiry: - type: string - diskEncryptionKey: - type: string - resourceGroup: - type: string + awsSettings: + properties: + backupBucket: + type: string + customVirtualNetworkID: + type: string + encryptionKey: + type: string + type: object + azureSettings: + properties: + customVirtualNetworkID: + type: string + resourceGroup: + type: string + storageNetwork: + type: string + type: object + gcpSettings: + properties: + customVirtualNetworkID: + type: string + disableSnapshotAutoExpiry: + type: string + type: object type: object type: array name: diff --git a/config/samples/clusters_v1beta1_opensearch.yaml b/config/samples/clusters_v1beta1_opensearch.yaml index c5bef4e3e..1c2e13e30 100644 --- a/config/samples/clusters_v1beta1_opensearch.yaml +++ b/config/samples/clusters_v1beta1_opensearch.yaml @@ -11,7 +11,7 @@ metadata: annotations: test.annotation/first: testAnnotation spec: - name: opensearch-test + name: bohdan-test alertingPlugin: false anomalyDetectionPlugin: false asynchronousSearchPlugin: false diff --git a/pkg/models/apiv2.go b/pkg/models/apiv2.go index 9473551cf..74bcc4cc8 100644 --- a/pkg/models/apiv2.go +++ b/pkg/models/apiv2.go @@ -75,7 +75,9 @@ type GCPSetting struct { } type AzureSetting struct { - ResourceGroup string `json:"resourceGroup,omitempty"` + ResourceGroup string `json:"resourceGroup,omitempty"` + CustomVirtualNetworkID string `json:"customVirtualNetworkID,omitempty"` + StorageNetwork string `json:"storageNetwork,omitempty"` } type Tag struct {