com.pulumi.azure.siterecovery.kotlin.ReplicatedVMArgs.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-azure-kotlin Show documentation
Show all versions of pulumi-azure-kotlin Show documentation
Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.
@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
© 2015 - 2025 Weber Informatics LLC | Privacy Policy