@azure-rest/arm-compute 1.0.0-alpha.20251127.1 → 1.0.0-alpha.20251201.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/models.d.ts.map +1 -1
- package/dist/browser/models.js.map +1 -1
- package/dist/browser/outputModels.d.ts.map +1 -1
- package/dist/browser/outputModels.js.map +1 -1
- package/dist/browser/responses.d.ts.map +1 -1
- package/dist/browser/responses.js.map +1 -1
- package/dist/commonjs/models.d.ts.map +1 -1
- package/dist/commonjs/models.js.map +1 -1
- package/dist/commonjs/outputModels.d.ts.map +1 -1
- package/dist/commonjs/outputModels.js.map +1 -1
- package/dist/commonjs/responses.d.ts.map +1 -1
- package/dist/commonjs/responses.js.map +1 -1
- package/dist/esm/models.d.ts.map +1 -1
- package/dist/esm/models.js.map +1 -1
- package/dist/esm/outputModels.d.ts.map +1 -1
- package/dist/esm/outputModels.js.map +1 -1
- package/dist/esm/responses.d.ts.map +1 -1
- package/dist/esm/responses.js.map +1 -1
- package/dist/react-native/models.d.ts.map +1 -1
- package/dist/react-native/models.js.map +1 -1
- package/dist/react-native/outputModels.d.ts.map +1 -1
- package/dist/react-native/outputModels.js.map +1 -1
- package/dist/react-native/responses.d.ts.map +1 -1
- package/dist/react-native/responses.js.map +1 -1
- package/package.json +3 -3
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outputModels.js","sourceRoot":"","sources":["../../src/outputModels.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/** The List Compute Operation operation response. */\nexport interface ComputeOperationListResultOutput {\n /** The list of compute operations */\n readonly value?: Array<ComputeOperationValueOutput>;\n}\n\n/** Describes the properties of a Compute Operation value. */\nexport interface ComputeOperationValueOutput {\n /** The origin of the compute operation. */\n readonly origin?: string;\n /** The name of the compute operation. */\n readonly name?: string;\n /** Describes the properties of a Compute Operation Value Display. */\n display?: ComputeOperationValueDisplayOutput;\n}\n\n/** Describes the properties of a Compute Operation Value Display. */\nexport interface ComputeOperationValueDisplayOutput {\n /** The display name of the compute operation. */\n readonly operation?: string;\n /** The display name of the resource the operation applies to. */\n readonly resource?: string;\n /** The description of the operation. */\n readonly description?: string;\n /** The resource provider for the operation. */\n readonly provider?: string;\n}\n\n/** An error response from the Compute service. */\nexport interface CloudErrorOutput {\n /** Api error. */\n error?: ApiErrorOutput;\n}\n\n/** Api error. */\nexport interface ApiErrorOutput {\n /** The Api error details */\n details?: Array<ApiErrorBaseOutput>;\n /** The Api inner error */\n innererror?: InnerErrorOutput;\n /** The error code. */\n code?: string;\n /** The target of the particular error. */\n target?: string;\n /** The error message. */\n message?: string;\n}\n\n/** Api error base. */\nexport interface ApiErrorBaseOutput {\n /** The error code. */\n code?: string;\n /** The target of the particular error. */\n target?: string;\n /** The error message. */\n message?: string;\n}\n\n/** Inner error details. */\nexport interface InnerErrorOutput {\n /** The exception type. */\n exceptiontype?: string;\n /** The internal error message or exception dump. */\n errordetail?: string;\n}\n\n/** The List Usages operation response. */\nexport interface ListUsagesResultOutput {\n /** The list of compute resource usages. */\n value: Array<UsageOutput>;\n /** The URI to fetch the next page of compute resource usage information. Call ListNext() with this to fetch the next page of compute resource usage information. */\n nextLink?: string;\n}\n\n/** Describes Compute Resource Usage. */\nexport interface UsageOutput {\n /** An enum describing the unit of usage measurement. */\n unit: \"Count\";\n /** The current usage of the resource. */\n currentValue: number;\n /** The maximum permitted usage of the resource. */\n limit: number;\n /** The name of the type of usage. */\n name: UsageNameOutput;\n}\n\n/** The Usage Names. */\nexport interface UsageNameOutput {\n /** The name of the resource. */\n value?: string;\n /** The localized name of the resource. */\n localizedValue?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineSizeListResultOutput {\n /** The list of virtual machine sizes. */\n value?: Array<VirtualMachineSizeOutput>;\n}\n\n/** Describes the properties of a VM size. */\nexport interface VirtualMachineSizeOutput {\n /** The name of the virtual machine size. */\n name?: string;\n /** The number of cores supported by the virtual machine size. For Constrained vCPU capable VM sizes, this number represents the total vCPUs of quota that the VM uses. For accurate vCPU count, please refer to https://docs.microsoft.com/azure/virtual-machines/constrained-vcpu or https://docs.microsoft.com/rest/api/compute/resourceskus/list */\n numberOfCores?: number;\n /** The OS disk size, in MB, allowed by the virtual machine size. */\n osDiskSizeInMB?: number;\n /** The resource disk size, in MB, allowed by the virtual machine size. */\n resourceDiskSizeInMB?: number;\n /** The amount of memory, in MB, supported by the virtual machine size. */\n memoryInMB?: number;\n /** The maximum number of data disks that can be attached to the virtual machine size. */\n maxDataDiskCount?: number;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineScaleSetListResultOutput {\n /** The list of virtual machine scale sets. */\n value: Array<VirtualMachineScaleSetOutput>;\n /** The uri to fetch the next page of Virtual Machine Scale Sets. Call ListNext() with this to fetch the next page of VMSS. */\n nextLink?: string;\n}\n\n/** Describes a Virtual Machine Scale Set. */\nexport interface VirtualMachineScaleSetOutput extends ResourceOutput {\n /** The virtual machine scale set sku. */\n sku?: SkuOutput;\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: PlanOutput;\n /** Describes the properties of a Virtual Machine Scale Set. */\n properties?: VirtualMachineScaleSetPropertiesOutput;\n /** The identity of the virtual machine scale set, if configured. */\n identity?: VirtualMachineScaleSetIdentityOutput;\n /** The virtual machine scale set zones. NOTE: Availability zones can only be set when you create the scale set */\n zones?: Array<string>;\n /** The extended location of the Virtual Machine Scale Set. */\n extendedLocation?: ExtendedLocationOutput;\n}\n\n/** Describes a virtual machine scale set sku. NOTE: If the new VM SKU is not supported on the hardware the scale set is currently on, you need to deallocate the VMs in the scale set before you modify the SKU name. */\nexport interface SkuOutput {\n /** The sku name. */\n name?: string;\n /** Specifies the tier of virtual machines in a scale set.<br /><br /> Possible Values:<br /><br /> **Standard**<br /><br /> **Basic** */\n tier?: string;\n /** Specifies the number of virtual machines in the scale set. */\n capacity?: number;\n}\n\n/** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\nexport interface PlanOutput {\n /** The plan ID. */\n name?: string;\n /** The publisher ID. */\n publisher?: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product?: string;\n /** The promotion code. */\n promotionCode?: string;\n}\n\n/** Describes the properties of a Virtual Machine Scale Set. */\nexport interface VirtualMachineScaleSetPropertiesOutput {\n /** The upgrade policy. */\n upgradePolicy?: UpgradePolicyOutput;\n /** Policy for automatic repairs. */\n automaticRepairsPolicy?: AutomaticRepairsPolicyOutput;\n /** The virtual machine profile. */\n virtualMachineProfile?: VirtualMachineScaleSetVMProfileOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** Specifies whether the Virtual Machine Scale Set should be overprovisioned. */\n overprovision?: boolean;\n /** When Overprovision is enabled, extensions are launched only on the requested number of VMs which are finally kept. This property will hence ensure that the extensions do not run on the extra overprovisioned VMs. */\n doNotRunExtensionsOnOverprovisionedVMs?: boolean;\n /** Specifies the ID which uniquely identifies a Virtual Machine Scale Set. */\n readonly uniqueId?: string;\n /** When true this limits the scale set to a single placement group, of max size 100 virtual machines. NOTE: If singlePlacementGroup is true, it may be modified to false. However, if singlePlacementGroup is false, it may not be modified to true. */\n singlePlacementGroup?: boolean;\n /** Whether to force strictly even Virtual Machine distribution cross x-zones in case there is zone outage. zoneBalance property can only be set if the zones property of the scale set contains more than one zone. If there are no zones or only one zone specified, then zoneBalance property should not be set. */\n zoneBalance?: boolean;\n /** Fault Domain count for each placement group. */\n platformFaultDomainCount?: number;\n /** Specifies information about the proximity placement group that the virtual machine scale set should be assigned to. <br><br>Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResourceOutput;\n /** Specifies information about the dedicated host group that the virtual machine scale set resides in. <br><br>Minimum api-version: 2020-06-01. */\n hostGroup?: SubResourceOutput;\n /** Specifies additional capabilities enabled or disabled on the Virtual Machines in the Virtual Machine Scale Set. For instance: whether the Virtual Machines have the capability to support attaching managed data disks with UltraSSD_LRS storage account type. */\n additionalCapabilities?: AdditionalCapabilitiesOutput;\n /** Specifies the policies applied when scaling in Virtual Machines in the Virtual Machine Scale Set. */\n scaleInPolicy?: ScaleInPolicyOutput;\n /** Specifies the orchestration mode for the virtual machine scale set. */\n orchestrationMode?: \"Uniform\" | \"Flexible\";\n /** Specifies the Spot Restore properties for the virtual machine scale set. */\n spotRestorePolicy?: SpotRestorePolicyOutput;\n /** Specifies the desired targets for mixing Spot and Regular priority VMs within the same VMSS Flex instance. */\n priorityMixPolicy?: PriorityMixPolicyOutput;\n /** Specifies the time at which the Virtual Machine Scale Set resource was created.<br><br>Minimum api-version: 2021-11-01. */\n readonly timeCreated?: string;\n}\n\n/** Describes an upgrade policy - automatic, manual, or rolling. */\nexport interface UpgradePolicyOutput {\n /** Specifies the mode of an upgrade to virtual machines in the scale set.<br /><br /> Possible values are:<br /><br /> **Manual** - You control the application of updates to virtual machines in the scale set. You do this by using the manualUpgrade action.<br /><br /> **Automatic** - All virtual machines in the scale set are automatically updated at the same time. */\n mode?: \"Automatic\" | \"Manual\" | \"Rolling\";\n /** The configuration parameters used while performing a rolling upgrade. */\n rollingUpgradePolicy?: RollingUpgradePolicyOutput;\n /** Configuration parameters used for performing automatic OS Upgrade. */\n automaticOSUpgradePolicy?: AutomaticOSUpgradePolicyOutput;\n}\n\n/** The configuration parameters used while performing a rolling upgrade. */\nexport interface RollingUpgradePolicyOutput {\n /** The maximum percent of total virtual machine instances that will be upgraded simultaneously by the rolling upgrade in one batch. As this is a maximum, unhealthy instances in previous or future batches can cause the percentage of instances in a batch to decrease to ensure higher reliability. The default value for this parameter is 20%. */\n maxBatchInstancePercent?: number;\n /** The maximum percentage of the total virtual machine instances in the scale set that can be simultaneously unhealthy, either as a result of being upgraded, or by being found in an unhealthy state by the virtual machine health checks before the rolling upgrade aborts. This constraint will be checked prior to starting any batch. The default value for this parameter is 20%. */\n maxUnhealthyInstancePercent?: number;\n /** The maximum percentage of upgraded virtual machine instances that can be found to be in an unhealthy state. This check will happen after each batch is upgraded. If this percentage is ever exceeded, the rolling update aborts. The default value for this parameter is 20%. */\n maxUnhealthyUpgradedInstancePercent?: number;\n /** The wait time between completing the update for all virtual machines in one batch and starting the next batch. The time duration should be specified in ISO 8601 format. The default value is 0 seconds (PT0S). */\n pauseTimeBetweenBatches?: string;\n /** Allow VMSS to ignore AZ boundaries when constructing upgrade batches. Take into consideration the Update Domain and maxBatchInstancePercent to determine the batch size. */\n enableCrossZoneUpgrade?: boolean;\n /** Upgrade all unhealthy instances in a scale set before any healthy instances. */\n prioritizeUnhealthyInstances?: boolean;\n}\n\n/** The configuration parameters used for performing automatic OS upgrade. */\nexport interface AutomaticOSUpgradePolicyOutput {\n /** Indicates whether OS upgrades should automatically be applied to scale set instances in a rolling fashion when a newer version of the OS image becomes available. Default value is false. <br><br> If this is set to true for Windows based scale sets, [enableAutomaticUpdates](https://docs.microsoft.com/dotnet/api/microsoft.azure.management.compute.models.windowsconfiguration.enableautomaticupdates?view=azure-dotnet) is automatically set to false and cannot be set to true. */\n enableAutomaticOSUpgrade?: boolean;\n /** Whether OS image rollback feature should be disabled. Default value is false. */\n disableAutomaticRollback?: boolean;\n /** Indicates whether rolling upgrade policy should be used during Auto OS Upgrade. Default value is false. Auto OS Upgrade will fallback to the default policy if no policy is defined on the VMSS. */\n useRollingUpgradePolicy?: boolean;\n}\n\n/** Specifies the configuration parameters for automatic repairs on the virtual machine scale set. */\nexport interface AutomaticRepairsPolicyOutput {\n /** Specifies whether automatic repairs should be enabled on the virtual machine scale set. The default value is false. */\n enabled?: boolean;\n /** The amount of time for which automatic repairs are suspended due to a state change on VM. The grace time starts after the state change has completed. This helps avoid premature or accidental repairs. The time duration should be specified in ISO 8601 format. The minimum allowed grace period is 10 minutes (PT10M), which is also the default value. The maximum allowed grace period is 90 minutes (PT90M). */\n gracePeriod?: string;\n /** Type of repair action (replace, restart, reimage) that will be used for repairing unhealthy virtual machines in the scale set. Default value is replace. */\n repairAction?: \"Replace\" | \"Restart\" | \"Reimage\";\n}\n\n/** Describes a virtual machine scale set virtual machine profile. */\nexport interface VirtualMachineScaleSetVMProfileOutput {\n /** Specifies the operating system settings for the virtual machines in the scale set. */\n osProfile?: VirtualMachineScaleSetOSProfileOutput;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: VirtualMachineScaleSetStorageProfileOutput;\n /** Specifies properties of the network interfaces of the virtual machines in the scale set. */\n networkProfile?: VirtualMachineScaleSetNetworkProfileOutput;\n /** Specifies the Security related profile settings for the virtual machines in the scale set. */\n securityProfile?: SecurityProfileOutput;\n /** Specifies the boot diagnostic settings state. <br><br>Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfileOutput;\n /** Specifies a collection of settings for extensions installed on virtual machines in the scale set. */\n extensionProfile?: VirtualMachineScaleSetExtensionProfileOutput;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /** Specifies the priority for the virtual machines in the scale set. <br><br>Minimum api-version: 2017-10-30-preview */\n priority?: \"Regular\" | \"Low\" | \"Spot\";\n /** Specifies the eviction policy for the Azure Spot virtual machine and Azure Spot scale set. <br><br>For Azure Spot virtual machines, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2019-03-01. <br><br>For Azure Spot scale sets, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2017-10-30-preview. */\n evictionPolicy?: \"Deallocate\" | \"Delete\";\n /** Specifies the billing related details of a Azure Spot VMSS. <br><br>Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfileOutput;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfileOutput;\n /** UserData for the virtual machines in the scale set, which must be base-64 encoded. Customer should not pass any secrets in here. <br><br>Minimum api-version: 2021-03-01 */\n userData?: string;\n /** Specifies the capacity reservation related details of a scale set. <br><br>Minimum api-version: 2021-04-01. */\n capacityReservation?: CapacityReservationProfileOutput;\n /** Specifies the gallery applications that should be made available to the VM/VMSS */\n applicationProfile?: ApplicationProfileOutput;\n /** Specifies the hardware profile related details of a scale set. <br><br>Minimum api-version: 2021-11-01. */\n hardwareProfile?: VirtualMachineScaleSetHardwareProfileOutput;\n}\n\n/** Describes a virtual machine scale set OS profile. */\nexport interface VirtualMachineScaleSetOSProfileOutput {\n /** Specifies the computer name prefix for all of the virtual machines in the scale set. Computer name prefixes must be 1 to 15 characters long. */\n computerNamePrefix?: string;\n /** Specifies the name of the administrator account. <br><br> **Windows-only restriction:** Cannot end in \".\" <br><br> **Disallowed values:** \"administrator\", \"admin\", \"user\", \"user1\", \"test\", \"user2\", \"test1\", \"user3\", \"admin1\", \"1\", \"123\", \"a\", \"actuser\", \"adm\", \"admin2\", \"aspnet\", \"backup\", \"console\", \"david\", \"guest\", \"john\", \"owner\", \"root\", \"server\", \"sql\", \"support\", \"support_388945a0\", \"sys\", \"test2\", \"test3\", \"user4\", \"user5\". <br><br> **Minimum-length (Linux):** 1 character <br><br> **Max-length (Linux):** 64 characters <br><br> **Max-length (Windows):** 20 characters */\n adminUsername?: string;\n /** Specifies the password of the administrator account. <br><br> **Minimum-length (Windows):** 8 characters <br><br> **Minimum-length (Linux):** 6 characters <br><br> **Max-length (Windows):** 123 characters <br><br> **Max-length (Linux):** 72 characters <br><br> **Complexity requirements:** 3 out of 4 conditions below need to be fulfilled <br> Has lower characters <br>Has upper characters <br> Has a digit <br> Has a special character (Regex match [\\W_]) <br><br> **Disallowed values:** \"abc@123\", \"P@$$w0rd\", \"P@ssw0rd\", \"P@ssword123\", \"Pa$$word\", \"pass@word1\", \"Password!\", \"Password1\", \"Password22\", \"iloveyou!\" <br><br> For resetting the password, see [How to reset the Remote Desktop service or its login password in a Windows VM](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/reset-rdp) <br><br> For resetting root password, see [Manage users, SSH, and check or repair disks on Azure Linux VMs using the VMAccess Extension](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection) */\n adminPassword?: string;\n /** Specifies a base-64 encoded string of custom data. The base-64 encoded string is decoded to a binary array that is saved as a file on the Virtual Machine. The maximum length of the binary array is 65535 bytes. <br><br> For using cloud-init for your VM, see [Using cloud-init to customize a Linux VM during creation](https://docs.microsoft.com/azure/virtual-machines/linux/using-cloud-init) */\n customData?: string;\n /** Specifies Windows operating system settings on the virtual machine. */\n windowsConfiguration?: WindowsConfigurationOutput;\n /** Specifies the Linux operating system settings on the virtual machine. <br><br>For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\n linuxConfiguration?: LinuxConfigurationOutput;\n /** Specifies set of certificates that should be installed onto the virtual machines in the scale set. To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n secrets?: Array<VaultSecretGroupOutput>;\n /** Specifies whether extension operations should be allowed on the virtual machine scale set. <br><br>This may only be set to False when no extensions are present on the virtual machine scale set. */\n allowExtensionOperations?: boolean;\n}\n\n/** Specifies Windows operating system settings on the virtual machine. */\nexport interface WindowsConfigurationOutput {\n /** Indicates whether virtual machine agent should be provisioned on the virtual machine. <br><br> When this property is not specified in the request body, default behavior is to set it to true. This will ensure that VM Agent is installed on the VM so that extensions can be added to the VM later. */\n provisionVMAgent?: boolean;\n /** Indicates whether Automatic Updates is enabled for the Windows virtual machine. Default value is true. <br><br> For virtual machine scale sets, this property can be updated and updates will take effect on OS reprovisioning. */\n enableAutomaticUpdates?: boolean;\n /** Specifies the time zone of the virtual machine. e.g. \"Pacific Standard Time\". <br><br> Possible values can be [TimeZoneInfo.Id](https://docs.microsoft.com/dotnet/api/system.timezoneinfo.id?#System_TimeZoneInfo_Id) value from time zones returned by [TimeZoneInfo.GetSystemTimeZones](https://docs.microsoft.com/dotnet/api/system.timezoneinfo.getsystemtimezones). */\n timeZone?: string;\n /** Specifies additional base-64 encoded XML formatted information that can be included in the Unattend.xml file, which is used by Windows Setup. */\n additionalUnattendContent?: Array<AdditionalUnattendContentOutput>;\n /** [Preview Feature] Specifies settings related to VM Guest Patching on Windows. */\n patchSettings?: PatchSettingsOutput;\n /** Specifies the Windows Remote Management listeners. This enables remote Windows PowerShell. */\n winRM?: WinRMConfigurationOutput;\n /** Indicates whether VMAgent Platform Updates is enabled for the Windows virtual machine. Default value is false. */\n enableVMAgentPlatformUpdates?: boolean;\n}\n\n/** Specifies additional XML formatted information that can be included in the Unattend.xml file, which is used by Windows Setup. Contents are defined by setting name, component name, and the pass in which the content is applied. */\nexport interface AdditionalUnattendContentOutput {\n /** The pass name. Currently, the only allowable value is OobeSystem. */\n passName?: \"OobeSystem\";\n /** The component name. Currently, the only allowable value is Microsoft-Windows-Shell-Setup. */\n componentName?: \"Microsoft-Windows-Shell-Setup\";\n /** Specifies the name of the setting to which the content applies. Possible values are: FirstLogonCommands and AutoLogon. */\n settingName?: \"AutoLogon\" | \"FirstLogonCommands\";\n /** Specifies the XML formatted content that is added to the unattend.xml file for the specified path and component. The XML must be less than 4KB and must include the root element for the setting or feature that is being inserted. */\n content?: string;\n}\n\n/** Specifies settings related to VM Guest Patching on Windows. */\nexport interface PatchSettingsOutput {\n /** Specifies the mode of VM Guest Patching to IaaS virtual machine or virtual machines associated to virtual machine scale set with OrchestrationMode as Flexible.<br /><br /> Possible values are:<br /><br /> **Manual** - You control the application of patches to a virtual machine. You do this by applying patches manually inside the VM. In this mode, automatic updates are disabled; the property WindowsConfiguration.enableAutomaticUpdates must be false<br /><br /> **AutomaticByOS** - The virtual machine will automatically be updated by the OS. The property WindowsConfiguration.enableAutomaticUpdates must be true. <br /><br /> **AutomaticByPlatform** - the virtual machine will automatically updated by the platform. The properties provisionVMAgent and WindowsConfiguration.enableAutomaticUpdates must be true */\n patchMode?: \"Manual\" | \"AutomaticByOS\" | \"AutomaticByPlatform\";\n /** Enables customers to patch their Azure VMs without requiring a reboot. For enableHotpatching, the 'provisionVMAgent' must be set to true and 'patchMode' must be set to 'AutomaticByPlatform'. */\n enableHotpatching?: boolean;\n /** Specifies the mode of VM Guest patch assessment for the IaaS virtual machine.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - You control the timing of patch assessments on a virtual machine.<br /><br /> **AutomaticByPlatform** - The platform will trigger periodic patch assessments. The property provisionVMAgent must be true. */\n assessmentMode?: \"ImageDefault\" | \"AutomaticByPlatform\";\n /** Specifies additional settings for patch mode AutomaticByPlatform in VM Guest Patching on Windows. */\n automaticByPlatformSettings?: WindowsVMGuestPatchAutomaticByPlatformSettingsOutput;\n}\n\n/** Specifies additional settings to be applied when patch mode AutomaticByPlatform is selected in Windows patch settings. */\nexport interface WindowsVMGuestPatchAutomaticByPlatformSettingsOutput {\n /** Specifies the reboot setting for all AutomaticByPlatform patch installation operations. */\n rebootSetting?: \"Unknown\" | \"IfRequired\" | \"Never\" | \"Always\";\n}\n\n/** Describes Windows Remote Management configuration of the VM */\nexport interface WinRMConfigurationOutput {\n /** The list of Windows Remote Management listeners */\n listeners?: Array<WinRMListenerOutput>;\n}\n\n/** Describes Protocol and thumbprint of Windows Remote Management listener */\nexport interface WinRMListenerOutput {\n /** Specifies the protocol of WinRM listener. <br><br> Possible values are: <br>**http** <br><br> **https** */\n protocol?: \"Http\" | \"Https\";\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. For adding a secret to the Key Vault, see [Add a key or secret to the key vault](https://docs.microsoft.com/azure/key-vault/key-vault-get-started/#add). In this case, your certificate needs to be It is the Base64 encoding of the following JSON Object which is encoded in UTF-8: <br><br> {<br> \"data\":\"<Base64-encoded-certificate>\",<br> \"dataType\":\"pfx\",<br> \"password\":\"<pfx-file-password>\"<br>} <br> To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n certificateUrl?: string;\n}\n\n/** Specifies the Linux operating system settings on the virtual machine. <br><br>For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\nexport interface LinuxConfigurationOutput {\n /** Specifies whether password authentication should be disabled. */\n disablePasswordAuthentication?: boolean;\n /** Specifies the ssh key configuration for a Linux OS. */\n ssh?: SshConfigurationOutput;\n /** Indicates whether virtual machine agent should be provisioned on the virtual machine. <br><br> When this property is not specified in the request body, default behavior is to set it to true. This will ensure that VM Agent is installed on the VM so that extensions can be added to the VM later. */\n provisionVMAgent?: boolean;\n /** [Preview Feature] Specifies settings related to VM Guest Patching on Linux. */\n patchSettings?: LinuxPatchSettingsOutput;\n /** Indicates whether VMAgent Platform Updates is enabled for the Linux virtual machine. Default value is false. */\n enableVMAgentPlatformUpdates?: boolean;\n}\n\n/** SSH configuration for Linux based VMs running on Azure */\nexport interface SshConfigurationOutput {\n /** The list of SSH public keys used to authenticate with linux based VMs. */\n publicKeys?: Array<SshPublicKeyOutput>;\n}\n\n/** Contains information about SSH certificate public key and the path on the Linux VM where the public key is placed. */\nexport interface SshPublicKeyOutput {\n /** Specifies the full path on the created VM where ssh public key is stored. If the file already exists, the specified key is appended to the file. Example: /home/user/.ssh/authorized_keys */\n path?: string;\n /** SSH public key certificate used to authenticate with the VM through ssh. The key needs to be at least 2048-bit and in ssh-rsa format. <br><br> For creating ssh keys, see [Create SSH keys on Linux and Mac for Linux VMs in Azure]https://docs.microsoft.com/azure/virtual-machines/linux/create-ssh-keys-detailed). */\n keyData?: string;\n}\n\n/** Specifies settings related to VM Guest Patching on Linux. */\nexport interface LinuxPatchSettingsOutput {\n /** Specifies the mode of VM Guest Patching to IaaS virtual machine or virtual machines associated to virtual machine scale set with OrchestrationMode as Flexible.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - The virtual machine's default patching configuration is used. <br /><br /> **AutomaticByPlatform** - The virtual machine will be automatically updated by the platform. The property provisionVMAgent must be true */\n patchMode?: \"ImageDefault\" | \"AutomaticByPlatform\";\n /** Specifies the mode of VM Guest Patch Assessment for the IaaS virtual machine.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - You control the timing of patch assessments on a virtual machine. <br /><br /> **AutomaticByPlatform** - The platform will trigger periodic patch assessments. The property provisionVMAgent must be true. */\n assessmentMode?: \"ImageDefault\" | \"AutomaticByPlatform\";\n /** Specifies additional settings for patch mode AutomaticByPlatform in VM Guest Patching on Linux. */\n automaticByPlatformSettings?: LinuxVMGuestPatchAutomaticByPlatformSettingsOutput;\n}\n\n/** Specifies additional settings to be applied when patch mode AutomaticByPlatform is selected in Linux patch settings. */\nexport interface LinuxVMGuestPatchAutomaticByPlatformSettingsOutput {\n /** Specifies the reboot setting for all AutomaticByPlatform patch installation operations. */\n rebootSetting?: \"Unknown\" | \"IfRequired\" | \"Never\" | \"Always\";\n}\n\n/** Describes a set of certificates which are all in the same Key Vault. */\nexport interface VaultSecretGroupOutput {\n /** The relative URL of the Key Vault containing all of the certificates in VaultCertificates. */\n sourceVault?: SubResourceOutput;\n /** The list of key vault references in SourceVault which contain certificates. */\n vaultCertificates?: Array<VaultCertificateOutput>;\n}\n\nexport interface SubResourceOutput {\n /** Resource Id */\n id?: string;\n}\n\n/** Describes a single certificate reference in a Key Vault, and where the certificate should reside on the VM. */\nexport interface VaultCertificateOutput {\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. For adding a secret to the Key Vault, see [Add a key or secret to the key vault](https://docs.microsoft.com/azure/key-vault/key-vault-get-started/#add). In this case, your certificate needs to be It is the Base64 encoding of the following JSON Object which is encoded in UTF-8: <br><br> {<br> \"data\":\"<Base64-encoded-certificate>\",<br> \"dataType\":\"pfx\",<br> \"password\":\"<pfx-file-password>\"<br>} <br> To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n certificateUrl?: string;\n /** For Windows VMs, specifies the certificate store on the Virtual Machine to which the certificate should be added. The specified certificate store is implicitly in the LocalMachine account. <br><br>For Linux VMs, the certificate file is placed under the /var/lib/waagent directory, with the file name <UppercaseThumbprint>.crt for the X509 certificate file and <UppercaseThumbprint>.prv for private key. Both of these files are .pem formatted. */\n certificateStore?: string;\n}\n\n/** Describes a virtual machine scale set storage profile. */\nexport interface VirtualMachineScaleSetStorageProfileOutput {\n /** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. */\n imageReference?: ImageReferenceOutput;\n /** Specifies information about the operating system disk used by the virtual machines in the scale set. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: VirtualMachineScaleSetOSDiskOutput;\n /** Specifies the parameters that are used to add data disks to the virtual machines in the scale set. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: Array<VirtualMachineScaleSetDataDiskOutput>;\n diskControllerType?: string;\n}\n\n/** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. NOTE: Image reference publisher and offer can only be set when you create the scale set. */\nexport interface ImageReferenceOutput extends SubResourceOutput {\n /** The image publisher. */\n publisher?: string;\n /** Specifies the offer of the platform image or marketplace image used to create the virtual machine. */\n offer?: string;\n /** The image SKU. */\n sku?: string;\n /** Specifies the version of the platform image or marketplace image used to create the virtual machine. The allowed formats are Major.Minor.Build or 'latest'. Major, Minor, and Build are decimal numbers. Specify 'latest' to use the latest version of an image available at deploy time. Even if you use 'latest', the VM image will not automatically update after deploy time even if a new version becomes available. Please do not use field 'version' for gallery image deployment, gallery image should always use 'id' field for deployment, to use 'latest' version of gallery image, just set '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/galleries/{galleryName}/images/{imageName}' in the 'id' field without version input. */\n version?: string;\n /** Specifies in decimal numbers, the version of platform image or marketplace image used to create the virtual machine. This readonly field differs from 'version', only if the value specified in 'version' field is 'latest'. */\n readonly exactVersion?: string;\n /** Specified the shared gallery image unique id for vm deployment. This can be fetched from shared gallery image GET call. */\n sharedGalleryImageId?: string;\n /** Specified the community gallery image unique id for vm deployment. This can be fetched from community gallery image GET call. */\n communityGalleryImageId?: string;\n}\n\n/** Describes a virtual machine scale set operating system disk. */\nexport interface VirtualMachineScaleSetOSDiskOutput {\n /** The disk name. */\n name?: string;\n /** Specifies the caching requirements. <br><br> Possible values are: <br><br> **None** <br><br> **ReadOnly** <br><br> **ReadWrite** <br><br> Default: **None for Standard storage. ReadOnly for Premium storage** */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies how the virtual machines in the scale set should be created.<br><br> The only allowed value is: **FromImage** \\u2013 This value is used when you are using an image to create the virtual machine. If you are using a platform image, you also use the imageReference element described above. If you are using a marketplace image, you also use the plan element previously described. */\n createOption: \"FromImage\" | \"Empty\" | \"Attach\";\n /** Specifies the ephemeral disk Settings for the operating system disk used by the virtual machine scale set. */\n diffDiskSettings?: DiffDiskSettingsOutput;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. <br><br> diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023 */\n diskSizeGB?: number;\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from user-image or a specialized VHD. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType?: \"Windows\" | \"Linux\";\n /** Specifies information about the unmanaged user image to base the scale set on. */\n image?: VirtualHardDiskOutput;\n /** Specifies the container urls that are used to store operating system disks for the scale set. */\n vhdContainers?: Array<string>;\n /** The managed disk parameters. */\n managedDisk?: VirtualMachineScaleSetManagedDiskParametersOutput;\n /** Specifies whether OS Disk should be deleted or detached upon VMSS Flex deletion (This feature is available for VMSS with Flexible OrchestrationMode only). <br><br> Possible values: <br><br> **Delete** If this value is used, the OS disk is deleted when VMSS Flex VM is deleted.<br><br> **Detach** If this value is used, the OS disk is retained after VMSS Flex VM is deleted. <br><br> The default value is set to **Delete**. For an Ephemeral OS Disk, the default value is set to **Delete**. User cannot change the delete option for Ephemeral OS Disk. */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes the parameters of ephemeral disk settings that can be specified for operating system disk. <br><br> NOTE: The ephemeral disk settings can only be specified for managed disk. */\nexport interface DiffDiskSettingsOutput {\n /** Specifies the ephemeral disk settings for operating system disk. */\n option?: \"Local\";\n /** Specifies the ephemeral disk placement for operating system disk.<br><br> Possible values are: <br><br> **CacheDisk** <br><br> **ResourceDisk** <br><br> Default: **CacheDisk** if one is configured for the VM size otherwise **ResourceDisk** is used.<br><br> Refer to VM size documentation for Windows VM at https://docs.microsoft.com/azure/virtual-machines/windows/sizes and Linux VM at https://docs.microsoft.com/azure/virtual-machines/linux/sizes to check which VM sizes exposes a cache disk. */\n placement?: \"CacheDisk\" | \"ResourceDisk\";\n}\n\n/** Describes the uri of a disk. */\nexport interface VirtualHardDiskOutput {\n /** Specifies the virtual hard disk's uri. */\n uri?: string;\n}\n\n/** Describes the parameters of a ScaleSet managed disk. */\nexport interface VirtualMachineScaleSetManagedDiskParametersOutput {\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?:\n | \"Standard_LRS\"\n | \"Premium_LRS\"\n | \"StandardSSD_LRS\"\n | \"UltraSSD_LRS\"\n | \"Premium_ZRS\"\n | \"StandardSSD_ZRS\"\n | \"PremiumV2_LRS\";\n /** Specifies the customer managed disk encryption set resource id for the managed disk. */\n diskEncryptionSet?: DiskEncryptionSetParametersOutput;\n /** Specifies the security profile for the managed disk. */\n securityProfile?: VMDiskSecurityProfileOutput;\n}\n\n/** Describes the parameter of customer managed disk encryption set resource id that can be specified for disk. <br><br> NOTE: The disk encryption set resource id can only be specified for managed disk. Please refer https://aka.ms/mdssewithcmkoverview for more details. */\nexport interface DiskEncryptionSetParametersOutput extends SubResourceOutput {}\n\n/** Specifies the security profile settings for the managed disk. <br><br> NOTE: It can only be set for Confidential VMs */\nexport interface VMDiskSecurityProfileOutput {\n /** Specifies the EncryptionType of the managed disk. <br> It is set to DiskWithVMGuestState for encryption of the managed disk along with VMGuestState blob, and VMGuestStateOnly for encryption of just the VMGuestState blob. <br><br> NOTE: It can be set for only Confidential VMs. */\n securityEncryptionType?: \"VMGuestStateOnly\" | \"DiskWithVMGuestState\";\n /** Specifies the customer managed disk encryption set resource id for the managed disk that is used for Customer Managed Key encrypted ConfidentialVM OS Disk and VMGuest blob. */\n diskEncryptionSet?: DiskEncryptionSetParametersOutput;\n}\n\n/** Describes a virtual machine scale set data disk. */\nexport interface VirtualMachineScaleSetDataDiskOutput {\n /** The disk name. */\n name?: string;\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n /** Specifies the caching requirements. <br><br> Possible values are: <br><br> **None** <br><br> **ReadOnly** <br><br> **ReadWrite** <br><br> Default: **None for Standard storage. ReadOnly for Premium storage** */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** The create option. */\n createOption: \"FromImage\" | \"Empty\" | \"Attach\";\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. <br><br> diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023 */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: VirtualMachineScaleSetManagedDiskParametersOutput;\n /** Specifies the Read-Write IOPS for the managed disk. Should be used only when StorageAccountType is UltraSSD_LRS. If not specified, a default value would be assigned based on diskSizeGB. */\n diskIOPSReadWrite?: number;\n /** Specifies the bandwidth in MB per second for the managed disk. Should be used only when StorageAccountType is UltraSSD_LRS. If not specified, a default value would be assigned based on diskSizeGB. */\n diskMBpsReadWrite?: number;\n /** Specifies whether data disk should be deleted or detached upon VMSS Flex deletion (This feature is available for VMSS with Flexible OrchestrationMode only).<br><br> Possible values: <br><br> **Delete** If this value is used, the data disk is deleted when the VMSS Flex VM is deleted.<br><br> **Detach** If this value is used, the data disk is retained after VMSS Flex VM is deleted.<br><br> The default value is set to **Delete**. */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes a virtual machine scale set network profile. */\nexport interface VirtualMachineScaleSetNetworkProfileOutput {\n /** A reference to a load balancer probe used to determine the health of an instance in the virtual machine scale set. The reference will be in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/probes/{probeName}'. */\n healthProbe?: ApiEntityReferenceOutput;\n /** The list of network configurations. */\n networkInterfaceConfigurations?: Array<VirtualMachineScaleSetNetworkConfigurationOutput>;\n /** specifies the Microsoft.Network API version used when creating networking resources in the Network Interface Configurations for Virtual Machine Scale Set with orchestration mode 'Flexible' */\n networkApiVersion?: \"2020-11-01\";\n}\n\n/** The API entity reference. */\nexport interface ApiEntityReferenceOutput {\n /** The ARM resource id in the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/... */\n id?: string;\n}\n\n/** Describes a virtual machine scale set network profile's network configurations. */\nexport interface VirtualMachineScaleSetNetworkConfigurationOutput extends SubResourceOutput {\n /** The network configuration name. */\n name: string;\n /** Describes a virtual machine scale set network profile's IP configuration. */\n properties?: VirtualMachineScaleSetNetworkConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration. */\nexport interface VirtualMachineScaleSetNetworkConfigurationPropertiesOutput {\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResourceOutput;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineScaleSetNetworkConfigurationDnsSettingsOutput;\n /** Specifies the IP configurations of the network interface. */\n ipConfigurations: Array<VirtualMachineScaleSetIPConfigurationOutput>;\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes a virtual machines scale sets network configuration's DNS settings. */\nexport interface VirtualMachineScaleSetNetworkConfigurationDnsSettingsOutput {\n /** List of DNS servers IP addresses */\n dnsServers?: Array<string>;\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration. */\nexport interface VirtualMachineScaleSetIPConfigurationOutput extends SubResourceOutput {\n /** The IP configuration name. */\n name: string;\n /** Describes a virtual machine scale set network profile's IP configuration properties. */\n properties?: VirtualMachineScaleSetIPConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration properties. */\nexport interface VirtualMachineScaleSetIPConfigurationPropertiesOutput {\n /** Specifies the identifier of the subnet. */\n subnet?: ApiEntityReferenceOutput;\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachineScaleSetPublicIPAddressConfigurationOutput;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: \"IPv4\" | \"IPv6\";\n /** Specifies an array of references to backend address pools of application gateways. A scale set can reference backend address pools of multiple application gateways. Multiple scale sets cannot use the same application gateway. */\n applicationGatewayBackendAddressPools?: Array<SubResourceOutput>;\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: Array<SubResourceOutput>;\n /** Specifies an array of references to backend address pools of load balancers. A scale set can reference backend address pools of one public and one internal load balancer. Multiple scale sets cannot use the same basic sku load balancer. */\n loadBalancerBackendAddressPools?: Array<SubResourceOutput>;\n /** Specifies an array of references to inbound Nat pools of the load balancers. A scale set can reference inbound nat pools of one public and one internal load balancer. Multiple scale sets cannot use the same basic sku load balancer. */\n loadBalancerInboundNatPools?: Array<SubResourceOutput>;\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetPublicIPAddressConfigurationOutput {\n /** The publicIP address configuration name. */\n name: string;\n /** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\n properties?: VirtualMachineScaleSetPublicIPAddressConfigurationPropertiesOutput;\n /** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\n sku?: PublicIPAddressSkuOutput;\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetPublicIPAddressConfigurationPropertiesOutput {\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettingsOutput;\n /** The list of IP tags associated with the public IP address. */\n ipTags?: Array<VirtualMachineScaleSetIpTagOutput>;\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResourceOutput;\n /** Available from Api-Version 2019-07-01 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n publicIPAddressVersion?: \"IPv4\" | \"IPv6\";\n /** Specify what happens to the public IP when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes a virtual machines scale sets network configuration's DNS settings. */\nexport interface VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettingsOutput {\n /** The Domain name label.The concatenation of the domain name label and vm index will be the domain name labels of the PublicIPAddress resources that will be created */\n domainNameLabel: string;\n}\n\n/** Contains the IP tag associated with the public IP address. */\nexport interface VirtualMachineScaleSetIpTagOutput {\n /** IP tag type. Example: FirstPartyUsage. */\n ipTagType?: string;\n /** IP tag associated with the public IP. Example: SQL, Storage etc. */\n tag?: string;\n}\n\n/** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\nexport interface PublicIPAddressSkuOutput {\n /** Specify public IP sku name */\n name?: \"Basic\" | \"Standard\";\n /** Specify public IP sku tier */\n tier?: \"Regional\" | \"Global\";\n}\n\n/** Specifies the Security profile settings for the virtual machine or virtual machine scale set. */\nexport interface SecurityProfileOutput {\n /** Specifies the security settings like secure boot and vTPM used while creating the virtual machine. <br><br>Minimum api-version: 2020-12-01 */\n uefiSettings?: UefiSettingsOutput;\n /** This property can be used by user in the request to enable or disable the Host Encryption for the virtual machine or virtual machine scale set. This will enable the encryption for all the disks including Resource/Temp disk at host itself. <br><br> Default: The Encryption at host will be disabled unless this property is set to true for the resource. */\n encryptionAtHost?: boolean;\n /** Specifies the SecurityType of the virtual machine. It has to be set to any specified value to enable UefiSettings. <br><br> Default: UefiSettings will not be enabled unless this property is set. */\n securityType?: \"TrustedLaunch\" | \"ConfidentialVM\";\n}\n\n/** Specifies the security settings like secure boot and vTPM used while creating the virtual machine. <br><br>Minimum api-version: 2020-12-01 */\nexport interface UefiSettingsOutput {\n /** Specifies whether secure boot should be enabled on the virtual machine. <br><br>Minimum api-version: 2020-12-01 */\n secureBootEnabled?: boolean;\n /** Specifies whether vTPM should be enabled on the virtual machine. <br><br>Minimum api-version: 2020-12-01 */\n vTpmEnabled?: boolean;\n}\n\n/** Specifies the boot diagnostic settings state. <br><br>Minimum api-version: 2015-06-15. */\nexport interface DiagnosticsProfileOutput {\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. <br>**NOTE**: If storageUri is being specified then ensure that the storage account is in the same region and subscription as the VM. <br><br> You can easily view the output of your console log. <br><br> Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnosticsOutput;\n}\n\n/** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. <br><br> You can easily view the output of your console log. <br><br> Azure also enables you to see a screenshot of the VM from the hypervisor. */\nexport interface BootDiagnosticsOutput {\n /** Whether boot diagnostics should be enabled on the Virtual Machine. */\n enabled?: boolean;\n /** Uri of the storage account to use for placing the console output and screenshot. <br><br>If storageUri is not specified while enabling boot diagnostics, managed storage will be used. */\n storageUri?: string;\n}\n\n/** Describes a virtual machine scale set extension profile. */\nexport interface VirtualMachineScaleSetExtensionProfileOutput {\n /** The virtual machine scale set child extension resources. */\n extensions?: Array<VirtualMachineScaleSetExtensionOutput>;\n /** Specifies the time alloted for all extensions to start. The time duration should be between 15 minutes and 120 minutes (inclusive) and should be specified in ISO 8601 format. The default value is 90 minutes (PT1H30M). <br><br> Minimum api-version: 2020-06-01 */\n extensionsTimeBudget?: string;\n}\n\n/** Describes a Virtual Machine Scale Set Extension. */\nexport interface VirtualMachineScaleSetExtensionOutput extends SubResourceReadOnlyOutput {\n /** The name of the extension. */\n name?: string;\n /** Resource type */\n readonly type?: string;\n /** Describes the properties of a Virtual Machine Scale Set Extension. */\n properties?: VirtualMachineScaleSetExtensionPropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine Scale Set Extension. */\nexport interface VirtualMachineScaleSetExtensionPropertiesOutput {\n /** If a value is provided and is different from the previous value, the extension handler will be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** Collection of extension names after which this extension needs to be provisioned. */\n provisionAfterExtensions?: Array<string>;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReferenceOutput;\n}\n\n/** Describes a reference to Key Vault Secret */\nexport interface KeyVaultSecretReferenceOutput {\n /** The URL referencing a secret in a Key Vault. */\n secretUrl: string;\n /** The relative URL of the Key Vault containing the secret. */\n sourceVault: SubResourceOutput;\n}\n\nexport interface SubResourceReadOnlyOutput {\n /** Resource Id */\n readonly id?: string;\n}\n\n/** Specifies the billing related details of a Azure Spot VM or VMSS. <br><br>Minimum api-version: 2019-03-01. */\nexport interface BillingProfileOutput {\n /** Specifies the maximum price you are willing to pay for a Azure Spot VM/VMSS. This price is in US Dollars. <br><br> This price will be compared with the current Azure Spot price for the VM size. Also, the prices are compared at the time of create/update of Azure Spot VM/VMSS and the operation will only succeed if the maxPrice is greater than the current Azure Spot price. <br><br> The maxPrice will also be used for evicting a Azure Spot VM/VMSS if the current Azure Spot price goes beyond the maxPrice after creation of VM/VMSS. <br><br> Possible values are: <br><br> - Any decimal value greater than zero. Example: 0.01538 <br><br> -1 – indicates default price to be up-to on-demand. <br><br> You can set the maxPrice to -1 to indicate that the Azure Spot VM/VMSS should not be evicted for price reasons. Also, the default max price is -1 if it is not provided by you. <br><br>Minimum api-version: 2019-03-01. */\n maxPrice?: number;\n}\n\nexport interface ScheduledEventsProfileOutput {\n /** Specifies Terminate Scheduled Event related configurations. */\n terminateNotificationProfile?: TerminateNotificationProfileOutput;\n}\n\nexport interface TerminateNotificationProfileOutput {\n /** Configurable length of time a Virtual Machine being deleted will have to potentially approve the Terminate Scheduled Event before the event is auto approved (timed out). The configuration must be specified in ISO 8601 format, the default value is 5 minutes (PT5M) */\n notBeforeTimeout?: string;\n /** Specifies whether the Terminate Scheduled event is enabled or disabled. */\n enable?: boolean;\n}\n\n/** The parameters of a capacity reservation Profile. */\nexport interface CapacityReservationProfileOutput {\n /** Specifies the capacity reservation group resource id that should be used for allocating the virtual machine or scaleset vm instances provided enough capacity has been reserved. Please refer to https://aka.ms/CapacityReservation for more details. */\n capacityReservationGroup?: SubResourceOutput;\n}\n\n/** Contains the list of gallery applications that should be made available to the VM/VMSS */\nexport interface ApplicationProfileOutput {\n /** Specifies the gallery applications that should be made available to the VM/VMSS */\n galleryApplications?: Array<VMGalleryApplicationOutput>;\n}\n\n/** Specifies the required information to reference a compute gallery application version */\nexport interface VMGalleryApplicationOutput {\n /** Optional, Specifies a passthrough value for more generic context. */\n tags?: string;\n /** Optional, Specifies the order in which the packages have to be installed */\n order?: number;\n /** Specifies the GalleryApplicationVersion resource id on the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/providers/Microsoft.Compute/galleries/{galleryName}/applications/{application}/versions/{version} */\n packageReferenceId: string;\n /** Optional, Specifies the uri to an azure blob that will replace the default configuration for the package if provided */\n configurationReference?: string;\n /** Optional, If true, any failure for any operation in the VmApplication will fail the deployment */\n treatFailureAsDeploymentFailure?: boolean;\n /** If set to true, when a new Gallery Application version is available in PIR/SIG, it will be automatically updated for the VM/VMSS */\n enableAutomaticUpgrade?: boolean;\n}\n\n/** Specifies the hardware settings for the virtual machine scale set. */\nexport interface VirtualMachineScaleSetHardwareProfileOutput {\n /** Specifies the properties for customizing the size of the virtual machine. Minimum api-version: 2021-11-01. <br><br> Please follow the instructions in [VM Customization](https://aka.ms/vmcustomization) for more details. */\n vmSizeProperties?: VMSizePropertiesOutput;\n}\n\n/** Specifies VM Size Property settings on the virtual machine. */\nexport interface VMSizePropertiesOutput {\n /** Specifies the number of vCPUs available for the VM. <br><br> When this property is not specified in the request body the default behavior is to set it to the value of vCPUs available for that VM size exposed in api response of [List all available virtual machine sizes in a region](https://docs.microsoft.com/en-us/rest/api/compute/resource-skus/list) . */\n vCPUsAvailable?: number;\n /** Specifies the vCPU to physical core ratio. <br><br> When this property is not specified in the request body the default behavior is set to the value of vCPUsPerCore for the VM Size exposed in api response of [List all available virtual machine sizes in a region](https://docs.microsoft.com/en-us/rest/api/compute/resource-skus/list) <br><br> Setting this property to 1 also means that hyper-threading is disabled. */\n vCPUsPerCore?: number;\n}\n\n/** Enables or disables a capability on the virtual machine or virtual machine scale set. */\nexport interface AdditionalCapabilitiesOutput {\n /** The flag that enables or disables a capability to have one or more managed data disks with UltraSSD_LRS storage account type on the VM or VMSS. Managed disks with storage account type UltraSSD_LRS can be added to a virtual machine or virtual machine scale set only if this property is enabled. */\n ultraSSDEnabled?: boolean;\n /** The flag that enables or disables hibernation capability on the VM. */\n hibernationEnabled?: boolean;\n}\n\n/** Describes a scale-in policy for a virtual machine scale set. */\nexport interface ScaleInPolicyOutput {\n /** The rules to be followed when scaling-in a virtual machine scale set. <br><br> Possible values are: <br><br> **Default** When a virtual machine scale set is scaled in, the scale set will first be balanced across zones if it is a zonal scale set. Then, it will be balanced across Fault Domains as far as possible. Within each Fault Domain, the virtual machines chosen for removal will be the newest ones that are not protected from scale-in. <br><br> **OldestVM** When a virtual machine scale set is being scaled-in, the oldest virtual machines that are not protected from scale-in will be chosen for removal. For zonal virtual machine scale sets, the scale set will first be balanced across zones. Within each zone, the oldest virtual machines that are not protected will be chosen for removal. <br><br> **NewestVM** When a virtual machine scale set is being scaled-in, the newest virtual machines that are not protected from scale-in will be chosen for removal. For zonal virtual machine scale sets, the scale set will first be balanced across zones. Within each zone, the newest virtual machines that are not protected will be chosen for removal. <br><br> */\n rules?: Array<\"Default\" | \"OldestVM\" | \"NewestVM\">;\n /** This property allows you to specify if virtual machines chosen for removal have to be force deleted when a virtual machine scale set is being scaled-in.(Feature in Preview) */\n forceDeletion?: boolean;\n}\n\n/** Specifies the Spot-Try-Restore properties for the virtual machine scale set. <br><br> With this property customer can enable or disable automatic restore of the evicted Spot VMSS VM instances opportunistically based on capacity availability and pricing constraint. */\nexport interface SpotRestorePolicyOutput {\n /** Enables the Spot-Try-Restore feature where evicted VMSS SPOT instances will be tried to be restored opportunistically based on capacity availability and pricing constraints */\n enabled?: boolean;\n /** Timeout value expressed as an ISO 8601 time duration after which the platform will not try to restore the VMSS SPOT instances */\n restoreTimeout?: string;\n}\n\n/** Specifies the target splits for Spot and Regular priority VMs within a scale set with flexible orchestration mode. <br><br>With this property the customer is able to specify the base number of regular priority VMs created as the VMSS flex instance scales out and the split between Spot and Regular priority VMs after this base target has been reached. */\nexport interface PriorityMixPolicyOutput {\n /** The base number of regular priority VMs that will be created in this scale set as it scales out. */\n baseRegularPriorityCount?: number;\n /** The percentage of VM instances, after the base regular priority count has been reached, that are expected to use regular priority. */\n regularPriorityPercentageAboveBase?: number;\n}\n\n/** Identity for the virtual machine scale set. */\nexport interface VirtualMachineScaleSetIdentityOutput {\n /** The principal id of virtual machine scale set identity. This property will only be provided for a system assigned identity. */\n readonly principalId?: string;\n /** The tenant id associated with the virtual machine scale set. This property will only be provided for a system assigned identity. */\n readonly tenantId?: string;\n /** The type of identity used for the virtual machine scale set. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user assigned identities. The type 'None' will remove any identities from the virtual machine scale set. */\n type?: \"SystemAssigned\" | \"UserAssigned\" | \"SystemAssigned, UserAssigned\" | \"None\";\n /** The list of user identities associated with the virtual machine scale set. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: Record<string, UserAssignedIdentitiesValueOutput>;\n}\n\nexport interface UserAssignedIdentitiesValueOutput {\n /** The principal id of user assigned identity. */\n readonly principalId?: string;\n /** The client id of user assigned identity. */\n readonly clientId?: string;\n}\n\n/** The complex type of the extended location. */\nexport interface ExtendedLocationOutput {\n /** The name of the extended location. */\n name?: string;\n /** The type of the extended location. */\n type?: \"EdgeZone\";\n}\n\n/** The Resource model definition. */\nexport interface ResourceOutput {\n /** Resource Id */\n readonly id?: string;\n /** Resource name */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Resource location */\n location: string;\n /** Resource tags */\n tags?: Record<string, string>;\n}\n\n/** Describes a virtual machine scale set network profile's network configurations. */\nexport interface VirtualMachineScaleSetUpdateNetworkConfigurationOutput extends SubResourceOutput {\n /** The network configuration name. */\n name?: string;\n /** Describes a virtual machine scale set updatable network profile's IP configuration.Use this object for updating network profile's IP Configuration. */\n properties?: VirtualMachineScaleSetUpdateNetworkConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine scale set updatable network profile's IP configuration.Use this object for updating network profile's IP Configuration. */\nexport interface VirtualMachineScaleSetUpdateNetworkConfigurationPropertiesOutput {\n /** Whether this is a primary NIC on a virtual machine. */\n primary?: boolean;\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResourceOutput;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineScaleSetNetworkConfigurationDnsSettingsOutput;\n /** The virtual machine scale set IP Configuration. */\n ipConfigurations?: Array<VirtualMachineScaleSetUpdateIPConfigurationOutput>;\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration. NOTE: The subnet of a scale set may be modified as long as the original subnet and the new subnet are in the same virtual network */\nexport interface VirtualMachineScaleSetUpdateIPConfigurationOutput extends SubResourceOutput {\n /** The IP configuration name. */\n name?: string;\n /** Describes a virtual machine scale set network profile's IP configuration properties. */\n properties?: VirtualMachineScaleSetUpdateIPConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration properties. */\nexport interface VirtualMachineScaleSetUpdateIPConfigurationPropertiesOutput {\n /** The subnet. */\n subnet?: ApiEntityReferenceOutput;\n /** Specifies the primary IP Configuration in case the network interface has more than one IP Configuration. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachineScaleSetUpdatePublicIPAddressConfigurationOutput;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: \"IPv4\" | \"IPv6\";\n /** The application gateway backend address pools. */\n applicationGatewayBackendAddressPools?: Array<SubResourceOutput>;\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: Array<SubResourceOutput>;\n /** The load balancer backend address pools. */\n loadBalancerBackendAddressPools?: Array<SubResourceOutput>;\n /** The load balancer inbound nat pools. */\n loadBalancerInboundNatPools?: Array<SubResourceOutput>;\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetUpdatePublicIPAddressConfigurationOutput {\n /** The publicIP address configuration name. */\n name?: string;\n /** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\n properties?: VirtualMachineScaleSetUpdatePublicIPAddressConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetUpdatePublicIPAddressConfigurationPropertiesOutput {\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettingsOutput;\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResourceOutput;\n /** Specify what happens to the public IP when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** The instance view of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetInstanceViewOutput {\n /** The instance view status summary for the virtual machine scale set. */\n readonly virtualMachine?: VirtualMachineScaleSetInstanceViewStatusesSummaryOutput;\n /** The extensions information. */\n readonly extensions?: Array<VirtualMachineScaleSetVMExtensionsSummaryOutput>;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n /** The orchestration services information. */\n readonly orchestrationServices?: Array<OrchestrationServiceSummaryOutput>;\n}\n\n/** Instance view statuses summary for virtual machines of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetInstanceViewStatusesSummaryOutput {\n /** The extensions information. */\n readonly statusesSummary?: Array<VirtualMachineStatusCodeCountOutput>;\n}\n\n/** The status code and count of the virtual machine scale set instance view status summary. */\nexport interface VirtualMachineStatusCodeCountOutput {\n /** The instance view status code. */\n readonly code?: string;\n /** The number of instances having a particular status code. */\n readonly count?: number;\n}\n\n/** Extensions summary for virtual machines of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetVMExtensionsSummaryOutput {\n /** The extension name. */\n readonly name?: string;\n /** The extensions information. */\n readonly statusesSummary?: Array<VirtualMachineStatusCodeCountOutput>;\n}\n\n/** Instance view status. */\nexport interface InstanceViewStatusOutput {\n /** The status code. */\n code?: string;\n /** The level code. */\n level?: \"Info\" | \"Warning\" | \"Error\";\n /** The short localizable label for the status. */\n displayStatus?: string;\n /** The detailed status message, including for alerts and error messages. */\n message?: string;\n /** The time of the status. */\n time?: string;\n}\n\n/** Summary for an orchestration service of a virtual machine scale set. */\nexport interface OrchestrationServiceSummaryOutput {\n /** The name of the service. */\n readonly serviceName?: \"AutomaticRepairs\";\n /** The current state of the service. */\n readonly serviceState?: \"NotRunning\" | \"Running\" | \"Suspended\";\n}\n\n/** Describes a Virtual Machine Scale Set Extension. */\nexport interface VirtualMachineScaleSetExtensionUpdateOutput extends SubResourceReadOnlyOutput {\n /** The name of the extension. */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Describes the properties of a Virtual Machine Scale Set Extension. */\n properties?: VirtualMachineScaleSetExtensionPropertiesOutput;\n}\n\n/** The List VM scale set extension operation response. */\nexport interface VirtualMachineScaleSetExtensionListResultOutput {\n /** The list of VM scale set extensions. */\n value: Array<VirtualMachineScaleSetExtensionOutput>;\n /** The uri to fetch the next page of VM scale set extensions. Call ListNext() with this to fetch the next page of VM scale set extensions. */\n nextLink?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineScaleSetListWithLinkResultOutput {\n /** The list of virtual machine scale sets. */\n value: Array<VirtualMachineScaleSetOutput>;\n /** The uri to fetch the next page of Virtual Machine Scale Sets. Call ListNext() with this to fetch the next page of Virtual Machine Scale Sets. */\n nextLink?: string;\n}\n\n/** The Virtual Machine Scale Set List Skus operation response. */\nexport interface VirtualMachineScaleSetListSkusResultOutput {\n /** The list of skus available for the virtual machine scale set. */\n value: Array<VirtualMachineScaleSetSkuOutput>;\n /** The uri to fetch the next page of Virtual Machine Scale Set Skus. Call ListNext() with this to fetch the next page of VMSS Skus. */\n nextLink?: string;\n}\n\n/** Describes an available virtual machine scale set sku. */\nexport interface VirtualMachineScaleSetSkuOutput {\n /** The type of resource the sku applies to. */\n readonly resourceType?: string;\n /** The Sku. */\n readonly sku?: SkuOutput;\n /** Specifies the number of virtual machines in the scale set. */\n readonly capacity?: VirtualMachineScaleSetSkuCapacityOutput;\n}\n\n/** Describes scaling information of a sku. */\nexport interface VirtualMachineScaleSetSkuCapacityOutput {\n /** The minimum capacity. */\n readonly minimum?: number;\n /** The maximum capacity that can be set. */\n readonly maximum?: number;\n /** The default capacity. */\n readonly defaultCapacity?: number;\n /** The scale type applicable to the sku. */\n readonly scaleType?: \"Automatic\" | \"None\";\n}\n\n/** List of Virtual Machine Scale Set OS Upgrade History operation response. */\nexport interface VirtualMachineScaleSetListOSUpgradeHistoryOutput {\n /** The list of OS upgrades performed on the virtual machine scale set. */\n value: Array<UpgradeOperationHistoricalStatusInfoOutput>;\n /** The uri to fetch the next page of OS Upgrade History. Call ListNext() with this to fetch the next page of history of upgrades. */\n nextLink?: string;\n}\n\n/** Virtual Machine Scale Set OS Upgrade History operation response. */\nexport interface UpgradeOperationHistoricalStatusInfoOutput {\n /** Information about the properties of the upgrade operation. */\n readonly properties?: UpgradeOperationHistoricalStatusInfoPropertiesOutput;\n /** Resource type */\n readonly type?: string;\n /** Resource location */\n readonly location?: string;\n}\n\n/** Describes each OS upgrade on the Virtual Machine Scale Set. */\nexport interface UpgradeOperationHistoricalStatusInfoPropertiesOutput {\n /** Information about the overall status of the upgrade operation. */\n readonly runningStatus?: UpgradeOperationHistoryStatusOutput;\n /** Counts of the VMs in each state. */\n readonly progress?: RollingUpgradeProgressInfoOutput;\n /** Error Details for this upgrade if there are any. */\n readonly error?: ApiErrorOutput;\n /** Invoker of the Upgrade Operation */\n readonly startedBy?: \"Unknown\" | \"User\" | \"Platform\";\n /** Image Reference details */\n readonly targetImageReference?: ImageReferenceOutput;\n /** Information about OS rollback if performed */\n readonly rollbackInfo?: RollbackStatusInfoOutput;\n}\n\n/** Information about the current running state of the overall upgrade. */\nexport interface UpgradeOperationHistoryStatusOutput {\n /** Code indicating the current status of the upgrade. */\n readonly code?: \"RollingForward\" | \"Cancelled\" | \"Completed\" | \"Faulted\";\n /** Start time of the upgrade. */\n readonly startTime?: string;\n /** End time of the upgrade. */\n readonly endTime?: string;\n}\n\n/** Information about the number of virtual machine instances in each upgrade state. */\nexport interface RollingUpgradeProgressInfoOutput {\n /** The number of instances that have been successfully upgraded. */\n readonly successfulInstanceCount?: number;\n /** The number of instances that have failed to be upgraded successfully. */\n readonly failedInstanceCount?: number;\n /** The number of instances that are currently being upgraded. */\n readonly inProgressInstanceCount?: number;\n /** The number of instances that have not yet begun to be upgraded. */\n readonly pendingInstanceCount?: number;\n}\n\n/** Information about rollback on failed VM instances after a OS Upgrade operation. */\nexport interface RollbackStatusInfoOutput {\n /** The number of instances which have been successfully rolled back. */\n readonly successfullyRolledbackInstanceCount?: number;\n /** The number of instances which failed to rollback. */\n readonly failedRolledbackInstanceCount?: number;\n /** Error details if OS rollback failed. */\n readonly rollbackError?: ApiErrorOutput;\n}\n\n/** The status of the latest virtual machine scale set rolling upgrade. */\nexport interface RollingUpgradeStatusInfoOutput extends ResourceOutput {\n /** The status of the latest virtual machine scale set rolling upgrade. */\n properties?: RollingUpgradeStatusInfoPropertiesOutput;\n}\n\n/** The status of the latest virtual machine scale set rolling upgrade. */\nexport interface RollingUpgradeStatusInfoPropertiesOutput {\n /** The rolling upgrade policies applied for this upgrade. */\n readonly policy?: RollingUpgradePolicyOutput;\n /** Information about the current running state of the overall upgrade. */\n readonly runningStatus?: RollingUpgradeRunningStatusOutput;\n /** Information about the number of virtual machine instances in each upgrade state. */\n readonly progress?: RollingUpgradeProgressInfoOutput;\n /** Error details for this upgrade, if there are any. */\n readonly error?: ApiErrorOutput;\n}\n\n/** Information about the current running state of the overall upgrade. */\nexport interface RollingUpgradeRunningStatusOutput {\n /** Code indicating the current status of the upgrade. */\n readonly code?: \"RollingForward\" | \"Cancelled\" | \"Completed\" | \"Faulted\";\n /** Start time of the upgrade. */\n readonly startTime?: string;\n /** The last action performed on the rolling upgrade. */\n readonly lastAction?: \"Start\" | \"Cancel\";\n /** Last action time of the upgrade. */\n readonly lastActionTime?: string;\n}\n\n/** Response after calling a manual recovery walk */\nexport interface RecoveryWalkResponseOutput {\n /** Whether the recovery walk was performed */\n readonly walkPerformed?: boolean;\n /** The next update domain that needs to be walked. Null means walk spanning all update domains has been completed */\n readonly nextPlatformUpdateDomain?: number;\n}\n\n/** Describes a VMSS VM Extension. */\nexport interface VirtualMachineScaleSetVMExtensionOutput extends SubResourceReadOnlyOutput {\n /** The name of the extension. */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Describes the properties of a Virtual Machine Extension. */\n properties?: VirtualMachineExtensionPropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine Extension. */\nexport interface VirtualMachineExtensionPropertiesOutput {\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The virtual machine extension instance view. */\n instanceView?: VirtualMachineExtensionInstanceViewOutput;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReferenceOutput;\n}\n\n/** The instance view of a virtual machine extension. */\nexport interface VirtualMachineExtensionInstanceViewOutput {\n /** The virtual machine extension name. */\n name?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** The resource status information. */\n substatuses?: Array<InstanceViewStatusOutput>;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** Describes a VMSS VM Extension. */\nexport interface VirtualMachineScaleSetVMExtensionUpdateOutput extends SubResourceReadOnlyOutput {\n /** The name of the extension. */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Describes the properties of a Virtual Machine Extension. */\n properties?: VirtualMachineExtensionUpdatePropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine Extension. */\nexport interface VirtualMachineExtensionUpdatePropertiesOutput {\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReferenceOutput;\n}\n\n/** The List VMSS VM Extension operation response */\nexport interface VirtualMachineScaleSetVMExtensionsListResultOutput {\n /** The list of VMSS VM extensions */\n value?: Array<VirtualMachineScaleSetVMExtensionOutput>;\n}\n\n/** Describes a virtual machine scale set virtual machine. */\nexport interface VirtualMachineScaleSetVMOutput extends ResourceOutput {\n /** The virtual machine instance ID. */\n readonly instanceId?: string;\n /** The virtual machine SKU. */\n readonly sku?: SkuOutput;\n /** Describes the properties of a virtual machine scale set virtual machine. */\n properties?: VirtualMachineScaleSetVMPropertiesOutput;\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: PlanOutput;\n /** The virtual machine child extension resources. */\n readonly resources?: Array<VirtualMachineExtensionOutput>;\n /** The virtual machine zones. */\n readonly zones?: Array<string>;\n /** The identity of the virtual machine, if configured. */\n identity?: VirtualMachineIdentityOutput;\n}\n\n/** Describes the properties of a virtual machine scale set virtual machine. */\nexport interface VirtualMachineScaleSetVMPropertiesOutput {\n /** Specifies whether the latest model has been applied to the virtual machine. */\n readonly latestModelApplied?: boolean;\n /** Azure VM unique ID. */\n readonly vmId?: string;\n /** The virtual machine instance view. */\n readonly instanceView?: VirtualMachineScaleSetVMInstanceViewOutput;\n /** Specifies the hardware settings for the virtual machine. */\n hardwareProfile?: HardwareProfileOutput;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: StorageProfileOutput;\n /** Specifies additional capabilities enabled or disabled on the virtual machine in the scale set. For instance: whether the virtual machine has the capability to support attaching managed data disks with UltraSSD_LRS storage account type. */\n additionalCapabilities?: AdditionalCapabilitiesOutput;\n /** Specifies the operating system settings for the virtual machine. */\n osProfile?: OSProfileOutput;\n /** Specifies the Security related profile settings for the virtual machine. */\n securityProfile?: SecurityProfileOutput;\n /** Specifies the network interfaces of the virtual machine. */\n networkProfile?: NetworkProfileOutput;\n /** Specifies the network profile configuration of the virtual machine. */\n networkProfileConfiguration?: VirtualMachineScaleSetVMNetworkProfileConfigurationOutput;\n /** Specifies the boot diagnostic settings state. <br><br>Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfileOutput;\n /** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). <br><br> For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates) <br><br> Currently, a VM can only be added to availability set at creation time. An existing VM cannot be added to an availability set. */\n availabilitySet?: SubResourceOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /** Specifies whether the model applied to the virtual machine is the model of the virtual machine scale set or the customized model for the virtual machine. */\n readonly modelDefinitionApplied?: string;\n /** Specifies the protection policy of the virtual machine. */\n protectionPolicy?: VirtualMachineScaleSetVMProtectionPolicyOutput;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. <br><br>Minimum api-version: 2021-03-01 */\n userData?: string;\n}\n\n/** The instance view of a virtual machine scale set VM. */\nexport interface VirtualMachineScaleSetVMInstanceViewOutput {\n /** The Update Domain count. */\n platformUpdateDomain?: number;\n /** The Fault Domain count. */\n platformFaultDomain?: number;\n /** The Remote desktop certificate thumbprint. */\n rdpThumbPrint?: string;\n /** The VM Agent running on the virtual machine. */\n vmAgent?: VirtualMachineAgentInstanceViewOutput;\n /** The Maintenance Operation status on the virtual machine. */\n maintenanceRedeployStatus?: MaintenanceRedeployStatusOutput;\n /** The disks information. */\n disks?: Array<DiskInstanceViewOutput>;\n /** The extensions information. */\n extensions?: Array<VirtualMachineExtensionInstanceViewOutput>;\n /** The health status for the VM. */\n readonly vmHealth?: VirtualMachineHealthStatusOutput;\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. <br><br> You can easily view the output of your console log. <br><br> Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnosticsInstanceViewOutput;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n /** Resource id of the dedicated host, on which the virtual machine is allocated through automatic placement, when the virtual machine is associated with a dedicated host group that has automatic placement enabled. <br><br>Minimum api-version: 2020-06-01. */\n readonly assignedHost?: string;\n /** The placement group in which the VM is running. If the VM is deallocated it will not have a placementGroupId. */\n placementGroupId?: string;\n}\n\n/** The instance view of the VM Agent running on the virtual machine. */\nexport interface VirtualMachineAgentInstanceViewOutput {\n /** The VM Agent full version. */\n vmAgentVersion?: string;\n /** The virtual machine extension handler instance view. */\n extensionHandlers?: Array<VirtualMachineExtensionHandlerInstanceViewOutput>;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** The instance view of a virtual machine extension handler. */\nexport interface VirtualMachineExtensionHandlerInstanceViewOutput {\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** The extension handler status. */\n status?: InstanceViewStatusOutput;\n}\n\n/** Maintenance Operation Status. */\nexport interface MaintenanceRedeployStatusOutput {\n /** True, if customer is allowed to perform Maintenance. */\n isCustomerInitiatedMaintenanceAllowed?: boolean;\n /** Start Time for the Pre Maintenance Window. */\n preMaintenanceWindowStartTime?: string;\n /** End Time for the Pre Maintenance Window. */\n preMaintenanceWindowEndTime?: string;\n /** Start Time for the Maintenance Window. */\n maintenanceWindowStartTime?: string;\n /** End Time for the Maintenance Window. */\n maintenanceWindowEndTime?: string;\n /** The Last Maintenance Operation Result Code. */\n lastOperationResultCode?: \"None\" | \"RetryLater\" | \"MaintenanceAborted\" | \"MaintenanceCompleted\";\n /** Message returned for the last Maintenance Operation. */\n lastOperationMessage?: string;\n}\n\n/** The instance view of the disk. */\nexport interface DiskInstanceViewOutput {\n /** The disk name. */\n name?: string;\n /** Specifies the encryption settings for the OS Disk. <br><br> Minimum api-version: 2015-06-15 */\n encryptionSettings?: Array<DiskEncryptionSettingsOutput>;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** Describes a Encryption Settings for a Disk */\nexport interface DiskEncryptionSettingsOutput {\n /** Specifies the location of the disk encryption key, which is a Key Vault Secret. */\n diskEncryptionKey?: KeyVaultSecretReferenceOutput;\n /** Specifies the location of the key encryption key in Key Vault. */\n keyEncryptionKey?: KeyVaultKeyReferenceOutput;\n /** Specifies whether disk encryption should be enabled on the virtual machine. */\n enabled?: boolean;\n}\n\n/** Describes a reference to Key Vault Key */\nexport interface KeyVaultKeyReferenceOutput {\n /** The URL referencing a key encryption key in Key Vault. */\n keyUrl: string;\n /** The relative URL of the Key Vault containing the key. */\n sourceVault: SubResourceOutput;\n}\n\n/** The health status of the VM. */\nexport interface VirtualMachineHealthStatusOutput {\n /** The health status information for the VM. */\n readonly status?: InstanceViewStatusOutput;\n}\n\n/** The instance view of a virtual machine boot diagnostics. */\nexport interface BootDiagnosticsInstanceViewOutput {\n /** The console screenshot blob URI. <br><br>NOTE: This will **not** be set if boot diagnostics is currently enabled with managed storage. */\n readonly consoleScreenshotBlobUri?: string;\n /** The serial console log blob Uri. <br><br>NOTE: This will **not** be set if boot diagnostics is currently enabled with managed storage. */\n readonly serialConsoleLogBlobUri?: string;\n /** The boot diagnostics status information for the VM. <br><br> NOTE: It will be set only if there are errors encountered in enabling boot diagnostics. */\n readonly status?: InstanceViewStatusOutput;\n}\n\n/** Specifies the hardware settings for the virtual machine. */\nexport interface HardwareProfileOutput {\n /** Specifies the size of the virtual machine. <br><br> The enum data type is currently deprecated and will be removed by December 23rd 2023. <br><br> Recommended way to get the list of available sizes is using these APIs: <br><br> [List all available virtual machine sizes in an availability set](https://docs.microsoft.com/rest/api/compute/availabilitysets/listavailablesizes) <br><br> [List all available virtual machine sizes in a region]( https://docs.microsoft.com/rest/api/compute/resourceskus/list) <br><br> [List all available virtual machine sizes for resizing](https://docs.microsoft.com/rest/api/compute/virtualmachines/listavailablesizes). For more information about virtual machine sizes, see [Sizes for virtual machines](https://docs.microsoft.com/azure/virtual-machines/sizes). <br><br> The available VM sizes depend on region and availability set. */\n vmSize?:\n | \"Basic_A0\"\n | \"Basic_A1\"\n | \"Basic_A2\"\n | \"Basic_A3\"\n | \"Basic_A4\"\n | \"Standard_A0\"\n | \"Standard_A1\"\n | \"Standard_A2\"\n | \"Standard_A3\"\n | \"Standard_A4\"\n | \"Standard_A5\"\n | \"Standard_A6\"\n | \"Standard_A7\"\n | \"Standard_A8\"\n | \"Standard_A9\"\n | \"Standard_A10\"\n | \"Standard_A11\"\n | \"Standard_A1_v2\"\n | \"Standard_A2_v2\"\n | \"Standard_A4_v2\"\n | \"Standard_A8_v2\"\n | \"Standard_A2m_v2\"\n | \"Standard_A4m_v2\"\n | \"Standard_A8m_v2\"\n | \"Standard_B1s\"\n | \"Standard_B1ms\"\n | \"Standard_B2s\"\n | \"Standard_B2ms\"\n | \"Standard_B4ms\"\n | \"Standard_B8ms\"\n | \"Standard_D1\"\n | \"Standard_D2\"\n | \"Standard_D3\"\n | \"Standard_D4\"\n | \"Standard_D11\"\n | \"Standard_D12\"\n | \"Standard_D13\"\n | \"Standard_D14\"\n | \"Standard_D1_v2\"\n | \"Standard_D2_v2\"\n | \"Standard_D3_v2\"\n | \"Standard_D4_v2\"\n | \"Standard_D5_v2\"\n | \"Standard_D2_v3\"\n | \"Standard_D4_v3\"\n | \"Standard_D8_v3\"\n | \"Standard_D16_v3\"\n | \"Standard_D32_v3\"\n | \"Standard_D64_v3\"\n | \"Standard_D2s_v3\"\n | \"Standard_D4s_v3\"\n | \"Standard_D8s_v3\"\n | \"Standard_D16s_v3\"\n | \"Standard_D32s_v3\"\n | \"Standard_D64s_v3\"\n | \"Standard_D11_v2\"\n | \"Standard_D12_v2\"\n | \"Standard_D13_v2\"\n | \"Standard_D14_v2\"\n | \"Standard_D15_v2\"\n | \"Standard_DS1\"\n | \"Standard_DS2\"\n | \"Standard_DS3\"\n | \"Standard_DS4\"\n | \"Standard_DS11\"\n | \"Standard_DS12\"\n | \"Standard_DS13\"\n | \"Standard_DS14\"\n | \"Standard_DS1_v2\"\n | \"Standard_DS2_v2\"\n | \"Standard_DS3_v2\"\n | \"Standard_DS4_v2\"\n | \"Standard_DS5_v2\"\n | \"Standard_DS11_v2\"\n | \"Standard_DS12_v2\"\n | \"Standard_DS13_v2\"\n | \"Standard_DS14_v2\"\n | \"Standard_DS15_v2\"\n | \"Standard_DS13-4_v2\"\n | \"Standard_DS13-2_v2\"\n | \"Standard_DS14-8_v2\"\n | \"Standard_DS14-4_v2\"\n | \"Standard_E2_v3\"\n | \"Standard_E4_v3\"\n | \"Standard_E8_v3\"\n | \"Standard_E16_v3\"\n | \"Standard_E32_v3\"\n | \"Standard_E64_v3\"\n | \"Standard_E2s_v3\"\n | \"Standard_E4s_v3\"\n | \"Standard_E8s_v3\"\n | \"Standard_E16s_v3\"\n | \"Standard_E32s_v3\"\n | \"Standard_E64s_v3\"\n | \"Standard_E32-16_v3\"\n | \"Standard_E32-8s_v3\"\n | \"Standard_E64-32s_v3\"\n | \"Standard_E64-16s_v3\"\n | \"Standard_F1\"\n | \"Standard_F2\"\n | \"Standard_F4\"\n | \"Standard_F8\"\n | \"Standard_F16\"\n | \"Standard_F1s\"\n | \"Standard_F2s\"\n | \"Standard_F4s\"\n | \"Standard_F8s\"\n | \"Standard_F16s\"\n | \"Standard_F2s_v2\"\n | \"Standard_F4s_v2\"\n | \"Standard_F8s_v2\"\n | \"Standard_F16s_v2\"\n | \"Standard_F32s_v2\"\n | \"Standard_F64s_v2\"\n | \"Standard_F72s_v2\"\n | \"Standard_G1\"\n | \"Standard_G2\"\n | \"Standard_G3\"\n | \"Standard_G4\"\n | \"Standard_G5\"\n | \"Standard_GS1\"\n | \"Standard_GS2\"\n | \"Standard_GS3\"\n | \"Standard_GS4\"\n | \"Standard_GS5\"\n | \"Standard_GS4-8\"\n | \"Standard_GS4-4\"\n | \"Standard_GS5-16\"\n | \"Standard_GS5-8\"\n | \"Standard_H8\"\n | \"Standard_H16\"\n | \"Standard_H8m\"\n | \"Standard_H16m\"\n | \"Standard_H16r\"\n | \"Standard_H16mr\"\n | \"Standard_L4s\"\n | \"Standard_L8s\"\n | \"Standard_L16s\"\n | \"Standard_L32s\"\n | \"Standard_M64s\"\n | \"Standard_M64ms\"\n | \"Standard_M128s\"\n | \"Standard_M128ms\"\n | \"Standard_M64-32ms\"\n | \"Standard_M64-16ms\"\n | \"Standard_M128-64ms\"\n | \"Standard_M128-32ms\"\n | \"Standard_NC6\"\n | \"Standard_NC12\"\n | \"Standard_NC24\"\n | \"Standard_NC24r\"\n | \"Standard_NC6s_v2\"\n | \"Standard_NC12s_v2\"\n | \"Standard_NC24s_v2\"\n | \"Standard_NC24rs_v2\"\n | \"Standard_NC6s_v3\"\n | \"Standard_NC12s_v3\"\n | \"Standard_NC24s_v3\"\n | \"Standard_NC24rs_v3\"\n | \"Standard_ND6s\"\n | \"Standard_ND12s\"\n | \"Standard_ND24s\"\n | \"Standard_ND24rs\"\n | \"Standard_NV6\"\n | \"Standard_NV12\"\n | \"Standard_NV24\";\n /** Specifies the properties for customizing the size of the virtual machine. Minimum api-version: 2021-07-01. <br><br> This feature is still in preview mode and is not supported for VirtualMachineScaleSet. <br><br> Please follow the instructions in [VM Customization](https://aka.ms/vmcustomization) for more details. */\n vmSizeProperties?: VMSizePropertiesOutput;\n}\n\n/** Specifies the storage settings for the virtual machine disks. */\nexport interface StorageProfileOutput {\n /** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. */\n imageReference?: ImageReferenceOutput;\n /** Specifies information about the operating system disk used by the virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: OSDiskOutput;\n /** Specifies the parameters that are used to add a data disk to a virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: Array<DataDiskOutput>;\n /** Specifies the disk controller type configured for the VM. <br><br>NOTE: This property will be set to the default disk controller type if not specified provided virtual machine is being created as a hyperVGeneration: V2 based on the capabilities of the operating system disk and VM size from the the specified minimum api version. <br>You need to deallocate the VM before updating its disk controller type unless you are updating the VM size in the VM configuration which implicitly deallocates and reallocates the VM. <br><br> Minimum api-version: 2022-08-01 */\n diskControllerType?: \"SCSI\" | \"NVMe\";\n}\n\n/** Specifies information about the operating system disk used by the virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\nexport interface OSDiskOutput {\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from user-image or a specialized VHD. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType?: \"Windows\" | \"Linux\";\n /** Specifies the encryption settings for the OS Disk. <br><br> Minimum api-version: 2015-06-15 */\n encryptionSettings?: DiskEncryptionSettingsOutput;\n /** The disk name. */\n name?: string;\n /** The virtual hard disk. */\n vhd?: VirtualHardDiskOutput;\n /** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\n image?: VirtualHardDiskOutput;\n /** Specifies the caching requirements. <br><br> Possible values are: <br><br> **None** <br><br> **ReadOnly** <br><br> **ReadWrite** <br><br> Default: **None** for Standard storage. **ReadOnly** for Premium storage. */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies the ephemeral Disk Settings for the operating system disk used by the virtual machine. */\n diffDiskSettings?: DiffDiskSettingsOutput;\n /** Specifies how the virtual machine should be created.<br><br> Possible values are:<br><br> **Attach** \\u2013 This value is used when you are using a specialized disk to create the virtual machine.<br><br> **FromImage** \\u2013 This value is used when you are using an image to create the virtual machine. If you are using a platform image, you also use the imageReference element described above. If you are using a marketplace image, you also use the plan element previously described. */\n createOption: \"FromImage\" | \"Empty\" | \"Attach\";\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. <br><br> diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023 */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: ManagedDiskParametersOutput;\n /** Specifies whether OS Disk should be deleted or detached upon VM deletion. <br><br> Possible values: <br><br> **Delete** If this value is used, the OS disk is deleted when VM is deleted.<br><br> **Detach** If this value is used, the os disk is retained after VM is deleted. <br><br> The default value is set to **detach**. For an ephemeral OS Disk, the default value is set to **Delete**. User cannot change the delete option for ephemeral OS Disk. */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** The parameters of a managed disk. */\nexport interface ManagedDiskParametersOutput extends SubResourceOutput {\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?:\n | \"Standard_LRS\"\n | \"Premium_LRS\"\n | \"StandardSSD_LRS\"\n | \"UltraSSD_LRS\"\n | \"Premium_ZRS\"\n | \"StandardSSD_ZRS\"\n | \"PremiumV2_LRS\";\n /** Specifies the customer managed disk encryption set resource id for the managed disk. */\n diskEncryptionSet?: DiskEncryptionSetParametersOutput;\n /** Specifies the security profile for the managed disk. */\n securityProfile?: VMDiskSecurityProfileOutput;\n}\n\n/** Describes a data disk. */\nexport interface DataDiskOutput {\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n /** The disk name. */\n name?: string;\n /** The virtual hard disk. */\n vhd?: VirtualHardDiskOutput;\n /** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\n image?: VirtualHardDiskOutput;\n /** Specifies the caching requirements. <br><br> Possible values are: <br><br> **None** <br><br> **ReadOnly** <br><br> **ReadWrite** <br><br> Default: **None for Standard storage. ReadOnly for Premium storage** */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies how the virtual machine should be created.<br><br> Possible values are:<br><br> **Attach** \\u2013 This value is used when you are using a specialized disk to create the virtual machine.<br><br> **FromImage** \\u2013 This value is used when you are using an image to create the virtual machine. If you are using a platform image, you also use the imageReference element described above. If you are using a marketplace image, you also use the plan element previously described. */\n createOption: \"FromImage\" | \"Empty\" | \"Attach\";\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. <br><br> diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023 */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: ManagedDiskParametersOutput;\n /** Specifies whether the data disk is in process of detachment from the VirtualMachine/VirtualMachineScaleset */\n toBeDetached?: boolean;\n /** Specifies the Read-Write IOPS for the managed disk when StorageAccountType is UltraSSD_LRS. Returned only for VirtualMachine ScaleSet VM disks. Can be updated only via updates to the VirtualMachine Scale Set. */\n readonly diskIOPSReadWrite?: number;\n /** Specifies the bandwidth in MB per second for the managed disk when StorageAccountType is UltraSSD_LRS. Returned only for VirtualMachine ScaleSet VM disks. Can be updated only via updates to the VirtualMachine Scale Set. */\n readonly diskMBpsReadWrite?: number;\n /** Specifies the detach behavior to be used while detaching a disk or which is already in the process of detachment from the virtual machine. Supported values: **ForceDetach**. <br><br> detachOption: **ForceDetach** is applicable only for managed data disks. If a previous detachment attempt of the data disk did not complete due to an unexpected failure from the virtual machine and the disk is still not released then use force-detach as a last resort option to detach the disk forcibly from the VM. All writes might not have been flushed when using this detach behavior. <br><br> This feature is still in preview mode and is not supported for VirtualMachineScaleSet. To force-detach a data disk update toBeDetached to 'true' along with setting detachOption: 'ForceDetach'. */\n detachOption?: \"ForceDetach\";\n /** Specifies whether data disk should be deleted or detached upon VM deletion.<br><br> Possible values: <br><br> **Delete** If this value is used, the data disk is deleted when VM is deleted.<br><br> **Detach** If this value is used, the data disk is retained after VM is deleted.<br><br> The default value is set to **detach** */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Specifies the operating system settings for the virtual machine. Some of the settings cannot be changed once VM is provisioned. */\nexport interface OSProfileOutput {\n /** Specifies the host OS name of the virtual machine. <br><br> This name cannot be updated after the VM is created. <br><br> **Max-length (Windows):** 15 characters <br><br> **Max-length (Linux):** 64 characters. <br><br> For naming conventions and restrictions see [Azure infrastructure services implementation guidelines](https://docs.microsoft.com/azure/azure-resource-manager/management/resource-name-rules). */\n computerName?: string;\n /** Specifies the name of the administrator account. <br><br> This property cannot be updated after the VM is created. <br><br> **Windows-only restriction:** Cannot end in \".\" <br><br> **Disallowed values:** \"administrator\", \"admin\", \"user\", \"user1\", \"test\", \"user2\", \"test1\", \"user3\", \"admin1\", \"1\", \"123\", \"a\", \"actuser\", \"adm\", \"admin2\", \"aspnet\", \"backup\", \"console\", \"david\", \"guest\", \"john\", \"owner\", \"root\", \"server\", \"sql\", \"support\", \"support_388945a0\", \"sys\", \"test2\", \"test3\", \"user4\", \"user5\". <br><br> **Minimum-length (Linux):** 1 character <br><br> **Max-length (Linux):** 64 characters <br><br> **Max-length (Windows):** 20 characters. */\n adminUsername?: string;\n /** Specifies the password of the administrator account. <br><br> **Minimum-length (Windows):** 8 characters <br><br> **Minimum-length (Linux):** 6 characters <br><br> **Max-length (Windows):** 123 characters <br><br> **Max-length (Linux):** 72 characters <br><br> **Complexity requirements:** 3 out of 4 conditions below need to be fulfilled <br> Has lower characters <br>Has upper characters <br> Has a digit <br> Has a special character (Regex match [\\W_]) <br><br> **Disallowed values:** \"abc@123\", \"P@$$w0rd\", \"P@ssw0rd\", \"P@ssword123\", \"Pa$$word\", \"pass@word1\", \"Password!\", \"Password1\", \"Password22\", \"iloveyou!\" <br><br> For resetting the password, see [How to reset the Remote Desktop service or its login password in a Windows VM](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/reset-rdp) <br><br> For resetting root password, see [Manage users, SSH, and check or repair disks on Azure Linux VMs using the VMAccess Extension](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection) */\n adminPassword?: string;\n /** Specifies a base-64 encoded string of custom data. The base-64 encoded string is decoded to a binary array that is saved as a file on the Virtual Machine. The maximum length of the binary array is 65535 bytes. <br><br> **Note: Do not pass any secrets or passwords in customData property** <br><br> This property cannot be updated after the VM is created. <br><br> customData is passed to the VM to be saved as a file, for more information see [Custom Data on Azure VMs](https://azure.microsoft.com/blog/custom-data-and-cloud-init-on-windows-azure/) <br><br> For using cloud-init for your Linux VM, see [Using cloud-init to customize a Linux VM during creation](https://docs.microsoft.com/azure/virtual-machines/linux/using-cloud-init) */\n customData?: string;\n /** Specifies Windows operating system settings on the virtual machine. */\n windowsConfiguration?: WindowsConfigurationOutput;\n /** Specifies the Linux operating system settings on the virtual machine. <br><br>For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\n linuxConfiguration?: LinuxConfigurationOutput;\n /** Specifies set of certificates that should be installed onto the virtual machine. To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n secrets?: Array<VaultSecretGroupOutput>;\n /** Specifies whether extension operations should be allowed on the virtual machine. <br><br>This may only be set to False when no extensions are present on the virtual machine. */\n allowExtensionOperations?: boolean;\n /** Optional property which must either be set to True or omitted. */\n requireGuestProvisionSignal?: boolean;\n}\n\n/** Specifies the network interfaces or the networking configuration of the virtual machine. */\nexport interface NetworkProfileOutput {\n /** Specifies the list of resource Ids for the network interfaces associated with the virtual machine. */\n networkInterfaces?: Array<NetworkInterfaceReferenceOutput>;\n /** specifies the Microsoft.Network API version used when creating networking resources in the Network Interface Configurations */\n networkApiVersion?: \"2020-11-01\";\n /** Specifies the networking configurations that will be used to create the virtual machine networking resources. */\n networkInterfaceConfigurations?: Array<VirtualMachineNetworkInterfaceConfigurationOutput>;\n}\n\n/** Describes a network interface reference. */\nexport interface NetworkInterfaceReferenceOutput extends SubResourceOutput {\n /** Describes a network interface reference properties. */\n properties?: NetworkInterfaceReferencePropertiesOutput;\n}\n\n/** Describes a network interface reference properties. */\nexport interface NetworkInterfaceReferencePropertiesOutput {\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes a virtual machine network interface configurations. */\nexport interface VirtualMachineNetworkInterfaceConfigurationOutput {\n /** The network interface configuration name. */\n name: string;\n /** Describes a virtual machine network profile's IP configuration. */\n properties?: VirtualMachineNetworkInterfaceConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine network profile's IP configuration. */\nexport interface VirtualMachineNetworkInterfaceConfigurationPropertiesOutput {\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResourceOutput;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineNetworkInterfaceDnsSettingsConfigurationOutput;\n /** Specifies the IP configurations of the network interface. */\n ipConfigurations: Array<VirtualMachineNetworkInterfaceIPConfigurationOutput>;\n dscpConfiguration?: SubResourceOutput;\n}\n\n/** Describes a virtual machines network configuration's DNS settings. */\nexport interface VirtualMachineNetworkInterfaceDnsSettingsConfigurationOutput {\n /** List of DNS servers IP addresses */\n dnsServers?: Array<string>;\n}\n\n/** Describes a virtual machine network profile's IP configuration. */\nexport interface VirtualMachineNetworkInterfaceIPConfigurationOutput {\n /** The IP configuration name. */\n name: string;\n /** Describes a virtual machine network interface IP configuration properties. */\n properties?: VirtualMachineNetworkInterfaceIPConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine network interface IP configuration properties. */\nexport interface VirtualMachineNetworkInterfaceIPConfigurationPropertiesOutput {\n /** Specifies the identifier of the subnet. */\n subnet?: SubResourceOutput;\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachinePublicIPAddressConfigurationOutput;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: \"IPv4\" | \"IPv6\";\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: Array<SubResourceOutput>;\n /** Specifies an array of references to backend address pools of application gateways. A virtual machine can reference backend address pools of multiple application gateways. Multiple virtual machines cannot use the same application gateway. */\n applicationGatewayBackendAddressPools?: Array<SubResourceOutput>;\n /** Specifies an array of references to backend address pools of load balancers. A virtual machine can reference backend address pools of one public and one internal load balancer. [Multiple virtual machines cannot use the same basic sku load balancer]. */\n loadBalancerBackendAddressPools?: Array<SubResourceOutput>;\n}\n\n/** Describes a virtual machines IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachinePublicIPAddressConfigurationOutput {\n /** The publicIP address configuration name. */\n name: string;\n /** Describes a virtual machines IP Configuration's PublicIPAddress configuration */\n properties?: VirtualMachinePublicIPAddressConfigurationPropertiesOutput;\n /** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\n sku?: PublicIPAddressSkuOutput;\n}\n\n/** Describes a virtual machines IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachinePublicIPAddressConfigurationPropertiesOutput {\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** Specify what happens to the public IP address when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachinePublicIPAddressDnsSettingsConfigurationOutput;\n /** The list of IP tags associated with the public IP address. */\n ipTags?: Array<VirtualMachineIpTagOutput>;\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResourceOutput;\n /** Available from Api-Version 2019-07-01 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n publicIPAddressVersion?: \"IPv4\" | \"IPv6\";\n /** Specify the public IP allocation type */\n publicIPAllocationMethod?: \"Dynamic\" | \"Static\";\n}\n\n/** Describes a virtual machines network configuration's DNS settings. */\nexport interface VirtualMachinePublicIPAddressDnsSettingsConfigurationOutput {\n /** The Domain name label prefix of the PublicIPAddress resources that will be created. The generated name label is the concatenation of the domain name label and vm network profile unique ID. */\n domainNameLabel: string;\n}\n\n/** Contains the IP tag associated with the public IP address. */\nexport interface VirtualMachineIpTagOutput {\n /** IP tag type. Example: FirstPartyUsage. */\n ipTagType?: string;\n /** IP tag associated with the public IP. Example: SQL, Storage etc. */\n tag?: string;\n}\n\n/** Describes a virtual machine scale set VM network profile. */\nexport interface VirtualMachineScaleSetVMNetworkProfileConfigurationOutput {\n /** The list of network configurations. */\n networkInterfaceConfigurations?: Array<VirtualMachineScaleSetNetworkConfigurationOutput>;\n}\n\n/** The protection policy of a virtual machine scale set VM. */\nexport interface VirtualMachineScaleSetVMProtectionPolicyOutput {\n /** Indicates that the virtual machine scale set VM shouldn't be considered for deletion during a scale-in operation. */\n protectFromScaleIn?: boolean;\n /** Indicates that model updates or actions (including scale-in) initiated on the virtual machine scale set should not be applied to the virtual machine scale set VM. */\n protectFromScaleSetActions?: boolean;\n}\n\n/** Describes a Virtual Machine Extension. */\nexport interface VirtualMachineExtensionOutput extends ResourceWithOptionalLocationOutput {\n /** Describes the properties of a Virtual Machine Extension. */\n properties?: VirtualMachineExtensionPropertiesOutput;\n}\n\n/** The Resource model definition with location property as optional. */\nexport interface ResourceWithOptionalLocationOutput {\n /** Resource location */\n location?: string;\n /** Resource Id */\n readonly id?: string;\n /** Resource name */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Resource tags */\n tags?: Record<string, string>;\n}\n\n/** Identity for the virtual machine. */\nexport interface VirtualMachineIdentityOutput {\n /** The principal id of virtual machine identity. This property will only be provided for a system assigned identity. */\n readonly principalId?: string;\n /** The tenant id associated with the virtual machine. This property will only be provided for a system assigned identity. */\n readonly tenantId?: string;\n /** The type of identity used for the virtual machine. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user assigned identities. The type 'None' will remove any identities from the virtual machine. */\n type?: \"SystemAssigned\" | \"UserAssigned\" | \"SystemAssigned, UserAssigned\" | \"None\";\n /** The list of user identities associated with the Virtual Machine. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: Record<string, UserAssignedIdentitiesValueOutput>;\n}\n\n/** The List Virtual Machine Scale Set VMs operation response. */\nexport interface VirtualMachineScaleSetVMListResultOutput {\n /** The list of virtual machine scale sets VMs. */\n value: Array<VirtualMachineScaleSetVMOutput>;\n /** The uri to fetch the next page of Virtual Machine Scale Set VMs. Call ListNext() with this to fetch the next page of VMSS VMs */\n nextLink?: string;\n}\n\n/** The SAS URIs of the console screenshot and serial log blobs. */\nexport interface RetrieveBootDiagnosticsDataResultOutput {\n /** The console screenshot blob URI */\n readonly consoleScreenshotBlobUri?: string;\n /** The serial console log blob URI. */\n readonly serialConsoleLogBlobUri?: string;\n}\n\n/** The List Extension operation response */\nexport interface VirtualMachineExtensionsListResultOutput {\n /** The list of extensions */\n value?: Array<VirtualMachineExtensionOutput>;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineListResultOutput {\n /** The list of virtual machines. */\n value: Array<VirtualMachineOutput>;\n /** The URI to fetch the next page of VMs. Call ListNext() with this URI to fetch the next page of Virtual Machines. */\n nextLink?: string;\n}\n\n/** Describes a Virtual Machine. */\nexport interface VirtualMachineOutput extends ResourceOutput {\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: PlanOutput;\n /** Describes the properties of a Virtual Machine. */\n properties?: VirtualMachinePropertiesOutput;\n /** The virtual machine child extension resources. */\n readonly resources?: Array<VirtualMachineExtensionOutput>;\n /** The identity of the virtual machine, if configured. */\n identity?: VirtualMachineIdentityOutput;\n /** The virtual machine zones. */\n zones?: Array<string>;\n /** The extended location of the Virtual Machine. */\n extendedLocation?: ExtendedLocationOutput;\n}\n\n/** Describes the properties of a Virtual Machine. */\nexport interface VirtualMachinePropertiesOutput {\n /** Specifies the hardware settings for the virtual machine. */\n hardwareProfile?: HardwareProfileOutput;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: StorageProfileOutput;\n /** Specifies additional capabilities enabled or disabled on the virtual machine. */\n additionalCapabilities?: AdditionalCapabilitiesOutput;\n /** Specifies the operating system settings used while creating the virtual machine. Some of the settings cannot be changed once VM is provisioned. */\n osProfile?: OSProfileOutput;\n /** Specifies the network interfaces of the virtual machine. */\n networkProfile?: NetworkProfileOutput;\n /** Specifies the Security related profile settings for the virtual machine. */\n securityProfile?: SecurityProfileOutput;\n /** Specifies the boot diagnostic settings state. <br><br>Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfileOutput;\n /** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). <br><br> For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates) <br><br> Currently, a VM can only be added to availability set at creation time. The availability set to which the VM is being added should be under the same resource group as the availability set resource. An existing VM cannot be added to an availability set. <br><br>This property cannot exist along with a non-null properties.virtualMachineScaleSet reference. */\n availabilitySet?: SubResourceOutput;\n /** Specifies information about the virtual machine scale set that the virtual machine should be assigned to. Virtual machines specified in the same virtual machine scale set are allocated to different nodes to maximize availability. Currently, a VM can only be added to virtual machine scale set at creation time. An existing VM cannot be added to a virtual machine scale set. <br><br>This property cannot exist along with a non-null properties.availabilitySet reference. <br><br>Minimum api‐version: 2019‐03‐01 */\n virtualMachineScaleSet?: SubResourceOutput;\n /** Specifies information about the proximity placement group that the virtual machine should be assigned to. <br><br>Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResourceOutput;\n /** Specifies the priority for the virtual machine. <br><br>Minimum api-version: 2019-03-01 */\n priority?: \"Regular\" | \"Low\" | \"Spot\";\n /** Specifies the eviction policy for the Azure Spot virtual machine and Azure Spot scale set. <br><br>For Azure Spot virtual machines, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2019-03-01. <br><br>For Azure Spot scale sets, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2017-10-30-preview. */\n evictionPolicy?: \"Deallocate\" | \"Delete\";\n /** Specifies the billing related details of a Azure Spot virtual machine. <br><br>Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfileOutput;\n /** Specifies information about the dedicated host that the virtual machine resides in. <br><br>Minimum api-version: 2018-10-01. */\n host?: SubResourceOutput;\n /** Specifies information about the dedicated host group that the virtual machine resides in. <br><br>Minimum api-version: 2020-06-01. <br><br>NOTE: User cannot specify both host and hostGroup properties. */\n hostGroup?: SubResourceOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The virtual machine instance view. */\n readonly instanceView?: VirtualMachineInstanceViewOutput;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /** Specifies the VM unique ID which is a 128-bits identifier that is encoded and stored in all Azure IaaS VMs SMBIOS and can be read using platform BIOS commands. */\n readonly vmId?: string;\n /** Specifies the time alloted for all extensions to start. The time duration should be between 15 minutes and 120 minutes (inclusive) and should be specified in ISO 8601 format. The default value is 90 minutes (PT1H30M). <br><br> Minimum api-version: 2020-06-01 */\n extensionsTimeBudget?: string;\n /** Specifies the scale set logical fault domain into which the Virtual Machine will be created. By default, the Virtual Machine will by automatically assigned to a fault domain that best maintains balance across available fault domains.<br><li>This is applicable only if the 'virtualMachineScaleSet' property of this Virtual Machine is set.<li>The Virtual Machine Scale Set that is referenced, must have 'platformFaultDomainCount' > 1.<li>This property cannot be updated once the Virtual Machine is created.<li>Fault domain assignment can be viewed in the Virtual Machine Instance View.<br><br>Minimum api‐version: 2020‐12‐01 */\n platformFaultDomain?: number;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfileOutput;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. <br><br>Minimum api-version: 2021-03-01 */\n userData?: string;\n /** Specifies information about the capacity reservation that is used to allocate virtual machine. <br><br>Minimum api-version: 2021-04-01. */\n capacityReservation?: CapacityReservationProfileOutput;\n /** Specifies the gallery applications that should be made available to the VM/VMSS */\n applicationProfile?: ApplicationProfileOutput;\n /** Specifies the time at which the Virtual Machine resource was created.<br><br>Minimum api-version: 2021-11-01. */\n readonly timeCreated?: string;\n}\n\n/** The instance view of a virtual machine. */\nexport interface VirtualMachineInstanceViewOutput {\n /** Specifies the update domain of the virtual machine. */\n platformUpdateDomain?: number;\n /** Specifies the fault domain of the virtual machine. */\n platformFaultDomain?: number;\n /** The computer name assigned to the virtual machine. */\n computerName?: string;\n /** The Operating System running on the virtual machine. */\n osName?: string;\n /** The version of Operating System running on the virtual machine. */\n osVersion?: string;\n /** Specifies the HyperVGeneration Type associated with a resource */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** The Remote desktop certificate thumbprint. */\n rdpThumbPrint?: string;\n /** The VM Agent running on the virtual machine. */\n vmAgent?: VirtualMachineAgentInstanceViewOutput;\n /** The Maintenance Operation status on the virtual machine. */\n maintenanceRedeployStatus?: MaintenanceRedeployStatusOutput;\n /** The virtual machine disk information. */\n disks?: Array<DiskInstanceViewOutput>;\n /** The extensions information. */\n extensions?: Array<VirtualMachineExtensionInstanceViewOutput>;\n /** The health status for the VM. */\n readonly vmHealth?: VirtualMachineHealthStatusOutput;\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. <br><br> You can easily view the output of your console log. <br><br> Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnosticsInstanceViewOutput;\n /** Resource id of the dedicated host, on which the virtual machine is allocated through automatic placement, when the virtual machine is associated with a dedicated host group that has automatic placement enabled. <br><br>Minimum api-version: 2020-06-01. */\n readonly assignedHost?: string;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n /** [Preview Feature] The status of virtual machine patch operations. */\n patchStatus?: VirtualMachinePatchStatusOutput;\n}\n\n/** The status of virtual machine patch operations. */\nexport interface VirtualMachinePatchStatusOutput {\n /** The available patch summary of the latest assessment operation for the virtual machine. */\n availablePatchSummary?: AvailablePatchSummaryOutput;\n /** The installation summary of the latest installation operation for the virtual machine. */\n lastPatchInstallationSummary?: LastPatchInstallationSummaryOutput;\n /** The enablement status of the specified patchMode */\n readonly configurationStatuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** Describes the properties of an virtual machine instance view for available patch summary. */\nexport interface AvailablePatchSummaryOutput {\n /** The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\" */\n readonly status?: \"Unknown\" | \"InProgress\" | \"Failed\" | \"Succeeded\" | \"CompletedWithWarnings\";\n /** The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs. */\n readonly assessmentActivityId?: string;\n /** The overall reboot status of the VM. It will be true when partially installed patches require a reboot to complete installation but the reboot has not yet occurred. */\n readonly rebootPending?: boolean;\n /** The number of critical or security patches that have been detected as available and not yet installed. */\n readonly criticalAndSecurityPatchCount?: number;\n /** The number of all available patches excluding critical and security. */\n readonly otherPatchCount?: number;\n /** The UTC timestamp when the operation began. */\n readonly startTime?: string;\n /** The UTC timestamp when the operation began. */\n readonly lastModifiedTime?: string;\n /** The errors that were encountered during execution of the operation. The details array contains the list of them. */\n readonly error?: ApiErrorOutput;\n}\n\n/** Describes the properties of the last installed patch summary. */\nexport interface LastPatchInstallationSummaryOutput {\n /** The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\" */\n readonly status?: \"Unknown\" | \"InProgress\" | \"Failed\" | \"Succeeded\" | \"CompletedWithWarnings\";\n /** The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs. */\n readonly installationActivityId?: string;\n /** Describes whether the operation ran out of time before it completed all its intended actions */\n readonly maintenanceWindowExceeded?: boolean;\n /** The number of all available patches but not going to be installed because it didn't match a classification or inclusion list entry. */\n readonly notSelectedPatchCount?: number;\n /** The number of all available patches but excluded explicitly by a customer-specified exclusion list match. */\n readonly excludedPatchCount?: number;\n /** The number of all available patches expected to be installed over the course of the patch installation operation. */\n readonly pendingPatchCount?: number;\n /** The count of patches that successfully installed. */\n readonly installedPatchCount?: number;\n /** The count of patches that failed installation. */\n readonly failedPatchCount?: number;\n /** The UTC timestamp when the operation began. */\n readonly startTime?: string;\n /** The UTC timestamp when the operation began. */\n readonly lastModifiedTime?: string;\n /** The errors that were encountered during execution of the operation. The details array contains the list of them. */\n readonly error?: ApiErrorOutput;\n}\n\n/** Output of virtual machine capture operation. */\nexport interface VirtualMachineCaptureResultOutput extends SubResourceOutput {\n /** the schema of the captured virtual machine */\n readonly $schema?: string;\n /** the version of the content */\n readonly contentVersion?: string;\n /** parameters of the captured virtual machine */\n readonly parameters?: any;\n /** a list of resource items of the captured virtual machine */\n readonly resources?: Array<any>;\n}\n\n/** Describes the properties of an AssessPatches result. */\nexport interface VirtualMachineAssessPatchesResultOutput {\n /** The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\" */\n readonly status?: \"Unknown\" | \"InProgress\" | \"Failed\" | \"Succeeded\" | \"CompletedWithWarnings\";\n /** The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs. */\n readonly assessmentActivityId?: string;\n /** The overall reboot status of the VM. It will be true when partially installed patches require a reboot to complete installation but the reboot has not yet occurred. */\n readonly rebootPending?: boolean;\n /** The number of critical or security patches that have been detected as available and not yet installed. */\n readonly criticalAndSecurityPatchCount?: number;\n /** The number of all available patches excluding critical and security. */\n readonly otherPatchCount?: number;\n /** The UTC timestamp when the operation began. */\n readonly startDateTime?: string;\n /** The list of patches that have been detected as available for installation. */\n readonly availablePatches?: Array<VirtualMachineSoftwarePatchPropertiesOutput>;\n /** The errors that were encountered during execution of the operation. The details array contains the list of them. */\n readonly error?: ApiErrorOutput;\n}\n\n/** Describes the properties of a Virtual Machine software patch. */\nexport interface VirtualMachineSoftwarePatchPropertiesOutput {\n /** A unique identifier for the patch. */\n readonly patchId?: string;\n /** The friendly name of the patch. */\n readonly name?: string;\n /** The version number of the patch. This property applies only to Linux patches. */\n readonly version?: string;\n /** The KBID of the patch. Only applies to Windows patches. */\n readonly kbId?: string;\n /** The classification(s) of the patch as provided by the patch publisher. */\n readonly classifications?: Array<string>;\n /** Describes the reboot requirements of the patch. */\n readonly rebootBehavior?:\n | \"Unknown\"\n | \"NeverReboots\"\n | \"AlwaysRequiresReboot\"\n | \"CanRequestReboot\";\n /** The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs. */\n readonly activityId?: string;\n /** The UTC timestamp when the repository published this patch. */\n readonly publishedDate?: string;\n /** The UTC timestamp of the last update to this patch record. */\n readonly lastModifiedDateTime?: string;\n /** Describes the availability of a given patch. */\n readonly assessmentState?: \"Unknown\" | \"Available\";\n}\n\n/** The result summary of an installation operation. */\nexport interface VirtualMachineInstallPatchesResultOutput {\n /** The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Failed\", \"Succeeded\", \"Unknown\" or \"CompletedWithWarnings.\" */\n readonly status?: \"Unknown\" | \"InProgress\" | \"Failed\" | \"Succeeded\" | \"CompletedWithWarnings\";\n /** The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs. */\n readonly installationActivityId?: string;\n /** The reboot state of the VM following completion of the operation. */\n readonly rebootStatus?: \"Unknown\" | \"NotNeeded\" | \"Required\" | \"Started\" | \"Failed\" | \"Completed\";\n /** Whether the operation ran out of time before it completed all its intended actions. */\n readonly maintenanceWindowExceeded?: boolean;\n /** The number of patches that were not installed due to the user blocking their installation. */\n readonly excludedPatchCount?: number;\n /** The number of patches that were detected as available for install, but did not meet the operation's criteria. */\n readonly notSelectedPatchCount?: number;\n /** The number of patches that were identified as meeting the installation criteria, but were not able to be installed. Typically this happens when maintenanceWindowExceeded == true. */\n readonly pendingPatchCount?: number;\n /** The number of patches successfully installed. */\n readonly installedPatchCount?: number;\n /** The number of patches that could not be installed due to some issue. See errors for details. */\n readonly failedPatchCount?: number;\n /** The patches that were installed during the operation. */\n readonly patches?: Array<PatchInstallationDetailOutput>;\n /** The UTC timestamp when the operation began. */\n readonly startDateTime?: string;\n /** The errors that were encountered during execution of the operation. The details array contains the list of them. */\n readonly error?: ApiErrorOutput;\n}\n\n/** Information about a specific patch that was encountered during an installation action. */\nexport interface PatchInstallationDetailOutput {\n /** A unique identifier for the patch. */\n readonly patchId?: string;\n /** The friendly name of the patch. */\n readonly name?: string;\n /** The version string of the package. It may conform to Semantic Versioning. Only applies to Linux. */\n readonly version?: string;\n /** The KBID of the patch. Only applies to Windows patches. */\n readonly kbId?: string;\n /** The classification(s) of the patch as provided by the patch publisher. */\n readonly classifications?: Array<string>;\n /** The state of the patch after the installation operation completed. */\n readonly installationState?:\n | \"Unknown\"\n | \"Installed\"\n | \"Failed\"\n | \"Excluded\"\n | \"NotSelected\"\n | \"Pending\";\n}\n\n/** Describes a Virtual Machine Image. */\nexport interface VirtualMachineImageOutput extends VirtualMachineImageResourceOutput {\n /** Describes the properties of a Virtual Machine Image. */\n properties?: VirtualMachineImagePropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine Image. */\nexport interface VirtualMachineImagePropertiesOutput {\n /** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\n plan?: PurchasePlanOutput;\n /** Contains the os disk image information. */\n osDiskImage?: OSDiskImageOutput;\n dataDiskImages?: Array<DataDiskImageOutput>;\n /** Describes automatic OS upgrade properties on the image. */\n automaticOSUpgradeProperties?: AutomaticOSUpgradePropertiesOutput;\n /** Specifies the HyperVGeneration Type */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** Specifies disallowed configuration for the VirtualMachine created from the image */\n disallowed?: DisallowedConfigurationOutput;\n features?: Array<VirtualMachineImageFeatureOutput>;\n /** Specifies the Architecture Type */\n architecture?: \"x64\" | \"Arm64\";\n}\n\n/** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\nexport interface PurchasePlanOutput {\n /** The publisher ID. */\n publisher: string;\n /** The plan ID. */\n name: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product: string;\n}\n\n/** Contains the os disk image information. */\nexport interface OSDiskImageOutput {\n /** The operating system of the osDiskImage. */\n operatingSystem: \"Windows\" | \"Linux\";\n}\n\n/** Contains the data disk images information. */\nexport interface DataDiskImageOutput {\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n readonly lun?: number;\n}\n\n/** Describes automatic OS upgrade properties on the image. */\nexport interface AutomaticOSUpgradePropertiesOutput {\n /** Specifies whether automatic OS upgrade is supported on the image. */\n automaticOSUpgradeSupported: boolean;\n}\n\n/** Specifies the disallowed configuration for a virtual machine image. */\nexport interface DisallowedConfigurationOutput {\n /** VM disk types which are disallowed. */\n vmDiskType?: \"None\" | \"Unmanaged\";\n}\n\n/** Specifies additional capabilities supported by the image */\nexport interface VirtualMachineImageFeatureOutput {\n /** The name of the feature. */\n name?: string;\n /** The corresponding value for the feature. */\n value?: string;\n}\n\n/** Virtual machine image resource information. */\nexport interface VirtualMachineImageResourceOutput extends SubResourceOutput {\n /** The name of the resource. */\n name: string;\n /** The supported Azure location of the resource. */\n location: string;\n /** Specifies the tags that are assigned to the virtual machine. For more information about using tags, see [Using tags to organize your Azure resources](https://docs.microsoft.com/azure/azure-resource-manager/resource-group-using-tags.md). */\n tags?: Record<string, string>;\n /** The extended location of the Virtual Machine. */\n extendedLocation?: ExtendedLocationOutput;\n}\n\n/** The List VmImages in EdgeZone operation response. */\nexport interface VmImagesInEdgeZoneListResultOutput {\n /** The list of VMImages in EdgeZone */\n value?: Array<VirtualMachineImageResourceOutput>;\n /** The URI to fetch the next page of VMImages in EdgeZone. Call ListNext() with this URI to fetch the next page of VmImages. */\n nextLink?: string;\n}\n\n/** Describes a Virtual Machine Extension Image. */\nexport interface VirtualMachineExtensionImageOutput extends ResourceOutput {\n /** Describes the properties of a Virtual Machine Extension Image. */\n properties?: VirtualMachineExtensionImagePropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine Extension Image. */\nexport interface VirtualMachineExtensionImagePropertiesOutput {\n /** The operating system this extension supports. */\n operatingSystem: string;\n /** The type of role (IaaS or PaaS) this extension supports. */\n computeRole: string;\n /** The schema defined by publisher, where extension consumers should provide settings in a matching schema. */\n handlerSchema: string;\n /** Whether the extension can be used on xRP VMScaleSets. By default existing extensions are usable on scalesets, but there might be cases where a publisher wants to explicitly indicate the extension is only enabled for CRP VMs but not VMSS. */\n vmScaleSetEnabled?: boolean;\n /** Whether the handler can support multiple extensions. */\n supportsMultipleExtensions?: boolean;\n}\n\n/** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). <br><br> For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates) <br><br> Currently, a VM can only be added to availability set at creation time. An existing VM cannot be added to an availability set. */\nexport interface AvailabilitySetOutput extends ResourceOutput {\n /** The instance view of a resource. */\n properties?: AvailabilitySetPropertiesOutput;\n /** Sku of the availability set, only name is required to be set. See AvailabilitySetSkuTypes for possible set of values. Use 'Aligned' for virtual machines with managed disks and 'Classic' for virtual machines with unmanaged disks. Default value is 'Classic'. */\n sku?: SkuOutput;\n}\n\n/** The instance view of a resource. */\nexport interface AvailabilitySetPropertiesOutput {\n /** Update Domain count. */\n platformUpdateDomainCount?: number;\n /** Fault Domain count. */\n platformFaultDomainCount?: number;\n /** A list of references to all virtual machines in the availability set. */\n virtualMachines?: Array<SubResourceOutput>;\n /** Specifies information about the proximity placement group that the availability set should be assigned to. <br><br>Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResourceOutput;\n /** The resource status information. */\n readonly statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** The List Availability Set operation response. */\nexport interface AvailabilitySetListResultOutput {\n /** The list of availability sets */\n value: Array<AvailabilitySetOutput>;\n /** The URI to fetch the next page of AvailabilitySets. Call ListNext() with this URI to fetch the next page of AvailabilitySets. */\n nextLink?: string;\n}\n\n/** Specifies information about the proximity placement group. */\nexport interface ProximityPlacementGroupOutput extends ResourceOutput {\n /** Describes the properties of a Proximity Placement Group. */\n properties?: ProximityPlacementGroupPropertiesOutput;\n /** Specifies the Availability Zone where virtual machine, virtual machine scale set or availability set associated with the proximity placement group can be created. */\n zones?: Array<string>;\n}\n\n/** Describes the properties of a Proximity Placement Group. */\nexport interface ProximityPlacementGroupPropertiesOutput {\n /** Specifies the type of the proximity placement group. <br><br> Possible values are: <br><br> **Standard** : Co-locate resources within an Azure region or Availability Zone. <br><br> **Ultra** : For future use. */\n proximityPlacementGroupType?: \"Standard\" | \"Ultra\";\n /** A list of references to all virtual machines in the proximity placement group. */\n readonly virtualMachines?: Array<SubResourceWithColocationStatusOutput>;\n /** A list of references to all virtual machine scale sets in the proximity placement group. */\n readonly virtualMachineScaleSets?: Array<SubResourceWithColocationStatusOutput>;\n /** A list of references to all availability sets in the proximity placement group. */\n readonly availabilitySets?: Array<SubResourceWithColocationStatusOutput>;\n /** Describes colocation status of the Proximity Placement Group. */\n colocationStatus?: InstanceViewStatusOutput;\n /** Specifies the user intent of the proximity placement group. */\n intent?: ProximityPlacementGroupPropertiesIntentOutput;\n}\n\nexport interface SubResourceWithColocationStatusOutput extends SubResourceOutput {\n /** Describes colocation status of a resource in the Proximity Placement Group. */\n colocationStatus?: InstanceViewStatusOutput;\n}\n\n/** Specifies the user intent of the proximity placement group. */\nexport interface ProximityPlacementGroupPropertiesIntentOutput {\n /** Specifies possible sizes of virtual machines that can be created in the proximity placement group. */\n vmSizes?: Array<string>;\n}\n\n/** The List Proximity Placement Group operation response. */\nexport interface ProximityPlacementGroupListResultOutput {\n /** The list of proximity placement groups */\n value: Array<ProximityPlacementGroupOutput>;\n /** The URI to fetch the next page of proximity placement groups. */\n nextLink?: string;\n}\n\n/** Specifies information about the dedicated host group that the dedicated hosts should be assigned to. <br><br> Currently, a dedicated host can only be added to a dedicated host group at creation time. An existing dedicated host cannot be added to another dedicated host group. */\nexport interface DedicatedHostGroupOutput extends ResourceOutput {\n /** Dedicated Host Group Properties. */\n properties?: DedicatedHostGroupPropertiesOutput;\n /** Availability Zone to use for this host group. Only single zone is supported. The zone can be assigned only during creation. If not provided, the group supports all zones in the region. If provided, enforces each host in the group to be in the same zone. */\n zones?: Array<string>;\n}\n\n/** Dedicated Host Group Properties. */\nexport interface DedicatedHostGroupPropertiesOutput {\n /** Number of fault domains that the host group can span. */\n platformFaultDomainCount: number;\n /** A list of references to all dedicated hosts in the dedicated host group. */\n readonly hosts?: Array<SubResourceReadOnlyOutput>;\n /** The dedicated host group instance view, which has the list of instance view of the dedicated hosts under the dedicated host group. */\n readonly instanceView?: DedicatedHostGroupInstanceViewOutput;\n /** Specifies whether virtual machines or virtual machine scale sets can be placed automatically on the dedicated host group. Automatic placement means resources are allocated on dedicated hosts, that are chosen by Azure, under the dedicated host group. The value is defaulted to 'false' when not provided. <br><br>Minimum api-version: 2020-06-01. */\n supportAutomaticPlacement?: boolean;\n /** Enables or disables a capability on the dedicated host group.<br><br>Minimum api-version: 2022-03-01. */\n additionalCapabilities?: DedicatedHostGroupPropertiesAdditionalCapabilitiesOutput;\n}\n\nexport interface DedicatedHostGroupInstanceViewOutput {\n /** List of instance view of the dedicated hosts under the dedicated host group. */\n hosts?: Array<DedicatedHostInstanceViewWithNameOutput>;\n}\n\n/** The instance view of a dedicated host that includes the name of the dedicated host. It is used for the response to the instance view of a dedicated host group. */\nexport interface DedicatedHostInstanceViewWithNameOutput extends DedicatedHostInstanceViewOutput {\n /** The name of the dedicated host. */\n readonly name?: string;\n}\n\n/** The instance view of a dedicated host. */\nexport interface DedicatedHostInstanceViewOutput {\n /** Specifies the unique id of the dedicated physical machine on which the dedicated host resides. */\n readonly assetId?: string;\n /** Unutilized capacity of the dedicated host. */\n availableCapacity?: DedicatedHostAvailableCapacityOutput;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** Dedicated host unutilized capacity. */\nexport interface DedicatedHostAvailableCapacityOutput {\n /** The unutilized capacity of the dedicated host represented in terms of each VM size that is allowed to be deployed to the dedicated host. */\n allocatableVMs?: Array<DedicatedHostAllocatableVMOutput>;\n}\n\n/** Represents the dedicated host unutilized capacity in terms of a specific VM size. */\nexport interface DedicatedHostAllocatableVMOutput {\n /** VM size in terms of which the unutilized capacity is represented. */\n vmSize?: string;\n /** Maximum number of VMs of size vmSize that can fit in the dedicated host's remaining capacity. */\n count?: number;\n}\n\n/** Enables or disables a capability on the dedicated host group.<br><br>Minimum api-version: 2022-03-01. */\nexport interface DedicatedHostGroupPropertiesAdditionalCapabilitiesOutput {\n /** The flag that enables or disables a capability to have UltraSSD Enabled Virtual Machines on Dedicated Hosts of the Dedicated Host Group. For the Virtual Machines to be UltraSSD Enabled, UltraSSDEnabled flag for the resource needs to be set true as well. The value is defaulted to 'false' when not provided. Please refer to https://docs.microsoft.com/en-us/azure/virtual-machines/disks-enable-ultra-ssd for more details on Ultra SSD feature. <br><br>NOTE: The ultraSSDEnabled setting can only be enabled for Host Groups that are created as zonal. <br><br>Minimum api-version: 2022-03-01. */\n ultraSSDEnabled?: boolean;\n}\n\n/** The List Dedicated Host Group with resource group response. */\nexport interface DedicatedHostGroupListResultOutput {\n /** The list of dedicated host groups */\n value: Array<DedicatedHostGroupOutput>;\n /** The URI to fetch the next page of Dedicated Host Groups. Call ListNext() with this URI to fetch the next page of Dedicated Host Groups. */\n nextLink?: string;\n}\n\n/** Specifies information about the Dedicated host. */\nexport interface DedicatedHostOutput extends ResourceOutput {\n /** Properties of the dedicated host. */\n properties?: DedicatedHostPropertiesOutput;\n /** SKU of the dedicated host for Hardware Generation and VM family. Only name is required to be set. List Microsoft.Compute SKUs for a list of possible values. */\n sku: SkuOutput;\n}\n\n/** Properties of the dedicated host. */\nexport interface DedicatedHostPropertiesOutput {\n /** Fault domain of the dedicated host within a dedicated host group. */\n platformFaultDomain?: number;\n /** Specifies whether the dedicated host should be replaced automatically in case of a failure. The value is defaulted to 'true' when not provided. */\n autoReplaceOnFailure?: boolean;\n /** A unique id generated and assigned to the dedicated host by the platform. <br><br> Does not change throughout the lifetime of the host. */\n readonly hostId?: string;\n /** A list of references to all virtual machines in the Dedicated Host. */\n readonly virtualMachines?: Array<SubResourceReadOnlyOutput>;\n /** Specifies the software license type that will be applied to the VMs deployed on the dedicated host. <br><br> Possible values are: <br><br> **None** <br><br> **Windows_Server_Hybrid** <br><br> **Windows_Server_Perpetual** <br><br> Default: **None** */\n licenseType?: \"None\" | \"Windows_Server_Hybrid\" | \"Windows_Server_Perpetual\";\n /** The date when the host was first provisioned. */\n readonly provisioningTime?: string;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The dedicated host instance view. */\n readonly instanceView?: DedicatedHostInstanceViewOutput;\n /** Specifies the time at which the Dedicated Host resource was created.<br><br>Minimum api-version: 2021-11-01. */\n readonly timeCreated?: string;\n}\n\n/** The list dedicated host operation response. */\nexport interface DedicatedHostListResultOutput {\n /** The list of dedicated hosts */\n value: Array<DedicatedHostOutput>;\n /** The URI to fetch the next page of dedicated hosts. Call ListNext() with this URI to fetch the next page of dedicated hosts. */\n nextLink?: string;\n}\n\n/** The list SSH public keys operation response. */\nexport interface SshPublicKeysGroupListResultOutput {\n /** The list of SSH public keys */\n value: Array<SshPublicKeyResourceOutput>;\n /** The URI to fetch the next page of SSH public keys. Call ListNext() with this URI to fetch the next page of SSH public keys. */\n nextLink?: string;\n}\n\n/** Specifies information about the SSH public key. */\nexport interface SshPublicKeyResourceOutput extends ResourceOutput {\n /** Properties of the SSH public key. */\n properties?: SshPublicKeyResourcePropertiesOutput;\n}\n\n/** Properties of the SSH public key. */\nexport interface SshPublicKeyResourcePropertiesOutput {\n /** SSH public key used to authenticate to a virtual machine through ssh. If this property is not initially provided when the resource is created, the publicKey property will be populated when generateKeyPair is called. If the public key is provided upon resource creation, the provided public key needs to be at least 2048-bit and in ssh-rsa format. */\n publicKey?: string;\n}\n\n/** Response from generation of an SSH key pair. */\nexport interface SshPublicKeyGenerateKeyPairResultOutput {\n /** Private key portion of the key pair used to authenticate to a virtual machine through ssh. The private key is returned in RFC3447 format and should be treated as a secret. */\n privateKey: string;\n /** Public key portion of the key pair used to authenticate to a virtual machine through ssh. The public key is in ssh-rsa format. */\n publicKey: string;\n /** The ARM resource id in the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/providers/Microsoft.Compute/sshPublicKeys/{SshPublicKeyName} */\n id: string;\n}\n\n/** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\nexport interface ImageOutput extends ResourceOutput {\n /** Describes the properties of an Image. */\n properties?: ImagePropertiesOutput;\n /** The extended location of the Image. */\n extendedLocation?: ExtendedLocationOutput;\n}\n\n/** Describes the properties of an Image. */\nexport interface ImagePropertiesOutput {\n /** The source virtual machine from which Image is created. */\n sourceVirtualMachine?: SubResourceOutput;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: ImageStorageProfileOutput;\n /** The provisioning state. */\n readonly provisioningState?: string;\n /** Specifies the HyperVGenerationType of the VirtualMachine created from the image. From API Version 2019-03-01 if the image source is a blob, then we need the user to specify the value, if the source is managed resource like disk or snapshot, we may require the user to specify the property if we cannot deduce it from the source managed resource. */\n hyperVGeneration?: \"V1\" | \"V2\";\n}\n\n/** Describes a storage profile. */\nexport interface ImageStorageProfileOutput {\n /** Specifies information about the operating system disk used by the virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: ImageOSDiskOutput;\n /** Specifies the parameters that are used to add a data disk to a virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: Array<ImageDataDiskOutput>;\n /** Specifies whether an image is zone resilient or not. Default is false. Zone resilient images can be created only in regions that provide Zone Redundant Storage (ZRS). */\n zoneResilient?: boolean;\n}\n\n/** Describes an Operating System disk. */\nexport interface ImageOSDiskOutput extends ImageDiskOutput {\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from a custom image. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType: \"Windows\" | \"Linux\";\n /** The OS State. For managed images, use Generalized. */\n osState: \"Generalized\" | \"Specialized\";\n}\n\n/** Describes a image disk. */\nexport interface ImageDiskOutput {\n /** The snapshot. */\n snapshot?: SubResourceOutput;\n /** The managedDisk. */\n managedDisk?: SubResourceOutput;\n /** The Virtual Hard Disk. */\n blobUri?: string;\n /** Specifies the caching requirements. <br><br> Possible values are: <br><br> **None** <br><br> **ReadOnly** <br><br> **ReadWrite** <br><br> Default: **None for Standard storage. ReadOnly for Premium storage** */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Specifies the size of empty data disks in gigabytes. This element can be used to overwrite the name of the disk in a virtual machine image. <br><br> This value cannot be larger than 1023 GB */\n diskSizeGB?: number;\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?:\n | \"Standard_LRS\"\n | \"Premium_LRS\"\n | \"StandardSSD_LRS\"\n | \"UltraSSD_LRS\"\n | \"Premium_ZRS\"\n | \"StandardSSD_ZRS\"\n | \"PremiumV2_LRS\";\n /** Specifies the customer managed disk encryption set resource id for the managed image disk. */\n diskEncryptionSet?: DiskEncryptionSetParametersOutput;\n}\n\n/** Describes a data disk. */\nexport interface ImageDataDiskOutput extends ImageDiskOutput {\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n}\n\n/** The List Image operation response. */\nexport interface ImageListResultOutput {\n /** The list of Images. */\n value: Array<ImageOutput>;\n /** The uri to fetch the next page of Images. Call ListNext() with this to fetch the next page of Images. */\n nextLink?: string;\n}\n\n/** Create or update Restore Point collection parameters. */\nexport interface RestorePointCollectionOutput extends ResourceOutput {\n /** The restore point collection properties. */\n properties?: RestorePointCollectionPropertiesOutput;\n}\n\n/** The restore point collection properties. */\nexport interface RestorePointCollectionPropertiesOutput {\n /** The properties of the source resource that this restore point collection is created from. */\n source?: RestorePointCollectionSourcePropertiesOutput;\n /** The provisioning state of the restore point collection. */\n readonly provisioningState?: string;\n /** The unique id of the restore point collection. */\n readonly restorePointCollectionId?: string;\n /** A list containing all restore points created under this restore point collection. */\n readonly restorePoints?: Array<RestorePointOutput>;\n}\n\n/** The properties of the source resource that this restore point collection is created from. */\nexport interface RestorePointCollectionSourcePropertiesOutput {\n /** Location of the source resource used to create this restore point collection. */\n readonly location?: string;\n /** Resource Id of the source resource used to create this restore point collection */\n id?: string;\n}\n\n/** Restore Point details. */\nexport interface RestorePointOutput extends ProxyResourceOutput {\n /** The restore point properties. */\n properties?: RestorePointPropertiesOutput;\n}\n\n/** The restore point properties. */\nexport interface RestorePointPropertiesOutput {\n /** List of disk resource ids that the customer wishes to exclude from the restore point. If no disks are specified, all disks will be included. */\n excludeDisks?: Array<ApiEntityReferenceOutput>;\n /** Gets the details of the VM captured at the time of the restore point creation. */\n readonly sourceMetadata?: RestorePointSourceMetadataOutput;\n /** Gets the provisioning state of the restore point. */\n readonly provisioningState?: string;\n /** ConsistencyMode of the RestorePoint. Can be specified in the input while creating a restore point. For now, only CrashConsistent is accepted as a valid input. Please refer to https://aka.ms/RestorePoints for more details. */\n consistencyMode?: \"CrashConsistent\" | \"FileSystemConsistent\" | \"ApplicationConsistent\";\n /** Gets the creation time of the restore point. */\n timeCreated?: string;\n /** Resource Id of the source restore point from which a copy needs to be created. */\n sourceRestorePoint?: ApiEntityReferenceOutput;\n /** The restore point instance view. */\n readonly instanceView?: RestorePointInstanceViewOutput;\n}\n\n/** Describes the properties of the Virtual Machine for which the restore point was created. The properties provided are a subset and the snapshot of the overall Virtual Machine properties captured at the time of the restore point creation. */\nexport interface RestorePointSourceMetadataOutput {\n /** Gets the hardware profile. */\n hardwareProfile?: HardwareProfileOutput;\n /** Gets the storage profile. */\n storageProfile?: RestorePointSourceVMStorageProfileOutput;\n /** Gets the OS profile. */\n osProfile?: OSProfileOutput;\n /** Gets the diagnostics profile. */\n diagnosticsProfile?: DiagnosticsProfileOutput;\n /** Gets the license type, which is for bring your own license scenario. */\n licenseType?: string;\n /** Gets the virtual machine unique id. */\n vmId?: string;\n /** Gets the security profile. */\n securityProfile?: SecurityProfileOutput;\n /** Location of the VM from which the restore point was created. */\n location?: string;\n}\n\n/** Describes the storage profile. */\nexport interface RestorePointSourceVMStorageProfileOutput {\n /** Gets the OS disk of the VM captured at the time of the restore point creation. */\n osDisk?: RestorePointSourceVmosDiskOutput;\n /** Gets the data disks of the VM captured at the time of the restore point creation. */\n dataDisks?: Array<RestorePointSourceVMDataDiskOutput>;\n}\n\n/** Describes an Operating System disk. */\nexport interface RestorePointSourceVmosDiskOutput {\n /** Gets the Operating System type. */\n osType?: \"Windows\" | \"Linux\";\n /** Gets the disk encryption settings. */\n encryptionSettings?: DiskEncryptionSettingsOutput;\n /** Gets the disk name. */\n name?: string;\n /** Gets the caching type. */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Gets the disk size in GB. */\n diskSizeGB?: number;\n /** Gets the managed disk details */\n managedDisk?: ManagedDiskParametersOutput;\n /** Gets the disk restore point Id. */\n diskRestorePoint?: ApiEntityReferenceOutput;\n}\n\n/** Describes a data disk. */\nexport interface RestorePointSourceVMDataDiskOutput {\n /** Gets the logical unit number. */\n lun?: number;\n /** Gets the disk name. */\n name?: string;\n /** Gets the caching type. */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Gets the initial disk size in GB for blank data disks, and the new desired size for existing OS and Data disks. */\n diskSizeGB?: number;\n /** Gets the managed disk details */\n managedDisk?: ManagedDiskParametersOutput;\n /** Gets the disk restore point Id. */\n diskRestorePoint?: ApiEntityReferenceOutput;\n}\n\n/** The instance view of a restore point. */\nexport interface RestorePointInstanceViewOutput {\n /** The disk restore points information. */\n diskRestorePoints?: Array<DiskRestorePointInstanceViewOutput>;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** The instance view of a disk restore point. */\nexport interface DiskRestorePointInstanceViewOutput {\n /** Disk restore point Id. */\n id?: string;\n /** The disk restore point replication status information. */\n replicationStatus?: DiskRestorePointReplicationStatusOutput;\n}\n\n/** The instance view of a disk restore point. */\nexport interface DiskRestorePointReplicationStatusOutput {\n /** The resource status information. */\n status?: InstanceViewStatusOutput;\n /** Replication completion percentage. */\n completionPercent?: number;\n}\n\n/** The resource model definition for an Azure Resource Manager proxy resource. It will not have tags and a location */\nexport interface ProxyResourceOutput {\n /** Resource Id */\n readonly id?: string;\n /** Resource name */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n}\n\n/** The List restore point collection operation response. */\nexport interface RestorePointCollectionListResultOutput {\n /** Gets the list of restore point collections. */\n value?: Array<RestorePointCollectionOutput>;\n /** The uri to fetch the next page of RestorePointCollections. Call ListNext() with this to fetch the next page of RestorePointCollections */\n nextLink?: string;\n}\n\n/** Specifies information about the capacity reservation group that the capacity reservations should be assigned to. <br><br> Currently, a capacity reservation can only be added to a capacity reservation group at creation time. An existing capacity reservation cannot be added or moved to another capacity reservation group. */\nexport interface CapacityReservationGroupOutput extends ResourceOutput {\n /** capacity reservation group Properties. */\n properties?: CapacityReservationGroupPropertiesOutput;\n /** Availability Zones to use for this capacity reservation group. The zones can be assigned only during creation. If not provided, the group supports only regional resources in the region. If provided, enforces each capacity reservation in the group to be in one of the zones. */\n zones?: Array<string>;\n}\n\n/** capacity reservation group Properties. */\nexport interface CapacityReservationGroupPropertiesOutput {\n /** A list of all capacity reservation resource ids that belong to capacity reservation group. */\n readonly capacityReservations?: Array<SubResourceReadOnlyOutput>;\n /** A list of references to all virtual machines associated to the capacity reservation group. */\n readonly virtualMachinesAssociated?: Array<SubResourceReadOnlyOutput>;\n /** The capacity reservation group instance view which has the list of instance views for all the capacity reservations that belong to the capacity reservation group. */\n readonly instanceView?: CapacityReservationGroupInstanceViewOutput;\n}\n\nexport interface CapacityReservationGroupInstanceViewOutput {\n /** List of instance view of the capacity reservations under the capacity reservation group. */\n readonly capacityReservations?: Array<CapacityReservationInstanceViewWithNameOutput>;\n}\n\n/** The instance view of a capacity reservation that includes the name of the capacity reservation. It is used for the response to the instance view of a capacity reservation group. */\nexport interface CapacityReservationInstanceViewWithNameOutput\n extends CapacityReservationInstanceViewOutput {\n /** The name of the capacity reservation. */\n readonly name?: string;\n}\n\n/** The instance view of a capacity reservation that provides as snapshot of the runtime properties of the capacity reservation that is managed by the platform and can change outside of control plane operations. */\nexport interface CapacityReservationInstanceViewOutput {\n /** Unutilized capacity of the capacity reservation. */\n utilizationInfo?: CapacityReservationUtilizationOutput;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** Represents the capacity reservation utilization in terms of resources allocated. */\nexport interface CapacityReservationUtilizationOutput {\n /** The value provides the current capacity of the VM size which was reserved successfully and for which the customer is getting billed.<br><br>Minimum api-version: 2022-08-01. */\n readonly currentCapacity?: number;\n /** A list of all virtual machines resource ids allocated against the capacity reservation. */\n readonly virtualMachinesAllocated?: Array<SubResourceReadOnlyOutput>;\n}\n\n/** The List capacity reservation group with resource group response. */\nexport interface CapacityReservationGroupListResultOutput {\n /** The list of capacity reservation groups */\n value: Array<CapacityReservationGroupOutput>;\n /** The URI to fetch the next page of capacity reservation groups. Call ListNext() with this URI to fetch the next page of capacity reservation groups. */\n nextLink?: string;\n}\n\n/** Specifies information about the capacity reservation. */\nexport interface CapacityReservationOutput extends ResourceOutput {\n /** Properties of the Capacity reservation. */\n properties?: CapacityReservationPropertiesOutput;\n /** SKU of the resource for which capacity needs be reserved. The SKU name and capacity is required to be set. Currently VM Skus with the capability called 'CapacityReservationSupported' set to true are supported. Refer to List Microsoft.Compute SKUs in a region (https://docs.microsoft.com/rest/api/compute/resourceskus/list) for supported values. */\n sku: SkuOutput;\n /** Availability Zone to use for this capacity reservation. The zone has to be single value and also should be part for the list of zones specified during the capacity reservation group creation. The zone can be assigned only during creation. If not provided, the reservation supports only non-zonal deployments. If provided, enforces VM/VMSS using this capacity reservation to be in same zone. */\n zones?: Array<string>;\n}\n\n/** Properties of the Capacity reservation. */\nexport interface CapacityReservationPropertiesOutput {\n /** A unique id generated and assigned to the capacity reservation by the platform which does not change throughout the lifetime of the resource. */\n readonly reservationId?: string;\n /** Specifies the value of fault domain count that Capacity Reservation supports for requested VM size.<br>NOTE: The fault domain count specified for a resource (like virtual machines scale set) must be less than or equal to this value if it deploys using capacity reservation.<br><br>Minimum api-version: 2022-08-01. */\n readonly platformFaultDomainCount?: number;\n /** A list of all virtual machine resource ids that are associated with the capacity reservation. */\n readonly virtualMachinesAssociated?: Array<SubResourceReadOnlyOutput>;\n /** The date time when the capacity reservation was last updated. */\n readonly provisioningTime?: string;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The Capacity reservation instance view. */\n readonly instanceView?: CapacityReservationInstanceViewOutput;\n /** Specifies the time at which the Capacity Reservation resource was created.<br><br>Minimum api-version: 2021-11-01. */\n readonly timeCreated?: string;\n}\n\n/** The list capacity reservation operation response. */\nexport interface CapacityReservationListResultOutput {\n /** The list of capacity reservations */\n value: Array<CapacityReservationOutput>;\n /** The URI to fetch the next page of capacity reservations. Call ListNext() with this URI to fetch the next page of capacity reservations. */\n nextLink?: string;\n}\n\n/** LogAnalytics operation status response */\nexport interface LogAnalyticsOperationResultOutput {\n /** LogAnalyticsOutput */\n readonly properties?: LogAnalyticsOutputOutput;\n}\n\n/** LogAnalytics output properties */\nexport interface LogAnalyticsOutputOutput {\n /** Output file Uri path to blob container. */\n readonly output?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface RunCommandListResultOutput {\n /** The list of virtual machine run commands. */\n value: Array<RunCommandDocumentBaseOutput>;\n /** The uri to fetch the next page of run commands. Call ListNext() with this to fetch the next page of run commands. */\n nextLink?: string;\n}\n\n/** Describes the properties of a Run Command metadata. */\nexport interface RunCommandDocumentBaseOutput {\n /** The VM run command schema. */\n $schema: string;\n /** The VM run command id. */\n id: string;\n /** The Operating System type. */\n osType: \"Windows\" | \"Linux\";\n /** The VM run command label. */\n label: string;\n /** The VM run command description. */\n description: string;\n}\n\n/** Describes the properties of a Run Command. */\nexport interface RunCommandDocumentOutput extends RunCommandDocumentBaseOutput {\n /** The script to be executed. */\n script: Array<string>;\n /** The parameters used by the script. */\n parameters?: Array<RunCommandParameterDefinitionOutput>;\n}\n\n/** Describes the properties of a run command parameter. */\nexport interface RunCommandParameterDefinitionOutput {\n /** The run command parameter name. */\n name: string;\n /** The run command parameter type. */\n type: string;\n /** The run command parameter default value. */\n defaultValue?: string;\n /** The run command parameter required. */\n required?: boolean;\n}\n\n/** Describes the properties of a run command parameter. */\nexport interface RunCommandInputParameterOutput {\n /** The run command parameter name. */\n name: string;\n /** The run command parameter value. */\n value: string;\n}\n\nexport interface RunCommandResultOutput {\n /** Run command operation response. */\n value?: Array<InstanceViewStatusOutput>;\n}\n\n/** Describes a Virtual Machine run command. */\nexport interface VirtualMachineRunCommandOutput extends ResourceOutput {\n /** Describes the properties of a Virtual Machine run command. */\n properties?: VirtualMachineRunCommandPropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine run command. */\nexport interface VirtualMachineRunCommandPropertiesOutput {\n /** The source of the run command script. */\n source?: VirtualMachineRunCommandScriptSourceOutput;\n /** The parameters used by the script. */\n parameters?: Array<RunCommandInputParameterOutput>;\n /** The parameters used by the script. */\n protectedParameters?: Array<RunCommandInputParameterOutput>;\n /** Optional. If set to true, provisioning will complete as soon as the script starts and will not wait for script to complete. */\n asyncExecution?: boolean;\n /** Specifies the user account on the VM when executing the run command. */\n runAsUser?: string;\n /** Specifies the user account password on the VM when executing the run command. */\n runAsPassword?: string;\n /** The timeout in seconds to execute the run command. */\n timeoutInSeconds?: number;\n /** Specifies the Azure storage blob where script output stream will be uploaded. */\n outputBlobUri?: string;\n /** Specifies the Azure storage blob where script error stream will be uploaded. */\n errorBlobUri?: string;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The virtual machine run command instance view. */\n readonly instanceView?: VirtualMachineRunCommandInstanceViewOutput;\n}\n\n/** Describes the script sources for run command. */\nexport interface VirtualMachineRunCommandScriptSourceOutput {\n /** Specifies the script content to be executed on the VM. */\n script?: string;\n /** Specifies the script download location. */\n scriptUri?: string;\n /** Specifies a commandId of predefined built-in script. */\n commandId?: string;\n}\n\n/** The instance view of a virtual machine run command. */\nexport interface VirtualMachineRunCommandInstanceViewOutput {\n /** Script execution status. */\n executionState?:\n | \"Unknown\"\n | \"Pending\"\n | \"Running\"\n | \"Failed\"\n | \"Succeeded\"\n | \"TimedOut\"\n | \"Canceled\";\n /** Communicate script configuration errors or execution messages. */\n executionMessage?: string;\n /** Exit code returned from script execution. */\n exitCode?: number;\n /** Script output stream. */\n output?: string;\n /** Script error stream. */\n error?: string;\n /** Script start time. */\n startTime?: string;\n /** Script end time. */\n endTime?: string;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** The List run command operation response */\nexport interface VirtualMachineRunCommandsListResultOutput {\n /** The list of run commands */\n value: Array<VirtualMachineRunCommandOutput>;\n /** The uri to fetch the next page of run commands. */\n nextLink?: string;\n}\n\n/** Disk resource. */\nexport interface DiskOutput extends ResourceOutput {\n /** A relative URI containing the ID of the VM that has the disk attached. */\n readonly managedBy?: string;\n /** List of relative URIs containing the IDs of the VMs that have the disk attached. maxShares should be set to a value greater than one for disks to allow attaching them to multiple VMs. */\n readonly managedByExtended?: Array<string>;\n /** The disks sku name. Can be Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, or PremiumV2_LRS. */\n sku?: DiskSkuOutput;\n /** The Logical zone list for Disk. */\n zones?: Array<string>;\n /** The extended location where the disk will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocationOutput;\n /** Disk resource properties. */\n properties?: DiskPropertiesOutput;\n}\n\n/** The disks sku name. Can be Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, or PremiumV2_LRS. */\nexport interface DiskSkuOutput {\n /** The sku name. */\n name?:\n | \"Standard_LRS\"\n | \"Premium_LRS\"\n | \"StandardSSD_LRS\"\n | \"UltraSSD_LRS\"\n | \"Premium_ZRS\"\n | \"StandardSSD_ZRS\"\n | \"PremiumV2_LRS\";\n /** The sku tier. */\n readonly tier?: string;\n}\n\n/** Disk resource properties. */\nexport interface DiskPropertiesOutput {\n /** The time when the disk was created. */\n readonly timeCreated?: string;\n /** The Operating System type. */\n osType?: \"Windows\" | \"Linux\";\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** Purchase plan information for the the image from which the OS disk was created. E.g. - {name: 2019-Datacenter, publisher: MicrosoftWindowsServer, product: WindowsServer} */\n purchasePlan?: PurchasePlanAutoGeneratedOutput;\n /** List of supported capabilities for the image from which the OS disk was created. */\n supportedCapabilities?: SupportedCapabilitiesOutput;\n /** Disk source information. CreationData information cannot be changed after the disk has been created. */\n creationData: CreationDataOutput;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /** The size of the disk in bytes. This field is read only. */\n readonly diskSizeBytes?: number;\n /** Unique Guid identifying the resource. */\n readonly uniqueId?: string;\n /** Encryption settings collection used for Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollectionOutput;\n /** The disk provisioning state. */\n readonly provisioningState?: string;\n /** The number of IOPS allowed for this disk; only settable for UltraSSD disks. One operation can transfer between 4k and 256k bytes. */\n diskIOPSReadWrite?: number;\n /** The bandwidth allowed for this disk; only settable for UltraSSD disks. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadWrite?: number;\n /** The total number of IOPS that will be allowed across all VMs mounting the shared disk as ReadOnly. One operation can transfer between 4k and 256k bytes. */\n diskIOPSReadOnly?: number;\n /** The total throughput (MBps) that will be allowed across all VMs mounting the shared disk as ReadOnly. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadOnly?: number;\n /** The state of the disk. */\n readonly diskState?:\n | \"Unattached\"\n | \"Attached\"\n | \"Reserved\"\n | \"Frozen\"\n | \"ActiveSAS\"\n | \"ActiveSASFrozen\"\n | \"ReadyToUpload\"\n | \"ActiveUpload\";\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: EncryptionOutput;\n /** The maximum number of VMs that can attach to the disk at the same time. Value greater than one indicates a disk that can be mounted on multiple VMs at the same time. */\n maxShares?: number;\n /** Details of the list of all VMs that have the disk attached. maxShares should be set to a value greater than one for disks to allow attaching them to multiple VMs. */\n readonly shareInfo?: Array<ShareInfoElementOutput>;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: \"AllowAll\" | \"AllowPrivate\" | \"DenyAll\";\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Latest time when bursting was last enabled on a disk. */\n readonly burstingEnabledTime?: string;\n /** Performance tier of the disk (e.g, P4, S10) as described here: https://azure.microsoft.com/en-us/pricing/details/managed-disks/. Does not apply to Ultra disks. */\n tier?: string;\n /** Set to true to enable bursting beyond the provisioned performance target of the disk. Bursting is disabled by default. Does not apply to Ultra disks. */\n burstingEnabled?: boolean;\n /** Properties of the disk for which update is pending. */\n readonly propertyUpdatesInProgress?: PropertyUpdatesInProgressOutput;\n /** Indicates the OS on a disk supports hibernation. */\n supportsHibernation?: boolean;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfileOutput;\n /** Percentage complete for the background copy when a resource is created via the CopyStart operation. */\n completionPercent?: number;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: \"Enabled\" | \"Disabled\";\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: \"AzureActiveDirectory\" | \"None\";\n /** Setting this property to true improves reliability and performance of data disks that are frequently (more than 5 times a day) by detached from one virtual machine and attached to another. This property should not be set for disks that are not detached and attached frequently as it causes the disks to not align with the fault domain of the virtual machine. */\n optimizedForFrequentAttach?: boolean;\n}\n\n/** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\nexport interface PurchasePlanAutoGeneratedOutput {\n /** The plan ID. */\n name: string;\n /** The publisher ID. */\n publisher: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product: string;\n /** The Offer Promotion Code. */\n promotionCode?: string;\n}\n\n/** List of supported capabilities persisted on the disk resource for VM use. */\nexport interface SupportedCapabilitiesOutput {\n /** The disk controllers that an OS disk supports. If set it can be SCSI or SCSI, NVME or NVME, SCSI. */\n diskControllerTypes?: string;\n /** True if the image from which the OS disk is created supports accelerated networking. */\n acceleratedNetwork?: boolean;\n /** CPU architecture supported by an OS disk. */\n architecture?: \"x64\" | \"Arm64\";\n}\n\n/** Data used when creating a disk. */\nexport interface CreationDataOutput {\n /** This enumerates the possible sources of a disk's creation. */\n createOption:\n | \"Empty\"\n | \"Attach\"\n | \"FromImage\"\n | \"Import\"\n | \"Copy\"\n | \"Restore\"\n | \"Upload\"\n | \"CopyStart\"\n | \"ImportSecure\"\n | \"UploadPreparedSecure\";\n /** Required if createOption is Import. The Azure Resource Manager identifier of the storage account containing the blob to import as a disk. */\n storageAccountId?: string;\n /** Disk source information for PIR or user images. */\n imageReference?: ImageDiskReferenceOutput;\n /** Required if creating from a Gallery Image. The id/sharedGalleryImageId/communityGalleryImageId of the ImageDiskReference will be the ARM id of the shared galley image version from which to create a disk. */\n galleryImageReference?: ImageDiskReferenceOutput;\n /** If createOption is Import, this is the URI of a blob to be imported into a managed disk. */\n sourceUri?: string;\n /** If createOption is Copy, this is the ARM id of the source snapshot or disk. */\n sourceResourceId?: string;\n /** If this field is set, this is the unique id identifying the source of this resource. */\n readonly sourceUniqueId?: string;\n /** If createOption is Upload, this is the size of the contents of the upload including the VHD footer. This value should be between 20972032 (20 MiB + 512 bytes for the VHD footer) and 35183298347520 bytes (32 TiB + 512 bytes for the VHD footer). */\n uploadSizeBytes?: number;\n /** Logical sector size in bytes for Ultra disks. Supported values are 512 ad 4096. 4096 is the default. */\n logicalSectorSize?: number;\n /** If createOption is ImportSecure, this is the URI of a blob to be imported into VM guest state. */\n securityDataUri?: string;\n /** Set this flag to true to get a boost on the performance target of the disk deployed, see here on the respective performance target. This flag can only be set on disk creation time and cannot be disabled after enabled. */\n performancePlus?: boolean;\n}\n\n/** The source image used for creating the disk. */\nexport interface ImageDiskReferenceOutput {\n /** A relative uri containing either a Platform Image Repository, user image, or Azure Compute Gallery image reference. */\n id?: string;\n /** A relative uri containing a direct shared Azure Compute Gallery image reference. */\n sharedGalleryImageId?: string;\n /** A relative uri containing a community Azure Compute Gallery image reference. */\n communityGalleryImageId?: string;\n /** If the disk is created from an image's data disk, this is an index that indicates which of the data disks in the image to use. For OS disks, this field is null. */\n lun?: number;\n}\n\n/** Encryption settings for disk or snapshot */\nexport interface EncryptionSettingsCollectionOutput {\n /** Set this flag to true and provide DiskEncryptionKey and optional KeyEncryptionKey to enable encryption. Set this flag to false and remove DiskEncryptionKey and KeyEncryptionKey to disable encryption. If EncryptionSettings is null in the request object, the existing settings remain unchanged. */\n enabled: boolean;\n /** A collection of encryption settings, one for each disk volume. */\n encryptionSettings?: Array<EncryptionSettingsElementOutput>;\n /** Describes what type of encryption is used for the disks. Once this field is set, it cannot be overwritten. '1.0' corresponds to Azure Disk Encryption with AAD app.'1.1' corresponds to Azure Disk Encryption. */\n encryptionSettingsVersion?: string;\n}\n\n/** Encryption settings for one disk volume. */\nexport interface EncryptionSettingsElementOutput {\n /** Key Vault Secret Url and vault id of the disk encryption key */\n diskEncryptionKey?: KeyVaultAndSecretReferenceOutput;\n /** Key Vault Key Url and vault id of the key encryption key. KeyEncryptionKey is optional and when provided is used to unwrap the disk encryption key. */\n keyEncryptionKey?: KeyVaultAndKeyReferenceOutput;\n}\n\n/** Key Vault Secret Url and vault id of the encryption key */\nexport interface KeyVaultAndSecretReferenceOutput {\n /** Resource id of the KeyVault containing the key or secret */\n sourceVault: SourceVaultOutput;\n /** Url pointing to a key or secret in KeyVault */\n secretUrl: string;\n}\n\n/** The vault id is an Azure Resource Manager Resource id in the form /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.KeyVault/vaults/{vaultName} */\nexport interface SourceVaultOutput {\n /** Resource Id */\n id?: string;\n}\n\n/** Key Vault Key Url and vault id of KeK, KeK is optional and when provided is used to unwrap the encryptionKey */\nexport interface KeyVaultAndKeyReferenceOutput {\n /** Resource id of the KeyVault containing the key or secret */\n sourceVault: SourceVaultOutput;\n /** Url pointing to a key or secret in KeyVault */\n keyUrl: string;\n}\n\n/** Encryption at rest settings for disk or snapshot */\nexport interface EncryptionOutput {\n /** ResourceId of the disk encryption set to use for enabling encryption at rest. */\n diskEncryptionSetId?: string;\n /** The type of key used to encrypt the data of the disk. */\n type?:\n | \"EncryptionAtRestWithPlatformKey\"\n | \"EncryptionAtRestWithCustomerKey\"\n | \"EncryptionAtRestWithPlatformAndCustomerKeys\";\n}\n\nexport interface ShareInfoElementOutput {\n /** A relative URI containing the ID of the VM that has the disk attached. */\n readonly vmUri?: string;\n}\n\n/** Properties of the disk for which update is pending. */\nexport interface PropertyUpdatesInProgressOutput {\n /** The target performance tier of the disk if a tier change operation is in progress. */\n targetTier?: string;\n}\n\n/** Contains the security related information for the resource. */\nexport interface DiskSecurityProfileOutput {\n /** Specifies the SecurityType of the VM. Applicable for OS disks only. */\n securityType?:\n | \"TrustedLaunch\"\n | \"ConfidentialVM_VMGuestStateOnlyEncryptedWithPlatformKey\"\n | \"ConfidentialVM_DiskEncryptedWithPlatformKey\"\n | \"ConfidentialVM_DiskEncryptedWithCustomerKey\";\n /** ResourceId of the disk encryption set associated to Confidential VM supported disk encrypted with customer managed key */\n secureVMDiskEncryptionSetId?: string;\n}\n\n/** The List Disks operation response. */\nexport interface DiskListOutput {\n /** A list of disks. */\n value: Array<DiskOutput>;\n /** The uri to fetch the next page of disks. Call ListNext() with this to fetch the next page of disks. */\n nextLink?: string;\n}\n\n/** A disk access SAS uri. */\nexport interface AccessUriOutput {\n /** A SAS uri for accessing a disk. */\n readonly accessSAS?: string;\n /** A SAS uri for accessing a VM guest state. */\n readonly securityDataAccessSAS?: string;\n}\n\n/** disk access resource. */\nexport interface DiskAccessOutput extends ResourceOutput {\n properties?: DiskAccessPropertiesOutput;\n /** The extended location where the disk access will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocationOutput;\n}\n\nexport interface DiskAccessPropertiesOutput {\n /** A readonly collection of private endpoint connections created on the disk. Currently only one endpoint connection is supported. */\n readonly privateEndpointConnections?: Array<PrivateEndpointConnectionOutput>;\n /** The disk access resource provisioning state. */\n readonly provisioningState?: string;\n /** The time when the disk access was created. */\n readonly timeCreated?: string;\n}\n\n/** The Private Endpoint Connection resource. */\nexport interface PrivateEndpointConnectionOutput {\n /** Resource properties. */\n properties?: PrivateEndpointConnectionPropertiesOutput;\n /** private endpoint connection Id */\n readonly id?: string;\n /** private endpoint connection name */\n readonly name?: string;\n /** private endpoint connection type */\n readonly type?: string;\n}\n\n/** Properties of the PrivateEndpointConnectProperties. */\nexport interface PrivateEndpointConnectionPropertiesOutput {\n /** The resource of private end point. */\n readonly privateEndpoint?: PrivateEndpointOutput;\n /** A collection of information about the state of the connection between DiskAccess and Virtual Network. */\n privateLinkServiceConnectionState: PrivateLinkServiceConnectionStateOutput;\n /** The provisioning state of the private endpoint connection resource. */\n readonly provisioningState?: \"Succeeded\" | \"Creating\" | \"Deleting\" | \"Failed\";\n}\n\n/** The Private Endpoint resource. */\nexport interface PrivateEndpointOutput {\n /** The ARM identifier for Private Endpoint */\n readonly id?: string;\n}\n\n/** A collection of information about the state of the connection between service consumer and provider. */\nexport interface PrivateLinkServiceConnectionStateOutput {\n /** Indicates whether the connection has been Approved/Rejected/Removed by the owner of the service. */\n status?: \"Pending\" | \"Approved\" | \"Rejected\";\n /** The reason for approval/rejection of the connection. */\n description?: string;\n /** A message indicating if changes on the service provider require any updates on the consumer. */\n actionsRequired?: string;\n}\n\n/** The List disk access operation response. */\nexport interface DiskAccessListOutput {\n /** A list of disk access resources. */\n value: Array<DiskAccessOutput>;\n /** The uri to fetch the next page of disk access resources. Call ListNext() with this to fetch the next page of disk access resources. */\n nextLink?: string;\n}\n\n/** A list of private link resources */\nexport interface PrivateLinkResourceListResultOutput {\n /** Array of private link resources */\n value?: Array<PrivateLinkResourceOutput>;\n}\n\n/** A private link resource */\nexport interface PrivateLinkResourceOutput {\n /** Resource properties. */\n properties?: PrivateLinkResourcePropertiesOutput;\n /** private link resource Id */\n readonly id?: string;\n /** private link resource name */\n readonly name?: string;\n /** private link resource type */\n readonly type?: string;\n}\n\n/** Properties of a private link resource. */\nexport interface PrivateLinkResourcePropertiesOutput {\n /** The private link resource group id. */\n readonly groupId?: string;\n /** The private link resource required member names. */\n readonly requiredMembers?: Array<string>;\n /** The private link resource DNS zone name. */\n requiredZoneNames?: Array<string>;\n}\n\n/** A list of private link resources */\nexport interface PrivateEndpointConnectionListResultOutput {\n /** Array of private endpoint connections */\n value?: Array<PrivateEndpointConnectionOutput>;\n /** The uri to fetch the next page of snapshots. Call ListNext() with this to fetch the next page of snapshots. */\n nextLink?: string;\n}\n\n/** disk encryption set resource. */\nexport interface DiskEncryptionSetOutput extends ResourceOutput {\n /** The managed identity for the disk encryption set. It should be given permission on the key vault before it can be used to encrypt disks. */\n identity?: EncryptionSetIdentityOutput;\n properties?: EncryptionSetPropertiesOutput;\n}\n\n/** The managed identity for the disk encryption set. It should be given permission on the key vault before it can be used to encrypt disks. */\nexport interface EncryptionSetIdentityOutput {\n /** The type of Managed Identity used by the DiskEncryptionSet. Only SystemAssigned is supported for new creations. Disk Encryption Sets can be updated with Identity type None during migration of subscription to a new Azure Active Directory tenant; it will cause the encrypted resources to lose access to the keys. */\n type?: \"SystemAssigned\" | \"UserAssigned\" | \"SystemAssigned, UserAssigned\" | \"None\";\n /** The object id of the Managed Identity Resource. This will be sent to the RP from ARM via the x-ms-identity-principal-id header in the PUT request if the resource has a systemAssigned(implicit) identity */\n readonly principalId?: string;\n /** The tenant id of the Managed Identity Resource. This will be sent to the RP from ARM via the x-ms-client-tenant-id header in the PUT request if the resource has a systemAssigned(implicit) identity */\n readonly tenantId?: string;\n /** The list of user identities associated with the disk encryption set. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: Record<string, UserAssignedIdentitiesValueOutput>;\n}\n\nexport interface EncryptionSetPropertiesOutput {\n /** The type of key used to encrypt the data of the disk. */\n encryptionType?:\n | \"EncryptionAtRestWithCustomerKey\"\n | \"EncryptionAtRestWithPlatformAndCustomerKeys\"\n | \"ConfidentialVmEncryptedWithCustomerKey\";\n /** The key vault key which is currently used by this disk encryption set. */\n activeKey?: KeyForDiskEncryptionSetOutput;\n /** A readonly collection of key vault keys previously used by this disk encryption set while a key rotation is in progress. It will be empty if there is no ongoing key rotation. */\n readonly previousKeys?: Array<KeyForDiskEncryptionSetOutput>;\n /** The disk encryption set provisioning state. */\n readonly provisioningState?: string;\n /** Set this flag to true to enable auto-updating of this disk encryption set to the latest key version. */\n rotationToLatestKeyVersionEnabled?: boolean;\n /** The time when the active key of this disk encryption set was updated. */\n readonly lastKeyRotationTimestamp?: string;\n /** The error that was encountered during auto-key rotation. If an error is present, then auto-key rotation will not be attempted until the error on this disk encryption set is fixed. */\n readonly autoKeyRotationError?: ApiErrorOutput;\n /** Multi-tenant application client id to access key vault in a different tenant. Setting the value to 'None' will clear the property. */\n federatedClientId?: string;\n}\n\n/** Key Vault Key Url to be used for server side encryption of Managed Disks and Snapshots */\nexport interface KeyForDiskEncryptionSetOutput {\n /** Resource id of the KeyVault containing the key or secret. This property is optional and cannot be used if the KeyVault subscription is not the same as the Disk Encryption Set subscription. */\n sourceVault?: SourceVaultOutput;\n /** Fully versioned Key Url pointing to a key in KeyVault. Version segment of the Url is required regardless of rotationToLatestKeyVersionEnabled value. */\n keyUrl: string;\n}\n\n/** The List disk encryption set operation response. */\nexport interface DiskEncryptionSetListOutput {\n /** A list of disk encryption sets. */\n value: Array<DiskEncryptionSetOutput>;\n /** The uri to fetch the next page of disk encryption sets. Call ListNext() with this to fetch the next page of disk encryption sets. */\n nextLink?: string;\n}\n\n/** The List resources which are encrypted with the disk encryption set. */\nexport interface ResourceUriListOutput {\n /** A list of IDs or Owner IDs of resources which are encrypted with the disk encryption set. */\n value: Array<string>;\n /** The uri to fetch the next page of encrypted resources. Call ListNext() with this to fetch the next page of encrypted resources. */\n nextLink?: string;\n}\n\n/** Properties of disk restore point */\nexport interface DiskRestorePointOutput extends ProxyOnlyResourceOutput {\n /** Properties of an incremental disk restore point */\n properties?: DiskRestorePointPropertiesOutput;\n}\n\n/** Properties of an incremental disk restore point */\nexport interface DiskRestorePointPropertiesOutput {\n /** The timestamp of restorePoint creation */\n readonly timeCreated?: string;\n /** arm id of source disk or source disk restore point. */\n readonly sourceResourceId?: string;\n /** The Operating System type. */\n readonly osType?: \"Windows\" | \"Linux\";\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** Purchase plan information for the the image from which the OS disk was created. */\n purchasePlan?: PurchasePlanAutoGeneratedOutput;\n /** List of supported capabilities for the image from which the OS disk was created. */\n supportedCapabilities?: SupportedCapabilitiesOutput;\n /** id of the backing snapshot's MIS family */\n readonly familyId?: string;\n /** unique incarnation id of the source disk */\n readonly sourceUniqueId?: string;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n readonly encryption?: EncryptionOutput;\n /** Indicates the OS on a disk supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: \"AllowAll\" | \"AllowPrivate\" | \"DenyAll\";\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: \"Enabled\" | \"Disabled\";\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Percentage complete for the background copy of disk restore point when source resource is from a different region. */\n completionPercent?: number;\n /** Replication state of disk restore point when source resource is from a different region. */\n readonly replicationState?: string;\n /** Location of source disk or source disk restore point when source resource is from a different region. */\n readonly sourceResourceLocation?: string;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfileOutput;\n}\n\n/** The ProxyOnly Resource model definition. */\nexport interface ProxyOnlyResourceOutput {\n /** Resource Id */\n readonly id?: string;\n /** Resource name */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n}\n\n/** The List Disk Restore Points operation response. */\nexport interface DiskRestorePointListOutput {\n /** A list of disk restore points. */\n value: Array<DiskRestorePointOutput>;\n /** The uri to fetch the next page of disk restore points. Call ListNext() with this to fetch the next page of disk restore points. */\n nextLink?: string;\n}\n\n/** Snapshot resource. */\nexport interface SnapshotOutput extends ResourceOutput {\n /** Unused. Always Null. */\n readonly managedBy?: string;\n /** The snapshots sku name. Can be Standard_LRS, Premium_LRS, or Standard_ZRS. This is an optional parameter for incremental snapshot and the default behavior is the SKU will be set to the same sku as the previous snapshot */\n sku?: SnapshotSkuOutput;\n /** The extended location where the snapshot will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocationOutput;\n /** Snapshot resource properties. */\n properties?: SnapshotPropertiesOutput;\n}\n\n/** The snapshots sku name. Can be Standard_LRS, Premium_LRS, or Standard_ZRS. This is an optional parameter for incremental snapshot and the default behavior is the SKU will be set to the same sku as the previous snapshot */\nexport interface SnapshotSkuOutput {\n /** The sku name. */\n name?: \"Standard_LRS\" | \"Premium_LRS\" | \"Standard_ZRS\";\n /** The sku tier. */\n readonly tier?: string;\n}\n\n/** Snapshot resource properties. */\nexport interface SnapshotPropertiesOutput {\n /** The time when the snapshot was created. */\n readonly timeCreated?: string;\n /** The Operating System type. */\n osType?: \"Windows\" | \"Linux\";\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** Purchase plan information for the image from which the source disk for the snapshot was originally created. */\n purchasePlan?: PurchasePlanAutoGeneratedOutput;\n /** List of supported capabilities for the image from which the source disk from the snapshot was originally created. */\n supportedCapabilities?: SupportedCapabilitiesOutput;\n /** Disk source information. CreationData information cannot be changed after the disk has been created. */\n creationData: CreationDataOutput;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /** The size of the disk in bytes. This field is read only. */\n readonly diskSizeBytes?: number;\n /** The state of the snapshot. */\n readonly diskState?:\n | \"Unattached\"\n | \"Attached\"\n | \"Reserved\"\n | \"Frozen\"\n | \"ActiveSAS\"\n | \"ActiveSASFrozen\"\n | \"ReadyToUpload\"\n | \"ActiveUpload\";\n /** Unique Guid identifying the resource. */\n readonly uniqueId?: string;\n /** Encryption settings collection used be Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollectionOutput;\n /** The disk provisioning state. */\n readonly provisioningState?: string;\n /** Whether a snapshot is incremental. Incremental snapshots on the same disk occupy less space than full snapshots and can be diffed. */\n incremental?: boolean;\n /** Incremental snapshots for a disk share an incremental snapshot family id. The Get Page Range Diff API can only be called on incremental snapshots with the same family id. */\n readonly incrementalSnapshotFamilyId?: string;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: EncryptionOutput;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: \"AllowAll\" | \"AllowPrivate\" | \"DenyAll\";\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfileOutput;\n /** Indicates the OS on a snapshot supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: \"Enabled\" | \"Disabled\";\n /** Percentage complete for the background copy when a resource is created via the CopyStart operation. */\n completionPercent?: number;\n /** Indicates the error details if the background copy of a resource created via the CopyStart operation fails. */\n copyCompletionError?: CopyCompletionErrorOutput;\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: \"AzureActiveDirectory\" | \"None\";\n}\n\n/** Indicates the error details if the background copy of a resource created via the CopyStart operation fails. */\nexport interface CopyCompletionErrorOutput {\n /** Indicates the error code if the background copy of a resource created via the CopyStart operation fails. */\n errorCode: \"CopySourceNotFound\";\n /** Indicates the error message if the background copy of a resource created via the CopyStart operation fails. */\n errorMessage: string;\n}\n\n/** The List Snapshots operation response. */\nexport interface SnapshotListOutput {\n /** A list of snapshots. */\n value: Array<SnapshotOutput>;\n /** The uri to fetch the next page of snapshots. Call ListNext() with this to fetch the next page of snapshots. */\n nextLink?: string;\n}\n\n/** The List Resource Skus operation response. */\nexport interface ResourceSkusResultOutput {\n /** The list of skus available for the subscription. */\n value: Array<ResourceSkuOutput>;\n /** The URI to fetch the next page of Resource Skus. Call ListNext() with this URI to fetch the next page of Resource Skus */\n nextLink?: string;\n}\n\n/** Describes an available Compute SKU. */\nexport interface ResourceSkuOutput {\n /** The type of resource the SKU applies to. */\n readonly resourceType?: string;\n /** The name of SKU. */\n readonly name?: string;\n /** Specifies the tier of virtual machines in a scale set.<br /><br /> Possible Values:<br /><br /> **Standard**<br /><br /> **Basic** */\n readonly tier?: string;\n /** The Size of the SKU. */\n readonly size?: string;\n /** The Family of this particular SKU. */\n readonly family?: string;\n /** The Kind of resources that are supported in this SKU. */\n readonly kind?: string;\n /** Specifies the number of virtual machines in the scale set. */\n readonly capacity?: ResourceSkuCapacityOutput;\n /** The set of locations that the SKU is available. */\n readonly locations?: Array<string>;\n /** A list of locations and availability zones in those locations where the SKU is available. */\n readonly locationInfo?: Array<ResourceSkuLocationInfoOutput>;\n /** The api versions that support this SKU. */\n readonly apiVersions?: Array<string>;\n /** Metadata for retrieving price info. */\n readonly costs?: Array<ResourceSkuCostsOutput>;\n /** A name value pair to describe the capability. */\n readonly capabilities?: Array<ResourceSkuCapabilitiesOutput>;\n /** The restrictions because of which SKU cannot be used. This is empty if there are no restrictions. */\n readonly restrictions?: Array<ResourceSkuRestrictionsOutput>;\n}\n\n/** Describes scaling information of a SKU. */\nexport interface ResourceSkuCapacityOutput {\n /** The minimum capacity. */\n readonly minimum?: number;\n /** The maximum capacity that can be set. */\n readonly maximum?: number;\n /** The default capacity. */\n readonly default?: number;\n /** The scale type applicable to the sku. */\n readonly scaleType?: \"Automatic\" | \"Manual\" | \"None\";\n}\n\n/** Describes an available Compute SKU Location Information. */\nexport interface ResourceSkuLocationInfoOutput {\n /** Location of the SKU */\n readonly location?: string;\n /** List of availability zones where the SKU is supported. */\n readonly zones?: Array<string>;\n /** Details of capabilities available to a SKU in specific zones. */\n readonly zoneDetails?: Array<ResourceSkuZoneDetailsOutput>;\n /** The names of extended locations. */\n readonly extendedLocations?: Array<string>;\n /** The type of the extended location. */\n readonly type?: \"EdgeZone\";\n}\n\n/** Describes The zonal capabilities of a SKU. */\nexport interface ResourceSkuZoneDetailsOutput {\n /** The set of zones that the SKU is available in with the specified capabilities. */\n readonly name?: Array<string>;\n /** A list of capabilities that are available for the SKU in the specified list of zones. */\n readonly capabilities?: Array<ResourceSkuCapabilitiesOutput>;\n}\n\n/** Describes The SKU capabilities object. */\nexport interface ResourceSkuCapabilitiesOutput {\n /** An invariant to describe the feature. */\n readonly name?: string;\n /** An invariant if the feature is measured by quantity. */\n readonly value?: string;\n}\n\n/** Describes metadata for retrieving price info. */\nexport interface ResourceSkuCostsOutput {\n /** Used for querying price from commerce. */\n readonly meterID?: string;\n /** The multiplier is needed to extend the base metered cost. */\n readonly quantity?: number;\n /** An invariant to show the extended unit. */\n readonly extendedUnit?: string;\n}\n\n/** Describes scaling information of a SKU. */\nexport interface ResourceSkuRestrictionsOutput {\n /** The type of restrictions. */\n readonly type?: \"Location\" | \"Zone\";\n /** The value of restrictions. If the restriction type is set to location. This would be different locations where the SKU is restricted. */\n readonly values?: Array<string>;\n /** The information about the restriction where the SKU cannot be used. */\n readonly restrictionInfo?: ResourceSkuRestrictionInfoOutput;\n /** The reason for restriction. */\n readonly reasonCode?: \"QuotaId\" | \"NotAvailableForSubscription\";\n}\n\n/** Describes an available Compute SKU Restriction Information. */\nexport interface ResourceSkuRestrictionInfoOutput {\n /** Locations where the SKU is restricted */\n readonly locations?: Array<string>;\n /** List of availability zones where the SKU is restricted. */\n readonly zones?: Array<string>;\n}\n\n/** Specifies information about the Shared Image Gallery that you want to create or update. */\nexport interface GalleryOutput extends ResourceOutput {\n /** Describes the properties of a Shared Image Gallery. */\n properties?: GalleryPropertiesOutput;\n}\n\n/** Describes the properties of a Shared Image Gallery. */\nexport interface GalleryPropertiesOutput {\n /** The description of this Shared Image Gallery resource. This property is updatable. */\n description?: string;\n /** Describes the gallery unique name. */\n identifier?: GalleryIdentifierOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?:\n | \"Creating\"\n | \"Updating\"\n | \"Failed\"\n | \"Succeeded\"\n | \"Deleting\"\n | \"Migrating\";\n /** Profile for gallery sharing to subscription or tenant */\n sharingProfile?: SharingProfileOutput;\n /** Contains information about the soft deletion policy of the gallery. */\n softDeletePolicy?: SoftDeletePolicyOutput;\n /** Sharing status of current gallery. */\n readonly sharingStatus?: SharingStatusOutput;\n}\n\n/** Describes the gallery unique name. */\nexport interface GalleryIdentifierOutput {\n /** The unique name of the Shared Image Gallery. This name is generated automatically by Azure. */\n readonly uniqueName?: string;\n}\n\n/** Profile for gallery sharing to subscription or tenant */\nexport interface SharingProfileOutput {\n /** This property allows you to specify the permission of sharing gallery. <br><br> Possible values are: <br><br> **Private** <br><br> **Groups** <br><br> **Community** */\n permissions?: \"Private\" | \"Groups\" | \"Community\";\n /** A list of sharing profile groups. */\n readonly groups?: Array<SharingProfileGroupOutput>;\n /** Information of community gallery if current gallery is shared to community. */\n communityGalleryInfo?: CommunityGalleryInfoOutput;\n}\n\n/** Group of the gallery sharing profile */\nexport interface SharingProfileGroupOutput {\n /** This property allows you to specify the type of sharing group. <br><br> Possible values are: <br><br> **Subscriptions** <br><br> **AADTenants** */\n type?: \"Subscriptions\" | \"AADTenants\";\n /** A list of subscription/tenant ids the gallery is aimed to be shared to. */\n ids?: Array<string>;\n}\n\n/** Information of community gallery if current gallery is shared to community */\nexport interface CommunityGalleryInfoOutput {\n /** The link to the publisher website. Visible to all users. */\n publisherUri?: string;\n /** Community gallery publisher support email. The email address of the publisher. Visible to all users. */\n publisherContact?: string;\n /** End-user license agreement for community gallery image. */\n eula?: string;\n /** The prefix of the gallery name that will be displayed publicly. Visible to all users. */\n publicNamePrefix?: string;\n /** Contains info about whether community gallery sharing is enabled. */\n readonly communityGalleryEnabled?: boolean;\n /** Community gallery public name list. */\n readonly publicNames?: Array<string>;\n}\n\n/** Contains information about the soft deletion policy of the gallery. */\nexport interface SoftDeletePolicyOutput {\n /** Enables soft-deletion for resources in this gallery, allowing them to be recovered within retention time. */\n isSoftDeleteEnabled?: boolean;\n}\n\n/** Sharing status of current gallery. */\nexport interface SharingStatusOutput {\n /** Aggregated sharing state of current gallery. */\n readonly aggregatedState?: \"Succeeded\" | \"InProgress\" | \"Failed\" | \"Unknown\";\n /** Summary of all regional sharing status. */\n summary?: Array<RegionalSharingStatusOutput>;\n}\n\n/** Gallery regional sharing status */\nexport interface RegionalSharingStatusOutput {\n /** Region name */\n region?: string;\n /** Gallery sharing state in current region */\n readonly state?: \"Succeeded\" | \"InProgress\" | \"Failed\" | \"Unknown\";\n /** Details of gallery regional sharing failure. */\n details?: string;\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface GalleryImageOutput extends ResourceOutput {\n /** Describes the properties of a gallery image definition. */\n properties?: GalleryImagePropertiesOutput;\n}\n\n/** Describes the properties of a gallery image definition. */\nexport interface GalleryImagePropertiesOutput {\n /** The description of this gallery image definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery image definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType: \"Windows\" | \"Linux\";\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState: \"Generalized\" | \"Specialized\";\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** This is the gallery image definition identifier. */\n identifier: GalleryImageIdentifierOutput;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfigurationOutput;\n /** Describes the disallowed disk types. */\n disallowed?: DisallowedOutput;\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlanOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?:\n | \"Creating\"\n | \"Updating\"\n | \"Failed\"\n | \"Succeeded\"\n | \"Deleting\"\n | \"Migrating\";\n /** A list of gallery image features. */\n features?: Array<GalleryImageFeatureOutput>;\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: \"x64\" | \"Arm64\";\n}\n\n/** This is the gallery image definition identifier. */\nexport interface GalleryImageIdentifierOutput {\n /** The name of the gallery image definition publisher. */\n publisher: string;\n /** The name of the gallery image definition offer. */\n offer: string;\n /** The name of the gallery image definition SKU. */\n sku: string;\n}\n\n/** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\nexport interface RecommendedMachineConfigurationOutput {\n /** Describes the resource range. */\n vCPUs?: ResourceRangeOutput;\n /** Describes the resource range. */\n memory?: ResourceRangeOutput;\n}\n\n/** Describes the resource range. */\nexport interface ResourceRangeOutput {\n /** The minimum number of the resource. */\n min?: number;\n /** The maximum number of the resource. */\n max?: number;\n}\n\n/** Describes the disallowed disk types. */\nexport interface DisallowedOutput {\n /** A list of disk types. */\n diskTypes?: Array<string>;\n}\n\n/** Describes the gallery image definition purchase plan. This is used by marketplace images. */\nexport interface ImagePurchasePlanOutput {\n /** The plan ID. */\n name?: string;\n /** The publisher ID. */\n publisher?: string;\n /** The product ID. */\n product?: string;\n}\n\n/** A feature for gallery image. */\nexport interface GalleryImageFeatureOutput {\n /** The name of the gallery image feature. */\n name?: string;\n /** The value of the gallery image feature. */\n value?: string;\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface GalleryImageVersionOutput extends ResourceOutput {\n /** Describes the properties of a gallery image version. */\n properties?: GalleryImageVersionPropertiesOutput;\n}\n\n/** Describes the properties of a gallery image version. */\nexport interface GalleryImageVersionPropertiesOutput {\n /** The publishing profile of a gallery image Version. */\n publishingProfile?: GalleryImageVersionPublishingProfileOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?:\n | \"Creating\"\n | \"Updating\"\n | \"Failed\"\n | \"Succeeded\"\n | \"Deleting\"\n | \"Migrating\";\n /** This is the storage profile of a Gallery Image Version. */\n storageProfile: GalleryImageVersionStorageProfileOutput;\n /** This is the replication status of the gallery image version. */\n readonly replicationStatus?: ReplicationStatusOutput;\n}\n\n/** The publishing profile of a gallery image Version. */\nexport interface GalleryImageVersionPublishingProfileOutput\n extends GalleryArtifactPublishingProfileBaseOutput {}\n\n/** Describes the basic gallery artifact publishing profile. */\nexport interface GalleryArtifactPublishingProfileBaseOutput {\n /** The target regions where the Image Version is going to be replicated to. This property is updatable. */\n targetRegions?: Array<TargetRegionOutput>;\n /** The number of replicas of the Image Version to be created per region. This property would take effect for a region when regionalReplicaCount is not specified. This property is updatable. */\n replicaCount?: number;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /** The timestamp for when the gallery image version is published. */\n readonly publishedDate?: string;\n /** The end of life date of the gallery image version. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: \"Standard_LRS\" | \"Standard_ZRS\" | \"Premium_LRS\";\n /** Optional parameter which specifies the mode to be used for replication. This property is not updatable. */\n replicationMode?: \"Full\" | \"Shallow\";\n /** The target extended locations where the Image Version is going to be replicated to. This property is updatable. */\n targetExtendedLocations?: Array<GalleryTargetExtendedLocationOutput>;\n}\n\n/** Describes the target region information. */\nexport interface TargetRegionOutput {\n /** The name of the region. */\n name: string;\n /** The number of replicas of the Image Version to be created per region. This property is updatable. */\n regionalReplicaCount?: number;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: \"Standard_LRS\" | \"Standard_ZRS\" | \"Premium_LRS\";\n /** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\n encryption?: EncryptionImagesOutput;\n}\n\n/** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\nexport interface EncryptionImagesOutput {\n /** Contains encryption settings for an OS disk image. */\n osDiskImage?: OSDiskImageEncryptionOutput;\n /** A list of encryption specifications for data disk images. */\n dataDiskImages?: Array<DataDiskImageEncryptionOutput>;\n}\n\n/** Contains encryption settings for an OS disk image. */\nexport interface OSDiskImageEncryptionOutput extends DiskImageEncryptionOutput {\n /** This property specifies the security profile of an OS disk image. */\n securityProfile?: OSDiskImageSecurityProfileOutput;\n}\n\n/** Contains security profile for an OS disk image. */\nexport interface OSDiskImageSecurityProfileOutput {\n /** confidential VM encryption types */\n confidentialVMEncryptionType?:\n | \"EncryptedVMGuestStateOnlyWithPmk\"\n | \"EncryptedWithPmk\"\n | \"EncryptedWithCmk\";\n /** secure VM disk encryption set id */\n secureVMDiskEncryptionSetId?: string;\n}\n\n/** This is the disk image encryption base class. */\nexport interface DiskImageEncryptionOutput {\n /** A relative URI containing the resource ID of the disk encryption set. */\n diskEncryptionSetId?: string;\n}\n\n/** Contains encryption settings for a data disk image. */\nexport interface DataDiskImageEncryptionOutput extends DiskImageEncryptionOutput {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\nexport interface GalleryTargetExtendedLocationOutput {\n /** The name of the region. */\n name?: string;\n /** The name of the extended location. */\n extendedLocation?: GalleryExtendedLocationOutput;\n /** The number of replicas of the Image Version to be created per extended location. This property is updatable. */\n extendedLocationReplicaCount?: number;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: \"Standard_LRS\" | \"Standard_ZRS\" | \"Premium_LRS\";\n /** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\n encryption?: EncryptionImagesOutput;\n}\n\n/** The name of the extended location. */\nexport interface GalleryExtendedLocationOutput {\n name?: string;\n /** It is type of the extended location. */\n type?: \"EdgeZone\" | \"Unknown\";\n}\n\n/** This is the storage profile of a Gallery Image Version. */\nexport interface GalleryImageVersionStorageProfileOutput {\n /** The gallery artifact version source. */\n source?: GalleryArtifactVersionSourceOutput;\n /** This is the OS disk image. */\n osDiskImage?: GalleryOSDiskImageOutput;\n /** A list of data disk images. */\n dataDiskImages?: Array<GalleryDataDiskImageOutput>;\n}\n\n/** The gallery artifact version source. */\nexport interface GalleryArtifactVersionSourceOutput {\n /** The id of the gallery artifact version source. Can specify a disk uri, snapshot uri, user image or storage account resource. */\n id?: string;\n /** The uri of the gallery artifact version source. Currently used to specify vhd/blob source. */\n uri?: string;\n}\n\n/** This is the OS disk image. */\nexport interface GalleryOSDiskImageOutput extends GalleryDiskImageOutput {}\n\n/** This is the disk image base class. */\nexport interface GalleryDiskImageOutput {\n /** This property indicates the size of the VHD to be created. */\n readonly sizeInGB?: number;\n /** The host caching of the disk. Valid values are 'None', 'ReadOnly', and 'ReadWrite' */\n hostCaching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** The gallery artifact version source. */\n source?: GalleryArtifactVersionSourceOutput;\n}\n\n/** This is the data disk image. */\nexport interface GalleryDataDiskImageOutput extends GalleryDiskImageOutput {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\n/** This is the replication status of the gallery image version. */\nexport interface ReplicationStatusOutput {\n /** This is the aggregated replication status based on all the regional replication status flags. */\n readonly aggregatedState?: \"Unknown\" | \"InProgress\" | \"Completed\" | \"Failed\";\n /** This is a summary of replication status for each region. */\n readonly summary?: Array<RegionalReplicationStatusOutput>;\n}\n\n/** This is the regional replication status. */\nexport interface RegionalReplicationStatusOutput {\n /** The region to which the gallery image version is being replicated to. */\n readonly region?: string;\n /** This is the regional replication state. */\n readonly state?: \"Unknown\" | \"Replicating\" | \"Completed\" | \"Failed\";\n /** The details of the replication status. */\n readonly details?: string;\n /** It indicates progress of the replication job. */\n readonly progress?: number;\n}\n\n/** Specifies information about the gallery Application Definition that you want to create or update. */\nexport interface GalleryApplicationOutput extends ResourceOutput {\n /** Describes the properties of a gallery Application Definition. */\n properties?: GalleryApplicationPropertiesOutput;\n}\n\n/** Describes the properties of a gallery Application Definition. */\nexport interface GalleryApplicationPropertiesOutput {\n /** The description of this gallery Application Definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery Application Definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** The end of life date of the gallery Application Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** This property allows you to specify the supported type of the OS that application is built for. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n supportedOSType: \"Windows\" | \"Linux\";\n}\n\n/** Specifies information about the gallery Application Version that you want to create or update. */\nexport interface GalleryApplicationVersionOutput extends ResourceOutput {\n /** Describes the properties of a gallery image version. */\n properties?: GalleryApplicationVersionPropertiesOutput;\n}\n\n/** Describes the properties of a gallery image version. */\nexport interface GalleryApplicationVersionPropertiesOutput {\n /** The publishing profile of a gallery image version. */\n publishingProfile: GalleryApplicationVersionPublishingProfileOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?:\n | \"Creating\"\n | \"Updating\"\n | \"Failed\"\n | \"Succeeded\"\n | \"Deleting\"\n | \"Migrating\";\n /** This is the replication status of the gallery image version. */\n readonly replicationStatus?: ReplicationStatusOutput;\n}\n\n/** The publishing profile of a gallery image version. */\nexport interface GalleryApplicationVersionPublishingProfileOutput\n extends GalleryArtifactPublishingProfileBaseOutput {\n /** The source image from which the Image Version is going to be created. */\n source: UserArtifactSourceOutput;\n manageActions?: UserArtifactManageOutput;\n /** Additional settings for the VM app that contains the target package and config file name when it is deployed to target VM or VM scale set. */\n settings?: UserArtifactSettingsOutput;\n /** Optional. Additional settings to pass to the vm-application-manager extension. For advanced use only. */\n advancedSettings?: Record<string, string>;\n /** Optional. Whether or not this application reports health. */\n enableHealthCheck?: boolean;\n}\n\n/** The source image from which the Image Version is going to be created. */\nexport interface UserArtifactSourceOutput {\n /** Required. The mediaLink of the artifact, must be a readable storage page blob. */\n mediaLink: string;\n /** Optional. The defaultConfigurationLink of the artifact, must be a readable storage page blob. */\n defaultConfigurationLink?: string;\n}\n\nexport interface UserArtifactManageOutput {\n /** Required. The path and arguments to install the gallery application. This is limited to 4096 characters. */\n install: string;\n /** Required. The path and arguments to remove the gallery application. This is limited to 4096 characters. */\n remove: string;\n /** Optional. The path and arguments to update the gallery application. If not present, then update operation will invoke remove command on the previous version and install command on the current version of the gallery application. This is limited to 4096 characters. */\n update?: string;\n}\n\n/** Additional settings for the VM app that contains the target package and config file name when it is deployed to target VM or VM scale set. */\nexport interface UserArtifactSettingsOutput {\n /** Optional. The name to assign the downloaded package file on the VM. This is limited to 4096 characters. If not specified, the package file will be named the same as the Gallery Application name. */\n packageFileName?: string;\n /** Optional. The name to assign the downloaded config file on the VM. This is limited to 4096 characters. If not specified, the config file will be named the Gallery Application name appended with \"_config\". */\n configFileName?: string;\n}\n\n/** The List Galleries operation response. */\nexport interface GalleryListOutput {\n /** A list of galleries. */\n value: Array<GalleryOutput>;\n /** The uri to fetch the next page of galleries. Call ListNext() with this to fetch the next page of galleries. */\n nextLink?: string;\n}\n\n/** The List Gallery Images operation response. */\nexport interface GalleryImageListOutput {\n /** A list of Shared Image Gallery images. */\n value: Array<GalleryImageOutput>;\n /** The uri to fetch the next page of Image Definitions in the Shared Image Gallery. Call ListNext() with this to fetch the next page of gallery image definitions. */\n nextLink?: string;\n}\n\n/** The List Gallery Image version operation response. */\nexport interface GalleryImageVersionListOutput {\n /** A list of gallery image versions. */\n value: Array<GalleryImageVersionOutput>;\n /** The uri to fetch the next page of gallery image versions. Call ListNext() with this to fetch the next page of gallery image versions. */\n nextLink?: string;\n}\n\n/** The List Gallery Applications operation response. */\nexport interface GalleryApplicationListOutput {\n /** A list of Gallery Applications. */\n value: Array<GalleryApplicationOutput>;\n /** The uri to fetch the next page of Application Definitions in the Application Gallery. Call ListNext() with this to fetch the next page of gallery Application Definitions. */\n nextLink?: string;\n}\n\n/** The List Gallery Application version operation response. */\nexport interface GalleryApplicationVersionListOutput {\n /** A list of gallery Application Versions. */\n value: Array<GalleryApplicationVersionOutput>;\n /** The uri to fetch the next page of gallery Application Versions. Call ListNext() with this to fetch the next page of gallery Application Versions. */\n nextLink?: string;\n}\n\n/** Specifies information about the gallery sharing profile update. */\nexport interface SharingUpdateOutput {\n /** This property allows you to specify the operation type of gallery sharing update. <br><br> Possible values are: <br><br> **Add** <br><br> **Remove** <br><br> **Reset** */\n operationType: \"Add\" | \"Remove\" | \"Reset\" | \"EnableCommunity\";\n /** A list of sharing profile groups. */\n groups?: Array<SharingProfileGroupOutput>;\n}\n\n/** The List Shared Galleries operation response. */\nexport interface SharedGalleryListOutput {\n /** A list of shared galleries. */\n value: Array<SharedGalleryOutput>;\n /** The uri to fetch the next page of shared galleries. Call ListNext() with this to fetch the next page of shared galleries. */\n nextLink?: string;\n}\n\n/** Specifies information about the Shared Gallery that you want to create or update. */\nexport interface SharedGalleryOutput extends PirSharedGalleryResourceOutput {}\n\n/** Base information about the shared gallery resource in pir. */\nexport interface PirSharedGalleryResourceOutput extends PirResourceOutput {\n /** The identifier information of shared gallery. */\n identifier?: SharedGalleryIdentifierOutput;\n}\n\n/** The identifier information of shared gallery. */\nexport interface SharedGalleryIdentifierOutput {\n /** The unique id of this shared gallery. */\n uniqueId?: string;\n}\n\n/** The Resource model definition. */\nexport interface PirResourceOutput {\n /** Resource name */\n readonly name?: string;\n /** Resource location */\n readonly location?: string;\n}\n\n/** The List Shared Gallery Images operation response. */\nexport interface SharedGalleryImageListOutput {\n /** A list of shared gallery images. */\n value: Array<SharedGalleryImageOutput>;\n /** The uri to fetch the next page of shared gallery images. Call ListNext() with this to fetch the next page of shared gallery images. */\n nextLink?: string;\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface SharedGalleryImageOutput extends PirSharedGalleryResourceOutput {\n /** Describes the properties of a gallery image definition. */\n properties?: SharedGalleryImagePropertiesOutput;\n}\n\n/** Describes the properties of a gallery image definition. */\nexport interface SharedGalleryImagePropertiesOutput {\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType: \"Windows\" | \"Linux\";\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState: \"Generalized\" | \"Specialized\";\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** This is the gallery image definition identifier. */\n identifier: GalleryImageIdentifierOutput;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfigurationOutput;\n /** Describes the disallowed disk types. */\n disallowed?: DisallowedOutput;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** A list of gallery image features. */\n features?: Array<GalleryImageFeatureOutput>;\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlanOutput;\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: \"x64\" | \"Arm64\";\n}\n\n/** The List Shared Gallery Image versions operation response. */\nexport interface SharedGalleryImageVersionListOutput {\n /** A list of shared gallery images versions. */\n value: Array<SharedGalleryImageVersionOutput>;\n /** The uri to fetch the next page of shared gallery image versions. Call ListNext() with this to fetch the next page of shared gallery image versions. */\n nextLink?: string;\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface SharedGalleryImageVersionOutput extends PirSharedGalleryResourceOutput {\n /** Describes the properties of a gallery image version. */\n properties?: SharedGalleryImageVersionPropertiesOutput;\n}\n\n/** Describes the properties of a gallery image version. */\nexport interface SharedGalleryImageVersionPropertiesOutput {\n /** The published date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n publishedDate?: string;\n /** The end of life date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /** Describes the storage profile of the image version. */\n storageProfile?: SharedGalleryImageVersionStorageProfileOutput;\n}\n\n/** This is the storage profile of a Gallery Image Version. */\nexport interface SharedGalleryImageVersionStorageProfileOutput {\n /** This is the OS disk image. */\n osDiskImage?: SharedGalleryOSDiskImageOutput;\n /** A list of data disk images. */\n dataDiskImages?: Array<SharedGalleryDataDiskImageOutput>;\n}\n\n/** This is the OS disk image. */\nexport interface SharedGalleryOSDiskImageOutput extends SharedGalleryDiskImageOutput {}\n\n/** This is the disk image base class. */\nexport interface SharedGalleryDiskImageOutput {\n /** This property indicates the size of the VHD to be created. */\n readonly diskSizeGB?: number;\n /** The host caching of the disk. Valid values are 'None', 'ReadOnly', and 'ReadWrite' */\n hostCaching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n}\n\n/** This is the data disk image. */\nexport interface SharedGalleryDataDiskImageOutput extends SharedGalleryDiskImageOutput {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\n/** Specifies information about the Community Gallery that you want to create or update. */\nexport interface CommunityGalleryOutput extends PirCommunityGalleryResourceOutput {}\n\n/** Base information about the community gallery resource in pir. */\nexport interface PirCommunityGalleryResourceOutput {\n /** Resource name */\n readonly name?: string;\n /** Resource location */\n readonly location?: string;\n /** Resource type */\n readonly type?: string;\n /** The identifier information of community gallery. */\n identifier?: CommunityGalleryIdentifierOutput;\n}\n\n/** The identifier information of community gallery. */\nexport interface CommunityGalleryIdentifierOutput {\n /** The unique id of this community gallery. */\n uniqueId?: string;\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface CommunityGalleryImageOutput extends PirCommunityGalleryResourceOutput {\n /** Describes the properties of a gallery image definition. */\n properties?: CommunityGalleryImagePropertiesOutput;\n}\n\n/** Describes the properties of a gallery image definition. */\nexport interface CommunityGalleryImagePropertiesOutput {\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType: \"Windows\" | \"Linux\";\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState: \"Generalized\" | \"Specialized\";\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** This is the gallery image definition identifier. */\n identifier: GalleryImageIdentifierOutput;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfigurationOutput;\n /** Describes the disallowed disk types. */\n disallowed?: DisallowedOutput;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** A list of gallery image features. */\n features?: Array<GalleryImageFeatureOutput>;\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlanOutput;\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: \"x64\" | \"Arm64\";\n /** Privacy statement uri for the current community gallery image. */\n privacyStatementUri?: string;\n /** End-user license agreement for the current community gallery image. */\n eula?: string;\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface CommunityGalleryImageVersionOutput extends PirCommunityGalleryResourceOutput {\n /** Describes the properties of a gallery image version. */\n properties?: CommunityGalleryImageVersionPropertiesOutput;\n}\n\n/** Describes the properties of a gallery image version. */\nexport interface CommunityGalleryImageVersionPropertiesOutput {\n /** The published date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n publishedDate?: string;\n /** The end of life date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /** Describes the storage profile of the image version. */\n storageProfile?: SharedGalleryImageVersionStorageProfileOutput;\n}\n\n/** The List Community Gallery Images operation response. */\nexport interface CommunityGalleryImageListOutput {\n /** A list of community gallery images. */\n value: Array<CommunityGalleryImageOutput>;\n /** The uri to fetch the next page of community gallery images. Call ListNext() with this to fetch the next page of community gallery images. */\n nextLink?: string;\n}\n\n/** The List Community Gallery Image versions operation response. */\nexport interface CommunityGalleryImageVersionListOutput {\n /** A list of community gallery image versions. */\n value: Array<CommunityGalleryImageVersionOutput>;\n /** The uri to fetch the next page of community gallery image versions. Call ListNext() with this to fetch the next page of community gallery image versions. */\n nextLink?: string;\n}\n\n/** Describes the cloud service role instance. */\nexport interface RoleInstanceOutput {\n /** Resource Id */\n readonly id?: string;\n /** Resource Name. */\n readonly name?: string;\n /** Resource Type. */\n readonly type?: string;\n /** Resource Location. */\n readonly location?: string;\n /** Resource tags. */\n readonly tags?: Record<string, string>;\n /** The role instance SKU. */\n sku?: InstanceSkuOutput;\n /** Role instance properties. */\n properties?: RoleInstancePropertiesOutput;\n}\n\n/** The role instance SKU. */\nexport interface InstanceSkuOutput {\n /** The sku name. */\n readonly name?: string;\n /** The tier of the cloud service role instance. */\n readonly tier?: string;\n}\n\n/** Role instance properties. */\nexport interface RoleInstancePropertiesOutput {\n /** Describes the network profile for the role instance. */\n networkProfile?: RoleInstanceNetworkProfileOutput;\n /** The instance view of the role instance. */\n instanceView?: RoleInstanceViewOutput;\n}\n\n/** Describes the network profile for the role instance. */\nexport interface RoleInstanceNetworkProfileOutput {\n /** Specifies the list of resource Ids for the network interfaces associated with the role instance. */\n readonly networkInterfaces?: Array<SubResourceOutput>;\n}\n\n/** The instance view of the role instance. */\nexport interface RoleInstanceViewOutput {\n /** The Update Domain. */\n readonly platformUpdateDomain?: number;\n /** The Fault Domain. */\n readonly platformFaultDomain?: number;\n /** Specifies a unique identifier generated internally for the cloud service associated with this role instance. <br /><br /> NOTE: If you are using Azure Diagnostics extension, this property can be used as 'DeploymentId' for querying details. */\n readonly privateId?: string;\n readonly statuses?: Array<ResourceInstanceViewStatusOutput>;\n}\n\n/** Instance view status. */\nexport interface ResourceInstanceViewStatusOutput {\n /** The status code. */\n readonly code?: string;\n /** The short localizable label for the status. */\n readonly displayStatus?: string;\n /** The detailed status message, including for alerts and error messages. */\n readonly message?: string;\n /** The time of the status. */\n readonly time?: string;\n /** The level code. */\n level?: \"Info\" | \"Warning\" | \"Error\";\n}\n\n/** The list operation result. */\nexport interface RoleInstanceListResultOutput {\n /** The list of resources. */\n value: Array<RoleInstanceOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a role of the cloud service. */\nexport interface CloudServiceRoleOutput {\n /** Resource id */\n readonly id?: string;\n /** Resource name */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Resource location */\n readonly location?: string;\n /** Describes the cloud service role sku. */\n sku?: CloudServiceRoleSkuOutput;\n /** The cloud service role properties. */\n properties?: CloudServiceRolePropertiesOutput;\n}\n\n/** Describes the cloud service role sku. */\nexport interface CloudServiceRoleSkuOutput {\n /** The sku name. NOTE: If the new SKU is not supported on the hardware the cloud service is currently on, you need to delete and recreate the cloud service or move back to the old sku. */\n name?: string;\n /** Specifies the tier of the cloud service. Possible Values are <br /><br /> **Standard** <br /><br /> **Basic** */\n tier?: string;\n /** Specifies the number of role instances in the cloud service. */\n capacity?: number;\n}\n\n/** The cloud service role properties. */\nexport interface CloudServiceRolePropertiesOutput {\n /** Specifies the ID which uniquely identifies a cloud service role. */\n readonly uniqueId?: string;\n}\n\n/** The list operation result. */\nexport interface CloudServiceRoleListResultOutput {\n /** The list of resources. */\n value: Array<CloudServiceRoleOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes the cloud service. */\nexport interface CloudServiceOutput {\n /** Resource Id. */\n readonly id?: string;\n /** Resource name. */\n readonly name?: string;\n /** Resource type. */\n readonly type?: string;\n /** Resource location. */\n location: string;\n /** Resource tags. */\n tags?: Record<string, string>;\n /** Cloud service properties */\n properties?: CloudServicePropertiesOutput;\n /** The system meta data relating to this resource. */\n systemData?: SystemDataOutput;\n}\n\n/** Cloud service properties */\nexport interface CloudServicePropertiesOutput {\n /**\n * Specifies a URL that refers to the location of the service package in the Blob service. The service package URL can be Shared Access Signature (SAS) URI from any storage account.\n * This is a write-only property and is not returned in GET calls.\n */\n packageUrl?: string;\n /** Specifies the XML service configuration (.cscfg) for the cloud service. */\n configuration?: string;\n /**\n * Specifies a URL that refers to the location of the service configuration in the Blob service. The service package URL can be Shared Access Signature (SAS) URI from any storage account.\n * This is a write-only property and is not returned in GET calls.\n */\n configurationUrl?: string;\n /**\n * (Optional) Indicates whether to start the cloud service immediately after it is created. The default value is `true`.\n * If false, the service model is still deployed, but the code is not run immediately. Instead, the service is PoweredOff until you call Start, at which time the service will be started. A deployed service still incurs charges, even if it is poweredoff.\n */\n startCloudService?: boolean;\n /**\n * (Optional) Indicates whether the role sku properties (roleProfile.roles.sku) specified in the model/template should override the role instance count and vm size specified in the .cscfg and .csdef respectively.\n * The default value is `false`.\n */\n allowModelOverride?: boolean;\n /**\n * Update mode for the cloud service. Role instances are allocated to update domains when the service is deployed. Updates can be initiated manually in each update domain or initiated automatically in all update domains.\n * Possible Values are <br /><br />**Auto**<br /><br />**Manual** <br /><br />**Simultaneous**<br /><br />\n * If not specified, the default value is Auto. If set to Manual, PUT UpdateDomain must be called to apply the update. If set to Auto, the update is automatically applied to each update domain in sequence.\n */\n upgradeMode?: \"Auto\" | \"Manual\" | \"Simultaneous\";\n /** Describes the role profile for the cloud service. */\n roleProfile?: CloudServiceRoleProfileOutput;\n /** Describes the OS profile for the cloud service. */\n osProfile?: CloudServiceOsProfileOutput;\n /** Network Profile for the cloud service. */\n networkProfile?: CloudServiceNetworkProfileOutput;\n /** Describes a cloud service extension profile. */\n extensionProfile?: CloudServiceExtensionProfileOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The unique identifier for the cloud service. */\n readonly uniqueId?: string;\n}\n\n/** Describes the role profile for the cloud service. */\nexport interface CloudServiceRoleProfileOutput {\n /** List of roles for the cloud service. */\n roles?: Array<CloudServiceRoleProfilePropertiesOutput>;\n}\n\n/** Describes the role properties. */\nexport interface CloudServiceRoleProfilePropertiesOutput {\n /** Resource name. */\n name?: string;\n /** Describes the cloud service role sku. */\n sku?: CloudServiceRoleSkuOutput;\n}\n\n/** Describes the OS profile for the cloud service. */\nexport interface CloudServiceOsProfileOutput {\n /** Specifies set of certificates that should be installed onto the role instances. */\n secrets?: Array<CloudServiceVaultSecretGroupOutput>;\n}\n\n/** Describes a set of certificates which are all in the same Key Vault. */\nexport interface CloudServiceVaultSecretGroupOutput {\n /** The relative URL of the Key Vault containing all of the certificates in VaultCertificates. */\n sourceVault?: SubResourceOutput;\n /** The list of key vault references in SourceVault which contain certificates. */\n vaultCertificates?: Array<CloudServiceVaultCertificateOutput>;\n}\n\n/** Describes a single certificate reference in a Key Vault, and where the certificate should reside on the role instance. */\nexport interface CloudServiceVaultCertificateOutput {\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. */\n certificateUrl?: string;\n}\n\n/** Network Profile for the cloud service. */\nexport interface CloudServiceNetworkProfileOutput {\n /** List of Load balancer configurations. Cloud service can have up to two load balancer configurations, corresponding to a Public Load Balancer and an Internal Load Balancer. */\n loadBalancerConfigurations?: Array<LoadBalancerConfigurationOutput>;\n /**\n * Slot type for the cloud service.\n * Possible values are <br /><br />**Production**<br /><br />**Staging**<br /><br />\n * If not specified, the default value is Production.\n */\n slotType?: \"Production\" | \"Staging\";\n /** The id reference of the cloud service containing the target IP with which the subject cloud service can perform a swap. This property cannot be updated once it is set. The swappable cloud service referred by this id must be present otherwise an error will be thrown. */\n swappableCloudService?: SubResourceOutput;\n}\n\n/** Describes the load balancer configuration. */\nexport interface LoadBalancerConfigurationOutput {\n /** Resource Id */\n id?: string;\n /** The name of the Load balancer */\n name: string;\n /** Properties of the load balancer configuration. */\n properties: LoadBalancerConfigurationPropertiesOutput;\n}\n\n/** Describes the properties of the load balancer configuration. */\nexport interface LoadBalancerConfigurationPropertiesOutput {\n /** Specifies the frontend IP to be used for the load balancer. Only IPv4 frontend IP address is supported. Each load balancer configuration must have exactly one frontend IP configuration. */\n frontendIPConfigurations: Array<LoadBalancerFrontendIPConfigurationOutput>;\n}\n\n/** Specifies the frontend IP to be used for the load balancer. Only IPv4 frontend IP address is supported. Each load balancer configuration must have exactly one frontend IP configuration. */\nexport interface LoadBalancerFrontendIPConfigurationOutput {\n /** The name of the resource that is unique within the set of frontend IP configurations used by the load balancer. This name can be used to access the resource. */\n name: string;\n /** Properties of load balancer frontend ip configuration. */\n properties: LoadBalancerFrontendIPConfigurationPropertiesOutput;\n}\n\n/** Describes a cloud service IP Configuration */\nexport interface LoadBalancerFrontendIPConfigurationPropertiesOutput {\n /** The reference to the public ip address resource. */\n publicIPAddress?: SubResourceOutput;\n /** The reference to the virtual network subnet resource. */\n subnet?: SubResourceOutput;\n /** The virtual network private IP address of the IP configuration. */\n privateIPAddress?: string;\n}\n\n/** Describes a cloud service extension profile. */\nexport interface CloudServiceExtensionProfileOutput {\n /** List of extensions for the cloud service. */\n extensions?: Array<ExtensionOutput>;\n}\n\n/** Describes a cloud service Extension. */\nexport interface ExtensionOutput {\n /** The name of the extension. */\n name?: string;\n /** Extension Properties. */\n properties?: CloudServiceExtensionPropertiesOutput;\n}\n\n/** Extension Properties. */\nexport interface CloudServiceExtensionPropertiesOutput {\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension. */\n type?: string;\n /** Specifies the version of the extension. Specifies the version of the extension. If this element is not specified or an asterisk (*) is used as the value, the latest version of the extension is used. If the value is specified with a major version number and an asterisk as the minor version number (X.), the latest minor version of the specified major version is selected. If a major version number and a minor version number are specified (X.Y), the specific extension version is selected. If a version is specified, an auto-upgrade is performed on the role instance. */\n typeHandlerVersion?: string;\n /** Explicitly specify whether platform can automatically upgrade typeHandlerVersion to higher minor versions when they become available. */\n autoUpgradeMinorVersion?: boolean;\n /** Public settings for the extension. For JSON extensions, this is the JSON settings for the extension. For XML Extension (like RDP), this is the XML setting for the extension. */\n settings?: any;\n /** Protected settings for the extension which are encrypted before sent to the role instance. */\n protectedSettings?: any;\n /** Protected settings for the extension, referenced using KeyVault which are encrypted before sent to the role instance. */\n protectedSettingsFromKeyVault?: CloudServiceVaultAndSecretReferenceOutput;\n /**\n * Tag to force apply the provided public and protected settings.\n * Changing the tag value allows for re-running the extension without changing any of the public or protected settings.\n * If forceUpdateTag is not changed, updates to public or protected settings would still be applied by the handler.\n * If neither forceUpdateTag nor any of public or protected settings change, extension would flow to the role instance with the same sequence-number, and\n * it is up to handler implementation whether to re-run it or not\n */\n forceUpdateTag?: string;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** Optional list of roles to apply this extension. If property is not specified or '*' is specified, extension is applied to all roles in the cloud service. */\n rolesAppliedTo?: Array<string>;\n}\n\n/** Protected settings for the extension, referenced using KeyVault which are encrypted before sent to the role instance. */\nexport interface CloudServiceVaultAndSecretReferenceOutput {\n /** The ARM Resource ID of the Key Vault */\n sourceVault?: SubResourceOutput;\n /** Secret URL which contains the protected settings of the extension */\n secretUrl?: string;\n}\n\n/** The system meta data relating to this resource. */\nexport interface SystemDataOutput {\n /** Specifies the time in UTC at which the Cloud Service (extended support) resource was created. <br />Minimum api-version: 2022-04-04. */\n readonly createdAt?: string;\n /** Specifies the time in UTC at which the Cloud Service (extended support) resource was last modified. <br />Minimum api-version: 2022-04-04. */\n readonly lastModifiedAt?: string;\n}\n\n/** InstanceView of CloudService as a whole */\nexport interface CloudServiceInstanceViewOutput {\n /** Instance view statuses. */\n roleInstance?: InstanceViewStatusesSummaryOutput;\n /** The version of the SDK that was used to generate the package for the cloud service. */\n readonly sdkVersion?: string;\n /** Specifies a list of unique identifiers generated internally for the cloud service. <br /><br /> NOTE: If you are using Azure Diagnostics extension, this property can be used as 'DeploymentId' for querying details. */\n readonly privateIds?: Array<string>;\n readonly statuses?: Array<ResourceInstanceViewStatusOutput>;\n}\n\n/** Instance view statuses. */\nexport interface InstanceViewStatusesSummaryOutput {\n /** The summary. */\n readonly statusesSummary?: Array<StatusCodeCountOutput>;\n}\n\n/** The status code and count of the cloud service instance view statuses */\nexport interface StatusCodeCountOutput {\n /** The instance view status code */\n readonly code?: string;\n /** Number of instances having this status code */\n readonly count?: number;\n}\n\n/** The list operation result. */\nexport interface CloudServiceListResultOutput {\n /** The list of resources. */\n value: Array<CloudServiceOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Defines an update domain for the cloud service. */\nexport interface UpdateDomainOutput {\n /** Resource Id */\n readonly id?: string;\n /** Resource Name */\n readonly name?: string;\n}\n\n/** The list operation result. */\nexport interface UpdateDomainListResultOutput {\n /** The list of resources. */\n value: Array<UpdateDomainOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a cloud service OS version. */\nexport interface OSVersionOutput {\n /** Resource Id. */\n readonly id?: string;\n /** Resource name. */\n readonly name?: string;\n /** Resource type. */\n readonly type?: string;\n /** Resource location. */\n readonly location?: string;\n /** OS version properties. */\n properties?: OSVersionPropertiesOutput;\n}\n\n/** OS version properties. */\nexport interface OSVersionPropertiesOutput {\n /** The family of this OS version. */\n readonly family?: string;\n /** The family label of this OS version. */\n readonly familyLabel?: string;\n /** The OS version. */\n readonly version?: string;\n /** The OS version label. */\n readonly label?: string;\n /** Specifies whether this is the default OS version for its family. */\n readonly isDefault?: boolean;\n /** Specifies whether this OS version is active. */\n readonly isActive?: boolean;\n}\n\n/** The list operation result. */\nexport interface OSVersionListResultOutput {\n /** The list of resources. */\n value: Array<OSVersionOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a cloud service OS family. */\nexport interface OSFamilyOutput {\n /** Resource Id. */\n readonly id?: string;\n /** Resource name. */\n readonly name?: string;\n /** Resource type. */\n readonly type?: string;\n /** Resource location. */\n readonly location?: string;\n /** OS family properties. */\n properties?: OSFamilyPropertiesOutput;\n}\n\n/** OS family properties. */\nexport interface OSFamilyPropertiesOutput {\n /** The OS family name. */\n readonly name?: string;\n /** The OS family label. */\n readonly label?: string;\n /** List of OS versions belonging to this family. */\n readonly versions?: Array<OSVersionPropertiesBaseOutput>;\n}\n\n/** Configuration view of an OS version. */\nexport interface OSVersionPropertiesBaseOutput {\n /** The OS version. */\n readonly version?: string;\n /** The OS version label. */\n readonly label?: string;\n /** Specifies whether this is the default OS version for its family. */\n readonly isDefault?: boolean;\n /** Specifies whether this OS version is active. */\n readonly isActive?: boolean;\n}\n\n/** The list operation result. */\nexport interface OSFamilyListResultOutput {\n /** The list of resources. */\n value: Array<OSFamilyOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n"]}
|
|
1
|
+
{"version":3,"file":"outputModels.js","sourceRoot":"","sources":["../../src/outputModels.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/** The List Compute Operation operation response. */\nexport interface ComputeOperationListResultOutput {\n /** The list of compute operations */\n readonly value?: Array<ComputeOperationValueOutput>;\n}\n\n/** Describes the properties of a Compute Operation value. */\nexport interface ComputeOperationValueOutput {\n /** The origin of the compute operation. */\n readonly origin?: string;\n /** The name of the compute operation. */\n readonly name?: string;\n /** Describes the properties of a Compute Operation Value Display. */\n display?: ComputeOperationValueDisplayOutput;\n}\n\n/** Describes the properties of a Compute Operation Value Display. */\nexport interface ComputeOperationValueDisplayOutput {\n /** The display name of the compute operation. */\n readonly operation?: string;\n /** The display name of the resource the operation applies to. */\n readonly resource?: string;\n /** The description of the operation. */\n readonly description?: string;\n /** The resource provider for the operation. */\n readonly provider?: string;\n}\n\n/** An error response from the Compute service. */\nexport interface CloudErrorOutput {\n /** Api error. */\n error?: ApiErrorOutput;\n}\n\n/** Api error. */\nexport interface ApiErrorOutput {\n /** The Api error details */\n details?: Array<ApiErrorBaseOutput>;\n /** The Api inner error */\n innererror?: InnerErrorOutput;\n /** The error code. */\n code?: string;\n /** The target of the particular error. */\n target?: string;\n /** The error message. */\n message?: string;\n}\n\n/** Api error base. */\nexport interface ApiErrorBaseOutput {\n /** The error code. */\n code?: string;\n /** The target of the particular error. */\n target?: string;\n /** The error message. */\n message?: string;\n}\n\n/** Inner error details. */\nexport interface InnerErrorOutput {\n /** The exception type. */\n exceptiontype?: string;\n /** The internal error message or exception dump. */\n errordetail?: string;\n}\n\n/** The List Usages operation response. */\nexport interface ListUsagesResultOutput {\n /** The list of compute resource usages. */\n value: Array<UsageOutput>;\n /** The URI to fetch the next page of compute resource usage information. Call ListNext() with this to fetch the next page of compute resource usage information. */\n nextLink?: string;\n}\n\n/** Describes Compute Resource Usage. */\nexport interface UsageOutput {\n /** An enum describing the unit of usage measurement. */\n unit: \"Count\";\n /** The current usage of the resource. */\n currentValue: number;\n /** The maximum permitted usage of the resource. */\n limit: number;\n /** The name of the type of usage. */\n name: UsageNameOutput;\n}\n\n/** The Usage Names. */\nexport interface UsageNameOutput {\n /** The name of the resource. */\n value?: string;\n /** The localized name of the resource. */\n localizedValue?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineSizeListResultOutput {\n /** The list of virtual machine sizes. */\n value?: Array<VirtualMachineSizeOutput>;\n}\n\n/** Describes the properties of a VM size. */\nexport interface VirtualMachineSizeOutput {\n /** The name of the virtual machine size. */\n name?: string;\n /** The number of cores supported by the virtual machine size. For Constrained vCPU capable VM sizes, this number represents the total vCPUs of quota that the VM uses. For accurate vCPU count, please refer to https://docs.microsoft.com/azure/virtual-machines/constrained-vcpu or https://docs.microsoft.com/rest/api/compute/resourceskus/list */\n numberOfCores?: number;\n /** The OS disk size, in MB, allowed by the virtual machine size. */\n osDiskSizeInMB?: number;\n /** The resource disk size, in MB, allowed by the virtual machine size. */\n resourceDiskSizeInMB?: number;\n /** The amount of memory, in MB, supported by the virtual machine size. */\n memoryInMB?: number;\n /** The maximum number of data disks that can be attached to the virtual machine size. */\n maxDataDiskCount?: number;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineScaleSetListResultOutput {\n /** The list of virtual machine scale sets. */\n value: Array<VirtualMachineScaleSetOutput>;\n /** The uri to fetch the next page of Virtual Machine Scale Sets. Call ListNext() with this to fetch the next page of VMSS. */\n nextLink?: string;\n}\n\n/** Describes a Virtual Machine Scale Set. */\nexport interface VirtualMachineScaleSetOutput extends ResourceOutput {\n /** The virtual machine scale set sku. */\n sku?: SkuOutput;\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: PlanOutput;\n /** Describes the properties of a Virtual Machine Scale Set. */\n properties?: VirtualMachineScaleSetPropertiesOutput;\n /** The identity of the virtual machine scale set, if configured. */\n identity?: VirtualMachineScaleSetIdentityOutput;\n /** The virtual machine scale set zones. NOTE: Availability zones can only be set when you create the scale set */\n zones?: Array<string>;\n /** The extended location of the Virtual Machine Scale Set. */\n extendedLocation?: ExtendedLocationOutput;\n}\n\n/** Describes a virtual machine scale set sku. NOTE: If the new VM SKU is not supported on the hardware the scale set is currently on, you need to deallocate the VMs in the scale set before you modify the SKU name. */\nexport interface SkuOutput {\n /** The sku name. */\n name?: string;\n /** Specifies the tier of virtual machines in a scale set.<br /><br /> Possible Values:<br /><br /> **Standard**<br /><br /> **Basic** */\n tier?: string;\n /** Specifies the number of virtual machines in the scale set. */\n capacity?: number;\n}\n\n/** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\nexport interface PlanOutput {\n /** The plan ID. */\n name?: string;\n /** The publisher ID. */\n publisher?: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product?: string;\n /** The promotion code. */\n promotionCode?: string;\n}\n\n/** Describes the properties of a Virtual Machine Scale Set. */\nexport interface VirtualMachineScaleSetPropertiesOutput {\n /** The upgrade policy. */\n upgradePolicy?: UpgradePolicyOutput;\n /** Policy for automatic repairs. */\n automaticRepairsPolicy?: AutomaticRepairsPolicyOutput;\n /** The virtual machine profile. */\n virtualMachineProfile?: VirtualMachineScaleSetVMProfileOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** Specifies whether the Virtual Machine Scale Set should be overprovisioned. */\n overprovision?: boolean;\n /** When Overprovision is enabled, extensions are launched only on the requested number of VMs which are finally kept. This property will hence ensure that the extensions do not run on the extra overprovisioned VMs. */\n doNotRunExtensionsOnOverprovisionedVMs?: boolean;\n /** Specifies the ID which uniquely identifies a Virtual Machine Scale Set. */\n readonly uniqueId?: string;\n /** When true this limits the scale set to a single placement group, of max size 100 virtual machines. NOTE: If singlePlacementGroup is true, it may be modified to false. However, if singlePlacementGroup is false, it may not be modified to true. */\n singlePlacementGroup?: boolean;\n /** Whether to force strictly even Virtual Machine distribution cross x-zones in case there is zone outage. zoneBalance property can only be set if the zones property of the scale set contains more than one zone. If there are no zones or only one zone specified, then zoneBalance property should not be set. */\n zoneBalance?: boolean;\n /** Fault Domain count for each placement group. */\n platformFaultDomainCount?: number;\n /** Specifies information about the proximity placement group that the virtual machine scale set should be assigned to. <br><br>Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResourceOutput;\n /** Specifies information about the dedicated host group that the virtual machine scale set resides in. <br><br>Minimum api-version: 2020-06-01. */\n hostGroup?: SubResourceOutput;\n /** Specifies additional capabilities enabled or disabled on the Virtual Machines in the Virtual Machine Scale Set. For instance: whether the Virtual Machines have the capability to support attaching managed data disks with UltraSSD_LRS storage account type. */\n additionalCapabilities?: AdditionalCapabilitiesOutput;\n /** Specifies the policies applied when scaling in Virtual Machines in the Virtual Machine Scale Set. */\n scaleInPolicy?: ScaleInPolicyOutput;\n /** Specifies the orchestration mode for the virtual machine scale set. */\n orchestrationMode?: \"Uniform\" | \"Flexible\";\n /** Specifies the Spot Restore properties for the virtual machine scale set. */\n spotRestorePolicy?: SpotRestorePolicyOutput;\n /** Specifies the desired targets for mixing Spot and Regular priority VMs within the same VMSS Flex instance. */\n priorityMixPolicy?: PriorityMixPolicyOutput;\n /** Specifies the time at which the Virtual Machine Scale Set resource was created.<br><br>Minimum api-version: 2021-11-01. */\n readonly timeCreated?: string;\n}\n\n/** Describes an upgrade policy - automatic, manual, or rolling. */\nexport interface UpgradePolicyOutput {\n /** Specifies the mode of an upgrade to virtual machines in the scale set.<br /><br /> Possible values are:<br /><br /> **Manual** - You control the application of updates to virtual machines in the scale set. You do this by using the manualUpgrade action.<br /><br /> **Automatic** - All virtual machines in the scale set are automatically updated at the same time. */\n mode?: \"Automatic\" | \"Manual\" | \"Rolling\";\n /** The configuration parameters used while performing a rolling upgrade. */\n rollingUpgradePolicy?: RollingUpgradePolicyOutput;\n /** Configuration parameters used for performing automatic OS Upgrade. */\n automaticOSUpgradePolicy?: AutomaticOSUpgradePolicyOutput;\n}\n\n/** The configuration parameters used while performing a rolling upgrade. */\nexport interface RollingUpgradePolicyOutput {\n /** The maximum percent of total virtual machine instances that will be upgraded simultaneously by the rolling upgrade in one batch. As this is a maximum, unhealthy instances in previous or future batches can cause the percentage of instances in a batch to decrease to ensure higher reliability. The default value for this parameter is 20%. */\n maxBatchInstancePercent?: number;\n /** The maximum percentage of the total virtual machine instances in the scale set that can be simultaneously unhealthy, either as a result of being upgraded, or by being found in an unhealthy state by the virtual machine health checks before the rolling upgrade aborts. This constraint will be checked prior to starting any batch. The default value for this parameter is 20%. */\n maxUnhealthyInstancePercent?: number;\n /** The maximum percentage of upgraded virtual machine instances that can be found to be in an unhealthy state. This check will happen after each batch is upgraded. If this percentage is ever exceeded, the rolling update aborts. The default value for this parameter is 20%. */\n maxUnhealthyUpgradedInstancePercent?: number;\n /** The wait time between completing the update for all virtual machines in one batch and starting the next batch. The time duration should be specified in ISO 8601 format. The default value is 0 seconds (PT0S). */\n pauseTimeBetweenBatches?: string;\n /** Allow VMSS to ignore AZ boundaries when constructing upgrade batches. Take into consideration the Update Domain and maxBatchInstancePercent to determine the batch size. */\n enableCrossZoneUpgrade?: boolean;\n /** Upgrade all unhealthy instances in a scale set before any healthy instances. */\n prioritizeUnhealthyInstances?: boolean;\n}\n\n/** The configuration parameters used for performing automatic OS upgrade. */\nexport interface AutomaticOSUpgradePolicyOutput {\n /** Indicates whether OS upgrades should automatically be applied to scale set instances in a rolling fashion when a newer version of the OS image becomes available. Default value is false. <br><br> If this is set to true for Windows based scale sets, [enableAutomaticUpdates](https://docs.microsoft.com/dotnet/api/microsoft.azure.management.compute.models.windowsconfiguration.enableautomaticupdates?view=azure-dotnet) is automatically set to false and cannot be set to true. */\n enableAutomaticOSUpgrade?: boolean;\n /** Whether OS image rollback feature should be disabled. Default value is false. */\n disableAutomaticRollback?: boolean;\n /** Indicates whether rolling upgrade policy should be used during Auto OS Upgrade. Default value is false. Auto OS Upgrade will fallback to the default policy if no policy is defined on the VMSS. */\n useRollingUpgradePolicy?: boolean;\n}\n\n/** Specifies the configuration parameters for automatic repairs on the virtual machine scale set. */\nexport interface AutomaticRepairsPolicyOutput {\n /** Specifies whether automatic repairs should be enabled on the virtual machine scale set. The default value is false. */\n enabled?: boolean;\n /** The amount of time for which automatic repairs are suspended due to a state change on VM. The grace time starts after the state change has completed. This helps avoid premature or accidental repairs. The time duration should be specified in ISO 8601 format. The minimum allowed grace period is 10 minutes (PT10M), which is also the default value. The maximum allowed grace period is 90 minutes (PT90M). */\n gracePeriod?: string;\n /** Type of repair action (replace, restart, reimage) that will be used for repairing unhealthy virtual machines in the scale set. Default value is replace. */\n repairAction?: \"Replace\" | \"Restart\" | \"Reimage\";\n}\n\n/** Describes a virtual machine scale set virtual machine profile. */\nexport interface VirtualMachineScaleSetVMProfileOutput {\n /** Specifies the operating system settings for the virtual machines in the scale set. */\n osProfile?: VirtualMachineScaleSetOSProfileOutput;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: VirtualMachineScaleSetStorageProfileOutput;\n /** Specifies properties of the network interfaces of the virtual machines in the scale set. */\n networkProfile?: VirtualMachineScaleSetNetworkProfileOutput;\n /** Specifies the Security related profile settings for the virtual machines in the scale set. */\n securityProfile?: SecurityProfileOutput;\n /** Specifies the boot diagnostic settings state. <br><br>Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfileOutput;\n /** Specifies a collection of settings for extensions installed on virtual machines in the scale set. */\n extensionProfile?: VirtualMachineScaleSetExtensionProfileOutput;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /** Specifies the priority for the virtual machines in the scale set. <br><br>Minimum api-version: 2017-10-30-preview */\n priority?: \"Regular\" | \"Low\" | \"Spot\";\n /** Specifies the eviction policy for the Azure Spot virtual machine and Azure Spot scale set. <br><br>For Azure Spot virtual machines, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2019-03-01. <br><br>For Azure Spot scale sets, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2017-10-30-preview. */\n evictionPolicy?: \"Deallocate\" | \"Delete\";\n /** Specifies the billing related details of a Azure Spot VMSS. <br><br>Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfileOutput;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfileOutput;\n /** UserData for the virtual machines in the scale set, which must be base-64 encoded. Customer should not pass any secrets in here. <br><br>Minimum api-version: 2021-03-01 */\n userData?: string;\n /** Specifies the capacity reservation related details of a scale set. <br><br>Minimum api-version: 2021-04-01. */\n capacityReservation?: CapacityReservationProfileOutput;\n /** Specifies the gallery applications that should be made available to the VM/VMSS */\n applicationProfile?: ApplicationProfileOutput;\n /** Specifies the hardware profile related details of a scale set. <br><br>Minimum api-version: 2021-11-01. */\n hardwareProfile?: VirtualMachineScaleSetHardwareProfileOutput;\n}\n\n/** Describes a virtual machine scale set OS profile. */\nexport interface VirtualMachineScaleSetOSProfileOutput {\n /** Specifies the computer name prefix for all of the virtual machines in the scale set. Computer name prefixes must be 1 to 15 characters long. */\n computerNamePrefix?: string;\n /** Specifies the name of the administrator account. <br><br> **Windows-only restriction:** Cannot end in \".\" <br><br> **Disallowed values:** \"administrator\", \"admin\", \"user\", \"user1\", \"test\", \"user2\", \"test1\", \"user3\", \"admin1\", \"1\", \"123\", \"a\", \"actuser\", \"adm\", \"admin2\", \"aspnet\", \"backup\", \"console\", \"david\", \"guest\", \"john\", \"owner\", \"root\", \"server\", \"sql\", \"support\", \"support_388945a0\", \"sys\", \"test2\", \"test3\", \"user4\", \"user5\". <br><br> **Minimum-length (Linux):** 1 character <br><br> **Max-length (Linux):** 64 characters <br><br> **Max-length (Windows):** 20 characters */\n adminUsername?: string;\n /** Specifies the password of the administrator account. <br><br> **Minimum-length (Windows):** 8 characters <br><br> **Minimum-length (Linux):** 6 characters <br><br> **Max-length (Windows):** 123 characters <br><br> **Max-length (Linux):** 72 characters <br><br> **Complexity requirements:** 3 out of 4 conditions below need to be fulfilled <br> Has lower characters <br>Has upper characters <br> Has a digit <br> Has a special character (Regex match [\\W_]) <br><br> **Disallowed values:** \"abc@123\", \"P@$$w0rd\", \"P@ssw0rd\", \"P@ssword123\", \"Pa$$word\", \"pass@word1\", \"Password!\", \"Password1\", \"Password22\", \"iloveyou!\" <br><br> For resetting the password, see [How to reset the Remote Desktop service or its login password in a Windows VM](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/reset-rdp) <br><br> For resetting root password, see [Manage users, SSH, and check or repair disks on Azure Linux VMs using the VMAccess Extension](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection) */\n adminPassword?: string;\n /** Specifies a base-64 encoded string of custom data. The base-64 encoded string is decoded to a binary array that is saved as a file on the Virtual Machine. The maximum length of the binary array is 65535 bytes. <br><br> For using cloud-init for your VM, see [Using cloud-init to customize a Linux VM during creation](https://docs.microsoft.com/azure/virtual-machines/linux/using-cloud-init) */\n customData?: string;\n /** Specifies Windows operating system settings on the virtual machine. */\n windowsConfiguration?: WindowsConfigurationOutput;\n /** Specifies the Linux operating system settings on the virtual machine. <br><br>For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\n linuxConfiguration?: LinuxConfigurationOutput;\n /** Specifies set of certificates that should be installed onto the virtual machines in the scale set. To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n secrets?: Array<VaultSecretGroupOutput>;\n /** Specifies whether extension operations should be allowed on the virtual machine scale set. <br><br>This may only be set to False when no extensions are present on the virtual machine scale set. */\n allowExtensionOperations?: boolean;\n}\n\n/** Specifies Windows operating system settings on the virtual machine. */\nexport interface WindowsConfigurationOutput {\n /** Indicates whether virtual machine agent should be provisioned on the virtual machine. <br><br> When this property is not specified in the request body, default behavior is to set it to true. This will ensure that VM Agent is installed on the VM so that extensions can be added to the VM later. */\n provisionVMAgent?: boolean;\n /** Indicates whether Automatic Updates is enabled for the Windows virtual machine. Default value is true. <br><br> For virtual machine scale sets, this property can be updated and updates will take effect on OS reprovisioning. */\n enableAutomaticUpdates?: boolean;\n /** Specifies the time zone of the virtual machine. e.g. \"Pacific Standard Time\". <br><br> Possible values can be [TimeZoneInfo.Id](https://docs.microsoft.com/dotnet/api/system.timezoneinfo.id?#System_TimeZoneInfo_Id) value from time zones returned by [TimeZoneInfo.GetSystemTimeZones](https://docs.microsoft.com/dotnet/api/system.timezoneinfo.getsystemtimezones). */\n timeZone?: string;\n /** Specifies additional base-64 encoded XML formatted information that can be included in the Unattend.xml file, which is used by Windows Setup. */\n additionalUnattendContent?: Array<AdditionalUnattendContentOutput>;\n /** [Preview Feature] Specifies settings related to VM Guest Patching on Windows. */\n patchSettings?: PatchSettingsOutput;\n /** Specifies the Windows Remote Management listeners. This enables remote Windows PowerShell. */\n winRM?: WinRMConfigurationOutput;\n /** Indicates whether VMAgent Platform Updates is enabled for the Windows virtual machine. Default value is false. */\n enableVMAgentPlatformUpdates?: boolean;\n}\n\n/** Specifies additional XML formatted information that can be included in the Unattend.xml file, which is used by Windows Setup. Contents are defined by setting name, component name, and the pass in which the content is applied. */\nexport interface AdditionalUnattendContentOutput {\n /** The pass name. Currently, the only allowable value is OobeSystem. */\n passName?: \"OobeSystem\";\n /** The component name. Currently, the only allowable value is Microsoft-Windows-Shell-Setup. */\n componentName?: \"Microsoft-Windows-Shell-Setup\";\n /** Specifies the name of the setting to which the content applies. Possible values are: FirstLogonCommands and AutoLogon. */\n settingName?: \"AutoLogon\" | \"FirstLogonCommands\";\n /** Specifies the XML formatted content that is added to the unattend.xml file for the specified path and component. The XML must be less than 4KB and must include the root element for the setting or feature that is being inserted. */\n content?: string;\n}\n\n/** Specifies settings related to VM Guest Patching on Windows. */\nexport interface PatchSettingsOutput {\n /** Specifies the mode of VM Guest Patching to IaaS virtual machine or virtual machines associated to virtual machine scale set with OrchestrationMode as Flexible.<br /><br /> Possible values are:<br /><br /> **Manual** - You control the application of patches to a virtual machine. You do this by applying patches manually inside the VM. In this mode, automatic updates are disabled; the property WindowsConfiguration.enableAutomaticUpdates must be false<br /><br /> **AutomaticByOS** - The virtual machine will automatically be updated by the OS. The property WindowsConfiguration.enableAutomaticUpdates must be true. <br /><br /> **AutomaticByPlatform** - the virtual machine will automatically updated by the platform. The properties provisionVMAgent and WindowsConfiguration.enableAutomaticUpdates must be true */\n patchMode?: \"Manual\" | \"AutomaticByOS\" | \"AutomaticByPlatform\";\n /** Enables customers to patch their Azure VMs without requiring a reboot. For enableHotpatching, the 'provisionVMAgent' must be set to true and 'patchMode' must be set to 'AutomaticByPlatform'. */\n enableHotpatching?: boolean;\n /** Specifies the mode of VM Guest patch assessment for the IaaS virtual machine.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - You control the timing of patch assessments on a virtual machine.<br /><br /> **AutomaticByPlatform** - The platform will trigger periodic patch assessments. The property provisionVMAgent must be true. */\n assessmentMode?: \"ImageDefault\" | \"AutomaticByPlatform\";\n /** Specifies additional settings for patch mode AutomaticByPlatform in VM Guest Patching on Windows. */\n automaticByPlatformSettings?: WindowsVMGuestPatchAutomaticByPlatformSettingsOutput;\n}\n\n/** Specifies additional settings to be applied when patch mode AutomaticByPlatform is selected in Windows patch settings. */\nexport interface WindowsVMGuestPatchAutomaticByPlatformSettingsOutput {\n /** Specifies the reboot setting for all AutomaticByPlatform patch installation operations. */\n rebootSetting?: \"Unknown\" | \"IfRequired\" | \"Never\" | \"Always\";\n}\n\n/** Describes Windows Remote Management configuration of the VM */\nexport interface WinRMConfigurationOutput {\n /** The list of Windows Remote Management listeners */\n listeners?: Array<WinRMListenerOutput>;\n}\n\n/** Describes Protocol and thumbprint of Windows Remote Management listener */\nexport interface WinRMListenerOutput {\n /** Specifies the protocol of WinRM listener. <br><br> Possible values are: <br>**http** <br><br> **https** */\n protocol?: \"Http\" | \"Https\";\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. For adding a secret to the Key Vault, see [Add a key or secret to the key vault](https://docs.microsoft.com/azure/key-vault/key-vault-get-started/#add). In this case, your certificate needs to be It is the Base64 encoding of the following JSON Object which is encoded in UTF-8: <br><br> {<br> \"data\":\"<Base64-encoded-certificate>\",<br> \"dataType\":\"pfx\",<br> \"password\":\"<pfx-file-password>\"<br>} <br> To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n certificateUrl?: string;\n}\n\n/** Specifies the Linux operating system settings on the virtual machine. <br><br>For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\nexport interface LinuxConfigurationOutput {\n /** Specifies whether password authentication should be disabled. */\n disablePasswordAuthentication?: boolean;\n /** Specifies the ssh key configuration for a Linux OS. */\n ssh?: SshConfigurationOutput;\n /** Indicates whether virtual machine agent should be provisioned on the virtual machine. <br><br> When this property is not specified in the request body, default behavior is to set it to true. This will ensure that VM Agent is installed on the VM so that extensions can be added to the VM later. */\n provisionVMAgent?: boolean;\n /** [Preview Feature] Specifies settings related to VM Guest Patching on Linux. */\n patchSettings?: LinuxPatchSettingsOutput;\n /** Indicates whether VMAgent Platform Updates is enabled for the Linux virtual machine. Default value is false. */\n enableVMAgentPlatformUpdates?: boolean;\n}\n\n/** SSH configuration for Linux based VMs running on Azure */\nexport interface SshConfigurationOutput {\n /** The list of SSH public keys used to authenticate with linux based VMs. */\n publicKeys?: Array<SshPublicKeyOutput>;\n}\n\n/** Contains information about SSH certificate public key and the path on the Linux VM where the public key is placed. */\nexport interface SshPublicKeyOutput {\n /** Specifies the full path on the created VM where ssh public key is stored. If the file already exists, the specified key is appended to the file. Example: /home/user/.ssh/authorized_keys */\n path?: string;\n /** SSH public key certificate used to authenticate with the VM through ssh. The key needs to be at least 2048-bit and in ssh-rsa format. <br><br> For creating ssh keys, see [Create SSH keys on Linux and Mac for Linux VMs in Azure]https://docs.microsoft.com/azure/virtual-machines/linux/create-ssh-keys-detailed). */\n keyData?: string;\n}\n\n/** Specifies settings related to VM Guest Patching on Linux. */\nexport interface LinuxPatchSettingsOutput {\n /** Specifies the mode of VM Guest Patching to IaaS virtual machine or virtual machines associated to virtual machine scale set with OrchestrationMode as Flexible.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - The virtual machine's default patching configuration is used. <br /><br /> **AutomaticByPlatform** - The virtual machine will be automatically updated by the platform. The property provisionVMAgent must be true */\n patchMode?: \"ImageDefault\" | \"AutomaticByPlatform\";\n /** Specifies the mode of VM Guest Patch Assessment for the IaaS virtual machine.<br /><br /> Possible values are:<br /><br /> **ImageDefault** - You control the timing of patch assessments on a virtual machine. <br /><br /> **AutomaticByPlatform** - The platform will trigger periodic patch assessments. The property provisionVMAgent must be true. */\n assessmentMode?: \"ImageDefault\" | \"AutomaticByPlatform\";\n /** Specifies additional settings for patch mode AutomaticByPlatform in VM Guest Patching on Linux. */\n automaticByPlatformSettings?: LinuxVMGuestPatchAutomaticByPlatformSettingsOutput;\n}\n\n/** Specifies additional settings to be applied when patch mode AutomaticByPlatform is selected in Linux patch settings. */\nexport interface LinuxVMGuestPatchAutomaticByPlatformSettingsOutput {\n /** Specifies the reboot setting for all AutomaticByPlatform patch installation operations. */\n rebootSetting?: \"Unknown\" | \"IfRequired\" | \"Never\" | \"Always\";\n}\n\n/** Describes a set of certificates which are all in the same Key Vault. */\nexport interface VaultSecretGroupOutput {\n /** The relative URL of the Key Vault containing all of the certificates in VaultCertificates. */\n sourceVault?: SubResourceOutput;\n /** The list of key vault references in SourceVault which contain certificates. */\n vaultCertificates?: Array<VaultCertificateOutput>;\n}\n\nexport interface SubResourceOutput {\n /** Resource Id */\n id?: string;\n}\n\n/** Describes a single certificate reference in a Key Vault, and where the certificate should reside on the VM. */\nexport interface VaultCertificateOutput {\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. For adding a secret to the Key Vault, see [Add a key or secret to the key vault](https://docs.microsoft.com/azure/key-vault/key-vault-get-started/#add). In this case, your certificate needs to be It is the Base64 encoding of the following JSON Object which is encoded in UTF-8: <br><br> {<br> \"data\":\"<Base64-encoded-certificate>\",<br> \"dataType\":\"pfx\",<br> \"password\":\"<pfx-file-password>\"<br>} <br> To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n certificateUrl?: string;\n /** For Windows VMs, specifies the certificate store on the Virtual Machine to which the certificate should be added. The specified certificate store is implicitly in the LocalMachine account. <br><br>For Linux VMs, the certificate file is placed under the /var/lib/waagent directory, with the file name <UppercaseThumbprint>.crt for the X509 certificate file and <UppercaseThumbprint>.prv for private key. Both of these files are .pem formatted. */\n certificateStore?: string;\n}\n\n/** Describes a virtual machine scale set storage profile. */\nexport interface VirtualMachineScaleSetStorageProfileOutput {\n /** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. */\n imageReference?: ImageReferenceOutput;\n /** Specifies information about the operating system disk used by the virtual machines in the scale set. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: VirtualMachineScaleSetOSDiskOutput;\n /** Specifies the parameters that are used to add data disks to the virtual machines in the scale set. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: Array<VirtualMachineScaleSetDataDiskOutput>;\n diskControllerType?: string;\n}\n\n/** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. NOTE: Image reference publisher and offer can only be set when you create the scale set. */\nexport interface ImageReferenceOutput extends SubResourceOutput {\n /** The image publisher. */\n publisher?: string;\n /** Specifies the offer of the platform image or marketplace image used to create the virtual machine. */\n offer?: string;\n /** The image SKU. */\n sku?: string;\n /** Specifies the version of the platform image or marketplace image used to create the virtual machine. The allowed formats are Major.Minor.Build or 'latest'. Major, Minor, and Build are decimal numbers. Specify 'latest' to use the latest version of an image available at deploy time. Even if you use 'latest', the VM image will not automatically update after deploy time even if a new version becomes available. Please do not use field 'version' for gallery image deployment, gallery image should always use 'id' field for deployment, to use 'latest' version of gallery image, just set '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Compute/galleries/{galleryName}/images/{imageName}' in the 'id' field without version input. */\n version?: string;\n /** Specifies in decimal numbers, the version of platform image or marketplace image used to create the virtual machine. This readonly field differs from 'version', only if the value specified in 'version' field is 'latest'. */\n readonly exactVersion?: string;\n /** Specified the shared gallery image unique id for vm deployment. This can be fetched from shared gallery image GET call. */\n sharedGalleryImageId?: string;\n /** Specified the community gallery image unique id for vm deployment. This can be fetched from community gallery image GET call. */\n communityGalleryImageId?: string;\n}\n\n/** Describes a virtual machine scale set operating system disk. */\nexport interface VirtualMachineScaleSetOSDiskOutput {\n /** The disk name. */\n name?: string;\n /** Specifies the caching requirements. <br><br> Possible values are: <br><br> **None** <br><br> **ReadOnly** <br><br> **ReadWrite** <br><br> Default: **None for Standard storage. ReadOnly for Premium storage** */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies how the virtual machines in the scale set should be created.<br><br> The only allowed value is: **FromImage** \\u2013 This value is used when you are using an image to create the virtual machine. If you are using a platform image, you also use the imageReference element described above. If you are using a marketplace image, you also use the plan element previously described. */\n createOption: \"FromImage\" | \"Empty\" | \"Attach\";\n /** Specifies the ephemeral disk Settings for the operating system disk used by the virtual machine scale set. */\n diffDiskSettings?: DiffDiskSettingsOutput;\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. <br><br> diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023 */\n diskSizeGB?: number;\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from user-image or a specialized VHD. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType?: \"Windows\" | \"Linux\";\n /** Specifies information about the unmanaged user image to base the scale set on. */\n image?: VirtualHardDiskOutput;\n /** Specifies the container urls that are used to store operating system disks for the scale set. */\n vhdContainers?: Array<string>;\n /** The managed disk parameters. */\n managedDisk?: VirtualMachineScaleSetManagedDiskParametersOutput;\n /** Specifies whether OS Disk should be deleted or detached upon VMSS Flex deletion (This feature is available for VMSS with Flexible OrchestrationMode only). <br><br> Possible values: <br><br> **Delete** If this value is used, the OS disk is deleted when VMSS Flex VM is deleted.<br><br> **Detach** If this value is used, the OS disk is retained after VMSS Flex VM is deleted. <br><br> The default value is set to **Delete**. For an Ephemeral OS Disk, the default value is set to **Delete**. User cannot change the delete option for Ephemeral OS Disk. */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes the parameters of ephemeral disk settings that can be specified for operating system disk. <br><br> NOTE: The ephemeral disk settings can only be specified for managed disk. */\nexport interface DiffDiskSettingsOutput {\n /** Specifies the ephemeral disk settings for operating system disk. */\n option?: \"Local\";\n /** Specifies the ephemeral disk placement for operating system disk.<br><br> Possible values are: <br><br> **CacheDisk** <br><br> **ResourceDisk** <br><br> Default: **CacheDisk** if one is configured for the VM size otherwise **ResourceDisk** is used.<br><br> Refer to VM size documentation for Windows VM at https://docs.microsoft.com/azure/virtual-machines/windows/sizes and Linux VM at https://docs.microsoft.com/azure/virtual-machines/linux/sizes to check which VM sizes exposes a cache disk. */\n placement?: \"CacheDisk\" | \"ResourceDisk\";\n}\n\n/** Describes the uri of a disk. */\nexport interface VirtualHardDiskOutput {\n /** Specifies the virtual hard disk's uri. */\n uri?: string;\n}\n\n/** Describes the parameters of a ScaleSet managed disk. */\nexport interface VirtualMachineScaleSetManagedDiskParametersOutput {\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?:\n | \"Standard_LRS\"\n | \"Premium_LRS\"\n | \"StandardSSD_LRS\"\n | \"UltraSSD_LRS\"\n | \"Premium_ZRS\"\n | \"StandardSSD_ZRS\"\n | \"PremiumV2_LRS\";\n /** Specifies the customer managed disk encryption set resource id for the managed disk. */\n diskEncryptionSet?: DiskEncryptionSetParametersOutput;\n /** Specifies the security profile for the managed disk. */\n securityProfile?: VMDiskSecurityProfileOutput;\n}\n\n/** Describes the parameter of customer managed disk encryption set resource id that can be specified for disk. <br><br> NOTE: The disk encryption set resource id can only be specified for managed disk. Please refer https://aka.ms/mdssewithcmkoverview for more details. */\nexport interface DiskEncryptionSetParametersOutput extends SubResourceOutput {}\n\n/** Specifies the security profile settings for the managed disk. <br><br> NOTE: It can only be set for Confidential VMs */\nexport interface VMDiskSecurityProfileOutput {\n /** Specifies the EncryptionType of the managed disk. <br> It is set to DiskWithVMGuestState for encryption of the managed disk along with VMGuestState blob, and VMGuestStateOnly for encryption of just the VMGuestState blob. <br><br> NOTE: It can be set for only Confidential VMs. */\n securityEncryptionType?: \"VMGuestStateOnly\" | \"DiskWithVMGuestState\";\n /** Specifies the customer managed disk encryption set resource id for the managed disk that is used for Customer Managed Key encrypted ConfidentialVM OS Disk and VMGuest blob. */\n diskEncryptionSet?: DiskEncryptionSetParametersOutput;\n}\n\n/** Describes a virtual machine scale set data disk. */\nexport interface VirtualMachineScaleSetDataDiskOutput {\n /** The disk name. */\n name?: string;\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n /** Specifies the caching requirements. <br><br> Possible values are: <br><br> **None** <br><br> **ReadOnly** <br><br> **ReadWrite** <br><br> Default: **None for Standard storage. ReadOnly for Premium storage** */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** The create option. */\n createOption: \"FromImage\" | \"Empty\" | \"Attach\";\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. <br><br> diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023 */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: VirtualMachineScaleSetManagedDiskParametersOutput;\n /** Specifies the Read-Write IOPS for the managed disk. Should be used only when StorageAccountType is UltraSSD_LRS. If not specified, a default value would be assigned based on diskSizeGB. */\n diskIOPSReadWrite?: number;\n /** Specifies the bandwidth in MB per second for the managed disk. Should be used only when StorageAccountType is UltraSSD_LRS. If not specified, a default value would be assigned based on diskSizeGB. */\n diskMBpsReadWrite?: number;\n /** Specifies whether data disk should be deleted or detached upon VMSS Flex deletion (This feature is available for VMSS with Flexible OrchestrationMode only).<br><br> Possible values: <br><br> **Delete** If this value is used, the data disk is deleted when the VMSS Flex VM is deleted.<br><br> **Detach** If this value is used, the data disk is retained after VMSS Flex VM is deleted.<br><br> The default value is set to **Delete**. */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes a virtual machine scale set network profile. */\nexport interface VirtualMachineScaleSetNetworkProfileOutput {\n /** A reference to a load balancer probe used to determine the health of an instance in the virtual machine scale set. The reference will be in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Network/loadBalancers/{loadBalancerName}/probes/{probeName}'. */\n healthProbe?: ApiEntityReferenceOutput;\n /** The list of network configurations. */\n networkInterfaceConfigurations?: Array<VirtualMachineScaleSetNetworkConfigurationOutput>;\n /** specifies the Microsoft.Network API version used when creating networking resources in the Network Interface Configurations for Virtual Machine Scale Set with orchestration mode 'Flexible' */\n networkApiVersion?: \"2020-11-01\";\n}\n\n/** The API entity reference. */\nexport interface ApiEntityReferenceOutput {\n /** The ARM resource id in the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/... */\n id?: string;\n}\n\n/** Describes a virtual machine scale set network profile's network configurations. */\nexport interface VirtualMachineScaleSetNetworkConfigurationOutput extends SubResourceOutput {\n /** The network configuration name. */\n name: string;\n /** Describes a virtual machine scale set network profile's IP configuration. */\n properties?: VirtualMachineScaleSetNetworkConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration. */\nexport interface VirtualMachineScaleSetNetworkConfigurationPropertiesOutput {\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResourceOutput;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineScaleSetNetworkConfigurationDnsSettingsOutput;\n /** Specifies the IP configurations of the network interface. */\n ipConfigurations: Array<VirtualMachineScaleSetIPConfigurationOutput>;\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes a virtual machines scale sets network configuration's DNS settings. */\nexport interface VirtualMachineScaleSetNetworkConfigurationDnsSettingsOutput {\n /** List of DNS servers IP addresses */\n dnsServers?: Array<string>;\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration. */\nexport interface VirtualMachineScaleSetIPConfigurationOutput extends SubResourceOutput {\n /** The IP configuration name. */\n name: string;\n /** Describes a virtual machine scale set network profile's IP configuration properties. */\n properties?: VirtualMachineScaleSetIPConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration properties. */\nexport interface VirtualMachineScaleSetIPConfigurationPropertiesOutput {\n /** Specifies the identifier of the subnet. */\n subnet?: ApiEntityReferenceOutput;\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachineScaleSetPublicIPAddressConfigurationOutput;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: \"IPv4\" | \"IPv6\";\n /** Specifies an array of references to backend address pools of application gateways. A scale set can reference backend address pools of multiple application gateways. Multiple scale sets cannot use the same application gateway. */\n applicationGatewayBackendAddressPools?: Array<SubResourceOutput>;\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: Array<SubResourceOutput>;\n /** Specifies an array of references to backend address pools of load balancers. A scale set can reference backend address pools of one public and one internal load balancer. Multiple scale sets cannot use the same basic sku load balancer. */\n loadBalancerBackendAddressPools?: Array<SubResourceOutput>;\n /** Specifies an array of references to inbound Nat pools of the load balancers. A scale set can reference inbound nat pools of one public and one internal load balancer. Multiple scale sets cannot use the same basic sku load balancer. */\n loadBalancerInboundNatPools?: Array<SubResourceOutput>;\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetPublicIPAddressConfigurationOutput {\n /** The publicIP address configuration name. */\n name: string;\n /** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\n properties?: VirtualMachineScaleSetPublicIPAddressConfigurationPropertiesOutput;\n /** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\n sku?: PublicIPAddressSkuOutput;\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetPublicIPAddressConfigurationPropertiesOutput {\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettingsOutput;\n /** The list of IP tags associated with the public IP address. */\n ipTags?: Array<VirtualMachineScaleSetIpTagOutput>;\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResourceOutput;\n /** Available from Api-Version 2019-07-01 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n publicIPAddressVersion?: \"IPv4\" | \"IPv6\";\n /** Specify what happens to the public IP when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes a virtual machines scale sets network configuration's DNS settings. */\nexport interface VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettingsOutput {\n /** The Domain name label.The concatenation of the domain name label and vm index will be the domain name labels of the PublicIPAddress resources that will be created */\n domainNameLabel: string;\n}\n\n/** Contains the IP tag associated with the public IP address. */\nexport interface VirtualMachineScaleSetIpTagOutput {\n /** IP tag type. Example: FirstPartyUsage. */\n ipTagType?: string;\n /** IP tag associated with the public IP. Example: SQL, Storage etc. */\n tag?: string;\n}\n\n/** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\nexport interface PublicIPAddressSkuOutput {\n /** Specify public IP sku name */\n name?: \"Basic\" | \"Standard\";\n /** Specify public IP sku tier */\n tier?: \"Regional\" | \"Global\";\n}\n\n/** Specifies the Security profile settings for the virtual machine or virtual machine scale set. */\nexport interface SecurityProfileOutput {\n /** Specifies the security settings like secure boot and vTPM used while creating the virtual machine. <br><br>Minimum api-version: 2020-12-01 */\n uefiSettings?: UefiSettingsOutput;\n /** This property can be used by user in the request to enable or disable the Host Encryption for the virtual machine or virtual machine scale set. This will enable the encryption for all the disks including Resource/Temp disk at host itself. <br><br> Default: The Encryption at host will be disabled unless this property is set to true for the resource. */\n encryptionAtHost?: boolean;\n /** Specifies the SecurityType of the virtual machine. It has to be set to any specified value to enable UefiSettings. <br><br> Default: UefiSettings will not be enabled unless this property is set. */\n securityType?: \"TrustedLaunch\" | \"ConfidentialVM\";\n}\n\n/** Specifies the security settings like secure boot and vTPM used while creating the virtual machine. <br><br>Minimum api-version: 2020-12-01 */\nexport interface UefiSettingsOutput {\n /** Specifies whether secure boot should be enabled on the virtual machine. <br><br>Minimum api-version: 2020-12-01 */\n secureBootEnabled?: boolean;\n /** Specifies whether vTPM should be enabled on the virtual machine. <br><br>Minimum api-version: 2020-12-01 */\n vTpmEnabled?: boolean;\n}\n\n/** Specifies the boot diagnostic settings state. <br><br>Minimum api-version: 2015-06-15. */\nexport interface DiagnosticsProfileOutput {\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. <br>**NOTE**: If storageUri is being specified then ensure that the storage account is in the same region and subscription as the VM. <br><br> You can easily view the output of your console log. <br><br> Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnosticsOutput;\n}\n\n/** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. <br><br> You can easily view the output of your console log. <br><br> Azure also enables you to see a screenshot of the VM from the hypervisor. */\nexport interface BootDiagnosticsOutput {\n /** Whether boot diagnostics should be enabled on the Virtual Machine. */\n enabled?: boolean;\n /** Uri of the storage account to use for placing the console output and screenshot. <br><br>If storageUri is not specified while enabling boot diagnostics, managed storage will be used. */\n storageUri?: string;\n}\n\n/** Describes a virtual machine scale set extension profile. */\nexport interface VirtualMachineScaleSetExtensionProfileOutput {\n /** The virtual machine scale set child extension resources. */\n extensions?: Array<VirtualMachineScaleSetExtensionOutput>;\n /** Specifies the time alloted for all extensions to start. The time duration should be between 15 minutes and 120 minutes (inclusive) and should be specified in ISO 8601 format. The default value is 90 minutes (PT1H30M). <br><br> Minimum api-version: 2020-06-01 */\n extensionsTimeBudget?: string;\n}\n\n/** Describes a Virtual Machine Scale Set Extension. */\nexport interface VirtualMachineScaleSetExtensionOutput extends SubResourceReadOnlyOutput {\n /** The name of the extension. */\n name?: string;\n /** Resource type */\n readonly type?: string;\n /** Describes the properties of a Virtual Machine Scale Set Extension. */\n properties?: VirtualMachineScaleSetExtensionPropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine Scale Set Extension. */\nexport interface VirtualMachineScaleSetExtensionPropertiesOutput {\n /** If a value is provided and is different from the previous value, the extension handler will be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** Collection of extension names after which this extension needs to be provisioned. */\n provisionAfterExtensions?: Array<string>;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReferenceOutput;\n}\n\n/** Describes a reference to Key Vault Secret */\nexport interface KeyVaultSecretReferenceOutput {\n /** The URL referencing a secret in a Key Vault. */\n secretUrl: string;\n /** The relative URL of the Key Vault containing the secret. */\n sourceVault: SubResourceOutput;\n}\n\nexport interface SubResourceReadOnlyOutput {\n /** Resource Id */\n readonly id?: string;\n}\n\n/** Specifies the billing related details of a Azure Spot VM or VMSS. <br><br>Minimum api-version: 2019-03-01. */\nexport interface BillingProfileOutput {\n /** Specifies the maximum price you are willing to pay for a Azure Spot VM/VMSS. This price is in US Dollars. <br><br> This price will be compared with the current Azure Spot price for the VM size. Also, the prices are compared at the time of create/update of Azure Spot VM/VMSS and the operation will only succeed if the maxPrice is greater than the current Azure Spot price. <br><br> The maxPrice will also be used for evicting a Azure Spot VM/VMSS if the current Azure Spot price goes beyond the maxPrice after creation of VM/VMSS. <br><br> Possible values are: <br><br> - Any decimal value greater than zero. Example: 0.01538 <br><br> -1 – indicates default price to be up-to on-demand. <br><br> You can set the maxPrice to -1 to indicate that the Azure Spot VM/VMSS should not be evicted for price reasons. Also, the default max price is -1 if it is not provided by you. <br><br>Minimum api-version: 2019-03-01. */\n maxPrice?: number;\n}\n\nexport interface ScheduledEventsProfileOutput {\n /** Specifies Terminate Scheduled Event related configurations. */\n terminateNotificationProfile?: TerminateNotificationProfileOutput;\n}\n\nexport interface TerminateNotificationProfileOutput {\n /** Configurable length of time a Virtual Machine being deleted will have to potentially approve the Terminate Scheduled Event before the event is auto approved (timed out). The configuration must be specified in ISO 8601 format, the default value is 5 minutes (PT5M) */\n notBeforeTimeout?: string;\n /** Specifies whether the Terminate Scheduled event is enabled or disabled. */\n enable?: boolean;\n}\n\n/** The parameters of a capacity reservation Profile. */\nexport interface CapacityReservationProfileOutput {\n /** Specifies the capacity reservation group resource id that should be used for allocating the virtual machine or scaleset vm instances provided enough capacity has been reserved. Please refer to https://aka.ms/CapacityReservation for more details. */\n capacityReservationGroup?: SubResourceOutput;\n}\n\n/** Contains the list of gallery applications that should be made available to the VM/VMSS */\nexport interface ApplicationProfileOutput {\n /** Specifies the gallery applications that should be made available to the VM/VMSS */\n galleryApplications?: Array<VMGalleryApplicationOutput>;\n}\n\n/** Specifies the required information to reference a compute gallery application version */\nexport interface VMGalleryApplicationOutput {\n /** Optional, Specifies a passthrough value for more generic context. */\n tags?: string;\n /** Optional, Specifies the order in which the packages have to be installed */\n order?: number;\n /** Specifies the GalleryApplicationVersion resource id on the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/providers/Microsoft.Compute/galleries/{galleryName}/applications/{application}/versions/{version} */\n packageReferenceId: string;\n /** Optional, Specifies the uri to an azure blob that will replace the default configuration for the package if provided */\n configurationReference?: string;\n /** Optional, If true, any failure for any operation in the VmApplication will fail the deployment */\n treatFailureAsDeploymentFailure?: boolean;\n /** If set to true, when a new Gallery Application version is available in PIR/SIG, it will be automatically updated for the VM/VMSS */\n enableAutomaticUpgrade?: boolean;\n}\n\n/** Specifies the hardware settings for the virtual machine scale set. */\nexport interface VirtualMachineScaleSetHardwareProfileOutput {\n /** Specifies the properties for customizing the size of the virtual machine. Minimum api-version: 2021-11-01. <br><br> Please follow the instructions in [VM Customization](https://aka.ms/vmcustomization) for more details. */\n vmSizeProperties?: VMSizePropertiesOutput;\n}\n\n/** Specifies VM Size Property settings on the virtual machine. */\nexport interface VMSizePropertiesOutput {\n /** Specifies the number of vCPUs available for the VM. <br><br> When this property is not specified in the request body the default behavior is to set it to the value of vCPUs available for that VM size exposed in api response of [List all available virtual machine sizes in a region](https://docs.microsoft.com/en-us/rest/api/compute/resource-skus/list) . */\n vCPUsAvailable?: number;\n /** Specifies the vCPU to physical core ratio. <br><br> When this property is not specified in the request body the default behavior is set to the value of vCPUsPerCore for the VM Size exposed in api response of [List all available virtual machine sizes in a region](https://docs.microsoft.com/en-us/rest/api/compute/resource-skus/list) <br><br> Setting this property to 1 also means that hyper-threading is disabled. */\n vCPUsPerCore?: number;\n}\n\n/** Enables or disables a capability on the virtual machine or virtual machine scale set. */\nexport interface AdditionalCapabilitiesOutput {\n /** The flag that enables or disables a capability to have one or more managed data disks with UltraSSD_LRS storage account type on the VM or VMSS. Managed disks with storage account type UltraSSD_LRS can be added to a virtual machine or virtual machine scale set only if this property is enabled. */\n ultraSSDEnabled?: boolean;\n /** The flag that enables or disables hibernation capability on the VM. */\n hibernationEnabled?: boolean;\n}\n\n/** Describes a scale-in policy for a virtual machine scale set. */\nexport interface ScaleInPolicyOutput {\n /** The rules to be followed when scaling-in a virtual machine scale set. <br><br> Possible values are: <br><br> **Default** When a virtual machine scale set is scaled in, the scale set will first be balanced across zones if it is a zonal scale set. Then, it will be balanced across Fault Domains as far as possible. Within each Fault Domain, the virtual machines chosen for removal will be the newest ones that are not protected from scale-in. <br><br> **OldestVM** When a virtual machine scale set is being scaled-in, the oldest virtual machines that are not protected from scale-in will be chosen for removal. For zonal virtual machine scale sets, the scale set will first be balanced across zones. Within each zone, the oldest virtual machines that are not protected will be chosen for removal. <br><br> **NewestVM** When a virtual machine scale set is being scaled-in, the newest virtual machines that are not protected from scale-in will be chosen for removal. For zonal virtual machine scale sets, the scale set will first be balanced across zones. Within each zone, the newest virtual machines that are not protected will be chosen for removal. <br><br> */\n rules?: Array<\"Default\" | \"OldestVM\" | \"NewestVM\">;\n /** This property allows you to specify if virtual machines chosen for removal have to be force deleted when a virtual machine scale set is being scaled-in.(Feature in Preview) */\n forceDeletion?: boolean;\n}\n\n/** Specifies the Spot-Try-Restore properties for the virtual machine scale set. <br><br> With this property customer can enable or disable automatic restore of the evicted Spot VMSS VM instances opportunistically based on capacity availability and pricing constraint. */\nexport interface SpotRestorePolicyOutput {\n /** Enables the Spot-Try-Restore feature where evicted VMSS SPOT instances will be tried to be restored opportunistically based on capacity availability and pricing constraints */\n enabled?: boolean;\n /** Timeout value expressed as an ISO 8601 time duration after which the platform will not try to restore the VMSS SPOT instances */\n restoreTimeout?: string;\n}\n\n/** Specifies the target splits for Spot and Regular priority VMs within a scale set with flexible orchestration mode. <br><br>With this property the customer is able to specify the base number of regular priority VMs created as the VMSS flex instance scales out and the split between Spot and Regular priority VMs after this base target has been reached. */\nexport interface PriorityMixPolicyOutput {\n /** The base number of regular priority VMs that will be created in this scale set as it scales out. */\n baseRegularPriorityCount?: number;\n /** The percentage of VM instances, after the base regular priority count has been reached, that are expected to use regular priority. */\n regularPriorityPercentageAboveBase?: number;\n}\n\n/** Identity for the virtual machine scale set. */\nexport interface VirtualMachineScaleSetIdentityOutput {\n /** The principal id of virtual machine scale set identity. This property will only be provided for a system assigned identity. */\n readonly principalId?: string;\n /** The tenant id associated with the virtual machine scale set. This property will only be provided for a system assigned identity. */\n readonly tenantId?: string;\n /** The type of identity used for the virtual machine scale set. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user assigned identities. The type 'None' will remove any identities from the virtual machine scale set. */\n type?: \"SystemAssigned\" | \"UserAssigned\" | \"SystemAssigned, UserAssigned\" | \"None\";\n /** The list of user identities associated with the virtual machine scale set. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: Record<string, UserAssignedIdentitiesValueOutput>;\n}\n\nexport interface UserAssignedIdentitiesValueOutput {\n /** The principal id of user assigned identity. */\n readonly principalId?: string;\n /** The client id of user assigned identity. */\n readonly clientId?: string;\n}\n\n/** The complex type of the extended location. */\nexport interface ExtendedLocationOutput {\n /** The name of the extended location. */\n name?: string;\n /** The type of the extended location. */\n type?: \"EdgeZone\";\n}\n\n/** The Resource model definition. */\nexport interface ResourceOutput {\n /** Resource Id */\n readonly id?: string;\n /** Resource name */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Resource location */\n location: string;\n /** Resource tags */\n tags?: Record<string, string>;\n}\n\n/** Describes a virtual machine scale set network profile's network configurations. */\nexport interface VirtualMachineScaleSetUpdateNetworkConfigurationOutput extends SubResourceOutput {\n /** The network configuration name. */\n name?: string;\n /** Describes a virtual machine scale set updatable network profile's IP configuration.Use this object for updating network profile's IP Configuration. */\n properties?: VirtualMachineScaleSetUpdateNetworkConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine scale set updatable network profile's IP configuration.Use this object for updating network profile's IP Configuration. */\nexport interface VirtualMachineScaleSetUpdateNetworkConfigurationPropertiesOutput {\n /** Whether this is a primary NIC on a virtual machine. */\n primary?: boolean;\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResourceOutput;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineScaleSetNetworkConfigurationDnsSettingsOutput;\n /** The virtual machine scale set IP Configuration. */\n ipConfigurations?: Array<VirtualMachineScaleSetUpdateIPConfigurationOutput>;\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration. NOTE: The subnet of a scale set may be modified as long as the original subnet and the new subnet are in the same virtual network */\nexport interface VirtualMachineScaleSetUpdateIPConfigurationOutput extends SubResourceOutput {\n /** The IP configuration name. */\n name?: string;\n /** Describes a virtual machine scale set network profile's IP configuration properties. */\n properties?: VirtualMachineScaleSetUpdateIPConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine scale set network profile's IP configuration properties. */\nexport interface VirtualMachineScaleSetUpdateIPConfigurationPropertiesOutput {\n /** The subnet. */\n subnet?: ApiEntityReferenceOutput;\n /** Specifies the primary IP Configuration in case the network interface has more than one IP Configuration. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachineScaleSetUpdatePublicIPAddressConfigurationOutput;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: \"IPv4\" | \"IPv6\";\n /** The application gateway backend address pools. */\n applicationGatewayBackendAddressPools?: Array<SubResourceOutput>;\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: Array<SubResourceOutput>;\n /** The load balancer backend address pools. */\n loadBalancerBackendAddressPools?: Array<SubResourceOutput>;\n /** The load balancer inbound nat pools. */\n loadBalancerInboundNatPools?: Array<SubResourceOutput>;\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetUpdatePublicIPAddressConfigurationOutput {\n /** The publicIP address configuration name. */\n name?: string;\n /** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\n properties?: VirtualMachineScaleSetUpdatePublicIPAddressConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machines scale set IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachineScaleSetUpdatePublicIPAddressConfigurationPropertiesOutput {\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachineScaleSetPublicIPAddressConfigurationDnsSettingsOutput;\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResourceOutput;\n /** Specify what happens to the public IP when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** The instance view of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetInstanceViewOutput {\n /** The instance view status summary for the virtual machine scale set. */\n readonly virtualMachine?: VirtualMachineScaleSetInstanceViewStatusesSummaryOutput;\n /** The extensions information. */\n readonly extensions?: Array<VirtualMachineScaleSetVMExtensionsSummaryOutput>;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n /** The orchestration services information. */\n readonly orchestrationServices?: Array<OrchestrationServiceSummaryOutput>;\n}\n\n/** Instance view statuses summary for virtual machines of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetInstanceViewStatusesSummaryOutput {\n /** The extensions information. */\n readonly statusesSummary?: Array<VirtualMachineStatusCodeCountOutput>;\n}\n\n/** The status code and count of the virtual machine scale set instance view status summary. */\nexport interface VirtualMachineStatusCodeCountOutput {\n /** The instance view status code. */\n readonly code?: string;\n /** The number of instances having a particular status code. */\n readonly count?: number;\n}\n\n/** Extensions summary for virtual machines of a virtual machine scale set. */\nexport interface VirtualMachineScaleSetVMExtensionsSummaryOutput {\n /** The extension name. */\n readonly name?: string;\n /** The extensions information. */\n readonly statusesSummary?: Array<VirtualMachineStatusCodeCountOutput>;\n}\n\n/** Instance view status. */\nexport interface InstanceViewStatusOutput {\n /** The status code. */\n code?: string;\n /** The level code. */\n level?: \"Info\" | \"Warning\" | \"Error\";\n /** The short localizable label for the status. */\n displayStatus?: string;\n /** The detailed status message, including for alerts and error messages. */\n message?: string;\n /** The time of the status. */\n time?: string;\n}\n\n/** Summary for an orchestration service of a virtual machine scale set. */\nexport interface OrchestrationServiceSummaryOutput {\n /** The name of the service. */\n readonly serviceName?: \"AutomaticRepairs\";\n /** The current state of the service. */\n readonly serviceState?: \"NotRunning\" | \"Running\" | \"Suspended\";\n}\n\n/** Describes a Virtual Machine Scale Set Extension. */\nexport interface VirtualMachineScaleSetExtensionUpdateOutput extends SubResourceReadOnlyOutput {\n /** The name of the extension. */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Describes the properties of a Virtual Machine Scale Set Extension. */\n properties?: VirtualMachineScaleSetExtensionPropertiesOutput;\n}\n\n/** The List VM scale set extension operation response. */\nexport interface VirtualMachineScaleSetExtensionListResultOutput {\n /** The list of VM scale set extensions. */\n value: Array<VirtualMachineScaleSetExtensionOutput>;\n /** The uri to fetch the next page of VM scale set extensions. Call ListNext() with this to fetch the next page of VM scale set extensions. */\n nextLink?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineScaleSetListWithLinkResultOutput {\n /** The list of virtual machine scale sets. */\n value: Array<VirtualMachineScaleSetOutput>;\n /** The uri to fetch the next page of Virtual Machine Scale Sets. Call ListNext() with this to fetch the next page of Virtual Machine Scale Sets. */\n nextLink?: string;\n}\n\n/** The Virtual Machine Scale Set List Skus operation response. */\nexport interface VirtualMachineScaleSetListSkusResultOutput {\n /** The list of skus available for the virtual machine scale set. */\n value: Array<VirtualMachineScaleSetSkuOutput>;\n /** The uri to fetch the next page of Virtual Machine Scale Set Skus. Call ListNext() with this to fetch the next page of VMSS Skus. */\n nextLink?: string;\n}\n\n/** Describes an available virtual machine scale set sku. */\nexport interface VirtualMachineScaleSetSkuOutput {\n /** The type of resource the sku applies to. */\n readonly resourceType?: string;\n /** The Sku. */\n readonly sku?: SkuOutput;\n /** Specifies the number of virtual machines in the scale set. */\n readonly capacity?: VirtualMachineScaleSetSkuCapacityOutput;\n}\n\n/** Describes scaling information of a sku. */\nexport interface VirtualMachineScaleSetSkuCapacityOutput {\n /** The minimum capacity. */\n readonly minimum?: number;\n /** The maximum capacity that can be set. */\n readonly maximum?: number;\n /** The default capacity. */\n readonly defaultCapacity?: number;\n /** The scale type applicable to the sku. */\n readonly scaleType?: \"Automatic\" | \"None\";\n}\n\n/** List of Virtual Machine Scale Set OS Upgrade History operation response. */\nexport interface VirtualMachineScaleSetListOSUpgradeHistoryOutput {\n /** The list of OS upgrades performed on the virtual machine scale set. */\n value: Array<UpgradeOperationHistoricalStatusInfoOutput>;\n /** The uri to fetch the next page of OS Upgrade History. Call ListNext() with this to fetch the next page of history of upgrades. */\n nextLink?: string;\n}\n\n/** Virtual Machine Scale Set OS Upgrade History operation response. */\nexport interface UpgradeOperationHistoricalStatusInfoOutput {\n /** Information about the properties of the upgrade operation. */\n readonly properties?: UpgradeOperationHistoricalStatusInfoPropertiesOutput;\n /** Resource type */\n readonly type?: string;\n /** Resource location */\n readonly location?: string;\n}\n\n/** Describes each OS upgrade on the Virtual Machine Scale Set. */\nexport interface UpgradeOperationHistoricalStatusInfoPropertiesOutput {\n /** Information about the overall status of the upgrade operation. */\n readonly runningStatus?: UpgradeOperationHistoryStatusOutput;\n /** Counts of the VMs in each state. */\n readonly progress?: RollingUpgradeProgressInfoOutput;\n /** Error Details for this upgrade if there are any. */\n readonly error?: ApiErrorOutput;\n /** Invoker of the Upgrade Operation */\n readonly startedBy?: \"Unknown\" | \"User\" | \"Platform\";\n /** Image Reference details */\n readonly targetImageReference?: ImageReferenceOutput;\n /** Information about OS rollback if performed */\n readonly rollbackInfo?: RollbackStatusInfoOutput;\n}\n\n/** Information about the current running state of the overall upgrade. */\nexport interface UpgradeOperationHistoryStatusOutput {\n /** Code indicating the current status of the upgrade. */\n readonly code?: \"RollingForward\" | \"Cancelled\" | \"Completed\" | \"Faulted\";\n /** Start time of the upgrade. */\n readonly startTime?: string;\n /** End time of the upgrade. */\n readonly endTime?: string;\n}\n\n/** Information about the number of virtual machine instances in each upgrade state. */\nexport interface RollingUpgradeProgressInfoOutput {\n /** The number of instances that have been successfully upgraded. */\n readonly successfulInstanceCount?: number;\n /** The number of instances that have failed to be upgraded successfully. */\n readonly failedInstanceCount?: number;\n /** The number of instances that are currently being upgraded. */\n readonly inProgressInstanceCount?: number;\n /** The number of instances that have not yet begun to be upgraded. */\n readonly pendingInstanceCount?: number;\n}\n\n/** Information about rollback on failed VM instances after a OS Upgrade operation. */\nexport interface RollbackStatusInfoOutput {\n /** The number of instances which have been successfully rolled back. */\n readonly successfullyRolledbackInstanceCount?: number;\n /** The number of instances which failed to rollback. */\n readonly failedRolledbackInstanceCount?: number;\n /** Error details if OS rollback failed. */\n readonly rollbackError?: ApiErrorOutput;\n}\n\n/** The status of the latest virtual machine scale set rolling upgrade. */\nexport interface RollingUpgradeStatusInfoOutput extends ResourceOutput {\n /** The status of the latest virtual machine scale set rolling upgrade. */\n properties?: RollingUpgradeStatusInfoPropertiesOutput;\n}\n\n/** The status of the latest virtual machine scale set rolling upgrade. */\nexport interface RollingUpgradeStatusInfoPropertiesOutput {\n /** The rolling upgrade policies applied for this upgrade. */\n readonly policy?: RollingUpgradePolicyOutput;\n /** Information about the current running state of the overall upgrade. */\n readonly runningStatus?: RollingUpgradeRunningStatusOutput;\n /** Information about the number of virtual machine instances in each upgrade state. */\n readonly progress?: RollingUpgradeProgressInfoOutput;\n /** Error details for this upgrade, if there are any. */\n readonly error?: ApiErrorOutput;\n}\n\n/** Information about the current running state of the overall upgrade. */\nexport interface RollingUpgradeRunningStatusOutput {\n /** Code indicating the current status of the upgrade. */\n readonly code?: \"RollingForward\" | \"Cancelled\" | \"Completed\" | \"Faulted\";\n /** Start time of the upgrade. */\n readonly startTime?: string;\n /** The last action performed on the rolling upgrade. */\n readonly lastAction?: \"Start\" | \"Cancel\";\n /** Last action time of the upgrade. */\n readonly lastActionTime?: string;\n}\n\n/** Response after calling a manual recovery walk */\nexport interface RecoveryWalkResponseOutput {\n /** Whether the recovery walk was performed */\n readonly walkPerformed?: boolean;\n /** The next update domain that needs to be walked. Null means walk spanning all update domains has been completed */\n readonly nextPlatformUpdateDomain?: number;\n}\n\n/** Describes a VMSS VM Extension. */\nexport interface VirtualMachineScaleSetVMExtensionOutput extends SubResourceReadOnlyOutput {\n /** The name of the extension. */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Describes the properties of a Virtual Machine Extension. */\n properties?: VirtualMachineExtensionPropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine Extension. */\nexport interface VirtualMachineExtensionPropertiesOutput {\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The virtual machine extension instance view. */\n instanceView?: VirtualMachineExtensionInstanceViewOutput;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReferenceOutput;\n}\n\n/** The instance view of a virtual machine extension. */\nexport interface VirtualMachineExtensionInstanceViewOutput {\n /** The virtual machine extension name. */\n name?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** The resource status information. */\n substatuses?: Array<InstanceViewStatusOutput>;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** Describes a VMSS VM Extension. */\nexport interface VirtualMachineScaleSetVMExtensionUpdateOutput extends SubResourceReadOnlyOutput {\n /** The name of the extension. */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Describes the properties of a Virtual Machine Extension. */\n properties?: VirtualMachineExtensionUpdatePropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine Extension. */\nexport interface VirtualMachineExtensionUpdatePropertiesOutput {\n /** How the extension handler should be forced to update even if the extension configuration has not changed. */\n forceUpdateTag?: string;\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** Indicates whether the extension should use a newer minor version if one is available at deployment time. Once deployed, however, the extension will not upgrade minor versions unless redeployed, even with this property set to true. */\n autoUpgradeMinorVersion?: boolean;\n /** Indicates whether the extension should be automatically upgraded by the platform if there is a newer version of the extension available. */\n enableAutomaticUpgrade?: boolean;\n /** Json formatted public settings for the extension. */\n settings?: any;\n /** The extension can contain either protectedSettings or protectedSettingsFromKeyVault or no protected settings at all. */\n protectedSettings?: any;\n /** Indicates whether failures stemming from the extension will be suppressed (Operational failures such as not connecting to the VM will not be suppressed regardless of this value). The default is false. */\n suppressFailures?: boolean;\n /** The extensions protected settings that are passed by reference, and consumed from key vault */\n protectedSettingsFromKeyVault?: KeyVaultSecretReferenceOutput;\n}\n\n/** The List VMSS VM Extension operation response */\nexport interface VirtualMachineScaleSetVMExtensionsListResultOutput {\n /** The list of VMSS VM extensions */\n value?: Array<VirtualMachineScaleSetVMExtensionOutput>;\n}\n\n/** Describes a virtual machine scale set virtual machine. */\nexport interface VirtualMachineScaleSetVMOutput extends ResourceOutput {\n /** The virtual machine instance ID. */\n readonly instanceId?: string;\n /** The virtual machine SKU. */\n readonly sku?: SkuOutput;\n /** Describes the properties of a virtual machine scale set virtual machine. */\n properties?: VirtualMachineScaleSetVMPropertiesOutput;\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: PlanOutput;\n /** The virtual machine child extension resources. */\n readonly resources?: Array<VirtualMachineExtensionOutput>;\n /** The virtual machine zones. */\n readonly zones?: Array<string>;\n /** The identity of the virtual machine, if configured. */\n identity?: VirtualMachineIdentityOutput;\n}\n\n/** Describes the properties of a virtual machine scale set virtual machine. */\nexport interface VirtualMachineScaleSetVMPropertiesOutput {\n /** Specifies whether the latest model has been applied to the virtual machine. */\n readonly latestModelApplied?: boolean;\n /** Azure VM unique ID. */\n readonly vmId?: string;\n /** The virtual machine instance view. */\n readonly instanceView?: VirtualMachineScaleSetVMInstanceViewOutput;\n /** Specifies the hardware settings for the virtual machine. */\n hardwareProfile?: HardwareProfileOutput;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: StorageProfileOutput;\n /** Specifies additional capabilities enabled or disabled on the virtual machine in the scale set. For instance: whether the virtual machine has the capability to support attaching managed data disks with UltraSSD_LRS storage account type. */\n additionalCapabilities?: AdditionalCapabilitiesOutput;\n /** Specifies the operating system settings for the virtual machine. */\n osProfile?: OSProfileOutput;\n /** Specifies the Security related profile settings for the virtual machine. */\n securityProfile?: SecurityProfileOutput;\n /** Specifies the network interfaces of the virtual machine. */\n networkProfile?: NetworkProfileOutput;\n /** Specifies the network profile configuration of the virtual machine. */\n networkProfileConfiguration?: VirtualMachineScaleSetVMNetworkProfileConfigurationOutput;\n /** Specifies the boot diagnostic settings state. <br><br>Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfileOutput;\n /** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). <br><br> For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates) <br><br> Currently, a VM can only be added to availability set at creation time. An existing VM cannot be added to an availability set. */\n availabilitySet?: SubResourceOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /** Specifies whether the model applied to the virtual machine is the model of the virtual machine scale set or the customized model for the virtual machine. */\n readonly modelDefinitionApplied?: string;\n /** Specifies the protection policy of the virtual machine. */\n protectionPolicy?: VirtualMachineScaleSetVMProtectionPolicyOutput;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. <br><br>Minimum api-version: 2021-03-01 */\n userData?: string;\n}\n\n/** The instance view of a virtual machine scale set VM. */\nexport interface VirtualMachineScaleSetVMInstanceViewOutput {\n /** The Update Domain count. */\n platformUpdateDomain?: number;\n /** The Fault Domain count. */\n platformFaultDomain?: number;\n /** The Remote desktop certificate thumbprint. */\n rdpThumbPrint?: string;\n /** The VM Agent running on the virtual machine. */\n vmAgent?: VirtualMachineAgentInstanceViewOutput;\n /** The Maintenance Operation status on the virtual machine. */\n maintenanceRedeployStatus?: MaintenanceRedeployStatusOutput;\n /** The disks information. */\n disks?: Array<DiskInstanceViewOutput>;\n /** The extensions information. */\n extensions?: Array<VirtualMachineExtensionInstanceViewOutput>;\n /** The health status for the VM. */\n readonly vmHealth?: VirtualMachineHealthStatusOutput;\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. <br><br> You can easily view the output of your console log. <br><br> Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnosticsInstanceViewOutput;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n /** Resource id of the dedicated host, on which the virtual machine is allocated through automatic placement, when the virtual machine is associated with a dedicated host group that has automatic placement enabled. <br><br>Minimum api-version: 2020-06-01. */\n readonly assignedHost?: string;\n /** The placement group in which the VM is running. If the VM is deallocated it will not have a placementGroupId. */\n placementGroupId?: string;\n}\n\n/** The instance view of the VM Agent running on the virtual machine. */\nexport interface VirtualMachineAgentInstanceViewOutput {\n /** The VM Agent full version. */\n vmAgentVersion?: string;\n /** The virtual machine extension handler instance view. */\n extensionHandlers?: Array<VirtualMachineExtensionHandlerInstanceViewOutput>;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** The instance view of a virtual machine extension handler. */\nexport interface VirtualMachineExtensionHandlerInstanceViewOutput {\n /** Specifies the type of the extension; an example is \"CustomScriptExtension\". */\n type?: string;\n /** Specifies the version of the script handler. */\n typeHandlerVersion?: string;\n /** The extension handler status. */\n status?: InstanceViewStatusOutput;\n}\n\n/** Maintenance Operation Status. */\nexport interface MaintenanceRedeployStatusOutput {\n /** True, if customer is allowed to perform Maintenance. */\n isCustomerInitiatedMaintenanceAllowed?: boolean;\n /** Start Time for the Pre Maintenance Window. */\n preMaintenanceWindowStartTime?: string;\n /** End Time for the Pre Maintenance Window. */\n preMaintenanceWindowEndTime?: string;\n /** Start Time for the Maintenance Window. */\n maintenanceWindowStartTime?: string;\n /** End Time for the Maintenance Window. */\n maintenanceWindowEndTime?: string;\n /** The Last Maintenance Operation Result Code. */\n lastOperationResultCode?: \"None\" | \"RetryLater\" | \"MaintenanceAborted\" | \"MaintenanceCompleted\";\n /** Message returned for the last Maintenance Operation. */\n lastOperationMessage?: string;\n}\n\n/** The instance view of the disk. */\nexport interface DiskInstanceViewOutput {\n /** The disk name. */\n name?: string;\n /** Specifies the encryption settings for the OS Disk. <br><br> Minimum api-version: 2015-06-15 */\n encryptionSettings?: Array<DiskEncryptionSettingsOutput>;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** Describes a Encryption Settings for a Disk */\nexport interface DiskEncryptionSettingsOutput {\n /** Specifies the location of the disk encryption key, which is a Key Vault Secret. */\n diskEncryptionKey?: KeyVaultSecretReferenceOutput;\n /** Specifies the location of the key encryption key in Key Vault. */\n keyEncryptionKey?: KeyVaultKeyReferenceOutput;\n /** Specifies whether disk encryption should be enabled on the virtual machine. */\n enabled?: boolean;\n}\n\n/** Describes a reference to Key Vault Key */\nexport interface KeyVaultKeyReferenceOutput {\n /** The URL referencing a key encryption key in Key Vault. */\n keyUrl: string;\n /** The relative URL of the Key Vault containing the key. */\n sourceVault: SubResourceOutput;\n}\n\n/** The health status of the VM. */\nexport interface VirtualMachineHealthStatusOutput {\n /** The health status information for the VM. */\n readonly status?: InstanceViewStatusOutput;\n}\n\n/** The instance view of a virtual machine boot diagnostics. */\nexport interface BootDiagnosticsInstanceViewOutput {\n /** The console screenshot blob URI. <br><br>NOTE: This will **not** be set if boot diagnostics is currently enabled with managed storage. */\n readonly consoleScreenshotBlobUri?: string;\n /** The serial console log blob Uri. <br><br>NOTE: This will **not** be set if boot diagnostics is currently enabled with managed storage. */\n readonly serialConsoleLogBlobUri?: string;\n /** The boot diagnostics status information for the VM. <br><br> NOTE: It will be set only if there are errors encountered in enabling boot diagnostics. */\n readonly status?: InstanceViewStatusOutput;\n}\n\n/** Specifies the hardware settings for the virtual machine. */\nexport interface HardwareProfileOutput {\n /** Specifies the size of the virtual machine. <br><br> The enum data type is currently deprecated and will be removed by December 23rd 2023. <br><br> Recommended way to get the list of available sizes is using these APIs: <br><br> [List all available virtual machine sizes in an availability set](https://docs.microsoft.com/rest/api/compute/availabilitysets/listavailablesizes) <br><br> [List all available virtual machine sizes in a region]( https://docs.microsoft.com/rest/api/compute/resourceskus/list) <br><br> [List all available virtual machine sizes for resizing](https://docs.microsoft.com/rest/api/compute/virtualmachines/listavailablesizes). For more information about virtual machine sizes, see [Sizes for virtual machines](https://docs.microsoft.com/azure/virtual-machines/sizes). <br><br> The available VM sizes depend on region and availability set. */\n vmSize?:\n | \"Basic_A0\"\n | \"Basic_A1\"\n | \"Basic_A2\"\n | \"Basic_A3\"\n | \"Basic_A4\"\n | \"Standard_A0\"\n | \"Standard_A1\"\n | \"Standard_A2\"\n | \"Standard_A3\"\n | \"Standard_A4\"\n | \"Standard_A5\"\n | \"Standard_A6\"\n | \"Standard_A7\"\n | \"Standard_A8\"\n | \"Standard_A9\"\n | \"Standard_A10\"\n | \"Standard_A11\"\n | \"Standard_A1_v2\"\n | \"Standard_A2_v2\"\n | \"Standard_A4_v2\"\n | \"Standard_A8_v2\"\n | \"Standard_A2m_v2\"\n | \"Standard_A4m_v2\"\n | \"Standard_A8m_v2\"\n | \"Standard_B1s\"\n | \"Standard_B1ms\"\n | \"Standard_B2s\"\n | \"Standard_B2ms\"\n | \"Standard_B4ms\"\n | \"Standard_B8ms\"\n | \"Standard_D1\"\n | \"Standard_D2\"\n | \"Standard_D3\"\n | \"Standard_D4\"\n | \"Standard_D11\"\n | \"Standard_D12\"\n | \"Standard_D13\"\n | \"Standard_D14\"\n | \"Standard_D1_v2\"\n | \"Standard_D2_v2\"\n | \"Standard_D3_v2\"\n | \"Standard_D4_v2\"\n | \"Standard_D5_v2\"\n | \"Standard_D2_v3\"\n | \"Standard_D4_v3\"\n | \"Standard_D8_v3\"\n | \"Standard_D16_v3\"\n | \"Standard_D32_v3\"\n | \"Standard_D64_v3\"\n | \"Standard_D2s_v3\"\n | \"Standard_D4s_v3\"\n | \"Standard_D8s_v3\"\n | \"Standard_D16s_v3\"\n | \"Standard_D32s_v3\"\n | \"Standard_D64s_v3\"\n | \"Standard_D11_v2\"\n | \"Standard_D12_v2\"\n | \"Standard_D13_v2\"\n | \"Standard_D14_v2\"\n | \"Standard_D15_v2\"\n | \"Standard_DS1\"\n | \"Standard_DS2\"\n | \"Standard_DS3\"\n | \"Standard_DS4\"\n | \"Standard_DS11\"\n | \"Standard_DS12\"\n | \"Standard_DS13\"\n | \"Standard_DS14\"\n | \"Standard_DS1_v2\"\n | \"Standard_DS2_v2\"\n | \"Standard_DS3_v2\"\n | \"Standard_DS4_v2\"\n | \"Standard_DS5_v2\"\n | \"Standard_DS11_v2\"\n | \"Standard_DS12_v2\"\n | \"Standard_DS13_v2\"\n | \"Standard_DS14_v2\"\n | \"Standard_DS15_v2\"\n | \"Standard_DS13-4_v2\"\n | \"Standard_DS13-2_v2\"\n | \"Standard_DS14-8_v2\"\n | \"Standard_DS14-4_v2\"\n | \"Standard_E2_v3\"\n | \"Standard_E4_v3\"\n | \"Standard_E8_v3\"\n | \"Standard_E16_v3\"\n | \"Standard_E32_v3\"\n | \"Standard_E64_v3\"\n | \"Standard_E2s_v3\"\n | \"Standard_E4s_v3\"\n | \"Standard_E8s_v3\"\n | \"Standard_E16s_v3\"\n | \"Standard_E32s_v3\"\n | \"Standard_E64s_v3\"\n | \"Standard_E32-16_v3\"\n | \"Standard_E32-8s_v3\"\n | \"Standard_E64-32s_v3\"\n | \"Standard_E64-16s_v3\"\n | \"Standard_F1\"\n | \"Standard_F2\"\n | \"Standard_F4\"\n | \"Standard_F8\"\n | \"Standard_F16\"\n | \"Standard_F1s\"\n | \"Standard_F2s\"\n | \"Standard_F4s\"\n | \"Standard_F8s\"\n | \"Standard_F16s\"\n | \"Standard_F2s_v2\"\n | \"Standard_F4s_v2\"\n | \"Standard_F8s_v2\"\n | \"Standard_F16s_v2\"\n | \"Standard_F32s_v2\"\n | \"Standard_F64s_v2\"\n | \"Standard_F72s_v2\"\n | \"Standard_G1\"\n | \"Standard_G2\"\n | \"Standard_G3\"\n | \"Standard_G4\"\n | \"Standard_G5\"\n | \"Standard_GS1\"\n | \"Standard_GS2\"\n | \"Standard_GS3\"\n | \"Standard_GS4\"\n | \"Standard_GS5\"\n | \"Standard_GS4-8\"\n | \"Standard_GS4-4\"\n | \"Standard_GS5-16\"\n | \"Standard_GS5-8\"\n | \"Standard_H8\"\n | \"Standard_H16\"\n | \"Standard_H8m\"\n | \"Standard_H16m\"\n | \"Standard_H16r\"\n | \"Standard_H16mr\"\n | \"Standard_L4s\"\n | \"Standard_L8s\"\n | \"Standard_L16s\"\n | \"Standard_L32s\"\n | \"Standard_M64s\"\n | \"Standard_M64ms\"\n | \"Standard_M128s\"\n | \"Standard_M128ms\"\n | \"Standard_M64-32ms\"\n | \"Standard_M64-16ms\"\n | \"Standard_M128-64ms\"\n | \"Standard_M128-32ms\"\n | \"Standard_NC6\"\n | \"Standard_NC12\"\n | \"Standard_NC24\"\n | \"Standard_NC24r\"\n | \"Standard_NC6s_v2\"\n | \"Standard_NC12s_v2\"\n | \"Standard_NC24s_v2\"\n | \"Standard_NC24rs_v2\"\n | \"Standard_NC6s_v3\"\n | \"Standard_NC12s_v3\"\n | \"Standard_NC24s_v3\"\n | \"Standard_NC24rs_v3\"\n | \"Standard_ND6s\"\n | \"Standard_ND12s\"\n | \"Standard_ND24s\"\n | \"Standard_ND24rs\"\n | \"Standard_NV6\"\n | \"Standard_NV12\"\n | \"Standard_NV24\";\n /** Specifies the properties for customizing the size of the virtual machine. Minimum api-version: 2021-07-01. <br><br> This feature is still in preview mode and is not supported for VirtualMachineScaleSet. <br><br> Please follow the instructions in [VM Customization](https://aka.ms/vmcustomization) for more details. */\n vmSizeProperties?: VMSizePropertiesOutput;\n}\n\n/** Specifies the storage settings for the virtual machine disks. */\nexport interface StorageProfileOutput {\n /** Specifies information about the image to use. You can specify information about platform images, marketplace images, or virtual machine images. This element is required when you want to use a platform image, marketplace image, or virtual machine image, but is not used in other creation operations. */\n imageReference?: ImageReferenceOutput;\n /** Specifies information about the operating system disk used by the virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: OSDiskOutput;\n /** Specifies the parameters that are used to add a data disk to a virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: Array<DataDiskOutput>;\n /** Specifies the disk controller type configured for the VM. <br><br>NOTE: This property will be set to the default disk controller type if not specified provided virtual machine is being created as a hyperVGeneration: V2 based on the capabilities of the operating system disk and VM size from the the specified minimum api version. <br>You need to deallocate the VM before updating its disk controller type unless you are updating the VM size in the VM configuration which implicitly deallocates and reallocates the VM. <br><br> Minimum api-version: 2022-08-01 */\n diskControllerType?: \"SCSI\" | \"NVMe\";\n}\n\n/** Specifies information about the operating system disk used by the virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\nexport interface OSDiskOutput {\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from user-image or a specialized VHD. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType?: \"Windows\" | \"Linux\";\n /** Specifies the encryption settings for the OS Disk. <br><br> Minimum api-version: 2015-06-15 */\n encryptionSettings?: DiskEncryptionSettingsOutput;\n /** The disk name. */\n name?: string;\n /** The virtual hard disk. */\n vhd?: VirtualHardDiskOutput;\n /** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\n image?: VirtualHardDiskOutput;\n /** Specifies the caching requirements. <br><br> Possible values are: <br><br> **None** <br><br> **ReadOnly** <br><br> **ReadWrite** <br><br> Default: **None** for Standard storage. **ReadOnly** for Premium storage. */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies the ephemeral Disk Settings for the operating system disk used by the virtual machine. */\n diffDiskSettings?: DiffDiskSettingsOutput;\n /** Specifies how the virtual machine should be created.<br><br> Possible values are:<br><br> **Attach** \\u2013 This value is used when you are using a specialized disk to create the virtual machine.<br><br> **FromImage** \\u2013 This value is used when you are using an image to create the virtual machine. If you are using a platform image, you also use the imageReference element described above. If you are using a marketplace image, you also use the plan element previously described. */\n createOption: \"FromImage\" | \"Empty\" | \"Attach\";\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. <br><br> diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023 */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: ManagedDiskParametersOutput;\n /** Specifies whether OS Disk should be deleted or detached upon VM deletion. <br><br> Possible values: <br><br> **Delete** If this value is used, the OS disk is deleted when VM is deleted.<br><br> **Detach** If this value is used, the os disk is retained after VM is deleted. <br><br> The default value is set to **detach**. For an ephemeral OS Disk, the default value is set to **Delete**. User cannot change the delete option for ephemeral OS Disk. */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** The parameters of a managed disk. */\nexport interface ManagedDiskParametersOutput extends SubResourceOutput {\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?:\n | \"Standard_LRS\"\n | \"Premium_LRS\"\n | \"StandardSSD_LRS\"\n | \"UltraSSD_LRS\"\n | \"Premium_ZRS\"\n | \"StandardSSD_ZRS\"\n | \"PremiumV2_LRS\";\n /** Specifies the customer managed disk encryption set resource id for the managed disk. */\n diskEncryptionSet?: DiskEncryptionSetParametersOutput;\n /** Specifies the security profile for the managed disk. */\n securityProfile?: VMDiskSecurityProfileOutput;\n}\n\n/** Describes a data disk. */\nexport interface DataDiskOutput {\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n /** The disk name. */\n name?: string;\n /** The virtual hard disk. */\n vhd?: VirtualHardDiskOutput;\n /** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\n image?: VirtualHardDiskOutput;\n /** Specifies the caching requirements. <br><br> Possible values are: <br><br> **None** <br><br> **ReadOnly** <br><br> **ReadWrite** <br><br> Default: **None for Standard storage. ReadOnly for Premium storage** */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Specifies whether writeAccelerator should be enabled or disabled on the disk. */\n writeAcceleratorEnabled?: boolean;\n /** Specifies how the virtual machine should be created.<br><br> Possible values are:<br><br> **Attach** \\u2013 This value is used when you are using a specialized disk to create the virtual machine.<br><br> **FromImage** \\u2013 This value is used when you are using an image to create the virtual machine. If you are using a platform image, you also use the imageReference element described above. If you are using a marketplace image, you also use the plan element previously described. */\n createOption: \"FromImage\" | \"Empty\" | \"Attach\";\n /** Specifies the size of an empty data disk in gigabytes. This element can be used to overwrite the size of the disk in a virtual machine image. <br><br> diskSizeGB is the number of bytes x 1024^3 for the disk and the value cannot be larger than 1023 */\n diskSizeGB?: number;\n /** The managed disk parameters. */\n managedDisk?: ManagedDiskParametersOutput;\n /** Specifies whether the data disk is in process of detachment from the VirtualMachine/VirtualMachineScaleset */\n toBeDetached?: boolean;\n /** Specifies the Read-Write IOPS for the managed disk when StorageAccountType is UltraSSD_LRS. Returned only for VirtualMachine ScaleSet VM disks. Can be updated only via updates to the VirtualMachine Scale Set. */\n readonly diskIOPSReadWrite?: number;\n /** Specifies the bandwidth in MB per second for the managed disk when StorageAccountType is UltraSSD_LRS. Returned only for VirtualMachine ScaleSet VM disks. Can be updated only via updates to the VirtualMachine Scale Set. */\n readonly diskMBpsReadWrite?: number;\n /** Specifies the detach behavior to be used while detaching a disk or which is already in the process of detachment from the virtual machine. Supported values: **ForceDetach**. <br><br> detachOption: **ForceDetach** is applicable only for managed data disks. If a previous detachment attempt of the data disk did not complete due to an unexpected failure from the virtual machine and the disk is still not released then use force-detach as a last resort option to detach the disk forcibly from the VM. All writes might not have been flushed when using this detach behavior. <br><br> This feature is still in preview mode and is not supported for VirtualMachineScaleSet. To force-detach a data disk update toBeDetached to 'true' along with setting detachOption: 'ForceDetach'. */\n detachOption?: \"ForceDetach\";\n /** Specifies whether data disk should be deleted or detached upon VM deletion.<br><br> Possible values: <br><br> **Delete** If this value is used, the data disk is deleted when VM is deleted.<br><br> **Detach** If this value is used, the data disk is retained after VM is deleted.<br><br> The default value is set to **detach** */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Specifies the operating system settings for the virtual machine. Some of the settings cannot be changed once VM is provisioned. */\nexport interface OSProfileOutput {\n /** Specifies the host OS name of the virtual machine. <br><br> This name cannot be updated after the VM is created. <br><br> **Max-length (Windows):** 15 characters <br><br> **Max-length (Linux):** 64 characters. <br><br> For naming conventions and restrictions see [Azure infrastructure services implementation guidelines](https://docs.microsoft.com/azure/azure-resource-manager/management/resource-name-rules). */\n computerName?: string;\n /** Specifies the name of the administrator account. <br><br> This property cannot be updated after the VM is created. <br><br> **Windows-only restriction:** Cannot end in \".\" <br><br> **Disallowed values:** \"administrator\", \"admin\", \"user\", \"user1\", \"test\", \"user2\", \"test1\", \"user3\", \"admin1\", \"1\", \"123\", \"a\", \"actuser\", \"adm\", \"admin2\", \"aspnet\", \"backup\", \"console\", \"david\", \"guest\", \"john\", \"owner\", \"root\", \"server\", \"sql\", \"support\", \"support_388945a0\", \"sys\", \"test2\", \"test3\", \"user4\", \"user5\". <br><br> **Minimum-length (Linux):** 1 character <br><br> **Max-length (Linux):** 64 characters <br><br> **Max-length (Windows):** 20 characters. */\n adminUsername?: string;\n /** Specifies the password of the administrator account. <br><br> **Minimum-length (Windows):** 8 characters <br><br> **Minimum-length (Linux):** 6 characters <br><br> **Max-length (Windows):** 123 characters <br><br> **Max-length (Linux):** 72 characters <br><br> **Complexity requirements:** 3 out of 4 conditions below need to be fulfilled <br> Has lower characters <br>Has upper characters <br> Has a digit <br> Has a special character (Regex match [\\W_]) <br><br> **Disallowed values:** \"abc@123\", \"P@$$w0rd\", \"P@ssw0rd\", \"P@ssword123\", \"Pa$$word\", \"pass@word1\", \"Password!\", \"Password1\", \"Password22\", \"iloveyou!\" <br><br> For resetting the password, see [How to reset the Remote Desktop service or its login password in a Windows VM](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/reset-rdp) <br><br> For resetting root password, see [Manage users, SSH, and check or repair disks on Azure Linux VMs using the VMAccess Extension](https://docs.microsoft.com/troubleshoot/azure/virtual-machines/troubleshoot-ssh-connection) */\n adminPassword?: string;\n /** Specifies a base-64 encoded string of custom data. The base-64 encoded string is decoded to a binary array that is saved as a file on the Virtual Machine. The maximum length of the binary array is 65535 bytes. <br><br> **Note: Do not pass any secrets or passwords in customData property** <br><br> This property cannot be updated after the VM is created. <br><br> customData is passed to the VM to be saved as a file, for more information see [Custom Data on Azure VMs](https://azure.microsoft.com/blog/custom-data-and-cloud-init-on-windows-azure/) <br><br> For using cloud-init for your Linux VM, see [Using cloud-init to customize a Linux VM during creation](https://docs.microsoft.com/azure/virtual-machines/linux/using-cloud-init) */\n customData?: string;\n /** Specifies Windows operating system settings on the virtual machine. */\n windowsConfiguration?: WindowsConfigurationOutput;\n /** Specifies the Linux operating system settings on the virtual machine. <br><br>For a list of supported Linux distributions, see [Linux on Azure-Endorsed Distributions](https://docs.microsoft.com/azure/virtual-machines/linux/endorsed-distros). */\n linuxConfiguration?: LinuxConfigurationOutput;\n /** Specifies set of certificates that should be installed onto the virtual machine. To install certificates on a virtual machine it is recommended to use the [Azure Key Vault virtual machine extension for Linux](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-linux) or the [Azure Key Vault virtual machine extension for Windows](https://docs.microsoft.com/azure/virtual-machines/extensions/key-vault-windows). */\n secrets?: Array<VaultSecretGroupOutput>;\n /** Specifies whether extension operations should be allowed on the virtual machine. <br><br>This may only be set to False when no extensions are present on the virtual machine. */\n allowExtensionOperations?: boolean;\n /** Optional property which must either be set to True or omitted. */\n requireGuestProvisionSignal?: boolean;\n}\n\n/** Specifies the network interfaces or the networking configuration of the virtual machine. */\nexport interface NetworkProfileOutput {\n /** Specifies the list of resource Ids for the network interfaces associated with the virtual machine. */\n networkInterfaces?: Array<NetworkInterfaceReferenceOutput>;\n /** specifies the Microsoft.Network API version used when creating networking resources in the Network Interface Configurations */\n networkApiVersion?: \"2020-11-01\";\n /** Specifies the networking configurations that will be used to create the virtual machine networking resources. */\n networkInterfaceConfigurations?: Array<VirtualMachineNetworkInterfaceConfigurationOutput>;\n}\n\n/** Describes a network interface reference. */\nexport interface NetworkInterfaceReferenceOutput extends SubResourceOutput {\n /** Describes a network interface reference properties. */\n properties?: NetworkInterfaceReferencePropertiesOutput;\n}\n\n/** Describes a network interface reference properties. */\nexport interface NetworkInterfaceReferencePropertiesOutput {\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n}\n\n/** Describes a virtual machine network interface configurations. */\nexport interface VirtualMachineNetworkInterfaceConfigurationOutput {\n /** The network interface configuration name. */\n name: string;\n /** Describes a virtual machine network profile's IP configuration. */\n properties?: VirtualMachineNetworkInterfaceConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine network profile's IP configuration. */\nexport interface VirtualMachineNetworkInterfaceConfigurationPropertiesOutput {\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** Specify what happens to the network interface when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n /** Specifies whether the network interface is accelerated networking-enabled. */\n enableAcceleratedNetworking?: boolean;\n /** Specifies whether the network interface is disabled for tcp state tracking. */\n disableTcpStateTracking?: boolean;\n /** Specifies whether the network interface is FPGA networking-enabled. */\n enableFpga?: boolean;\n /** Whether IP forwarding enabled on this NIC. */\n enableIPForwarding?: boolean;\n /** The network security group. */\n networkSecurityGroup?: SubResourceOutput;\n /** The dns settings to be applied on the network interfaces. */\n dnsSettings?: VirtualMachineNetworkInterfaceDnsSettingsConfigurationOutput;\n /** Specifies the IP configurations of the network interface. */\n ipConfigurations: Array<VirtualMachineNetworkInterfaceIPConfigurationOutput>;\n dscpConfiguration?: SubResourceOutput;\n}\n\n/** Describes a virtual machines network configuration's DNS settings. */\nexport interface VirtualMachineNetworkInterfaceDnsSettingsConfigurationOutput {\n /** List of DNS servers IP addresses */\n dnsServers?: Array<string>;\n}\n\n/** Describes a virtual machine network profile's IP configuration. */\nexport interface VirtualMachineNetworkInterfaceIPConfigurationOutput {\n /** The IP configuration name. */\n name: string;\n /** Describes a virtual machine network interface IP configuration properties. */\n properties?: VirtualMachineNetworkInterfaceIPConfigurationPropertiesOutput;\n}\n\n/** Describes a virtual machine network interface IP configuration properties. */\nexport interface VirtualMachineNetworkInterfaceIPConfigurationPropertiesOutput {\n /** Specifies the identifier of the subnet. */\n subnet?: SubResourceOutput;\n /** Specifies the primary network interface in case the virtual machine has more than 1 network interface. */\n primary?: boolean;\n /** The publicIPAddressConfiguration. */\n publicIPAddressConfiguration?: VirtualMachinePublicIPAddressConfigurationOutput;\n /** Available from Api-Version 2017-03-30 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n privateIPAddressVersion?: \"IPv4\" | \"IPv6\";\n /** Specifies an array of references to application security group. */\n applicationSecurityGroups?: Array<SubResourceOutput>;\n /** Specifies an array of references to backend address pools of application gateways. A virtual machine can reference backend address pools of multiple application gateways. Multiple virtual machines cannot use the same application gateway. */\n applicationGatewayBackendAddressPools?: Array<SubResourceOutput>;\n /** Specifies an array of references to backend address pools of load balancers. A virtual machine can reference backend address pools of one public and one internal load balancer. [Multiple virtual machines cannot use the same basic sku load balancer]. */\n loadBalancerBackendAddressPools?: Array<SubResourceOutput>;\n}\n\n/** Describes a virtual machines IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachinePublicIPAddressConfigurationOutput {\n /** The publicIP address configuration name. */\n name: string;\n /** Describes a virtual machines IP Configuration's PublicIPAddress configuration */\n properties?: VirtualMachinePublicIPAddressConfigurationPropertiesOutput;\n /** Describes the public IP Sku. It can only be set with OrchestrationMode as Flexible. */\n sku?: PublicIPAddressSkuOutput;\n}\n\n/** Describes a virtual machines IP Configuration's PublicIPAddress configuration */\nexport interface VirtualMachinePublicIPAddressConfigurationPropertiesOutput {\n /** The idle timeout of the public IP address. */\n idleTimeoutInMinutes?: number;\n /** Specify what happens to the public IP address when the VM is deleted */\n deleteOption?: \"Delete\" | \"Detach\";\n /** The dns settings to be applied on the publicIP addresses . */\n dnsSettings?: VirtualMachinePublicIPAddressDnsSettingsConfigurationOutput;\n /** The list of IP tags associated with the public IP address. */\n ipTags?: Array<VirtualMachineIpTagOutput>;\n /** The PublicIPPrefix from which to allocate publicIP addresses. */\n publicIPPrefix?: SubResourceOutput;\n /** Available from Api-Version 2019-07-01 onwards, it represents whether the specific ipconfiguration is IPv4 or IPv6. Default is taken as IPv4. Possible values are: 'IPv4' and 'IPv6'. */\n publicIPAddressVersion?: \"IPv4\" | \"IPv6\";\n /** Specify the public IP allocation type */\n publicIPAllocationMethod?: \"Dynamic\" | \"Static\";\n}\n\n/** Describes a virtual machines network configuration's DNS settings. */\nexport interface VirtualMachinePublicIPAddressDnsSettingsConfigurationOutput {\n /** The Domain name label prefix of the PublicIPAddress resources that will be created. The generated name label is the concatenation of the domain name label and vm network profile unique ID. */\n domainNameLabel: string;\n}\n\n/** Contains the IP tag associated with the public IP address. */\nexport interface VirtualMachineIpTagOutput {\n /** IP tag type. Example: FirstPartyUsage. */\n ipTagType?: string;\n /** IP tag associated with the public IP. Example: SQL, Storage etc. */\n tag?: string;\n}\n\n/** Describes a virtual machine scale set VM network profile. */\nexport interface VirtualMachineScaleSetVMNetworkProfileConfigurationOutput {\n /** The list of network configurations. */\n networkInterfaceConfigurations?: Array<VirtualMachineScaleSetNetworkConfigurationOutput>;\n}\n\n/** The protection policy of a virtual machine scale set VM. */\nexport interface VirtualMachineScaleSetVMProtectionPolicyOutput {\n /** Indicates that the virtual machine scale set VM shouldn't be considered for deletion during a scale-in operation. */\n protectFromScaleIn?: boolean;\n /** Indicates that model updates or actions (including scale-in) initiated on the virtual machine scale set should not be applied to the virtual machine scale set VM. */\n protectFromScaleSetActions?: boolean;\n}\n\n/** Describes a Virtual Machine Extension. */\nexport interface VirtualMachineExtensionOutput extends ResourceWithOptionalLocationOutput {\n /** Describes the properties of a Virtual Machine Extension. */\n properties?: VirtualMachineExtensionPropertiesOutput;\n}\n\n/** The Resource model definition with location property as optional. */\nexport interface ResourceWithOptionalLocationOutput {\n /** Resource location */\n location?: string;\n /** Resource Id */\n readonly id?: string;\n /** Resource name */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Resource tags */\n tags?: Record<string, string>;\n}\n\n/** Identity for the virtual machine. */\nexport interface VirtualMachineIdentityOutput {\n /** The principal id of virtual machine identity. This property will only be provided for a system assigned identity. */\n readonly principalId?: string;\n /** The tenant id associated with the virtual machine. This property will only be provided for a system assigned identity. */\n readonly tenantId?: string;\n /** The type of identity used for the virtual machine. The type 'SystemAssigned, UserAssigned' includes both an implicitly created identity and a set of user assigned identities. The type 'None' will remove any identities from the virtual machine. */\n type?: \"SystemAssigned\" | \"UserAssigned\" | \"SystemAssigned, UserAssigned\" | \"None\";\n /** The list of user identities associated with the Virtual Machine. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: Record<string, UserAssignedIdentitiesValueOutput>;\n}\n\n/** The List Virtual Machine Scale Set VMs operation response. */\nexport interface VirtualMachineScaleSetVMListResultOutput {\n /** The list of virtual machine scale sets VMs. */\n value: Array<VirtualMachineScaleSetVMOutput>;\n /** The uri to fetch the next page of Virtual Machine Scale Set VMs. Call ListNext() with this to fetch the next page of VMSS VMs */\n nextLink?: string;\n}\n\n/** The SAS URIs of the console screenshot and serial log blobs. */\nexport interface RetrieveBootDiagnosticsDataResultOutput {\n /** The console screenshot blob URI */\n readonly consoleScreenshotBlobUri?: string;\n /** The serial console log blob URI. */\n readonly serialConsoleLogBlobUri?: string;\n}\n\n/** The List Extension operation response */\nexport interface VirtualMachineExtensionsListResultOutput {\n /** The list of extensions */\n value?: Array<VirtualMachineExtensionOutput>;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface VirtualMachineListResultOutput {\n /** The list of virtual machines. */\n value: Array<VirtualMachineOutput>;\n /** The URI to fetch the next page of VMs. Call ListNext() with this URI to fetch the next page of Virtual Machines. */\n nextLink?: string;\n}\n\n/** Describes a Virtual Machine. */\nexport interface VirtualMachineOutput extends ResourceOutput {\n /** Specifies information about the marketplace image used to create the virtual machine. This element is only used for marketplace images. Before you can use a marketplace image from an API, you must enable the image for programmatic use. In the Azure portal, find the marketplace image that you want to use and then click **Want to deploy programmatically, Get Started ->**. Enter any required information and then click **Save**. */\n plan?: PlanOutput;\n /** Describes the properties of a Virtual Machine. */\n properties?: VirtualMachinePropertiesOutput;\n /** The virtual machine child extension resources. */\n readonly resources?: Array<VirtualMachineExtensionOutput>;\n /** The identity of the virtual machine, if configured. */\n identity?: VirtualMachineIdentityOutput;\n /** The virtual machine zones. */\n zones?: Array<string>;\n /** The extended location of the Virtual Machine. */\n extendedLocation?: ExtendedLocationOutput;\n}\n\n/** Describes the properties of a Virtual Machine. */\nexport interface VirtualMachinePropertiesOutput {\n /** Specifies the hardware settings for the virtual machine. */\n hardwareProfile?: HardwareProfileOutput;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: StorageProfileOutput;\n /** Specifies additional capabilities enabled or disabled on the virtual machine. */\n additionalCapabilities?: AdditionalCapabilitiesOutput;\n /** Specifies the operating system settings used while creating the virtual machine. Some of the settings cannot be changed once VM is provisioned. */\n osProfile?: OSProfileOutput;\n /** Specifies the network interfaces of the virtual machine. */\n networkProfile?: NetworkProfileOutput;\n /** Specifies the Security related profile settings for the virtual machine. */\n securityProfile?: SecurityProfileOutput;\n /** Specifies the boot diagnostic settings state. <br><br>Minimum api-version: 2015-06-15. */\n diagnosticsProfile?: DiagnosticsProfileOutput;\n /** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). <br><br> For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates) <br><br> Currently, a VM can only be added to availability set at creation time. The availability set to which the VM is being added should be under the same resource group as the availability set resource. An existing VM cannot be added to an availability set. <br><br>This property cannot exist along with a non-null properties.virtualMachineScaleSet reference. */\n availabilitySet?: SubResourceOutput;\n /** Specifies information about the virtual machine scale set that the virtual machine should be assigned to. Virtual machines specified in the same virtual machine scale set are allocated to different nodes to maximize availability. Currently, a VM can only be added to virtual machine scale set at creation time. An existing VM cannot be added to a virtual machine scale set. <br><br>This property cannot exist along with a non-null properties.availabilitySet reference. <br><br>Minimum api‐version: 2019‐03‐01 */\n virtualMachineScaleSet?: SubResourceOutput;\n /** Specifies information about the proximity placement group that the virtual machine should be assigned to. <br><br>Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResourceOutput;\n /** Specifies the priority for the virtual machine. <br><br>Minimum api-version: 2019-03-01 */\n priority?: \"Regular\" | \"Low\" | \"Spot\";\n /** Specifies the eviction policy for the Azure Spot virtual machine and Azure Spot scale set. <br><br>For Azure Spot virtual machines, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2019-03-01. <br><br>For Azure Spot scale sets, both 'Deallocate' and 'Delete' are supported and the minimum api-version is 2017-10-30-preview. */\n evictionPolicy?: \"Deallocate\" | \"Delete\";\n /** Specifies the billing related details of a Azure Spot virtual machine. <br><br>Minimum api-version: 2019-03-01. */\n billingProfile?: BillingProfileOutput;\n /** Specifies information about the dedicated host that the virtual machine resides in. <br><br>Minimum api-version: 2018-10-01. */\n host?: SubResourceOutput;\n /** Specifies information about the dedicated host group that the virtual machine resides in. <br><br>Minimum api-version: 2020-06-01. <br><br>NOTE: User cannot specify both host and hostGroup properties. */\n hostGroup?: SubResourceOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The virtual machine instance view. */\n readonly instanceView?: VirtualMachineInstanceViewOutput;\n /** Specifies that the image or disk that is being used was licensed on-premises. <br><br> Possible values for Windows Server operating system are: <br><br> Windows_Client <br><br> Windows_Server <br><br> Possible values for Linux Server operating system are: <br><br> RHEL_BYOS (for RHEL) <br><br> SLES_BYOS (for SUSE) <br><br> For more information, see [Azure Hybrid Use Benefit for Windows Server](https://docs.microsoft.com/azure/virtual-machines/windows/hybrid-use-benefit-licensing) <br><br> [Azure Hybrid Use Benefit for Linux Server](https://docs.microsoft.com/azure/virtual-machines/linux/azure-hybrid-benefit-linux) <br><br> Minimum api-version: 2015-06-15 */\n licenseType?: string;\n /** Specifies the VM unique ID which is a 128-bits identifier that is encoded and stored in all Azure IaaS VMs SMBIOS and can be read using platform BIOS commands. */\n readonly vmId?: string;\n /** Specifies the time alloted for all extensions to start. The time duration should be between 15 minutes and 120 minutes (inclusive) and should be specified in ISO 8601 format. The default value is 90 minutes (PT1H30M). <br><br> Minimum api-version: 2020-06-01 */\n extensionsTimeBudget?: string;\n /** Specifies the scale set logical fault domain into which the Virtual Machine will be created. By default, the Virtual Machine will by automatically assigned to a fault domain that best maintains balance across available fault domains.<br><li>This is applicable only if the 'virtualMachineScaleSet' property of this Virtual Machine is set.<li>The Virtual Machine Scale Set that is referenced, must have 'platformFaultDomainCount' > 1.<li>This property cannot be updated once the Virtual Machine is created.<li>Fault domain assignment can be viewed in the Virtual Machine Instance View.<br><br>Minimum api‐version: 2020‐12‐01 */\n platformFaultDomain?: number;\n /** Specifies Scheduled Event related configurations. */\n scheduledEventsProfile?: ScheduledEventsProfileOutput;\n /** UserData for the VM, which must be base-64 encoded. Customer should not pass any secrets in here. <br><br>Minimum api-version: 2021-03-01 */\n userData?: string;\n /** Specifies information about the capacity reservation that is used to allocate virtual machine. <br><br>Minimum api-version: 2021-04-01. */\n capacityReservation?: CapacityReservationProfileOutput;\n /** Specifies the gallery applications that should be made available to the VM/VMSS */\n applicationProfile?: ApplicationProfileOutput;\n /** Specifies the time at which the Virtual Machine resource was created.<br><br>Minimum api-version: 2021-11-01. */\n readonly timeCreated?: string;\n}\n\n/** The instance view of a virtual machine. */\nexport interface VirtualMachineInstanceViewOutput {\n /** Specifies the update domain of the virtual machine. */\n platformUpdateDomain?: number;\n /** Specifies the fault domain of the virtual machine. */\n platformFaultDomain?: number;\n /** The computer name assigned to the virtual machine. */\n computerName?: string;\n /** The Operating System running on the virtual machine. */\n osName?: string;\n /** The version of Operating System running on the virtual machine. */\n osVersion?: string;\n /** Specifies the HyperVGeneration Type associated with a resource */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** The Remote desktop certificate thumbprint. */\n rdpThumbPrint?: string;\n /** The VM Agent running on the virtual machine. */\n vmAgent?: VirtualMachineAgentInstanceViewOutput;\n /** The Maintenance Operation status on the virtual machine. */\n maintenanceRedeployStatus?: MaintenanceRedeployStatusOutput;\n /** The virtual machine disk information. */\n disks?: Array<DiskInstanceViewOutput>;\n /** The extensions information. */\n extensions?: Array<VirtualMachineExtensionInstanceViewOutput>;\n /** The health status for the VM. */\n readonly vmHealth?: VirtualMachineHealthStatusOutput;\n /** Boot Diagnostics is a debugging feature which allows you to view Console Output and Screenshot to diagnose VM status. <br><br> You can easily view the output of your console log. <br><br> Azure also enables you to see a screenshot of the VM from the hypervisor. */\n bootDiagnostics?: BootDiagnosticsInstanceViewOutput;\n /** Resource id of the dedicated host, on which the virtual machine is allocated through automatic placement, when the virtual machine is associated with a dedicated host group that has automatic placement enabled. <br><br>Minimum api-version: 2020-06-01. */\n readonly assignedHost?: string;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n /** [Preview Feature] The status of virtual machine patch operations. */\n patchStatus?: VirtualMachinePatchStatusOutput;\n}\n\n/** The status of virtual machine patch operations. */\nexport interface VirtualMachinePatchStatusOutput {\n /** The available patch summary of the latest assessment operation for the virtual machine. */\n availablePatchSummary?: AvailablePatchSummaryOutput;\n /** The installation summary of the latest installation operation for the virtual machine. */\n lastPatchInstallationSummary?: LastPatchInstallationSummaryOutput;\n /** The enablement status of the specified patchMode */\n readonly configurationStatuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** Describes the properties of an virtual machine instance view for available patch summary. */\nexport interface AvailablePatchSummaryOutput {\n /** The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\" */\n readonly status?: \"Unknown\" | \"InProgress\" | \"Failed\" | \"Succeeded\" | \"CompletedWithWarnings\";\n /** The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs. */\n readonly assessmentActivityId?: string;\n /** The overall reboot status of the VM. It will be true when partially installed patches require a reboot to complete installation but the reboot has not yet occurred. */\n readonly rebootPending?: boolean;\n /** The number of critical or security patches that have been detected as available and not yet installed. */\n readonly criticalAndSecurityPatchCount?: number;\n /** The number of all available patches excluding critical and security. */\n readonly otherPatchCount?: number;\n /** The UTC timestamp when the operation began. */\n readonly startTime?: string;\n /** The UTC timestamp when the operation began. */\n readonly lastModifiedTime?: string;\n /** The errors that were encountered during execution of the operation. The details array contains the list of them. */\n readonly error?: ApiErrorOutput;\n}\n\n/** Describes the properties of the last installed patch summary. */\nexport interface LastPatchInstallationSummaryOutput {\n /** The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\" */\n readonly status?: \"Unknown\" | \"InProgress\" | \"Failed\" | \"Succeeded\" | \"CompletedWithWarnings\";\n /** The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs. */\n readonly installationActivityId?: string;\n /** Describes whether the operation ran out of time before it completed all its intended actions */\n readonly maintenanceWindowExceeded?: boolean;\n /** The number of all available patches but not going to be installed because it didn't match a classification or inclusion list entry. */\n readonly notSelectedPatchCount?: number;\n /** The number of all available patches but excluded explicitly by a customer-specified exclusion list match. */\n readonly excludedPatchCount?: number;\n /** The number of all available patches expected to be installed over the course of the patch installation operation. */\n readonly pendingPatchCount?: number;\n /** The count of patches that successfully installed. */\n readonly installedPatchCount?: number;\n /** The count of patches that failed installation. */\n readonly failedPatchCount?: number;\n /** The UTC timestamp when the operation began. */\n readonly startTime?: string;\n /** The UTC timestamp when the operation began. */\n readonly lastModifiedTime?: string;\n /** The errors that were encountered during execution of the operation. The details array contains the list of them. */\n readonly error?: ApiErrorOutput;\n}\n\n/** Output of virtual machine capture operation. */\nexport interface VirtualMachineCaptureResultOutput extends SubResourceOutput {\n /** the schema of the captured virtual machine */\n readonly $schema?: string;\n /** the version of the content */\n readonly contentVersion?: string;\n /** parameters of the captured virtual machine */\n readonly parameters?: any;\n /** a list of resource items of the captured virtual machine */\n readonly resources?: Array<any>;\n}\n\n/** Describes the properties of an AssessPatches result. */\nexport interface VirtualMachineAssessPatchesResultOutput {\n /** The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Unknown\", \"Failed\", \"Succeeded\", or \"CompletedWithWarnings.\" */\n readonly status?: \"Unknown\" | \"InProgress\" | \"Failed\" | \"Succeeded\" | \"CompletedWithWarnings\";\n /** The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs. */\n readonly assessmentActivityId?: string;\n /** The overall reboot status of the VM. It will be true when partially installed patches require a reboot to complete installation but the reboot has not yet occurred. */\n readonly rebootPending?: boolean;\n /** The number of critical or security patches that have been detected as available and not yet installed. */\n readonly criticalAndSecurityPatchCount?: number;\n /** The number of all available patches excluding critical and security. */\n readonly otherPatchCount?: number;\n /** The UTC timestamp when the operation began. */\n readonly startDateTime?: string;\n /** The list of patches that have been detected as available for installation. */\n readonly availablePatches?: Array<VirtualMachineSoftwarePatchPropertiesOutput>;\n /** The errors that were encountered during execution of the operation. The details array contains the list of them. */\n readonly error?: ApiErrorOutput;\n}\n\n/** Describes the properties of a Virtual Machine software patch. */\nexport interface VirtualMachineSoftwarePatchPropertiesOutput {\n /** A unique identifier for the patch. */\n readonly patchId?: string;\n /** The friendly name of the patch. */\n readonly name?: string;\n /** The version number of the patch. This property applies only to Linux patches. */\n readonly version?: string;\n /** The KBID of the patch. Only applies to Windows patches. */\n readonly kbId?: string;\n /** The classification(s) of the patch as provided by the patch publisher. */\n readonly classifications?: Array<string>;\n /** Describes the reboot requirements of the patch. */\n readonly rebootBehavior?:\n | \"Unknown\"\n | \"NeverReboots\"\n | \"AlwaysRequiresReboot\"\n | \"CanRequestReboot\";\n /** The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs. */\n readonly activityId?: string;\n /** The UTC timestamp when the repository published this patch. */\n readonly publishedDate?: string;\n /** The UTC timestamp of the last update to this patch record. */\n readonly lastModifiedDateTime?: string;\n /** Describes the availability of a given patch. */\n readonly assessmentState?: \"Unknown\" | \"Available\";\n}\n\n/** The result summary of an installation operation. */\nexport interface VirtualMachineInstallPatchesResultOutput {\n /** The overall success or failure status of the operation. It remains \"InProgress\" until the operation completes. At that point it will become \"Failed\", \"Succeeded\", \"Unknown\" or \"CompletedWithWarnings.\" */\n readonly status?: \"Unknown\" | \"InProgress\" | \"Failed\" | \"Succeeded\" | \"CompletedWithWarnings\";\n /** The activity ID of the operation that produced this result. It is used to correlate across CRP and extension logs. */\n readonly installationActivityId?: string;\n /** The reboot state of the VM following completion of the operation. */\n readonly rebootStatus?: \"Unknown\" | \"NotNeeded\" | \"Required\" | \"Started\" | \"Failed\" | \"Completed\";\n /** Whether the operation ran out of time before it completed all its intended actions. */\n readonly maintenanceWindowExceeded?: boolean;\n /** The number of patches that were not installed due to the user blocking their installation. */\n readonly excludedPatchCount?: number;\n /** The number of patches that were detected as available for install, but did not meet the operation's criteria. */\n readonly notSelectedPatchCount?: number;\n /** The number of patches that were identified as meeting the installation criteria, but were not able to be installed. Typically this happens when maintenanceWindowExceeded == true. */\n readonly pendingPatchCount?: number;\n /** The number of patches successfully installed. */\n readonly installedPatchCount?: number;\n /** The number of patches that could not be installed due to some issue. See errors for details. */\n readonly failedPatchCount?: number;\n /** The patches that were installed during the operation. */\n readonly patches?: Array<PatchInstallationDetailOutput>;\n /** The UTC timestamp when the operation began. */\n readonly startDateTime?: string;\n /** The errors that were encountered during execution of the operation. The details array contains the list of them. */\n readonly error?: ApiErrorOutput;\n}\n\n/** Information about a specific patch that was encountered during an installation action. */\nexport interface PatchInstallationDetailOutput {\n /** A unique identifier for the patch. */\n readonly patchId?: string;\n /** The friendly name of the patch. */\n readonly name?: string;\n /** The version string of the package. It may conform to Semantic Versioning. Only applies to Linux. */\n readonly version?: string;\n /** The KBID of the patch. Only applies to Windows patches. */\n readonly kbId?: string;\n /** The classification(s) of the patch as provided by the patch publisher. */\n readonly classifications?: Array<string>;\n /** The state of the patch after the installation operation completed. */\n readonly installationState?:\n | \"Unknown\"\n | \"Installed\"\n | \"Failed\"\n | \"Excluded\"\n | \"NotSelected\"\n | \"Pending\";\n}\n\n/** Describes a Virtual Machine Image. */\nexport interface VirtualMachineImageOutput extends VirtualMachineImageResourceOutput {\n /** Describes the properties of a Virtual Machine Image. */\n properties?: VirtualMachineImagePropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine Image. */\nexport interface VirtualMachineImagePropertiesOutput {\n /** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\n plan?: PurchasePlanOutput;\n /** Contains the os disk image information. */\n osDiskImage?: OSDiskImageOutput;\n dataDiskImages?: Array<DataDiskImageOutput>;\n /** Describes automatic OS upgrade properties on the image. */\n automaticOSUpgradeProperties?: AutomaticOSUpgradePropertiesOutput;\n /** Specifies the HyperVGeneration Type */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** Specifies disallowed configuration for the VirtualMachine created from the image */\n disallowed?: DisallowedConfigurationOutput;\n features?: Array<VirtualMachineImageFeatureOutput>;\n /** Specifies the Architecture Type */\n architecture?: \"x64\" | \"Arm64\";\n}\n\n/** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\nexport interface PurchasePlanOutput {\n /** The publisher ID. */\n publisher: string;\n /** The plan ID. */\n name: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product: string;\n}\n\n/** Contains the os disk image information. */\nexport interface OSDiskImageOutput {\n /** The operating system of the osDiskImage. */\n operatingSystem: \"Windows\" | \"Linux\";\n}\n\n/** Contains the data disk images information. */\nexport interface DataDiskImageOutput {\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n readonly lun?: number;\n}\n\n/** Describes automatic OS upgrade properties on the image. */\nexport interface AutomaticOSUpgradePropertiesOutput {\n /** Specifies whether automatic OS upgrade is supported on the image. */\n automaticOSUpgradeSupported: boolean;\n}\n\n/** Specifies the disallowed configuration for a virtual machine image. */\nexport interface DisallowedConfigurationOutput {\n /** VM disk types which are disallowed. */\n vmDiskType?: \"None\" | \"Unmanaged\";\n}\n\n/** Specifies additional capabilities supported by the image */\nexport interface VirtualMachineImageFeatureOutput {\n /** The name of the feature. */\n name?: string;\n /** The corresponding value for the feature. */\n value?: string;\n}\n\n/** Virtual machine image resource information. */\nexport interface VirtualMachineImageResourceOutput extends SubResourceOutput {\n /** The name of the resource. */\n name: string;\n /** The supported Azure location of the resource. */\n location: string;\n /** Specifies the tags that are assigned to the virtual machine. For more information about using tags, see [Using tags to organize your Azure resources](https://docs.microsoft.com/azure/azure-resource-manager/resource-group-using-tags.md). */\n tags?: Record<string, string>;\n /** The extended location of the Virtual Machine. */\n extendedLocation?: ExtendedLocationOutput;\n}\n\n/** The List VmImages in EdgeZone operation response. */\nexport interface VmImagesInEdgeZoneListResultOutput {\n /** The list of VMImages in EdgeZone */\n value?: Array<VirtualMachineImageResourceOutput>;\n /** The URI to fetch the next page of VMImages in EdgeZone. Call ListNext() with this URI to fetch the next page of VmImages. */\n nextLink?: string;\n}\n\n/** Describes a Virtual Machine Extension Image. */\nexport interface VirtualMachineExtensionImageOutput extends ResourceOutput {\n /** Describes the properties of a Virtual Machine Extension Image. */\n properties?: VirtualMachineExtensionImagePropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine Extension Image. */\nexport interface VirtualMachineExtensionImagePropertiesOutput {\n /** The operating system this extension supports. */\n operatingSystem: string;\n /** The type of role (IaaS or PaaS) this extension supports. */\n computeRole: string;\n /** The schema defined by publisher, where extension consumers should provide settings in a matching schema. */\n handlerSchema: string;\n /** Whether the extension can be used on xRP VMScaleSets. By default existing extensions are usable on scalesets, but there might be cases where a publisher wants to explicitly indicate the extension is only enabled for CRP VMs but not VMSS. */\n vmScaleSetEnabled?: boolean;\n /** Whether the handler can support multiple extensions. */\n supportsMultipleExtensions?: boolean;\n}\n\n/** Specifies information about the availability set that the virtual machine should be assigned to. Virtual machines specified in the same availability set are allocated to different nodes to maximize availability. For more information about availability sets, see [Availability sets overview](https://docs.microsoft.com/azure/virtual-machines/availability-set-overview). <br><br> For more information on Azure planned maintenance, see [Maintenance and updates for Virtual Machines in Azure](https://docs.microsoft.com/azure/virtual-machines/maintenance-and-updates) <br><br> Currently, a VM can only be added to availability set at creation time. An existing VM cannot be added to an availability set. */\nexport interface AvailabilitySetOutput extends ResourceOutput {\n /** The instance view of a resource. */\n properties?: AvailabilitySetPropertiesOutput;\n /** Sku of the availability set, only name is required to be set. See AvailabilitySetSkuTypes for possible set of values. Use 'Aligned' for virtual machines with managed disks and 'Classic' for virtual machines with unmanaged disks. Default value is 'Classic'. */\n sku?: SkuOutput;\n}\n\n/** The instance view of a resource. */\nexport interface AvailabilitySetPropertiesOutput {\n /** Update Domain count. */\n platformUpdateDomainCount?: number;\n /** Fault Domain count. */\n platformFaultDomainCount?: number;\n /** A list of references to all virtual machines in the availability set. */\n virtualMachines?: Array<SubResourceOutput>;\n /** Specifies information about the proximity placement group that the availability set should be assigned to. <br><br>Minimum api-version: 2018-04-01. */\n proximityPlacementGroup?: SubResourceOutput;\n /** The resource status information. */\n readonly statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** The List Availability Set operation response. */\nexport interface AvailabilitySetListResultOutput {\n /** The list of availability sets */\n value: Array<AvailabilitySetOutput>;\n /** The URI to fetch the next page of AvailabilitySets. Call ListNext() with this URI to fetch the next page of AvailabilitySets. */\n nextLink?: string;\n}\n\n/** Specifies information about the proximity placement group. */\nexport interface ProximityPlacementGroupOutput extends ResourceOutput {\n /** Describes the properties of a Proximity Placement Group. */\n properties?: ProximityPlacementGroupPropertiesOutput;\n /** Specifies the Availability Zone where virtual machine, virtual machine scale set or availability set associated with the proximity placement group can be created. */\n zones?: Array<string>;\n}\n\n/** Describes the properties of a Proximity Placement Group. */\nexport interface ProximityPlacementGroupPropertiesOutput {\n /** Specifies the type of the proximity placement group. <br><br> Possible values are: <br><br> **Standard** : Co-locate resources within an Azure region or Availability Zone. <br><br> **Ultra** : For future use. */\n proximityPlacementGroupType?: \"Standard\" | \"Ultra\";\n /** A list of references to all virtual machines in the proximity placement group. */\n readonly virtualMachines?: Array<SubResourceWithColocationStatusOutput>;\n /** A list of references to all virtual machine scale sets in the proximity placement group. */\n readonly virtualMachineScaleSets?: Array<SubResourceWithColocationStatusOutput>;\n /** A list of references to all availability sets in the proximity placement group. */\n readonly availabilitySets?: Array<SubResourceWithColocationStatusOutput>;\n /** Describes colocation status of the Proximity Placement Group. */\n colocationStatus?: InstanceViewStatusOutput;\n /** Specifies the user intent of the proximity placement group. */\n intent?: ProximityPlacementGroupPropertiesIntentOutput;\n}\n\nexport interface SubResourceWithColocationStatusOutput extends SubResourceOutput {\n /** Describes colocation status of a resource in the Proximity Placement Group. */\n colocationStatus?: InstanceViewStatusOutput;\n}\n\n/** Specifies the user intent of the proximity placement group. */\nexport interface ProximityPlacementGroupPropertiesIntentOutput {\n /** Specifies possible sizes of virtual machines that can be created in the proximity placement group. */\n vmSizes?: Array<string>;\n}\n\n/** The List Proximity Placement Group operation response. */\nexport interface ProximityPlacementGroupListResultOutput {\n /** The list of proximity placement groups */\n value: Array<ProximityPlacementGroupOutput>;\n /** The URI to fetch the next page of proximity placement groups. */\n nextLink?: string;\n}\n\n/** Specifies information about the dedicated host group that the dedicated hosts should be assigned to. <br><br> Currently, a dedicated host can only be added to a dedicated host group at creation time. An existing dedicated host cannot be added to another dedicated host group. */\nexport interface DedicatedHostGroupOutput extends ResourceOutput {\n /** Dedicated Host Group Properties. */\n properties?: DedicatedHostGroupPropertiesOutput;\n /** Availability Zone to use for this host group. Only single zone is supported. The zone can be assigned only during creation. If not provided, the group supports all zones in the region. If provided, enforces each host in the group to be in the same zone. */\n zones?: Array<string>;\n}\n\n/** Dedicated Host Group Properties. */\nexport interface DedicatedHostGroupPropertiesOutput {\n /** Number of fault domains that the host group can span. */\n platformFaultDomainCount: number;\n /** A list of references to all dedicated hosts in the dedicated host group. */\n readonly hosts?: Array<SubResourceReadOnlyOutput>;\n /** The dedicated host group instance view, which has the list of instance view of the dedicated hosts under the dedicated host group. */\n readonly instanceView?: DedicatedHostGroupInstanceViewOutput;\n /** Specifies whether virtual machines or virtual machine scale sets can be placed automatically on the dedicated host group. Automatic placement means resources are allocated on dedicated hosts, that are chosen by Azure, under the dedicated host group. The value is defaulted to 'false' when not provided. <br><br>Minimum api-version: 2020-06-01. */\n supportAutomaticPlacement?: boolean;\n /** Enables or disables a capability on the dedicated host group.<br><br>Minimum api-version: 2022-03-01. */\n additionalCapabilities?: DedicatedHostGroupPropertiesAdditionalCapabilitiesOutput;\n}\n\nexport interface DedicatedHostGroupInstanceViewOutput {\n /** List of instance view of the dedicated hosts under the dedicated host group. */\n hosts?: Array<DedicatedHostInstanceViewWithNameOutput>;\n}\n\n/** The instance view of a dedicated host that includes the name of the dedicated host. It is used for the response to the instance view of a dedicated host group. */\nexport interface DedicatedHostInstanceViewWithNameOutput extends DedicatedHostInstanceViewOutput {\n /** The name of the dedicated host. */\n readonly name?: string;\n}\n\n/** The instance view of a dedicated host. */\nexport interface DedicatedHostInstanceViewOutput {\n /** Specifies the unique id of the dedicated physical machine on which the dedicated host resides. */\n readonly assetId?: string;\n /** Unutilized capacity of the dedicated host. */\n availableCapacity?: DedicatedHostAvailableCapacityOutput;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** Dedicated host unutilized capacity. */\nexport interface DedicatedHostAvailableCapacityOutput {\n /** The unutilized capacity of the dedicated host represented in terms of each VM size that is allowed to be deployed to the dedicated host. */\n allocatableVMs?: Array<DedicatedHostAllocatableVMOutput>;\n}\n\n/** Represents the dedicated host unutilized capacity in terms of a specific VM size. */\nexport interface DedicatedHostAllocatableVMOutput {\n /** VM size in terms of which the unutilized capacity is represented. */\n vmSize?: string;\n /** Maximum number of VMs of size vmSize that can fit in the dedicated host's remaining capacity. */\n count?: number;\n}\n\n/** Enables or disables a capability on the dedicated host group.<br><br>Minimum api-version: 2022-03-01. */\nexport interface DedicatedHostGroupPropertiesAdditionalCapabilitiesOutput {\n /** The flag that enables or disables a capability to have UltraSSD Enabled Virtual Machines on Dedicated Hosts of the Dedicated Host Group. For the Virtual Machines to be UltraSSD Enabled, UltraSSDEnabled flag for the resource needs to be set true as well. The value is defaulted to 'false' when not provided. Please refer to https://docs.microsoft.com/en-us/azure/virtual-machines/disks-enable-ultra-ssd for more details on Ultra SSD feature. <br><br>NOTE: The ultraSSDEnabled setting can only be enabled for Host Groups that are created as zonal. <br><br>Minimum api-version: 2022-03-01. */\n ultraSSDEnabled?: boolean;\n}\n\n/** The List Dedicated Host Group with resource group response. */\nexport interface DedicatedHostGroupListResultOutput {\n /** The list of dedicated host groups */\n value: Array<DedicatedHostGroupOutput>;\n /** The URI to fetch the next page of Dedicated Host Groups. Call ListNext() with this URI to fetch the next page of Dedicated Host Groups. */\n nextLink?: string;\n}\n\n/** Specifies information about the Dedicated host. */\nexport interface DedicatedHostOutput extends ResourceOutput {\n /** Properties of the dedicated host. */\n properties?: DedicatedHostPropertiesOutput;\n /** SKU of the dedicated host for Hardware Generation and VM family. Only name is required to be set. List Microsoft.Compute SKUs for a list of possible values. */\n sku: SkuOutput;\n}\n\n/** Properties of the dedicated host. */\nexport interface DedicatedHostPropertiesOutput {\n /** Fault domain of the dedicated host within a dedicated host group. */\n platformFaultDomain?: number;\n /** Specifies whether the dedicated host should be replaced automatically in case of a failure. The value is defaulted to 'true' when not provided. */\n autoReplaceOnFailure?: boolean;\n /** A unique id generated and assigned to the dedicated host by the platform. <br><br> Does not change throughout the lifetime of the host. */\n readonly hostId?: string;\n /** A list of references to all virtual machines in the Dedicated Host. */\n readonly virtualMachines?: Array<SubResourceReadOnlyOutput>;\n /** Specifies the software license type that will be applied to the VMs deployed on the dedicated host. <br><br> Possible values are: <br><br> **None** <br><br> **Windows_Server_Hybrid** <br><br> **Windows_Server_Perpetual** <br><br> Default: **None** */\n licenseType?: \"None\" | \"Windows_Server_Hybrid\" | \"Windows_Server_Perpetual\";\n /** The date when the host was first provisioned. */\n readonly provisioningTime?: string;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The dedicated host instance view. */\n readonly instanceView?: DedicatedHostInstanceViewOutput;\n /** Specifies the time at which the Dedicated Host resource was created.<br><br>Minimum api-version: 2021-11-01. */\n readonly timeCreated?: string;\n}\n\n/** The list dedicated host operation response. */\nexport interface DedicatedHostListResultOutput {\n /** The list of dedicated hosts */\n value: Array<DedicatedHostOutput>;\n /** The URI to fetch the next page of dedicated hosts. Call ListNext() with this URI to fetch the next page of dedicated hosts. */\n nextLink?: string;\n}\n\n/** The list SSH public keys operation response. */\nexport interface SshPublicKeysGroupListResultOutput {\n /** The list of SSH public keys */\n value: Array<SshPublicKeyResourceOutput>;\n /** The URI to fetch the next page of SSH public keys. Call ListNext() with this URI to fetch the next page of SSH public keys. */\n nextLink?: string;\n}\n\n/** Specifies information about the SSH public key. */\nexport interface SshPublicKeyResourceOutput extends ResourceOutput {\n /** Properties of the SSH public key. */\n properties?: SshPublicKeyResourcePropertiesOutput;\n}\n\n/** Properties of the SSH public key. */\nexport interface SshPublicKeyResourcePropertiesOutput {\n /** SSH public key used to authenticate to a virtual machine through ssh. If this property is not initially provided when the resource is created, the publicKey property will be populated when generateKeyPair is called. If the public key is provided upon resource creation, the provided public key needs to be at least 2048-bit and in ssh-rsa format. */\n publicKey?: string;\n}\n\n/** Response from generation of an SSH key pair. */\nexport interface SshPublicKeyGenerateKeyPairResultOutput {\n /** Private key portion of the key pair used to authenticate to a virtual machine through ssh. The private key is returned in RFC3447 format and should be treated as a secret. */\n privateKey: string;\n /** Public key portion of the key pair used to authenticate to a virtual machine through ssh. The public key is in ssh-rsa format. */\n publicKey: string;\n /** The ARM resource id in the form of /subscriptions/{SubscriptionId}/resourceGroups/{ResourceGroupName}/providers/Microsoft.Compute/sshPublicKeys/{SshPublicKeyName} */\n id: string;\n}\n\n/** The source user image virtual hard disk. The virtual hard disk will be copied before being attached to the virtual machine. If SourceImage is provided, the destination virtual hard drive must not exist. */\nexport interface ImageOutput extends ResourceOutput {\n /** Describes the properties of an Image. */\n properties?: ImagePropertiesOutput;\n /** The extended location of the Image. */\n extendedLocation?: ExtendedLocationOutput;\n}\n\n/** Describes the properties of an Image. */\nexport interface ImagePropertiesOutput {\n /** The source virtual machine from which Image is created. */\n sourceVirtualMachine?: SubResourceOutput;\n /** Specifies the storage settings for the virtual machine disks. */\n storageProfile?: ImageStorageProfileOutput;\n /** The provisioning state. */\n readonly provisioningState?: string;\n /** Specifies the HyperVGenerationType of the VirtualMachine created from the image. From API Version 2019-03-01 if the image source is a blob, then we need the user to specify the value, if the source is managed resource like disk or snapshot, we may require the user to specify the property if we cannot deduce it from the source managed resource. */\n hyperVGeneration?: \"V1\" | \"V2\";\n}\n\n/** Describes a storage profile. */\nexport interface ImageStorageProfileOutput {\n /** Specifies information about the operating system disk used by the virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n osDisk?: ImageOSDiskOutput;\n /** Specifies the parameters that are used to add a data disk to a virtual machine. <br><br> For more information about disks, see [About disks and VHDs for Azure virtual machines](https://docs.microsoft.com/azure/virtual-machines/managed-disks-overview). */\n dataDisks?: Array<ImageDataDiskOutput>;\n /** Specifies whether an image is zone resilient or not. Default is false. Zone resilient images can be created only in regions that provide Zone Redundant Storage (ZRS). */\n zoneResilient?: boolean;\n}\n\n/** Describes an Operating System disk. */\nexport interface ImageOSDiskOutput extends ImageDiskOutput {\n /** This property allows you to specify the type of the OS that is included in the disk if creating a VM from a custom image. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType: \"Windows\" | \"Linux\";\n /** The OS State. For managed images, use Generalized. */\n osState: \"Generalized\" | \"Specialized\";\n}\n\n/** Describes a image disk. */\nexport interface ImageDiskOutput {\n /** The snapshot. */\n snapshot?: SubResourceOutput;\n /** The managedDisk. */\n managedDisk?: SubResourceOutput;\n /** The Virtual Hard Disk. */\n blobUri?: string;\n /** Specifies the caching requirements. <br><br> Possible values are: <br><br> **None** <br><br> **ReadOnly** <br><br> **ReadWrite** <br><br> Default: **None for Standard storage. ReadOnly for Premium storage** */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Specifies the size of empty data disks in gigabytes. This element can be used to overwrite the name of the disk in a virtual machine image. <br><br> This value cannot be larger than 1023 GB */\n diskSizeGB?: number;\n /** Specifies the storage account type for the managed disk. NOTE: UltraSSD_LRS can only be used with data disks, it cannot be used with OS Disk. */\n storageAccountType?:\n | \"Standard_LRS\"\n | \"Premium_LRS\"\n | \"StandardSSD_LRS\"\n | \"UltraSSD_LRS\"\n | \"Premium_ZRS\"\n | \"StandardSSD_ZRS\"\n | \"PremiumV2_LRS\";\n /** Specifies the customer managed disk encryption set resource id for the managed image disk. */\n diskEncryptionSet?: DiskEncryptionSetParametersOutput;\n}\n\n/** Describes a data disk. */\nexport interface ImageDataDiskOutput extends ImageDiskOutput {\n /** Specifies the logical unit number of the data disk. This value is used to identify data disks within the VM and therefore must be unique for each data disk attached to a VM. */\n lun: number;\n}\n\n/** The List Image operation response. */\nexport interface ImageListResultOutput {\n /** The list of Images. */\n value: Array<ImageOutput>;\n /** The uri to fetch the next page of Images. Call ListNext() with this to fetch the next page of Images. */\n nextLink?: string;\n}\n\n/** Create or update Restore Point collection parameters. */\nexport interface RestorePointCollectionOutput extends ResourceOutput {\n /** The restore point collection properties. */\n properties?: RestorePointCollectionPropertiesOutput;\n}\n\n/** The restore point collection properties. */\nexport interface RestorePointCollectionPropertiesOutput {\n /** The properties of the source resource that this restore point collection is created from. */\n source?: RestorePointCollectionSourcePropertiesOutput;\n /** The provisioning state of the restore point collection. */\n readonly provisioningState?: string;\n /** The unique id of the restore point collection. */\n readonly restorePointCollectionId?: string;\n /** A list containing all restore points created under this restore point collection. */\n readonly restorePoints?: Array<RestorePointOutput>;\n}\n\n/** The properties of the source resource that this restore point collection is created from. */\nexport interface RestorePointCollectionSourcePropertiesOutput {\n /** Location of the source resource used to create this restore point collection. */\n readonly location?: string;\n /** Resource Id of the source resource used to create this restore point collection */\n id?: string;\n}\n\n/** Restore Point details. */\nexport interface RestorePointOutput extends ProxyResourceOutput {\n /** The restore point properties. */\n properties?: RestorePointPropertiesOutput;\n}\n\n/** The restore point properties. */\nexport interface RestorePointPropertiesOutput {\n /** List of disk resource ids that the customer wishes to exclude from the restore point. If no disks are specified, all disks will be included. */\n excludeDisks?: Array<ApiEntityReferenceOutput>;\n /** Gets the details of the VM captured at the time of the restore point creation. */\n readonly sourceMetadata?: RestorePointSourceMetadataOutput;\n /** Gets the provisioning state of the restore point. */\n readonly provisioningState?: string;\n /** ConsistencyMode of the RestorePoint. Can be specified in the input while creating a restore point. For now, only CrashConsistent is accepted as a valid input. Please refer to https://aka.ms/RestorePoints for more details. */\n consistencyMode?: \"CrashConsistent\" | \"FileSystemConsistent\" | \"ApplicationConsistent\";\n /** Gets the creation time of the restore point. */\n timeCreated?: string;\n /** Resource Id of the source restore point from which a copy needs to be created. */\n sourceRestorePoint?: ApiEntityReferenceOutput;\n /** The restore point instance view. */\n readonly instanceView?: RestorePointInstanceViewOutput;\n}\n\n/** Describes the properties of the Virtual Machine for which the restore point was created. The properties provided are a subset and the snapshot of the overall Virtual Machine properties captured at the time of the restore point creation. */\nexport interface RestorePointSourceMetadataOutput {\n /** Gets the hardware profile. */\n hardwareProfile?: HardwareProfileOutput;\n /** Gets the storage profile. */\n storageProfile?: RestorePointSourceVMStorageProfileOutput;\n /** Gets the OS profile. */\n osProfile?: OSProfileOutput;\n /** Gets the diagnostics profile. */\n diagnosticsProfile?: DiagnosticsProfileOutput;\n /** Gets the license type, which is for bring your own license scenario. */\n licenseType?: string;\n /** Gets the virtual machine unique id. */\n vmId?: string;\n /** Gets the security profile. */\n securityProfile?: SecurityProfileOutput;\n /** Location of the VM from which the restore point was created. */\n location?: string;\n}\n\n/** Describes the storage profile. */\nexport interface RestorePointSourceVMStorageProfileOutput {\n /** Gets the OS disk of the VM captured at the time of the restore point creation. */\n osDisk?: RestorePointSourceVmosDiskOutput;\n /** Gets the data disks of the VM captured at the time of the restore point creation. */\n dataDisks?: Array<RestorePointSourceVMDataDiskOutput>;\n}\n\n/** Describes an Operating System disk. */\nexport interface RestorePointSourceVmosDiskOutput {\n /** Gets the Operating System type. */\n osType?: \"Windows\" | \"Linux\";\n /** Gets the disk encryption settings. */\n encryptionSettings?: DiskEncryptionSettingsOutput;\n /** Gets the disk name. */\n name?: string;\n /** Gets the caching type. */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Gets the disk size in GB. */\n diskSizeGB?: number;\n /** Gets the managed disk details */\n managedDisk?: ManagedDiskParametersOutput;\n /** Gets the disk restore point Id. */\n diskRestorePoint?: ApiEntityReferenceOutput;\n}\n\n/** Describes a data disk. */\nexport interface RestorePointSourceVMDataDiskOutput {\n /** Gets the logical unit number. */\n lun?: number;\n /** Gets the disk name. */\n name?: string;\n /** Gets the caching type. */\n caching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** Gets the initial disk size in GB for blank data disks, and the new desired size for existing OS and Data disks. */\n diskSizeGB?: number;\n /** Gets the managed disk details */\n managedDisk?: ManagedDiskParametersOutput;\n /** Gets the disk restore point Id. */\n diskRestorePoint?: ApiEntityReferenceOutput;\n}\n\n/** The instance view of a restore point. */\nexport interface RestorePointInstanceViewOutput {\n /** The disk restore points information. */\n diskRestorePoints?: Array<DiskRestorePointInstanceViewOutput>;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** The instance view of a disk restore point. */\nexport interface DiskRestorePointInstanceViewOutput {\n /** Disk restore point Id. */\n id?: string;\n /** The disk restore point replication status information. */\n replicationStatus?: DiskRestorePointReplicationStatusOutput;\n}\n\n/** The instance view of a disk restore point. */\nexport interface DiskRestorePointReplicationStatusOutput {\n /** The resource status information. */\n status?: InstanceViewStatusOutput;\n /** Replication completion percentage. */\n completionPercent?: number;\n}\n\n/** The resource model definition for an Azure Resource Manager proxy resource. It will not have tags and a location */\nexport interface ProxyResourceOutput {\n /** Resource Id */\n readonly id?: string;\n /** Resource name */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n}\n\n/** The List restore point collection operation response. */\nexport interface RestorePointCollectionListResultOutput {\n /** Gets the list of restore point collections. */\n value?: Array<RestorePointCollectionOutput>;\n /** The uri to fetch the next page of RestorePointCollections. Call ListNext() with this to fetch the next page of RestorePointCollections */\n nextLink?: string;\n}\n\n/** Specifies information about the capacity reservation group that the capacity reservations should be assigned to. <br><br> Currently, a capacity reservation can only be added to a capacity reservation group at creation time. An existing capacity reservation cannot be added or moved to another capacity reservation group. */\nexport interface CapacityReservationGroupOutput extends ResourceOutput {\n /** capacity reservation group Properties. */\n properties?: CapacityReservationGroupPropertiesOutput;\n /** Availability Zones to use for this capacity reservation group. The zones can be assigned only during creation. If not provided, the group supports only regional resources in the region. If provided, enforces each capacity reservation in the group to be in one of the zones. */\n zones?: Array<string>;\n}\n\n/** capacity reservation group Properties. */\nexport interface CapacityReservationGroupPropertiesOutput {\n /** A list of all capacity reservation resource ids that belong to capacity reservation group. */\n readonly capacityReservations?: Array<SubResourceReadOnlyOutput>;\n /** A list of references to all virtual machines associated to the capacity reservation group. */\n readonly virtualMachinesAssociated?: Array<SubResourceReadOnlyOutput>;\n /** The capacity reservation group instance view which has the list of instance views for all the capacity reservations that belong to the capacity reservation group. */\n readonly instanceView?: CapacityReservationGroupInstanceViewOutput;\n}\n\nexport interface CapacityReservationGroupInstanceViewOutput {\n /** List of instance view of the capacity reservations under the capacity reservation group. */\n readonly capacityReservations?: Array<CapacityReservationInstanceViewWithNameOutput>;\n}\n\n/** The instance view of a capacity reservation that includes the name of the capacity reservation. It is used for the response to the instance view of a capacity reservation group. */\nexport interface CapacityReservationInstanceViewWithNameOutput extends CapacityReservationInstanceViewOutput {\n /** The name of the capacity reservation. */\n readonly name?: string;\n}\n\n/** The instance view of a capacity reservation that provides as snapshot of the runtime properties of the capacity reservation that is managed by the platform and can change outside of control plane operations. */\nexport interface CapacityReservationInstanceViewOutput {\n /** Unutilized capacity of the capacity reservation. */\n utilizationInfo?: CapacityReservationUtilizationOutput;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** Represents the capacity reservation utilization in terms of resources allocated. */\nexport interface CapacityReservationUtilizationOutput {\n /** The value provides the current capacity of the VM size which was reserved successfully and for which the customer is getting billed.<br><br>Minimum api-version: 2022-08-01. */\n readonly currentCapacity?: number;\n /** A list of all virtual machines resource ids allocated against the capacity reservation. */\n readonly virtualMachinesAllocated?: Array<SubResourceReadOnlyOutput>;\n}\n\n/** The List capacity reservation group with resource group response. */\nexport interface CapacityReservationGroupListResultOutput {\n /** The list of capacity reservation groups */\n value: Array<CapacityReservationGroupOutput>;\n /** The URI to fetch the next page of capacity reservation groups. Call ListNext() with this URI to fetch the next page of capacity reservation groups. */\n nextLink?: string;\n}\n\n/** Specifies information about the capacity reservation. */\nexport interface CapacityReservationOutput extends ResourceOutput {\n /** Properties of the Capacity reservation. */\n properties?: CapacityReservationPropertiesOutput;\n /** SKU of the resource for which capacity needs be reserved. The SKU name and capacity is required to be set. Currently VM Skus with the capability called 'CapacityReservationSupported' set to true are supported. Refer to List Microsoft.Compute SKUs in a region (https://docs.microsoft.com/rest/api/compute/resourceskus/list) for supported values. */\n sku: SkuOutput;\n /** Availability Zone to use for this capacity reservation. The zone has to be single value and also should be part for the list of zones specified during the capacity reservation group creation. The zone can be assigned only during creation. If not provided, the reservation supports only non-zonal deployments. If provided, enforces VM/VMSS using this capacity reservation to be in same zone. */\n zones?: Array<string>;\n}\n\n/** Properties of the Capacity reservation. */\nexport interface CapacityReservationPropertiesOutput {\n /** A unique id generated and assigned to the capacity reservation by the platform which does not change throughout the lifetime of the resource. */\n readonly reservationId?: string;\n /** Specifies the value of fault domain count that Capacity Reservation supports for requested VM size.<br>NOTE: The fault domain count specified for a resource (like virtual machines scale set) must be less than or equal to this value if it deploys using capacity reservation.<br><br>Minimum api-version: 2022-08-01. */\n readonly platformFaultDomainCount?: number;\n /** A list of all virtual machine resource ids that are associated with the capacity reservation. */\n readonly virtualMachinesAssociated?: Array<SubResourceReadOnlyOutput>;\n /** The date time when the capacity reservation was last updated. */\n readonly provisioningTime?: string;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The Capacity reservation instance view. */\n readonly instanceView?: CapacityReservationInstanceViewOutput;\n /** Specifies the time at which the Capacity Reservation resource was created.<br><br>Minimum api-version: 2021-11-01. */\n readonly timeCreated?: string;\n}\n\n/** The list capacity reservation operation response. */\nexport interface CapacityReservationListResultOutput {\n /** The list of capacity reservations */\n value: Array<CapacityReservationOutput>;\n /** The URI to fetch the next page of capacity reservations. Call ListNext() with this URI to fetch the next page of capacity reservations. */\n nextLink?: string;\n}\n\n/** LogAnalytics operation status response */\nexport interface LogAnalyticsOperationResultOutput {\n /** LogAnalyticsOutput */\n readonly properties?: LogAnalyticsOutputOutput;\n}\n\n/** LogAnalytics output properties */\nexport interface LogAnalyticsOutputOutput {\n /** Output file Uri path to blob container. */\n readonly output?: string;\n}\n\n/** The List Virtual Machine operation response. */\nexport interface RunCommandListResultOutput {\n /** The list of virtual machine run commands. */\n value: Array<RunCommandDocumentBaseOutput>;\n /** The uri to fetch the next page of run commands. Call ListNext() with this to fetch the next page of run commands. */\n nextLink?: string;\n}\n\n/** Describes the properties of a Run Command metadata. */\nexport interface RunCommandDocumentBaseOutput {\n /** The VM run command schema. */\n $schema: string;\n /** The VM run command id. */\n id: string;\n /** The Operating System type. */\n osType: \"Windows\" | \"Linux\";\n /** The VM run command label. */\n label: string;\n /** The VM run command description. */\n description: string;\n}\n\n/** Describes the properties of a Run Command. */\nexport interface RunCommandDocumentOutput extends RunCommandDocumentBaseOutput {\n /** The script to be executed. */\n script: Array<string>;\n /** The parameters used by the script. */\n parameters?: Array<RunCommandParameterDefinitionOutput>;\n}\n\n/** Describes the properties of a run command parameter. */\nexport interface RunCommandParameterDefinitionOutput {\n /** The run command parameter name. */\n name: string;\n /** The run command parameter type. */\n type: string;\n /** The run command parameter default value. */\n defaultValue?: string;\n /** The run command parameter required. */\n required?: boolean;\n}\n\n/** Describes the properties of a run command parameter. */\nexport interface RunCommandInputParameterOutput {\n /** The run command parameter name. */\n name: string;\n /** The run command parameter value. */\n value: string;\n}\n\nexport interface RunCommandResultOutput {\n /** Run command operation response. */\n value?: Array<InstanceViewStatusOutput>;\n}\n\n/** Describes a Virtual Machine run command. */\nexport interface VirtualMachineRunCommandOutput extends ResourceOutput {\n /** Describes the properties of a Virtual Machine run command. */\n properties?: VirtualMachineRunCommandPropertiesOutput;\n}\n\n/** Describes the properties of a Virtual Machine run command. */\nexport interface VirtualMachineRunCommandPropertiesOutput {\n /** The source of the run command script. */\n source?: VirtualMachineRunCommandScriptSourceOutput;\n /** The parameters used by the script. */\n parameters?: Array<RunCommandInputParameterOutput>;\n /** The parameters used by the script. */\n protectedParameters?: Array<RunCommandInputParameterOutput>;\n /** Optional. If set to true, provisioning will complete as soon as the script starts and will not wait for script to complete. */\n asyncExecution?: boolean;\n /** Specifies the user account on the VM when executing the run command. */\n runAsUser?: string;\n /** Specifies the user account password on the VM when executing the run command. */\n runAsPassword?: string;\n /** The timeout in seconds to execute the run command. */\n timeoutInSeconds?: number;\n /** Specifies the Azure storage blob where script output stream will be uploaded. */\n outputBlobUri?: string;\n /** Specifies the Azure storage blob where script error stream will be uploaded. */\n errorBlobUri?: string;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The virtual machine run command instance view. */\n readonly instanceView?: VirtualMachineRunCommandInstanceViewOutput;\n}\n\n/** Describes the script sources for run command. */\nexport interface VirtualMachineRunCommandScriptSourceOutput {\n /** Specifies the script content to be executed on the VM. */\n script?: string;\n /** Specifies the script download location. */\n scriptUri?: string;\n /** Specifies a commandId of predefined built-in script. */\n commandId?: string;\n}\n\n/** The instance view of a virtual machine run command. */\nexport interface VirtualMachineRunCommandInstanceViewOutput {\n /** Script execution status. */\n executionState?:\n | \"Unknown\"\n | \"Pending\"\n | \"Running\"\n | \"Failed\"\n | \"Succeeded\"\n | \"TimedOut\"\n | \"Canceled\";\n /** Communicate script configuration errors or execution messages. */\n executionMessage?: string;\n /** Exit code returned from script execution. */\n exitCode?: number;\n /** Script output stream. */\n output?: string;\n /** Script error stream. */\n error?: string;\n /** Script start time. */\n startTime?: string;\n /** Script end time. */\n endTime?: string;\n /** The resource status information. */\n statuses?: Array<InstanceViewStatusOutput>;\n}\n\n/** The List run command operation response */\nexport interface VirtualMachineRunCommandsListResultOutput {\n /** The list of run commands */\n value: Array<VirtualMachineRunCommandOutput>;\n /** The uri to fetch the next page of run commands. */\n nextLink?: string;\n}\n\n/** Disk resource. */\nexport interface DiskOutput extends ResourceOutput {\n /** A relative URI containing the ID of the VM that has the disk attached. */\n readonly managedBy?: string;\n /** List of relative URIs containing the IDs of the VMs that have the disk attached. maxShares should be set to a value greater than one for disks to allow attaching them to multiple VMs. */\n readonly managedByExtended?: Array<string>;\n /** The disks sku name. Can be Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, or PremiumV2_LRS. */\n sku?: DiskSkuOutput;\n /** The Logical zone list for Disk. */\n zones?: Array<string>;\n /** The extended location where the disk will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocationOutput;\n /** Disk resource properties. */\n properties?: DiskPropertiesOutput;\n}\n\n/** The disks sku name. Can be Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, or PremiumV2_LRS. */\nexport interface DiskSkuOutput {\n /** The sku name. */\n name?:\n | \"Standard_LRS\"\n | \"Premium_LRS\"\n | \"StandardSSD_LRS\"\n | \"UltraSSD_LRS\"\n | \"Premium_ZRS\"\n | \"StandardSSD_ZRS\"\n | \"PremiumV2_LRS\";\n /** The sku tier. */\n readonly tier?: string;\n}\n\n/** Disk resource properties. */\nexport interface DiskPropertiesOutput {\n /** The time when the disk was created. */\n readonly timeCreated?: string;\n /** The Operating System type. */\n osType?: \"Windows\" | \"Linux\";\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** Purchase plan information for the the image from which the OS disk was created. E.g. - {name: 2019-Datacenter, publisher: MicrosoftWindowsServer, product: WindowsServer} */\n purchasePlan?: PurchasePlanAutoGeneratedOutput;\n /** List of supported capabilities for the image from which the OS disk was created. */\n supportedCapabilities?: SupportedCapabilitiesOutput;\n /** Disk source information. CreationData information cannot be changed after the disk has been created. */\n creationData: CreationDataOutput;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /** The size of the disk in bytes. This field is read only. */\n readonly diskSizeBytes?: number;\n /** Unique Guid identifying the resource. */\n readonly uniqueId?: string;\n /** Encryption settings collection used for Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollectionOutput;\n /** The disk provisioning state. */\n readonly provisioningState?: string;\n /** The number of IOPS allowed for this disk; only settable for UltraSSD disks. One operation can transfer between 4k and 256k bytes. */\n diskIOPSReadWrite?: number;\n /** The bandwidth allowed for this disk; only settable for UltraSSD disks. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadWrite?: number;\n /** The total number of IOPS that will be allowed across all VMs mounting the shared disk as ReadOnly. One operation can transfer between 4k and 256k bytes. */\n diskIOPSReadOnly?: number;\n /** The total throughput (MBps) that will be allowed across all VMs mounting the shared disk as ReadOnly. MBps means millions of bytes per second - MB here uses the ISO notation, of powers of 10. */\n diskMBpsReadOnly?: number;\n /** The state of the disk. */\n readonly diskState?:\n | \"Unattached\"\n | \"Attached\"\n | \"Reserved\"\n | \"Frozen\"\n | \"ActiveSAS\"\n | \"ActiveSASFrozen\"\n | \"ReadyToUpload\"\n | \"ActiveUpload\";\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: EncryptionOutput;\n /** The maximum number of VMs that can attach to the disk at the same time. Value greater than one indicates a disk that can be mounted on multiple VMs at the same time. */\n maxShares?: number;\n /** Details of the list of all VMs that have the disk attached. maxShares should be set to a value greater than one for disks to allow attaching them to multiple VMs. */\n readonly shareInfo?: Array<ShareInfoElementOutput>;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: \"AllowAll\" | \"AllowPrivate\" | \"DenyAll\";\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Latest time when bursting was last enabled on a disk. */\n readonly burstingEnabledTime?: string;\n /** Performance tier of the disk (e.g, P4, S10) as described here: https://azure.microsoft.com/en-us/pricing/details/managed-disks/. Does not apply to Ultra disks. */\n tier?: string;\n /** Set to true to enable bursting beyond the provisioned performance target of the disk. Bursting is disabled by default. Does not apply to Ultra disks. */\n burstingEnabled?: boolean;\n /** Properties of the disk for which update is pending. */\n readonly propertyUpdatesInProgress?: PropertyUpdatesInProgressOutput;\n /** Indicates the OS on a disk supports hibernation. */\n supportsHibernation?: boolean;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfileOutput;\n /** Percentage complete for the background copy when a resource is created via the CopyStart operation. */\n completionPercent?: number;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: \"Enabled\" | \"Disabled\";\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: \"AzureActiveDirectory\" | \"None\";\n /** Setting this property to true improves reliability and performance of data disks that are frequently (more than 5 times a day) by detached from one virtual machine and attached to another. This property should not be set for disks that are not detached and attached frequently as it causes the disks to not align with the fault domain of the virtual machine. */\n optimizedForFrequentAttach?: boolean;\n}\n\n/** Used for establishing the purchase context of any 3rd Party artifact through MarketPlace. */\nexport interface PurchasePlanAutoGeneratedOutput {\n /** The plan ID. */\n name: string;\n /** The publisher ID. */\n publisher: string;\n /** Specifies the product of the image from the marketplace. This is the same value as Offer under the imageReference element. */\n product: string;\n /** The Offer Promotion Code. */\n promotionCode?: string;\n}\n\n/** List of supported capabilities persisted on the disk resource for VM use. */\nexport interface SupportedCapabilitiesOutput {\n /** The disk controllers that an OS disk supports. If set it can be SCSI or SCSI, NVME or NVME, SCSI. */\n diskControllerTypes?: string;\n /** True if the image from which the OS disk is created supports accelerated networking. */\n acceleratedNetwork?: boolean;\n /** CPU architecture supported by an OS disk. */\n architecture?: \"x64\" | \"Arm64\";\n}\n\n/** Data used when creating a disk. */\nexport interface CreationDataOutput {\n /** This enumerates the possible sources of a disk's creation. */\n createOption:\n | \"Empty\"\n | \"Attach\"\n | \"FromImage\"\n | \"Import\"\n | \"Copy\"\n | \"Restore\"\n | \"Upload\"\n | \"CopyStart\"\n | \"ImportSecure\"\n | \"UploadPreparedSecure\";\n /** Required if createOption is Import. The Azure Resource Manager identifier of the storage account containing the blob to import as a disk. */\n storageAccountId?: string;\n /** Disk source information for PIR or user images. */\n imageReference?: ImageDiskReferenceOutput;\n /** Required if creating from a Gallery Image. The id/sharedGalleryImageId/communityGalleryImageId of the ImageDiskReference will be the ARM id of the shared galley image version from which to create a disk. */\n galleryImageReference?: ImageDiskReferenceOutput;\n /** If createOption is Import, this is the URI of a blob to be imported into a managed disk. */\n sourceUri?: string;\n /** If createOption is Copy, this is the ARM id of the source snapshot or disk. */\n sourceResourceId?: string;\n /** If this field is set, this is the unique id identifying the source of this resource. */\n readonly sourceUniqueId?: string;\n /** If createOption is Upload, this is the size of the contents of the upload including the VHD footer. This value should be between 20972032 (20 MiB + 512 bytes for the VHD footer) and 35183298347520 bytes (32 TiB + 512 bytes for the VHD footer). */\n uploadSizeBytes?: number;\n /** Logical sector size in bytes for Ultra disks. Supported values are 512 ad 4096. 4096 is the default. */\n logicalSectorSize?: number;\n /** If createOption is ImportSecure, this is the URI of a blob to be imported into VM guest state. */\n securityDataUri?: string;\n /** Set this flag to true to get a boost on the performance target of the disk deployed, see here on the respective performance target. This flag can only be set on disk creation time and cannot be disabled after enabled. */\n performancePlus?: boolean;\n}\n\n/** The source image used for creating the disk. */\nexport interface ImageDiskReferenceOutput {\n /** A relative uri containing either a Platform Image Repository, user image, or Azure Compute Gallery image reference. */\n id?: string;\n /** A relative uri containing a direct shared Azure Compute Gallery image reference. */\n sharedGalleryImageId?: string;\n /** A relative uri containing a community Azure Compute Gallery image reference. */\n communityGalleryImageId?: string;\n /** If the disk is created from an image's data disk, this is an index that indicates which of the data disks in the image to use. For OS disks, this field is null. */\n lun?: number;\n}\n\n/** Encryption settings for disk or snapshot */\nexport interface EncryptionSettingsCollectionOutput {\n /** Set this flag to true and provide DiskEncryptionKey and optional KeyEncryptionKey to enable encryption. Set this flag to false and remove DiskEncryptionKey and KeyEncryptionKey to disable encryption. If EncryptionSettings is null in the request object, the existing settings remain unchanged. */\n enabled: boolean;\n /** A collection of encryption settings, one for each disk volume. */\n encryptionSettings?: Array<EncryptionSettingsElementOutput>;\n /** Describes what type of encryption is used for the disks. Once this field is set, it cannot be overwritten. '1.0' corresponds to Azure Disk Encryption with AAD app.'1.1' corresponds to Azure Disk Encryption. */\n encryptionSettingsVersion?: string;\n}\n\n/** Encryption settings for one disk volume. */\nexport interface EncryptionSettingsElementOutput {\n /** Key Vault Secret Url and vault id of the disk encryption key */\n diskEncryptionKey?: KeyVaultAndSecretReferenceOutput;\n /** Key Vault Key Url and vault id of the key encryption key. KeyEncryptionKey is optional and when provided is used to unwrap the disk encryption key. */\n keyEncryptionKey?: KeyVaultAndKeyReferenceOutput;\n}\n\n/** Key Vault Secret Url and vault id of the encryption key */\nexport interface KeyVaultAndSecretReferenceOutput {\n /** Resource id of the KeyVault containing the key or secret */\n sourceVault: SourceVaultOutput;\n /** Url pointing to a key or secret in KeyVault */\n secretUrl: string;\n}\n\n/** The vault id is an Azure Resource Manager Resource id in the form /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.KeyVault/vaults/{vaultName} */\nexport interface SourceVaultOutput {\n /** Resource Id */\n id?: string;\n}\n\n/** Key Vault Key Url and vault id of KeK, KeK is optional and when provided is used to unwrap the encryptionKey */\nexport interface KeyVaultAndKeyReferenceOutput {\n /** Resource id of the KeyVault containing the key or secret */\n sourceVault: SourceVaultOutput;\n /** Url pointing to a key or secret in KeyVault */\n keyUrl: string;\n}\n\n/** Encryption at rest settings for disk or snapshot */\nexport interface EncryptionOutput {\n /** ResourceId of the disk encryption set to use for enabling encryption at rest. */\n diskEncryptionSetId?: string;\n /** The type of key used to encrypt the data of the disk. */\n type?:\n | \"EncryptionAtRestWithPlatformKey\"\n | \"EncryptionAtRestWithCustomerKey\"\n | \"EncryptionAtRestWithPlatformAndCustomerKeys\";\n}\n\nexport interface ShareInfoElementOutput {\n /** A relative URI containing the ID of the VM that has the disk attached. */\n readonly vmUri?: string;\n}\n\n/** Properties of the disk for which update is pending. */\nexport interface PropertyUpdatesInProgressOutput {\n /** The target performance tier of the disk if a tier change operation is in progress. */\n targetTier?: string;\n}\n\n/** Contains the security related information for the resource. */\nexport interface DiskSecurityProfileOutput {\n /** Specifies the SecurityType of the VM. Applicable for OS disks only. */\n securityType?:\n | \"TrustedLaunch\"\n | \"ConfidentialVM_VMGuestStateOnlyEncryptedWithPlatformKey\"\n | \"ConfidentialVM_DiskEncryptedWithPlatformKey\"\n | \"ConfidentialVM_DiskEncryptedWithCustomerKey\";\n /** ResourceId of the disk encryption set associated to Confidential VM supported disk encrypted with customer managed key */\n secureVMDiskEncryptionSetId?: string;\n}\n\n/** The List Disks operation response. */\nexport interface DiskListOutput {\n /** A list of disks. */\n value: Array<DiskOutput>;\n /** The uri to fetch the next page of disks. Call ListNext() with this to fetch the next page of disks. */\n nextLink?: string;\n}\n\n/** A disk access SAS uri. */\nexport interface AccessUriOutput {\n /** A SAS uri for accessing a disk. */\n readonly accessSAS?: string;\n /** A SAS uri for accessing a VM guest state. */\n readonly securityDataAccessSAS?: string;\n}\n\n/** disk access resource. */\nexport interface DiskAccessOutput extends ResourceOutput {\n properties?: DiskAccessPropertiesOutput;\n /** The extended location where the disk access will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocationOutput;\n}\n\nexport interface DiskAccessPropertiesOutput {\n /** A readonly collection of private endpoint connections created on the disk. Currently only one endpoint connection is supported. */\n readonly privateEndpointConnections?: Array<PrivateEndpointConnectionOutput>;\n /** The disk access resource provisioning state. */\n readonly provisioningState?: string;\n /** The time when the disk access was created. */\n readonly timeCreated?: string;\n}\n\n/** The Private Endpoint Connection resource. */\nexport interface PrivateEndpointConnectionOutput {\n /** Resource properties. */\n properties?: PrivateEndpointConnectionPropertiesOutput;\n /** private endpoint connection Id */\n readonly id?: string;\n /** private endpoint connection name */\n readonly name?: string;\n /** private endpoint connection type */\n readonly type?: string;\n}\n\n/** Properties of the PrivateEndpointConnectProperties. */\nexport interface PrivateEndpointConnectionPropertiesOutput {\n /** The resource of private end point. */\n readonly privateEndpoint?: PrivateEndpointOutput;\n /** A collection of information about the state of the connection between DiskAccess and Virtual Network. */\n privateLinkServiceConnectionState: PrivateLinkServiceConnectionStateOutput;\n /** The provisioning state of the private endpoint connection resource. */\n readonly provisioningState?: \"Succeeded\" | \"Creating\" | \"Deleting\" | \"Failed\";\n}\n\n/** The Private Endpoint resource. */\nexport interface PrivateEndpointOutput {\n /** The ARM identifier for Private Endpoint */\n readonly id?: string;\n}\n\n/** A collection of information about the state of the connection between service consumer and provider. */\nexport interface PrivateLinkServiceConnectionStateOutput {\n /** Indicates whether the connection has been Approved/Rejected/Removed by the owner of the service. */\n status?: \"Pending\" | \"Approved\" | \"Rejected\";\n /** The reason for approval/rejection of the connection. */\n description?: string;\n /** A message indicating if changes on the service provider require any updates on the consumer. */\n actionsRequired?: string;\n}\n\n/** The List disk access operation response. */\nexport interface DiskAccessListOutput {\n /** A list of disk access resources. */\n value: Array<DiskAccessOutput>;\n /** The uri to fetch the next page of disk access resources. Call ListNext() with this to fetch the next page of disk access resources. */\n nextLink?: string;\n}\n\n/** A list of private link resources */\nexport interface PrivateLinkResourceListResultOutput {\n /** Array of private link resources */\n value?: Array<PrivateLinkResourceOutput>;\n}\n\n/** A private link resource */\nexport interface PrivateLinkResourceOutput {\n /** Resource properties. */\n properties?: PrivateLinkResourcePropertiesOutput;\n /** private link resource Id */\n readonly id?: string;\n /** private link resource name */\n readonly name?: string;\n /** private link resource type */\n readonly type?: string;\n}\n\n/** Properties of a private link resource. */\nexport interface PrivateLinkResourcePropertiesOutput {\n /** The private link resource group id. */\n readonly groupId?: string;\n /** The private link resource required member names. */\n readonly requiredMembers?: Array<string>;\n /** The private link resource DNS zone name. */\n requiredZoneNames?: Array<string>;\n}\n\n/** A list of private link resources */\nexport interface PrivateEndpointConnectionListResultOutput {\n /** Array of private endpoint connections */\n value?: Array<PrivateEndpointConnectionOutput>;\n /** The uri to fetch the next page of snapshots. Call ListNext() with this to fetch the next page of snapshots. */\n nextLink?: string;\n}\n\n/** disk encryption set resource. */\nexport interface DiskEncryptionSetOutput extends ResourceOutput {\n /** The managed identity for the disk encryption set. It should be given permission on the key vault before it can be used to encrypt disks. */\n identity?: EncryptionSetIdentityOutput;\n properties?: EncryptionSetPropertiesOutput;\n}\n\n/** The managed identity for the disk encryption set. It should be given permission on the key vault before it can be used to encrypt disks. */\nexport interface EncryptionSetIdentityOutput {\n /** The type of Managed Identity used by the DiskEncryptionSet. Only SystemAssigned is supported for new creations. Disk Encryption Sets can be updated with Identity type None during migration of subscription to a new Azure Active Directory tenant; it will cause the encrypted resources to lose access to the keys. */\n type?: \"SystemAssigned\" | \"UserAssigned\" | \"SystemAssigned, UserAssigned\" | \"None\";\n /** The object id of the Managed Identity Resource. This will be sent to the RP from ARM via the x-ms-identity-principal-id header in the PUT request if the resource has a systemAssigned(implicit) identity */\n readonly principalId?: string;\n /** The tenant id of the Managed Identity Resource. This will be sent to the RP from ARM via the x-ms-client-tenant-id header in the PUT request if the resource has a systemAssigned(implicit) identity */\n readonly tenantId?: string;\n /** The list of user identities associated with the disk encryption set. The user identity dictionary key references will be ARM resource ids in the form: '/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'. */\n userAssignedIdentities?: Record<string, UserAssignedIdentitiesValueOutput>;\n}\n\nexport interface EncryptionSetPropertiesOutput {\n /** The type of key used to encrypt the data of the disk. */\n encryptionType?:\n | \"EncryptionAtRestWithCustomerKey\"\n | \"EncryptionAtRestWithPlatformAndCustomerKeys\"\n | \"ConfidentialVmEncryptedWithCustomerKey\";\n /** The key vault key which is currently used by this disk encryption set. */\n activeKey?: KeyForDiskEncryptionSetOutput;\n /** A readonly collection of key vault keys previously used by this disk encryption set while a key rotation is in progress. It will be empty if there is no ongoing key rotation. */\n readonly previousKeys?: Array<KeyForDiskEncryptionSetOutput>;\n /** The disk encryption set provisioning state. */\n readonly provisioningState?: string;\n /** Set this flag to true to enable auto-updating of this disk encryption set to the latest key version. */\n rotationToLatestKeyVersionEnabled?: boolean;\n /** The time when the active key of this disk encryption set was updated. */\n readonly lastKeyRotationTimestamp?: string;\n /** The error that was encountered during auto-key rotation. If an error is present, then auto-key rotation will not be attempted until the error on this disk encryption set is fixed. */\n readonly autoKeyRotationError?: ApiErrorOutput;\n /** Multi-tenant application client id to access key vault in a different tenant. Setting the value to 'None' will clear the property. */\n federatedClientId?: string;\n}\n\n/** Key Vault Key Url to be used for server side encryption of Managed Disks and Snapshots */\nexport interface KeyForDiskEncryptionSetOutput {\n /** Resource id of the KeyVault containing the key or secret. This property is optional and cannot be used if the KeyVault subscription is not the same as the Disk Encryption Set subscription. */\n sourceVault?: SourceVaultOutput;\n /** Fully versioned Key Url pointing to a key in KeyVault. Version segment of the Url is required regardless of rotationToLatestKeyVersionEnabled value. */\n keyUrl: string;\n}\n\n/** The List disk encryption set operation response. */\nexport interface DiskEncryptionSetListOutput {\n /** A list of disk encryption sets. */\n value: Array<DiskEncryptionSetOutput>;\n /** The uri to fetch the next page of disk encryption sets. Call ListNext() with this to fetch the next page of disk encryption sets. */\n nextLink?: string;\n}\n\n/** The List resources which are encrypted with the disk encryption set. */\nexport interface ResourceUriListOutput {\n /** A list of IDs or Owner IDs of resources which are encrypted with the disk encryption set. */\n value: Array<string>;\n /** The uri to fetch the next page of encrypted resources. Call ListNext() with this to fetch the next page of encrypted resources. */\n nextLink?: string;\n}\n\n/** Properties of disk restore point */\nexport interface DiskRestorePointOutput extends ProxyOnlyResourceOutput {\n /** Properties of an incremental disk restore point */\n properties?: DiskRestorePointPropertiesOutput;\n}\n\n/** Properties of an incremental disk restore point */\nexport interface DiskRestorePointPropertiesOutput {\n /** The timestamp of restorePoint creation */\n readonly timeCreated?: string;\n /** arm id of source disk or source disk restore point. */\n readonly sourceResourceId?: string;\n /** The Operating System type. */\n readonly osType?: \"Windows\" | \"Linux\";\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** Purchase plan information for the the image from which the OS disk was created. */\n purchasePlan?: PurchasePlanAutoGeneratedOutput;\n /** List of supported capabilities for the image from which the OS disk was created. */\n supportedCapabilities?: SupportedCapabilitiesOutput;\n /** id of the backing snapshot's MIS family */\n readonly familyId?: string;\n /** unique incarnation id of the source disk */\n readonly sourceUniqueId?: string;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n readonly encryption?: EncryptionOutput;\n /** Indicates the OS on a disk supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: \"AllowAll\" | \"AllowPrivate\" | \"DenyAll\";\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: \"Enabled\" | \"Disabled\";\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Percentage complete for the background copy of disk restore point when source resource is from a different region. */\n completionPercent?: number;\n /** Replication state of disk restore point when source resource is from a different region. */\n readonly replicationState?: string;\n /** Location of source disk or source disk restore point when source resource is from a different region. */\n readonly sourceResourceLocation?: string;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfileOutput;\n}\n\n/** The ProxyOnly Resource model definition. */\nexport interface ProxyOnlyResourceOutput {\n /** Resource Id */\n readonly id?: string;\n /** Resource name */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n}\n\n/** The List Disk Restore Points operation response. */\nexport interface DiskRestorePointListOutput {\n /** A list of disk restore points. */\n value: Array<DiskRestorePointOutput>;\n /** The uri to fetch the next page of disk restore points. Call ListNext() with this to fetch the next page of disk restore points. */\n nextLink?: string;\n}\n\n/** Snapshot resource. */\nexport interface SnapshotOutput extends ResourceOutput {\n /** Unused. Always Null. */\n readonly managedBy?: string;\n /** The snapshots sku name. Can be Standard_LRS, Premium_LRS, or Standard_ZRS. This is an optional parameter for incremental snapshot and the default behavior is the SKU will be set to the same sku as the previous snapshot */\n sku?: SnapshotSkuOutput;\n /** The extended location where the snapshot will be created. Extended location cannot be changed. */\n extendedLocation?: ExtendedLocationOutput;\n /** Snapshot resource properties. */\n properties?: SnapshotPropertiesOutput;\n}\n\n/** The snapshots sku name. Can be Standard_LRS, Premium_LRS, or Standard_ZRS. This is an optional parameter for incremental snapshot and the default behavior is the SKU will be set to the same sku as the previous snapshot */\nexport interface SnapshotSkuOutput {\n /** The sku name. */\n name?: \"Standard_LRS\" | \"Premium_LRS\" | \"Standard_ZRS\";\n /** The sku tier. */\n readonly tier?: string;\n}\n\n/** Snapshot resource properties. */\nexport interface SnapshotPropertiesOutput {\n /** The time when the snapshot was created. */\n readonly timeCreated?: string;\n /** The Operating System type. */\n osType?: \"Windows\" | \"Linux\";\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** Purchase plan information for the image from which the source disk for the snapshot was originally created. */\n purchasePlan?: PurchasePlanAutoGeneratedOutput;\n /** List of supported capabilities for the image from which the source disk from the snapshot was originally created. */\n supportedCapabilities?: SupportedCapabilitiesOutput;\n /** Disk source information. CreationData information cannot be changed after the disk has been created. */\n creationData: CreationDataOutput;\n /** If creationData.createOption is Empty, this field is mandatory and it indicates the size of the disk to create. If this field is present for updates or creation with other options, it indicates a resize. Resizes are only allowed if the disk is not attached to a running VM, and can only increase the disk's size. */\n diskSizeGB?: number;\n /** The size of the disk in bytes. This field is read only. */\n readonly diskSizeBytes?: number;\n /** The state of the snapshot. */\n readonly diskState?:\n | \"Unattached\"\n | \"Attached\"\n | \"Reserved\"\n | \"Frozen\"\n | \"ActiveSAS\"\n | \"ActiveSASFrozen\"\n | \"ReadyToUpload\"\n | \"ActiveUpload\";\n /** Unique Guid identifying the resource. */\n readonly uniqueId?: string;\n /** Encryption settings collection used be Azure Disk Encryption, can contain multiple encryption settings per disk or snapshot. */\n encryptionSettingsCollection?: EncryptionSettingsCollectionOutput;\n /** The disk provisioning state. */\n readonly provisioningState?: string;\n /** Whether a snapshot is incremental. Incremental snapshots on the same disk occupy less space than full snapshots and can be diffed. */\n incremental?: boolean;\n /** Incremental snapshots for a disk share an incremental snapshot family id. The Get Page Range Diff API can only be called on incremental snapshots with the same family id. */\n readonly incrementalSnapshotFamilyId?: string;\n /** Encryption property can be used to encrypt data at rest with customer managed keys or platform managed keys. */\n encryption?: EncryptionOutput;\n /** Policy for accessing the disk via network. */\n networkAccessPolicy?: \"AllowAll\" | \"AllowPrivate\" | \"DenyAll\";\n /** ARM id of the DiskAccess resource for using private endpoints on disks. */\n diskAccessId?: string;\n /** Contains the security related information for the resource. */\n securityProfile?: DiskSecurityProfileOutput;\n /** Indicates the OS on a snapshot supports hibernation. */\n supportsHibernation?: boolean;\n /** Policy for controlling export on the disk. */\n publicNetworkAccess?: \"Enabled\" | \"Disabled\";\n /** Percentage complete for the background copy when a resource is created via the CopyStart operation. */\n completionPercent?: number;\n /** Indicates the error details if the background copy of a resource created via the CopyStart operation fails. */\n copyCompletionError?: CopyCompletionErrorOutput;\n /** Additional authentication requirements when exporting or uploading to a disk or snapshot. */\n dataAccessAuthMode?: \"AzureActiveDirectory\" | \"None\";\n}\n\n/** Indicates the error details if the background copy of a resource created via the CopyStart operation fails. */\nexport interface CopyCompletionErrorOutput {\n /** Indicates the error code if the background copy of a resource created via the CopyStart operation fails. */\n errorCode: \"CopySourceNotFound\";\n /** Indicates the error message if the background copy of a resource created via the CopyStart operation fails. */\n errorMessage: string;\n}\n\n/** The List Snapshots operation response. */\nexport interface SnapshotListOutput {\n /** A list of snapshots. */\n value: Array<SnapshotOutput>;\n /** The uri to fetch the next page of snapshots. Call ListNext() with this to fetch the next page of snapshots. */\n nextLink?: string;\n}\n\n/** The List Resource Skus operation response. */\nexport interface ResourceSkusResultOutput {\n /** The list of skus available for the subscription. */\n value: Array<ResourceSkuOutput>;\n /** The URI to fetch the next page of Resource Skus. Call ListNext() with this URI to fetch the next page of Resource Skus */\n nextLink?: string;\n}\n\n/** Describes an available Compute SKU. */\nexport interface ResourceSkuOutput {\n /** The type of resource the SKU applies to. */\n readonly resourceType?: string;\n /** The name of SKU. */\n readonly name?: string;\n /** Specifies the tier of virtual machines in a scale set.<br /><br /> Possible Values:<br /><br /> **Standard**<br /><br /> **Basic** */\n readonly tier?: string;\n /** The Size of the SKU. */\n readonly size?: string;\n /** The Family of this particular SKU. */\n readonly family?: string;\n /** The Kind of resources that are supported in this SKU. */\n readonly kind?: string;\n /** Specifies the number of virtual machines in the scale set. */\n readonly capacity?: ResourceSkuCapacityOutput;\n /** The set of locations that the SKU is available. */\n readonly locations?: Array<string>;\n /** A list of locations and availability zones in those locations where the SKU is available. */\n readonly locationInfo?: Array<ResourceSkuLocationInfoOutput>;\n /** The api versions that support this SKU. */\n readonly apiVersions?: Array<string>;\n /** Metadata for retrieving price info. */\n readonly costs?: Array<ResourceSkuCostsOutput>;\n /** A name value pair to describe the capability. */\n readonly capabilities?: Array<ResourceSkuCapabilitiesOutput>;\n /** The restrictions because of which SKU cannot be used. This is empty if there are no restrictions. */\n readonly restrictions?: Array<ResourceSkuRestrictionsOutput>;\n}\n\n/** Describes scaling information of a SKU. */\nexport interface ResourceSkuCapacityOutput {\n /** The minimum capacity. */\n readonly minimum?: number;\n /** The maximum capacity that can be set. */\n readonly maximum?: number;\n /** The default capacity. */\n readonly default?: number;\n /** The scale type applicable to the sku. */\n readonly scaleType?: \"Automatic\" | \"Manual\" | \"None\";\n}\n\n/** Describes an available Compute SKU Location Information. */\nexport interface ResourceSkuLocationInfoOutput {\n /** Location of the SKU */\n readonly location?: string;\n /** List of availability zones where the SKU is supported. */\n readonly zones?: Array<string>;\n /** Details of capabilities available to a SKU in specific zones. */\n readonly zoneDetails?: Array<ResourceSkuZoneDetailsOutput>;\n /** The names of extended locations. */\n readonly extendedLocations?: Array<string>;\n /** The type of the extended location. */\n readonly type?: \"EdgeZone\";\n}\n\n/** Describes The zonal capabilities of a SKU. */\nexport interface ResourceSkuZoneDetailsOutput {\n /** The set of zones that the SKU is available in with the specified capabilities. */\n readonly name?: Array<string>;\n /** A list of capabilities that are available for the SKU in the specified list of zones. */\n readonly capabilities?: Array<ResourceSkuCapabilitiesOutput>;\n}\n\n/** Describes The SKU capabilities object. */\nexport interface ResourceSkuCapabilitiesOutput {\n /** An invariant to describe the feature. */\n readonly name?: string;\n /** An invariant if the feature is measured by quantity. */\n readonly value?: string;\n}\n\n/** Describes metadata for retrieving price info. */\nexport interface ResourceSkuCostsOutput {\n /** Used for querying price from commerce. */\n readonly meterID?: string;\n /** The multiplier is needed to extend the base metered cost. */\n readonly quantity?: number;\n /** An invariant to show the extended unit. */\n readonly extendedUnit?: string;\n}\n\n/** Describes scaling information of a SKU. */\nexport interface ResourceSkuRestrictionsOutput {\n /** The type of restrictions. */\n readonly type?: \"Location\" | \"Zone\";\n /** The value of restrictions. If the restriction type is set to location. This would be different locations where the SKU is restricted. */\n readonly values?: Array<string>;\n /** The information about the restriction where the SKU cannot be used. */\n readonly restrictionInfo?: ResourceSkuRestrictionInfoOutput;\n /** The reason for restriction. */\n readonly reasonCode?: \"QuotaId\" | \"NotAvailableForSubscription\";\n}\n\n/** Describes an available Compute SKU Restriction Information. */\nexport interface ResourceSkuRestrictionInfoOutput {\n /** Locations where the SKU is restricted */\n readonly locations?: Array<string>;\n /** List of availability zones where the SKU is restricted. */\n readonly zones?: Array<string>;\n}\n\n/** Specifies information about the Shared Image Gallery that you want to create or update. */\nexport interface GalleryOutput extends ResourceOutput {\n /** Describes the properties of a Shared Image Gallery. */\n properties?: GalleryPropertiesOutput;\n}\n\n/** Describes the properties of a Shared Image Gallery. */\nexport interface GalleryPropertiesOutput {\n /** The description of this Shared Image Gallery resource. This property is updatable. */\n description?: string;\n /** Describes the gallery unique name. */\n identifier?: GalleryIdentifierOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?:\n | \"Creating\"\n | \"Updating\"\n | \"Failed\"\n | \"Succeeded\"\n | \"Deleting\"\n | \"Migrating\";\n /** Profile for gallery sharing to subscription or tenant */\n sharingProfile?: SharingProfileOutput;\n /** Contains information about the soft deletion policy of the gallery. */\n softDeletePolicy?: SoftDeletePolicyOutput;\n /** Sharing status of current gallery. */\n readonly sharingStatus?: SharingStatusOutput;\n}\n\n/** Describes the gallery unique name. */\nexport interface GalleryIdentifierOutput {\n /** The unique name of the Shared Image Gallery. This name is generated automatically by Azure. */\n readonly uniqueName?: string;\n}\n\n/** Profile for gallery sharing to subscription or tenant */\nexport interface SharingProfileOutput {\n /** This property allows you to specify the permission of sharing gallery. <br><br> Possible values are: <br><br> **Private** <br><br> **Groups** <br><br> **Community** */\n permissions?: \"Private\" | \"Groups\" | \"Community\";\n /** A list of sharing profile groups. */\n readonly groups?: Array<SharingProfileGroupOutput>;\n /** Information of community gallery if current gallery is shared to community. */\n communityGalleryInfo?: CommunityGalleryInfoOutput;\n}\n\n/** Group of the gallery sharing profile */\nexport interface SharingProfileGroupOutput {\n /** This property allows you to specify the type of sharing group. <br><br> Possible values are: <br><br> **Subscriptions** <br><br> **AADTenants** */\n type?: \"Subscriptions\" | \"AADTenants\";\n /** A list of subscription/tenant ids the gallery is aimed to be shared to. */\n ids?: Array<string>;\n}\n\n/** Information of community gallery if current gallery is shared to community */\nexport interface CommunityGalleryInfoOutput {\n /** The link to the publisher website. Visible to all users. */\n publisherUri?: string;\n /** Community gallery publisher support email. The email address of the publisher. Visible to all users. */\n publisherContact?: string;\n /** End-user license agreement for community gallery image. */\n eula?: string;\n /** The prefix of the gallery name that will be displayed publicly. Visible to all users. */\n publicNamePrefix?: string;\n /** Contains info about whether community gallery sharing is enabled. */\n readonly communityGalleryEnabled?: boolean;\n /** Community gallery public name list. */\n readonly publicNames?: Array<string>;\n}\n\n/** Contains information about the soft deletion policy of the gallery. */\nexport interface SoftDeletePolicyOutput {\n /** Enables soft-deletion for resources in this gallery, allowing them to be recovered within retention time. */\n isSoftDeleteEnabled?: boolean;\n}\n\n/** Sharing status of current gallery. */\nexport interface SharingStatusOutput {\n /** Aggregated sharing state of current gallery. */\n readonly aggregatedState?: \"Succeeded\" | \"InProgress\" | \"Failed\" | \"Unknown\";\n /** Summary of all regional sharing status. */\n summary?: Array<RegionalSharingStatusOutput>;\n}\n\n/** Gallery regional sharing status */\nexport interface RegionalSharingStatusOutput {\n /** Region name */\n region?: string;\n /** Gallery sharing state in current region */\n readonly state?: \"Succeeded\" | \"InProgress\" | \"Failed\" | \"Unknown\";\n /** Details of gallery regional sharing failure. */\n details?: string;\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface GalleryImageOutput extends ResourceOutput {\n /** Describes the properties of a gallery image definition. */\n properties?: GalleryImagePropertiesOutput;\n}\n\n/** Describes the properties of a gallery image definition. */\nexport interface GalleryImagePropertiesOutput {\n /** The description of this gallery image definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery image definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType: \"Windows\" | \"Linux\";\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState: \"Generalized\" | \"Specialized\";\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** This is the gallery image definition identifier. */\n identifier: GalleryImageIdentifierOutput;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfigurationOutput;\n /** Describes the disallowed disk types. */\n disallowed?: DisallowedOutput;\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlanOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?:\n | \"Creating\"\n | \"Updating\"\n | \"Failed\"\n | \"Succeeded\"\n | \"Deleting\"\n | \"Migrating\";\n /** A list of gallery image features. */\n features?: Array<GalleryImageFeatureOutput>;\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: \"x64\" | \"Arm64\";\n}\n\n/** This is the gallery image definition identifier. */\nexport interface GalleryImageIdentifierOutput {\n /** The name of the gallery image definition publisher. */\n publisher: string;\n /** The name of the gallery image definition offer. */\n offer: string;\n /** The name of the gallery image definition SKU. */\n sku: string;\n}\n\n/** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\nexport interface RecommendedMachineConfigurationOutput {\n /** Describes the resource range. */\n vCPUs?: ResourceRangeOutput;\n /** Describes the resource range. */\n memory?: ResourceRangeOutput;\n}\n\n/** Describes the resource range. */\nexport interface ResourceRangeOutput {\n /** The minimum number of the resource. */\n min?: number;\n /** The maximum number of the resource. */\n max?: number;\n}\n\n/** Describes the disallowed disk types. */\nexport interface DisallowedOutput {\n /** A list of disk types. */\n diskTypes?: Array<string>;\n}\n\n/** Describes the gallery image definition purchase plan. This is used by marketplace images. */\nexport interface ImagePurchasePlanOutput {\n /** The plan ID. */\n name?: string;\n /** The publisher ID. */\n publisher?: string;\n /** The product ID. */\n product?: string;\n}\n\n/** A feature for gallery image. */\nexport interface GalleryImageFeatureOutput {\n /** The name of the gallery image feature. */\n name?: string;\n /** The value of the gallery image feature. */\n value?: string;\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface GalleryImageVersionOutput extends ResourceOutput {\n /** Describes the properties of a gallery image version. */\n properties?: GalleryImageVersionPropertiesOutput;\n}\n\n/** Describes the properties of a gallery image version. */\nexport interface GalleryImageVersionPropertiesOutput {\n /** The publishing profile of a gallery image Version. */\n publishingProfile?: GalleryImageVersionPublishingProfileOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?:\n | \"Creating\"\n | \"Updating\"\n | \"Failed\"\n | \"Succeeded\"\n | \"Deleting\"\n | \"Migrating\";\n /** This is the storage profile of a Gallery Image Version. */\n storageProfile: GalleryImageVersionStorageProfileOutput;\n /** This is the replication status of the gallery image version. */\n readonly replicationStatus?: ReplicationStatusOutput;\n}\n\n/** The publishing profile of a gallery image Version. */\nexport interface GalleryImageVersionPublishingProfileOutput extends GalleryArtifactPublishingProfileBaseOutput {}\n\n/** Describes the basic gallery artifact publishing profile. */\nexport interface GalleryArtifactPublishingProfileBaseOutput {\n /** The target regions where the Image Version is going to be replicated to. This property is updatable. */\n targetRegions?: Array<TargetRegionOutput>;\n /** The number of replicas of the Image Version to be created per region. This property would take effect for a region when regionalReplicaCount is not specified. This property is updatable. */\n replicaCount?: number;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /** The timestamp for when the gallery image version is published. */\n readonly publishedDate?: string;\n /** The end of life date of the gallery image version. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: \"Standard_LRS\" | \"Standard_ZRS\" | \"Premium_LRS\";\n /** Optional parameter which specifies the mode to be used for replication. This property is not updatable. */\n replicationMode?: \"Full\" | \"Shallow\";\n /** The target extended locations where the Image Version is going to be replicated to. This property is updatable. */\n targetExtendedLocations?: Array<GalleryTargetExtendedLocationOutput>;\n}\n\n/** Describes the target region information. */\nexport interface TargetRegionOutput {\n /** The name of the region. */\n name: string;\n /** The number of replicas of the Image Version to be created per region. This property is updatable. */\n regionalReplicaCount?: number;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: \"Standard_LRS\" | \"Standard_ZRS\" | \"Premium_LRS\";\n /** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\n encryption?: EncryptionImagesOutput;\n}\n\n/** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\nexport interface EncryptionImagesOutput {\n /** Contains encryption settings for an OS disk image. */\n osDiskImage?: OSDiskImageEncryptionOutput;\n /** A list of encryption specifications for data disk images. */\n dataDiskImages?: Array<DataDiskImageEncryptionOutput>;\n}\n\n/** Contains encryption settings for an OS disk image. */\nexport interface OSDiskImageEncryptionOutput extends DiskImageEncryptionOutput {\n /** This property specifies the security profile of an OS disk image. */\n securityProfile?: OSDiskImageSecurityProfileOutput;\n}\n\n/** Contains security profile for an OS disk image. */\nexport interface OSDiskImageSecurityProfileOutput {\n /** confidential VM encryption types */\n confidentialVMEncryptionType?:\n | \"EncryptedVMGuestStateOnlyWithPmk\"\n | \"EncryptedWithPmk\"\n | \"EncryptedWithCmk\";\n /** secure VM disk encryption set id */\n secureVMDiskEncryptionSetId?: string;\n}\n\n/** This is the disk image encryption base class. */\nexport interface DiskImageEncryptionOutput {\n /** A relative URI containing the resource ID of the disk encryption set. */\n diskEncryptionSetId?: string;\n}\n\n/** Contains encryption settings for a data disk image. */\nexport interface DataDiskImageEncryptionOutput extends DiskImageEncryptionOutput {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\nexport interface GalleryTargetExtendedLocationOutput {\n /** The name of the region. */\n name?: string;\n /** The name of the extended location. */\n extendedLocation?: GalleryExtendedLocationOutput;\n /** The number of replicas of the Image Version to be created per extended location. This property is updatable. */\n extendedLocationReplicaCount?: number;\n /** Specifies the storage account type to be used to store the image. This property is not updatable. */\n storageAccountType?: \"Standard_LRS\" | \"Standard_ZRS\" | \"Premium_LRS\";\n /** Optional. Allows users to provide customer managed keys for encrypting the OS and data disks in the gallery artifact. */\n encryption?: EncryptionImagesOutput;\n}\n\n/** The name of the extended location. */\nexport interface GalleryExtendedLocationOutput {\n name?: string;\n /** It is type of the extended location. */\n type?: \"EdgeZone\" | \"Unknown\";\n}\n\n/** This is the storage profile of a Gallery Image Version. */\nexport interface GalleryImageVersionStorageProfileOutput {\n /** The gallery artifact version source. */\n source?: GalleryArtifactVersionSourceOutput;\n /** This is the OS disk image. */\n osDiskImage?: GalleryOSDiskImageOutput;\n /** A list of data disk images. */\n dataDiskImages?: Array<GalleryDataDiskImageOutput>;\n}\n\n/** The gallery artifact version source. */\nexport interface GalleryArtifactVersionSourceOutput {\n /** The id of the gallery artifact version source. Can specify a disk uri, snapshot uri, user image or storage account resource. */\n id?: string;\n /** The uri of the gallery artifact version source. Currently used to specify vhd/blob source. */\n uri?: string;\n}\n\n/** This is the OS disk image. */\nexport interface GalleryOSDiskImageOutput extends GalleryDiskImageOutput {}\n\n/** This is the disk image base class. */\nexport interface GalleryDiskImageOutput {\n /** This property indicates the size of the VHD to be created. */\n readonly sizeInGB?: number;\n /** The host caching of the disk. Valid values are 'None', 'ReadOnly', and 'ReadWrite' */\n hostCaching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n /** The gallery artifact version source. */\n source?: GalleryArtifactVersionSourceOutput;\n}\n\n/** This is the data disk image. */\nexport interface GalleryDataDiskImageOutput extends GalleryDiskImageOutput {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\n/** This is the replication status of the gallery image version. */\nexport interface ReplicationStatusOutput {\n /** This is the aggregated replication status based on all the regional replication status flags. */\n readonly aggregatedState?: \"Unknown\" | \"InProgress\" | \"Completed\" | \"Failed\";\n /** This is a summary of replication status for each region. */\n readonly summary?: Array<RegionalReplicationStatusOutput>;\n}\n\n/** This is the regional replication status. */\nexport interface RegionalReplicationStatusOutput {\n /** The region to which the gallery image version is being replicated to. */\n readonly region?: string;\n /** This is the regional replication state. */\n readonly state?: \"Unknown\" | \"Replicating\" | \"Completed\" | \"Failed\";\n /** The details of the replication status. */\n readonly details?: string;\n /** It indicates progress of the replication job. */\n readonly progress?: number;\n}\n\n/** Specifies information about the gallery Application Definition that you want to create or update. */\nexport interface GalleryApplicationOutput extends ResourceOutput {\n /** Describes the properties of a gallery Application Definition. */\n properties?: GalleryApplicationPropertiesOutput;\n}\n\n/** Describes the properties of a gallery Application Definition. */\nexport interface GalleryApplicationPropertiesOutput {\n /** The description of this gallery Application Definition resource. This property is updatable. */\n description?: string;\n /** The Eula agreement for the gallery Application Definition. */\n eula?: string;\n /** The privacy statement uri. */\n privacyStatementUri?: string;\n /** The release note uri. */\n releaseNoteUri?: string;\n /** The end of life date of the gallery Application Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** This property allows you to specify the supported type of the OS that application is built for. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n supportedOSType: \"Windows\" | \"Linux\";\n}\n\n/** Specifies information about the gallery Application Version that you want to create or update. */\nexport interface GalleryApplicationVersionOutput extends ResourceOutput {\n /** Describes the properties of a gallery image version. */\n properties?: GalleryApplicationVersionPropertiesOutput;\n}\n\n/** Describes the properties of a gallery image version. */\nexport interface GalleryApplicationVersionPropertiesOutput {\n /** The publishing profile of a gallery image version. */\n publishingProfile: GalleryApplicationVersionPublishingProfileOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?:\n | \"Creating\"\n | \"Updating\"\n | \"Failed\"\n | \"Succeeded\"\n | \"Deleting\"\n | \"Migrating\";\n /** This is the replication status of the gallery image version. */\n readonly replicationStatus?: ReplicationStatusOutput;\n}\n\n/** The publishing profile of a gallery image version. */\nexport interface GalleryApplicationVersionPublishingProfileOutput extends GalleryArtifactPublishingProfileBaseOutput {\n /** The source image from which the Image Version is going to be created. */\n source: UserArtifactSourceOutput;\n manageActions?: UserArtifactManageOutput;\n /** Additional settings for the VM app that contains the target package and config file name when it is deployed to target VM or VM scale set. */\n settings?: UserArtifactSettingsOutput;\n /** Optional. Additional settings to pass to the vm-application-manager extension. For advanced use only. */\n advancedSettings?: Record<string, string>;\n /** Optional. Whether or not this application reports health. */\n enableHealthCheck?: boolean;\n}\n\n/** The source image from which the Image Version is going to be created. */\nexport interface UserArtifactSourceOutput {\n /** Required. The mediaLink of the artifact, must be a readable storage page blob. */\n mediaLink: string;\n /** Optional. The defaultConfigurationLink of the artifact, must be a readable storage page blob. */\n defaultConfigurationLink?: string;\n}\n\nexport interface UserArtifactManageOutput {\n /** Required. The path and arguments to install the gallery application. This is limited to 4096 characters. */\n install: string;\n /** Required. The path and arguments to remove the gallery application. This is limited to 4096 characters. */\n remove: string;\n /** Optional. The path and arguments to update the gallery application. If not present, then update operation will invoke remove command on the previous version and install command on the current version of the gallery application. This is limited to 4096 characters. */\n update?: string;\n}\n\n/** Additional settings for the VM app that contains the target package and config file name when it is deployed to target VM or VM scale set. */\nexport interface UserArtifactSettingsOutput {\n /** Optional. The name to assign the downloaded package file on the VM. This is limited to 4096 characters. If not specified, the package file will be named the same as the Gallery Application name. */\n packageFileName?: string;\n /** Optional. The name to assign the downloaded config file on the VM. This is limited to 4096 characters. If not specified, the config file will be named the Gallery Application name appended with \"_config\". */\n configFileName?: string;\n}\n\n/** The List Galleries operation response. */\nexport interface GalleryListOutput {\n /** A list of galleries. */\n value: Array<GalleryOutput>;\n /** The uri to fetch the next page of galleries. Call ListNext() with this to fetch the next page of galleries. */\n nextLink?: string;\n}\n\n/** The List Gallery Images operation response. */\nexport interface GalleryImageListOutput {\n /** A list of Shared Image Gallery images. */\n value: Array<GalleryImageOutput>;\n /** The uri to fetch the next page of Image Definitions in the Shared Image Gallery. Call ListNext() with this to fetch the next page of gallery image definitions. */\n nextLink?: string;\n}\n\n/** The List Gallery Image version operation response. */\nexport interface GalleryImageVersionListOutput {\n /** A list of gallery image versions. */\n value: Array<GalleryImageVersionOutput>;\n /** The uri to fetch the next page of gallery image versions. Call ListNext() with this to fetch the next page of gallery image versions. */\n nextLink?: string;\n}\n\n/** The List Gallery Applications operation response. */\nexport interface GalleryApplicationListOutput {\n /** A list of Gallery Applications. */\n value: Array<GalleryApplicationOutput>;\n /** The uri to fetch the next page of Application Definitions in the Application Gallery. Call ListNext() with this to fetch the next page of gallery Application Definitions. */\n nextLink?: string;\n}\n\n/** The List Gallery Application version operation response. */\nexport interface GalleryApplicationVersionListOutput {\n /** A list of gallery Application Versions. */\n value: Array<GalleryApplicationVersionOutput>;\n /** The uri to fetch the next page of gallery Application Versions. Call ListNext() with this to fetch the next page of gallery Application Versions. */\n nextLink?: string;\n}\n\n/** Specifies information about the gallery sharing profile update. */\nexport interface SharingUpdateOutput {\n /** This property allows you to specify the operation type of gallery sharing update. <br><br> Possible values are: <br><br> **Add** <br><br> **Remove** <br><br> **Reset** */\n operationType: \"Add\" | \"Remove\" | \"Reset\" | \"EnableCommunity\";\n /** A list of sharing profile groups. */\n groups?: Array<SharingProfileGroupOutput>;\n}\n\n/** The List Shared Galleries operation response. */\nexport interface SharedGalleryListOutput {\n /** A list of shared galleries. */\n value: Array<SharedGalleryOutput>;\n /** The uri to fetch the next page of shared galleries. Call ListNext() with this to fetch the next page of shared galleries. */\n nextLink?: string;\n}\n\n/** Specifies information about the Shared Gallery that you want to create or update. */\nexport interface SharedGalleryOutput extends PirSharedGalleryResourceOutput {}\n\n/** Base information about the shared gallery resource in pir. */\nexport interface PirSharedGalleryResourceOutput extends PirResourceOutput {\n /** The identifier information of shared gallery. */\n identifier?: SharedGalleryIdentifierOutput;\n}\n\n/** The identifier information of shared gallery. */\nexport interface SharedGalleryIdentifierOutput {\n /** The unique id of this shared gallery. */\n uniqueId?: string;\n}\n\n/** The Resource model definition. */\nexport interface PirResourceOutput {\n /** Resource name */\n readonly name?: string;\n /** Resource location */\n readonly location?: string;\n}\n\n/** The List Shared Gallery Images operation response. */\nexport interface SharedGalleryImageListOutput {\n /** A list of shared gallery images. */\n value: Array<SharedGalleryImageOutput>;\n /** The uri to fetch the next page of shared gallery images. Call ListNext() with this to fetch the next page of shared gallery images. */\n nextLink?: string;\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface SharedGalleryImageOutput extends PirSharedGalleryResourceOutput {\n /** Describes the properties of a gallery image definition. */\n properties?: SharedGalleryImagePropertiesOutput;\n}\n\n/** Describes the properties of a gallery image definition. */\nexport interface SharedGalleryImagePropertiesOutput {\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType: \"Windows\" | \"Linux\";\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState: \"Generalized\" | \"Specialized\";\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** This is the gallery image definition identifier. */\n identifier: GalleryImageIdentifierOutput;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfigurationOutput;\n /** Describes the disallowed disk types. */\n disallowed?: DisallowedOutput;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** A list of gallery image features. */\n features?: Array<GalleryImageFeatureOutput>;\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlanOutput;\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: \"x64\" | \"Arm64\";\n}\n\n/** The List Shared Gallery Image versions operation response. */\nexport interface SharedGalleryImageVersionListOutput {\n /** A list of shared gallery images versions. */\n value: Array<SharedGalleryImageVersionOutput>;\n /** The uri to fetch the next page of shared gallery image versions. Call ListNext() with this to fetch the next page of shared gallery image versions. */\n nextLink?: string;\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface SharedGalleryImageVersionOutput extends PirSharedGalleryResourceOutput {\n /** Describes the properties of a gallery image version. */\n properties?: SharedGalleryImageVersionPropertiesOutput;\n}\n\n/** Describes the properties of a gallery image version. */\nexport interface SharedGalleryImageVersionPropertiesOutput {\n /** The published date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n publishedDate?: string;\n /** The end of life date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /** Describes the storage profile of the image version. */\n storageProfile?: SharedGalleryImageVersionStorageProfileOutput;\n}\n\n/** This is the storage profile of a Gallery Image Version. */\nexport interface SharedGalleryImageVersionStorageProfileOutput {\n /** This is the OS disk image. */\n osDiskImage?: SharedGalleryOSDiskImageOutput;\n /** A list of data disk images. */\n dataDiskImages?: Array<SharedGalleryDataDiskImageOutput>;\n}\n\n/** This is the OS disk image. */\nexport interface SharedGalleryOSDiskImageOutput extends SharedGalleryDiskImageOutput {}\n\n/** This is the disk image base class. */\nexport interface SharedGalleryDiskImageOutput {\n /** This property indicates the size of the VHD to be created. */\n readonly diskSizeGB?: number;\n /** The host caching of the disk. Valid values are 'None', 'ReadOnly', and 'ReadWrite' */\n hostCaching?: \"None\" | \"ReadOnly\" | \"ReadWrite\";\n}\n\n/** This is the data disk image. */\nexport interface SharedGalleryDataDiskImageOutput extends SharedGalleryDiskImageOutput {\n /** This property specifies the logical unit number of the data disk. This value is used to identify data disks within the Virtual Machine and therefore must be unique for each data disk attached to the Virtual Machine. */\n lun: number;\n}\n\n/** Specifies information about the Community Gallery that you want to create or update. */\nexport interface CommunityGalleryOutput extends PirCommunityGalleryResourceOutput {}\n\n/** Base information about the community gallery resource in pir. */\nexport interface PirCommunityGalleryResourceOutput {\n /** Resource name */\n readonly name?: string;\n /** Resource location */\n readonly location?: string;\n /** Resource type */\n readonly type?: string;\n /** The identifier information of community gallery. */\n identifier?: CommunityGalleryIdentifierOutput;\n}\n\n/** The identifier information of community gallery. */\nexport interface CommunityGalleryIdentifierOutput {\n /** The unique id of this community gallery. */\n uniqueId?: string;\n}\n\n/** Specifies information about the gallery image definition that you want to create or update. */\nexport interface CommunityGalleryImageOutput extends PirCommunityGalleryResourceOutput {\n /** Describes the properties of a gallery image definition. */\n properties?: CommunityGalleryImagePropertiesOutput;\n}\n\n/** Describes the properties of a gallery image definition. */\nexport interface CommunityGalleryImagePropertiesOutput {\n /** This property allows you to specify the type of the OS that is included in the disk when creating a VM from a managed image. <br><br> Possible values are: <br><br> **Windows** <br><br> **Linux** */\n osType: \"Windows\" | \"Linux\";\n /** This property allows the user to specify whether the virtual machines created under this image are 'Generalized' or 'Specialized'. */\n osState: \"Generalized\" | \"Specialized\";\n /** The end of life date of the gallery image definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** This is the gallery image definition identifier. */\n identifier: GalleryImageIdentifierOutput;\n /** The properties describe the recommended machine configuration for this Image Definition. These properties are updatable. */\n recommended?: RecommendedMachineConfigurationOutput;\n /** Describes the disallowed disk types. */\n disallowed?: DisallowedOutput;\n /** The hypervisor generation of the Virtual Machine. Applicable to OS disks only. */\n hyperVGeneration?: \"V1\" | \"V2\";\n /** A list of gallery image features. */\n features?: Array<GalleryImageFeatureOutput>;\n /** Describes the gallery image definition purchase plan. This is used by marketplace images. */\n purchasePlan?: ImagePurchasePlanOutput;\n /** The architecture of the image. Applicable to OS disks only. */\n architecture?: \"x64\" | \"Arm64\";\n /** Privacy statement uri for the current community gallery image. */\n privacyStatementUri?: string;\n /** End-user license agreement for the current community gallery image. */\n eula?: string;\n}\n\n/** Specifies information about the gallery image version that you want to create or update. */\nexport interface CommunityGalleryImageVersionOutput extends PirCommunityGalleryResourceOutput {\n /** Describes the properties of a gallery image version. */\n properties?: CommunityGalleryImageVersionPropertiesOutput;\n}\n\n/** Describes the properties of a gallery image version. */\nexport interface CommunityGalleryImageVersionPropertiesOutput {\n /** The published date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n publishedDate?: string;\n /** The end of life date of the gallery image version Definition. This property can be used for decommissioning purposes. This property is updatable. */\n endOfLifeDate?: string;\n /** If set to true, Virtual Machines deployed from the latest version of the Image Definition won't use this Image Version. */\n excludeFromLatest?: boolean;\n /** Describes the storage profile of the image version. */\n storageProfile?: SharedGalleryImageVersionStorageProfileOutput;\n}\n\n/** The List Community Gallery Images operation response. */\nexport interface CommunityGalleryImageListOutput {\n /** A list of community gallery images. */\n value: Array<CommunityGalleryImageOutput>;\n /** The uri to fetch the next page of community gallery images. Call ListNext() with this to fetch the next page of community gallery images. */\n nextLink?: string;\n}\n\n/** The List Community Gallery Image versions operation response. */\nexport interface CommunityGalleryImageVersionListOutput {\n /** A list of community gallery image versions. */\n value: Array<CommunityGalleryImageVersionOutput>;\n /** The uri to fetch the next page of community gallery image versions. Call ListNext() with this to fetch the next page of community gallery image versions. */\n nextLink?: string;\n}\n\n/** Describes the cloud service role instance. */\nexport interface RoleInstanceOutput {\n /** Resource Id */\n readonly id?: string;\n /** Resource Name. */\n readonly name?: string;\n /** Resource Type. */\n readonly type?: string;\n /** Resource Location. */\n readonly location?: string;\n /** Resource tags. */\n readonly tags?: Record<string, string>;\n /** The role instance SKU. */\n sku?: InstanceSkuOutput;\n /** Role instance properties. */\n properties?: RoleInstancePropertiesOutput;\n}\n\n/** The role instance SKU. */\nexport interface InstanceSkuOutput {\n /** The sku name. */\n readonly name?: string;\n /** The tier of the cloud service role instance. */\n readonly tier?: string;\n}\n\n/** Role instance properties. */\nexport interface RoleInstancePropertiesOutput {\n /** Describes the network profile for the role instance. */\n networkProfile?: RoleInstanceNetworkProfileOutput;\n /** The instance view of the role instance. */\n instanceView?: RoleInstanceViewOutput;\n}\n\n/** Describes the network profile for the role instance. */\nexport interface RoleInstanceNetworkProfileOutput {\n /** Specifies the list of resource Ids for the network interfaces associated with the role instance. */\n readonly networkInterfaces?: Array<SubResourceOutput>;\n}\n\n/** The instance view of the role instance. */\nexport interface RoleInstanceViewOutput {\n /** The Update Domain. */\n readonly platformUpdateDomain?: number;\n /** The Fault Domain. */\n readonly platformFaultDomain?: number;\n /** Specifies a unique identifier generated internally for the cloud service associated with this role instance. <br /><br /> NOTE: If you are using Azure Diagnostics extension, this property can be used as 'DeploymentId' for querying details. */\n readonly privateId?: string;\n readonly statuses?: Array<ResourceInstanceViewStatusOutput>;\n}\n\n/** Instance view status. */\nexport interface ResourceInstanceViewStatusOutput {\n /** The status code. */\n readonly code?: string;\n /** The short localizable label for the status. */\n readonly displayStatus?: string;\n /** The detailed status message, including for alerts and error messages. */\n readonly message?: string;\n /** The time of the status. */\n readonly time?: string;\n /** The level code. */\n level?: \"Info\" | \"Warning\" | \"Error\";\n}\n\n/** The list operation result. */\nexport interface RoleInstanceListResultOutput {\n /** The list of resources. */\n value: Array<RoleInstanceOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a role of the cloud service. */\nexport interface CloudServiceRoleOutput {\n /** Resource id */\n readonly id?: string;\n /** Resource name */\n readonly name?: string;\n /** Resource type */\n readonly type?: string;\n /** Resource location */\n readonly location?: string;\n /** Describes the cloud service role sku. */\n sku?: CloudServiceRoleSkuOutput;\n /** The cloud service role properties. */\n properties?: CloudServiceRolePropertiesOutput;\n}\n\n/** Describes the cloud service role sku. */\nexport interface CloudServiceRoleSkuOutput {\n /** The sku name. NOTE: If the new SKU is not supported on the hardware the cloud service is currently on, you need to delete and recreate the cloud service or move back to the old sku. */\n name?: string;\n /** Specifies the tier of the cloud service. Possible Values are <br /><br /> **Standard** <br /><br /> **Basic** */\n tier?: string;\n /** Specifies the number of role instances in the cloud service. */\n capacity?: number;\n}\n\n/** The cloud service role properties. */\nexport interface CloudServiceRolePropertiesOutput {\n /** Specifies the ID which uniquely identifies a cloud service role. */\n readonly uniqueId?: string;\n}\n\n/** The list operation result. */\nexport interface CloudServiceRoleListResultOutput {\n /** The list of resources. */\n value: Array<CloudServiceRoleOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes the cloud service. */\nexport interface CloudServiceOutput {\n /** Resource Id. */\n readonly id?: string;\n /** Resource name. */\n readonly name?: string;\n /** Resource type. */\n readonly type?: string;\n /** Resource location. */\n location: string;\n /** Resource tags. */\n tags?: Record<string, string>;\n /** Cloud service properties */\n properties?: CloudServicePropertiesOutput;\n /** The system meta data relating to this resource. */\n systemData?: SystemDataOutput;\n}\n\n/** Cloud service properties */\nexport interface CloudServicePropertiesOutput {\n /**\n * Specifies a URL that refers to the location of the service package in the Blob service. The service package URL can be Shared Access Signature (SAS) URI from any storage account.\n * This is a write-only property and is not returned in GET calls.\n */\n packageUrl?: string;\n /** Specifies the XML service configuration (.cscfg) for the cloud service. */\n configuration?: string;\n /**\n * Specifies a URL that refers to the location of the service configuration in the Blob service. The service package URL can be Shared Access Signature (SAS) URI from any storage account.\n * This is a write-only property and is not returned in GET calls.\n */\n configurationUrl?: string;\n /**\n * (Optional) Indicates whether to start the cloud service immediately after it is created. The default value is `true`.\n * If false, the service model is still deployed, but the code is not run immediately. Instead, the service is PoweredOff until you call Start, at which time the service will be started. A deployed service still incurs charges, even if it is poweredoff.\n */\n startCloudService?: boolean;\n /**\n * (Optional) Indicates whether the role sku properties (roleProfile.roles.sku) specified in the model/template should override the role instance count and vm size specified in the .cscfg and .csdef respectively.\n * The default value is `false`.\n */\n allowModelOverride?: boolean;\n /**\n * Update mode for the cloud service. Role instances are allocated to update domains when the service is deployed. Updates can be initiated manually in each update domain or initiated automatically in all update domains.\n * Possible Values are <br /><br />**Auto**<br /><br />**Manual** <br /><br />**Simultaneous**<br /><br />\n * If not specified, the default value is Auto. If set to Manual, PUT UpdateDomain must be called to apply the update. If set to Auto, the update is automatically applied to each update domain in sequence.\n */\n upgradeMode?: \"Auto\" | \"Manual\" | \"Simultaneous\";\n /** Describes the role profile for the cloud service. */\n roleProfile?: CloudServiceRoleProfileOutput;\n /** Describes the OS profile for the cloud service. */\n osProfile?: CloudServiceOsProfileOutput;\n /** Network Profile for the cloud service. */\n networkProfile?: CloudServiceNetworkProfileOutput;\n /** Describes a cloud service extension profile. */\n extensionProfile?: CloudServiceExtensionProfileOutput;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** The unique identifier for the cloud service. */\n readonly uniqueId?: string;\n}\n\n/** Describes the role profile for the cloud service. */\nexport interface CloudServiceRoleProfileOutput {\n /** List of roles for the cloud service. */\n roles?: Array<CloudServiceRoleProfilePropertiesOutput>;\n}\n\n/** Describes the role properties. */\nexport interface CloudServiceRoleProfilePropertiesOutput {\n /** Resource name. */\n name?: string;\n /** Describes the cloud service role sku. */\n sku?: CloudServiceRoleSkuOutput;\n}\n\n/** Describes the OS profile for the cloud service. */\nexport interface CloudServiceOsProfileOutput {\n /** Specifies set of certificates that should be installed onto the role instances. */\n secrets?: Array<CloudServiceVaultSecretGroupOutput>;\n}\n\n/** Describes a set of certificates which are all in the same Key Vault. */\nexport interface CloudServiceVaultSecretGroupOutput {\n /** The relative URL of the Key Vault containing all of the certificates in VaultCertificates. */\n sourceVault?: SubResourceOutput;\n /** The list of key vault references in SourceVault which contain certificates. */\n vaultCertificates?: Array<CloudServiceVaultCertificateOutput>;\n}\n\n/** Describes a single certificate reference in a Key Vault, and where the certificate should reside on the role instance. */\nexport interface CloudServiceVaultCertificateOutput {\n /** This is the URL of a certificate that has been uploaded to Key Vault as a secret. */\n certificateUrl?: string;\n}\n\n/** Network Profile for the cloud service. */\nexport interface CloudServiceNetworkProfileOutput {\n /** List of Load balancer configurations. Cloud service can have up to two load balancer configurations, corresponding to a Public Load Balancer and an Internal Load Balancer. */\n loadBalancerConfigurations?: Array<LoadBalancerConfigurationOutput>;\n /**\n * Slot type for the cloud service.\n * Possible values are <br /><br />**Production**<br /><br />**Staging**<br /><br />\n * If not specified, the default value is Production.\n */\n slotType?: \"Production\" | \"Staging\";\n /** The id reference of the cloud service containing the target IP with which the subject cloud service can perform a swap. This property cannot be updated once it is set. The swappable cloud service referred by this id must be present otherwise an error will be thrown. */\n swappableCloudService?: SubResourceOutput;\n}\n\n/** Describes the load balancer configuration. */\nexport interface LoadBalancerConfigurationOutput {\n /** Resource Id */\n id?: string;\n /** The name of the Load balancer */\n name: string;\n /** Properties of the load balancer configuration. */\n properties: LoadBalancerConfigurationPropertiesOutput;\n}\n\n/** Describes the properties of the load balancer configuration. */\nexport interface LoadBalancerConfigurationPropertiesOutput {\n /** Specifies the frontend IP to be used for the load balancer. Only IPv4 frontend IP address is supported. Each load balancer configuration must have exactly one frontend IP configuration. */\n frontendIPConfigurations: Array<LoadBalancerFrontendIPConfigurationOutput>;\n}\n\n/** Specifies the frontend IP to be used for the load balancer. Only IPv4 frontend IP address is supported. Each load balancer configuration must have exactly one frontend IP configuration. */\nexport interface LoadBalancerFrontendIPConfigurationOutput {\n /** The name of the resource that is unique within the set of frontend IP configurations used by the load balancer. This name can be used to access the resource. */\n name: string;\n /** Properties of load balancer frontend ip configuration. */\n properties: LoadBalancerFrontendIPConfigurationPropertiesOutput;\n}\n\n/** Describes a cloud service IP Configuration */\nexport interface LoadBalancerFrontendIPConfigurationPropertiesOutput {\n /** The reference to the public ip address resource. */\n publicIPAddress?: SubResourceOutput;\n /** The reference to the virtual network subnet resource. */\n subnet?: SubResourceOutput;\n /** The virtual network private IP address of the IP configuration. */\n privateIPAddress?: string;\n}\n\n/** Describes a cloud service extension profile. */\nexport interface CloudServiceExtensionProfileOutput {\n /** List of extensions for the cloud service. */\n extensions?: Array<ExtensionOutput>;\n}\n\n/** Describes a cloud service Extension. */\nexport interface ExtensionOutput {\n /** The name of the extension. */\n name?: string;\n /** Extension Properties. */\n properties?: CloudServiceExtensionPropertiesOutput;\n}\n\n/** Extension Properties. */\nexport interface CloudServiceExtensionPropertiesOutput {\n /** The name of the extension handler publisher. */\n publisher?: string;\n /** Specifies the type of the extension. */\n type?: string;\n /** Specifies the version of the extension. Specifies the version of the extension. If this element is not specified or an asterisk (*) is used as the value, the latest version of the extension is used. If the value is specified with a major version number and an asterisk as the minor version number (X.), the latest minor version of the specified major version is selected. If a major version number and a minor version number are specified (X.Y), the specific extension version is selected. If a version is specified, an auto-upgrade is performed on the role instance. */\n typeHandlerVersion?: string;\n /** Explicitly specify whether platform can automatically upgrade typeHandlerVersion to higher minor versions when they become available. */\n autoUpgradeMinorVersion?: boolean;\n /** Public settings for the extension. For JSON extensions, this is the JSON settings for the extension. For XML Extension (like RDP), this is the XML setting for the extension. */\n settings?: any;\n /** Protected settings for the extension which are encrypted before sent to the role instance. */\n protectedSettings?: any;\n /** Protected settings for the extension, referenced using KeyVault which are encrypted before sent to the role instance. */\n protectedSettingsFromKeyVault?: CloudServiceVaultAndSecretReferenceOutput;\n /**\n * Tag to force apply the provided public and protected settings.\n * Changing the tag value allows for re-running the extension without changing any of the public or protected settings.\n * If forceUpdateTag is not changed, updates to public or protected settings would still be applied by the handler.\n * If neither forceUpdateTag nor any of public or protected settings change, extension would flow to the role instance with the same sequence-number, and\n * it is up to handler implementation whether to re-run it or not\n */\n forceUpdateTag?: string;\n /** The provisioning state, which only appears in the response. */\n readonly provisioningState?: string;\n /** Optional list of roles to apply this extension. If property is not specified or '*' is specified, extension is applied to all roles in the cloud service. */\n rolesAppliedTo?: Array<string>;\n}\n\n/** Protected settings for the extension, referenced using KeyVault which are encrypted before sent to the role instance. */\nexport interface CloudServiceVaultAndSecretReferenceOutput {\n /** The ARM Resource ID of the Key Vault */\n sourceVault?: SubResourceOutput;\n /** Secret URL which contains the protected settings of the extension */\n secretUrl?: string;\n}\n\n/** The system meta data relating to this resource. */\nexport interface SystemDataOutput {\n /** Specifies the time in UTC at which the Cloud Service (extended support) resource was created. <br />Minimum api-version: 2022-04-04. */\n readonly createdAt?: string;\n /** Specifies the time in UTC at which the Cloud Service (extended support) resource was last modified. <br />Minimum api-version: 2022-04-04. */\n readonly lastModifiedAt?: string;\n}\n\n/** InstanceView of CloudService as a whole */\nexport interface CloudServiceInstanceViewOutput {\n /** Instance view statuses. */\n roleInstance?: InstanceViewStatusesSummaryOutput;\n /** The version of the SDK that was used to generate the package for the cloud service. */\n readonly sdkVersion?: string;\n /** Specifies a list of unique identifiers generated internally for the cloud service. <br /><br /> NOTE: If you are using Azure Diagnostics extension, this property can be used as 'DeploymentId' for querying details. */\n readonly privateIds?: Array<string>;\n readonly statuses?: Array<ResourceInstanceViewStatusOutput>;\n}\n\n/** Instance view statuses. */\nexport interface InstanceViewStatusesSummaryOutput {\n /** The summary. */\n readonly statusesSummary?: Array<StatusCodeCountOutput>;\n}\n\n/** The status code and count of the cloud service instance view statuses */\nexport interface StatusCodeCountOutput {\n /** The instance view status code */\n readonly code?: string;\n /** Number of instances having this status code */\n readonly count?: number;\n}\n\n/** The list operation result. */\nexport interface CloudServiceListResultOutput {\n /** The list of resources. */\n value: Array<CloudServiceOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Defines an update domain for the cloud service. */\nexport interface UpdateDomainOutput {\n /** Resource Id */\n readonly id?: string;\n /** Resource Name */\n readonly name?: string;\n}\n\n/** The list operation result. */\nexport interface UpdateDomainListResultOutput {\n /** The list of resources. */\n value: Array<UpdateDomainOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a cloud service OS version. */\nexport interface OSVersionOutput {\n /** Resource Id. */\n readonly id?: string;\n /** Resource name. */\n readonly name?: string;\n /** Resource type. */\n readonly type?: string;\n /** Resource location. */\n readonly location?: string;\n /** OS version properties. */\n properties?: OSVersionPropertiesOutput;\n}\n\n/** OS version properties. */\nexport interface OSVersionPropertiesOutput {\n /** The family of this OS version. */\n readonly family?: string;\n /** The family label of this OS version. */\n readonly familyLabel?: string;\n /** The OS version. */\n readonly version?: string;\n /** The OS version label. */\n readonly label?: string;\n /** Specifies whether this is the default OS version for its family. */\n readonly isDefault?: boolean;\n /** Specifies whether this OS version is active. */\n readonly isActive?: boolean;\n}\n\n/** The list operation result. */\nexport interface OSVersionListResultOutput {\n /** The list of resources. */\n value: Array<OSVersionOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n\n/** Describes a cloud service OS family. */\nexport interface OSFamilyOutput {\n /** Resource Id. */\n readonly id?: string;\n /** Resource name. */\n readonly name?: string;\n /** Resource type. */\n readonly type?: string;\n /** Resource location. */\n readonly location?: string;\n /** OS family properties. */\n properties?: OSFamilyPropertiesOutput;\n}\n\n/** OS family properties. */\nexport interface OSFamilyPropertiesOutput {\n /** The OS family name. */\n readonly name?: string;\n /** The OS family label. */\n readonly label?: string;\n /** List of OS versions belonging to this family. */\n readonly versions?: Array<OSVersionPropertiesBaseOutput>;\n}\n\n/** Configuration view of an OS version. */\nexport interface OSVersionPropertiesBaseOutput {\n /** The OS version. */\n readonly version?: string;\n /** The OS version label. */\n readonly label?: string;\n /** Specifies whether this is the default OS version for its family. */\n readonly isDefault?: boolean;\n /** Specifies whether this OS version is active. */\n readonly isActive?: boolean;\n}\n\n/** The list operation result. */\nexport interface OSFamilyListResultOutput {\n /** The list of resources. */\n value: Array<OSFamilyOutput>;\n /** The URI to fetch the next page of resources. Use this to get the next page of resources. Do this till nextLink is null to fetch all the resources. */\n nextLink?: string;\n}\n"]}
|