-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathequinix_ne.tf
64 lines (54 loc) · 2.08 KB
/
equinix_ne.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
/*
* Terraform Network Edge resources for Equinix.
*/
data "equinix_network_device_type" "router" {
name = "CSR 1000V"
}
resource "equinix_network_device" "router" {
count = var.eqx_ne_create_ne_device ? 1 : 0
name = var.eqx_ne_device_name
type_code = data.equinix_network_device_type.router.code
hostname = var.eqx_ne_device_hostname
byol = false
metro_code = var.eqx_ne_device_metro_code
notifications = var.eqx_fabric_notification_users
package_code = var.eqx_ne_device_package_code
term_length = var.eqx_ne_device_term_length
throughput = var.eqx_ne_device_throughput
throughput_unit = var.eqx_ne_device_throughput_unit
account_number = var.eqx_ne_account_number
interface_count = var.eqx_ne_device_interface_count
core_count = var.eqx_ne_device_core_count
version = var.eqx_ne_device_version
acl_template_id = equinix_network_acl_template.acl.id
self_managed = false
}
resource "equinix_network_ssh_user" "router" {
count = var.eqx_ne_create_ne_device ? 1 : 0
username = var.eqx_ne_ssh_user
password = var.eqx_ne_ssh_pwd
device_ids = [ local.router_id ]
}
locals {
router_id = var.eqx_ne_create_ne_device ? equinix_network_device.router[0].id : var.eqx_ne_device_id
}
data "external" "myipaddr" {
program = ["bash", "-c", "curl -s 'https://ipinfo.io/json'"]
}
resource "equinix_network_acl_template" "acl" {
name = var.eqx_ne_acl_template_name
description = "Configure device automatically"
inbound_rule {
subnets = ["${data.external.myipaddr.result.ip}/32"]
protocol = "TCP"
src_port = "any"
dst_port = "22"
}
}
resource "equinix_network_bgp" "gcp" {
connection_id = equinix_ecx_l2_connection.gcp.id
local_ip_address = local.gcp_bgp_equinix_side_address
local_asn = var.gcp_bgp_equinix_side_asn
remote_ip_address = cidrhost(local.gcp_bgp_cloud_address,1)
remote_asn = 16550 // The Cloud Router used by PARTNER type interconnect attachments must be assigned a local ASN of '16550'
}