* Service agents script * Service agents update * WIP * Update script and terraform * Fix tests * Fix linter * Update docs * Bring back pf example inventory * Fix tests * Fix more tests * Fix tests * Use dataclasses for build_service_agents.py * Remove unneeded field() from build_service_agents * Re-enable CMEK depends_on in project outputs * Update tools/requirements.txt * Enable storage in GCS example projects * Fix tests * Add CMEK Service Agents dependencies for services * Fix typos and data platform cmek * More typos
390 lines
15 KiB
HCL
390 lines
15 KiB
HCL
/**
|
|
* Copyright 2024 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.
|
|
*/
|
|
|
|
variable "apigee_config" {
|
|
description = "Apigee configuration."
|
|
type = object({
|
|
addons_config = optional(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)
|
|
}))
|
|
organization = object({
|
|
analytics_region = optional(string)
|
|
api_consumer_data_encryption_key_config = optional(object({
|
|
auto_create = optional(bool, false)
|
|
id = optional(string)
|
|
}), {})
|
|
api_consumer_data_location = optional(string)
|
|
billing_type = optional(string)
|
|
control_plane_encryption_key_config = optional(object({
|
|
auto_create = optional(bool, false)
|
|
id = optional(string)
|
|
}), {})
|
|
database_encryption_key_config = optional(object({
|
|
auto_create = optional(bool, false)
|
|
id = optional(string)
|
|
}), {})
|
|
description = optional(string, "Terraform-managed")
|
|
disable_vpc_peering = optional(bool, false)
|
|
display_name = optional(string)
|
|
properties = optional(map(string), {})
|
|
retention = optional(string)
|
|
})
|
|
envgroups = optional(map(list(string)), {})
|
|
environments = optional(map(object({
|
|
description = optional(string)
|
|
display_name = optional(string)
|
|
envgroups = optional(list(string), [])
|
|
forward_proxy_uri = optional(string)
|
|
iam = optional(map(list(string)), {})
|
|
iam_bindings = optional(map(object({
|
|
role = string
|
|
members = list(string)
|
|
condition = optional(object({
|
|
expression = string
|
|
title = string
|
|
description = optional(string)
|
|
}))
|
|
})), {})
|
|
iam_bindings_additive = optional(map(object({
|
|
role = string
|
|
member = string
|
|
condition = optional(object({
|
|
expression = string
|
|
title = string
|
|
description = optional(string)
|
|
}))
|
|
})), {})
|
|
node_config = optional(object({
|
|
min_node_count = optional(number)
|
|
max_node_count = optional(number)
|
|
}), {})
|
|
type = optional(string)
|
|
})), {})
|
|
instances = optional(map(object({
|
|
disk_encryption_key_config = optional(object({
|
|
auto_create = optional(bool, false)
|
|
id = optional(string)
|
|
}), {})
|
|
environments = optional(list(string), [])
|
|
external = optional(bool, true)
|
|
runtime_ip_cidr_range = optional(string)
|
|
troubleshooting_ip_cidr_range = optional(string)
|
|
})), {})
|
|
endpoint_attachments = optional(map(object({
|
|
region = string
|
|
service_attachment = string
|
|
dns_names = optional(list(string), [])
|
|
})), {})
|
|
})
|
|
validation {
|
|
condition = (!var.apigee_config.organization.disable_vpc_peering ||
|
|
alltrue([for k, v in var.apigee_config.endpoint_attachments : length(v.dns_names) == 0]))
|
|
error_message = "If disable_vpc_peering is true for the organization, DNS names cannot be used for endpoint attachments."
|
|
}
|
|
validation {
|
|
condition = !(var.apigee_config.organization.database_encryption_key_config.auto_create && var.apigee_config.organization.database_encryption_key_config.id != null)
|
|
error_message = "If the database encryption key is to be created you should not be passing an id."
|
|
}
|
|
validation {
|
|
condition = !(var.apigee_config.organization.api_consumer_data_encryption_key_config.auto_create && var.apigee_config.organization.api_consumer_data_encryption_key_config.id != null)
|
|
error_message = "If the api consumer data encryption key is to be created you should not be passing an id."
|
|
}
|
|
validation {
|
|
condition = !(var.apigee_config.organization.control_plane_encryption_key_config.auto_create && var.apigee_config.organization.control_plane_encryption_key_config.id != null)
|
|
error_message = "If the control plane encryption key is to be created you should not be passing an id."
|
|
}
|
|
nullable = false
|
|
}
|
|
|
|
variable "enable_monitoring" {
|
|
description = "Boolean flag indicating whether an custom metric to monitor instances should be created in Cloud monitoring."
|
|
type = bool
|
|
default = false
|
|
}
|
|
|
|
variable "ext_lb_config" {
|
|
description = "External application load balancer configuration."
|
|
type = object({
|
|
log_sample_rate = optional(number)
|
|
outlier_detection = optional(object({
|
|
consecutive_errors = optional(number)
|
|
consecutive_gateway_failure = optional(number)
|
|
enforcing_consecutive_errors = optional(number)
|
|
enforcing_consecutive_gateway_failure = optional(number)
|
|
enforcing_success_rate = optional(number)
|
|
max_ejection_percent = optional(number)
|
|
success_rate_minimum_hosts = optional(number)
|
|
success_rate_request_volume = optional(number)
|
|
success_rate_stdev_factor = optional(number)
|
|
base_ejection_time = optional(object({
|
|
seconds = number
|
|
nanos = optional(number)
|
|
}))
|
|
interval = optional(object({
|
|
seconds = number
|
|
nanos = optional(number)
|
|
}))
|
|
}))
|
|
security_policy = optional(object({
|
|
advanced_options_config = optional(object({
|
|
json_parsing = optional(object({
|
|
enable = optional(bool, false)
|
|
content_types = optional(list(string))
|
|
}))
|
|
log_level = optional(string)
|
|
}))
|
|
adaptive_protection_config = optional(object({
|
|
layer_7_ddos_defense_config = optional(object({
|
|
enable = optional(bool, false)
|
|
rule_visibility = optional(string)
|
|
}))
|
|
auto_deploy_config = optional(object({
|
|
load_threshold = optional(number)
|
|
confidence_threshold = optional(number)
|
|
impacted_baseline_threshold = optional(number)
|
|
expiration_sec = optional(number)
|
|
}))
|
|
}))
|
|
rate_limit_threshold = optional(object({
|
|
count = number
|
|
interval_sec = number
|
|
}))
|
|
forbidden_src_ip_ranges = optional(list(string), [])
|
|
forbidden_regions = optional(list(string), [])
|
|
preconfigured_waf_rules = optional(map(object({
|
|
sensitivity = optional(number)
|
|
opt_in_rule_ids = optional(list(string), [])
|
|
opt_out_rule_ids = optional(list(string), [])
|
|
})))
|
|
}))
|
|
ssl_certificates = object({
|
|
certificate_ids = optional(list(string), [])
|
|
create_configs = optional(map(object({
|
|
certificate = string
|
|
private_key = string
|
|
})), {})
|
|
managed_configs = optional(map(object({
|
|
domains = list(string)
|
|
description = optional(string)
|
|
})), {})
|
|
self_signed_configs = optional(list(string), null)
|
|
})
|
|
})
|
|
default = null
|
|
}
|
|
|
|
variable "int_cross_region_lb_config" {
|
|
description = "Internal application load balancer configuration."
|
|
type = object({
|
|
log_sample_rate = optional(number)
|
|
outlier_detection = optional(object({
|
|
consecutive_errors = optional(number)
|
|
consecutive_gateway_failure = optional(number)
|
|
enforcing_consecutive_errors = optional(number)
|
|
enforcing_consecutive_gateway_failure = optional(number)
|
|
enforcing_success_rate = optional(number)
|
|
max_ejection_percent = optional(number)
|
|
success_rate_minimum_hosts = optional(number)
|
|
success_rate_request_volume = optional(number)
|
|
success_rate_stdev_factor = optional(number)
|
|
base_ejection_time = optional(object({
|
|
seconds = number
|
|
nanos = optional(number)
|
|
}))
|
|
interval = optional(object({
|
|
seconds = number
|
|
nanos = optional(number)
|
|
}))
|
|
}))
|
|
certificate_manager_certificates = optional(list(string))
|
|
})
|
|
default = null
|
|
}
|
|
|
|
variable "int_lb_config" {
|
|
description = "Internal application load balancer configuration."
|
|
type = object({
|
|
log_sample_rate = optional(number)
|
|
outlier_detection = optional(object({
|
|
consecutive_errors = optional(number)
|
|
consecutive_gateway_failure = optional(number)
|
|
enforcing_consecutive_errors = optional(number)
|
|
enforcing_consecutive_gateway_failure = optional(number)
|
|
enforcing_success_rate = optional(number)
|
|
max_ejection_percent = optional(number)
|
|
success_rate_minimum_hosts = optional(number)
|
|
success_rate_request_volume = optional(number)
|
|
success_rate_stdev_factor = optional(number)
|
|
base_ejection_time = optional(object({
|
|
seconds = number
|
|
nanos = optional(number)
|
|
}))
|
|
interval = optional(object({
|
|
seconds = number
|
|
nanos = optional(number)
|
|
}))
|
|
}))
|
|
ssl_certificates = object({
|
|
certificate_ids = optional(list(string), [])
|
|
create_configs = optional(map(object({
|
|
certificate = string
|
|
private_key = string
|
|
})), {})
|
|
self_signed_configs = optional(list(string), [])
|
|
})
|
|
})
|
|
default = null
|
|
}
|
|
|
|
|
|
variable "network_config" {
|
|
description = "Network configuration."
|
|
type = object({
|
|
shared_vpc = optional(object({
|
|
name = string
|
|
subnets = map(string)
|
|
subnets_psc = map(string)
|
|
}))
|
|
apigee_vpc = optional(object({
|
|
name = optional(string)
|
|
auto_create = optional(bool, true)
|
|
subnets = optional(map(object({
|
|
id = optional(string)
|
|
name = optional(string)
|
|
ip_cidr_range = optional(string)
|
|
})), {})
|
|
subnets_proxy_only = optional(map(object({
|
|
name = optional(string)
|
|
ip_cidr_range = string
|
|
})), {})
|
|
subnets_psc = optional(map(object({
|
|
id = optional(string)
|
|
name = optional(string)
|
|
ip_cidr_range = optional(string)
|
|
})), {})
|
|
}))
|
|
})
|
|
nullable = false
|
|
default = {}
|
|
validation {
|
|
condition = var.network_config.shared_vpc != null || var.network_config.apigee_vpc != null
|
|
error_message = "Shared VPC and/or local VPC details need to be provided."
|
|
}
|
|
validation {
|
|
condition = alltrue([for k, v in try(var.network_config.apigee_vpc.subnets, {}) : (v.id != null || v.ip_cidr_range != null) && !(v.id != null && v.ip_cidr_range != null)])
|
|
error_message = "An IP CIDR range and id cannot be specified at the same time for a subnet."
|
|
}
|
|
validation {
|
|
condition = alltrue([for k, v in try(var.network_config.apigee_vpc.subnets_psc, {}) : (v.id != null || v.ip_cidr_range != null) && !(v.id != null && v.ip_cidr_range != null)])
|
|
error_message = "An IP CIDR range and id cannot be specified at the same time for a PSC subnet."
|
|
}
|
|
}
|
|
|
|
variable "project_config" {
|
|
description = "Project configuration."
|
|
type = object({
|
|
billing_account_id = optional(string)
|
|
compute_metadata = optional(map(string), {})
|
|
contacts = optional(map(list(string)), {})
|
|
custom_roles = optional(map(list(string)), {})
|
|
default_service_account = optional(string, "keep")
|
|
descriptive_name = optional(string)
|
|
iam = optional(map(list(string)), {})
|
|
group_iam = optional(map(list(string)), {})
|
|
iam_bindings = optional(map(object({
|
|
role = string
|
|
members = list(string)
|
|
condition = optional(object({
|
|
expression = string
|
|
title = string
|
|
description = optional(string)
|
|
}))
|
|
})), {})
|
|
iam_bindings_additive = optional(map(object({
|
|
role = string
|
|
member = string
|
|
condition = optional(object({
|
|
expression = string
|
|
title = string
|
|
description = optional(string)
|
|
}))
|
|
})), {})
|
|
labels = optional(map(string), {})
|
|
lien_reason = optional(string)
|
|
logging_data_access = optional(map(map(list(string))), {})
|
|
log_exclusions = optional(map(string), {})
|
|
logging_sinks = optional(map(object({
|
|
bq_partitioned_table = optional(bool)
|
|
description = optional(string)
|
|
destination = string
|
|
disabled = optional(bool, false)
|
|
exclusions = optional(map(string), {})
|
|
filter = string
|
|
iam = optional(bool, true)
|
|
type = string
|
|
unique_writer = optional(bool, true)
|
|
})), {})
|
|
metric_scopes = optional(list(string), [])
|
|
name = string
|
|
org_policies = optional(map(object({
|
|
inherit_from_parent = optional(bool) # for list policies only.
|
|
reset = optional(bool)
|
|
rules = optional(list(object({
|
|
allow = optional(object({
|
|
all = optional(bool)
|
|
values = optional(list(string))
|
|
}))
|
|
deny = optional(object({
|
|
all = optional(bool)
|
|
values = optional(list(string))
|
|
}))
|
|
enforce = optional(bool) # for boolean policies only.
|
|
condition = optional(object({
|
|
description = optional(string)
|
|
expression = optional(string)
|
|
location = optional(string)
|
|
title = optional(string)
|
|
}), {})
|
|
})), [])
|
|
})), {})
|
|
parent = optional(string)
|
|
prefix = optional(string)
|
|
project_create = optional(bool, true)
|
|
vpc_sc = optional(object({
|
|
perimeter_name = string
|
|
perimeter_bridges = optional(list(string), [])
|
|
is_dry_run = optional(bool, false)
|
|
}))
|
|
services = optional(list(string), [])
|
|
shared_vpc_host_config = optional(object({
|
|
enabled = bool
|
|
service_projects = optional(list(string), [])
|
|
}))
|
|
shared_vpc_service_config = optional(object({
|
|
host_project = string
|
|
service_agent_iam = optional(map(list(string)), {})
|
|
service_iam_grants = optional(list(string), [])
|
|
}))
|
|
skip_delete = optional(bool, false)
|
|
tag_bindings = optional(map(string))
|
|
})
|
|
}
|
|
|