FAQ | CONTRIBUTING | CHANGELOG
This module allows you to configure a Google Cloud Platform project.
This module requires terraform version >=1.3.1.
A VPC network will be created in the requested regions. Private Google Access will be enabled, so you can connect to Google Services without public IPs. Private services access is also configured allowing you to run services like Cloud SQL with private IPs. It's also possible to configure Cloud NAT and Serverless VPC Access per region.
For more details please check docs/DEFAULT-VPC.md, especially if you plan to extend it by adding custom subnetworks or similar. Also all used IP address ranges are documented there.
This module acts "mostly" authoritative on IAM roles. It aims to configure all IAM and Service Account related resources in a central place for easy review and adjustments. All active roles are fetched initially and compared with the roles given via roles input. If a role shouldn't be set the module will create an empty resource for this role, means terraform will remove it. This will result in a module deletion on the next terraform run.
All roles listed for service agents (like for example
roles/dataproc.serviceAgent
) are ignored, so if a service gets enabled the
default permissions granted automatically by Google Cloud Platform to the
related service accounts will stay in place. This excludes are configured
in data.tf - look for a local variable called role_excludes
module "projectcfg" {
source = "metro-digital/cf-projectcfg/google"
version = "~> 2.4"
project_id = "metro-cf-example-ex1-e8v"
roles = {
"roles/bigquery.admin" = [
"group:[email protected]",
"user:[email protected]",
"serviceAccount:[email protected]"
],
"roles/cloudsql.admin" = [
"group:[email protected]",
]
}
}
Please also take a deeper look into the FAQ - there are additional examples available. Examples how to use Workload Identity Federation with GitHub and similar things are explained giving simple examples.
Name | Description | Type | Default | Required |
---|---|---|---|---|
project_id | GCP project ID | string |
n/a | yes |
roles | IAM roles and their members. If you create a service account in this project via the service_accounts input, we recommendto use the project_roles attribute of the respective service account to grant it permissionson the project's IAM policy. This allows you to better re-use your code in staged environments. Example: roles = { |
map(list(string)) |
n/a | yes |
custom_roles | Create custom roles and define who gains that role on project level Example: custom_roles = { |
map(object({ |
{} |
no |
enabled_services | List of GCP enabled services / APIs to enable. Dependencies will be enabled automatically. Remark: Google sometimes changes (mostly adding) dependencies and will activate those automatically for your project. Therefore being authoritative on services usually causes a lot of trouble. The module doesn't provide any option to be authoritative for this reason. By default we are partly authoritative. This can can be controlled by the enabled_services_disable_on_destroy flag.Example: enabled_services = [ |
list(string) |
[] |
no |
enabled_services_disable_on_destroy | If true, try to disable a service given via enabled_services after its removal from from the list.Defaults to true. May be useful in the event that a project is long-lived but the infrastructure running in that project changes frequently. Can result in failing terraform runs if the removed service is a dependency for any other active service. |
bool |
true |
no |
essential_contacts | Essential contacts receive configurable notifications from Google Cloud Platform based on selected categories. language : The preferred language for notifications, as an ISO 639-1 language code.See documentation for a list of supported languages. categories : The categories of notifications that the contact will receive communications for.See documentation for a list of supported categories. Remark: The module will enable the essential contacts API automatically once one contact is configured. You still need to grant the role roles/essentialcontacts.admin to the principle that is executingthe terraform code (most likely your service account used in your pipeline) if you plan to use github_action_repositories .Example: essential_contacts = { |
map(object({ |
{} |
no |
firewall_rules | The module will create default firewall rules unless skip_default_vpc_creation is set to true The following rules are created by default: - allow_ssh_iap : A firewall rule allowing SSH via IAP if the network tag fw-allow-ssh-iap is set on an Compute Instance - allow_rdp_iap : A firewall rule allowing SSH via IAP if the network tag fw-allow-rdp-iap is set on an Compute Instance The following additional rules are available if explicitly enabled: - all_internal : A firewall rule allowing all kinds of traffic inside the VPCExample: # Disable IAP RDP rule rule, keep default for all other rules |
object({ |
{} |
no |
non_authoritative_roles | List of roles (regex) to exclude from authoritative project IAM handling. Roles listed here can have bindings outside of this module. Example: non_authoritative_roles = [ |
list(string) |
[] |
no |
service_accounts | Service accounts to create for this project.display_name : Human-readable name shown in Google Cloud Consoledescription (optional): Human-readable description shown in Google Cloud Consoleiam (optional): IAM permissions assigned to this Service Account as a resource. This defines which principalcan do something on this Service Account. An example: If you grant roles/iam.serviceAccountKeyAdmin to a grouphere, this group will be able to maintain Service Account keys for this specific SA. If you want to allow this SA to use BigQuery, you need to use the project-wide roles input or, even better, use the project_roles attribute todo so. project_roles (optional): IAM permissions assigned to this Service Account on project level.This parameter is merged with whatever is provided as the project's IAM policy via the roles input.iam_non_authoritative_roles (optional): Any role given in this list will be added to the authoritative policywith its current value as defined in the Google Cloud Platform. Example use case: Composer 2 adds values to roles/iam.workloadIdentityUser binding when an environment is created or updated. Thus, you might want toautomatically import those permissions. runtime_service_accounts (optional): You can list Kubernetes Service Accounts within Cloud Native Runtimeclusters here. For details on the format, see the example below. A Workload Identity Pool and a Workload Identity Provider needed for Workload Identity Federation will be created automatically. Each service account given gains permissions to authenticate as this service account using Workload Identity Federation. This allows workloads running in Cloud Native Runtime clusters to use this service account without the need for service account keys. A detailed example can be found within the FAQ. github_action_repositories (optional): You can list GitHub repositories (format: user/repo ) here.A Workload Identity Pool and a Workload Identity Provider needed for Workload Identity Federation will be created automatically. Each repository given gains permissions to authenticate as this service account using Workload Identity Federation. This allows any GitHub Action pipeline to use this service account without the need for service account keys. An example can be found within the FAQ. For more details, see the documentation for Google's GitHub action for authentication: google-github-actions/auth .Remark: If you configure github_action_repositories , the module binds a member for each repository to the roleroles/iam.workloadIdentityUser inside the service account's IAM policy. This is done regardless of whetheror not you list this role in the iam_non_authoritative_roles key. The same happens if you useruntime_service_accounts . A member per runtime service account is added to the service account's IAM policy.Remark: You need to grant the role roles/iam.workloadIdentityPoolAdmin to the principal that isexecuting the terraform code (most likely a service account used in a pipeline) if you plan to use github_action_repositories or runtime_service_accounts .Example: service_accounts = { |
map(object({ |
{} |
no |
skip_default_vpc_creation | When set to true the module will not create the default VPC or any related resource like NAT Gateway, firewall rules or Serverless VPC access configuration. |
bool |
false |
no |
vpc_regions | Enabled regions and configuration Example: vpc_regions = {By default the module will create a subnetwork in europe-west1 but do not launch any additional features like NAT or VPC access. Secondary ranges for GKE are disabled, too. |
map(object({ |
{ |
no |
workload_identity_pool_attribute_condition | A Common Expression Language (CEL) expression to restrict what otherwise valid authentication credentials issued by the provider should not be accepted. By default, credentials issued by GitHub within any organisation/user owning a repository given via github_action_repositories property of a any service account are accepted.You should never only rely on this condition to limit the principals who can get access to Google Cloud resources but e.g. explicitly limit the repository using the attribute.repository attribute of your principalset. This is done automatically if you use the github_action_repositories property of a service account managed by this module. If the repository of your GitHub workflow runs in a different GitHub organisation, make sure to provide a valid CEL expression which allows workflows from your organisation. A list of all METRO-owned organisations can be obtained from METRO's GitHub Enterprise. |
string |
null |
no |
workload_identity_pool_attribute_mapping | Maps attributes from authentication credentials issued by an external identity provider to Google Cloud attributes Note Teams must be cautious before modifying the attribute mapping as it may cause undesired permission issues. See documentation Example: { |
map(any) |
{ |
no |
Name | Description |
---|---|
project_id | GCP project ID |
service_accounts | List of service accounts created |
This module needs some command line utils to be installed:
- curl
- jq
- dig
- xargs
This project is licensed under the terms of the Apache License 2.0
This terraform module depends on providers from HashiCorp, Inc. which are licensed under MPL-2.0. You can obtain the respective source code for these provider here:
This terraform module uses pre-commit hooks which are licensed under MPL-2.0. You can obtain the respective source code here: