All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.pulumi.azure.siterecovery.kotlin.ReplicatedVMArgs.kt Maven / Gradle / Ivy

Go to download

Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.

There is a newer version: 6.15.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.azure.siterecovery.kotlin

import com.pulumi.azure.siterecovery.ReplicatedVMArgs.builder
import com.pulumi.azure.siterecovery.kotlin.inputs.ReplicatedVMManagedDiskArgs
import com.pulumi.azure.siterecovery.kotlin.inputs.ReplicatedVMManagedDiskArgsBuilder
import com.pulumi.azure.siterecovery.kotlin.inputs.ReplicatedVMNetworkInterfaceArgs
import com.pulumi.azure.siterecovery.kotlin.inputs.ReplicatedVMNetworkInterfaceArgsBuilder
import com.pulumi.azure.siterecovery.kotlin.inputs.ReplicatedVMUnmanagedDiskArgs
import com.pulumi.azure.siterecovery.kotlin.inputs.ReplicatedVMUnmanagedDiskArgsBuilder
import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import kotlin.jvm.JvmName

/**
 * Manages a VM replicated using Azure Site Recovery (Azure to Azure only). A replicated VM keeps a copiously updated image of the VM in another region in order to be able to start the VM in that region in case of a disaster.
 * ## Example Usage
 * 
 * ```typescript
 * import * as pulumi from "@pulumi/pulumi";
 * import * as azure from "@pulumi/azure";
 * const primary = new azure.core.ResourceGroup("primary", {
 *     name: "tfex-replicated-vm-primary",
 *     location: "West US",
 * });
 * const secondary = new azure.core.ResourceGroup("secondary", {
 *     name: "tfex-replicated-vm-secondary",
 *     location: "East US",
 * });
 * const primaryVirtualNetwork = new azure.network.VirtualNetwork("primary", {
 *     name: "network1",
 *     resourceGroupName: primary.name,
 *     addressSpaces: ["192.168.1.0/24"],
 *     location: primary.location,
 * });
 * const primarySubnet = new azure.network.Subnet("primary", {
 *     name: "network1-subnet",
 *     resourceGroupName: primary.name,
 *     virtualNetworkName: primaryVirtualNetwork.name,
 *     addressPrefixes: ["192.168.1.0/24"],
 * });
 * const primaryPublicIp = new azure.network.PublicIp("primary", {
 *     name: "vm-public-ip-primary",
 *     allocationMethod: "Static",
 *     location: primary.location,
 *     resourceGroupName: primary.name,
 *     sku: "Basic",
 * });
 * const vmNetworkInterface = new azure.network.NetworkInterface("vm", {
 *     name: "vm-nic",
 *     location: primary.location,
 *     resourceGroupName: primary.name,
 *     ipConfigurations: [{
 *         name: "vm",
 *         subnetId: primarySubnet.id,
 *         privateIpAddressAllocation: "Dynamic",
 *         publicIpAddressId: primaryPublicIp.id,
 *     }],
 * });
 * const vm = new azure.compute.VirtualMachine("vm", {
 *     name: "vm",
 *     location: primary.location,
 *     resourceGroupName: primary.name,
 *     vmSize: "Standard_B1s",
 *     networkInterfaceIds: [vmNetworkInterface.id],
 *     storageImageReference: {
 *         publisher: "Canonical",
 *         offer: "0001-com-ubuntu-server-jammy",
 *         sku: "22_04-lts",
 *         version: "latest",
 *     },
 *     storageOsDisk: {
 *         name: "vm-os-disk",
 *         osType: "Linux",
 *         caching: "ReadWrite",
 *         createOption: "FromImage",
 *         managedDiskType: "Premium_LRS",
 *     },
 *     osProfile: {
 *         adminUsername: "test-admin-123",
 *         adminPassword: "test-pwd-123",
 *         computerName: "vm",
 *     },
 *     osProfileLinuxConfig: {
 *         disablePasswordAuthentication: false,
 *     },
 * });
 * const vault = new azure.recoveryservices.Vault("vault", {
 *     name: "example-recovery-vault",
 *     location: secondary.location,
 *     resourceGroupName: secondary.name,
 *     sku: "Standard",
 * });
 * const primaryFabric = new azure.siterecovery.Fabric("primary", {
 *     name: "primary-fabric",
 *     resourceGroupName: secondary.name,
 *     recoveryVaultName: vault.name,
 *     location: primary.location,
 * });
 * const secondaryFabric = new azure.siterecovery.Fabric("secondary", {
 *     name: "secondary-fabric",
 *     resourceGroupName: secondary.name,
 *     recoveryVaultName: vault.name,
 *     location: secondary.location,
 * });
 * const primaryProtectionContainer = new azure.siterecovery.ProtectionContainer("primary", {
 *     name: "primary-protection-container",
 *     resourceGroupName: secondary.name,
 *     recoveryVaultName: vault.name,
 *     recoveryFabricName: primaryFabric.name,
 * });
 * const secondaryProtectionContainer = new azure.siterecovery.ProtectionContainer("secondary", {
 *     name: "secondary-protection-container",
 *     resourceGroupName: secondary.name,
 *     recoveryVaultName: vault.name,
 *     recoveryFabricName: secondaryFabric.name,
 * });
 * const policy = new azure.siterecovery.ReplicationPolicy("policy", {
 *     name: "policy",
 *     resourceGroupName: secondary.name,
 *     recoveryVaultName: vault.name,
 *     recoveryPointRetentionInMinutes: 24 * 60,
 *     applicationConsistentSnapshotFrequencyInMinutes: 4 * 60,
 * });
 * const container_mapping = new azure.siterecovery.ProtectionContainerMapping("container-mapping", {
 *     name: "container-mapping",
 *     resourceGroupName: secondary.name,
 *     recoveryVaultName: vault.name,
 *     recoveryFabricName: primaryFabric.name,
 *     recoverySourceProtectionContainerName: primaryProtectionContainer.name,
 *     recoveryTargetProtectionContainerId: secondaryProtectionContainer.id,
 *     recoveryReplicationPolicyId: policy.id,
 * });
 * const secondaryVirtualNetwork = new azure.network.VirtualNetwork("secondary", {
 *     name: "network2",
 *     resourceGroupName: secondary.name,
 *     addressSpaces: ["192.168.2.0/24"],
 *     location: secondary.location,
 * });
 * const network_mapping = new azure.siterecovery.NetworkMapping("network-mapping", {
 *     name: "network-mapping",
 *     resourceGroupName: secondary.name,
 *     recoveryVaultName: vault.name,
 *     sourceRecoveryFabricName: primaryFabric.name,
 *     targetRecoveryFabricName: secondaryFabric.name,
 *     sourceNetworkId: primaryVirtualNetwork.id,
 *     targetNetworkId: secondaryVirtualNetwork.id,
 * });
 * const primaryAccount = new azure.storage.Account("primary", {
 *     name: "primaryrecoverycache",
 *     location: primary.location,
 *     resourceGroupName: primary.name,
 *     accountTier: "Standard",
 *     accountReplicationType: "LRS",
 * });
 * const secondarySubnet = new azure.network.Subnet("secondary", {
 *     name: "network2-subnet",
 *     resourceGroupName: secondary.name,
 *     virtualNetworkName: secondaryVirtualNetwork.name,
 *     addressPrefixes: ["192.168.2.0/24"],
 * });
 * const secondaryPublicIp = new azure.network.PublicIp("secondary", {
 *     name: "vm-public-ip-secondary",
 *     allocationMethod: "Static",
 *     location: secondary.location,
 *     resourceGroupName: secondary.name,
 *     sku: "Basic",
 * });
 * const vm_replication = new azure.siterecovery.ReplicatedVM("vm-replication", {
 *     name: "vm-replication",
 *     resourceGroupName: secondary.name,
 *     recoveryVaultName: vault.name,
 *     sourceRecoveryFabricName: primaryFabric.name,
 *     sourceVmId: vm.id,
 *     recoveryReplicationPolicyId: policy.id,
 *     sourceRecoveryProtectionContainerName: primaryProtectionContainer.name,
 *     targetResourceGroupId: secondary.id,
 *     targetRecoveryFabricId: secondaryFabric.id,
 *     targetRecoveryProtectionContainerId: secondaryProtectionContainer.id,
 *     managedDisks: [{
 *         diskId: vm.storageOsDisk.apply(storageOsDisk => storageOsDisk.managedDiskId),
 *         stagingStorageAccountId: primaryAccount.id,
 *         targetResourceGroupId: secondary.id,
 *         targetDiskType: "Premium_LRS",
 *         targetReplicaDiskType: "Premium_LRS",
 *     }],
 *     networkInterfaces: [{
 *         sourceNetworkInterfaceId: vmNetworkInterface.id,
 *         targetSubnetName: secondarySubnet.name,
 *         recoveryPublicIpAddressId: secondaryPublicIp.id,
 *     }],
 * });
 * ```
 * ```python
 * import pulumi
 * import pulumi_azure as azure
 * primary = azure.core.ResourceGroup("primary",
 *     name="tfex-replicated-vm-primary",
 *     location="West US")
 * secondary = azure.core.ResourceGroup("secondary",
 *     name="tfex-replicated-vm-secondary",
 *     location="East US")
 * primary_virtual_network = azure.network.VirtualNetwork("primary",
 *     name="network1",
 *     resource_group_name=primary.name,
 *     address_spaces=["192.168.1.0/24"],
 *     location=primary.location)
 * primary_subnet = azure.network.Subnet("primary",
 *     name="network1-subnet",
 *     resource_group_name=primary.name,
 *     virtual_network_name=primary_virtual_network.name,
 *     address_prefixes=["192.168.1.0/24"])
 * primary_public_ip = azure.network.PublicIp("primary",
 *     name="vm-public-ip-primary",
 *     allocation_method="Static",
 *     location=primary.location,
 *     resource_group_name=primary.name,
 *     sku="Basic")
 * vm_network_interface = azure.network.NetworkInterface("vm",
 *     name="vm-nic",
 *     location=primary.location,
 *     resource_group_name=primary.name,
 *     ip_configurations=[azure.network.NetworkInterfaceIpConfigurationArgs(
 *         name="vm",
 *         subnet_id=primary_subnet.id,
 *         private_ip_address_allocation="Dynamic",
 *         public_ip_address_id=primary_public_ip.id,
 *     )])
 * vm = azure.compute.VirtualMachine("vm",
 *     name="vm",
 *     location=primary.location,
 *     resource_group_name=primary.name,
 *     vm_size="Standard_B1s",
 *     network_interface_ids=[vm_network_interface.id],
 *     storage_image_reference=azure.compute.VirtualMachineStorageImageReferenceArgs(
 *         publisher="Canonical",
 *         offer="0001-com-ubuntu-server-jammy",
 *         sku="22_04-lts",
 *         version="latest",
 *     ),
 *     storage_os_disk=azure.compute.VirtualMachineStorageOsDiskArgs(
 *         name="vm-os-disk",
 *         os_type="Linux",
 *         caching="ReadWrite",
 *         create_option="FromImage",
 *         managed_disk_type="Premium_LRS",
 *     ),
 *     os_profile=azure.compute.VirtualMachineOsProfileArgs(
 *         admin_username="test-admin-123",
 *         admin_password="test-pwd-123",
 *         computer_name="vm",
 *     ),
 *     os_profile_linux_config=azure.compute.VirtualMachineOsProfileLinuxConfigArgs(
 *         disable_password_authentication=False,
 *     ))
 * vault = azure.recoveryservices.Vault("vault",
 *     name="example-recovery-vault",
 *     location=secondary.location,
 *     resource_group_name=secondary.name,
 *     sku="Standard")
 * primary_fabric = azure.siterecovery.Fabric("primary",
 *     name="primary-fabric",
 *     resource_group_name=secondary.name,
 *     recovery_vault_name=vault.name,
 *     location=primary.location)
 * secondary_fabric = azure.siterecovery.Fabric("secondary",
 *     name="secondary-fabric",
 *     resource_group_name=secondary.name,
 *     recovery_vault_name=vault.name,
 *     location=secondary.location)
 * primary_protection_container = azure.siterecovery.ProtectionContainer("primary",
 *     name="primary-protection-container",
 *     resource_group_name=secondary.name,
 *     recovery_vault_name=vault.name,
 *     recovery_fabric_name=primary_fabric.name)
 * secondary_protection_container = azure.siterecovery.ProtectionContainer("secondary",
 *     name="secondary-protection-container",
 *     resource_group_name=secondary.name,
 *     recovery_vault_name=vault.name,
 *     recovery_fabric_name=secondary_fabric.name)
 * policy = azure.siterecovery.ReplicationPolicy("policy",
 *     name="policy",
 *     resource_group_name=secondary.name,
 *     recovery_vault_name=vault.name,
 *     recovery_point_retention_in_minutes=24 * 60,
 *     application_consistent_snapshot_frequency_in_minutes=4 * 60)
 * container_mapping = azure.siterecovery.ProtectionContainerMapping("container-mapping",
 *     name="container-mapping",
 *     resource_group_name=secondary.name,
 *     recovery_vault_name=vault.name,
 *     recovery_fabric_name=primary_fabric.name,
 *     recovery_source_protection_container_name=primary_protection_container.name,
 *     recovery_target_protection_container_id=secondary_protection_container.id,
 *     recovery_replication_policy_id=policy.id)
 * secondary_virtual_network = azure.network.VirtualNetwork("secondary",
 *     name="network2",
 *     resource_group_name=secondary.name,
 *     address_spaces=["192.168.2.0/24"],
 *     location=secondary.location)
 * network_mapping = azure.siterecovery.NetworkMapping("network-mapping",
 *     name="network-mapping",
 *     resource_group_name=secondary.name,
 *     recovery_vault_name=vault.name,
 *     source_recovery_fabric_name=primary_fabric.name,
 *     target_recovery_fabric_name=secondary_fabric.name,
 *     source_network_id=primary_virtual_network.id,
 *     target_network_id=secondary_virtual_network.id)
 * primary_account = azure.storage.Account("primary",
 *     name="primaryrecoverycache",
 *     location=primary.location,
 *     resource_group_name=primary.name,
 *     account_tier="Standard",
 *     account_replication_type="LRS")
 * secondary_subnet = azure.network.Subnet("secondary",
 *     name="network2-subnet",
 *     resource_group_name=secondary.name,
 *     virtual_network_name=secondary_virtual_network.name,
 *     address_prefixes=["192.168.2.0/24"])
 * secondary_public_ip = azure.network.PublicIp("secondary",
 *     name="vm-public-ip-secondary",
 *     allocation_method="Static",
 *     location=secondary.location,
 *     resource_group_name=secondary.name,
 *     sku="Basic")
 * vm_replication = azure.siterecovery.ReplicatedVM("vm-replication",
 *     name="vm-replication",
 *     resource_group_name=secondary.name,
 *     recovery_vault_name=vault.name,
 *     source_recovery_fabric_name=primary_fabric.name,
 *     source_vm_id=vm.id,
 *     recovery_replication_policy_id=policy.id,
 *     source_recovery_protection_container_name=primary_protection_container.name,
 *     target_resource_group_id=secondary.id,
 *     target_recovery_fabric_id=secondary_fabric.id,
 *     target_recovery_protection_container_id=secondary_protection_container.id,
 *     managed_disks=[azure.siterecovery.ReplicatedVMManagedDiskArgs(
 *         disk_id=vm.storage_os_disk.managed_disk_id,
 *         staging_storage_account_id=primary_account.id,
 *         target_resource_group_id=secondary.id,
 *         target_disk_type="Premium_LRS",
 *         target_replica_disk_type="Premium_LRS",
 *     )],
 *     network_interfaces=[azure.siterecovery.ReplicatedVMNetworkInterfaceArgs(
 *         source_network_interface_id=vm_network_interface.id,
 *         target_subnet_name=secondary_subnet.name,
 *         recovery_public_ip_address_id=secondary_public_ip.id,
 *     )])
 * ```
 * ```csharp
 * using System.Collections.Generic;
 * using System.Linq;
 * using Pulumi;
 * using Azure = Pulumi.Azure;
 * return await Deployment.RunAsync(() =>
 * {
 *     var primary = new Azure.Core.ResourceGroup("primary", new()
 *     {
 *         Name = "tfex-replicated-vm-primary",
 *         Location = "West US",
 *     });
 *     var secondary = new Azure.Core.ResourceGroup("secondary", new()
 *     {
 *         Name = "tfex-replicated-vm-secondary",
 *         Location = "East US",
 *     });
 *     var primaryVirtualNetwork = new Azure.Network.VirtualNetwork("primary", new()
 *     {
 *         Name = "network1",
 *         ResourceGroupName = primary.Name,
 *         AddressSpaces = new[]
 *         {
 *             "192.168.1.0/24",
 *         },
 *         Location = primary.Location,
 *     });
 *     var primarySubnet = new Azure.Network.Subnet("primary", new()
 *     {
 *         Name = "network1-subnet",
 *         ResourceGroupName = primary.Name,
 *         VirtualNetworkName = primaryVirtualNetwork.Name,
 *         AddressPrefixes = new[]
 *         {
 *             "192.168.1.0/24",
 *         },
 *     });
 *     var primaryPublicIp = new Azure.Network.PublicIp("primary", new()
 *     {
 *         Name = "vm-public-ip-primary",
 *         AllocationMethod = "Static",
 *         Location = primary.Location,
 *         ResourceGroupName = primary.Name,
 *         Sku = "Basic",
 *     });
 *     var vmNetworkInterface = new Azure.Network.NetworkInterface("vm", new()
 *     {
 *         Name = "vm-nic",
 *         Location = primary.Location,
 *         ResourceGroupName = primary.Name,
 *         IpConfigurations = new[]
 *         {
 *             new Azure.Network.Inputs.NetworkInterfaceIpConfigurationArgs
 *             {
 *                 Name = "vm",
 *                 SubnetId = primarySubnet.Id,
 *                 PrivateIpAddressAllocation = "Dynamic",
 *                 PublicIpAddressId = primaryPublicIp.Id,
 *             },
 *         },
 *     });
 *     var vm = new Azure.Compute.VirtualMachine("vm", new()
 *     {
 *         Name = "vm",
 *         Location = primary.Location,
 *         ResourceGroupName = primary.Name,
 *         VmSize = "Standard_B1s",
 *         NetworkInterfaceIds = new[]
 *         {
 *             vmNetworkInterface.Id,
 *         },
 *         StorageImageReference = new Azure.Compute.Inputs.VirtualMachineStorageImageReferenceArgs
 *         {
 *             Publisher = "Canonical",
 *             Offer = "0001-com-ubuntu-server-jammy",
 *             Sku = "22_04-lts",
 *             Version = "latest",
 *         },
 *         StorageOsDisk = new Azure.Compute.Inputs.VirtualMachineStorageOsDiskArgs
 *         {
 *             Name = "vm-os-disk",
 *             OsType = "Linux",
 *             Caching = "ReadWrite",
 *             CreateOption = "FromImage",
 *             ManagedDiskType = "Premium_LRS",
 *         },
 *         OsProfile = new Azure.Compute.Inputs.VirtualMachineOsProfileArgs
 *         {
 *             AdminUsername = "test-admin-123",
 *             AdminPassword = "test-pwd-123",
 *             ComputerName = "vm",
 *         },
 *         OsProfileLinuxConfig = new Azure.Compute.Inputs.VirtualMachineOsProfileLinuxConfigArgs
 *         {
 *             DisablePasswordAuthentication = false,
 *         },
 *     });
 *     var vault = new Azure.RecoveryServices.Vault("vault", new()
 *     {
 *         Name = "example-recovery-vault",
 *         Location = secondary.Location,
 *         ResourceGroupName = secondary.Name,
 *         Sku = "Standard",
 *     });
 *     var primaryFabric = new Azure.SiteRecovery.Fabric("primary", new()
 *     {
 *         Name = "primary-fabric",
 *         ResourceGroupName = secondary.Name,
 *         RecoveryVaultName = vault.Name,
 *         Location = primary.Location,
 *     });
 *     var secondaryFabric = new Azure.SiteRecovery.Fabric("secondary", new()
 *     {
 *         Name = "secondary-fabric",
 *         ResourceGroupName = secondary.Name,
 *         RecoveryVaultName = vault.Name,
 *         Location = secondary.Location,
 *     });
 *     var primaryProtectionContainer = new Azure.SiteRecovery.ProtectionContainer("primary", new()
 *     {
 *         Name = "primary-protection-container",
 *         ResourceGroupName = secondary.Name,
 *         RecoveryVaultName = vault.Name,
 *         RecoveryFabricName = primaryFabric.Name,
 *     });
 *     var secondaryProtectionContainer = new Azure.SiteRecovery.ProtectionContainer("secondary", new()
 *     {
 *         Name = "secondary-protection-container",
 *         ResourceGroupName = secondary.Name,
 *         RecoveryVaultName = vault.Name,
 *         RecoveryFabricName = secondaryFabric.Name,
 *     });
 *     var policy = new Azure.SiteRecovery.ReplicationPolicy("policy", new()
 *     {
 *         Name = "policy",
 *         ResourceGroupName = secondary.Name,
 *         RecoveryVaultName = vault.Name,
 *         RecoveryPointRetentionInMinutes = 24 * 60,
 *         ApplicationConsistentSnapshotFrequencyInMinutes = 4 * 60,
 *     });
 *     var container_mapping = new Azure.SiteRecovery.ProtectionContainerMapping("container-mapping", new()
 *     {
 *         Name = "container-mapping",
 *         ResourceGroupName = secondary.Name,
 *         RecoveryVaultName = vault.Name,
 *         RecoveryFabricName = primaryFabric.Name,
 *         RecoverySourceProtectionContainerName = primaryProtectionContainer.Name,
 *         RecoveryTargetProtectionContainerId = secondaryProtectionContainer.Id,
 *         RecoveryReplicationPolicyId = policy.Id,
 *     });
 *     var secondaryVirtualNetwork = new Azure.Network.VirtualNetwork("secondary", new()
 *     {
 *         Name = "network2",
 *         ResourceGroupName = secondary.Name,
 *         AddressSpaces = new[]
 *         {
 *             "192.168.2.0/24",
 *         },
 *         Location = secondary.Location,
 *     });
 *     var network_mapping = new Azure.SiteRecovery.NetworkMapping("network-mapping", new()
 *     {
 *         Name = "network-mapping",
 *         ResourceGroupName = secondary.Name,
 *         RecoveryVaultName = vault.Name,
 *         SourceRecoveryFabricName = primaryFabric.Name,
 *         TargetRecoveryFabricName = secondaryFabric.Name,
 *         SourceNetworkId = primaryVirtualNetwork.Id,
 *         TargetNetworkId = secondaryVirtualNetwork.Id,
 *     });
 *     var primaryAccount = new Azure.Storage.Account("primary", new()
 *     {
 *         Name = "primaryrecoverycache",
 *         Location = primary.Location,
 *         ResourceGroupName = primary.Name,
 *         AccountTier = "Standard",
 *         AccountReplicationType = "LRS",
 *     });
 *     var secondarySubnet = new Azure.Network.Subnet("secondary", new()
 *     {
 *         Name = "network2-subnet",
 *         ResourceGroupName = secondary.Name,
 *         VirtualNetworkName = secondaryVirtualNetwork.Name,
 *         AddressPrefixes = new[]
 *         {
 *             "192.168.2.0/24",
 *         },
 *     });
 *     var secondaryPublicIp = new Azure.Network.PublicIp("secondary", new()
 *     {
 *         Name = "vm-public-ip-secondary",
 *         AllocationMethod = "Static",
 *         Location = secondary.Location,
 *         ResourceGroupName = secondary.Name,
 *         Sku = "Basic",
 *     });
 *     var vm_replication = new Azure.SiteRecovery.ReplicatedVM("vm-replication", new()
 *     {
 *         Name = "vm-replication",
 *         ResourceGroupName = secondary.Name,
 *         RecoveryVaultName = vault.Name,
 *         SourceRecoveryFabricName = primaryFabric.Name,
 *         SourceVmId = vm.Id,
 *         RecoveryReplicationPolicyId = policy.Id,
 *         SourceRecoveryProtectionContainerName = primaryProtectionContainer.Name,
 *         TargetResourceGroupId = secondary.Id,
 *         TargetRecoveryFabricId = secondaryFabric.Id,
 *         TargetRecoveryProtectionContainerId = secondaryProtectionContainer.Id,
 *         ManagedDisks = new[]
 *         {
 *             new Azure.SiteRecovery.Inputs.ReplicatedVMManagedDiskArgs
 *             {
 *                 DiskId = vm.StorageOsDisk.Apply(storageOsDisk => storageOsDisk.ManagedDiskId),
 *                 StagingStorageAccountId = primaryAccount.Id,
 *                 TargetResourceGroupId = secondary.Id,
 *                 TargetDiskType = "Premium_LRS",
 *                 TargetReplicaDiskType = "Premium_LRS",
 *             },
 *         },
 *         NetworkInterfaces = new[]
 *         {
 *             new Azure.SiteRecovery.Inputs.ReplicatedVMNetworkInterfaceArgs
 *             {
 *                 SourceNetworkInterfaceId = vmNetworkInterface.Id,
 *                 TargetSubnetName = secondarySubnet.Name,
 *                 RecoveryPublicIpAddressId = secondaryPublicIp.Id,
 *             },
 *         },
 *     });
 * });
 * ```
 * ```go
 * package main
 * import (
 * 	"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/compute"
 * 	"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/core"
 * 	"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/network"
 * 	"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/recoveryservices"
 * 	"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/siterecovery"
 * 	"github.com/pulumi/pulumi-azure/sdk/v5/go/azure/storage"
 * 	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
 * )
 * func main() {
 * 	pulumi.Run(func(ctx *pulumi.Context) error {
 * 		primary, err := core.NewResourceGroup(ctx, "primary", &core.ResourceGroupArgs{
 * 			Name:     pulumi.String("tfex-replicated-vm-primary"),
 * 			Location: pulumi.String("West US"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		secondary, err := core.NewResourceGroup(ctx, "secondary", &core.ResourceGroupArgs{
 * 			Name:     pulumi.String("tfex-replicated-vm-secondary"),
 * 			Location: pulumi.String("East US"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		primaryVirtualNetwork, err := network.NewVirtualNetwork(ctx, "primary", &network.VirtualNetworkArgs{
 * 			Name:              pulumi.String("network1"),
 * 			ResourceGroupName: primary.Name,
 * 			AddressSpaces: pulumi.StringArray{
 * 				pulumi.String("192.168.1.0/24"),
 * 			},
 * 			Location: primary.Location,
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		primarySubnet, err := network.NewSubnet(ctx, "primary", &network.SubnetArgs{
 * 			Name:               pulumi.String("network1-subnet"),
 * 			ResourceGroupName:  primary.Name,
 * 			VirtualNetworkName: primaryVirtualNetwork.Name,
 * 			AddressPrefixes: pulumi.StringArray{
 * 				pulumi.String("192.168.1.0/24"),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		primaryPublicIp, err := network.NewPublicIp(ctx, "primary", &network.PublicIpArgs{
 * 			Name:              pulumi.String("vm-public-ip-primary"),
 * 			AllocationMethod:  pulumi.String("Static"),
 * 			Location:          primary.Location,
 * 			ResourceGroupName: primary.Name,
 * 			Sku:               pulumi.String("Basic"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		vmNetworkInterface, err := network.NewNetworkInterface(ctx, "vm", &network.NetworkInterfaceArgs{
 * 			Name:              pulumi.String("vm-nic"),
 * 			Location:          primary.Location,
 * 			ResourceGroupName: primary.Name,
 * 			IpConfigurations: network.NetworkInterfaceIpConfigurationArray{
 * 				&network.NetworkInterfaceIpConfigurationArgs{
 * 					Name:                       pulumi.String("vm"),
 * 					SubnetId:                   primarySubnet.ID(),
 * 					PrivateIpAddressAllocation: pulumi.String("Dynamic"),
 * 					PublicIpAddressId:          primaryPublicIp.ID(),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		vm, err := compute.NewVirtualMachine(ctx, "vm", &compute.VirtualMachineArgs{
 * 			Name:              pulumi.String("vm"),
 * 			Location:          primary.Location,
 * 			ResourceGroupName: primary.Name,
 * 			VmSize:            pulumi.String("Standard_B1s"),
 * 			NetworkInterfaceIds: pulumi.StringArray{
 * 				vmNetworkInterface.ID(),
 * 			},
 * 			StorageImageReference: &compute.VirtualMachineStorageImageReferenceArgs{
 * 				Publisher: pulumi.String("Canonical"),
 * 				Offer:     pulumi.String("0001-com-ubuntu-server-jammy"),
 * 				Sku:       pulumi.String("22_04-lts"),
 * 				Version:   pulumi.String("latest"),
 * 			},
 * 			StorageOsDisk: &compute.VirtualMachineStorageOsDiskArgs{
 * 				Name:            pulumi.String("vm-os-disk"),
 * 				OsType:          pulumi.String("Linux"),
 * 				Caching:         pulumi.String("ReadWrite"),
 * 				CreateOption:    pulumi.String("FromImage"),
 * 				ManagedDiskType: pulumi.String("Premium_LRS"),
 * 			},
 * 			OsProfile: &compute.VirtualMachineOsProfileArgs{
 * 				AdminUsername: pulumi.String("test-admin-123"),
 * 				AdminPassword: pulumi.String("test-pwd-123"),
 * 				ComputerName:  pulumi.String("vm"),
 * 			},
 * 			OsProfileLinuxConfig: &compute.VirtualMachineOsProfileLinuxConfigArgs{
 * 				DisablePasswordAuthentication: pulumi.Bool(false),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		vault, err := recoveryservices.NewVault(ctx, "vault", &recoveryservices.VaultArgs{
 * 			Name:              pulumi.String("example-recovery-vault"),
 * 			Location:          secondary.Location,
 * 			ResourceGroupName: secondary.Name,
 * 			Sku:               pulumi.String("Standard"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		primaryFabric, err := siterecovery.NewFabric(ctx, "primary", &siterecovery.FabricArgs{
 * 			Name:              pulumi.String("primary-fabric"),
 * 			ResourceGroupName: secondary.Name,
 * 			RecoveryVaultName: vault.Name,
 * 			Location:          primary.Location,
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		secondaryFabric, err := siterecovery.NewFabric(ctx, "secondary", &siterecovery.FabricArgs{
 * 			Name:              pulumi.String("secondary-fabric"),
 * 			ResourceGroupName: secondary.Name,
 * 			RecoveryVaultName: vault.Name,
 * 			Location:          secondary.Location,
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		primaryProtectionContainer, err := siterecovery.NewProtectionContainer(ctx, "primary", &siterecovery.ProtectionContainerArgs{
 * 			Name:               pulumi.String("primary-protection-container"),
 * 			ResourceGroupName:  secondary.Name,
 * 			RecoveryVaultName:  vault.Name,
 * 			RecoveryFabricName: primaryFabric.Name,
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		secondaryProtectionContainer, err := siterecovery.NewProtectionContainer(ctx, "secondary", &siterecovery.ProtectionContainerArgs{
 * 			Name:               pulumi.String("secondary-protection-container"),
 * 			ResourceGroupName:  secondary.Name,
 * 			RecoveryVaultName:  vault.Name,
 * 			RecoveryFabricName: secondaryFabric.Name,
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		policy, err := siterecovery.NewReplicationPolicy(ctx, "policy", &siterecovery.ReplicationPolicyArgs{
 * 			Name:                            pulumi.String("policy"),
 * 			ResourceGroupName:               secondary.Name,
 * 			RecoveryVaultName:               vault.Name,
 * 			RecoveryPointRetentionInMinutes: 24 * 60,
 * 			ApplicationConsistentSnapshotFrequencyInMinutes: 4 * 60,
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = siterecovery.NewProtectionContainerMapping(ctx, "container-mapping", &siterecovery.ProtectionContainerMappingArgs{
 * 			Name:                                  pulumi.String("container-mapping"),
 * 			ResourceGroupName:                     secondary.Name,
 * 			RecoveryVaultName:                     vault.Name,
 * 			RecoveryFabricName:                    primaryFabric.Name,
 * 			RecoverySourceProtectionContainerName: primaryProtectionContainer.Name,
 * 			RecoveryTargetProtectionContainerId:   secondaryProtectionContainer.ID(),
 * 			RecoveryReplicationPolicyId:           policy.ID(),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		secondaryVirtualNetwork, err := network.NewVirtualNetwork(ctx, "secondary", &network.VirtualNetworkArgs{
 * 			Name:              pulumi.String("network2"),
 * 			ResourceGroupName: secondary.Name,
 * 			AddressSpaces: pulumi.StringArray{
 * 				pulumi.String("192.168.2.0/24"),
 * 			},
 * 			Location: secondary.Location,
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = siterecovery.NewNetworkMapping(ctx, "network-mapping", &siterecovery.NetworkMappingArgs{
 * 			Name:                     pulumi.String("network-mapping"),
 * 			ResourceGroupName:        secondary.Name,
 * 			RecoveryVaultName:        vault.Name,
 * 			SourceRecoveryFabricName: primaryFabric.Name,
 * 			TargetRecoveryFabricName: secondaryFabric.Name,
 * 			SourceNetworkId:          primaryVirtualNetwork.ID(),
 * 			TargetNetworkId:          secondaryVirtualNetwork.ID(),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		primaryAccount, err := storage.NewAccount(ctx, "primary", &storage.AccountArgs{
 * 			Name:                   pulumi.String("primaryrecoverycache"),
 * 			Location:               primary.Location,
 * 			ResourceGroupName:      primary.Name,
 * 			AccountTier:            pulumi.String("Standard"),
 * 			AccountReplicationType: pulumi.String("LRS"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		secondarySubnet, err := network.NewSubnet(ctx, "secondary", &network.SubnetArgs{
 * 			Name:               pulumi.String("network2-subnet"),
 * 			ResourceGroupName:  secondary.Name,
 * 			VirtualNetworkName: secondaryVirtualNetwork.Name,
 * 			AddressPrefixes: pulumi.StringArray{
 * 				pulumi.String("192.168.2.0/24"),
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		secondaryPublicIp, err := network.NewPublicIp(ctx, "secondary", &network.PublicIpArgs{
 * 			Name:              pulumi.String("vm-public-ip-secondary"),
 * 			AllocationMethod:  pulumi.String("Static"),
 * 			Location:          secondary.Location,
 * 			ResourceGroupName: secondary.Name,
 * 			Sku:               pulumi.String("Basic"),
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		_, err = siterecovery.NewReplicatedVM(ctx, "vm-replication", &siterecovery.ReplicatedVMArgs{
 * 			Name:                                  pulumi.String("vm-replication"),
 * 			ResourceGroupName:                     secondary.Name,
 * 			RecoveryVaultName:                     vault.Name,
 * 			SourceRecoveryFabricName:              primaryFabric.Name,
 * 			SourceVmId:                            vm.ID(),
 * 			RecoveryReplicationPolicyId:           policy.ID(),
 * 			SourceRecoveryProtectionContainerName: primaryProtectionContainer.Name,
 * 			TargetResourceGroupId:                 secondary.ID(),
 * 			TargetRecoveryFabricId:                secondaryFabric.ID(),
 * 			TargetRecoveryProtectionContainerId:   secondaryProtectionContainer.ID(),
 * 			ManagedDisks: siterecovery.ReplicatedVMManagedDiskArray{
 * 				&siterecovery.ReplicatedVMManagedDiskArgs{
 * 					DiskId: vm.StorageOsDisk.ApplyT(func(storageOsDisk compute.VirtualMachineStorageOsDisk) (*string, error) {
 * 						return &storageOsDisk.ManagedDiskId, nil
 * 					}).(pulumi.StringPtrOutput),
 * 					StagingStorageAccountId: primaryAccount.ID(),
 * 					TargetResourceGroupId:   secondary.ID(),
 * 					TargetDiskType:          pulumi.String("Premium_LRS"),
 * 					TargetReplicaDiskType:   pulumi.String("Premium_LRS"),
 * 				},
 * 			},
 * 			NetworkInterfaces: siterecovery.ReplicatedVMNetworkInterfaceArray{
 * 				&siterecovery.ReplicatedVMNetworkInterfaceArgs{
 * 					SourceNetworkInterfaceId:  vmNetworkInterface.ID(),
 * 					TargetSubnetName:          secondarySubnet.Name,
 * 					RecoveryPublicIpAddressId: secondaryPublicIp.ID(),
 * 				},
 * 			},
 * 		})
 * 		if err != nil {
 * 			return err
 * 		}
 * 		return nil
 * 	})
 * }
 * ```
 * ```java
 * package generated_program;
 * import com.pulumi.Context;
 * import com.pulumi.Pulumi;
 * import com.pulumi.core.Output;
 * import com.pulumi.azure.core.ResourceGroup;
 * import com.pulumi.azure.core.ResourceGroupArgs;
 * import com.pulumi.azure.network.VirtualNetwork;
 * import com.pulumi.azure.network.VirtualNetworkArgs;
 * import com.pulumi.azure.network.Subnet;
 * import com.pulumi.azure.network.SubnetArgs;
 * import com.pulumi.azure.network.PublicIp;
 * import com.pulumi.azure.network.PublicIpArgs;
 * import com.pulumi.azure.network.NetworkInterface;
 * import com.pulumi.azure.network.NetworkInterfaceArgs;
 * import com.pulumi.azure.network.inputs.NetworkInterfaceIpConfigurationArgs;
 * import com.pulumi.azure.compute.VirtualMachine;
 * import com.pulumi.azure.compute.VirtualMachineArgs;
 * import com.pulumi.azure.compute.inputs.VirtualMachineStorageImageReferenceArgs;
 * import com.pulumi.azure.compute.inputs.VirtualMachineStorageOsDiskArgs;
 * import com.pulumi.azure.compute.inputs.VirtualMachineOsProfileArgs;
 * import com.pulumi.azure.compute.inputs.VirtualMachineOsProfileLinuxConfigArgs;
 * import com.pulumi.azure.recoveryservices.Vault;
 * import com.pulumi.azure.recoveryservices.VaultArgs;
 * import com.pulumi.azure.siterecovery.Fabric;
 * import com.pulumi.azure.siterecovery.FabricArgs;
 * import com.pulumi.azure.siterecovery.ProtectionContainer;
 * import com.pulumi.azure.siterecovery.ProtectionContainerArgs;
 * import com.pulumi.azure.siterecovery.ReplicationPolicy;
 * import com.pulumi.azure.siterecovery.ReplicationPolicyArgs;
 * import com.pulumi.azure.siterecovery.ProtectionContainerMapping;
 * import com.pulumi.azure.siterecovery.ProtectionContainerMappingArgs;
 * import com.pulumi.azure.siterecovery.NetworkMapping;
 * import com.pulumi.azure.siterecovery.NetworkMappingArgs;
 * import com.pulumi.azure.storage.Account;
 * import com.pulumi.azure.storage.AccountArgs;
 * import com.pulumi.azure.siterecovery.ReplicatedVM;
 * import com.pulumi.azure.siterecovery.ReplicatedVMArgs;
 * import com.pulumi.azure.siterecovery.inputs.ReplicatedVMManagedDiskArgs;
 * import com.pulumi.azure.siterecovery.inputs.ReplicatedVMNetworkInterfaceArgs;
 * import java.util.List;
 * import java.util.ArrayList;
 * import java.util.Map;
 * import java.io.File;
 * import java.nio.file.Files;
 * import java.nio.file.Paths;
 * public class App {
 *     public static void main(String[] args) {
 *         Pulumi.run(App::stack);
 *     }
 *     public static void stack(Context ctx) {
 *         var primary = new ResourceGroup("primary", ResourceGroupArgs.builder()
 *             .name("tfex-replicated-vm-primary")
 *             .location("West US")
 *             .build());
 *         var secondary = new ResourceGroup("secondary", ResourceGroupArgs.builder()
 *             .name("tfex-replicated-vm-secondary")
 *             .location("East US")
 *             .build());
 *         var primaryVirtualNetwork = new VirtualNetwork("primaryVirtualNetwork", VirtualNetworkArgs.builder()
 *             .name("network1")
 *             .resourceGroupName(primary.name())
 *             .addressSpaces("192.168.1.0/24")
 *             .location(primary.location())
 *             .build());
 *         var primarySubnet = new Subnet("primarySubnet", SubnetArgs.builder()
 *             .name("network1-subnet")
 *             .resourceGroupName(primary.name())
 *             .virtualNetworkName(primaryVirtualNetwork.name())
 *             .addressPrefixes("192.168.1.0/24")
 *             .build());
 *         var primaryPublicIp = new PublicIp("primaryPublicIp", PublicIpArgs.builder()
 *             .name("vm-public-ip-primary")
 *             .allocationMethod("Static")
 *             .location(primary.location())
 *             .resourceGroupName(primary.name())
 *             .sku("Basic")
 *             .build());
 *         var vmNetworkInterface = new NetworkInterface("vmNetworkInterface", NetworkInterfaceArgs.builder()
 *             .name("vm-nic")
 *             .location(primary.location())
 *             .resourceGroupName(primary.name())
 *             .ipConfigurations(NetworkInterfaceIpConfigurationArgs.builder()
 *                 .name("vm")
 *                 .subnetId(primarySubnet.id())
 *                 .privateIpAddressAllocation("Dynamic")
 *                 .publicIpAddressId(primaryPublicIp.id())
 *                 .build())
 *             .build());
 *         var vm = new VirtualMachine("vm", VirtualMachineArgs.builder()
 *             .name("vm")
 *             .location(primary.location())
 *             .resourceGroupName(primary.name())
 *             .vmSize("Standard_B1s")
 *             .networkInterfaceIds(vmNetworkInterface.id())
 *             .storageImageReference(VirtualMachineStorageImageReferenceArgs.builder()
 *                 .publisher("Canonical")
 *                 .offer("0001-com-ubuntu-server-jammy")
 *                 .sku("22_04-lts")
 *                 .version("latest")
 *                 .build())
 *             .storageOsDisk(VirtualMachineStorageOsDiskArgs.builder()
 *                 .name("vm-os-disk")
 *                 .osType("Linux")
 *                 .caching("ReadWrite")
 *                 .createOption("FromImage")
 *                 .managedDiskType("Premium_LRS")
 *                 .build())
 *             .osProfile(VirtualMachineOsProfileArgs.builder()
 *                 .adminUsername("test-admin-123")
 *                 .adminPassword("test-pwd-123")
 *                 .computerName("vm")
 *                 .build())
 *             .osProfileLinuxConfig(VirtualMachineOsProfileLinuxConfigArgs.builder()
 *                 .disablePasswordAuthentication(false)
 *                 .build())
 *             .build());
 *         var vault = new Vault("vault", VaultArgs.builder()
 *             .name("example-recovery-vault")
 *             .location(secondary.location())
 *             .resourceGroupName(secondary.name())
 *             .sku("Standard")
 *             .build());
 *         var primaryFabric = new Fabric("primaryFabric", FabricArgs.builder()
 *             .name("primary-fabric")
 *             .resourceGroupName(secondary.name())
 *             .recoveryVaultName(vault.name())
 *             .location(primary.location())
 *             .build());
 *         var secondaryFabric = new Fabric("secondaryFabric", FabricArgs.builder()
 *             .name("secondary-fabric")
 *             .resourceGroupName(secondary.name())
 *             .recoveryVaultName(vault.name())
 *             .location(secondary.location())
 *             .build());
 *         var primaryProtectionContainer = new ProtectionContainer("primaryProtectionContainer", ProtectionContainerArgs.builder()
 *             .name("primary-protection-container")
 *             .resourceGroupName(secondary.name())
 *             .recoveryVaultName(vault.name())
 *             .recoveryFabricName(primaryFabric.name())
 *             .build());
 *         var secondaryProtectionContainer = new ProtectionContainer("secondaryProtectionContainer", ProtectionContainerArgs.builder()
 *             .name("secondary-protection-container")
 *             .resourceGroupName(secondary.name())
 *             .recoveryVaultName(vault.name())
 *             .recoveryFabricName(secondaryFabric.name())
 *             .build());
 *         var policy = new ReplicationPolicy("policy", ReplicationPolicyArgs.builder()
 *             .name("policy")
 *             .resourceGroupName(secondary.name())
 *             .recoveryVaultName(vault.name())
 *             .recoveryPointRetentionInMinutes(24 * 60)
 *             .applicationConsistentSnapshotFrequencyInMinutes(4 * 60)
 *             .build());
 *         var container_mapping = new ProtectionContainerMapping("container-mapping", ProtectionContainerMappingArgs.builder()
 *             .name("container-mapping")
 *             .resourceGroupName(secondary.name())
 *             .recoveryVaultName(vault.name())
 *             .recoveryFabricName(primaryFabric.name())
 *             .recoverySourceProtectionContainerName(primaryProtectionContainer.name())
 *             .recoveryTargetProtectionContainerId(secondaryProtectionContainer.id())
 *             .recoveryReplicationPolicyId(policy.id())
 *             .build());
 *         var secondaryVirtualNetwork = new VirtualNetwork("secondaryVirtualNetwork", VirtualNetworkArgs.builder()
 *             .name("network2")
 *             .resourceGroupName(secondary.name())
 *             .addressSpaces("192.168.2.0/24")
 *             .location(secondary.location())
 *             .build());
 *         var network_mapping = new NetworkMapping("network-mapping", NetworkMappingArgs.builder()
 *             .name("network-mapping")
 *             .resourceGroupName(secondary.name())
 *             .recoveryVaultName(vault.name())
 *             .sourceRecoveryFabricName(primaryFabric.name())
 *             .targetRecoveryFabricName(secondaryFabric.name())
 *             .sourceNetworkId(primaryVirtualNetwork.id())
 *             .targetNetworkId(secondaryVirtualNetwork.id())
 *             .build());
 *         var primaryAccount = new Account("primaryAccount", AccountArgs.builder()
 *             .name("primaryrecoverycache")
 *             .location(primary.location())
 *             .resourceGroupName(primary.name())
 *             .accountTier("Standard")
 *             .accountReplicationType("LRS")
 *             .build());
 *         var secondarySubnet = new Subnet("secondarySubnet", SubnetArgs.builder()
 *             .name("network2-subnet")
 *             .resourceGroupName(secondary.name())
 *             .virtualNetworkName(secondaryVirtualNetwork.name())
 *             .addressPrefixes("192.168.2.0/24")
 *             .build());
 *         var secondaryPublicIp = new PublicIp("secondaryPublicIp", PublicIpArgs.builder()
 *             .name("vm-public-ip-secondary")
 *             .allocationMethod("Static")
 *             .location(secondary.location())
 *             .resourceGroupName(secondary.name())
 *             .sku("Basic")
 *             .build());
 *         var vm_replication = new ReplicatedVM("vm-replication", ReplicatedVMArgs.builder()
 *             .name("vm-replication")
 *             .resourceGroupName(secondary.name())
 *             .recoveryVaultName(vault.name())
 *             .sourceRecoveryFabricName(primaryFabric.name())
 *             .sourceVmId(vm.id())
 *             .recoveryReplicationPolicyId(policy.id())
 *             .sourceRecoveryProtectionContainerName(primaryProtectionContainer.name())
 *             .targetResourceGroupId(secondary.id())
 *             .targetRecoveryFabricId(secondaryFabric.id())
 *             .targetRecoveryProtectionContainerId(secondaryProtectionContainer.id())
 *             .managedDisks(ReplicatedVMManagedDiskArgs.builder()
 *                 .diskId(vm.storageOsDisk().applyValue(storageOsDisk -> storageOsDisk.managedDiskId()))
 *                 .stagingStorageAccountId(primaryAccount.id())
 *                 .targetResourceGroupId(secondary.id())
 *                 .targetDiskType("Premium_LRS")
 *                 .targetReplicaDiskType("Premium_LRS")
 *                 .build())
 *             .networkInterfaces(ReplicatedVMNetworkInterfaceArgs.builder()
 *                 .sourceNetworkInterfaceId(vmNetworkInterface.id())
 *                 .targetSubnetName(secondarySubnet.name())
 *                 .recoveryPublicIpAddressId(secondaryPublicIp.id())
 *                 .build())
 *             .build());
 *     }
 * }
 * ```
 * 
 * ## Import
 * Site Recovery Replicated VM's can be imported using the `resource id`, e.g.
 * ```sh
 * $ pulumi import azure:siterecovery/replicatedVM:ReplicatedVM vmreplication /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/resource-group-name/providers/Microsoft.RecoveryServices/vaults/recovery-vault-name/replicationFabrics/fabric-name/replicationProtectionContainers/protection-container-name/replicationProtectedItems/vm-replication-name
 * ```
 * @property managedDisks One or more `managed_disk` block as defined below. Changing this forces a new resource to be created.
 * @property multiVmGroupName Name of group in which all machines will replicate together and have shared crash consistent and app-consistent recovery points when failed over.
 * @property name The name of the replication for the replicated VM. Changing this forces a new resource to be created.
 * @property networkInterfaces One or more `network_interface` block as defined below.
 * @property recoveryReplicationPolicyId Id of the policy to use for this replicated vm. Changing this forces a new resource to be created.
 * @property recoveryVaultName The name of the vault that should be updated. Changing this forces a new resource to be created.
 * @property resourceGroupName Name of the resource group where the vault that should be updated is located. Changing this forces a new resource to be created.
 * @property sourceRecoveryFabricName Name of fabric that should contain this replication. Changing this forces a new resource to be created.
 * @property sourceRecoveryProtectionContainerName Name of the protection container to use. Changing this forces a new resource to be created.
 * @property sourceVmId Id of the VM to replicate Changing this forces a new resource to be created.
 * @property targetAvailabilitySetId Id of availability set that the new VM should belong to when a failover is done.
 * @property targetBootDiagnosticStorageAccountId Id of the storage account which the new VM should used for boot diagnostic when a failover is done.
 * @property targetCapacityReservationGroupId Id of the Capacity reservation group where the new VM should belong to when a failover is done.
 * @property targetEdgeZone Specifies the Edge Zone within the Azure Region where this Managed Kubernetes Cluster should exist. Changing this forces a new resource to be created.
 * @property targetNetworkId Network to use when a failover is done (recommended to set if any network_interface is configured for failover).
 * @property targetProximityPlacementGroupId Id of Proximity Placement Group the new VM should belong to when a failover is done.
 * @property targetRecoveryFabricId Id of fabric where the VM replication should be handled when a failover is done. Changing this forces a new resource to be created.
 * @property targetRecoveryProtectionContainerId Id of protection container where the VM replication should be created when a failover is done. Changing this forces a new resource to be created.
 * @property targetResourceGroupId Id of resource group where the VM should be created when a failover is done. Changing this forces a new resource to be created.
 * @property targetVirtualMachineScaleSetId Id of the Virtual Machine Scale Set which the new Vm should belong to when a failover is done.
 * @property targetZone Specifies the Availability Zone where the Failover VM should exist. Changing this forces a new resource to be created.
 * @property testNetworkId Network to use when a test failover is done.
 * @property unmanagedDisks One or more `unmanaged_disk` block as defined below. Changing this forces a new resource to be created.
 */
