3-networks-hub-and-spoke/vpc_config_tef_scheme.yaml (395 lines of code) (raw):
regions:
region1:
name: "northamerica-northeast1"
region2:
name: "northamerica-northeast2"
enabled: false
spokes:
spoke_common_routes:
# the complete route name is similar to rt-${vpc_name}-${name_suffix}
# the VPC name is vpc-${env_code}-${env_type} e.g. vpc-d-shared-base
- id: rt_nat_to_internet
name_suffix: "1000-egress-internet-default"
description: "Tag based route through IGW to access internet"
destination_range: 0.0.0.0/0
tags: egress-internet
next_hop_internet: true
priority: 1000
- id: rt_windows_activation
name_suffix: "1000-all-default-windows-kms"
description: "Route through IGW to allow Windows KMS activation for GCP."
destination_range: 35.190.247.13/32
next_hop_internet: true
priority: 1000
all_env_ip_range: 10.0.0.0/8
development:
env_code: "d"
env_enabled: true
nat_igw_enabled: true
windows_activation_enabled: true
enable_hub_and_spoke_transitivity: false
router_ha_enabled: false
mode: spoke
base:
env_type: "shared-base"
enabled: true
private_service_cidr: 10.16.8.0/21
private_service_connect_ip: 10.17.0.2
subnets:
- id: primary
description: "Primary subnet"
ip_ranges:
region1: 10.0.64.0/18
region2: 10.1.64.0/18
subnet_suffix: ""
flow_logs:
enable: false
interval: 1
private_access : true
service_projects:
- id: proj_base_dev_s1
mode: service
- id: proj_base_dev_s2
mode: service
secondary_ranges:
- range_suffix: "gke-pod"
ip_cidr_range:
region1: 100.64.64.0/18
- range_suffix: "gke-svc"
ip_cidr_range:
region1: 100.65.64.0/18
- id: proxy
ip_ranges:
region1: 10.18.2.0/23
region2: 10.19.2.0/23
subnet_suffix: "-proxy"
flow_logs:
enable: false
interval: 1
private_access : false
role: ACTIVE
purpose: "REGIONAL_MANAGED_PROXY"
restricted:
env_type: "shared-restricted"
enabled: true
private_service_cidr: 10.16.40.0/21
private_service_connect_ip: 10.17.0.6
subnets:
- id: primary
ip_ranges:
region1: 10.8.64.0/18
region2: 10.9.64.0/18
subnet_suffix: ""
flow_logs:
enable: false
interval: 1
private_access : true
secondary_ranges:
- range_suffix: "gke-pod"
ip_cidr_range:
region1: 100.72.64.0/18
- range_suffix: "gke-svc"
ip_cidr_range:
region1: 100.73.64.0/18
service_projects:
- id: proj_restr_dev_s1
mode: service
- id: proj_restr_dev_s2
mode: service
- id: proxy
ip_ranges:
region1: 10.26.2.0/23
region2: 10.27.2.0/23
subnet_suffix: "-proxy"
flow_logs:
enable: false
interval: 1
private_access : false
role: ACTIVE
purpose: "REGIONAL_MANAGED_PROXY"
nonproduction:
env_code: "n"
env_enabled: true
nat_igw_enabled: true
windows_activation_enabled: true
enable_hub_and_spoke_transitivity: false
router_ha_enabled: false
mode: spoke
base:
env_type: "shared-base"
enabled: true
private_service_cidr: 10.16.16.0/21
private_service_connect_ip: 10.17.0.3
subnets:
- id: primary
ip_ranges:
region1: 10.0.128.0/18
region2: 10.1.128.0/18
subnet_suffix: ""
flow_logs:
enable: false
interval: 1
private_access : true
secondary_ranges:
- range_suffix: "gke-pod"
ip_cidr_range:
region1: 100.64.128.0/18
- range_suffix: "gke-svc"
ip_cidr_range:
region1: 100.65.128.0/18
service_projects:
- id: proj_base_np_s1
mode: service
- id: proj_base_np_s2
mode: service
- id: proxy
ip_ranges:
region1: 10.18.4.0/23
region2: 10.19.4.0/23
subnet_suffix: "-proxy"
flow_logs:
enable: false
interval: 1
private_access : false
role: ACTIVE
purpose: "REGIONAL_MANAGED_PROXY"
restricted:
env_type: "shared-restricted"
enabled: true
private_service_cidr: 10.16.48.0/21
private_service_connect_ip: 10.17.0.7
subnets:
- id: primary
ip_ranges:
region1: 10.8.128.0/18
region2: 10.9.128.0/18
subnet_suffix: ""
flow_logs:
enable: false
interval: 1
private_access : true
secondary_ranges:
- range_suffix: "gke-pod"
ip_cidr_range:
region1: 100.72.128.0/18
- range_suffix: "gke-svc"
ip_cidr_range:
region1: 100.73.128.0/18
service_projects:
- id: proj_restr_np_s1
mode: service
- id: proj_restr_np_s2
mode: service
- id: proxy
ip_ranges:
region1: 10.26.4.0/23
region2: 10.27.4.0/23
subnet_suffix: "-proxy"
flow_logs:
enable: false
interval: 1
private_access : false
role: ACTIVE
purpose: "REGIONAL_MANAGED_PROXY"
production:
env_code: "p"
env_enabled: true
nat_igw_enabled: true
windows_activation_enabled: true
enable_hub_and_spoke_transitivity: false
router_ha_enabled: true
mode: spoke
base:
env_type: "shared-base"
enabled: true
private_service_cidr: 10.16.24.0/21
private_service_connect_ip: 10.17.0.4
subnets:
- id: primary
ip_ranges:
region1: 10.0.192.0/18
region2: 10.1.192.0/18
subnet_suffix: ""
flow_logs:
enable: false
interval: 1
private_access : true
secondary_ranges:
- range_suffix: "gke-pod"
ip_cidr_range:
region1: 100.64.192.0/18
- range_suffix: "gke-svc"
ip_cidr_range:
region1: 100.65.192.0/18
service_projects:
- id: proj_base_prod_s1
mode: service
- id: proj_base_prod_s2
mode: service
- id: proxy
ip_ranges:
region1: 10.18.6.0/23
region2: 10.19.6.0/23
subnet_suffix: "-proxy"
flow_logs:
enable: false
interval: 1
private_access : false
role: ACTIVE
purpose: "REGIONAL_MANAGED_PROXY"
restricted:
env_type: "shared-restricted"
enabled: true
private_service_cidr: 10.16.56.0/21
private_service_connect_ip: 10.17.0.8
subnets:
- id: primary
ip_ranges:
region1: 10.8.192.0/18
region2: 10.9.192.0/18
subnet_suffix: ""
flow_logs:
enable: false
interval: 1
private_access : true
secondary_ranges:
- range_suffix: "gke-pod"
ip_cidr_range:
region1: 100.72.192.0/18
- range_suffix: "gke-svc"
ip_cidr_range:
region1: 100.73.192.0/18
service_projects:
- id: proj_restr_prod_s1
mode: service
- id: proj_restr_prod_s2
mode: service
- id: proxy
ip_ranges:
region1: 10.26.6.0/23
region2: 10.27.6.0/23
subnet_suffix: "-proxy"
flow_logs:
enable: false
interval: 1
private_access : false
role: ACTIVE
purpose: "REGIONAL_MANAGED_PROXY"
common:
env_code: c
env_enabled: true
# Toggle creation of 2'nd cloud router in each enabled region
router_ha_enabled: true
common_routes:
# the complete route name is similar to rt-${vpc_name}-${name_suffix}
# the VPC name is vpc-${env_code}-${env_type} e.g. vpc-d-shared-base
- id: rt_nat_to_internet
name_suffix: "1000-egress-internet-default"
description: "Tag based route through IGW to access internet"
destination_range: 0.0.0.0/0
tags: egress-internet
next_hop_internet: true
priority: 1000
- id: rt_windows_activation
name_suffix: "1000-all-default-windows-kms"
description: "Route through IGW to allow Windows KMS activation for GCP."
destination_range: 35.190.247.13/32
next_hop_internet: true
priority: 1000
dns_hub:
env_type: "dns-hub"
mode: spoke
dns_vpc_ip_range: 172.16.0.0/24
routes:
rt_private_googleapis:
name_suffix: "1000-all-default-private-api"
description: "Route through IGW to allow private google api access."
destination_range: 199.36.153.8/30
next_hop_internet: true
priority: 1000
subnets:
- id: primary
ip_ranges:
region1: 172.16.0.0/25
region2: 172.16.128.0/25
subnet_suffix: ""
target_servers:
- ipv4_address: 192.168.0.1
forwarding_path: default
- ipv4_address: 192.168.0.2
forwarding_path: default
net_hub:
env_enabled: true
nat_igw_enabled: true
windows_activation_enabled: true
enable_hub_and_spoke_transitivity: false
router_ha_enabled: true
mode: hub
base:
env_type: "shared-base-hub"
enabled: true
private_service_connect_ip: 10.17.0.1
dns_enable_inbound_forwarding: true
dns_enable_logging: true
firewall_enable_logging: true
nat_bgp_asn: 64514
nat_num_addresses_region1: 2
nat_num_addresses_region2: 2
windows_activation_enabled: true
subnets:
- id: primary
ip_ranges:
region1: 10.0.0.0/18
region2: 10.1.0.0/18
subnet_suffix: ""
flow_logs:
enable: false
interval: 1
private_access : true
- id: proxy
ip_ranges:
region1: 10.18.0.0/23
region2: 10.19.0.0/23
subnet_suffix: "-proxy"
flow_logs:
enable: false
interval: 1
private_access : false
role: ACTIVE
purpose: "REGIONAL_MANAGED_PROXY"
restricted:
env_type: "shared-restricted-hub"
enabled: true
private_service_connect_ip: 10.17.0.5
dns_enable_inbound_forwarding: true
dns_enable_logging: true
firewall_enable_logging: true
nat_bgp_asn: 64514
nat_num_addresses_region1: 2
nat_num_addresses_region2: 2
windows_activation_enabled: true
subnets:
- id: primary
ip_ranges:
region1: 10.8.0.0/18
region2: 10.9.0.0/18
subnet_suffix: ""
flow_logs:
enable: false
interval: 1
private_access : true
- id: proxy
ip_ranges:
region1: 10.26.0.0/23
region2: 10.27.0.0/23
subnet_suffix: "-proxy"
flow_logs:
enable: false
interval: 1
private_access : false
role: ACTIVE
purpose: "REGIONAL_MANAGED_PROXY"
onsite:
on_site_ip_range: 192.168.0.0/16
sites:
site1:
nameservers:
- ipv4_address = "192.168.0.1"
forwarding_path = "default"
- ipv4_address = "192.168.0.2"
forwarding_path = "default"