From e66d2e1a83fa06a18cd7ccca671ec792d7b73ae9 Mon Sep 17 00:00:00 2001 From: Alexis Autret Date: Thu, 17 Oct 2024 15:49:31 +0200 Subject: [PATCH] Add efiBootloaderPath for dedicated server resource (and dedicated server update) --- ovh/data_dedicated_server.go | 6 +++++ ovh/data_dedicated_server_test.go | 2 ++ ovh/resource_dedicated_server_gen.go | 21 ++++++++++++++++ ...urce_dedicated_server_install_task_test.go | 25 +++++++++++-------- ovh/resource_dedicated_server_test.go | 19 +++++++++----- ovh/resource_dedicated_server_update.go | 6 +++++ ovh/resource_dedicated_server_update_test.go | 6 +++++ ovh/types_dedicated_server.go | 11 +++++--- website/docs/d/dedicated_server.html.markdown | 1 + website/docs/r/dedicated_server.html.markdown | 1 + .../r/dedicated_server_update.html.markdown | 2 ++ 11 files changed, 79 insertions(+), 21 deletions(-) diff --git a/ovh/data_dedicated_server.go b/ovh/data_dedicated_server.go index 9ce0af2fd..6bb9729d5 100644 --- a/ovh/data_dedicated_server.go +++ b/ovh/data_dedicated_server.go @@ -46,6 +46,11 @@ func dataSourceDedicatedServer() *schema.Resource { Computed: true, Description: "dedicated datacenter localisation (bhs1,bhs2,...)", }, + "efi_bootloader_path": { + Type: schema.TypeString, + Computed: true, + Description: "path of the EFI bootloader", + }, "ip": { Type: schema.TypeString, Computed: true, @@ -215,6 +220,7 @@ func dataSourceDedicatedServerRead(d *schema.ResourceData, meta interface{}) err d.Set("boot_script", ds.BootScript) d.Set("commercial_range", ds.CommercialRange) d.Set("datacenter", ds.Datacenter) + d.Set("efi_bootloader_path", ds.EfiBootloaderPath) d.Set("ip", ds.Ip) d.Set("link_speed", ds.LinkSpeed) d.Set("monitoring", ds.Monitoring) diff --git a/ovh/data_dedicated_server_test.go b/ovh/data_dedicated_server_test.go index a8addfe9a..810d40c99 100644 --- a/ovh/data_dedicated_server_test.go +++ b/ovh/data_dedicated_server_test.go @@ -29,6 +29,8 @@ func TestAccDedicatedServerDataSource_basic(t *testing.T) { "data.ovh_dedicated_server.server", "vnis.0.server_name", dedicated_server), resource.TestCheckResourceAttr( "data.ovh_dedicated_server.server", "boot_script", ""), + resource.TestCheckResourceAttrSet( + "data.ovh_dedicated_server.server", "efi_bootloader_path"), resource.TestCheckResourceAttrSet( "data.ovh_dedicated_server.server", "urn"), resource.TestCheckResourceAttrSet( diff --git a/ovh/resource_dedicated_server_gen.go b/ovh/resource_dedicated_server_gen.go index b46156355..61d9bc9f0 100644 --- a/ovh/resource_dedicated_server_gen.go +++ b/ovh/resource_dedicated_server_gen.go @@ -152,6 +152,13 @@ func DedicatedServerResourceSchema(ctx context.Context) schema.Schema { Description: "The display name of your dedicated server", MarkdownDescription: "The display name of your dedicated server", }, + "efi_bootloader_path": schema.StringAttribute{ + CustomType: ovhtypes.TfStringType{}, + Optional: true, + Computed: true, + Description: "Path of the EFI bootloader served on boot", + MarkdownDescription: "Path of the EFI bootloader served on boot", + }, "iam": schema.SingleNestedAttribute{ Attributes: map[string]schema.Attribute{ "display_name": schema.StringAttribute{ @@ -375,6 +382,7 @@ type DedicatedServerModel struct { Datacenter ovhtypes.TfStringValue `tfsdk:"datacenter" json:"datacenter"` Details DetailsValue `tfsdk:"details" json:"details"` DisplayName ovhtypes.TfStringValue `tfsdk:"display_name" json:"displayName"` + EfiBootloaderPath ovhtypes.TfStringValue `tfsdk:"efi_bootloader_path" json:"efiBootloaderPath"` Iam IamValue `tfsdk:"iam" json:"iam"` Ip ovhtypes.TfStringValue `tfsdk:"ip" json:"ip"` LinkSpeed ovhtypes.TfInt64Value `tfsdk:"link_speed" json:"linkSpeed"` @@ -435,6 +443,10 @@ func (v *DedicatedServerModel) MergeWith(other *DedicatedServerModel) { v.DisplayName = other.DisplayName } + if (v.EfiBootloaderPath.IsUnknown() || v.EfiBootloaderPath.IsNull()) && !other.EfiBootloaderPath.IsUnknown() { + v.EfiBootloaderPath = other.EfiBootloaderPath + } + if v.Iam.IsUnknown() && !other.Iam.IsUnknown() { v.Iam = other.Iam } else if !other.Iam.IsUnknown() { @@ -574,6 +586,7 @@ type DedicatedServerWritableModel struct { BootId *ovhtypes.TfInt64Value `tfsdk:"boot_id" json:"bootId,omitempty"` BootScript *ovhtypes.TfStringValue `tfsdk:"boot_script" json:"bootScript,omitempty"` Details *DetailsWritableValue `tfsdk:"details" json:"details,omitempty"` + EfiBootloaderPath *ovhtypes.TfStringValue `tfsdk:"efi_bootloader_path" json:"efiBootloaderPath,omitempty"` Monitoring *ovhtypes.TfBoolValue `tfsdk:"monitoring" json:"monitoring,omitempty"` NoIntervention *ovhtypes.TfBoolValue `tfsdk:"no_intervention" json:"noIntervention,omitempty"` PartitionSchemeName *ovhtypes.TfStringValue `tfsdk:"partition_scheme_name" json:"partitionSchemeName,omitempty"` @@ -596,6 +609,10 @@ func (v DedicatedServerModel) ToCreate() *DedicatedServerWritableModel { res.BootScript = &v.BootScript } + if !v.EfiBootloaderPath.IsUnknown() { + res.EfiBootloaderPath = &v.EfiBootloaderPath + } + if !v.Monitoring.IsUnknown() { res.Monitoring = &v.Monitoring } @@ -666,6 +683,10 @@ func (v DedicatedServerModel) ToUpdate() *DedicatedServerWritableModel { res.BootScript = &v.BootScript } + if !v.EfiBootloaderPath.IsUnknown() { + res.EfiBootloaderPath = &v.EfiBootloaderPath + } + if !v.Monitoring.IsUnknown() { res.Monitoring = &v.Monitoring } diff --git a/ovh/resource_dedicated_server_install_task_test.go b/ovh/resource_dedicated_server_install_task_test.go index 521b7c131..54fa3d57e 100644 --- a/ovh/resource_dedicated_server_install_task_test.go +++ b/ovh/resource_dedicated_server_install_task_test.go @@ -144,10 +144,11 @@ data ovh_dedicated_server_boots "harddisk" { } resource ovh_dedicated_server_update "server" { - service_name = data.ovh_dedicated_server_boots.harddisk.service_name - boot_id = data.ovh_dedicated_server_boots.harddisk.result[0] - monitoring = true - state = "ok" + service_name = data.ovh_dedicated_server_boots.harddisk.service_name + boot_id = data.ovh_dedicated_server_boots.harddisk.result[0] + monitoring = true + state = "ok" + efiBootloaderPath = "" } resource "ovh_me_installation_template" "debian" { @@ -186,10 +187,11 @@ data ovh_dedicated_server_boots "rescue" { } resource ovh_dedicated_server_update "server" { - service_name = data.ovh_dedicated_server_boots.harddisk.service_name - boot_id = data.ovh_dedicated_server_boots.harddisk.result[0] - monitoring = true - state = "ok" + service_name = data.ovh_dedicated_server_boots.harddisk.service_name + boot_id = data.ovh_dedicated_server_boots.harddisk.result[0] + monitoring = true + state = "ok" + efiBootloaderPath = "" } resource ovh_dedicated_server_install_task "server_install" { @@ -209,9 +211,10 @@ data ovh_dedicated_server_boots "harddisk" { } resource ovh_dedicated_server_update "server" { - service_name = data.ovh_dedicated_server_boots.harddisk.service_name - monitoring = true - state = "ok" + service_name = data.ovh_dedicated_server_boots.harddisk.service_name + monitoring = true + state = "ok" + efiBootloaderPath = "" } resource ovh_dedicated_server_install_task "server_install" { diff --git a/ovh/resource_dedicated_server_test.go b/ovh/resource_dedicated_server_test.go index c7c9384f2..d2bfabc6d 100644 --- a/ovh/resource_dedicated_server_test.go +++ b/ovh/resource_dedicated_server_test.go @@ -11,10 +11,11 @@ import ( func dedicatedServerResourceTestConfig(updated bool) string { var ( - monitoring = true - noIntervention = false - baseTemplate = "debian11_64" - displayName = "First display name" + monitoring = true + noIntervention = false + baseTemplate = "debian11_64" + displayName = "First display name" + efiBootloaderPath = "" ) if updated { @@ -22,6 +23,7 @@ func dedicatedServerResourceTestConfig(updated bool) string { noIntervention = true baseTemplate = "debian12_64" displayName = "Second display name" + efiBootloaderPath = "\\efi\\debian\\grubx64.efi" } return fmt.Sprintf(` @@ -33,6 +35,7 @@ func dedicatedServerResourceTestConfig(updated bool) string { no_intervention = %t display_name = "%s" template_name = "%s" + efi_bootloader_path = "%s" plan = [ { @@ -84,7 +87,7 @@ func dedicatedServerResourceTestConfig(updated bool) string { } ] } - `, monitoring, noIntervention, displayName, baseTemplate) + `, monitoring, noIntervention, displayName, baseTemplate, efiBootloaderPath) } func TestAccDedicatedServer_basic(t *testing.T) { @@ -107,6 +110,8 @@ func TestAccDedicatedServer_basic(t *testing.T) { "ovh_dedicated_server.server", "iam.display_name", "First display name"), resource.TestCheckResourceAttr( "ovh_dedicated_server.server", "os", "debian11_64"), + resource.TestCheckResourceAttr( + "ovh_dedicated_server.server", "efi_bootloader_path", ""), ), }, { @@ -122,6 +127,8 @@ func TestAccDedicatedServer_basic(t *testing.T) { "ovh_dedicated_server.server", "iam.display_name", "Second display name"), resource.TestCheckResourceAttr( "ovh_dedicated_server.server", "os", "debian12_64"), + resource.TestCheckResourceAttr( + "ovh_dedicated_server.server", "efi_bootloader_path", "\\efi\\debian\\grubx64.efi"), ), }, { @@ -130,7 +137,7 @@ func TestAccDedicatedServer_basic(t *testing.T) { ImportStateVerify: true, ImportStateVerifyIdentifierAttribute: "service_name", ImportStateVerifyIgnore: []string{ - "display_name", "order", "ovh_subsidiary", "plan", "plan_option", "template_name", + "display_name", "order", "ovh_subsidiary", "plan", "plan_option", "template_name", "efi_bootloader_path", }, ImportStateIdFunc: func(s *terraform.State) (string, error) { service, ok := s.RootModule().Resources["ovh_dedicated_server.server"] diff --git a/ovh/resource_dedicated_server_update.go b/ovh/resource_dedicated_server_update.go index 4abeb9312..747442b2e 100644 --- a/ovh/resource_dedicated_server_update.go +++ b/ovh/resource_dedicated_server_update.go @@ -34,6 +34,11 @@ func resourceDedicatedServerUpdate() *schema.Resource { Description: "The boot script of your dedicated server.", Optional: true, }, + "efi_bootloader_path": { + Type: schema.TypeString, + Description: "The path of the EFI bootloader.", + Optional: true, + }, "monitoring": { Type: schema.TypeBool, Computed: true, @@ -113,6 +118,7 @@ func resourceDedicatedServerUpdateRead(ctx context.Context, d *schema.ResourceDa d.Set("boot_id", ds.BootId) d.Set("boot_script", ds.BootScript) + d.Set("efi_bootloader_path", ds.EfiBootloaderPath) d.Set("monitoring", ds.Monitoring) d.Set("state", ds.State) d.Set("display_name", ds.DisplayName) diff --git a/ovh/resource_dedicated_server_update_test.go b/ovh/resource_dedicated_server_update_test.go index cfdb5c658..53d11536b 100644 --- a/ovh/resource_dedicated_server_update_test.go +++ b/ovh/resource_dedicated_server_update_test.go @@ -26,6 +26,8 @@ func TestAccDedicatedServerUpdate_basic(t *testing.T) { "ovh_dedicated_server_update.server", "state", "ok"), resource.TestCheckResourceAttr( "ovh_dedicated_server_update.server", "boot_script", ""), + resource.TestCheckResourceAttr( + "ovh_dedicated_server_update.server", "efi_bootloader_path", "\\efi\\boot\\bootx64.efi"), resource.TestCheckResourceAttr( "ovh_dedicated_server_update.server", "display_name", "An awesome display name"), ), @@ -40,6 +42,8 @@ func TestAccDedicatedServerUpdate_basic(t *testing.T) { "ovh_dedicated_server_update.server", "state", "ok"), resource.TestCheckResourceAttr( "ovh_dedicated_server_update.server", "boot_script", ""), + resource.TestCheckResourceAttr( + "ovh_dedicated_server_update.server", "efi_bootloader_path", "\\efi\\boot\\bootx64.efi"), resource.TestCheckResourceAttr( "ovh_dedicated_server_update.server", "display_name", "An awesome display name restored"), ), @@ -76,6 +80,7 @@ resource ovh_dedicated_server_update "server" { monitoring = true state = "ok" display_name = "An awesome display name" + efi_bootloader_path = "\\efi\\boot\\bootx64.efi" } output test { @@ -95,6 +100,7 @@ resource ovh_dedicated_server_update "server" { monitoring = false state = "ok" display_name = "An awesome display name restored" + efi_bootloader_path = "\\efi\\boot\\bootx64.efi" } output test { diff --git a/ovh/types_dedicated_server.go b/ovh/types_dedicated_server.go index 9738212ab..e344335cd 100644 --- a/ovh/types_dedicated_server.go +++ b/ovh/types_dedicated_server.go @@ -14,6 +14,7 @@ type DedicatedServer struct { BootScript string `json:"bootScript"` CommercialRange string `json:"commercialRange"` Datacenter string `json:"datacenter"` + EfiBootloaderPath string `json:"efiBootloaderPath"` Ip string `json:"ip"` LinkSpeed int `json:"linkSpeed"` Monitoring bool `json:"monitoring"` @@ -40,15 +41,17 @@ func (ds DedicatedServer) String() string { } type DedicatedServerUpdateOpts struct { - BootId *int64 `json:"bootId,omitempty"` - BootScript *string `json:"bootScript,omitempty"` - Monitoring *bool `json:"monitoring,omitempty"` - State *string `json:"state,omitempty"` + BootId *int64 `json:"bootId,omitempty"` + BootScript *string `json:"bootScript,omitempty"` + EfiBootloaderPath *string `json:"efiBootloaderPath,omitempty"` + Monitoring *bool `json:"monitoring,omitempty"` + State *string `json:"state,omitempty"` } func (opts *DedicatedServerUpdateOpts) FromResource(d *schema.ResourceData) *DedicatedServerUpdateOpts { opts.BootId = helpers.GetNilInt64PointerFromData(d, "boot_id") opts.BootScript = helpers.GetNilStringPointerFromData(d, "boot_script") + opts.EfiBootloaderPath = helpers.GetNilStringPointerFromData(d, "efi_bootloader_path") opts.Monitoring = helpers.GetNilBoolPointerFromData(d, "monitoring") opts.State = helpers.GetNilStringPointerFromData(d, "state") return opts diff --git a/website/docs/d/dedicated_server.html.markdown b/website/docs/d/dedicated_server.html.markdown index 00da3ff02..a2416b2e2 100644 --- a/website/docs/d/dedicated_server.html.markdown +++ b/website/docs/d/dedicated_server.html.markdown @@ -28,6 +28,7 @@ In addition, the following attributes are exported: * `urn` - URN of the dedicated server instance * `commercial_range` - Dedicated server commercial range * `datacenter` - Dedicated datacenter localisation (bhs1,bhs2,...) +* `efi_bootloader_path` - Path of the EFI bootloader of the dedicated server * `ip` - Dedicated server ip (IPv4) * `ips` - Dedicated server ip blocks * `link_speed` - Link speed of the server diff --git a/website/docs/r/dedicated_server.html.markdown b/website/docs/r/dedicated_server.html.markdown index bd3b91401..48599c185 100644 --- a/website/docs/r/dedicated_server.html.markdown +++ b/website/docs/r/dedicated_server.html.markdown @@ -142,6 +142,7 @@ The `user_metadata` block supports many arguments, here is a non-exhaustive list * `tags` - Resource tags. Tags that were internally computed are prefixed with `ovh:` * `boot_id` - Boot id of the server * `boot_script` - Boot script of the server +* `efi_bootloader_path` - Path of the EFI bootloader * `link_speed` - Link speed of the server * `monitoring` - Icmp monitoring state * `no_intervention` - Prevent datacenter intervention diff --git a/website/docs/r/dedicated_server_update.html.markdown b/website/docs/r/dedicated_server_update.html.markdown index 30f68bcaf..5d511710b 100644 --- a/website/docs/r/dedicated_server_update.html.markdown +++ b/website/docs/r/dedicated_server_update.html.markdown @@ -36,6 +36,7 @@ The following arguments are supported: * `service_name` - (Required) The service_name of your dedicated server. * `boot_id` - boot id of the server * `boot_script` - boot script of the server +* `efi_bootloader_path` - path of the EFI bootloader * `monitoring` - Icmp monitoring state * `state` - error, hacked, hackedBlocked, ok * `display_name` - display name of the dedicated server @@ -46,6 +47,7 @@ The following attributes are exported: * `service_name` - See Argument Reference above. * `boot_id` - See Argument Reference above. +* `efi_bootloader_path` - See Argument Reference above. * `monitoring` - See Argument Reference above. * `state` - See Argument Reference above. * `display_name` - See Argument Reference above.