public data class ReplicatedVMArgs(
    public val managedDisks: Output>? = null,
    public val multiVmGroupName: Output? = null,
    public val name: Output? = null,
    public val networkInterfaces: Output>? = null,
    public val recoveryReplicationPolicyId: Output? = null,
    public val recoveryVaultName: Output? = null,
    public val resourceGroupName: Output? = null,
    public val sourceRecoveryFabricName: Output? = null,
    public val sourceRecoveryProtectionContainerName: Output? = null,
    public val sourceVmId: Output? = null,
    public val targetAvailabilitySetId: Output? = null,
    public val targetBootDiagnosticStorageAccountId: Output? = null,
    public val targetCapacityReservationGroupId: Output? = null,
    public val targetEdgeZone: Output? = null,
    public val targetNetworkId: Output? = null,
    public val targetProximityPlacementGroupId: Output? = null,
    public val targetRecoveryFabricId: Output? = null,
    public val targetRecoveryProtectionContainerId: Output? = null,
    public val targetResourceGroupId: Output? = null,
    public val targetVirtualMachineScaleSetId: Output? = null,
    public val targetZone: Output? = null,
    public val testNetworkId: Output? = null,
    public val unmanagedDisks: Output>? = null,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.azure.siterecovery.ReplicatedVMArgs =
        com.pulumi.azure.siterecovery.ReplicatedVMArgs.builder()
            .managedDisks(
                managedDisks?.applyValue({ args0 ->
                    args0.map({ args0 ->
                        args0.let({ args0 ->
                            args0.toJava()
                        })
                    })
                }),
            )
            .multiVmGroupName(multiVmGroupName?.applyValue({ args0 -> args0 }))
            .name(name?.applyValue({ args0 -> args0 }))
            .networkInterfaces(
                networkInterfaces?.applyValue({ args0 ->
                    args0.map({ args0 ->
                        args0.let({ args0 ->
                            args0.toJava()
                        })
                    })
                }),
            )
            .recoveryReplicationPolicyId(recoveryReplicationPolicyId?.applyValue({ args0 -> args0 }))
            .recoveryVaultName(recoveryVaultName?.applyValue({ args0 -> args0 }))
            .resourceGroupName(resourceGroupName?.applyValue({ args0 -> args0 }))
            .sourceRecoveryFabricName(sourceRecoveryFabricName?.applyValue({ args0 -> args0 }))
            .sourceRecoveryProtectionContainerName(
                sourceRecoveryProtectionContainerName?.applyValue({ args0 ->
                    args0
                }),
            )
            .sourceVmId(sourceVmId?.applyValue({ args0 -> args0 }))
            .targetAvailabilitySetId(targetAvailabilitySetId?.applyValue({ args0 -> args0 }))
            .targetBootDiagnosticStorageAccountId(
                targetBootDiagnosticStorageAccountId?.applyValue({ args0 ->
                    args0
                }),
            )
            .targetCapacityReservationGroupId(targetCapacityReservationGroupId?.applyValue({ args0 -> args0 }))
            .targetEdgeZone(targetEdgeZone?.applyValue({ args0 -> args0 }))
            .targetNetworkId(targetNetworkId?.applyValue({ args0 -> args0 }))
            .targetProximityPlacementGroupId(targetProximityPlacementGroupId?.applyValue({ args0 -> args0 }))
            .targetRecoveryFabricId(targetRecoveryFabricId?.applyValue({ args0 -> args0 }))
            .targetRecoveryProtectionContainerId(
                targetRecoveryProtectionContainerId?.applyValue({ args0 ->
                    args0
                }),
            )
            .targetResourceGroupId(targetResourceGroupId?.applyValue({ args0 -> args0 }))
            .targetVirtualMachineScaleSetId(targetVirtualMachineScaleSetId?.applyValue({ args0 -> args0 }))
            .targetZone(targetZone?.applyValue({ args0 -> args0 }))
            .testNetworkId(testNetworkId?.applyValue({ args0 -> args0 }))
            .unmanagedDisks(
                unmanagedDisks?.applyValue({ args0 ->
                    args0.map({ args0 ->
                        args0.let({ args0 ->
                            args0.toJava()
                        })
                    })
                }),
            ).build()
}

