dependency/azapi_examples/Microsoft.Network_virtualNetworkGateways_natRules@2022-07-01/main.tf (154 lines of code) (raw):

terraform { required_providers { azapi = { source = "Azure/azapi" } } } provider "azapi" { skip_provider_registration = false } variable "resource_name" { type = string default = "acctest0001" } variable "location" { type = string default = "westeurope" } resource "azapi_resource" "resourceGroup" { type = "Microsoft.Resources/resourceGroups@2020-06-01" name = var.resource_name location = var.location } resource "azapi_resource" "virtualNetwork" { type = "Microsoft.Network/virtualNetworks@2022-07-01" parent_id = azapi_resource.resourceGroup.id name = var.resource_name location = var.location body = { properties = { addressSpace = { addressPrefixes = [ "10.0.0.0/16", ] } dhcpOptions = { dnsServers = [ ] } subnets = [ ] } } schema_validation_enabled = false response_export_values = ["*"] lifecycle { ignore_changes = [body.properties.subnets] } } resource "azapi_resource" "publicIPAddress" { type = "Microsoft.Network/publicIPAddresses@2022-07-01" parent_id = azapi_resource.resourceGroup.id name = var.resource_name location = var.location body = { properties = { ddosSettings = { protectionMode = "VirtualNetworkInherited" } idleTimeoutInMinutes = 4 publicIPAddressVersion = "IPv4" publicIPAllocationMethod = "Dynamic" } sku = { name = "Basic" tier = "Regional" } } schema_validation_enabled = false response_export_values = ["*"] } resource "azapi_resource" "subnet" { type = "Microsoft.Network/virtualNetworks/subnets@2022-07-01" parent_id = azapi_resource.virtualNetwork.id name = "GatewaySubnet" body = { properties = { addressPrefix = "10.0.1.0/24" delegations = [ ] privateEndpointNetworkPolicies = "Enabled" privateLinkServiceNetworkPolicies = "Enabled" serviceEndpointPolicies = [ ] serviceEndpoints = [ ] } } schema_validation_enabled = false response_export_values = ["*"] } resource "azapi_resource" "virtualNetworkGateway" { type = "Microsoft.Network/virtualNetworkGateways@2022-07-01" parent_id = azapi_resource.resourceGroup.id name = var.resource_name location = var.location body = { properties = { activeActive = false enableBgp = false enablePrivateIpAddress = false gatewayType = "Vpn" ipConfigurations = [ { name = "vnetGatewayConfig" properties = { privateIPAllocationMethod = "Dynamic" publicIPAddress = { id = azapi_resource.publicIPAddress.id } subnet = { id = azapi_resource.subnet.id } } }, ] sku = { name = "Basic" tier = "Basic" } vpnType = "RouteBased" } } schema_validation_enabled = false response_export_values = ["*"] timeouts { create = "180m" update = "180m" delete = "60m" } } resource "azapi_resource" "natRule" { type = "Microsoft.Network/virtualNetworkGateways/natRules@2022-07-01" parent_id = azapi_resource.virtualNetworkGateway.id name = var.resource_name body = { properties = { externalMappings = [ { addressSpace = "10.1.0.0/26" }, ] internalMappings = [ { addressSpace = "10.3.0.0/26" }, ] mode = "EgressSnat" type = "Static" } } schema_validation_enabled = false response_export_values = ["*"] }