diff --git a/CHANGELOG.md b/CHANGELOG.md index c2545a85c..812a319a0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,12 +2,18 @@ ## .Next (Not Released) +FEATURES: + +- `resource/vsphere_virtual_machine`: Adds ability to add `usb_controller` to virtual machine on creation or clone. + [#2280](https://github.com/hashicorp/terraform-provider-vsphere/pull/2280) +- `data/vsphere_virtual_machine`: Adds ability read `usb_controller` on virtual machine; will return `true` or `false` based on the configuration. + [#2280](https://github.com/hashicorp/terraform-provider-vsphere/pull/2280) + CHORE: - `provider`: Updated `golang/go` to v1.22.8. ([#2289](https://github.com/terraform-providers/terraform-provider-vsphere/pull/2289)) - ## 2.10.0 (October 16, 2024) FEATURES: diff --git a/vsphere/data_source_vsphere_virtual_machine.go b/vsphere/data_source_vsphere_virtual_machine.go index 607d6e56e..b3f6eebfd 100644 --- a/vsphere/data_source_vsphere_virtual_machine.go +++ b/vsphere/data_source_vsphere_virtual_machine.go @@ -170,6 +170,20 @@ func dataSourceVSphereVirtualMachine() *schema.Resource { Computed: true, Description: "Indicates whether a virtual Trusted Platform Module (TPM) device is present on the virtual machine.", }, + "usb_controller": { + Type: schema.TypeList, + Computed: true, + Description: "List of virtual USB controllers present on the virtual machine, including their versions.", + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "version": { + Type: schema.TypeString, + Computed: true, + Description: "The version of the USB controller.", + }, + }, + }, + }, } // Merge the VirtualMachineConfig structure so that we can include the number of @@ -298,6 +312,24 @@ func dataSourceVSphereVirtualMachineRead(d *schema.ResourceData, meta interface{ } _ = d.Set("vtpm_present", isVTPMPresent) + var usbControllers []map[string]interface{} + for _, dev := range props.Config.Hardware.Device { + switch dev.(type) { + case *types.VirtualUSBController: + usbControllers = append(usbControllers, map[string]interface{}{ + "version": "2.x", + }) + case *types.VirtualUSBXHCIController: + usbControllers = append(usbControllers, map[string]interface{}{ + "version": "3.x", + }) + } + } + + if err := d.Set("usb_controller", usbControllers); err != nil { + return fmt.Errorf("error setting usb_controller: %s", err) + } + log.Printf("[DEBUG] VM search for %q completed successfully (UUID %q)", name, props.Config.Uuid) return nil } diff --git a/vsphere/resource_vsphere_virtual_machine.go b/vsphere/resource_vsphere_virtual_machine.go index c0b47f982..1272b7277 100644 --- a/vsphere/resource_vsphere_virtual_machine.go +++ b/vsphere/resource_vsphere_virtual_machine.go @@ -74,6 +74,8 @@ https://www.terraform.io/docs/commands/taint.html const questionCheckIntervalSecs = 5 +var usbControllerVersions = []string{"2.0", "3.1", "3.2"} + func resourceVSphereVirtualMachine() *schema.Resource { s := map[string]*schema.Schema{ "resource_pool_id": { @@ -300,6 +302,22 @@ func resourceVSphereVirtualMachine() *schema.Resource { }, }, }, + "usb_controller": { + Type: schema.TypeList, + Optional: true, + Description: "A specification for a USB controller on the virtual machine.", + Elem: &schema.Resource{ + Schema: map[string]*schema.Schema{ + "usb_version": { + Type: schema.TypeString, + Optional: true, + Default: "2.0", + Description: "The version of the USB controller.", + ValidateFunc: validation.StringInSlice(usbControllerVersions, false), + }, + }, + }, + }, vSphereTagAttributeKey: tagsSchema(), customattribute.ConfigKey: customattribute.ConfigSchema(), } @@ -629,6 +647,23 @@ func resourceVSphereVirtualMachineRead(d *schema.ResourceData, meta interface{}) _ = d.Set("vtpm_present", isVTPMPresent) + // Set the USB controllers for the virtual machine. + usbControllers := d.Get("usb_controller").([]interface{}) + var desiredUSBVersions []string + for _, usbController := range usbControllers { + controller := usbController.(map[string]interface{}) + desiredUSBVersions = append(desiredUSBVersions, controller["usb_version"].(string)) + } + + usbControllersState, err := readUSBControllers(vprops.Config, desiredUSBVersions) + if err != nil { + return fmt.Errorf("error reading USB controllers: %s", err) + } + + if err := d.Set("usb_controller", usbControllersState); err != nil { + return fmt.Errorf("error setting usb_controller: %s", err) + } + log.Printf("[DEBUG] %s: Read complete", resourceVSphereVirtualMachineIDString(d)) return nil } @@ -744,8 +779,8 @@ func resourceVSphereVirtualMachineUpdate(d *schema.ResourceData, meta interface{ return err } + // Virtual Trusted Platform Module (vTPM) device. if d.HasChange("vtpm") { - spec.DeviceChange = append(spec.DeviceChange, &types.VirtualDeviceConfigSpec{ Operation: types.VirtualDeviceConfigSpecOperationAdd, Device: &types.VirtualTPM{ @@ -756,6 +791,156 @@ func resourceVSphereVirtualMachineUpdate(d *schema.ResourceData, meta interface{ }) } + // USB controller devices. Check for changes and apply them. + if d.HasChange("usb_controller") { + old, new := d.GetChange("usb_controller") + oldUSB := old.([]interface{}) + newUSB := new.([]interface{}) + + // Initialize a key counter. + keyCounter := -100 + + // Initialize controller presence flags. + usb2ControllerPresent := false + usb3ControllerPresent := false + + // Map to store existing USB controllers and their keys. + existingUSBControllers := make(map[string]int32) + + // Check for existing USB controllers and store their keys. + for _, dev := range vprops.Config.Hardware.Device { + switch controller := dev.(type) { + case *types.VirtualUSBController: + usb2ControllerPresent = true + existingUSBControllers["2.0"] = controller.Key + case *types.VirtualUSBXHCIController: + usb3ControllerPresent = true + existingUSBControllers["3.x"] = controller.Key + } + } + + // Remove USB controllers that are no longer in the configuration. + for _, oldUSBControllerInterface := range oldUSB { + oldUSBController := oldUSBControllerInterface.(map[string]interface{}) + oldUSBVersion := oldUSBController["usb_version"].(string) + + found := false + for _, newUSBControllerInterface := range newUSB { + newUSBController := newUSBControllerInterface.(map[string]interface{}) + newUSBVersion := newUSBController["usb_version"].(string) + if oldUSBVersion == newUSBVersion { + found = true + break + } + } + + if !found { + var device types.BaseVirtualDevice + switch oldUSBVersion { + case "2.0": + if key, ok := existingUSBControllers["2.0"]; ok { + device = &types.VirtualUSBController{ + VirtualController: types.VirtualController{ + VirtualDevice: types.VirtualDevice{ + Key: key, + }, + }, + } + } + case "3.1", "3.2": + if key, ok := existingUSBControllers["3.x"]; ok { + device = &types.VirtualUSBXHCIController{ + VirtualController: types.VirtualController{ + VirtualDevice: types.VirtualDevice{ + Key: key, + }, + }, + } + } + default: + return fmt.Errorf("unsupported USB version: %s", oldUSBVersion) + } + + if device != nil { + // Power off the virtual machine before removing the USB controller. + if vprops.Runtime.PowerState != types.VirtualMachinePowerStatePoweredOff { + log.Printf("[DEBUG] Powering off VM to remove USB controller: %s", oldUSBVersion) + timeout := d.Get("shutdown_wait_timeout").(int) + force := d.Get("force_power_off").(bool) + if err := virtualmachine.GracefulPowerOff(client, vm, timeout, force); err != nil { + return fmt.Errorf("error powering off virtual machine: %s", err) + } + } + + spec.DeviceChange = append(spec.DeviceChange, &types.VirtualDeviceConfigSpec{ + Operation: types.VirtualDeviceConfigSpecOperationRemove, + Device: device, + }) + log.Printf("[DEBUG] Removed USB controller: %s", oldUSBVersion) + } + } + } + + // Add new USB controller devices. + for _, usbControllerInterface := range newUSB { + usbController := usbControllerInterface.(map[string]interface{}) + usbVersion := usbController["usb_version"].(string) + + var ehciEnabled *bool + var device types.BaseVirtualDevice + + switch usbVersion { + case "2.0": + if usb2ControllerPresent { + log.Printf("[DEBUG] USB 2.0 controller already exists, skipping addition") + continue + } + usb2ControllerPresent = true + enabled := true + ehciEnabled = &enabled + device = &types.VirtualUSBController{ + VirtualController: types.VirtualController{ + VirtualDevice: types.VirtualDevice{ + Key: int32(keyCounter), + }, + }, + EhciEnabled: ehciEnabled, + } + case "3.1", "3.2": + if usb3ControllerPresent { + log.Printf("[DEBUG] USB 3.x controller already exists, skipping addition") + continue + } + usb3ControllerPresent = true + device = &types.VirtualUSBXHCIController{ + VirtualController: types.VirtualController{ + VirtualDevice: types.VirtualDevice{ + Key: int32(keyCounter), + }, + }, + } + + default: + return fmt.Errorf("unsupported USB version: %s", usbVersion) + } + + spec.DeviceChange = append(spec.DeviceChange, &types.VirtualDeviceConfigSpec{ + Operation: types.VirtualDeviceConfigSpecOperationAdd, + Device: device, + }) + log.Printf("[DEBUG] Added USB controller: %s", usbVersion) + keyCounter-- + } + + // Power on the virtual machine after adding the USB controller devices. + if vprops.Runtime.PowerState != types.VirtualMachinePowerStatePoweredOn { + log.Printf("[DEBUG] Powering on VM after USB controller changes") + if err := virtualmachine.PowerOn(vm, timeout); err != nil { + return fmt.Errorf("error powering on virtual machine: %s", err) + } + } + } + // Only carry out the reconfigure if we actually have a change to process. cv := virtualmachine.GetHardwareVersionNumber(vprops.Config.Version) tv := d.Get("hardware_version").(int) @@ -1090,6 +1275,8 @@ func resourceVSphereVirtualMachineCustomizeDiff(_ context.Context, d *schema.Res _ = d.ForceNew(k) } } + + return nil } // Validate hardware version changes. @@ -1106,6 +1293,11 @@ func resourceVSphereVirtualMachineCustomizeDiff(_ context.Context, d *schema.Res return err } + // Call the USB controller diff customization function + if err := resourceVSphereVirtualMachineCustomizeDiffUSBController(d, meta); err != nil { + return err + } + log.Printf("[DEBUG] %s: Diff customization and validation complete", resourceVSphereVirtualMachineIDString(d)) return nil } @@ -1414,6 +1606,7 @@ func resourceVSphereVirtualMachineCreateBareStandard( VmPathName: fmt.Sprintf("[%s]", ds.Name()), } + // Add virtual Trusted Platform Module (vTPM) device. if vtpms, ok := d.GetOk("vtpm"); ok && len(vtpms.([]interface{})) > 0 { spec.DeviceChange = append(spec.DeviceChange, &types.VirtualDeviceConfigSpec{ Operation: types.VirtualDeviceConfigSpecOperationAdd, @@ -1425,6 +1618,56 @@ func resourceVSphereVirtualMachineCreateBareStandard( }) } + // Add USB controller devices. + if usb, ok := d.GetOk("usb_controller"); ok && len(usb.([]interface{})) > 0 { + var usb2ControllerSpecified bool + var usb3xControllerSpecified bool + for _, usbControllerInterface := range usb.([]interface{}) { + usbController := usbControllerInterface.(map[string]interface{}) + usbVersion := usbController["usb_version"].(string) + + var ehciEnabled *bool + var device types.BaseVirtualDevice + + switch usbVersion { + case "2.0": + if usb2ControllerSpecified { + return nil, fmt.Errorf("only one USB 2.0 controller can be specified") + } + usb2ControllerSpecified = true + enabled := true + ehciEnabled = &enabled + device = &types.VirtualUSBController{ + VirtualController: types.VirtualController{ + VirtualDevice: types.VirtualDevice{ + Key: -1, + }, + }, + EhciEnabled: ehciEnabled, + } + case "3.1", "3.2": + if usb3xControllerSpecified { + return nil, fmt.Errorf("only one USB 3.x controller (3.1 or 3.2) can be specified") + } + usb3xControllerSpecified = true + device = &types.VirtualUSBXHCIController{ + VirtualController: types.VirtualController{ + VirtualDevice: types.VirtualDevice{ + Key: -1, + }, + }, + } + default: + return nil, fmt.Errorf("unsupported USB version: %s", usbVersion) + } + + spec.DeviceChange = append(spec.DeviceChange, &types.VirtualDeviceConfigSpec{ + Operation: types.VirtualDeviceConfigSpecOperationAdd, + Device: device, + }) + } + } + timeout := meta.(*Client).timeout vm, err := virtualmachine.Create(client, fo, spec, pool, hs, timeout) if err != nil { @@ -2083,3 +2326,126 @@ func NewOvfHelperParamsFromVMResource(d *schema.ResourceData) *ovfdeploy.OvfHelp } return ovfParams } + +func readUSBControllers(vprops *types.VirtualMachineConfigInfo, desiredUSBVersions []string) ([]map[string]interface{}, error) { + var usbControllers []map[string]interface{} + var usb2ControllerPresent bool + var usb3ControllerPresent bool + + for _, dev := range vprops.Hardware.Device { + switch dev.(type) { + case *types.VirtualUSBController: + if usb2ControllerPresent { + return nil, fmt.Errorf("more than one USB 2.0 controller found") + } + usb2ControllerPresent = true + for _, version := range desiredUSBVersions { + if version == "2.0" { + usbControllers = append(usbControllers, map[string]interface{}{ + "usb_version": version, + }) + break + } + } + case *types.VirtualUSBXHCIController: + if usb3ControllerPresent { + return nil, fmt.Errorf("more than one USB 3.x controller found") + } + usb3ControllerPresent = true + // Use the specific version from desiredUSBVersions + for _, version := range desiredUSBVersions { + if version == "3.1" || version == "3.2" { + usbControllers = append(usbControllers, map[string]interface{}{ + "usb_version": version, + }) + break + } + } + default: + log.Printf("[DEBUG] Found other device type: %T", dev) + } + } + + // Use the desired USB versions specified in the main.tf + for _, version := range desiredUSBVersions { + if version == "2.0" && !usb2ControllerPresent { + usbControllers = append(usbControllers, map[string]interface{}{ + "usb_version": version, + }) + } else if (version == "3.1" || version == "3.2") && !usb3ControllerPresent { + usbControllers = append(usbControllers, map[string]interface{}{ + "usb_version": version, + }) + } + } + + return usbControllers, nil +} + +func resourceVSphereVirtualMachineCustomizeDiffUSBController(d *schema.ResourceDiff, meta interface{}) error { + client := meta.(*Client).vimClient + + // Check if the VM exists + vm, err := virtualmachine.FromUUID(client, d.Id()) + if err != nil { + if strings.Contains(err.Error(), "not found") { + log.Printf("[DEBUG] VM with UUID %q does not exist, skipping existing USB controller check", d.Id()) + vm = nil + } else { + return fmt.Errorf("error locating virtual machine with UUID %q: %s", d.Id(), err) + } + } + + var existingUSB2Controller, existingUSB3Controller bool + + if vm != nil { + vprops, err := virtualmachine.Properties(vm) + if err != nil { + return fmt.Errorf("error fetching VM properties: %s", err) + } + + // Check for existing USB controllers + for _, dev := range vprops.Config.Hardware.Device { + switch dev.(type) { + case *types.VirtualUSBController: + existingUSB2Controller = true + case *types.VirtualUSBXHCIController: + existingUSB3Controller = true + } + } + } + + if d.HasChange("usb_controller") { + usb := d.Get("usb_controller").([]interface{}) + if len(usb) == 0 { + return fmt.Errorf("usb_controller is empty") + } + + // Initialize controller presence flags + usb2ControllerPresent := existingUSB2Controller + usb3ControllerPresent := existingUSB3Controller + + for _, usbControllerInterface := range usb { + usbController := usbControllerInterface.(map[string]interface{}) + usbVersion := usbController["usb_version"].(string) + + switch usbVersion { + case "2.0": + if usb2ControllerPresent { + log.Printf("[DEBUG] USB 2.0 controller already exists, skipping addition") + continue + } + usb2ControllerPresent = true + case "3.1", "3.2": + if usb3ControllerPresent { + log.Printf("[DEBUG] USB 3.x controller already exists, skipping addition") + continue + } + usb3ControllerPresent = true + default: + return fmt.Errorf("unsupported USB version: %s", usbVersion) + } + } + } + return nil +} diff --git a/website/docs/d/virtual_machine.html.markdown b/website/docs/d/virtual_machine.html.markdown index e0599ecdb..836abfc48 100644 --- a/website/docs/d/virtual_machine.html.markdown +++ b/website/docs/d/virtual_machine.html.markdown @@ -8,7 +8,7 @@ description: |- This can be used to return data from a virtual machine or template. --- -# vsphere\_virtual\_machine +# vsphere_virtual_machine The `vsphere_virtual_machine` data source can be used to find the UUID of an existing virtual machine or template. The most common purpose is for finding the @@ -57,21 +57,21 @@ data "vsphere_virtual_machine" "development_template" { The following arguments are supported: -* `name` - (Optional) The name of the virtual machine. This can be a name or the +- `name` - (Optional) The name of the virtual machine. This can be a name or the full path relative to the datacenter. This is required if a UUID lookup is not performed. -* `uuid` - (Optional) Specify this field for a UUID lookup, `name` and +- `uuid` - (Optional) Specify this field for a UUID lookup, `name` and `datacenter_id` are not required if this is specified. -* `folder` - (Optional) The name of the virtual machine folder where the virtual +- `folder` - (Optional) The name of the virtual machine folder where the virtual machine is located. The `name` argument is limited to 80 characters. If the `name` argument includes the full path to the virtual machine and exceeds the 80 characters limit, the `folder` folder argument can be used. -* `datacenter_id` - (Optional) The [managed object reference +- `datacenter_id` - (Optional) The [managed object reference ID][docs-about-morefs] of the datacenter the virtual machine is located in. This can be omitted if the search path used in `name` is an absolute path. For default datacenters, use the `id` attribute from an empty `vsphere_datacenter` data source. -* `scsi_controller_scan_count` - (Optional) The number of SCSI controllers to +- `scsi_controller_scan_count` - (Optional) The number of SCSI controllers to scan for disk attributes and controller types on. Default: `1`. [docs-about-morefs]: /docs/providers/vsphere/index.html#use-of-managed-object-references-by-the-vsphere-provider @@ -90,29 +90,29 @@ section. The following attributes are exported: -* `id` - The UUID of the virtual machine or template. -* `guest_id` - The guest ID of the virtual machine or template. -* `alternate_guest_name` - The alternate guest name of the virtual machine when +- `id` - The UUID of the virtual machine or template. +- `guest_id` - The guest ID of the virtual machine or template. +- `alternate_guest_name` - The alternate guest name of the virtual machine when `guest_id` is a non-specific operating system, like `otherGuest` or `otherGuest64`. -* `annotation` - The user-provided description of this virtual machine. -* `memory` - The size of the virtual machine's memory, in MB. -* `num_cpus` - The total number of virtual processor cores assigned to this +- `annotation` - The user-provided description of this virtual machine. +- `memory` - The size of the virtual machine's memory, in MB. +- `num_cpus` - The total number of virtual processor cores assigned to this virtual machine. -* `num_cores_per_socket` - The number of cores per socket for this virtual +- `num_cores_per_socket` - The number of cores per socket for this virtual machine. -* `firmware` - The firmware interface that is used by this virtual machine. Can +- `firmware` - The firmware interface that is used by this virtual machine. Can be either `bios` or `efi`. -* `hardware_version` - The hardware version number on this virtual machine. -* `scsi_type` - The common type of all SCSI controllers on this virtual machine. +- `hardware_version` - The hardware version number on this virtual machine. +- `scsi_type` - The common type of all SCSI controllers on this virtual machine. Will be one of `lsilogic` (LSI Logic Parallel), `lsilogic-sas` (LSI Logic SAS), `pvscsi` (VMware Paravirtual), `buslogic` (BusLogic), or `mixed` when there are multiple controller types. Only the first number of controllers defined by `scsi_controller_scan_count` are scanned. -* `scsi_bus_sharing` - Mode for sharing the SCSI bus. The modes are +- `scsi_bus_sharing` - Mode for sharing the SCSI bus. The modes are physicalSharing, virtualSharing, and noSharing. Only the first number of controllers defined by `scsi_controller_scan_count` are scanned. -* `disks` - Information about each of the disks on this virtual machine or +- `disks` - Information about each of the disks on this virtual machine or template. These are sorted by bus and unit number so that they can be applied to a `vsphere_virtual_machine` resource in the order the resource expects while cloning. This is useful for discovering certain disk settings while @@ -120,46 +120,49 @@ The following attributes are exported: must be the same on the destination virtual machine as the source. Only the first number of controllers defined by `scsi_controller_scan_count` are scanned for disks. The sub-attributes are: - * `label` - The label for the disk. - * `size` - The size of the disk, in GIB. - * `eagerly_scrub` - Set to `true` if the disk has been eager zeroed. - * `thin_provisioned` - Set to `true` if the disk has been thin provisioned. - * `unit_number` - The disk number on the storage bus. -* `network_interface_types` - The network interface types for each network +- `label` - The label for the disk. +- `size` - The size of the disk, in GIB. +- `eagerly_scrub` - Set to `true` if the disk has been eager zeroed. +- `thin_provisioned` - Set to `true` if the disk has been thin provisioned. +- `unit_number` - The disk number on the storage bus. +- `network_interface_types` - The network interface types for each network interface found on the virtual machine, in device bus order. Will be one of `e1000`, `e1000e`, `pcnet32`, `sriov`, `vmxnet2`, `vmxnet3vrdma`, or `vmxnet3`. -* `network_interfaces` - Information about each of the network interfaces on +- `network_interfaces` - Information about each of the network interfaces on this virtual machine or template. These are sorted by device bus order so that they can be applied to a `vsphere_virtual_machine` resource in the order the resource expects while cloning. This is useful for discovering certain network interface settings while performing a linked clone, as all settings that are output by this data source must be the same on the destination virtual machine as the source. The sub-attributes are: - * `adapter_type` - The network interface types for each network interface found - on the virtual machine, in device bus order. Will be one of `e1000`, - `e1000e`, `vmxnet3vrdma`, or `vmxnet3`. - * `bandwidth_limit` - The upper bandwidth limit of this network interface, +- `adapter_type` - The network interface types for each network interface found + on the virtual machine, in device bus order. Will be one of `e1000`, + `e1000e`, `vmxnet3vrdma`, or `vmxnet3`. +- `bandwidth_limit` - The upper bandwidth limit of this network interface, in Mbits/sec. - * `bandwidth_reservation` - The bandwidth reservation of this network - interface, in Mbits/sec. - * `bandwidth_share_level` - The bandwidth share allocation level for this - interface. Can be one of `low`, `normal`, `high`, or `custom`. - * `bandwidth_share_count` - The share count for this network interface when the - share level is custom. - * `mac_address` - The MAC address of this network interface. - * `network_id` - The managed object reference ID of the network this interface - is connected to. -* `firmware` - The firmware type for this virtual machine. Can be `bios` or +- `bandwidth_reservation` - The bandwidth reservation of this network + interface, in Mbits/sec. +- `bandwidth_share_level` - The bandwidth share allocation level for this + interface. Can be one of `low`, `normal`, `high`, or `custom`. +- `bandwidth_share_count` - The share count for this network interface when the + share level is custom. +- `mac_address` - The MAC address of this network interface. +- `network_id` - The managed object reference ID of the network this interface + is connected to. +- `firmware` - The firmware type for this virtual machine. Can be `bios` or `efi`. -* `default_ip_address` - Whenever possible, this is the first IPv4 address that +- `default_ip_address` - Whenever possible, this is the first IPv4 address that is reachable through the default gateway configured on the machine, then the first reachable IPv6 address, and then the first general discovered address if neither exist. If VMware Tools is not running on the virtual machine, or if the VM is powered off, this value will be blank. -* `guest_ip_addresses` - A list of IP addresses as reported by VMware Tools. -* `instance_uuid` - The instance UUID of the virtual machine or template. -* `vtpm` - Indicates whether a virtual Trusted Platform Module (TPM) device is present on the virtual machine. +- `guest_ip_addresses` - A list of IP addresses as reported by VMware Tools. +- `instance_uuid` - The instance UUID of the virtual machine or template. +- `vtpm` - Indicates whether a virtual Trusted Platform Module (TPM) device is + present on the virtual machine. +- `usb_controller` - Indicates whether a virtual USB controller device is + present on the virtual machine. ~> **NOTE:** Keep in mind when using the results of `scsi_type` and `network_interface_types`, that the `vsphere_virtual_machine` resource only diff --git a/website/docs/r/virtual_machine.html.markdown b/website/docs/r/virtual_machine.html.markdown index ecd8dffa7..4de84b1a0 100644 --- a/website/docs/r/virtual_machine.html.markdown +++ b/website/docs/r/virtual_machine.html.markdown @@ -8,7 +8,7 @@ description: |- This resource can be used to create, modify, and delete virtual machines. --- -# vsphere\_virtual\_machine +# vsphere_virtual_machine The `vsphere_virtual_machine` resource is used to manage the lifecycle of a virtual machine. @@ -28,7 +28,7 @@ The `vsphere_virtual_machine` resource supports standard VMDK-backed virtual dis Disks are managed by a label supplied to the [`label`](#label) attribute in a [`disk` block](#disk-options). This is separate from the automatic naming that vSphere assigns when a virtual machine is created. Control of the name for a virtual disk is not supported unless you are attaching an external disk with the [`attach`](#attach) attribute. -Virtual disks can be SCSI, SATA, or IDE. The storage controllers managed by the Terraform provider can vary, depending on the value supplied to [`scsi_controller_count`](#scsi_controller_count), [`sata_controller_count`](#sata_controller_count), or [`ide_controller_count`](#ide_controller_count). This also dictates the controllers that are checked when looking for disks during a cloning process. SCSI controllers are all configured with the controller type defined by the [`scsi_type`](#scsi_type) setting. If you are cloning from a template, devices will be added or re-configured as necessary. +Virtual disks can be SCSI, SATA, or IDE. The storage controllers managed by the Terraform provider can vary, depending on the value supplied to [`scsi_controller_count`](#scsi_controller_count), [`sata_controller_count`](#sata_controller_count), or [`ide_controller_count`](#ide_controller_count). This also dictates the controllers that are checked when looking for disks during a cloning process. SCSI controllers are all configured with the controller type defined by the [`scsi_type`](#scsi_type) setting. If you are cloning from a template, devices will be added or re-configured as necessary. When cloning from a template, you must specify disks of either the same or greater size than the disks in the source template or the same size when cloning from a snapshot (also known as a linked clone). @@ -40,11 +40,11 @@ Terraform waits during various parts of a virtual machine deployment to ensure t The waiters include the following: -* **Customization Waiter**: +- **Customization Waiter**: This waiter watches events in vSphere to monitor when customization on a virtual machine completes during creation. Depending on your vSphere or virtual machine configuration, it may be necessary to change the timeout or turn off the waiter. This can be controlled by using the [`timeout`](#timeout-1) setting in the [customization settings](#virtual-machine-customizations) block. -* **Network Waiter**: +- **Network Waiter**: This waiter waits for interfaces to appear on a virtual machine guest operating system and occurs close to the end of both virtual machine creation and update. This waiter ensures that the IP information gets reported to the guest operating system, mainly to facilitate the availability of a valid, reachable default IP address for any provisioners. @@ -58,13 +58,13 @@ The following block contains the option necessary to create a virtual machine, w In this example, the resource makes use of the following data sources: -* [`vsphere_datacenter`][tf-vsphere-datacenter] to locate the datacenter, +- [`vsphere_datacenter`][tf-vsphere-datacenter] to locate the datacenter, -* [`vsphere_datastore`][tf-vsphere-datastore] to locate the default datastore to place the virtual machine files, +- [`vsphere_datastore`][tf-vsphere-datastore] to locate the default datastore to place the virtual machine files, -* [`vsphere_compute-cluster`][tf-vsphere-compute-cluster] to locate a resource pool located in a cluster or standalone host, and +- [`vsphere_compute-cluster`][tf-vsphere-compute-cluster] to locate a resource pool located in a cluster or standalone host, and -* [`vsphere_network`][tf-vsphere-network] to locate the network. +- [`vsphere_network`][tf-vsphere-network] to locate the network. [tf-vsphere-datacenter]: /docs/providers/vsphere/d/datacenter.html [tf-vsphere-datastore]: /docs/providers/vsphere/d/datastore.html @@ -624,25 +624,25 @@ The following arguments are supported: The following options are general virtual machine and provider workflow options: -* `alternate_guest_name` - (Optional) The guest name for the operating system when `guest_id` is `otherGuest` or `otherGuest64`. +- `alternate_guest_name` - (Optional) The guest name for the operating system when `guest_id` is `otherGuest` or `otherGuest64`. -* `annotation` - (Optional) A user-provided description of the virtual machine. +- `annotation` - (Optional) A user-provided description of the virtual machine. -* `cdrom` - (Optional) A specification for a CD-ROM device on the virtual machine. See [CD-ROM options](#cd-rom-options) for more information. +- `cdrom` - (Optional) A specification for a CD-ROM device on the virtual machine. See [CD-ROM options](#cd-rom-options) for more information. -* `clone` - (Optional) When specified, the virtual machine will be created as a clone of a specified template. Optional customization options can be submitted for the resource. See [creating a virtual machine from a template](#creating-a-virtual-machine-from-a-template) for more information. +- `clone` - (Optional) When specified, the virtual machine will be created as a clone of a specified template. Optional customization options can be submitted for the resource. See [creating a virtual machine from a template](#creating-a-virtual-machine-from-a-template) for more information. -* `extra_config_reboot_required` - (Optional) Allow the virtual machine to be rebooted when a change to `extra_config` occurs. Default: `true`. +- `extra_config_reboot_required` - (Optional) Allow the virtual machine to be rebooted when a change to `extra_config` occurs. Default: `true`. -* `custom_attributes` - (Optional) Map of custom attribute ids to attribute value strings to set for virtual machine. Please refer to the [`vsphere_custom_attributes`][docs-setting-custom-attributes] resource for more information on setting custom attributes. +- `custom_attributes` - (Optional) Map of custom attribute ids to attribute value strings to set for virtual machine. Please refer to the [`vsphere_custom_attributes`][docs-setting-custom-attributes] resource for more information on setting custom attributes. [docs-setting-custom-attributes]: /docs/providers/vsphere/r/custom_attribute.html#using-custom-attributes-in-a-supported-resource ~> **NOTE:** Custom attributes requires vCenter Server and is not supported on direct ESXi host connections. -* `datastore_id` - (Optional) The [managed object reference ID][docs-about-morefs] of the datastore in which to place the virtual machine. The virtual machine configuration files is placed here, along with any virtual disks that are created where a datastore is not explicitly specified. See the section on [virtual machine migration](#virtual-machine-migration) for more information on modifying this value. +- `datastore_id` - (Optional) The [managed object reference ID][docs-about-morefs] of the datastore in which to place the virtual machine. The virtual machine configuration files is placed here, along with any virtual disks that are created where a datastore is not explicitly specified. See the section on [virtual machine migration](#virtual-machine-migration) for more information on modifying this value. -* `datastore_cluster_id` - (Optional) The [managed object reference ID][docs-about-morefs] of the datastore cluster in which to place the virtual machine. This setting applies to entire virtual machine and implies that you wish to use vSphere Storage DRS with the virtual machine. See the section on [virtual machine migration](#virtual-machine-migration) for more information on modifying this value. +- `datastore_cluster_id` - (Optional) The [managed object reference ID][docs-about-morefs] of the datastore cluster in which to place the virtual machine. This setting applies to entire virtual machine and implies that you wish to use vSphere Storage DRS with the virtual machine. See the section on [virtual machine migration](#virtual-machine-migration) for more information on modifying this value. ~> **NOTE:** One of `datastore_id` or `datastore_cluster_id` must be specified. @@ -650,53 +650,53 @@ The following options are general virtual machine and provider workflow options: ~> **NOTE:** The `datastore_cluster_id` setting applies to the entire virtual machine resource. You cannot assign individual individual disks to datastore clusters. In addition, you cannot use the [`attach`](#attach) setting to attach external disks on virtual machines that are assigned to datastore clusters. -* `datacenter_id` - (Optional) The datacenter ID. Required only when deploying an OVF/OVA template. +- `datacenter_id` - (Optional) The datacenter ID. Required only when deploying an OVF/OVA template. -* `disk` - (Required) A specification for a virtual disk device on the virtual machine. See [disk options](#disk-options) for more information. +- `disk` - (Required) A specification for a virtual disk device on the virtual machine. See [disk options](#disk-options) for more information. -* `extra_config` - (Optional) Extra configuration data for the virtual machine. Can be used to supply advanced parameters not normally in configuration, such as instance metadata and userdata. +- `extra_config` - (Optional) Extra configuration data for the virtual machine. Can be used to supply advanced parameters not normally in configuration, such as instance metadata and userdata. ~> **NOTE:** Do not use `extra_config` when working with a template imported from OVF/OVA as your settings may be ignored. Use the `vapp` block `properties` section as described in [Using vApp Properties for OVF/OVA Configuration](#using-vapp-properties-for-ovf-ova-configuration). -* `firmware` - (Optional) The firmware for the virtual machine. One of `bios` or `efi`. +- `firmware` - (Optional) The firmware for the virtual machine. One of `bios` or `efi`. -* `folder` - (Optional) The path to the virtual machine folder in which to place the virtual machine, relative to the datacenter path (`//vm`). For example, `/dc-01/vm/foo` +- `folder` - (Optional) The path to the virtual machine folder in which to place the virtual machine, relative to the datacenter path (`//vm`). For example, `/dc-01/vm/foo` -* `guest_id` - (Optional) The guest ID for the operating system type. Default: `otherGuest64`. +- `guest_id` - (Optional) The guest ID for the operating system type. Default: `otherGuest64`. ~> **NOTE:** To get a list of supported guest operating system identifiers for your ESXi host, run the following PowerShell command using `VMware.PowerCLI`: - ```powershell - Connect-VIServer -Server "vcenter.example.com" -User "administrator@vsphere.local" -Password "password" - $esxiHost = Get-VMHost -Name "esxi-01.example.com" - $environmentBrowser = Get-View -Id $esxiHost.ExtensionData.Parent.ExtensionData.ConfigManager.EnvironmentBrowser - $vmxVersion = ($environmentBrowser.QueryConfigOptionDescriptor() | Where-Object DefaultConfigOption).Key - $osDescriptor = $environmentBrowser.QueryConfigOption($vmxVersion, $null).GuestOSDescriptor - $osDescriptor | Select-Object Id, Fullname - ``` +```powershell +Connect-VIServer -Server "vcenter.example.com" -User "administrator@vsphere.local" -Password "password" +$esxiHost = Get-VMHost -Name "esxi-01.example.com" +$environmentBrowser = Get-View -Id $esxiHost.ExtensionData.Parent.ExtensionData.ConfigManager.EnvironmentBrowser +$vmxVersion = ($environmentBrowser.QueryConfigOptionDescriptor() | Where-Object DefaultConfigOption).Key +$osDescriptor = $environmentBrowser.QueryConfigOption($vmxVersion, $null).GuestOSDescriptor +$osDescriptor | Select-Object Id, Fullname +``` -* `hardware_version` - (Optional) The hardware version number. Valid range is from 4 to 21. The hardware version cannot be downgraded. See virtual machine hardware [versions][virtual-machine-hardware-versions] and [compatibility][virtual-machine-hardware-compatibility] for more information on supported settings. +- `hardware_version` - (Optional) The hardware version number. Valid range is from 4 to 21. The hardware version cannot be downgraded. See virtual machine hardware [versions][virtual-machine-hardware-versions] and [compatibility][virtual-machine-hardware-compatibility] for more information on supported settings. [virtual-machine-hardware-versions]: https://knowledge.broadcom.com/external/article?articleNumber=315655 [virtual-machine-hardware-compatibility]: https://knowledge.broadcom.com/external/article?articleNumber=312100 -* `host_system_id` - (Optional) The [managed object reference ID][docs-about-morefs] of a host on which to place the virtual machine. See the section on [virtual machine migration](#virtual-machine-migration) for more information on modifying this value. When using a vSphere cluster, if a `host_system_id` is not supplied, vSphere will select a host in the cluster to place the virtual machine, according to any defaults or vSphere DRS placement policies. +- `host_system_id` - (Optional) The [managed object reference ID][docs-about-morefs] of a host on which to place the virtual machine. See the section on [virtual machine migration](#virtual-machine-migration) for more information on modifying this value. When using a vSphere cluster, if a `host_system_id` is not supplied, vSphere will select a host in the cluster to place the virtual machine, according to any defaults or vSphere DRS placement policies. -* `name` - (Required) The name of the virtual machine. +- `name` - (Required) The name of the virtual machine. -* `network_interface` - (Required) A specification for a virtual NIC on the virtual machine. See [network interface options](#network-interface-options) for more information. +- `network_interface` - (Required) A specification for a virtual NIC on the virtual machine. See [network interface options](#network-interface-options) for more information. -* `pci_device_id` - (Optional) List of host PCI device IDs in which to create PCI passthroughs. +- `pci_device_id` - (Optional) List of host PCI device IDs in which to create PCI passthroughs. ~> **NOTE:** Cloning requires vCenter Server and is not supported on direct ESXi host connections. -* `ovf_deploy` - (Optional) When specified, the virtual machine will be deployed from the provided OVF/OVA template. See [creating a virtual machine from an OVF/OVA template](#creating-a-virtual-machine-from-an-ovf-ova-template) for more information. +- `ovf_deploy` - (Optional) When specified, the virtual machine will be deployed from the provided OVF/OVA template. See [creating a virtual machine from an OVF/OVA template](#creating-a-virtual-machine-from-an-ovf-ova-template) for more information. -* `replace_trigger` - (Optional) Triggers replacement of resource whenever it changes. +- `replace_trigger` - (Optional) Triggers replacement of resource whenever it changes. For example, `replace_trigger = sha256(format("%s-%s",data.template_file.cloud_init_metadata.rendered,data.template_file.cloud_init_userdata.rendered))` will fingerprint the changes in cloud-init metadata and userdata templates. This will enable a replacement of the resource whenever the dependant template renders a new configuration. (Forces a replacement.) -* `resource_pool_id` - (Required) The [managed object reference ID][docs-about-morefs] of the resource pool in which to place the virtual machine. See the [Virtual Machine Migration](#virtual-machine-migration) section for more information on modifying this value. +- `resource_pool_id` - (Required) The [managed object reference ID][docs-about-morefs] of the resource pool in which to place the virtual machine. See the [Virtual Machine Migration](#virtual-machine-migration) section for more information on modifying this value. [docs-about-morefs]: /docs/providers/vsphere/index.html#use-of-managed-object-references-by-the-vsphere-provider @@ -704,31 +704,31 @@ For example, `replace_trigger = sha256(format("%s-%s",data.template_file.cloud_i [docs-resource-pool-cluster-default]: /docs/providers/vsphere/d/resource_pool.html#specifying-the-root-resource-pool-for-a-standalone-host -* `scsi_type` - (Optional) The SCSI controller type for the virtual machine. One of `lsilogic` (LSI Logic Parallel), `lsilogic-sas` (LSI Logic SAS) or `pvscsi` (VMware Paravirtual). Default: `pvscsi`. +- `scsi_type` - (Optional) The SCSI controller type for the virtual machine. One of `lsilogic` (LSI Logic Parallel), `lsilogic-sas` (LSI Logic SAS) or `pvscsi` (VMware Paravirtual). Default: `pvscsi`. -* `scsi_bus_sharing` - (Optional) The type of SCSI bus sharing for the virtual machine SCSI controller. One of `physicalSharing`, `virtualSharing`, and `noSharing`. Default: `noSharing`. +- `scsi_bus_sharing` - (Optional) The type of SCSI bus sharing for the virtual machine SCSI controller. One of `physicalSharing`, `virtualSharing`, and `noSharing`. Default: `noSharing`. -* `storage_policy_id` - (Optional) The ID of the storage policy to assign to the home directory of a virtual machine. +- `storage_policy_id` - (Optional) The ID of the storage policy to assign to the home directory of a virtual machine. -* `tags` - (Optional) The IDs of any tags to attach to this resource. Please refer to the [`vsphere_tag`][docs-applying-tags] resource for more information on applying tags to virtual machine resources. +- `tags` - (Optional) The IDs of any tags to attach to this resource. Please refer to the [`vsphere_tag`][docs-applying-tags] resource for more information on applying tags to virtual machine resources. [docs-applying-tags]: /docs/providers/vsphere/r/tag.html#using-tags-in-a-supported-resource ~> **NOTE:** Tagging support is unsupported on direct ESXi host connections and requires vCenter Server instance. -* `vapp` - (Optional) Used for vApp configurations. The only sub-key available is `properties`, which is a key/value map of properties for virtual machines imported from and OVF/OVA. See [Using vApp Properties for OVF/OVA Configuration](#using-vapp-properties-for-ovf-ova-configuration) for more information. +- `vapp` - (Optional) Used for vApp configurations. The only sub-key available is `properties`, which is a key/value map of properties for virtual machines imported from and OVF/OVA. See [Using vApp Properties for OVF/OVA Configuration](#using-vapp-properties-for-ovf-ova-configuration) for more information. ### CPU and Memory Options The following options control CPU and memory settings on a virtual machine: -* `cpu_hot_add_enabled` - (Optional) Allow CPUs to be added to the virtual machine while it is powered on. +- `cpu_hot_add_enabled` - (Optional) Allow CPUs to be added to the virtual machine while it is powered on. -* `cpu_hot_remove_enabled` - (Optional) Allow CPUs to be removed to the virtual machine while it is powered on. +- `cpu_hot_remove_enabled` - (Optional) Allow CPUs to be removed to the virtual machine while it is powered on. -* `memory` - (Optional) The memory size to assign to the virtual machine, in MB. Default: `1024` (1 GB). +- `memory` - (Optional) The memory size to assign to the virtual machine, in MB. Default: `1024` (1 GB). -* `memory_hot_add_enabled` - (Optional) Allow memory to be added to the virtual machine while it is powered on. +- `memory_hot_add_enabled` - (Optional) Allow memory to be added to the virtual machine while it is powered on. ~> **NOTE:** CPU and memory hot add options are not available on all guest operating systems. Please refer to the [VMware Guest OS Compatibility Guide][vmware-docs-compat-guide] to which settings are allow for your guest operating system. In addition, at least one `terraform apply` must be run before you are able to use CPU and memory hot add. @@ -738,45 +738,45 @@ The following options control CPU and memory settings on a virtual machine: [kb-2008405]: https://knowledge.broadcom.com/external/article?articleNumber=343190 -* `num_cores_per_socket` - (Optional) The number of cores per socket in the virtual machine. The number of vCPUs on the virtual machine will be `num_cpus` divided by `num_cores_per_socket`. If specified, the value supplied to `num_cpus` must be evenly divisible by this value. Default: `1`. +- `num_cores_per_socket` - (Optional) The number of cores per socket in the virtual machine. The number of vCPUs on the virtual machine will be `num_cpus` divided by `num_cores_per_socket`. If specified, the value supplied to `num_cpus` must be evenly divisible by this value. Default: `1`. -* `num_cpus` - (Optional) The total number of virtual processor cores to assign to the virtual machine. Default: `1`. +- `num_cpus` - (Optional) The total number of virtual processor cores to assign to the virtual machine. Default: `1`. ### Boot Options The following options control boot settings on a virtual machine: -* `boot_delay` - (Optional) The number of milliseconds to wait before starting the boot sequence. The default is no delay. +- `boot_delay` - (Optional) The number of milliseconds to wait before starting the boot sequence. The default is no delay. -* `boot_retry_delay` - (Optional) The number of milliseconds to wait before retrying the boot sequence. This option is only valid if `boot_retry_enabled` is `true`. Default: `10000` (10 seconds). +- `boot_retry_delay` - (Optional) The number of milliseconds to wait before retrying the boot sequence. This option is only valid if `boot_retry_enabled` is `true`. Default: `10000` (10 seconds). -* `boot_retry_enabled` - (Optional) If set to `true`, a virtual machine that fails to boot will try again after the delay defined in `boot_retry_delay`. Default: `false`. +- `boot_retry_enabled` - (Optional) If set to `true`, a virtual machine that fails to boot will try again after the delay defined in `boot_retry_delay`. Default: `false`. -* `efi_secure_boot_enabled` - (Optional) Use this option to enable EFI secure boot when the `firmware` type is set to is `efi`. Default: `false`. +- `efi_secure_boot_enabled` - (Optional) Use this option to enable EFI secure boot when the `firmware` type is set to is `efi`. Default: `false`. ### VMware Tools Options The following options control VMware Tools settings on the virtual machine: -* `sync_time_with_host` - (Optional) Enable the guest operating system to synchronization its clock with the host when the virtual machine is powered on or resumed. Requires VMware Tools to be installed. Default: `true`. +- `sync_time_with_host` - (Optional) Enable the guest operating system to synchronization its clock with the host when the virtual machine is powered on or resumed. Requires VMware Tools to be installed. Default: `true`. ~> **NOTE:** `sync_time_with_host` is only available on vSphere 7.0 Update 1 and later. -* `sync_time_with_host_periodically` - (Optional) Enable the guest operating system to periodically synchronize its clock with the host. Default: `false`. +- `sync_time_with_host_periodically` - (Optional) Enable the guest operating system to periodically synchronize its clock with the host. Default: `false`. ~> **NOTE:** `sync_time_with_host_periodically` is only available on vSphere 7.0 Update 1 and later. On previous versions, setting `sync_time_with_host` is will enable periodic synchronization. -* `run_tools_scripts_after_power_on` - (Optional) Enable post-power-on scripts to run when VMware Tools is installed. Default: `true`. +- `run_tools_scripts_after_power_on` - (Optional) Enable post-power-on scripts to run when VMware Tools is installed. Default: `true`. -* `run_tools_scripts_after_resume` - (Optional) Enable ost-resume scripts to run when VMware Tools is installed. Default: `true`. +- `run_tools_scripts_after_resume` - (Optional) Enable ost-resume scripts to run when VMware Tools is installed. Default: `true`. -* `run_tools_scripts_before_guest_reboot` - (Optional) Enable pre-reboot scripts to run when VMware Tools is installed. Default: `false`. +- `run_tools_scripts_before_guest_reboot` - (Optional) Enable pre-reboot scripts to run when VMware Tools is installed. Default: `false`. -* `run_tools_scripts_before_guest_shutdown` - (Optional) Enable pre-shutdown scripts to run when VMware Tools is installed. Default: `true`. +- `run_tools_scripts_before_guest_shutdown` - (Optional) Enable pre-shutdown scripts to run when VMware Tools is installed. Default: `true`. -* `run_tools_scripts_before_guest_standby` - (Optional) Enable pre-standby scripts to run when VMware Tools is installed. Default: `true`. +- `run_tools_scripts_before_guest_standby` - (Optional) Enable pre-standby scripts to run when VMware Tools is installed. Default: `true`. -* `tools_upgrade_policy` - (Optional) Enable automatic upgrade of the VMware Tools version when the virtual machine is rebooted. If necessary, VMware Tools is upgraded to the latest version supported by the host on which the virtual machine is running. Requires VMware Tools to be installed. One of `manual` or `upgradeAtPowerCycle`. Default: `manual`. +- `tools_upgrade_policy` - (Optional) Enable automatic upgrade of the VMware Tools version when the virtual machine is rebooted. If necessary, VMware Tools is upgraded to the latest version supported by the host on which the virtual machine is running. Requires VMware Tools to be installed. One of `manual` or `upgradeAtPowerCycle`. Default: `manual`. ### Resource Allocation Options @@ -784,21 +784,21 @@ The following options control CPU and memory allocation on the virtual machine. The options are: -* `cpu_limit` - (Optional) The maximum amount of CPU (in MHz) that the virtual machine can consume, regardless of available resources. The default is no limit. +- `cpu_limit` - (Optional) The maximum amount of CPU (in MHz) that the virtual machine can consume, regardless of available resources. The default is no limit. -* `cpu_reservation` - (Optional) The amount of CPU (in MHz) that the virtual machine is guaranteed. The default is no reservation. +- `cpu_reservation` - (Optional) The amount of CPU (in MHz) that the virtual machine is guaranteed. The default is no reservation. -* `cpu_share_level` - (Optional) The allocation level for the virtual machine CPU resources. One of `high`, `low`, `normal`, or `custom`. Default: `custom`. +- `cpu_share_level` - (Optional) The allocation level for the virtual machine CPU resources. One of `high`, `low`, `normal`, or `custom`. Default: `custom`. -* `cpu_share_count` - (Optional) The number of CPU shares allocated to the virtual machine when the `cpu_share_level` is `custom`. +- `cpu_share_count` - (Optional) The number of CPU shares allocated to the virtual machine when the `cpu_share_level` is `custom`. -* `memory_limit` - (Optional) The maximum amount of memory (in MB) that th virtual machine can consume, regardless of available resources. The default is no limit. +- `memory_limit` - (Optional) The maximum amount of memory (in MB) that th virtual machine can consume, regardless of available resources. The default is no limit. -* `memory_reservation` - (Optional) The amount of memory (in MB) that the virtual machine is guaranteed. The default is no reservation. +- `memory_reservation` - (Optional) The amount of memory (in MB) that the virtual machine is guaranteed. The default is no reservation. -* `memory_share_level` - (Optional) The allocation level for the virtual machine memory resources. One of `high`, `low`, `normal`, or `custom`. Default: `custom`. +- `memory_share_level` - (Optional) The allocation level for the virtual machine memory resources. One of `high`, `low`, `normal`, or `custom`. Default: `custom`. -* `memory_share_count` - (Optional) The number of memory shares allocated to the virtual machine when the `memory_share_level` is `custom`. +- `memory_share_count` - (Optional) The number of memory shares allocated to the virtual machine when the `memory_share_level` is `custom`. ### Advanced Options @@ -806,53 +806,53 @@ The following options control advanced operation of the virtual machine, or cont The options are: -* `cpu_performance_counters_enabled` - (Optional) Enable CPU performance counters on the virtual machine. Default: `false`. +- `cpu_performance_counters_enabled` - (Optional) Enable CPU performance counters on the virtual machine. Default: `false`. -* `enable_disk_uuid` - (Optional) Expose the UUIDs of attached virtual disks to the virtual machine, allowing access to them in the guest. Default: `false`. +- `enable_disk_uuid` - (Optional) Expose the UUIDs of attached virtual disks to the virtual machine, allowing access to them in the guest. Default: `false`. -* `enable_logging` - (Optional) Enable logging of virtual machine events to a log file stored in the virtual machine directory. Default: `false`. +- `enable_logging` - (Optional) Enable logging of virtual machine events to a log file stored in the virtual machine directory. Default: `false`. -* `ept_rvi_mode` - (Optional) The EPT/RVI (hardware memory virtualization) setting for the virtual machine. One of `automatic`, `on`, or `off`. Default: `automatic`. +- `ept_rvi_mode` - (Optional) The EPT/RVI (hardware memory virtualization) setting for the virtual machine. One of `automatic`, `on`, or `off`. Default: `automatic`. -* `force_power_off` - (Optional) If a guest shutdown failed or times out while updating or destroying (see [`shutdown_wait_timeout`](#shutdown_wait_timeout)), force the power-off of the virtual machine. Default: `true`. +- `force_power_off` - (Optional) If a guest shutdown failed or times out while updating or destroying (see [`shutdown_wait_timeout`](#shutdown_wait_timeout)), force the power-off of the virtual machine. Default: `true`. -* `hv_mode` - (Optional) The hardware virtualization (non-nested) setting for the virtual machine. One of `hvAuto`, `hvOn`, or `hvOff`. Default: `hvAuto`. +- `hv_mode` - (Optional) The hardware virtualization (non-nested) setting for the virtual machine. One of `hvAuto`, `hvOn`, or `hvOff`. Default: `hvAuto`. -* `ide_controller_count` - (Optional) The number of IDE controllers that the virtual machine. This directly affects the number of disks you can add to the virtual machine and the maximum disk unit number. Note that lowering this value does not remove controllers. Default: `2`. +- `ide_controller_count` - (Optional) The number of IDE controllers that the virtual machine. This directly affects the number of disks you can add to the virtual machine and the maximum disk unit number. Note that lowering this value does not remove controllers. Default: `2`. -* `ignored_guest_ips` - (Optional) List of IP addresses and CIDR networks to ignore while waiting for an available IP address using either of the waiters. Any IP addresses in this list will be ignored so that the waiter will continue to wait for a valid IP address. Default: `[]`. +- `ignored_guest_ips` - (Optional) List of IP addresses and CIDR networks to ignore while waiting for an available IP address using either of the waiters. Any IP addresses in this list will be ignored so that the waiter will continue to wait for a valid IP address. Default: `[]`. -* `latency_sensitivity` - (Optional) Controls the scheduling delay of the virtual machine. Use a higher sensitivity for applications that require lower latency, such as VOIP, media player applications, or applications that require frequent access to mouse or keyboard devices. One of `low`, `normal`, `medium`, or `high`. +- `latency_sensitivity` - (Optional) Controls the scheduling delay of the virtual machine. Use a higher sensitivity for applications that require lower latency, such as VOIP, media player applications, or applications that require frequent access to mouse or keyboard devices. One of `low`, `normal`, `medium`, or `high`. ~> **NOTE:** On higher sensitivities, you may need to adjust the [`memory_reservation`](#memory_reservation) to the full amount of memory provisioned for the virtual machine. -* `migrate_wait_timeout` - (Optional) The amount of time, in minutes, to wait for a virtual machine migration to complete before failing. Default: `10` minutes. See the section on [virtual machine migration](#virtual-machine-migration) for more information. +- `migrate_wait_timeout` - (Optional) The amount of time, in minutes, to wait for a virtual machine migration to complete before failing. Default: `10` minutes. See the section on [virtual machine migration](#virtual-machine-migration) for more information. -* `nested_hv_enabled` - (Optional) Enable nested hardware virtualization on the virtual machine, facilitating nested virtualization in the guest operating system. Default: `false`. +- `nested_hv_enabled` - (Optional) Enable nested hardware virtualization on the virtual machine, facilitating nested virtualization in the guest operating system. Default: `false`. -* `sata_controller_count` - (Optional) The number of SATA controllers that the virtual machine. This directly affects the number of disks you can add to the virtual machine and the maximum disk unit number. Note that lowering this value does not remove controllers. Default: `0`. +- `sata_controller_count` - (Optional) The number of SATA controllers that the virtual machine. This directly affects the number of disks you can add to the virtual machine and the maximum disk unit number. Note that lowering this value does not remove controllers. Default: `0`. -* `scsi_controller_count` - (Optional) The number of SCSI controllers on the virtual machine. This setting directly affects the number of disks you can add to the virtual machine and the maximum disk unit number. Note that lowering this value does not remove controllers. Default: `1`. +- `scsi_controller_count` - (Optional) The number of SCSI controllers on the virtual machine. This setting directly affects the number of disks you can add to the virtual machine and the maximum disk unit number. Note that lowering this value does not remove controllers. Default: `1`. -* `shutdown_wait_timeout` - (Optional) The amount of time, in minutes, to wait for a graceful guest shutdown when making necessary updates to the virtual machine. If `force_power_off` is set to `true`, the virtual machine will be forced to power-off after the timeout, otherwise an error is returned. Default: `3` minutes. +- `shutdown_wait_timeout` - (Optional) The amount of time, in minutes, to wait for a graceful guest shutdown when making necessary updates to the virtual machine. If `force_power_off` is set to `true`, the virtual machine will be forced to power-off after the timeout, otherwise an error is returned. Default: `3` minutes. -* `swap_placement_policy` - (Optional) The swap file placement policy for the virtual machine. One of `inherit`, `hostLocal`, or `vmDirectory`. Default: `inherit`. +- `swap_placement_policy` - (Optional) The swap file placement policy for the virtual machine. One of `inherit`, `hostLocal`, or `vmDirectory`. Default: `inherit`. -* `vbs_enabled` - (Optional) Enable Virtualization Based Security. Requires `firmware` to be `efi`. In addition, `vvtd_enabled`, `nested_hv_enabled`, and `efi_secure_boot_enabled` must all have a value of `true`. Default: `false`. +- `vbs_enabled` - (Optional) Enable Virtualization Based Security. Requires `firmware` to be `efi`. In addition, `vvtd_enabled`, `nested_hv_enabled`, and `efi_secure_boot_enabled` must all have a value of `true`. Default: `false`. -* `vvtd_enabled` - (Optional) Enable Intel Virtualization Technology for Directed I/O for the virtual machine (_I/O MMU_ in the vSphere Client). Default: `false`. +- `vvtd_enabled` - (Optional) Enable Intel Virtualization Technology for Directed I/O for the virtual machine (_I/O MMU_ in the vSphere Client). Default: `false`. -* `wait_for_guest_ip_timeout` - (Optional) The amount of time, in minutes, to wait for an available guest IP address on the virtual machine. This should only be used if the version VMware Tools does not allow the [`wait_for_guest_net_timeout`](#wait_for_guest_net_timeout) waiter to be used. A value less than `1` disables the waiter. Default: `0`. +- `wait_for_guest_ip_timeout` - (Optional) The amount of time, in minutes, to wait for an available guest IP address on the virtual machine. This should only be used if the version VMware Tools does not allow the [`wait_for_guest_net_timeout`](#wait_for_guest_net_timeout) waiter to be used. A value less than `1` disables the waiter. Default: `0`. -* `wait_for_guest_net_routable` - (Optional) Controls whether or not the guest network waiter waits for a routable address. When `false`, the waiter does not wait for a default gateway, nor are IP addresses checked against any discovered default gateways as part of its success criteria. This property is ignored if the [`wait_for_guest_ip_timeout`](#wait_for_guest_ip_timeout) waiter is used. Default: `true`. +- `wait_for_guest_net_routable` - (Optional) Controls whether or not the guest network waiter waits for a routable address. When `false`, the waiter does not wait for a default gateway, nor are IP addresses checked against any discovered default gateways as part of its success criteria. This property is ignored if the [`wait_for_guest_ip_timeout`](#wait_for_guest_ip_timeout) waiter is used. Default: `true`. -* `wait_for_guest_net_timeout` - (Optional) The amount of time, in minutes, to wait for an available guest IP address on the virtual machine. Older versions of VMware Tools do not populate this property. In those cases, this waiter can be disabled and the [`wait_for_guest_ip_timeout`](#wait_for_guest_ip_timeout) waiter can be used instead. A value less than `1` disables the waiter. Default: `5` minutes. +- `wait_for_guest_net_timeout` - (Optional) The amount of time, in minutes, to wait for an available guest IP address on the virtual machine. Older versions of VMware Tools do not populate this property. In those cases, this waiter can be disabled and the [`wait_for_guest_ip_timeout`](#wait_for_guest_ip_timeout) waiter can be used instead. A value less than `1` disables the waiter. Default: `5` minutes. ### Disk Options Virtual disks are managed by adding one or more instance of the `disk` block. -At a minimum, both the `label` and `size` attributes must be provided. The `unit_number` is required for any disk other than the first, and there must be at least one resource with the implicit number of `0`. +At a minimum, both the `label` and `size` attributes must be provided. The `unit_number` is required for any disk other than the first, and there must be at least one resource with the implicit number of `0`. The following example demonstrates an abridged multi-disk configuration: @@ -876,58 +876,58 @@ resource "vsphere_virtual_machine" "vm" { The options are: -* `label` - (Required) A label for the virtual disk. Forces a new disk, if changed. +- `label` - (Required) A label for the virtual disk. Forces a new disk, if changed. ~> **NOTE:** It's recommended that you set the disk label to a format matching `diskN`, where `N` is the number of the disk, starting from disk number 0. This will ensure that your configuration is compatible when importing a virtual machine. See the section on [importing](#importing) for more information. ~> **NOTE:** Do not choose a label that starts with `orphaned_disk_` (_e.g._ `orphaned_disk_0`), as this prefix is reserved for disks that the provider does not recognize. Such as disks that are attached externally. The Terraform provider will issue an error if you try to label a disk with this prefix. -* `size` - (Required) The size of the disk, in GB. Must be a whole number. +- `size` - (Required) The size of the disk, in GB. Must be a whole number. ~> **NOTE:** Use the [`api_timeout`](/docs/providers/vsphere/index.html#argument-reference) option to increase the default timeout when creating virtual machines with large disk sizes and avoid "context deadline exceeded" errors. -* `unit_number` - (Optional) The disk number on the storage bus. The maximum value for this setting is the value of the controller count times the controller capacity (15 for SCSI, 30 for SATA, and 2 for IDE). Duplicate unit numbers are not allowed. Default `0`, for which one disk must be set to. +- `unit_number` - (Optional) The disk number on the storage bus. The maximum value for this setting is the value of the controller count times the controller capacity (15 for SCSI, 30 for SATA, and 2 for IDE). Duplicate unit numbers are not allowed. Default `0`, for which one disk must be set to. -* `datastore_id` - (Optional) The [managed object reference ID][docs-about-morefs] for the datastore on which the virtual disk is placed. The default is to use the datastore of the virtual machine. See the section on [virtual machine migration](#virtual-machine-migration) for information on modifying this value. +- `datastore_id` - (Optional) The [managed object reference ID][docs-about-morefs] for the datastore on which the virtual disk is placed. The default is to use the datastore of the virtual machine. See the section on [virtual machine migration](#virtual-machine-migration) for information on modifying this value. ~> **NOTE:** Datastores cannot be assigned to individual disks when [`datastore_cluster_id`](#datastore_cluster_id) is used. -* `attach` - (Optional) Attach an external disk instead of creating a new one. Implies and conflicts with `keep_on_remove`. If set, you cannot set `size`, `eagerly_scrub`, or `thin_provisioned`. Must set `path` if used. +- `attach` - (Optional) Attach an external disk instead of creating a new one. Implies and conflicts with `keep_on_remove`. If set, you cannot set `size`, `eagerly_scrub`, or `thin_provisioned`. Must set `path` if used. ~> **NOTE:** External disks cannot be attached when [`datastore_cluster_id`](#datastore_cluster_id) is used. -* `path` - (Optional) When using `attach`, this parameter controls the path of a virtual disk to attach externally. Otherwise, it is a computed attribute that contains the virtual disk filename. +- `path` - (Optional) When using `attach`, this parameter controls the path of a virtual disk to attach externally. Otherwise, it is a computed attribute that contains the virtual disk filename. -* `keep_on_remove` - (Optional) Keep this disk when removing the device or destroying the virtual machine. Default: `false`. +- `keep_on_remove` - (Optional) Keep this disk when removing the device or destroying the virtual machine. Default: `false`. -* `disk_mode` - (Optional) The mode of this this virtual disk for purposes of writes and snapshots. One of `append`, `independent_nonpersistent`, `independent_persistent`, `nonpersistent`, `persistent`, or `undoable`. Default: `persistent`. For more information on these option, please refer to the [product documentation][vmware-docs-disk-mode]. +- `disk_mode` - (Optional) The mode of this this virtual disk for purposes of writes and snapshots. One of `append`, `independent_nonpersistent`, `independent_persistent`, `nonpersistent`, `persistent`, or `undoable`. Default: `persistent`. For more information on these option, please refer to the [product documentation][vmware-docs-disk-mode]. [vmware-docs-disk-mode]: https://developer.broadcom.com/xapis/virtual-infrastructure-json-api/latest/data-structures/VirtualDiskMode/enum/ -* `eagerly_scrub` - (Optional) If set to `true`, the disk space is zeroed out when the virtual machine is created. This will delay the creation of the virtual disk. Cannot be set to `true` when `thin_provisioned` is `true`. See the section on [picking a disk type](#picking-a-disk-type) for more information. Default: `false`. +- `eagerly_scrub` - (Optional) If set to `true`, the disk space is zeroed out when the virtual machine is created. This will delay the creation of the virtual disk. Cannot be set to `true` when `thin_provisioned` is `true`. See the section on [picking a disk type](#picking-a-disk-type) for more information. Default: `false`. -* `thin_provisioned` - (Optional) If `true`, the disk is thin provisioned, with space for the file being allocated on an as-needed basis. Cannot be set to `true` when `eagerly_scrub` is `true`. See the section on [selecting a disk type](#selecting-a-disk-type) for more information. Default: `true`. +- `thin_provisioned` - (Optional) If `true`, the disk is thin provisioned, with space for the file being allocated on an as-needed basis. Cannot be set to `true` when `eagerly_scrub` is `true`. See the section on [selecting a disk type](#selecting-a-disk-type) for more information. Default: `true`. -* `disk_sharing` - (Optional) The sharing mode of this virtual disk. One of `sharingMultiWriter` or `sharingNone`. Default: `sharingNone`. +- `disk_sharing` - (Optional) The sharing mode of this virtual disk. One of `sharingMultiWriter` or `sharingNone`. Default: `sharingNone`. -* `write_through` - (Optional) If `true`, writes for this disk are sent directly to the filesystem immediately instead of being buffered. Default: `false`. +- `write_through` - (Optional) If `true`, writes for this disk are sent directly to the filesystem immediately instead of being buffered. Default: `false`. -* `io_limit` - (Optional) The upper limit of IOPS that this disk can use. The default is no limit. +- `io_limit` - (Optional) The upper limit of IOPS that this disk can use. The default is no limit. -* `io_reservation` - (Optional) The I/O reservation (guarantee) for the virtual disk has, in IOPS. The default is no reservation. +- `io_reservation` - (Optional) The I/O reservation (guarantee) for the virtual disk has, in IOPS. The default is no reservation. -* `io_share_level` - (Optional) The share allocation level for the virtual disk. One of `low`, `normal`, `high`, or `custom`. Default: `normal`. +- `io_share_level` - (Optional) The share allocation level for the virtual disk. One of `low`, `normal`, `high`, or `custom`. Default: `normal`. -* `io_share_count` - (Optional) The share count for the virtual disk when the share level is `custom`. +- `io_share_count` - (Optional) The share count for the virtual disk when the share level is `custom`. -* `storage_policy_id` - (Optional) The UUID of the storage policy to assign to the virtual disk. +- `storage_policy_id` - (Optional) The UUID of the storage policy to assign to the virtual disk. -* `controller_type` - (Optional) The type of storage controller to attach the disk to. Can be `scsi`, `sata`, or `ide`. You must have the appropriate number of controllers enabled for the selected type. Default `scsi`. +- `controller_type` - (Optional) The type of storage controller to attach the disk to. Can be `scsi`, `sata`, or `ide`. You must have the appropriate number of controllers enabled for the selected type. Default `scsi`. #### Computed Disk Attributes -* `uuid` - The UUID of the virtual disk VMDK file. This is used to track the virtual disk on the virtual machine. +- `uuid` - The UUID of the virtual disk VMDK file. This is used to track the virtual disk on the virtual machine. #### Virtual Disk Provisioning Policies @@ -935,15 +935,15 @@ The `eagerly_scrub` and `thin_provisioned` options control the virtual disk spac The options are: -* **Thick Provision Lazy Zeroed**: +- **Thick Provision Lazy Zeroed**: Both `eagerly_scrub` and `thin_provisioned` should be set to `false`. -* **Thick Provision Eager Zeroed**: +- **Thick Provision Eager Zeroed**: `eagerly_scrub` should be set to `true`, and `thin_provisioned` should be set to `false`. -* **Thin Provision**: +- **Thin Provision**: `eagerly_scrub` should be set to `false`, and `thin_provisioned` should be set to `true`. @@ -1011,50 +1011,51 @@ On some Linux distributions, the first interface may be presented as `eth0` and The options are: -* `network_id` - (Required) The [managed object reference ID][docs-about-morefs] of the network on which to connect the virtual machine network interface. +- `network_id` - (Required) The [managed object reference ID][docs-about-morefs] of the network on which to connect the virtual machine network interface. -* `adapter_type` - (Optional) The network interface type. One of `e1000`, `e1000e`, `sriov`, or `vmxnet3`. Default: `vmxnet3`. +- `adapter_type` - (Optional) The network interface type. One of `e1000`, `e1000e`, `sriov`, or `vmxnet3`. Default: `vmxnet3`. -* `use_static_mac` - (Optional) If true, the `mac_address` field is treated as a static MAC address and set accordingly. Setting this to `true` requires `mac_address` to be set. Default: `false`. +- `use_static_mac` - (Optional) If true, the `mac_address` field is treated as a static MAC address and set accordingly. Setting this to `true` requires `mac_address` to be set. Default: `false`. -* `mac_address` - (Optional) The MAC address of the network interface. Can only be manually set if `use_static_mac` is `true`. Otherwise, the value is computed and presents the assigned MAC address for the interface. +- `mac_address` - (Optional) The MAC address of the network interface. Can only be manually set if `use_static_mac` is `true`. Otherwise, the value is computed and presents the assigned MAC address for the interface. -* `bandwidth_limit` - (Optional) The upper bandwidth limit of the network interface, in Mbits/sec. The default is no limit. Ignored if `adapter_type` is set to `sriov`. +- `bandwidth_limit` - (Optional) The upper bandwidth limit of the network interface, in Mbits/sec. The default is no limit. Ignored if `adapter_type` is set to `sriov`. -* `bandwidth_reservation` - (Optional) The bandwidth reservation of the network interface, in Mbits/sec. The default is no reservation. +- `bandwidth_reservation` - (Optional) The bandwidth reservation of the network interface, in Mbits/sec. The default is no reservation. -* `bandwidth_share_level` - (Optional) The bandwidth share allocation level for the network interface. One of `low`, `normal`, `high`, or `custom`. Default: `normal`. Ignored if `adapter_type` is set to `sriov`. +- `bandwidth_share_level` - (Optional) The bandwidth share allocation level for the network interface. One of `low`, `normal`, `high`, or `custom`. Default: `normal`. Ignored if `adapter_type` is set to `sriov`. -* `bandwidth_share_count` - (Optional) The share count for the network interface when the share level is `custom`. Ignored if `adapter_type` is set to `sriov`. +- `bandwidth_share_count` - (Optional) The share count for the network interface when the share level is `custom`. Ignored if `adapter_type` is set to `sriov`. -* `ovf_mapping` - (Optional) Specifies which NIC in an OVF/OVA the `network_interface` should be associated. Only applies at creation when deploying from an OVF/OVA. +- `ovf_mapping` - (Optional) Specifies which NIC in an OVF/OVA the `network_interface` should be associated. Only applies at creation when deploying from an OVF/OVA. #### Using SR-IOV Network Interfaces In order to attach your virtual machine to an SR-IOV network interface, there are a few requirements -* SR-IOV network interfaces must be declared after all non-SRIOV network interfaces. +- SR-IOV network interfaces must be declared after all non-SRIOV network interfaces. + +- The target host must be known, if creating a VM from scratch, this means setting the `host_system_id` option. -* The target host must be known, if creating a VM from scratch, this means setting the `host_system_id` option. +- SR-IOV must be enabled on the relevant physical adapter on the host. -* SR-IOV must be enabled on the relevant physical adapter on the host. +- The `memory_reservation` must be fully set (that is, equal to the `memory`) for the VM. -* The `memory_reservation` must be fully set (that is, equal to the `memory`) for the VM. +- The `network_interface` sub-resource takes a `physical_function` argument: -* The `network_interface` sub-resource takes a `physical_function` argument: - * This **must** be set if your adapter type is `sriov`. - * This **must not** be set if your adapter type is not `sriov`. - * This can be found by navigating to the relevant host in the vSphere Client, + - This **must** be set if your adapter type is `sriov`. + - This **must not** be set if your adapter type is not `sriov`. + - This can be found by navigating to the relevant host in the vSphere Client, going to the 'Configure' tab followed by 'Networking' then 'Physical adapters' and finding the relevant physical network adapter; one of the properties of the NIC is its PCI Location. - * This is usually in the form of "0000:ab:cd.e" + - This is usually in the form of "0000:ab:cd.e" -* The `bandwidth_*` options on the network interface are not permitted. +- The `bandwidth_*` options on the network interface are not permitted. -* Adding, modifying, and deleting SR-IOV NICs is supported but requires a VM restart. +- Adding, modifying, and deleting SR-IOV NICs is supported but requires a VM restart. -* Modifying the number of non-SR-IOV (_e.g._, VMXNET3) interfaces when there are SR-IOV interfaces existing is +- Modifying the number of non-SR-IOV (_e.g._, VMXNET3) interfaces when there are SR-IOV interfaces existing is explicitly blocked (as the provider does not support modifying an interface at the same index from non-SR-IOV to SR-IOV or vice-versa). To work around this delete all SRIOV NICs for one terraform apply, and re-add them with any change to the number of non-SRIOV NICs on a second terraform apply. @@ -1097,11 +1098,11 @@ resource "vsphere_virtual_machine" "vm" { The options are: -* `client_device` - (Optional) Indicates whether the device should be backed by remote client device. Conflicts with `datastore_id` and `path`. +- `client_device` - (Optional) Indicates whether the device should be backed by remote client device. Conflicts with `datastore_id` and `path`. -* `datastore_id` - (Optional) The datastore ID that on which the ISO is located. Required for using a datastore ISO. Conflicts with `client_device`. +- `datastore_id` - (Optional) The datastore ID that on which the ISO is located. Required for using a datastore ISO. Conflicts with `client_device`. -* `path` - (Optional) The path to the ISO file. Required for using a datastore ISO. Conflicts with `client_device`. +- `path` - (Optional) The path to the ISO file. Required for using a datastore ISO. Conflicts with `client_device`. ~> **NOTE:** Either `client_device` (for a remote backed CD-ROM) or `datastore_id` and `path` (for a datastore ISO backed CD-ROM) are required to . @@ -1113,9 +1114,9 @@ Virtual devices (`disk`, `network_interface`, and `cdrom`) all export the follow The options are: -* `key` - The ID of the device within the virtual machine. +- `key` - The ID of the device within the virtual machine. -* `device_address` - An address internal to Terraform that helps locate the device when `key` is unavailable. This follows a convention of `CONTROLLER_TYPE:BUS_NUMBER:UNIT_NUMBER`. Example: `scsi:0:1` means device unit `1` on SCSI bus `0`. +- `device_address` - An address internal to Terraform that helps locate the device when `key` is unavailable. This follows a convention of `CONTROLLER_TYPE:BUS_NUMBER:UNIT_NUMBER`. Example: `scsi:0:1` means device unit `1` on SCSI bus `0`. ## Creating a Virtual Machine from a Template @@ -1129,13 +1130,13 @@ See the section on [cloning and customization](#cloning-and-customization) for m The options available in the `clone` block are: -* `template_uuid` - (Required) The UUID of the source virtual machine or template. +- `template_uuid` - (Required) The UUID of the source virtual machine or template. -* `linked_clone` - (Optional) Clone the virtual machine from a snapshot or a template. Default: `false`. +- `linked_clone` - (Optional) Clone the virtual machine from a snapshot or a template. Default: `false`. -* `timeout` - (Optional) The timeout, in minutes, to wait for the cloning process to complete. Default: 30 minutes. +- `timeout` - (Optional) The timeout, in minutes, to wait for the cloning process to complete. Default: 30 minutes. -* `customize` - (Optional) The customization spec for this clone. This allows the user to configure the virtual machine post-clone. For more details, see [virtual machine customizations](#virtual-machine-customizations). +- `customize` - (Optional) The customization spec for this clone. This allows the user to configure the virtual machine post-clone. For more details, see [virtual machine customizations](#virtual-machine-customizations). ### Virtual Machine Customizations @@ -1150,7 +1151,7 @@ The settings for `customize` are as follows: #### Customization Timeout Settings -* `timeout` - (Optional) The time, in minutes, that the provider waits for customization to complete before failing. The default is `10` minutes. Setting the value to `0` or a negative value disables the waiter. +- `timeout` - (Optional) The time, in minutes, that the provider waits for customization to complete before failing. The default is `10` minutes. Setting the value to `0` or a negative value disables the waiter. #### Network Interface Settings @@ -1213,17 +1214,17 @@ resource "vsphere_virtual_machine" "vm" { The options are: -* `dns_server_list` - (Optional) DNS servers for the network interface. Used by Windows guest operating systems, but ignored by Linux distribution guest operating systems. For Linux, please refer to the section on the [global DNS settings](#global-dns-settings). +- `dns_server_list` - (Optional) DNS servers for the network interface. Used by Windows guest operating systems, but ignored by Linux distribution guest operating systems. For Linux, please refer to the section on the [global DNS settings](#global-dns-settings). -* `dns_domain` - (Optional) DNS search domain for the network interface. Used by Windows guest operating systems, but ignored by Linux distribution guest operating systems. For Linux, please refer to the section on the [global DNS settings](#global-dns-settings). +- `dns_domain` - (Optional) DNS search domain for the network interface. Used by Windows guest operating systems, but ignored by Linux distribution guest operating systems. For Linux, please refer to the section on the [global DNS settings](#global-dns-settings). -* `ipv4_address` - (Optional) The IPv4 address assigned to the network adapter. If blank or not included, DHCP is used. +- `ipv4_address` - (Optional) The IPv4 address assigned to the network adapter. If blank or not included, DHCP is used. -* `ipv4_netmask` The IPv4 subnet mask, in bits (_e.g._ `24` for 255.255.255.0). +- `ipv4_netmask` The IPv4 subnet mask, in bits (_e.g._ `24` for 255.255.255.0). -* `ipv6_address` - (Optional) The IPv6 address assigned to the network adapter. If blank or not included, auto-configuration is used. +- `ipv6_address` - (Optional) The IPv6 address assigned to the network adapter. If blank or not included, auto-configuration is used. -* `ipv6_netmask` - (Optional) The IPv6 subnet mask, in bits (_e.g._ `32`). +- `ipv6_netmask` - (Optional) The IPv6 subnet mask, in bits (_e.g._ `32`). ~> **NOTE:** The minimum setting for IPv4 in a customization specification is DHCP. If you are setting up an IPv6-exclusive network without DHCP, you may need to set [`wait_for_guest_net_timeout`](#wait_for_guest_net_timeout) to a high enough value to cover the DHCP timeout of your virtual machine, or disable by supplying a zero or negative value. Disabling `wait_for_guest_net_timeout` may result in IP addresses not being reported to any provisioners you may have configured on the resource. @@ -1235,17 +1236,17 @@ The settings must match the IP address and netmask of at least one `network_inte The options are: -* `ipv4_gateway` - (Optional) The IPv4 default gateway when using `network_interface` customization on the virtual machine. +- `ipv4_gateway` - (Optional) The IPv4 default gateway when using `network_interface` customization on the virtual machine. -* `ipv6_gateway` - (Optional) The IPv6 default gateway when using `network_interface` customization on the virtual machine. +- `ipv6_gateway` - (Optional) The IPv6 default gateway when using `network_interface` customization on the virtual machine. #### Global DNS Settings The following settings configure DNS globally, generally for Linux distribution guest operating systems. For Windows guest operating systems, this is performer per-interface. See the section on [network interface settings](#network-interface-settings) for more information. -* `dns_server_list` - The list of DNS servers to configure on the virtual machine. +- `dns_server_list` - The list of DNS servers to configure on the virtual machine. -* `dns_suffix_list` - A list of DNS search domains to add to the DNS configuration on the virtual machine. +- `dns_suffix_list` - A list of DNS search domains to add to the DNS configuration on the virtual machine. #### Linux Customization Options @@ -1271,18 +1272,18 @@ resource "vsphere_virtual_machine" "vm" { The options are: -* `host_name` - (Required) The host name for this machine. This, along with `domain`, make up the FQDN of the virtual machine. +- `host_name` - (Required) The host name for this machine. This, along with `domain`, make up the FQDN of the virtual machine. -* `domain` - (Required) The domain name for this machine. This, along with `host_name`, make up the FQDN of the virtual machine. +- `domain` - (Required) The domain name for this machine. This, along with `host_name`, make up the FQDN of the virtual machine. -* `hw_clock_utc` - (Optional) Tells the operating system that the hardware clock is set to UTC. Default: `true`. +- `hw_clock_utc` - (Optional) Tells the operating system that the hardware clock is set to UTC. Default: `true`. -* `script_text` - (Optional) The customization script for the virtual machine that will be applied before and / or after guest customization. For more information on enabling and using a customization script, please refer to [VMware KB 74880][kb-74880]. The [Heredoc style][tf-heredoc-strings] of string literal is recommended. +- `script_text` - (Optional) The customization script for the virtual machine that will be applied before and / or after guest customization. For more information on enabling and using a customization script, please refer to [VMware KB 74880][kb-74880]. The [Heredoc style][tf-heredoc-strings] of string literal is recommended. [kb-74880]: https://knowledge.broadcom.com/external/article?articleNumber=313048 [tf-heredoc-strings]: https://www.terraform.io/language/expressions/strings#heredoc-strings -* `time_zone` - (Optional) Sets the time zone. For a list of possible combinations, please refer to [VMware KB 2145518][kb-2145518]. The default is UTC. +- `time_zone` - (Optional) Sets the time zone. For a list of possible combinations, please refer to [VMware KB 2145518][kb-2145518]. The default is UTC. [kb-2145518]: https://knowledge.broadcom.com/external/article?articleNumber=320212 @@ -1311,17 +1312,17 @@ resource "vsphere_virtual_machine" "vm" { The options are: -* `computer_name` - (Required) The computer name of the virtual machine. +- `computer_name` - (Required) The computer name of the virtual machine. -* `admin_password` - (Optional) The administrator password for the virtual machine. +- `admin_password` - (Optional) The administrator password for the virtual machine. ~> **NOTE:** `admin_password` is a sensitive field and will not be output on-screen, but is stored in state and sent to the virtual machine in plain text. -* `workgroup` - (Optional) The workgroup name for the virtual machine. One of this or `join_domain` must be included. +- `workgroup` - (Optional) The workgroup name for the virtual machine. One of this or `join_domain` must be included. -* `join_domain` - (Optional) The domain name in which to join the virtual machine. One of this or `workgroup` must be included. +- `join_domain` - (Optional) The domain name in which to join the virtual machine. One of this or `workgroup` must be included. -* `domain_ou` - (Optional) The `MachineObjectOU` which specifies the full LDAP path name of the OU to which the virtual machine belongs (_e.g._, OU=bar,OU=foo,DC=example,DC=com"). +- `domain_ou` - (Optional) The `MachineObjectOU` which specifies the full LDAP path name of the OU to which the virtual machine belongs (_e.g._, OU=bar,OU=foo,DC=example,DC=com"). ~> **NOTE:** `domain_ou` is only available on vSphere 8.0 Update 2 and later. @@ -1344,25 +1345,25 @@ resource "vsphere_virtual_machine" "vm" { } ``` -* `domain_admin_user` - (Optional) The user account with administrative privileges to use to join the guest operating system to the domain. Required if setting `join_domain`. +- `domain_admin_user` - (Optional) The user account with administrative privileges to use to join the guest operating system to the domain. Required if setting `join_domain`. -* `domain_admin_password` - (Optional) The password user account with administrative privileges used to join the virtual machine to the domain. Required if setting `join_domain`. +- `domain_admin_password` - (Optional) The password user account with administrative privileges used to join the virtual machine to the domain. Required if setting `join_domain`. ~> **NOTE:** `domain_admin_password` is a sensitive field and will not be output on-screen, but is stored in state and sent to the virtual machine in plain text -* `full_name` - (Optional) The full name of the organization owner of the virtual machine. This populates the "user" field in the general Windows system information. Default: `Administrator`. +- `full_name` - (Optional) The full name of the organization owner of the virtual machine. This populates the "user" field in the general Windows system information. Default: `Administrator`. -* `organization_name` - (Optional) The name of the organization for the virtual machine. This option populates the "organization" field in the general Windows system information. Default: `Managed by Terraform`. +- `organization_name` - (Optional) The name of the organization for the virtual machine. This option populates the "organization" field in the general Windows system information. Default: `Managed by Terraform`. -* `product_key` - (Optional) The product key for the virtual machine Windows guest operating system. The default is no key. +- `product_key` - (Optional) The product key for the virtual machine Windows guest operating system. The default is no key. -* `run_once_command_list` - (Optional) A list of commands to run at first user logon, after guest customization. Each run once command is limited by the API to 260 characters. +- `run_once_command_list` - (Optional) A list of commands to run at first user logon, after guest customization. Each run once command is limited by the API to 260 characters. -* `auto_logon` - (Optional) Specifies whether or not the virtual machine automatically logs on as Administrator. Default: `false`. +- `auto_logon` - (Optional) Specifies whether or not the virtual machine automatically logs on as Administrator. Default: `false`. -* `auto_logon_count` - (Optional) Specifies how many times the virtual machine should auto-logon the Administrator account when `auto_logon` is `true`. This option should be set accordingly to ensure that all of your commands that run in `run_once_command_list` can log in to run. Default: `1`. +- `auto_logon_count` - (Optional) Specifies how many times the virtual machine should auto-logon the Administrator account when `auto_logon` is `true`. This option should be set accordingly to ensure that all of your commands that run in `run_once_command_list` can log in to run. Default: `1`. -* `time_zone` - (Optional) The time zone for the virtual machine. For a list of supported codes, please refer to the [MIcrosoft documentation][ms-docs-valid-sysprep-tzs]. The default is `85` (GMT/UTC). +- `time_zone` - (Optional) The time zone for the virtual machine. For a list of supported codes, please refer to the [MIcrosoft documentation][ms-docs-valid-sysprep-tzs]. The default is `85` (GMT/UTC). [ms-docs-valid-sysprep-tzs]: https://msdn.microsoft.com/en-us/library/ms912391(v=winembedded.11).aspx @@ -1397,25 +1398,25 @@ See the [Deploying from OVF example](#deploying-vm-from-an-ovf-ova-template) for The options available in the `ovf_deploy` block are: -* `allow_unverified_ssl_cert` - (Optional) Allow unverified SSL certificates while deploying OVF/OVA from a URL. Defaults `false`. +- `allow_unverified_ssl_cert` - (Optional) Allow unverified SSL certificates while deploying OVF/OVA from a URL. Defaults `false`. -* `enable_hidden_properties` - (Optional) Allow properties with `ovf:userConfigurable=false` to be set. Defaults `false`. +- `enable_hidden_properties` - (Optional) Allow properties with `ovf:userConfigurable=false` to be set. Defaults `false`. -* `local_ovf_path` - (Optional) The absolute path to the OVF/OVA file on the local system. When deploying from an OVF, ensure the necessary files, such as `.vmdk` and `.mf` files are also in the same directory as the `.ovf` file. +- `local_ovf_path` - (Optional) The absolute path to the OVF/OVA file on the local system. When deploying from an OVF, ensure the necessary files, such as `.vmdk` and `.mf` files are also in the same directory as the `.ovf` file. -* `remote_ovf_url` - (Optional) URL to the OVF/OVA file. +- `remote_ovf_url` - (Optional) URL to the OVF/OVA file. ~> **NOTE:** Either `local_ovf_path` or `remote_ovf_url` is required. -* `ip_allocation_policy` - (Optional) The IP allocation policy. +- `ip_allocation_policy` - (Optional) The IP allocation policy. -* `ip_protocol` - (Optional) The IP protocol. +- `ip_protocol` - (Optional) The IP protocol. -* `disk_provisioning` - (Optional) The disk provisioning policy. If set, all the disks included in the OVF/OVA will have the same specified policy. One of `thin`, `flat`, `thick`, or `sameAsSource`. +- `disk_provisioning` - (Optional) The disk provisioning policy. If set, all the disks included in the OVF/OVA will have the same specified policy. One of `thin`, `flat`, `thick`, or `sameAsSource`. -* `deployment_option` - (Optional) The key for the deployment option. If empty, the default option is selected. +- `deployment_option` - (Optional) The key for the deployment option. If empty, the default option is selected. -* `ovf_network_map` - (Optional) The mapping of network identifiers from the OVF descriptor to a network UUID. +- `ovf_network_map` - (Optional) The mapping of network identifiers from the OVF descriptor to a network UUID. ### Using vApp Properties for OVF/OVA Configuration @@ -1508,13 +1509,13 @@ resource "vsphere_virtual_machine" "vm" { When cloning from a template, there are additional requirements in both the resource configuration and source template: -* The virtual machine must not be powered on at the time of cloning. -* All disks on the virtual machine must be SCSI disks. -* You must specify at least the same number of `disk` devices as there are disks that exist in the template. These devices are ordered and lined up by the `unit_number` attribute. Additional disks can be added past this. -* The `size` of a virtual disk must be at least the same size as its counterpart disk in the source template. -* When using `linked_clone`, the `size`, `thin_provisioned`, and `eagerly_scrub` settings for each disk must be an exact match to the individual disk's counterpart in the source template. -* The storage controller count settings should be configured as necessary to cover all of the disks on the template. For best results, only configure this setting for the number of controllers you will need to cover your disk quantity and bandwidth needs, and configure your template accordingly. For most workloads, this setting should be kept at the default of `1` SCSI controller, and all disks in the template should reside on the single, primary controller. -* Some operating systems do not respond well to a change in disk controller type. Ensure that `scsi_type` is set to an exact match of the template's controller set. For maximum compatibility, make sure the SCSI controllers on the source template are all the same type. +- The virtual machine must not be powered on at the time of cloning. +- All disks on the virtual machine must be SCSI disks. +- You must specify at least the same number of `disk` devices as there are disks that exist in the template. These devices are ordered and lined up by the `unit_number` attribute. Additional disks can be added past this. +- The `size` of a virtual disk must be at least the same size as its counterpart disk in the source template. +- When using `linked_clone`, the `size`, `thin_provisioned`, and `eagerly_scrub` settings for each disk must be an exact match to the individual disk's counterpart in the source template. +- The storage controller count settings should be configured as necessary to cover all of the disks on the template. For best results, only configure this setting for the number of controllers you will need to cover your disk quantity and bandwidth needs, and configure your template accordingly. For most workloads, this setting should be kept at the default of `1` SCSI controller, and all disks in the template should reside on the single, primary controller. +- Some operating systems do not respond well to a change in disk controller type. Ensure that `scsi_type` is set to an exact match of the template's controller set. For maximum compatibility, make sure the SCSI controllers on the source template are all the same type. You can use the [`vsphere_virtual_machine`][tf-vsphere-virtual-machine-ds] data source, which provides disk attributes, network interface types, SCSI bus types, and the guest ID of the source template, to return this information. See the section on [cloning and customization](#cloning-and-customization) for more information. @@ -1527,7 +1528,7 @@ When creating a virtual machine or cloning one from a template, you have the opt ```hcl resource "vsphere_virtual_machine" "vm" { # ... other configuration ... - vtpm { + vtpm { version = "2.0" } # ... other configuration ... @@ -1536,6 +1537,24 @@ resource "vsphere_virtual_machine" "vm" { ~> **NOTE:** Supported versions include 1.2 or 2.0. +## USB Controller + +When creating a virtual machine or cloning one from a template, you have the option to add virtual USB controller devices. + +**Example**: + +```hcl +resource "vsphere_virtual_machine" "vm" { + # ... other configuration ... + usb_controller { + version = "3.2" + } + # ... other configuration ... +} +``` + +~> **NOTE:** Supported versions include 2.0 or 3.1 for vSphere 7.x. Supported versions include 2.0 or 3.2 for vSphere 8.x. This setting is only available on new builds, reconfiguration to add a USB controller, and removal of the USB controller. For any reconfiguration option, the machine will power off and back on. + ## Virtual Machine Migration The `vsphere_virtual_machine` resource supports live migration both on the host and storage level. You can migrate the virtual machine to another host, cluster, resource pool, or datastore. You can also migrate or pin a virtual disk to a specific datastore. @@ -1550,9 +1569,9 @@ The same rules apply for migration as they do for virtual machine creation - any Storage migration can be done on two levels: -* Global datastore migration can be handled by changing the global `datastore_id` attribute. This triggers a storage migration for all disks that do not have an explicit `datastore_id` specified. -* When using Storage DRS through the `datastore_cluster_id` attribute, the entire virtual machine can be migrated from one datastore cluster to another by changing the value of this setting. In addition, when `datastore_cluster_id` is in use, any disks that drift to datastores outside of the datastore cluster via such actions as manual modification will be migrated back to the datastore cluster on the next apply. -* An individual `disk` device can be migrated by manually specifying the `datastore_id` in its configuration block. This also pins it to the specific datastore that is specified - if at a later time the virtual machine and any unpinned disks migrate to another host, the disk will stay on the specified datastore. +- Global datastore migration can be handled by changing the global `datastore_id` attribute. This triggers a storage migration for all disks that do not have an explicit `datastore_id` specified. +- When using Storage DRS through the `datastore_cluster_id` attribute, the entire virtual machine can be migrated from one datastore cluster to another by changing the value of this setting. In addition, when `datastore_cluster_id` is in use, any disks that drift to datastores outside of the datastore cluster via such actions as manual modification will be migrated back to the datastore cluster on the next apply. +- An individual `disk` device can be migrated by manually specifying the `datastore_id` in its configuration block. This also pins it to the specific datastore that is specified - if at a later time the virtual machine and any unpinned disks migrate to another host, the disk will stay on the specified datastore. An example of datastore pinning is below. As long as the datastore in the `pinned_datastore` data source does not change, any change to the standard `vm_datastore` data source will not affect the data disk - the disk will stay where it is. @@ -1586,69 +1605,69 @@ You cannot migrate external disks added with the `attach` parameter. Typically, The virtual machine will be rebooted if any of the following parameters are changed: -* `alternate_guest_name` -* `cpu_hot_add_enabled` -* `cpu_hot_remove_enabled` -* `cpu_performance_counters_enabled` -* `disk.controller_type` -* `disk.unit_number` -* `disk.disk_mode` -* `disk.write_through` -* `disk.disk_sharing` -* `efi_secure_boot_enabled` -* `ept_rvi_mode` -* `enable_disk_uuid` -* `enable_logging` -* `extra_config` -* `firmware` -* `guest_id` -* `hardware_version` -* `hv_mode` -* `memory` - When reducing the memory size, or when increasing the memory size and `memory_hot_add_enabled` is set to `false` -* `memory_hot_add_enabled` -* `nested_hv_enabled` -* `network_interface` - When deleting a network interface and VMware Tools is not running. -* `network_interface.adapter_type` - When VMware Tools is not running. -* `num_cores_per_socket` -* `pci_device_id` -* `run_tools_scripts_after_power_on` -* `run_tools_scripts_after_resume` -* `run_tools_scripts_before_guest_standby` -* `run_tools_scripts_before_guest_shutdown` -* `run_tools_scripts_before_guest_reboot` -* `swap_placement_policy` -* `tools_upgrade_policy` -* `vbs_enabled` -* `vvtd_enabled` -* `vtpm` +- `alternate_guest_name` +- `cpu_hot_add_enabled` +- `cpu_hot_remove_enabled` +- `cpu_performance_counters_enabled` +- `disk.controller_type` +- `disk.unit_number` +- `disk.disk_mode` +- `disk.write_through` +- `disk.disk_sharing` +- `efi_secure_boot_enabled` +- `ept_rvi_mode` +- `enable_disk_uuid` +- `enable_logging` +- `extra_config` +- `firmware` +- `guest_id` +- `hardware_version` +- `hv_mode` +- `memory` - When reducing the memory size, or when increasing the memory size and `memory_hot_add_enabled` is set to `false` +- `memory_hot_add_enabled` +- `nested_hv_enabled` +- `network_interface` - When deleting a network interface and VMware Tools is not running. +- `network_interface.adapter_type` - When VMware Tools is not running. +- `num_cores_per_socket` +- `pci_device_id` +- `run_tools_scripts_after_power_on` +- `run_tools_scripts_after_resume` +- `run_tools_scripts_before_guest_standby` +- `run_tools_scripts_before_guest_shutdown` +- `run_tools_scripts_before_guest_reboot` +- `swap_placement_policy` +- `tools_upgrade_policy` +- `vbs_enabled` +- `vvtd_enabled` +- `vtpm` ## Attribute Reference The following attributes are exported on the base level of this resource: -* `id` - The UUID of the virtual machine. +- `id` - The UUID of the virtual machine. -* `reboot_required` - Value internal to Terraform used to determine if a configuration set change requires a reboot. This value is most useful during an update process and gets reset on refresh. +- `reboot_required` - Value internal to Terraform used to determine if a configuration set change requires a reboot. This value is most useful during an update process and gets reset on refresh. -* `vmware_tools_status` - The state of VMware Tools in the guest. This will determine the proper course of action for some device operations. +- `vmware_tools_status` - The state of VMware Tools in the guest. This will determine the proper course of action for some device operations. -* `vmx_path` - The path of the virtual machine configuration file on the datastore in which the virtual machine is placed. +- `vmx_path` - The path of the virtual machine configuration file on the datastore in which the virtual machine is placed. -* `imported` - Indicates if the virtual machine resource has been imported, or if the state has been migrated from a previous version of the resource. It influences the behavior of the first post-import apply operation. See the section on [importing](#importing) below. +- `imported` - Indicates if the virtual machine resource has been imported, or if the state has been migrated from a previous version of the resource. It influences the behavior of the first post-import apply operation. See the section on [importing](#importing) below. -* `change_version` - A unique identifier for a given version of the last configuration was applied. +- `change_version` - A unique identifier for a given version of the last configuration was applied. -* `uuid` - The UUID of the virtual machine. Also exposed as the `id` of the resource. +- `uuid` - The UUID of the virtual machine. Also exposed as the `id` of the resource. -* `default_ip_address` - The IP address selected by Terraform to be used with any [provisioners][tf-docs-provisioners] configured on this resource. When possible, this is the first IPv4 address that is reachable through the default gateway configured on the machine, then the first reachable IPv6 address, and then the first general discovered address if neither exists. If VMware Tools is not running on the virtual machine, or if the virtual machine is powered off, this value will be blank. +- `default_ip_address` - The IP address selected by Terraform to be used with any [provisioners][tf-docs-provisioners] configured on this resource. When possible, this is the first IPv4 address that is reachable through the default gateway configured on the machine, then the first reachable IPv6 address, and then the first general discovered address if neither exists. If VMware Tools is not running on the virtual machine, or if the virtual machine is powered off, this value will be blank. -* `guest_ip_addresses` - The current list of IP addresses on this machine, including the value of `default_ip_address`. If VMware Tools is not running on the virtual machine, or if the virtul machine is powered off, this list will be empty. +- `guest_ip_addresses` - The current list of IP addresses on this machine, including the value of `default_ip_address`. If VMware Tools is not running on the virtual machine, or if the virtul machine is powered off, this list will be empty. -* `moid`: The [managed object reference ID][docs-about-morefs] of the created virtual machine. +- `moid`: The [managed object reference ID][docs-about-morefs] of the created virtual machine. -* `vapp_transport` - Computed value which is only valid for cloned virtual machines. A list of vApp transport methods supported by the source virtual machine or template. +- `vapp_transport` - Computed value which is only valid for cloned virtual machines. A list of vApp transport methods supported by the source virtual machine or template. -* `power_state` - A computed value for the current power state of the virtual machine. One of `on`, `off`, or `suspended`. +- `power_state` - A computed value for the current power state of the virtual machine. One of `on`, `off`, or `suspended`. [docs-about-morefs]: https://registry.terraform.io/providers/hashicorp/vsphere/latest/docs#use-of-managed-object-references-by-the-vsphere-provider @@ -1680,21 +1699,21 @@ Many of the requirements for [cloning](#additional-requirements-and-notes-for-cl The following requirements apply to import: -* The disks must have a [`label`](#label) argument assigned in a convention matching `Hard Disk`, starting with disk number 0, based on each virtual disk order on the SCSI bus. As an example, a disk on SCSI controller `0` with a unit number of `0` would be labeled as `Hard Disk 0`, a disk on the same controller with a unit number of `1` would be `Hard Disk 1`, but the next disk, which is on SCSI controller `1` with a unit number of `0`, still becomes `Hard Disk 2`. +- The disks must have a [`label`](#label) argument assigned in a convention matching `Hard Disk`, starting with disk number 0, based on each virtual disk order on the SCSI bus. As an example, a disk on SCSI controller `0` with a unit number of `0` would be labeled as `Hard Disk 0`, a disk on the same controller with a unit number of `1` would be `Hard Disk 1`, but the next disk, which is on SCSI controller `1` with a unit number of `0`, still becomes `Hard Disk 2`. ~> **NOTE:** Any custom `label` set at deployment of machine through Terraform, on import will not have the custom `label` and will default to `Hard Disk _x_`. -* Disks are always imported with [`keep_on_remove`](#keep_on_remove) enabled until the first `terraform apply` run which will remove the setting for known disks. This process safeguards against naming or accounting mistakes in the disk configuration. +- Disks are always imported with [`keep_on_remove`](#keep_on_remove) enabled until the first `terraform apply` run which will remove the setting for known disks. This process safeguards against naming or accounting mistakes in the disk configuration. -* The storage controller count for the resource is set to the number of contiguous storage controllers found, starting with the controller at SCSI bus number `0`. If no storage controllers are discovered, the virtual machine is not eligible for import. For maximum compatibility, ensure that the virtual machine has the exact number of storage controllers needed and set the storage controller count accordingly. +- The storage controller count for the resource is set to the number of contiguous storage controllers found, starting with the controller at SCSI bus number `0`. If no storage controllers are discovered, the virtual machine is not eligible for import. For maximum compatibility, ensure that the virtual machine has the exact number of storage controllers needed and set the storage controller count accordingly. After importing, you should run `terraform plan`. Unless you have changed anything else in the configuration that would cause other attributes to change. The only difference should be configuration-only changes, which are typically comprised of: -* The [`imported`](#imported) flag will transition from `true` to `false`. +- The [`imported`](#imported) flag will transition from `true` to `false`. -* The [`keep_on_remove`](#keep_on_remove) of known disks will transition from `true` to `false`. +- The [`keep_on_remove`](#keep_on_remove) of known disks will transition from `true` to `false`. -* Configuration supplied in the [`clone`](#clone) block, if present, will be persisted to state. This initial persistence operation does not perform any cloning or customization actions, nor does it force a new resource. After the first apply operation, further changes to `clone` will force the creation of a new resource. +- Configuration supplied in the [`clone`](#clone) block, if present, will be persisted to state. This initial persistence operation does not perform any cloning or customization actions, nor does it force a new resource. After the first apply operation, further changes to `clone` will force the creation of a new resource. ~> **NOTE:** Do not make any configuration changes to `clone` after importing or upgrading from a legacy version of the provider before doing an initial `terraform apply` as these changes will not correctly force a new resource and your changes will have persisted to state, preventing further plans from correctly triggering a diff.