/**
 * Builder for [ReplicatedVMArgs].
 */
@PulumiTagMarker
public class ReplicatedVMArgsBuilder internal constructor() {
    private var managedDisks: Output>? = null

    private var multiVmGroupName: Output? = null

    private var name: Output? = null

    private var networkInterfaces: Output>? = null

    private var recoveryReplicationPolicyId: Output? = null

    private var recoveryVaultName: Output? = null

    private var resourceGroupName: Output? = null

    private var sourceRecoveryFabricName: Output? = null

    private var sourceRecoveryProtectionContainerName: Output? = null

    private var sourceVmId: Output? = null

    private var targetAvailabilitySetId: Output? = null

    private var targetBootDiagnosticStorageAccountId: Output? = null

    private var targetCapacityReservationGroupId: Output? = null

    private var targetEdgeZone: Output? = null

    private var targetNetworkId: Output? = null

    private var targetProximityPlacementGroupId: Output? = null

    private var targetRecoveryFabricId: Output? = null

    private var targetRecoveryProtectionContainerId: Output? = null

    private var targetResourceGroupId: Output? = null

    private var targetVirtualMachineScaleSetId: Output? = null

    private var targetZone: Output? = null

    private var testNetworkId: Output? = null

    private var unmanagedDisks: Output>? = null

