From f9e7efaebdb321d8ced15e00a7c96c0fcfcb96fb Mon Sep 17 00:00:00 2001 From: oleh_mykolaishyn Date: Mon, 26 Feb 2024 12:09:54 +0200 Subject: [PATCH 1/2] fix: support system schemas --- main.tf | 6 ++++++ variables.tf | 12 ++++++++++++ 2 files changed, 18 insertions(+) diff --git a/main.tf b/main.tf index 6dae451..a8edc49 100644 --- a/main.tf +++ b/main.tf @@ -51,3 +51,9 @@ resource "databricks_sql_endpoint" "this" { } depends_on = [databricks_sql_global_config.this] } + +resource "databricks_system_schema" "this" { + for_each = var.system_schemas_enabled ? var.system_schemas : toset([]) + + schema = each.value +} diff --git a/variables.tf b/variables.tf index 51eb7f6..515600f 100644 --- a/variables.tf +++ b/variables.tf @@ -231,3 +231,15 @@ variable "mount_cluster_name" { description = "Name of the cluster that will be used during storage mounting. If mount_adls_passthrough == true, cluster should also have option cluster_conf_passthrought == true" default = null } + +variable "system_schemas" { + type = set(string) + description = "Set of strings with all possible System Schema names" + default = ["access", "billing", "compute", "marketplace", "storage"] +} + +variable "system_schemas_enabled" { + type = bool + description = "System Schemas only works with assigned Unity Catalog Metastore. Boolean flag to enabled this feature" + default = false +} From ffb140cc2732aaf427234647ae405df54f4a54fa Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Mon, 26 Feb 2024 10:10:24 +0000 Subject: [PATCH 2/2] terraform-docs: automated action --- README.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/README.md b/README.md index e886871..2790a57 100644 --- a/README.md +++ b/README.md @@ -202,6 +202,7 @@ No modules. | [databricks_service_principal.this](https://registry.terraform.io/providers/databricks/databricks/latest/docs/resources/service_principal) | resource | | [databricks_sql_endpoint.this](https://registry.terraform.io/providers/databricks/databricks/latest/docs/resources/sql_endpoint) | resource | | [databricks_sql_global_config.this](https://registry.terraform.io/providers/databricks/databricks/latest/docs/resources/sql_global_config) | resource | +| [databricks_system_schema.this](https://registry.terraform.io/providers/databricks/databricks/latest/docs/resources/system_schema) | resource | | [databricks_token.pat](https://registry.terraform.io/providers/databricks/databricks/latest/docs/resources/token) | resource | | [databricks_user.this](https://registry.terraform.io/providers/databricks/databricks/latest/docs/resources/user) | resource | | [databricks_workspace_conf.this](https://registry.terraform.io/providers/databricks/databricks/latest/docs/resources/workspace_conf) | resource | @@ -231,6 +232,8 @@ No modules. | [secret\_scope](#input\_secret\_scope) | Provides an ability to create custom Secret Scope, store secrets in it and assigning ACL for access management
scope\_name - name of Secret Scope to create;
acl - list of objects, where 'principal' custom group name, this group is created in 'Premium' module; 'permission' is one of "READ", "WRITE", "MANAGE";
secrets - list of objects, where object's 'key' param is created key name and 'string\_value' is a value for it; |
list(object({
scope_name = string
acl = optional(list(object({
principal = string
permission = string
})))
secrets = optional(list(object({
key = string
string_value = string
})))
}))
|
[
{
"acl": null,
"scope_name": null,
"secrets": null
}
]
| no | | [sql\_endpoint](#input\_sql\_endpoint) | Set of objects with parameters to configure SQL Endpoint and assign permissions to it for certain custom groups |
set(object({
name = string
cluster_size = optional(string, "2X-Small")
min_num_clusters = optional(number, 0)
max_num_clusters = optional(number, 1)
auto_stop_mins = optional(string, "30")
enable_photon = optional(bool, false)
enable_serverless_compute = optional(bool, false)
spot_instance_policy = optional(string, "COST_OPTIMIZED")
warehouse_type = optional(string, "PRO")
permissions = optional(set(object({
group_name = string
permission_level = string
})), [])
}))
| `[]` | no | | [suffix](#input\_suffix) | Optional suffix that would be added to the end of resources names. | `string` | `""` | no | +| [system\_schemas](#input\_system\_schemas) | Set of strings with all possible System Schema names | `set(string)` |
[
"access",
"billing",
"compute",
"marketplace",
"storage"
]
| no | +| [system\_schemas\_enabled](#input\_system\_schemas\_enabled) | System Schemas only works with assigned Unity Catalog Metastore. Boolean flag to enabled this feature | `bool` | `false` | no | | [user\_object\_ids](#input\_user\_object\_ids) | Map of AD usernames and corresponding object IDs | `map(string)` | `{}` | no | | [workspace\_admins](#input\_workspace\_admins) | Provide users or service principals to grant them Admin permissions in Workspace. |
object({
user = list(string)
service_principal = list(string)
})
|
{
"service_principal": null,
"user": null
}
| no |