Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Adding MultiCloud(FCR 2 AWS and Azure) Connection Example #409

Merged
merged 3 commits into from
Oct 16, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,109 @@
# ECX Fabric Layer2 MultiCloud Connection: FCR 2 AWS and Azure
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Excellent PR, Srushti! Just had a couple of Nit comments on this. Be sure to add the variables.tf with this PR and then it will be ready to go.


This example shows how to create Layer 2 Connection between FCR to AWS and Azure.

## Adjust variables

At minimum, you must set below variables in `terraform.tfvars` file:

* `equinix_client_id` - Equinix client ID (consumer key), obtained after
registering app in the developer platform
* `equinix_client_secret` - Equinix client secret ID (consumer secret),
obtained same way as above

`fcr_name` - Name of ECX Fabric Cloud Router on a-side , i.e. amcrh007-fcr
`fcr_type` - Fabric Cloud Router type
`fcr_location` - Fabric Cloud Router location
`fcr_project` - Fabric Cloud Router project
`fcr_account` - Fabric Cloud Router account
`fcr_package` - Fabric Cloud Router package type, i.e. PRO
`notifications_type` - notification type
`notifications_emails` - List of emails


`azure_connection_name` - The name of the Azure connection
`azure_connection_type` - Connection type, please refer to OAS schema for enum values.
`azure_notifications_type` - Notification type
`azure_notifications_emails` - List of emails
`azure_bandwidth` - Bandwidth in MBs
`azure_redundancy` - Port redundancy PRIMARY or SECONDARY
`azure_purchase_order_number` - Purchase order number applied to billing invoices for this connection.
`azure_peering_type` - Peering Type
`azure_aside_ap_type` - Access point type

`azure_zside_ap_type` - Z side access point type
`azure_zside_ap_authentication_key` - AZURE authorization key, like c620477c-3f30-41e8-a0b9-cf324a12121d
`azure_zside_ap_profile_type` - Service profile type
`azure_zside_location` - Equinix Metro Code for the Z side access point
`azure_fabric_sp_name` - Service profile name like i.e. AZURE

`azure_rp_name`- Name of Direct routing Protocol
`azure_rp_type`- Type of Direct routing Protocol entity, "DIRECT" or "BGP"
`azure_equinix_ipv4_ip` = Equinix Side IpV4 Address
`azure_equinix_ipv6_ip` = Equinix Side IpV6 Address

`azure_bgp_rp_name` - Name of BGP routing Protocol
`azure_bgp_rp_type` - Type of BGP routing Protocol entity, "BGP"
`azure_bgp_customer_peer_ipv4` - Customer Side IpV4 Address
`azure_bgp_customer_peer_ipv6` - Customer Side IpV6 Address
`azure_bgp_enabled_ipv4` - Enable BGP IpV4 session from customer side
`azure_bgp_enabled_ipv6` - Enable BGP IpV6 session from customer side
`azure_bgp_customer_asn` - Customer ASN Number

`aws_connection_name` - The name of the AWS connection
`aws_connection_type` - connection type, please refer schema
`aws_notifications_type` - notification type
`aws_notifications_emails` - List of emails
`aws_bandwidth` - bandwidth in MBs
`aws_redundancy` - Port redundancy
`aws_aside_ap_type` - Fabric Cloud Router type
`aws_zside_ap_type` - Z side access point type
`aws_zside_ap_authentication_key` - AWS authorization key, account number like 357848912121
`aws_access_key` - AWS access key, like BQR12AHQKSYUTPBGHPIJ
`aws_secret_key` - AWS secret key, like 2qwrbYTUUIQWOOEIHDJSKbhikjhalpe
`aws_zside_ap_profile_type` - Service profile type
`aws_fabric_sp_name` - Service profile name, fetched based on Service Profile get call using Service Profile search schema
`aws_zside_location` - Seller location
`aws_seller_region` - Seller region code

`aws_rp_name`- Name of Direct routing Protocol
`aws_rp_type`- Type of Direct routing Protocol entity, "DIRECT" or "BGP"
`aws_equinix_ipv4_ip` = Equinix Side IpV4 Address
`aws_equinix_ipv6_ip` = Equinix Side IpV6 Address