    /**
     * @param value One or more `managed_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("cvbmurpevrettbpx")
    public suspend fun managedDisks(`value`: Output>) {
        this.managedDisks = value
    }

    @JvmName("byuwbuefulyxexql")
    public suspend fun managedDisks(vararg values: Output) {
        this.managedDisks = Output.all(values.asList())
    }

    /**
     * @param values One or more `managed_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("qisjbegkofdljxxu")
    public suspend fun managedDisks(values: List>) {
        this.managedDisks = Output.all(values)
    }

    /**
     * @param value Name of group in which all machines will replicate together and have shared crash consistent and app-consistent recovery points when failed over.
     */
    @JvmName("mfrjyvehhavlgptd")
    public suspend fun multiVmGroupName(`value`: Output) {
        this.multiVmGroupName = value
    }

    /**
     * @param value The name of the replication for the replicated VM. Changing this forces a new resource to be created.
     */
    @JvmName("ojbeijdaawjixgdq")
    public suspend fun name(`value`: Output) {
        this.name = value
    }

    /**
     * @param value One or more `network_interface` block as defined below.
     */
    @JvmName("rwgirbjslkkgsbho")
    public suspend fun networkInterfaces(`value`: Output>) {
        this.networkInterfaces = value
    }

    @JvmName("oaeyfmsyqhefkvfv")
    public suspend fun networkInterfaces(vararg values: Output) {
        this.networkInterfaces = Output.all(values.asList())
    }

