87 lines
3.6 KiB
Markdown
87 lines
3.6 KiB
Markdown
# Google Cloud Storage Module
|
|
|
|
## TODO
|
|
|
|
- [ ] add support for defining [notifications](https://www.terraform.io/docs/providers/google/r/storage_notification.html)
|
|
|
|
## Example
|
|
|
|
```hcl
|
|
module "bucket" {
|
|
source = "./modules/gcs"
|
|
project_id = "myproject"
|
|
prefix = "test"
|
|
name = "my-bucket"
|
|
iam = {
|
|
"roles/storage.admin" = ["group:storage@example.com"]
|
|
}
|
|
}
|
|
```
|
|
|
|
### Example with Cloud KMS
|
|
|
|
```hcl
|
|
module "bucket" {
|
|
source = "./modules/gcs"
|
|
project_id = "myproject"
|
|
prefix = "test"
|
|
name = "my-bucket"
|
|
iam = {
|
|
"roles/storage.admin" = ["group:storage@example.com"]
|
|
}
|
|
encryption_keys = local.kms_key.self_link
|
|
}
|
|
```
|
|
|
|
### Example with retention policy
|
|
|
|
```hcl
|
|
module "bucket" {
|
|
source = "./modules/gcs"
|
|
project_id = "myproject"
|
|
prefix = "test"
|
|
name = "my-bucket"
|
|
iam = {
|
|
"roles/storage.admin" = ["group:storage@example.com"]
|
|
}
|
|
|
|
retention_policies = {
|
|
retention_period = 100
|
|
is_locked = true
|
|
}
|
|
|
|
logging_config = {
|
|
log_bucket = bucket_name_for_logging
|
|
log_object_prefix = null
|
|
}
|
|
}
|
|
```
|
|
|
|
<!-- BEGIN TFDOC -->
|
|
## Variables
|
|
|
|
| name | description | type | required | default |
|
|
|---|---|:---: |:---:|:---:|
|
|
| name | Bucket name suffix. | <code title="">string</code> | ✓ | |
|
|
| project_id | Bucket project id. | <code title="">string</code> | ✓ | |
|
|
| *encryption_key* | KMS key that will be used for encryption. | <code title="">string</code> | | <code title="">null</code> |
|
|
| *force_destroy* | Optional map to set force destroy keyed by name, defaults to false. | <code title="">bool</code> | | <code title="">false</code> |
|
|
| *iam* | IAM bindings in {ROLE => [MEMBERS]} format. | <code title="map(list(string))">map(list(string))</code> | | <code title="">{}</code> |
|
|
| *labels* | Labels to be attached to all buckets. | <code title="map(string)">map(string)</code> | | <code title="">{}</code> |
|
|
| *location* | Bucket location. | <code title="">string</code> | | <code title="">EU</code> |
|
|
| *logging_config* | Bucket logging configuration. | <code title="object({ log_bucket = string log_object_prefix = string })">object({...})</code> | | <code title="">null</code> |
|
|
| *prefix* | Prefix used to generate the bucket name. | <code title="">string</code> | | <code title="">null</code> |
|
|
| *retention_policy* | Bucket retention policy. | <code title="object({ retention_period = number is_locked = bool })">object({...})</code> | | <code title="">null</code> |
|
|
| *storage_class* | Bucket storage class. | <code title="">string</code> | | <code title="MULTI_REGIONAL validation { condition = contains(["STANDARD", "MULTI_REGIONAL", "REGIONAL", "NEARLINE", "COLDLINE", "ARCHIVE"], var.storage_class) error_message = "Storage class must be one of STANDARD, MULTI_REGIONAL, REGIONAL, NEARLINE, COLDLINE, ARCHIVE." }">...</code> |
|
|
| *uniform_bucket_level_access* | Allow using object ACLs (false) or not (true, this is the recommended behavior) , defaults to true (which is the recommended practice, but not the behavior of storage API). | <code title="">bool</code> | | <code title="">true</code> |
|
|
| *versioning* | Enable versioning, defaults to false. | <code title="">bool</code> | | <code title="">false</code> |
|
|
|
|
## Outputs
|
|
|
|
| name | description | sensitive |
|
|
|---|---|:---:|
|
|
| bucket | Bucket resource. | |
|
|
| name | Bucket name. | |
|
|
| url | Bucket URL. | |
|
|
<!-- END TFDOC -->
|