`aws_bgp_rp_name` - Name of BGP routing Protocol
`aws_bgp_rp_type` - Type of BGP routing Protocol entity, "BGP"
`aws_bgp_customer_peer_ipv4` - Customer Side IpV4 Address
`aws_bgp_customer_peer_ipv6` - Customer Side IpV6 Address
`aws_bgp_enabled_ipv4` - Enable BGP IpV4 session from customer side
`aws_bgp_enabled_ipv6` - Enable BGP IpV6 session from customer side
`aws_bgp_customer_asn` - Customer ASN Number

## Azure login

Log in to Azure portal with an account that has permission to create necessary resources.

Create an Azure ExpressRoute Circuit and use its Service Key as the Authentication Key in the examples.

Bandwidth in Terraform must match the bandwidth of the ExpressRoute Circuit created in Azure.

## AWS login

Log in to AWS portal use account that has permission to create necessary resources.

## Initialize
- First step is to initialize the terraform directory/resource we are going to work on.
In the given example, the folder to perform CRUD operations for multi cloud connections can be found at examples/fabric/v4/cloudRouterConnectivity/MutliCloudConnection

- Change directory into - `CD examples/fabric/v4/cloudRouterConnectivity/MutliCloudConnection`
- Initialize Terraform plugins - `terraform init`

## Multi Cloud connection : Create, Read, Update and Delete(CRUD) operations
Note: `–auto-approve` command does not prompt the user for validating the applying config. Remove it to get a prompt to confirm the operation.

| Operation | Command | Description |
|:----------|:---------------------------------:|--------------------------------------------------------------------------:|
| CREATE | `terraform apply –auto-approve` | Creates multi-cloud connection resources |
| READ | `terraform show` | Reads/Shows the current state of the multi-cloud connection resources |
| UPDATE | `terraform apply -refresh` | Updates the connections with values provided in the terraform.tfvars file |
| DELETE | `terraform destroy –auto-approve` | Deletes the created multi-cloud connection resources |
Original file line number Diff line number Diff line change
@@ -0,0 +1,218 @@
provider "equinix" {
client_id = var.equinix_client_id
client_secret = var.equinix_client_secret
}

resource "equinix_fabric_cloud_router" "test"{
name = var.fcr_name
type = var.fcr_type
notifications{
type =var.notifications_type
emails =var.notifications_emails
}
order {
purchase_order_number = var.purchase_order_number
}
location {
metro_code = var.fcr_location
}
package {
code = var.fcr_package
}
project {
project_id = var.fcr_project
}
account {
account_number = var.fcr_account
}
}

output "fcr_result" {
value = equinix_fabric_cloud_router.test.id
}

data "equinix_fabric_service_profiles" "azure"{
filter{
property = "/name"
operator = "="
values = [var.azure_fabric_sp_name]
}
}

resource "equinix_fabric_connection" "fcr2azure"{
name = var.azure_connection_name
type = var.azure_connection_type

notifications {
type = var.azure_notifications_type
emails = var.azure_notifications_emails
}
bandwidth = var.azure_bandwidth
redundancy {
priority = var.azure_redundancy
}
order {
purchase_order_number = var.azure_purchase_order_number
}
a_side {
access_point {
type = var.azure_aside_ap_type
router {
uuid = equinix_fabric_cloud_router.test.id
}
}
}

z_side {
access_point {
type = var.azure_zside_ap_type
authentication_key = var.azure_zside_ap_authentication_key
peering_type = var.azure_peering_type
profile {
type = var.azure_zside_ap_profile_type
uuid = data.equinix_fabric_service_profiles.azure.id
}
location {
metro_code = var.azure_zside_location
}
}
}
}
output "azure_connection_azure" {
value = var.azure_connection_name
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit: This should be grabbed from the created resource and not just directly from the input variable. It will be the same name but better to have it derived from the correct place.

}
output "azure_connection_id" {
value = equinix_fabric_connection.fcr2azure.id
}

