2022-10-24 08:44:21 -07:00
|
|
|
/**
|
2023-08-24 09:15:15 -07:00
|
|
|
* Copyright 2023 Google LLC
|
2022-10-24 08:44:21 -07:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2023-08-08 09:50:57 -07:00
|
|
|
variable "addons_config" {
|
|
|
|
description = "Addons configuration."
|
|
|
|
type = object({
|
|
|
|
advanced_api_ops = optional(bool, false)
|
|
|
|
api_security = optional(bool, false)
|
|
|
|
connectors_platform = optional(bool, false)
|
|
|
|
integration = optional(bool, false)
|
|
|
|
monetization = optional(bool, false)
|
|
|
|
})
|
|
|
|
default = null
|
|
|
|
}
|
|
|
|
|
2022-11-22 03:51:27 -08:00
|
|
|
variable "endpoint_attachments" {
|
|
|
|
description = "Endpoint attachments."
|
|
|
|
type = map(object({
|
|
|
|
region = string
|
|
|
|
service_attachment = string
|
|
|
|
}))
|
2023-08-24 09:15:15 -07:00
|
|
|
default = {}
|
|
|
|
nullable = false
|
2022-11-22 03:51:27 -08:00
|
|
|
}
|
2022-10-24 08:44:21 -07:00
|
|
|
|
|
|
|
variable "envgroups" {
|
|
|
|
description = "Environment groups (NAME => [HOSTNAMES])."
|
|
|
|
type = map(list(string))
|
2023-08-24 09:15:15 -07:00
|
|
|
default = {}
|
|
|
|
nullable = false
|
2022-10-24 08:44:21 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
variable "environments" {
|
|
|
|
description = "Environments."
|
|
|
|
type = map(object({
|
2024-06-25 00:50:19 -07:00
|
|
|
api_proxy_type = optional(string)
|
|
|
|
description = optional(string, "Terraform-managed")
|
|
|
|
display_name = optional(string)
|
|
|
|
deployment_type = optional(string)
|
|
|
|
envgroups = optional(list(string), [])
|
|
|
|
forward_proxy_uri = optional(string)
|
|
|
|
iam = optional(map(list(string)), {})
|
2023-10-27 09:15:37 -07:00
|
|
|
iam_bindings = optional(map(object({
|
|
|
|
role = string
|
|
|
|
members = list(string)
|
|
|
|
})), {})
|
|
|
|
iam_bindings_additive = optional(map(object({
|
|
|
|
role = string
|
|
|
|
member = string
|
|
|
|
})), {})
|
2024-04-28 08:31:42 -07:00
|
|
|
node_config = optional(object({
|
|
|
|
min_node_count = optional(number)
|
|
|
|
max_node_count = optional(number)
|
|
|
|
}))
|
|
|
|
type = optional(string)
|
2022-10-24 08:44:21 -07:00
|
|
|
}))
|
2023-08-24 09:15:15 -07:00
|
|
|
default = {}
|
|
|
|
nullable = false
|
2022-10-24 08:44:21 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
variable "instances" {
|
2023-06-16 07:39:38 -07:00
|
|
|
description = "Instances ([REGION] => [INSTANCE])."
|
2022-10-24 08:44:21 -07:00
|
|
|
type = map(object({
|
2024-04-28 08:31:42 -07:00
|
|
|
consumer_accept_list = optional(list(string))
|
2023-01-24 07:57:01 -08:00
|
|
|
description = optional(string, "Terraform-managed")
|
|
|
|
disk_encryption_key = optional(string)
|
2024-04-28 08:31:42 -07:00
|
|
|
display_name = optional(string)
|
2023-08-24 10:46:39 -07:00
|
|
|
enable_nat = optional(bool, false)
|
2023-10-27 09:15:37 -07:00
|
|
|
environments = optional(list(string), [])
|
2024-04-28 08:31:42 -07:00
|
|
|
name = optional(string)
|
|
|
|
runtime_ip_cidr_range = optional(string)
|
|
|
|
troubleshooting_ip_cidr_range = optional(string)
|
2022-10-24 08:44:21 -07:00
|
|
|
}))
|
2023-09-07 01:49:33 -07:00
|
|
|
validation {
|
|
|
|
condition = alltrue([
|
|
|
|
for k, v in var.instances :
|
|
|
|
# has troubleshooting_ip => has runtime_ip
|
|
|
|
v.runtime_ip_cidr_range != null || v.troubleshooting_ip_cidr_range == null
|
|
|
|
])
|
|
|
|
error_message = "Using a troubleshooting range requires specifying a runtime range too."
|
|
|
|
}
|
2023-08-24 09:15:15 -07:00
|
|
|
default = {}
|
|
|
|
nullable = false
|
2022-10-24 08:44:21 -07:00
|
|
|
}
|
2022-11-18 08:48:16 -08:00
|
|
|
|
|
|
|
variable "organization" {
|
|
|
|
description = "Apigee organization. If set to null the organization must already exist."
|
|
|
|
type = object({
|
2024-04-28 08:31:42 -07:00
|
|
|
analytics_region = optional(string)
|
|
|
|
api_consumer_data_encryption_key = optional(string)
|
|
|
|
api_consumer_data_location = optional(string)
|
|
|
|
authorized_network = optional(string)
|
|
|
|
billing_type = optional(string)
|
|
|
|
control_plane_encryption_key = optional(string)
|
|
|
|
database_encryption_key = optional(string)
|
|
|
|
description = optional(string, "Terraform-managed")
|
|
|
|
disable_vpc_peering = optional(bool, false)
|
|
|
|
display_name = optional(string)
|
|
|
|
properties = optional(map(string), {})
|
|
|
|
runtime_type = optional(string, "CLOUD")
|
|
|
|
retention = optional(string)
|
2022-11-18 08:48:16 -08:00
|
|
|
})
|
2023-09-07 01:49:33 -07:00
|
|
|
validation {
|
|
|
|
condition = var.organization == null || (
|
|
|
|
try(var.organization.runtime_type, null) == "CLOUD" || !try(var.organization.disable_vpc_peering, false)
|
|
|
|
)
|
2023-09-07 01:52:30 -07:00
|
|
|
error_message = "Disabling the VPC peering can only be done in organization using the CLOUD runtime."
|
2023-09-07 01:49:33 -07:00
|
|
|
}
|
|
|
|
validation {
|
|
|
|
condition = var.organization == null || (
|
|
|
|
try(var.organization.authorized_network, null) == null || !try(var.organization.disable_vpc_peering, false)
|
|
|
|
)
|
|
|
|
error_message = "Disabling the VPC peering is mutually exclusive with authorized_network."
|
|
|
|
}
|
2022-11-18 08:48:16 -08:00
|
|
|
default = null
|
|
|
|
}
|
|
|
|
|
|
|
|
variable "project_id" {
|
|
|
|
description = "Project ID."
|
|
|
|
type = string
|
2022-11-29 03:32:24 -08:00
|
|
|
}
|