mirror of
https://github.com/letic/terraform-provider-proxmox.git
synced 2024-07-01 07:02:40 +00:00
Serial devices management
This commit is contained in:
parent
f6b0d92053
commit
5158d17a3c
|
@ -274,6 +274,22 @@ func resourceVmQemu() *schema.Resource {
|
||||||
return strings.TrimSpace(old) == strings.TrimSpace(new)
|
return strings.TrimSpace(old) == strings.TrimSpace(new)
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
"serial": &schema.Schema{
|
||||||
|
Type: schema.TypeSet,
|
||||||
|
Optional: true,
|
||||||
|
Elem: &schema.Resource{
|
||||||
|
Schema: map[string]*schema.Schema{
|
||||||
|
"id": &schema.Schema{
|
||||||
|
Type: schema.TypeInt,
|
||||||
|
Required: true,
|
||||||
|
},
|
||||||
|
"type": &schema.Schema{
|
||||||
|
Type: schema.TypeString,
|
||||||
|
Required: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
"os_type": {
|
"os_type": {
|
||||||
Type: schema.TypeString,
|
Type: schema.TypeString,
|
||||||
Optional: true,
|
Optional: true,
|
||||||
|
@ -375,6 +391,8 @@ func resourceVmQemuCreate(d *schema.ResourceData, meta interface{}) error {
|
||||||
qemuNetworks := DevicesSetToMap(networks)
|
qemuNetworks := DevicesSetToMap(networks)
|
||||||
disks := d.Get("disk").(*schema.Set)
|
disks := d.Get("disk").(*schema.Set)
|
||||||
qemuDisks := DevicesSetToMap(disks)
|
qemuDisks := DevicesSetToMap(disks)
|
||||||
|
serials := d.Get("serial").(*schema.Set)
|
||||||
|
qemuSerials := DevicesSetToMap(serials)
|
||||||
|
|
||||||
config := pxapi.ConfigQemu{
|
config := pxapi.ConfigQemu{
|
||||||
Name: vmName,
|
Name: vmName,
|
||||||
|
@ -390,6 +408,7 @@ func resourceVmQemuCreate(d *schema.ResourceData, meta interface{}) error {
|
||||||
QemuOs: d.Get("qemu_os").(string),
|
QemuOs: d.Get("qemu_os").(string),
|
||||||
QemuNetworks: qemuNetworks,
|
QemuNetworks: qemuNetworks,
|
||||||
QemuDisks: qemuDisks,
|
QemuDisks: qemuDisks,
|
||||||
|
QemuSerials: qemuSerials,
|
||||||
// Cloud-init.
|
// Cloud-init.
|
||||||
CIuser: d.Get("ciuser").(string),
|
CIuser: d.Get("ciuser").(string),
|
||||||
CIpassword: d.Get("cipassword").(string),
|
CIpassword: d.Get("cipassword").(string),
|
||||||
|
@ -534,6 +553,8 @@ func resourceVmQemuUpdate(d *schema.ResourceData, meta interface{}) error {
|
||||||
qemuDisks := DevicesSetToMap(configDisksSet)
|
qemuDisks := DevicesSetToMap(configDisksSet)
|
||||||
configNetworksSet := d.Get("network").(*schema.Set)
|
configNetworksSet := d.Get("network").(*schema.Set)
|
||||||
qemuNetworks := DevicesSetToMap(configNetworksSet)
|
qemuNetworks := DevicesSetToMap(configNetworksSet)
|
||||||
|
serials := d.Get("serial").(*schema.Set)
|
||||||
|
qemuSerials := DevicesSetToMap(serials)
|
||||||
|
|
||||||
config := pxapi.ConfigQemu{
|
config := pxapi.ConfigQemu{
|
||||||
Name: d.Get("name").(string),
|
Name: d.Get("name").(string),
|
||||||
|
@ -549,6 +570,7 @@ func resourceVmQemuUpdate(d *schema.ResourceData, meta interface{}) error {
|
||||||
QemuOs: d.Get("qemu_os").(string),
|
QemuOs: d.Get("qemu_os").(string),
|
||||||
QemuNetworks: qemuNetworks,
|
QemuNetworks: qemuNetworks,
|
||||||
QemuDisks: qemuDisks,
|
QemuDisks: qemuDisks,
|
||||||
|
QemuSerials: qemuSerials,
|
||||||
// Cloud-init.
|
// Cloud-init.
|
||||||
CIuser: d.Get("ciuser").(string),
|
CIuser: d.Get("ciuser").(string),
|
||||||
CIpassword: d.Get("cipassword").(string),
|
CIpassword: d.Get("cipassword").(string),
|
||||||
|
@ -664,6 +686,10 @@ func resourceVmQemuRead(d *schema.ResourceData, meta interface{}) error {
|
||||||
d.Set("vlan", config.QemuVlanTag)
|
d.Set("vlan", config.QemuVlanTag)
|
||||||
d.Set("mac", config.QemuMacAddr)
|
d.Set("mac", config.QemuMacAddr)
|
||||||
d.Set("pool", vmr.Pool())
|
d.Set("pool", vmr.Pool())
|
||||||
|
//Serials
|
||||||
|
configSerialsSet := d.Get("serial").(*schema.Set)
|
||||||
|
activeSerialSet := UpdateDevicesSet(configSerialsSet, config.QemuSerials)
|
||||||
|
d.Set("serial", activeSerialSet)
|
||||||
|
|
||||||
pmParallelEnd(pconf)
|
pmParallelEnd(pconf)
|
||||||
return nil
|
return nil
|
||||||
|
|
Loading…
Reference in New Issue
Block a user