{
     "NameField": "VirtualMachine",
     "DescriptionField": "VirtualMachine is the managed object type for manipulating virtual machines, including templates that can be deployed (repeatedly) as new virtual machines. This type provides methods for configuring and controlling a virtual machine. VirtualMachine extends the ManagedEntity type because virtual machines are part of a virtual infrastructure inventory. The parent of a virtual machine must be a folder, and a virtual machine has no children. Destroying a virtual machine disposes of all associated storage, including the virtual disks. To remove a virtual machine while retaining its virtual disk storage, a client must remove the virtual disks from the virtual machine before destroying it. ",
     "Name": "Name of Virtual Machine.",
     "environmentBrowser": "The current virtual machines environment browser object. This contains information on all the configurations that can be used on the virtual machine. This is identical to the environment browser on the ComputeResource to which this virtual machine belongs.",
     "guestHeartbeatStatus": "The guest heartbeat. The heartbeat status is classified as:  gray - VMware Tools are not installed or not running. red - No heartbeat. Guest operating system may have stopped responding. yellow - Intermittent heartbeat. May be due to guest load. green - Guest operating system is responding normally. The guest heartbeat is a statistics metric. Alarms can be configured on this metric to trigger emails or other actions.",
     "layout": "Deprecated. As of vSphere API 4.0, use LayoutEx instead. In releases after vSphere API 5.0, vSphere Servers might not generate property collector update notifications for this property. To obtain the latest value of the property, you can use PropertyCollector methods RetrievePropertiesEx or WaitForUpdatesEx. If you use the PropertyCollector.WaitForUpdatesEx method, specify an empty string for the version parameter. Any other version value will not produce any property values as no updates are generated. Detailed information about the files that comprise this virtual machine.",
     "layoutEx": "Detailed information about the files that comprise this virtual machine. Can be explicitly refreshed by the RefreshStorageInfo operation. In releases after vSphere API 5.0, vSphere Servers might not generate property collector update notifications for this property. To obtain the latest value of the property, you can use PropertyCollector methods RetrievePropertiesEx or WaitForUpdatesEx. If you use the PropertyCollector.WaitForUpdatesEx method, specify an empty string for the version parameter. Any other version value will not produce any property values as no updates are generated. Since vSphere API 4.0",
     "parentVApp": "Reference to the parent vApp. Since vSphere API 4.1",
     "resourcePool": "The current resource pool that specifies resource allocation for this virtual machine. This property is set when a virtual machine is created or associated with a different resource pool. Returns null if the virtual machine is a template or the session has no access to the resource pool.",
     "runtime": "Execution state and history for this virtual machine. The contents of this property change when:  the virtual machines power state changes. an execution message is pending. an event occurs.",
     "snapshot": "Current snapshot and tree. The property is valid if snapshots have been created for this virtual machine. The contents of this property change in response to the methods:  CreateSnapshot_Task RevertToCurrentSnapshot_Task RemoveSnapshot_Task RevertToSnapshot_Task RemoveAllSnapshots_Task",
     "storage": "Storage space used by the virtual machine, split by datastore. Can be explicitly refreshed by the RefreshStorageInfo operation. In releases after vSphere API 5.0, vSphere Servers might not generate property collector update notifications for this property. To obtain the latest value of the property, you can use PropertyCollector methods RetrievePropertiesEx or WaitForUpdatesEx. If you use the PropertyCollector.WaitForUpdatesEx method, specify an empty string for the version parameter. Any other version value will not produce any property values as no updates are generated. Since vSphere API 4.0",
     "summary": "Basic information about this virtual machine. This includes:  runtimeInfo guest basic configuration alarms performance information",
     "capability": {
          "NameField": "capability",
          "DescriptionField": " This data object type contains information about the operation/capabilities of a virtual machine ",
          "bootOptionsSupported": "Indicates whether boot options can be configured for this virtual machine.Since VI API 2.5",
          "bootRetryOptionsSupported": "Indicates whether automatic boot retry can be configured for this virtual machine.Since vSphere API 4.1",
          "changeModeDisksSupported": "Indicates support for change mode on virtual disksSince 8.0.0.1",
          "changeTrackingSupported": "Indicates that change tracking is supported for virtual disks of this virtual machine. However, even if change tracking is supported, it might not be available for all disks of the virtual machine. For example, passthru raw disk mappings or disks backed by any Ver1BackingInfo cannot be tracked.Since vSphere API 4.0",
          "consolePreferencesSupported": "Indicates whether console preferences can be set for this virtual machine.",
          "cpuFeatureMaskSupported": "Indicates whether CPU feature requirements masks can be set for this virtual machine. Masking for hardware version 9 and newer virtual machines is controlled by featureRequirementSupported.",
          "disableSnapshotsSupported": "Deprecated. As of vSphere API 4.0. The value returned from the server is always false. Indicates whether or not snapshots can be disabled.Since VI API 2.5",
          "diskOnlySnapshotOnSuspendedVMSupported": "Indicates whether this virtual machine supports creating disk-only snapshots in suspended state. If this capability is not set, the snapshot of a virtual machine in suspended state will always include memory.Since vSphere API 6.7",
          "diskSharesSupported": "Indicates whether resource settings for disks can be applied to this virtual machine.Since VI API 2.5",
          "featureRequirementSupported": "Indicates whether featureRequirement feature is supported.Since vSphere API 5.1",
          "guestAutoLockSupported": "Indicates whether features like guest OS auto-lock and MKS connection controls are supported for this virtual machine.Since vSphere API 5.0",
          "hostBasedReplicationSupported": "Indicates that host based replication is supported on this virtual machine. However, even if host based replication is supported, it might not be available for all disk types. For example, passthru raw disk mappings can not be replicated.Since vSphere API 5.0",
          "lockSnapshotsSupported": "Indicates whether or not the snapshot tree can be locked.Since VI API 2.5",
          "memoryReservationLockSupported": "Indicates whether memoryReservationLockedToMax may be set to true for this virtual machine.Since vSphere API 5.0",
          "memorySnapshotsSupported": "Indicates whether or not a virtual machine supports memory snapshots.",
          "multipleCoresPerSocketSupported": "Indicates whether multiple virtual cores per socket is supported on this VM.Since vSphere API 5.0",
          "multipleSnapshotsSupported": "Indicates whether or not a virtual machine supports multiple snapshots. This value is not set when the virtual machine is unavailable, for instance, when it is being created or deleted.",
          "nestedHVSupported": "Indicates whether this virtual machine supports nested hardware-assisted virtualization.Since vSphere API 5.1",
          "npivWwnOnNonRdmVmSupported": "Supports assigning NPIV WWN to virtual machines that dont have RDM disks.Since VI API 2.5",
          "perVmEvcSupported": "Indicates whether this virtual machine supports Per-VM EVC mode.Since vSphere API 6.7",
          "pmemFailoverSupported": "Indicates support for failover to a different host on VMs with pmem. Failover is supported when set to true, and unsupported otherwise.Since vSphere API 7.0.2.0",
          "poweredOffSnapshotsSupported": "Indicates whether or not a virtual machine supports snapshot operations in poweredOff state. This flag doesnt affect vim.VirtualMachine.GetSnapshot, which is always supported.",
          "poweredOnMonitorTypeChangeSupported": "Indicates whether a monitor type change is supported while this virtual machine is in the poweredOn state.Since vSphere API 5.1",
          "quiescedSnapshotsSupported": "Indicates whether or not a virtual machine supports quiesced snapshots.",
          "recordReplaySupported": "Deprecated. as of vSphere API 6.0Indicates whether record and replay functionality is supported on this virtual machine.Since vSphere API 4.0",
          "requireSgxAttestationSupported": "Whether the VM supports requiring SGX remote attestation.Since 8.0.0.1",
          "revertToSnapshotSupported": "Indicates whether or not a virtual machine supports reverting to a snapshot.",
          "s1AcpiManagementSupported": "Indicates whether or not a virtual machine supports ACPI S1 settings management.",
          "secureBootSupported": "Indicates whether secureBoot is supported for this virtual machine.Since vSphere API 6.5",
          "seSparseDiskSupported": "Indicates whether this virtual machine supports the Flex-SE (space-efficient, sparse) format for virtual disks.Since vSphere API 5.1",
          "settingDisplayTopologySupported": "Indicates whether or not this virtual machine supports setting the display topology of the console window. This capability depends on the guest operating system configured for this virtual machine.Since vSphere API 4.0",
          "settingScreenResolutionSupported": "Indicates whether or not this virtual machine supports setting the screen resolution of the console window. This capability depends on the guest operating system configured for this virtual machine.",
          "settingVideoRamSizeSupported": "Flag indicating whether the video ram size of this virtual machine can be configured.Since VI API 2.5",
          "sevSupported": "Indicates support for AMD-SEV (Secure Encrypted Virtualization). SEV is supported when set to true, and unsupported otherwise.Since vSphere API 7.0.1.0",
          "snapshotConfigSupported": "Indicates whether or not a virtual machine supports snapshot config.",
          "snapshotOperationsSupported": "Indicates whether or not a virtual machine supports snapshot operations.",
          "suspendToMemorySupported": "Indicates whether this virtual machine supports suspending to memory.Since vSphere API 7.0.2.0",
          "swapPlacementSupported": "Flag indicating whether the virtual machine has a configurable swapPlacement.Since VI API 2.5",
          "toolsAutoUpdateSupported": "Supports tools auto-update.",
          "toolsSyncTimeAllowSupported": "Indicates support for allowing or disallowing all tools time sync with host.Since vSphere API 7.0.1.0",
          "toolsSyncTimeSupported": "Indicates whether asking tools to sync time with the host is supported.Since VI API 2.5",
          "vendorDeviceGroupSupported": "Indicates support for Vendor Device GroupsSince 8.0.1.0",
          "virtualExecUsageIgnored": "Indicates that virtualExecUsage is ignored by this virtual machine, always operating as if hvOn was selected.Since vSphere API 6.7",
          "virtualMmuUsageIgnored": "Indicates that virtualMmuUsage is ignored by this virtual machine, always operating as if on was selected.Since vSphere API 6.7",
          "virtualMmuUsageSupported": "Indicates whether or not the use of nested page table hardware support can be explicitly set.Since VI API 2.5",
          "vmNpivWwnDisableSupported": "Indicates whether the NPIV disabling operation is supported the virtual machine.Since vSphere API 4.0",
          "vmNpivWwnSupported": "Supports virtual machine NPIV WWN.Since VI API 2.5",
          "vmNpivWwnUpdateSupported": "Indicates whether the update of NPIV WWNs are supported on the virtual machine.Since vSphere API 4.0",
          "vPMCSupported": "Indicates whether this virtual machine supports virtualized CPU performance counters.Since vSphere API 5.1",
          "nesting_SQL_name": "Virtualmachinecapability"
     },
     "config": {
          "NameField": "config",
          "DescriptionField": " The ConfigInfo data object type encapsulates the configuration settings and virtual hardware for a virtual machine. This type holds all the information that is present in the .vmx configuration file for the virtual machine. ",
          "alternateGuestName": "Used as display name for the operating system if guestId is {@code other} or {@code other-64}. See guestFullName Since VI API 2.5",
          "annotation": "Description for the virtual machine.",
          "bootOptions": "Configuration options for the boot behavior of the virtual machine. Since VI API 2.5",
          "changeTrackingEnabled": "Indicates whether changed block tracking for this VMs disks is active. Since vSphere API 4.0",
          "changeVersion": "The changeVersion is a unique identifier for a given version of the configuration. Each change to the configuration updates this value. This is typically implemented as an ever increasing count or a time-stamp. However, a client should always treat this as an opaque string.",
          "consolePreferences": "Legacy console viewer preferences when doing power operations.",
          "contentLibItemInfo": "Content Library Item info. Since vSphere API 7.0",
          "cpuAffinity": "Affinity settings for CPU.",
          "cpuFeatureMask": "Specifies CPU feature compatibility masks that override the defaults from the GuestOsDescriptor of the virtual machines guest OS. As of vSphere API 6.5 FeatureMask is the recommended method for masking virtual machines with hardware version 9 and above (newer). They can be viewed via featureMask.",
          "cpuHotAddEnabled": "Whether virtual processors can be added while this virtual machine is running. Since vSphere API 4.0",
          "cpuHotRemoveEnabled": "Whether virtual processors can be removed while this virtual machine is running. Since vSphere API 4.0",
          "createDate": "Time the virtual machines configuration was created. Since vSphere API 6.7",
          "datastoreUrl": "Enumerates the set of datastores that this virtual machine is stored on, as well as the URL identification for each of these. Changes to datastores do not generate property updates on this property. However, when this property is retrieved it returns the current datastore information.",
          "defaultPowerOps": "Configuration of default power operations. Since 8.0.0.1",
          "deviceGroups": "Assignable hardware device groups. Since 8.0.0.1",
          "deviceSwap": "Status of the device swap operation. Since 8.0.0.1",
          "files": "Information about the files associated with a virtual machine. This information does not include files for specific virtual disks or snapshots.",
          "firmware": "Information about firmware type for this Virtual Machine. Possible values are described in GuestOsDescriptorFirmwareType When creating a new VM: - If vim.vm.FlagInfo.vbsEnabled is set to true and this property is set to bios, error is returned. - If this property is unset and vim.vm.FlagInfo.vbsEnabled is set to true, this property is set to efi. Since vSphere API 5.0",
          "fixedPassthruHotPlugEnabled": "Indicates whether support to add and remove fixed passthrough devices when the VM is running is enabled. Since 8.0.1.0",
          "flags": "Additional flags for a virtual machine.",
          "forkConfigInfo": "Fork configuration of this virtual machines. If unset, this virtual machine is not configured for fork. Since vSphere API 6.0",
          "ftEncryptionMode": "An enum describing whether encrypted Fault Tolerance is required for this VM. See VirtualMachineConfigSpecEncryptedFtModes for allowed values. - This defaults to opportunistic for a regular VM, and will be set to required for an encrypted VM. - If this property is unset, the mode of encrypted Fault Tolerance will be set to opportunistic. Since vSphere API 7.0.2.0",
          "ftInfo": "Fault Tolerance settings for this virtual machine. Since vSphere API 4.0",
          "guestAutoLockEnabled": "Indicates whether the guest operating system will logout any active sessions whenever there are no remote display connections open to the virtual machine. Since vSphere API 5.0",
          "guestFullName": "This is the full name of the guest operating system for the virtual machine. For example: Windows 2000 Professional.",
          "guestId": "Guest operating system configured on a virtual machine. This is a guest identifier that can be used to access the GuestOsDescriptor list for information about default configuration. For more information on possible values, see VirtualMachineGuestOsIdentifier.",
          "guestIntegrityInfo": "Guest integrity platform configuration. Since vSphere API 6.5",
          "guestMonitoringModeInfo": "GMM configuration. Since vSphere API 7.0",
          "hotPlugMemoryIncrementSize": "Memory, in MB that can be added to a running virtual machine must be in increments of this value and needs be a multiple of this value. This value is determined by the virtual machine and is specified only if memoryHotAddEnabled has been set to true. Since vSphere API 4.0",
          "hotPlugMemoryLimit": "The maximum amount of memory, in MB, than can be added to a running virtual machine. This value is determined by the virtual machine and is specified only if memoryHotAddEnabled is set to true. Since vSphere API 4.0",
          "initialOverhead": "Set of values to be used only to perform admission control when determining if a host has sufficient resources for the virtual machine to power on. Since vSphere API 5.0",
          "instanceUuid": "VirtualCenter-specific 128-bit UUID of a virtual machine, represented as a hexademical string. This identifier is used by VirtualCenter to uniquely identify all virtual machine instances, including those that may share the same SMBIOS UUID. Since vSphere API 4.0",
          "keyId": "Virtual Machine cryptographic options. Since vSphere API 6.5",
          "latencySensitivity": "The latency-sensitivity of the virtual machine. Since vSphere API 5.1",
          "locationId": "Hash incorporating the virtual machines config file location and the UUID of the host assigned to run the virtual machine.",
          "managedBy": "Specifies that this VM is managed by a VC Extension. See the managedBy property in the ConfigSpec for more details. Since vSphere API 5.0",
          "maxMksConnections": "Indicates the maximum number of active remote display connections that the virtual machine will support. Since vSphere API 5.0",
          "memoryAffinity": "Deprecated. since vSphere 6.0. Affinity settings for memory.",
          "memoryHotAddEnabled": "Whether memory can be added while this virtual machine is running. Since vSphere API 4.0",
          "memoryReservationLockedToMax": "If set true, memory resource reservation for this virtual machine will always be equal to the virtual machines memory size; increases in memory size will be rejected when a corresponding reservation increase is not possible. Since vSphere API 5.0",
          "messageBusTunnelEnabled": "Whether to allow tunneling of clients from the guest VM into the common message bus on the host network. Since vSphere API 6.0",
          "migrateEncryption": "An enum describing whether encrypted vMotion is required for this VM. See VirtualMachineConfigSpecEncryptedVMotionModes for allowed values. This defaults to opportunistic for a regular VM, and will be set to required for an encrypted VM. Since vSphere API 6.5",
          "modified": "Last time a virtual machines configuration was modified.",
          "name": "Display name of the virtual machine. Any / (slash), \\ (backslash), character used in this name element is escaped. Similarly, any % (percent) character used in this name element is escaped, unless it is used to start an escape sequence. A slash is escaped as %2F or %2f. A backslash is escaped as %5C or %5c, and a percent is escaped as %25.",
          "nestedHVEnabled": "Indicates whether this VM is configured to use nested hardware-assisted virtualization. Since vSphere API 5.1",
          "networkShaper": "Deprecated. from vSphere 5.5, shaping policy on VM is not supported. Resource limits for network.",
          "npivDesiredNodeWwns": "The NPIV node WWNs to be extended from the original list of WWN nummbers. This property should be set to desired number which is an aggregate of existing plus new numbers. Desired Node WWNs should always be greater than the existing number of node WWNs. Since vSphere API 4.0",
          "npivDesiredPortWwns": "The NPIV port WWNs to be extended from the original list of WWN numbers. This property should be set to desired number which is an aggregate of existing plus new numbers. Desired Node WWNs should always be greater than the existing number of port WWNs. Since vSphere API 4.0",
          "npivNodeWorldWideName": "A 64-bit node WWN (World Wide Name). These WWNs are paired with the npivPortWorldWideName to be used by the NPIV VPORTs instantiated for the virtual machine on the physical HBAs of the host. A pair of node and port WWNs serves as a unique identifier in accessing a LUN, so that it can be monitored or controlled by the storage administrator. If this property contains a single node WWN, the same node WWN is used to pair with all port WWNs listed in npivPortWorldWideName. If this property or npivPortWorldWideName is empty or unset, NPIV WWN is disabled for the virtual machine. Since VI API 2.5",
          "npivOnNonRdmDisks": "This property is used to check whether the NPIV can be enabled on the Virtual machine with non-rdm disks in the configuration, so this is potentially not enabling npiv on vmfs disks. Also this property is used to check whether RDM is required to generate WWNs for a virtual machine. Since vSphere API 4.0",
          "npivPortWorldWideName": "A 64-bit port WWN (World Wide Name). For detail description on WWN, see npivNodeWorldWideName. Since VI API 2.5",
          "npivTemporaryDisabled": "This property is used to enable or disable the NPIV capability on a desired virtual machine on a temporary basis. When this property is set NPIV Vport will not be instantiated by the VMX process of the Virtual Machine. When this property is set port WWNs and node WWNs in the VM configuration are preserved. Since vSphere API 4.0",
          "npivWorldWideNameType": "The source that provides/generates the assigned WWNs. See VirtualMachineConfigInfoNpivWwnType Since VI API 2.5",
          "numaInfo": "vNUMA info. Since 8.0.0.1",
          "pmem": "Virtual persistent memory info. Since vSphere API 7.0.3.0",
          "pmemFailoverEnabled": "Property to indicate PMem HA failover configuration. - When set to TRUE, VMs configured to use PMem will be failed over to other hosts by HA, but the data in NVDIMM is not persistent. - When set to FALSE, VMs configured to use PMem will not be failed over to other hosts by HA. Property is currently only applicable to VMs with NVDimms and will fail to set True if vPMem disks are present. Since vSphere API 7.0.2.0",
          "rebootPowerOff": "Whether the next reboot will result in a power off. Since 8.0.0.1",
          "repConfig": "vSphere Replication settings for this virtual machine. Note this may become deprecated in the future releases. We discourage any unnecessary dependency on this field. Since vSphere API 6.0",
          "scheduledHardwareUpgradeInfo": "Configuration of scheduled hardware upgrades and result from last attempt to run scheduled hardware upgrade. See ScheduledHardwareUpgradeInfo Since vSphere API 5.1",
          "sevEnabled": "SEV (Secure Encrypted Virtualization) enabled or not. SEV is enabled when set to true, and disabled otherwise. Since vSphere API 7.0.1.0",
          "sgxInfo": "Configuration of SGX, Software Guard Extensions for the VM. Since vSphere API 7.0",
          "swapPlacement": "Virtual machine swapfile placement policy. This will be unset if the virtual machines swapPlacementSupported capability is false. If swapPlacementSupported is true, the default policy is inherit. See VirtualMachineConfigInfoSwapPlacementType Since VI API 2.5",
          "swapStorageObjectId": "Virtual Machine Swap Object Identifier. With Object-based Storage systems, VMs Swap is backed by an object. This identifier will be set only if VM swap resided on object-based storage systems. Since vSphere API 6.0",
          "template": "Flag indicating whether or not a virtual machine is a template.",
          "tools": "Configuration of VMware Tools running in the guest operating system.",
          "uuid": "128-bit SMBIOS UUID of a virtual machine represented as a hexadecimal string in 12345678-abcd-1234-cdef-123456789abc format.",
          "vAssertsEnabled": "Indicates whether user-configured virtual asserts will be triggered during virtual machine replay. Since vSphere API 4.0",
          "vcpuConfig": "Vcpu configuration. The vcpuConfig array is indexed by vcpu number. Since vSphere API 7.0",
          "version": "The version string for this virtual machine.",
          "vFlashCacheReservation": "Deprecated. since vSphere 7.0 because vFlash Read Cache end of availability. Specifies the total vFlash resource reservation for the vFlash caches associated with this VMs virtual disks, in bytes. This reservation must be allocated to power on the VM. See vFlashCacheAllocation for allocated reservation when VM is powered on. Since vSphere API 5.5",
          "vmOpNotificationTimeout": "Operation notification timeout in seconds. - Specifies the maximum time the application can take to prepare for the operation after its been notified. This value is used only if vmOpNotificationToAppEnabled is set to TRUE. - If vmOpNotificationTimeout is unset, then it defaults to cluster/host timeout. Since 8.0.0.1",
          "vmOpNotificationToAppEnabled": "Indicates whether operation notification to applications is enabled/disabled. - When set to TRUE, application running inside the VM will be notified of operations for which they have registered. - If unset or FALSE, new applications are not allowed to register for notifications and RPCs will no longer be supported from already registered applications. Since vSphere API 7.0.3.0",
          "vmStorageObjectId": "Virtual Machine Object Identifier. With Object-based Storage systems, Virtual Machine home directory is backed by an object. This identifier will be set only if VM directory resided on object-based storage systems. Since vSphere API 6.0",
          "vmxConfigChecksum": "A checksum of vmx config file. Since vSphere API 6.0",
          "vmxStatsCollectionEnabled": "Indicates whether VMXStats Collection is enabled/disabled. - If TRUE, VMXStats is enabled for the VM and a scoreboard file is created to store stats for various VMX components. - If FALSE, VMXStats is disabled for the VM and there is no scoreboard file created. Since 7.0.3.1",
          "vPMCEnabled": "Indicates whether this VM have virtual CPU performance counters enabled. Since vSphere API 5.1",
          "cpualloc": {
               "NameField": "cpualloc",
               "DescriptionField": "The ResourceAllocationInfo data object specifies the reserved resource requirement as well as the limit (maximum allowed usage) for a given kind of resource. This is specified for both memory allocation (specified in MB) and CPU allocation (specified in MHz).For a ResourcePool, the ResourceAllocationInfo object describes both the guaranteed amount of the resource (reservation) and whether or not it is expandable (expandableReservation). If expandableReservation is true, then the resource pool can grow its reservation dynamically by borrowing unreserved resources from its parent resource pool. For the methods CreateResourcePool, CreateVApp and ImportVApp, you must provide values for all properties except overheadLimit; they are not optional. (Currently, overheadLimit is for vCenter Server use only.) If the limit is configured, it must be greater than or equal to the reservation. ",
               "expandableReservation": "In a resource pool with an expandable reservation, the reservation on a resource pool can grow beyond the specified value, if the parent resource pool has unreserved resources. A non-expandable reservation is called a fixed reservation. This property is invalid for virtual machines.",
               "limit_": "The utilization of a virtual machine/resource pool will not exceed this limit, even if there are available resources. This is typically used to ensure a consistent performance of virtual machines / resource pools independent of available resources. If set to -1, then there is no fixed limit on resource usage (only bounded by available resources and shares). Units are MB for memory, MHz for CPU.",
               "overheadLimit": "The maximum allowed overhead memory. For a powered on virtual machine, the overhead memory reservation cannot be larger than its overheadLimit. This property is only applicable to powered on virtual machines and is not persisted across reboots. This property is not applicable for resource pools. If set to -1, then there is no limit on reservation. Units are MB.    Note: For vCenter Server use only. Not available for other clients at this time. The server will throw an exception if you attempt to set this property.    Since VI API 2.5",
               "reservation": "Amount of resource that is guaranteed available to the virtual machine or resource pool. Reserved resources are not wasted if they are not used. If the utilization is less than the reservation, the resources can be utilized by other running virtual machines. Units are MB for memory, MHz for CPU.",
               "shares": "Memory shares are used in case of resource contention.",
               "nesting_SQL_name": "Virtualmachineconfigcpualloc"
          },
          "extraConfig": {
               "NameField": "extraConfig",
               "DescriptionField": " Describes the key/value pair of a configured option. ",
               "key_": "The name of the option using dot notation to reflect the options position in a hierarchy. For example, you might have an option called Ethernet and another option that is a child of that called Connection. In this case, the key for the latter could be defined as Ethernet.Connection",
               "value": "The value of the option. The Any data object type enables you to define any value for the option. Typically, however, the value of an option is of type String or Integer.",
               "nesting_SQL_name": "Virtualmachineconfigextraconfig"
          },
          "hardware": {
               "NameField": "hardware",
               "DescriptionField": " The VirtualHardware data object type contains the complete configuration of the hardware in a virtual machine. ",
               "autoCoresPerSocket": "Cores per socket is automatically determined.    Since 8.0.0.1",
               "memoryMB": "Memory size, in MB.",
               "motherboardLayout": "One of motherboardLayout choices. Default is i440bxHostBridge. See motherboardLayout    Since 8.0.0.1",
               "numCoresPerSocket": "Number of cores used to distribute virtual CPUs among sockets in this virtual machine. This field should be ignored for powered off VM with autoCoresPerSocket equals TRUE, because the virtual socket size will be assigned during power-on. This field could be unset for releases prior to 7.0 U3, and it implies numCoresPerSocket is 1. In other cases, this field represents the actual virtual socket size seen by the virtual machine.    Since vSphere API 5.0",
               "numCPU": "Number of virtual CPUs present in this virtual machine.",
               "simultaneousThreads": "Number of SMT (Simultaneous multithreading) threads. If unset, then system defaults are in use.    Since 8.0.0.1",
               "virtualICH7MPresent": "Does this virtual machine have Virtual Intel I/O Controller Hub 7    Since vSphere API 5.0",
               "virtualSMCPresent": "Does this virtual machine have System Management Controller    Since vSphere API 5.0",
               "device": {
                    "NameField": "device",
                    "DescriptionField": "VirtualDevice is the base data object type for devices in a virtual machine. This type contains enough information about a virtual device to allow clients to display devices they do not recognize. For example, a client with an older version than the server to which it connects may see a device without knowing what it is. ",
                    "backing": "Information about the backing of this virtual device presented in the context of the virtual machines environment. Not all devices are required to have backing information. See VirtualMachineConfigOption",
                    "connectable": "Provides information about restrictions on removing this device while a virtual machine is running. If the device is not removable, then this property is null.",
                    "controllerKey": "Object key for the controller object for this device. This property contains the key property value of the controller device object.",
                    "deviceInfo": "Provides a label and summary information for the device.",
                    "key_": "A unique key that distinguishes this device from other devices in the same virtual machine. Keys are immutable but may be recycled; that is, a key does not change as long as the device is associated with a particular virtual machine. However, once a device is removed, its key may be used when another device is added. This property is not read-only, but the client cannot control its value. Persistent device keys are always assigned and managed by the server, which guarantees that all devices will have non-negative key values. When adding new devices, it may be necessary for a client to assign keys temporarily in order to associate controllers with devices in configuring a virtual machine. However, the server does not allow a client to reassign a device key, and the server may assign a different value from the one passed during configuration. Clients should ensure that existing device keys are not reused as temporary key values for the new device to be added (for example, by using unique negative integers as temporary keys). When editing or deleting a device, clients must use the server-provided key to refer to an existing device.",
                    "slotInfo": "Information about the bus slot of a device in a virtual machine. Since vSphere API 5.1",
                    "unitNumber": "The unit number of this device on its controller. This property is null if the controller property is null, for example, when the device is not attached to a specific controller object,. Normally, two devices on the same controller may not be assigned the same unit number. If multiple devices could exist on a controller, then unit number has to be specified to configure respective devices.",
                    "nesting_SQL_name": "Virtualmachineconfighardwaredevice"
               },
               "nesting_SQL_name": "Virtualmachineconfighardware"
          },
          "memalloc": {
               "NameField": "memalloc",
               "DescriptionField": "The ResourceAllocationInfo data object specifies the reserved resource requirement as well as the limit (maximum allowed usage) for a given kind of resource. This is specified for both memory allocation (specified in MB) and CPU allocation (specified in MHz).For a ResourcePool, the ResourceAllocationInfo object describes both the guaranteed amount of the resource (reservation) and whether or not it is expandable (expandableReservation). If expandableReservation is true, then the resource pool can grow its reservation dynamically by borrowing unreserved resources from its parent resource pool. For the methods CreateResourcePool, CreateVApp and ImportVApp, you must provide values for all properties except overheadLimit; they are not optional. (Currently, overheadLimit is for vCenter Server use only.) If the limit is configured, it must be greater than or equal to the reservation. ",
               "expandableReservation": "In a resource pool with an expandable reservation, the reservation on a resource pool can grow beyond the specified value, if the parent resource pool has unreserved resources. A non-expandable reservation is called a fixed reservation. This property is invalid for virtual machines.",
               "limit_": "The utilization of a virtual machine/resource pool will not exceed this limit, even if there are available resources. This is typically used to ensure a consistent performance of virtual machines / resource pools independent of available resources. If set to -1, then there is no fixed limit on resource usage (only bounded by available resources and shares). Units are MB for memory, MHz for CPU.",
               "overheadLimit": "The maximum allowed overhead memory. For a powered on virtual machine, the overhead memory reservation cannot be larger than its overheadLimit. This property is only applicable to powered on virtual machines and is not persisted across reboots. This property is not applicable for resource pools. If set to -1, then there is no limit on reservation. Units are MB.    Note: For vCenter Server use only. Not available for other clients at this time. The server will throw an exception if you attempt to set this property.    Since VI API 2.5",
               "reservation": "Amount of resource that is guaranteed available to the virtual machine or resource pool. Reserved resources are not wasted if they are not used. If the utilization is less than the reservation, the resources can be utilized by other running virtual machines. Units are MB for memory, MHz for CPU.",
               "shares": "Memory shares are used in case of resource contention.",
               "nesting_SQL_name": "Virtualmachineconfigmemalloc"
          },
          "vAppConfig": {
               "NameField": "vAppConfig",
               "DescriptionField": " VM Configuration. ",
               "eula": "End User License Agreements.",
               "installBootRequired": "Specifies whether the VM needs an initial boot before the deployment is complete. Not relevant for vApps. This means that the value is always false when reading the configuration and is ignored when setting the configuration. If a vApp requires an install boot (because one of its VMs does), this is visible on the installBootRequired field of the vApp.",
               "installBootStopDelay": "Specifies the delay in seconds to wait for the VM to power off after the initial boot (used only if installBootRequired is true). A value of 0 means wait forever. Not relevant for vApps. This means that the value is always false when reading the configuration and is ignored when setting the configuration.",
               "ipAssignment": "IP assignment policy and DHCP support configuration.",
               "ovfEnvironmentTransport": "List the transports to use for properties. Supported values are: iso and com.vmware.guestInfo.",
               "ovfSection": "List of uninterpreted OVF meta-data sections.",
               "product": {
                    "NameField": "product",
                    "DescriptionField": " Information that describes what product a vApp contains, for example, the software that is installed in the contained virtual machines. ",
                    "appUrl": "URL to entry-point for application. This is often specified using a macro, for example, http://${app.ip}/, where app.ip is a defined property on the virtual machine or vApp container.",
                    "classId": "Class name for this attribute.\n\nValid values for classId: Any string except any white-space characters.",
                    "fullVersion": "Full-version of the product, for example, 1.0-build 12323.",
                    "instanceId": "Class name for this attribute.\n\nValid values for instanceId: Any string except any white-space characters.",
                    "key_": "A unique key for the product section",
                    "name": "Name of the product.",
                    "productUrl": "URL to product homepage.",
                    "vendor": "Vendor of the product.",
                    "vendorUrl": "URL to vendor homepage.",
                    "version": "Short version of the product, for example, 1.0.",
                    "nesting_SQL_name": "Virtualmachineconfigvappconfigproduct"
               },
               "property": {
                    "NameField": "property",
                    "DescriptionField": " A vApp Property description, including deployment values ",
                    "category": "A user-visible description of the category the property belongs to.",
                    "classId": "Class name for this property. Valid values for classId: Any string except any white-space characters.",
                    "defaultValue": "This either contains the default value of a field (used if value is empty string), or the expression if the type is expression. See comment for the",
                    "description": "A description of the field.",
                    "id": "Name of property. In the OVF environment, the property is listed as [classId.]id[.instanceId]. The [classId.]name[.instanceId] must be unique. This field cannot be empty for a property. Thus, it must be specified at creation and cannot be set to the empty string. Valid values for id: Any string except any white-space characters.",
                    "instanceId": "Class name for this property. Valid values for instanceId: Any string except any white-space characters.",
                    "key_": "A unique integer key for the property.",
                    "label": "The display name for the property.",
                    "type": "Describes the valid format of the property.",
                    "typeReference": "Contains extra configuration data depending on the property type. For types that refer to network names, the type reference is the managed object reference of the network. Since vSphere API 5.1",
                    "userConfigurable": "Whether the property is user-configurable or a system property. This is not used if the type is expression.",
                    "value": "The value of the field at deployment time. For expressions, this will contain the value that has been computed.",
                    "nesting_SQL_name": "Virtualmachineconfigvappconfigproperty"
               },
               "nesting_SQL_name": "Virtualmachineconfigvappconfig"
          },
          "nesting_SQL_name": "Virtualmachineconfig"
     },
     "guest": {
          "NameField": "guest",
          "DescriptionField": "Information about the guest operating system. Most of this information is collected by VMware Tools. In general, be sure you have VMware Tools installed and that the virtual machine is running when you access this information. ",
          "appHeartbeatStatus": "Application heartbeat status. Please see VirtualMachineAppHeartbeatStatusType. Since vSphere API 4.1",
          "appState": "Application state. If vSphere HA is enabled and the vm is configured for Application Monitoring and this fields value is appStateNeedReset then HA will attempt immediately reset the vm. There are some system conditions which may delay the immediate reset. The immediate reset will be performed as soon as allowed by vSphere HA and ESX. If during these conditions the value is changed to appStateOk the reset will be cancelled. See GuestInfoAppStateType. Since vSphere API 5.5",
          "customizationInfo": "Guest OS Customization status info. Since vSphere API 7.0.2.0",
          "disk": "Guest information about disks. You can obtain Linux guest disk information for the following file system types: Ext2, Ext3, Ext4, ReiserFS, XFS, Btrfs, NTFS, VFAT, UFS, PCFS, HFS, and MS-DOS. NOTE: Installing a more recent version of VMware Tools in the guest may help obtain disk information for more file system types. Please refer to the VMware Tools User Guide for up-to-date supported file system types.",
          "generationInfo": "A list of namespaces and their corresponding generation numbers. Only namespaces with non-zero maxSizeEventsFromGuest are guaranteed to be present here. Use ListNamespaces to retrieve a list of namespaces. Since vSphere API 5.1",
          "guestDetailedData": "Guest OS Detailed data. The guest detailed data string is a property list (space separated, name=value pairs where the value is embedded in single quotes) of metadata provided by the guest OS when sufficiently recent tools are installed. The fields supplied will vary between distributions and distribution versions. The order of these fields is not guaranteed. The guest detailed data string is not available before a virtual machine is first powered on. The guest must first be booted and a supported version of tools must be run to record the data (approximately 30-60 seconds after booting). Once the guest detailed data string has been recorded, it will be available whether the virtual machine is powered off or on. Available fields: Name, Description, Tools version first available, architecture, bitness, buildNumber, cpeString, distroAddlVersion, distroName, distroVersion, familyName, kernelVersion, prettyName. Since 8.0.2.0",
          "guestDetailedDataExtended": "The  architecture  field indicates whether the architecture is Arm or X86. The  bitness  field specifies the bit-level of the system, being either 32 or 64.  buildNumber  refers to the OS build number.  cpeString  is defined as the NIST Common Platform Enumeration Specification string, serving as a standardized identifier for the OS. The  distroAddlVersion  field contains a longer OS version string that may include additional information, such as the version name.  distroName  denotes the name of the OS distribution. The  distroVersion  field is concerned with the OS version string.  familyName  identifies the OS family name, like Windows or Linux. The  kernelVersion  field varies, encompassing the Linux kernel version, Windows 10+ patch number, or Windows build number. Lastly,  prettyName  represents the officially specified pretty name of the distro.",
          "guestFamily": "Guest operating system family, if known.",
          "guestFullName": "Guest operating system full name, if known.",
          "guestId": "Guest operating system identifier (short name), if known.",
          "guestKernelCrashed": "Guest operating systems kernel crash state. If true, the guest operating systems kernel has crashed. Since vSphere API 6.0",
          "guestOperationsReady": "Guest Operations availability. If true, the virtual machine is ready to process guest operations. Since vSphere API 5.0",
          "guestState": "Operation mode of guest operating system. One of: running - Guest is running normally. shuttingdown - Guest has a pending shutdown command. resetting - Guest has a pending reset command. standby - Guest has a pending standby command. notrunning - Guest is not running. unknown - Guest information is not available.",
          "guestStateChangeSupported": "State change support. If true, the virtual machine is ready to process soft power operations. Since vSphere API 6.0",
          "hostName": "Hostname of the guest operating system, if known.",
          "hwVersion": "The hardware version string for this virtual machine. Since vSphere API 6.9.1",
          "interactiveGuestOperationsReady": "Interactive Guest Operations availability. If true, the virtual machine is ready to process guest operations as the user interacting with the guest desktop. Since vSphere API 5.0",
          "ipAddress": "Primary IP address assigned to the guest operating system, if known.",
          "ipStack": "Guest information about IP networking stack, if known. Since vSphere API 4.1",
          "net": "Guest information about network adapters, if known.",
          "screen": "Guest screen resolution info, if known.",
          "toolsInstallType": "Current installation type of VMware Tools in the guest operating system. The set of possible values is described in VirtualMachineToolsInstallType. Since vSphere API 6.5",
          "toolsRunningStatus": "Current running status of VMware Tools in the guest operating system, if known. The set of possible values is described in VirtualMachineToolsRunningStatus. Since vSphere API 4.0",
          "toolsStatus": "Deprecated. As of vSphere API 4.0 use toolsVersionStatus and toolsRunningStatus. Current status of VMware Tools in the guest operating system, if known.",
          "toolsVersion": "Current version of VMware Tools, if known. Since vSphere API 4.0",
          "toolsVersionStatus": "Deprecated. As of vSphere API 5.1 use toolsVersionStatus2. Current version status of VMware Tools in the guest operating system, if known. The set of possible values is described in VirtualMachineToolsVersionStatus for vSphere API 5.0. Since vSphere API 4.0",
          "toolsVersionStatus2": "Current version status of VMware Tools in the guest operating system, if known. The set of possible values is described in VirtualMachineToolsVersionStatus. Since vSphere API 5.0",
          "nesting_SQL_name": "Virtualmachineguest"
     },
     "resourceConfig": {
          "NameField": "resourceConfig",
          "DescriptionField": " This data object type is a specification for a set of resources allocated to a virtual machine or a resource pool. ",
          "changeVersion": "The changeVersion is a unique identifier for a given version of the configuration. Each change to the configuration will update this value. This is typically implemented as an ever-increasing count or a time-stamp. However, a client should always treat this as an opaque string. If specified when updating the resource config., the changes will only be applied if the current changeVersion matches the specified changeVersion. This field can be used to guard against updates that have happened between the configInfo was read and until it is applied.",
          "entity": "Reference to the entity with this resource specification: either a VirtualMachine or a ResourcePool.",
          "lastModified": "Timestamp when the resources were last modified. This is ignored when the object is used to update a configuration.",
          "scaleDescendantsShares": "Specifies the scaling behavior of the shares of all descendant resource pools under a given resource pool. See ResourceConfigSpecScaleSharesBehavior for possible values. If any scaling behavior other than ScaleSharesBehavior#disabled is specified, the system will scale the CPU and memory shares allocated to each descendant resource pool with the total shares of all powered on virtual machines under each respective pool. The system will also use the SharesInfo set on each descendant resource pool as a multiplier for the scale. If a resource pool s shares are already scalable through the scaleDescendantsShares setting on an ancestor resource pool, the system will not allow scaleDescendantsShares to be set on the resource pool. The sharesScalable property indicates whether or not a resource pool s shares are scalable. This property does not apply to virtual machines. Since vSphere API 7.0",
          "cpualloc": {
               "NameField": "cpualloc",
               "DescriptionField": "The ResourceAllocationInfo data object specifies the reserved resource requirement as well as the limit (maximum allowed usage) for a given kind of resource. This is specified for both memory allocation (specified in MB) and CPU allocation (specified in MHz).For a ResourcePool, the ResourceAllocationInfo object describes both the guaranteed amount of the resource (reservation) and whether or not it is expandable (expandableReservation). If expandableReservation is true, then the resource pool can grow its reservation dynamically by borrowing unreserved resources from its parent resource pool. For the methods CreateResourcePool, CreateVApp and ImportVApp, you must provide values for all properties except overheadLimit; they are not optional. (Currently, overheadLimit is for vCenter Server use only.) If the limit is configured, it must be greater than or equal to the reservation. ",
               "expandableReservation": "In a resource pool with an expandable reservation, the reservation on a resource pool can grow beyond the specified value, if the parent resource pool has unreserved resources. A non-expandable reservation is called a fixed reservation. This property is invalid for virtual machines.",
               "limit_": "The utilization of a virtual machine/resource pool will not exceed this limit, even if there are available resources. This is typically used to ensure a consistent performance of virtual machines / resource pools independent of available resources. If set to -1, then there is no fixed limit on resource usage (only bounded by available resources and shares). Units are MB for memory, MHz for CPU.",
               "overheadLimit": "The maximum allowed overhead memory. For a powered on virtual machine, the overhead memory reservation cannot be larger than its overheadLimit. This property is only applicable to powered on virtual machines and is not persisted across reboots. This property is not applicable for resource pools. If set to -1, then there is no limit on reservation. Units are MB.    Note: For vCenter Server use only. Not available for other clients at this time. The server will throw an exception if you attempt to set this property.    Since VI API 2.5",
               "reservation": "Amount of resource that is guaranteed available to the virtual machine or resource pool. Reserved resources are not wasted if they are not used. If the utilization is less than the reservation, the resources can be utilized by other running virtual machines. Units are MB for memory, MHz for CPU.",
               "shares": "Memory shares are used in case of resource contention.",
               "nesting_SQL_name": "Virtualmachineresourceconfigcpualloc"
          },
          "memalloc": {
               "NameField": "memalloc",
               "DescriptionField": "The ResourceAllocationInfo data object specifies the reserved resource requirement as well as the limit (maximum allowed usage) for a given kind of resource. This is specified for both memory allocation (specified in MB) and CPU allocation (specified in MHz).For a ResourcePool, the ResourceAllocationInfo object describes both the guaranteed amount of the resource (reservation) and whether or not it is expandable (expandableReservation). If expandableReservation is true, then the resource pool can grow its reservation dynamically by borrowing unreserved resources from its parent resource pool. For the methods CreateResourcePool, CreateVApp and ImportVApp, you must provide values for all properties except overheadLimit; they are not optional. (Currently, overheadLimit is for vCenter Server use only.) If the limit is configured, it must be greater than or equal to the reservation. ",
               "expandableReservation": "In a resource pool with an expandable reservation, the reservation on a resource pool can grow beyond the specified value, if the parent resource pool has unreserved resources. A non-expandable reservation is called a fixed reservation. This property is invalid for virtual machines.",
               "limit_": "The utilization of a virtual machine/resource pool will not exceed this limit, even if there are available resources. This is typically used to ensure a consistent performance of virtual machines / resource pools independent of available resources. If set to -1, then there is no fixed limit on resource usage (only bounded by available resources and shares). Units are MB for memory, MHz for CPU.",
               "overheadLimit": "The maximum allowed overhead memory. For a powered on virtual machine, the overhead memory reservation cannot be larger than its overheadLimit. This property is only applicable to powered on virtual machines and is not persisted across reboots. This property is not applicable for resource pools. If set to -1, then there is no limit on reservation. Units are MB.    Note: For vCenter Server use only. Not available for other clients at this time. The server will throw an exception if you attempt to set this property.    Since VI API 2.5",
               "reservation": "Amount of resource that is guaranteed available to the virtual machine or resource pool. Reserved resources are not wasted if they are not used. If the utilization is less than the reservation, the resources can be utilized by other running virtual machines. Units are MB for memory, MHz for CPU.",
               "shares": "Memory shares are used in case of resource contention.",
               "nesting_SQL_name": "Virtualmachineresourceconfigmemalloc"
          },
          "nesting_SQL_name": "Virtualmachineresourceconfig"
     },
     "nesting_SQL_name": "Virtualmachine",
     "VirtualMachine_id": "ID of VirtualMachine"
}