ai-infrastructure/terraform-modules/gke-aiml/service_account.tf (23 lines of code) (raw):

# 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. locals { node_pool_sa_config = ( !(var.node_pool_sa.email != "") ? { "${var.node_pool_sa.name}" = { description = var.node_pool_sa.description roles = var.node_pool_sa.roles } } : {} ) service_accounts = merge(local.node_pool_sa_config, {}) } module "service_accounts" { source = "github.com/GoogleCloudPlatform/cloud-foundation-fabric//modules/iam-service-account?ref=v29.0.0&depth=1" for_each = local.service_accounts project_id = var.project_id name = each.key display_name = each.value.description iam_project_roles = { "${var.project_id}" = [for role in each.value.roles : "roles/${role}"] } }