    /**
     * @param values One or more `network_interface` block as defined below.
     */
    @JvmName("lotdypcsnoetrgce")
    public suspend fun networkInterfaces(values: List>) {
        this.networkInterfaces = Output.all(values)
    }

    /**
     * @param value Id of the policy to use for this replicated vm. Changing this forces a new resource to be created.
     */
    @JvmName("nlljrgejicodbakf")
    public suspend fun recoveryReplicationPolicyId(`value`: Output) {
        this.recoveryReplicationPolicyId = value
    }

    /**
     * @param value The name of the vault that should be updated. Changing this forces a new resource to be created.
     */
    @JvmName("wkedxeekscrvuauu")
    public suspend fun recoveryVaultName(`value`: Output) {
        this.recoveryVaultName = value
    }

    /**
     * @param value Name of the resource group where the vault that should be updated is located. Changing this forces a new resource to be created.
     */
    @JvmName("svkdythmesyimbao")
    public suspend fun resourceGroupName(`value`: Output) {
        this.resourceGroupName = value
    }

    /**
     * @param value Name of fabric that should contain this replication. Changing this forces a new resource to be created.
     */
    @JvmName("umhhpwjqkldcifot")
    public suspend fun sourceRecoveryFabricName(`value`: Output) {
        this.sourceRecoveryFabricName = value
    }

