Add patch for compute sep_id and pool

gos_tech_4.4.3
stSolo 3 years ago
parent 81443a3d02
commit fc32db30b6

@ -34,6 +34,7 @@ package kvmvm
import ( import (
"context" "context"
"encoding/json" "encoding/json"
"errors"
"fmt" "fmt"
// "net/url" // "net/url"
@ -43,6 +44,7 @@ import (
"github.com/hashicorp/terraform-plugin-sdk/v2/diag" "github.com/hashicorp/terraform-plugin-sdk/v2/diag"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
// "github.com/hashicorp/terraform-plugin-sdk/helper/validation"
) )
// Parse list of all disks from API compute/get into a list of "extra disks" attached to this compute // Parse list of all disks from API compute/get into a list of "extra disks" attached to this compute
@ -105,6 +107,16 @@ func parseBootDiskId(disks []DiskRecord) uint {
return 0 return 0
} }
func findBootDisk(disks []DiskRecord) (*DiskRecord, error) {
for _, d := range disks {
if d.Type == "B" {
return &d, nil
}
}
return nil, errors.New("boot disk not found")
}
// Parse the list of interfaces from compute/get response into a list of networks // Parse the list of interfaces from compute/get response into a list of networks
// attached to this compute // attached to this compute
func parseComputeInterfacesToNetworks(ifaces []InterfaceRecord) []interface{} { func parseComputeInterfacesToNetworks(ifaces []InterfaceRecord) []interface{} {
@ -131,7 +143,7 @@ func parseComputeInterfacesToNetworks(ifaces []InterfaceRecord) []interface{} {
return result return result
} }
func flattenCompute(d *schema.ResourceData, compFacts string) error { func flattenCompute(d *schema.ResourceData, compFacts string) diag.Diagnostics {
// This function expects that compFacts string contains response from API compute/get, // This function expects that compFacts string contains response from API compute/get,
// i.e. detailed information about compute instance. // i.e. detailed information about compute instance.
// //
@ -141,7 +153,7 @@ func flattenCompute(d *schema.ResourceData, compFacts string) error {
log.Debugf("flattenCompute: ready to unmarshal string %s", compFacts) log.Debugf("flattenCompute: ready to unmarshal string %s", compFacts)
err := json.Unmarshal([]byte(compFacts), &model) err := json.Unmarshal([]byte(compFacts), &model)
if err != nil { if err != nil {
return err return diag.FromErr(err)
} }
log.Debugf("flattenCompute: ID %d, RG ID %d", model.ID, model.RgID) log.Debugf("flattenCompute: ID %d, RG ID %d", model.ID, model.RgID)
@ -157,8 +169,6 @@ func flattenCompute(d *schema.ResourceData, compFacts string) error {
d.Set("cpu", model.Cpu) d.Set("cpu", model.Cpu)
d.Set("ram", model.Ram) d.Set("ram", model.Ram)
// d.Set("boot_disk_size", model.BootDiskSize) - bootdiskSize key in API compute/get is always zero, so we set boot_disk_size in another way // d.Set("boot_disk_size", model.BootDiskSize) - bootdiskSize key in API compute/get is always zero, so we set boot_disk_size in another way
d.Set("boot_disk_size", parseBootDiskSize(model.Disks))
d.Set("boot_disk_id", parseBootDiskId(model.Disks)) // we may need boot disk ID in resize operations
d.Set("image_id", model.ImageID) d.Set("image_id", model.ImageID)
d.Set("description", model.Desc) d.Set("description", model.Desc)
d.Set("cloud_init", "applied") // NOTE: for existing compute we hard-code this value as an indicator for DiffSuppress fucntion d.Set("cloud_init", "applied") // NOTE: for existing compute we hard-code this value as an indicator for DiffSuppress fucntion
@ -171,24 +181,34 @@ func flattenCompute(d *schema.ResourceData, compFacts string) error {
d.Set("started", false) d.Set("started", false)
} }
bootDisk, err := findBootDisk(model.Disks)
if err != nil {
return diag.FromErr(err)
}
d.Set("boot_disk_size", bootDisk.SizeMax)
d.Set("boot_disk_id", bootDisk.ID) // we may need boot disk ID in resize operations
d.Set("sep_id", bootDisk.SepID)
d.Set("pool", bootDisk.Pool)
if len(model.Disks) > 0 { if len(model.Disks) > 0 {
log.Debugf("flattenCompute: calling parseComputeDisksToExtraDisks for %d disks", len(model.Disks)) log.Debugf("flattenCompute: calling parseComputeDisksToExtraDisks for %d disks", len(model.Disks))
if err = d.Set("extra_disks", parseComputeDisksToExtraDisks(model.Disks)); err != nil { if err = d.Set("extra_disks", parseComputeDisksToExtraDisks(model.Disks)); err != nil {
return err return diag.FromErr(err)
} }
} }
if len(model.Interfaces) > 0 { if len(model.Interfaces) > 0 {
log.Debugf("flattenCompute: calling parseComputeInterfacesToNetworks for %d interfaces", len(model.Interfaces)) log.Debugf("flattenCompute: calling parseComputeInterfacesToNetworks for %d interfaces", len(model.Interfaces))
if err = d.Set("network", parseComputeInterfacesToNetworks(model.Interfaces)); err != nil { if err = d.Set("network", parseComputeInterfacesToNetworks(model.Interfaces)); err != nil {
return err return diag.FromErr(err)
} }
} }
if len(model.OsUsers) > 0 { if len(model.OsUsers) > 0 {
log.Debugf("flattenCompute: calling parseOsUsers for %d logins", len(model.OsUsers)) log.Debugf("flattenCompute: calling parseOsUsers for %d logins", len(model.OsUsers))
if err = d.Set("os_users", parseOsUsers(model.OsUsers)); err != nil { if err = d.Set("os_users", parseOsUsers(model.OsUsers)); err != nil {
return err return diag.FromErr(err)
} }
} }
@ -204,7 +224,7 @@ func dataSourceComputeRead(ctx context.Context, d *schema.ResourceData, m interf
return diag.FromErr(err) return diag.FromErr(err)
} }
return diag.FromErr(flattenCompute(d, compFacts)) return flattenCompute(d, compFacts)
} }
func DataSourceCompute() *schema.Resource { func DataSourceCompute() *schema.Resource {

@ -85,6 +85,14 @@ func resourceComputeCreate(ctx context.Context, d *schema.ResourceData, m interf
urlValues.Add("desc", argVal.(string)) urlValues.Add("desc", argVal.(string))
} }
if sepID, ok := d.GetOk("sep_id"); ok {
urlValues.Add("sepId", strconv.Itoa(sepID.(int)))
}
if pool, ok := d.GetOk("pool"); ok {
urlValues.Add("pool", pool.(string))
}
/* /*
sshKeysVal, sshKeysSet := d.GetOk("ssh_keys") sshKeysVal, sshKeysSet := d.GetOk("ssh_keys")
if sshKeysSet { if sshKeysSet {
@ -178,8 +186,8 @@ func resourceComputeRead(ctx context.Context, d *schema.ResourceData, m interfac
return nil return nil
} }
if err = flattenCompute(d, compFacts); err != nil { if diagnostic := flattenCompute(d, compFacts); diagnostic != nil {
return diag.FromErr(err) return diagnostic
} }
log.Debugf("resourceComputeRead: after flattenCompute: Compute ID %s, name %q, RG ID %d", log.Debugf("resourceComputeRead: after flattenCompute: Compute ID %s, name %q, RG ID %d",
@ -427,6 +435,22 @@ func ResourceCompute() *schema.Resource {
Description: "This compute instance boot disk size in GB. Make sure it is large enough to accomodate selected OS image.", Description: "This compute instance boot disk size in GB. Make sure it is large enough to accomodate selected OS image.",
}, },
"sep_id": {
Type: schema.TypeInt,
Optional: true,
Computed: true,
ForceNew: true,
Description: "ID of SEP to create bootDisk on. Uses image's sepId if not set.",
},
"pool": {
Type: schema.TypeString,
Optional: true,
Computed: true,
ForceNew: true,
Description: "Pool to use if sepId is set, can be also empty if needed to be chosen by system.",
},
"extra_disks": { "extra_disks": {
Type: schema.TypeSet, Type: schema.TypeSet,
Optional: true, Optional: true,

Loading…
Cancel
Save