To use theses terraform modules, you will need a GCP project with:
-
APIs enabled
- Artifact Registry API
artifactregistry.googleapis.com
- BigQuery API
bigquery.googleapis.com
(default) - Cloud Asset API
cloudasset.googleapis.com
- Cloud Firestore API
firestore.googleapis.com
- Cloud Logging API
logging.googleapis.com
(default) - Cloud Monitoring API
monitoring.googleapis.com
(default) - Cloud Pub/Sub API
pubsub.googleapis.com
- Cloud Run Admin API
run.googleapis.com
- Cloud Scheduler API
cloudscheduler.googleapis.com
- Cloud Storage API
storage.googleapis.com
(default) - Cloud Trace API
cloudtrace.googleapis.com
(default) - Eventarc API
eventarc.googleapis.com
- Stackdriver Profiler API
cloudprofiler.googleapis.com
(default)
- Artifact Registry API
-
IAM roles for the service account used to run Terraform:
- On the project or folder hosting RAM
- Project IAM Admin
roles/resourcemanager.projectIamAdmin
- Pub/sub Admin
roles/pubsub.admin
- Service Account Admin
roles/iam.serviceAccountAdmin
- Service Usage Consumer
roles/serviceusage.serviceUsageConsumer
when creating CAI feeds on org or folder level attached to the RAM project - Cloud Run Admin
roles/run.admin
- Service Account User
roles/iam.serviceAccountUser
- Eventarc Admin
roles/eventarc.admin
- Storage Admin
roles/storage.admin
- BigQuery Admin
roles/bigquery.admin
- Cloud Scheduler Admin
roles/cloudscheduler.admin
- Project IAM Admin
- On the real-time monitored assets parent orgs / folders
- Cloud Asset Owner
roles/cloudasset.owner
- Cloud Asset Owner
- on batch monitored assets parent orgs
- a custom role with
- resourcemanager.organizations.get
- resourcemanager.organizations.getIamPolicy
- resourcemanager.organizations.setIamPolicy
- a custom role with
- on batch monitored assets parent folders
- a custome role with
- resourcemanager.folders.get
- resourcemanager.folders.getIamPolicy
- resourcemanager.folders.setIamPolicy
- or roles/resourcemanager.organizationAdmin on the folder's parent org
- a custome role with
- On the monitored assets projects (aka when creating CAI feeds at project level)
- Service Usage Consumer
roles/serviceusage.serviceUsageConsumer
- Service Usage Consumer
- On the project or folder hosting RAM
-
FireStore: select native mode
-
Provision a GCS bucket to manage Terraform state.
-
Install Terraform and google provider consistent with version specifyied in
versions.tf
See the examples folder