    /**
     * @param value Name of the protection container to use. Changing this forces a new resource to be created.
     */
    @JvmName("vbpfhuftvowathre")
    public suspend fun sourceRecoveryProtectionContainerName(`value`: Output) {
        this.sourceRecoveryProtectionContainerName = value
    }

    /**
     * @param value Id of the VM to replicate Changing this forces a new resource to be created.
     */
    @JvmName("phngwercjlcggijd")
    public suspend fun sourceVmId(`value`: Output) {
        this.sourceVmId = value
    }

    /**
     * @param value Id of availability set that the new VM should belong to when a failover is done.
     */
    @JvmName("fkbunefpvvdtdfcn")
    public suspend fun targetAvailabilitySetId(`value`: Output) {
        this.targetAvailabilitySetId = value
    }

    /**
     * @param value Id of the storage account which the new VM should used for boot diagnostic when a failover is done.
     */
    @JvmName("htlfekcvlliojtwx")
    public suspend fun targetBootDiagnosticStorageAccountId(`value`: Output) {
        this.targetBootDiagnosticStorageAccountId = value
    }

    /**
     * @param value Id of the Capacity reservation group where the new VM should belong to when a failover is done.
     */
    @JvmName("vmkiskkdriihgcsu")
    public suspend fun targetCapacityReservationGroupId(`value`: Output) {
        this.targetCapacityReservationGroupId = value
    }