resource "equinix_fabric_routing_protocol" "azure-direct-protocol"{
connection_uuid = equinix_fabric_connection.fcr2azure.id
type = var.azure_rp_type
name = var.azure_rp_name
direct_ipv4 {
equinix_iface_ip = var.azure_equinix_ipv4_ip
}
direct_ipv6{
equinix_iface_ip = var.azure_equinix_ipv6_ip
}
}

output "azure_rp_direct_id" {
value = equinix_fabric_routing_protocol.azure-direct-protocol.id
}

resource "equinix_fabric_routing_protocol" "azure-bgp-protocol" {
connection_uuid = equinix_fabric_connection.fcr2azure.id
type = var.azure_bgp_rp_type
name = var.azure_bgp_rp_name
bgp_ipv4 {
customer_peer_ip = var.azure_bgp_customer_peer_ipv4
enabled = var.azure_bgp_enabled_ipv4
}
bgp_ipv6 {
customer_peer_ip = var.azure_bgp_customer_peer_ipv6
enabled = var.azure_bgp_enabled_ipv6
}
customer_asn = var.azure_bgp_customer_asn
depends_on = [equinix_fabric_routing_protocol.azure-direct-protocol]
}

output "azure_rp_bgp_id" {
value = equinix_fabric_routing_protocol.azure-bgp-protocol.id
}


data "equinix_fabric_service_profiles" "aws" {
filter {
property = "/name"
operator = "="
values = [var.aws_fabric_sp_name]
}
}

resource "equinix_fabric_connection" "fcr2aws"{
name = var.aws_connection_name
type = var.aws_connection_type
notifications{
type = var.aws_notifications_type
emails = var.aws_notifications_emails
}
additional_info = [{"key"= "accessKey", "value"= var.aws_access_key }, {"key"= "secretKey", "value"= var.aws_secret_key }]
bandwidth = var.aws_bandwidth
redundancy {priority = var.aws_redundancy}
order {
purchase_order_number = var.aws_purchase_order_number
}
a_side {
access_point {
type = var.aws_aside_ap_type
router {
uuid = equinix_fabric_cloud_router.test.id
}
}
}
z_side {
access_point {
type = var.aws_zside_ap_type
authentication_key = var.aws_zside_ap_authentication_key
seller_region = var.aws_seller_region
profile {
type = var.aws_zside_ap_profile_type
uuid = data.equinix_fabric_service_profiles.aws.id
}
location {
metro_code = var.aws_zside_location
}
}
}
}

output "aws_connection_name" {
value = var.aws_connection_name
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same as comment about azure connection.

}

output "aws_connection_id" {
value = equinix_fabric_connection.fcr2aws.id
}

resource "equinix_fabric_routing_protocol" "aws-direct-protocol"{
connection_uuid = equinix_fabric_connection.fcr2aws.id
type = var.aws_rp_type
name = var.aws_rp_name
direct_ipv4 {
equinix_iface_ip = var.aws_equinix_ipv4_ip
}
direct_ipv6{
equinix_iface_ip = var.aws_equinix_ipv6_ip
}
}

output "aws_rp_direct_id" {
value = equinix_fabric_routing_protocol.aws-direct-protocol.id
}

resource "equinix_fabric_routing_protocol" "aws-bgp-protocol" {
connection_uuid = equinix_fabric_connection.fcr2aws.id
type = var.aws_bgp_rp_type
name = var.aws_bgp_rp_name
bgp_ipv4 {
customer_peer_ip = var.aws_bgp_customer_peer_ipv4
enabled = var.aws_bgp_enabled_ipv4
}
bgp_ipv6 {
customer_peer_ip = var.aws_bgp_customer_peer_ipv6
enabled = var.aws_bgp_enabled_ipv6
}
customer_asn = var.aws_bgp_customer_asn

depends_on = [equinix_fabric_routing_protocol.aws-direct-protocol]
}

output "aws_rp_bgp_id" {
value = equinix_fabric_routing_protocol.aws-bgp-protocol.id
}





Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
terraform {
required_providers {
equinix = {
source = "equinix/equinix"
}
}
}
Loading
Loading