# Copyright 2022 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 # # https://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. # tfdoc:file:description Trasformation project and VPC. locals { group_iam_trf = { "${local.groups.data-engineers}" = [ "roles/bigquery.jobUser", "roles/dataflow.admin", ] } iam_trf = { "roles/bigquery.dataViewer" = [ module.orc-sa-cmp-0.iam_email ] "roles/bigquery.jobUser" = [ module.trf-sa-bq-0.iam_email, ] "roles/dataflow.admin" = [ module.orc-sa-cmp-0.iam_email, ] "roles/dataflow.worker" = [ module.trf-sa-df-0.iam_email ] "roles/storage.objectAdmin" = [ module.trf-sa-df-0.iam_email, module.orc-sa-cmp-0.iam_email, "serviceAccount:${module.trf-prj.service_accounts.robots.dataflow}" ] } prefix_trf = "${var.prefix}-trf" } # Project module "trf-prj" { source = "../../../modules/project" name = var.project_id["trasformation"] parent = try(var.project_create.parent, null) billing_account = try(var.project_create.billing_account_id, null) project_create = var.project_create != null prefix = var.project_create == null ? null : var.prefix # additive IAM bindings avoid disrupting bindings in existing project iam = var.project_create != null ? local.iam_trf : {} iam_additive = var.project_create == null ? local.iam_trf : {} group_iam = local.group_iam_trf services = concat(var.project_services, [ "bigquery.googleapis.com", "bigqueryreservation.googleapis.com", "bigquerystorage.googleapis.com", "cloudkms.googleapis.com", "compute.googleapis.com", "dataflow.googleapis.com", "dlp.googleapis.com", "pubsub.googleapis.com", "servicenetworking.googleapis.com", "storage.googleapis.com", "storage-component.googleapis.com" ]) service_encryption_key_ids = { dataflow = [try(local.service_encryption_keys.dataflow, null)] storage = [try(local.service_encryption_keys.storage, null)] } shared_vpc_service_config = local._shared_vpc_service_config } module "trf-vpc" { count = var.network_config.network != null ? 0 : 1 source = "../../../modules/net-vpc" project_id = module.trf-prj.project_id name = "${local.prefix_trf}-vpc" subnets = [ { ip_cidr_range = var.network_config.vpc_subnet.transformation.range name = "${local.prefix_trf}-subnet" region = var.location_config.region secondary_ip_range = {} } ] } module "trf-vpc-firewall" { count = var.network_config.network != null ? 0 : 1 source = "../../../modules/net-vpc-firewall" project_id = module.trf-prj.project_id network = local._networks.transformation.network_name admin_ranges = [local._networks.transformation.subnet_range] } module "trf-nat" { count = var.network_config.enable_cloud_nat ? 1 : 0 source = "../../../modules/net-cloudnat" project_id = module.trf-prj.project_id region = var.location_config.region name = "${local.prefix_trf}-default" router_network = local._networks.transformation.network_name }