    /**
     * @param value Specifies the Edge Zone within the Azure Region where this Managed Kubernetes Cluster should exist. Changing this forces a new resource to be created.
     */
    @JvmName("fjhsaknfdwsaxwbu")
    public suspend fun targetEdgeZone(`value`: Output) {
        this.targetEdgeZone = value
    }

    /**
     * @param value Network to use when a failover is done (recommended to set if any network_interface is configured for failover).
     */
    @JvmName("lowoyjjxaypiwbgd")
    public suspend fun targetNetworkId(`value`: Output) {
        this.targetNetworkId = value
    }

    /**
     * @param value Id of Proximity Placement Group the new VM should belong to when a failover is done.
     */
    @JvmName("firmswjtmhkvrklq")
    public suspend fun targetProximityPlacementGroupId(`value`: Output) {
        this.targetProximityPlacementGroupId = value
    }

    /**
     * @param value Id of fabric where the VM replication should be handled when a failover is done. Changing this forces a new resource to be created.
     */
    @JvmName("vkkibpmmsyrktody")
    public suspend fun targetRecoveryFabricId(`value`: Output) {
        this.targetRecoveryFabricId = value
    }

    /**
     * @param value Id of protection container where the VM replication should be created when a failover is done. Changing this forces a new resource to be created.
     */
    @JvmName("lhhuocvriqejvogd")
    public suspend fun targetRecoveryProtectionContainerId(`value`: Output) {
        this.targetRecoveryProtectionContainerId = value
    }

    /**
     * @param value Id of resource group where the VM should be created when a failover is done. Changing this forces a new resource to be created.
     */
    @JvmName("uoiluiavvyujwxhy")
    public suspend fun targetResourceGroupId(`value`: Output) {
        this.targetResourceGroupId = value
    }

    /**
     * @param value Id of the Virtual Machine Scale Set which the new Vm should belong to when a failover is done.
     */
    @JvmName("arvuestvrahulbhl")
    public suspend fun targetVirtualMachineScaleSetId(`value`: Output) {
        this.targetVirtualMachineScaleSetId = value
    }

    /**
     * @param value Specifies the Availability Zone where the Failover VM should exist. Changing this forces a new resource to be created.
     */
    @JvmName("bykwgfkntivhhxsy")
    public suspend fun targetZone(`value`: Output) {
        this.targetZone = value
    }

    /**
     * @param value Network to use when a test failover is done.
     */
    @JvmName("kdrqfdskfktvrgct")
    public suspend fun testNetworkId(`value`: Output) {
        this.testNetworkId = value
    }

    /**
     * @param value One or more `unmanaged_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("breoenqqusluwfot")
    public suspend fun unmanagedDisks(`value`: Output>) {
        this.unmanagedDisks = value
    }

    @JvmName("bpqcbpcepmdgsvam")
    public suspend fun unmanagedDisks(vararg values: Output) {
        this.unmanagedDisks = Output.all(values.asList())
    }

    /**
     * @param values One or more `unmanaged_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("mcwtcremnkkrtrql")
    public suspend fun unmanagedDisks(values: List>) {
        this.unmanagedDisks = Output.all(values)
    }

    /**
     * @param value One or more `managed_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("wkjpwllmpioeckdj")
    public suspend fun managedDisks(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.managedDisks = mapped
    }

    /**
     * @param argument One or more `managed_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("ynegnqcvrmsywdtn")
    public suspend
    fun managedDisks(argument: List Unit>) {
        val toBeMapped = argument.toList().map {
            ReplicatedVMManagedDiskArgsBuilder().applySuspend {
                it()
            }.build()
        }
        val mapped = of(toBeMapped)
        this.managedDisks = mapped
    }

    /**
     * @param argument One or more `managed_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("aensnnrqdsbxynkb")
    public suspend fun managedDisks(
        vararg
        argument: suspend ReplicatedVMManagedDiskArgsBuilder.() -> Unit,
    ) {
        val toBeMapped = argument.toList().map {
            ReplicatedVMManagedDiskArgsBuilder().applySuspend {
                it()
            }.build()
        }
        val mapped = of(toBeMapped)
        this.managedDisks = mapped
    }

    /**
     * @param argument One or more `managed_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("pyrihqdbhmdbnbya")
    public suspend fun managedDisks(argument: suspend ReplicatedVMManagedDiskArgsBuilder.() -> Unit) {
        val toBeMapped = listOf(
            ReplicatedVMManagedDiskArgsBuilder().applySuspend {
                argument()
            }.build(),
        )
        val mapped = of(toBeMapped)
        this.managedDisks = mapped
    }

    /**
     * @param values One or more `managed_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("lmswjvtaewtoalgw")
    public suspend fun managedDisks(vararg values: ReplicatedVMManagedDiskArgs) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.managedDisks = mapped
    }

    /**
     * @param value Name of group in which all machines will replicate together and have shared crash consistent and app-consistent recovery points when failed over.
     */
    @JvmName("ygclistqeqfubibn")
    public suspend fun multiVmGroupName(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.multiVmGroupName = mapped
    }

    /**
     * @param value The name of the replication for the replicated VM. Changing this forces a new resource to be created.
     */
    @JvmName("xkkaoigjxsncwrid")
    public suspend fun name(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.name = mapped
    }

    /**
     * @param value One or more `network_interface` block as defined below.
     */
    @JvmName("vepvukunopijxnam")
    public suspend fun networkInterfaces(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.networkInterfaces = mapped
    }

