/
create_vm.go
96 lines (83 loc) · 3.06 KB
/
create_vm.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
package vms
import (
"context"
"fmt"
"time"
"github.com/awlsring/terraform-provider-proxmox/internal/service"
vt "github.com/awlsring/terraform-provider-proxmox/proxmox/qemu/vms/types"
"github.com/awlsring/terraform-provider-proxmox/proxmox/utils"
"github.com/hashicorp/terraform-plugin-log/tflog"
)
func (r *virtualMachineResource) routeCreateVm(ctx context.Context, plan *vt.VirtualMachineResourceModel) error {
tflog.Debug(ctx, "route virtual machine creation method")
switch true {
case plan.Clone != nil:
return r.clone(ctx, plan)
case plan.ISO != nil:
return r.iso(ctx, plan)
default:
tflog.Debug(ctx, "No valid init options provided")
return fmt.Errorf("no valid init options provided")
}
}
func (r *virtualMachineResource) clone(ctx context.Context, plan *vt.VirtualMachineResourceModel) error {
tflog.Debug(ctx, "clone virtual machine creation method")
node := plan.Node.ValueString()
vmId := int(plan.ID.ValueInt64())
err := r.client.CloneVirtualMachine(ctx, &service.CloneVirtualMachineInput{
Node: node,
VmId: vmId,
Source: int(plan.Clone.Source.ValueInt64()),
FullClone: plan.Clone.FullClone.ValueBool(),
Storage: utils.OptionalToPointerString(plan.Clone.Storage.ValueString()),
Description: utils.OptionalToPointerString(plan.Description.ValueString()),
Name: utils.OptionalToPointerString(plan.Name.ValueString()),
ResourcePool: utils.OptionalToPointerString(plan.ResourcePool.ValueString()),
})
if err != nil {
tflog.Error(ctx, "clone recieved error: "+err.Error())
return err
}
// wait till clone is complete
err = r.waitForLock(ctx, node, vmId, r.timeouts.Clone)
if err != nil {
tflog.Error(ctx, "clone recieved error: "+err.Error())
return err
}
tflog.Debug(ctx, "clone virtual machine complete")
return nil
}
func (r *virtualMachineResource) iso(ctx context.Context, plan *vt.VirtualMachineResourceModel) error {
tflog.Debug(ctx, "iso virtual machine creation method")
err := r.client.CreateVirtualMachineIso(ctx, &service.CreateVirtualMachineIsoInput{
Node: plan.Node.ValueString(),
VmId: int(plan.ID.ValueInt64()),
IsoStorage: plan.ISO.Storage.ValueString(),
IsoImage: plan.ISO.Image.ValueString(),
Name: utils.OptionalToPointerString(plan.Name.ValueString()),
Description: utils.OptionalToPointerString(plan.Description.ValueString()),
ResourcePool: utils.OptionalToPointerString(plan.ResourcePool.ValueString()),
})
if err != nil {
return nil
}
return nil
}
func (r *virtualMachineResource) waitForLock(ctx context.Context, node string, vmId int, timeout int64) error {
tflog.Debug(ctx, "waiting lock to release...")
deadline := setDeadline(timeout)
for {
status, err := r.client.GetVirtualMachineStatus(ctx, node, vmId)
if err != nil {
tflog.Error(ctx, "error: "+err.Error())
if time.Now().After(deadline) {
return fmt.Errorf("timeout waiting for lock to release")
}
} else if !status.HasLock() {
break
}
tflog.Debug(ctx, "lock is still active, waiting 5 seconds...")
time.Sleep(5 * time.Second)
}
return nil
}