mirror of
https://github.com/letic/terraform-provider-proxmox.git
synced 2024-10-03 01:01:05 +00:00
resourceLxcRead
This commit is contained in:
parent
73cd5e4a2c
commit
abe8e813d7
@ -20,7 +20,6 @@ func resourceLxc() *schema.Resource {
|
|||||||
"ostemplate": {
|
"ostemplate": {
|
||||||
Type: schema.TypeString,
|
Type: schema.TypeString,
|
||||||
Optional: true,
|
Optional: true,
|
||||||
ForceNew: true,
|
|
||||||
},
|
},
|
||||||
"arch": {
|
"arch": {
|
||||||
Type: schema.TypeString,
|
Type: schema.TypeString,
|
||||||
@ -405,6 +404,80 @@ func resourceLxcUpdate(d *schema.ResourceData, meta interface{}) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func resourceLxcRead(d *schema.ResourceData, meta interface{}) error {
|
func resourceLxcRead(d *schema.ResourceData, meta interface{}) error {
|
||||||
|
pconf := meta.(*providerConfiguration)
|
||||||
|
pmParallelBegin(pconf)
|
||||||
|
client := pconf.Client
|
||||||
|
_, _, vmID, err := parseResourceId(d.Id())
|
||||||
|
if err != nil {
|
||||||
|
pmParallelEnd(pconf)
|
||||||
|
d.SetId("")
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
vmr := pxapi.NewVmRef(vmID)
|
||||||
|
_, err = client.GetVmInfo(vmr)
|
||||||
|
if err != nil {
|
||||||
|
pmParallelEnd(pconf)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
config, err := pxapi.NewConfigLxcFromApi(vmr, client)
|
||||||
|
if err != nil {
|
||||||
|
pmParallelEnd(pconf)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
d.SetId(resourceId(vmr.Node(), "lxc", vmr.VmId()))
|
||||||
|
d.Set("target_node", vmr.Node())
|
||||||
|
|
||||||
|
d.Set("arch", config.Arch)
|
||||||
|
d.Set("bwlimit", config.BWLimit)
|
||||||
|
d.Set("cmode", config.CMode)
|
||||||
|
d.Set("console", config.Console)
|
||||||
|
d.Set("cores", config.Cores)
|
||||||
|
d.Set("cpulimit", config.CPULimit)
|
||||||
|
d.Set("cpuunits", config.CPUUnits)
|
||||||
|
d.Set("description", config.Description)
|
||||||
|
|
||||||
|
defaultFeatures := d.Get("features").(*schema.Set)
|
||||||
|
featuresWithDefaults := UpdateDeviceConfDefaults(config.Features, defaultFeatures)
|
||||||
|
d.Set("features", featuresWithDefaults)
|
||||||
|
|
||||||
|
d.Set("force", config.Force)
|
||||||
|
d.Set("hookscript", config.Hookscript)
|
||||||
|
d.Set("hostname", config.Hostname)
|
||||||
|
d.Set("ignore_unpack_errors", config.IgnoreUnpackErrors)
|
||||||
|
d.Set("lock", config.Lock)
|
||||||
|
d.Set("memory", config.Memory)
|
||||||
|
|
||||||
|
configMountpointSet := d.Get("mountpoint").(*schema.Set)
|
||||||
|
activeMountpointSet := UpdateDevicesSet(configMountpointSet, config.Mountpoints)
|
||||||
|
d.Set("mountpoint", activeMountpointSet)
|
||||||
|
|
||||||
|
d.Set("nameserver", config.Nameserver)
|
||||||
|
|
||||||
|
configNetworksSet := d.Get("network").(*schema.Set)
|
||||||
|
activeNetworksSet := UpdateDevicesSet(configNetworksSet, config.Networks)
|
||||||
|
d.Set("network", activeNetworksSet)
|
||||||
|
|
||||||
|
d.Set("onboot", config.OnBoot)
|
||||||
|
d.Set("ostemplate", config.Ostemplate)
|
||||||
|
d.Set("ostype", config.OsType)
|
||||||
|
d.Set("password", config.Password)
|
||||||
|
d.Set("pool", config.Pool)
|
||||||
|
d.Set("protection", config.Protection)
|
||||||
|
d.Set("restore", config.Restore)
|
||||||
|
d.Set("rootfs", config.RootFs)
|
||||||
|
d.Set("searchdomain", config.SearchDomain)
|
||||||
|
d.Set("ssh_public_keys", config.SSHPublicKeys)
|
||||||
|
d.Set("start", config.Start)
|
||||||
|
d.Set("startup", config.Startup)
|
||||||
|
d.Set("storage", config.Storage)
|
||||||
|
d.Set("swap", config.Swap)
|
||||||
|
d.Set("template", config.Template)
|
||||||
|
d.Set("tty", config.Tty)
|
||||||
|
d.Set("unique", config.Unique)
|
||||||
|
d.Set("unprivileged", config.Unprivileged)
|
||||||
|
d.Set("unused", config.Unused)
|
||||||
|
|
||||||
|
pmParallelEnd(pconf)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -615,11 +615,11 @@ func resourceVmQemuRead(d *schema.ResourceData, meta interface{}) error {
|
|||||||
d.Set("ipconfig1", config.Ipconfig1)
|
d.Set("ipconfig1", config.Ipconfig1)
|
||||||
// Disks.
|
// Disks.
|
||||||
configDisksSet := d.Get("disk").(*schema.Set)
|
configDisksSet := d.Get("disk").(*schema.Set)
|
||||||
activeDisksSet := updateDevicesSet(configDisksSet, config.QemuDisks)
|
activeDisksSet := UpdateDevicesSet(configDisksSet, config.QemuDisks)
|
||||||
d.Set("disk", activeDisksSet)
|
d.Set("disk", activeDisksSet)
|
||||||
// Networks.
|
// Networks.
|
||||||
configNetworksSet := d.Get("network").(*schema.Set)
|
configNetworksSet := d.Get("network").(*schema.Set)
|
||||||
activeNetworksSet := updateDevicesSet(configNetworksSet, config.QemuNetworks)
|
activeNetworksSet := UpdateDevicesSet(configNetworksSet, config.QemuNetworks)
|
||||||
d.Set("network", activeNetworksSet)
|
d.Set("network", activeNetworksSet)
|
||||||
// Deprecated single disk config.
|
// Deprecated single disk config.
|
||||||
d.Set("storage", config.Storage)
|
d.Set("storage", config.Storage)
|
||||||
@ -722,12 +722,13 @@ func DevicesSetToMap(devicesSet *schema.Set) pxapi.QemuDevices {
|
|||||||
|
|
||||||
// Update schema.TypeSet with new values comes from Proxmox API.
|
// Update schema.TypeSet with new values comes from Proxmox API.
|
||||||
// TODO: Maybe it's better to create a new Set instead add to current one.
|
// TODO: Maybe it's better to create a new Set instead add to current one.
|
||||||
func updateDevicesSet(
|
func UpdateDevicesSet(
|
||||||
devicesSet *schema.Set,
|
devicesSet *schema.Set,
|
||||||
devicesMap pxapi.QemuDevices,
|
devicesMap pxapi.QemuDevices,
|
||||||
) *schema.Set {
|
) *schema.Set {
|
||||||
|
|
||||||
configDevicesMap := DevicesSetToMap(devicesSet)
|
configDevicesMap := DevicesSetToMap(devicesSet)
|
||||||
|
|
||||||
activeDevicesMap := updateDevicesDefaults(devicesMap, configDevicesMap)
|
activeDevicesMap := updateDevicesDefaults(devicesMap, configDevicesMap)
|
||||||
|
|
||||||
for _, setConf := range devicesSet.List() {
|
for _, setConf := range devicesSet.List() {
|
||||||
|
33
proxmox/util.go
Normal file
33
proxmox/util.go
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
package proxmox
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strconv"
|
||||||
|
pxapi "github.com/Telmate/proxmox-api-go/proxmox"
|
||||||
|
"github.com/hashicorp/terraform/helper/schema"
|
||||||
|
)
|
||||||
|
|
||||||
|
func UpdateDeviceConfDefaults(
|
||||||
|
activeDeviceConf pxapi.QemuDevice,
|
||||||
|
defaultDeviceConf *schema.Set,
|
||||||
|
) *schema.Set {
|
||||||
|
defaultDeviceConfMap := defaultDeviceConf.List()[0].(map[string]interface{})
|
||||||
|
for key, _ := range defaultDeviceConfMap {
|
||||||
|
if deviceConfigValue, ok := activeDeviceConf[key]; ok {
|
||||||
|
defaultDeviceConfMap[key] = deviceConfigValue
|
||||||
|
switch deviceConfigValue.(type) {
|
||||||
|
case int:
|
||||||
|
sValue := strconv.Itoa(deviceConfigValue.(int))
|
||||||
|
bValue, err := strconv.ParseBool(sValue)
|
||||||
|
if err == nil {
|
||||||
|
defaultDeviceConfMap[key] = bValue
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
defaultDeviceConfMap[key] = deviceConfigValue
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
defaultDeviceConf.Remove(defaultDeviceConf.List()[0])
|
||||||
|
defaultDeviceConf.Add(defaultDeviceConfMap)
|
||||||
|
return defaultDeviceConf
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user