error_message = "Datascan data must specify one of 'entity', 'resource'."
}
}
variable"data_profile_spec"{
description = "DataProfileScan related setting. Variable descriptions are provided in https://cloud.google.com/dataplex/docs/reference/rest/v1/DataProfileSpec."
default = null
type = object({
sampling_percent = optional(number)
row_filter = optional(string)
})
}
variable"data_quality_spec"{
description = "DataQualityScan related setting. Variable descriptions are provided in https://cloud.google.com/dataplex/docs/reference/rest/v1/DataQualitySpec."
default = null
type = object({
sampling_percent = optional(number)
row_filter = optional(string)
rules = list(object({
column = optional(string)
ignore_null = optional(bool,null)
dimension = string
threshold = optional(number)
non_null_expectation = optional(object({}))
range_expectation = optional(object({
min_value = optional(number)
max_value = optional(number)
strict_min_enabled = optional(bool)
strict_max_enabled = optional(bool)
}))
regex_expectation = optional(object({
regex = string
}))
set_expectation = optional(object({
values = list(string)
}))
uniqueness_expectation = optional(object({}))
statistic_range_expectation = optional(object({
statistic = string
min_value = optional(number)
max_value = optional(number)
strict_min_enabled = optional(bool)
strict_max_enabled = optional(bool)
}))
row_condition_expectation = optional(object({
sql_expression = string
}))
table_condition_expectation = optional(object({
sql_expression = string
}))
}))
})
}
variable"data_quality_spec_file"{
description = "Path to a YAML file containing DataQualityScan related setting. Input content can use either camelCase or snake_case. Variables description are provided in https://cloud.google.com/dataplex/docs/reference/rest/v1/DataQualitySpec."
default = null
type = object({
path = string
})
}
variable"description"{
description = "Custom description for DataScan."
default = null
type = string
}
variable"execution_schedule"{
description = "Schedule DataScan to run periodically based on a cron schedule expression. If not specified, the DataScan is created with `on_demand` schedule, which means it will not run until the user calls `dataScans.run` API."
type = string
default = null
}
variable"group_iam"{
description = "Authoritative IAM binding for organization groups, in {GROUP_EMAIL => [ROLES]} format. Group emails need to be static. Can be used in combination with the `iam` variable."
type = map(list(string))
default = {}
nullable = false
}
variable"iam"{
description = "Dataplex DataScan IAM bindings in {ROLE => [MEMBERS]} format."
type = map(list(string))
default = {}
nullable = false
}
variable"iam_additive"{
description = "IAM additive bindings in {ROLE => [MEMBERS]} format."
type = map(list(string))
default = {}
nullable = false
}
variable"iam_additive_members"{
description = "IAM additive bindings in {MEMBERS => [ROLE]} format. This might break if members are dynamic values."
description = "Individual additive IAM bindings, use this when iam_additive does not work due to dynamic resources. Keys are arbitrary and only used for the internal loop."
description = "IAM authoritative policy in {ROLE => [MEMBERS]} format. Roles and members not explicitly listed will be cleared, use with extreme caution."
type = map(list(string))
default = null
}
variable"incremental_field"{
description = "The unnested field (of type Date or Timestamp) that contains values which monotonically increase over time. If not specified, a data scan will run for all data in the table."
type = string
default = null
}
variable"labels"{
description = "Resource labels."
type = map(string)
default = {}
nullable = false
}
variable"name"{
description = "Name of Dataplex Scan."
type = string
}
variable"prefix"{
description = "Optional prefix used to generate Dataplex DataScan ID."
type = string
default = null
}
variable"project_id"{
description = "The ID of the project where the Dataplex DataScan will be created."