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

azurerm_mysql_flexible_server add suport for customer_managed_key #19905

Merged
merged 5 commits into from
Jan 10, 2023
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
11 changes: 9 additions & 2 deletions internal/services/mysql/client/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ package client
import (
"github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2020-01-01/mysql" // nolint: staticcheck
"github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2021-05-01/mysqlflexibleservers" // nolint: staticcheck
"github.com/hashicorp/go-azure-sdk/resource-manager/mysql/2021-05-01/serverfailover"
"github.com/hashicorp/go-azure-sdk/resource-manager/mysql/2021-05-01/servers"
"github.com/hashicorp/terraform-provider-azurerm/internal/common"
)

Expand All @@ -12,7 +14,8 @@ type Client struct {
FirewallRulesClient *mysql.FirewallRulesClient
FlexibleDatabasesClient *mysqlflexibleservers.DatabasesClient
FlexibleServerConfigurationsClient *mysqlflexibleservers.ConfigurationsClient
FlexibleServerClient *mysqlflexibleservers.ServersClient
FlexibleServerClient *servers.ServersClient
FlexibleServerFailoverClient *serverfailover.ServerFailoverClient
FlexibleServerFirewallRulesClient *mysqlflexibleservers.FirewallRulesClient
ServersClient *mysql.ServersClient
ServerKeysClient *mysql.ServerKeysClient
Expand All @@ -34,9 +37,12 @@ func NewClient(o *common.ClientOptions) *Client {
flexibleDatabasesClient := mysqlflexibleservers.NewDatabasesClientWithBaseURI(o.ResourceManagerEndpoint, o.SubscriptionId)
o.ConfigureClient(&flexibleDatabasesClient.Client, o.ResourceManagerAuthorizer)

flexibleServerClient := mysqlflexibleservers.NewServersClientWithBaseURI(o.ResourceManagerEndpoint, o.SubscriptionId)
flexibleServerClient := servers.NewServersClientWithBaseURI(o.ResourceManagerEndpoint)
o.ConfigureClient(&flexibleServerClient.Client, o.ResourceManagerAuthorizer)

flexibleServerFailoverClient := serverfailover.NewServerFailoverClientWithBaseURI(o.ResourceManagerEndpoint)
o.ConfigureClient(&flexibleServerFailoverClient.Client, o.ResourceManagerAuthorizer)

flexibleServerFirewallRulesClient := mysqlflexibleservers.NewFirewallRulesClientWithBaseURI(o.ResourceManagerEndpoint, o.SubscriptionId)
o.ConfigureClient(&flexibleServerFirewallRulesClient.Client, o.ResourceManagerAuthorizer)

Expand Down Expand Up @@ -64,6 +70,7 @@ func NewClient(o *common.ClientOptions) *Client {
FirewallRulesClient: &FirewallRulesClient,
FlexibleDatabasesClient: &flexibleDatabasesClient,
FlexibleServerClient: &flexibleServerClient,
FlexibleServerFailoverClient: &flexibleServerFailoverClient,
FlexibleServerFirewallRulesClient: &flexibleServerFirewallRulesClient,
FlexibleServerConfigurationsClient: &flexibleServerConfigurationsClient,
ServersClient: &ServersClient,
Expand Down
128 changes: 65 additions & 63 deletions internal/services/mysql/mysql_flexible_server_data_source.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,15 @@ import (
"strings"
"time"

"github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2021-05-01/mysqlflexibleservers" // nolint: staticcheck
"github.com/hashicorp/go-azure-helpers/lang/response"
"github.com/hashicorp/go-azure-helpers/resourcemanager/commonschema"
"github.com/hashicorp/go-azure-helpers/resourcemanager/location"
"github.com/hashicorp/go-azure-helpers/resourcemanager/tags"
"github.com/hashicorp/go-azure-sdk/resource-manager/mysql/2021-05-01/servers"
"github.com/hashicorp/terraform-provider-azurerm/internal/clients"
"github.com/hashicorp/terraform-provider-azurerm/internal/services/mysql/parse"
"github.com/hashicorp/terraform-provider-azurerm/internal/services/mysql/validate"
"github.com/hashicorp/terraform-provider-azurerm/internal/tags"
"github.com/hashicorp/terraform-provider-azurerm/internal/tf/pluginsdk"
"github.com/hashicorp/terraform-provider-azurerm/internal/timeouts"
"github.com/hashicorp/terraform-provider-azurerm/utils"
)

func dataSourceMysqlFlexibleServer() *pluginsdk.Resource {
Expand Down Expand Up @@ -162,7 +161,7 @@ func dataSourceMysqlFlexibleServer() *pluginsdk.Resource {
Computed: true,
},

"tags": tags.SchemaDataSource(),
"tags": commonschema.TagsDataSource(),
},
}
}
Expand All @@ -173,69 +172,72 @@ func dataSourceMysqlFlexibleServerRead(d *pluginsdk.ResourceData, meta interface
ctx, cancel := timeouts.ForRead(meta.(*clients.Client).StopContext, d)
defer cancel()

id := parse.NewFlexibleServerID(subscriptionId, d.Get("resource_group_name").(string), d.Get("name").(string))
resp, err := client.Get(ctx, id.ResourceGroup, id.Name)
id := servers.NewFlexibleServerID(subscriptionId, d.Get("resource_group_name").(string), d.Get("name").(string))
resp, err := client.Get(ctx, id)
if err != nil {
if utils.ResponseWasNotFound(resp.Response) {
if response.WasNotFound(resp.HttpResponse) {
return fmt.Errorf("%s was not found", id)
}
return fmt.Errorf("retrieving %s: %+v", id, err)
}

d.SetId(id.ID())

d.Set("name", id.Name)
d.Set("resource_group_name", id.ResourceGroup)
d.Set("location", location.NormalizeNilable(resp.Location))

if props := resp.ServerProperties; props != nil {
d.Set("administrator_login", props.AdministratorLogin)
d.Set("zone", props.AvailabilityZone)
d.Set("version", props.Version)
d.Set("fqdn", props.FullyQualifiedDomainName)

if network := props.Network; network != nil {
d.Set("public_network_access_enabled", network.PublicNetworkAccess == mysqlflexibleservers.EnableStatusEnumEnabled)
d.Set("delegated_subnet_id", network.DelegatedSubnetResourceID)
d.Set("private_dns_zone_id", network.PrivateDNSZoneResourceID)
}

if err := d.Set("maintenance_window", flattenDataSourceArmServerMaintenanceWindow(props.MaintenanceWindow)); err != nil {
return fmt.Errorf("setting `maintenance_window`: %+v", err)
}

if err := d.Set("storage", flattenDataSourceArmServerStorage(props.Storage)); err != nil {
return fmt.Errorf("setting `storage`: %+v", err)
d.Set("name", id.ServerName)
d.Set("resource_group_name", id.ResourceGroupName)

if model := resp.Model; model != nil {
d.Set("location", location.NormalizeNilable(&model.Location))

if props := model.Properties; props != nil {
d.Set("administrator_login", props.AdministratorLogin)
d.Set("zone", props.AvailabilityZone)
d.Set("version", props.Version)
d.Set("fqdn", props.FullyQualifiedDomainName)

if network := props.Network; network != nil {
d.Set("public_network_access_enabled", *network.PublicNetworkAccess == servers.EnableStatusEnumEnabled)
d.Set("delegated_subnet_id", network.DelegatedSubnetResourceId)
d.Set("private_dns_zone_id", network.PrivateDnsZoneResourceId)
}

if err := d.Set("maintenance_window", flattenDataSourceArmServerMaintenanceWindow(props.MaintenanceWindow)); err != nil {
return fmt.Errorf("setting `maintenance_window`: %+v", err)
}

if err := d.Set("storage", flattenDataSourceArmServerStorage(props.Storage)); err != nil {
return fmt.Errorf("setting `storage`: %+v", err)
}

if backup := props.Backup; backup != nil {
d.Set("backup_retention_days", backup.BackupRetentionDays)
d.Set("geo_redundant_backup_enabled", *backup.GeoRedundantBackup == servers.EnableStatusEnumEnabled)
}

if err := d.Set("high_availability", flattenDataSourceFlexibleServerHighAvailability(props.HighAvailability)); err != nil {
return fmt.Errorf("setting `high_availability`: %+v", err)
}
d.Set("replication_role", props.ReplicationRole)
d.Set("replica_capacity", props.ReplicaCapacity)
}

if backup := props.Backup; backup != nil {
d.Set("backup_retention_days", backup.BackupRetentionDays)
d.Set("geo_redundant_backup_enabled", backup.GeoRedundantBackup == mysqlflexibleservers.EnableStatusEnumEnabled)
sku, err := flattenDataSourceFlexibleServerSku(model.Sku)
if err != nil {
return fmt.Errorf("flattening `sku_name` for %q: %v", id, err)
}

if err := d.Set("high_availability", flattenDataSourceFlexibleServerHighAvailability(props.HighAvailability)); err != nil {
return fmt.Errorf("setting `high_availability`: %+v", err)
}
d.Set("replication_role", props.ReplicationRole)
d.Set("replica_capacity", props.ReplicaCapacity)
}
d.Set("sku_name", sku)

sku, err := flattenDataSourceFlexibleServerSku(resp.Sku)
if err != nil {
return fmt.Errorf("flattening `sku_name` for %q: %v", id, err)
return tags.FlattenAndSet(d, model.Tags)
}

d.Set("sku_name", sku)

return tags.FlattenAndSet(d, resp.Tags)
return nil
}

func flattenDataSourceArmServerStorage(storage *mysqlflexibleservers.Storage) []interface{} {
func flattenDataSourceArmServerStorage(storage *servers.Storage) []interface{} {
if storage == nil {
return []interface{}{}
}

var size, iops int32
var size, iops int64
if storage.StorageSizeGB != nil {
size = *storage.StorageSizeGB
}
Expand All @@ -248,45 +250,45 @@ func flattenDataSourceArmServerStorage(storage *mysqlflexibleservers.Storage) []
map[string]interface{}{
"size_gb": size,
"iops": iops,
"auto_grow_enabled": storage.AutoGrow == mysqlflexibleservers.EnableStatusEnumEnabled,
"auto_grow_enabled": *storage.AutoGrow == servers.EnableStatusEnumEnabled,
},
}
}

func flattenDataSourceFlexibleServerSku(sku *mysqlflexibleservers.Sku) (string, error) {
if sku == nil || sku.Name == nil || sku.Tier == "" {
func flattenDataSourceFlexibleServerSku(sku *servers.Sku) (string, error) {
if sku == nil || sku.Name == "" || sku.Tier == "" {
return "", nil
}

var tier string
switch sku.Tier {
case mysqlflexibleservers.SkuTierBurstable:
case servers.SkuTierBurstable:
tier = "B"
case mysqlflexibleservers.SkuTierGeneralPurpose:
case servers.SkuTierGeneralPurpose:
tier = "GP"
case mysqlflexibleservers.SkuTierMemoryOptimized:
case servers.SkuTierMemoryOptimized:
tier = "MO"
default:
return "", fmt.Errorf("sku_name has unknown sku tier %s", sku.Tier)
}

return strings.Join([]string{tier, *sku.Name}, "_"), nil
return strings.Join([]string{tier, sku.Name}, "_"), nil
}

func flattenDataSourceArmServerMaintenanceWindow(input *mysqlflexibleservers.MaintenanceWindow) []interface{} {
func flattenDataSourceArmServerMaintenanceWindow(input *servers.MaintenanceWindow) []interface{} {
if input == nil || input.CustomWindow == nil || *input.CustomWindow == string(ServerMaintenanceWindowDisabled) {
return make([]interface{}, 0)
}

var dayOfWeek int32
var dayOfWeek int64
if input.DayOfWeek != nil {
dayOfWeek = *input.DayOfWeek
}
var startHour int32
var startHour int64
if input.StartHour != nil {
startHour = *input.StartHour
}
var startMinute int32
var startMinute int64
if input.StartMinute != nil {
startMinute = *input.StartMinute
}
Expand All @@ -299,8 +301,8 @@ func flattenDataSourceArmServerMaintenanceWindow(input *mysqlflexibleservers.Mai
}
}

func flattenDataSourceFlexibleServerHighAvailability(ha *mysqlflexibleservers.HighAvailability) []interface{} {
if ha == nil || ha.Mode == mysqlflexibleservers.HighAvailabilityModeDisabled {
func flattenDataSourceFlexibleServerHighAvailability(ha *servers.HighAvailability) []interface{} {
if ha == nil || *ha.Mode == servers.HighAvailabilityModeDisabled {
return []interface{}{}
}

Expand All @@ -311,7 +313,7 @@ func flattenDataSourceFlexibleServerHighAvailability(ha *mysqlflexibleservers.Hi

return []interface{}{
map[string]interface{}{
"mode": string(ha.Mode),
"mode": string(*ha.Mode),
"standby_availability_zone": zone,
},
}
Expand Down
Loading