-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathNetwork_Resources.tf
357 lines (322 loc) · 17.8 KB
/
Network_Resources.tf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
#-----------------------------------------------------------------
# Network Resources
#-----------------------------------------------------------------
resource "azurerm_resource_group" "Virtual_Network" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-rg-${var.Virtual_Network_Resource_Group_Name_suffix}"
location = var.region
}
#-----------------------------------------------------------------
# Azure Network Watcher (Only is deploying into a new blank subscription)
#-----------------------------------------------------------------
/*
When you create or update a virtual network in your subscription,
Network Watcher will be enabled automatically in your Virtual Network's region.
There is no impact to your resources or associated charge for automatically enabling Network Watcher.
https://docs.microsoft.com/en-us/azure/network-watcher/network-watcher-create
- deploying it here to control the configuration, forcing custom configuration, instead of automatic configuration
resource "azurerm_network_watcher" "connectivity" {
name = "${var.environment_code}-${var.region_code}-anw-${var.network_watcher_suffix}"
location = var.region
resource_group_name = azurerm_resource_group.Virtual_Network.name
}
*/
#-----------------------------------------------------------------
# Spoke Virtual Network 01
#-----------------------------------------------------------------
resource "azurerm_virtual_network" "Prod_Virtual_Network_01" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vnt-${var.spoke_prod_virtual_network_01.vnet_suffix}"
location = var.region
resource_group_name = azurerm_resource_group.Virtual_Network.name
address_space = var.spoke_prod_virtual_network_01.address_space
tags = var.tags
dns_servers = var.spoke_prod_virtual_network_01.dns_servers
}
#-----------------------------------------------------------------
# Spoke Subnets 01
#-----------------------------------------------------------------
resource "azurerm_subnet" "Prod_Virtual_Network_Subnets_01" {
for_each = var.spoke_subnets_01
provider = azurerm.connectivity
name = (each.value.name_suffix != "AzureFirewallSubnet") && (each.value.name_suffix != "AzureBastionSubnet") ? "${local.subnetprefix}-${each.value.name_suffix}" : each.value.name_suffix
address_prefixes = each.value.address_prefixes
resource_group_name = azurerm_resource_group.Virtual_Network.name
virtual_network_name = azurerm_virtual_network.Prod_Virtual_Network_01.name
service_endpoints = each.value.service_endpoints
enforce_private_link_endpoint_network_policies = true
#enforce_private_link_service_network_policies = true
depends_on = [
azurerm_resource_group.Virtual_Network
]
}
#-----------------------------------------------------------------
# Spoke Virtual Network 02
#-----------------------------------------------------------------
resource "azurerm_virtual_network" "NonProd_Virtual_Network_01" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vnt-${var.spoke_nonprod_virtual_network_01.vnet_suffix}"
location = var.region
resource_group_name = azurerm_resource_group.Virtual_Network.name
address_space = var.spoke_nonprod_virtual_network_01.address_space
tags = var.tags
dns_servers = var.spoke_nonprod_virtual_network_01.dns_servers
}
#-----------------------------------------------------------------
# Spoke Subnets 02
#-----------------------------------------------------------------
resource "azurerm_subnet" "NonProd_Virtual_Network_Subnets_01" {
for_each = var.spoke_subnets_02
provider = azurerm.connectivity
name = (each.value.name_suffix != "AzureFirewallSubnet") && (each.value.name_suffix != "AzureBastionSubnet") ? "${local.subnetprefix}-${each.value.name_suffix}" : each.value.name_suffix
address_prefixes = each.value.address_prefixes
resource_group_name = azurerm_resource_group.Virtual_Network.name
virtual_network_name = azurerm_virtual_network.NonProd_Virtual_Network_01.name
service_endpoints = each.value.service_endpoints
enforce_private_link_endpoint_network_policies = true
#enforce_private_link_service_network_policies = true
depends_on = [
azurerm_resource_group.Virtual_Network
]
}
#-----------------------------------------------------------------
# Spoke Virtual Network 03
#-----------------------------------------------------------------
resource "azurerm_virtual_network" "SS_Virtual_Network_01" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vnt-${var.spoke_ss_virtual_network_01.vnet_suffix}"
location = var.region
resource_group_name = azurerm_resource_group.Virtual_Network.name
address_space = var.spoke_ss_virtual_network_01.address_space
tags = var.tags
dns_servers = var.spoke_ss_virtual_network_01.dns_servers
}
#-----------------------------------------------------------------
# Spoke Subnets 03
#-----------------------------------------------------------------
resource "azurerm_subnet" "SS_Virtual_Network_Subnets_01" {
for_each = var.spoke_subnets_03
provider = azurerm.connectivity
name = (each.value.name_suffix != "AzureFirewallSubnet") && (each.value.name_suffix != "AzureBastionSubnet") ? "${local.subnetprefix}-${each.value.name_suffix}" : each.value.name_suffix
address_prefixes = each.value.address_prefixes
resource_group_name = azurerm_resource_group.Virtual_Network.name
virtual_network_name = azurerm_virtual_network.SS_Virtual_Network_01.name
service_endpoints = each.value.service_endpoints
enforce_private_link_endpoint_network_policies = true
#enforce_private_link_service_network_policies = true
depends_on = [
azurerm_resource_group.Virtual_Network
]
}
#-----------------------------------------------------------------
# IP Group to represent vNet address spaces, to use with the Azure Firewall Policies
#-----------------------------------------------------------------
resource "azurerm_ip_group" "virtual_wan_hubs" {
for_each = var.virtual_wan
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwan-ipg-${each.value.name_suffix}"
location = var.region
resource_group_name = azurerm_resource_group.Virtual_Network.name
cidrs = [each.value.address_prefix]
}
resource "azurerm_ip_group" "spoke_prod_virtual_network_01_subnets" {
for_each = var.spoke_subnets_01
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-sub-ipg-${each.value.name_suffix}"
location = var.region
resource_group_name = azurerm_resource_group.Virtual_Network.name
cidrs = [each.value.address_prefixes[0]]
}
resource "azurerm_ip_group" "spoke_prod_virtual_network_01" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vnet-ipg-${var.spoke_prod_virtual_network_01.vnet_suffix}"
location = var.region
resource_group_name = azurerm_resource_group.Virtual_Network.name
cidrs = var.spoke_prod_virtual_network_01.address_space
}
#-----------------------------------------------------------------
# Azure Virtual WAN
#-----------------------------------------------------------------
resource "azurerm_virtual_wan" "vwan" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwan-${var.azurerm_virtual_wan_name_suffix}"
resource_group_name = azurerm_resource_group.Virtual_Network.name
location = var.region
}
#-----------------------------------------------------------------
# Azure Virtual WAN Hub/s
#-----------------------------------------------------------------
resource "azurerm_virtual_hub" "vwan_hubs" {
for_each = var.virtual_wan
provider = azurerm.connectivity
name = "${var.environment_code}-${each.value.region_code}-vwanhub-${each.value.environment}-${each.value.name_suffix}"
resource_group_name = azurerm_resource_group.Virtual_Network.name
location = each.value.region
virtual_wan_id = azurerm_virtual_wan.vwan.id
address_prefix = each.value.address_prefix
}
#-----------------------------------------------------------------
# Azure Virtual WAN connections
#-----------------------------------------------------------------
# From Production vNet 01 - to Prod Hub
resource "azurerm_virtual_hub_connection" "prod_spoke_Virtual_Network_01" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwanconn-${var.spoke_prod_virtual_network_01.vnet_suffix}"
virtual_hub_id = azurerm_virtual_hub.vwan_hubs["prod"].id
remote_virtual_network_id = azurerm_virtual_network.Prod_Virtual_Network_01.id
routing {
associated_route_table_id = azurerm_virtual_hub_route_table.prod_vWAN_Route_Table.id # (Optional) The ID of the route table associated with this Virtual Hub connection.
propagated_route_table {
labels = ["Shared", "Default"] # (Optional) The list of labels to assign to this route table.
route_table_ids = [azurerm_virtual_hub_route_table.prod_vWAN_Route_Table.id] # (Optional) A list of Route Table ID's to associated with this Virtual Hub Connection.
}
/*
static_vnet_route {
name = "" # (Optional) The name which should be used for this Static Route
address_prefixes = [] # (Optional) A list of CIDR Ranges which should be used as Address
next_hop_ip_address = [] # (Optional) The IP Address which should be used for the Next Hop
}
*/
}
depends_on = [
azurerm_virtual_hub_route_table.prod_vWAN_Route_Table
]
}
# From Non-Production vNet 01 - to Non-Prod Hub
resource "azurerm_virtual_hub_connection" "nonprod_spoke_Virtual_Network_01" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwanconn-${var.spoke_nonprod_virtual_network_01.vnet_suffix}"
virtual_hub_id = azurerm_virtual_hub.vwan_hubs["non_prod"].id
remote_virtual_network_id = azurerm_virtual_network.NonProd_Virtual_Network_01.id
routing {
associated_route_table_id = azurerm_virtual_hub_route_table.nonprod_vWAN_Route_Table.id # (Optional) The ID of the route table associated with this Virtual Hub connection.
propagated_route_table {
labels = ["Shared", "Default"] # (Optional) The list of labels to assign to this route table.
route_table_ids = [azurerm_virtual_hub_route_table.nonprod_vWAN_Route_Table.id] # (Optional) A list of Route Table ID's to associated with this Virtual Hub Connection.
}
/*
static_vnet_route {
name = "" # (Optional) The name which should be used for this Static Route
address_prefixes = [] # (Optional) A list of CIDR Ranges which should be used as Address
next_hop_ip_address = [] # (Optional) The IP Address which should be used for the Next Hop
}
*/
}
depends_on = [
azurerm_virtual_hub_route_table.nonprod_vWAN_Route_Table
]
}
# From Shared Services vNet 01 - to Shared Services Hub
resource "azurerm_virtual_hub_connection" "ss_spoke_Virtual_Network_01" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwanconn-${var.spoke_ss_virtual_network_01.vnet_suffix}"
virtual_hub_id = azurerm_virtual_hub.vwan_hubs["ss"].id
remote_virtual_network_id = azurerm_virtual_network.SS_Virtual_Network_01.id
routing {
associated_route_table_id = azurerm_virtual_hub_route_table.ss_vWAN_Route_Table.id # (Optional) The ID of the route table associated with this Virtual Hub connection.
propagated_route_table {
labels = ["Default", "Prod", "Non-Prod"] # (Optional) The list of labels to assign to this route table.
route_table_ids = [azurerm_virtual_hub_route_table.ss_vWAN_Route_Table.id] # (Optional) A list of Route Table ID's to associated with this Virtual Hub Connection.
}
/*
static_vnet_route {
name = "" # (Optional) The name which should be used for this Static Route
address_prefixes = [] # (Optional) A list of CIDR Ranges which should be used as Address
next_hop_ip_address = [] # (Optional) The IP Address which should be used for the Next Hop
}
*/
}
depends_on = [
azurerm_virtual_hub_route_table.ss_vWAN_Route_Table
]
}
#-----------------------------------------------------------------
# Azure Virtual WAN Route Table
#-----------------------------------------------------------------
# Prod Hub
resource "azurerm_virtual_hub_route_table" "prod_vWAN_Route_Table" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwanrt-${var.virtual_wan["prod"].environment}"
virtual_hub_id = azurerm_virtual_hub.vwan_hubs["prod"].id
labels = ["Prod"]
/*
route {
name = "Shared_Services_01"
destinations_type = "CIDR" # (Required) The type of destinations. Possible values are CIDR, ResourceId and Service
destinations = var.spoke_ss_virtual_network_01.address_space # (Required) A list of destination addresses for this route.
next_hop_type = "ResourceId" # (Optional) The type of next hop. Currently the only possible value is ResourceId. Defaults to ResourceId
next_hop = azurerm_virtual_hub_connection.ss_spoke_Virtual_Network_01.id # (Required) The next hop's resource ID
}
*/
}
# Non-Prod Hub
resource "azurerm_virtual_hub_route_table" "nonprod_vWAN_Route_Table" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwanrt-${var.virtual_wan["non_prod"].environment}"
virtual_hub_id = azurerm_virtual_hub.vwan_hubs["non_prod"].id
labels = ["Non-Prod"]
/*
route {
name = "Shared_Services_01"
destinations_type = "CIDR"
destinations = var.spoke_ss_virtual_network_01.address_space
next_hop_type = "ResourceId"
next_hop = azurerm_virtual_hub_connection.ss_spoke_Virtual_Network_01.id
}
*/
}
# Shared Services Hub
resource "azurerm_virtual_hub_route_table" "ss_vWAN_Route_Table" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwanrt-${var.virtual_wan["ss"].environment}"
virtual_hub_id = azurerm_virtual_hub.vwan_hubs["ss"].id
labels = ["Shared"]
/*
route {
name = "SS_01"
destinations_type = "CIDR"
destinations = var.spoke_ss_virtual_network_01.address_space
next_hop_type = "ResourceId"
next_hop = azurerm_virtual_hub_connection.ss_spoke_Virtual_Network_01.id
}
*/
}
#-----------------------------------------------------------------
# Azure Virtual WAN VPN Gateway
#-----------------------------------------------------------------
# Production ER Gateway
resource "azurerm_express_route_gateway" "prod_vWAN_ER_Gateway" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwanergw-${var.virtual_wan["prod"].environment}"
location = var.region
resource_group_name = azurerm_resource_group.Virtual_Network.name
virtual_hub_id = azurerm_virtual_hub.vwan_hubs["prod"].id
scale_units = 1 # (Required) The number of scale units with which to provision the ExpressRoute gateway. Each scale unit is equal to 2Gbps, with support for up to 10 scale units (20Gbps)
depends_on = [
azurerm_virtual_hub.vwan_hubs
]
}
# Non Production ER Gateway
resource "azurerm_express_route_gateway" "nonprod_vWAN_ER_Gateway" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwanergw-${var.virtual_wan["non_prod"].environment}"
location = var.region
resource_group_name = azurerm_resource_group.Virtual_Network.name
virtual_hub_id = azurerm_virtual_hub.vwan_hubs["non_prod"].id
scale_units = 1 # (Required) The number of scale units with which to provision the ExpressRoute gateway. Each scale unit is equal to 2Gbps, with support for up to 10 scale units (20Gbps)
depends_on = [
azurerm_virtual_hub.vwan_hubs
]
}
# Shared Services ER Gateway
resource "azurerm_express_route_gateway" "ss_vWAN_ER_Gateway" {
provider = azurerm.connectivity
name = "${var.environment_code}-${var.region_code}-vwanergw-${var.virtual_wan["ss"].environment}"
location = var.region
resource_group_name = azurerm_resource_group.Virtual_Network.name
virtual_hub_id = azurerm_virtual_hub.vwan_hubs["ss"].id
scale_units = 1 # (Required) The number of scale units with which to provision the ExpressRoute gateway. Each scale unit is equal to 2Gbps, with support for up to 10 scale units (20Gbps)
depends_on = [
azurerm_virtual_hub.vwan_hubs
]
}