cloud-foundation-fabric/foundations/environments
Ludovico Magnocavallo e8a9d73f4f foundations/environments: do not use liens by default 2020-01-10 18:53:02 +01:00
..
README.md Update docs using tfdoc format (#28) 2020-01-10 13:44:54 +01:00
backend.tf.sample Rename 'organization-bootstrap' to 'foundations' 2019-09-11 14:46:07 +02:00
diagram.png Rename 'organization-bootstrap' to 'foundations' 2019-09-11 14:46:07 +02:00
main.tf foundations/environments: do not use liens by default 2020-01-10 18:53:02 +01:00
outputs.tf Rename 'organization-bootstrap' to 'foundations' 2019-09-11 14:46:07 +02:00
providers.tf Rename 'organization-bootstrap' to 'foundations' 2019-09-11 14:46:07 +02:00
variables.tf foundations/environments: move log filter to a variable, use org for xpn by default 2020-01-10 18:22:46 +01:00
versions.tf Rename 'organization-bootstrap' to 'foundations' 2019-09-11 14:46:07 +02:00

README.md

Environment-based organizational sample

This sample creates an organizational layout with a single level, where each folder is usually mapped to one infrastructure environment (test, dev, etc.). It also sets up all prerequisites for automation (GCS state buckets, service accounts, etc.), and the correct roles on those to enforce separation of duties at the environment level.

This layout is well suited for medium-sized infrastructures managed by a small set of teams, where the complexity in application resource ownership and access roles is mostly dealt with at the project level, and/or in the individual services (GKE, Cloud SQL, etc.). Its simplicity also makes it a good starting point for more complex or specialized layouts.

High-level diagram

Refer to the section-level README for general considerations about this type of samples, and usage instructions.

Managed resources and services

This sample creates several distinct groups of resources:

  • one folder per environment
  • one top-level project to hold Terraform-related resources
  • one top-level project to set up and host centralized audit log exports (optional)
  • one top-level shared services project

The number of resources in this sample is kept to a minimum so as to make it more generally applicable, further resources can be easily added by leveraging the full array of Cloud Foundation Toolkit modules, especially in the shared services project.

Shared services project

This sample contains a single, top-level project used to host services shared across environments (eg GCS, GCR, KMS, Cloud Build, etc.). In our experience, that is enough for many customers, especially those using this organizational layout.

For more complex setups where multiple shared services projects are needed to encapsulate a larger number of resources, shared services should be treated as an extra environment so that they can be managed by a dedicated set of Terraform files, using a separate service account and GCS bucket, with a folder to contain shared projects.

If no shared services are needed, the shared service project module can of course be removed from main.tf.

Variables

name description type required default
billing_account_id Billing account id used as default for new projects. string
environments Environment short names. list(string)
organization_id Organization id. string
prefix Prefix used for resources that need unique names. string
root_node Root node for the new hierarchy, either 'organizations/org_id' or 'folders/folder_id'. string
audit_viewers Audit project viewers, in IAM format. list(string) []
gcs_location GCS bucket location. string EU
generate_service_account_keys Generate and store service account keys in the state file. bool false
grant_xpn_folder_roles Grant roles needed for Shared VPC creation to service accounts at the environment folder level. bool true
grant_xpn_org_roles Grant roles needed for Shared VPC creation to service accounts at the organization level. bool false
project_services Service APIs enabled by default in new projects. list(string) ...
shared_bindings_members List of comma-delimited IAM-format members for the additional shared project bindings. list(string) []
shared_bindings_roles List of roles for additional shared project bindings. list(string) []
terraform_owners Terraform project owners, in IAM format. list(string) []

Outputs

name description sensitive
audit_logs_bq_dataset Bigquery dataset for the audit logs export.
audit_logs_project Project that holds the audit logs export resources.
bootstrap_tf_gcs_bucket GCS bucket used for the bootstrap Terraform state.
environment_folders Top-level environment folders.
environment_service_account_keys Service account keys used to run each environment Terraform modules.
environment_service_accounts Service accounts used to run each environment Terraform modules.
environment_tf_gcs_buckets GCS buckets used for each environment Terraform state.
shared_resources_project Project that holdes resources shared across environments.
terraform_project Project that holds the base Terraform resources.