    /**
     * @param argument One or more `network_interface` block as defined below.
     */
    @JvmName("ghjefpwqioeqkhcs")
    public suspend
    fun networkInterfaces(argument: List Unit>) {
        val toBeMapped = argument.toList().map {
            ReplicatedVMNetworkInterfaceArgsBuilder().applySuspend {
                it()
            }.build()
        }
        val mapped = of(toBeMapped)
        this.networkInterfaces = mapped
    }

    /**
     * @param argument One or more `network_interface` block as defined below.
     */
    @JvmName("faogpvjavdehcuvw")
    public suspend fun networkInterfaces(
        vararg
        argument: suspend ReplicatedVMNetworkInterfaceArgsBuilder.() -> Unit,
    ) {
        val toBeMapped = argument.toList().map {
            ReplicatedVMNetworkInterfaceArgsBuilder().applySuspend {
                it()
            }.build()
        }
        val mapped = of(toBeMapped)
        this.networkInterfaces = mapped
    }

    /**
     * @param argument One or more `network_interface` block as defined below.
     */
    @JvmName("oossycclsgaiwtnp")
    public suspend
    fun networkInterfaces(argument: suspend ReplicatedVMNetworkInterfaceArgsBuilder.() -> Unit) {
        val toBeMapped = listOf(
            ReplicatedVMNetworkInterfaceArgsBuilder().applySuspend {
                argument()
            }.build(),
        )
        val mapped = of(toBeMapped)
        this.networkInterfaces = mapped
    }

    /**
     * @param values One or more `network_interface` block as defined below.
     */
    @JvmName("ndxlnbnarxcmgawo")
    public suspend fun networkInterfaces(vararg values: ReplicatedVMNetworkInterfaceArgs) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.networkInterfaces = mapped
    }

    /**
     * @param value Id of the policy to use for this replicated vm. Changing this forces a new resource to be created.
     */
    @JvmName("lxbafplnlfxyofls")
    public suspend fun recoveryReplicationPolicyId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.recoveryReplicationPolicyId = mapped
    }

    /**
     * @param value The name of the vault that should be updated. Changing this forces a new resource to be created.
     */
    @JvmName("kjtqjidujubuyrnj")
    public suspend fun recoveryVaultName(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.recoveryVaultName = mapped
    }

    /**
     * @param value Name of the resource group where the vault that should be updated is located. Changing this forces a new resource to be created.
     */
    @JvmName("shbfxwmcwvgiwxsq")
    public suspend fun resourceGroupName(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.resourceGroupName = mapped
    }

    /**
     * @param value Name of fabric that should contain this replication. Changing this forces a new resource to be created.
     */
    @JvmName("bchqojpkbhhndgrf")
    public suspend fun sourceRecoveryFabricName(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.sourceRecoveryFabricName = mapped
    }

    /**
     * @param value Name of the protection container to use. Changing this forces a new resource to be created.
     */
    @JvmName("pmcjcsdkvhfmjvjf")
    public suspend fun sourceRecoveryProtectionContainerName(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.sourceRecoveryProtectionContainerName = mapped
    }

    /**
     * @param value Id of the VM to replicate Changing this forces a new resource to be created.
     */
    @JvmName("emfcowxqhcrsnsbt")
    public suspend fun sourceVmId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.sourceVmId = mapped
    }

    /**
     * @param value Id of availability set that the new VM should belong to when a failover is done.
     */
    @JvmName("krvvhpngsthtxoex")
    public suspend fun targetAvailabilitySetId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetAvailabilitySetId = mapped
    }

    /**
     * @param value Id of the storage account which the new VM should used for boot diagnostic when a failover is done.
     */
    @JvmName("hasohkshoioipvdy")
    public suspend fun targetBootDiagnosticStorageAccountId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetBootDiagnosticStorageAccountId = mapped
    }

    /**
     * @param value Id of the Capacity reservation group where the new VM should belong to when a failover is done.
     */
    @JvmName("xgypxovievihctyc")
    public suspend fun targetCapacityReservationGroupId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetCapacityReservationGroupId = mapped
    }

    /**
     * @param value Specifies the Edge Zone within the Azure Region where this Managed Kubernetes Cluster should exist. Changing this forces a new resource to be created.
     */
    @JvmName("xhomudpvunjcofis")
    public suspend fun targetEdgeZone(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetEdgeZone = mapped
    }

    /**
     * @param value Network to use when a failover is done (recommended to set if any network_interface is configured for failover).
     */
    @JvmName("gmeulehsekcxxkpn")
    public suspend fun targetNetworkId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetNetworkId = mapped
    }

    /**
     * @param value Id of Proximity Placement Group the new VM should belong to when a failover is done.
     */
    @JvmName("dtxscjfktlujhpgt")
    public suspend fun targetProximityPlacementGroupId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetProximityPlacementGroupId = mapped
    }

    /**
     * @param value Id of fabric where the VM replication should be handled when a failover is done. Changing this forces a new resource to be created.
     */
    @JvmName("xrmyygnmrjdbdheh")
    public suspend fun targetRecoveryFabricId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetRecoveryFabricId = mapped
    }

    /**
     * @param value Id of protection container where the VM replication should be created when a failover is done. Changing this forces a new resource to be created.
     */
    @JvmName("qiwndgbdmtkgjmkj")
    public suspend fun targetRecoveryProtectionContainerId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetRecoveryProtectionContainerId = mapped
    }

    /**
     * @param value Id of resource group where the VM should be created when a failover is done. Changing this forces a new resource to be created.
     */
    @JvmName("babawlqayqincfxn")
    public suspend fun targetResourceGroupId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetResourceGroupId = mapped
    }

    /**
     * @param value Id of the Virtual Machine Scale Set which the new Vm should belong to when a failover is done.
     */
    @JvmName("kfrbxljqlokkesrp")
    public suspend fun targetVirtualMachineScaleSetId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetVirtualMachineScaleSetId = mapped
    }

    /**
     * @param value Specifies the Availability Zone where the Failover VM should exist. Changing this forces a new resource to be created.
     */
    @JvmName("ibyssndbcgfrnjqr")
    public suspend fun targetZone(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetZone = mapped
    }

    /**
     * @param value Network to use when a test failover is done.
     */
    @JvmName("ntwhsrilqmjfootu")
    public suspend fun testNetworkId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.testNetworkId = mapped
    }

    /**
     * @param value One or more `unmanaged_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("sfpqdnwoppqxxkoo")
    public suspend fun unmanagedDisks(`value`: List?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.unmanagedDisks = mapped
    }

    /**
     * @param argument One or more `unmanaged_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("jypansctyavakupo")
    public suspend
    fun unmanagedDisks(argument: List Unit>) {
        val toBeMapped = argument.toList().map {
            ReplicatedVMUnmanagedDiskArgsBuilder().applySuspend {
                it()
            }.build()
        }
        val mapped = of(toBeMapped)
        this.unmanagedDisks = mapped
    }

    /**
     * @param argument One or more `unmanaged_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("uexkurqyrvgwmdtd")
    public suspend fun unmanagedDisks(
        vararg
        argument: suspend ReplicatedVMUnmanagedDiskArgsBuilder.() -> Unit,
    ) {
        val toBeMapped = argument.toList().map {
            ReplicatedVMUnmanagedDiskArgsBuilder().applySuspend {
                it()
            }.build()
        }
        val mapped = of(toBeMapped)
        this.unmanagedDisks = mapped
    }

    /**
     * @param argument One or more `unmanaged_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("cdkpjpvgmxwakgxf")
    public suspend
    fun unmanagedDisks(argument: suspend ReplicatedVMUnmanagedDiskArgsBuilder.() -> Unit) {
        val toBeMapped = listOf(
            ReplicatedVMUnmanagedDiskArgsBuilder().applySuspend {
                argument()
            }.build(),
        )
        val mapped = of(toBeMapped)
        this.unmanagedDisks = mapped
    }

    /**
     * @param values One or more `unmanaged_disk` block as defined below. Changing this forces a new resource to be created.
     */
    @JvmName("jrkcogcweqwtedul")
    public suspend fun unmanagedDisks(vararg values: ReplicatedVMUnmanagedDiskArgs) {
        val toBeMapped = values.toList()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.unmanagedDisks = mapped
    }

    internal fun build(): ReplicatedVMArgs = ReplicatedVMArgs(
        managedDisks = managedDisks,
        multiVmGroupName = multiVmGroupName,
        name = name,
        networkInterfaces = networkInterfaces,
        recoveryReplicationPolicyId = recoveryReplicationPolicyId,
        recoveryVaultName = recoveryVaultName,
        resourceGroupName = resourceGroupName,
        sourceRecoveryFabricName = sourceRecoveryFabricName,
        sourceRecoveryProtectionContainerName = sourceRecoveryProtectionContainerName,
        sourceVmId = sourceVmId,
        targetAvailabilitySetId = targetAvailabilitySetId,
        targetBootDiagnosticStorageAccountId = targetBootDiagnosticStorageAccountId,
        targetCapacityReservationGroupId = targetCapacityReservationGroupId,
        targetEdgeZone = targetEdgeZone,
        targetNetworkId = targetNetworkId,
        targetProximityPlacementGroupId = targetProximityPlacementGroupId,
        targetRecoveryFabricId = targetRecoveryFabricId,
        targetRecoveryProtectionContainerId = targetRecoveryProtectionContainerId,
        targetResourceGroupId = targetResourceGroupId,
        targetVirtualMachineScaleSetId = targetVirtualMachineScaleSetId,
        targetZone = targetZone,
        testNetworkId = testNetworkId,
        unmanagedDisks = unmanagedDisks,
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy