cloud-foundation-fabric/modules/data-catalog-tag-template/README.md

217 lines
7.7 KiB
Markdown

# Google Cloud Data Catalog Tag Template Module
This module allows managing [Data Catalog Tag Templates](https://cloud.google.com/data-catalog/docs/tags-and-tag-templates).
## Examples
### Simple Tag Template
```hcl
module "data-catalog-tag-template" {
source = "./fabric/modules/data-catalog-tag-template"
project_id = "my-project"
tag_templates = {
demo_var = {
region = "europe-west1"
display_name = "Demo Tag Template"
fields = {
source = {
display_name = "Source of data asset"
type = {
primitive_type = "STRING"
}
is_required = true
}
}
}
}
}
# tftest modules=1 resources=1
```
### Tag Template with IAM
```hcl
module "data-catalog-tag-template" {
source = "./fabric/modules/data-catalog-tag-template"
project_id = "my-project"
tag_templates = {
demo_var = {
region = "europe-west1"
display_name = "Demo Tag Template"
fields = {
source = {
display_name = "Source of data asset"
type = {
primitive_type = "STRING"
}
is_required = true
}
}
}
}
iam = {
"roles/datacatalog.tagTemplateOwner" = ["group:data-governance@example.com"]
"roles/datacatalog.tagTemplateUser" = ["group:data-product-eng@example.com"]
}
}
# tftest modules=1 resources=3
```
```hcl
module "data-catalog-tag-template" {
source = "./fabric/modules/data-catalog-tag-template"
project_id = var.project_id
tag_templates = {
demo_var = {
region = "europe-west1"
display_name = "Demo Tag Template"
fields = {
source = {
display_name = "Source of data asset"
type = {
primitive_type = "STRING"
}
is_required = true
}
}
}
}
iam_bindings = {
admin-with-delegated_roles = {
role = "roles/datacatalog.tagTemplateOwner"
members = ["group:data-governance@example.com"]
condition = {
title = "delegated-role-grants"
expression = format(
"api.getAttribute('iam.googleapis.com/modifiedGrantsByRole', []).hasOnly([%s])",
join(",", formatlist("'%s'",
[
"roles/datacatalog.tagTemplateOwner"
]
))
)
}
}
}
}
# tftest modules=1 resources=2
```
```hcl
module "data-catalog-tag-template" {
source = "./fabric/modules/data-catalog-tag-template"
project_id = var.project_id
tag_templates = {
demo_var = {
region = "europe-west1"
display_name = "Demo Tag Template"
fields = {
source = {
display_name = "Source of data asset"
type = {
primitive_type = "STRING"
}
is_required = true
}
}
}
}
iam_bindings_additive = {
admin-with-delegated_roles = {
role = "roles/datacatalog.tagTemplateOwner"
member = "group:data-governance@example.com"
condition = {
title = "delegated-role-grants"
expression = format(
"api.getAttribute('iam.googleapis.com/modifiedGrantsByRole', []).hasOnly([%s])",
join(",", formatlist("'%s'",
[
"roles/datacatalog.tagTemplateOwner"
]
))
)
}
}
}
}
# tftest modules=1 resources=2
```
### Factory
Similarly to other modules, a rules factory (see [Resource Factories](../../blueprints/factories/)) is also included here to allow tag template management via descriptive configuration files.
Factory configuration is via one optional attributes in the `factory_config_path` variable specifying the path where tag template files are stored.
Factory tag templates are merged with rules declared in code, with the latter taking precedence where both use the same key.
The name of the file will be used as `tag_template_id` field.
This is an example of a simple factory:
```hcl
module "data-catalog-tag-template" {
source = "./fabric/modules/data-catalog-tag-template"
project_id = "my-project"
tag_templates = {
demo_var = {
region = "europe-west1"
display_name = "Demo Tag Template"
fields = {
source = {
display_name = "Source of data asset"
type = {
primitive_type = "STRING"
}
is_required = true
}
}
}
}
factories_config = {
tag_templates = "data"
}
}
# tftest modules=1 resources=2 files=demo_tag
```
```yaml
# tftest-file id=demo_tag path=data/demo.yaml
region: europe-west2
display_name: Demo Tag Template
fields:
source:
display_name: Source of data asset
type:
primitive_type: STRING
is_required: true
pii_type:
display_name: PII type
type:
enum_type:
- EMAIL
- SOCIAL SECURITY NUMBER
- NONE
```
<!-- BEGIN TFDOC -->
## Variables
| name | description | type | required | default |
|---|---|:---:|:---:|:---:|
| [project_id](variables.tf#L62) | Id of the project where Tag Templates will be created. | <code>string</code> | ✓ | |
| [factories_config](variables.tf#L17) | Paths to data files and folders that enable factory functionality. | <code title="object&#40;&#123;&#10; tag_templates &#61; optional&#40;string&#41;&#10;&#125;&#41;">object&#40;&#123;&#8230;&#125;&#41;</code> | | <code>&#123;&#125;</code> |
| [iam](variables.tf#L26) | IAM bindings in {ROLE => [MEMBERS]} format. | <code>map&#40;list&#40;string&#41;&#41;</code> | | <code>&#123;&#125;</code> |
| [iam_bindings](variables.tf#L32) | Authoritative IAM bindings in {KEY => {role = ROLE, members = [], condition = {}}}. Keys are arbitrary. | <code title="map&#40;object&#40;&#123;&#10; members &#61; list&#40;string&#41;&#10; role &#61; string&#10; condition &#61; optional&#40;object&#40;&#123;&#10; expression &#61; string&#10; title &#61; string&#10; description &#61; optional&#40;string&#41;&#10; &#125;&#41;&#41;&#10;&#125;&#41;&#41;">map&#40;object&#40;&#123;&#8230;&#125;&#41;&#41;</code> | | <code>&#123;&#125;</code> |
| [iam_bindings_additive](variables.tf#L47) | Individual additive IAM bindings. Keys are arbitrary. | <code title="map&#40;object&#40;&#123;&#10; member &#61; string&#10; role &#61; string&#10; condition &#61; optional&#40;object&#40;&#123;&#10; expression &#61; string&#10; title &#61; string&#10; description &#61; optional&#40;string&#41;&#10; &#125;&#41;&#41;&#10;&#125;&#41;&#41;">map&#40;object&#40;&#123;&#8230;&#125;&#41;&#41;</code> | | <code>&#123;&#125;</code> |
| [tag_templates](variables.tf#L67) | Tag templates definitions in the form {TAG_TEMPLATE_ID => TEMPLATE_DEFINITION}. | <code title="map&#40;object&#40;&#123;&#10; display_name &#61; optional&#40;string&#41;&#10; force_delete &#61; optional&#40;bool, false&#41;&#10; region &#61; string&#10; fields &#61; map&#40;object&#40;&#123;&#10; display_name &#61; optional&#40;string&#41;&#10; description &#61; optional&#40;string&#41;&#10; type &#61; object&#40;&#123;&#10; primitive_type &#61; optional&#40;string&#41;&#10; enum_type &#61; optional&#40;list&#40;object&#40;&#123;&#10; allowed_values &#61; object&#40;&#123;&#10; display_name &#61; string&#10; &#125;&#41;&#10; &#125;&#41;&#41;, null&#41;&#10; &#125;&#41;&#10; is_required &#61; optional&#40;bool, false&#41;&#10; order &#61; optional&#40;number&#41;&#10; &#125;&#41;&#41;&#10;&#125;&#41;&#41;">map&#40;object&#40;&#123;&#8230;&#125;&#41;&#41;</code> | | <code>&#123;&#125;</code> |
## Outputs
| name | description | sensitive |
|---|---|:---:|
| [data_catalog_tag_template_ids](outputs.tf#L17) | Data catalog tag template ids. | |
| [data_catalog_tag_templates](outputs.tf#L22) | Data catalog tag templates. | |
<!-- END TFDOC -->