modules/secure-serverless-net/iam.tf (41 lines of code) (raw):

/** * 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 * * 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. */ data "google_project" "serverless_project_id" { project_id = var.serverless_project_id } resource "google_project_service_identity" "vpcaccess_identity_sa" { provider = google-beta project = var.serverless_project_id service = "vpcaccess.googleapis.com" } resource "google_project_iam_member" "gca_sa_vpcaccess" { count = var.connector_on_host_project ? 0 : 1 project = var.vpc_project_id role = "roles/compute.networkUser" member = "serviceAccount:${google_project_service_identity.vpcaccess_identity_sa.email}" } resource "google_project_iam_member" "cloud_services" { count = var.connector_on_host_project ? 0 : 1 project = var.vpc_project_id role = "roles/compute.networkUser" member = "serviceAccount:${data.google_project.serverless_project_id.number}@cloudservices.gserviceaccount.com" } resource "google_project_iam_member" "run_identity_services" { count = var.connector_on_host_project ? 0 : 1 project = var.vpc_project_id role = "roles/vpcaccess.user" member = "serviceAccount:${var.serverless_service_identity_email}" }