cloud-foundation-fabric/modules/net-vpc/outputs.tf

160 lines
5.0 KiB
HCL

/**
* Copyright 2023 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
output "id" {
description = "Fully qualified network id."
value = local.network.id
depends_on = [
google_compute_network_peering.local,
google_compute_network_peering.remote,
google_compute_shared_vpc_host_project.shared_vpc_host,
google_compute_shared_vpc_service_project.service_projects,
google_service_networking_connection.psa_connection
]
}
output "internal_ipv6_range" {
description = "ULA range."
value = try(local.network.internal_ipv6_range, null)
}
output "name" {
description = "Network name."
value = local.network.name
depends_on = [
google_compute_network_peering.local,
google_compute_network_peering.remote,
google_compute_shared_vpc_host_project.shared_vpc_host,
google_compute_shared_vpc_service_project.service_projects,
google_service_networking_connection.psa_connection
]
}
output "network" {
description = "Network resource."
value = local.network
depends_on = [
google_compute_network_peering.local,
google_compute_network_peering.remote,
google_compute_shared_vpc_host_project.shared_vpc_host,
google_compute_shared_vpc_service_project.service_projects,
google_service_networking_connection.psa_connection
]
}
output "network_attachment_ids" {
description = "IDs of network attachments."
value = {
for k, v in google_compute_network_attachment.default :
k => v.id
}
}
output "project_id" {
description = "Project ID containing the network. Use this when you need to create resources *after* the VPC is fully set up (e.g. subnets created, shared VPC service projects attached, Private Service Networking configured)."
value = var.project_id
depends_on = [
google_compute_subnetwork.subnetwork,
google_compute_network_peering.local,
google_compute_network_peering.remote,
google_compute_shared_vpc_host_project.shared_vpc_host,
google_compute_shared_vpc_service_project.service_projects,
google_service_networking_connection.psa_connection
]
}
output "self_link" {
description = "Network self link."
value = local.network.self_link
depends_on = [
google_compute_network_peering.local,
google_compute_network_peering.remote,
google_compute_shared_vpc_host_project.shared_vpc_host,
google_compute_shared_vpc_service_project.service_projects,
google_service_networking_connection.psa_connection
]
}
output "subnet_ids" {
description = "Map of subnet IDs keyed by name."
value = { for k, v in google_compute_subnetwork.subnetwork : k => v.id }
depends_on = [
# allows correct destruction of internal application load balancers
google_compute_subnetwork.proxy_only
]
}
output "subnet_ips" {
description = "Map of subnet address ranges keyed by name."
value = {
for k, v in google_compute_subnetwork.subnetwork : k => v.ip_cidr_range
}
}
output "subnet_ipv6_external_prefixes" {
description = "Map of subnet external IPv6 prefixes keyed by name."
value = {
for k, v in google_compute_subnetwork.subnetwork :
k => try(v.external_ipv6_prefix, null)
}
}
output "subnet_regions" {
description = "Map of subnet regions keyed by name."
value = {
for k, v in google_compute_subnetwork.subnetwork : k => v.region
}
}
output "subnet_secondary_ranges" {
description = "Map of subnet secondary ranges keyed by name."
value = {
for k, v in google_compute_subnetwork.subnetwork :
k => {
for range in v.secondary_ip_range :
range.range_name => range.ip_cidr_range
}
}
}
output "subnet_self_links" {
description = "Map of subnet self links keyed by name."
value = { for k, v in google_compute_subnetwork.subnetwork : k => v.self_link }
depends_on = [
# allows correct destruction of internal application load balancers
google_compute_subnetwork.proxy_only
]
}
output "subnets" {
description = "Subnet resources."
value = { for k, v in google_compute_subnetwork.subnetwork : k => v }
depends_on = [
# allows correct destruction of internal application load balancers
google_compute_subnetwork.proxy_only
]
}
output "subnets_proxy_only" {
description = "L7 ILB or L7 Regional LB subnet resources."
value = { for k, v in google_compute_subnetwork.proxy_only : k => v }
}
output "subnets_psc" {
description = "Private Service Connect subnet resources."
value = { for k, v in google_compute_subnetwork.psc : k => v }
}