diff --git a/.codegen.json b/.codegen.json index 3e2cd7a6a5..79a5d8cb8e 100644 --- a/.codegen.json +++ b/.codegen.json @@ -1,5 +1,8 @@ { "formatter": "make fmt", + "packages": { + ".codegen/model.go.tmpl": "internal/service/{{.Name}}_tf/model.go" + }, "changelog_config": ".codegen/changelog_config.yml", "version": { "common/version.go": "version = \"$VERSION\"" diff --git a/.codegen/model.go.tmpl b/.codegen/model.go.tmpl new file mode 100644 index 0000000000..84d635be44 --- /dev/null +++ b/.codegen/model.go.tmpl @@ -0,0 +1,54 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package {{.Name}}_tf + +import ( + {{range .ImportedPackages}} + "github.com/databricks/databricks-sdk-go/service/{{.}}"{{end}} + "github.com/databricks/databricks-sdk-go/service/{{.Name}}" + "io" + "github.com/databricks/databricks-sdk-go/marshal" + "github.com/hashicorp/terraform-plugin-framework/types" +) +{{range .Types}} +{{- if or .Fields .IsEmpty}} +{{.Comment "// " 80}} +type {{.PascalName}} struct { + {{- range .Fields}} + {{.Comment " // " 80}} + {{.PascalName}} {{if .IsOptionalObject}}*{{end}}{{template "type" .Entity}} `{{template "field-tag" . }}`{{end}} +} + +{{end}} +{{end}} + +{{- define "field-tag" -}} + {{if .IsJson}}tfsdk:"{{.Name}}" tf:"{{if not .Required}}optional{{end}}"{{else}}tfsdk:"-"{{end -}} +{{- end -}} + +{{- define "type" -}} + {{- if not . }}any /* ERROR */ + {{- else if .IsExternal }}{{.Package.Name}}.{{.PascalName}} + {{- else if .IsAny}}any + {{- else if .IsEmpty}}{{.PascalName}} + {{- else if .IsString}}types.String + {{- else if .IsBool}}types.Bool + {{- else if .IsInt64}}types.Int64 + {{- else if .IsFloat64}}types.Float64 + {{- else if .IsInt}}types.Int64 + {{- else if .IsByteStream}}io.ReadCloser + {{- else if .ArrayValue }}[]{{template "type" .ArrayValue}} + {{- else if .MapValue }}map[string]{{template "type" .MapValue}} + {{- else if .IsObject }}{{.PascalName}} + {{- else if .Enum }}types.String + {{- else}}any /* MISSING TYPE */ + {{- end -}} +{{- end -}} diff --git a/.gitattributes b/.gitattributes index e69de29bb2..de998c3b19 100755 --- a/.gitattributes +++ b/.gitattributes @@ -0,0 +1,18 @@ +internal/service/billing_tf/model.go linguist-generated=true +internal/service/catalog_tf/model.go linguist-generated=true +internal/service/compute_tf/model.go linguist-generated=true +internal/service/dashboards_tf/model.go linguist-generated=true +internal/service/files_tf/model.go linguist-generated=true +internal/service/iam_tf/model.go linguist-generated=true +internal/service/jobs_tf/model.go linguist-generated=true +internal/service/marketplace_tf/model.go linguist-generated=true +internal/service/ml_tf/model.go linguist-generated=true +internal/service/oauth2_tf/model.go linguist-generated=true +internal/service/pipelines_tf/model.go linguist-generated=true +internal/service/provisioning_tf/model.go linguist-generated=true +internal/service/serving_tf/model.go linguist-generated=true +internal/service/settings_tf/model.go linguist-generated=true +internal/service/sharing_tf/model.go linguist-generated=true +internal/service/sql_tf/model.go linguist-generated=true +internal/service/vectorsearch_tf/model.go linguist-generated=true +internal/service/workspace_tf/model.go linguist-generated=true diff --git a/internal/service/billing_tf/model.go b/internal/service/billing_tf/model.go new file mode 100755 index 0000000000..6354863a61 --- /dev/null +++ b/internal/service/billing_tf/model.go @@ -0,0 +1,381 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package billing_tf + +import ( + "io" + + "github.com/hashicorp/terraform-plugin-framework/types" +) + +// Budget configuration to be created. +type Budget struct { + Alerts []BudgetAlert `tfsdk:"alerts" tf:"optional"` + // Optional end date of the budget. + EndDate types.String `tfsdk:"end_date" tf:"optional"` + // SQL-like filter expression with workspaceId, SKU and tag. Usage in your + // account that matches this expression will be counted in this budget. + // + // Supported properties on left-hand side of comparison: * `workspaceId` - + // the ID of the workspace * `sku` - SKU of the cluster, e.g. + // `STANDARD_ALL_PURPOSE_COMPUTE` * `tag.tagName`, `tag.'tag name'` - tag of + // the cluster + // + // Supported comparison operators: * `=` - equal * `!=` - not equal + // + // Supported logical operators: `AND`, `OR`. + // + // Examples: * `workspaceId=123 OR (sku='STANDARD_ALL_PURPOSE_COMPUTE' AND + // tag.'my tag'='my value')` * `workspaceId!=456` * + // `sku='STANDARD_ALL_PURPOSE_COMPUTE' OR sku='PREMIUM_ALL_PURPOSE_COMPUTE'` + // * `tag.name1='value1' AND tag.name2='value2'` + Filter types.String `tfsdk:"filter" tf:""` + // Human-readable name of the budget. + Name types.String `tfsdk:"name" tf:""` + // Period length in years, months, weeks and/or days. Examples: `1 month`, + // `30 days`, `1 year, 2 months, 1 week, 2 days` + Period types.String `tfsdk:"period" tf:""` + // Start date of the budget period calculation. + StartDate types.String `tfsdk:"start_date" tf:""` + // Target amount of the budget per period in USD. + TargetAmount types.String `tfsdk:"target_amount" tf:""` +} + +type BudgetAlert struct { + // List of email addresses to be notified when budget percentage is exceeded + // in the given period. + EmailNotifications []types.String `tfsdk:"email_notifications" tf:"optional"` + // Percentage of the target amount used in the currect period that will + // trigger a notification. + MinPercentage types.Int64 `tfsdk:"min_percentage" tf:"optional"` +} + +// List of budgets. +type BudgetList struct { + Budgets []BudgetWithStatus `tfsdk:"budgets" tf:"optional"` +} + +// Budget configuration with daily status. +type BudgetWithStatus struct { + Alerts []BudgetAlert `tfsdk:"alerts" tf:"optional"` + + BudgetId types.String `tfsdk:"budget_id" tf:"optional"` + + CreationTime types.String `tfsdk:"creation_time" tf:"optional"` + // Optional end date of the budget. + EndDate types.String `tfsdk:"end_date" tf:"optional"` + // SQL-like filter expression with workspaceId, SKU and tag. Usage in your + // account that matches this expression will be counted in this budget. + // + // Supported properties on left-hand side of comparison: * `workspaceId` - + // the ID of the workspace * `sku` - SKU of the cluster, e.g. + // `STANDARD_ALL_PURPOSE_COMPUTE` * `tag.tagName`, `tag.'tag name'` - tag of + // the cluster + // + // Supported comparison operators: * `=` - equal * `!=` - not equal + // + // Supported logical operators: `AND`, `OR`. + // + // Examples: * `workspaceId=123 OR (sku='STANDARD_ALL_PURPOSE_COMPUTE' AND + // tag.'my tag'='my value')` * `workspaceId!=456` * + // `sku='STANDARD_ALL_PURPOSE_COMPUTE' OR sku='PREMIUM_ALL_PURPOSE_COMPUTE'` + // * `tag.name1='value1' AND tag.name2='value2'` + Filter types.String `tfsdk:"filter" tf:"optional"` + // Human-readable name of the budget. + Name types.String `tfsdk:"name" tf:"optional"` + // Period length in years, months, weeks and/or days. Examples: `1 month`, + // `30 days`, `1 year, 2 months, 1 week, 2 days` + Period types.String `tfsdk:"period" tf:"optional"` + // Start date of the budget period calculation. + StartDate types.String `tfsdk:"start_date" tf:"optional"` + // Amount used in the budget for each day (noncumulative). + StatusDaily []BudgetWithStatusStatusDailyItem `tfsdk:"status_daily" tf:"optional"` + // Target amount of the budget per period in USD. + TargetAmount types.String `tfsdk:"target_amount" tf:"optional"` + + UpdateTime types.String `tfsdk:"update_time" tf:"optional"` +} + +type BudgetWithStatusStatusDailyItem struct { + // Amount used in this day in USD. + Amount types.String `tfsdk:"amount" tf:"optional"` + + Date types.String `tfsdk:"date" tf:"optional"` +} + +type CreateLogDeliveryConfigurationParams struct { + // The optional human-readable name of the log delivery configuration. + // Defaults to empty. + ConfigName types.String `tfsdk:"config_name" tf:"optional"` + // The ID for a method:credentials/create that represents the AWS IAM role + // with policy and trust relationship as described in the main billable + // usage documentation page. See [Configure billable usage delivery]. + // + // [Configure billable usage delivery]: https://docs.databricks.com/administration-guide/account-settings/billable-usage-delivery.html + CredentialsId types.String `tfsdk:"credentials_id" tf:""` + // The optional delivery path prefix within Amazon S3 storage. Defaults to + // empty, which means that logs are delivered to the root of the bucket. + // This must be a valid S3 object key. This must not start or end with a + // slash character. + DeliveryPathPrefix types.String `tfsdk:"delivery_path_prefix" tf:"optional"` + // This field applies only if `log_type` is `BILLABLE_USAGE`. This is the + // optional start month and year for delivery, specified in `YYYY-MM` + // format. Defaults to current year and month. `BILLABLE_USAGE` logs are not + // available for usage before March 2019 (`2019-03`). + DeliveryStartTime types.String `tfsdk:"delivery_start_time" tf:"optional"` + // Log delivery type. Supported values are: + // + // * `BILLABLE_USAGE` — Configure [billable usage log delivery]. For the + // CSV schema, see the [View billable usage]. + // + // * `AUDIT_LOGS` — Configure [audit log delivery]. For the JSON schema, + // see [Configure audit logging] + // + // [Configure audit logging]: https://docs.databricks.com/administration-guide/account-settings/audit-logs.html + // [View billable usage]: https://docs.databricks.com/administration-guide/account-settings/usage.html + // [audit log delivery]: https://docs.databricks.com/administration-guide/account-settings/audit-logs.html + // [billable usage log delivery]: https://docs.databricks.com/administration-guide/account-settings/billable-usage-delivery.html + LogType types.String `tfsdk:"log_type" tf:""` + // The file type of log delivery. + // + // * If `log_type` is `BILLABLE_USAGE`, this value must be `CSV`. Only the + // CSV (comma-separated values) format is supported. For the schema, see the + // [View billable usage] * If `log_type` is `AUDIT_LOGS`, this value must be + // `JSON`. Only the JSON (JavaScript Object Notation) format is supported. + // For the schema, see the [Configuring audit logs]. + // + // [Configuring audit logs]: https://docs.databricks.com/administration-guide/account-settings/audit-logs.html + // [View billable usage]: https://docs.databricks.com/administration-guide/account-settings/usage.html + OutputFormat types.String `tfsdk:"output_format" tf:""` + // Status of log delivery configuration. Set to `ENABLED` (enabled) or + // `DISABLED` (disabled). Defaults to `ENABLED`. You can [enable or disable + // the configuration](#operation/patch-log-delivery-config-status) later. + // Deletion of a configuration is not supported, so disable a log delivery + // configuration that is no longer needed. + Status types.String `tfsdk:"status" tf:"optional"` + // The ID for a method:storage/create that represents the S3 bucket with + // bucket policy as described in the main billable usage documentation page. + // See [Configure billable usage delivery]. + // + // [Configure billable usage delivery]: https://docs.databricks.com/administration-guide/account-settings/billable-usage-delivery.html + StorageConfigurationId types.String `tfsdk:"storage_configuration_id" tf:""` + // Optional filter that specifies workspace IDs to deliver logs for. By + // default the workspace filter is empty and log delivery applies at the + // account level, delivering workspace-level logs for all workspaces in your + // account, plus account level logs. You can optionally set this field to an + // array of workspace IDs (each one is an `int64`) to which log delivery + // should apply, in which case only workspace-level logs relating to the + // specified workspaces are delivered. If you plan to use different log + // delivery configurations for different workspaces, set this field + // explicitly. Be aware that delivery configurations mentioning specific + // workspaces won't apply to new workspaces created in the future, and + // delivery won't include account level logs. For some types of Databricks + // deployments there is only one workspace per account ID, so this field is + // unnecessary. + WorkspaceIdsFilter []types.Int64 `tfsdk:"workspace_ids_filter" tf:"optional"` +} + +// Delete budget +type DeleteBudgetRequest struct { + // Budget ID + BudgetId types.String `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +// Return billable usage logs +type DownloadRequest struct { + // Format: `YYYY-MM`. Last month to return billable usage logs for. This + // field is required. + EndMonth types.String `tfsdk:"-"` + // Specify whether to include personally identifiable information in the + // billable usage logs, for example the email addresses of cluster creators. + // Handle this information with care. Defaults to false. + PersonalData types.Bool `tfsdk:"-"` + // Format: `YYYY-MM`. First month to return billable usage logs for. This + // field is required. + StartMonth types.String `tfsdk:"-"` +} + +type DownloadResponse struct { + Contents io.ReadCloser `tfsdk:"-"` +} + +// Get budget and its status +type GetBudgetRequest struct { + // Budget ID + BudgetId types.String `tfsdk:"-"` +} + +// Get log delivery configuration +type GetLogDeliveryRequest struct { + // Databricks log delivery configuration ID + LogDeliveryConfigurationId types.String `tfsdk:"-"` +} + +// Get all log delivery configurations +type ListLogDeliveryRequest struct { + // Filter by credential configuration ID. + CredentialsId types.String `tfsdk:"-"` + // Filter by status `ENABLED` or `DISABLED`. + Status types.String `tfsdk:"-"` + // Filter by storage configuration ID. + StorageConfigurationId types.String `tfsdk:"-"` +} + +type LogDeliveryConfiguration struct { + // The Databricks account ID that hosts the log delivery configuration. + AccountId types.String `tfsdk:"account_id" tf:"optional"` + // Databricks log delivery configuration ID. + ConfigId types.String `tfsdk:"config_id" tf:"optional"` + // The optional human-readable name of the log delivery configuration. + // Defaults to empty. + ConfigName types.String `tfsdk:"config_name" tf:"optional"` + // Time in epoch milliseconds when the log delivery configuration was + // created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // The ID for a method:credentials/create that represents the AWS IAM role + // with policy and trust relationship as described in the main billable + // usage documentation page. See [Configure billable usage delivery]. + // + // [Configure billable usage delivery]: https://docs.databricks.com/administration-guide/account-settings/billable-usage-delivery.html + CredentialsId types.String `tfsdk:"credentials_id" tf:"optional"` + // The optional delivery path prefix within Amazon S3 storage. Defaults to + // empty, which means that logs are delivered to the root of the bucket. + // This must be a valid S3 object key. This must not start or end with a + // slash character. + DeliveryPathPrefix types.String `tfsdk:"delivery_path_prefix" tf:"optional"` + // This field applies only if `log_type` is `BILLABLE_USAGE`. This is the + // optional start month and year for delivery, specified in `YYYY-MM` + // format. Defaults to current year and month. `BILLABLE_USAGE` logs are not + // available for usage before March 2019 (`2019-03`). + DeliveryStartTime types.String `tfsdk:"delivery_start_time" tf:"optional"` + // Databricks log delivery status. + LogDeliveryStatus *LogDeliveryStatus `tfsdk:"log_delivery_status" tf:"optional"` + // Log delivery type. Supported values are: + // + // * `BILLABLE_USAGE` — Configure [billable usage log delivery]. For the + // CSV schema, see the [View billable usage]. + // + // * `AUDIT_LOGS` — Configure [audit log delivery]. For the JSON schema, + // see [Configure audit logging] + // + // [Configure audit logging]: https://docs.databricks.com/administration-guide/account-settings/audit-logs.html + // [View billable usage]: https://docs.databricks.com/administration-guide/account-settings/usage.html + // [audit log delivery]: https://docs.databricks.com/administration-guide/account-settings/audit-logs.html + // [billable usage log delivery]: https://docs.databricks.com/administration-guide/account-settings/billable-usage-delivery.html + LogType types.String `tfsdk:"log_type" tf:"optional"` + // The file type of log delivery. + // + // * If `log_type` is `BILLABLE_USAGE`, this value must be `CSV`. Only the + // CSV (comma-separated values) format is supported. For the schema, see the + // [View billable usage] * If `log_type` is `AUDIT_LOGS`, this value must be + // `JSON`. Only the JSON (JavaScript Object Notation) format is supported. + // For the schema, see the [Configuring audit logs]. + // + // [Configuring audit logs]: https://docs.databricks.com/administration-guide/account-settings/audit-logs.html + // [View billable usage]: https://docs.databricks.com/administration-guide/account-settings/usage.html + OutputFormat types.String `tfsdk:"output_format" tf:"optional"` + // Status of log delivery configuration. Set to `ENABLED` (enabled) or + // `DISABLED` (disabled). Defaults to `ENABLED`. You can [enable or disable + // the configuration](#operation/patch-log-delivery-config-status) later. + // Deletion of a configuration is not supported, so disable a log delivery + // configuration that is no longer needed. + Status types.String `tfsdk:"status" tf:"optional"` + // The ID for a method:storage/create that represents the S3 bucket with + // bucket policy as described in the main billable usage documentation page. + // See [Configure billable usage delivery]. + // + // [Configure billable usage delivery]: https://docs.databricks.com/administration-guide/account-settings/billable-usage-delivery.html + StorageConfigurationId types.String `tfsdk:"storage_configuration_id" tf:"optional"` + // Time in epoch milliseconds when the log delivery configuration was + // updated. + UpdateTime types.Int64 `tfsdk:"update_time" tf:"optional"` + // Optional filter that specifies workspace IDs to deliver logs for. By + // default the workspace filter is empty and log delivery applies at the + // account level, delivering workspace-level logs for all workspaces in your + // account, plus account level logs. You can optionally set this field to an + // array of workspace IDs (each one is an `int64`) to which log delivery + // should apply, in which case only workspace-level logs relating to the + // specified workspaces are delivered. If you plan to use different log + // delivery configurations for different workspaces, set this field + // explicitly. Be aware that delivery configurations mentioning specific + // workspaces won't apply to new workspaces created in the future, and + // delivery won't include account level logs. For some types of Databricks + // deployments there is only one workspace per account ID, so this field is + // unnecessary. + WorkspaceIdsFilter []types.Int64 `tfsdk:"workspace_ids_filter" tf:"optional"` +} + +// Databricks log delivery status. +type LogDeliveryStatus struct { + // The UTC time for the latest log delivery attempt. + LastAttemptTime types.String `tfsdk:"last_attempt_time" tf:"optional"` + // The UTC time for the latest successful log delivery. + LastSuccessfulAttemptTime types.String `tfsdk:"last_successful_attempt_time" tf:"optional"` + // Informative message about the latest log delivery attempt. If the log + // delivery fails with USER_FAILURE, error details will be provided for + // fixing misconfigurations in cloud permissions. + Message types.String `tfsdk:"message" tf:"optional"` + // The status string for log delivery. Possible values are: * `CREATED`: + // There were no log delivery attempts since the config was created. * + // `SUCCEEDED`: The latest attempt of log delivery has succeeded completely. + // * `USER_FAILURE`: The latest attempt of log delivery failed because of + // misconfiguration of customer provided permissions on role or storage. * + // `SYSTEM_FAILURE`: The latest attempt of log delivery failed because of an + // Databricks internal error. Contact support if it doesn't go away soon. * + // `NOT_FOUND`: The log delivery status as the configuration has been + // disabled since the release of this feature or there are no workspaces in + // the account. + Status types.String `tfsdk:"status" tf:"optional"` +} + +type PatchStatusResponse struct { +} + +type UpdateLogDeliveryConfigurationStatusRequest struct { + // Databricks log delivery configuration ID + LogDeliveryConfigurationId types.String `tfsdk:"-"` + // Status of log delivery configuration. Set to `ENABLED` (enabled) or + // `DISABLED` (disabled). Defaults to `ENABLED`. You can [enable or disable + // the configuration](#operation/patch-log-delivery-config-status) later. + // Deletion of a configuration is not supported, so disable a log delivery + // configuration that is no longer needed. + Status types.String `tfsdk:"status" tf:""` +} + +type UpdateResponse struct { +} + +type WrappedBudget struct { + // Budget configuration to be created. + Budget Budget `tfsdk:"budget" tf:""` + // Budget ID + BudgetId types.String `tfsdk:"-"` +} + +type WrappedBudgetWithStatus struct { + // Budget configuration with daily status. + Budget BudgetWithStatus `tfsdk:"budget" tf:""` +} + +type WrappedCreateLogDeliveryConfiguration struct { + LogDeliveryConfiguration *CreateLogDeliveryConfigurationParams `tfsdk:"log_delivery_configuration" tf:"optional"` +} + +type WrappedLogDeliveryConfiguration struct { + LogDeliveryConfiguration *LogDeliveryConfiguration `tfsdk:"log_delivery_configuration" tf:"optional"` +} + +type WrappedLogDeliveryConfigurations struct { + LogDeliveryConfigurations []LogDeliveryConfiguration `tfsdk:"log_delivery_configurations" tf:"optional"` +} diff --git a/internal/service/catalog_tf/model.go b/internal/service/catalog_tf/model.go new file mode 100755 index 0000000000..b15e87ffef --- /dev/null +++ b/internal/service/catalog_tf/model.go @@ -0,0 +1,2666 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package catalog_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type AccountsCreateMetastore struct { + MetastoreInfo *CreateMetastore `tfsdk:"metastore_info" tf:"optional"` +} + +type AccountsCreateMetastoreAssignment struct { + MetastoreAssignment *CreateMetastoreAssignment `tfsdk:"metastore_assignment" tf:"optional"` + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` + // Workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type AccountsCreateStorageCredential struct { + CredentialInfo *CreateStorageCredential `tfsdk:"credential_info" tf:"optional"` + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` +} + +type AccountsMetastoreAssignment struct { + MetastoreAssignment *MetastoreAssignment `tfsdk:"metastore_assignment" tf:"optional"` +} + +type AccountsMetastoreInfo struct { + MetastoreInfo *MetastoreInfo `tfsdk:"metastore_info" tf:"optional"` +} + +type AccountsStorageCredentialInfo struct { + CredentialInfo *StorageCredentialInfo `tfsdk:"credential_info" tf:"optional"` +} + +type AccountsUpdateMetastore struct { + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` + + MetastoreInfo *UpdateMetastore `tfsdk:"metastore_info" tf:"optional"` +} + +type AccountsUpdateMetastoreAssignment struct { + MetastoreAssignment *UpdateMetastoreAssignment `tfsdk:"metastore_assignment" tf:"optional"` + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` + // Workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type AccountsUpdateStorageCredential struct { + CredentialInfo *UpdateStorageCredential `tfsdk:"credential_info" tf:"optional"` + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` + // Name of the storage credential. + StorageCredentialName types.String `tfsdk:"-"` +} + +type ArtifactAllowlistInfo struct { + // A list of allowed artifact match patterns. + ArtifactMatchers []ArtifactMatcher `tfsdk:"artifact_matchers" tf:"optional"` + // Time at which this artifact allowlist was set, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of the user who set the artifact allowlist. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Unique identifier of parent metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` +} + +type ArtifactMatcher struct { + // The artifact path or maven coordinate + Artifact types.String `tfsdk:"artifact" tf:""` + // The pattern matching type of the artifact + MatchType types.String `tfsdk:"match_type" tf:""` +} + +type AssignResponse struct { +} + +type AwsIamRoleRequest struct { + // The Amazon Resource Name (ARN) of the AWS IAM role for S3 data access. + RoleArn types.String `tfsdk:"role_arn" tf:""` +} + +type AwsIamRoleResponse struct { + // The external ID used in role assumption to prevent confused deputy + // problem.. + ExternalId types.String `tfsdk:"external_id" tf:"optional"` + // The Amazon Resource Name (ARN) of the AWS IAM role for S3 data access. + RoleArn types.String `tfsdk:"role_arn" tf:""` + // The Amazon Resource Name (ARN) of the AWS IAM user managed by Databricks. + // This is the identity that is going to assume the AWS IAM role. + UnityCatalogIamArn types.String `tfsdk:"unity_catalog_iam_arn" tf:"optional"` +} + +type AzureManagedIdentityRequest struct { + // The Azure resource ID of the Azure Databricks Access Connector. Use the + // format + // /subscriptions/{guid}/resourceGroups/{rg-name}/providers/Microsoft.Databricks/accessConnectors/{connector-name}. + AccessConnectorId types.String `tfsdk:"access_connector_id" tf:""` + // The Azure resource ID of the managed identity. Use the format + // /subscriptions/{guid}/resourceGroups/{rg-name}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identity-name}. + // This is only available for user-assgined identities. For system-assigned + // identities, the access_connector_id is used to identify the identity. If + // this field is not provided, then we assume the AzureManagedIdentity is + // for a system-assigned identity. + ManagedIdentityId types.String `tfsdk:"managed_identity_id" tf:"optional"` +} + +type AzureManagedIdentityResponse struct { + // The Azure resource ID of the Azure Databricks Access Connector. Use the + // format + // /subscriptions/{guid}/resourceGroups/{rg-name}/providers/Microsoft.Databricks/accessConnectors/{connector-name}. + AccessConnectorId types.String `tfsdk:"access_connector_id" tf:""` + // The Databricks internal ID that represents this managed identity. + CredentialId types.String `tfsdk:"credential_id" tf:"optional"` + // The Azure resource ID of the managed identity. Use the format + // /subscriptions/{guid}/resourceGroups/{rg-name}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identity-name}. + // This is only available for user-assgined identities. For system-assigned + // identities, the access_connector_id is used to identify the identity. If + // this field is not provided, then we assume the AzureManagedIdentity is + // for a system-assigned identity. + ManagedIdentityId types.String `tfsdk:"managed_identity_id" tf:"optional"` +} + +type AzureServicePrincipal struct { + // The application ID of the application registration within the referenced + // AAD tenant. + ApplicationId types.String `tfsdk:"application_id" tf:""` + // The client secret generated for the above app ID in AAD. + ClientSecret types.String `tfsdk:"client_secret" tf:""` + // The directory ID corresponding to the Azure Active Directory (AAD) tenant + // of the application. + DirectoryId types.String `tfsdk:"directory_id" tf:""` +} + +// Cancel refresh +type CancelRefreshRequest struct { + // ID of the refresh. + RefreshId types.String `tfsdk:"-"` + // Full name of the table. + TableName types.String `tfsdk:"-"` +} + +type CancelRefreshResponse struct { +} + +type CatalogInfo struct { + // Indicates whether the principal is limited to retrieving metadata for the + // associated object through the BROWSE privilege when include_browse is + // enabled in the request. + BrowseOnly types.Bool `tfsdk:"browse_only" tf:"optional"` + // The type of the catalog. + CatalogType types.String `tfsdk:"catalog_type" tf:"optional"` + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The name of the connection to an external data source. + ConnectionName types.String `tfsdk:"connection_name" tf:"optional"` + // Time at which this catalog was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of catalog creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + + EffectivePredictiveOptimizationFlag *EffectivePredictiveOptimizationFlag `tfsdk:"effective_predictive_optimization_flag" tf:"optional"` + // Whether predictive optimization should be enabled for this object and + // objects under it. + EnablePredictiveOptimization types.String `tfsdk:"enable_predictive_optimization" tf:"optional"` + // The full name of the catalog. Corresponds with the name field. + FullName types.String `tfsdk:"full_name" tf:"optional"` + // Whether the current securable is accessible from all workspaces or a + // specific set of workspaces. + IsolationMode types.String `tfsdk:"isolation_mode" tf:"optional"` + // Unique identifier of parent metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // Name of catalog. + Name types.String `tfsdk:"name" tf:"optional"` + // A map of key-value properties attached to the securable. + Options map[string]types.String `tfsdk:"options" tf:"optional"` + // Username of current owner of catalog. + Owner types.String `tfsdk:"owner" tf:"optional"` + // A map of key-value properties attached to the securable. + Properties map[string]types.String `tfsdk:"properties" tf:"optional"` + // The name of delta sharing provider. + // + // A Delta Sharing catalog is a catalog that is based on a Delta share on a + // remote sharing server. + ProviderName types.String `tfsdk:"provider_name" tf:"optional"` + // Status of an asynchronously provisioned resource. + ProvisioningInfo *ProvisioningInfo `tfsdk:"provisioning_info" tf:"optional"` + // Kind of catalog securable. + SecurableKind types.String `tfsdk:"securable_kind" tf:"optional"` + + SecurableType types.String `tfsdk:"securable_type" tf:"optional"` + // The name of the share under the share provider. + ShareName types.String `tfsdk:"share_name" tf:"optional"` + // Storage Location URL (full path) for managed tables within catalog. + StorageLocation types.String `tfsdk:"storage_location" tf:"optional"` + // Storage root URL for managed tables within catalog. + StorageRoot types.String `tfsdk:"storage_root" tf:"optional"` + // Time at which this catalog was last modified, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of user who last modified catalog. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type CloudflareApiToken struct { + // The Cloudflare access key id of the token. + AccessKeyId types.String `tfsdk:"access_key_id" tf:""` + // The account id associated with the API token. + AccountId types.String `tfsdk:"account_id" tf:""` + // The secret access token generated for the access key id + SecretAccessKey types.String `tfsdk:"secret_access_key" tf:""` +} + +type ColumnInfo struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + + Mask *ColumnMask `tfsdk:"mask" tf:"optional"` + // Name of Column. + Name types.String `tfsdk:"name" tf:"optional"` + // Whether field may be Null (default: true). + Nullable types.Bool `tfsdk:"nullable" tf:"optional"` + // Partition index for column. + PartitionIndex types.Int64 `tfsdk:"partition_index" tf:"optional"` + // Ordinal position of column (starting at position 0). + Position types.Int64 `tfsdk:"position" tf:"optional"` + // Format of IntervalType. + TypeIntervalType types.String `tfsdk:"type_interval_type" tf:"optional"` + // Full data type specification, JSON-serialized. + TypeJson types.String `tfsdk:"type_json" tf:"optional"` + // Name of type (INT, STRUCT, MAP, etc.). + TypeName types.String `tfsdk:"type_name" tf:"optional"` + // Digits of precision; required for DecimalTypes. + TypePrecision types.Int64 `tfsdk:"type_precision" tf:"optional"` + // Digits to right of decimal; Required for DecimalTypes. + TypeScale types.Int64 `tfsdk:"type_scale" tf:"optional"` + // Full data type specification as SQL/catalogString text. + TypeText types.String `tfsdk:"type_text" tf:"optional"` +} + +type ColumnMask struct { + // The full name of the column mask SQL UDF. + FunctionName types.String `tfsdk:"function_name" tf:"optional"` + // The list of additional table columns to be passed as input to the column + // mask function. The first arg of the mask function should be of the type + // of the column being masked and the types of the rest of the args should + // match the types of columns in 'using_column_names'. + UsingColumnNames []types.String `tfsdk:"using_column_names" tf:"optional"` +} + +type ConnectionInfo struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Unique identifier of the Connection. + ConnectionId types.String `tfsdk:"connection_id" tf:"optional"` + // The type of connection. + ConnectionType types.String `tfsdk:"connection_type" tf:"optional"` + // Time at which this connection was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of connection creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // The type of credential. + CredentialType types.String `tfsdk:"credential_type" tf:"optional"` + // Full name of connection. + FullName types.String `tfsdk:"full_name" tf:"optional"` + // Unique identifier of parent metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // Name of the connection. + Name types.String `tfsdk:"name" tf:"optional"` + // A map of key-value properties attached to the securable. + Options map[string]types.String `tfsdk:"options" tf:"optional"` + // Username of current owner of the connection. + Owner types.String `tfsdk:"owner" tf:"optional"` + // An object containing map of key-value properties attached to the + // connection. + Properties map[string]types.String `tfsdk:"properties" tf:"optional"` + // Status of an asynchronously provisioned resource. + ProvisioningInfo *ProvisioningInfo `tfsdk:"provisioning_info" tf:"optional"` + // If the connection is read only. + ReadOnly types.Bool `tfsdk:"read_only" tf:"optional"` + // Kind of connection securable. + SecurableKind types.String `tfsdk:"securable_kind" tf:"optional"` + + SecurableType types.String `tfsdk:"securable_type" tf:"optional"` + // Time at which this connection was updated, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of user who last modified connection. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` + // URL of the remote data source, extracted from options. + Url types.String `tfsdk:"url" tf:"optional"` +} + +// Detailed status of an online table. Shown if the online table is in the +// ONLINE_CONTINUOUS_UPDATE or the ONLINE_UPDATING_PIPELINE_RESOURCES state. +type ContinuousUpdateStatus struct { + // Progress of the initial data synchronization. + InitialPipelineSyncProgress *PipelineProgress `tfsdk:"initial_pipeline_sync_progress" tf:"optional"` + // The last source table Delta version that was synced to the online table. + // Note that this Delta version may not be completely synced to the online + // table yet. + LastProcessedCommitVersion types.Int64 `tfsdk:"last_processed_commit_version" tf:"optional"` + // The timestamp of the last time any data was synchronized from the source + // table to the online table. + Timestamp types.String `tfsdk:"timestamp" tf:"optional"` +} + +type CreateCatalog struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The name of the connection to an external data source. + ConnectionName types.String `tfsdk:"connection_name" tf:"optional"` + // Name of catalog. + Name types.String `tfsdk:"name" tf:""` + // A map of key-value properties attached to the securable. + Options map[string]types.String `tfsdk:"options" tf:"optional"` + // A map of key-value properties attached to the securable. + Properties map[string]types.String `tfsdk:"properties" tf:"optional"` + // The name of delta sharing provider. + // + // A Delta Sharing catalog is a catalog that is based on a Delta share on a + // remote sharing server. + ProviderName types.String `tfsdk:"provider_name" tf:"optional"` + // The name of the share under the share provider. + ShareName types.String `tfsdk:"share_name" tf:"optional"` + // Storage root URL for managed tables within catalog. + StorageRoot types.String `tfsdk:"storage_root" tf:"optional"` +} + +type CreateConnection struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The type of connection. + ConnectionType types.String `tfsdk:"connection_type" tf:""` + // Name of the connection. + Name types.String `tfsdk:"name" tf:""` + // A map of key-value properties attached to the securable. + Options map[string]types.String `tfsdk:"options" tf:""` + // An object containing map of key-value properties attached to the + // connection. + Properties map[string]types.String `tfsdk:"properties" tf:"optional"` + // If the connection is read only. + ReadOnly types.Bool `tfsdk:"read_only" tf:"optional"` +} + +type CreateExternalLocation struct { + // The AWS access point to use when accesing s3 for this external location. + AccessPoint types.String `tfsdk:"access_point" tf:"optional"` + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of the storage credential used with this location. + CredentialName types.String `tfsdk:"credential_name" tf:""` + // Encryption options that apply to clients connecting to cloud storage. + EncryptionDetails *EncryptionDetails `tfsdk:"encryption_details" tf:"optional"` + // Name of the external location. + Name types.String `tfsdk:"name" tf:""` + // Indicates whether the external location is read-only. + ReadOnly types.Bool `tfsdk:"read_only" tf:"optional"` + // Skips validation of the storage credential associated with the external + // location. + SkipValidation types.Bool `tfsdk:"skip_validation" tf:"optional"` + // Path URL of the external location. + Url types.String `tfsdk:"url" tf:""` +} + +type CreateFunction struct { + // Name of parent catalog. + CatalogName types.String `tfsdk:"catalog_name" tf:""` + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Scalar function return data type. + DataType types.String `tfsdk:"data_type" tf:""` + // External function language. + ExternalLanguage types.String `tfsdk:"external_language" tf:"optional"` + // External function name. + ExternalName types.String `tfsdk:"external_name" tf:"optional"` + // Pretty printed function data type. + FullDataType types.String `tfsdk:"full_data_type" tf:""` + + InputParams FunctionParameterInfos `tfsdk:"input_params" tf:""` + // Whether the function is deterministic. + IsDeterministic types.Bool `tfsdk:"is_deterministic" tf:""` + // Function null call. + IsNullCall types.Bool `tfsdk:"is_null_call" tf:""` + // Name of function, relative to parent schema. + Name types.String `tfsdk:"name" tf:""` + // Function parameter style. **S** is the value for SQL. + ParameterStyle types.String `tfsdk:"parameter_style" tf:""` + // JSON-serialized key-value pair map, encoded (escaped) as a string. + Properties types.String `tfsdk:"properties" tf:"optional"` + // Table function return parameters. + ReturnParams FunctionParameterInfos `tfsdk:"return_params" tf:""` + // Function language. When **EXTERNAL** is used, the language of the routine + // function should be specified in the __external_language__ field, and the + // __return_params__ of the function cannot be used (as **TABLE** return + // type is not supported), and the __sql_data_access__ field must be + // **NO_SQL**. + RoutineBody types.String `tfsdk:"routine_body" tf:""` + // Function body. + RoutineDefinition types.String `tfsdk:"routine_definition" tf:""` + // Function dependencies. + RoutineDependencies DependencyList `tfsdk:"routine_dependencies" tf:""` + // Name of parent schema relative to its parent catalog. + SchemaName types.String `tfsdk:"schema_name" tf:""` + // Function security type. + SecurityType types.String `tfsdk:"security_type" tf:""` + // Specific name of the function; Reserved for future use. + SpecificName types.String `tfsdk:"specific_name" tf:""` + // Function SQL data access. + SqlDataAccess types.String `tfsdk:"sql_data_access" tf:""` + // List of schemes whose objects can be referenced without qualification. + SqlPath types.String `tfsdk:"sql_path" tf:"optional"` +} + +type CreateFunctionRequest struct { + // Partial __FunctionInfo__ specifying the function to be created. + FunctionInfo CreateFunction `tfsdk:"function_info" tf:""` +} + +type CreateMetastore struct { + // The user-specified name of the metastore. + Name types.String `tfsdk:"name" tf:""` + // Cloud region which the metastore serves (e.g., `us-west-2`, `westus`). + // The field can be omitted in the __workspace-level__ __API__ but not in + // the __account-level__ __API__. If this field is omitted, the region of + // the workspace receiving the request will be used. + Region types.String `tfsdk:"region" tf:"optional"` + // The storage root URL for metastore + StorageRoot types.String `tfsdk:"storage_root" tf:"optional"` +} + +type CreateMetastoreAssignment struct { + // The name of the default catalog in the metastore. + DefaultCatalogName types.String `tfsdk:"default_catalog_name" tf:""` + // The unique ID of the metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:""` + // A workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type CreateMonitor struct { + // The directory to store monitoring assets (e.g. dashboard, metric tables). + AssetsDir types.String `tfsdk:"assets_dir" tf:""` + // Name of the baseline table from which drift metrics are computed from. + // Columns in the monitored table should also be present in the baseline + // table. + BaselineTableName types.String `tfsdk:"baseline_table_name" tf:"optional"` + // Custom metrics to compute on the monitored table. These can be aggregate + // metrics, derived metrics (from already computed aggregate metrics), or + // drift metrics (comparing metrics across time windows). + CustomMetrics []MonitorMetric `tfsdk:"custom_metrics" tf:"optional"` + // The data classification config for the monitor. + DataClassificationConfig *MonitorDataClassificationConfig `tfsdk:"data_classification_config" tf:"optional"` + // Configuration for monitoring inference logs. + InferenceLog *MonitorInferenceLog `tfsdk:"inference_log" tf:"optional"` + // The notification settings for the monitor. + Notifications *MonitorNotifications `tfsdk:"notifications" tf:"optional"` + // Schema where output metric tables are created. + OutputSchemaName types.String `tfsdk:"output_schema_name" tf:""` + // The schedule for automatically updating and refreshing metric tables. + Schedule *MonitorCronSchedule `tfsdk:"schedule" tf:"optional"` + // Whether to skip creating a default dashboard summarizing data quality + // metrics. + SkipBuiltinDashboard types.Bool `tfsdk:"skip_builtin_dashboard" tf:"optional"` + // List of column expressions to slice data with for targeted analysis. The + // data is grouped by each expression independently, resulting in a separate + // slice for each predicate and its complements. For high-cardinality + // columns, only the top 100 unique values by frequency will generate + // slices. + SlicingExprs []types.String `tfsdk:"slicing_exprs" tf:"optional"` + // Configuration for monitoring snapshot tables. + Snapshot *MonitorSnapshot `tfsdk:"snapshot" tf:"optional"` + // Full name of the table. + TableName types.String `tfsdk:"-"` + // Configuration for monitoring time series tables. + TimeSeries *MonitorTimeSeries `tfsdk:"time_series" tf:"optional"` + // Optional argument to specify the warehouse for dashboard creation. If not + // specified, the first running warehouse will be used. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +// Online Table information. +type CreateOnlineTableRequest struct { + // Full three-part (catalog, schema, table) name of the table. + Name types.String `tfsdk:"name" tf:"optional"` + // Specification of the online table. + Spec *OnlineTableSpec `tfsdk:"spec" tf:"optional"` +} + +type CreateRegisteredModelRequest struct { + // The name of the catalog where the schema and the registered model reside + CatalogName types.String `tfsdk:"catalog_name" tf:""` + // The comment attached to the registered model + Comment types.String `tfsdk:"comment" tf:"optional"` + // The name of the registered model + Name types.String `tfsdk:"name" tf:""` + // The name of the schema where the registered model resides + SchemaName types.String `tfsdk:"schema_name" tf:""` + // The storage location on the cloud under which model version data files + // are stored + StorageLocation types.String `tfsdk:"storage_location" tf:"optional"` +} + +type CreateResponse struct { +} + +type CreateSchema struct { + // Name of parent catalog. + CatalogName types.String `tfsdk:"catalog_name" tf:""` + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of schema, relative to parent catalog. + Name types.String `tfsdk:"name" tf:""` + // A map of key-value properties attached to the securable. + Properties map[string]types.String `tfsdk:"properties" tf:"optional"` + // Storage root URL for managed tables within schema. + StorageRoot types.String `tfsdk:"storage_root" tf:"optional"` +} + +type CreateStorageCredential struct { + // The AWS IAM role configuration. + AwsIamRole *AwsIamRoleRequest `tfsdk:"aws_iam_role" tf:"optional"` + // The Azure managed identity configuration. + AzureManagedIdentity *AzureManagedIdentityRequest `tfsdk:"azure_managed_identity" tf:"optional"` + // The Azure service principal configuration. + AzureServicePrincipal *AzureServicePrincipal `tfsdk:"azure_service_principal" tf:"optional"` + // The Cloudflare API token configuration. + CloudflareApiToken *CloudflareApiToken `tfsdk:"cloudflare_api_token" tf:"optional"` + // Comment associated with the credential. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The Databricks managed GCP service account configuration. + DatabricksGcpServiceAccount *DatabricksGcpServiceAccountRequest `tfsdk:"databricks_gcp_service_account" tf:"optional"` + // The credential name. The name must be unique within the metastore. + Name types.String `tfsdk:"name" tf:""` + // Whether the storage credential is only usable for read operations. + ReadOnly types.Bool `tfsdk:"read_only" tf:"optional"` + // Supplying true to this argument skips validation of the created + // credential. + SkipValidation types.Bool `tfsdk:"skip_validation" tf:"optional"` +} + +type CreateTableConstraint struct { + // A table constraint, as defined by *one* of the following fields being + // set: __primary_key_constraint__, __foreign_key_constraint__, + // __named_table_constraint__. + Constraint TableConstraint `tfsdk:"constraint" tf:""` + // The full name of the table referenced by the constraint. + FullNameArg types.String `tfsdk:"full_name_arg" tf:""` +} + +type CreateVolumeRequestContent struct { + // The name of the catalog where the schema and the volume are + CatalogName types.String `tfsdk:"catalog_name" tf:""` + // The comment attached to the volume + Comment types.String `tfsdk:"comment" tf:"optional"` + // The name of the volume + Name types.String `tfsdk:"name" tf:""` + // The name of the schema where the volume is + SchemaName types.String `tfsdk:"schema_name" tf:""` + // The storage location on the cloud + StorageLocation types.String `tfsdk:"storage_location" tf:"optional"` + + VolumeType types.String `tfsdk:"volume_type" tf:""` +} + +// Currently assigned workspaces +type CurrentWorkspaceBindings struct { + // A list of workspace IDs. + Workspaces []types.Int64 `tfsdk:"workspaces" tf:"optional"` +} + +type DatabricksGcpServiceAccountRequest struct { +} + +type DatabricksGcpServiceAccountResponse struct { + // The Databricks internal ID that represents this service account. This is + // an output-only field. + CredentialId types.String `tfsdk:"credential_id" tf:"optional"` + // The email of the service account. This is an output-only field. + Email types.String `tfsdk:"email" tf:"optional"` +} + +// Delete a metastore assignment +type DeleteAccountMetastoreAssignmentRequest struct { + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` + // Workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +// Delete a metastore +type DeleteAccountMetastoreRequest struct { + // Force deletion even if the metastore is not empty. Default is false. + Force types.Bool `tfsdk:"-"` + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` +} + +// Delete a storage credential +type DeleteAccountStorageCredentialRequest struct { + // Force deletion even if the Storage Credential is not empty. Default is + // false. + Force types.Bool `tfsdk:"-"` + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` + // Name of the storage credential. + StorageCredentialName types.String `tfsdk:"-"` +} + +// Delete a Registered Model Alias +type DeleteAliasRequest struct { + // The name of the alias + Alias types.String `tfsdk:"-"` + // The three-level (fully qualified) name of the registered model + FullName types.String `tfsdk:"-"` +} + +type DeleteAliasResponse struct { +} + +// Delete a catalog +type DeleteCatalogRequest struct { + // Force deletion even if the catalog is not empty. + Force types.Bool `tfsdk:"-"` + // The name of the catalog. + Name types.String `tfsdk:"-"` +} + +// Delete a connection +type DeleteConnectionRequest struct { + // The name of the connection to be deleted. + Name types.String `tfsdk:"-"` +} + +// Delete an external location +type DeleteExternalLocationRequest struct { + // Force deletion even if there are dependent external tables or mounts. + Force types.Bool `tfsdk:"-"` + // Name of the external location. + Name types.String `tfsdk:"-"` +} + +// Delete a function +type DeleteFunctionRequest struct { + // Force deletion even if the function is notempty. + Force types.Bool `tfsdk:"-"` + // The fully-qualified name of the function (of the form + // __catalog_name__.__schema_name__.__function__name__). + Name types.String `tfsdk:"-"` +} + +// Delete a metastore +type DeleteMetastoreRequest struct { + // Force deletion even if the metastore is not empty. Default is false. + Force types.Bool `tfsdk:"-"` + // Unique ID of the metastore. + Id types.String `tfsdk:"-"` +} + +// Delete a Model Version +type DeleteModelVersionRequest struct { + // The three-level (fully qualified) name of the model version + FullName types.String `tfsdk:"-"` + // The integer version number of the model version + Version types.Int64 `tfsdk:"-"` +} + +// Delete an Online Table +type DeleteOnlineTableRequest struct { + // Full three-part (catalog, schema, table) name of the table. + Name types.String `tfsdk:"-"` +} + +// Delete a table monitor +type DeleteQualityMonitorRequest struct { + // Full name of the table. + TableName types.String `tfsdk:"-"` +} + +// Delete a Registered Model +type DeleteRegisteredModelRequest struct { + // The three-level (fully qualified) name of the registered model + FullName types.String `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +// Delete a schema +type DeleteSchemaRequest struct { + // Full name of the schema. + FullName types.String `tfsdk:"-"` +} + +// Delete a credential +type DeleteStorageCredentialRequest struct { + // Force deletion even if there are dependent external locations or external + // tables. + Force types.Bool `tfsdk:"-"` + // Name of the storage credential. + Name types.String `tfsdk:"-"` +} + +// Delete a table constraint +type DeleteTableConstraintRequest struct { + // If true, try deleting all child constraints of the current constraint. If + // false, reject this operation if the current constraint has any child + // constraints. + Cascade types.Bool `tfsdk:"-"` + // The name of the constraint to delete. + ConstraintName types.String `tfsdk:"-"` + // Full name of the table referenced by the constraint. + FullName types.String `tfsdk:"-"` +} + +// Delete a table +type DeleteTableRequest struct { + // Full name of the table. + FullName types.String `tfsdk:"-"` +} + +// Delete a Volume +type DeleteVolumeRequest struct { + // The three-level (fully qualified) name of the volume + Name types.String `tfsdk:"-"` +} + +// Properties pertaining to the current state of the delta table as given by the +// commit server. This does not contain **delta.*** (input) properties in +// __TableInfo.properties__. +type DeltaRuntimePropertiesKvPairs struct { + // A map of key-value properties attached to the securable. + DeltaRuntimeProperties map[string]types.String `tfsdk:"delta_runtime_properties" tf:""` +} + +// A dependency of a SQL object. Either the __table__ field or the __function__ +// field must be defined. +type Dependency struct { + // A function that is dependent on a SQL object. + Function *FunctionDependency `tfsdk:"function" tf:"optional"` + // A table that is dependent on a SQL object. + Table *TableDependency `tfsdk:"table" tf:"optional"` +} + +// A list of dependencies. +type DependencyList struct { + // Array of dependencies. + Dependencies []Dependency `tfsdk:"dependencies" tf:"optional"` +} + +// Disable a system schema +type DisableRequest struct { + // The metastore ID under which the system schema lives. + MetastoreId types.String `tfsdk:"-"` + // Full name of the system schema. + SchemaName types.String `tfsdk:"-"` +} + +type DisableResponse struct { +} + +type EffectivePermissionsList struct { + // The privileges conveyed to each principal (either directly or via + // inheritance) + PrivilegeAssignments []EffectivePrivilegeAssignment `tfsdk:"privilege_assignments" tf:"optional"` +} + +type EffectivePredictiveOptimizationFlag struct { + // The name of the object from which the flag was inherited. If there was no + // inheritance, this field is left blank. + InheritedFromName types.String `tfsdk:"inherited_from_name" tf:"optional"` + // The type of the object from which the flag was inherited. If there was no + // inheritance, this field is left blank. + InheritedFromType types.String `tfsdk:"inherited_from_type" tf:"optional"` + // Whether predictive optimization should be enabled for this object and + // objects under it. + Value types.String `tfsdk:"value" tf:""` +} + +type EffectivePrivilege struct { + // The full name of the object that conveys this privilege via inheritance. + // This field is omitted when privilege is not inherited (it's assigned to + // the securable itself). + InheritedFromName types.String `tfsdk:"inherited_from_name" tf:"optional"` + // The type of the object that conveys this privilege via inheritance. This + // field is omitted when privilege is not inherited (it's assigned to the + // securable itself). + InheritedFromType types.String `tfsdk:"inherited_from_type" tf:"optional"` + // The privilege assigned to the principal. + Privilege types.String `tfsdk:"privilege" tf:"optional"` +} + +type EffectivePrivilegeAssignment struct { + // The principal (user email address or group name). + Principal types.String `tfsdk:"principal" tf:"optional"` + // The privileges conveyed to the principal (either directly or via + // inheritance). + Privileges []EffectivePrivilege `tfsdk:"privileges" tf:"optional"` +} + +// Enable a system schema +type EnableRequest struct { + // The metastore ID under which the system schema lives. + MetastoreId types.String `tfsdk:"-"` + // Full name of the system schema. + SchemaName types.String `tfsdk:"-"` +} + +type EnableResponse struct { +} + +// Encryption options that apply to clients connecting to cloud storage. +type EncryptionDetails struct { + // Server-Side Encryption properties for clients communicating with AWS s3. + SseEncryptionDetails *SseEncryptionDetails `tfsdk:"sse_encryption_details" tf:"optional"` +} + +// Get boolean reflecting if table exists +type ExistsRequest struct { + // Full name of the table. + FullName types.String `tfsdk:"-"` +} + +type ExternalLocationInfo struct { + // The AWS access point to use when accesing s3 for this external location. + AccessPoint types.String `tfsdk:"access_point" tf:"optional"` + // Indicates whether the principal is limited to retrieving metadata for the + // associated object through the BROWSE privilege when include_browse is + // enabled in the request. + BrowseOnly types.Bool `tfsdk:"browse_only" tf:"optional"` + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Time at which this external location was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of external location creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Unique ID of the location's storage credential. + CredentialId types.String `tfsdk:"credential_id" tf:"optional"` + // Name of the storage credential used with this location. + CredentialName types.String `tfsdk:"credential_name" tf:"optional"` + // Encryption options that apply to clients connecting to cloud storage. + EncryptionDetails *EncryptionDetails `tfsdk:"encryption_details" tf:"optional"` + // Whether the current securable is accessible from all workspaces or a + // specific set of workspaces. + IsolationMode types.String `tfsdk:"isolation_mode" tf:"optional"` + // Unique identifier of metastore hosting the external location. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // Name of the external location. + Name types.String `tfsdk:"name" tf:"optional"` + // The owner of the external location. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Indicates whether the external location is read-only. + ReadOnly types.Bool `tfsdk:"read_only" tf:"optional"` + // Time at which external location this was last modified, in epoch + // milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of user who last modified the external location. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` + // Path URL of the external location. + Url types.String `tfsdk:"url" tf:"optional"` +} + +// Detailed status of an online table. Shown if the online table is in the +// OFFLINE_FAILED or the ONLINE_PIPELINE_FAILED state. +type FailedStatus struct { + // The last source table Delta version that was synced to the online table. + // Note that this Delta version may only be partially synced to the online + // table. Only populated if the table is still online and available for + // serving. + LastProcessedCommitVersion types.Int64 `tfsdk:"last_processed_commit_version" tf:"optional"` + // The timestamp of the last time any data was synchronized from the source + // table to the online table. Only populated if the table is still online + // and available for serving. + Timestamp types.String `tfsdk:"timestamp" tf:"optional"` +} + +type ForeignKeyConstraint struct { + // Column names for this constraint. + ChildColumns []types.String `tfsdk:"child_columns" tf:""` + // The name of the constraint. + Name types.String `tfsdk:"name" tf:""` + // Column names for this constraint. + ParentColumns []types.String `tfsdk:"parent_columns" tf:""` + // The full name of the parent constraint. + ParentTable types.String `tfsdk:"parent_table" tf:""` +} + +// A function that is dependent on a SQL object. +type FunctionDependency struct { + // Full name of the dependent function, in the form of + // __catalog_name__.__schema_name__.__function_name__. + FunctionFullName types.String `tfsdk:"function_full_name" tf:""` +} + +type FunctionInfo struct { + // Indicates whether the principal is limited to retrieving metadata for the + // associated object through the BROWSE privilege when include_browse is + // enabled in the request. + BrowseOnly types.Bool `tfsdk:"browse_only" tf:"optional"` + // Name of parent catalog. + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Time at which this function was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of function creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Scalar function return data type. + DataType types.String `tfsdk:"data_type" tf:"optional"` + // External function language. + ExternalLanguage types.String `tfsdk:"external_language" tf:"optional"` + // External function name. + ExternalName types.String `tfsdk:"external_name" tf:"optional"` + // Pretty printed function data type. + FullDataType types.String `tfsdk:"full_data_type" tf:"optional"` + // Full name of function, in form of + // __catalog_name__.__schema_name__.__function__name__ + FullName types.String `tfsdk:"full_name" tf:"optional"` + // Id of Function, relative to parent schema. + FunctionId types.String `tfsdk:"function_id" tf:"optional"` + + InputParams *FunctionParameterInfos `tfsdk:"input_params" tf:"optional"` + // Whether the function is deterministic. + IsDeterministic types.Bool `tfsdk:"is_deterministic" tf:"optional"` + // Function null call. + IsNullCall types.Bool `tfsdk:"is_null_call" tf:"optional"` + // Unique identifier of parent metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // Name of function, relative to parent schema. + Name types.String `tfsdk:"name" tf:"optional"` + // Username of current owner of function. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Function parameter style. **S** is the value for SQL. + ParameterStyle types.String `tfsdk:"parameter_style" tf:"optional"` + // JSON-serialized key-value pair map, encoded (escaped) as a string. + Properties types.String `tfsdk:"properties" tf:"optional"` + // Table function return parameters. + ReturnParams *FunctionParameterInfos `tfsdk:"return_params" tf:"optional"` + // Function language. When **EXTERNAL** is used, the language of the routine + // function should be specified in the __external_language__ field, and the + // __return_params__ of the function cannot be used (as **TABLE** return + // type is not supported), and the __sql_data_access__ field must be + // **NO_SQL**. + RoutineBody types.String `tfsdk:"routine_body" tf:"optional"` + // Function body. + RoutineDefinition types.String `tfsdk:"routine_definition" tf:"optional"` + // Function dependencies. + RoutineDependencies *DependencyList `tfsdk:"routine_dependencies" tf:"optional"` + // Name of parent schema relative to its parent catalog. + SchemaName types.String `tfsdk:"schema_name" tf:"optional"` + // Function security type. + SecurityType types.String `tfsdk:"security_type" tf:"optional"` + // Specific name of the function; Reserved for future use. + SpecificName types.String `tfsdk:"specific_name" tf:"optional"` + // Function SQL data access. + SqlDataAccess types.String `tfsdk:"sql_data_access" tf:"optional"` + // List of schemes whose objects can be referenced without qualification. + SqlPath types.String `tfsdk:"sql_path" tf:"optional"` + // Time at which this function was created, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of user who last modified function. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type FunctionParameterInfo struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of parameter. + Name types.String `tfsdk:"name" tf:""` + // Default value of the parameter. + ParameterDefault types.String `tfsdk:"parameter_default" tf:"optional"` + // The mode of the function parameter. + ParameterMode types.String `tfsdk:"parameter_mode" tf:"optional"` + // The type of function parameter. + ParameterType types.String `tfsdk:"parameter_type" tf:"optional"` + // Ordinal position of column (starting at position 0). + Position types.Int64 `tfsdk:"position" tf:""` + // Format of IntervalType. + TypeIntervalType types.String `tfsdk:"type_interval_type" tf:"optional"` + // Full data type spec, JSON-serialized. + TypeJson types.String `tfsdk:"type_json" tf:"optional"` + // Name of type (INT, STRUCT, MAP, etc.). + TypeName types.String `tfsdk:"type_name" tf:""` + // Digits of precision; required on Create for DecimalTypes. + TypePrecision types.Int64 `tfsdk:"type_precision" tf:"optional"` + // Digits to right of decimal; Required on Create for DecimalTypes. + TypeScale types.Int64 `tfsdk:"type_scale" tf:"optional"` + // Full data type spec, SQL/catalogString text. + TypeText types.String `tfsdk:"type_text" tf:""` +} + +type FunctionParameterInfos struct { + // The array of __FunctionParameterInfo__ definitions of the function's + // parameters. + Parameters []FunctionParameterInfo `tfsdk:"parameters" tf:"optional"` +} + +// Gets the metastore assignment for a workspace +type GetAccountMetastoreAssignmentRequest struct { + // Workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +// Get a metastore +type GetAccountMetastoreRequest struct { + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` +} + +// Gets the named storage credential +type GetAccountStorageCredentialRequest struct { + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` + // Name of the storage credential. + StorageCredentialName types.String `tfsdk:"-"` +} + +// Get an artifact allowlist +type GetArtifactAllowlistRequest struct { + // The artifact type of the allowlist. + ArtifactType types.String `tfsdk:"-"` +} + +// Get securable workspace bindings +type GetBindingsRequest struct { + // The name of the securable. + SecurableName types.String `tfsdk:"-"` + // The type of the securable. + SecurableType types.String `tfsdk:"-"` +} + +// Get Model Version By Alias +type GetByAliasRequest struct { + // The name of the alias + Alias types.String `tfsdk:"-"` + // The three-level (fully qualified) name of the registered model + FullName types.String `tfsdk:"-"` +} + +// Get a catalog +type GetCatalogRequest struct { + // Whether to include catalogs in the response for which the principal can + // only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // The name of the catalog. + Name types.String `tfsdk:"-"` +} + +// Get a connection +type GetConnectionRequest struct { + // Name of the connection. + Name types.String `tfsdk:"-"` +} + +// Get effective permissions +type GetEffectiveRequest struct { + // Full name of securable. + FullName types.String `tfsdk:"-"` + // If provided, only the effective permissions for the specified principal + // (user or group) are returned. + Principal types.String `tfsdk:"-"` + // Type of securable. + SecurableType types.String `tfsdk:"-"` +} + +// Get an external location +type GetExternalLocationRequest struct { + // Whether to include external locations in the response for which the + // principal can only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // Name of the external location. + Name types.String `tfsdk:"-"` +} + +// Get a function +type GetFunctionRequest struct { + // Whether to include functions in the response for which the principal can + // only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // The fully-qualified name of the function (of the form + // __catalog_name__.__schema_name__.__function__name__). + Name types.String `tfsdk:"-"` +} + +// Get permissions +type GetGrantRequest struct { + // Full name of securable. + FullName types.String `tfsdk:"-"` + // If provided, only the permissions for the specified principal (user or + // group) are returned. + Principal types.String `tfsdk:"-"` + // Type of securable. + SecurableType types.String `tfsdk:"-"` +} + +// Get a metastore +type GetMetastoreRequest struct { + // Unique ID of the metastore. + Id types.String `tfsdk:"-"` +} + +type GetMetastoreSummaryResponse struct { + // Cloud vendor of the metastore home shard (e.g., `aws`, `azure`, `gcp`). + Cloud types.String `tfsdk:"cloud" tf:"optional"` + // Time at which this metastore was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of metastore creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Unique identifier of the metastore's (Default) Data Access Configuration. + DefaultDataAccessConfigId types.String `tfsdk:"default_data_access_config_id" tf:"optional"` + // The organization name of a Delta Sharing entity, to be used in + // Databricks-to-Databricks Delta Sharing as the official name. + DeltaSharingOrganizationName types.String `tfsdk:"delta_sharing_organization_name" tf:"optional"` + // The lifetime of delta sharing recipient token in seconds. + DeltaSharingRecipientTokenLifetimeInSeconds types.Int64 `tfsdk:"delta_sharing_recipient_token_lifetime_in_seconds" tf:"optional"` + // The scope of Delta Sharing enabled for the metastore. + DeltaSharingScope types.String `tfsdk:"delta_sharing_scope" tf:"optional"` + // Globally unique metastore ID across clouds and regions, of the form + // `cloud:region:metastore_id`. + GlobalMetastoreId types.String `tfsdk:"global_metastore_id" tf:"optional"` + // Unique identifier of metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // The user-specified name of the metastore. + Name types.String `tfsdk:"name" tf:"optional"` + // The owner of the metastore. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Privilege model version of the metastore, of the form `major.minor` + // (e.g., `1.0`). + PrivilegeModelVersion types.String `tfsdk:"privilege_model_version" tf:"optional"` + // Cloud region which the metastore serves (e.g., `us-west-2`, `westus`). + Region types.String `tfsdk:"region" tf:"optional"` + // The storage root URL for metastore + StorageRoot types.String `tfsdk:"storage_root" tf:"optional"` + // UUID of storage credential to access the metastore storage_root. + StorageRootCredentialId types.String `tfsdk:"storage_root_credential_id" tf:"optional"` + // Name of the storage credential to access the metastore storage_root. + StorageRootCredentialName types.String `tfsdk:"storage_root_credential_name" tf:"optional"` + // Time at which the metastore was last modified, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of user who last modified the metastore. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +// Get a Model Version +type GetModelVersionRequest struct { + // The three-level (fully qualified) name of the model version + FullName types.String `tfsdk:"-"` + // Whether to include model versions in the response for which the principal + // can only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // The integer version number of the model version + Version types.Int64 `tfsdk:"-"` +} + +// Get an Online Table +type GetOnlineTableRequest struct { + // Full three-part (catalog, schema, table) name of the table. + Name types.String `tfsdk:"-"` +} + +// Get a table monitor +type GetQualityMonitorRequest struct { + // Full name of the table. + TableName types.String `tfsdk:"-"` +} + +// Get refresh +type GetRefreshRequest struct { + // ID of the refresh. + RefreshId types.String `tfsdk:"-"` + // Full name of the table. + TableName types.String `tfsdk:"-"` +} + +// Get a Registered Model +type GetRegisteredModelRequest struct { + // The three-level (fully qualified) name of the registered model + FullName types.String `tfsdk:"-"` + // Whether to include registered models in the response for which the + // principal can only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` +} + +// Get a schema +type GetSchemaRequest struct { + // Full name of the schema. + FullName types.String `tfsdk:"-"` + // Whether to include schemas in the response for which the principal can + // only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` +} + +// Get a credential +type GetStorageCredentialRequest struct { + // Name of the storage credential. + Name types.String `tfsdk:"-"` +} + +// Get a table +type GetTableRequest struct { + // Full name of the table. + FullName types.String `tfsdk:"-"` + // Whether to include tables in the response for which the principal can + // only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // Whether delta metadata should be included in the response. + IncludeDeltaMetadata types.Bool `tfsdk:"-"` +} + +// Get catalog workspace bindings +type GetWorkspaceBindingRequest struct { + // The name of the catalog. + Name types.String `tfsdk:"-"` +} + +// Get all workspaces assigned to a metastore +type ListAccountMetastoreAssignmentsRequest struct { + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` +} + +// The list of workspaces to which the given metastore is assigned. +type ListAccountMetastoreAssignmentsResponse struct { + WorkspaceIds []types.Int64 `tfsdk:"workspace_ids" tf:"optional"` +} + +// Get all storage credentials assigned to a metastore +type ListAccountStorageCredentialsRequest struct { + // Unity Catalog metastore ID + MetastoreId types.String `tfsdk:"-"` +} + +type ListAccountStorageCredentialsResponse struct { + // An array of metastore storage credentials. + StorageCredentials []StorageCredentialInfo `tfsdk:"storage_credentials" tf:"optional"` +} + +// List catalogs +type ListCatalogsRequest struct { + // Whether to include catalogs in the response for which the principal can + // only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // Maximum number of catalogs to return. - when set to 0, the page length is + // set to a server configured value (recommended); - when set to a value + // greater than 0, the page length is the minimum of this value and a server + // configured value; - when set to a value less than 0, an invalid parameter + // error is returned; - If not set, all valid catalogs are returned (not + // recommended). - Note: The number of returned catalogs might be less than + // the specified max_results size, even zero. The only definitive indication + // that no further catalogs can be fetched is when the next_page_token is + // unset from the response. + MaxResults types.Int64 `tfsdk:"-"` + // Opaque pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` +} + +type ListCatalogsResponse struct { + // An array of catalog information objects. + Catalogs []CatalogInfo `tfsdk:"catalogs" tf:"optional"` + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request (for the next page of results). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List connections +type ListConnectionsRequest struct { + // Maximum number of connections to return. - If not set, all connections + // are returned (not recommended). - when set to a value greater than 0, the + // page length is the minimum of this value and a server configured value; - + // when set to 0, the page length is set to a server configured value + // (recommended); - when set to a value less than 0, an invalid parameter + // error is returned; + MaxResults types.Int64 `tfsdk:"-"` + // Opaque pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` +} + +type ListConnectionsResponse struct { + // An array of connection information objects. + Connections []ConnectionInfo `tfsdk:"connections" tf:"optional"` + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request (for the next page of results). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List external locations +type ListExternalLocationsRequest struct { + // Whether to include external locations in the response for which the + // principal can only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // Maximum number of external locations to return. If not set, all the + // external locations are returned (not recommended). - when set to a value + // greater than 0, the page length is the minimum of this value and a server + // configured value; - when set to 0, the page length is set to a server + // configured value (recommended); - when set to a value less than 0, an + // invalid parameter error is returned; + MaxResults types.Int64 `tfsdk:"-"` + // Opaque pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` +} + +type ListExternalLocationsResponse struct { + // An array of external locations. + ExternalLocations []ExternalLocationInfo `tfsdk:"external_locations" tf:"optional"` + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request (for the next page of results). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List functions +type ListFunctionsRequest struct { + // Name of parent catalog for functions of interest. + CatalogName types.String `tfsdk:"-"` + // Whether to include functions in the response for which the principal can + // only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // Maximum number of functions to return. If not set, all the functions are + // returned (not recommended). - when set to a value greater than 0, the + // page length is the minimum of this value and a server configured value; - + // when set to 0, the page length is set to a server configured value + // (recommended); - when set to a value less than 0, an invalid parameter + // error is returned; + MaxResults types.Int64 `tfsdk:"-"` + // Opaque pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` + // Parent schema of functions. + SchemaName types.String `tfsdk:"-"` +} + +type ListFunctionsResponse struct { + // An array of function information objects. + Functions []FunctionInfo `tfsdk:"functions" tf:"optional"` + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request (for the next page of results). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +type ListMetastoresResponse struct { + // An array of metastore information objects. + Metastores []MetastoreInfo `tfsdk:"metastores" tf:"optional"` +} + +// List Model Versions +type ListModelVersionsRequest struct { + // The full three-level name of the registered model under which to list + // model versions + FullName types.String `tfsdk:"-"` + // Whether to include model versions in the response for which the principal + // can only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // Maximum number of model versions to return. If not set, the page length + // is set to a server configured value (100, as of 1/3/2024). - when set to + // a value greater than 0, the page length is the minimum of this value and + // a server configured value(1000, as of 1/3/2024); - when set to 0, the + // page length is set to a server configured value (100, as of 1/3/2024) + // (recommended); - when set to a value less than 0, an invalid parameter + // error is returned; + MaxResults types.Int64 `tfsdk:"-"` + // Opaque pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` +} + +type ListModelVersionsResponse struct { + ModelVersions []ModelVersionInfo `tfsdk:"model_versions" tf:"optional"` + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request (for the next page of results). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List refreshes +type ListRefreshesRequest struct { + // Full name of the table. + TableName types.String `tfsdk:"-"` +} + +// List Registered Models +type ListRegisteredModelsRequest struct { + // The identifier of the catalog under which to list registered models. If + // specified, schema_name must be specified. + CatalogName types.String `tfsdk:"-"` + // Whether to include registered models in the response for which the + // principal can only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // Max number of registered models to return. + // + // If both catalog and schema are specified: - when max_results is not + // specified, the page length is set to a server configured value (10000, as + // of 4/2/2024). - when set to a value greater than 0, the page length is + // the minimum of this value and a server configured value (10000, as of + // 4/2/2024); - when set to 0, the page length is set to a server configured + // value (10000, as of 4/2/2024); - when set to a value less than 0, an + // invalid parameter error is returned; + // + // If neither schema nor catalog is specified: - when max_results is not + // specified, the page length is set to a server configured value (100, as + // of 4/2/2024). - when set to a value greater than 0, the page length is + // the minimum of this value and a server configured value (1000, as of + // 4/2/2024); - when set to 0, the page length is set to a server configured + // value (100, as of 4/2/2024); - when set to a value less than 0, an + // invalid parameter error is returned; + MaxResults types.Int64 `tfsdk:"-"` + // Opaque token to send for the next page of results (pagination). + PageToken types.String `tfsdk:"-"` + // The identifier of the schema under which to list registered models. If + // specified, catalog_name must be specified. + SchemaName types.String `tfsdk:"-"` +} + +type ListRegisteredModelsResponse struct { + // Opaque token for pagination. Omitted if there are no more results. + // page_token should be set to this value for fetching the next page. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + RegisteredModels []RegisteredModelInfo `tfsdk:"registered_models" tf:"optional"` +} + +// List schemas +type ListSchemasRequest struct { + // Parent catalog for schemas of interest. + CatalogName types.String `tfsdk:"-"` + // Whether to include schemas in the response for which the principal can + // only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // Maximum number of schemas to return. If not set, all the schemas are + // returned (not recommended). - when set to a value greater than 0, the + // page length is the minimum of this value and a server configured value; - + // when set to 0, the page length is set to a server configured value + // (recommended); - when set to a value less than 0, an invalid parameter + // error is returned; + MaxResults types.Int64 `tfsdk:"-"` + // Opaque pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` +} + +type ListSchemasResponse struct { + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request (for the next page of results). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // An array of schema information objects. + Schemas []SchemaInfo `tfsdk:"schemas" tf:"optional"` +} + +// List credentials +type ListStorageCredentialsRequest struct { + // Maximum number of storage credentials to return. If not set, all the + // storage credentials are returned (not recommended). - when set to a value + // greater than 0, the page length is the minimum of this value and a server + // configured value; - when set to 0, the page length is set to a server + // configured value (recommended); - when set to a value less than 0, an + // invalid parameter error is returned; + MaxResults types.Int64 `tfsdk:"-"` + // Opaque pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` +} + +type ListStorageCredentialsResponse struct { + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request (for the next page of results). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + StorageCredentials []StorageCredentialInfo `tfsdk:"storage_credentials" tf:"optional"` +} + +// List table summaries +type ListSummariesRequest struct { + // Name of parent catalog for tables of interest. + CatalogName types.String `tfsdk:"-"` + // Maximum number of summaries for tables to return. If not set, the page + // length is set to a server configured value (10000, as of 1/5/2024). - + // when set to a value greater than 0, the page length is the minimum of + // this value and a server configured value (10000, as of 1/5/2024); - when + // set to 0, the page length is set to a server configured value (10000, as + // of 1/5/2024) (recommended); - when set to a value less than 0, an invalid + // parameter error is returned; + MaxResults types.Int64 `tfsdk:"-"` + // Opaque pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` + // A sql LIKE pattern (% and _) for schema names. All schemas will be + // returned if not set or empty. + SchemaNamePattern types.String `tfsdk:"-"` + // A sql LIKE pattern (% and _) for table names. All tables will be returned + // if not set or empty. + TableNamePattern types.String `tfsdk:"-"` +} + +// List system schemas +type ListSystemSchemasRequest struct { + // The ID for the metastore in which the system schema resides. + MetastoreId types.String `tfsdk:"-"` +} + +type ListSystemSchemasResponse struct { + // An array of system schema information objects. + Schemas []SystemSchemaInfo `tfsdk:"schemas" tf:"optional"` +} + +type ListTableSummariesResponse struct { + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request (for the next page of results). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // List of table summaries. + Tables []TableSummary `tfsdk:"tables" tf:"optional"` +} + +// List tables +type ListTablesRequest struct { + // Name of parent catalog for tables of interest. + CatalogName types.String `tfsdk:"-"` + // Whether to include tables in the response for which the principal can + // only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // Whether delta metadata should be included in the response. + IncludeDeltaMetadata types.Bool `tfsdk:"-"` + // Maximum number of tables to return. If not set, all the tables are + // returned (not recommended). - when set to a value greater than 0, the + // page length is the minimum of this value and a server configured value; - + // when set to 0, the page length is set to a server configured value + // (recommended); - when set to a value less than 0, an invalid parameter + // error is returned; + MaxResults types.Int64 `tfsdk:"-"` + // Whether to omit the columns of the table from the response or not. + OmitColumns types.Bool `tfsdk:"-"` + // Whether to omit the properties of the table from the response or not. + OmitProperties types.Bool `tfsdk:"-"` + // Opaque token to send for the next page of results (pagination). + PageToken types.String `tfsdk:"-"` + // Parent schema of tables. + SchemaName types.String `tfsdk:"-"` +} + +type ListTablesResponse struct { + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request (for the next page of results). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // An array of table information objects. + Tables []TableInfo `tfsdk:"tables" tf:"optional"` +} + +// List Volumes +type ListVolumesRequest struct { + // The identifier of the catalog + CatalogName types.String `tfsdk:"-"` + // Whether to include volumes in the response for which the principal can + // only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // Maximum number of volumes to return (page length). + // + // If not set, the page length is set to a server configured value (10000, + // as of 1/29/2024). - when set to a value greater than 0, the page length + // is the minimum of this value and a server configured value (10000, as of + // 1/29/2024); - when set to 0, the page length is set to a server + // configured value (10000, as of 1/29/2024) (recommended); - when set to a + // value less than 0, an invalid parameter error is returned; + // + // Note: this parameter controls only the maximum number of volumes to + // return. The actual number of volumes returned in a page may be smaller + // than this value, including 0, even if there are more pages. + MaxResults types.Int64 `tfsdk:"-"` + // Opaque token returned by a previous request. It must be included in the + // request to retrieve the next page of results (pagination). + PageToken types.String `tfsdk:"-"` + // The identifier of the schema + SchemaName types.String `tfsdk:"-"` +} + +type ListVolumesResponseContent struct { + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request to retrieve the next page of results. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + Volumes []VolumeInfo `tfsdk:"volumes" tf:"optional"` +} + +type MetastoreAssignment struct { + // The name of the default catalog in the metastore. + DefaultCatalogName types.String `tfsdk:"default_catalog_name" tf:"optional"` + // The unique ID of the metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:""` + // The unique ID of the Databricks workspace. + WorkspaceId types.Int64 `tfsdk:"workspace_id" tf:""` +} + +type MetastoreInfo struct { + // Cloud vendor of the metastore home shard (e.g., `aws`, `azure`, `gcp`). + Cloud types.String `tfsdk:"cloud" tf:"optional"` + // Time at which this metastore was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of metastore creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Unique identifier of the metastore's (Default) Data Access Configuration. + DefaultDataAccessConfigId types.String `tfsdk:"default_data_access_config_id" tf:"optional"` + // The organization name of a Delta Sharing entity, to be used in + // Databricks-to-Databricks Delta Sharing as the official name. + DeltaSharingOrganizationName types.String `tfsdk:"delta_sharing_organization_name" tf:"optional"` + // The lifetime of delta sharing recipient token in seconds. + DeltaSharingRecipientTokenLifetimeInSeconds types.Int64 `tfsdk:"delta_sharing_recipient_token_lifetime_in_seconds" tf:"optional"` + // The scope of Delta Sharing enabled for the metastore. + DeltaSharingScope types.String `tfsdk:"delta_sharing_scope" tf:"optional"` + // Globally unique metastore ID across clouds and regions, of the form + // `cloud:region:metastore_id`. + GlobalMetastoreId types.String `tfsdk:"global_metastore_id" tf:"optional"` + // Unique identifier of metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // The user-specified name of the metastore. + Name types.String `tfsdk:"name" tf:"optional"` + // The owner of the metastore. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Privilege model version of the metastore, of the form `major.minor` + // (e.g., `1.0`). + PrivilegeModelVersion types.String `tfsdk:"privilege_model_version" tf:"optional"` + // Cloud region which the metastore serves (e.g., `us-west-2`, `westus`). + Region types.String `tfsdk:"region" tf:"optional"` + // The storage root URL for metastore + StorageRoot types.String `tfsdk:"storage_root" tf:"optional"` + // UUID of storage credential to access the metastore storage_root. + StorageRootCredentialId types.String `tfsdk:"storage_root_credential_id" tf:"optional"` + // Name of the storage credential to access the metastore storage_root. + StorageRootCredentialName types.String `tfsdk:"storage_root_credential_name" tf:"optional"` + // Time at which the metastore was last modified, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of user who last modified the metastore. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type ModelVersionInfo struct { + // Indicates whether the principal is limited to retrieving metadata for the + // associated object through the BROWSE privilege when include_browse is + // enabled in the request. + BrowseOnly types.Bool `tfsdk:"browse_only" tf:"optional"` + // The name of the catalog containing the model version + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // The comment attached to the model version + Comment types.String `tfsdk:"comment" tf:"optional"` + + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // The identifier of the user who created the model version + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // The unique identifier of the model version + Id types.String `tfsdk:"id" tf:"optional"` + // The unique identifier of the metastore containing the model version + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // The name of the parent registered model of the model version, relative to + // parent schema + ModelName types.String `tfsdk:"model_name" tf:"optional"` + // Model version dependencies, for feature-store packaged models + ModelVersionDependencies *DependencyList `tfsdk:"model_version_dependencies" tf:"optional"` + // MLflow run ID used when creating the model version, if ``source`` was + // generated by an experiment run stored in an MLflow tracking server + RunId types.String `tfsdk:"run_id" tf:"optional"` + // ID of the Databricks workspace containing the MLflow run that generated + // this model version, if applicable + RunWorkspaceId types.Int64 `tfsdk:"run_workspace_id" tf:"optional"` + // The name of the schema containing the model version, relative to parent + // catalog + SchemaName types.String `tfsdk:"schema_name" tf:"optional"` + // URI indicating the location of the source artifacts (files) for the model + // version + Source types.String `tfsdk:"source" tf:"optional"` + // Current status of the model version. Newly created model versions start + // in PENDING_REGISTRATION status, then move to READY status once the model + // version files are uploaded and the model version is finalized. Only model + // versions in READY status can be loaded for inference or served. + Status types.String `tfsdk:"status" tf:"optional"` + // The storage location on the cloud under which model version data files + // are stored + StorageLocation types.String `tfsdk:"storage_location" tf:"optional"` + + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // The identifier of the user who updated the model version last time + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` + // Integer model version number, used to reference the model version in API + // requests. + Version types.Int64 `tfsdk:"version" tf:"optional"` +} + +type MonitorCronSchedule struct { + // Read only field that indicates whether a schedule is paused or not. + PauseStatus types.String `tfsdk:"pause_status" tf:"optional"` + // The expression that determines when to run the monitor. See [examples]. + // + // [examples]: https://www.quartz-scheduler.org/documentation/quartz-2.3.0/tutorials/crontrigger.html + QuartzCronExpression types.String `tfsdk:"quartz_cron_expression" tf:""` + // The timezone id (e.g., ``"PST"``) in which to evaluate the quartz + // expression. + TimezoneId types.String `tfsdk:"timezone_id" tf:""` +} + +type MonitorDataClassificationConfig struct { + // Whether data classification is enabled. + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` +} + +type MonitorDestination struct { + // The list of email addresses to send the notification to. A maximum of 5 + // email addresses is supported. + EmailAddresses []types.String `tfsdk:"email_addresses" tf:"optional"` +} + +type MonitorInferenceLog struct { + // Granularities for aggregating data into time windows based on their + // timestamp. Currently the following static granularities are supported: + // {``"5 minutes"``, ``"30 minutes"``, ``"1 hour"``, ``"1 day"``, ``" + // week(s)"``, ``"1 month"``, ``"1 year"``}. + Granularities []types.String `tfsdk:"granularities" tf:""` + // Optional column that contains the ground truth for the prediction. + LabelCol types.String `tfsdk:"label_col" tf:"optional"` + // Column that contains the id of the model generating the predictions. + // Metrics will be computed per model id by default, and also across all + // model ids. + ModelIdCol types.String `tfsdk:"model_id_col" tf:""` + // Column that contains the output/prediction from the model. + PredictionCol types.String `tfsdk:"prediction_col" tf:""` + // Optional column that contains the prediction probabilities for each class + // in a classification problem type. The values in this column should be a + // map, mapping each class label to the prediction probability for a given + // sample. The map should be of PySpark MapType(). + PredictionProbaCol types.String `tfsdk:"prediction_proba_col" tf:"optional"` + // Problem type the model aims to solve. Determines the type of + // model-quality metrics that will be computed. + ProblemType types.String `tfsdk:"problem_type" tf:""` + // Column that contains the timestamps of requests. The column must be one + // of the following: - A ``TimestampType`` column - A column whose values + // can be converted to timestamps through the pyspark ``to_timestamp`` + // [function]. + // + // [function]: https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.to_timestamp.html + TimestampCol types.String `tfsdk:"timestamp_col" tf:""` +} + +type MonitorInfo struct { + // The directory to store monitoring assets (e.g. dashboard, metric tables). + AssetsDir types.String `tfsdk:"assets_dir" tf:"optional"` + // Name of the baseline table from which drift metrics are computed from. + // Columns in the monitored table should also be present in the baseline + // table. + BaselineTableName types.String `tfsdk:"baseline_table_name" tf:"optional"` + // Custom metrics to compute on the monitored table. These can be aggregate + // metrics, derived metrics (from already computed aggregate metrics), or + // drift metrics (comparing metrics across time windows). + CustomMetrics []MonitorMetric `tfsdk:"custom_metrics" tf:"optional"` + // Id of dashboard that visualizes the computed metrics. This can be empty + // if the monitor is in PENDING state. + DashboardId types.String `tfsdk:"dashboard_id" tf:"optional"` + // The data classification config for the monitor. + DataClassificationConfig *MonitorDataClassificationConfig `tfsdk:"data_classification_config" tf:"optional"` + // The full name of the drift metrics table. Format: + // __catalog_name__.__schema_name__.__table_name__. + DriftMetricsTableName types.String `tfsdk:"drift_metrics_table_name" tf:""` + // Configuration for monitoring inference logs. + InferenceLog *MonitorInferenceLog `tfsdk:"inference_log" tf:"optional"` + // The latest failure message of the monitor (if any). + LatestMonitorFailureMsg types.String `tfsdk:"latest_monitor_failure_msg" tf:"optional"` + // The version of the monitor config (e.g. 1,2,3). If negative, the monitor + // may be corrupted. + MonitorVersion types.String `tfsdk:"monitor_version" tf:""` + // The notification settings for the monitor. + Notifications *MonitorNotifications `tfsdk:"notifications" tf:"optional"` + // Schema where output metric tables are created. + OutputSchemaName types.String `tfsdk:"output_schema_name" tf:"optional"` + // The full name of the profile metrics table. Format: + // __catalog_name__.__schema_name__.__table_name__. + ProfileMetricsTableName types.String `tfsdk:"profile_metrics_table_name" tf:""` + // The schedule for automatically updating and refreshing metric tables. + Schedule *MonitorCronSchedule `tfsdk:"schedule" tf:"optional"` + // List of column expressions to slice data with for targeted analysis. The + // data is grouped by each expression independently, resulting in a separate + // slice for each predicate and its complements. For high-cardinality + // columns, only the top 100 unique values by frequency will generate + // slices. + SlicingExprs []types.String `tfsdk:"slicing_exprs" tf:"optional"` + // Configuration for monitoring snapshot tables. + Snapshot *MonitorSnapshot `tfsdk:"snapshot" tf:"optional"` + // The status of the monitor. + Status types.String `tfsdk:"status" tf:""` + // The full name of the table to monitor. Format: + // __catalog_name__.__schema_name__.__table_name__. + TableName types.String `tfsdk:"table_name" tf:""` + // Configuration for monitoring time series tables. + TimeSeries *MonitorTimeSeries `tfsdk:"time_series" tf:"optional"` +} + +type MonitorMetric struct { + // Jinja template for a SQL expression that specifies how to compute the + // metric. See [create metric definition]. + // + // [create metric definition]: https://docs.databricks.com/en/lakehouse-monitoring/custom-metrics.html#create-definition + Definition types.String `tfsdk:"definition" tf:""` + // A list of column names in the input table the metric should be computed + // for. Can use ``":table"`` to indicate that the metric needs information + // from multiple columns. + InputColumns []types.String `tfsdk:"input_columns" tf:""` + // Name of the metric in the output tables. + Name types.String `tfsdk:"name" tf:""` + // The output type of the custom metric. + OutputDataType types.String `tfsdk:"output_data_type" tf:""` + // Can only be one of ``"CUSTOM_METRIC_TYPE_AGGREGATE"``, + // ``"CUSTOM_METRIC_TYPE_DERIVED"``, or ``"CUSTOM_METRIC_TYPE_DRIFT"``. The + // ``"CUSTOM_METRIC_TYPE_AGGREGATE"`` and ``"CUSTOM_METRIC_TYPE_DERIVED"`` + // metrics are computed on a single table, whereas the + // ``"CUSTOM_METRIC_TYPE_DRIFT"`` compare metrics across baseline and input + // table, or across the two consecutive time windows. - + // CUSTOM_METRIC_TYPE_AGGREGATE: only depend on the existing columns in your + // table - CUSTOM_METRIC_TYPE_DERIVED: depend on previously computed + // aggregate metrics - CUSTOM_METRIC_TYPE_DRIFT: depend on previously + // computed aggregate or derived metrics + Type types.String `tfsdk:"type" tf:""` +} + +type MonitorNotifications struct { + // Who to send notifications to on monitor failure. + OnFailure *MonitorDestination `tfsdk:"on_failure" tf:"optional"` + // Who to send notifications to when new data classification tags are + // detected. + OnNewClassificationTagDetected *MonitorDestination `tfsdk:"on_new_classification_tag_detected" tf:"optional"` +} + +type MonitorRefreshInfo struct { + // Time at which refresh operation completed (milliseconds since 1/1/1970 + // UTC). + EndTimeMs types.Int64 `tfsdk:"end_time_ms" tf:"optional"` + // An optional message to give insight into the current state of the job + // (e.g. FAILURE messages). + Message types.String `tfsdk:"message" tf:"optional"` + // Unique id of the refresh operation. + RefreshId types.Int64 `tfsdk:"refresh_id" tf:""` + // Time at which refresh operation was initiated (milliseconds since + // 1/1/1970 UTC). + StartTimeMs types.Int64 `tfsdk:"start_time_ms" tf:""` + // The current state of the refresh. + State types.String `tfsdk:"state" tf:""` + // The method by which the refresh was triggered. + Trigger types.String `tfsdk:"trigger" tf:"optional"` +} + +type MonitorRefreshListResponse struct { + // List of refreshes. + Refreshes []MonitorRefreshInfo `tfsdk:"refreshes" tf:"optional"` +} + +type MonitorSnapshot struct { +} + +type MonitorTimeSeries struct { + // Granularities for aggregating data into time windows based on their + // timestamp. Currently the following static granularities are supported: + // {``"5 minutes"``, ``"30 minutes"``, ``"1 hour"``, ``"1 day"``, ``" + // week(s)"``, ``"1 month"``, ``"1 year"``}. + Granularities []types.String `tfsdk:"granularities" tf:""` + // Column that contains the timestamps of requests. The column must be one + // of the following: - A ``TimestampType`` column - A column whose values + // can be converted to timestamps through the pyspark ``to_timestamp`` + // [function]. + // + // [function]: https://spark.apache.org/docs/latest/api/python/reference/pyspark.sql/api/pyspark.sql.functions.to_timestamp.html + TimestampCol types.String `tfsdk:"timestamp_col" tf:""` +} + +type NamedTableConstraint struct { + // The name of the constraint. + Name types.String `tfsdk:"name" tf:""` +} + +// Online Table information. +type OnlineTable struct { + // Full three-part (catalog, schema, table) name of the table. + Name types.String `tfsdk:"name" tf:"optional"` + // Specification of the online table. + Spec *OnlineTableSpec `tfsdk:"spec" tf:"optional"` + // Online Table status + Status *OnlineTableStatus `tfsdk:"status" tf:"optional"` + // Data serving REST API URL for this table + TableServingUrl types.String `tfsdk:"table_serving_url" tf:"optional"` +} + +// Specification of an online table. +type OnlineTableSpec struct { + // Whether to create a full-copy pipeline -- a pipeline that stops after + // creates a full copy of the source table upon initialization and does not + // process any change data feeds (CDFs) afterwards. The pipeline can still + // be manually triggered afterwards, but it always perform a full copy of + // the source table and there are no incremental updates. This mode is + // useful for syncing views or tables without CDFs to online tables. Note + // that the full-copy pipeline only supports "triggered" scheduling policy. + PerformFullCopy types.Bool `tfsdk:"perform_full_copy" tf:"optional"` + // ID of the associated pipeline. Generated by the server - cannot be set by + // the caller. + PipelineId types.String `tfsdk:"pipeline_id" tf:"optional"` + // Primary Key columns to be used for data insert/update in the destination. + PrimaryKeyColumns []types.String `tfsdk:"primary_key_columns" tf:"optional"` + // Pipeline runs continuously after generating the initial data. + RunContinuously *OnlineTableSpecContinuousSchedulingPolicy `tfsdk:"run_continuously" tf:"optional"` + // Pipeline stops after generating the initial data and can be triggered + // later (manually, through a cron job or through data triggers) + RunTriggered *OnlineTableSpecTriggeredSchedulingPolicy `tfsdk:"run_triggered" tf:"optional"` + // Three-part (catalog, schema, table) name of the source Delta table. + SourceTableFullName types.String `tfsdk:"source_table_full_name" tf:"optional"` + // Time series key to deduplicate (tie-break) rows with the same primary + // key. + TimeseriesKey types.String `tfsdk:"timeseries_key" tf:"optional"` +} + +type OnlineTableSpecContinuousSchedulingPolicy struct { +} + +type OnlineTableSpecTriggeredSchedulingPolicy struct { +} + +// Status of an online table. +type OnlineTableStatus struct { + // Detailed status of an online table. Shown if the online table is in the + // ONLINE_CONTINUOUS_UPDATE or the ONLINE_UPDATING_PIPELINE_RESOURCES state. + ContinuousUpdateStatus *ContinuousUpdateStatus `tfsdk:"continuous_update_status" tf:"optional"` + // The state of the online table. + DetailedState types.String `tfsdk:"detailed_state" tf:"optional"` + // Detailed status of an online table. Shown if the online table is in the + // OFFLINE_FAILED or the ONLINE_PIPELINE_FAILED state. + FailedStatus *FailedStatus `tfsdk:"failed_status" tf:"optional"` + // A text description of the current state of the online table. + Message types.String `tfsdk:"message" tf:"optional"` + // Detailed status of an online table. Shown if the online table is in the + // PROVISIONING_PIPELINE_RESOURCES or the PROVISIONING_INITIAL_SNAPSHOT + // state. + ProvisioningStatus *ProvisioningStatus `tfsdk:"provisioning_status" tf:"optional"` + // Detailed status of an online table. Shown if the online table is in the + // ONLINE_TRIGGERED_UPDATE or the ONLINE_NO_PENDING_UPDATE state. + TriggeredUpdateStatus *TriggeredUpdateStatus `tfsdk:"triggered_update_status" tf:"optional"` +} + +type PermissionsChange struct { + // The set of privileges to add. + Add []types.String `tfsdk:"add" tf:"optional"` + // The principal whose privileges we are changing. + Principal types.String `tfsdk:"principal" tf:"optional"` + // The set of privileges to remove. + Remove []types.String `tfsdk:"remove" tf:"optional"` +} + +type PermissionsList struct { + // The privileges assigned to each principal + PrivilegeAssignments []PrivilegeAssignment `tfsdk:"privilege_assignments" tf:"optional"` +} + +// Progress information of the Online Table data synchronization pipeline. +type PipelineProgress struct { + // The estimated time remaining to complete this update in seconds. + EstimatedCompletionTimeSeconds types.Float64 `tfsdk:"estimated_completion_time_seconds" tf:"optional"` + // The source table Delta version that was last processed by the pipeline. + // The pipeline may not have completely processed this version yet. + LatestVersionCurrentlyProcessing types.Int64 `tfsdk:"latest_version_currently_processing" tf:"optional"` + // The completion ratio of this update. This is a number between 0 and 1. + SyncProgressCompletion types.Float64 `tfsdk:"sync_progress_completion" tf:"optional"` + // The number of rows that have been synced in this update. + SyncedRowCount types.Int64 `tfsdk:"synced_row_count" tf:"optional"` + // The total number of rows that need to be synced in this update. This + // number may be an estimate. + TotalRowCount types.Int64 `tfsdk:"total_row_count" tf:"optional"` +} + +type PrimaryKeyConstraint struct { + // Column names for this constraint. + ChildColumns []types.String `tfsdk:"child_columns" tf:""` + // The name of the constraint. + Name types.String `tfsdk:"name" tf:""` +} + +type PrivilegeAssignment struct { + // The principal (user email address or group name). + Principal types.String `tfsdk:"principal" tf:"optional"` + // The privileges assigned to the principal. + Privileges []types.String `tfsdk:"privileges" tf:"optional"` +} + +// Status of an asynchronously provisioned resource. +type ProvisioningInfo struct { + State types.String `tfsdk:"state" tf:"optional"` +} + +// Detailed status of an online table. Shown if the online table is in the +// PROVISIONING_PIPELINE_RESOURCES or the PROVISIONING_INITIAL_SNAPSHOT state. +type ProvisioningStatus struct { + // Details about initial data synchronization. Only populated when in the + // PROVISIONING_INITIAL_SNAPSHOT state. + InitialPipelineSyncProgress *PipelineProgress `tfsdk:"initial_pipeline_sync_progress" tf:"optional"` +} + +// Get a Volume +type ReadVolumeRequest struct { + // Whether to include volumes in the response for which the principal can + // only access selective metadata for + IncludeBrowse types.Bool `tfsdk:"-"` + // The three-level (fully qualified) name of the volume + Name types.String `tfsdk:"-"` +} + +// Registered model alias. +type RegisteredModelAlias struct { + // Name of the alias, e.g. 'champion' or 'latest_stable' + AliasName types.String `tfsdk:"alias_name" tf:"optional"` + // Integer version number of the model version to which this alias points. + VersionNum types.Int64 `tfsdk:"version_num" tf:"optional"` +} + +type RegisteredModelInfo struct { + // List of aliases associated with the registered model + Aliases []RegisteredModelAlias `tfsdk:"aliases" tf:"optional"` + // Indicates whether the principal is limited to retrieving metadata for the + // associated object through the BROWSE privilege when include_browse is + // enabled in the request. + BrowseOnly types.Bool `tfsdk:"browse_only" tf:"optional"` + // The name of the catalog where the schema and the registered model reside + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // The comment attached to the registered model + Comment types.String `tfsdk:"comment" tf:"optional"` + // Creation timestamp of the registered model in milliseconds since the Unix + // epoch + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // The identifier of the user who created the registered model + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // The three-level (fully qualified) name of the registered model + FullName types.String `tfsdk:"full_name" tf:"optional"` + // The unique identifier of the metastore + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // The name of the registered model + Name types.String `tfsdk:"name" tf:"optional"` + // The identifier of the user who owns the registered model + Owner types.String `tfsdk:"owner" tf:"optional"` + // The name of the schema where the registered model resides + SchemaName types.String `tfsdk:"schema_name" tf:"optional"` + // The storage location on the cloud under which model version data files + // are stored + StorageLocation types.String `tfsdk:"storage_location" tf:"optional"` + // Last-update timestamp of the registered model in milliseconds since the + // Unix epoch + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // The identifier of the user who updated the registered model last time + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +// Queue a metric refresh for a monitor +type RunRefreshRequest struct { + // Full name of the table. + TableName types.String `tfsdk:"-"` +} + +type SchemaInfo struct { + // Indicates whether the principal is limited to retrieving metadata for the + // associated object through the BROWSE privilege when include_browse is + // enabled in the request. + BrowseOnly types.Bool `tfsdk:"browse_only" tf:"optional"` + // Name of parent catalog. + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // The type of the parent catalog. + CatalogType types.String `tfsdk:"catalog_type" tf:"optional"` + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Time at which this schema was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of schema creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + + EffectivePredictiveOptimizationFlag *EffectivePredictiveOptimizationFlag `tfsdk:"effective_predictive_optimization_flag" tf:"optional"` + // Whether predictive optimization should be enabled for this object and + // objects under it. + EnablePredictiveOptimization types.String `tfsdk:"enable_predictive_optimization" tf:"optional"` + // Full name of schema, in form of __catalog_name__.__schema_name__. + FullName types.String `tfsdk:"full_name" tf:"optional"` + // Unique identifier of parent metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // Name of schema, relative to parent catalog. + Name types.String `tfsdk:"name" tf:"optional"` + // Username of current owner of schema. + Owner types.String `tfsdk:"owner" tf:"optional"` + // A map of key-value properties attached to the securable. + Properties map[string]types.String `tfsdk:"properties" tf:"optional"` + // The unique identifier of the schema. + SchemaId types.String `tfsdk:"schema_id" tf:"optional"` + // Storage location for managed tables within schema. + StorageLocation types.String `tfsdk:"storage_location" tf:"optional"` + // Storage root URL for managed tables within schema. + StorageRoot types.String `tfsdk:"storage_root" tf:"optional"` + // Time at which this schema was created, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of user who last modified schema. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type SetArtifactAllowlist struct { + // A list of allowed artifact match patterns. + ArtifactMatchers []ArtifactMatcher `tfsdk:"artifact_matchers" tf:""` + // The artifact type of the allowlist. + ArtifactType types.String `tfsdk:"-"` +} + +type SetRegisteredModelAliasRequest struct { + // The name of the alias + Alias types.String `tfsdk:"alias" tf:""` + // Full name of the registered model + FullName types.String `tfsdk:"full_name" tf:""` + // The version number of the model version to which the alias points + VersionNum types.Int64 `tfsdk:"version_num" tf:""` +} + +// Server-Side Encryption properties for clients communicating with AWS s3. +type SseEncryptionDetails struct { + // The type of key encryption to use (affects headers from s3 client). + Algorithm types.String `tfsdk:"algorithm" tf:"optional"` + // When algorithm is **AWS_SSE_KMS** this field specifies the ARN of the SSE + // key to use. + AwsKmsKeyArn types.String `tfsdk:"aws_kms_key_arn" tf:"optional"` +} + +type StorageCredentialInfo struct { + // The AWS IAM role configuration. + AwsIamRole *AwsIamRoleResponse `tfsdk:"aws_iam_role" tf:"optional"` + // The Azure managed identity configuration. + AzureManagedIdentity *AzureManagedIdentityResponse `tfsdk:"azure_managed_identity" tf:"optional"` + // The Azure service principal configuration. + AzureServicePrincipal *AzureServicePrincipal `tfsdk:"azure_service_principal" tf:"optional"` + // The Cloudflare API token configuration. + CloudflareApiToken *CloudflareApiToken `tfsdk:"cloudflare_api_token" tf:"optional"` + // Comment associated with the credential. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Time at which this Credential was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of credential creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // The Databricks managed GCP service account configuration. + DatabricksGcpServiceAccount *DatabricksGcpServiceAccountResponse `tfsdk:"databricks_gcp_service_account" tf:"optional"` + // The unique identifier of the credential. + Id types.String `tfsdk:"id" tf:"optional"` + // Whether the current securable is accessible from all workspaces or a + // specific set of workspaces. + IsolationMode types.String `tfsdk:"isolation_mode" tf:"optional"` + // Unique identifier of parent metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // The credential name. The name must be unique within the metastore. + Name types.String `tfsdk:"name" tf:"optional"` + // Username of current owner of credential. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Whether the storage credential is only usable for read operations. + ReadOnly types.Bool `tfsdk:"read_only" tf:"optional"` + // Time at which this credential was last modified, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of user who last modified the credential. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` + // Whether this credential is the current metastore's root storage + // credential. + UsedForManagedStorage types.Bool `tfsdk:"used_for_managed_storage" tf:"optional"` +} + +type SystemSchemaInfo struct { + // Name of the system schema. + Schema types.String `tfsdk:"schema" tf:"optional"` + // The current state of enablement for the system schema. An empty string + // means the system schema is available and ready for opt-in. + State types.String `tfsdk:"state" tf:"optional"` +} + +// A table constraint, as defined by *one* of the following fields being set: +// __primary_key_constraint__, __foreign_key_constraint__, +// __named_table_constraint__. +type TableConstraint struct { + ForeignKeyConstraint *ForeignKeyConstraint `tfsdk:"foreign_key_constraint" tf:"optional"` + + NamedTableConstraint *NamedTableConstraint `tfsdk:"named_table_constraint" tf:"optional"` + + PrimaryKeyConstraint *PrimaryKeyConstraint `tfsdk:"primary_key_constraint" tf:"optional"` +} + +// A table that is dependent on a SQL object. +type TableDependency struct { + // Full name of the dependent table, in the form of + // __catalog_name__.__schema_name__.__table_name__. + TableFullName types.String `tfsdk:"table_full_name" tf:""` +} + +type TableExistsResponse struct { + // Whether the table exists or not. + TableExists types.Bool `tfsdk:"table_exists" tf:"optional"` +} + +type TableInfo struct { + // The AWS access point to use when accesing s3 for this external location. + AccessPoint types.String `tfsdk:"access_point" tf:"optional"` + // Indicates whether the principal is limited to retrieving metadata for the + // associated object through the BROWSE privilege when include_browse is + // enabled in the request. + BrowseOnly types.Bool `tfsdk:"browse_only" tf:"optional"` + // Name of parent catalog. + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // The array of __ColumnInfo__ definitions of the table's columns. + Columns []ColumnInfo `tfsdk:"columns" tf:"optional"` + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Time at which this table was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of table creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Unique ID of the Data Access Configuration to use with the table data. + DataAccessConfigurationId types.String `tfsdk:"data_access_configuration_id" tf:"optional"` + // Data source format + DataSourceFormat types.String `tfsdk:"data_source_format" tf:"optional"` + // Time at which this table was deleted, in epoch milliseconds. Field is + // omitted if table is not deleted. + DeletedAt types.Int64 `tfsdk:"deleted_at" tf:"optional"` + // Information pertaining to current state of the delta table. + DeltaRuntimePropertiesKvpairs *DeltaRuntimePropertiesKvPairs `tfsdk:"delta_runtime_properties_kvpairs" tf:"optional"` + + EffectivePredictiveOptimizationFlag *EffectivePredictiveOptimizationFlag `tfsdk:"effective_predictive_optimization_flag" tf:"optional"` + // Whether predictive optimization should be enabled for this object and + // objects under it. + EnablePredictiveOptimization types.String `tfsdk:"enable_predictive_optimization" tf:"optional"` + // Encryption options that apply to clients connecting to cloud storage. + EncryptionDetails *EncryptionDetails `tfsdk:"encryption_details" tf:"optional"` + // Full name of table, in form of + // __catalog_name__.__schema_name__.__table_name__ + FullName types.String `tfsdk:"full_name" tf:"optional"` + // Unique identifier of parent metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // Name of table, relative to parent schema. + Name types.String `tfsdk:"name" tf:"optional"` + // Username of current owner of table. + Owner types.String `tfsdk:"owner" tf:"optional"` + // The pipeline ID of the table. Applicable for tables created by pipelines + // (Materialized View, Streaming Table, etc.). + PipelineId types.String `tfsdk:"pipeline_id" tf:"optional"` + // A map of key-value properties attached to the securable. + Properties map[string]types.String `tfsdk:"properties" tf:"optional"` + + RowFilter *TableRowFilter `tfsdk:"row_filter" tf:"optional"` + // Name of parent schema relative to its parent catalog. + SchemaName types.String `tfsdk:"schema_name" tf:"optional"` + // List of schemes whose objects can be referenced without qualification. + SqlPath types.String `tfsdk:"sql_path" tf:"optional"` + // Name of the storage credential, when a storage credential is configured + // for use with this table. + StorageCredentialName types.String `tfsdk:"storage_credential_name" tf:"optional"` + // Storage root URL for table (for **MANAGED**, **EXTERNAL** tables) + StorageLocation types.String `tfsdk:"storage_location" tf:"optional"` + // List of table constraints. Note: this field is not set in the output of + // the __listTables__ API. + TableConstraints []TableConstraint `tfsdk:"table_constraints" tf:"optional"` + // The unique identifier of the table. + TableId types.String `tfsdk:"table_id" tf:"optional"` + + TableType types.String `tfsdk:"table_type" tf:"optional"` + // Time at which this table was last modified, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of user who last modified the table. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` + // View definition SQL (when __table_type__ is **VIEW**, + // **MATERIALIZED_VIEW**, or **STREAMING_TABLE**) + ViewDefinition types.String `tfsdk:"view_definition" tf:"optional"` + // View dependencies (when table_type == **VIEW** or **MATERIALIZED_VIEW**, + // **STREAMING_TABLE**) - when DependencyList is None, the dependency is not + // provided; - when DependencyList is an empty list, the dependency is + // provided but is empty; - when DependencyList is not an empty list, + // dependencies are provided and recorded. + ViewDependencies *DependencyList `tfsdk:"view_dependencies" tf:"optional"` +} + +type TableRowFilter struct { + // The full name of the row filter SQL UDF. + FunctionName types.String `tfsdk:"function_name" tf:""` + // The list of table columns to be passed as input to the row filter + // function. The column types should match the types of the filter function + // arguments. + InputColumnNames []types.String `tfsdk:"input_column_names" tf:""` +} + +type TableSummary struct { + // The full name of the table. + FullName types.String `tfsdk:"full_name" tf:"optional"` + + TableType types.String `tfsdk:"table_type" tf:"optional"` +} + +// Detailed status of an online table. Shown if the online table is in the +// ONLINE_TRIGGERED_UPDATE or the ONLINE_NO_PENDING_UPDATE state. +type TriggeredUpdateStatus struct { + // The last source table Delta version that was synced to the online table. + // Note that this Delta version may not be completely synced to the online + // table yet. + LastProcessedCommitVersion types.Int64 `tfsdk:"last_processed_commit_version" tf:"optional"` + // The timestamp of the last time any data was synchronized from the source + // table to the online table. + Timestamp types.String `tfsdk:"timestamp" tf:"optional"` + // Progress of the active data synchronization pipeline. + TriggeredUpdateProgress *PipelineProgress `tfsdk:"triggered_update_progress" tf:"optional"` +} + +// Delete an assignment +type UnassignRequest struct { + // Query for the ID of the metastore to delete. + MetastoreId types.String `tfsdk:"-"` + // A workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type UnassignResponse struct { +} + +type UpdateAssignmentResponse struct { +} + +type UpdateCatalog struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Whether predictive optimization should be enabled for this object and + // objects under it. + EnablePredictiveOptimization types.String `tfsdk:"enable_predictive_optimization" tf:"optional"` + // Whether the current securable is accessible from all workspaces or a + // specific set of workspaces. + IsolationMode types.String `tfsdk:"isolation_mode" tf:"optional"` + // The name of the catalog. + Name types.String `tfsdk:"-"` + // New name for the catalog. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // Username of current owner of catalog. + Owner types.String `tfsdk:"owner" tf:"optional"` + // A map of key-value properties attached to the securable. + Properties map[string]types.String `tfsdk:"properties" tf:"optional"` +} + +type UpdateConnection struct { + // Name of the connection. + Name types.String `tfsdk:"-"` + // New name for the connection. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // A map of key-value properties attached to the securable. + Options map[string]types.String `tfsdk:"options" tf:""` + // Username of current owner of the connection. + Owner types.String `tfsdk:"owner" tf:"optional"` +} + +type UpdateExternalLocation struct { + // The AWS access point to use when accesing s3 for this external location. + AccessPoint types.String `tfsdk:"access_point" tf:"optional"` + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of the storage credential used with this location. + CredentialName types.String `tfsdk:"credential_name" tf:"optional"` + // Encryption options that apply to clients connecting to cloud storage. + EncryptionDetails *EncryptionDetails `tfsdk:"encryption_details" tf:"optional"` + // Force update even if changing url invalidates dependent external tables + // or mounts. + Force types.Bool `tfsdk:"force" tf:"optional"` + // Whether the current securable is accessible from all workspaces or a + // specific set of workspaces. + IsolationMode types.String `tfsdk:"isolation_mode" tf:"optional"` + // Name of the external location. + Name types.String `tfsdk:"-"` + // New name for the external location. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // The owner of the external location. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Indicates whether the external location is read-only. + ReadOnly types.Bool `tfsdk:"read_only" tf:"optional"` + // Skips validation of the storage credential associated with the external + // location. + SkipValidation types.Bool `tfsdk:"skip_validation" tf:"optional"` + // Path URL of the external location. + Url types.String `tfsdk:"url" tf:"optional"` +} + +type UpdateFunction struct { + // The fully-qualified name of the function (of the form + // __catalog_name__.__schema_name__.__function__name__). + Name types.String `tfsdk:"-"` + // Username of current owner of function. + Owner types.String `tfsdk:"owner" tf:"optional"` +} + +type UpdateMetastore struct { + // The organization name of a Delta Sharing entity, to be used in + // Databricks-to-Databricks Delta Sharing as the official name. + DeltaSharingOrganizationName types.String `tfsdk:"delta_sharing_organization_name" tf:"optional"` + // The lifetime of delta sharing recipient token in seconds. + DeltaSharingRecipientTokenLifetimeInSeconds types.Int64 `tfsdk:"delta_sharing_recipient_token_lifetime_in_seconds" tf:"optional"` + // The scope of Delta Sharing enabled for the metastore. + DeltaSharingScope types.String `tfsdk:"delta_sharing_scope" tf:"optional"` + // Unique ID of the metastore. + Id types.String `tfsdk:"-"` + // New name for the metastore. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // The owner of the metastore. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Privilege model version of the metastore, of the form `major.minor` + // (e.g., `1.0`). + PrivilegeModelVersion types.String `tfsdk:"privilege_model_version" tf:"optional"` + // UUID of storage credential to access the metastore storage_root. + StorageRootCredentialId types.String `tfsdk:"storage_root_credential_id" tf:"optional"` +} + +type UpdateMetastoreAssignment struct { + // The name of the default catalog for the metastore. + DefaultCatalogName types.String `tfsdk:"default_catalog_name" tf:"optional"` + // The unique ID of the metastore. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // A workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type UpdateModelVersionRequest struct { + // The comment attached to the model version + Comment types.String `tfsdk:"comment" tf:"optional"` + // The three-level (fully qualified) name of the model version + FullName types.String `tfsdk:"-"` + // The integer version number of the model version + Version types.Int64 `tfsdk:"-"` +} + +type UpdateMonitor struct { + // Name of the baseline table from which drift metrics are computed from. + // Columns in the monitored table should also be present in the baseline + // table. + BaselineTableName types.String `tfsdk:"baseline_table_name" tf:"optional"` + // Custom metrics to compute on the monitored table. These can be aggregate + // metrics, derived metrics (from already computed aggregate metrics), or + // drift metrics (comparing metrics across time windows). + CustomMetrics []MonitorMetric `tfsdk:"custom_metrics" tf:"optional"` + // Id of dashboard that visualizes the computed metrics. This can be empty + // if the monitor is in PENDING state. + DashboardId types.String `tfsdk:"dashboard_id" tf:"optional"` + // The data classification config for the monitor. + DataClassificationConfig *MonitorDataClassificationConfig `tfsdk:"data_classification_config" tf:"optional"` + // Configuration for monitoring inference logs. + InferenceLog *MonitorInferenceLog `tfsdk:"inference_log" tf:"optional"` + // The notification settings for the monitor. + Notifications *MonitorNotifications `tfsdk:"notifications" tf:"optional"` + // Schema where output metric tables are created. + OutputSchemaName types.String `tfsdk:"output_schema_name" tf:""` + // The schedule for automatically updating and refreshing metric tables. + Schedule *MonitorCronSchedule `tfsdk:"schedule" tf:"optional"` + // List of column expressions to slice data with for targeted analysis. The + // data is grouped by each expression independently, resulting in a separate + // slice for each predicate and its complements. For high-cardinality + // columns, only the top 100 unique values by frequency will generate + // slices. + SlicingExprs []types.String `tfsdk:"slicing_exprs" tf:"optional"` + // Configuration for monitoring snapshot tables. + Snapshot *MonitorSnapshot `tfsdk:"snapshot" tf:"optional"` + // Full name of the table. + TableName types.String `tfsdk:"-"` + // Configuration for monitoring time series tables. + TimeSeries *MonitorTimeSeries `tfsdk:"time_series" tf:"optional"` +} + +type UpdatePermissions struct { + // Array of permissions change objects. + Changes []PermissionsChange `tfsdk:"changes" tf:"optional"` + // Full name of securable. + FullName types.String `tfsdk:"-"` + // Type of securable. + SecurableType types.String `tfsdk:"-"` +} + +type UpdateRegisteredModelRequest struct { + // The comment attached to the registered model + Comment types.String `tfsdk:"comment" tf:"optional"` + // The three-level (fully qualified) name of the registered model + FullName types.String `tfsdk:"-"` + // New name for the registered model. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // The identifier of the user who owns the registered model + Owner types.String `tfsdk:"owner" tf:"optional"` +} + +type UpdateResponse struct { +} + +type UpdateSchema struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Whether predictive optimization should be enabled for this object and + // objects under it. + EnablePredictiveOptimization types.String `tfsdk:"enable_predictive_optimization" tf:"optional"` + // Full name of the schema. + FullName types.String `tfsdk:"-"` + // New name for the schema. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // Username of current owner of schema. + Owner types.String `tfsdk:"owner" tf:"optional"` + // A map of key-value properties attached to the securable. + Properties map[string]types.String `tfsdk:"properties" tf:"optional"` +} + +type UpdateStorageCredential struct { + // The AWS IAM role configuration. + AwsIamRole *AwsIamRoleRequest `tfsdk:"aws_iam_role" tf:"optional"` + // The Azure managed identity configuration. + AzureManagedIdentity *AzureManagedIdentityResponse `tfsdk:"azure_managed_identity" tf:"optional"` + // The Azure service principal configuration. + AzureServicePrincipal *AzureServicePrincipal `tfsdk:"azure_service_principal" tf:"optional"` + // The Cloudflare API token configuration. + CloudflareApiToken *CloudflareApiToken `tfsdk:"cloudflare_api_token" tf:"optional"` + // Comment associated with the credential. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The Databricks managed GCP service account configuration. + DatabricksGcpServiceAccount *DatabricksGcpServiceAccountRequest `tfsdk:"databricks_gcp_service_account" tf:"optional"` + // Force update even if there are dependent external locations or external + // tables. + Force types.Bool `tfsdk:"force" tf:"optional"` + // Whether the current securable is accessible from all workspaces or a + // specific set of workspaces. + IsolationMode types.String `tfsdk:"isolation_mode" tf:"optional"` + // Name of the storage credential. + Name types.String `tfsdk:"-"` + // New name for the storage credential. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // Username of current owner of credential. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Whether the storage credential is only usable for read operations. + ReadOnly types.Bool `tfsdk:"read_only" tf:"optional"` + // Supplying true to this argument skips validation of the updated + // credential. + SkipValidation types.Bool `tfsdk:"skip_validation" tf:"optional"` +} + +// Update a table owner. +type UpdateTableRequest struct { + // Full name of the table. + FullName types.String `tfsdk:"-"` + + Owner types.String `tfsdk:"owner" tf:"optional"` +} + +type UpdateVolumeRequestContent struct { + // The comment attached to the volume + Comment types.String `tfsdk:"comment" tf:"optional"` + // The three-level (fully qualified) name of the volume + Name types.String `tfsdk:"-"` + // New name for the volume. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // The identifier of the user who owns the volume + Owner types.String `tfsdk:"owner" tf:"optional"` +} + +type UpdateWorkspaceBindings struct { + // A list of workspace IDs. + AssignWorkspaces []types.Int64 `tfsdk:"assign_workspaces" tf:"optional"` + // The name of the catalog. + Name types.String `tfsdk:"-"` + // A list of workspace IDs. + UnassignWorkspaces []types.Int64 `tfsdk:"unassign_workspaces" tf:"optional"` +} + +type UpdateWorkspaceBindingsParameters struct { + // List of workspace bindings + Add []WorkspaceBinding `tfsdk:"add" tf:"optional"` + // List of workspace bindings + Remove []WorkspaceBinding `tfsdk:"remove" tf:"optional"` + // The name of the securable. + SecurableName types.String `tfsdk:"-"` + // The type of the securable. + SecurableType types.String `tfsdk:"-"` +} + +type ValidateStorageCredential struct { + // The AWS IAM role configuration. + AwsIamRole *AwsIamRoleRequest `tfsdk:"aws_iam_role" tf:"optional"` + // The Azure managed identity configuration. + AzureManagedIdentity *AzureManagedIdentityRequest `tfsdk:"azure_managed_identity" tf:"optional"` + // The Azure service principal configuration. + AzureServicePrincipal *AzureServicePrincipal `tfsdk:"azure_service_principal" tf:"optional"` + // The Cloudflare API token configuration. + CloudflareApiToken *CloudflareApiToken `tfsdk:"cloudflare_api_token" tf:"optional"` + // The Databricks created GCP service account configuration. + DatabricksGcpServiceAccount *DatabricksGcpServiceAccountRequest `tfsdk:"databricks_gcp_service_account" tf:"optional"` + // The name of an existing external location to validate. + ExternalLocationName types.String `tfsdk:"external_location_name" tf:"optional"` + // Whether the storage credential is only usable for read operations. + ReadOnly types.Bool `tfsdk:"read_only" tf:"optional"` + // The name of the storage credential to validate. + StorageCredentialName types.String `tfsdk:"storage_credential_name" tf:"optional"` + // The external location url to validate. + Url types.String `tfsdk:"url" tf:"optional"` +} + +type ValidateStorageCredentialResponse struct { + // Whether the tested location is a directory in cloud storage. + IsDir types.Bool `tfsdk:"isDir" tf:"optional"` + // The results of the validation check. + Results []ValidationResult `tfsdk:"results" tf:"optional"` +} + +type ValidationResult struct { + // Error message would exist when the result does not equal to **PASS**. + Message types.String `tfsdk:"message" tf:"optional"` + // The operation tested. + Operation types.String `tfsdk:"operation" tf:"optional"` + // The results of the tested operation. + Result types.String `tfsdk:"result" tf:"optional"` +} + +type VolumeInfo struct { + // The AWS access point to use when accesing s3 for this external location. + AccessPoint types.String `tfsdk:"access_point" tf:"optional"` + // Indicates whether the principal is limited to retrieving metadata for the + // associated object through the BROWSE privilege when include_browse is + // enabled in the request. + BrowseOnly types.Bool `tfsdk:"browse_only" tf:"optional"` + // The name of the catalog where the schema and the volume are + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // The comment attached to the volume + Comment types.String `tfsdk:"comment" tf:"optional"` + + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // The identifier of the user who created the volume + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Encryption options that apply to clients connecting to cloud storage. + EncryptionDetails *EncryptionDetails `tfsdk:"encryption_details" tf:"optional"` + // The three-level (fully qualified) name of the volume + FullName types.String `tfsdk:"full_name" tf:"optional"` + // The unique identifier of the metastore + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // The name of the volume + Name types.String `tfsdk:"name" tf:"optional"` + // The identifier of the user who owns the volume + Owner types.String `tfsdk:"owner" tf:"optional"` + // The name of the schema where the volume is + SchemaName types.String `tfsdk:"schema_name" tf:"optional"` + // The storage location on the cloud + StorageLocation types.String `tfsdk:"storage_location" tf:"optional"` + + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // The identifier of the user who updated the volume last time + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` + // The unique identifier of the volume + VolumeId types.String `tfsdk:"volume_id" tf:"optional"` + + VolumeType types.String `tfsdk:"volume_type" tf:"optional"` +} + +type WorkspaceBinding struct { + BindingType types.String `tfsdk:"binding_type" tf:"optional"` + + WorkspaceId types.Int64 `tfsdk:"workspace_id" tf:"optional"` +} + +// Currently assigned workspace bindings +type WorkspaceBindingsResponse struct { + // List of workspace bindings + Bindings []WorkspaceBinding `tfsdk:"bindings" tf:"optional"` +} diff --git a/internal/service/compute_tf/model.go b/internal/service/compute_tf/model.go new file mode 100755 index 0000000000..32f137bb33 --- /dev/null +++ b/internal/service/compute_tf/model.go @@ -0,0 +1,2735 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package compute_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type AddInstanceProfile struct { + // The AWS IAM role ARN of the role associated with the instance profile. + // This field is required if your role name and instance profile name do not + // match and you want to use the instance profile with [Databricks SQL + // Serverless]. + // + // Otherwise, this field is optional. + // + // [Databricks SQL Serverless]: https://docs.databricks.com/sql/admin/serverless.html + IamRoleArn types.String `tfsdk:"iam_role_arn" tf:"optional"` + // The AWS ARN of the instance profile to register with Databricks. This + // field is required. + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:""` + // Boolean flag indicating whether the instance profile should only be used + // in credential passthrough scenarios. If true, it means the instance + // profile contains an meta IAM role which could assume a wide range of + // roles. Therefore it should always be used with authorization. This field + // is optional, the default value is `false`. + IsMetaInstanceProfile types.Bool `tfsdk:"is_meta_instance_profile" tf:"optional"` + // By default, Databricks validates that it has sufficient permissions to + // launch instances with the instance profile. This validation uses AWS + // dry-run mode for the RunInstances API. If validation fails with an error + // message that does not indicate an IAM related permission issue, (e.g. + // “Your requested instance type is not supported in your requested + // availability zone”), you can pass this flag to skip the validation and + // forcibly add the instance profile. + SkipValidation types.Bool `tfsdk:"skip_validation" tf:"optional"` +} + +type AddResponse struct { +} + +type Adlsgen2Info struct { + // abfss destination, e.g. + // `abfss://@.dfs.core.windows.net/`. + Destination types.String `tfsdk:"destination" tf:""` +} + +type AutoScale struct { + // The maximum number of workers to which the cluster can scale up when + // overloaded. Note that `max_workers` must be strictly greater than + // `min_workers`. + MaxWorkers types.Int64 `tfsdk:"max_workers" tf:"optional"` + // The minimum number of workers to which the cluster can scale down when + // underutilized. It is also the initial number of workers the cluster will + // have after creation. + MinWorkers types.Int64 `tfsdk:"min_workers" tf:"optional"` +} + +type AwsAttributes struct { + // Availability type used for all subsequent nodes past the + // `first_on_demand` ones. + // + // Note: If `first_on_demand` is zero, this availability type will be used + // for the entire cluster. + Availability types.String `tfsdk:"availability" tf:"optional"` + // The number of volumes launched for each instance. Users can choose up to + // 10 volumes. This feature is only enabled for supported node types. Legacy + // node types cannot specify custom EBS volumes. For node types with no + // instance store, at least one EBS volume needs to be specified; otherwise, + // cluster creation will fail. + // + // These EBS volumes will be mounted at `/ebs0`, `/ebs1`, and etc. Instance + // store volumes will be mounted at `/local_disk0`, `/local_disk1`, and etc. + // + // If EBS volumes are attached, Databricks will configure Spark to use only + // the EBS volumes for scratch storage because heterogenously sized scratch + // devices can lead to inefficient disk utilization. If no EBS volumes are + // attached, Databricks will configure Spark to use instance store volumes. + // + // Please note that if EBS volumes are specified, then the Spark + // configuration `spark.local.dir` will be overridden. + EbsVolumeCount types.Int64 `tfsdk:"ebs_volume_count" tf:"optional"` + // If using gp3 volumes, what IOPS to use for the disk. If this is not set, + // the maximum performance of a gp2 volume with the same volume size will be + // used. + EbsVolumeIops types.Int64 `tfsdk:"ebs_volume_iops" tf:"optional"` + // The size of each EBS volume (in GiB) launched for each instance. For + // general purpose SSD, this value must be within the range 100 - 4096. For + // throughput optimized HDD, this value must be within the range 500 - 4096. + EbsVolumeSize types.Int64 `tfsdk:"ebs_volume_size" tf:"optional"` + // If using gp3 volumes, what throughput to use for the disk. If this is not + // set, the maximum performance of a gp2 volume with the same volume size + // will be used. + EbsVolumeThroughput types.Int64 `tfsdk:"ebs_volume_throughput" tf:"optional"` + // The type of EBS volumes that will be launched with this cluster. + EbsVolumeType types.String `tfsdk:"ebs_volume_type" tf:"optional"` + // The first `first_on_demand` nodes of the cluster will be placed on + // on-demand instances. If this value is greater than 0, the cluster driver + // node in particular will be placed on an on-demand instance. If this value + // is greater than or equal to the current cluster size, all nodes will be + // placed on on-demand instances. If this value is less than the current + // cluster size, `first_on_demand` nodes will be placed on on-demand + // instances and the remainder will be placed on `availability` instances. + // Note that this value does not affect cluster size and cannot currently be + // mutated over the lifetime of a cluster. + FirstOnDemand types.Int64 `tfsdk:"first_on_demand" tf:"optional"` + // Nodes for this cluster will only be placed on AWS instances with this + // instance profile. If ommitted, nodes will be placed on instances without + // an IAM instance profile. The instance profile must have previously been + // added to the Databricks environment by an account administrator. + // + // This feature may only be available to certain customer plans. + // + // If this field is ommitted, we will pull in the default from the conf if + // it exists. + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // The bid price for AWS spot instances, as a percentage of the + // corresponding instance type's on-demand price. For example, if this field + // is set to 50, and the cluster needs a new `r3.xlarge` spot instance, then + // the bid price is half of the price of on-demand `r3.xlarge` instances. + // Similarly, if this field is set to 200, the bid price is twice the price + // of on-demand `r3.xlarge` instances. If not specified, the default value + // is 100. When spot instances are requested for this cluster, only spot + // instances whose bid price percentage matches this field will be + // considered. Note that, for safety, we enforce this field to be no more + // than 10000. + // + // The default value and documentation here should be kept consistent with + // CommonConf.defaultSpotBidPricePercent and + // CommonConf.maxSpotBidPricePercent. + SpotBidPricePercent types.Int64 `tfsdk:"spot_bid_price_percent" tf:"optional"` + // Identifier for the availability zone/datacenter in which the cluster + // resides. This string will be of a form like "us-west-2a". The provided + // availability zone must be in the same region as the Databricks + // deployment. For example, "us-west-2a" is not a valid zone id if the + // Databricks deployment resides in the "us-east-1" region. This is an + // optional field at cluster creation, and if not specified, a default zone + // will be used. If the zone specified is "auto", will try to place cluster + // in a zone with high availability, and will retry placement in a different + // AZ if there is not enough capacity. The list of available zones as well + // as the default value can be found by using the `List Zones` method. + ZoneId types.String `tfsdk:"zone_id" tf:"optional"` +} + +type AzureAttributes struct { + // Availability type used for all subsequent nodes past the + // `first_on_demand` ones. Note: If `first_on_demand` is zero (which only + // happens on pool clusters), this availability type will be used for the + // entire cluster. + Availability types.String `tfsdk:"availability" tf:"optional"` + // The first `first_on_demand` nodes of the cluster will be placed on + // on-demand instances. This value should be greater than 0, to make sure + // the cluster driver node is placed on an on-demand instance. If this value + // is greater than or equal to the current cluster size, all nodes will be + // placed on on-demand instances. If this value is less than the current + // cluster size, `first_on_demand` nodes will be placed on on-demand + // instances and the remainder will be placed on `availability` instances. + // Note that this value does not affect cluster size and cannot currently be + // mutated over the lifetime of a cluster. + FirstOnDemand types.Int64 `tfsdk:"first_on_demand" tf:"optional"` + // Defines values necessary to configure and run Azure Log Analytics agent + LogAnalyticsInfo *LogAnalyticsInfo `tfsdk:"log_analytics_info" tf:"optional"` + // The max bid price to be used for Azure spot instances. The Max price for + // the bid cannot be higher than the on-demand price of the instance. If not + // specified, the default value is -1, which specifies that the instance + // cannot be evicted on the basis of price, and only on the basis of + // availability. Further, the value should > 0 or -1. + SpotBidMaxPrice types.Float64 `tfsdk:"spot_bid_max_price" tf:"optional"` +} + +type CancelCommand struct { + ClusterId types.String `tfsdk:"clusterId" tf:"optional"` + + CommandId types.String `tfsdk:"commandId" tf:"optional"` + + ContextId types.String `tfsdk:"contextId" tf:"optional"` +} + +type CancelResponse struct { +} + +type ChangeClusterOwner struct { + // + ClusterId types.String `tfsdk:"cluster_id" tf:""` + // New owner of the cluster_id after this RPC. + OwnerUsername types.String `tfsdk:"owner_username" tf:""` +} + +type ChangeClusterOwnerResponse struct { +} + +type ClientsTypes struct { + // With jobs set, the cluster can be used for jobs + Jobs types.Bool `tfsdk:"jobs" tf:"optional"` + // With notebooks set, this cluster can be used for notebooks + Notebooks types.Bool `tfsdk:"notebooks" tf:"optional"` +} + +type CloneCluster struct { + // The cluster that is being cloned. + SourceClusterId types.String `tfsdk:"source_cluster_id" tf:""` +} + +type CloudProviderNodeInfo struct { + Status []types.String `tfsdk:"status" tf:"optional"` +} + +type ClusterAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type ClusterAccessControlResponse struct { + // All permissions. + AllPermissions []ClusterPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type ClusterAttributes struct { + // Automatically terminates the cluster after it is inactive for this time + // in minutes. If not set, this cluster will not be automatically + // terminated. If specified, the threshold must be between 10 and 10000 + // minutes. Users can also set this value to 0 to explicitly disable + // automatic termination. + AutoterminationMinutes types.Int64 `tfsdk:"autotermination_minutes" tf:"optional"` + // Attributes related to clusters running on Amazon Web Services. If not + // specified at cluster creation, a set of default values will be used. + AwsAttributes *AwsAttributes `tfsdk:"aws_attributes" tf:"optional"` + // Attributes related to clusters running on Microsoft Azure. If not + // specified at cluster creation, a set of default values will be used. + AzureAttributes *AzureAttributes `tfsdk:"azure_attributes" tf:"optional"` + // The configuration for delivering spark logs to a long-term storage + // destination. Two kinds of destinations (dbfs and s3) are supported. Only + // one destination can be specified for one cluster. If the conf is given, + // the logs will be delivered to the destination every `5 mins`. The + // destination of driver logs is `$destination/$clusterId/driver`, while the + // destination of executor logs is `$destination/$clusterId/executor`. + ClusterLogConf *ClusterLogConf `tfsdk:"cluster_log_conf" tf:"optional"` + // Cluster name requested by the user. This doesn't have to be unique. If + // not specified at creation, the cluster name will be an empty string. + ClusterName types.String `tfsdk:"cluster_name" tf:"optional"` + // Additional tags for cluster resources. Databricks will tag all cluster + // resources (e.g., AWS instances and EBS volumes) with these tags in + // addition to `default_tags`. Notes: + // + // - Currently, Databricks allows at most 45 custom tags + // + // - Clusters can only reuse cloud resources if the resources' tags are a + // subset of the cluster tags + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // Data security mode decides what data governance model to use when + // accessing data from a cluster. + // + // * `NONE`: No security isolation for multiple users sharing the cluster. + // Data governance features are not available in this mode. * `SINGLE_USER`: + // A secure cluster that can only be exclusively used by a single user + // specified in `single_user_name`. Most programming languages, cluster + // features and data governance features are available in this mode. * + // `USER_ISOLATION`: A secure cluster that can be shared by multiple users. + // Cluster users are fully isolated so that they cannot see each other's + // data and credentials. Most data governance features are supported in this + // mode. But programming languages and cluster features might be limited. + // + // The following modes are deprecated starting with Databricks Runtime 15.0 + // and will be removed for future Databricks Runtime versions: + // + // * `LEGACY_TABLE_ACL`: This mode is for users migrating from legacy Table + // ACL clusters. * `LEGACY_PASSTHROUGH`: This mode is for users migrating + // from legacy Passthrough on high concurrency clusters. * + // `LEGACY_SINGLE_USER`: This mode is for users migrating from legacy + // Passthrough on standard clusters. * `LEGACY_SINGLE_USER_STANDARD`: This + // mode provides a way that doesn’t have UC nor passthrough enabled. + DataSecurityMode types.String `tfsdk:"data_security_mode" tf:"optional"` + + DockerImage *DockerImage `tfsdk:"docker_image" tf:"optional"` + // The optional ID of the instance pool for the driver of the cluster + // belongs. The pool cluster uses the instance pool with id + // (instance_pool_id) if the driver pool is not assigned. + DriverInstancePoolId types.String `tfsdk:"driver_instance_pool_id" tf:"optional"` + // The node type of the Spark driver. Note that this field is optional; if + // unset, the driver node type will be set as the same value as + // `node_type_id` defined above. + DriverNodeTypeId types.String `tfsdk:"driver_node_type_id" tf:"optional"` + // Autoscaling Local Storage: when enabled, this cluster will dynamically + // acquire additional disk space when its Spark workers are running low on + // disk space. This feature requires specific AWS permissions to function + // correctly - refer to the User Guide for more details. + EnableElasticDisk types.Bool `tfsdk:"enable_elastic_disk" tf:"optional"` + // Whether to enable LUKS on cluster VMs' local disks + EnableLocalDiskEncryption types.Bool `tfsdk:"enable_local_disk_encryption" tf:"optional"` + // Attributes related to clusters running on Google Cloud Platform. If not + // specified at cluster creation, a set of default values will be used. + GcpAttributes *GcpAttributes `tfsdk:"gcp_attributes" tf:"optional"` + // The configuration for storing init scripts. Any number of destinations + // can be specified. The scripts are executed sequentially in the order + // provided. If `cluster_log_conf` is specified, init script logs are sent + // to `//init_scripts`. + InitScripts []InitScriptInfo `tfsdk:"init_scripts" tf:"optional"` + // The optional ID of the instance pool to which the cluster belongs. + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:"optional"` + // This field encodes, through a single value, the resources available to + // each of the Spark nodes in this cluster. For example, the Spark nodes can + // be provisioned and optimized for memory or compute intensive workloads. A + // list of available node types can be retrieved by using the + // :method:clusters/listNodeTypes API call. + NodeTypeId types.String `tfsdk:"node_type_id" tf:"optional"` + // The ID of the cluster policy used to create the cluster if applicable. + PolicyId types.String `tfsdk:"policy_id" tf:"optional"` + // Decides which runtime engine to be use, e.g. Standard vs. Photon. If + // unspecified, the runtime engine is inferred from spark_version. + RuntimeEngine types.String `tfsdk:"runtime_engine" tf:"optional"` + // Single user name if data_security_mode is `SINGLE_USER` + SingleUserName types.String `tfsdk:"single_user_name" tf:"optional"` + // An object containing a set of optional, user-specified Spark + // configuration key-value pairs. Users can also pass in a string of extra + // JVM options to the driver and the executors via + // `spark.driver.extraJavaOptions` and `spark.executor.extraJavaOptions` + // respectively. + SparkConf map[string]types.String `tfsdk:"spark_conf" tf:"optional"` + // An object containing a set of optional, user-specified environment + // variable key-value pairs. Please note that key-value pair of the form + // (X,Y) will be exported as is (i.e., `export X='Y'`) while launching the + // driver and workers. + // + // In order to specify an additional set of `SPARK_DAEMON_JAVA_OPTS`, we + // recommend appending them to `$SPARK_DAEMON_JAVA_OPTS` as shown in the + // example below. This ensures that all default databricks managed + // environmental variables are included as well. + // + // Example Spark environment variables: `{"SPARK_WORKER_MEMORY": "28000m", + // "SPARK_LOCAL_DIRS": "/local_disk0"}` or `{"SPARK_DAEMON_JAVA_OPTS": + // "$SPARK_DAEMON_JAVA_OPTS -Dspark.shuffle.service.enabled=true"}` + SparkEnvVars map[string]types.String `tfsdk:"spark_env_vars" tf:"optional"` + // The Spark version of the cluster, e.g. `3.3.x-scala2.11`. A list of + // available Spark versions can be retrieved by using the + // :method:clusters/sparkVersions API call. + SparkVersion types.String `tfsdk:"spark_version" tf:""` + // SSH public key contents that will be added to each Spark node in this + // cluster. The corresponding private keys can be used to login with the + // user name `ubuntu` on port `2200`. Up to 10 keys can be specified. + SshPublicKeys []types.String `tfsdk:"ssh_public_keys" tf:"optional"` + + WorkloadType *WorkloadType `tfsdk:"workload_type" tf:"optional"` +} + +type ClusterDetails struct { + // Parameters needed in order to automatically scale clusters up and down + // based on load. Note: autoscaling works best with DB runtime versions 3.0 + // or later. + Autoscale *AutoScale `tfsdk:"autoscale" tf:"optional"` + // Automatically terminates the cluster after it is inactive for this time + // in minutes. If not set, this cluster will not be automatically + // terminated. If specified, the threshold must be between 10 and 10000 + // minutes. Users can also set this value to 0 to explicitly disable + // automatic termination. + AutoterminationMinutes types.Int64 `tfsdk:"autotermination_minutes" tf:"optional"` + // Attributes related to clusters running on Amazon Web Services. If not + // specified at cluster creation, a set of default values will be used. + AwsAttributes *AwsAttributes `tfsdk:"aws_attributes" tf:"optional"` + // Attributes related to clusters running on Microsoft Azure. If not + // specified at cluster creation, a set of default values will be used. + AzureAttributes *AzureAttributes `tfsdk:"azure_attributes" tf:"optional"` + // Number of CPU cores available for this cluster. Note that this can be + // fractional, e.g. 7.5 cores, since certain node types are configured to + // share cores between Spark nodes on the same instance. + ClusterCores types.Float64 `tfsdk:"cluster_cores" tf:"optional"` + // Canonical identifier for the cluster. This id is retained during cluster + // restarts and resizes, while each new cluster has a globally unique id. + ClusterId types.String `tfsdk:"cluster_id" tf:"optional"` + // The configuration for delivering spark logs to a long-term storage + // destination. Two kinds of destinations (dbfs and s3) are supported. Only + // one destination can be specified for one cluster. If the conf is given, + // the logs will be delivered to the destination every `5 mins`. The + // destination of driver logs is `$destination/$clusterId/driver`, while the + // destination of executor logs is `$destination/$clusterId/executor`. + ClusterLogConf *ClusterLogConf `tfsdk:"cluster_log_conf" tf:"optional"` + // Cluster log delivery status. + ClusterLogStatus *LogSyncStatus `tfsdk:"cluster_log_status" tf:"optional"` + // Total amount of cluster memory, in megabytes + ClusterMemoryMb types.Int64 `tfsdk:"cluster_memory_mb" tf:"optional"` + // Cluster name requested by the user. This doesn't have to be unique. If + // not specified at creation, the cluster name will be an empty string. + ClusterName types.String `tfsdk:"cluster_name" tf:"optional"` + // Determines whether the cluster was created by a user through the UI, + // created by the Databricks Jobs Scheduler, or through an API request. This + // is the same as cluster_creator, but read only. + ClusterSource types.String `tfsdk:"cluster_source" tf:"optional"` + // Creator user name. The field won't be included in the response if the + // user has already been deleted. + CreatorUserName types.String `tfsdk:"creator_user_name" tf:"optional"` + // Additional tags for cluster resources. Databricks will tag all cluster + // resources (e.g., AWS instances and EBS volumes) with these tags in + // addition to `default_tags`. Notes: + // + // - Currently, Databricks allows at most 45 custom tags + // + // - Clusters can only reuse cloud resources if the resources' tags are a + // subset of the cluster tags + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // Data security mode decides what data governance model to use when + // accessing data from a cluster. + // + // * `NONE`: No security isolation for multiple users sharing the cluster. + // Data governance features are not available in this mode. * `SINGLE_USER`: + // A secure cluster that can only be exclusively used by a single user + // specified in `single_user_name`. Most programming languages, cluster + // features and data governance features are available in this mode. * + // `USER_ISOLATION`: A secure cluster that can be shared by multiple users. + // Cluster users are fully isolated so that they cannot see each other's + // data and credentials. Most data governance features are supported in this + // mode. But programming languages and cluster features might be limited. + // + // The following modes are deprecated starting with Databricks Runtime 15.0 + // and will be removed for future Databricks Runtime versions: + // + // * `LEGACY_TABLE_ACL`: This mode is for users migrating from legacy Table + // ACL clusters. * `LEGACY_PASSTHROUGH`: This mode is for users migrating + // from legacy Passthrough on high concurrency clusters. * + // `LEGACY_SINGLE_USER`: This mode is for users migrating from legacy + // Passthrough on standard clusters. * `LEGACY_SINGLE_USER_STANDARD`: This + // mode provides a way that doesn’t have UC nor passthrough enabled. + DataSecurityMode types.String `tfsdk:"data_security_mode" tf:"optional"` + // Tags that are added by Databricks regardless of any `custom_tags`, + // including: + // + // - Vendor: Databricks + // + // - Creator: + // + // - ClusterName: + // + // - ClusterId: + // + // - Name: + DefaultTags map[string]types.String `tfsdk:"default_tags" tf:"optional"` + + DockerImage *DockerImage `tfsdk:"docker_image" tf:"optional"` + // Node on which the Spark driver resides. The driver node contains the + // Spark master and the Databricks application that manages the per-notebook + // Spark REPLs. + Driver *SparkNode `tfsdk:"driver" tf:"optional"` + // The optional ID of the instance pool for the driver of the cluster + // belongs. The pool cluster uses the instance pool with id + // (instance_pool_id) if the driver pool is not assigned. + DriverInstancePoolId types.String `tfsdk:"driver_instance_pool_id" tf:"optional"` + // The node type of the Spark driver. Note that this field is optional; if + // unset, the driver node type will be set as the same value as + // `node_type_id` defined above. + DriverNodeTypeId types.String `tfsdk:"driver_node_type_id" tf:"optional"` + // Autoscaling Local Storage: when enabled, this cluster will dynamically + // acquire additional disk space when its Spark workers are running low on + // disk space. This feature requires specific AWS permissions to function + // correctly - refer to the User Guide for more details. + EnableElasticDisk types.Bool `tfsdk:"enable_elastic_disk" tf:"optional"` + // Whether to enable LUKS on cluster VMs' local disks + EnableLocalDiskEncryption types.Bool `tfsdk:"enable_local_disk_encryption" tf:"optional"` + // Nodes on which the Spark executors reside. + Executors []SparkNode `tfsdk:"executors" tf:"optional"` + // Attributes related to clusters running on Google Cloud Platform. If not + // specified at cluster creation, a set of default values will be used. + GcpAttributes *GcpAttributes `tfsdk:"gcp_attributes" tf:"optional"` + // The configuration for storing init scripts. Any number of destinations + // can be specified. The scripts are executed sequentially in the order + // provided. If `cluster_log_conf` is specified, init script logs are sent + // to `//init_scripts`. + InitScripts []InitScriptInfo `tfsdk:"init_scripts" tf:"optional"` + // The optional ID of the instance pool to which the cluster belongs. + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:"optional"` + // Port on which Spark JDBC server is listening, in the driver nod. No + // service will be listeningon on this port in executor nodes. + JdbcPort types.Int64 `tfsdk:"jdbc_port" tf:"optional"` + // the timestamp that the cluster was started/restarted + LastRestartedTime types.Int64 `tfsdk:"last_restarted_time" tf:"optional"` + // Time when the cluster driver last lost its state (due to a restart or + // driver failure). + LastStateLossTime types.Int64 `tfsdk:"last_state_loss_time" tf:"optional"` + // This field encodes, through a single value, the resources available to + // each of the Spark nodes in this cluster. For example, the Spark nodes can + // be provisioned and optimized for memory or compute intensive workloads. A + // list of available node types can be retrieved by using the + // :method:clusters/listNodeTypes API call. + NodeTypeId types.String `tfsdk:"node_type_id" tf:"optional"` + // Number of worker nodes that this cluster should have. A cluster has one + // Spark Driver and `num_workers` Executors for a total of `num_workers` + 1 + // Spark nodes. + // + // Note: When reading the properties of a cluster, this field reflects the + // desired number of workers rather than the actual current number of + // workers. For instance, if a cluster is resized from 5 to 10 workers, this + // field will immediately be updated to reflect the target size of 10 + // workers, whereas the workers listed in `spark_info` will gradually + // increase from 5 to 10 as the new nodes are provisioned. + NumWorkers types.Int64 `tfsdk:"num_workers" tf:"optional"` + // The ID of the cluster policy used to create the cluster if applicable. + PolicyId types.String `tfsdk:"policy_id" tf:"optional"` + // Decides which runtime engine to be use, e.g. Standard vs. Photon. If + // unspecified, the runtime engine is inferred from spark_version. + RuntimeEngine types.String `tfsdk:"runtime_engine" tf:"optional"` + // Single user name if data_security_mode is `SINGLE_USER` + SingleUserName types.String `tfsdk:"single_user_name" tf:"optional"` + // An object containing a set of optional, user-specified Spark + // configuration key-value pairs. Users can also pass in a string of extra + // JVM options to the driver and the executors via + // `spark.driver.extraJavaOptions` and `spark.executor.extraJavaOptions` + // respectively. + SparkConf map[string]types.String `tfsdk:"spark_conf" tf:"optional"` + // A canonical SparkContext identifier. This value *does* change when the + // Spark driver restarts. The pair `(cluster_id, spark_context_id)` is a + // globally unique identifier over all Spark contexts. + SparkContextId types.Int64 `tfsdk:"spark_context_id" tf:"optional"` + // An object containing a set of optional, user-specified environment + // variable key-value pairs. Please note that key-value pair of the form + // (X,Y) will be exported as is (i.e., `export X='Y'`) while launching the + // driver and workers. + // + // In order to specify an additional set of `SPARK_DAEMON_JAVA_OPTS`, we + // recommend appending them to `$SPARK_DAEMON_JAVA_OPTS` as shown in the + // example below. This ensures that all default databricks managed + // environmental variables are included as well. + // + // Example Spark environment variables: `{"SPARK_WORKER_MEMORY": "28000m", + // "SPARK_LOCAL_DIRS": "/local_disk0"}` or `{"SPARK_DAEMON_JAVA_OPTS": + // "$SPARK_DAEMON_JAVA_OPTS -Dspark.shuffle.service.enabled=true"}` + SparkEnvVars map[string]types.String `tfsdk:"spark_env_vars" tf:"optional"` + // The Spark version of the cluster, e.g. `3.3.x-scala2.11`. A list of + // available Spark versions can be retrieved by using the + // :method:clusters/sparkVersions API call. + SparkVersion types.String `tfsdk:"spark_version" tf:"optional"` + // `spec` contains a snapshot of the field values that were used to create + // or edit this cluster. The contents of `spec` can be used in the body of a + // create cluster request. This field might not be populated for older + // clusters. Note: not included in the response of the ListClusters API. + Spec *ClusterSpec `tfsdk:"spec" tf:"optional"` + // SSH public key contents that will be added to each Spark node in this + // cluster. The corresponding private keys can be used to login with the + // user name `ubuntu` on port `2200`. Up to 10 keys can be specified. + SshPublicKeys []types.String `tfsdk:"ssh_public_keys" tf:"optional"` + // Time (in epoch milliseconds) when the cluster creation request was + // received (when the cluster entered a `PENDING` state). + StartTime types.Int64 `tfsdk:"start_time" tf:"optional"` + // Current state of the cluster. + State types.String `tfsdk:"state" tf:"optional"` + // A message associated with the most recent state transition (e.g., the + // reason why the cluster entered a `TERMINATED` state). + StateMessage types.String `tfsdk:"state_message" tf:"optional"` + // Time (in epoch milliseconds) when the cluster was terminated, if + // applicable. + TerminatedTime types.Int64 `tfsdk:"terminated_time" tf:"optional"` + // Information about why the cluster was terminated. This field only appears + // when the cluster is in a `TERMINATING` or `TERMINATED` state. + TerminationReason *TerminationReason `tfsdk:"termination_reason" tf:"optional"` + + WorkloadType *WorkloadType `tfsdk:"workload_type" tf:"optional"` +} + +type ClusterEvent struct { + // + ClusterId types.String `tfsdk:"cluster_id" tf:""` + // + DataPlaneEventDetails *DataPlaneEventDetails `tfsdk:"data_plane_event_details" tf:"optional"` + // + Details *EventDetails `tfsdk:"details" tf:"optional"` + // The timestamp when the event occurred, stored as the number of + // milliseconds since the Unix epoch. If not provided, this will be assigned + // by the Timeline service. + Timestamp types.Int64 `tfsdk:"timestamp" tf:"optional"` + + Type types.String `tfsdk:"type" tf:"optional"` +} + +type ClusterLibraryStatuses struct { + // Unique identifier for the cluster. + ClusterId types.String `tfsdk:"cluster_id" tf:"optional"` + // Status of all libraries on the cluster. + LibraryStatuses []LibraryFullStatus `tfsdk:"library_statuses" tf:"optional"` +} + +type ClusterLogConf struct { + // destination needs to be provided. e.g. `{ "dbfs" : { "destination" : + // "dbfs:/home/cluster_log" } }` + Dbfs *DbfsStorageInfo `tfsdk:"dbfs" tf:"optional"` + // destination and either the region or endpoint need to be provided. e.g. + // `{ "s3": { "destination" : "s3://cluster_log_bucket/prefix", "region" : + // "us-west-2" } }` Cluster iam role is used to access s3, please make sure + // the cluster iam role in `instance_profile_arn` has permission to write + // data to the s3 destination. + S3 *S3StorageInfo `tfsdk:"s3" tf:"optional"` +} + +type ClusterPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type ClusterPermissions struct { + AccessControlList []ClusterAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type ClusterPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type ClusterPermissionsRequest struct { + AccessControlList []ClusterAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The cluster for which to get or manage permissions. + ClusterId types.String `tfsdk:"-"` +} + +type ClusterPolicyAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type ClusterPolicyAccessControlResponse struct { + // All permissions. + AllPermissions []ClusterPolicyPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type ClusterPolicyPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type ClusterPolicyPermissions struct { + AccessControlList []ClusterPolicyAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type ClusterPolicyPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type ClusterPolicyPermissionsRequest struct { + AccessControlList []ClusterPolicyAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The cluster policy for which to get or manage permissions. + ClusterPolicyId types.String `tfsdk:"-"` +} + +type ClusterSize struct { + // Parameters needed in order to automatically scale clusters up and down + // based on load. Note: autoscaling works best with DB runtime versions 3.0 + // or later. + Autoscale *AutoScale `tfsdk:"autoscale" tf:"optional"` + // Number of worker nodes that this cluster should have. A cluster has one + // Spark Driver and `num_workers` Executors for a total of `num_workers` + 1 + // Spark nodes. + // + // Note: When reading the properties of a cluster, this field reflects the + // desired number of workers rather than the actual current number of + // workers. For instance, if a cluster is resized from 5 to 10 workers, this + // field will immediately be updated to reflect the target size of 10 + // workers, whereas the workers listed in `spark_info` will gradually + // increase from 5 to 10 as the new nodes are provisioned. + NumWorkers types.Int64 `tfsdk:"num_workers" tf:"optional"` +} + +type ClusterSpec struct { + // When set to true, fixed and default values from the policy will be used + // for fields that are omitted. When set to false, only fixed values from + // the policy will be applied. + ApplyPolicyDefaultValues types.Bool `tfsdk:"apply_policy_default_values" tf:"optional"` + // Parameters needed in order to automatically scale clusters up and down + // based on load. Note: autoscaling works best with DB runtime versions 3.0 + // or later. + Autoscale *AutoScale `tfsdk:"autoscale" tf:"optional"` + // Automatically terminates the cluster after it is inactive for this time + // in minutes. If not set, this cluster will not be automatically + // terminated. If specified, the threshold must be between 10 and 10000 + // minutes. Users can also set this value to 0 to explicitly disable + // automatic termination. + AutoterminationMinutes types.Int64 `tfsdk:"autotermination_minutes" tf:"optional"` + // Attributes related to clusters running on Amazon Web Services. If not + // specified at cluster creation, a set of default values will be used. + AwsAttributes *AwsAttributes `tfsdk:"aws_attributes" tf:"optional"` + // Attributes related to clusters running on Microsoft Azure. If not + // specified at cluster creation, a set of default values will be used. + AzureAttributes *AzureAttributes `tfsdk:"azure_attributes" tf:"optional"` + // The configuration for delivering spark logs to a long-term storage + // destination. Two kinds of destinations (dbfs and s3) are supported. Only + // one destination can be specified for one cluster. If the conf is given, + // the logs will be delivered to the destination every `5 mins`. The + // destination of driver logs is `$destination/$clusterId/driver`, while the + // destination of executor logs is `$destination/$clusterId/executor`. + ClusterLogConf *ClusterLogConf `tfsdk:"cluster_log_conf" tf:"optional"` + // Cluster name requested by the user. This doesn't have to be unique. If + // not specified at creation, the cluster name will be an empty string. + ClusterName types.String `tfsdk:"cluster_name" tf:"optional"` + // Additional tags for cluster resources. Databricks will tag all cluster + // resources (e.g., AWS instances and EBS volumes) with these tags in + // addition to `default_tags`. Notes: + // + // - Currently, Databricks allows at most 45 custom tags + // + // - Clusters can only reuse cloud resources if the resources' tags are a + // subset of the cluster tags + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // Data security mode decides what data governance model to use when + // accessing data from a cluster. + // + // * `NONE`: No security isolation for multiple users sharing the cluster. + // Data governance features are not available in this mode. * `SINGLE_USER`: + // A secure cluster that can only be exclusively used by a single user + // specified in `single_user_name`. Most programming languages, cluster + // features and data governance features are available in this mode. * + // `USER_ISOLATION`: A secure cluster that can be shared by multiple users. + // Cluster users are fully isolated so that they cannot see each other's + // data and credentials. Most data governance features are supported in this + // mode. But programming languages and cluster features might be limited. + // + // The following modes are deprecated starting with Databricks Runtime 15.0 + // and will be removed for future Databricks Runtime versions: + // + // * `LEGACY_TABLE_ACL`: This mode is for users migrating from legacy Table + // ACL clusters. * `LEGACY_PASSTHROUGH`: This mode is for users migrating + // from legacy Passthrough on high concurrency clusters. * + // `LEGACY_SINGLE_USER`: This mode is for users migrating from legacy + // Passthrough on standard clusters. * `LEGACY_SINGLE_USER_STANDARD`: This + // mode provides a way that doesn’t have UC nor passthrough enabled. + DataSecurityMode types.String `tfsdk:"data_security_mode" tf:"optional"` + + DockerImage *DockerImage `tfsdk:"docker_image" tf:"optional"` + // The optional ID of the instance pool for the driver of the cluster + // belongs. The pool cluster uses the instance pool with id + // (instance_pool_id) if the driver pool is not assigned. + DriverInstancePoolId types.String `tfsdk:"driver_instance_pool_id" tf:"optional"` + // The node type of the Spark driver. Note that this field is optional; if + // unset, the driver node type will be set as the same value as + // `node_type_id` defined above. + DriverNodeTypeId types.String `tfsdk:"driver_node_type_id" tf:"optional"` + // Autoscaling Local Storage: when enabled, this cluster will dynamically + // acquire additional disk space when its Spark workers are running low on + // disk space. This feature requires specific AWS permissions to function + // correctly - refer to the User Guide for more details. + EnableElasticDisk types.Bool `tfsdk:"enable_elastic_disk" tf:"optional"` + // Whether to enable LUKS on cluster VMs' local disks + EnableLocalDiskEncryption types.Bool `tfsdk:"enable_local_disk_encryption" tf:"optional"` + // Attributes related to clusters running on Google Cloud Platform. If not + // specified at cluster creation, a set of default values will be used. + GcpAttributes *GcpAttributes `tfsdk:"gcp_attributes" tf:"optional"` + // The configuration for storing init scripts. Any number of destinations + // can be specified. The scripts are executed sequentially in the order + // provided. If `cluster_log_conf` is specified, init script logs are sent + // to `//init_scripts`. + InitScripts []InitScriptInfo `tfsdk:"init_scripts" tf:"optional"` + // The optional ID of the instance pool to which the cluster belongs. + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:"optional"` + // This field encodes, through a single value, the resources available to + // each of the Spark nodes in this cluster. For example, the Spark nodes can + // be provisioned and optimized for memory or compute intensive workloads. A + // list of available node types can be retrieved by using the + // :method:clusters/listNodeTypes API call. + NodeTypeId types.String `tfsdk:"node_type_id" tf:"optional"` + // Number of worker nodes that this cluster should have. A cluster has one + // Spark Driver and `num_workers` Executors for a total of `num_workers` + 1 + // Spark nodes. + // + // Note: When reading the properties of a cluster, this field reflects the + // desired number of workers rather than the actual current number of + // workers. For instance, if a cluster is resized from 5 to 10 workers, this + // field will immediately be updated to reflect the target size of 10 + // workers, whereas the workers listed in `spark_info` will gradually + // increase from 5 to 10 as the new nodes are provisioned. + NumWorkers types.Int64 `tfsdk:"num_workers" tf:"optional"` + // The ID of the cluster policy used to create the cluster if applicable. + PolicyId types.String `tfsdk:"policy_id" tf:"optional"` + // Decides which runtime engine to be use, e.g. Standard vs. Photon. If + // unspecified, the runtime engine is inferred from spark_version. + RuntimeEngine types.String `tfsdk:"runtime_engine" tf:"optional"` + // Single user name if data_security_mode is `SINGLE_USER` + SingleUserName types.String `tfsdk:"single_user_name" tf:"optional"` + // An object containing a set of optional, user-specified Spark + // configuration key-value pairs. Users can also pass in a string of extra + // JVM options to the driver and the executors via + // `spark.driver.extraJavaOptions` and `spark.executor.extraJavaOptions` + // respectively. + SparkConf map[string]types.String `tfsdk:"spark_conf" tf:"optional"` + // An object containing a set of optional, user-specified environment + // variable key-value pairs. Please note that key-value pair of the form + // (X,Y) will be exported as is (i.e., `export X='Y'`) while launching the + // driver and workers. + // + // In order to specify an additional set of `SPARK_DAEMON_JAVA_OPTS`, we + // recommend appending them to `$SPARK_DAEMON_JAVA_OPTS` as shown in the + // example below. This ensures that all default databricks managed + // environmental variables are included as well. + // + // Example Spark environment variables: `{"SPARK_WORKER_MEMORY": "28000m", + // "SPARK_LOCAL_DIRS": "/local_disk0"}` or `{"SPARK_DAEMON_JAVA_OPTS": + // "$SPARK_DAEMON_JAVA_OPTS -Dspark.shuffle.service.enabled=true"}` + SparkEnvVars map[string]types.String `tfsdk:"spark_env_vars" tf:"optional"` + // The Spark version of the cluster, e.g. `3.3.x-scala2.11`. A list of + // available Spark versions can be retrieved by using the + // :method:clusters/sparkVersions API call. + SparkVersion types.String `tfsdk:"spark_version" tf:"optional"` + // SSH public key contents that will be added to each Spark node in this + // cluster. The corresponding private keys can be used to login with the + // user name `ubuntu` on port `2200`. Up to 10 keys can be specified. + SshPublicKeys []types.String `tfsdk:"ssh_public_keys" tf:"optional"` + + WorkloadType *WorkloadType `tfsdk:"workload_type" tf:"optional"` +} + +// Get status +type ClusterStatus struct { + // Unique identifier of the cluster whose status should be retrieved. + ClusterId types.String `tfsdk:"-"` +} + +type Command struct { + // Running cluster id + ClusterId types.String `tfsdk:"clusterId" tf:"optional"` + // Executable code + Command types.String `tfsdk:"command" tf:"optional"` + // Running context id + ContextId types.String `tfsdk:"contextId" tf:"optional"` + + Language types.String `tfsdk:"language" tf:"optional"` +} + +// Get command info +type CommandStatusRequest struct { + ClusterId types.String `tfsdk:"-"` + + CommandId types.String `tfsdk:"-"` + + ContextId types.String `tfsdk:"-"` +} + +type CommandStatusResponse struct { + Id types.String `tfsdk:"id" tf:"optional"` + + Results *Results `tfsdk:"results" tf:"optional"` + + Status types.String `tfsdk:"status" tf:"optional"` +} + +// Get status +type ContextStatusRequest struct { + ClusterId types.String `tfsdk:"-"` + + ContextId types.String `tfsdk:"-"` +} + +type ContextStatusResponse struct { + Id types.String `tfsdk:"id" tf:"optional"` + + Status types.String `tfsdk:"status" tf:"optional"` +} + +type CreateCluster struct { + // When set to true, fixed and default values from the policy will be used + // for fields that are omitted. When set to false, only fixed values from + // the policy will be applied. + ApplyPolicyDefaultValues types.Bool `tfsdk:"apply_policy_default_values" tf:"optional"` + // Parameters needed in order to automatically scale clusters up and down + // based on load. Note: autoscaling works best with DB runtime versions 3.0 + // or later. + Autoscale *AutoScale `tfsdk:"autoscale" tf:"optional"` + // Automatically terminates the cluster after it is inactive for this time + // in minutes. If not set, this cluster will not be automatically + // terminated. If specified, the threshold must be between 10 and 10000 + // minutes. Users can also set this value to 0 to explicitly disable + // automatic termination. + AutoterminationMinutes types.Int64 `tfsdk:"autotermination_minutes" tf:"optional"` + // Attributes related to clusters running on Amazon Web Services. If not + // specified at cluster creation, a set of default values will be used. + AwsAttributes *AwsAttributes `tfsdk:"aws_attributes" tf:"optional"` + // Attributes related to clusters running on Microsoft Azure. If not + // specified at cluster creation, a set of default values will be used. + AzureAttributes *AzureAttributes `tfsdk:"azure_attributes" tf:"optional"` + // When specified, this clones libraries from a source cluster during the + // creation of a new cluster. + CloneFrom *CloneCluster `tfsdk:"clone_from" tf:"optional"` + // The configuration for delivering spark logs to a long-term storage + // destination. Two kinds of destinations (dbfs and s3) are supported. Only + // one destination can be specified for one cluster. If the conf is given, + // the logs will be delivered to the destination every `5 mins`. The + // destination of driver logs is `$destination/$clusterId/driver`, while the + // destination of executor logs is `$destination/$clusterId/executor`. + ClusterLogConf *ClusterLogConf `tfsdk:"cluster_log_conf" tf:"optional"` + // Cluster name requested by the user. This doesn't have to be unique. If + // not specified at creation, the cluster name will be an empty string. + ClusterName types.String `tfsdk:"cluster_name" tf:"optional"` + // Additional tags for cluster resources. Databricks will tag all cluster + // resources (e.g., AWS instances and EBS volumes) with these tags in + // addition to `default_tags`. Notes: + // + // - Currently, Databricks allows at most 45 custom tags + // + // - Clusters can only reuse cloud resources if the resources' tags are a + // subset of the cluster tags + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // Data security mode decides what data governance model to use when + // accessing data from a cluster. + // + // * `NONE`: No security isolation for multiple users sharing the cluster. + // Data governance features are not available in this mode. * `SINGLE_USER`: + // A secure cluster that can only be exclusively used by a single user + // specified in `single_user_name`. Most programming languages, cluster + // features and data governance features are available in this mode. * + // `USER_ISOLATION`: A secure cluster that can be shared by multiple users. + // Cluster users are fully isolated so that they cannot see each other's + // data and credentials. Most data governance features are supported in this + // mode. But programming languages and cluster features might be limited. + // + // The following modes are deprecated starting with Databricks Runtime 15.0 + // and will be removed for future Databricks Runtime versions: + // + // * `LEGACY_TABLE_ACL`: This mode is for users migrating from legacy Table + // ACL clusters. * `LEGACY_PASSTHROUGH`: This mode is for users migrating + // from legacy Passthrough on high concurrency clusters. * + // `LEGACY_SINGLE_USER`: This mode is for users migrating from legacy + // Passthrough on standard clusters. * `LEGACY_SINGLE_USER_STANDARD`: This + // mode provides a way that doesn’t have UC nor passthrough enabled. + DataSecurityMode types.String `tfsdk:"data_security_mode" tf:"optional"` + + DockerImage *DockerImage `tfsdk:"docker_image" tf:"optional"` + // The optional ID of the instance pool for the driver of the cluster + // belongs. The pool cluster uses the instance pool with id + // (instance_pool_id) if the driver pool is not assigned. + DriverInstancePoolId types.String `tfsdk:"driver_instance_pool_id" tf:"optional"` + // The node type of the Spark driver. Note that this field is optional; if + // unset, the driver node type will be set as the same value as + // `node_type_id` defined above. + DriverNodeTypeId types.String `tfsdk:"driver_node_type_id" tf:"optional"` + // Autoscaling Local Storage: when enabled, this cluster will dynamically + // acquire additional disk space when its Spark workers are running low on + // disk space. This feature requires specific AWS permissions to function + // correctly - refer to the User Guide for more details. + EnableElasticDisk types.Bool `tfsdk:"enable_elastic_disk" tf:"optional"` + // Whether to enable LUKS on cluster VMs' local disks + EnableLocalDiskEncryption types.Bool `tfsdk:"enable_local_disk_encryption" tf:"optional"` + // Attributes related to clusters running on Google Cloud Platform. If not + // specified at cluster creation, a set of default values will be used. + GcpAttributes *GcpAttributes `tfsdk:"gcp_attributes" tf:"optional"` + // The configuration for storing init scripts. Any number of destinations + // can be specified. The scripts are executed sequentially in the order + // provided. If `cluster_log_conf` is specified, init script logs are sent + // to `//init_scripts`. + InitScripts []InitScriptInfo `tfsdk:"init_scripts" tf:"optional"` + // The optional ID of the instance pool to which the cluster belongs. + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:"optional"` + // This field encodes, through a single value, the resources available to + // each of the Spark nodes in this cluster. For example, the Spark nodes can + // be provisioned and optimized for memory or compute intensive workloads. A + // list of available node types can be retrieved by using the + // :method:clusters/listNodeTypes API call. + NodeTypeId types.String `tfsdk:"node_type_id" tf:"optional"` + // Number of worker nodes that this cluster should have. A cluster has one + // Spark Driver and `num_workers` Executors for a total of `num_workers` + 1 + // Spark nodes. + // + // Note: When reading the properties of a cluster, this field reflects the + // desired number of workers rather than the actual current number of + // workers. For instance, if a cluster is resized from 5 to 10 workers, this + // field will immediately be updated to reflect the target size of 10 + // workers, whereas the workers listed in `spark_info` will gradually + // increase from 5 to 10 as the new nodes are provisioned. + NumWorkers types.Int64 `tfsdk:"num_workers" tf:"optional"` + // The ID of the cluster policy used to create the cluster if applicable. + PolicyId types.String `tfsdk:"policy_id" tf:"optional"` + // Decides which runtime engine to be use, e.g. Standard vs. Photon. If + // unspecified, the runtime engine is inferred from spark_version. + RuntimeEngine types.String `tfsdk:"runtime_engine" tf:"optional"` + // Single user name if data_security_mode is `SINGLE_USER` + SingleUserName types.String `tfsdk:"single_user_name" tf:"optional"` + // An object containing a set of optional, user-specified Spark + // configuration key-value pairs. Users can also pass in a string of extra + // JVM options to the driver and the executors via + // `spark.driver.extraJavaOptions` and `spark.executor.extraJavaOptions` + // respectively. + SparkConf map[string]types.String `tfsdk:"spark_conf" tf:"optional"` + // An object containing a set of optional, user-specified environment + // variable key-value pairs. Please note that key-value pair of the form + // (X,Y) will be exported as is (i.e., `export X='Y'`) while launching the + // driver and workers. + // + // In order to specify an additional set of `SPARK_DAEMON_JAVA_OPTS`, we + // recommend appending them to `$SPARK_DAEMON_JAVA_OPTS` as shown in the + // example below. This ensures that all default databricks managed + // environmental variables are included as well. + // + // Example Spark environment variables: `{"SPARK_WORKER_MEMORY": "28000m", + // "SPARK_LOCAL_DIRS": "/local_disk0"}` or `{"SPARK_DAEMON_JAVA_OPTS": + // "$SPARK_DAEMON_JAVA_OPTS -Dspark.shuffle.service.enabled=true"}` + SparkEnvVars map[string]types.String `tfsdk:"spark_env_vars" tf:"optional"` + // The Spark version of the cluster, e.g. `3.3.x-scala2.11`. A list of + // available Spark versions can be retrieved by using the + // :method:clusters/sparkVersions API call. + SparkVersion types.String `tfsdk:"spark_version" tf:""` + // SSH public key contents that will be added to each Spark node in this + // cluster. The corresponding private keys can be used to login with the + // user name `ubuntu` on port `2200`. Up to 10 keys can be specified. + SshPublicKeys []types.String `tfsdk:"ssh_public_keys" tf:"optional"` + + WorkloadType *WorkloadType `tfsdk:"workload_type" tf:"optional"` +} + +type CreateClusterResponse struct { + ClusterId types.String `tfsdk:"cluster_id" tf:"optional"` +} + +type CreateContext struct { + // Running cluster id + ClusterId types.String `tfsdk:"clusterId" tf:"optional"` + + Language types.String `tfsdk:"language" tf:"optional"` +} + +type CreateInstancePool struct { + // Attributes related to instance pools running on Amazon Web Services. If + // not specified at pool creation, a set of default values will be used. + AwsAttributes *InstancePoolAwsAttributes `tfsdk:"aws_attributes" tf:"optional"` + // Attributes related to instance pools running on Azure. If not specified + // at pool creation, a set of default values will be used. + AzureAttributes *InstancePoolAzureAttributes `tfsdk:"azure_attributes" tf:"optional"` + // Additional tags for pool resources. Databricks will tag all pool + // resources (e.g., AWS instances and EBS volumes) with these tags in + // addition to `default_tags`. Notes: + // + // - Currently, Databricks allows at most 45 custom tags + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // Defines the specification of the disks that will be attached to all spark + // containers. + DiskSpec *DiskSpec `tfsdk:"disk_spec" tf:"optional"` + // Autoscaling Local Storage: when enabled, this instances in this pool will + // dynamically acquire additional disk space when its Spark workers are + // running low on disk space. In AWS, this feature requires specific AWS + // permissions to function correctly - refer to the User Guide for more + // details. + EnableElasticDisk types.Bool `tfsdk:"enable_elastic_disk" tf:"optional"` + // Attributes related to instance pools running on Google Cloud Platform. If + // not specified at pool creation, a set of default values will be used. + GcpAttributes *InstancePoolGcpAttributes `tfsdk:"gcp_attributes" tf:"optional"` + // Automatically terminates the extra instances in the pool cache after they + // are inactive for this time in minutes if min_idle_instances requirement + // is already met. If not set, the extra pool instances will be + // automatically terminated after a default timeout. If specified, the + // threshold must be between 0 and 10000 minutes. Users can also set this + // value to 0 to instantly remove idle instances from the cache if min cache + // size could still hold. + IdleInstanceAutoterminationMinutes types.Int64 `tfsdk:"idle_instance_autotermination_minutes" tf:"optional"` + // Pool name requested by the user. Pool name must be unique. Length must be + // between 1 and 100 characters. + InstancePoolName types.String `tfsdk:"instance_pool_name" tf:""` + // Maximum number of outstanding instances to keep in the pool, including + // both instances used by clusters and idle instances. Clusters that require + // further instance provisioning will fail during upsize requests. + MaxCapacity types.Int64 `tfsdk:"max_capacity" tf:"optional"` + // Minimum number of idle instances to keep in the instance pool + MinIdleInstances types.Int64 `tfsdk:"min_idle_instances" tf:"optional"` + // This field encodes, through a single value, the resources available to + // each of the Spark nodes in this cluster. For example, the Spark nodes can + // be provisioned and optimized for memory or compute intensive workloads. A + // list of available node types can be retrieved by using the + // :method:clusters/listNodeTypes API call. + NodeTypeId types.String `tfsdk:"node_type_id" tf:""` + // Custom Docker Image BYOC + PreloadedDockerImages []DockerImage `tfsdk:"preloaded_docker_images" tf:"optional"` + // A list containing at most one preloaded Spark image version for the pool. + // Pool-backed clusters started with the preloaded Spark version will start + // faster. A list of available Spark versions can be retrieved by using the + // :method:clusters/sparkVersions API call. + PreloadedSparkVersions []types.String `tfsdk:"preloaded_spark_versions" tf:"optional"` +} + +type CreateInstancePoolResponse struct { + // The ID of the created instance pool. + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:"optional"` +} + +type CreatePolicy struct { + // Policy definition document expressed in [Databricks Cluster Policy + // Definition Language]. + // + // [Databricks Cluster Policy Definition Language]: https://docs.databricks.com/administration-guide/clusters/policy-definition.html + Definition types.String `tfsdk:"definition" tf:"optional"` + // Additional human-readable description of the cluster policy. + Description types.String `tfsdk:"description" tf:"optional"` + // A list of libraries to be installed on the next cluster restart that uses + // this policy. The maximum number of libraries is 500. + Libraries []Library `tfsdk:"libraries" tf:"optional"` + // Max number of clusters per user that can be active using this policy. If + // not present, there is no max limit. + MaxClustersPerUser types.Int64 `tfsdk:"max_clusters_per_user" tf:"optional"` + // Cluster Policy name requested by the user. This has to be unique. Length + // must be between 1 and 100 characters. + Name types.String `tfsdk:"name" tf:""` + // Policy definition JSON document expressed in [Databricks Policy + // Definition Language]. The JSON document must be passed as a string and + // cannot be embedded in the requests. + // + // You can use this to customize the policy definition inherited from the + // policy family. Policy rules specified here are merged into the inherited + // policy definition. + // + // [Databricks Policy Definition Language]: https://docs.databricks.com/administration-guide/clusters/policy-definition.html + PolicyFamilyDefinitionOverrides types.String `tfsdk:"policy_family_definition_overrides" tf:"optional"` + // ID of the policy family. The cluster policy's policy definition inherits + // the policy family's policy definition. + // + // Cannot be used with `definition`. Use + // `policy_family_definition_overrides` instead to customize the policy + // definition. + PolicyFamilyId types.String `tfsdk:"policy_family_id" tf:"optional"` +} + +type CreatePolicyResponse struct { + // Canonical unique identifier for the cluster policy. + PolicyId types.String `tfsdk:"policy_id" tf:"optional"` +} + +type CreateResponse struct { + // The global init script ID. + ScriptId types.String `tfsdk:"script_id" tf:"optional"` +} + +type Created struct { + Id types.String `tfsdk:"id" tf:"optional"` +} + +type DataPlaneEventDetails struct { + // + EventType types.String `tfsdk:"event_type" tf:"optional"` + // + ExecutorFailures types.Int64 `tfsdk:"executor_failures" tf:"optional"` + // + HostId types.String `tfsdk:"host_id" tf:"optional"` + // + Timestamp types.Int64 `tfsdk:"timestamp" tf:"optional"` +} + +type DbfsStorageInfo struct { + // dbfs destination, e.g. `dbfs:/my/path` + Destination types.String `tfsdk:"destination" tf:""` +} + +type DeleteCluster struct { + // The cluster to be terminated. + ClusterId types.String `tfsdk:"cluster_id" tf:""` +} + +type DeleteClusterResponse struct { +} + +// Delete init script +type DeleteGlobalInitScriptRequest struct { + // The ID of the global init script. + ScriptId types.String `tfsdk:"-"` +} + +type DeleteInstancePool struct { + // The instance pool to be terminated. + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:""` +} + +type DeleteInstancePoolResponse struct { +} + +type DeletePolicy struct { + // The ID of the policy to delete. + PolicyId types.String `tfsdk:"policy_id" tf:""` +} + +type DeletePolicyResponse struct { +} + +type DeleteResponse struct { +} + +type DestroyContext struct { + ClusterId types.String `tfsdk:"clusterId" tf:""` + + ContextId types.String `tfsdk:"contextId" tf:""` +} + +type DestroyResponse struct { +} + +type DiskSpec struct { + // The number of disks launched for each instance: - This feature is only + // enabled for supported node types. - Users can choose up to the limit of + // the disks supported by the node type. - For node types with no OS disk, + // at least one disk must be specified; otherwise, cluster creation will + // fail. + // + // If disks are attached, Databricks will configure Spark to use only the + // disks for scratch storage, because heterogenously sized scratch devices + // can lead to inefficient disk utilization. If no disks are attached, + // Databricks will configure Spark to use instance store disks. + // + // Note: If disks are specified, then the Spark configuration + // `spark.local.dir` will be overridden. + // + // Disks will be mounted at: - For AWS: `/ebs0`, `/ebs1`, and etc. - For + // Azure: `/remote_volume0`, `/remote_volume1`, and etc. + DiskCount types.Int64 `tfsdk:"disk_count" tf:"optional"` + + DiskIops types.Int64 `tfsdk:"disk_iops" tf:"optional"` + // The size of each disk (in GiB) launched for each instance. Values must + // fall into the supported range for a particular instance type. + // + // For AWS: - General Purpose SSD: 100 - 4096 GiB - Throughput Optimized + // HDD: 500 - 4096 GiB + // + // For Azure: - Premium LRS (SSD): 1 - 1023 GiB - Standard LRS (HDD): 1- + // 1023 GiB + DiskSize types.Int64 `tfsdk:"disk_size" tf:"optional"` + + DiskThroughput types.Int64 `tfsdk:"disk_throughput" tf:"optional"` + // The type of disks that will be launched with this cluster. + DiskType *DiskType `tfsdk:"disk_type" tf:"optional"` +} + +type DiskType struct { + AzureDiskVolumeType types.String `tfsdk:"azure_disk_volume_type" tf:"optional"` + + EbsVolumeType types.String `tfsdk:"ebs_volume_type" tf:"optional"` +} + +type DockerBasicAuth struct { + // Password of the user + Password types.String `tfsdk:"password" tf:"optional"` + // Name of the user + Username types.String `tfsdk:"username" tf:"optional"` +} + +type DockerImage struct { + BasicAuth *DockerBasicAuth `tfsdk:"basic_auth" tf:"optional"` + // URL of the docker image. + Url types.String `tfsdk:"url" tf:"optional"` +} + +type EditCluster struct { + // When set to true, fixed and default values from the policy will be used + // for fields that are omitted. When set to false, only fixed values from + // the policy will be applied. + ApplyPolicyDefaultValues types.Bool `tfsdk:"apply_policy_default_values" tf:"optional"` + // Parameters needed in order to automatically scale clusters up and down + // based on load. Note: autoscaling works best with DB runtime versions 3.0 + // or later. + Autoscale *AutoScale `tfsdk:"autoscale" tf:"optional"` + // Automatically terminates the cluster after it is inactive for this time + // in minutes. If not set, this cluster will not be automatically + // terminated. If specified, the threshold must be between 10 and 10000 + // minutes. Users can also set this value to 0 to explicitly disable + // automatic termination. + AutoterminationMinutes types.Int64 `tfsdk:"autotermination_minutes" tf:"optional"` + // Attributes related to clusters running on Amazon Web Services. If not + // specified at cluster creation, a set of default values will be used. + AwsAttributes *AwsAttributes `tfsdk:"aws_attributes" tf:"optional"` + // Attributes related to clusters running on Microsoft Azure. If not + // specified at cluster creation, a set of default values will be used. + AzureAttributes *AzureAttributes `tfsdk:"azure_attributes" tf:"optional"` + // ID of the cluser + ClusterId types.String `tfsdk:"cluster_id" tf:""` + // The configuration for delivering spark logs to a long-term storage + // destination. Two kinds of destinations (dbfs and s3) are supported. Only + // one destination can be specified for one cluster. If the conf is given, + // the logs will be delivered to the destination every `5 mins`. The + // destination of driver logs is `$destination/$clusterId/driver`, while the + // destination of executor logs is `$destination/$clusterId/executor`. + ClusterLogConf *ClusterLogConf `tfsdk:"cluster_log_conf" tf:"optional"` + // Cluster name requested by the user. This doesn't have to be unique. If + // not specified at creation, the cluster name will be an empty string. + ClusterName types.String `tfsdk:"cluster_name" tf:"optional"` + // Additional tags for cluster resources. Databricks will tag all cluster + // resources (e.g., AWS instances and EBS volumes) with these tags in + // addition to `default_tags`. Notes: + // + // - Currently, Databricks allows at most 45 custom tags + // + // - Clusters can only reuse cloud resources if the resources' tags are a + // subset of the cluster tags + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // Data security mode decides what data governance model to use when + // accessing data from a cluster. + // + // * `NONE`: No security isolation for multiple users sharing the cluster. + // Data governance features are not available in this mode. * `SINGLE_USER`: + // A secure cluster that can only be exclusively used by a single user + // specified in `single_user_name`. Most programming languages, cluster + // features and data governance features are available in this mode. * + // `USER_ISOLATION`: A secure cluster that can be shared by multiple users. + // Cluster users are fully isolated so that they cannot see each other's + // data and credentials. Most data governance features are supported in this + // mode. But programming languages and cluster features might be limited. + // + // The following modes are deprecated starting with Databricks Runtime 15.0 + // and will be removed for future Databricks Runtime versions: + // + // * `LEGACY_TABLE_ACL`: This mode is for users migrating from legacy Table + // ACL clusters. * `LEGACY_PASSTHROUGH`: This mode is for users migrating + // from legacy Passthrough on high concurrency clusters. * + // `LEGACY_SINGLE_USER`: This mode is for users migrating from legacy + // Passthrough on standard clusters. * `LEGACY_SINGLE_USER_STANDARD`: This + // mode provides a way that doesn’t have UC nor passthrough enabled. + DataSecurityMode types.String `tfsdk:"data_security_mode" tf:"optional"` + + DockerImage *DockerImage `tfsdk:"docker_image" tf:"optional"` + // The optional ID of the instance pool for the driver of the cluster + // belongs. The pool cluster uses the instance pool with id + // (instance_pool_id) if the driver pool is not assigned. + DriverInstancePoolId types.String `tfsdk:"driver_instance_pool_id" tf:"optional"` + // The node type of the Spark driver. Note that this field is optional; if + // unset, the driver node type will be set as the same value as + // `node_type_id` defined above. + DriverNodeTypeId types.String `tfsdk:"driver_node_type_id" tf:"optional"` + // Autoscaling Local Storage: when enabled, this cluster will dynamically + // acquire additional disk space when its Spark workers are running low on + // disk space. This feature requires specific AWS permissions to function + // correctly - refer to the User Guide for more details. + EnableElasticDisk types.Bool `tfsdk:"enable_elastic_disk" tf:"optional"` + // Whether to enable LUKS on cluster VMs' local disks + EnableLocalDiskEncryption types.Bool `tfsdk:"enable_local_disk_encryption" tf:"optional"` + // Attributes related to clusters running on Google Cloud Platform. If not + // specified at cluster creation, a set of default values will be used. + GcpAttributes *GcpAttributes `tfsdk:"gcp_attributes" tf:"optional"` + // The configuration for storing init scripts. Any number of destinations + // can be specified. The scripts are executed sequentially in the order + // provided. If `cluster_log_conf` is specified, init script logs are sent + // to `//init_scripts`. + InitScripts []InitScriptInfo `tfsdk:"init_scripts" tf:"optional"` + // The optional ID of the instance pool to which the cluster belongs. + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:"optional"` + // This field encodes, through a single value, the resources available to + // each of the Spark nodes in this cluster. For example, the Spark nodes can + // be provisioned and optimized for memory or compute intensive workloads. A + // list of available node types can be retrieved by using the + // :method:clusters/listNodeTypes API call. + NodeTypeId types.String `tfsdk:"node_type_id" tf:"optional"` + // Number of worker nodes that this cluster should have. A cluster has one + // Spark Driver and `num_workers` Executors for a total of `num_workers` + 1 + // Spark nodes. + // + // Note: When reading the properties of a cluster, this field reflects the + // desired number of workers rather than the actual current number of + // workers. For instance, if a cluster is resized from 5 to 10 workers, this + // field will immediately be updated to reflect the target size of 10 + // workers, whereas the workers listed in `spark_info` will gradually + // increase from 5 to 10 as the new nodes are provisioned. + NumWorkers types.Int64 `tfsdk:"num_workers" tf:"optional"` + // The ID of the cluster policy used to create the cluster if applicable. + PolicyId types.String `tfsdk:"policy_id" tf:"optional"` + // Decides which runtime engine to be use, e.g. Standard vs. Photon. If + // unspecified, the runtime engine is inferred from spark_version. + RuntimeEngine types.String `tfsdk:"runtime_engine" tf:"optional"` + // Single user name if data_security_mode is `SINGLE_USER` + SingleUserName types.String `tfsdk:"single_user_name" tf:"optional"` + // An object containing a set of optional, user-specified Spark + // configuration key-value pairs. Users can also pass in a string of extra + // JVM options to the driver and the executors via + // `spark.driver.extraJavaOptions` and `spark.executor.extraJavaOptions` + // respectively. + SparkConf map[string]types.String `tfsdk:"spark_conf" tf:"optional"` + // An object containing a set of optional, user-specified environment + // variable key-value pairs. Please note that key-value pair of the form + // (X,Y) will be exported as is (i.e., `export X='Y'`) while launching the + // driver and workers. + // + // In order to specify an additional set of `SPARK_DAEMON_JAVA_OPTS`, we + // recommend appending them to `$SPARK_DAEMON_JAVA_OPTS` as shown in the + // example below. This ensures that all default databricks managed + // environmental variables are included as well. + // + // Example Spark environment variables: `{"SPARK_WORKER_MEMORY": "28000m", + // "SPARK_LOCAL_DIRS": "/local_disk0"}` or `{"SPARK_DAEMON_JAVA_OPTS": + // "$SPARK_DAEMON_JAVA_OPTS -Dspark.shuffle.service.enabled=true"}` + SparkEnvVars map[string]types.String `tfsdk:"spark_env_vars" tf:"optional"` + // The Spark version of the cluster, e.g. `3.3.x-scala2.11`. A list of + // available Spark versions can be retrieved by using the + // :method:clusters/sparkVersions API call. + SparkVersion types.String `tfsdk:"spark_version" tf:""` + // SSH public key contents that will be added to each Spark node in this + // cluster. The corresponding private keys can be used to login with the + // user name `ubuntu` on port `2200`. Up to 10 keys can be specified. + SshPublicKeys []types.String `tfsdk:"ssh_public_keys" tf:"optional"` + + WorkloadType *WorkloadType `tfsdk:"workload_type" tf:"optional"` +} + +type EditClusterResponse struct { +} + +type EditInstancePool struct { + // Additional tags for pool resources. Databricks will tag all pool + // resources (e.g., AWS instances and EBS volumes) with these tags in + // addition to `default_tags`. Notes: + // + // - Currently, Databricks allows at most 45 custom tags + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // Automatically terminates the extra instances in the pool cache after they + // are inactive for this time in minutes if min_idle_instances requirement + // is already met. If not set, the extra pool instances will be + // automatically terminated after a default timeout. If specified, the + // threshold must be between 0 and 10000 minutes. Users can also set this + // value to 0 to instantly remove idle instances from the cache if min cache + // size could still hold. + IdleInstanceAutoterminationMinutes types.Int64 `tfsdk:"idle_instance_autotermination_minutes" tf:"optional"` + // Instance pool ID + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:""` + // Pool name requested by the user. Pool name must be unique. Length must be + // between 1 and 100 characters. + InstancePoolName types.String `tfsdk:"instance_pool_name" tf:""` + // Maximum number of outstanding instances to keep in the pool, including + // both instances used by clusters and idle instances. Clusters that require + // further instance provisioning will fail during upsize requests. + MaxCapacity types.Int64 `tfsdk:"max_capacity" tf:"optional"` + // Minimum number of idle instances to keep in the instance pool + MinIdleInstances types.Int64 `tfsdk:"min_idle_instances" tf:"optional"` + // This field encodes, through a single value, the resources available to + // each of the Spark nodes in this cluster. For example, the Spark nodes can + // be provisioned and optimized for memory or compute intensive workloads. A + // list of available node types can be retrieved by using the + // :method:clusters/listNodeTypes API call. + NodeTypeId types.String `tfsdk:"node_type_id" tf:""` +} + +type EditInstancePoolResponse struct { +} + +type EditPolicy struct { + // Policy definition document expressed in [Databricks Cluster Policy + // Definition Language]. + // + // [Databricks Cluster Policy Definition Language]: https://docs.databricks.com/administration-guide/clusters/policy-definition.html + Definition types.String `tfsdk:"definition" tf:"optional"` + // Additional human-readable description of the cluster policy. + Description types.String `tfsdk:"description" tf:"optional"` + // A list of libraries to be installed on the next cluster restart that uses + // this policy. The maximum number of libraries is 500. + Libraries []Library `tfsdk:"libraries" tf:"optional"` + // Max number of clusters per user that can be active using this policy. If + // not present, there is no max limit. + MaxClustersPerUser types.Int64 `tfsdk:"max_clusters_per_user" tf:"optional"` + // Cluster Policy name requested by the user. This has to be unique. Length + // must be between 1 and 100 characters. + Name types.String `tfsdk:"name" tf:""` + // Policy definition JSON document expressed in [Databricks Policy + // Definition Language]. The JSON document must be passed as a string and + // cannot be embedded in the requests. + // + // You can use this to customize the policy definition inherited from the + // policy family. Policy rules specified here are merged into the inherited + // policy definition. + // + // [Databricks Policy Definition Language]: https://docs.databricks.com/administration-guide/clusters/policy-definition.html + PolicyFamilyDefinitionOverrides types.String `tfsdk:"policy_family_definition_overrides" tf:"optional"` + // ID of the policy family. The cluster policy's policy definition inherits + // the policy family's policy definition. + // + // Cannot be used with `definition`. Use + // `policy_family_definition_overrides` instead to customize the policy + // definition. + PolicyFamilyId types.String `tfsdk:"policy_family_id" tf:"optional"` + // The ID of the policy to update. + PolicyId types.String `tfsdk:"policy_id" tf:""` +} + +type EditPolicyResponse struct { +} + +type EditResponse struct { +} + +// The environment entity used to preserve serverless environment side panel and +// jobs' environment for non-notebook task. In this minimal environment spec, +// only pip dependencies are supported. +type Environment struct { + // Client version used by the environment The client is the user-facing + // environment of the runtime. Each client comes with a specific set of + // pre-installed libraries. The version is a string, consisting of the major + // client version. + Client types.String `tfsdk:"client" tf:""` + // List of pip dependencies, as supported by the version of pip in this + // environment. Each dependency is a pip requirement file line + // https://pip.pypa.io/en/stable/reference/requirements-file-format/ Allowed + // dependency could be , , (WSFS or Volumes in Databricks), E.g. + // dependencies: ["foo==0.0.1", "-r /Workspace/test/requirements.txt"] + Dependencies []types.String `tfsdk:"dependencies" tf:"optional"` +} + +type EventDetails struct { + // * For created clusters, the attributes of the cluster. * For edited + // clusters, the new attributes of the cluster. + Attributes *ClusterAttributes `tfsdk:"attributes" tf:"optional"` + // The cause of a change in target size. + Cause types.String `tfsdk:"cause" tf:"optional"` + // The actual cluster size that was set in the cluster creation or edit. + ClusterSize *ClusterSize `tfsdk:"cluster_size" tf:"optional"` + // The current number of vCPUs in the cluster. + CurrentNumVcpus types.Int64 `tfsdk:"current_num_vcpus" tf:"optional"` + // The current number of nodes in the cluster. + CurrentNumWorkers types.Int64 `tfsdk:"current_num_workers" tf:"optional"` + // + DidNotExpandReason types.String `tfsdk:"did_not_expand_reason" tf:"optional"` + // Current disk size in bytes + DiskSize types.Int64 `tfsdk:"disk_size" tf:"optional"` + // More details about the change in driver's state + DriverStateMessage types.String `tfsdk:"driver_state_message" tf:"optional"` + // Whether or not a blocklisted node should be terminated. For + // ClusterEventType NODE_BLACKLISTED. + EnableTerminationForNodeBlocklisted types.Bool `tfsdk:"enable_termination_for_node_blocklisted" tf:"optional"` + // + FreeSpace types.Int64 `tfsdk:"free_space" tf:"optional"` + // List of global and cluster init scripts associated with this cluster + // event. + InitScripts *InitScriptEventDetails `tfsdk:"init_scripts" tf:"optional"` + // Instance Id where the event originated from + InstanceId types.String `tfsdk:"instance_id" tf:"optional"` + // Unique identifier of the specific job run associated with this cluster + // event * For clusters created for jobs, this will be the same as the + // cluster name + JobRunName types.String `tfsdk:"job_run_name" tf:"optional"` + // The cluster attributes before a cluster was edited. + PreviousAttributes *ClusterAttributes `tfsdk:"previous_attributes" tf:"optional"` + // The size of the cluster before an edit or resize. + PreviousClusterSize *ClusterSize `tfsdk:"previous_cluster_size" tf:"optional"` + // Previous disk size in bytes + PreviousDiskSize types.Int64 `tfsdk:"previous_disk_size" tf:"optional"` + // A termination reason: * On a TERMINATED event, this is the reason of the + // termination. * On a RESIZE_COMPLETE event, this indicates the reason that + // we failed to acquire some nodes. + Reason *TerminationReason `tfsdk:"reason" tf:"optional"` + // The targeted number of vCPUs in the cluster. + TargetNumVcpus types.Int64 `tfsdk:"target_num_vcpus" tf:"optional"` + // The targeted number of nodes in the cluster. + TargetNumWorkers types.Int64 `tfsdk:"target_num_workers" tf:"optional"` + // The user that caused the event to occur. (Empty if it was done by the + // control plane.) + User types.String `tfsdk:"user" tf:"optional"` +} + +type GcpAttributes struct { + // This field determines whether the instance pool will contain preemptible + // VMs, on-demand VMs, or preemptible VMs with a fallback to on-demand VMs + // if the former is unavailable. + Availability types.String `tfsdk:"availability" tf:"optional"` + // boot disk size in GB + BootDiskSize types.Int64 `tfsdk:"boot_disk_size" tf:"optional"` + // If provided, the cluster will impersonate the google service account when + // accessing gcloud services (like GCS). The google service account must + // have previously been added to the Databricks environment by an account + // administrator. + GoogleServiceAccount types.String `tfsdk:"google_service_account" tf:"optional"` + // If provided, each node (workers and driver) in the cluster will have this + // number of local SSDs attached. Each local SSD is 375GB in size. Refer to + // [GCP documentation] for the supported number of local SSDs for each + // instance type. + // + // [GCP documentation]: https://cloud.google.com/compute/docs/disks/local-ssd#choose_number_local_ssds + LocalSsdCount types.Int64 `tfsdk:"local_ssd_count" tf:"optional"` + // This field determines whether the spark executors will be scheduled to + // run on preemptible VMs (when set to true) versus standard compute engine + // VMs (when set to false; default). Note: Soon to be deprecated, use the + // availability field instead. + UsePreemptibleExecutors types.Bool `tfsdk:"use_preemptible_executors" tf:"optional"` + // Identifier for the availability zone in which the cluster resides. This + // can be one of the following: - "HA" => High availability, spread nodes + // across availability zones for a Databricks deployment region [default] - + // "AUTO" => Databricks picks an availability zone to schedule the cluster + // on. - A GCP availability zone => Pick One of the available zones for + // (machine type + region) from + // https://cloud.google.com/compute/docs/regions-zones. + ZoneId types.String `tfsdk:"zone_id" tf:"optional"` +} + +type GcsStorageInfo struct { + // GCS destination/URI, e.g. `gs://my-bucket/some-prefix` + Destination types.String `tfsdk:"destination" tf:""` +} + +// Get cluster permission levels +type GetClusterPermissionLevelsRequest struct { + // The cluster for which to get or manage permissions. + ClusterId types.String `tfsdk:"-"` +} + +type GetClusterPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []ClusterPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get cluster permissions +type GetClusterPermissionsRequest struct { + // The cluster for which to get or manage permissions. + ClusterId types.String `tfsdk:"-"` +} + +// Get cluster policy permission levels +type GetClusterPolicyPermissionLevelsRequest struct { + // The cluster policy for which to get or manage permissions. + ClusterPolicyId types.String `tfsdk:"-"` +} + +type GetClusterPolicyPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []ClusterPolicyPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get cluster policy permissions +type GetClusterPolicyPermissionsRequest struct { + // The cluster policy for which to get or manage permissions. + ClusterPolicyId types.String `tfsdk:"-"` +} + +// Get a cluster policy +type GetClusterPolicyRequest struct { + // Canonical unique identifier for the cluster policy. + PolicyId types.String `tfsdk:"-"` +} + +// Get cluster info +type GetClusterRequest struct { + // The cluster about which to retrieve information. + ClusterId types.String `tfsdk:"-"` +} + +type GetEvents struct { + // The ID of the cluster to retrieve events about. + ClusterId types.String `tfsdk:"cluster_id" tf:""` + // The end time in epoch milliseconds. If empty, returns events up to the + // current time. + EndTime types.Int64 `tfsdk:"end_time" tf:"optional"` + // An optional set of event types to filter on. If empty, all event types + // are returned. + EventTypes []types.String `tfsdk:"event_types" tf:"optional"` + // The maximum number of events to include in a page of events. Defaults to + // 50, and maximum allowed value is 500. + Limit types.Int64 `tfsdk:"limit" tf:"optional"` + // The offset in the result set. Defaults to 0 (no offset). When an offset + // is specified and the results are requested in descending order, the + // end_time field is required. + Offset types.Int64 `tfsdk:"offset" tf:"optional"` + // The order to list events in; either "ASC" or "DESC". Defaults to "DESC". + Order types.String `tfsdk:"order" tf:"optional"` + // The start time in epoch milliseconds. If empty, returns events starting + // from the beginning of time. + StartTime types.Int64 `tfsdk:"start_time" tf:"optional"` +} + +type GetEventsResponse struct { + // + Events []ClusterEvent `tfsdk:"events" tf:"optional"` + // The parameters required to retrieve the next page of events. Omitted if + // there are no more events to read. + NextPage *GetEvents `tfsdk:"next_page" tf:"optional"` + // The total number of events filtered by the start_time, end_time, and + // event_types. + TotalCount types.Int64 `tfsdk:"total_count" tf:"optional"` +} + +// Get an init script +type GetGlobalInitScriptRequest struct { + // The ID of the global init script. + ScriptId types.String `tfsdk:"-"` +} + +type GetInstancePool struct { + // Attributes related to instance pools running on Amazon Web Services. If + // not specified at pool creation, a set of default values will be used. + AwsAttributes *InstancePoolAwsAttributes `tfsdk:"aws_attributes" tf:"optional"` + // Attributes related to instance pools running on Azure. If not specified + // at pool creation, a set of default values will be used. + AzureAttributes *InstancePoolAzureAttributes `tfsdk:"azure_attributes" tf:"optional"` + // Additional tags for pool resources. Databricks will tag all pool + // resources (e.g., AWS instances and EBS volumes) with these tags in + // addition to `default_tags`. Notes: + // + // - Currently, Databricks allows at most 45 custom tags + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // Tags that are added by Databricks regardless of any `custom_tags`, + // including: + // + // - Vendor: Databricks + // + // - InstancePoolCreator: + // + // - InstancePoolName: + // + // - InstancePoolId: + DefaultTags map[string]types.String `tfsdk:"default_tags" tf:"optional"` + // Defines the specification of the disks that will be attached to all spark + // containers. + DiskSpec *DiskSpec `tfsdk:"disk_spec" tf:"optional"` + // Autoscaling Local Storage: when enabled, this instances in this pool will + // dynamically acquire additional disk space when its Spark workers are + // running low on disk space. In AWS, this feature requires specific AWS + // permissions to function correctly - refer to the User Guide for more + // details. + EnableElasticDisk types.Bool `tfsdk:"enable_elastic_disk" tf:"optional"` + // Attributes related to instance pools running on Google Cloud Platform. If + // not specified at pool creation, a set of default values will be used. + GcpAttributes *InstancePoolGcpAttributes `tfsdk:"gcp_attributes" tf:"optional"` + // Automatically terminates the extra instances in the pool cache after they + // are inactive for this time in minutes if min_idle_instances requirement + // is already met. If not set, the extra pool instances will be + // automatically terminated after a default timeout. If specified, the + // threshold must be between 0 and 10000 minutes. Users can also set this + // value to 0 to instantly remove idle instances from the cache if min cache + // size could still hold. + IdleInstanceAutoterminationMinutes types.Int64 `tfsdk:"idle_instance_autotermination_minutes" tf:"optional"` + // Canonical unique identifier for the pool. + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:""` + // Pool name requested by the user. Pool name must be unique. Length must be + // between 1 and 100 characters. + InstancePoolName types.String `tfsdk:"instance_pool_name" tf:"optional"` + // Maximum number of outstanding instances to keep in the pool, including + // both instances used by clusters and idle instances. Clusters that require + // further instance provisioning will fail during upsize requests. + MaxCapacity types.Int64 `tfsdk:"max_capacity" tf:"optional"` + // Minimum number of idle instances to keep in the instance pool + MinIdleInstances types.Int64 `tfsdk:"min_idle_instances" tf:"optional"` + // This field encodes, through a single value, the resources available to + // each of the Spark nodes in this cluster. For example, the Spark nodes can + // be provisioned and optimized for memory or compute intensive workloads. A + // list of available node types can be retrieved by using the + // :method:clusters/listNodeTypes API call. + NodeTypeId types.String `tfsdk:"node_type_id" tf:"optional"` + // Custom Docker Image BYOC + PreloadedDockerImages []DockerImage `tfsdk:"preloaded_docker_images" tf:"optional"` + // A list containing at most one preloaded Spark image version for the pool. + // Pool-backed clusters started with the preloaded Spark version will start + // faster. A list of available Spark versions can be retrieved by using the + // :method:clusters/sparkVersions API call. + PreloadedSparkVersions []types.String `tfsdk:"preloaded_spark_versions" tf:"optional"` + // Current state of the instance pool. + State types.String `tfsdk:"state" tf:"optional"` + // Usage statistics about the instance pool. + Stats *InstancePoolStats `tfsdk:"stats" tf:"optional"` + // Status of failed pending instances in the pool. + Status *InstancePoolStatus `tfsdk:"status" tf:"optional"` +} + +// Get instance pool permission levels +type GetInstancePoolPermissionLevelsRequest struct { + // The instance pool for which to get or manage permissions. + InstancePoolId types.String `tfsdk:"-"` +} + +type GetInstancePoolPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []InstancePoolPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get instance pool permissions +type GetInstancePoolPermissionsRequest struct { + // The instance pool for which to get or manage permissions. + InstancePoolId types.String `tfsdk:"-"` +} + +// Get instance pool information +type GetInstancePoolRequest struct { + // The canonical unique identifier for the instance pool. + InstancePoolId types.String `tfsdk:"-"` +} + +// Get policy family information +type GetPolicyFamilyRequest struct { + PolicyFamilyId types.String `tfsdk:"-"` +} + +type GetSparkVersionsResponse struct { + // All the available Spark versions. + Versions []SparkVersion `tfsdk:"versions" tf:"optional"` +} + +type GlobalInitScriptCreateRequest struct { + // Specifies whether the script is enabled. The script runs only if enabled. + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` + // The name of the script + Name types.String `tfsdk:"name" tf:""` + // The position of a global init script, where 0 represents the first script + // to run, 1 is the second script to run, in ascending order. + // + // If you omit the numeric position for a new global init script, it + // defaults to last position. It will run after all current scripts. Setting + // any value greater than the position of the last script is equivalent to + // the last position. Example: Take three existing scripts with positions 0, + // 1, and 2. Any position of (3) or greater puts the script in the last + // position. If an explicit position value conflicts with an existing script + // value, your request succeeds, but the original script at that position + // and all later scripts have their positions incremented by 1. + Position types.Int64 `tfsdk:"position" tf:"optional"` + // The Base64-encoded content of the script. + Script types.String `tfsdk:"script" tf:""` +} + +type GlobalInitScriptDetails struct { + // Time when the script was created, represented as a Unix timestamp in + // milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // The username of the user who created the script. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Specifies whether the script is enabled. The script runs only if enabled. + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` + // The name of the script + Name types.String `tfsdk:"name" tf:"optional"` + // The position of a script, where 0 represents the first script to run, 1 + // is the second script to run, in ascending order. + Position types.Int64 `tfsdk:"position" tf:"optional"` + // The global init script ID. + ScriptId types.String `tfsdk:"script_id" tf:"optional"` + // Time when the script was updated, represented as a Unix timestamp in + // milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // The username of the user who last updated the script + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type GlobalInitScriptDetailsWithContent struct { + // Time when the script was created, represented as a Unix timestamp in + // milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // The username of the user who created the script. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Specifies whether the script is enabled. The script runs only if enabled. + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` + // The name of the script + Name types.String `tfsdk:"name" tf:"optional"` + // The position of a script, where 0 represents the first script to run, 1 + // is the second script to run, in ascending order. + Position types.Int64 `tfsdk:"position" tf:"optional"` + // The Base64-encoded content of the script. + Script types.String `tfsdk:"script" tf:"optional"` + // The global init script ID. + ScriptId types.String `tfsdk:"script_id" tf:"optional"` + // Time when the script was updated, represented as a Unix timestamp in + // milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // The username of the user who last updated the script + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type GlobalInitScriptUpdateRequest struct { + // Specifies whether the script is enabled. The script runs only if enabled. + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` + // The name of the script + Name types.String `tfsdk:"name" tf:""` + // The position of a script, where 0 represents the first script to run, 1 + // is the second script to run, in ascending order. To move the script to + // run first, set its position to 0. + // + // To move the script to the end, set its position to any value greater or + // equal to the position of the last script. Example, three existing scripts + // with positions 0, 1, and 2. Any position value of 2 or greater puts the + // script in the last position (2). + // + // If an explicit position value conflicts with an existing script, your + // request succeeds, but the original script at that position and all later + // scripts have their positions incremented by 1. + Position types.Int64 `tfsdk:"position" tf:"optional"` + // The Base64-encoded content of the script. + Script types.String `tfsdk:"script" tf:""` + // The ID of the global init script. + ScriptId types.String `tfsdk:"-"` +} + +type InitScriptEventDetails struct { + // The cluster scoped init scripts associated with this cluster event + Cluster []InitScriptInfoAndExecutionDetails `tfsdk:"cluster" tf:"optional"` + // The global init scripts associated with this cluster event + Global []InitScriptInfoAndExecutionDetails `tfsdk:"global" tf:"optional"` + // The private ip address of the node where the init scripts were run. + ReportedForNode types.String `tfsdk:"reported_for_node" tf:"optional"` +} + +type InitScriptExecutionDetails struct { + // Addition details regarding errors. + ErrorMessage types.String `tfsdk:"error_message" tf:"optional"` + // The duration of the script execution in seconds. + ExecutionDurationSeconds types.Int64 `tfsdk:"execution_duration_seconds" tf:"optional"` + // The current status of the script + Status types.String `tfsdk:"status" tf:"optional"` +} + +type InitScriptInfo struct { + // destination needs to be provided. e.g. `{ "abfss" : { "destination" : + // "abfss://@.dfs.core.windows.net/" + // } } + Abfss *Adlsgen2Info `tfsdk:"abfss" tf:"optional"` + // destination needs to be provided. e.g. `{ "dbfs" : { "destination" : + // "dbfs:/home/cluster_log" } }` + Dbfs *DbfsStorageInfo `tfsdk:"dbfs" tf:"optional"` + // destination needs to be provided. e.g. `{ "file" : { "destination" : + // "file:/my/local/file.sh" } }` + File *LocalFileInfo `tfsdk:"file" tf:"optional"` + // destination needs to be provided. e.g. `{ "gcs": { "destination": + // "gs://my-bucket/file.sh" } }` + Gcs *GcsStorageInfo `tfsdk:"gcs" tf:"optional"` + // destination and either the region or endpoint need to be provided. e.g. + // `{ "s3": { "destination" : "s3://cluster_log_bucket/prefix", "region" : + // "us-west-2" } }` Cluster iam role is used to access s3, please make sure + // the cluster iam role in `instance_profile_arn` has permission to write + // data to the s3 destination. + S3 *S3StorageInfo `tfsdk:"s3" tf:"optional"` + // destination needs to be provided. e.g. `{ "volumes" : { "destination" : + // "/Volumes/my-init.sh" } }` + Volumes *VolumesStorageInfo `tfsdk:"volumes" tf:"optional"` + // destination needs to be provided. e.g. `{ "workspace" : { "destination" : + // "/Users/user1@databricks.com/my-init.sh" } }` + Workspace *WorkspaceStorageInfo `tfsdk:"workspace" tf:"optional"` +} + +type InitScriptInfoAndExecutionDetails struct { + // Details about the script + ExecutionDetails *InitScriptExecutionDetails `tfsdk:"execution_details" tf:"optional"` + // The script + Script *InitScriptInfo `tfsdk:"script" tf:"optional"` +} + +type InstallLibraries struct { + // Unique identifier for the cluster on which to install these libraries. + ClusterId types.String `tfsdk:"cluster_id" tf:""` + // The libraries to install. + Libraries []Library `tfsdk:"libraries" tf:""` +} + +type InstallLibrariesResponse struct { +} + +type InstancePoolAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type InstancePoolAccessControlResponse struct { + // All permissions. + AllPermissions []InstancePoolPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type InstancePoolAndStats struct { + // Attributes related to instance pools running on Amazon Web Services. If + // not specified at pool creation, a set of default values will be used. + AwsAttributes *InstancePoolAwsAttributes `tfsdk:"aws_attributes" tf:"optional"` + // Attributes related to instance pools running on Azure. If not specified + // at pool creation, a set of default values will be used. + AzureAttributes *InstancePoolAzureAttributes `tfsdk:"azure_attributes" tf:"optional"` + // Additional tags for pool resources. Databricks will tag all pool + // resources (e.g., AWS instances and EBS volumes) with these tags in + // addition to `default_tags`. Notes: + // + // - Currently, Databricks allows at most 45 custom tags + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // Tags that are added by Databricks regardless of any `custom_tags`, + // including: + // + // - Vendor: Databricks + // + // - InstancePoolCreator: + // + // - InstancePoolName: + // + // - InstancePoolId: + DefaultTags map[string]types.String `tfsdk:"default_tags" tf:"optional"` + // Defines the specification of the disks that will be attached to all spark + // containers. + DiskSpec *DiskSpec `tfsdk:"disk_spec" tf:"optional"` + // Autoscaling Local Storage: when enabled, this instances in this pool will + // dynamically acquire additional disk space when its Spark workers are + // running low on disk space. In AWS, this feature requires specific AWS + // permissions to function correctly - refer to the User Guide for more + // details. + EnableElasticDisk types.Bool `tfsdk:"enable_elastic_disk" tf:"optional"` + // Attributes related to instance pools running on Google Cloud Platform. If + // not specified at pool creation, a set of default values will be used. + GcpAttributes *InstancePoolGcpAttributes `tfsdk:"gcp_attributes" tf:"optional"` + // Automatically terminates the extra instances in the pool cache after they + // are inactive for this time in minutes if min_idle_instances requirement + // is already met. If not set, the extra pool instances will be + // automatically terminated after a default timeout. If specified, the + // threshold must be between 0 and 10000 minutes. Users can also set this + // value to 0 to instantly remove idle instances from the cache if min cache + // size could still hold. + IdleInstanceAutoterminationMinutes types.Int64 `tfsdk:"idle_instance_autotermination_minutes" tf:"optional"` + // Canonical unique identifier for the pool. + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:"optional"` + // Pool name requested by the user. Pool name must be unique. Length must be + // between 1 and 100 characters. + InstancePoolName types.String `tfsdk:"instance_pool_name" tf:"optional"` + // Maximum number of outstanding instances to keep in the pool, including + // both instances used by clusters and idle instances. Clusters that require + // further instance provisioning will fail during upsize requests. + MaxCapacity types.Int64 `tfsdk:"max_capacity" tf:"optional"` + // Minimum number of idle instances to keep in the instance pool + MinIdleInstances types.Int64 `tfsdk:"min_idle_instances" tf:"optional"` + // This field encodes, through a single value, the resources available to + // each of the Spark nodes in this cluster. For example, the Spark nodes can + // be provisioned and optimized for memory or compute intensive workloads. A + // list of available node types can be retrieved by using the + // :method:clusters/listNodeTypes API call. + NodeTypeId types.String `tfsdk:"node_type_id" tf:"optional"` + // Custom Docker Image BYOC + PreloadedDockerImages []DockerImage `tfsdk:"preloaded_docker_images" tf:"optional"` + // A list containing at most one preloaded Spark image version for the pool. + // Pool-backed clusters started with the preloaded Spark version will start + // faster. A list of available Spark versions can be retrieved by using the + // :method:clusters/sparkVersions API call. + PreloadedSparkVersions []types.String `tfsdk:"preloaded_spark_versions" tf:"optional"` + // Current state of the instance pool. + State types.String `tfsdk:"state" tf:"optional"` + // Usage statistics about the instance pool. + Stats *InstancePoolStats `tfsdk:"stats" tf:"optional"` + // Status of failed pending instances in the pool. + Status *InstancePoolStatus `tfsdk:"status" tf:"optional"` +} + +type InstancePoolAwsAttributes struct { + // Availability type used for the spot nodes. + // + // The default value is defined by + // InstancePoolConf.instancePoolDefaultAwsAvailability + Availability types.String `tfsdk:"availability" tf:"optional"` + // Calculates the bid price for AWS spot instances, as a percentage of the + // corresponding instance type's on-demand price. For example, if this field + // is set to 50, and the cluster needs a new `r3.xlarge` spot instance, then + // the bid price is half of the price of on-demand `r3.xlarge` instances. + // Similarly, if this field is set to 200, the bid price is twice the price + // of on-demand `r3.xlarge` instances. If not specified, the default value + // is 100. When spot instances are requested for this cluster, only spot + // instances whose bid price percentage matches this field will be + // considered. Note that, for safety, we enforce this field to be no more + // than 10000. + // + // The default value and documentation here should be kept consistent with + // CommonConf.defaultSpotBidPricePercent and + // CommonConf.maxSpotBidPricePercent. + SpotBidPricePercent types.Int64 `tfsdk:"spot_bid_price_percent" tf:"optional"` + // Identifier for the availability zone/datacenter in which the cluster + // resides. This string will be of a form like "us-west-2a". The provided + // availability zone must be in the same region as the Databricks + // deployment. For example, "us-west-2a" is not a valid zone id if the + // Databricks deployment resides in the "us-east-1" region. This is an + // optional field at cluster creation, and if not specified, a default zone + // will be used. The list of available zones as well as the default value + // can be found by using the `List Zones` method. + ZoneId types.String `tfsdk:"zone_id" tf:"optional"` +} + +type InstancePoolAzureAttributes struct { + // Shows the Availability type used for the spot nodes. + // + // The default value is defined by + // InstancePoolConf.instancePoolDefaultAzureAvailability + Availability types.String `tfsdk:"availability" tf:"optional"` + // The default value and documentation here should be kept consistent with + // CommonConf.defaultSpotBidMaxPrice. + SpotBidMaxPrice types.Float64 `tfsdk:"spot_bid_max_price" tf:"optional"` +} + +type InstancePoolGcpAttributes struct { + // This field determines whether the instance pool will contain preemptible + // VMs, on-demand VMs, or preemptible VMs with a fallback to on-demand VMs + // if the former is unavailable. + GcpAvailability types.String `tfsdk:"gcp_availability" tf:"optional"` + // If provided, each node in the instance pool will have this number of + // local SSDs attached. Each local SSD is 375GB in size. Refer to [GCP + // documentation] for the supported number of local SSDs for each instance + // type. + // + // [GCP documentation]: https://cloud.google.com/compute/docs/disks/local-ssd#choose_number_local_ssds + LocalSsdCount types.Int64 `tfsdk:"local_ssd_count" tf:"optional"` + // Identifier for the availability zone/datacenter in which the cluster + // resides. This string will be of a form like "us-west1-a". The provided + // availability zone must be in the same region as the Databricks workspace. + // For example, "us-west1-a" is not a valid zone id if the Databricks + // workspace resides in the "us-east1" region. This is an optional field at + // instance pool creation, and if not specified, a default zone will be + // used. + // + // This field can be one of the following: - "HA" => High availability, + // spread nodes across availability zones for a Databricks deployment region + // - A GCP availability zone => Pick One of the available zones for (machine + // type + region) from https://cloud.google.com/compute/docs/regions-zones + // (e.g. "us-west1-a"). + // + // If empty, Databricks picks an availability zone to schedule the cluster + // on. + ZoneId types.String `tfsdk:"zone_id" tf:"optional"` +} + +type InstancePoolPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type InstancePoolPermissions struct { + AccessControlList []InstancePoolAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type InstancePoolPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type InstancePoolPermissionsRequest struct { + AccessControlList []InstancePoolAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The instance pool for which to get or manage permissions. + InstancePoolId types.String `tfsdk:"-"` +} + +type InstancePoolStats struct { + // Number of active instances in the pool that are NOT part of a cluster. + IdleCount types.Int64 `tfsdk:"idle_count" tf:"optional"` + // Number of pending instances in the pool that are NOT part of a cluster. + PendingIdleCount types.Int64 `tfsdk:"pending_idle_count" tf:"optional"` + // Number of pending instances in the pool that are part of a cluster. + PendingUsedCount types.Int64 `tfsdk:"pending_used_count" tf:"optional"` + // Number of active instances in the pool that are part of a cluster. + UsedCount types.Int64 `tfsdk:"used_count" tf:"optional"` +} + +type InstancePoolStatus struct { + // List of error messages for the failed pending instances. The + // pending_instance_errors follows FIFO with maximum length of the min_idle + // of the pool. The pending_instance_errors is emptied once the number of + // exiting available instances reaches the min_idle of the pool. + PendingInstanceErrors []PendingInstanceError `tfsdk:"pending_instance_errors" tf:"optional"` +} + +type InstanceProfile struct { + // The AWS IAM role ARN of the role associated with the instance profile. + // This field is required if your role name and instance profile name do not + // match and you want to use the instance profile with [Databricks SQL + // Serverless]. + // + // Otherwise, this field is optional. + // + // [Databricks SQL Serverless]: https://docs.databricks.com/sql/admin/serverless.html + IamRoleArn types.String `tfsdk:"iam_role_arn" tf:"optional"` + // The AWS ARN of the instance profile to register with Databricks. This + // field is required. + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:""` + // Boolean flag indicating whether the instance profile should only be used + // in credential passthrough scenarios. If true, it means the instance + // profile contains an meta IAM role which could assume a wide range of + // roles. Therefore it should always be used with authorization. This field + // is optional, the default value is `false`. + IsMetaInstanceProfile types.Bool `tfsdk:"is_meta_instance_profile" tf:"optional"` +} + +type Library struct { + // Specification of a CRAN library to be installed as part of the library + Cran *RCranLibrary `tfsdk:"cran" tf:"optional"` + // URI of the egg library to install. Supported URIs include Workspace + // paths, Unity Catalog Volumes paths, and S3 URIs. For example: `{ "egg": + // "/Workspace/path/to/library.egg" }`, `{ "egg" : + // "/Volumes/path/to/library.egg" }` or `{ "egg": + // "s3://my-bucket/library.egg" }`. If S3 is used, please make sure the + // cluster has read access on the library. You may need to launch the + // cluster with an IAM role to access the S3 URI. + Egg types.String `tfsdk:"egg" tf:"optional"` + // URI of the JAR library to install. Supported URIs include Workspace + // paths, Unity Catalog Volumes paths, and S3 URIs. For example: `{ "jar": + // "/Workspace/path/to/library.jar" }`, `{ "jar" : + // "/Volumes/path/to/library.jar" }` or `{ "jar": + // "s3://my-bucket/library.jar" }`. If S3 is used, please make sure the + // cluster has read access on the library. You may need to launch the + // cluster with an IAM role to access the S3 URI. + Jar types.String `tfsdk:"jar" tf:"optional"` + // Specification of a maven library to be installed. For example: `{ + // "coordinates": "org.jsoup:jsoup:1.7.2" }` + Maven *MavenLibrary `tfsdk:"maven" tf:"optional"` + // Specification of a PyPi library to be installed. For example: `{ + // "package": "simplejson" }` + Pypi *PythonPyPiLibrary `tfsdk:"pypi" tf:"optional"` + // URI of the requirements.txt file to install. Only Workspace paths and + // Unity Catalog Volumes paths are supported. For example: `{ + // "requirements": "/Workspace/path/to/requirements.txt" }` or `{ + // "requirements" : "/Volumes/path/to/requirements.txt" }` + Requirements types.String `tfsdk:"requirements" tf:"optional"` + // URI of the wheel library to install. Supported URIs include Workspace + // paths, Unity Catalog Volumes paths, and S3 URIs. For example: `{ "whl": + // "/Workspace/path/to/library.whl" }`, `{ "whl" : + // "/Volumes/path/to/library.whl" }` or `{ "whl": + // "s3://my-bucket/library.whl" }`. If S3 is used, please make sure the + // cluster has read access on the library. You may need to launch the + // cluster with an IAM role to access the S3 URI. + Whl types.String `tfsdk:"whl" tf:"optional"` +} + +// The status of the library on a specific cluster. +type LibraryFullStatus struct { + // Whether the library was set to be installed on all clusters via the + // libraries UI. + IsLibraryForAllClusters types.Bool `tfsdk:"is_library_for_all_clusters" tf:"optional"` + // Unique identifier for the library. + Library *Library `tfsdk:"library" tf:"optional"` + // All the info and warning messages that have occurred so far for this + // library. + Messages []types.String `tfsdk:"messages" tf:"optional"` + // Status of installing the library on the cluster. + Status types.String `tfsdk:"status" tf:"optional"` +} + +type ListAllClusterLibraryStatusesResponse struct { + // A list of cluster statuses. + Statuses []ClusterLibraryStatuses `tfsdk:"statuses" tf:"optional"` +} + +type ListAvailableZonesResponse struct { + // The availability zone if no `zone_id` is provided in the cluster creation + // request. + DefaultZone types.String `tfsdk:"default_zone" tf:"optional"` + // The list of available zones (e.g., ['us-west-2c', 'us-east-2']). + Zones []types.String `tfsdk:"zones" tf:"optional"` +} + +// List cluster policies +type ListClusterPoliciesRequest struct { + // The cluster policy attribute to sort by. * `POLICY_CREATION_TIME` - Sort + // result list by policy creation time. * `POLICY_NAME` - Sort result list + // by policy name. + SortColumn types.String `tfsdk:"-"` + // The order in which the policies get listed. * `DESC` - Sort result list + // in descending order. * `ASC` - Sort result list in ascending order. + SortOrder types.String `tfsdk:"-"` +} + +// List all clusters +type ListClustersRequest struct { + // Filter clusters based on what type of client it can be used for. Could be + // either NOTEBOOKS or JOBS. No input for this field will get all clusters + // in the workspace without filtering on its supported client + CanUseClient types.String `tfsdk:"-"` +} + +type ListClustersResponse struct { + // + Clusters []ClusterDetails `tfsdk:"clusters" tf:"optional"` +} + +type ListGlobalInitScriptsResponse struct { + Scripts []GlobalInitScriptDetails `tfsdk:"scripts" tf:"optional"` +} + +type ListInstancePools struct { + InstancePools []InstancePoolAndStats `tfsdk:"instance_pools" tf:"optional"` +} + +type ListInstanceProfilesResponse struct { + // A list of instance profiles that the user can access. + InstanceProfiles []InstanceProfile `tfsdk:"instance_profiles" tf:"optional"` +} + +type ListNodeTypesResponse struct { + // The list of available Spark node types. + NodeTypes []NodeType `tfsdk:"node_types" tf:"optional"` +} + +type ListPoliciesResponse struct { + // List of policies. + Policies []Policy `tfsdk:"policies" tf:"optional"` +} + +// List policy families +type ListPolicyFamiliesRequest struct { + // The max number of policy families to return. + MaxResults types.Int64 `tfsdk:"-"` + // A token that can be used to get the next page of results. + PageToken types.String `tfsdk:"-"` +} + +type ListPolicyFamiliesResponse struct { + // A token that can be used to get the next page of results. If not present, + // there are no more results to show. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // List of policy families. + PolicyFamilies []PolicyFamily `tfsdk:"policy_families" tf:""` +} + +type LocalFileInfo struct { + // local file destination, e.g. `file:/my/local/file.sh` + Destination types.String `tfsdk:"destination" tf:""` +} + +type LogAnalyticsInfo struct { + // + LogAnalyticsPrimaryKey types.String `tfsdk:"log_analytics_primary_key" tf:"optional"` + // + LogAnalyticsWorkspaceId types.String `tfsdk:"log_analytics_workspace_id" tf:"optional"` +} + +type LogSyncStatus struct { + // The timestamp of last attempt. If the last attempt fails, + // `last_exception` will contain the exception in the last attempt. + LastAttempted types.Int64 `tfsdk:"last_attempted" tf:"optional"` + // The exception thrown in the last attempt, it would be null (omitted in + // the response) if there is no exception in last attempted. + LastException types.String `tfsdk:"last_exception" tf:"optional"` +} + +type MavenLibrary struct { + // Gradle-style maven coordinates. For example: "org.jsoup:jsoup:1.7.2". + Coordinates types.String `tfsdk:"coordinates" tf:""` + // List of dependences to exclude. For example: `["slf4j:slf4j", + // "*:hadoop-client"]`. + // + // Maven dependency exclusions: + // https://maven.apache.org/guides/introduction/introduction-to-optional-and-excludes-dependencies.html. + Exclusions []types.String `tfsdk:"exclusions" tf:"optional"` + // Maven repo to install the Maven package from. If omitted, both Maven + // Central Repository and Spark Packages are searched. + Repo types.String `tfsdk:"repo" tf:"optional"` +} + +type NodeInstanceType struct { + InstanceTypeId types.String `tfsdk:"instance_type_id" tf:"optional"` + + LocalDiskSizeGb types.Int64 `tfsdk:"local_disk_size_gb" tf:"optional"` + + LocalDisks types.Int64 `tfsdk:"local_disks" tf:"optional"` + + LocalNvmeDiskSizeGb types.Int64 `tfsdk:"local_nvme_disk_size_gb" tf:"optional"` + + LocalNvmeDisks types.Int64 `tfsdk:"local_nvme_disks" tf:"optional"` +} + +type NodeType struct { + Category types.String `tfsdk:"category" tf:"optional"` + // A string description associated with this node type, e.g., "r3.xlarge". + Description types.String `tfsdk:"description" tf:""` + + DisplayOrder types.Int64 `tfsdk:"display_order" tf:"optional"` + // An identifier for the type of hardware that this node runs on, e.g., + // "r3.2xlarge" in AWS. + InstanceTypeId types.String `tfsdk:"instance_type_id" tf:""` + // Whether the node type is deprecated. Non-deprecated node types offer + // greater performance. + IsDeprecated types.Bool `tfsdk:"is_deprecated" tf:"optional"` + // AWS specific, whether this instance supports encryption in transit, used + // for hipaa and pci workloads. + IsEncryptedInTransit types.Bool `tfsdk:"is_encrypted_in_transit" tf:"optional"` + + IsGraviton types.Bool `tfsdk:"is_graviton" tf:"optional"` + + IsHidden types.Bool `tfsdk:"is_hidden" tf:"optional"` + + IsIoCacheEnabled types.Bool `tfsdk:"is_io_cache_enabled" tf:"optional"` + // Memory (in MB) available for this node type. + MemoryMb types.Int64 `tfsdk:"memory_mb" tf:""` + + NodeInfo *CloudProviderNodeInfo `tfsdk:"node_info" tf:"optional"` + + NodeInstanceType *NodeInstanceType `tfsdk:"node_instance_type" tf:"optional"` + // Unique identifier for this node type. + NodeTypeId types.String `tfsdk:"node_type_id" tf:""` + // Number of CPU cores available for this node type. Note that this can be + // fractional, e.g., 2.5 cores, if the the number of cores on a machine + // instance is not divisible by the number of Spark nodes on that machine. + NumCores types.Float64 `tfsdk:"num_cores" tf:""` + + NumGpus types.Int64 `tfsdk:"num_gpus" tf:"optional"` + + PhotonDriverCapable types.Bool `tfsdk:"photon_driver_capable" tf:"optional"` + + PhotonWorkerCapable types.Bool `tfsdk:"photon_worker_capable" tf:"optional"` + + SupportClusterTags types.Bool `tfsdk:"support_cluster_tags" tf:"optional"` + + SupportEbsVolumes types.Bool `tfsdk:"support_ebs_volumes" tf:"optional"` + + SupportPortForwarding types.Bool `tfsdk:"support_port_forwarding" tf:"optional"` + // Indicates if this node type can be used for an instance pool or cluster + // with elastic disk enabled. This is true for most node types. + SupportsElasticDisk types.Bool `tfsdk:"supports_elastic_disk" tf:"optional"` +} + +type PendingInstanceError struct { + InstanceId types.String `tfsdk:"instance_id" tf:"optional"` + + Message types.String `tfsdk:"message" tf:"optional"` +} + +type PermanentDeleteCluster struct { + // The cluster to be deleted. + ClusterId types.String `tfsdk:"cluster_id" tf:""` +} + +type PermanentDeleteClusterResponse struct { +} + +type PinCluster struct { + // + ClusterId types.String `tfsdk:"cluster_id" tf:""` +} + +type PinClusterResponse struct { +} + +type Policy struct { + // Creation time. The timestamp (in millisecond) when this Cluster Policy + // was created. + CreatedAtTimestamp types.Int64 `tfsdk:"created_at_timestamp" tf:"optional"` + // Creator user name. The field won't be included in the response if the + // user has already been deleted. + CreatorUserName types.String `tfsdk:"creator_user_name" tf:"optional"` + // Policy definition document expressed in [Databricks Cluster Policy + // Definition Language]. + // + // [Databricks Cluster Policy Definition Language]: https://docs.databricks.com/administration-guide/clusters/policy-definition.html + Definition types.String `tfsdk:"definition" tf:"optional"` + // Additional human-readable description of the cluster policy. + Description types.String `tfsdk:"description" tf:"optional"` + // If true, policy is a default policy created and managed by Databricks. + // Default policies cannot be deleted, and their policy families cannot be + // changed. + IsDefault types.Bool `tfsdk:"is_default" tf:"optional"` + // A list of libraries to be installed on the next cluster restart that uses + // this policy. The maximum number of libraries is 500. + Libraries []Library `tfsdk:"libraries" tf:"optional"` + // Max number of clusters per user that can be active using this policy. If + // not present, there is no max limit. + MaxClustersPerUser types.Int64 `tfsdk:"max_clusters_per_user" tf:"optional"` + // Cluster Policy name requested by the user. This has to be unique. Length + // must be between 1 and 100 characters. + Name types.String `tfsdk:"name" tf:"optional"` + // Policy definition JSON document expressed in [Databricks Policy + // Definition Language]. The JSON document must be passed as a string and + // cannot be embedded in the requests. + // + // You can use this to customize the policy definition inherited from the + // policy family. Policy rules specified here are merged into the inherited + // policy definition. + // + // [Databricks Policy Definition Language]: https://docs.databricks.com/administration-guide/clusters/policy-definition.html + PolicyFamilyDefinitionOverrides types.String `tfsdk:"policy_family_definition_overrides" tf:"optional"` + // ID of the policy family. + PolicyFamilyId types.String `tfsdk:"policy_family_id" tf:"optional"` + // Canonical unique identifier for the Cluster Policy. + PolicyId types.String `tfsdk:"policy_id" tf:"optional"` +} + +type PolicyFamily struct { + // Policy definition document expressed in [Databricks Cluster Policy + // Definition Language]. + // + // [Databricks Cluster Policy Definition Language]: https://docs.databricks.com/administration-guide/clusters/policy-definition.html + Definition types.String `tfsdk:"definition" tf:""` + // Human-readable description of the purpose of the policy family. + Description types.String `tfsdk:"description" tf:""` + // Name of the policy family. + Name types.String `tfsdk:"name" tf:""` + // ID of the policy family. + PolicyFamilyId types.String `tfsdk:"policy_family_id" tf:""` +} + +type PythonPyPiLibrary struct { + // The name of the pypi package to install. An optional exact version + // specification is also supported. Examples: "simplejson" and + // "simplejson==3.8.0". + Package types.String `tfsdk:"package" tf:""` + // The repository where the package can be found. If not specified, the + // default pip index is used. + Repo types.String `tfsdk:"repo" tf:"optional"` +} + +type RCranLibrary struct { + // The name of the CRAN package to install. + Package types.String `tfsdk:"package" tf:""` + // The repository where the package can be found. If not specified, the + // default CRAN repo is used. + Repo types.String `tfsdk:"repo" tf:"optional"` +} + +type RemoveInstanceProfile struct { + // The ARN of the instance profile to remove. This field is required. + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:""` +} + +type RemoveResponse struct { +} + +type ResizeCluster struct { + // Parameters needed in order to automatically scale clusters up and down + // based on load. Note: autoscaling works best with DB runtime versions 3.0 + // or later. + Autoscale *AutoScale `tfsdk:"autoscale" tf:"optional"` + // The cluster to be resized. + ClusterId types.String `tfsdk:"cluster_id" tf:""` + // Number of worker nodes that this cluster should have. A cluster has one + // Spark Driver and `num_workers` Executors for a total of `num_workers` + 1 + // Spark nodes. + // + // Note: When reading the properties of a cluster, this field reflects the + // desired number of workers rather than the actual current number of + // workers. For instance, if a cluster is resized from 5 to 10 workers, this + // field will immediately be updated to reflect the target size of 10 + // workers, whereas the workers listed in `spark_info` will gradually + // increase from 5 to 10 as the new nodes are provisioned. + NumWorkers types.Int64 `tfsdk:"num_workers" tf:"optional"` +} + +type ResizeClusterResponse struct { +} + +type RestartCluster struct { + // The cluster to be started. + ClusterId types.String `tfsdk:"cluster_id" tf:""` + // + RestartUser types.String `tfsdk:"restart_user" tf:"optional"` +} + +type RestartClusterResponse struct { +} + +type Results struct { + // The cause of the error + Cause types.String `tfsdk:"cause" tf:"optional"` + + Data any `tfsdk:"data" tf:"optional"` + // The image filename + FileName types.String `tfsdk:"fileName" tf:"optional"` + + FileNames []types.String `tfsdk:"fileNames" tf:"optional"` + // true if a JSON schema is returned instead of a string representation of + // the Hive type. + IsJsonSchema types.Bool `tfsdk:"isJsonSchema" tf:"optional"` + // internal field used by SDK + Pos types.Int64 `tfsdk:"pos" tf:"optional"` + + ResultType types.String `tfsdk:"resultType" tf:"optional"` + // The table schema + Schema []map[string]any `tfsdk:"schema" tf:"optional"` + // The summary of the error + Summary types.String `tfsdk:"summary" tf:"optional"` + // true if partial results are returned. + Truncated types.Bool `tfsdk:"truncated" tf:"optional"` +} + +type S3StorageInfo struct { + // (Optional) Set canned access control list for the logs, e.g. + // `bucket-owner-full-control`. If `canned_cal` is set, please make sure the + // cluster iam role has `s3:PutObjectAcl` permission on the destination + // bucket and prefix. The full list of possible canned acl can be found at + // http://docs.aws.amazon.com/AmazonS3/latest/dev/acl-overview.html#canned-acl. + // Please also note that by default only the object owner gets full + // controls. If you are using cross account role for writing data, you may + // want to set `bucket-owner-full-control` to make bucket owner able to read + // the logs. + CannedAcl types.String `tfsdk:"canned_acl" tf:"optional"` + // S3 destination, e.g. `s3://my-bucket/some-prefix` Note that logs will be + // delivered using cluster iam role, please make sure you set cluster iam + // role and the role has write access to the destination. Please also note + // that you cannot use AWS keys to deliver logs. + Destination types.String `tfsdk:"destination" tf:""` + // (Optional) Flag to enable server side encryption, `false` by default. + EnableEncryption types.Bool `tfsdk:"enable_encryption" tf:"optional"` + // (Optional) The encryption type, it could be `sse-s3` or `sse-kms`. It + // will be used only when encryption is enabled and the default type is + // `sse-s3`. + EncryptionType types.String `tfsdk:"encryption_type" tf:"optional"` + // S3 endpoint, e.g. `https://s3-us-west-2.amazonaws.com`. Either region or + // endpoint needs to be set. If both are set, endpoint will be used. + Endpoint types.String `tfsdk:"endpoint" tf:"optional"` + // (Optional) Kms key which will be used if encryption is enabled and + // encryption type is set to `sse-kms`. + KmsKey types.String `tfsdk:"kms_key" tf:"optional"` + // S3 region, e.g. `us-west-2`. Either region or endpoint needs to be set. + // If both are set, endpoint will be used. + Region types.String `tfsdk:"region" tf:"optional"` +} + +type SparkNode struct { + // The private IP address of the host instance. + HostPrivateIp types.String `tfsdk:"host_private_ip" tf:"optional"` + // Globally unique identifier for the host instance from the cloud provider. + InstanceId types.String `tfsdk:"instance_id" tf:"optional"` + // Attributes specific to AWS for a Spark node. + NodeAwsAttributes *SparkNodeAwsAttributes `tfsdk:"node_aws_attributes" tf:"optional"` + // Globally unique identifier for this node. + NodeId types.String `tfsdk:"node_id" tf:"optional"` + // Private IP address (typically a 10.x.x.x address) of the Spark node. Note + // that this is different from the private IP address of the host instance. + PrivateIp types.String `tfsdk:"private_ip" tf:"optional"` + // Public DNS address of this node. This address can be used to access the + // Spark JDBC server on the driver node. To communicate with the JDBC + // server, traffic must be manually authorized by adding security group + // rules to the "worker-unmanaged" security group via the AWS console. + // + // Actually it's the public DNS address of the host instance. + PublicDns types.String `tfsdk:"public_dns" tf:"optional"` + // The timestamp (in millisecond) when the Spark node is launched. + // + // The start_timestamp is set right before the container is being launched. + // The timestamp when the container is placed on the ResourceManager, before + // its launch and setup by the NodeDaemon. This timestamp is the same as the + // creation timestamp in the database. + StartTimestamp types.Int64 `tfsdk:"start_timestamp" tf:"optional"` +} + +type SparkNodeAwsAttributes struct { + // Whether this node is on an Amazon spot instance. + IsSpot types.Bool `tfsdk:"is_spot" tf:"optional"` +} + +type SparkVersion struct { + // Spark version key, for example "2.1.x-scala2.11". This is the value which + // should be provided as the "spark_version" when creating a new cluster. + // Note that the exact Spark version may change over time for a "wildcard" + // version (i.e., "2.1.x-scala2.11" is a "wildcard" version) with minor bug + // fixes. + Key types.String `tfsdk:"key" tf:"optional"` + // A descriptive name for this Spark version, for example "Spark 2.1". + Name types.String `tfsdk:"name" tf:"optional"` +} + +type StartCluster struct { + // The cluster to be started. + ClusterId types.String `tfsdk:"cluster_id" tf:""` +} + +type StartClusterResponse struct { +} + +type TerminationReason struct { + // status code indicating why the cluster was terminated + Code types.String `tfsdk:"code" tf:"optional"` + // list of parameters that provide additional information about why the + // cluster was terminated + Parameters map[string]types.String `tfsdk:"parameters" tf:"optional"` + // type of the termination + Type types.String `tfsdk:"type" tf:"optional"` +} + +type UninstallLibraries struct { + // Unique identifier for the cluster on which to uninstall these libraries. + ClusterId types.String `tfsdk:"cluster_id" tf:""` + // The libraries to uninstall. + Libraries []Library `tfsdk:"libraries" tf:""` +} + +type UninstallLibrariesResponse struct { +} + +type UnpinCluster struct { + // + ClusterId types.String `tfsdk:"cluster_id" tf:""` +} + +type UnpinClusterResponse struct { +} + +type UpdateResponse struct { +} + +type VolumesStorageInfo struct { + // Unity Catalog Volumes file destination, e.g. `/Volumes/my-init.sh` + Destination types.String `tfsdk:"destination" tf:""` +} + +type WorkloadType struct { + // defined what type of clients can use the cluster. E.g. Notebooks, Jobs + Clients ClientsTypes `tfsdk:"clients" tf:""` +} + +type WorkspaceStorageInfo struct { + // workspace files destination, e.g. + // `/Users/user1@databricks.com/my-init.sh` + Destination types.String `tfsdk:"destination" tf:""` +} diff --git a/internal/service/dashboards_tf/model.go b/internal/service/dashboards_tf/model.go new file mode 100755 index 0000000000..921f62b925 --- /dev/null +++ b/internal/service/dashboards_tf/model.go @@ -0,0 +1,360 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package dashboards_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type CreateDashboardRequest struct { + // The display name of the dashboard. + DisplayName types.String `tfsdk:"display_name" tf:""` + // The workspace path of the folder containing the dashboard. Includes + // leading slash and no trailing slash. + ParentPath types.String `tfsdk:"parent_path" tf:"optional"` + // The contents of the dashboard in serialized string form. + SerializedDashboard types.String `tfsdk:"serialized_dashboard" tf:"optional"` + // The warehouse ID used to run the dashboard. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +type CreateScheduleRequest struct { + // The cron expression describing the frequency of the periodic refresh for + // this schedule. + CronSchedule CronSchedule `tfsdk:"cron_schedule" tf:""` + // UUID identifying the dashboard to which the schedule belongs. + DashboardId types.String `tfsdk:"-"` + // The display name for schedule. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // The status indicates whether this schedule is paused or not. + PauseStatus types.String `tfsdk:"pause_status" tf:"optional"` +} + +type CreateSubscriptionRequest struct { + // UUID identifying the dashboard to which the subscription belongs. + DashboardId types.String `tfsdk:"-"` + // UUID identifying the schedule to which the subscription belongs. + ScheduleId types.String `tfsdk:"-"` + // Subscriber details for users and destinations to be added as subscribers + // to the schedule. + Subscriber Subscriber `tfsdk:"subscriber" tf:""` +} + +type CronSchedule struct { + // A cron expression using quartz syntax. EX: `0 0 8 * * ?` represents + // everyday at 8am. See [Cron Trigger] for details. + // + // [Cron Trigger]: http://www.quartz-scheduler.org/documentation/quartz-2.3.0/tutorials/crontrigger.html + QuartzCronExpression types.String `tfsdk:"quartz_cron_expression" tf:""` + // A Java timezone id. The schedule will be resolved with respect to this + // timezone. See [Java TimeZone] for details. + // + // [Java TimeZone]: https://docs.oracle.com/javase/7/docs/api/java/util/TimeZone.html + TimezoneId types.String `tfsdk:"timezone_id" tf:""` +} + +type Dashboard struct { + // The timestamp of when the dashboard was created. + CreateTime types.String `tfsdk:"create_time" tf:"optional"` + // UUID identifying the dashboard. + DashboardId types.String `tfsdk:"dashboard_id" tf:"optional"` + // The display name of the dashboard. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // The etag for the dashboard. Can be optionally provided on updates to + // ensure that the dashboard has not been modified since the last read. + Etag types.String `tfsdk:"etag" tf:"optional"` + // The state of the dashboard resource. Used for tracking trashed status. + LifecycleState types.String `tfsdk:"lifecycle_state" tf:"optional"` + // The workspace path of the folder containing the dashboard. Includes + // leading slash and no trailing slash. + ParentPath types.String `tfsdk:"parent_path" tf:"optional"` + // The workspace path of the dashboard asset, including the file name. + Path types.String `tfsdk:"path" tf:"optional"` + // The contents of the dashboard in serialized string form. + SerializedDashboard types.String `tfsdk:"serialized_dashboard" tf:"optional"` + // The timestamp of when the dashboard was last updated by the user. + UpdateTime types.String `tfsdk:"update_time" tf:"optional"` + // The warehouse ID used to run the dashboard. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +// Delete dashboard schedule +type DeleteScheduleRequest struct { + // UUID identifying the dashboard to which the schedule belongs. + DashboardId types.String `tfsdk:"-"` + // The etag for the schedule. Optionally, it can be provided to verify that + // the schedule has not been modified from its last retrieval. + Etag types.String `tfsdk:"-"` + // UUID identifying the schedule. + ScheduleId types.String `tfsdk:"-"` +} + +type DeleteScheduleResponse struct { +} + +// Delete schedule subscription +type DeleteSubscriptionRequest struct { + // UUID identifying the dashboard which the subscription belongs. + DashboardId types.String `tfsdk:"-"` + // The etag for the subscription. Can be optionally provided to ensure that + // the subscription has not been modified since the last read. + Etag types.String `tfsdk:"-"` + // UUID identifying the schedule which the subscription belongs. + ScheduleId types.String `tfsdk:"-"` + // UUID identifying the subscription. + SubscriptionId types.String `tfsdk:"-"` +} + +type DeleteSubscriptionResponse struct { +} + +// Get dashboard +type GetDashboardRequest struct { + // UUID identifying the dashboard. + DashboardId types.String `tfsdk:"-"` +} + +// Get published dashboard +type GetPublishedDashboardRequest struct { + // UUID identifying the dashboard to be published. + DashboardId types.String `tfsdk:"-"` +} + +// Get dashboard schedule +type GetScheduleRequest struct { + // UUID identifying the dashboard to which the schedule belongs. + DashboardId types.String `tfsdk:"-"` + // UUID identifying the schedule. + ScheduleId types.String `tfsdk:"-"` +} + +// Get schedule subscription +type GetSubscriptionRequest struct { + // UUID identifying the dashboard which the subscription belongs. + DashboardId types.String `tfsdk:"-"` + // UUID identifying the schedule which the subscription belongs. + ScheduleId types.String `tfsdk:"-"` + // UUID identifying the subscription. + SubscriptionId types.String `tfsdk:"-"` +} + +// List dashboards +type ListDashboardsRequest struct { + // The number of dashboards to return per page. + PageSize types.Int64 `tfsdk:"-"` + // A page token, received from a previous `ListDashboards` call. This token + // can be used to retrieve the subsequent page. + PageToken types.String `tfsdk:"-"` + // The flag to include dashboards located in the trash. If unspecified, only + // active dashboards will be returned. + ShowTrashed types.Bool `tfsdk:"-"` + // Indicates whether to include all metadata from the dashboard in the + // response. If unset, the response defaults to `DASHBOARD_VIEW_BASIC` which + // only includes summary metadata from the dashboard. + View types.String `tfsdk:"-"` +} + +type ListDashboardsResponse struct { + Dashboards []Dashboard `tfsdk:"dashboards" tf:"optional"` + // A token, which can be sent as `page_token` to retrieve the next page. If + // this field is omitted, there are no subsequent dashboards. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List dashboard schedules +type ListSchedulesRequest struct { + // UUID identifying the dashboard to which the schedule belongs. + DashboardId types.String `tfsdk:"-"` + // The number of schedules to return per page. + PageSize types.Int64 `tfsdk:"-"` + // A page token, received from a previous `ListSchedules` call. Use this to + // retrieve the subsequent page. + PageToken types.String `tfsdk:"-"` +} + +type ListSchedulesResponse struct { + // A token that can be used as a `page_token` in subsequent requests to + // retrieve the next page of results. If this field is omitted, there are no + // subsequent schedules. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + Schedules []Schedule `tfsdk:"schedules" tf:"optional"` +} + +// List schedule subscriptions +type ListSubscriptionsRequest struct { + // UUID identifying the dashboard to which the subscription belongs. + DashboardId types.String `tfsdk:"-"` + // The number of subscriptions to return per page. + PageSize types.Int64 `tfsdk:"-"` + // A page token, received from a previous `ListSubscriptions` call. Use this + // to retrieve the subsequent page. + PageToken types.String `tfsdk:"-"` + // UUID identifying the schedule to which the subscription belongs. + ScheduleId types.String `tfsdk:"-"` +} + +type ListSubscriptionsResponse struct { + // A token that can be used as a `page_token` in subsequent requests to + // retrieve the next page of results. If this field is omitted, there are no + // subsequent subscriptions. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + Subscriptions []Subscription `tfsdk:"subscriptions" tf:"optional"` +} + +type MigrateDashboardRequest struct { + // Display name for the new Lakeview dashboard. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // The workspace path of the folder to contain the migrated Lakeview + // dashboard. + ParentPath types.String `tfsdk:"parent_path" tf:"optional"` + // UUID of the dashboard to be migrated. + SourceDashboardId types.String `tfsdk:"source_dashboard_id" tf:""` +} + +type PublishRequest struct { + // UUID identifying the dashboard to be published. + DashboardId types.String `tfsdk:"-"` + // Flag to indicate if the publisher's credentials should be embedded in the + // published dashboard. These embedded credentials will be used to execute + // the published dashboard's queries. + EmbedCredentials types.Bool `tfsdk:"embed_credentials" tf:"optional"` + // The ID of the warehouse that can be used to override the warehouse which + // was set in the draft. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +type PublishedDashboard struct { + // The display name of the published dashboard. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // Indicates whether credentials are embedded in the published dashboard. + EmbedCredentials types.Bool `tfsdk:"embed_credentials" tf:"optional"` + // The timestamp of when the published dashboard was last revised. + RevisionCreateTime types.String `tfsdk:"revision_create_time" tf:"optional"` + // The warehouse ID used to run the published dashboard. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +type Schedule struct { + // A timestamp indicating when the schedule was created. + CreateTime types.String `tfsdk:"create_time" tf:"optional"` + // The cron expression describing the frequency of the periodic refresh for + // this schedule. + CronSchedule CronSchedule `tfsdk:"cron_schedule" tf:""` + // UUID identifying the dashboard to which the schedule belongs. + DashboardId types.String `tfsdk:"dashboard_id" tf:"optional"` + // The display name for schedule. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // The etag for the schedule. Must be left empty on create, must be provided + // on updates to ensure that the schedule has not been modified since the + // last read, and can be optionally provided on delete. + Etag types.String `tfsdk:"etag" tf:"optional"` + // The status indicates whether this schedule is paused or not. + PauseStatus types.String `tfsdk:"pause_status" tf:"optional"` + // UUID identifying the schedule. + ScheduleId types.String `tfsdk:"schedule_id" tf:"optional"` + // A timestamp indicating when the schedule was last updated. + UpdateTime types.String `tfsdk:"update_time" tf:"optional"` +} + +type Subscriber struct { + // The destination to receive the subscription email. This parameter is + // mutually exclusive with `user_subscriber`. + DestinationSubscriber *SubscriptionSubscriberDestination `tfsdk:"destination_subscriber" tf:"optional"` + // The user to receive the subscription email. This parameter is mutually + // exclusive with `destination_subscriber`. + UserSubscriber *SubscriptionSubscriberUser `tfsdk:"user_subscriber" tf:"optional"` +} + +type Subscription struct { + // A timestamp indicating when the subscription was created. + CreateTime types.String `tfsdk:"create_time" tf:"optional"` + // UserId of the user who adds subscribers (users or notification + // destinations) to the dashboard's schedule. + CreatedByUserId types.Int64 `tfsdk:"created_by_user_id" tf:"optional"` + // UUID identifying the dashboard to which the subscription belongs. + DashboardId types.String `tfsdk:"dashboard_id" tf:"optional"` + // The etag for the subscription. Must be left empty on create, can be + // optionally provided on delete to ensure that the subscription has not + // been deleted since the last read. + Etag types.String `tfsdk:"etag" tf:"optional"` + // UUID identifying the schedule to which the subscription belongs. + ScheduleId types.String `tfsdk:"schedule_id" tf:"optional"` + // Subscriber details for users and destinations to be added as subscribers + // to the schedule. + Subscriber Subscriber `tfsdk:"subscriber" tf:""` + // UUID identifying the subscription. + SubscriptionId types.String `tfsdk:"subscription_id" tf:"optional"` + // A timestamp indicating when the subscription was last updated. + UpdateTime types.String `tfsdk:"update_time" tf:"optional"` +} + +type SubscriptionSubscriberDestination struct { + // The canonical identifier of the destination to receive email + // notification. + DestinationId types.String `tfsdk:"destination_id" tf:""` +} + +type SubscriptionSubscriberUser struct { + // UserId of the subscriber. + UserId types.Int64 `tfsdk:"user_id" tf:""` +} + +// Trash dashboard +type TrashDashboardRequest struct { + // UUID identifying the dashboard. + DashboardId types.String `tfsdk:"-"` +} + +type TrashDashboardResponse struct { +} + +// Unpublish dashboard +type UnpublishDashboardRequest struct { + // UUID identifying the dashboard to be published. + DashboardId types.String `tfsdk:"-"` +} + +type UnpublishDashboardResponse struct { +} + +type UpdateDashboardRequest struct { + // UUID identifying the dashboard. + DashboardId types.String `tfsdk:"-"` + // The display name of the dashboard. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // The etag for the dashboard. Can be optionally provided on updates to + // ensure that the dashboard has not been modified since the last read. + Etag types.String `tfsdk:"etag" tf:"optional"` + // The contents of the dashboard in serialized string form. + SerializedDashboard types.String `tfsdk:"serialized_dashboard" tf:"optional"` + // The warehouse ID used to run the dashboard. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +type UpdateScheduleRequest struct { + // The cron expression describing the frequency of the periodic refresh for + // this schedule. + CronSchedule CronSchedule `tfsdk:"cron_schedule" tf:""` + // UUID identifying the dashboard to which the schedule belongs. + DashboardId types.String `tfsdk:"-"` + // The display name for schedule. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // The etag for the schedule. Must be left empty on create, must be provided + // on updates to ensure that the schedule has not been modified since the + // last read, and can be optionally provided on delete. + Etag types.String `tfsdk:"etag" tf:"optional"` + // The status indicates whether this schedule is paused or not. + PauseStatus types.String `tfsdk:"pause_status" tf:"optional"` + // UUID identifying the schedule. + ScheduleId types.String `tfsdk:"-"` +} diff --git a/internal/service/files_tf/model.go b/internal/service/files_tf/model.go new file mode 100755 index 0000000000..e3e67e9961 --- /dev/null +++ b/internal/service/files_tf/model.go @@ -0,0 +1,266 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package files_tf + +import ( + "io" + + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type AddBlock struct { + // The base64-encoded data to append to the stream. This has a limit of 1 + // MB. + Data types.String `tfsdk:"data" tf:""` + // The handle on an open stream. + Handle types.Int64 `tfsdk:"handle" tf:""` +} + +type AddBlockResponse struct { +} + +type Close struct { + // The handle on an open stream. + Handle types.Int64 `tfsdk:"handle" tf:""` +} + +type CloseResponse struct { +} + +type Create struct { + // The flag that specifies whether to overwrite existing file/files. + Overwrite types.Bool `tfsdk:"overwrite" tf:"optional"` + // The path of the new file. The path should be the absolute DBFS path. + Path types.String `tfsdk:"path" tf:""` +} + +// Create a directory +type CreateDirectoryRequest struct { + // The absolute path of a directory. + DirectoryPath types.String `tfsdk:"-"` +} + +type CreateDirectoryResponse struct { +} + +type CreateResponse struct { + // Handle which should subsequently be passed into the AddBlock and Close + // calls when writing to a file through a stream. + Handle types.Int64 `tfsdk:"handle" tf:"optional"` +} + +type Delete struct { + // The path of the file or directory to delete. The path should be the + // absolute DBFS path. + Path types.String `tfsdk:"path" tf:""` + // Whether or not to recursively delete the directory's contents. Deleting + // empty directories can be done without providing the recursive flag. + Recursive types.Bool `tfsdk:"recursive" tf:"optional"` +} + +// Delete a directory +type DeleteDirectoryRequest struct { + // The absolute path of a directory. + DirectoryPath types.String `tfsdk:"-"` +} + +type DeleteDirectoryResponse struct { +} + +// Delete a file +type DeleteFileRequest struct { + // The absolute path of the file. + FilePath types.String `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +type DirectoryEntry struct { + // The length of the file in bytes. This field is omitted for directories. + FileSize types.Int64 `tfsdk:"file_size" tf:"optional"` + // True if the path is a directory. + IsDirectory types.Bool `tfsdk:"is_directory" tf:"optional"` + // Last modification time of given file in milliseconds since unix epoch. + LastModified types.Int64 `tfsdk:"last_modified" tf:"optional"` + // The name of the file or directory. This is the last component of the + // path. + Name types.String `tfsdk:"name" tf:"optional"` + // The absolute path of the file or directory. + Path types.String `tfsdk:"path" tf:"optional"` +} + +// Download a file +type DownloadRequest struct { + // The absolute path of the file. + FilePath types.String `tfsdk:"-"` +} + +type DownloadResponse struct { + ContentLength types.Int64 `tfsdk:"-"` + + ContentType types.String `tfsdk:"-"` + + Contents io.ReadCloser `tfsdk:"-"` + + LastModified types.String `tfsdk:"-"` +} + +type FileInfo struct { + // The length of the file in bytes. This field is omitted for directories. + FileSize types.Int64 `tfsdk:"file_size" tf:"optional"` + // True if the path is a directory. + IsDir types.Bool `tfsdk:"is_dir" tf:"optional"` + // Last modification time of given file in milliseconds since epoch. + ModificationTime types.Int64 `tfsdk:"modification_time" tf:"optional"` + // The absolute path of the file or directory. + Path types.String `tfsdk:"path" tf:"optional"` +} + +// Get directory metadata +type GetDirectoryMetadataRequest struct { + // The absolute path of a directory. + DirectoryPath types.String `tfsdk:"-"` +} + +type GetDirectoryMetadataResponse struct { +} + +// Get file metadata +type GetMetadataRequest struct { + // The absolute path of the file. + FilePath types.String `tfsdk:"-"` +} + +type GetMetadataResponse struct { + ContentLength types.Int64 `tfsdk:"-"` + + ContentType types.String `tfsdk:"-"` + + LastModified types.String `tfsdk:"-"` +} + +// Get the information of a file or directory +type GetStatusRequest struct { + // The path of the file or directory. The path should be the absolute DBFS + // path. + Path types.String `tfsdk:"-"` +} + +// List directory contents or file details +type ListDbfsRequest struct { + // The path of the file or directory. The path should be the absolute DBFS + // path. + Path types.String `tfsdk:"-"` +} + +// List directory contents +type ListDirectoryContentsRequest struct { + // The absolute path of a directory. + DirectoryPath types.String `tfsdk:"-"` + // The maximum number of directory entries to return. The response may + // contain fewer entries. If the response contains a `next_page_token`, + // there may be more entries, even if fewer than `page_size` entries are in + // the response. + // + // We recommend not to set this value unless you are intentionally listing + // less than the complete directory contents. + // + // If unspecified, at most 1000 directory entries will be returned. The + // maximum value is 1000. Values above 1000 will be coerced to 1000. + PageSize types.Int64 `tfsdk:"-"` + // An opaque page token which was the `next_page_token` in the response of + // the previous request to list the contents of this directory. Provide this + // token to retrieve the next page of directory entries. When providing a + // `page_token`, all other parameters provided to the request must match the + // previous request. To list all of the entries in a directory, it is + // necessary to continue requesting pages of entries until the response + // contains no `next_page_token`. Note that the number of entries returned + // must not be used to determine when the listing is complete. + PageToken types.String `tfsdk:"-"` +} + +type ListDirectoryResponse struct { + // Array of DirectoryEntry. + Contents []DirectoryEntry `tfsdk:"contents" tf:"optional"` + // A token, which can be sent as `page_token` to retrieve the next page. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +type ListStatusResponse struct { + // A list of FileInfo's that describe contents of directory or file. See + // example above. + Files []FileInfo `tfsdk:"files" tf:"optional"` +} + +type MkDirs struct { + // The path of the new directory. The path should be the absolute DBFS path. + Path types.String `tfsdk:"path" tf:""` +} + +type MkDirsResponse struct { +} + +type Move struct { + // The destination path of the file or directory. The path should be the + // absolute DBFS path. + DestinationPath types.String `tfsdk:"destination_path" tf:""` + // The source path of the file or directory. The path should be the absolute + // DBFS path. + SourcePath types.String `tfsdk:"source_path" tf:""` +} + +type MoveResponse struct { +} + +type Put struct { + // This parameter might be absent, and instead a posted file will be used. + Contents types.String `tfsdk:"contents" tf:"optional"` + // The flag that specifies whether to overwrite existing file/files. + Overwrite types.Bool `tfsdk:"overwrite" tf:"optional"` + // The path of the new file. The path should be the absolute DBFS path. + Path types.String `tfsdk:"path" tf:""` +} + +type PutResponse struct { +} + +// Get the contents of a file +type ReadDbfsRequest struct { + // The number of bytes to read starting from the offset. This has a limit of + // 1 MB, and a default value of 0.5 MB. + Length types.Int64 `tfsdk:"-"` + // The offset to read from in bytes. + Offset types.Int64 `tfsdk:"-"` + // The path of the file to read. The path should be the absolute DBFS path. + Path types.String `tfsdk:"-"` +} + +type ReadResponse struct { + // The number of bytes read (could be less than ``length`` if we hit end of + // file). This refers to number of bytes read in unencoded version (response + // data is base64-encoded). + BytesRead types.Int64 `tfsdk:"bytes_read" tf:"optional"` + // The base64-encoded contents of the file read. + Data types.String `tfsdk:"data" tf:"optional"` +} + +// Upload a file +type UploadRequest struct { + Contents io.ReadCloser `tfsdk:"-"` + // The absolute path of the file. + FilePath types.String `tfsdk:"-"` + // If true, an existing file will be overwritten. + Overwrite types.Bool `tfsdk:"-"` +} + +type UploadResponse struct { +} diff --git a/internal/service/iam_tf/model.go b/internal/service/iam_tf/model.go new file mode 100755 index 0000000000..f7f7240fd2 --- /dev/null +++ b/internal/service/iam_tf/model.go @@ -0,0 +1,744 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package iam_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type AccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type AccessControlResponse struct { + // All permissions. + AllPermissions []Permission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type ComplexValue struct { + Display types.String `tfsdk:"display" tf:"optional"` + + Primary types.Bool `tfsdk:"primary" tf:"optional"` + + Ref types.String `tfsdk:"$ref" tf:"optional"` + + Type types.String `tfsdk:"type" tf:"optional"` + + Value types.String `tfsdk:"value" tf:"optional"` +} + +// Delete a group +type DeleteAccountGroupRequest struct { + // Unique ID for a group in the Databricks account. + Id types.String `tfsdk:"-"` +} + +// Delete a service principal +type DeleteAccountServicePrincipalRequest struct { + // Unique ID for a service principal in the Databricks account. + Id types.String `tfsdk:"-"` +} + +// Delete a user +type DeleteAccountUserRequest struct { + // Unique ID for a user in the Databricks account. + Id types.String `tfsdk:"-"` +} + +// Delete a group +type DeleteGroupRequest struct { + // Unique ID for a group in the Databricks workspace. + Id types.String `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +// Delete a service principal +type DeleteServicePrincipalRequest struct { + // Unique ID for a service principal in the Databricks workspace. + Id types.String `tfsdk:"-"` +} + +// Delete a user +type DeleteUserRequest struct { + // Unique ID for a user in the Databricks workspace. + Id types.String `tfsdk:"-"` +} + +// Delete permissions assignment +type DeleteWorkspaceAssignmentRequest struct { + // The ID of the user, service principal, or group. + PrincipalId types.Int64 `tfsdk:"-"` + // The workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type DeleteWorkspaceAssignments struct { +} + +// Get group details +type GetAccountGroupRequest struct { + // Unique ID for a group in the Databricks account. + Id types.String `tfsdk:"-"` +} + +// Get service principal details +type GetAccountServicePrincipalRequest struct { + // Unique ID for a service principal in the Databricks account. + Id types.String `tfsdk:"-"` +} + +// Get user details +type GetAccountUserRequest struct { + // Comma-separated list of attributes to return in response. + Attributes types.String `tfsdk:"-"` + // Desired number of results per page. Default is 10000. + Count types.Int64 `tfsdk:"-"` + // Comma-separated list of attributes to exclude in response. + ExcludedAttributes types.String `tfsdk:"-"` + // Query by which the results have to be filtered. Supported operators are + // equals(`eq`), contains(`co`), starts with(`sw`) and not equals(`ne`). + // Additionally, simple expressions can be formed using logical operators - + // `and` and `or`. The [SCIM RFC] has more details but we currently only + // support simple expressions. + // + // [SCIM RFC]: https://tools.ietf.org/html/rfc7644#section-3.4.2.2 + Filter types.String `tfsdk:"-"` + // Unique ID for a user in the Databricks account. + Id types.String `tfsdk:"-"` + // Attribute to sort the results. Multi-part paths are supported. For + // example, `userName`, `name.givenName`, and `emails`. + SortBy types.String `tfsdk:"-"` + // The order to sort the results. + SortOrder types.String `tfsdk:"-"` + // Specifies the index of the first result. First item is number 1. + StartIndex types.Int64 `tfsdk:"-"` +} + +// Get assignable roles for a resource +type GetAssignableRolesForResourceRequest struct { + // The resource name for which assignable roles will be listed. + Resource types.String `tfsdk:"-"` +} + +type GetAssignableRolesForResourceResponse struct { + Roles []Role `tfsdk:"roles" tf:"optional"` +} + +// Get group details +type GetGroupRequest struct { + // Unique ID for a group in the Databricks workspace. + Id types.String `tfsdk:"-"` +} + +type GetPasswordPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []PasswordPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get object permission levels +type GetPermissionLevelsRequest struct { + // + RequestObjectId types.String `tfsdk:"-"` + // + RequestObjectType types.String `tfsdk:"-"` +} + +type GetPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []PermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get object permissions +type GetPermissionRequest struct { + // The id of the request object. + RequestObjectId types.String `tfsdk:"-"` + // The type of the request object. Can be one of the following: + // authorization, clusters, cluster-policies, directories, experiments, + // files, instance-pools, jobs, notebooks, pipelines, registered-models, + // repos, serving-endpoints, or warehouses. + RequestObjectType types.String `tfsdk:"-"` +} + +// Get a rule set +type GetRuleSetRequest struct { + // Etag used for versioning. The response is at least as fresh as the eTag + // provided. Etag is used for optimistic concurrency control as a way to + // help prevent simultaneous updates of a rule set from overwriting each + // other. It is strongly suggested that systems make use of the etag in the + // read -> modify -> write pattern to perform rule set updates in order to + // avoid race conditions that is get an etag from a GET rule set request, + // and pass it with the PUT update request to identify the rule set version + // you are updating. + Etag types.String `tfsdk:"-"` + // The ruleset name associated with the request. + Name types.String `tfsdk:"-"` +} + +// Get service principal details +type GetServicePrincipalRequest struct { + // Unique ID for a service principal in the Databricks workspace. + Id types.String `tfsdk:"-"` +} + +// Get user details +type GetUserRequest struct { + // Comma-separated list of attributes to return in response. + Attributes types.String `tfsdk:"-"` + // Desired number of results per page. + Count types.Int64 `tfsdk:"-"` + // Comma-separated list of attributes to exclude in response. + ExcludedAttributes types.String `tfsdk:"-"` + // Query by which the results have to be filtered. Supported operators are + // equals(`eq`), contains(`co`), starts with(`sw`) and not equals(`ne`). + // Additionally, simple expressions can be formed using logical operators - + // `and` and `or`. The [SCIM RFC] has more details but we currently only + // support simple expressions. + // + // [SCIM RFC]: https://tools.ietf.org/html/rfc7644#section-3.4.2.2 + Filter types.String `tfsdk:"-"` + // Unique ID for a user in the Databricks workspace. + Id types.String `tfsdk:"-"` + // Attribute to sort the results. Multi-part paths are supported. For + // example, `userName`, `name.givenName`, and `emails`. + SortBy types.String `tfsdk:"-"` + // The order to sort the results. + SortOrder types.String `tfsdk:"-"` + // Specifies the index of the first result. First item is number 1. + StartIndex types.Int64 `tfsdk:"-"` +} + +// List workspace permissions +type GetWorkspaceAssignmentRequest struct { + // The workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type GrantRule struct { + // Principals this grant rule applies to. + Principals []types.String `tfsdk:"principals" tf:"optional"` + // Role that is assigned to the list of principals. + Role types.String `tfsdk:"role" tf:""` +} + +type Group struct { + // String that represents a human-readable group name + DisplayName types.String `tfsdk:"displayName" tf:"optional"` + // Entitlements assigned to the group. See [assigning entitlements] for a + // full list of supported values. + // + // [assigning entitlements]: https://docs.databricks.com/administration-guide/users-groups/index.html#assigning-entitlements + Entitlements []ComplexValue `tfsdk:"entitlements" tf:"optional"` + + ExternalId types.String `tfsdk:"externalId" tf:"optional"` + + Groups []ComplexValue `tfsdk:"groups" tf:"optional"` + // Databricks group ID + Id types.String `tfsdk:"id" tf:"optional"` + + Members []ComplexValue `tfsdk:"members" tf:"optional"` + // Container for the group identifier. Workspace local versus account. + Meta *ResourceMeta `tfsdk:"meta" tf:"optional"` + // Corresponds to AWS instance profile/arn role. + Roles []ComplexValue `tfsdk:"roles" tf:"optional"` + // The schema of the group. + Schemas []types.String `tfsdk:"schemas" tf:"optional"` +} + +// List group details +type ListAccountGroupsRequest struct { + // Comma-separated list of attributes to return in response. + Attributes types.String `tfsdk:"-"` + // Desired number of results per page. Default is 10000. + Count types.Int64 `tfsdk:"-"` + // Comma-separated list of attributes to exclude in response. + ExcludedAttributes types.String `tfsdk:"-"` + // Query by which the results have to be filtered. Supported operators are + // equals(`eq`), contains(`co`), starts with(`sw`) and not equals(`ne`). + // Additionally, simple expressions can be formed using logical operators - + // `and` and `or`. The [SCIM RFC] has more details but we currently only + // support simple expressions. + // + // [SCIM RFC]: https://tools.ietf.org/html/rfc7644#section-3.4.2.2 + Filter types.String `tfsdk:"-"` + // Attribute to sort the results. + SortBy types.String `tfsdk:"-"` + // The order to sort the results. + SortOrder types.String `tfsdk:"-"` + // Specifies the index of the first result. First item is number 1. + StartIndex types.Int64 `tfsdk:"-"` +} + +// List service principals +type ListAccountServicePrincipalsRequest struct { + // Comma-separated list of attributes to return in response. + Attributes types.String `tfsdk:"-"` + // Desired number of results per page. Default is 10000. + Count types.Int64 `tfsdk:"-"` + // Comma-separated list of attributes to exclude in response. + ExcludedAttributes types.String `tfsdk:"-"` + // Query by which the results have to be filtered. Supported operators are + // equals(`eq`), contains(`co`), starts with(`sw`) and not equals(`ne`). + // Additionally, simple expressions can be formed using logical operators - + // `and` and `or`. The [SCIM RFC] has more details but we currently only + // support simple expressions. + // + // [SCIM RFC]: https://tools.ietf.org/html/rfc7644#section-3.4.2.2 + Filter types.String `tfsdk:"-"` + // Attribute to sort the results. + SortBy types.String `tfsdk:"-"` + // The order to sort the results. + SortOrder types.String `tfsdk:"-"` + // Specifies the index of the first result. First item is number 1. + StartIndex types.Int64 `tfsdk:"-"` +} + +// List users +type ListAccountUsersRequest struct { + // Comma-separated list of attributes to return in response. + Attributes types.String `tfsdk:"-"` + // Desired number of results per page. Default is 10000. + Count types.Int64 `tfsdk:"-"` + // Comma-separated list of attributes to exclude in response. + ExcludedAttributes types.String `tfsdk:"-"` + // Query by which the results have to be filtered. Supported operators are + // equals(`eq`), contains(`co`), starts with(`sw`) and not equals(`ne`). + // Additionally, simple expressions can be formed using logical operators - + // `and` and `or`. The [SCIM RFC] has more details but we currently only + // support simple expressions. + // + // [SCIM RFC]: https://tools.ietf.org/html/rfc7644#section-3.4.2.2 + Filter types.String `tfsdk:"-"` + // Attribute to sort the results. Multi-part paths are supported. For + // example, `userName`, `name.givenName`, and `emails`. + SortBy types.String `tfsdk:"-"` + // The order to sort the results. + SortOrder types.String `tfsdk:"-"` + // Specifies the index of the first result. First item is number 1. + StartIndex types.Int64 `tfsdk:"-"` +} + +// List group details +type ListGroupsRequest struct { + // Comma-separated list of attributes to return in response. + Attributes types.String `tfsdk:"-"` + // Desired number of results per page. + Count types.Int64 `tfsdk:"-"` + // Comma-separated list of attributes to exclude in response. + ExcludedAttributes types.String `tfsdk:"-"` + // Query by which the results have to be filtered. Supported operators are + // equals(`eq`), contains(`co`), starts with(`sw`) and not equals(`ne`). + // Additionally, simple expressions can be formed using logical operators - + // `and` and `or`. The [SCIM RFC] has more details but we currently only + // support simple expressions. + // + // [SCIM RFC]: https://tools.ietf.org/html/rfc7644#section-3.4.2.2 + Filter types.String `tfsdk:"-"` + // Attribute to sort the results. + SortBy types.String `tfsdk:"-"` + // The order to sort the results. + SortOrder types.String `tfsdk:"-"` + // Specifies the index of the first result. First item is number 1. + StartIndex types.Int64 `tfsdk:"-"` +} + +type ListGroupsResponse struct { + // Total results returned in the response. + ItemsPerPage types.Int64 `tfsdk:"itemsPerPage" tf:"optional"` + // User objects returned in the response. + Resources []Group `tfsdk:"Resources" tf:"optional"` + // The schema of the service principal. + Schemas []types.String `tfsdk:"schemas" tf:"optional"` + // Starting index of all the results that matched the request filters. First + // item is number 1. + StartIndex types.Int64 `tfsdk:"startIndex" tf:"optional"` + // Total results that match the request filters. + TotalResults types.Int64 `tfsdk:"totalResults" tf:"optional"` +} + +type ListServicePrincipalResponse struct { + // Total results returned in the response. + ItemsPerPage types.Int64 `tfsdk:"itemsPerPage" tf:"optional"` + // User objects returned in the response. + Resources []ServicePrincipal `tfsdk:"Resources" tf:"optional"` + // The schema of the List response. + Schemas []types.String `tfsdk:"schemas" tf:"optional"` + // Starting index of all the results that matched the request filters. First + // item is number 1. + StartIndex types.Int64 `tfsdk:"startIndex" tf:"optional"` + // Total results that match the request filters. + TotalResults types.Int64 `tfsdk:"totalResults" tf:"optional"` +} + +// List service principals +type ListServicePrincipalsRequest struct { + // Comma-separated list of attributes to return in response. + Attributes types.String `tfsdk:"-"` + // Desired number of results per page. + Count types.Int64 `tfsdk:"-"` + // Comma-separated list of attributes to exclude in response. + ExcludedAttributes types.String `tfsdk:"-"` + // Query by which the results have to be filtered. Supported operators are + // equals(`eq`), contains(`co`), starts with(`sw`) and not equals(`ne`). + // Additionally, simple expressions can be formed using logical operators - + // `and` and `or`. The [SCIM RFC] has more details but we currently only + // support simple expressions. + // + // [SCIM RFC]: https://tools.ietf.org/html/rfc7644#section-3.4.2.2 + Filter types.String `tfsdk:"-"` + // Attribute to sort the results. + SortBy types.String `tfsdk:"-"` + // The order to sort the results. + SortOrder types.String `tfsdk:"-"` + // Specifies the index of the first result. First item is number 1. + StartIndex types.Int64 `tfsdk:"-"` +} + +// List users +type ListUsersRequest struct { + // Comma-separated list of attributes to return in response. + Attributes types.String `tfsdk:"-"` + // Desired number of results per page. + Count types.Int64 `tfsdk:"-"` + // Comma-separated list of attributes to exclude in response. + ExcludedAttributes types.String `tfsdk:"-"` + // Query by which the results have to be filtered. Supported operators are + // equals(`eq`), contains(`co`), starts with(`sw`) and not equals(`ne`). + // Additionally, simple expressions can be formed using logical operators - + // `and` and `or`. The [SCIM RFC] has more details but we currently only + // support simple expressions. + // + // [SCIM RFC]: https://tools.ietf.org/html/rfc7644#section-3.4.2.2 + Filter types.String `tfsdk:"-"` + // Attribute to sort the results. Multi-part paths are supported. For + // example, `userName`, `name.givenName`, and `emails`. + SortBy types.String `tfsdk:"-"` + // The order to sort the results. + SortOrder types.String `tfsdk:"-"` + // Specifies the index of the first result. First item is number 1. + StartIndex types.Int64 `tfsdk:"-"` +} + +type ListUsersResponse struct { + // Total results returned in the response. + ItemsPerPage types.Int64 `tfsdk:"itemsPerPage" tf:"optional"` + // User objects returned in the response. + Resources []User `tfsdk:"Resources" tf:"optional"` + // The schema of the List response. + Schemas []types.String `tfsdk:"schemas" tf:"optional"` + // Starting index of all the results that matched the request filters. First + // item is number 1. + StartIndex types.Int64 `tfsdk:"startIndex" tf:"optional"` + // Total results that match the request filters. + TotalResults types.Int64 `tfsdk:"totalResults" tf:"optional"` +} + +// Get permission assignments +type ListWorkspaceAssignmentRequest struct { + // The workspace ID for the account. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type Name struct { + // Family name of the Databricks user. + FamilyName types.String `tfsdk:"familyName" tf:"optional"` + // Given name of the Databricks user. + GivenName types.String `tfsdk:"givenName" tf:"optional"` +} + +type ObjectPermissions struct { + AccessControlList []AccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type PartialUpdate struct { + // Unique ID for a user in the Databricks workspace. + Id types.String `tfsdk:"-"` + + Operations []Patch `tfsdk:"Operations" tf:"optional"` + // The schema of the patch request. Must be + // ["urn:ietf:params:scim:api:messages:2.0:PatchOp"]. + Schemas []types.String `tfsdk:"schemas" tf:"optional"` +} + +type PasswordAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type PasswordAccessControlResponse struct { + // All permissions. + AllPermissions []PasswordPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type PasswordPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type PasswordPermissions struct { + AccessControlList []PasswordAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type PasswordPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type PasswordPermissionsRequest struct { + AccessControlList []PasswordAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` +} + +type Patch struct { + // Type of patch operation. + Op types.String `tfsdk:"op" tf:"optional"` + // Selection of patch operation + Path types.String `tfsdk:"path" tf:"optional"` + // Value to modify + Value any `tfsdk:"value" tf:"optional"` +} + +type PatchResponse struct { +} + +type Permission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type PermissionAssignment struct { + // Error response associated with a workspace permission assignment, if any. + Error types.String `tfsdk:"error" tf:"optional"` + // The permissions level of the principal. + Permissions []types.String `tfsdk:"permissions" tf:"optional"` + // Information about the principal assigned to the workspace. + Principal *PrincipalOutput `tfsdk:"principal" tf:"optional"` +} + +type PermissionAssignments struct { + // Array of permissions assignments defined for a workspace. + PermissionAssignments []PermissionAssignment `tfsdk:"permission_assignments" tf:"optional"` +} + +type PermissionMigrationRequest struct { + // The name of the workspace group that permissions will be migrated from. + FromWorkspaceGroupName types.String `tfsdk:"from_workspace_group_name" tf:""` + // The maximum number of permissions that will be migrated. + Size types.Int64 `tfsdk:"size" tf:"optional"` + // The name of the account group that permissions will be migrated to. + ToAccountGroupName types.String `tfsdk:"to_account_group_name" tf:""` + // WorkspaceId of the associated workspace where the permission migration + // will occur. Both workspace group and account group must be in this + // workspace. + WorkspaceId types.Int64 `tfsdk:"workspace_id" tf:""` +} + +type PermissionMigrationResponse struct { + // Number of permissions migrated. + PermissionsMigrated types.Int64 `tfsdk:"permissions_migrated" tf:"optional"` +} + +type PermissionOutput struct { + // The results of a permissions query. + Description types.String `tfsdk:"description" tf:"optional"` + + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type PermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type PermissionsRequest struct { + AccessControlList []AccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The id of the request object. + RequestObjectId types.String `tfsdk:"-"` + // The type of the request object. Can be one of the following: + // authorization, clusters, cluster-policies, directories, experiments, + // files, instance-pools, jobs, notebooks, pipelines, registered-models, + // repos, serving-endpoints, or warehouses. + RequestObjectType types.String `tfsdk:"-"` +} + +type PrincipalOutput struct { + // The display name of the principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // The group name of the group. Present only if the principal is a group. + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // The unique, opaque id of the principal. + PrincipalId types.Int64 `tfsdk:"principal_id" tf:"optional"` + // The name of the service principal. Present only if the principal is a + // service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // The username of the user. Present only if the principal is a user. + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type ResourceMeta struct { + // Identifier for group type. Can be local workspace group + // (`WorkspaceGroup`) or account group (`Group`). + ResourceType types.String `tfsdk:"resourceType" tf:"optional"` +} + +type Role struct { + // Role to assign to a principal or a list of principals on a resource. + Name types.String `tfsdk:"name" tf:""` +} + +type RuleSetResponse struct { + // Identifies the version of the rule set returned. + Etag types.String `tfsdk:"etag" tf:"optional"` + + GrantRules []GrantRule `tfsdk:"grant_rules" tf:"optional"` + // Name of the rule set. + Name types.String `tfsdk:"name" tf:"optional"` +} + +type RuleSetUpdateRequest struct { + // The expected etag of the rule set to update. The update will fail if the + // value does not match the value that is stored in account access control + // service. + Etag types.String `tfsdk:"etag" tf:""` + + GrantRules []GrantRule `tfsdk:"grant_rules" tf:"optional"` + // Name of the rule set. + Name types.String `tfsdk:"name" tf:""` +} + +type ServicePrincipal struct { + // If this user is active + Active types.Bool `tfsdk:"active" tf:"optional"` + // UUID relating to the service principal + ApplicationId types.String `tfsdk:"applicationId" tf:"optional"` + // String that represents a concatenation of given and family names. + DisplayName types.String `tfsdk:"displayName" tf:"optional"` + // Entitlements assigned to the service principal. See [assigning + // entitlements] for a full list of supported values. + // + // [assigning entitlements]: https://docs.databricks.com/administration-guide/users-groups/index.html#assigning-entitlements + Entitlements []ComplexValue `tfsdk:"entitlements" tf:"optional"` + + ExternalId types.String `tfsdk:"externalId" tf:"optional"` + + Groups []ComplexValue `tfsdk:"groups" tf:"optional"` + // Databricks service principal ID. + Id types.String `tfsdk:"id" tf:"optional"` + // Corresponds to AWS instance profile/arn role. + Roles []ComplexValue `tfsdk:"roles" tf:"optional"` + // The schema of the List response. + Schemas []types.String `tfsdk:"schemas" tf:"optional"` +} + +type UpdateResponse struct { +} + +type UpdateRuleSetRequest struct { + // Name of the rule set. + Name types.String `tfsdk:"name" tf:""` + + RuleSet RuleSetUpdateRequest `tfsdk:"rule_set" tf:""` +} + +type UpdateWorkspaceAssignments struct { + // Array of permissions assignments to update on the workspace. Note that + // excluding this field will have the same effect as providing an empty list + // which will result in the deletion of all permissions for the principal. + Permissions []types.String `tfsdk:"permissions" tf:""` + // The ID of the user, service principal, or group. + PrincipalId types.Int64 `tfsdk:"-"` + // The workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type User struct { + // If this user is active + Active types.Bool `tfsdk:"active" tf:"optional"` + // String that represents a concatenation of given and family names. For + // example `John Smith`. This field cannot be updated through the Workspace + // SCIM APIs when [identity federation is enabled]. Use Account SCIM APIs to + // update `displayName`. + // + // [identity federation is enabled]: https://docs.databricks.com/administration-guide/users-groups/best-practices.html#enable-identity-federation + DisplayName types.String `tfsdk:"displayName" tf:"optional"` + // All the emails associated with the Databricks user. + Emails []ComplexValue `tfsdk:"emails" tf:"optional"` + // Entitlements assigned to the user. See [assigning entitlements] for a + // full list of supported values. + // + // [assigning entitlements]: https://docs.databricks.com/administration-guide/users-groups/index.html#assigning-entitlements + Entitlements []ComplexValue `tfsdk:"entitlements" tf:"optional"` + // External ID is not currently supported. It is reserved for future use. + ExternalId types.String `tfsdk:"externalId" tf:"optional"` + + Groups []ComplexValue `tfsdk:"groups" tf:"optional"` + // Databricks user ID. This is automatically set by Databricks. Any value + // provided by the client will be ignored. + Id types.String `tfsdk:"id" tf:"optional"` + + Name *Name `tfsdk:"name" tf:"optional"` + // Corresponds to AWS instance profile/arn role. + Roles []ComplexValue `tfsdk:"roles" tf:"optional"` + // The schema of the user. + Schemas []types.String `tfsdk:"schemas" tf:"optional"` + // Email address of the Databricks user. + UserName types.String `tfsdk:"userName" tf:"optional"` +} + +type WorkspacePermissions struct { + // Array of permissions defined for a workspace. + Permissions []PermissionOutput `tfsdk:"permissions" tf:"optional"` +} diff --git a/internal/service/jobs_tf/model.go b/internal/service/jobs_tf/model.go new file mode 100755 index 0000000000..a96735e036 --- /dev/null +++ b/internal/service/jobs_tf/model.go @@ -0,0 +1,2581 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package jobs_tf + +import ( + "github.com/databricks/databricks-sdk-go/service/compute" + "github.com/databricks/databricks-sdk-go/service/iam" + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type BaseJob struct { + // The time at which this job was created in epoch milliseconds + // (milliseconds since 1/1/1970 UTC). + CreatedTime types.Int64 `tfsdk:"created_time" tf:"optional"` + // The creator user name. This field won’t be included in the response if + // the user has already been deleted. + CreatorUserName types.String `tfsdk:"creator_user_name" tf:"optional"` + // The canonical identifier for this job. + JobId types.Int64 `tfsdk:"job_id" tf:"optional"` + // Settings for this job and all of its runs. These settings can be updated + // using the `resetJob` method. + Settings *JobSettings `tfsdk:"settings" tf:"optional"` +} + +type BaseRun struct { + // The sequence number of this run attempt for a triggered job run. The + // initial attempt of a run has an attempt_number of 0\. If the initial run + // attempt fails, and the job has a retry policy (`max_retries` \> 0), + // subsequent runs are created with an `original_attempt_run_id` of the + // original attempt’s ID and an incrementing `attempt_number`. Runs are + // retried only until they succeed, and the maximum `attempt_number` is the + // same as the `max_retries` value for the job. + AttemptNumber types.Int64 `tfsdk:"attempt_number" tf:"optional"` + // The time in milliseconds it took to terminate the cluster and clean up + // any associated artifacts. The duration of a task run is the sum of the + // `setup_duration`, `execution_duration`, and the `cleanup_duration`. The + // `cleanup_duration` field is set to 0 for multitask job runs. The total + // duration of a multitask job run is the value of the `run_duration` field. + CleanupDuration types.Int64 `tfsdk:"cleanup_duration" tf:"optional"` + // The cluster used for this run. If the run is specified to use a new + // cluster, this field is set once the Jobs service has requested a cluster + // for the run. + ClusterInstance *ClusterInstance `tfsdk:"cluster_instance" tf:"optional"` + // A snapshot of the job’s cluster specification when this run was + // created. + ClusterSpec *ClusterSpec `tfsdk:"cluster_spec" tf:"optional"` + // The creator user name. This field won’t be included in the response if + // the user has already been deleted. + CreatorUserName types.String `tfsdk:"creator_user_name" tf:"optional"` + // Description of the run + Description types.String `tfsdk:"description" tf:"optional"` + // The time at which this run ended in epoch milliseconds (milliseconds + // since 1/1/1970 UTC). This field is set to 0 if the job is still running. + EndTime types.Int64 `tfsdk:"end_time" tf:"optional"` + // The time in milliseconds it took to execute the commands in the JAR or + // notebook until they completed, failed, timed out, were cancelled, or + // encountered an unexpected error. The duration of a task run is the sum of + // the `setup_duration`, `execution_duration`, and the `cleanup_duration`. + // The `execution_duration` field is set to 0 for multitask job runs. The + // total duration of a multitask job run is the value of the `run_duration` + // field. + ExecutionDuration types.Int64 `tfsdk:"execution_duration" tf:"optional"` + // An optional specification for a remote Git repository containing the + // source code used by tasks. Version-controlled source code is supported by + // notebook, dbt, Python script, and SQL File tasks. + // + // If `git_source` is set, these tasks retrieve the file from the remote + // repository by default. However, this behavior can be overridden by + // setting `source` to `WORKSPACE` on the task. + // + // Note: dbt and SQL File tasks support only version-controlled sources. If + // dbt or SQL File tasks are used, `git_source` must be defined on the job. + GitSource *GitSource `tfsdk:"git_source" tf:"optional"` + // A list of job cluster specifications that can be shared and reused by + // tasks of this job. Libraries cannot be declared in a shared job cluster. + // You must declare dependent libraries in task settings. + JobClusters []JobCluster `tfsdk:"job_clusters" tf:"optional"` + // The canonical identifier of the job that contains this run. + JobId types.Int64 `tfsdk:"job_id" tf:"optional"` + // Job-level parameters used in the run + JobParameters []JobParameter `tfsdk:"job_parameters" tf:"optional"` + // A unique identifier for this job run. This is set to the same value as + // `run_id`. + NumberInJob types.Int64 `tfsdk:"number_in_job" tf:"optional"` + // If this run is a retry of a prior run attempt, this field contains the + // run_id of the original attempt; otherwise, it is the same as the run_id. + OriginalAttemptRunId types.Int64 `tfsdk:"original_attempt_run_id" tf:"optional"` + // The parameters used for this run. + OverridingParameters *RunParameters `tfsdk:"overriding_parameters" tf:"optional"` + // The time in milliseconds that the run has spent in the queue. + QueueDuration types.Int64 `tfsdk:"queue_duration" tf:"optional"` + // The repair history of the run. + RepairHistory []RepairHistoryItem `tfsdk:"repair_history" tf:"optional"` + // The time in milliseconds it took the job run and all of its repairs to + // finish. + RunDuration types.Int64 `tfsdk:"run_duration" tf:"optional"` + // The canonical identifier of the run. This ID is unique across all runs of + // all jobs. + RunId types.Int64 `tfsdk:"run_id" tf:"optional"` + // An optional name for the run. The maximum length is 4096 bytes in UTF-8 + // encoding. + RunName types.String `tfsdk:"run_name" tf:"optional"` + // The URL to the detail page of the run. + RunPageUrl types.String `tfsdk:"run_page_url" tf:"optional"` + // The type of a run. * `JOB_RUN`: Normal job run. A run created with + // :method:jobs/runNow. * `WORKFLOW_RUN`: Workflow run. A run created with + // [dbutils.notebook.run]. * `SUBMIT_RUN`: Submit run. A run created with + // :method:jobs/submit. + // + // [dbutils.notebook.run]: https://docs.databricks.com/dev-tools/databricks-utils.html#dbutils-workflow + RunType types.String `tfsdk:"run_type" tf:"optional"` + // The cron schedule that triggered this run if it was triggered by the + // periodic scheduler. + Schedule *CronSchedule `tfsdk:"schedule" tf:"optional"` + // The time in milliseconds it took to set up the cluster. For runs that run + // on new clusters this is the cluster creation time, for runs that run on + // existing clusters this time should be very short. The duration of a task + // run is the sum of the `setup_duration`, `execution_duration`, and the + // `cleanup_duration`. The `setup_duration` field is set to 0 for multitask + // job runs. The total duration of a multitask job run is the value of the + // `run_duration` field. + SetupDuration types.Int64 `tfsdk:"setup_duration" tf:"optional"` + // The time at which this run was started in epoch milliseconds + // (milliseconds since 1/1/1970 UTC). This may not be the time when the job + // task starts executing, for example, if the job is scheduled to run on a + // new cluster, this is the time the cluster creation call is issued. + StartTime types.Int64 `tfsdk:"start_time" tf:"optional"` + // The current state of the run. + State *RunState `tfsdk:"state" tf:"optional"` + // The list of tasks performed by the run. Each task has its own `run_id` + // which you can use to call `JobsGetOutput` to retrieve the run resutls. + Tasks []RunTask `tfsdk:"tasks" tf:"optional"` + // The type of trigger that fired this run. + // + // * `PERIODIC`: Schedules that periodically trigger runs, such as a cron + // scheduler. * `ONE_TIME`: One time triggers that fire a single run. This + // occurs you triggered a single run on demand through the UI or the API. * + // `RETRY`: Indicates a run that is triggered as a retry of a previously + // failed run. This occurs when you request to re-run the job in case of + // failures. * `RUN_JOB_TASK`: Indicates a run that is triggered using a Run + // Job task. * `FILE_ARRIVAL`: Indicates a run that is triggered by a file + // arrival. * `TABLE`: Indicates a run that is triggered by a table update. + Trigger types.String `tfsdk:"trigger" tf:"optional"` + // Additional details about what triggered the run + TriggerInfo *TriggerInfo `tfsdk:"trigger_info" tf:"optional"` +} + +type CancelAllRuns struct { + // Optional boolean parameter to cancel all queued runs. If no job_id is + // provided, all queued runs in the workspace are canceled. + AllQueuedRuns types.Bool `tfsdk:"all_queued_runs" tf:"optional"` + // The canonical identifier of the job to cancel all runs of. + JobId types.Int64 `tfsdk:"job_id" tf:"optional"` +} + +type CancelAllRunsResponse struct { +} + +type CancelRun struct { + // This field is required. + RunId types.Int64 `tfsdk:"run_id" tf:""` +} + +type CancelRunResponse struct { +} + +type ClusterInstance struct { + // The canonical identifier for the cluster used by a run. This field is + // always available for runs on existing clusters. For runs on new clusters, + // it becomes available once the cluster is created. This value can be used + // to view logs by browsing to `/#setting/sparkui/$cluster_id/driver-logs`. + // The logs continue to be available after the run completes. + // + // The response won’t include this field if the identifier is not + // available yet. + ClusterId types.String `tfsdk:"cluster_id" tf:"optional"` + // The canonical identifier for the Spark context used by a run. This field + // is filled in once the run begins execution. This value can be used to + // view the Spark UI by browsing to + // `/#setting/sparkui/$cluster_id/$spark_context_id`. The Spark UI continues + // to be available after the run has completed. + // + // The response won’t include this field if the identifier is not + // available yet. + SparkContextId types.String `tfsdk:"spark_context_id" tf:"optional"` +} + +type ClusterSpec struct { + // If existing_cluster_id, the ID of an existing cluster that is used for + // all runs. When running jobs or tasks on an existing cluster, you may need + // to manually restart the cluster if it stops responding. We suggest + // running jobs and tasks on new clusters for greater reliability + ExistingClusterId types.String `tfsdk:"existing_cluster_id" tf:"optional"` + // If job_cluster_key, this task is executed reusing the cluster specified + // in `job.settings.job_clusters`. + JobClusterKey types.String `tfsdk:"job_cluster_key" tf:"optional"` + // An optional list of libraries to be installed on the cluster. The default + // value is an empty list. + Libraries []compute.Library `tfsdk:"libraries" tf:"optional"` + // If new_cluster, a description of a new cluster that is created for each + // run. + NewCluster *compute.ClusterSpec `tfsdk:"new_cluster" tf:"optional"` +} + +type ConditionTask struct { + // The left operand of the condition task. Can be either a string value or a + // job state or parameter reference. + Left types.String `tfsdk:"left" tf:""` + // * `EQUAL_TO`, `NOT_EQUAL` operators perform string comparison of their + // operands. This means that `“12.0” == “12”` will evaluate to + // `false`. * `GREATER_THAN`, `GREATER_THAN_OR_EQUAL`, `LESS_THAN`, + // `LESS_THAN_OR_EQUAL` operators perform numeric comparison of their + // operands. `“12.0” >= “12”` will evaluate to `true`, `“10.0” + // >= “12”` will evaluate to `false`. + // + // The boolean comparison to task values can be implemented with operators + // `EQUAL_TO`, `NOT_EQUAL`. If a task value was set to a boolean value, it + // will be serialized to `“true”` or `“false”` for the comparison. + Op types.String `tfsdk:"op" tf:""` + // The right operand of the condition task. Can be either a string value or + // a job state or parameter reference. + Right types.String `tfsdk:"right" tf:""` +} + +type Continuous struct { + // Indicate whether the continuous execution of the job is paused or not. + // Defaults to UNPAUSED. + PauseStatus types.String `tfsdk:"pause_status" tf:"optional"` +} + +type CreateJob struct { + // List of permissions to set on the job. + AccessControlList []iam.AccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // An optional continuous property for this job. The continuous property + // will ensure that there is always one run executing. Only one of + // `schedule` and `continuous` can be used. + Continuous *Continuous `tfsdk:"continuous" tf:"optional"` + // Deployment information for jobs managed by external sources. + Deployment *JobDeployment `tfsdk:"deployment" tf:"optional"` + // An optional description for the job. The maximum length is 1024 + // characters in UTF-8 encoding. + Description types.String `tfsdk:"description" tf:"optional"` + // Edit mode of the job. + // + // * `UI_LOCKED`: The job is in a locked UI state and cannot be modified. * + // `EDITABLE`: The job is in an editable state and can be modified. + EditMode types.String `tfsdk:"edit_mode" tf:"optional"` + // An optional set of email addresses that is notified when runs of this job + // begin or complete as well as when this job is deleted. + EmailNotifications *JobEmailNotifications `tfsdk:"email_notifications" tf:"optional"` + // A list of task execution environment specifications that can be + // referenced by tasks of this job. + Environments []JobEnvironment `tfsdk:"environments" tf:"optional"` + // Used to tell what is the format of the job. This field is ignored in + // Create/Update/Reset calls. When using the Jobs API 2.1 this value is + // always set to `"MULTI_TASK"`. + Format types.String `tfsdk:"format" tf:"optional"` + // An optional specification for a remote Git repository containing the + // source code used by tasks. Version-controlled source code is supported by + // notebook, dbt, Python script, and SQL File tasks. + // + // If `git_source` is set, these tasks retrieve the file from the remote + // repository by default. However, this behavior can be overridden by + // setting `source` to `WORKSPACE` on the task. + // + // Note: dbt and SQL File tasks support only version-controlled sources. If + // dbt or SQL File tasks are used, `git_source` must be defined on the job. + GitSource *GitSource `tfsdk:"git_source" tf:"optional"` + // An optional set of health rules that can be defined for this job. + Health *JobsHealthRules `tfsdk:"health" tf:"optional"` + // A list of job cluster specifications that can be shared and reused by + // tasks of this job. Libraries cannot be declared in a shared job cluster. + // You must declare dependent libraries in task settings. + JobClusters []JobCluster `tfsdk:"job_clusters" tf:"optional"` + // An optional maximum allowed number of concurrent runs of the job. Set + // this value if you want to be able to execute multiple runs of the same + // job concurrently. This is useful for example if you trigger your job on a + // frequent schedule and want to allow consecutive runs to overlap with each + // other, or if you want to trigger multiple runs which differ by their + // input parameters. This setting affects only new runs. For example, + // suppose the job’s concurrency is 4 and there are 4 concurrent active + // runs. Then setting the concurrency to 3 won’t kill any of the active + // runs. However, from then on, new runs are skipped unless there are fewer + // than 3 active runs. This value cannot exceed 1000. Setting this value to + // `0` causes all new runs to be skipped. + MaxConcurrentRuns types.Int64 `tfsdk:"max_concurrent_runs" tf:"optional"` + // An optional name for the job. The maximum length is 4096 bytes in UTF-8 + // encoding. + Name types.String `tfsdk:"name" tf:"optional"` + // Optional notification settings that are used when sending notifications + // to each of the `email_notifications` and `webhook_notifications` for this + // job. + NotificationSettings *JobNotificationSettings `tfsdk:"notification_settings" tf:"optional"` + // Job-level parameter definitions + Parameters []JobParameterDefinition `tfsdk:"parameters" tf:"optional"` + // The queue settings of the job. + Queue *QueueSettings `tfsdk:"queue" tf:"optional"` + // Write-only setting, available only in Create/Update/Reset and Submit + // calls. Specifies the user or service principal that the job runs as. If + // not specified, the job runs as the user who created the job. + // + // Only `user_name` or `service_principal_name` can be specified. If both + // are specified, an error is thrown. + RunAs *JobRunAs `tfsdk:"run_as" tf:"optional"` + // An optional periodic schedule for this job. The default behavior is that + // the job only runs when triggered by clicking “Run Now” in the Jobs UI + // or sending an API request to `runNow`. + Schedule *CronSchedule `tfsdk:"schedule" tf:"optional"` + // A map of tags associated with the job. These are forwarded to the cluster + // as cluster tags for jobs clusters, and are subject to the same + // limitations as cluster tags. A maximum of 25 tags can be added to the + // job. + Tags map[string]types.String `tfsdk:"tags" tf:"optional"` + // A list of task specifications to be executed by this job. + Tasks []Task `tfsdk:"tasks" tf:"optional"` + // An optional timeout applied to each run of this job. A value of `0` means + // no timeout. + TimeoutSeconds types.Int64 `tfsdk:"timeout_seconds" tf:"optional"` + // A configuration to trigger a run when certain conditions are met. The + // default behavior is that the job runs only when triggered by clicking + // “Run Now” in the Jobs UI or sending an API request to `runNow`. + Trigger *TriggerSettings `tfsdk:"trigger" tf:"optional"` + // A collection of system notification IDs to notify when runs of this job + // begin or complete. + WebhookNotifications *WebhookNotifications `tfsdk:"webhook_notifications" tf:"optional"` +} + +// Job was created successfully +type CreateResponse struct { + // The canonical identifier for the newly created job. + JobId types.Int64 `tfsdk:"job_id" tf:"optional"` +} + +type CronSchedule struct { + // Indicate whether this schedule is paused or not. + PauseStatus types.String `tfsdk:"pause_status" tf:"optional"` + // A Cron expression using Quartz syntax that describes the schedule for a + // job. See [Cron Trigger] for details. This field is required. + // + // [Cron Trigger]: http://www.quartz-scheduler.org/documentation/quartz-2.3.0/tutorials/crontrigger.html + QuartzCronExpression types.String `tfsdk:"quartz_cron_expression" tf:""` + // A Java timezone ID. The schedule for a job is resolved with respect to + // this timezone. See [Java TimeZone] for details. This field is required. + // + // [Java TimeZone]: https://docs.oracle.com/javase/7/docs/api/java/util/TimeZone.html + TimezoneId types.String `tfsdk:"timezone_id" tf:""` +} + +type DbtOutput struct { + // An optional map of headers to send when retrieving the artifact from the + // `artifacts_link`. + ArtifactsHeaders map[string]types.String `tfsdk:"artifacts_headers" tf:"optional"` + // A pre-signed URL to download the (compressed) dbt artifacts. This link is + // valid for a limited time (30 minutes). This information is only available + // after the run has finished. + ArtifactsLink types.String `tfsdk:"artifacts_link" tf:"optional"` +} + +type DbtTask struct { + // Optional name of the catalog to use. The value is the top level in the + // 3-level namespace of Unity Catalog (catalog / schema / relation). The + // catalog value can only be specified if a warehouse_id is specified. + // Requires dbt-databricks >= 1.1.1. + Catalog types.String `tfsdk:"catalog" tf:"optional"` + // A list of dbt commands to execute. All commands must start with `dbt`. + // This parameter must not be empty. A maximum of up to 10 commands can be + // provided. + Commands []types.String `tfsdk:"commands" tf:""` + // Optional (relative) path to the profiles directory. Can only be specified + // if no warehouse_id is specified. If no warehouse_id is specified and this + // folder is unset, the root directory is used. + ProfilesDirectory types.String `tfsdk:"profiles_directory" tf:"optional"` + // Path to the project directory. Optional for Git sourced tasks, in which + // case if no value is provided, the root of the Git repository is used. + ProjectDirectory types.String `tfsdk:"project_directory" tf:"optional"` + // Optional schema to write to. This parameter is only used when a + // warehouse_id is also provided. If not provided, the `default` schema is + // used. + Schema types.String `tfsdk:"schema" tf:"optional"` + // Optional location type of the project directory. When set to `WORKSPACE`, + // the project will be retrieved from the local Databricks workspace. When + // set to `GIT`, the project will be retrieved from a Git repository defined + // in `git_source`. If the value is empty, the task will use `GIT` if + // `git_source` is defined and `WORKSPACE` otherwise. + // + // * `WORKSPACE`: Project is located in Databricks workspace. * `GIT`: + // Project is located in cloud Git provider. + Source types.String `tfsdk:"source" tf:"optional"` + // ID of the SQL warehouse to connect to. If provided, we automatically + // generate and provide the profile and connection details to dbt. It can be + // overridden on a per-command basis by using the `--profiles-dir` command + // line argument. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +type DeleteJob struct { + // The canonical identifier of the job to delete. This field is required. + JobId types.Int64 `tfsdk:"job_id" tf:""` +} + +type DeleteResponse struct { +} + +type DeleteRun struct { + // ID of the run to delete. + RunId types.Int64 `tfsdk:"run_id" tf:""` +} + +type DeleteRunResponse struct { +} + +// Run was exported successfully. +type ExportRunOutput struct { + // The exported content in HTML format (one for every view item). To extract + // the HTML notebook from the JSON response, download and run this [Python + // script]. + // + // [Python script]: https://docs.databricks.com/en/_static/examples/extract.py + Views []ViewItem `tfsdk:"views" tf:"optional"` +} + +// Export and retrieve a job run +type ExportRunRequest struct { + // The canonical identifier for the run. This field is required. + RunId types.Int64 `tfsdk:"-"` + // Which views to export (CODE, DASHBOARDS, or ALL). Defaults to CODE. + ViewsToExport types.String `tfsdk:"-"` +} + +type FileArrivalTriggerConfiguration struct { + // If set, the trigger starts a run only after the specified amount of time + // passed since the last time the trigger fired. The minimum allowed value + // is 60 seconds + MinTimeBetweenTriggersSeconds types.Int64 `tfsdk:"min_time_between_triggers_seconds" tf:"optional"` + // URL to be monitored for file arrivals. The path must point to the root or + // a subpath of the external location. + Url types.String `tfsdk:"url" tf:""` + // If set, the trigger starts a run only after no file activity has occurred + // for the specified amount of time. This makes it possible to wait for a + // batch of incoming files to arrive before triggering a run. The minimum + // allowed value is 60 seconds. + WaitAfterLastChangeSeconds types.Int64 `tfsdk:"wait_after_last_change_seconds" tf:"optional"` +} + +type ForEachStats struct { + // Sample of 3 most common error messages occurred during the iteration. + ErrorMessageStats []ForEachTaskErrorMessageStats `tfsdk:"error_message_stats" tf:"optional"` + // Describes stats of the iteration. Only latest retries are considered. + TaskRunStats *ForEachTaskTaskRunStats `tfsdk:"task_run_stats" tf:"optional"` +} + +type ForEachTask struct { + // Controls the number of active iterations task runs. Default is 20, + // maximum allowed is 100. + Concurrency types.Int64 `tfsdk:"concurrency" tf:"optional"` + // Array for task to iterate on. This can be a JSON string or a reference to + // an array parameter. + Inputs types.String `tfsdk:"inputs" tf:""` + // Configuration for the task that will be run for each element in the array + Task Task `tfsdk:"task" tf:""` +} + +type ForEachTaskErrorMessageStats struct { + // Describes the count of such error message encountered during the + // iterations. + Count types.Int64 `tfsdk:"count" tf:"optional"` + // Describes the error message occured during the iterations. + ErrorMessage types.String `tfsdk:"error_message" tf:"optional"` + // Describes the termination reason for the error message. + TerminationCategory types.String `tfsdk:"termination_category" tf:"optional"` +} + +type ForEachTaskTaskRunStats struct { + // Describes the iteration runs having an active lifecycle state or an + // active run sub state. + ActiveIterations types.Int64 `tfsdk:"active_iterations" tf:"optional"` + // Describes the number of failed and succeeded iteration runs. + CompletedIterations types.Int64 `tfsdk:"completed_iterations" tf:"optional"` + // Describes the number of failed iteration runs. + FailedIterations types.Int64 `tfsdk:"failed_iterations" tf:"optional"` + // Describes the number of iteration runs that have been scheduled. + ScheduledIterations types.Int64 `tfsdk:"scheduled_iterations" tf:"optional"` + // Describes the number of succeeded iteration runs. + SucceededIterations types.Int64 `tfsdk:"succeeded_iterations" tf:"optional"` + // Describes the length of the list of items to iterate over. + TotalIterations types.Int64 `tfsdk:"total_iterations" tf:"optional"` +} + +// Get job permission levels +type GetJobPermissionLevelsRequest struct { + // The job for which to get or manage permissions. + JobId types.String `tfsdk:"-"` +} + +type GetJobPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []JobPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get job permissions +type GetJobPermissionsRequest struct { + // The job for which to get or manage permissions. + JobId types.String `tfsdk:"-"` +} + +// Get a single job +type GetJobRequest struct { + // The canonical identifier of the job to retrieve information about. This + // field is required. + JobId types.Int64 `tfsdk:"-"` +} + +// Get the output for a single run +type GetRunOutputRequest struct { + // The canonical identifier for the run. + RunId types.Int64 `tfsdk:"-"` +} + +// Get a single job run +type GetRunRequest struct { + // Whether to include the repair history in the response. + IncludeHistory types.Bool `tfsdk:"-"` + // Whether to include resolved parameter values in the response. + IncludeResolvedValues types.Bool `tfsdk:"-"` + // The canonical identifier of the run for which to retrieve the metadata. + // This field is required. + RunId types.Int64 `tfsdk:"-"` +} + +// Read-only state of the remote repository at the time the job was run. This +// field is only included on job runs. +type GitSnapshot struct { + // Commit that was used to execute the run. If git_branch was specified, + // this points to the HEAD of the branch at the time of the run; if git_tag + // was specified, this points to the commit the tag points to. + UsedCommit types.String `tfsdk:"used_commit" tf:"optional"` +} + +// An optional specification for a remote Git repository containing the source +// code used by tasks. Version-controlled source code is supported by notebook, +// dbt, Python script, and SQL File tasks. +// +// If `git_source` is set, these tasks retrieve the file from the remote +// repository by default. However, this behavior can be overridden by setting +// `source` to `WORKSPACE` on the task. +// +// Note: dbt and SQL File tasks support only version-controlled sources. If dbt +// or SQL File tasks are used, `git_source` must be defined on the job. +type GitSource struct { + // Name of the branch to be checked out and used by this job. This field + // cannot be specified in conjunction with git_tag or git_commit. + GitBranch types.String `tfsdk:"git_branch" tf:"optional"` + // Commit to be checked out and used by this job. This field cannot be + // specified in conjunction with git_branch or git_tag. + GitCommit types.String `tfsdk:"git_commit" tf:"optional"` + // Unique identifier of the service used to host the Git repository. The + // value is case insensitive. + GitProvider types.String `tfsdk:"git_provider" tf:""` + // Read-only state of the remote repository at the time the job was run. + // This field is only included on job runs. + GitSnapshot *GitSnapshot `tfsdk:"git_snapshot" tf:"optional"` + // Name of the tag to be checked out and used by this job. This field cannot + // be specified in conjunction with git_branch or git_commit. + GitTag types.String `tfsdk:"git_tag" tf:"optional"` + // URL of the repository to be cloned by this job. + GitUrl types.String `tfsdk:"git_url" tf:""` + // The source of the job specification in the remote repository when the job + // is source controlled. + JobSource *JobSource `tfsdk:"job_source" tf:"optional"` +} + +// Job was retrieved successfully. +type Job struct { + // The time at which this job was created in epoch milliseconds + // (milliseconds since 1/1/1970 UTC). + CreatedTime types.Int64 `tfsdk:"created_time" tf:"optional"` + // The creator user name. This field won’t be included in the response if + // the user has already been deleted. + CreatorUserName types.String `tfsdk:"creator_user_name" tf:"optional"` + // The canonical identifier for this job. + JobId types.Int64 `tfsdk:"job_id" tf:"optional"` + // The email of an active workspace user or the application ID of a service + // principal that the job runs as. This value can be changed by setting the + // `run_as` field when creating or updating a job. + // + // By default, `run_as_user_name` is based on the current job settings and + // is set to the creator of the job if job access control is disabled or to + // the user with the `is_owner` permission if job access control is enabled. + RunAsUserName types.String `tfsdk:"run_as_user_name" tf:"optional"` + // Settings for this job and all of its runs. These settings can be updated + // using the `resetJob` method. + Settings *JobSettings `tfsdk:"settings" tf:"optional"` +} + +type JobAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type JobAccessControlResponse struct { + // All permissions. + AllPermissions []JobPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type JobCluster struct { + // A unique name for the job cluster. This field is required and must be + // unique within the job. `JobTaskSettings` may refer to this field to + // determine which cluster to launch for the task execution. + JobClusterKey types.String `tfsdk:"job_cluster_key" tf:""` + // If new_cluster, a description of a cluster that is created for each task. + NewCluster compute.ClusterSpec `tfsdk:"new_cluster" tf:""` +} + +type JobDeployment struct { + // The kind of deployment that manages the job. + // + // * `BUNDLE`: The job is managed by Databricks Asset Bundle. + Kind types.String `tfsdk:"kind" tf:""` + // Path of the file that contains deployment metadata. + MetadataFilePath types.String `tfsdk:"metadata_file_path" tf:"optional"` +} + +type JobEmailNotifications struct { + // If true, do not send email to recipients specified in `on_failure` if the + // run is skipped. + NoAlertForSkippedRuns types.Bool `tfsdk:"no_alert_for_skipped_runs" tf:"optional"` + // A list of email addresses to be notified when the duration of a run + // exceeds the threshold specified for the `RUN_DURATION_SECONDS` metric in + // the `health` field. If no rule for the `RUN_DURATION_SECONDS` metric is + // specified in the `health` field for the job, notifications are not sent. + OnDurationWarningThresholdExceeded []types.String `tfsdk:"on_duration_warning_threshold_exceeded" tf:"optional"` + // A list of email addresses to be notified when a run unsuccessfully + // completes. A run is considered to have completed unsuccessfully if it + // ends with an `INTERNAL_ERROR` `life_cycle_state` or a `FAILED`, or + // `TIMED_OUT` result_state. If this is not specified on job creation, + // reset, or update the list is empty, and notifications are not sent. + OnFailure []types.String `tfsdk:"on_failure" tf:"optional"` + // A list of email addresses to be notified when a run begins. If not + // specified on job creation, reset, or update, the list is empty, and + // notifications are not sent. + OnStart []types.String `tfsdk:"on_start" tf:"optional"` + // A list of email addresses to notify when any streaming backlog thresholds + // are exceeded for any stream. Streaming backlog thresholds can be set in + // the `health` field using the following metrics: + // `STREAMING_BACKLOG_BYTES`, `STREAMING_BACKLOG_RECORDS`, + // `STREAMING_BACKLOG_SECONDS`, or `STREAMING_BACKLOG_FILES`. Alerting is + // based on the 10-minute average of these metrics. If the issue persists, + // notifications are resent every 30 minutes. + OnStreamingBacklogExceeded []types.String `tfsdk:"on_streaming_backlog_exceeded" tf:"optional"` + // A list of email addresses to be notified when a run successfully + // completes. A run is considered to have completed successfully if it ends + // with a `TERMINATED` `life_cycle_state` and a `SUCCESS` result_state. If + // not specified on job creation, reset, or update, the list is empty, and + // notifications are not sent. + OnSuccess []types.String `tfsdk:"on_success" tf:"optional"` +} + +type JobEnvironment struct { + // The key of an environment. It has to be unique within a job. + EnvironmentKey types.String `tfsdk:"environment_key" tf:""` + // The environment entity used to preserve serverless environment side panel + // and jobs' environment for non-notebook task. In this minimal environment + // spec, only pip dependencies are supported. + Spec *compute.Environment `tfsdk:"spec" tf:"optional"` +} + +type JobNotificationSettings struct { + // If true, do not send notifications to recipients specified in + // `on_failure` if the run is canceled. + NoAlertForCanceledRuns types.Bool `tfsdk:"no_alert_for_canceled_runs" tf:"optional"` + // If true, do not send notifications to recipients specified in + // `on_failure` if the run is skipped. + NoAlertForSkippedRuns types.Bool `tfsdk:"no_alert_for_skipped_runs" tf:"optional"` +} + +type JobParameter struct { + // The optional default value of the parameter + Default types.String `tfsdk:"default" tf:"optional"` + // The name of the parameter + Name types.String `tfsdk:"name" tf:"optional"` + // The value used in the run + Value types.String `tfsdk:"value" tf:"optional"` +} + +type JobParameterDefinition struct { + // Default value of the parameter. + Default types.String `tfsdk:"default" tf:""` + // The name of the defined parameter. May only contain alphanumeric + // characters, `_`, `-`, and `.` + Name types.String `tfsdk:"name" tf:""` +} + +type JobPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type JobPermissions struct { + AccessControlList []JobAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type JobPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type JobPermissionsRequest struct { + AccessControlList []JobAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The job for which to get or manage permissions. + JobId types.String `tfsdk:"-"` +} + +// Write-only setting, available only in Create/Update/Reset and Submit calls. +// Specifies the user or service principal that the job runs as. If not +// specified, the job runs as the user who created the job. +// +// Only `user_name` or `service_principal_name` can be specified. If both are +// specified, an error is thrown. +type JobRunAs struct { + // Application ID of an active service principal. Setting this field + // requires the `servicePrincipal/user` role. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // The email of an active workspace user. Non-admin users can only set this + // field to their own email. + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type JobSettings struct { + // An optional continuous property for this job. The continuous property + // will ensure that there is always one run executing. Only one of + // `schedule` and `continuous` can be used. + Continuous *Continuous `tfsdk:"continuous" tf:"optional"` + // Deployment information for jobs managed by external sources. + Deployment *JobDeployment `tfsdk:"deployment" tf:"optional"` + // An optional description for the job. The maximum length is 1024 + // characters in UTF-8 encoding. + Description types.String `tfsdk:"description" tf:"optional"` + // Edit mode of the job. + // + // * `UI_LOCKED`: The job is in a locked UI state and cannot be modified. * + // `EDITABLE`: The job is in an editable state and can be modified. + EditMode types.String `tfsdk:"edit_mode" tf:"optional"` + // An optional set of email addresses that is notified when runs of this job + // begin or complete as well as when this job is deleted. + EmailNotifications *JobEmailNotifications `tfsdk:"email_notifications" tf:"optional"` + // A list of task execution environment specifications that can be + // referenced by tasks of this job. + Environments []JobEnvironment `tfsdk:"environments" tf:"optional"` + // Used to tell what is the format of the job. This field is ignored in + // Create/Update/Reset calls. When using the Jobs API 2.1 this value is + // always set to `"MULTI_TASK"`. + Format types.String `tfsdk:"format" tf:"optional"` + // An optional specification for a remote Git repository containing the + // source code used by tasks. Version-controlled source code is supported by + // notebook, dbt, Python script, and SQL File tasks. + // + // If `git_source` is set, these tasks retrieve the file from the remote + // repository by default. However, this behavior can be overridden by + // setting `source` to `WORKSPACE` on the task. + // + // Note: dbt and SQL File tasks support only version-controlled sources. If + // dbt or SQL File tasks are used, `git_source` must be defined on the job. + GitSource *GitSource `tfsdk:"git_source" tf:"optional"` + // An optional set of health rules that can be defined for this job. + Health *JobsHealthRules `tfsdk:"health" tf:"optional"` + // A list of job cluster specifications that can be shared and reused by + // tasks of this job. Libraries cannot be declared in a shared job cluster. + // You must declare dependent libraries in task settings. + JobClusters []JobCluster `tfsdk:"job_clusters" tf:"optional"` + // An optional maximum allowed number of concurrent runs of the job. Set + // this value if you want to be able to execute multiple runs of the same + // job concurrently. This is useful for example if you trigger your job on a + // frequent schedule and want to allow consecutive runs to overlap with each + // other, or if you want to trigger multiple runs which differ by their + // input parameters. This setting affects only new runs. For example, + // suppose the job’s concurrency is 4 and there are 4 concurrent active + // runs. Then setting the concurrency to 3 won’t kill any of the active + // runs. However, from then on, new runs are skipped unless there are fewer + // than 3 active runs. This value cannot exceed 1000. Setting this value to + // `0` causes all new runs to be skipped. + MaxConcurrentRuns types.Int64 `tfsdk:"max_concurrent_runs" tf:"optional"` + // An optional name for the job. The maximum length is 4096 bytes in UTF-8 + // encoding. + Name types.String `tfsdk:"name" tf:"optional"` + // Optional notification settings that are used when sending notifications + // to each of the `email_notifications` and `webhook_notifications` for this + // job. + NotificationSettings *JobNotificationSettings `tfsdk:"notification_settings" tf:"optional"` + // Job-level parameter definitions + Parameters []JobParameterDefinition `tfsdk:"parameters" tf:"optional"` + // The queue settings of the job. + Queue *QueueSettings `tfsdk:"queue" tf:"optional"` + // Write-only setting, available only in Create/Update/Reset and Submit + // calls. Specifies the user or service principal that the job runs as. If + // not specified, the job runs as the user who created the job. + // + // Only `user_name` or `service_principal_name` can be specified. If both + // are specified, an error is thrown. + RunAs *JobRunAs `tfsdk:"run_as" tf:"optional"` + // An optional periodic schedule for this job. The default behavior is that + // the job only runs when triggered by clicking “Run Now” in the Jobs UI + // or sending an API request to `runNow`. + Schedule *CronSchedule `tfsdk:"schedule" tf:"optional"` + // A map of tags associated with the job. These are forwarded to the cluster + // as cluster tags for jobs clusters, and are subject to the same + // limitations as cluster tags. A maximum of 25 tags can be added to the + // job. + Tags map[string]types.String `tfsdk:"tags" tf:"optional"` + // A list of task specifications to be executed by this job. + Tasks []Task `tfsdk:"tasks" tf:"optional"` + // An optional timeout applied to each run of this job. A value of `0` means + // no timeout. + TimeoutSeconds types.Int64 `tfsdk:"timeout_seconds" tf:"optional"` + // A configuration to trigger a run when certain conditions are met. The + // default behavior is that the job runs only when triggered by clicking + // “Run Now” in the Jobs UI or sending an API request to `runNow`. + Trigger *TriggerSettings `tfsdk:"trigger" tf:"optional"` + // A collection of system notification IDs to notify when runs of this job + // begin or complete. + WebhookNotifications *WebhookNotifications `tfsdk:"webhook_notifications" tf:"optional"` +} + +// The source of the job specification in the remote repository when the job is +// source controlled. +type JobSource struct { + // Dirty state indicates the job is not fully synced with the job + // specification in the remote repository. + // + // Possible values are: * `NOT_SYNCED`: The job is not yet synced with the + // remote job specification. Import the remote job specification from UI to + // make the job fully synced. * `DISCONNECTED`: The job is temporary + // disconnected from the remote job specification and is allowed for live + // edit. Import the remote job specification again from UI to make the job + // fully synced. + DirtyState types.String `tfsdk:"dirty_state" tf:"optional"` + // Name of the branch which the job is imported from. + ImportFromGitBranch types.String `tfsdk:"import_from_git_branch" tf:""` + // Path of the job YAML file that contains the job specification. + JobConfigPath types.String `tfsdk:"job_config_path" tf:""` +} + +type JobsHealthRule struct { + // Specifies the health metric that is being evaluated for a particular + // health rule. + // + // * `RUN_DURATION_SECONDS`: Expected total time for a run in seconds. * + // `STREAMING_BACKLOG_BYTES`: An estimate of the maximum bytes of data + // waiting to be consumed across all streams. This metric is in Private + // Preview. * `STREAMING_BACKLOG_RECORDS`: An estimate of the maximum offset + // lag across all streams. This metric is in Private Preview. * + // `STREAMING_BACKLOG_SECONDS`: An estimate of the maximum consumer delay + // across all streams. This metric is in Private Preview. * + // `STREAMING_BACKLOG_FILES`: An estimate of the maximum number of + // outstanding files across all streams. This metric is in Private Preview. + Metric types.String `tfsdk:"metric" tf:""` + // Specifies the operator used to compare the health metric value with the + // specified threshold. + Op types.String `tfsdk:"op" tf:""` + // Specifies the threshold value that the health metric should obey to + // satisfy the health rule. + Value types.Int64 `tfsdk:"value" tf:""` +} + +// An optional set of health rules that can be defined for this job. +type JobsHealthRules struct { + Rules []JobsHealthRule `tfsdk:"rules" tf:"optional"` +} + +// List jobs +type ListJobsRequest struct { + // Whether to include task and cluster details in the response. + ExpandTasks types.Bool `tfsdk:"-"` + // The number of jobs to return. This value must be greater than 0 and less + // or equal to 100. The default value is 20. + Limit types.Int64 `tfsdk:"-"` + // A filter on the list based on the exact (case insensitive) job name. + Name types.String `tfsdk:"-"` + // The offset of the first job to return, relative to the most recently + // created job. Deprecated since June 2023. Use `page_token` to iterate + // through the pages instead. + Offset types.Int64 `tfsdk:"-"` + // Use `next_page_token` or `prev_page_token` returned from the previous + // request to list the next or previous page of jobs respectively. + PageToken types.String `tfsdk:"-"` +} + +// List of jobs was retrieved successfully. +type ListJobsResponse struct { + // If true, additional jobs matching the provided filter are available for + // listing. + HasMore types.Bool `tfsdk:"has_more" tf:"optional"` + // The list of jobs. Only included in the response if there are jobs to + // list. + Jobs []BaseJob `tfsdk:"jobs" tf:"optional"` + // A token that can be used to list the next page of jobs (if applicable). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // A token that can be used to list the previous page of jobs (if + // applicable). + PrevPageToken types.String `tfsdk:"prev_page_token" tf:"optional"` +} + +// List job runs +type ListRunsRequest struct { + // If active_only is `true`, only active runs are included in the results; + // otherwise, lists both active and completed runs. An active run is a run + // in the `QUEUED`, `PENDING`, `RUNNING`, or `TERMINATING`. This field + // cannot be `true` when completed_only is `true`. + ActiveOnly types.Bool `tfsdk:"-"` + // If completed_only is `true`, only completed runs are included in the + // results; otherwise, lists both active and completed runs. This field + // cannot be `true` when active_only is `true`. + CompletedOnly types.Bool `tfsdk:"-"` + // Whether to include task and cluster details in the response. + ExpandTasks types.Bool `tfsdk:"-"` + // The job for which to list runs. If omitted, the Jobs service lists runs + // from all jobs. + JobId types.Int64 `tfsdk:"-"` + // The number of runs to return. This value must be greater than 0 and less + // than 25. The default value is 20. If a request specifies a limit of 0, + // the service instead uses the maximum limit. + Limit types.Int64 `tfsdk:"-"` + // The offset of the first run to return, relative to the most recent run. + // Deprecated since June 2023. Use `page_token` to iterate through the pages + // instead. + Offset types.Int64 `tfsdk:"-"` + // Use `next_page_token` or `prev_page_token` returned from the previous + // request to list the next or previous page of runs respectively. + PageToken types.String `tfsdk:"-"` + // The type of runs to return. For a description of run types, see + // :method:jobs/getRun. + RunType types.String `tfsdk:"-"` + // Show runs that started _at or after_ this value. The value must be a UTC + // timestamp in milliseconds. Can be combined with _start_time_to_ to filter + // by a time range. + StartTimeFrom types.Int64 `tfsdk:"-"` + // Show runs that started _at or before_ this value. The value must be a UTC + // timestamp in milliseconds. Can be combined with _start_time_from_ to + // filter by a time range. + StartTimeTo types.Int64 `tfsdk:"-"` +} + +// List of runs was retrieved successfully. +type ListRunsResponse struct { + // If true, additional runs matching the provided filter are available for + // listing. + HasMore types.Bool `tfsdk:"has_more" tf:"optional"` + // A token that can be used to list the next page of runs (if applicable). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // A token that can be used to list the previous page of runs (if + // applicable). + PrevPageToken types.String `tfsdk:"prev_page_token" tf:"optional"` + // A list of runs, from most recently started to least. Only included in the + // response if there are runs to list. + Runs []BaseRun `tfsdk:"runs" tf:"optional"` +} + +type NotebookOutput struct { + // The value passed to + // [dbutils.notebook.exit()](/notebooks/notebook-workflows.html#notebook-workflows-exit). + // Databricks restricts this API to return the first 5 MB of the value. For + // a larger result, your job can store the results in a cloud storage + // service. This field is absent if `dbutils.notebook.exit()` was never + // called. + Result types.String `tfsdk:"result" tf:"optional"` + // Whether or not the result was truncated. + Truncated types.Bool `tfsdk:"truncated" tf:"optional"` +} + +type NotebookTask struct { + // Base parameters to be used for each run of this job. If the run is + // initiated by a call to :method:jobs/run Now with parameters specified, + // the two parameters maps are merged. If the same key is specified in + // `base_parameters` and in `run-now`, the value from `run-now` is used. Use + // [Task parameter variables] to set parameters containing information about + // job runs. + // + // If the notebook takes a parameter that is not specified in the job’s + // `base_parameters` or the `run-now` override parameters, the default value + // from the notebook is used. + // + // Retrieve these parameters in a notebook using [dbutils.widgets.get]. + // + // The JSON representation of this field cannot exceed 1MB. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + // [dbutils.widgets.get]: https://docs.databricks.com/dev-tools/databricks-utils.html#dbutils-widgets + BaseParameters map[string]types.String `tfsdk:"base_parameters" tf:"optional"` + // The path of the notebook to be run in the Databricks workspace or remote + // repository. For notebooks stored in the Databricks workspace, the path + // must be absolute and begin with a slash. For notebooks stored in a remote + // repository, the path must be relative. This field is required. + NotebookPath types.String `tfsdk:"notebook_path" tf:""` + // Optional location type of the notebook. When set to `WORKSPACE`, the + // notebook will be retrieved from the local Databricks workspace. When set + // to `GIT`, the notebook will be retrieved from a Git repository defined in + // `git_source`. If the value is empty, the task will use `GIT` if + // `git_source` is defined and `WORKSPACE` otherwise. * `WORKSPACE`: + // Notebook is located in Databricks workspace. * `GIT`: Notebook is located + // in cloud Git provider. + Source types.String `tfsdk:"source" tf:"optional"` + // Optional `warehouse_id` to run the notebook on a SQL warehouse. Classic + // SQL warehouses are NOT supported, please use serverless or pro SQL + // warehouses. + // + // Note that SQL warehouses only support SQL cells; if the notebook contains + // non-SQL cells, the run will fail. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +type PeriodicTriggerConfiguration struct { + // The interval at which the trigger should run. + Interval types.Int64 `tfsdk:"interval" tf:""` + // The unit of time for the interval. + Unit types.String `tfsdk:"unit" tf:""` +} + +type PipelineParams struct { + // If true, triggers a full refresh on the delta live table. + FullRefresh types.Bool `tfsdk:"full_refresh" tf:"optional"` +} + +type PipelineTask struct { + // If true, triggers a full refresh on the delta live table. + FullRefresh types.Bool `tfsdk:"full_refresh" tf:"optional"` + // The full name of the pipeline task to execute. + PipelineId types.String `tfsdk:"pipeline_id" tf:""` +} + +type PythonWheelTask struct { + // Named entry point to use, if it does not exist in the metadata of the + // package it executes the function from the package directly using + // `$packageName.$entryPoint()` + EntryPoint types.String `tfsdk:"entry_point" tf:""` + // Command-line parameters passed to Python wheel task in the form of + // `["--name=task", "--data=dbfs:/path/to/data.json"]`. Leave it empty if + // `parameters` is not null. + NamedParameters map[string]types.String `tfsdk:"named_parameters" tf:"optional"` + // Name of the package to execute + PackageName types.String `tfsdk:"package_name" tf:""` + // Command-line parameters passed to Python wheel task. Leave it empty if + // `named_parameters` is not null. + Parameters []types.String `tfsdk:"parameters" tf:"optional"` +} + +type QueueSettings struct { + // If true, enable queueing for the job. This is a required field. + Enabled types.Bool `tfsdk:"enabled" tf:""` +} + +type RepairHistoryItem struct { + // The end time of the (repaired) run. + EndTime types.Int64 `tfsdk:"end_time" tf:"optional"` + // The ID of the repair. Only returned for the items that represent a repair + // in `repair_history`. + Id types.Int64 `tfsdk:"id" tf:"optional"` + // The start time of the (repaired) run. + StartTime types.Int64 `tfsdk:"start_time" tf:"optional"` + // The current state of the run. + State *RunState `tfsdk:"state" tf:"optional"` + // The run IDs of the task runs that ran as part of this repair history + // item. + TaskRunIds []types.Int64 `tfsdk:"task_run_ids" tf:"optional"` + // The repair history item type. Indicates whether a run is the original run + // or a repair run. + Type types.String `tfsdk:"type" tf:"optional"` +} + +type RepairRun struct { + // An array of commands to execute for jobs with the dbt task, for example + // `"dbt_commands": ["dbt deps", "dbt seed", "dbt deps", "dbt seed", "dbt + // run"]` + DbtCommands []types.String `tfsdk:"dbt_commands" tf:"optional"` + // A list of parameters for jobs with Spark JAR tasks, for example + // `"jar_params": ["john doe", "35"]`. The parameters are used to invoke the + // main function of the main class specified in the Spark JAR task. If not + // specified upon `run-now`, it defaults to an empty list. jar_params cannot + // be specified in conjunction with notebook_params. The JSON representation + // of this field (for example `{"jar_params":["john doe","35"]}`) cannot + // exceed 10,000 bytes. + // + // Use [Task parameter variables](/jobs.html\"#parameter-variables\") to set + // parameters containing information about job runs. + JarParams []types.String `tfsdk:"jar_params" tf:"optional"` + // Job-level parameters used in the run. for example `"param": + // "overriding_val"` + JobParameters map[string]types.String `tfsdk:"job_parameters" tf:"optional"` + // The ID of the latest repair. This parameter is not required when + // repairing a run for the first time, but must be provided on subsequent + // requests to repair the same run. + LatestRepairId types.Int64 `tfsdk:"latest_repair_id" tf:"optional"` + // A map from keys to values for jobs with notebook task, for example + // `"notebook_params": {"name": "john doe", "age": "35"}`. The map is passed + // to the notebook and is accessible through the [dbutils.widgets.get] + // function. + // + // If not specified upon `run-now`, the triggered run uses the job’s base + // parameters. + // + // notebook_params cannot be specified in conjunction with jar_params. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // The JSON representation of this field (for example + // `{"notebook_params":{"name":"john doe","age":"35"}}`) cannot exceed + // 10,000 bytes. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + // [dbutils.widgets.get]: https://docs.databricks.com/dev-tools/databricks-utils.html + NotebookParams map[string]types.String `tfsdk:"notebook_params" tf:"optional"` + + PipelineParams *PipelineParams `tfsdk:"pipeline_params" tf:"optional"` + + PythonNamedParams map[string]types.String `tfsdk:"python_named_params" tf:"optional"` + // A list of parameters for jobs with Python tasks, for example + // `"python_params": ["john doe", "35"]`. The parameters are passed to + // Python file as command-line parameters. If specified upon `run-now`, it + // would overwrite the parameters specified in job setting. The JSON + // representation of this field (for example `{"python_params":["john + // doe","35"]}`) cannot exceed 10,000 bytes. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // Important + // + // These parameters accept only Latin characters (ASCII character set). + // Using non-ASCII characters returns an error. Examples of invalid, + // non-ASCII characters are Chinese, Japanese kanjis, and emojis. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + PythonParams []types.String `tfsdk:"python_params" tf:"optional"` + // If true, repair all failed tasks. Only one of `rerun_tasks` or + // `rerun_all_failed_tasks` can be used. + RerunAllFailedTasks types.Bool `tfsdk:"rerun_all_failed_tasks" tf:"optional"` + // If true, repair all tasks that depend on the tasks in `rerun_tasks`, even + // if they were previously successful. Can be also used in combination with + // `rerun_all_failed_tasks`. + RerunDependentTasks types.Bool `tfsdk:"rerun_dependent_tasks" tf:"optional"` + // The task keys of the task runs to repair. + RerunTasks []types.String `tfsdk:"rerun_tasks" tf:"optional"` + // The job run ID of the run to repair. The run must not be in progress. + RunId types.Int64 `tfsdk:"run_id" tf:""` + // A list of parameters for jobs with spark submit task, for example + // `"spark_submit_params": ["--class", + // "org.apache.spark.examples.SparkPi"]`. The parameters are passed to + // spark-submit script as command-line parameters. If specified upon + // `run-now`, it would overwrite the parameters specified in job setting. + // The JSON representation of this field (for example + // `{"python_params":["john doe","35"]}`) cannot exceed 10,000 bytes. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs + // + // Important + // + // These parameters accept only Latin characters (ASCII character set). + // Using non-ASCII characters returns an error. Examples of invalid, + // non-ASCII characters are Chinese, Japanese kanjis, and emojis. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + SparkSubmitParams []types.String `tfsdk:"spark_submit_params" tf:"optional"` + // A map from keys to values for jobs with SQL task, for example + // `"sql_params": {"name": "john doe", "age": "35"}`. The SQL alert task + // does not support custom parameters. + SqlParams map[string]types.String `tfsdk:"sql_params" tf:"optional"` +} + +// Run repair was initiated. +type RepairRunResponse struct { + // The ID of the repair. Must be provided in subsequent repairs using the + // `latest_repair_id` field to ensure sequential repairs. + RepairId types.Int64 `tfsdk:"repair_id" tf:"optional"` +} + +type ResetJob struct { + // The canonical identifier of the job to reset. This field is required. + JobId types.Int64 `tfsdk:"job_id" tf:""` + // The new settings of the job. These settings completely replace the old + // settings. + // + // Changes to the field `JobBaseSettings.timeout_seconds` are applied to + // active runs. Changes to other fields are applied to future runs only. + NewSettings JobSettings `tfsdk:"new_settings" tf:""` +} + +type ResetResponse struct { +} + +type ResolvedConditionTaskValues struct { + Left types.String `tfsdk:"left" tf:"optional"` + + Right types.String `tfsdk:"right" tf:"optional"` +} + +type ResolvedDbtTaskValues struct { + Commands []types.String `tfsdk:"commands" tf:"optional"` +} + +type ResolvedNotebookTaskValues struct { + BaseParameters map[string]types.String `tfsdk:"base_parameters" tf:"optional"` +} + +type ResolvedParamPairValues struct { + Parameters map[string]types.String `tfsdk:"parameters" tf:"optional"` +} + +type ResolvedPythonWheelTaskValues struct { + NamedParameters map[string]types.String `tfsdk:"named_parameters" tf:"optional"` + + Parameters []types.String `tfsdk:"parameters" tf:"optional"` +} + +type ResolvedRunJobTaskValues struct { + JobParameters map[string]types.String `tfsdk:"job_parameters" tf:"optional"` + + Parameters map[string]types.String `tfsdk:"parameters" tf:"optional"` +} + +type ResolvedStringParamsValues struct { + Parameters []types.String `tfsdk:"parameters" tf:"optional"` +} + +type ResolvedValues struct { + ConditionTask *ResolvedConditionTaskValues `tfsdk:"condition_task" tf:"optional"` + + DbtTask *ResolvedDbtTaskValues `tfsdk:"dbt_task" tf:"optional"` + + NotebookTask *ResolvedNotebookTaskValues `tfsdk:"notebook_task" tf:"optional"` + + PythonWheelTask *ResolvedPythonWheelTaskValues `tfsdk:"python_wheel_task" tf:"optional"` + + RunJobTask *ResolvedRunJobTaskValues `tfsdk:"run_job_task" tf:"optional"` + + SimulationTask *ResolvedParamPairValues `tfsdk:"simulation_task" tf:"optional"` + + SparkJarTask *ResolvedStringParamsValues `tfsdk:"spark_jar_task" tf:"optional"` + + SparkPythonTask *ResolvedStringParamsValues `tfsdk:"spark_python_task" tf:"optional"` + + SparkSubmitTask *ResolvedStringParamsValues `tfsdk:"spark_submit_task" tf:"optional"` + + SqlTask *ResolvedParamPairValues `tfsdk:"sql_task" tf:"optional"` +} + +// Run was retrieved successfully +type Run struct { + // The sequence number of this run attempt for a triggered job run. The + // initial attempt of a run has an attempt_number of 0\. If the initial run + // attempt fails, and the job has a retry policy (`max_retries` \> 0), + // subsequent runs are created with an `original_attempt_run_id` of the + // original attempt’s ID and an incrementing `attempt_number`. Runs are + // retried only until they succeed, and the maximum `attempt_number` is the + // same as the `max_retries` value for the job. + AttemptNumber types.Int64 `tfsdk:"attempt_number" tf:"optional"` + // The time in milliseconds it took to terminate the cluster and clean up + // any associated artifacts. The duration of a task run is the sum of the + // `setup_duration`, `execution_duration`, and the `cleanup_duration`. The + // `cleanup_duration` field is set to 0 for multitask job runs. The total + // duration of a multitask job run is the value of the `run_duration` field. + CleanupDuration types.Int64 `tfsdk:"cleanup_duration" tf:"optional"` + // The cluster used for this run. If the run is specified to use a new + // cluster, this field is set once the Jobs service has requested a cluster + // for the run. + ClusterInstance *ClusterInstance `tfsdk:"cluster_instance" tf:"optional"` + // A snapshot of the job’s cluster specification when this run was + // created. + ClusterSpec *ClusterSpec `tfsdk:"cluster_spec" tf:"optional"` + // The creator user name. This field won’t be included in the response if + // the user has already been deleted. + CreatorUserName types.String `tfsdk:"creator_user_name" tf:"optional"` + // Description of the run + Description types.String `tfsdk:"description" tf:"optional"` + // The time at which this run ended in epoch milliseconds (milliseconds + // since 1/1/1970 UTC). This field is set to 0 if the job is still running. + EndTime types.Int64 `tfsdk:"end_time" tf:"optional"` + // The time in milliseconds it took to execute the commands in the JAR or + // notebook until they completed, failed, timed out, were cancelled, or + // encountered an unexpected error. The duration of a task run is the sum of + // the `setup_duration`, `execution_duration`, and the `cleanup_duration`. + // The `execution_duration` field is set to 0 for multitask job runs. The + // total duration of a multitask job run is the value of the `run_duration` + // field. + ExecutionDuration types.Int64 `tfsdk:"execution_duration" tf:"optional"` + // An optional specification for a remote Git repository containing the + // source code used by tasks. Version-controlled source code is supported by + // notebook, dbt, Python script, and SQL File tasks. + // + // If `git_source` is set, these tasks retrieve the file from the remote + // repository by default. However, this behavior can be overridden by + // setting `source` to `WORKSPACE` on the task. + // + // Note: dbt and SQL File tasks support only version-controlled sources. If + // dbt or SQL File tasks are used, `git_source` must be defined on the job. + GitSource *GitSource `tfsdk:"git_source" tf:"optional"` + // A list of job cluster specifications that can be shared and reused by + // tasks of this job. Libraries cannot be declared in a shared job cluster. + // You must declare dependent libraries in task settings. + JobClusters []JobCluster `tfsdk:"job_clusters" tf:"optional"` + // The canonical identifier of the job that contains this run. + JobId types.Int64 `tfsdk:"job_id" tf:"optional"` + // Job-level parameters used in the run + JobParameters []JobParameter `tfsdk:"job_parameters" tf:"optional"` + // A unique identifier for this job run. This is set to the same value as + // `run_id`. + NumberInJob types.Int64 `tfsdk:"number_in_job" tf:"optional"` + // If this run is a retry of a prior run attempt, this field contains the + // run_id of the original attempt; otherwise, it is the same as the run_id. + OriginalAttemptRunId types.Int64 `tfsdk:"original_attempt_run_id" tf:"optional"` + // The parameters used for this run. + OverridingParameters *RunParameters `tfsdk:"overriding_parameters" tf:"optional"` + // The time in milliseconds that the run has spent in the queue. + QueueDuration types.Int64 `tfsdk:"queue_duration" tf:"optional"` + // The repair history of the run. + RepairHistory []RepairHistoryItem `tfsdk:"repair_history" tf:"optional"` + // The time in milliseconds it took the job run and all of its repairs to + // finish. + RunDuration types.Int64 `tfsdk:"run_duration" tf:"optional"` + // The canonical identifier of the run. This ID is unique across all runs of + // all jobs. + RunId types.Int64 `tfsdk:"run_id" tf:"optional"` + // An optional name for the run. The maximum length is 4096 bytes in UTF-8 + // encoding. + RunName types.String `tfsdk:"run_name" tf:"optional"` + // The URL to the detail page of the run. + RunPageUrl types.String `tfsdk:"run_page_url" tf:"optional"` + // The type of a run. * `JOB_RUN`: Normal job run. A run created with + // :method:jobs/runNow. * `WORKFLOW_RUN`: Workflow run. A run created with + // [dbutils.notebook.run]. * `SUBMIT_RUN`: Submit run. A run created with + // :method:jobs/submit. + // + // [dbutils.notebook.run]: https://docs.databricks.com/dev-tools/databricks-utils.html#dbutils-workflow + RunType types.String `tfsdk:"run_type" tf:"optional"` + // The cron schedule that triggered this run if it was triggered by the + // periodic scheduler. + Schedule *CronSchedule `tfsdk:"schedule" tf:"optional"` + // The time in milliseconds it took to set up the cluster. For runs that run + // on new clusters this is the cluster creation time, for runs that run on + // existing clusters this time should be very short. The duration of a task + // run is the sum of the `setup_duration`, `execution_duration`, and the + // `cleanup_duration`. The `setup_duration` field is set to 0 for multitask + // job runs. The total duration of a multitask job run is the value of the + // `run_duration` field. + SetupDuration types.Int64 `tfsdk:"setup_duration" tf:"optional"` + // The time at which this run was started in epoch milliseconds + // (milliseconds since 1/1/1970 UTC). This may not be the time when the job + // task starts executing, for example, if the job is scheduled to run on a + // new cluster, this is the time the cluster creation call is issued. + StartTime types.Int64 `tfsdk:"start_time" tf:"optional"` + // The current state of the run. + State *RunState `tfsdk:"state" tf:"optional"` + // The list of tasks performed by the run. Each task has its own `run_id` + // which you can use to call `JobsGetOutput` to retrieve the run resutls. + Tasks []RunTask `tfsdk:"tasks" tf:"optional"` + // The type of trigger that fired this run. + // + // * `PERIODIC`: Schedules that periodically trigger runs, such as a cron + // scheduler. * `ONE_TIME`: One time triggers that fire a single run. This + // occurs you triggered a single run on demand through the UI or the API. * + // `RETRY`: Indicates a run that is triggered as a retry of a previously + // failed run. This occurs when you request to re-run the job in case of + // failures. * `RUN_JOB_TASK`: Indicates a run that is triggered using a Run + // Job task. * `FILE_ARRIVAL`: Indicates a run that is triggered by a file + // arrival. * `TABLE`: Indicates a run that is triggered by a table update. + Trigger types.String `tfsdk:"trigger" tf:"optional"` + // Additional details about what triggered the run + TriggerInfo *TriggerInfo `tfsdk:"trigger_info" tf:"optional"` +} + +type RunConditionTask struct { + // The left operand of the condition task. Can be either a string value or a + // job state or parameter reference. + Left types.String `tfsdk:"left" tf:""` + // * `EQUAL_TO`, `NOT_EQUAL` operators perform string comparison of their + // operands. This means that `“12.0” == “12”` will evaluate to + // `false`. * `GREATER_THAN`, `GREATER_THAN_OR_EQUAL`, `LESS_THAN`, + // `LESS_THAN_OR_EQUAL` operators perform numeric comparison of their + // operands. `“12.0” >= “12”` will evaluate to `true`, `“10.0” + // >= “12”` will evaluate to `false`. + // + // The boolean comparison to task values can be implemented with operators + // `EQUAL_TO`, `NOT_EQUAL`. If a task value was set to a boolean value, it + // will be serialized to `“true”` or `“false”` for the comparison. + Op types.String `tfsdk:"op" tf:""` + // The condition expression evaluation result. Filled in if the task was + // successfully completed. Can be `"true"` or `"false"` + Outcome types.String `tfsdk:"outcome" tf:"optional"` + // The right operand of the condition task. Can be either a string value or + // a job state or parameter reference. + Right types.String `tfsdk:"right" tf:""` +} + +type RunForEachTask struct { + // Controls the number of active iterations task runs. Default is 20, + // maximum allowed is 100. + Concurrency types.Int64 `tfsdk:"concurrency" tf:"optional"` + // Array for task to iterate on. This can be a JSON string or a reference to + // an array parameter. + Inputs types.String `tfsdk:"inputs" tf:""` + // Read only field. Populated for GetRun and ListRuns RPC calls and stores + // the execution stats of an For each task + Stats *ForEachStats `tfsdk:"stats" tf:"optional"` + // Configuration for the task that will be run for each element in the array + Task Task `tfsdk:"task" tf:""` +} + +type RunJobOutput struct { + // The run id of the triggered job run + RunId types.Int64 `tfsdk:"run_id" tf:"optional"` +} + +type RunJobTask struct { + // An array of commands to execute for jobs with the dbt task, for example + // `"dbt_commands": ["dbt deps", "dbt seed", "dbt deps", "dbt seed", "dbt + // run"]` + DbtCommands []types.String `tfsdk:"dbt_commands" tf:"optional"` + // A list of parameters for jobs with Spark JAR tasks, for example + // `"jar_params": ["john doe", "35"]`. The parameters are used to invoke the + // main function of the main class specified in the Spark JAR task. If not + // specified upon `run-now`, it defaults to an empty list. jar_params cannot + // be specified in conjunction with notebook_params. The JSON representation + // of this field (for example `{"jar_params":["john doe","35"]}`) cannot + // exceed 10,000 bytes. + // + // Use [Task parameter variables](/jobs.html\"#parameter-variables\") to set + // parameters containing information about job runs. + JarParams []types.String `tfsdk:"jar_params" tf:"optional"` + // ID of the job to trigger. + JobId types.Int64 `tfsdk:"job_id" tf:""` + // Job-level parameters used to trigger the job. + JobParameters map[string]types.String `tfsdk:"job_parameters" tf:"optional"` + // A map from keys to values for jobs with notebook task, for example + // `"notebook_params": {"name": "john doe", "age": "35"}`. The map is passed + // to the notebook and is accessible through the [dbutils.widgets.get] + // function. + // + // If not specified upon `run-now`, the triggered run uses the job’s base + // parameters. + // + // notebook_params cannot be specified in conjunction with jar_params. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // The JSON representation of this field (for example + // `{"notebook_params":{"name":"john doe","age":"35"}}`) cannot exceed + // 10,000 bytes. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + // [dbutils.widgets.get]: https://docs.databricks.com/dev-tools/databricks-utils.html + NotebookParams map[string]types.String `tfsdk:"notebook_params" tf:"optional"` + + PipelineParams *PipelineParams `tfsdk:"pipeline_params" tf:"optional"` + + PythonNamedParams map[string]types.String `tfsdk:"python_named_params" tf:"optional"` + // A list of parameters for jobs with Python tasks, for example + // `"python_params": ["john doe", "35"]`. The parameters are passed to + // Python file as command-line parameters. If specified upon `run-now`, it + // would overwrite the parameters specified in job setting. The JSON + // representation of this field (for example `{"python_params":["john + // doe","35"]}`) cannot exceed 10,000 bytes. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // Important + // + // These parameters accept only Latin characters (ASCII character set). + // Using non-ASCII characters returns an error. Examples of invalid, + // non-ASCII characters are Chinese, Japanese kanjis, and emojis. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + PythonParams []types.String `tfsdk:"python_params" tf:"optional"` + // A list of parameters for jobs with spark submit task, for example + // `"spark_submit_params": ["--class", + // "org.apache.spark.examples.SparkPi"]`. The parameters are passed to + // spark-submit script as command-line parameters. If specified upon + // `run-now`, it would overwrite the parameters specified in job setting. + // The JSON representation of this field (for example + // `{"python_params":["john doe","35"]}`) cannot exceed 10,000 bytes. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs + // + // Important + // + // These parameters accept only Latin characters (ASCII character set). + // Using non-ASCII characters returns an error. Examples of invalid, + // non-ASCII characters are Chinese, Japanese kanjis, and emojis. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + SparkSubmitParams []types.String `tfsdk:"spark_submit_params" tf:"optional"` + // A map from keys to values for jobs with SQL task, for example + // `"sql_params": {"name": "john doe", "age": "35"}`. The SQL alert task + // does not support custom parameters. + SqlParams map[string]types.String `tfsdk:"sql_params" tf:"optional"` +} + +type RunNow struct { + // An array of commands to execute for jobs with the dbt task, for example + // `"dbt_commands": ["dbt deps", "dbt seed", "dbt deps", "dbt seed", "dbt + // run"]` + DbtCommands []types.String `tfsdk:"dbt_commands" tf:"optional"` + // An optional token to guarantee the idempotency of job run requests. If a + // run with the provided token already exists, the request does not create a + // new run but returns the ID of the existing run instead. If a run with the + // provided token is deleted, an error is returned. + // + // If you specify the idempotency token, upon failure you can retry until + // the request succeeds. Databricks guarantees that exactly one run is + // launched with that idempotency token. + // + // This token must have at most 64 characters. + // + // For more information, see [How to ensure idempotency for jobs]. + // + // [How to ensure idempotency for jobs]: https://kb.databricks.com/jobs/jobs-idempotency.html + IdempotencyToken types.String `tfsdk:"idempotency_token" tf:"optional"` + // A list of parameters for jobs with Spark JAR tasks, for example + // `"jar_params": ["john doe", "35"]`. The parameters are used to invoke the + // main function of the main class specified in the Spark JAR task. If not + // specified upon `run-now`, it defaults to an empty list. jar_params cannot + // be specified in conjunction with notebook_params. The JSON representation + // of this field (for example `{"jar_params":["john doe","35"]}`) cannot + // exceed 10,000 bytes. + // + // Use [Task parameter variables](/jobs.html\"#parameter-variables\") to set + // parameters containing information about job runs. + JarParams []types.String `tfsdk:"jar_params" tf:"optional"` + // The ID of the job to be executed + JobId types.Int64 `tfsdk:"job_id" tf:""` + // Job-level parameters used in the run. for example `"param": + // "overriding_val"` + JobParameters map[string]types.String `tfsdk:"job_parameters" tf:"optional"` + // A map from keys to values for jobs with notebook task, for example + // `"notebook_params": {"name": "john doe", "age": "35"}`. The map is passed + // to the notebook and is accessible through the [dbutils.widgets.get] + // function. + // + // If not specified upon `run-now`, the triggered run uses the job’s base + // parameters. + // + // notebook_params cannot be specified in conjunction with jar_params. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // The JSON representation of this field (for example + // `{"notebook_params":{"name":"john doe","age":"35"}}`) cannot exceed + // 10,000 bytes. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + // [dbutils.widgets.get]: https://docs.databricks.com/dev-tools/databricks-utils.html + NotebookParams map[string]types.String `tfsdk:"notebook_params" tf:"optional"` + + PipelineParams *PipelineParams `tfsdk:"pipeline_params" tf:"optional"` + + PythonNamedParams map[string]types.String `tfsdk:"python_named_params" tf:"optional"` + // A list of parameters for jobs with Python tasks, for example + // `"python_params": ["john doe", "35"]`. The parameters are passed to + // Python file as command-line parameters. If specified upon `run-now`, it + // would overwrite the parameters specified in job setting. The JSON + // representation of this field (for example `{"python_params":["john + // doe","35"]}`) cannot exceed 10,000 bytes. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // Important + // + // These parameters accept only Latin characters (ASCII character set). + // Using non-ASCII characters returns an error. Examples of invalid, + // non-ASCII characters are Chinese, Japanese kanjis, and emojis. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + PythonParams []types.String `tfsdk:"python_params" tf:"optional"` + // The queue settings of the run. + Queue *QueueSettings `tfsdk:"queue" tf:"optional"` + // A list of parameters for jobs with spark submit task, for example + // `"spark_submit_params": ["--class", + // "org.apache.spark.examples.SparkPi"]`. The parameters are passed to + // spark-submit script as command-line parameters. If specified upon + // `run-now`, it would overwrite the parameters specified in job setting. + // The JSON representation of this field (for example + // `{"python_params":["john doe","35"]}`) cannot exceed 10,000 bytes. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs + // + // Important + // + // These parameters accept only Latin characters (ASCII character set). + // Using non-ASCII characters returns an error. Examples of invalid, + // non-ASCII characters are Chinese, Japanese kanjis, and emojis. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + SparkSubmitParams []types.String `tfsdk:"spark_submit_params" tf:"optional"` + // A map from keys to values for jobs with SQL task, for example + // `"sql_params": {"name": "john doe", "age": "35"}`. The SQL alert task + // does not support custom parameters. + SqlParams map[string]types.String `tfsdk:"sql_params" tf:"optional"` +} + +// Run was started successfully. +type RunNowResponse struct { + // A unique identifier for this job run. This is set to the same value as + // `run_id`. + NumberInJob types.Int64 `tfsdk:"number_in_job" tf:"optional"` + // The globally unique ID of the newly triggered run. + RunId types.Int64 `tfsdk:"run_id" tf:"optional"` +} + +// Run output was retrieved successfully. +type RunOutput struct { + // The output of a dbt task, if available. + DbtOutput *DbtOutput `tfsdk:"dbt_output" tf:"optional"` + // An error message indicating why a task failed or why output is not + // available. The message is unstructured, and its exact format is subject + // to change. + Error types.String `tfsdk:"error" tf:"optional"` + // If there was an error executing the run, this field contains any + // available stack traces. + ErrorTrace types.String `tfsdk:"error_trace" tf:"optional"` + + Info types.String `tfsdk:"info" tf:"optional"` + // The output from tasks that write to standard streams (stdout/stderr) such + // as spark_jar_task, spark_python_task, python_wheel_task. + // + // It's not supported for the notebook_task, pipeline_task or + // spark_submit_task. + // + // Databricks restricts this API to return the last 5 MB of these logs. + Logs types.String `tfsdk:"logs" tf:"optional"` + // Whether the logs are truncated. + LogsTruncated types.Bool `tfsdk:"logs_truncated" tf:"optional"` + // All details of the run except for its output. + Metadata *Run `tfsdk:"metadata" tf:"optional"` + // The output of a notebook task, if available. A notebook task that + // terminates (either successfully or with a failure) without calling + // `dbutils.notebook.exit()` is considered to have an empty output. This + // field is set but its result value is empty. Databricks restricts this API + // to return the first 5 MB of the output. To return a larger result, use + // the [ClusterLogConf] field to configure log storage for the job cluster. + // + // [ClusterLogConf]: https://docs.databricks.com/dev-tools/api/latest/clusters.html#clusterlogconf + NotebookOutput *NotebookOutput `tfsdk:"notebook_output" tf:"optional"` + // The output of a run job task, if available + RunJobOutput *RunJobOutput `tfsdk:"run_job_output" tf:"optional"` + // The output of a SQL task, if available. + SqlOutput *SqlOutput `tfsdk:"sql_output" tf:"optional"` +} + +type RunParameters struct { + // An array of commands to execute for jobs with the dbt task, for example + // `"dbt_commands": ["dbt deps", "dbt seed", "dbt deps", "dbt seed", "dbt + // run"]` + DbtCommands []types.String `tfsdk:"dbt_commands" tf:"optional"` + // A list of parameters for jobs with Spark JAR tasks, for example + // `"jar_params": ["john doe", "35"]`. The parameters are used to invoke the + // main function of the main class specified in the Spark JAR task. If not + // specified upon `run-now`, it defaults to an empty list. jar_params cannot + // be specified in conjunction with notebook_params. The JSON representation + // of this field (for example `{"jar_params":["john doe","35"]}`) cannot + // exceed 10,000 bytes. + // + // Use [Task parameter variables](/jobs.html\"#parameter-variables\") to set + // parameters containing information about job runs. + JarParams []types.String `tfsdk:"jar_params" tf:"optional"` + // A map from keys to values for jobs with notebook task, for example + // `"notebook_params": {"name": "john doe", "age": "35"}`. The map is passed + // to the notebook and is accessible through the [dbutils.widgets.get] + // function. + // + // If not specified upon `run-now`, the triggered run uses the job’s base + // parameters. + // + // notebook_params cannot be specified in conjunction with jar_params. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // The JSON representation of this field (for example + // `{"notebook_params":{"name":"john doe","age":"35"}}`) cannot exceed + // 10,000 bytes. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + // [dbutils.widgets.get]: https://docs.databricks.com/dev-tools/databricks-utils.html + NotebookParams map[string]types.String `tfsdk:"notebook_params" tf:"optional"` + + PipelineParams *PipelineParams `tfsdk:"pipeline_params" tf:"optional"` + + PythonNamedParams map[string]types.String `tfsdk:"python_named_params" tf:"optional"` + // A list of parameters for jobs with Python tasks, for example + // `"python_params": ["john doe", "35"]`. The parameters are passed to + // Python file as command-line parameters. If specified upon `run-now`, it + // would overwrite the parameters specified in job setting. The JSON + // representation of this field (for example `{"python_params":["john + // doe","35"]}`) cannot exceed 10,000 bytes. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // Important + // + // These parameters accept only Latin characters (ASCII character set). + // Using non-ASCII characters returns an error. Examples of invalid, + // non-ASCII characters are Chinese, Japanese kanjis, and emojis. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + PythonParams []types.String `tfsdk:"python_params" tf:"optional"` + // A list of parameters for jobs with spark submit task, for example + // `"spark_submit_params": ["--class", + // "org.apache.spark.examples.SparkPi"]`. The parameters are passed to + // spark-submit script as command-line parameters. If specified upon + // `run-now`, it would overwrite the parameters specified in job setting. + // The JSON representation of this field (for example + // `{"python_params":["john doe","35"]}`) cannot exceed 10,000 bytes. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs + // + // Important + // + // These parameters accept only Latin characters (ASCII character set). + // Using non-ASCII characters returns an error. Examples of invalid, + // non-ASCII characters are Chinese, Japanese kanjis, and emojis. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + SparkSubmitParams []types.String `tfsdk:"spark_submit_params" tf:"optional"` + // A map from keys to values for jobs with SQL task, for example + // `"sql_params": {"name": "john doe", "age": "35"}`. The SQL alert task + // does not support custom parameters. + SqlParams map[string]types.String `tfsdk:"sql_params" tf:"optional"` +} + +// The current state of the run. +type RunState struct { + // A value indicating the run's current lifecycle state. This field is + // always available in the response. + LifeCycleState types.String `tfsdk:"life_cycle_state" tf:"optional"` + // The reason indicating why the run was queued. + QueueReason types.String `tfsdk:"queue_reason" tf:"optional"` + // A value indicating the run's result. This field is only available for + // terminal lifecycle states. + ResultState types.String `tfsdk:"result_state" tf:"optional"` + // A descriptive message for the current state. This field is unstructured, + // and its exact format is subject to change. + StateMessage types.String `tfsdk:"state_message" tf:"optional"` + // A value indicating whether a run was canceled manually by a user or by + // the scheduler because the run timed out. + UserCancelledOrTimedout types.Bool `tfsdk:"user_cancelled_or_timedout" tf:"optional"` +} + +// Used when outputting a child run, in GetRun or ListRuns. +type RunTask struct { + // The sequence number of this run attempt for a triggered job run. The + // initial attempt of a run has an attempt_number of 0\. If the initial run + // attempt fails, and the job has a retry policy (`max_retries` \> 0), + // subsequent runs are created with an `original_attempt_run_id` of the + // original attempt’s ID and an incrementing `attempt_number`. Runs are + // retried only until they succeed, and the maximum `attempt_number` is the + // same as the `max_retries` value for the job. + AttemptNumber types.Int64 `tfsdk:"attempt_number" tf:"optional"` + // The time in milliseconds it took to terminate the cluster and clean up + // any associated artifacts. The duration of a task run is the sum of the + // `setup_duration`, `execution_duration`, and the `cleanup_duration`. The + // `cleanup_duration` field is set to 0 for multitask job runs. The total + // duration of a multitask job run is the value of the `run_duration` field. + CleanupDuration types.Int64 `tfsdk:"cleanup_duration" tf:"optional"` + // The cluster used for this run. If the run is specified to use a new + // cluster, this field is set once the Jobs service has requested a cluster + // for the run. + ClusterInstance *ClusterInstance `tfsdk:"cluster_instance" tf:"optional"` + // If condition_task, specifies a condition with an outcome that can be used + // to control the execution of other tasks. Does not require a cluster to + // execute and does not support retries or notifications. + ConditionTask *RunConditionTask `tfsdk:"condition_task" tf:"optional"` + // If dbt_task, indicates that this must execute a dbt task. It requires + // both Databricks SQL and the ability to use a serverless or a pro SQL + // warehouse. + DbtTask *DbtTask `tfsdk:"dbt_task" tf:"optional"` + // An optional array of objects specifying the dependency graph of the task. + // All tasks specified in this field must complete successfully before + // executing this task. The key is `task_key`, and the value is the name + // assigned to the dependent task. + DependsOn []TaskDependency `tfsdk:"depends_on" tf:"optional"` + // An optional description for this task. + Description types.String `tfsdk:"description" tf:"optional"` + // An optional set of email addresses notified when the task run begins or + // completes. The default behavior is to not send any emails. + EmailNotifications *JobEmailNotifications `tfsdk:"email_notifications" tf:"optional"` + // The time at which this run ended in epoch milliseconds (milliseconds + // since 1/1/1970 UTC). This field is set to 0 if the job is still running. + EndTime types.Int64 `tfsdk:"end_time" tf:"optional"` + // The key that references an environment spec in a job. This field is + // required for Python script, Python wheel and dbt tasks when using + // serverless compute. + EnvironmentKey types.String `tfsdk:"environment_key" tf:"optional"` + // The time in milliseconds it took to execute the commands in the JAR or + // notebook until they completed, failed, timed out, were cancelled, or + // encountered an unexpected error. The duration of a task run is the sum of + // the `setup_duration`, `execution_duration`, and the `cleanup_duration`. + // The `execution_duration` field is set to 0 for multitask job runs. The + // total duration of a multitask job run is the value of the `run_duration` + // field. + ExecutionDuration types.Int64 `tfsdk:"execution_duration" tf:"optional"` + // If existing_cluster_id, the ID of an existing cluster that is used for + // all runs. When running jobs or tasks on an existing cluster, you may need + // to manually restart the cluster if it stops responding. We suggest + // running jobs and tasks on new clusters for greater reliability + ExistingClusterId types.String `tfsdk:"existing_cluster_id" tf:"optional"` + // If for_each_task, indicates that this task must execute the nested task + // within it. + ForEachTask *RunForEachTask `tfsdk:"for_each_task" tf:"optional"` + // An optional specification for a remote Git repository containing the + // source code used by tasks. Version-controlled source code is supported by + // notebook, dbt, Python script, and SQL File tasks. If `git_source` is set, + // these tasks retrieve the file from the remote repository by default. + // However, this behavior can be overridden by setting `source` to + // `WORKSPACE` on the task. Note: dbt and SQL File tasks support only + // version-controlled sources. If dbt or SQL File tasks are used, + // `git_source` must be defined on the job. + GitSource *GitSource `tfsdk:"git_source" tf:"optional"` + // If job_cluster_key, this task is executed reusing the cluster specified + // in `job.settings.job_clusters`. + JobClusterKey types.String `tfsdk:"job_cluster_key" tf:"optional"` + // An optional list of libraries to be installed on the cluster. The default + // value is an empty list. + Libraries []compute.Library `tfsdk:"libraries" tf:"optional"` + // If new_cluster, a description of a new cluster that is created for each + // run. + NewCluster *compute.ClusterSpec `tfsdk:"new_cluster" tf:"optional"` + // If notebook_task, indicates that this task must run a notebook. This + // field may not be specified in conjunction with spark_jar_task. + NotebookTask *NotebookTask `tfsdk:"notebook_task" tf:"optional"` + // Optional notification settings that are used when sending notifications + // to each of the `email_notifications` and `webhook_notifications` for this + // task run. + NotificationSettings *TaskNotificationSettings `tfsdk:"notification_settings" tf:"optional"` + // If pipeline_task, indicates that this task must execute a Pipeline. + PipelineTask *PipelineTask `tfsdk:"pipeline_task" tf:"optional"` + // If python_wheel_task, indicates that this job must execute a PythonWheel. + PythonWheelTask *PythonWheelTask `tfsdk:"python_wheel_task" tf:"optional"` + // The time in milliseconds that the run has spent in the queue. + QueueDuration types.Int64 `tfsdk:"queue_duration" tf:"optional"` + // Parameter values including resolved references + ResolvedValues *ResolvedValues `tfsdk:"resolved_values" tf:"optional"` + // The time in milliseconds it took the job run and all of its repairs to + // finish. + RunDuration types.Int64 `tfsdk:"run_duration" tf:"optional"` + // The ID of the task run. + RunId types.Int64 `tfsdk:"run_id" tf:"optional"` + // An optional value indicating the condition that determines whether the + // task should be run once its dependencies have been completed. When + // omitted, defaults to `ALL_SUCCESS`. See :method:jobs/create for a list of + // possible values. + RunIf types.String `tfsdk:"run_if" tf:"optional"` + // If run_job_task, indicates that this task must execute another job. + RunJobTask *RunJobTask `tfsdk:"run_job_task" tf:"optional"` + + RunPageUrl types.String `tfsdk:"run_page_url" tf:"optional"` + // The time in milliseconds it took to set up the cluster. For runs that run + // on new clusters this is the cluster creation time, for runs that run on + // existing clusters this time should be very short. The duration of a task + // run is the sum of the `setup_duration`, `execution_duration`, and the + // `cleanup_duration`. The `setup_duration` field is set to 0 for multitask + // job runs. The total duration of a multitask job run is the value of the + // `run_duration` field. + SetupDuration types.Int64 `tfsdk:"setup_duration" tf:"optional"` + // If spark_jar_task, indicates that this task must run a JAR. + SparkJarTask *SparkJarTask `tfsdk:"spark_jar_task" tf:"optional"` + // If spark_python_task, indicates that this task must run a Python file. + SparkPythonTask *SparkPythonTask `tfsdk:"spark_python_task" tf:"optional"` + // If `spark_submit_task`, indicates that this task must be launched by the + // spark submit script. This task can run only on new clusters. + // + // In the `new_cluster` specification, `libraries` and `spark_conf` are not + // supported. Instead, use `--jars` and `--py-files` to add Java and Python + // libraries and `--conf` to set the Spark configurations. + // + // `master`, `deploy-mode`, and `executor-cores` are automatically + // configured by Databricks; you _cannot_ specify them in parameters. + // + // By default, the Spark submit job uses all available memory (excluding + // reserved memory for Databricks services). You can set `--driver-memory`, + // and `--executor-memory` to a smaller value to leave some room for + // off-heap usage. + // + // The `--jars`, `--py-files`, `--files` arguments support DBFS and S3 + // paths. + SparkSubmitTask *SparkSubmitTask `tfsdk:"spark_submit_task" tf:"optional"` + // If sql_task, indicates that this job must execute a SQL task. + SqlTask *SqlTask `tfsdk:"sql_task" tf:"optional"` + // The time at which this run was started in epoch milliseconds + // (milliseconds since 1/1/1970 UTC). This may not be the time when the job + // task starts executing, for example, if the job is scheduled to run on a + // new cluster, this is the time the cluster creation call is issued. + StartTime types.Int64 `tfsdk:"start_time" tf:"optional"` + // The current state of the run. + State *RunState `tfsdk:"state" tf:"optional"` + // A unique name for the task. This field is used to refer to this task from + // other tasks. This field is required and must be unique within its parent + // job. On Update or Reset, this field is used to reference the tasks to be + // updated or reset. + TaskKey types.String `tfsdk:"task_key" tf:""` + // An optional timeout applied to each run of this job task. A value of `0` + // means no timeout. + TimeoutSeconds types.Int64 `tfsdk:"timeout_seconds" tf:"optional"` + // A collection of system notification IDs to notify when the run begins or + // completes. The default behavior is to not send any system notifications. + // Task webhooks respect the task notification settings. + WebhookNotifications *WebhookNotifications `tfsdk:"webhook_notifications" tf:"optional"` +} + +type SparkJarTask struct { + // Deprecated since 04/2016. Provide a `jar` through the `libraries` field + // instead. For an example, see :method:jobs/create. + JarUri types.String `tfsdk:"jar_uri" tf:"optional"` + // The full name of the class containing the main method to be executed. + // This class must be contained in a JAR provided as a library. + // + // The code must use `SparkContext.getOrCreate` to obtain a Spark context; + // otherwise, runs of the job fail. + MainClassName types.String `tfsdk:"main_class_name" tf:"optional"` + // Parameters passed to the main method. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + Parameters []types.String `tfsdk:"parameters" tf:"optional"` +} + +type SparkPythonTask struct { + // Command line parameters passed to the Python file. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + Parameters []types.String `tfsdk:"parameters" tf:"optional"` + // The Python file to be executed. Cloud file URIs (such as dbfs:/, s3:/, + // adls:/, gcs:/) and workspace paths are supported. For python files stored + // in the Databricks workspace, the path must be absolute and begin with + // `/`. For files stored in a remote repository, the path must be relative. + // This field is required. + PythonFile types.String `tfsdk:"python_file" tf:""` + // Optional location type of the Python file. When set to `WORKSPACE` or not + // specified, the file will be retrieved from the local Databricks workspace + // or cloud location (if the `python_file` has a URI format). When set to + // `GIT`, the Python file will be retrieved from a Git repository defined in + // `git_source`. + // + // * `WORKSPACE`: The Python file is located in a Databricks workspace or at + // a cloud filesystem URI. * `GIT`: The Python file is located in a remote + // Git repository. + Source types.String `tfsdk:"source" tf:"optional"` +} + +type SparkSubmitTask struct { + // Command-line parameters passed to spark submit. + // + // Use [Task parameter variables] to set parameters containing information + // about job runs. + // + // [Task parameter variables]: https://docs.databricks.com/jobs.html#parameter-variables + Parameters []types.String `tfsdk:"parameters" tf:"optional"` +} + +type SqlAlertOutput struct { + // The state of the SQL alert. + // + // * UNKNOWN: alert yet to be evaluated * OK: alert evaluated and did not + // fulfill trigger conditions * TRIGGERED: alert evaluated and fulfilled + // trigger conditions + AlertState types.String `tfsdk:"alert_state" tf:"optional"` + // The link to find the output results. + OutputLink types.String `tfsdk:"output_link" tf:"optional"` + // The text of the SQL query. Can Run permission of the SQL query associated + // with the SQL alert is required to view this field. + QueryText types.String `tfsdk:"query_text" tf:"optional"` + // Information about SQL statements executed in the run. + SqlStatements []SqlStatementOutput `tfsdk:"sql_statements" tf:"optional"` + // The canonical identifier of the SQL warehouse. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +type SqlDashboardOutput struct { + // The canonical identifier of the SQL warehouse. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` + // Widgets executed in the run. Only SQL query based widgets are listed. + Widgets []SqlDashboardWidgetOutput `tfsdk:"widgets" tf:"optional"` +} + +type SqlDashboardWidgetOutput struct { + // Time (in epoch milliseconds) when execution of the SQL widget ends. + EndTime types.Int64 `tfsdk:"end_time" tf:"optional"` + // The information about the error when execution fails. + Error *SqlOutputError `tfsdk:"error" tf:"optional"` + // The link to find the output results. + OutputLink types.String `tfsdk:"output_link" tf:"optional"` + // Time (in epoch milliseconds) when execution of the SQL widget starts. + StartTime types.Int64 `tfsdk:"start_time" tf:"optional"` + // The execution status of the SQL widget. + Status types.String `tfsdk:"status" tf:"optional"` + // The canonical identifier of the SQL widget. + WidgetId types.String `tfsdk:"widget_id" tf:"optional"` + // The title of the SQL widget. + WidgetTitle types.String `tfsdk:"widget_title" tf:"optional"` +} + +type SqlOutput struct { + // The output of a SQL alert task, if available. + AlertOutput *SqlAlertOutput `tfsdk:"alert_output" tf:"optional"` + // The output of a SQL dashboard task, if available. + DashboardOutput *SqlDashboardOutput `tfsdk:"dashboard_output" tf:"optional"` + // The output of a SQL query task, if available. + QueryOutput *SqlQueryOutput `tfsdk:"query_output" tf:"optional"` +} + +type SqlOutputError struct { + // The error message when execution fails. + Message types.String `tfsdk:"message" tf:"optional"` +} + +type SqlQueryOutput struct { + EndpointId types.String `tfsdk:"endpoint_id" tf:"optional"` + // The link to find the output results. + OutputLink types.String `tfsdk:"output_link" tf:"optional"` + // The text of the SQL query. Can Run permission of the SQL query is + // required to view this field. + QueryText types.String `tfsdk:"query_text" tf:"optional"` + // Information about SQL statements executed in the run. + SqlStatements []SqlStatementOutput `tfsdk:"sql_statements" tf:"optional"` + // The canonical identifier of the SQL warehouse. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +type SqlStatementOutput struct { + // A key that can be used to look up query details. + LookupKey types.String `tfsdk:"lookup_key" tf:"optional"` +} + +type SqlTask struct { + // If alert, indicates that this job must refresh a SQL alert. + Alert *SqlTaskAlert `tfsdk:"alert" tf:"optional"` + // If dashboard, indicates that this job must refresh a SQL dashboard. + Dashboard *SqlTaskDashboard `tfsdk:"dashboard" tf:"optional"` + // If file, indicates that this job runs a SQL file in a remote Git + // repository. + File *SqlTaskFile `tfsdk:"file" tf:"optional"` + // Parameters to be used for each run of this job. The SQL alert task does + // not support custom parameters. + Parameters map[string]types.String `tfsdk:"parameters" tf:"optional"` + // If query, indicates that this job must execute a SQL query. + Query *SqlTaskQuery `tfsdk:"query" tf:"optional"` + // The canonical identifier of the SQL warehouse. Recommended to use with + // serverless or pro SQL warehouses. Classic SQL warehouses are only + // supported for SQL alert, dashboard and query tasks and are limited to + // scheduled single-task jobs. + WarehouseId types.String `tfsdk:"warehouse_id" tf:""` +} + +type SqlTaskAlert struct { + // The canonical identifier of the SQL alert. + AlertId types.String `tfsdk:"alert_id" tf:""` + // If true, the alert notifications are not sent to subscribers. + PauseSubscriptions types.Bool `tfsdk:"pause_subscriptions" tf:"optional"` + // If specified, alert notifications are sent to subscribers. + Subscriptions []SqlTaskSubscription `tfsdk:"subscriptions" tf:"optional"` +} + +type SqlTaskDashboard struct { + // Subject of the email sent to subscribers of this task. + CustomSubject types.String `tfsdk:"custom_subject" tf:"optional"` + // The canonical identifier of the SQL dashboard. + DashboardId types.String `tfsdk:"dashboard_id" tf:""` + // If true, the dashboard snapshot is not taken, and emails are not sent to + // subscribers. + PauseSubscriptions types.Bool `tfsdk:"pause_subscriptions" tf:"optional"` + // If specified, dashboard snapshots are sent to subscriptions. + Subscriptions []SqlTaskSubscription `tfsdk:"subscriptions" tf:"optional"` +} + +type SqlTaskFile struct { + // Path of the SQL file. Must be relative if the source is a remote Git + // repository and absolute for workspace paths. + Path types.String `tfsdk:"path" tf:""` + // Optional location type of the SQL file. When set to `WORKSPACE`, the SQL + // file will be retrieved from the local Databricks workspace. When set to + // `GIT`, the SQL file will be retrieved from a Git repository defined in + // `git_source`. If the value is empty, the task will use `GIT` if + // `git_source` is defined and `WORKSPACE` otherwise. + // + // * `WORKSPACE`: SQL file is located in Databricks workspace. * `GIT`: SQL + // file is located in cloud Git provider. + Source types.String `tfsdk:"source" tf:"optional"` +} + +type SqlTaskQuery struct { + // The canonical identifier of the SQL query. + QueryId types.String `tfsdk:"query_id" tf:""` +} + +type SqlTaskSubscription struct { + // The canonical identifier of the destination to receive email + // notification. This parameter is mutually exclusive with user_name. You + // cannot set both destination_id and user_name for subscription + // notifications. + DestinationId types.String `tfsdk:"destination_id" tf:"optional"` + // The user name to receive the subscription email. This parameter is + // mutually exclusive with destination_id. You cannot set both + // destination_id and user_name for subscription notifications. + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type SubmitRun struct { + // List of permissions to set on the job. + AccessControlList []iam.AccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // An optional set of email addresses notified when the run begins or + // completes. + EmailNotifications *JobEmailNotifications `tfsdk:"email_notifications" tf:"optional"` + // A list of task execution environment specifications that can be + // referenced by tasks of this run. + Environments []JobEnvironment `tfsdk:"environments" tf:"optional"` + // An optional specification for a remote Git repository containing the + // source code used by tasks. Version-controlled source code is supported by + // notebook, dbt, Python script, and SQL File tasks. + // + // If `git_source` is set, these tasks retrieve the file from the remote + // repository by default. However, this behavior can be overridden by + // setting `source` to `WORKSPACE` on the task. + // + // Note: dbt and SQL File tasks support only version-controlled sources. If + // dbt or SQL File tasks are used, `git_source` must be defined on the job. + GitSource *GitSource `tfsdk:"git_source" tf:"optional"` + // An optional set of health rules that can be defined for this job. + Health *JobsHealthRules `tfsdk:"health" tf:"optional"` + // An optional token that can be used to guarantee the idempotency of job + // run requests. If a run with the provided token already exists, the + // request does not create a new run but returns the ID of the existing run + // instead. If a run with the provided token is deleted, an error is + // returned. + // + // If you specify the idempotency token, upon failure you can retry until + // the request succeeds. Databricks guarantees that exactly one run is + // launched with that idempotency token. + // + // This token must have at most 64 characters. + // + // For more information, see [How to ensure idempotency for jobs]. + // + // [How to ensure idempotency for jobs]: https://kb.databricks.com/jobs/jobs-idempotency.html + IdempotencyToken types.String `tfsdk:"idempotency_token" tf:"optional"` + // Optional notification settings that are used when sending notifications + // to each of the `email_notifications` and `webhook_notifications` for this + // run. + NotificationSettings *JobNotificationSettings `tfsdk:"notification_settings" tf:"optional"` + // The queue settings of the one-time run. + Queue *QueueSettings `tfsdk:"queue" tf:"optional"` + // Specifies the user or service principal that the job runs as. If not + // specified, the job runs as the user who submits the request. + RunAs *JobRunAs `tfsdk:"run_as" tf:"optional"` + // An optional name for the run. The default value is `Untitled`. + RunName types.String `tfsdk:"run_name" tf:"optional"` + + Tasks []SubmitTask `tfsdk:"tasks" tf:"optional"` + // An optional timeout applied to each run of this job. A value of `0` means + // no timeout. + TimeoutSeconds types.Int64 `tfsdk:"timeout_seconds" tf:"optional"` + // A collection of system notification IDs to notify when the run begins or + // completes. + WebhookNotifications *WebhookNotifications `tfsdk:"webhook_notifications" tf:"optional"` +} + +// Run was created and started successfully. +type SubmitRunResponse struct { + // The canonical identifier for the newly submitted run. + RunId types.Int64 `tfsdk:"run_id" tf:"optional"` +} + +type SubmitTask struct { + // If condition_task, specifies a condition with an outcome that can be used + // to control the execution of other tasks. Does not require a cluster to + // execute and does not support retries or notifications. + ConditionTask *ConditionTask `tfsdk:"condition_task" tf:"optional"` + // If dbt_task, indicates that this must execute a dbt task. It requires + // both Databricks SQL and the ability to use a serverless or a pro SQL + // warehouse. + DbtTask *DbtTask `tfsdk:"dbt_task" tf:"optional"` + // An optional array of objects specifying the dependency graph of the task. + // All tasks specified in this field must complete successfully before + // executing this task. The key is `task_key`, and the value is the name + // assigned to the dependent task. + DependsOn []TaskDependency `tfsdk:"depends_on" tf:"optional"` + // An optional description for this task. + Description types.String `tfsdk:"description" tf:"optional"` + // An optional set of email addresses notified when the task run begins or + // completes. The default behavior is to not send any emails. + EmailNotifications *JobEmailNotifications `tfsdk:"email_notifications" tf:"optional"` + // The key that references an environment spec in a job. This field is + // required for Python script, Python wheel and dbt tasks when using + // serverless compute. + EnvironmentKey types.String `tfsdk:"environment_key" tf:"optional"` + // If existing_cluster_id, the ID of an existing cluster that is used for + // all runs. When running jobs or tasks on an existing cluster, you may need + // to manually restart the cluster if it stops responding. We suggest + // running jobs and tasks on new clusters for greater reliability + ExistingClusterId types.String `tfsdk:"existing_cluster_id" tf:"optional"` + // If for_each_task, indicates that this task must execute the nested task + // within it. + ForEachTask *ForEachTask `tfsdk:"for_each_task" tf:"optional"` + // An optional set of health rules that can be defined for this job. + Health *JobsHealthRules `tfsdk:"health" tf:"optional"` + // An optional list of libraries to be installed on the cluster. The default + // value is an empty list. + Libraries []compute.Library `tfsdk:"libraries" tf:"optional"` + // If new_cluster, a description of a new cluster that is created for each + // run. + NewCluster *compute.ClusterSpec `tfsdk:"new_cluster" tf:"optional"` + // If notebook_task, indicates that this task must run a notebook. This + // field may not be specified in conjunction with spark_jar_task. + NotebookTask *NotebookTask `tfsdk:"notebook_task" tf:"optional"` + // Optional notification settings that are used when sending notifications + // to each of the `email_notifications` and `webhook_notifications` for this + // task run. + NotificationSettings *TaskNotificationSettings `tfsdk:"notification_settings" tf:"optional"` + // If pipeline_task, indicates that this task must execute a Pipeline. + PipelineTask *PipelineTask `tfsdk:"pipeline_task" tf:"optional"` + // If python_wheel_task, indicates that this job must execute a PythonWheel. + PythonWheelTask *PythonWheelTask `tfsdk:"python_wheel_task" tf:"optional"` + // An optional value indicating the condition that determines whether the + // task should be run once its dependencies have been completed. When + // omitted, defaults to `ALL_SUCCESS`. See :method:jobs/create for a list of + // possible values. + RunIf types.String `tfsdk:"run_if" tf:"optional"` + // If run_job_task, indicates that this task must execute another job. + RunJobTask *RunJobTask `tfsdk:"run_job_task" tf:"optional"` + // If spark_jar_task, indicates that this task must run a JAR. + SparkJarTask *SparkJarTask `tfsdk:"spark_jar_task" tf:"optional"` + // If spark_python_task, indicates that this task must run a Python file. + SparkPythonTask *SparkPythonTask `tfsdk:"spark_python_task" tf:"optional"` + // If `spark_submit_task`, indicates that this task must be launched by the + // spark submit script. This task can run only on new clusters. + // + // In the `new_cluster` specification, `libraries` and `spark_conf` are not + // supported. Instead, use `--jars` and `--py-files` to add Java and Python + // libraries and `--conf` to set the Spark configurations. + // + // `master`, `deploy-mode`, and `executor-cores` are automatically + // configured by Databricks; you _cannot_ specify them in parameters. + // + // By default, the Spark submit job uses all available memory (excluding + // reserved memory for Databricks services). You can set `--driver-memory`, + // and `--executor-memory` to a smaller value to leave some room for + // off-heap usage. + // + // The `--jars`, `--py-files`, `--files` arguments support DBFS and S3 + // paths. + SparkSubmitTask *SparkSubmitTask `tfsdk:"spark_submit_task" tf:"optional"` + // If sql_task, indicates that this job must execute a SQL task. + SqlTask *SqlTask `tfsdk:"sql_task" tf:"optional"` + // A unique name for the task. This field is used to refer to this task from + // other tasks. This field is required and must be unique within its parent + // job. On Update or Reset, this field is used to reference the tasks to be + // updated or reset. + TaskKey types.String `tfsdk:"task_key" tf:""` + // An optional timeout applied to each run of this job task. A value of `0` + // means no timeout. + TimeoutSeconds types.Int64 `tfsdk:"timeout_seconds" tf:"optional"` + // A collection of system notification IDs to notify when the run begins or + // completes. The default behavior is to not send any system notifications. + // Task webhooks respect the task notification settings. + WebhookNotifications *WebhookNotifications `tfsdk:"webhook_notifications" tf:"optional"` +} + +type TableUpdateTriggerConfiguration struct { + // The table(s) condition based on which to trigger a job run. + Condition types.String `tfsdk:"condition" tf:"optional"` + // If set, the trigger starts a run only after the specified amount of time + // has passed since the last time the trigger fired. The minimum allowed + // value is 60 seconds. + MinTimeBetweenTriggersSeconds types.Int64 `tfsdk:"min_time_between_triggers_seconds" tf:"optional"` + // A list of Delta tables to monitor for changes. The table name must be in + // the format `catalog_name.schema_name.table_name`. + TableNames []types.String `tfsdk:"table_names" tf:"optional"` + // If set, the trigger starts a run only after no table updates have + // occurred for the specified time and can be used to wait for a series of + // table updates before triggering a run. The minimum allowed value is 60 + // seconds. + WaitAfterLastChangeSeconds types.Int64 `tfsdk:"wait_after_last_change_seconds" tf:"optional"` +} + +type Task struct { + // If condition_task, specifies a condition with an outcome that can be used + // to control the execution of other tasks. Does not require a cluster to + // execute and does not support retries or notifications. + ConditionTask *ConditionTask `tfsdk:"condition_task" tf:"optional"` + // If dbt_task, indicates that this must execute a dbt task. It requires + // both Databricks SQL and the ability to use a serverless or a pro SQL + // warehouse. + DbtTask *DbtTask `tfsdk:"dbt_task" tf:"optional"` + // An optional array of objects specifying the dependency graph of the task. + // All tasks specified in this field must complete before executing this + // task. The task will run only if the `run_if` condition is true. The key + // is `task_key`, and the value is the name assigned to the dependent task. + DependsOn []TaskDependency `tfsdk:"depends_on" tf:"optional"` + // An optional description for this task. + Description types.String `tfsdk:"description" tf:"optional"` + // An option to disable auto optimization in serverless + DisableAutoOptimization types.Bool `tfsdk:"disable_auto_optimization" tf:"optional"` + // An optional set of email addresses that is notified when runs of this + // task begin or complete as well as when this task is deleted. The default + // behavior is to not send any emails. + EmailNotifications *TaskEmailNotifications `tfsdk:"email_notifications" tf:"optional"` + // The key that references an environment spec in a job. This field is + // required for Python script, Python wheel and dbt tasks when using + // serverless compute. + EnvironmentKey types.String `tfsdk:"environment_key" tf:"optional"` + // If existing_cluster_id, the ID of an existing cluster that is used for + // all runs. When running jobs or tasks on an existing cluster, you may need + // to manually restart the cluster if it stops responding. We suggest + // running jobs and tasks on new clusters for greater reliability + ExistingClusterId types.String `tfsdk:"existing_cluster_id" tf:"optional"` + // If for_each_task, indicates that this task must execute the nested task + // within it. + ForEachTask *ForEachTask `tfsdk:"for_each_task" tf:"optional"` + // An optional set of health rules that can be defined for this job. + Health *JobsHealthRules `tfsdk:"health" tf:"optional"` + // If job_cluster_key, this task is executed reusing the cluster specified + // in `job.settings.job_clusters`. + JobClusterKey types.String `tfsdk:"job_cluster_key" tf:"optional"` + // An optional list of libraries to be installed on the cluster. The default + // value is an empty list. + Libraries []compute.Library `tfsdk:"libraries" tf:"optional"` + // An optional maximum number of times to retry an unsuccessful run. A run + // is considered to be unsuccessful if it completes with the `FAILED` + // result_state or `INTERNAL_ERROR` `life_cycle_state`. The value `-1` means + // to retry indefinitely and the value `0` means to never retry. + MaxRetries types.Int64 `tfsdk:"max_retries" tf:"optional"` + // An optional minimal interval in milliseconds between the start of the + // failed run and the subsequent retry run. The default behavior is that + // unsuccessful runs are immediately retried. + MinRetryIntervalMillis types.Int64 `tfsdk:"min_retry_interval_millis" tf:"optional"` + // If new_cluster, a description of a new cluster that is created for each + // run. + NewCluster *compute.ClusterSpec `tfsdk:"new_cluster" tf:"optional"` + // If notebook_task, indicates that this task must run a notebook. This + // field may not be specified in conjunction with spark_jar_task. + NotebookTask *NotebookTask `tfsdk:"notebook_task" tf:"optional"` + // Optional notification settings that are used when sending notifications + // to each of the `email_notifications` and `webhook_notifications` for this + // task. + NotificationSettings *TaskNotificationSettings `tfsdk:"notification_settings" tf:"optional"` + // If pipeline_task, indicates that this task must execute a Pipeline. + PipelineTask *PipelineTask `tfsdk:"pipeline_task" tf:"optional"` + // If python_wheel_task, indicates that this job must execute a PythonWheel. + PythonWheelTask *PythonWheelTask `tfsdk:"python_wheel_task" tf:"optional"` + // An optional policy to specify whether to retry a job when it times out. + // The default behavior is to not retry on timeout. + RetryOnTimeout types.Bool `tfsdk:"retry_on_timeout" tf:"optional"` + // An optional value specifying the condition determining whether the task + // is run once its dependencies have been completed. + // + // * `ALL_SUCCESS`: All dependencies have executed and succeeded * + // `AT_LEAST_ONE_SUCCESS`: At least one dependency has succeeded * + // `NONE_FAILED`: None of the dependencies have failed and at least one was + // executed * `ALL_DONE`: All dependencies have been completed * + // `AT_LEAST_ONE_FAILED`: At least one dependency failed * `ALL_FAILED`: ALl + // dependencies have failed + RunIf types.String `tfsdk:"run_if" tf:"optional"` + // If run_job_task, indicates that this task must execute another job. + RunJobTask *RunJobTask `tfsdk:"run_job_task" tf:"optional"` + // If spark_jar_task, indicates that this task must run a JAR. + SparkJarTask *SparkJarTask `tfsdk:"spark_jar_task" tf:"optional"` + // If spark_python_task, indicates that this task must run a Python file. + SparkPythonTask *SparkPythonTask `tfsdk:"spark_python_task" tf:"optional"` + // If `spark_submit_task`, indicates that this task must be launched by the + // spark submit script. This task can run only on new clusters. + // + // In the `new_cluster` specification, `libraries` and `spark_conf` are not + // supported. Instead, use `--jars` and `--py-files` to add Java and Python + // libraries and `--conf` to set the Spark configurations. + // + // `master`, `deploy-mode`, and `executor-cores` are automatically + // configured by Databricks; you _cannot_ specify them in parameters. + // + // By default, the Spark submit job uses all available memory (excluding + // reserved memory for Databricks services). You can set `--driver-memory`, + // and `--executor-memory` to a smaller value to leave some room for + // off-heap usage. + // + // The `--jars`, `--py-files`, `--files` arguments support DBFS and S3 + // paths. + SparkSubmitTask *SparkSubmitTask `tfsdk:"spark_submit_task" tf:"optional"` + // If sql_task, indicates that this job must execute a SQL task. + SqlTask *SqlTask `tfsdk:"sql_task" tf:"optional"` + // A unique name for the task. This field is used to refer to this task from + // other tasks. This field is required and must be unique within its parent + // job. On Update or Reset, this field is used to reference the tasks to be + // updated or reset. + TaskKey types.String `tfsdk:"task_key" tf:""` + // An optional timeout applied to each run of this job task. A value of `0` + // means no timeout. + TimeoutSeconds types.Int64 `tfsdk:"timeout_seconds" tf:"optional"` + // A collection of system notification IDs to notify when runs of this task + // begin or complete. The default behavior is to not send any system + // notifications. + WebhookNotifications *WebhookNotifications `tfsdk:"webhook_notifications" tf:"optional"` +} + +type TaskDependency struct { + // Can only be specified on condition task dependencies. The outcome of the + // dependent task that must be met for this task to run. + Outcome types.String `tfsdk:"outcome" tf:"optional"` + // The name of the task this task depends on. + TaskKey types.String `tfsdk:"task_key" tf:""` +} + +type TaskEmailNotifications struct { + // If true, do not send email to recipients specified in `on_failure` if the + // run is skipped. + NoAlertForSkippedRuns types.Bool `tfsdk:"no_alert_for_skipped_runs" tf:"optional"` + // A list of email addresses to be notified when the duration of a run + // exceeds the threshold specified for the `RUN_DURATION_SECONDS` metric in + // the `health` field. If no rule for the `RUN_DURATION_SECONDS` metric is + // specified in the `health` field for the job, notifications are not sent. + OnDurationWarningThresholdExceeded []types.String `tfsdk:"on_duration_warning_threshold_exceeded" tf:"optional"` + // A list of email addresses to be notified when a run unsuccessfully + // completes. A run is considered to have completed unsuccessfully if it + // ends with an `INTERNAL_ERROR` `life_cycle_state` or a `FAILED`, or + // `TIMED_OUT` result_state. If this is not specified on job creation, + // reset, or update the list is empty, and notifications are not sent. + OnFailure []types.String `tfsdk:"on_failure" tf:"optional"` + // A list of email addresses to be notified when a run begins. If not + // specified on job creation, reset, or update, the list is empty, and + // notifications are not sent. + OnStart []types.String `tfsdk:"on_start" tf:"optional"` + // A list of email addresses to notify when any streaming backlog thresholds + // are exceeded for any stream. Streaming backlog thresholds can be set in + // the `health` field using the following metrics: + // `STREAMING_BACKLOG_BYTES`, `STREAMING_BACKLOG_RECORDS`, + // `STREAMING_BACKLOG_SECONDS`, or `STREAMING_BACKLOG_FILES`. Alerting is + // based on the 10-minute average of these metrics. If the issue persists, + // notifications are resent every 30 minutes. + OnStreamingBacklogExceeded []types.String `tfsdk:"on_streaming_backlog_exceeded" tf:"optional"` + // A list of email addresses to be notified when a run successfully + // completes. A run is considered to have completed successfully if it ends + // with a `TERMINATED` `life_cycle_state` and a `SUCCESS` result_state. If + // not specified on job creation, reset, or update, the list is empty, and + // notifications are not sent. + OnSuccess []types.String `tfsdk:"on_success" tf:"optional"` +} + +type TaskNotificationSettings struct { + // If true, do not send notifications to recipients specified in `on_start` + // for the retried runs and do not send notifications to recipients + // specified in `on_failure` until the last retry of the run. + AlertOnLastAttempt types.Bool `tfsdk:"alert_on_last_attempt" tf:"optional"` + // If true, do not send notifications to recipients specified in + // `on_failure` if the run is canceled. + NoAlertForCanceledRuns types.Bool `tfsdk:"no_alert_for_canceled_runs" tf:"optional"` + // If true, do not send notifications to recipients specified in + // `on_failure` if the run is skipped. + NoAlertForSkippedRuns types.Bool `tfsdk:"no_alert_for_skipped_runs" tf:"optional"` +} + +// Additional details about what triggered the run +type TriggerInfo struct { + // The run id of the Run Job task run + RunId types.Int64 `tfsdk:"run_id" tf:"optional"` +} + +type TriggerSettings struct { + // File arrival trigger settings. + FileArrival *FileArrivalTriggerConfiguration `tfsdk:"file_arrival" tf:"optional"` + // Whether this trigger is paused or not. + PauseStatus types.String `tfsdk:"pause_status" tf:"optional"` + // Periodic trigger settings. + Periodic *PeriodicTriggerConfiguration `tfsdk:"periodic" tf:"optional"` + // Old table trigger settings name. Deprecated in favor of `table_update`. + Table *TableUpdateTriggerConfiguration `tfsdk:"table" tf:"optional"` + + TableUpdate *TableUpdateTriggerConfiguration `tfsdk:"table_update" tf:"optional"` +} + +type UpdateJob struct { + // Remove top-level fields in the job settings. Removing nested fields is + // not supported, except for tasks and job clusters (`tasks/task_1`). This + // field is optional. + FieldsToRemove []types.String `tfsdk:"fields_to_remove" tf:"optional"` + // The canonical identifier of the job to update. This field is required. + JobId types.Int64 `tfsdk:"job_id" tf:""` + // The new settings for the job. + // + // Top-level fields specified in `new_settings` are completely replaced, + // except for arrays which are merged. That is, new and existing entries are + // completely replaced based on the respective key fields, i.e. `task_key` + // or `job_cluster_key`, while previous entries are kept. + // + // Partially updating nested fields is not supported. + // + // Changes to the field `JobSettings.timeout_seconds` are applied to active + // runs. Changes to other fields are applied to future runs only. + NewSettings *JobSettings `tfsdk:"new_settings" tf:"optional"` +} + +type UpdateResponse struct { +} + +type ViewItem struct { + // Content of the view. + Content types.String `tfsdk:"content" tf:"optional"` + // Name of the view item. In the case of code view, it would be the + // notebook’s name. In the case of dashboard view, it would be the + // dashboard’s name. + Name types.String `tfsdk:"name" tf:"optional"` + // Type of the view item. + Type types.String `tfsdk:"type" tf:"optional"` +} + +type Webhook struct { + Id types.String `tfsdk:"id" tf:""` +} + +type WebhookNotifications struct { + // An optional list of system notification IDs to call when the duration of + // a run exceeds the threshold specified for the `RUN_DURATION_SECONDS` + // metric in the `health` field. A maximum of 3 destinations can be + // specified for the `on_duration_warning_threshold_exceeded` property. + OnDurationWarningThresholdExceeded []Webhook `tfsdk:"on_duration_warning_threshold_exceeded" tf:"optional"` + // An optional list of system notification IDs to call when the run fails. A + // maximum of 3 destinations can be specified for the `on_failure` property. + OnFailure []Webhook `tfsdk:"on_failure" tf:"optional"` + // An optional list of system notification IDs to call when the run starts. + // A maximum of 3 destinations can be specified for the `on_start` property. + OnStart []Webhook `tfsdk:"on_start" tf:"optional"` + // An optional list of system notification IDs to call when any streaming + // backlog thresholds are exceeded for any stream. Streaming backlog + // thresholds can be set in the `health` field using the following metrics: + // `STREAMING_BACKLOG_BYTES`, `STREAMING_BACKLOG_RECORDS`, + // `STREAMING_BACKLOG_SECONDS`, or `STREAMING_BACKLOG_FILES`. Alerting is + // based on the 10-minute average of these metrics. If the issue persists, + // notifications are resent every 30 minutes. A maximum of 3 destinations + // can be specified for the `on_streaming_backlog_exceeded` property. + OnStreamingBacklogExceeded []Webhook `tfsdk:"on_streaming_backlog_exceeded" tf:"optional"` + // An optional list of system notification IDs to call when the run + // completes successfully. A maximum of 3 destinations can be specified for + // the `on_success` property. + OnSuccess []Webhook `tfsdk:"on_success" tf:"optional"` +} diff --git a/internal/service/marketplace_tf/model.go b/internal/service/marketplace_tf/model.go new file mode 100755 index 0000000000..cfdfdd9d44 --- /dev/null +++ b/internal/service/marketplace_tf/model.go @@ -0,0 +1,998 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package marketplace_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type AddExchangeForListingRequest struct { + ExchangeId types.String `tfsdk:"exchange_id" tf:""` + + ListingId types.String `tfsdk:"listing_id" tf:""` +} + +type AddExchangeForListingResponse struct { + ExchangeForListing *ExchangeListing `tfsdk:"exchange_for_listing" tf:"optional"` +} + +// Get one batch of listings. One may specify up to 50 IDs per request. +type BatchGetListingsRequest struct { + Ids []types.String `tfsdk:"-"` +} + +type BatchGetListingsResponse struct { + Listings []Listing `tfsdk:"listings" tf:"optional"` +} + +// Get one batch of providers. One may specify up to 50 IDs per request. +type BatchGetProvidersRequest struct { + Ids []types.String `tfsdk:"-"` +} + +type BatchGetProvidersResponse struct { + Providers []ProviderInfo `tfsdk:"providers" tf:"optional"` +} + +type ConsumerTerms struct { + Version types.String `tfsdk:"version" tf:""` +} + +// contact info for the consumer requesting data or performing a listing +// installation +type ContactInfo struct { + Company types.String `tfsdk:"company" tf:"optional"` + + Email types.String `tfsdk:"email" tf:"optional"` + + FirstName types.String `tfsdk:"first_name" tf:"optional"` + + LastName types.String `tfsdk:"last_name" tf:"optional"` +} + +type CreateExchangeFilterRequest struct { + Filter ExchangeFilter `tfsdk:"filter" tf:""` +} + +type CreateExchangeFilterResponse struct { + FilterId types.String `tfsdk:"filter_id" tf:"optional"` +} + +type CreateExchangeRequest struct { + Exchange Exchange `tfsdk:"exchange" tf:""` +} + +type CreateExchangeResponse struct { + ExchangeId types.String `tfsdk:"exchange_id" tf:"optional"` +} + +type CreateFileRequest struct { + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + + FileParent FileParent `tfsdk:"file_parent" tf:""` + + MarketplaceFileType types.String `tfsdk:"marketplace_file_type" tf:""` + + MimeType types.String `tfsdk:"mime_type" tf:""` +} + +type CreateFileResponse struct { + FileInfo *FileInfo `tfsdk:"file_info" tf:"optional"` + // Pre-signed POST URL to blob storage + UploadUrl types.String `tfsdk:"upload_url" tf:"optional"` +} + +type CreateInstallationRequest struct { + AcceptedConsumerTerms *ConsumerTerms `tfsdk:"accepted_consumer_terms" tf:"optional"` + + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + + ListingId types.String `tfsdk:"-"` + + RecipientType types.String `tfsdk:"recipient_type" tf:"optional"` + // for git repo installations + RepoDetail *RepoInstallation `tfsdk:"repo_detail" tf:"optional"` + + ShareName types.String `tfsdk:"share_name" tf:"optional"` +} + +type CreateListingRequest struct { + Listing Listing `tfsdk:"listing" tf:""` +} + +type CreateListingResponse struct { + ListingId types.String `tfsdk:"listing_id" tf:"optional"` +} + +// Data request messages also creates a lead (maybe) +type CreatePersonalizationRequest struct { + AcceptedConsumerTerms ConsumerTerms `tfsdk:"accepted_consumer_terms" tf:""` + + Comment types.String `tfsdk:"comment" tf:"optional"` + + Company types.String `tfsdk:"company" tf:"optional"` + + FirstName types.String `tfsdk:"first_name" tf:"optional"` + + IntendedUse types.String `tfsdk:"intended_use" tf:""` + + IsFromLighthouse types.Bool `tfsdk:"is_from_lighthouse" tf:"optional"` + + LastName types.String `tfsdk:"last_name" tf:"optional"` + + ListingId types.String `tfsdk:"-"` + + RecipientType types.String `tfsdk:"recipient_type" tf:"optional"` +} + +type CreatePersonalizationRequestResponse struct { + Id types.String `tfsdk:"id" tf:"optional"` +} + +type CreateProviderRequest struct { + Provider ProviderInfo `tfsdk:"provider" tf:""` +} + +type CreateProviderResponse struct { + Id types.String `tfsdk:"id" tf:"optional"` +} + +type DataRefreshInfo struct { + Interval types.Int64 `tfsdk:"interval" tf:""` + + Unit types.String `tfsdk:"unit" tf:""` +} + +// Delete an exchange filter +type DeleteExchangeFilterRequest struct { + Id types.String `tfsdk:"-"` +} + +type DeleteExchangeFilterResponse struct { +} + +// Delete an exchange +type DeleteExchangeRequest struct { + Id types.String `tfsdk:"-"` +} + +type DeleteExchangeResponse struct { +} + +// Delete a file +type DeleteFileRequest struct { + FileId types.String `tfsdk:"-"` +} + +type DeleteFileResponse struct { +} + +// Uninstall from a listing +type DeleteInstallationRequest struct { + InstallationId types.String `tfsdk:"-"` + + ListingId types.String `tfsdk:"-"` +} + +type DeleteInstallationResponse struct { +} + +// Delete a listing +type DeleteListingRequest struct { + Id types.String `tfsdk:"-"` +} + +type DeleteListingResponse struct { +} + +// Delete provider +type DeleteProviderRequest struct { + Id types.String `tfsdk:"-"` +} + +type DeleteProviderResponse struct { +} + +type Exchange struct { + Comment types.String `tfsdk:"comment" tf:"optional"` + + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + + Filters []ExchangeFilter `tfsdk:"filters" tf:"optional"` + + Id types.String `tfsdk:"id" tf:"optional"` + + LinkedListings []ExchangeListing `tfsdk:"linked_listings" tf:"optional"` + + Name types.String `tfsdk:"name" tf:""` + + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type ExchangeFilter struct { + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + + ExchangeId types.String `tfsdk:"exchange_id" tf:""` + + FilterType types.String `tfsdk:"filter_type" tf:""` + + FilterValue types.String `tfsdk:"filter_value" tf:""` + + Id types.String `tfsdk:"id" tf:"optional"` + + Name types.String `tfsdk:"name" tf:"optional"` + + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type ExchangeListing struct { + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + + ExchangeId types.String `tfsdk:"exchange_id" tf:"optional"` + + ExchangeName types.String `tfsdk:"exchange_name" tf:"optional"` + + Id types.String `tfsdk:"id" tf:"optional"` + + ListingId types.String `tfsdk:"listing_id" tf:"optional"` + + ListingName types.String `tfsdk:"listing_name" tf:"optional"` +} + +type FileInfo struct { + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Name displayed to users for applicable files, e.g. embedded notebooks + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + + DownloadLink types.String `tfsdk:"download_link" tf:"optional"` + + FileParent *FileParent `tfsdk:"file_parent" tf:"optional"` + + Id types.String `tfsdk:"id" tf:"optional"` + + MarketplaceFileType types.String `tfsdk:"marketplace_file_type" tf:"optional"` + + MimeType types.String `tfsdk:"mime_type" tf:"optional"` + + Status types.String `tfsdk:"status" tf:"optional"` + // Populated if status is in a failed state with more information on reason + // for the failure. + StatusMessage types.String `tfsdk:"status_message" tf:"optional"` + + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` +} + +type FileParent struct { + FileParentType types.String `tfsdk:"file_parent_type" tf:"optional"` + // TODO make the following fields required + ParentId types.String `tfsdk:"parent_id" tf:"optional"` +} + +// Get an exchange +type GetExchangeRequest struct { + Id types.String `tfsdk:"-"` +} + +type GetExchangeResponse struct { + Exchange *Exchange `tfsdk:"exchange" tf:"optional"` +} + +// Get a file +type GetFileRequest struct { + FileId types.String `tfsdk:"-"` +} + +type GetFileResponse struct { + FileInfo *FileInfo `tfsdk:"file_info" tf:"optional"` +} + +type GetLatestVersionProviderAnalyticsDashboardResponse struct { + // version here is latest logical version of the dashboard template + Version types.Int64 `tfsdk:"version" tf:"optional"` +} + +// Get listing content metadata +type GetListingContentMetadataRequest struct { + ListingId types.String `tfsdk:"-"` + + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type GetListingContentMetadataResponse struct { + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + SharedDataObjects []SharedDataObject `tfsdk:"shared_data_objects" tf:"optional"` +} + +// Get listing +type GetListingRequest struct { + Id types.String `tfsdk:"-"` +} + +type GetListingResponse struct { + Listing *Listing `tfsdk:"listing" tf:"optional"` +} + +// List listings +type GetListingsRequest struct { + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type GetListingsResponse struct { + Listings []Listing `tfsdk:"listings" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// Get the personalization request for a listing +type GetPersonalizationRequestRequest struct { + ListingId types.String `tfsdk:"-"` +} + +type GetPersonalizationRequestResponse struct { + PersonalizationRequests []PersonalizationRequest `tfsdk:"personalization_requests" tf:"optional"` +} + +// Get a provider +type GetProviderRequest struct { + Id types.String `tfsdk:"-"` +} + +type GetProviderResponse struct { + Provider *ProviderInfo `tfsdk:"provider" tf:"optional"` +} + +type Installation struct { + Installation *InstallationDetail `tfsdk:"installation" tf:"optional"` +} + +type InstallationDetail struct { + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + + ErrorMessage types.String `tfsdk:"error_message" tf:"optional"` + + Id types.String `tfsdk:"id" tf:"optional"` + + InstalledOn types.Int64 `tfsdk:"installed_on" tf:"optional"` + + ListingId types.String `tfsdk:"listing_id" tf:"optional"` + + ListingName types.String `tfsdk:"listing_name" tf:"optional"` + + RecipientType types.String `tfsdk:"recipient_type" tf:"optional"` + + RepoName types.String `tfsdk:"repo_name" tf:"optional"` + + RepoPath types.String `tfsdk:"repo_path" tf:"optional"` + + ShareName types.String `tfsdk:"share_name" tf:"optional"` + + Status types.String `tfsdk:"status" tf:"optional"` + + TokenDetail *TokenDetail `tfsdk:"token_detail" tf:"optional"` + + Tokens []TokenInfo `tfsdk:"tokens" tf:"optional"` +} + +// List all installations +type ListAllInstallationsRequest struct { + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type ListAllInstallationsResponse struct { + Installations []InstallationDetail `tfsdk:"installations" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List all personalization requests +type ListAllPersonalizationRequestsRequest struct { + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type ListAllPersonalizationRequestsResponse struct { + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + PersonalizationRequests []PersonalizationRequest `tfsdk:"personalization_requests" tf:"optional"` +} + +// List exchange filters +type ListExchangeFiltersRequest struct { + ExchangeId types.String `tfsdk:"-"` + + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type ListExchangeFiltersResponse struct { + Filters []ExchangeFilter `tfsdk:"filters" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List exchanges for listing +type ListExchangesForListingRequest struct { + ListingId types.String `tfsdk:"-"` + + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type ListExchangesForListingResponse struct { + ExchangeListing []ExchangeListing `tfsdk:"exchange_listing" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List exchanges +type ListExchangesRequest struct { + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type ListExchangesResponse struct { + Exchanges []Exchange `tfsdk:"exchanges" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List files +type ListFilesRequest struct { + FileParent FileParent `tfsdk:"-"` + + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type ListFilesResponse struct { + FileInfos []FileInfo `tfsdk:"file_infos" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List all listing fulfillments +type ListFulfillmentsRequest struct { + ListingId types.String `tfsdk:"-"` + + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type ListFulfillmentsResponse struct { + Fulfillments []ListingFulfillment `tfsdk:"fulfillments" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List installations for a listing +type ListInstallationsRequest struct { + ListingId types.String `tfsdk:"-"` + + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type ListInstallationsResponse struct { + Installations []InstallationDetail `tfsdk:"installations" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List listings for exchange +type ListListingsForExchangeRequest struct { + ExchangeId types.String `tfsdk:"-"` + + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type ListListingsForExchangeResponse struct { + ExchangeListings []ExchangeListing `tfsdk:"exchange_listings" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List listings +type ListListingsRequest struct { + // Matches any of the following asset types + Assets []types.String `tfsdk:"-"` + // Matches any of the following categories + Categories []types.String `tfsdk:"-"` + + IsAscending types.Bool `tfsdk:"-"` + // Filters each listing based on if it is free. + IsFree types.Bool `tfsdk:"-"` + // Filters each listing based on if it is a private exchange. + IsPrivateExchange types.Bool `tfsdk:"-"` + // Filters each listing based on whether it is a staff pick. + IsStaffPick types.Bool `tfsdk:"-"` + + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` + // Matches any of the following provider ids + ProviderIds []types.String `tfsdk:"-"` + // Criteria for sorting the resulting set of listings. + SortBy types.String `tfsdk:"-"` + // Matches any of the following tags + Tags []ListingTag `tfsdk:"-"` +} + +type ListListingsResponse struct { + Listings []Listing `tfsdk:"listings" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +type ListProviderAnalyticsDashboardResponse struct { + // dashboard_id will be used to open Lakeview dashboard. + DashboardId types.String `tfsdk:"dashboard_id" tf:""` + + Id types.String `tfsdk:"id" tf:""` + + Version types.Int64 `tfsdk:"version" tf:"optional"` +} + +// List providers +type ListProvidersRequest struct { + IsFeatured types.Bool `tfsdk:"-"` + + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` +} + +type ListProvidersResponse struct { + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + Providers []ProviderInfo `tfsdk:"providers" tf:"optional"` +} + +type Listing struct { + Detail *ListingDetail `tfsdk:"detail" tf:"optional"` + + Id types.String `tfsdk:"id" tf:"optional"` + // we can not use just ProviderListingSummary since we already have same + // name on entity side of the state + ProviderSummary *ProviderListingSummaryInfo `tfsdk:"provider_summary" tf:"optional"` + // Next Number: 26 + Summary ListingSummary `tfsdk:"summary" tf:""` +} + +type ListingDetail struct { + // Type of assets included in the listing. eg. GIT_REPO, DATA_TABLE, MODEL, + // NOTEBOOK + Assets []types.String `tfsdk:"assets" tf:"optional"` + // The ending date timestamp for when the data spans + CollectionDateEnd types.Int64 `tfsdk:"collection_date_end" tf:"optional"` + // The starting date timestamp for when the data spans + CollectionDateStart types.Int64 `tfsdk:"collection_date_start" tf:"optional"` + // Smallest unit of time in the dataset + CollectionGranularity *DataRefreshInfo `tfsdk:"collection_granularity" tf:"optional"` + // Whether the dataset is free or paid + Cost types.String `tfsdk:"cost" tf:"optional"` + // Where/how the data is sourced + DataSource types.String `tfsdk:"data_source" tf:"optional"` + + Description types.String `tfsdk:"description" tf:"optional"` + + DocumentationLink types.String `tfsdk:"documentation_link" tf:"optional"` + + EmbeddedNotebookFileInfos []FileInfo `tfsdk:"embedded_notebook_file_infos" tf:"optional"` + + FileIds []types.String `tfsdk:"file_ids" tf:"optional"` + // Which geo region the listing data is collected from + GeographicalCoverage types.String `tfsdk:"geographical_coverage" tf:"optional"` + // ID 20, 21 removed don't use License of the data asset - Required for + // listings with model based assets + License types.String `tfsdk:"license" tf:"optional"` + // What the pricing model is (e.g. paid, subscription, paid upfront); should + // only be present if cost is paid TODO: Not used yet, should deprecate if + // we will never use it + PricingModel types.String `tfsdk:"pricing_model" tf:"optional"` + + PrivacyPolicyLink types.String `tfsdk:"privacy_policy_link" tf:"optional"` + // size of the dataset in GB + Size types.Float64 `tfsdk:"size" tf:"optional"` + + SupportLink types.String `tfsdk:"support_link" tf:"optional"` + // Listing tags - Simple key value pair to annotate listings. When should I + // use tags vs dedicated fields? Using tags avoids the need to add new + // columns in the database for new annotations. However, this should be used + // sparingly since tags are stored as key value pair. Use tags only: 1. If + // the field is optional and won't need to have NOT NULL integrity check 2. + // The value is fairly fixed, static and low cardinality (eg. enums). 3. The + // value won't be used in filters or joins with other tables. + Tags []ListingTag `tfsdk:"tags" tf:"optional"` + + TermsOfService types.String `tfsdk:"terms_of_service" tf:"optional"` + // How often data is updated + UpdateFrequency *DataRefreshInfo `tfsdk:"update_frequency" tf:"optional"` +} + +type ListingFulfillment struct { + FulfillmentType types.String `tfsdk:"fulfillment_type" tf:"optional"` + + ListingId types.String `tfsdk:"listing_id" tf:""` + + RecipientType types.String `tfsdk:"recipient_type" tf:"optional"` + + RepoInfo *RepoInfo `tfsdk:"repo_info" tf:"optional"` + + ShareInfo *ShareInfo `tfsdk:"share_info" tf:"optional"` +} + +type ListingSetting struct { + // filters are joined with `or` conjunction. + Filters []VisibilityFilter `tfsdk:"filters" tf:"optional"` + + Visibility types.String `tfsdk:"visibility" tf:"optional"` +} + +// Next Number: 26 +type ListingSummary struct { + Categories []types.String `tfsdk:"categories" tf:"optional"` + + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + + CreatedById types.Int64 `tfsdk:"created_by_id" tf:"optional"` + + ExchangeIds []types.String `tfsdk:"exchange_ids" tf:"optional"` + // if a git repo is being created, a listing will be initialized with this + // field as opposed to a share + GitRepo *RepoInfo `tfsdk:"git_repo" tf:"optional"` + + ListingType types.String `tfsdk:"listingType" tf:""` + + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + + Name types.String `tfsdk:"name" tf:""` + + ProviderId types.String `tfsdk:"provider_id" tf:"optional"` + + ProviderRegion *RegionInfo `tfsdk:"provider_region" tf:"optional"` + + PublishedAt types.Int64 `tfsdk:"published_at" tf:"optional"` + + PublishedBy types.String `tfsdk:"published_by" tf:"optional"` + + Setting *ListingSetting `tfsdk:"setting" tf:"optional"` + + Share *ShareInfo `tfsdk:"share" tf:"optional"` + // Enums + Status types.String `tfsdk:"status" tf:"optional"` + + Subtitle types.String `tfsdk:"subtitle" tf:"optional"` + + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` + + UpdatedById types.Int64 `tfsdk:"updated_by_id" tf:"optional"` +} + +type ListingTag struct { + // Tag name (enum) + TagName types.String `tfsdk:"tag_name" tf:"optional"` + // String representation of the tag value. Values should be string literals + // (no complex types) + TagValues []types.String `tfsdk:"tag_values" tf:"optional"` +} + +type PersonalizationRequest struct { + Comment types.String `tfsdk:"comment" tf:"optional"` + + ConsumerRegion RegionInfo `tfsdk:"consumer_region" tf:""` + // contact info for the consumer requesting data or performing a listing + // installation + ContactInfo *ContactInfo `tfsdk:"contact_info" tf:"optional"` + + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + + Id types.String `tfsdk:"id" tf:"optional"` + + IntendedUse types.String `tfsdk:"intended_use" tf:"optional"` + + IsFromLighthouse types.Bool `tfsdk:"is_from_lighthouse" tf:"optional"` + + ListingId types.String `tfsdk:"listing_id" tf:"optional"` + + ListingName types.String `tfsdk:"listing_name" tf:"optional"` + + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + + ProviderId types.String `tfsdk:"provider_id" tf:"optional"` + + RecipientType types.String `tfsdk:"recipient_type" tf:"optional"` + + Share *ShareInfo `tfsdk:"share" tf:"optional"` + + Status types.String `tfsdk:"status" tf:"optional"` + + StatusMessage types.String `tfsdk:"status_message" tf:"optional"` + + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` +} + +type ProviderAnalyticsDashboard struct { + Id types.String `tfsdk:"id" tf:""` +} + +type ProviderIconFile struct { + IconFileId types.String `tfsdk:"icon_file_id" tf:"optional"` + + IconFilePath types.String `tfsdk:"icon_file_path" tf:"optional"` + + IconType types.String `tfsdk:"icon_type" tf:"optional"` +} + +type ProviderInfo struct { + BusinessContactEmail types.String `tfsdk:"business_contact_email" tf:""` + + CompanyWebsiteLink types.String `tfsdk:"company_website_link" tf:"optional"` + + DarkModeIconFileId types.String `tfsdk:"dark_mode_icon_file_id" tf:"optional"` + + DarkModeIconFilePath types.String `tfsdk:"dark_mode_icon_file_path" tf:"optional"` + + Description types.String `tfsdk:"description" tf:"optional"` + + IconFileId types.String `tfsdk:"icon_file_id" tf:"optional"` + + IconFilePath types.String `tfsdk:"icon_file_path" tf:"optional"` + + Id types.String `tfsdk:"id" tf:"optional"` + // is_featured is accessible by consumers only + IsFeatured types.Bool `tfsdk:"is_featured" tf:"optional"` + + Name types.String `tfsdk:"name" tf:""` + + PrivacyPolicyLink types.String `tfsdk:"privacy_policy_link" tf:""` + // published_by is only applicable to data aggregators (e.g. Crux) + PublishedBy types.String `tfsdk:"published_by" tf:"optional"` + + SupportContactEmail types.String `tfsdk:"support_contact_email" tf:"optional"` + + TermOfServiceLink types.String `tfsdk:"term_of_service_link" tf:""` +} + +// we can not use just ProviderListingSummary since we already have same name on +// entity side of the state +type ProviderListingSummaryInfo struct { + Description types.String `tfsdk:"description" tf:"optional"` + + IconFiles []ProviderIconFile `tfsdk:"icon_files" tf:"optional"` + + Name types.String `tfsdk:"name" tf:"optional"` +} + +type RegionInfo struct { + Cloud types.String `tfsdk:"cloud" tf:"optional"` + + Region types.String `tfsdk:"region" tf:"optional"` +} + +// Remove an exchange for listing +type RemoveExchangeForListingRequest struct { + Id types.String `tfsdk:"-"` +} + +type RemoveExchangeForListingResponse struct { +} + +type RepoInfo struct { + // the git repo url e.g. https://github.com/databrickslabs/dolly.git + GitRepoUrl types.String `tfsdk:"git_repo_url" tf:""` +} + +type RepoInstallation struct { + // the user-specified repo name for their installed git repo listing + RepoName types.String `tfsdk:"repo_name" tf:""` + // refers to the full url file path that navigates the user to the repo's + // entrypoint (e.g. a README.md file, or the repo file view in the unified + // UI) should just be a relative path + RepoPath types.String `tfsdk:"repo_path" tf:""` +} + +// Search listings +type SearchListingsRequest struct { + // Matches any of the following asset types + Assets []types.String `tfsdk:"-"` + // Matches any of the following categories + Categories []types.String `tfsdk:"-"` + + IsAscending types.Bool `tfsdk:"-"` + + IsFree types.Bool `tfsdk:"-"` + + IsPrivateExchange types.Bool `tfsdk:"-"` + + PageSize types.Int64 `tfsdk:"-"` + + PageToken types.String `tfsdk:"-"` + // Matches any of the following provider ids + ProviderIds []types.String `tfsdk:"-"` + // Fuzzy matches query + Query types.String `tfsdk:"-"` + + SortBy types.String `tfsdk:"-"` +} + +type SearchListingsResponse struct { + Listings []Listing `tfsdk:"listings" tf:"optional"` + + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +type ShareInfo struct { + Name types.String `tfsdk:"name" tf:""` + + Type types.String `tfsdk:"type" tf:""` +} + +type SharedDataObject struct { + // The type of the data object. Could be one of: TABLE, SCHEMA, + // NOTEBOOK_FILE, MODEL, VOLUME + DataObjectType types.String `tfsdk:"data_object_type" tf:"optional"` + // Name of the shared object + Name types.String `tfsdk:"name" tf:"optional"` +} + +type TokenDetail struct { + BearerToken types.String `tfsdk:"bearerToken" tf:"optional"` + + Endpoint types.String `tfsdk:"endpoint" tf:"optional"` + + ExpirationTime types.String `tfsdk:"expirationTime" tf:"optional"` + // These field names must follow the delta sharing protocol. Original + // message: RetrieveToken.Response in + // managed-catalog/api/messages/recipient.proto + ShareCredentialsVersion types.Int64 `tfsdk:"shareCredentialsVersion" tf:"optional"` +} + +type TokenInfo struct { + // Full activation url to retrieve the access token. It will be empty if the + // token is already retrieved. + ActivationUrl types.String `tfsdk:"activation_url" tf:"optional"` + // Time at which this Recipient Token was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of Recipient Token creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Expiration timestamp of the token in epoch milliseconds. + ExpirationTime types.Int64 `tfsdk:"expiration_time" tf:"optional"` + // Unique id of the Recipient Token. + Id types.String `tfsdk:"id" tf:"optional"` + // Time at which this Recipient Token was updated, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of Recipient Token updater. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type UpdateExchangeFilterRequest struct { + Filter ExchangeFilter `tfsdk:"filter" tf:""` + + Id types.String `tfsdk:"-"` +} + +type UpdateExchangeFilterResponse struct { + Filter *ExchangeFilter `tfsdk:"filter" tf:"optional"` +} + +type UpdateExchangeRequest struct { + Exchange Exchange `tfsdk:"exchange" tf:""` + + Id types.String `tfsdk:"-"` +} + +type UpdateExchangeResponse struct { + Exchange *Exchange `tfsdk:"exchange" tf:"optional"` +} + +type UpdateInstallationRequest struct { + Installation InstallationDetail `tfsdk:"installation" tf:""` + + InstallationId types.String `tfsdk:"-"` + + ListingId types.String `tfsdk:"-"` + + RotateToken types.Bool `tfsdk:"rotate_token" tf:"optional"` +} + +type UpdateInstallationResponse struct { + Installation *InstallationDetail `tfsdk:"installation" tf:"optional"` +} + +type UpdateListingRequest struct { + Id types.String `tfsdk:"-"` + + Listing Listing `tfsdk:"listing" tf:""` +} + +type UpdateListingResponse struct { + Listing *Listing `tfsdk:"listing" tf:"optional"` +} + +type UpdatePersonalizationRequestRequest struct { + ListingId types.String `tfsdk:"-"` + + Reason types.String `tfsdk:"reason" tf:"optional"` + + RequestId types.String `tfsdk:"-"` + + Share *ShareInfo `tfsdk:"share" tf:"optional"` + + Status types.String `tfsdk:"status" tf:""` +} + +type UpdatePersonalizationRequestResponse struct { + Request *PersonalizationRequest `tfsdk:"request" tf:"optional"` +} + +type UpdateProviderAnalyticsDashboardRequest struct { + // id is immutable property and can't be updated. + Id types.String `tfsdk:"-"` + // this is the version of the dashboard template we want to update our user + // to current expectation is that it should be equal to latest version of + // the dashboard template + Version types.Int64 `tfsdk:"version" tf:"optional"` +} + +type UpdateProviderAnalyticsDashboardResponse struct { + // this is newly created Lakeview dashboard for the user + DashboardId types.String `tfsdk:"dashboard_id" tf:""` + // id & version should be the same as the request + Id types.String `tfsdk:"id" tf:""` + + Version types.Int64 `tfsdk:"version" tf:"optional"` +} + +type UpdateProviderRequest struct { + Id types.String `tfsdk:"-"` + + Provider ProviderInfo `tfsdk:"provider" tf:""` +} + +type UpdateProviderResponse struct { + Provider *ProviderInfo `tfsdk:"provider" tf:"optional"` +} + +type VisibilityFilter struct { + FilterType types.String `tfsdk:"filterType" tf:"optional"` + + FilterValue types.String `tfsdk:"filterValue" tf:"optional"` +} diff --git a/internal/service/ml_tf/model.go b/internal/service/ml_tf/model.go new file mode 100755 index 0000000000..1d7a2d71fe --- /dev/null +++ b/internal/service/ml_tf/model.go @@ -0,0 +1,1664 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package ml_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +// Activity recorded for the action. +type Activity struct { + // Type of activity. Valid values are: * `APPLIED_TRANSITION`: User applied + // the corresponding stage transition. + // + // * `REQUESTED_TRANSITION`: User requested the corresponding stage + // transition. + // + // * `CANCELLED_REQUEST`: User cancelled an existing transition request. + // + // * `APPROVED_REQUEST`: User approved the corresponding stage transition. + // + // * `REJECTED_REQUEST`: User rejected the coressponding stage transition. + // + // * `SYSTEM_TRANSITION`: For events performed as a side effect, such as + // archiving existing model versions in a stage. + ActivityType types.String `tfsdk:"activity_type" tf:"optional"` + // User-provided comment associated with the activity. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Creation time of the object, as a Unix timestamp in milliseconds. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // Source stage of the transition (if the activity is stage transition + // related). Valid values are: + // + // * `None`: The initial stage of a model version. + // + // * `Staging`: Staging or pre-production stage. + // + // * `Production`: Production stage. + // + // * `Archived`: Archived stage. + FromStage types.String `tfsdk:"from_stage" tf:"optional"` + // Unique identifier for the object. + Id types.String `tfsdk:"id" tf:"optional"` + // Time of the object at last update, as a Unix timestamp in milliseconds. + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` + // Comment made by system, for example explaining an activity of type + // `SYSTEM_TRANSITION`. It usually describes a side effect, such as a + // version being archived as part of another version's stage transition, and + // may not be returned for some activity types. + SystemComment types.String `tfsdk:"system_comment" tf:"optional"` + // Target stage of the transition (if the activity is stage transition + // related). Valid values are: + // + // * `None`: The initial stage of a model version. + // + // * `Staging`: Staging or pre-production stage. + // + // * `Production`: Production stage. + // + // * `Archived`: Archived stage. + ToStage types.String `tfsdk:"to_stage" tf:"optional"` + // The username of the user that created the object. + UserId types.String `tfsdk:"user_id" tf:"optional"` +} + +type ApproveTransitionRequest struct { + // Specifies whether to archive all current model versions in the target + // stage. + ArchiveExistingVersions types.Bool `tfsdk:"archive_existing_versions" tf:""` + // User-provided comment on the action. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of the model. + Name types.String `tfsdk:"name" tf:""` + // Target stage of the transition. Valid values are: + // + // * `None`: The initial stage of a model version. + // + // * `Staging`: Staging or pre-production stage. + // + // * `Production`: Production stage. + // + // * `Archived`: Archived stage. + Stage types.String `tfsdk:"stage" tf:""` + // Version of the model. + Version types.String `tfsdk:"version" tf:""` +} + +type ApproveTransitionRequestResponse struct { + // Activity recorded for the action. + Activity *Activity `tfsdk:"activity" tf:"optional"` +} + +// Comment details. +type CommentObject struct { + // Array of actions on the activity allowed for the current viewer. + AvailableActions []types.String `tfsdk:"available_actions" tf:"optional"` + // User-provided comment on the action. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Creation time of the object, as a Unix timestamp in milliseconds. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // Comment ID + Id types.String `tfsdk:"id" tf:"optional"` + // Time of the object at last update, as a Unix timestamp in milliseconds. + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` + // The username of the user that created the object. + UserId types.String `tfsdk:"user_id" tf:"optional"` +} + +type CreateComment struct { + // User-provided comment on the action. + Comment types.String `tfsdk:"comment" tf:""` + // Name of the model. + Name types.String `tfsdk:"name" tf:""` + // Version of the model. + Version types.String `tfsdk:"version" tf:""` +} + +type CreateCommentResponse struct { + // Comment details. + Comment *CommentObject `tfsdk:"comment" tf:"optional"` +} + +type CreateExperiment struct { + // Location where all artifacts for the experiment are stored. If not + // provided, the remote server will select an appropriate default. + ArtifactLocation types.String `tfsdk:"artifact_location" tf:"optional"` + // Experiment name. + Name types.String `tfsdk:"name" tf:""` + // A collection of tags to set on the experiment. Maximum tag size and + // number of tags per request depends on the storage backend. All storage + // backends are guaranteed to support tag keys up to 250 bytes in size and + // tag values up to 5000 bytes in size. All storage backends are also + // guaranteed to support up to 20 tags per request. + Tags []ExperimentTag `tfsdk:"tags" tf:"optional"` +} + +type CreateExperimentResponse struct { + // Unique identifier for the experiment. + ExperimentId types.String `tfsdk:"experiment_id" tf:"optional"` +} + +type CreateModelRequest struct { + // Optional description for registered model. + Description types.String `tfsdk:"description" tf:"optional"` + // Register models under this name + Name types.String `tfsdk:"name" tf:""` + // Additional metadata for registered model. + Tags []ModelTag `tfsdk:"tags" tf:"optional"` +} + +type CreateModelResponse struct { + RegisteredModel *Model `tfsdk:"registered_model" tf:"optional"` +} + +type CreateModelVersionRequest struct { + // Optional description for model version. + Description types.String `tfsdk:"description" tf:"optional"` + // Register model under this name + Name types.String `tfsdk:"name" tf:""` + // MLflow run ID for correlation, if `source` was generated by an experiment + // run in MLflow tracking server + RunId types.String `tfsdk:"run_id" tf:"optional"` + // MLflow run link - this is the exact link of the run that generated this + // model version, potentially hosted at another instance of MLflow. + RunLink types.String `tfsdk:"run_link" tf:"optional"` + // URI indicating the location of the model artifacts. + Source types.String `tfsdk:"source" tf:""` + // Additional metadata for model version. + Tags []ModelVersionTag `tfsdk:"tags" tf:"optional"` +} + +type CreateModelVersionResponse struct { + // Return new version number generated for this model in registry. + ModelVersion *ModelVersion `tfsdk:"model_version" tf:"optional"` +} + +type CreateRegistryWebhook struct { + // User-specified description for the webhook. + Description types.String `tfsdk:"description" tf:"optional"` + // Events that can trigger a registry webhook: * `MODEL_VERSION_CREATED`: A + // new model version was created for the associated model. + // + // * `MODEL_VERSION_TRANSITIONED_STAGE`: A model version’s stage was + // changed. + // + // * `TRANSITION_REQUEST_CREATED`: A user requested a model version’s + // stage be transitioned. + // + // * `COMMENT_CREATED`: A user wrote a comment on a registered model. + // + // * `REGISTERED_MODEL_CREATED`: A new registered model was created. This + // event type can only be specified for a registry-wide webhook, which can + // be created by not specifying a model name in the create request. + // + // * `MODEL_VERSION_TAG_SET`: A user set a tag on the model version. + // + // * `MODEL_VERSION_TRANSITIONED_TO_STAGING`: A model version was + // transitioned to staging. + // + // * `MODEL_VERSION_TRANSITIONED_TO_PRODUCTION`: A model version was + // transitioned to production. + // + // * `MODEL_VERSION_TRANSITIONED_TO_ARCHIVED`: A model version was archived. + // + // * `TRANSITION_REQUEST_TO_STAGING_CREATED`: A user requested a model + // version be transitioned to staging. + // + // * `TRANSITION_REQUEST_TO_PRODUCTION_CREATED`: A user requested a model + // version be transitioned to production. + // + // * `TRANSITION_REQUEST_TO_ARCHIVED_CREATED`: A user requested a model + // version be archived. + Events []types.String `tfsdk:"events" tf:""` + + HttpUrlSpec *HttpUrlSpec `tfsdk:"http_url_spec" tf:"optional"` + + JobSpec *JobSpec `tfsdk:"job_spec" tf:"optional"` + // Name of the model whose events would trigger this webhook. + ModelName types.String `tfsdk:"model_name" tf:"optional"` + // Enable or disable triggering the webhook, or put the webhook into test + // mode. The default is `ACTIVE`: * `ACTIVE`: Webhook is triggered when an + // associated event happens. + // + // * `DISABLED`: Webhook is not triggered. + // + // * `TEST_MODE`: Webhook can be triggered through the test endpoint, but is + // not triggered on a real event. + Status types.String `tfsdk:"status" tf:"optional"` +} + +type CreateRun struct { + // ID of the associated experiment. + ExperimentId types.String `tfsdk:"experiment_id" tf:"optional"` + // Unix timestamp in milliseconds of when the run started. + StartTime types.Int64 `tfsdk:"start_time" tf:"optional"` + // Additional metadata for run. + Tags []RunTag `tfsdk:"tags" tf:"optional"` + // ID of the user executing the run. This field is deprecated as of MLflow + // 1.0, and will be removed in a future MLflow release. Use 'mlflow.user' + // tag instead. + UserId types.String `tfsdk:"user_id" tf:"optional"` +} + +type CreateRunResponse struct { + // The newly created run. + Run *Run `tfsdk:"run" tf:"optional"` +} + +type CreateTransitionRequest struct { + // User-provided comment on the action. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of the model. + Name types.String `tfsdk:"name" tf:""` + // Target stage of the transition. Valid values are: + // + // * `None`: The initial stage of a model version. + // + // * `Staging`: Staging or pre-production stage. + // + // * `Production`: Production stage. + // + // * `Archived`: Archived stage. + Stage types.String `tfsdk:"stage" tf:""` + // Version of the model. + Version types.String `tfsdk:"version" tf:""` +} + +type CreateTransitionRequestResponse struct { + // Transition request details. + Request *TransitionRequest `tfsdk:"request" tf:"optional"` +} + +type CreateWebhookResponse struct { + Webhook *RegistryWebhook `tfsdk:"webhook" tf:"optional"` +} + +type Dataset struct { + // Dataset digest, e.g. an md5 hash of the dataset that uniquely identifies + // it within datasets of the same name. + Digest types.String `tfsdk:"digest" tf:"optional"` + // The name of the dataset. E.g. “my.uc.table@2” “nyc-taxi-dataset”, + // “fantastic-elk-3” + Name types.String `tfsdk:"name" tf:"optional"` + // The profile of the dataset. Summary statistics for the dataset, such as + // the number of rows in a table, the mean / std / mode of each column in a + // table, or the number of elements in an array. + Profile types.String `tfsdk:"profile" tf:"optional"` + // The schema of the dataset. E.g., MLflow ColSpec JSON for a dataframe, + // MLflow TensorSpec JSON for an ndarray, or another schema format. + Schema types.String `tfsdk:"schema" tf:"optional"` + // The type of the dataset source, e.g. ‘databricks-uc-table’, + // ‘DBFS’, ‘S3’, ... + Source types.String `tfsdk:"source" tf:"optional"` + // Source information for the dataset. Note that the source may not exactly + // reproduce the dataset if it was transformed / modified before use with + // MLflow. + SourceType types.String `tfsdk:"source_type" tf:"optional"` +} + +type DatasetInput struct { + // The dataset being used as a Run input. + Dataset *Dataset `tfsdk:"dataset" tf:"optional"` + // A list of tags for the dataset input, e.g. a “context” tag with value + // “training” + Tags []InputTag `tfsdk:"tags" tf:"optional"` +} + +// Delete a comment +type DeleteCommentRequest struct { + Id types.String `tfsdk:"-"` +} + +type DeleteCommentResponse struct { +} + +type DeleteExperiment struct { + // ID of the associated experiment. + ExperimentId types.String `tfsdk:"experiment_id" tf:""` +} + +type DeleteExperimentResponse struct { +} + +// Delete a model +type DeleteModelRequest struct { + // Registered model unique name identifier. + Name types.String `tfsdk:"-"` +} + +type DeleteModelResponse struct { +} + +// Delete a model tag +type DeleteModelTagRequest struct { + // Name of the tag. The name must be an exact match; wild-card deletion is + // not supported. Maximum size is 250 bytes. + Key types.String `tfsdk:"-"` + // Name of the registered model that the tag was logged under. + Name types.String `tfsdk:"-"` +} + +type DeleteModelTagResponse struct { +} + +// Delete a model version. +type DeleteModelVersionRequest struct { + // Name of the registered model + Name types.String `tfsdk:"-"` + // Model version number + Version types.String `tfsdk:"-"` +} + +type DeleteModelVersionResponse struct { +} + +// Delete a model version tag +type DeleteModelVersionTagRequest struct { + // Name of the tag. The name must be an exact match; wild-card deletion is + // not supported. Maximum size is 250 bytes. + Key types.String `tfsdk:"-"` + // Name of the registered model that the tag was logged under. + Name types.String `tfsdk:"-"` + // Model version number that the tag was logged under. + Version types.String `tfsdk:"-"` +} + +type DeleteModelVersionTagResponse struct { +} + +type DeleteRun struct { + // ID of the run to delete. + RunId types.String `tfsdk:"run_id" tf:""` +} + +type DeleteRunResponse struct { +} + +type DeleteRuns struct { + // The ID of the experiment containing the runs to delete. + ExperimentId types.String `tfsdk:"experiment_id" tf:""` + // An optional positive integer indicating the maximum number of runs to + // delete. The maximum allowed value for max_runs is 10000. + MaxRuns types.Int64 `tfsdk:"max_runs" tf:"optional"` + // The maximum creation timestamp in milliseconds since the UNIX epoch for + // deleting runs. Only runs created prior to or at this timestamp are + // deleted. + MaxTimestampMillis types.Int64 `tfsdk:"max_timestamp_millis" tf:""` +} + +type DeleteRunsResponse struct { + // The number of runs deleted. + RunsDeleted types.Int64 `tfsdk:"runs_deleted" tf:"optional"` +} + +type DeleteTag struct { + // Name of the tag. Maximum size is 255 bytes. Must be provided. + Key types.String `tfsdk:"key" tf:""` + // ID of the run that the tag was logged under. Must be provided. + RunId types.String `tfsdk:"run_id" tf:""` +} + +type DeleteTagResponse struct { +} + +// Delete a transition request +type DeleteTransitionRequestRequest struct { + // User-provided comment on the action. + Comment types.String `tfsdk:"-"` + // Username of the user who created this request. Of the transition requests + // matching the specified details, only the one transition created by this + // user will be deleted. + Creator types.String `tfsdk:"-"` + // Name of the model. + Name types.String `tfsdk:"-"` + // Target stage of the transition request. Valid values are: + // + // * `None`: The initial stage of a model version. + // + // * `Staging`: Staging or pre-production stage. + // + // * `Production`: Production stage. + // + // * `Archived`: Archived stage. + Stage types.String `tfsdk:"-"` + // Version of the model. + Version types.String `tfsdk:"-"` +} + +type DeleteTransitionRequestResponse struct { +} + +// Delete a webhook +type DeleteWebhookRequest struct { + // Webhook ID required to delete a registry webhook. + Id types.String `tfsdk:"-"` +} + +type DeleteWebhookResponse struct { +} + +type Experiment struct { + // Location where artifacts for the experiment are stored. + ArtifactLocation types.String `tfsdk:"artifact_location" tf:"optional"` + // Creation time + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // Unique identifier for the experiment. + ExperimentId types.String `tfsdk:"experiment_id" tf:"optional"` + // Last update time + LastUpdateTime types.Int64 `tfsdk:"last_update_time" tf:"optional"` + // Current life cycle stage of the experiment: "active" or "deleted". + // Deleted experiments are not returned by APIs. + LifecycleStage types.String `tfsdk:"lifecycle_stage" tf:"optional"` + // Human readable name that identifies the experiment. + Name types.String `tfsdk:"name" tf:"optional"` + // Tags: Additional metadata key-value pairs. + Tags []ExperimentTag `tfsdk:"tags" tf:"optional"` +} + +type ExperimentAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type ExperimentAccessControlResponse struct { + // All permissions. + AllPermissions []ExperimentPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type ExperimentPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type ExperimentPermissions struct { + AccessControlList []ExperimentAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type ExperimentPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type ExperimentPermissionsRequest struct { + AccessControlList []ExperimentAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The experiment for which to get or manage permissions. + ExperimentId types.String `tfsdk:"-"` +} + +type ExperimentTag struct { + // The tag key. + Key types.String `tfsdk:"key" tf:"optional"` + // The tag value. + Value types.String `tfsdk:"value" tf:"optional"` +} + +type FileInfo struct { + // Size in bytes. Unset for directories. + FileSize types.Int64 `tfsdk:"file_size" tf:"optional"` + // Whether the path is a directory. + IsDir types.Bool `tfsdk:"is_dir" tf:"optional"` + // Path relative to the root artifact directory run. + Path types.String `tfsdk:"path" tf:"optional"` +} + +// Get metadata +type GetByNameRequest struct { + // Name of the associated experiment. + ExperimentName types.String `tfsdk:"-"` +} + +// Get experiment permission levels +type GetExperimentPermissionLevelsRequest struct { + // The experiment for which to get or manage permissions. + ExperimentId types.String `tfsdk:"-"` +} + +type GetExperimentPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []ExperimentPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get experiment permissions +type GetExperimentPermissionsRequest struct { + // The experiment for which to get or manage permissions. + ExperimentId types.String `tfsdk:"-"` +} + +// Get an experiment +type GetExperimentRequest struct { + // ID of the associated experiment. + ExperimentId types.String `tfsdk:"-"` +} + +type GetExperimentResponse struct { + // Experiment details. + Experiment *Experiment `tfsdk:"experiment" tf:"optional"` +} + +// Get history of a given metric within a run +type GetHistoryRequest struct { + // Maximum number of Metric records to return per paginated request. Default + // is set to 25,000. If set higher than 25,000, a request Exception will be + // raised. + MaxResults types.Int64 `tfsdk:"-"` + // Name of the metric. + MetricKey types.String `tfsdk:"-"` + // Token indicating the page of metric histories to fetch. + PageToken types.String `tfsdk:"-"` + // ID of the run from which to fetch metric values. Must be provided. + RunId types.String `tfsdk:"-"` + // [Deprecated, use run_id instead] ID of the run from which to fetch metric + // values. This field will be removed in a future MLflow version. + RunUuid types.String `tfsdk:"-"` +} + +type GetLatestVersionsRequest struct { + // Registered model unique name identifier. + Name types.String `tfsdk:"name" tf:""` + // List of stages. + Stages []types.String `tfsdk:"stages" tf:"optional"` +} + +type GetLatestVersionsResponse struct { + // Latest version models for each requests stage. Only return models with + // current `READY` status. If no `stages` provided, returns the latest + // version for each stage, including `"None"`. + ModelVersions []ModelVersion `tfsdk:"model_versions" tf:"optional"` +} + +type GetMetricHistoryResponse struct { + // All logged values for this metric. + Metrics []Metric `tfsdk:"metrics" tf:"optional"` + // Token that can be used to retrieve the next page of metric history + // results + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// Get model +type GetModelRequest struct { + // Registered model unique name identifier. + Name types.String `tfsdk:"-"` +} + +type GetModelResponse struct { + RegisteredModelDatabricks *ModelDatabricks `tfsdk:"registered_model_databricks" tf:"optional"` +} + +// Get a model version URI +type GetModelVersionDownloadUriRequest struct { + // Name of the registered model + Name types.String `tfsdk:"-"` + // Model version number + Version types.String `tfsdk:"-"` +} + +type GetModelVersionDownloadUriResponse struct { + // URI corresponding to where artifacts for this model version are stored. + ArtifactUri types.String `tfsdk:"artifact_uri" tf:"optional"` +} + +// Get a model version +type GetModelVersionRequest struct { + // Name of the registered model + Name types.String `tfsdk:"-"` + // Model version number + Version types.String `tfsdk:"-"` +} + +type GetModelVersionResponse struct { + ModelVersion *ModelVersion `tfsdk:"model_version" tf:"optional"` +} + +// Get registered model permission levels +type GetRegisteredModelPermissionLevelsRequest struct { + // The registered model for which to get or manage permissions. + RegisteredModelId types.String `tfsdk:"-"` +} + +type GetRegisteredModelPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []RegisteredModelPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get registered model permissions +type GetRegisteredModelPermissionsRequest struct { + // The registered model for which to get or manage permissions. + RegisteredModelId types.String `tfsdk:"-"` +} + +// Get a run +type GetRunRequest struct { + // ID of the run to fetch. Must be provided. + RunId types.String `tfsdk:"-"` + // [Deprecated, use run_id instead] ID of the run to fetch. This field will + // be removed in a future MLflow version. + RunUuid types.String `tfsdk:"-"` +} + +type GetRunResponse struct { + // Run metadata (name, start time, etc) and data (metrics, params, and + // tags). + Run *Run `tfsdk:"run" tf:"optional"` +} + +type HttpUrlSpec struct { + // Value of the authorization header that should be sent in the request sent + // by the wehbook. It should be of the form `" "`. + // If set to an empty string, no authorization header will be included in + // the request. + Authorization types.String `tfsdk:"authorization" tf:"optional"` + // Enable/disable SSL certificate validation. Default is true. For + // self-signed certificates, this field must be false AND the destination + // server must disable certificate validation as well. For security + // purposes, it is encouraged to perform secret validation with the + // HMAC-encoded portion of the payload and acknowledge the risk associated + // with disabling hostname validation whereby it becomes more likely that + // requests can be maliciously routed to an unintended host. + EnableSslVerification types.Bool `tfsdk:"enable_ssl_verification" tf:"optional"` + // Shared secret required for HMAC encoding payload. The HMAC-encoded + // payload will be sent in the header as: { "X-Databricks-Signature": + // $encoded_payload }. + Secret types.String `tfsdk:"secret" tf:"optional"` + // External HTTPS URL called on event trigger (by using a POST request). + Url types.String `tfsdk:"url" tf:""` +} + +type HttpUrlSpecWithoutSecret struct { + // Enable/disable SSL certificate validation. Default is true. For + // self-signed certificates, this field must be false AND the destination + // server must disable certificate validation as well. For security + // purposes, it is encouraged to perform secret validation with the + // HMAC-encoded portion of the payload and acknowledge the risk associated + // with disabling hostname validation whereby it becomes more likely that + // requests can be maliciously routed to an unintended host. + EnableSslVerification types.Bool `tfsdk:"enable_ssl_verification" tf:"optional"` + // External HTTPS URL called on event trigger (by using a POST request). + Url types.String `tfsdk:"url" tf:"optional"` +} + +type InputTag struct { + // The tag key. + Key types.String `tfsdk:"key" tf:"optional"` + // The tag value. + Value types.String `tfsdk:"value" tf:"optional"` +} + +type JobSpec struct { + // The personal access token used to authorize webhook's job runs. + AccessToken types.String `tfsdk:"access_token" tf:""` + // ID of the job that the webhook runs. + JobId types.String `tfsdk:"job_id" tf:""` + // URL of the workspace containing the job that this webhook runs. If not + // specified, the job’s workspace URL is assumed to be the same as the + // workspace where the webhook is created. + WorkspaceUrl types.String `tfsdk:"workspace_url" tf:"optional"` +} + +type JobSpecWithoutSecret struct { + // ID of the job that the webhook runs. + JobId types.String `tfsdk:"job_id" tf:"optional"` + // URL of the workspace containing the job that this webhook runs. Defaults + // to the workspace URL in which the webhook is created. If not specified, + // the job’s workspace is assumed to be the same as the webhook’s. + WorkspaceUrl types.String `tfsdk:"workspace_url" tf:"optional"` +} + +// Get all artifacts +type ListArtifactsRequest struct { + // Token indicating the page of artifact results to fetch + PageToken types.String `tfsdk:"-"` + // Filter artifacts matching this path (a relative path from the root + // artifact directory). + Path types.String `tfsdk:"-"` + // ID of the run whose artifacts to list. Must be provided. + RunId types.String `tfsdk:"-"` + // [Deprecated, use run_id instead] ID of the run whose artifacts to list. + // This field will be removed in a future MLflow version. + RunUuid types.String `tfsdk:"-"` +} + +type ListArtifactsResponse struct { + // File location and metadata for artifacts. + Files []FileInfo `tfsdk:"files" tf:"optional"` + // Token that can be used to retrieve the next page of artifact results + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // Root artifact directory for the run. + RootUri types.String `tfsdk:"root_uri" tf:"optional"` +} + +// List experiments +type ListExperimentsRequest struct { + // Maximum number of experiments desired. If `max_results` is unspecified, + // return all experiments. If `max_results` is too large, it'll be + // automatically capped at 1000. Callers of this endpoint are encouraged to + // pass max_results explicitly and leverage page_token to iterate through + // experiments. + MaxResults types.Int64 `tfsdk:"-"` + // Token indicating the page of experiments to fetch + PageToken types.String `tfsdk:"-"` + // Qualifier for type of experiments to be returned. If unspecified, return + // only active experiments. + ViewType types.String `tfsdk:"-"` +} + +type ListExperimentsResponse struct { + // Paginated Experiments beginning with the first item on the requested + // page. + Experiments []Experiment `tfsdk:"experiments" tf:"optional"` + // Token that can be used to retrieve the next page of experiments. Empty + // token means no more experiment is available for retrieval. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List models +type ListModelsRequest struct { + // Maximum number of registered models desired. Max threshold is 1000. + MaxResults types.Int64 `tfsdk:"-"` + // Pagination token to go to the next page based on a previous query. + PageToken types.String `tfsdk:"-"` +} + +type ListModelsResponse struct { + // Pagination token to request next page of models for the same query. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + RegisteredModels []Model `tfsdk:"registered_models" tf:"optional"` +} + +type ListRegistryWebhooks struct { + // Token that can be used to retrieve the next page of artifact results + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // Array of registry webhooks. + Webhooks []RegistryWebhook `tfsdk:"webhooks" tf:"optional"` +} + +// List transition requests +type ListTransitionRequestsRequest struct { + // Name of the model. + Name types.String `tfsdk:"-"` + // Version of the model. + Version types.String `tfsdk:"-"` +} + +type ListTransitionRequestsResponse struct { + // Array of open transition requests. + Requests []Activity `tfsdk:"requests" tf:"optional"` +} + +// List registry webhooks +type ListWebhooksRequest struct { + // If `events` is specified, any webhook with one or more of the specified + // trigger events is included in the output. If `events` is not specified, + // webhooks of all event types are included in the output. + Events []types.String `tfsdk:"-"` + // If not specified, all webhooks associated with the specified events are + // listed, regardless of their associated model. + ModelName types.String `tfsdk:"-"` + // Token indicating the page of artifact results to fetch + PageToken types.String `tfsdk:"-"` +} + +type LogBatch struct { + // Metrics to log. A single request can contain up to 1000 metrics, and up + // to 1000 metrics, params, and tags in total. + Metrics []Metric `tfsdk:"metrics" tf:"optional"` + // Params to log. A single request can contain up to 100 params, and up to + // 1000 metrics, params, and tags in total. + Params []Param `tfsdk:"params" tf:"optional"` + // ID of the run to log under + RunId types.String `tfsdk:"run_id" tf:"optional"` + // Tags to log. A single request can contain up to 100 tags, and up to 1000 + // metrics, params, and tags in total. + Tags []RunTag `tfsdk:"tags" tf:"optional"` +} + +type LogBatchResponse struct { +} + +type LogInputs struct { + // Dataset inputs + Datasets []DatasetInput `tfsdk:"datasets" tf:"optional"` + // ID of the run to log under + RunId types.String `tfsdk:"run_id" tf:"optional"` +} + +type LogInputsResponse struct { +} + +type LogMetric struct { + // Name of the metric. + Key types.String `tfsdk:"key" tf:""` + // ID of the run under which to log the metric. Must be provided. + RunId types.String `tfsdk:"run_id" tf:"optional"` + // [Deprecated, use run_id instead] ID of the run under which to log the + // metric. This field will be removed in a future MLflow version. + RunUuid types.String `tfsdk:"run_uuid" tf:"optional"` + // Step at which to log the metric + Step types.Int64 `tfsdk:"step" tf:"optional"` + // Unix timestamp in milliseconds at the time metric was logged. + Timestamp types.Int64 `tfsdk:"timestamp" tf:""` + // Double value of the metric being logged. + Value types.Float64 `tfsdk:"value" tf:""` +} + +type LogMetricResponse struct { +} + +type LogModel struct { + // MLmodel file in json format. + ModelJson types.String `tfsdk:"model_json" tf:"optional"` + // ID of the run to log under + RunId types.String `tfsdk:"run_id" tf:"optional"` +} + +type LogModelResponse struct { +} + +type LogParam struct { + // Name of the param. Maximum size is 255 bytes. + Key types.String `tfsdk:"key" tf:""` + // ID of the run under which to log the param. Must be provided. + RunId types.String `tfsdk:"run_id" tf:"optional"` + // [Deprecated, use run_id instead] ID of the run under which to log the + // param. This field will be removed in a future MLflow version. + RunUuid types.String `tfsdk:"run_uuid" tf:"optional"` + // String value of the param being logged. Maximum size is 500 bytes. + Value types.String `tfsdk:"value" tf:""` +} + +type LogParamResponse struct { +} + +type Metric struct { + // Key identifying this metric. + Key types.String `tfsdk:"key" tf:"optional"` + // Step at which to log the metric. + Step types.Int64 `tfsdk:"step" tf:"optional"` + // The timestamp at which this metric was recorded. + Timestamp types.Int64 `tfsdk:"timestamp" tf:"optional"` + // Value associated with this metric. + Value types.Float64 `tfsdk:"value" tf:"optional"` +} + +type Model struct { + // Timestamp recorded when this `registered_model` was created. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // Description of this `registered_model`. + Description types.String `tfsdk:"description" tf:"optional"` + // Timestamp recorded when metadata for this `registered_model` was last + // updated. + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` + // Collection of latest model versions for each stage. Only contains models + // with current `READY` status. + LatestVersions []ModelVersion `tfsdk:"latest_versions" tf:"optional"` + // Unique name for the model. + Name types.String `tfsdk:"name" tf:"optional"` + // Tags: Additional metadata key-value pairs for this `registered_model`. + Tags []ModelTag `tfsdk:"tags" tf:"optional"` + // User that created this `registered_model` + UserId types.String `tfsdk:"user_id" tf:"optional"` +} + +type ModelDatabricks struct { + // Creation time of the object, as a Unix timestamp in milliseconds. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // User-specified description for the object. + Description types.String `tfsdk:"description" tf:"optional"` + // Unique identifier for the object. + Id types.String `tfsdk:"id" tf:"optional"` + // Time of the object at last update, as a Unix timestamp in milliseconds. + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` + // Array of model versions, each the latest version for its stage. + LatestVersions []ModelVersion `tfsdk:"latest_versions" tf:"optional"` + // Name of the model. + Name types.String `tfsdk:"name" tf:"optional"` + // Permission level of the requesting user on the object. For what is + // allowed at each level, see [MLflow Model permissions](..). + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // Array of tags associated with the model. + Tags []ModelTag `tfsdk:"tags" tf:"optional"` + // The username of the user that created the object. + UserId types.String `tfsdk:"user_id" tf:"optional"` +} + +type ModelTag struct { + // The tag key. + Key types.String `tfsdk:"key" tf:"optional"` + // The tag value. + Value types.String `tfsdk:"value" tf:"optional"` +} + +type ModelVersion struct { + // Timestamp recorded when this `model_version` was created. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // Current stage for this `model_version`. + CurrentStage types.String `tfsdk:"current_stage" tf:"optional"` + // Description of this `model_version`. + Description types.String `tfsdk:"description" tf:"optional"` + // Timestamp recorded when metadata for this `model_version` was last + // updated. + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` + // Unique name of the model + Name types.String `tfsdk:"name" tf:"optional"` + // MLflow run ID used when creating `model_version`, if `source` was + // generated by an experiment run stored in MLflow tracking server. + RunId types.String `tfsdk:"run_id" tf:"optional"` + // Run Link: Direct link to the run that generated this version + RunLink types.String `tfsdk:"run_link" tf:"optional"` + // URI indicating the location of the source model artifacts, used when + // creating `model_version` + Source types.String `tfsdk:"source" tf:"optional"` + // Current status of `model_version` + Status types.String `tfsdk:"status" tf:"optional"` + // Details on current `status`, if it is pending or failed. + StatusMessage types.String `tfsdk:"status_message" tf:"optional"` + // Tags: Additional metadata key-value pairs for this `model_version`. + Tags []ModelVersionTag `tfsdk:"tags" tf:"optional"` + // User that created this `model_version`. + UserId types.String `tfsdk:"user_id" tf:"optional"` + // Model's version number. + Version types.String `tfsdk:"version" tf:"optional"` +} + +type ModelVersionDatabricks struct { + // Creation time of the object, as a Unix timestamp in milliseconds. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // Stage of the model version. Valid values are: + // + // * `None`: The initial stage of a model version. + // + // * `Staging`: Staging or pre-production stage. + // + // * `Production`: Production stage. + // + // * `Archived`: Archived stage. + CurrentStage types.String `tfsdk:"current_stage" tf:"optional"` + // User-specified description for the object. + Description types.String `tfsdk:"description" tf:"optional"` + // Time of the object at last update, as a Unix timestamp in milliseconds. + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` + // Name of the model. + Name types.String `tfsdk:"name" tf:"optional"` + // Permission level of the requesting user on the object. For what is + // allowed at each level, see [MLflow Model permissions](..). + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // Unique identifier for the MLflow tracking run associated with the source + // model artifacts. + RunId types.String `tfsdk:"run_id" tf:"optional"` + // URL of the run associated with the model artifacts. This field is set at + // model version creation time only for model versions whose source run is + // from a tracking server that is different from the registry server. + RunLink types.String `tfsdk:"run_link" tf:"optional"` + // URI that indicates the location of the source model artifacts. This is + // used when creating the model version. + Source types.String `tfsdk:"source" tf:"optional"` + // The status of the model version. Valid values are: * + // `PENDING_REGISTRATION`: Request to register a new model version is + // pending as server performs background tasks. + // + // * `FAILED_REGISTRATION`: Request to register a new model version has + // failed. + // + // * `READY`: Model version is ready for use. + Status types.String `tfsdk:"status" tf:"optional"` + // Details on the current status, for example why registration failed. + StatusMessage types.String `tfsdk:"status_message" tf:"optional"` + // Array of tags that are associated with the model version. + Tags []ModelVersionTag `tfsdk:"tags" tf:"optional"` + // The username of the user that created the object. + UserId types.String `tfsdk:"user_id" tf:"optional"` + // Version of the model. + Version types.String `tfsdk:"version" tf:"optional"` +} + +type ModelVersionTag struct { + // The tag key. + Key types.String `tfsdk:"key" tf:"optional"` + // The tag value. + Value types.String `tfsdk:"value" tf:"optional"` +} + +type Param struct { + // Key identifying this param. + Key types.String `tfsdk:"key" tf:"optional"` + // Value associated with this param. + Value types.String `tfsdk:"value" tf:"optional"` +} + +type RegisteredModelAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type RegisteredModelAccessControlResponse struct { + // All permissions. + AllPermissions []RegisteredModelPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type RegisteredModelPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type RegisteredModelPermissions struct { + AccessControlList []RegisteredModelAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type RegisteredModelPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type RegisteredModelPermissionsRequest struct { + AccessControlList []RegisteredModelAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The registered model for which to get or manage permissions. + RegisteredModelId types.String `tfsdk:"-"` +} + +type RegistryWebhook struct { + // Creation time of the object, as a Unix timestamp in milliseconds. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // User-specified description for the webhook. + Description types.String `tfsdk:"description" tf:"optional"` + // Events that can trigger a registry webhook: * `MODEL_VERSION_CREATED`: A + // new model version was created for the associated model. + // + // * `MODEL_VERSION_TRANSITIONED_STAGE`: A model version’s stage was + // changed. + // + // * `TRANSITION_REQUEST_CREATED`: A user requested a model version’s + // stage be transitioned. + // + // * `COMMENT_CREATED`: A user wrote a comment on a registered model. + // + // * `REGISTERED_MODEL_CREATED`: A new registered model was created. This + // event type can only be specified for a registry-wide webhook, which can + // be created by not specifying a model name in the create request. + // + // * `MODEL_VERSION_TAG_SET`: A user set a tag on the model version. + // + // * `MODEL_VERSION_TRANSITIONED_TO_STAGING`: A model version was + // transitioned to staging. + // + // * `MODEL_VERSION_TRANSITIONED_TO_PRODUCTION`: A model version was + // transitioned to production. + // + // * `MODEL_VERSION_TRANSITIONED_TO_ARCHIVED`: A model version was archived. + // + // * `TRANSITION_REQUEST_TO_STAGING_CREATED`: A user requested a model + // version be transitioned to staging. + // + // * `TRANSITION_REQUEST_TO_PRODUCTION_CREATED`: A user requested a model + // version be transitioned to production. + // + // * `TRANSITION_REQUEST_TO_ARCHIVED_CREATED`: A user requested a model + // version be archived. + Events []types.String `tfsdk:"events" tf:"optional"` + + HttpUrlSpec *HttpUrlSpecWithoutSecret `tfsdk:"http_url_spec" tf:"optional"` + // Webhook ID + Id types.String `tfsdk:"id" tf:"optional"` + + JobSpec *JobSpecWithoutSecret `tfsdk:"job_spec" tf:"optional"` + // Time of the object at last update, as a Unix timestamp in milliseconds. + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` + // Name of the model whose events would trigger this webhook. + ModelName types.String `tfsdk:"model_name" tf:"optional"` + // Enable or disable triggering the webhook, or put the webhook into test + // mode. The default is `ACTIVE`: * `ACTIVE`: Webhook is triggered when an + // associated event happens. + // + // * `DISABLED`: Webhook is not triggered. + // + // * `TEST_MODE`: Webhook can be triggered through the test endpoint, but is + // not triggered on a real event. + Status types.String `tfsdk:"status" tf:"optional"` +} + +type RejectTransitionRequest struct { + // User-provided comment on the action. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of the model. + Name types.String `tfsdk:"name" tf:""` + // Target stage of the transition. Valid values are: + // + // * `None`: The initial stage of a model version. + // + // * `Staging`: Staging or pre-production stage. + // + // * `Production`: Production stage. + // + // * `Archived`: Archived stage. + Stage types.String `tfsdk:"stage" tf:""` + // Version of the model. + Version types.String `tfsdk:"version" tf:""` +} + +type RejectTransitionRequestResponse struct { + // Activity recorded for the action. + Activity *Activity `tfsdk:"activity" tf:"optional"` +} + +type RenameModelRequest struct { + // Registered model unique name identifier. + Name types.String `tfsdk:"name" tf:""` + // If provided, updates the name for this `registered_model`. + NewName types.String `tfsdk:"new_name" tf:"optional"` +} + +type RenameModelResponse struct { + RegisteredModel *Model `tfsdk:"registered_model" tf:"optional"` +} + +type RestoreExperiment struct { + // ID of the associated experiment. + ExperimentId types.String `tfsdk:"experiment_id" tf:""` +} + +type RestoreExperimentResponse struct { +} + +type RestoreRun struct { + // ID of the run to restore. + RunId types.String `tfsdk:"run_id" tf:""` +} + +type RestoreRunResponse struct { +} + +type RestoreRuns struct { + // The ID of the experiment containing the runs to restore. + ExperimentId types.String `tfsdk:"experiment_id" tf:""` + // An optional positive integer indicating the maximum number of runs to + // restore. The maximum allowed value for max_runs is 10000. + MaxRuns types.Int64 `tfsdk:"max_runs" tf:"optional"` + // The minimum deletion timestamp in milliseconds since the UNIX epoch for + // restoring runs. Only runs deleted no earlier than this timestamp are + // restored. + MinTimestampMillis types.Int64 `tfsdk:"min_timestamp_millis" tf:""` +} + +type RestoreRunsResponse struct { + // The number of runs restored. + RunsRestored types.Int64 `tfsdk:"runs_restored" tf:"optional"` +} + +type Run struct { + // Run data. + Data *RunData `tfsdk:"data" tf:"optional"` + // Run metadata. + Info *RunInfo `tfsdk:"info" tf:"optional"` + // Run inputs. + Inputs *RunInputs `tfsdk:"inputs" tf:"optional"` +} + +type RunData struct { + // Run metrics. + Metrics []Metric `tfsdk:"metrics" tf:"optional"` + // Run parameters. + Params []Param `tfsdk:"params" tf:"optional"` + // Additional metadata key-value pairs. + Tags []RunTag `tfsdk:"tags" tf:"optional"` +} + +type RunInfo struct { + // URI of the directory where artifacts should be uploaded. This can be a + // local path (starting with "/"), or a distributed file system (DFS) path, + // like `s3://bucket/directory` or `dbfs:/my/directory`. If not set, the + // local `./mlruns` directory is chosen. + ArtifactUri types.String `tfsdk:"artifact_uri" tf:"optional"` + // Unix timestamp of when the run ended in milliseconds. + EndTime types.Int64 `tfsdk:"end_time" tf:"optional"` + // The experiment ID. + ExperimentId types.String `tfsdk:"experiment_id" tf:"optional"` + // Current life cycle stage of the experiment : OneOf("active", "deleted") + LifecycleStage types.String `tfsdk:"lifecycle_stage" tf:"optional"` + // Unique identifier for the run. + RunId types.String `tfsdk:"run_id" tf:"optional"` + // [Deprecated, use run_id instead] Unique identifier for the run. This + // field will be removed in a future MLflow version. + RunUuid types.String `tfsdk:"run_uuid" tf:"optional"` + // Unix timestamp of when the run started in milliseconds. + StartTime types.Int64 `tfsdk:"start_time" tf:"optional"` + // Current status of the run. + Status types.String `tfsdk:"status" tf:"optional"` + // User who initiated the run. This field is deprecated as of MLflow 1.0, + // and will be removed in a future MLflow release. Use 'mlflow.user' tag + // instead. + UserId types.String `tfsdk:"user_id" tf:"optional"` +} + +type RunInputs struct { + // Run metrics. + DatasetInputs []DatasetInput `tfsdk:"dataset_inputs" tf:"optional"` +} + +type RunTag struct { + // The tag key. + Key types.String `tfsdk:"key" tf:"optional"` + // The tag value. + Value types.String `tfsdk:"value" tf:"optional"` +} + +type SearchExperiments struct { + // String representing a SQL filter condition (e.g. "name ILIKE + // 'my-experiment%'") + Filter types.String `tfsdk:"filter" tf:"optional"` + // Maximum number of experiments desired. Max threshold is 3000. + MaxResults types.Int64 `tfsdk:"max_results" tf:"optional"` + // List of columns for ordering search results, which can include experiment + // name and last updated timestamp with an optional "DESC" or "ASC" + // annotation, where "ASC" is the default. Tiebreaks are done by experiment + // id DESC. + OrderBy []types.String `tfsdk:"order_by" tf:"optional"` + // Token indicating the page of experiments to fetch + PageToken types.String `tfsdk:"page_token" tf:"optional"` + // Qualifier for type of experiments to be returned. If unspecified, return + // only active experiments. + ViewType types.String `tfsdk:"view_type" tf:"optional"` +} + +type SearchExperimentsResponse struct { + // Experiments that match the search criteria + Experiments []Experiment `tfsdk:"experiments" tf:"optional"` + // Token that can be used to retrieve the next page of experiments. An empty + // token means that no more experiments are available for retrieval. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// Searches model versions +type SearchModelVersionsRequest struct { + // String filter condition, like "name='my-model-name'". Must be a single + // boolean condition, with string values wrapped in single quotes. + Filter types.String `tfsdk:"-"` + // Maximum number of models desired. Max threshold is 10K. + MaxResults types.Int64 `tfsdk:"-"` + // List of columns to be ordered by including model name, version, stage + // with an optional "DESC" or "ASC" annotation, where "ASC" is the default. + // Tiebreaks are done by latest stage transition timestamp, followed by name + // ASC, followed by version DESC. + OrderBy []types.String `tfsdk:"-"` + // Pagination token to go to next page based on previous search query. + PageToken types.String `tfsdk:"-"` +} + +type SearchModelVersionsResponse struct { + // Models that match the search criteria + ModelVersions []ModelVersion `tfsdk:"model_versions" tf:"optional"` + // Pagination token to request next page of models for the same search + // query. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// Search models +type SearchModelsRequest struct { + // String filter condition, like "name LIKE 'my-model-name'". Interpreted in + // the backend automatically as "name LIKE '%my-model-name%'". Single + // boolean condition, with string values wrapped in single quotes. + Filter types.String `tfsdk:"-"` + // Maximum number of models desired. Default is 100. Max threshold is 1000. + MaxResults types.Int64 `tfsdk:"-"` + // List of columns for ordering search results, which can include model name + // and last updated timestamp with an optional "DESC" or "ASC" annotation, + // where "ASC" is the default. Tiebreaks are done by model name ASC. + OrderBy []types.String `tfsdk:"-"` + // Pagination token to go to the next page based on a previous search query. + PageToken types.String `tfsdk:"-"` +} + +type SearchModelsResponse struct { + // Pagination token to request the next page of models. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // Registered Models that match the search criteria. + RegisteredModels []Model `tfsdk:"registered_models" tf:"optional"` +} + +type SearchRuns struct { + // List of experiment IDs to search over. + ExperimentIds []types.String `tfsdk:"experiment_ids" tf:"optional"` + // A filter expression over params, metrics, and tags, that allows returning + // a subset of runs. The syntax is a subset of SQL that supports ANDing + // together binary operations between a param, metric, or tag and a + // constant. + // + // Example: `metrics.rmse < 1 and params.model_class = 'LogisticRegression'` + // + // You can select columns with special characters (hyphen, space, period, + // etc.) by using double quotes: `metrics."model class" = 'LinearRegression' + // and tags."user-name" = 'Tomas'` + // + // Supported operators are `=`, `!=`, `>`, `>=`, `<`, and `<=`. + Filter types.String `tfsdk:"filter" tf:"optional"` + // Maximum number of runs desired. Max threshold is 50000 + MaxResults types.Int64 `tfsdk:"max_results" tf:"optional"` + // List of columns to be ordered by, including attributes, params, metrics, + // and tags with an optional "DESC" or "ASC" annotation, where "ASC" is the + // default. Example: ["params.input DESC", "metrics.alpha ASC", + // "metrics.rmse"] Tiebreaks are done by start_time DESC followed by run_id + // for runs with the same start time (and this is the default ordering + // criterion if order_by is not provided). + OrderBy []types.String `tfsdk:"order_by" tf:"optional"` + // Token for the current page of runs. + PageToken types.String `tfsdk:"page_token" tf:"optional"` + // Whether to display only active, only deleted, or all runs. Defaults to + // only active runs. + RunViewType types.String `tfsdk:"run_view_type" tf:"optional"` +} + +type SearchRunsResponse struct { + // Token for the next page of runs. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // Runs that match the search criteria. + Runs []Run `tfsdk:"runs" tf:"optional"` +} + +type SetExperimentTag struct { + // ID of the experiment under which to log the tag. Must be provided. + ExperimentId types.String `tfsdk:"experiment_id" tf:""` + // Name of the tag. Maximum size depends on storage backend. All storage + // backends are guaranteed to support key values up to 250 bytes in size. + Key types.String `tfsdk:"key" tf:""` + // String value of the tag being logged. Maximum size depends on storage + // backend. All storage backends are guaranteed to support key values up to + // 5000 bytes in size. + Value types.String `tfsdk:"value" tf:""` +} + +type SetExperimentTagResponse struct { +} + +type SetModelTagRequest struct { + // Name of the tag. Maximum size depends on storage backend. If a tag with + // this name already exists, its preexisting value will be replaced by the + // specified `value`. All storage backends are guaranteed to support key + // values up to 250 bytes in size. + Key types.String `tfsdk:"key" tf:""` + // Unique name of the model. + Name types.String `tfsdk:"name" tf:""` + // String value of the tag being logged. Maximum size depends on storage + // backend. All storage backends are guaranteed to support key values up to + // 5000 bytes in size. + Value types.String `tfsdk:"value" tf:""` +} + +type SetModelTagResponse struct { +} + +type SetModelVersionTagRequest struct { + // Name of the tag. Maximum size depends on storage backend. If a tag with + // this name already exists, its preexisting value will be replaced by the + // specified `value`. All storage backends are guaranteed to support key + // values up to 250 bytes in size. + Key types.String `tfsdk:"key" tf:""` + // Unique name of the model. + Name types.String `tfsdk:"name" tf:""` + // String value of the tag being logged. Maximum size depends on storage + // backend. All storage backends are guaranteed to support key values up to + // 5000 bytes in size. + Value types.String `tfsdk:"value" tf:""` + // Model version number. + Version types.String `tfsdk:"version" tf:""` +} + +type SetModelVersionTagResponse struct { +} + +type SetTag struct { + // Name of the tag. Maximum size depends on storage backend. All storage + // backends are guaranteed to support key values up to 250 bytes in size. + Key types.String `tfsdk:"key" tf:""` + // ID of the run under which to log the tag. Must be provided. + RunId types.String `tfsdk:"run_id" tf:"optional"` + // [Deprecated, use run_id instead] ID of the run under which to log the + // tag. This field will be removed in a future MLflow version. + RunUuid types.String `tfsdk:"run_uuid" tf:"optional"` + // String value of the tag being logged. Maximum size depends on storage + // backend. All storage backends are guaranteed to support key values up to + // 5000 bytes in size. + Value types.String `tfsdk:"value" tf:""` +} + +type SetTagResponse struct { +} + +// Test webhook response object. +type TestRegistryWebhook struct { + // Body of the response from the webhook URL + Body types.String `tfsdk:"body" tf:"optional"` + // Status code returned by the webhook URL + StatusCode types.Int64 `tfsdk:"status_code" tf:"optional"` +} + +type TestRegistryWebhookRequest struct { + // If `event` is specified, the test trigger uses the specified event. If + // `event` is not specified, the test trigger uses a randomly chosen event + // associated with the webhook. + Event types.String `tfsdk:"event" tf:"optional"` + // Webhook ID + Id types.String `tfsdk:"id" tf:""` +} + +type TestRegistryWebhookResponse struct { + // Test webhook response object. + Webhook *TestRegistryWebhook `tfsdk:"webhook" tf:"optional"` +} + +type TransitionModelVersionStageDatabricks struct { + // Specifies whether to archive all current model versions in the target + // stage. + ArchiveExistingVersions types.Bool `tfsdk:"archive_existing_versions" tf:""` + // User-provided comment on the action. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of the model. + Name types.String `tfsdk:"name" tf:""` + // Target stage of the transition. Valid values are: + // + // * `None`: The initial stage of a model version. + // + // * `Staging`: Staging or pre-production stage. + // + // * `Production`: Production stage. + // + // * `Archived`: Archived stage. + Stage types.String `tfsdk:"stage" tf:""` + // Version of the model. + Version types.String `tfsdk:"version" tf:""` +} + +// Transition request details. +type TransitionRequest struct { + // Array of actions on the activity allowed for the current viewer. + AvailableActions []types.String `tfsdk:"available_actions" tf:"optional"` + // User-provided comment associated with the transition request. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Creation time of the object, as a Unix timestamp in milliseconds. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // Target stage of the transition (if the activity is stage transition + // related). Valid values are: + // + // * `None`: The initial stage of a model version. + // + // * `Staging`: Staging or pre-production stage. + // + // * `Production`: Production stage. + // + // * `Archived`: Archived stage. + ToStage types.String `tfsdk:"to_stage" tf:"optional"` + // The username of the user that created the object. + UserId types.String `tfsdk:"user_id" tf:"optional"` +} + +type TransitionStageResponse struct { + ModelVersion *ModelVersionDatabricks `tfsdk:"model_version" tf:"optional"` +} + +type UpdateComment struct { + // User-provided comment on the action. + Comment types.String `tfsdk:"comment" tf:""` + // Unique identifier of an activity + Id types.String `tfsdk:"id" tf:""` +} + +type UpdateCommentResponse struct { + // Comment details. + Comment *CommentObject `tfsdk:"comment" tf:"optional"` +} + +type UpdateExperiment struct { + // ID of the associated experiment. + ExperimentId types.String `tfsdk:"experiment_id" tf:""` + // If provided, the experiment's name is changed to the new name. The new + // name must be unique. + NewName types.String `tfsdk:"new_name" tf:"optional"` +} + +type UpdateExperimentResponse struct { +} + +type UpdateModelRequest struct { + // If provided, updates the description for this `registered_model`. + Description types.String `tfsdk:"description" tf:"optional"` + // Registered model unique name identifier. + Name types.String `tfsdk:"name" tf:""` +} + +type UpdateModelResponse struct { +} + +type UpdateModelVersionRequest struct { + // If provided, updates the description for this `registered_model`. + Description types.String `tfsdk:"description" tf:"optional"` + // Name of the registered model + Name types.String `tfsdk:"name" tf:""` + // Model version number + Version types.String `tfsdk:"version" tf:""` +} + +type UpdateModelVersionResponse struct { +} + +type UpdateRegistryWebhook struct { + // User-specified description for the webhook. + Description types.String `tfsdk:"description" tf:"optional"` + // Events that can trigger a registry webhook: * `MODEL_VERSION_CREATED`: A + // new model version was created for the associated model. + // + // * `MODEL_VERSION_TRANSITIONED_STAGE`: A model version’s stage was + // changed. + // + // * `TRANSITION_REQUEST_CREATED`: A user requested a model version’s + // stage be transitioned. + // + // * `COMMENT_CREATED`: A user wrote a comment on a registered model. + // + // * `REGISTERED_MODEL_CREATED`: A new registered model was created. This + // event type can only be specified for a registry-wide webhook, which can + // be created by not specifying a model name in the create request. + // + // * `MODEL_VERSION_TAG_SET`: A user set a tag on the model version. + // + // * `MODEL_VERSION_TRANSITIONED_TO_STAGING`: A model version was + // transitioned to staging. + // + // * `MODEL_VERSION_TRANSITIONED_TO_PRODUCTION`: A model version was + // transitioned to production. + // + // * `MODEL_VERSION_TRANSITIONED_TO_ARCHIVED`: A model version was archived. + // + // * `TRANSITION_REQUEST_TO_STAGING_CREATED`: A user requested a model + // version be transitioned to staging. + // + // * `TRANSITION_REQUEST_TO_PRODUCTION_CREATED`: A user requested a model + // version be transitioned to production. + // + // * `TRANSITION_REQUEST_TO_ARCHIVED_CREATED`: A user requested a model + // version be archived. + Events []types.String `tfsdk:"events" tf:"optional"` + + HttpUrlSpec *HttpUrlSpec `tfsdk:"http_url_spec" tf:"optional"` + // Webhook ID + Id types.String `tfsdk:"id" tf:""` + + JobSpec *JobSpec `tfsdk:"job_spec" tf:"optional"` + // Enable or disable triggering the webhook, or put the webhook into test + // mode. The default is `ACTIVE`: * `ACTIVE`: Webhook is triggered when an + // associated event happens. + // + // * `DISABLED`: Webhook is not triggered. + // + // * `TEST_MODE`: Webhook can be triggered through the test endpoint, but is + // not triggered on a real event. + Status types.String `tfsdk:"status" tf:"optional"` +} + +type UpdateRun struct { + // Unix timestamp in milliseconds of when the run ended. + EndTime types.Int64 `tfsdk:"end_time" tf:"optional"` + // ID of the run to update. Must be provided. + RunId types.String `tfsdk:"run_id" tf:"optional"` + // [Deprecated, use run_id instead] ID of the run to update.. This field + // will be removed in a future MLflow version. + RunUuid types.String `tfsdk:"run_uuid" tf:"optional"` + // Updated status of the run. + Status types.String `tfsdk:"status" tf:"optional"` +} + +type UpdateRunResponse struct { + // Updated metadata of the run. + RunInfo *RunInfo `tfsdk:"run_info" tf:"optional"` +} + +type UpdateWebhookResponse struct { +} diff --git a/internal/service/oauth2_tf/model.go b/internal/service/oauth2_tf/model.go new file mode 100755 index 0000000000..095f7674dd --- /dev/null +++ b/internal/service/oauth2_tf/model.go @@ -0,0 +1,246 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package oauth2_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type CreateCustomAppIntegration struct { + // indicates if an oauth client-secret should be generated + Confidential types.Bool `tfsdk:"confidential" tf:"optional"` + // name of the custom oauth app + Name types.String `tfsdk:"name" tf:""` + // List of oauth redirect urls + RedirectUrls []types.String `tfsdk:"redirect_urls" tf:""` + // OAuth scopes granted to the application. Supported scopes: all-apis, sql, + // offline_access, openid, profile, email. + Scopes []types.String `tfsdk:"scopes" tf:"optional"` + // Token access policy + TokenAccessPolicy *TokenAccessPolicy `tfsdk:"token_access_policy" tf:"optional"` +} + +type CreateCustomAppIntegrationOutput struct { + // oauth client-id generated by the Databricks + ClientId types.String `tfsdk:"client_id" tf:"optional"` + // oauth client-secret generated by the Databricks if this is a confidential + // oauth app client-secret will be generated. + ClientSecret types.String `tfsdk:"client_secret" tf:"optional"` + // unique integration id for the custom oauth app + IntegrationId types.String `tfsdk:"integration_id" tf:"optional"` +} + +type CreatePublishedAppIntegration struct { + // app_id of the oauth published app integration. For example power-bi, + // tableau-deskop + AppId types.String `tfsdk:"app_id" tf:"optional"` + // Token access policy + TokenAccessPolicy *TokenAccessPolicy `tfsdk:"token_access_policy" tf:"optional"` +} + +type CreatePublishedAppIntegrationOutput struct { + // unique integration id for the published oauth app + IntegrationId types.String `tfsdk:"integration_id" tf:"optional"` +} + +// Create service principal secret +type CreateServicePrincipalSecretRequest struct { + // The service principal ID. + ServicePrincipalId types.Int64 `tfsdk:"-"` +} + +type CreateServicePrincipalSecretResponse struct { + // UTC time when the secret was created + CreateTime types.String `tfsdk:"create_time" tf:"optional"` + // ID of the secret + Id types.String `tfsdk:"id" tf:"optional"` + // Secret Value + Secret types.String `tfsdk:"secret" tf:"optional"` + // Secret Hash + SecretHash types.String `tfsdk:"secret_hash" tf:"optional"` + // Status of the secret + Status types.String `tfsdk:"status" tf:"optional"` + // UTC time when the secret was updated + UpdateTime types.String `tfsdk:"update_time" tf:"optional"` +} + +type DataPlaneInfo struct { + // Authorization details as a string. + AuthorizationDetails types.String `tfsdk:"authorization_details" tf:"optional"` + // The URL of the endpoint for this operation in the dataplane. + EndpointUrl types.String `tfsdk:"endpoint_url" tf:"optional"` +} + +type DeleteCustomAppIntegrationOutput struct { +} + +// Delete Custom OAuth App Integration +type DeleteCustomAppIntegrationRequest struct { + // The oauth app integration ID. + IntegrationId types.String `tfsdk:"-"` +} + +type DeletePublishedAppIntegrationOutput struct { +} + +// Delete Published OAuth App Integration +type DeletePublishedAppIntegrationRequest struct { + // The oauth app integration ID. + IntegrationId types.String `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +// Delete service principal secret +type DeleteServicePrincipalSecretRequest struct { + // The secret ID. + SecretId types.String `tfsdk:"-"` + // The service principal ID. + ServicePrincipalId types.Int64 `tfsdk:"-"` +} + +type GetCustomAppIntegrationOutput struct { + // oauth client id of the custom oauth app + ClientId types.String `tfsdk:"client_id" tf:"optional"` + // indicates if an oauth client-secret should be generated + Confidential types.Bool `tfsdk:"confidential" tf:"optional"` + // ID of this custom app + IntegrationId types.String `tfsdk:"integration_id" tf:"optional"` + // name of the custom oauth app + Name types.String `tfsdk:"name" tf:"optional"` + // List of oauth redirect urls + RedirectUrls []types.String `tfsdk:"redirect_urls" tf:"optional"` + // Token access policy + TokenAccessPolicy *TokenAccessPolicy `tfsdk:"token_access_policy" tf:"optional"` +} + +// Get OAuth Custom App Integration +type GetCustomAppIntegrationRequest struct { + // The oauth app integration ID. + IntegrationId types.String `tfsdk:"-"` +} + +type GetCustomAppIntegrationsOutput struct { + // Array of Custom OAuth App Integrations defined for the account. + Apps []GetCustomAppIntegrationOutput `tfsdk:"apps" tf:"optional"` +} + +type GetPublishedAppIntegrationOutput struct { + // app-id of the published app integration + AppId types.String `tfsdk:"app_id" tf:"optional"` + // unique integration id for the published oauth app + IntegrationId types.String `tfsdk:"integration_id" tf:"optional"` + // name of the published oauth app + Name types.String `tfsdk:"name" tf:"optional"` + // Token access policy + TokenAccessPolicy *TokenAccessPolicy `tfsdk:"token_access_policy" tf:"optional"` +} + +// Get OAuth Published App Integration +type GetPublishedAppIntegrationRequest struct { + // The oauth app integration ID. + IntegrationId types.String `tfsdk:"-"` +} + +type GetPublishedAppIntegrationsOutput struct { + // Array of Published OAuth App Integrations defined for the account. + Apps []GetPublishedAppIntegrationOutput `tfsdk:"apps" tf:"optional"` +} + +type GetPublishedAppsOutput struct { + // Array of Published OAuth Apps. + Apps []PublishedAppOutput `tfsdk:"apps" tf:"optional"` + // A token that can be used to get the next page of results. If not present, + // there are no more results to show. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// Get all the published OAuth apps +type ListOAuthPublishedAppsRequest struct { + // The max number of OAuth published apps to return. + PageSize types.Int64 `tfsdk:"-"` + // A token that can be used to get the next page of results. + PageToken types.String `tfsdk:"-"` +} + +// List service principal secrets +type ListServicePrincipalSecretsRequest struct { + // The service principal ID. + ServicePrincipalId types.Int64 `tfsdk:"-"` +} + +type ListServicePrincipalSecretsResponse struct { + // List of the secrets + Secrets []SecretInfo `tfsdk:"secrets" tf:"optional"` +} + +type PublishedAppOutput struct { + // Unique ID of the published OAuth app. + AppId types.String `tfsdk:"app_id" tf:"optional"` + // Client ID of the published OAuth app. It is the client_id in the OAuth + // flow + ClientId types.String `tfsdk:"client_id" tf:"optional"` + // Description of the published OAuth app. + Description types.String `tfsdk:"description" tf:"optional"` + // Whether the published OAuth app is a confidential client. It is always + // false for published OAuth apps. + IsConfidentialClient types.Bool `tfsdk:"is_confidential_client" tf:"optional"` + // Name of the published OAuth app. + Name types.String `tfsdk:"name" tf:"optional"` + // Redirect URLs of the published OAuth app. + RedirectUrls []types.String `tfsdk:"redirect_urls" tf:"optional"` + // Required scopes for the published OAuth app. + Scopes []types.String `tfsdk:"scopes" tf:"optional"` +} + +type SecretInfo struct { + // UTC time when the secret was created + CreateTime types.String `tfsdk:"create_time" tf:"optional"` + // ID of the secret + Id types.String `tfsdk:"id" tf:"optional"` + // Secret Hash + SecretHash types.String `tfsdk:"secret_hash" tf:"optional"` + // Status of the secret + Status types.String `tfsdk:"status" tf:"optional"` + // UTC time when the secret was updated + UpdateTime types.String `tfsdk:"update_time" tf:"optional"` +} + +type TokenAccessPolicy struct { + // access token time to live in minutes + AccessTokenTtlInMinutes types.Int64 `tfsdk:"access_token_ttl_in_minutes" tf:"optional"` + // refresh token time to live in minutes + RefreshTokenTtlInMinutes types.Int64 `tfsdk:"refresh_token_ttl_in_minutes" tf:"optional"` +} + +type UpdateCustomAppIntegration struct { + // The oauth app integration ID. + IntegrationId types.String `tfsdk:"-"` + // List of oauth redirect urls to be updated in the custom oauth app + // integration + RedirectUrls []types.String `tfsdk:"redirect_urls" tf:"optional"` + // Token access policy to be updated in the custom oauth app integration + TokenAccessPolicy *TokenAccessPolicy `tfsdk:"token_access_policy" tf:"optional"` +} + +type UpdateCustomAppIntegrationOutput struct { +} + +type UpdatePublishedAppIntegration struct { + // The oauth app integration ID. + IntegrationId types.String `tfsdk:"-"` + // Token access policy to be updated in the published oauth app integration + TokenAccessPolicy *TokenAccessPolicy `tfsdk:"token_access_policy" tf:"optional"` +} + +type UpdatePublishedAppIntegrationOutput struct { +} diff --git a/internal/service/pipelines_tf/model.go b/internal/service/pipelines_tf/model.go new file mode 100755 index 0000000000..d3685037a0 --- /dev/null +++ b/internal/service/pipelines_tf/model.go @@ -0,0 +1,864 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package pipelines_tf + +import ( + "github.com/databricks/databricks-sdk-go/service/compute" + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type CreatePipeline struct { + // If false, deployment will fail if name conflicts with that of another + // pipeline. + AllowDuplicateNames types.Bool `tfsdk:"allow_duplicate_names" tf:"optional"` + // A catalog in Unity Catalog to publish data from this pipeline to. If + // `target` is specified, tables in this pipeline are published to a + // `target` schema inside `catalog` (for example, + // `catalog`.`target`.`table`). If `target` is not specified, no data is + // published to Unity Catalog. + Catalog types.String `tfsdk:"catalog" tf:"optional"` + // DLT Release Channel that specifies which version to use. + Channel types.String `tfsdk:"channel" tf:"optional"` + // Cluster settings for this pipeline deployment. + Clusters []PipelineCluster `tfsdk:"clusters" tf:"optional"` + // String-String configuration for this pipeline execution. + Configuration map[string]types.String `tfsdk:"configuration" tf:"optional"` + // Whether the pipeline is continuous or triggered. This replaces `trigger`. + Continuous types.Bool `tfsdk:"continuous" tf:"optional"` + // Deployment type of this pipeline. + Deployment *PipelineDeployment `tfsdk:"deployment" tf:"optional"` + // Whether the pipeline is in Development mode. Defaults to false. + Development types.Bool `tfsdk:"development" tf:"optional"` + + DryRun types.Bool `tfsdk:"dry_run" tf:"optional"` + // Pipeline product edition. + Edition types.String `tfsdk:"edition" tf:"optional"` + // Filters on which Pipeline packages to include in the deployed graph. + Filters *Filters `tfsdk:"filters" tf:"optional"` + // The definition of a gateway pipeline to support CDC. + GatewayDefinition *IngestionGatewayPipelineDefinition `tfsdk:"gateway_definition" tf:"optional"` + // Unique identifier for this pipeline. + Id types.String `tfsdk:"id" tf:"optional"` + // The configuration for a managed ingestion pipeline. These settings cannot + // be used with the 'libraries', 'target' or 'catalog' settings. + IngestionDefinition *ManagedIngestionPipelineDefinition `tfsdk:"ingestion_definition" tf:"optional"` + // Libraries or code needed by this deployment. + Libraries []PipelineLibrary `tfsdk:"libraries" tf:"optional"` + // Friendly identifier for this pipeline. + Name types.String `tfsdk:"name" tf:"optional"` + // List of notification settings for this pipeline. + Notifications []Notifications `tfsdk:"notifications" tf:"optional"` + // Whether Photon is enabled for this pipeline. + Photon types.Bool `tfsdk:"photon" tf:"optional"` + // Whether serverless compute is enabled for this pipeline. + Serverless types.Bool `tfsdk:"serverless" tf:"optional"` + // DBFS root directory for storing checkpoints and tables. + Storage types.String `tfsdk:"storage" tf:"optional"` + // Target schema (database) to add tables in this pipeline to. If not + // specified, no data is published to the Hive metastore or Unity Catalog. + // To publish to Unity Catalog, also specify `catalog`. + Target types.String `tfsdk:"target" tf:"optional"` + // Which pipeline trigger to use. Deprecated: Use `continuous` instead. + Trigger *PipelineTrigger `tfsdk:"trigger" tf:"optional"` +} + +type CreatePipelineResponse struct { + // Only returned when dry_run is true. + EffectiveSettings *PipelineSpec `tfsdk:"effective_settings" tf:"optional"` + // The unique identifier for the newly created pipeline. Only returned when + // dry_run is false. + PipelineId types.String `tfsdk:"pipeline_id" tf:"optional"` +} + +type CronTrigger struct { + QuartzCronSchedule types.String `tfsdk:"quartz_cron_schedule" tf:"optional"` + + TimezoneId types.String `tfsdk:"timezone_id" tf:"optional"` +} + +type DataPlaneId struct { + // The instance name of the data plane emitting an event. + Instance types.String `tfsdk:"instance" tf:"optional"` + // A sequence number, unique and increasing within the data plane instance. + SeqNo types.Int64 `tfsdk:"seq_no" tf:"optional"` +} + +// Delete a pipeline +type DeletePipelineRequest struct { + PipelineId types.String `tfsdk:"-"` +} + +type DeletePipelineResponse struct { +} + +type EditPipeline struct { + // If false, deployment will fail if name has changed and conflicts the name + // of another pipeline. + AllowDuplicateNames types.Bool `tfsdk:"allow_duplicate_names" tf:"optional"` + // A catalog in Unity Catalog to publish data from this pipeline to. If + // `target` is specified, tables in this pipeline are published to a + // `target` schema inside `catalog` (for example, + // `catalog`.`target`.`table`). If `target` is not specified, no data is + // published to Unity Catalog. + Catalog types.String `tfsdk:"catalog" tf:"optional"` + // DLT Release Channel that specifies which version to use. + Channel types.String `tfsdk:"channel" tf:"optional"` + // Cluster settings for this pipeline deployment. + Clusters []PipelineCluster `tfsdk:"clusters" tf:"optional"` + // String-String configuration for this pipeline execution. + Configuration map[string]types.String `tfsdk:"configuration" tf:"optional"` + // Whether the pipeline is continuous or triggered. This replaces `trigger`. + Continuous types.Bool `tfsdk:"continuous" tf:"optional"` + // Deployment type of this pipeline. + Deployment *PipelineDeployment `tfsdk:"deployment" tf:"optional"` + // Whether the pipeline is in Development mode. Defaults to false. + Development types.Bool `tfsdk:"development" tf:"optional"` + // Pipeline product edition. + Edition types.String `tfsdk:"edition" tf:"optional"` + // If present, the last-modified time of the pipeline settings before the + // edit. If the settings were modified after that time, then the request + // will fail with a conflict. + ExpectedLastModified types.Int64 `tfsdk:"expected_last_modified" tf:"optional"` + // Filters on which Pipeline packages to include in the deployed graph. + Filters *Filters `tfsdk:"filters" tf:"optional"` + // The definition of a gateway pipeline to support CDC. + GatewayDefinition *IngestionGatewayPipelineDefinition `tfsdk:"gateway_definition" tf:"optional"` + // Unique identifier for this pipeline. + Id types.String `tfsdk:"id" tf:"optional"` + // The configuration for a managed ingestion pipeline. These settings cannot + // be used with the 'libraries', 'target' or 'catalog' settings. + IngestionDefinition *ManagedIngestionPipelineDefinition `tfsdk:"ingestion_definition" tf:"optional"` + // Libraries or code needed by this deployment. + Libraries []PipelineLibrary `tfsdk:"libraries" tf:"optional"` + // Friendly identifier for this pipeline. + Name types.String `tfsdk:"name" tf:"optional"` + // List of notification settings for this pipeline. + Notifications []Notifications `tfsdk:"notifications" tf:"optional"` + // Whether Photon is enabled for this pipeline. + Photon types.Bool `tfsdk:"photon" tf:"optional"` + // Unique identifier for this pipeline. + PipelineId types.String `tfsdk:"pipeline_id" tf:"optional"` + // Whether serverless compute is enabled for this pipeline. + Serverless types.Bool `tfsdk:"serverless" tf:"optional"` + // DBFS root directory for storing checkpoints and tables. + Storage types.String `tfsdk:"storage" tf:"optional"` + // Target schema (database) to add tables in this pipeline to. If not + // specified, no data is published to the Hive metastore or Unity Catalog. + // To publish to Unity Catalog, also specify `catalog`. + Target types.String `tfsdk:"target" tf:"optional"` + // Which pipeline trigger to use. Deprecated: Use `continuous` instead. + Trigger *PipelineTrigger `tfsdk:"trigger" tf:"optional"` +} + +type EditPipelineResponse struct { +} + +type ErrorDetail struct { + // The exception thrown for this error, with its chain of cause. + Exceptions []SerializedException `tfsdk:"exceptions" tf:"optional"` + // Whether this error is considered fatal, that is, unrecoverable. + Fatal types.Bool `tfsdk:"fatal" tf:"optional"` +} + +type FileLibrary struct { + // The absolute path of the file. + Path types.String `tfsdk:"path" tf:"optional"` +} + +type Filters struct { + // Paths to exclude. + Exclude []types.String `tfsdk:"exclude" tf:"optional"` + // Paths to include. + Include []types.String `tfsdk:"include" tf:"optional"` +} + +// Get pipeline permission levels +type GetPipelinePermissionLevelsRequest struct { + // The pipeline for which to get or manage permissions. + PipelineId types.String `tfsdk:"-"` +} + +type GetPipelinePermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []PipelinePermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get pipeline permissions +type GetPipelinePermissionsRequest struct { + // The pipeline for which to get or manage permissions. + PipelineId types.String `tfsdk:"-"` +} + +// Get a pipeline +type GetPipelineRequest struct { + PipelineId types.String `tfsdk:"-"` +} + +type GetPipelineResponse struct { + // An optional message detailing the cause of the pipeline state. + Cause types.String `tfsdk:"cause" tf:"optional"` + // The ID of the cluster that the pipeline is running on. + ClusterId types.String `tfsdk:"cluster_id" tf:"optional"` + // The username of the pipeline creator. + CreatorUserName types.String `tfsdk:"creator_user_name" tf:"optional"` + // The health of a pipeline. + Health types.String `tfsdk:"health" tf:"optional"` + // The last time the pipeline settings were modified or created. + LastModified types.Int64 `tfsdk:"last_modified" tf:"optional"` + // Status of the latest updates for the pipeline. Ordered with the newest + // update first. + LatestUpdates []UpdateStateInfo `tfsdk:"latest_updates" tf:"optional"` + // A human friendly identifier for the pipeline, taken from the `spec`. + Name types.String `tfsdk:"name" tf:"optional"` + // The ID of the pipeline. + PipelineId types.String `tfsdk:"pipeline_id" tf:"optional"` + // Username of the user that the pipeline will run on behalf of. + RunAsUserName types.String `tfsdk:"run_as_user_name" tf:"optional"` + // The pipeline specification. This field is not returned when called by + // `ListPipelines`. + Spec *PipelineSpec `tfsdk:"spec" tf:"optional"` + // The pipeline state. + State types.String `tfsdk:"state" tf:"optional"` +} + +// Get a pipeline update +type GetUpdateRequest struct { + // The ID of the pipeline. + PipelineId types.String `tfsdk:"-"` + // The ID of the update. + UpdateId types.String `tfsdk:"-"` +} + +type GetUpdateResponse struct { + // The current update info. + Update *UpdateInfo `tfsdk:"update" tf:"optional"` +} + +type IngestionConfig struct { + // Select tables from a specific source schema. + Schema *SchemaSpec `tfsdk:"schema" tf:"optional"` + // Select tables from a specific source table. + Table *TableSpec `tfsdk:"table" tf:"optional"` +} + +type IngestionGatewayPipelineDefinition struct { + // Immutable. The Unity Catalog connection this gateway pipeline uses to + // communicate with the source. + ConnectionId types.String `tfsdk:"connection_id" tf:"optional"` + // Required, Immutable. The name of the catalog for the gateway pipeline's + // storage location. + GatewayStorageCatalog types.String `tfsdk:"gateway_storage_catalog" tf:"optional"` + // Required. The Unity Catalog-compatible naming for the gateway storage + // location. This is the destination to use for the data that is extracted + // by the gateway. Delta Live Tables system will automatically create the + // storage location under the catalog and schema. + GatewayStorageName types.String `tfsdk:"gateway_storage_name" tf:"optional"` + // Required, Immutable. The name of the schema for the gateway pipelines's + // storage location. + GatewayStorageSchema types.String `tfsdk:"gateway_storage_schema" tf:"optional"` +} + +// List pipeline events +type ListPipelineEventsRequest struct { + // Criteria to select a subset of results, expressed using a SQL-like + // syntax. The supported filters are: 1. level='INFO' (or WARN or ERROR) 2. + // level in ('INFO', 'WARN') 3. id='[event-id]' 4. timestamp > 'TIMESTAMP' + // (or >=,<,<=,=) + // + // Composite expressions are supported, for example: level in ('ERROR', + // 'WARN') AND timestamp> '2021-07-22T06:37:33.083Z' + Filter types.String `tfsdk:"-"` + // Max number of entries to return in a single page. The system may return + // fewer than max_results events in a response, even if there are more + // events available. + MaxResults types.Int64 `tfsdk:"-"` + // A string indicating a sort order by timestamp for the results, for + // example, ["timestamp asc"]. The sort order can be ascending or + // descending. By default, events are returned in descending order by + // timestamp. + OrderBy []types.String `tfsdk:"-"` + // Page token returned by previous call. This field is mutually exclusive + // with all fields in this request except max_results. An error is returned + // if any fields other than max_results are set when this field is set. + PageToken types.String `tfsdk:"-"` + + PipelineId types.String `tfsdk:"-"` +} + +type ListPipelineEventsResponse struct { + // The list of events matching the request criteria. + Events []PipelineEvent `tfsdk:"events" tf:"optional"` + // If present, a token to fetch the next page of events. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // If present, a token to fetch the previous page of events. + PrevPageToken types.String `tfsdk:"prev_page_token" tf:"optional"` +} + +// List pipelines +type ListPipelinesRequest struct { + // Select a subset of results based on the specified criteria. The supported + // filters are: + // + // * `notebook=''` to select pipelines that reference the provided + // notebook path. * `name LIKE '[pattern]'` to select pipelines with a name + // that matches pattern. Wildcards are supported, for example: `name LIKE + // '%shopping%'` + // + // Composite filters are not supported. This field is optional. + Filter types.String `tfsdk:"-"` + // The maximum number of entries to return in a single page. The system may + // return fewer than max_results events in a response, even if there are + // more events available. This field is optional. The default value is 25. + // The maximum value is 100. An error is returned if the value of + // max_results is greater than 100. + MaxResults types.Int64 `tfsdk:"-"` + // A list of strings specifying the order of results. Supported order_by + // fields are id and name. The default is id asc. This field is optional. + OrderBy []types.String `tfsdk:"-"` + // Page token returned by previous call + PageToken types.String `tfsdk:"-"` +} + +type ListPipelinesResponse struct { + // If present, a token to fetch the next page of events. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // The list of events matching the request criteria. + Statuses []PipelineStateInfo `tfsdk:"statuses" tf:"optional"` +} + +// List pipeline updates +type ListUpdatesRequest struct { + // Max number of entries to return in a single page. + MaxResults types.Int64 `tfsdk:"-"` + // Page token returned by previous call + PageToken types.String `tfsdk:"-"` + // The pipeline to return updates for. + PipelineId types.String `tfsdk:"-"` + // If present, returns updates until and including this update_id. + UntilUpdateId types.String `tfsdk:"-"` +} + +type ListUpdatesResponse struct { + // If present, then there are more results, and this a token to be used in a + // subsequent request to fetch the next page. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // If present, then this token can be used in a subsequent request to fetch + // the previous page. + PrevPageToken types.String `tfsdk:"prev_page_token" tf:"optional"` + + Updates []UpdateInfo `tfsdk:"updates" tf:"optional"` +} + +type ManagedIngestionPipelineDefinition struct { + // Immutable. The Unity Catalog connection this ingestion pipeline uses to + // communicate with the source. Specify either ingestion_gateway_id or + // connection_name. + ConnectionName types.String `tfsdk:"connection_name" tf:"optional"` + // Immutable. Identifier for the ingestion gateway used by this ingestion + // pipeline to communicate with the source. Specify either + // ingestion_gateway_id or connection_name. + IngestionGatewayId types.String `tfsdk:"ingestion_gateway_id" tf:"optional"` + // Required. Settings specifying tables to replicate and the destination for + // the replicated tables. + Objects []IngestionConfig `tfsdk:"objects" tf:"optional"` + // Configuration settings to control the ingestion of tables. These settings + // are applied to all tables in the pipeline. + TableConfiguration *TableSpecificConfig `tfsdk:"table_configuration" tf:"optional"` +} + +type ManualTrigger struct { +} + +type NotebookLibrary struct { + // The absolute path of the notebook. + Path types.String `tfsdk:"path" tf:"optional"` +} + +type Notifications struct { + // A list of alerts that trigger the sending of notifications to the + // configured destinations. The supported alerts are: + // + // * `on-update-success`: A pipeline update completes successfully. * + // `on-update-failure`: Each time a pipeline update fails. * + // `on-update-fatal-failure`: A pipeline update fails with a non-retryable + // (fatal) error. * `on-flow-failure`: A single data flow fails. + Alerts []types.String `tfsdk:"alerts" tf:"optional"` + // A list of email addresses notified when a configured alert is triggered. + EmailRecipients []types.String `tfsdk:"email_recipients" tf:"optional"` +} + +type Origin struct { + // The id of a batch. Unique within a flow. + BatchId types.Int64 `tfsdk:"batch_id" tf:"optional"` + // The cloud provider, e.g., AWS or Azure. + Cloud types.String `tfsdk:"cloud" tf:"optional"` + // The id of the cluster where an execution happens. Unique within a region. + ClusterId types.String `tfsdk:"cluster_id" tf:"optional"` + // The name of a dataset. Unique within a pipeline. + DatasetName types.String `tfsdk:"dataset_name" tf:"optional"` + // The id of the flow. Globally unique. Incremental queries will generally + // reuse the same id while complete queries will have a new id per update. + FlowId types.String `tfsdk:"flow_id" tf:"optional"` + // The name of the flow. Not unique. + FlowName types.String `tfsdk:"flow_name" tf:"optional"` + // The optional host name where the event was triggered + Host types.String `tfsdk:"host" tf:"optional"` + // The id of a maintenance run. Globally unique. + MaintenanceId types.String `tfsdk:"maintenance_id" tf:"optional"` + // Materialization name. + MaterializationName types.String `tfsdk:"materialization_name" tf:"optional"` + // The org id of the user. Unique within a cloud. + OrgId types.Int64 `tfsdk:"org_id" tf:"optional"` + // The id of the pipeline. Globally unique. + PipelineId types.String `tfsdk:"pipeline_id" tf:"optional"` + // The name of the pipeline. Not unique. + PipelineName types.String `tfsdk:"pipeline_name" tf:"optional"` + // The cloud region. + Region types.String `tfsdk:"region" tf:"optional"` + // The id of the request that caused an update. + RequestId types.String `tfsdk:"request_id" tf:"optional"` + // The id of a (delta) table. Globally unique. + TableId types.String `tfsdk:"table_id" tf:"optional"` + // The Unity Catalog id of the MV or ST being updated. + UcResourceId types.String `tfsdk:"uc_resource_id" tf:"optional"` + // The id of an execution. Globally unique. + UpdateId types.String `tfsdk:"update_id" tf:"optional"` +} + +type PipelineAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type PipelineAccessControlResponse struct { + // All permissions. + AllPermissions []PipelinePermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type PipelineCluster struct { + // Note: This field won't be persisted. Only API users will check this + // field. + ApplyPolicyDefaultValues types.Bool `tfsdk:"apply_policy_default_values" tf:"optional"` + // Parameters needed in order to automatically scale clusters up and down + // based on load. Note: autoscaling works best with DB runtime versions 3.0 + // or later. + Autoscale *PipelineClusterAutoscale `tfsdk:"autoscale" tf:"optional"` + // Attributes related to clusters running on Amazon Web Services. If not + // specified at cluster creation, a set of default values will be used. + AwsAttributes *compute.AwsAttributes `tfsdk:"aws_attributes" tf:"optional"` + // Attributes related to clusters running on Microsoft Azure. If not + // specified at cluster creation, a set of default values will be used. + AzureAttributes *compute.AzureAttributes `tfsdk:"azure_attributes" tf:"optional"` + // The configuration for delivering spark logs to a long-term storage + // destination. Only dbfs destinations are supported. Only one destination + // can be specified for one cluster. If the conf is given, the logs will be + // delivered to the destination every `5 mins`. The destination of driver + // logs is `$destination/$clusterId/driver`, while the destination of + // executor logs is `$destination/$clusterId/executor`. + ClusterLogConf *compute.ClusterLogConf `tfsdk:"cluster_log_conf" tf:"optional"` + // Additional tags for cluster resources. Databricks will tag all cluster + // resources (e.g., AWS instances and EBS volumes) with these tags in + // addition to `default_tags`. Notes: + // + // - Currently, Databricks allows at most 45 custom tags + // + // - Clusters can only reuse cloud resources if the resources' tags are a + // subset of the cluster tags + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // The optional ID of the instance pool for the driver of the cluster + // belongs. The pool cluster uses the instance pool with id + // (instance_pool_id) if the driver pool is not assigned. + DriverInstancePoolId types.String `tfsdk:"driver_instance_pool_id" tf:"optional"` + // The node type of the Spark driver. Note that this field is optional; if + // unset, the driver node type will be set as the same value as + // `node_type_id` defined above. + DriverNodeTypeId types.String `tfsdk:"driver_node_type_id" tf:"optional"` + // Attributes related to clusters running on Google Cloud Platform. If not + // specified at cluster creation, a set of default values will be used. + GcpAttributes *compute.GcpAttributes `tfsdk:"gcp_attributes" tf:"optional"` + // The configuration for storing init scripts. Any number of destinations + // can be specified. The scripts are executed sequentially in the order + // provided. If `cluster_log_conf` is specified, init script logs are sent + // to `//init_scripts`. + InitScripts []compute.InitScriptInfo `tfsdk:"init_scripts" tf:"optional"` + // The optional ID of the instance pool to which the cluster belongs. + InstancePoolId types.String `tfsdk:"instance_pool_id" tf:"optional"` + // A label for the cluster specification, either `default` to configure the + // default cluster, or `maintenance` to configure the maintenance cluster. + // This field is optional. The default value is `default`. + Label types.String `tfsdk:"label" tf:"optional"` + // This field encodes, through a single value, the resources available to + // each of the Spark nodes in this cluster. For example, the Spark nodes can + // be provisioned and optimized for memory or compute intensive workloads. A + // list of available node types can be retrieved by using the + // :method:clusters/listNodeTypes API call. + NodeTypeId types.String `tfsdk:"node_type_id" tf:"optional"` + // Number of worker nodes that this cluster should have. A cluster has one + // Spark Driver and `num_workers` Executors for a total of `num_workers` + 1 + // Spark nodes. + // + // Note: When reading the properties of a cluster, this field reflects the + // desired number of workers rather than the actual current number of + // workers. For instance, if a cluster is resized from 5 to 10 workers, this + // field will immediately be updated to reflect the target size of 10 + // workers, whereas the workers listed in `spark_info` will gradually + // increase from 5 to 10 as the new nodes are provisioned. + NumWorkers types.Int64 `tfsdk:"num_workers" tf:"optional"` + // The ID of the cluster policy used to create the cluster if applicable. + PolicyId types.String `tfsdk:"policy_id" tf:"optional"` + // An object containing a set of optional, user-specified Spark + // configuration key-value pairs. See :method:clusters/create for more + // details. + SparkConf map[string]types.String `tfsdk:"spark_conf" tf:"optional"` + // An object containing a set of optional, user-specified environment + // variable key-value pairs. Please note that key-value pair of the form + // (X,Y) will be exported as is (i.e., `export X='Y'`) while launching the + // driver and workers. + // + // In order to specify an additional set of `SPARK_DAEMON_JAVA_OPTS`, we + // recommend appending them to `$SPARK_DAEMON_JAVA_OPTS` as shown in the + // example below. This ensures that all default databricks managed + // environmental variables are included as well. + // + // Example Spark environment variables: `{"SPARK_WORKER_MEMORY": "28000m", + // "SPARK_LOCAL_DIRS": "/local_disk0"}` or `{"SPARK_DAEMON_JAVA_OPTS": + // "$SPARK_DAEMON_JAVA_OPTS -Dspark.shuffle.service.enabled=true"}` + SparkEnvVars map[string]types.String `tfsdk:"spark_env_vars" tf:"optional"` + // SSH public key contents that will be added to each Spark node in this + // cluster. The corresponding private keys can be used to login with the + // user name `ubuntu` on port `2200`. Up to 10 keys can be specified. + SshPublicKeys []types.String `tfsdk:"ssh_public_keys" tf:"optional"` +} + +type PipelineClusterAutoscale struct { + // The maximum number of workers to which the cluster can scale up when + // overloaded. `max_workers` must be strictly greater than `min_workers`. + MaxWorkers types.Int64 `tfsdk:"max_workers" tf:""` + // The minimum number of workers the cluster can scale down to when + // underutilized. It is also the initial number of workers the cluster will + // have after creation. + MinWorkers types.Int64 `tfsdk:"min_workers" tf:""` + // Databricks Enhanced Autoscaling optimizes cluster utilization by + // automatically allocating cluster resources based on workload volume, with + // minimal impact to the data processing latency of your pipelines. Enhanced + // Autoscaling is available for `updates` clusters only. The legacy + // autoscaling feature is used for `maintenance` clusters. + Mode types.String `tfsdk:"mode" tf:"optional"` +} + +type PipelineDeployment struct { + // The deployment method that manages the pipeline. + Kind types.String `tfsdk:"kind" tf:"optional"` + // The path to the file containing metadata about the deployment. + MetadataFilePath types.String `tfsdk:"metadata_file_path" tf:"optional"` +} + +type PipelineEvent struct { + // Information about an error captured by the event. + Error *ErrorDetail `tfsdk:"error" tf:"optional"` + // The event type. Should always correspond to the details + EventType types.String `tfsdk:"event_type" tf:"optional"` + // A time-based, globally unique id. + Id types.String `tfsdk:"id" tf:"optional"` + // The severity level of the event. + Level types.String `tfsdk:"level" tf:"optional"` + // Maturity level for event_type. + MaturityLevel types.String `tfsdk:"maturity_level" tf:"optional"` + // The display message associated with the event. + Message types.String `tfsdk:"message" tf:"optional"` + // Describes where the event originates from. + Origin *Origin `tfsdk:"origin" tf:"optional"` + // A sequencing object to identify and order events. + Sequence *Sequencing `tfsdk:"sequence" tf:"optional"` + // The time of the event. + Timestamp types.String `tfsdk:"timestamp" tf:"optional"` +} + +type PipelineLibrary struct { + // The path to a file that defines a pipeline and is stored in the + // Databricks Repos. + File *FileLibrary `tfsdk:"file" tf:"optional"` + // URI of the jar to be installed. Currently only DBFS is supported. + Jar types.String `tfsdk:"jar" tf:"optional"` + // Specification of a maven library to be installed. + Maven *compute.MavenLibrary `tfsdk:"maven" tf:"optional"` + // The path to a notebook that defines a pipeline and is stored in the + // Databricks workspace. + Notebook *NotebookLibrary `tfsdk:"notebook" tf:"optional"` +} + +type PipelinePermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type PipelinePermissions struct { + AccessControlList []PipelineAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type PipelinePermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type PipelinePermissionsRequest struct { + AccessControlList []PipelineAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The pipeline for which to get or manage permissions. + PipelineId types.String `tfsdk:"-"` +} + +type PipelineSpec struct { + // A catalog in Unity Catalog to publish data from this pipeline to. If + // `target` is specified, tables in this pipeline are published to a + // `target` schema inside `catalog` (for example, + // `catalog`.`target`.`table`). If `target` is not specified, no data is + // published to Unity Catalog. + Catalog types.String `tfsdk:"catalog" tf:"optional"` + // DLT Release Channel that specifies which version to use. + Channel types.String `tfsdk:"channel" tf:"optional"` + // Cluster settings for this pipeline deployment. + Clusters []PipelineCluster `tfsdk:"clusters" tf:"optional"` + // String-String configuration for this pipeline execution. + Configuration map[string]types.String `tfsdk:"configuration" tf:"optional"` + // Whether the pipeline is continuous or triggered. This replaces `trigger`. + Continuous types.Bool `tfsdk:"continuous" tf:"optional"` + // Deployment type of this pipeline. + Deployment *PipelineDeployment `tfsdk:"deployment" tf:"optional"` + // Whether the pipeline is in Development mode. Defaults to false. + Development types.Bool `tfsdk:"development" tf:"optional"` + // Pipeline product edition. + Edition types.String `tfsdk:"edition" tf:"optional"` + // Filters on which Pipeline packages to include in the deployed graph. + Filters *Filters `tfsdk:"filters" tf:"optional"` + // The definition of a gateway pipeline to support CDC. + GatewayDefinition *IngestionGatewayPipelineDefinition `tfsdk:"gateway_definition" tf:"optional"` + // Unique identifier for this pipeline. + Id types.String `tfsdk:"id" tf:"optional"` + // The configuration for a managed ingestion pipeline. These settings cannot + // be used with the 'libraries', 'target' or 'catalog' settings. + IngestionDefinition *ManagedIngestionPipelineDefinition `tfsdk:"ingestion_definition" tf:"optional"` + // Libraries or code needed by this deployment. + Libraries []PipelineLibrary `tfsdk:"libraries" tf:"optional"` + // Friendly identifier for this pipeline. + Name types.String `tfsdk:"name" tf:"optional"` + // List of notification settings for this pipeline. + Notifications []Notifications `tfsdk:"notifications" tf:"optional"` + // Whether Photon is enabled for this pipeline. + Photon types.Bool `tfsdk:"photon" tf:"optional"` + // Whether serverless compute is enabled for this pipeline. + Serverless types.Bool `tfsdk:"serverless" tf:"optional"` + // DBFS root directory for storing checkpoints and tables. + Storage types.String `tfsdk:"storage" tf:"optional"` + // Target schema (database) to add tables in this pipeline to. If not + // specified, no data is published to the Hive metastore or Unity Catalog. + // To publish to Unity Catalog, also specify `catalog`. + Target types.String `tfsdk:"target" tf:"optional"` + // Which pipeline trigger to use. Deprecated: Use `continuous` instead. + Trigger *PipelineTrigger `tfsdk:"trigger" tf:"optional"` +} + +type PipelineStateInfo struct { + // The unique identifier of the cluster running the pipeline. + ClusterId types.String `tfsdk:"cluster_id" tf:"optional"` + // The username of the pipeline creator. + CreatorUserName types.String `tfsdk:"creator_user_name" tf:"optional"` + // Status of the latest updates for the pipeline. Ordered with the newest + // update first. + LatestUpdates []UpdateStateInfo `tfsdk:"latest_updates" tf:"optional"` + // The user-friendly name of the pipeline. + Name types.String `tfsdk:"name" tf:"optional"` + // The unique identifier of the pipeline. + PipelineId types.String `tfsdk:"pipeline_id" tf:"optional"` + // The username that the pipeline runs as. This is a read only value derived + // from the pipeline owner. + RunAsUserName types.String `tfsdk:"run_as_user_name" tf:"optional"` + // The pipeline state. + State types.String `tfsdk:"state" tf:"optional"` +} + +type PipelineTrigger struct { + Cron *CronTrigger `tfsdk:"cron" tf:"optional"` + + Manual *ManualTrigger `tfsdk:"manual" tf:"optional"` +} + +type SchemaSpec struct { + // Required. Destination catalog to store tables. + DestinationCatalog types.String `tfsdk:"destination_catalog" tf:"optional"` + // Required. Destination schema to store tables in. Tables with the same + // name as the source tables are created in this destination schema. The + // pipeline fails If a table with the same name already exists. + DestinationSchema types.String `tfsdk:"destination_schema" tf:"optional"` + // The source catalog name. Might be optional depending on the type of + // source. + SourceCatalog types.String `tfsdk:"source_catalog" tf:"optional"` + // Required. Schema name in the source database. + SourceSchema types.String `tfsdk:"source_schema" tf:"optional"` + // Configuration settings to control the ingestion of tables. These settings + // are applied to all tables in this schema and override the + // table_configuration defined in the ManagedIngestionPipelineDefinition + // object. + TableConfiguration *TableSpecificConfig `tfsdk:"table_configuration" tf:"optional"` +} + +type Sequencing struct { + // A sequence number, unique and increasing within the control plane. + ControlPlaneSeqNo types.Int64 `tfsdk:"control_plane_seq_no" tf:"optional"` + // the ID assigned by the data plane. + DataPlaneId *DataPlaneId `tfsdk:"data_plane_id" tf:"optional"` +} + +type SerializedException struct { + // Runtime class of the exception + ClassName types.String `tfsdk:"class_name" tf:"optional"` + // Exception message + Message types.String `tfsdk:"message" tf:"optional"` + // Stack trace consisting of a list of stack frames + Stack []StackFrame `tfsdk:"stack" tf:"optional"` +} + +type StackFrame struct { + // Class from which the method call originated + DeclaringClass types.String `tfsdk:"declaring_class" tf:"optional"` + // File where the method is defined + FileName types.String `tfsdk:"file_name" tf:"optional"` + // Line from which the method was called + LineNumber types.Int64 `tfsdk:"line_number" tf:"optional"` + // Name of the method which was called + MethodName types.String `tfsdk:"method_name" tf:"optional"` +} + +type StartUpdate struct { + Cause types.String `tfsdk:"cause" tf:"optional"` + // If true, this update will reset all tables before running. + FullRefresh types.Bool `tfsdk:"full_refresh" tf:"optional"` + // A list of tables to update with fullRefresh. If both refresh_selection + // and full_refresh_selection are empty, this is a full graph update. Full + // Refresh on a table means that the states of the table will be reset + // before the refresh. + FullRefreshSelection []types.String `tfsdk:"full_refresh_selection" tf:"optional"` + + PipelineId types.String `tfsdk:"-"` + // A list of tables to update without fullRefresh. If both refresh_selection + // and full_refresh_selection are empty, this is a full graph update. Full + // Refresh on a table means that the states of the table will be reset + // before the refresh. + RefreshSelection []types.String `tfsdk:"refresh_selection" tf:"optional"` + // If true, this update only validates the correctness of pipeline source + // code but does not materialize or publish any datasets. + ValidateOnly types.Bool `tfsdk:"validate_only" tf:"optional"` +} + +type StartUpdateResponse struct { + UpdateId types.String `tfsdk:"update_id" tf:"optional"` +} + +type StopPipelineResponse struct { +} + +// Stop a pipeline +type StopRequest struct { + PipelineId types.String `tfsdk:"-"` +} + +type TableSpec struct { + // Required. Destination catalog to store table. + DestinationCatalog types.String `tfsdk:"destination_catalog" tf:"optional"` + // Required. Destination schema to store table. + DestinationSchema types.String `tfsdk:"destination_schema" tf:"optional"` + // Optional. Destination table name. The pipeline fails If a table with that + // name already exists. If not set, the source table name is used. + DestinationTable types.String `tfsdk:"destination_table" tf:"optional"` + // Source catalog name. Might be optional depending on the type of source. + SourceCatalog types.String `tfsdk:"source_catalog" tf:"optional"` + // Schema name in the source database. Might be optional depending on the + // type of source. + SourceSchema types.String `tfsdk:"source_schema" tf:"optional"` + // Required. Table name in the source database. + SourceTable types.String `tfsdk:"source_table" tf:"optional"` + // Configuration settings to control the ingestion of tables. These settings + // override the table_configuration defined in the + // ManagedIngestionPipelineDefinition object and the SchemaSpec. + TableConfiguration *TableSpecificConfig `tfsdk:"table_configuration" tf:"optional"` +} + +type TableSpecificConfig struct { + // The primary key of the table used to apply changes. + PrimaryKeys []types.String `tfsdk:"primary_keys" tf:"optional"` + // If true, formula fields defined in the table are included in the + // ingestion. This setting is only valid for the Salesforce connector + SalesforceIncludeFormulaFields types.Bool `tfsdk:"salesforce_include_formula_fields" tf:"optional"` + // The SCD type to use to ingest the table. + ScdType types.String `tfsdk:"scd_type" tf:"optional"` +} + +type UpdateInfo struct { + // What triggered this update. + Cause types.String `tfsdk:"cause" tf:"optional"` + // The ID of the cluster that the update is running on. + ClusterId types.String `tfsdk:"cluster_id" tf:"optional"` + // The pipeline configuration with system defaults applied where unspecified + // by the user. Not returned by ListUpdates. + Config *PipelineSpec `tfsdk:"config" tf:"optional"` + // The time when this update was created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // If true, this update will reset all tables before running. + FullRefresh types.Bool `tfsdk:"full_refresh" tf:"optional"` + // A list of tables to update with fullRefresh. If both refresh_selection + // and full_refresh_selection are empty, this is a full graph update. Full + // Refresh on a table means that the states of the table will be reset + // before the refresh. + FullRefreshSelection []types.String `tfsdk:"full_refresh_selection" tf:"optional"` + // The ID of the pipeline. + PipelineId types.String `tfsdk:"pipeline_id" tf:"optional"` + // A list of tables to update without fullRefresh. If both refresh_selection + // and full_refresh_selection are empty, this is a full graph update. Full + // Refresh on a table means that the states of the table will be reset + // before the refresh. + RefreshSelection []types.String `tfsdk:"refresh_selection" tf:"optional"` + // The update state. + State types.String `tfsdk:"state" tf:"optional"` + // The ID of this update. + UpdateId types.String `tfsdk:"update_id" tf:"optional"` + // If true, this update only validates the correctness of pipeline source + // code but does not materialize or publish any datasets. + ValidateOnly types.Bool `tfsdk:"validate_only" tf:"optional"` +} + +type UpdateStateInfo struct { + CreationTime types.String `tfsdk:"creation_time" tf:"optional"` + + State types.String `tfsdk:"state" tf:"optional"` + + UpdateId types.String `tfsdk:"update_id" tf:"optional"` +} diff --git a/internal/service/provisioning_tf/model.go b/internal/service/provisioning_tf/model.go new file mode 100755 index 0000000000..691c118d6d --- /dev/null +++ b/internal/service/provisioning_tf/model.go @@ -0,0 +1,785 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package provisioning_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type AwsCredentials struct { + StsRole *StsRole `tfsdk:"sts_role" tf:"optional"` +} + +type AwsKeyInfo struct { + // The AWS KMS key alias. + KeyAlias types.String `tfsdk:"key_alias" tf:"optional"` + // The AWS KMS key's Amazon Resource Name (ARN). + KeyArn types.String `tfsdk:"key_arn" tf:""` + // The AWS KMS key region. + KeyRegion types.String `tfsdk:"key_region" tf:""` + // This field applies only if the `use_cases` property includes `STORAGE`. + // If this is set to `true` or omitted, the key is also used to encrypt + // cluster EBS volumes. If you do not want to use this key for encrypting + // EBS volumes, set to `false`. + ReuseKeyForClusterVolumes types.Bool `tfsdk:"reuse_key_for_cluster_volumes" tf:"optional"` +} + +type AzureWorkspaceInfo struct { + // Azure Resource Group name + ResourceGroup types.String `tfsdk:"resource_group" tf:"optional"` + // Azure Subscription ID + SubscriptionId types.String `tfsdk:"subscription_id" tf:"optional"` +} + +// The general workspace configurations that are specific to cloud providers. +type CloudResourceContainer struct { + // The general workspace configurations that are specific to Google Cloud. + Gcp *CustomerFacingGcpCloudResourceContainer `tfsdk:"gcp" tf:"optional"` +} + +type CreateAwsKeyInfo struct { + // The AWS KMS key alias. + KeyAlias types.String `tfsdk:"key_alias" tf:"optional"` + // The AWS KMS key's Amazon Resource Name (ARN). Note that the key's AWS + // region is inferred from the ARN. + KeyArn types.String `tfsdk:"key_arn" tf:""` + // This field applies only if the `use_cases` property includes `STORAGE`. + // If this is set to `true` or omitted, the key is also used to encrypt + // cluster EBS volumes. To not use this key also for encrypting EBS volumes, + // set this to `false`. + ReuseKeyForClusterVolumes types.Bool `tfsdk:"reuse_key_for_cluster_volumes" tf:"optional"` +} + +type CreateCredentialAwsCredentials struct { + StsRole *CreateCredentialStsRole `tfsdk:"sts_role" tf:"optional"` +} + +type CreateCredentialRequest struct { + AwsCredentials CreateCredentialAwsCredentials `tfsdk:"aws_credentials" tf:""` + // The human-readable name of the credential configuration object. + CredentialsName types.String `tfsdk:"credentials_name" tf:""` +} + +type CreateCredentialStsRole struct { + // The Amazon Resource Name (ARN) of the cross account role. + RoleArn types.String `tfsdk:"role_arn" tf:"optional"` +} + +type CreateCustomerManagedKeyRequest struct { + AwsKeyInfo *CreateAwsKeyInfo `tfsdk:"aws_key_info" tf:"optional"` + + GcpKeyInfo *CreateGcpKeyInfo `tfsdk:"gcp_key_info" tf:"optional"` + // The cases that the key can be used for. + UseCases []types.String `tfsdk:"use_cases" tf:""` +} + +type CreateGcpKeyInfo struct { + // The GCP KMS key's resource name + KmsKeyId types.String `tfsdk:"kms_key_id" tf:""` +} + +type CreateNetworkRequest struct { + // The Google Cloud specific information for this network (for example, the + // VPC ID, subnet ID, and secondary IP ranges). + GcpNetworkInfo *GcpNetworkInfo `tfsdk:"gcp_network_info" tf:"optional"` + // The human-readable name of the network configuration. + NetworkName types.String `tfsdk:"network_name" tf:""` + // IDs of one to five security groups associated with this network. Security + // group IDs **cannot** be used in multiple network configurations. + SecurityGroupIds []types.String `tfsdk:"security_group_ids" tf:"optional"` + // IDs of at least two subnets associated with this network. Subnet IDs + // **cannot** be used in multiple network configurations. + SubnetIds []types.String `tfsdk:"subnet_ids" tf:"optional"` + // If specified, contains the VPC endpoints used to allow cluster + // communication from this VPC over [AWS PrivateLink]. + // + // [AWS PrivateLink]: https://aws.amazon.com/privatelink/ + VpcEndpoints *NetworkVpcEndpoints `tfsdk:"vpc_endpoints" tf:"optional"` + // The ID of the VPC associated with this network. VPC IDs can be used in + // multiple network configurations. + VpcId types.String `tfsdk:"vpc_id" tf:"optional"` +} + +type CreateStorageConfigurationRequest struct { + // Root S3 bucket information. + RootBucketInfo RootBucketInfo `tfsdk:"root_bucket_info" tf:""` + // The human-readable name of the storage configuration. + StorageConfigurationName types.String `tfsdk:"storage_configuration_name" tf:""` +} + +type CreateVpcEndpointRequest struct { + // The ID of the VPC endpoint object in AWS. + AwsVpcEndpointId types.String `tfsdk:"aws_vpc_endpoint_id" tf:"optional"` + // The Google Cloud specific information for this Private Service Connect + // endpoint. + GcpVpcEndpointInfo *GcpVpcEndpointInfo `tfsdk:"gcp_vpc_endpoint_info" tf:"optional"` + // The AWS region in which this VPC endpoint object exists. + Region types.String `tfsdk:"region" tf:"optional"` + // The human-readable name of the storage configuration. + VpcEndpointName types.String `tfsdk:"vpc_endpoint_name" tf:""` +} + +type CreateWorkspaceRequest struct { + // The AWS region of the workspace's data plane. + AwsRegion types.String `tfsdk:"aws_region" tf:"optional"` + // The cloud provider which the workspace uses. For Google Cloud workspaces, + // always set this field to `gcp`. + Cloud types.String `tfsdk:"cloud" tf:"optional"` + // The general workspace configurations that are specific to cloud + // providers. + CloudResourceContainer *CloudResourceContainer `tfsdk:"cloud_resource_container" tf:"optional"` + // ID of the workspace's credential configuration object. + CredentialsId types.String `tfsdk:"credentials_id" tf:"optional"` + // The custom tags key-value pairing that is attached to this workspace. The + // key-value pair is a string of utf-8 characters. The value can be an empty + // string, with maximum length of 255 characters. The key can be of maximum + // length of 127 characters, and cannot be empty. + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // The deployment name defines part of the subdomain for the workspace. The + // workspace URL for the web application and REST APIs is + // `.cloud.databricks.com`. For example, if the + // deployment name is `abcsales`, your workspace URL will be + // `https://abcsales.cloud.databricks.com`. Hyphens are allowed. This + // property supports only the set of characters that are allowed in a + // subdomain. + // + // To set this value, you must have a deployment name prefix. Contact your + // Databricks account team to add an account deployment name prefix to your + // account. + // + // Workspace deployment names follow the account prefix and a hyphen. For + // example, if your account's deployment prefix is `acme` and the workspace + // deployment name is `workspace-1`, the JSON response for the + // `deployment_name` field becomes `acme-workspace-1`. The workspace URL + // would be `acme-workspace-1.cloud.databricks.com`. + // + // You can also set the `deployment_name` to the reserved keyword `EMPTY` if + // you want the deployment name to only include the deployment prefix. For + // example, if your account's deployment prefix is `acme` and the workspace + // deployment name is `EMPTY`, the `deployment_name` becomes `acme` only and + // the workspace URL is `acme.cloud.databricks.com`. + // + // This value must be unique across all non-deleted deployments across all + // AWS regions. + // + // If a new workspace omits this property, the server generates a unique + // deployment name for you with the pattern `dbc-xxxxxxxx-xxxx`. + DeploymentName types.String `tfsdk:"deployment_name" tf:"optional"` + // The network settings for the workspace. The configurations are only for + // Databricks-managed VPCs. It is ignored if you specify a customer-managed + // VPC in the `network_id` field.", All the IP range configurations must be + // mutually exclusive. An attempt to create a workspace fails if Databricks + // detects an IP range overlap. + // + // Specify custom IP ranges in CIDR format. The IP ranges for these fields + // must not overlap, and all IP addresses must be entirely within the + // following ranges: `10.0.0.0/8`, `100.64.0.0/10`, `172.16.0.0/12`, + // `192.168.0.0/16`, and `240.0.0.0/4`. + // + // The sizes of these IP ranges affect the maximum number of nodes for the + // workspace. + // + // **Important**: Confirm the IP ranges used by your Databricks workspace + // before creating the workspace. You cannot change them after your + // workspace is deployed. If the IP address ranges for your Databricks are + // too small, IP exhaustion can occur, causing your Databricks jobs to fail. + // To determine the address range sizes that you need, Databricks provides a + // calculator as a Microsoft Excel spreadsheet. See [calculate subnet sizes + // for a new workspace]. + // + // [calculate subnet sizes for a new workspace]: https://docs.gcp.databricks.com/administration-guide/cloud-configurations/gcp/network-sizing.html + GcpManagedNetworkConfig *GcpManagedNetworkConfig `tfsdk:"gcp_managed_network_config" tf:"optional"` + // The configurations for the GKE cluster of a Databricks workspace. + GkeConfig *GkeConfig `tfsdk:"gke_config" tf:"optional"` + // The Google Cloud region of the workspace data plane in your Google + // account. For example, `us-east4`. + Location types.String `tfsdk:"location" tf:"optional"` + // The ID of the workspace's managed services encryption key configuration + // object. This is used to help protect and control access to the + // workspace's notebooks, secrets, Databricks SQL queries, and query + // history. The provided key configuration object property `use_cases` must + // contain `MANAGED_SERVICES`. + ManagedServicesCustomerManagedKeyId types.String `tfsdk:"managed_services_customer_managed_key_id" tf:"optional"` + + NetworkId types.String `tfsdk:"network_id" tf:"optional"` + // The pricing tier of the workspace. For pricing tier information, see [AWS + // Pricing]. + // + // [AWS Pricing]: https://databricks.com/product/aws-pricing + PricingTier types.String `tfsdk:"pricing_tier" tf:"optional"` + // ID of the workspace's private access settings object. Only used for + // PrivateLink. This ID must be specified for customers using [AWS + // PrivateLink] for either front-end (user-to-workspace connection), + // back-end (data plane to control plane connection), or both connection + // types. + // + // Before configuring PrivateLink, read the [Databricks article about + // PrivateLink].", + // + // [AWS PrivateLink]: https://aws.amazon.com/privatelink/ + // [Databricks article about PrivateLink]: https://docs.databricks.com/administration-guide/cloud-configurations/aws/privatelink.html + PrivateAccessSettingsId types.String `tfsdk:"private_access_settings_id" tf:"optional"` + // The ID of the workspace's storage configuration object. + StorageConfigurationId types.String `tfsdk:"storage_configuration_id" tf:"optional"` + // The ID of the workspace's storage encryption key configuration object. + // This is used to encrypt the workspace's root S3 bucket (root DBFS and + // system data) and, optionally, cluster EBS volumes. The provided key + // configuration object property `use_cases` must contain `STORAGE`. + StorageCustomerManagedKeyId types.String `tfsdk:"storage_customer_managed_key_id" tf:"optional"` + // The workspace's human-readable name. + WorkspaceName types.String `tfsdk:"workspace_name" tf:""` +} + +type Credential struct { + // The Databricks account ID that hosts the credential. + AccountId types.String `tfsdk:"account_id" tf:"optional"` + + AwsCredentials *AwsCredentials `tfsdk:"aws_credentials" tf:"optional"` + // Time in epoch milliseconds when the credential was created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // Databricks credential configuration ID. + CredentialsId types.String `tfsdk:"credentials_id" tf:"optional"` + // The human-readable name of the credential configuration object. + CredentialsName types.String `tfsdk:"credentials_name" tf:"optional"` +} + +// The general workspace configurations that are specific to Google Cloud. +type CustomerFacingGcpCloudResourceContainer struct { + // The Google Cloud project ID, which the workspace uses to instantiate + // cloud resources for your workspace. + ProjectId types.String `tfsdk:"project_id" tf:"optional"` +} + +type CustomerManagedKey struct { + // The Databricks account ID that holds the customer-managed key. + AccountId types.String `tfsdk:"account_id" tf:"optional"` + + AwsKeyInfo *AwsKeyInfo `tfsdk:"aws_key_info" tf:"optional"` + // Time in epoch milliseconds when the customer key was created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // ID of the encryption key configuration object. + CustomerManagedKeyId types.String `tfsdk:"customer_managed_key_id" tf:"optional"` + + GcpKeyInfo *GcpKeyInfo `tfsdk:"gcp_key_info" tf:"optional"` + // The cases that the key can be used for. + UseCases []types.String `tfsdk:"use_cases" tf:"optional"` +} + +// Delete credential configuration +type DeleteCredentialRequest struct { + // Databricks Account API credential configuration ID + CredentialsId types.String `tfsdk:"-"` +} + +// Delete encryption key configuration +type DeleteEncryptionKeyRequest struct { + // Databricks encryption key configuration ID. + CustomerManagedKeyId types.String `tfsdk:"-"` +} + +// Delete a network configuration +type DeleteNetworkRequest struct { + // Databricks Account API network configuration ID. + NetworkId types.String `tfsdk:"-"` +} + +// Delete a private access settings object +type DeletePrivateAccesRequest struct { + // Databricks Account API private access settings ID. + PrivateAccessSettingsId types.String `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +// Delete storage configuration +type DeleteStorageRequest struct { + // Databricks Account API storage configuration ID. + StorageConfigurationId types.String `tfsdk:"-"` +} + +// Delete VPC endpoint configuration +type DeleteVpcEndpointRequest struct { + // Databricks VPC endpoint ID. + VpcEndpointId types.String `tfsdk:"-"` +} + +// Delete a workspace +type DeleteWorkspaceRequest struct { + // Workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type GcpKeyInfo struct { + // The GCP KMS key's resource name + KmsKeyId types.String `tfsdk:"kms_key_id" tf:""` +} + +// The network settings for the workspace. The configurations are only for +// Databricks-managed VPCs. It is ignored if you specify a customer-managed VPC +// in the `network_id` field.", All the IP range configurations must be mutually +// exclusive. An attempt to create a workspace fails if Databricks detects an IP +// range overlap. +// +// Specify custom IP ranges in CIDR format. The IP ranges for these fields must +// not overlap, and all IP addresses must be entirely within the following +// ranges: `10.0.0.0/8`, `100.64.0.0/10`, `172.16.0.0/12`, `192.168.0.0/16`, and +// `240.0.0.0/4`. +// +// The sizes of these IP ranges affect the maximum number of nodes for the +// workspace. +// +// **Important**: Confirm the IP ranges used by your Databricks workspace before +// creating the workspace. You cannot change them after your workspace is +// deployed. If the IP address ranges for your Databricks are too small, IP +// exhaustion can occur, causing your Databricks jobs to fail. To determine the +// address range sizes that you need, Databricks provides a calculator as a +// Microsoft Excel spreadsheet. See [calculate subnet sizes for a new +// workspace]. +// +// [calculate subnet sizes for a new workspace]: https://docs.gcp.databricks.com/administration-guide/cloud-configurations/gcp/network-sizing.html +type GcpManagedNetworkConfig struct { + // The IP range from which to allocate GKE cluster pods. No bigger than `/9` + // and no smaller than `/21`. + GkeClusterPodIpRange types.String `tfsdk:"gke_cluster_pod_ip_range" tf:"optional"` + // The IP range from which to allocate GKE cluster services. No bigger than + // `/16` and no smaller than `/27`. + GkeClusterServiceIpRange types.String `tfsdk:"gke_cluster_service_ip_range" tf:"optional"` + // The IP range from which to allocate GKE cluster nodes. No bigger than + // `/9` and no smaller than `/29`. + SubnetCidr types.String `tfsdk:"subnet_cidr" tf:"optional"` +} + +// The Google Cloud specific information for this network (for example, the VPC +// ID, subnet ID, and secondary IP ranges). +type GcpNetworkInfo struct { + // The Google Cloud project ID of the VPC network. + NetworkProjectId types.String `tfsdk:"network_project_id" tf:""` + // The name of the secondary IP range for pods. A Databricks-managed GKE + // cluster uses this IP range for its pods. This secondary IP range can be + // used by only one workspace. + PodIpRangeName types.String `tfsdk:"pod_ip_range_name" tf:""` + // The name of the secondary IP range for services. A Databricks-managed GKE + // cluster uses this IP range for its services. This secondary IP range can + // be used by only one workspace. + ServiceIpRangeName types.String `tfsdk:"service_ip_range_name" tf:""` + // The ID of the subnet associated with this network. + SubnetId types.String `tfsdk:"subnet_id" tf:""` + // The Google Cloud region of the workspace data plane (for example, + // `us-east4`). + SubnetRegion types.String `tfsdk:"subnet_region" tf:""` + // The ID of the VPC associated with this network. VPC IDs can be used in + // multiple network configurations. + VpcId types.String `tfsdk:"vpc_id" tf:""` +} + +// The Google Cloud specific information for this Private Service Connect +// endpoint. +type GcpVpcEndpointInfo struct { + // Region of the PSC endpoint. + EndpointRegion types.String `tfsdk:"endpoint_region" tf:""` + // The Google Cloud project ID of the VPC network where the PSC connection + // resides. + ProjectId types.String `tfsdk:"project_id" tf:""` + // The unique ID of this PSC connection. + PscConnectionId types.String `tfsdk:"psc_connection_id" tf:"optional"` + // The name of the PSC endpoint in the Google Cloud project. + PscEndpointName types.String `tfsdk:"psc_endpoint_name" tf:""` + // The service attachment this PSC connection connects to. + ServiceAttachmentId types.String `tfsdk:"service_attachment_id" tf:"optional"` +} + +// Get credential configuration +type GetCredentialRequest struct { + // Databricks Account API credential configuration ID + CredentialsId types.String `tfsdk:"-"` +} + +// Get encryption key configuration +type GetEncryptionKeyRequest struct { + // Databricks encryption key configuration ID. + CustomerManagedKeyId types.String `tfsdk:"-"` +} + +// Get a network configuration +type GetNetworkRequest struct { + // Databricks Account API network configuration ID. + NetworkId types.String `tfsdk:"-"` +} + +// Get a private access settings object +type GetPrivateAccesRequest struct { + // Databricks Account API private access settings ID. + PrivateAccessSettingsId types.String `tfsdk:"-"` +} + +// Get storage configuration +type GetStorageRequest struct { + // Databricks Account API storage configuration ID. + StorageConfigurationId types.String `tfsdk:"-"` +} + +// Get a VPC endpoint configuration +type GetVpcEndpointRequest struct { + // Databricks VPC endpoint ID. + VpcEndpointId types.String `tfsdk:"-"` +} + +// Get a workspace +type GetWorkspaceRequest struct { + // Workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +// The configurations for the GKE cluster of a Databricks workspace. +type GkeConfig struct { + // Specifies the network connectivity types for the GKE nodes and the GKE + // master network. + // + // Set to `PRIVATE_NODE_PUBLIC_MASTER` for a private GKE cluster for the + // workspace. The GKE nodes will not have public IPs. + // + // Set to `PUBLIC_NODE_PUBLIC_MASTER` for a public GKE cluster. The nodes of + // a public GKE cluster have public IP addresses. + ConnectivityType types.String `tfsdk:"connectivity_type" tf:"optional"` + // The IP range from which to allocate GKE cluster master resources. This + // field will be ignored if GKE private cluster is not enabled. + // + // It must be exactly as big as `/28`. + MasterIpRange types.String `tfsdk:"master_ip_range" tf:"optional"` +} + +type Network struct { + // The Databricks account ID associated with this network configuration. + AccountId types.String `tfsdk:"account_id" tf:"optional"` + // Time in epoch milliseconds when the network was created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // Array of error messages about the network configuration. + ErrorMessages []NetworkHealth `tfsdk:"error_messages" tf:"optional"` + // The Google Cloud specific information for this network (for example, the + // VPC ID, subnet ID, and secondary IP ranges). + GcpNetworkInfo *GcpNetworkInfo `tfsdk:"gcp_network_info" tf:"optional"` + // The Databricks network configuration ID. + NetworkId types.String `tfsdk:"network_id" tf:"optional"` + // The human-readable name of the network configuration. + NetworkName types.String `tfsdk:"network_name" tf:"optional"` + + SecurityGroupIds []types.String `tfsdk:"security_group_ids" tf:"optional"` + + SubnetIds []types.String `tfsdk:"subnet_ids" tf:"optional"` + // If specified, contains the VPC endpoints used to allow cluster + // communication from this VPC over [AWS PrivateLink]. + // + // [AWS PrivateLink]: https://aws.amazon.com/privatelink/ + VpcEndpoints *NetworkVpcEndpoints `tfsdk:"vpc_endpoints" tf:"optional"` + // The ID of the VPC associated with this network configuration. VPC IDs can + // be used in multiple networks. + VpcId types.String `tfsdk:"vpc_id" tf:"optional"` + // The status of this network configuration object in terms of its use in a + // workspace: * `UNATTACHED`: Unattached. * `VALID`: Valid. * `BROKEN`: + // Broken. * `WARNED`: Warned. + VpcStatus types.String `tfsdk:"vpc_status" tf:"optional"` + // Array of warning messages about the network configuration. + WarningMessages []NetworkWarning `tfsdk:"warning_messages" tf:"optional"` + // Workspace ID associated with this network configuration. + WorkspaceId types.Int64 `tfsdk:"workspace_id" tf:"optional"` +} + +type NetworkHealth struct { + // Details of the error. + ErrorMessage types.String `tfsdk:"error_message" tf:"optional"` + // The AWS resource associated with this error: credentials, VPC, subnet, + // security group, or network ACL. + ErrorType types.String `tfsdk:"error_type" tf:"optional"` +} + +// If specified, contains the VPC endpoints used to allow cluster communication +// from this VPC over [AWS PrivateLink]. +// +// [AWS PrivateLink]: https://aws.amazon.com/privatelink/ +type NetworkVpcEndpoints struct { + // The VPC endpoint ID used by this network to access the Databricks secure + // cluster connectivity relay. + DataplaneRelay []types.String `tfsdk:"dataplane_relay" tf:""` + // The VPC endpoint ID used by this network to access the Databricks REST + // API. + RestApi []types.String `tfsdk:"rest_api" tf:""` +} + +type NetworkWarning struct { + // Details of the warning. + WarningMessage types.String `tfsdk:"warning_message" tf:"optional"` + // The AWS resource associated with this warning: a subnet or a security + // group. + WarningType types.String `tfsdk:"warning_type" tf:"optional"` +} + +type PrivateAccessSettings struct { + // The Databricks account ID that hosts the credential. + AccountId types.String `tfsdk:"account_id" tf:"optional"` + // An array of Databricks VPC endpoint IDs. + AllowedVpcEndpointIds []types.String `tfsdk:"allowed_vpc_endpoint_ids" tf:"optional"` + // The private access level controls which VPC endpoints can connect to the + // UI or API of any workspace that attaches this private access settings + // object. * `ACCOUNT` level access (the default) allows only VPC endpoints + // that are registered in your Databricks account connect to your workspace. + // * `ENDPOINT` level access allows only specified VPC endpoints connect to + // your workspace. For details, see `allowed_vpc_endpoint_ids`. + PrivateAccessLevel types.String `tfsdk:"private_access_level" tf:"optional"` + // Databricks private access settings ID. + PrivateAccessSettingsId types.String `tfsdk:"private_access_settings_id" tf:"optional"` + // The human-readable name of the private access settings object. + PrivateAccessSettingsName types.String `tfsdk:"private_access_settings_name" tf:"optional"` + // Determines if the workspace can be accessed over public internet. For + // fully private workspaces, you can optionally specify `false`, but only if + // you implement both the front-end and the back-end PrivateLink + // connections. Otherwise, specify `true`, which means that public access is + // enabled. + PublicAccessEnabled types.Bool `tfsdk:"public_access_enabled" tf:"optional"` + // The cloud region for workspaces attached to this private access settings + // object. + Region types.String `tfsdk:"region" tf:"optional"` +} + +type ReplaceResponse struct { +} + +// Root S3 bucket information. +type RootBucketInfo struct { + // The name of the S3 bucket. + BucketName types.String `tfsdk:"bucket_name" tf:"optional"` +} + +type StorageConfiguration struct { + // The Databricks account ID that hosts the credential. + AccountId types.String `tfsdk:"account_id" tf:"optional"` + // Time in epoch milliseconds when the storage configuration was created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // Root S3 bucket information. + RootBucketInfo *RootBucketInfo `tfsdk:"root_bucket_info" tf:"optional"` + // Databricks storage configuration ID. + StorageConfigurationId types.String `tfsdk:"storage_configuration_id" tf:"optional"` + // The human-readable name of the storage configuration. + StorageConfigurationName types.String `tfsdk:"storage_configuration_name" tf:"optional"` +} + +type StsRole struct { + // The external ID that needs to be trusted by the cross-account role. This + // is always your Databricks account ID. + ExternalId types.String `tfsdk:"external_id" tf:"optional"` + // The Amazon Resource Name (ARN) of the cross account role. + RoleArn types.String `tfsdk:"role_arn" tf:"optional"` +} + +type UpdateResponse struct { +} + +type UpdateWorkspaceRequest struct { + // The AWS region of the workspace's data plane (for example, `us-west-2`). + // This parameter is available only for updating failed workspaces. + AwsRegion types.String `tfsdk:"aws_region" tf:"optional"` + // ID of the workspace's credential configuration object. This parameter is + // available for updating both failed and running workspaces. + CredentialsId types.String `tfsdk:"credentials_id" tf:"optional"` + // The custom tags key-value pairing that is attached to this workspace. The + // key-value pair is a string of utf-8 characters. The value can be an empty + // string, with maximum length of 255 characters. The key can be of maximum + // length of 127 characters, and cannot be empty. + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // The ID of the workspace's managed services encryption key configuration + // object. This parameter is available only for updating failed workspaces. + ManagedServicesCustomerManagedKeyId types.String `tfsdk:"managed_services_customer_managed_key_id" tf:"optional"` + + NetworkConnectivityConfigId types.String `tfsdk:"network_connectivity_config_id" tf:"optional"` + // The ID of the workspace's network configuration object. Used only if you + // already use a customer-managed VPC. For failed workspaces only, you can + // switch from a Databricks-managed VPC to a customer-managed VPC by + // updating the workspace to add a network configuration ID. + NetworkId types.String `tfsdk:"network_id" tf:"optional"` + // The ID of the workspace's storage configuration object. This parameter is + // available only for updating failed workspaces. + StorageConfigurationId types.String `tfsdk:"storage_configuration_id" tf:"optional"` + // The ID of the key configuration object for workspace storage. This + // parameter is available for updating both failed and running workspaces. + StorageCustomerManagedKeyId types.String `tfsdk:"storage_customer_managed_key_id" tf:"optional"` + // Workspace ID. + WorkspaceId types.Int64 `tfsdk:"-"` +} + +type UpsertPrivateAccessSettingsRequest struct { + // An array of Databricks VPC endpoint IDs. This is the Databricks ID that + // is returned when registering the VPC endpoint configuration in your + // Databricks account. This is not the ID of the VPC endpoint in AWS. + // + // Only used when `private_access_level` is set to `ENDPOINT`. This is an + // allow list of VPC endpoints that in your account that can connect to your + // workspace over AWS PrivateLink. + // + // If hybrid access to your workspace is enabled by setting + // `public_access_enabled` to `true`, this control only works for + // PrivateLink connections. To control how your workspace is accessed via + // public internet, see [IP access lists]. + // + // [IP access lists]: https://docs.databricks.com/security/network/ip-access-list.html + AllowedVpcEndpointIds []types.String `tfsdk:"allowed_vpc_endpoint_ids" tf:"optional"` + // The private access level controls which VPC endpoints can connect to the + // UI or API of any workspace that attaches this private access settings + // object. * `ACCOUNT` level access (the default) allows only VPC endpoints + // that are registered in your Databricks account connect to your workspace. + // * `ENDPOINT` level access allows only specified VPC endpoints connect to + // your workspace. For details, see `allowed_vpc_endpoint_ids`. + PrivateAccessLevel types.String `tfsdk:"private_access_level" tf:"optional"` + // Databricks Account API private access settings ID. + PrivateAccessSettingsId types.String `tfsdk:"-"` + // The human-readable name of the private access settings object. + PrivateAccessSettingsName types.String `tfsdk:"private_access_settings_name" tf:""` + // Determines if the workspace can be accessed over public internet. For + // fully private workspaces, you can optionally specify `false`, but only if + // you implement both the front-end and the back-end PrivateLink + // connections. Otherwise, specify `true`, which means that public access is + // enabled. + PublicAccessEnabled types.Bool `tfsdk:"public_access_enabled" tf:"optional"` + // The cloud region for workspaces associated with this private access + // settings object. + Region types.String `tfsdk:"region" tf:""` +} + +type VpcEndpoint struct { + // The Databricks account ID that hosts the VPC endpoint configuration. + AccountId types.String `tfsdk:"account_id" tf:"optional"` + // The AWS Account in which the VPC endpoint object exists. + AwsAccountId types.String `tfsdk:"aws_account_id" tf:"optional"` + // The ID of the Databricks [endpoint service] that this VPC endpoint is + // connected to. For a list of endpoint service IDs for each supported AWS + // region, see the [Databricks PrivateLink documentation]. + // + // [Databricks PrivateLink documentation]: https://docs.databricks.com/administration-guide/cloud-configurations/aws/privatelink.html + // [endpoint service]: https://docs.aws.amazon.com/vpc/latest/privatelink/endpoint-service.html + AwsEndpointServiceId types.String `tfsdk:"aws_endpoint_service_id" tf:"optional"` + // The ID of the VPC endpoint object in AWS. + AwsVpcEndpointId types.String `tfsdk:"aws_vpc_endpoint_id" tf:"optional"` + // The Google Cloud specific information for this Private Service Connect + // endpoint. + GcpVpcEndpointInfo *GcpVpcEndpointInfo `tfsdk:"gcp_vpc_endpoint_info" tf:"optional"` + // The AWS region in which this VPC endpoint object exists. + Region types.String `tfsdk:"region" tf:"optional"` + // The current state (such as `available` or `rejected`) of the VPC + // endpoint. Derived from AWS. For the full set of values, see [AWS + // DescribeVpcEndpoint documentation]. + // + // [AWS DescribeVpcEndpoint documentation]: https://docs.aws.amazon.com/cli/latest/reference/ec2/describe-vpc-endpoints.html + State types.String `tfsdk:"state" tf:"optional"` + // This enumeration represents the type of Databricks VPC [endpoint service] + // that was used when creating this VPC endpoint. + // + // [endpoint service]: https://docs.aws.amazon.com/vpc/latest/privatelink/endpoint-service.html + UseCase types.String `tfsdk:"use_case" tf:"optional"` + // Databricks VPC endpoint ID. This is the Databricks-specific name of the + // VPC endpoint. Do not confuse this with the `aws_vpc_endpoint_id`, which + // is the ID within AWS of the VPC endpoint. + VpcEndpointId types.String `tfsdk:"vpc_endpoint_id" tf:"optional"` + // The human-readable name of the storage configuration. + VpcEndpointName types.String `tfsdk:"vpc_endpoint_name" tf:"optional"` +} + +type Workspace struct { + // Databricks account ID. + AccountId types.String `tfsdk:"account_id" tf:"optional"` + // The AWS region of the workspace data plane (for example, `us-west-2`). + AwsRegion types.String `tfsdk:"aws_region" tf:"optional"` + + AzureWorkspaceInfo *AzureWorkspaceInfo `tfsdk:"azure_workspace_info" tf:"optional"` + // The cloud name. This field always has the value `gcp`. + Cloud types.String `tfsdk:"cloud" tf:"optional"` + // The general workspace configurations that are specific to cloud + // providers. + CloudResourceContainer *CloudResourceContainer `tfsdk:"cloud_resource_container" tf:"optional"` + // Time in epoch milliseconds when the workspace was created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // ID of the workspace's credential configuration object. + CredentialsId types.String `tfsdk:"credentials_id" tf:"optional"` + // The custom tags key-value pairing that is attached to this workspace. The + // key-value pair is a string of utf-8 characters. The value can be an empty + // string, with maximum length of 255 characters. The key can be of maximum + // length of 127 characters, and cannot be empty. + CustomTags map[string]types.String `tfsdk:"custom_tags" tf:"optional"` + // The deployment name defines part of the subdomain for the workspace. The + // workspace URL for web application and REST APIs is + // `.cloud.databricks.com`. + // + // This value must be unique across all non-deleted deployments across all + // AWS regions. + DeploymentName types.String `tfsdk:"deployment_name" tf:"optional"` + // The network settings for the workspace. The configurations are only for + // Databricks-managed VPCs. It is ignored if you specify a customer-managed + // VPC in the `network_id` field.", All the IP range configurations must be + // mutually exclusive. An attempt to create a workspace fails if Databricks + // detects an IP range overlap. + // + // Specify custom IP ranges in CIDR format. The IP ranges for these fields + // must not overlap, and all IP addresses must be entirely within the + // following ranges: `10.0.0.0/8`, `100.64.0.0/10`, `172.16.0.0/12`, + // `192.168.0.0/16`, and `240.0.0.0/4`. + // + // The sizes of these IP ranges affect the maximum number of nodes for the + // workspace. + // + // **Important**: Confirm the IP ranges used by your Databricks workspace + // before creating the workspace. You cannot change them after your + // workspace is deployed. If the IP address ranges for your Databricks are + // too small, IP exhaustion can occur, causing your Databricks jobs to fail. + // To determine the address range sizes that you need, Databricks provides a + // calculator as a Microsoft Excel spreadsheet. See [calculate subnet sizes + // for a new workspace]. + // + // [calculate subnet sizes for a new workspace]: https://docs.gcp.databricks.com/administration-guide/cloud-configurations/gcp/network-sizing.html + GcpManagedNetworkConfig *GcpManagedNetworkConfig `tfsdk:"gcp_managed_network_config" tf:"optional"` + // The configurations for the GKE cluster of a Databricks workspace. + GkeConfig *GkeConfig `tfsdk:"gke_config" tf:"optional"` + // The Google Cloud region of the workspace data plane in your Google + // account (for example, `us-east4`). + Location types.String `tfsdk:"location" tf:"optional"` + // ID of the key configuration for encrypting managed services. + ManagedServicesCustomerManagedKeyId types.String `tfsdk:"managed_services_customer_managed_key_id" tf:"optional"` + // The network configuration ID that is attached to the workspace. This + // field is available only if the network is a customer-managed network. + NetworkId types.String `tfsdk:"network_id" tf:"optional"` + // The pricing tier of the workspace. For pricing tier information, see [AWS + // Pricing]. + // + // [AWS Pricing]: https://databricks.com/product/aws-pricing + PricingTier types.String `tfsdk:"pricing_tier" tf:"optional"` + // ID of the workspace's private access settings object. Only used for + // PrivateLink. You must specify this ID if you are using [AWS PrivateLink] + // for either front-end (user-to-workspace connection), back-end (data plane + // to control plane connection), or both connection types. + // + // Before configuring PrivateLink, read the [Databricks article about + // PrivateLink].", + // + // [AWS PrivateLink]: https://aws.amazon.com/privatelink/ + // [Databricks article about PrivateLink]: https://docs.databricks.com/administration-guide/cloud-configurations/aws/privatelink.html + PrivateAccessSettingsId types.String `tfsdk:"private_access_settings_id" tf:"optional"` + // ID of the workspace's storage configuration object. + StorageConfigurationId types.String `tfsdk:"storage_configuration_id" tf:"optional"` + // ID of the key configuration for encrypting workspace storage. + StorageCustomerManagedKeyId types.String `tfsdk:"storage_customer_managed_key_id" tf:"optional"` + // A unique integer ID for the workspace + WorkspaceId types.Int64 `tfsdk:"workspace_id" tf:"optional"` + // The human-readable name of the workspace. + WorkspaceName types.String `tfsdk:"workspace_name" tf:"optional"` + // The status of the workspace. For workspace creation, usually it is set to + // `PROVISIONING` initially. Continue to check the status until the status + // is `RUNNING`. + WorkspaceStatus types.String `tfsdk:"workspace_status" tf:"optional"` + // Message describing the current workspace status. + WorkspaceStatusMessage types.String `tfsdk:"workspace_status_message" tf:"optional"` +} diff --git a/internal/service/serving_tf/model.go b/internal/service/serving_tf/model.go new file mode 100755 index 0000000000..549c4182b7 --- /dev/null +++ b/internal/service/serving_tf/model.go @@ -0,0 +1,1107 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package serving_tf + +import ( + "io" + + "github.com/databricks/databricks-sdk-go/service/oauth2" + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type Ai21LabsConfig struct { + // The Databricks secret key reference for an AI21Labs API key. + Ai21labsApiKey types.String `tfsdk:"ai21labs_api_key" tf:""` +} + +type AmazonBedrockConfig struct { + // The Databricks secret key reference for an AWS Access Key ID with + // permissions to interact with Bedrock services. + AwsAccessKeyId types.String `tfsdk:"aws_access_key_id" tf:""` + // The AWS region to use. Bedrock has to be enabled there. + AwsRegion types.String `tfsdk:"aws_region" tf:""` + // The Databricks secret key reference for an AWS Secret Access Key paired + // with the access key ID, with permissions to interact with Bedrock + // services. + AwsSecretAccessKey types.String `tfsdk:"aws_secret_access_key" tf:""` + // The underlying provider in Amazon Bedrock. Supported values (case + // insensitive) include: Anthropic, Cohere, AI21Labs, Amazon. + BedrockProvider types.String `tfsdk:"bedrock_provider" tf:""` +} + +type AnthropicConfig struct { + // The Databricks secret key reference for an Anthropic API key. + AnthropicApiKey types.String `tfsdk:"anthropic_api_key" tf:""` +} + +type App struct { + // The active deployment of the app. + ActiveDeployment *AppDeployment `tfsdk:"active_deployment" tf:"optional"` + // The creation time of the app. Formatted timestamp in ISO 6801. + CreateTime types.String `tfsdk:"create_time" tf:"optional"` + // The email of the user that created the app. + Creator types.String `tfsdk:"creator" tf:"optional"` + // The description of the app. + Description types.String `tfsdk:"description" tf:"optional"` + // The name of the app. The name must contain only lowercase alphanumeric + // characters and hyphens. It must be unique within the workspace. + Name types.String `tfsdk:"name" tf:""` + // The pending deployment of the app. + PendingDeployment *AppDeployment `tfsdk:"pending_deployment" tf:"optional"` + + ServicePrincipalId types.Int64 `tfsdk:"service_principal_id" tf:"optional"` + + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + + Status *AppStatus `tfsdk:"status" tf:"optional"` + // The update time of the app. Formatted timestamp in ISO 6801. + UpdateTime types.String `tfsdk:"update_time" tf:"optional"` + // The email of the user that last updated the app. + Updater types.String `tfsdk:"updater" tf:"optional"` + // The URL of the app once it is deployed. + Url types.String `tfsdk:"url" tf:"optional"` +} + +type AppDeployment struct { + // The creation time of the deployment. Formatted timestamp in ISO 6801. + CreateTime types.String `tfsdk:"create_time" tf:"optional"` + // The email of the user creates the deployment. + Creator types.String `tfsdk:"creator" tf:"optional"` + // The deployment artifacts for an app. + DeploymentArtifacts *AppDeploymentArtifacts `tfsdk:"deployment_artifacts" tf:"optional"` + // The unique id of the deployment. + DeploymentId types.String `tfsdk:"deployment_id" tf:"optional"` + // The mode of which the deployment will manage the source code. + Mode types.String `tfsdk:"mode" tf:""` + // The workspace file system path of the source code used to create the app + // deployment. This is different from + // `deployment_artifacts.source_code_path`, which is the path used by the + // deployed app. The former refers to the original source code location of + // the app in the workspace during deployment creation, whereas the latter + // provides a system generated stable snapshotted source code path used by + // the deployment. + SourceCodePath types.String `tfsdk:"source_code_path" tf:""` + // Status and status message of the deployment + Status *AppDeploymentStatus `tfsdk:"status" tf:"optional"` + // The update time of the deployment. Formatted timestamp in ISO 6801. + UpdateTime types.String `tfsdk:"update_time" tf:"optional"` +} + +type AppDeploymentArtifacts struct { + // The snapshotted workspace file system path of the source code loaded by + // the deployed app. + SourceCodePath types.String `tfsdk:"source_code_path" tf:"optional"` +} + +type AppDeploymentStatus struct { + // Message corresponding with the deployment state. + Message types.String `tfsdk:"message" tf:"optional"` + // State of the deployment. + State types.String `tfsdk:"state" tf:"optional"` +} + +type AppEnvironment struct { + Env []EnvVariable `tfsdk:"env" tf:"optional"` +} + +type AppStatus struct { + // Message corresponding with the app state. + Message types.String `tfsdk:"message" tf:"optional"` + // State of the app. + State types.String `tfsdk:"state" tf:"optional"` +} + +type AutoCaptureConfigInput struct { + // The name of the catalog in Unity Catalog. NOTE: On update, you cannot + // change the catalog name if the inference table is already enabled. + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // Indicates whether the inference table is enabled. + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` + // The name of the schema in Unity Catalog. NOTE: On update, you cannot + // change the schema name if the inference table is already enabled. + SchemaName types.String `tfsdk:"schema_name" tf:"optional"` + // The prefix of the table in Unity Catalog. NOTE: On update, you cannot + // change the prefix name if the inference table is already enabled. + TableNamePrefix types.String `tfsdk:"table_name_prefix" tf:"optional"` +} + +type AutoCaptureConfigOutput struct { + // The name of the catalog in Unity Catalog. + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // Indicates whether the inference table is enabled. + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` + // The name of the schema in Unity Catalog. + SchemaName types.String `tfsdk:"schema_name" tf:"optional"` + + State *AutoCaptureState `tfsdk:"state" tf:"optional"` + // The prefix of the table in Unity Catalog. + TableNamePrefix types.String `tfsdk:"table_name_prefix" tf:"optional"` +} + +type AutoCaptureState struct { + PayloadTable *PayloadTable `tfsdk:"payload_table" tf:"optional"` +} + +// Get build logs for a served model +type BuildLogsRequest struct { + // The name of the serving endpoint that the served model belongs to. This + // field is required. + Name types.String `tfsdk:"-"` + // The name of the served model that build logs will be retrieved for. This + // field is required. + ServedModelName types.String `tfsdk:"-"` +} + +type BuildLogsResponse struct { + // The logs associated with building the served entity's environment. + Logs types.String `tfsdk:"logs" tf:""` +} + +type ChatMessage struct { + // The content of the message. + Content types.String `tfsdk:"content" tf:"optional"` + // The role of the message. One of [system, user, assistant]. + Role types.String `tfsdk:"role" tf:"optional"` +} + +type CohereConfig struct { + // The Databricks secret key reference for a Cohere API key. + CohereApiKey types.String `tfsdk:"cohere_api_key" tf:""` +} + +type CreateAppDeploymentRequest struct { + // The name of the app. + AppName types.String `tfsdk:"-"` + // The mode of which the deployment will manage the source code. + Mode types.String `tfsdk:"mode" tf:""` + // The workspace file system path of the source code used to create the app + // deployment. This is different from + // `deployment_artifacts.source_code_path`, which is the path used by the + // deployed app. The former refers to the original source code location of + // the app in the workspace during deployment creation, whereas the latter + // provides a system generated stable snapshotted source code path used by + // the deployment. + SourceCodePath types.String `tfsdk:"source_code_path" tf:""` +} + +type CreateAppRequest struct { + // The description of the app. + Description types.String `tfsdk:"description" tf:"optional"` + // The name of the app. The name must contain only lowercase alphanumeric + // characters and hyphens. It must be unique within the workspace. + Name types.String `tfsdk:"name" tf:""` +} + +type CreateServingEndpoint struct { + // The core config of the serving endpoint. + Config EndpointCoreConfigInput `tfsdk:"config" tf:""` + // The name of the serving endpoint. This field is required and must be + // unique across a Databricks workspace. An endpoint name can consist of + // alphanumeric characters, dashes, and underscores. + Name types.String `tfsdk:"name" tf:""` + // Rate limits to be applied to the serving endpoint. NOTE: only external + // and foundation model endpoints are supported as of now. + RateLimits []RateLimit `tfsdk:"rate_limits" tf:"optional"` + // Enable route optimization for the serving endpoint. + RouteOptimized types.Bool `tfsdk:"route_optimized" tf:"optional"` + // Tags to be attached to the serving endpoint and automatically propagated + // to billing logs. + Tags []EndpointTag `tfsdk:"tags" tf:"optional"` +} + +type DatabricksModelServingConfig struct { + // The Databricks secret key reference for a Databricks API token that + // corresponds to a user or service principal with Can Query access to the + // model serving endpoint pointed to by this external model. + DatabricksApiToken types.String `tfsdk:"databricks_api_token" tf:""` + // The URL of the Databricks workspace containing the model serving endpoint + // pointed to by this external model. + DatabricksWorkspaceUrl types.String `tfsdk:"databricks_workspace_url" tf:""` +} + +type DataframeSplitInput struct { + Columns []any `tfsdk:"columns" tf:"optional"` + + Data []any `tfsdk:"data" tf:"optional"` + + Index []types.Int64 `tfsdk:"index" tf:"optional"` +} + +// Delete an app +type DeleteAppRequest struct { + // The name of the app. + Name types.String `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +// Delete a serving endpoint +type DeleteServingEndpointRequest struct { + // The name of the serving endpoint. This field is required. + Name types.String `tfsdk:"-"` +} + +type EmbeddingsV1ResponseEmbeddingElement struct { + Embedding []types.Float64 `tfsdk:"embedding" tf:"optional"` + // The index of the embedding in the response. + Index types.Int64 `tfsdk:"index" tf:"optional"` + // This will always be 'embedding'. + Object types.String `tfsdk:"object" tf:"optional"` +} + +type EndpointCoreConfigInput struct { + // Configuration for Inference Tables which automatically logs requests and + // responses to Unity Catalog. + AutoCaptureConfig *AutoCaptureConfigInput `tfsdk:"auto_capture_config" tf:"optional"` + // The name of the serving endpoint to update. This field is required. + Name types.String `tfsdk:"-"` + // A list of served entities for the endpoint to serve. A serving endpoint + // can have up to 15 served entities. + ServedEntities []ServedEntityInput `tfsdk:"served_entities" tf:"optional"` + // (Deprecated, use served_entities instead) A list of served models for the + // endpoint to serve. A serving endpoint can have up to 15 served models. + ServedModels []ServedModelInput `tfsdk:"served_models" tf:"optional"` + // The traffic config defining how invocations to the serving endpoint + // should be routed. + TrafficConfig *TrafficConfig `tfsdk:"traffic_config" tf:"optional"` +} + +type EndpointCoreConfigOutput struct { + // Configuration for Inference Tables which automatically logs requests and + // responses to Unity Catalog. + AutoCaptureConfig *AutoCaptureConfigOutput `tfsdk:"auto_capture_config" tf:"optional"` + // The config version that the serving endpoint is currently serving. + ConfigVersion types.Int64 `tfsdk:"config_version" tf:"optional"` + // The list of served entities under the serving endpoint config. + ServedEntities []ServedEntityOutput `tfsdk:"served_entities" tf:"optional"` + // (Deprecated, use served_entities instead) The list of served models under + // the serving endpoint config. + ServedModels []ServedModelOutput `tfsdk:"served_models" tf:"optional"` + // The traffic configuration associated with the serving endpoint config. + TrafficConfig *TrafficConfig `tfsdk:"traffic_config" tf:"optional"` +} + +type EndpointCoreConfigSummary struct { + // The list of served entities under the serving endpoint config. + ServedEntities []ServedEntitySpec `tfsdk:"served_entities" tf:"optional"` + // (Deprecated, use served_entities instead) The list of served models under + // the serving endpoint config. + ServedModels []ServedModelSpec `tfsdk:"served_models" tf:"optional"` +} + +type EndpointPendingConfig struct { + // Configuration for Inference Tables which automatically logs requests and + // responses to Unity Catalog. + AutoCaptureConfig *AutoCaptureConfigOutput `tfsdk:"auto_capture_config" tf:"optional"` + // The config version that the serving endpoint is currently serving. + ConfigVersion types.Int64 `tfsdk:"config_version" tf:"optional"` + // The list of served entities belonging to the last issued update to the + // serving endpoint. + ServedEntities []ServedEntityOutput `tfsdk:"served_entities" tf:"optional"` + // (Deprecated, use served_entities instead) The list of served models + // belonging to the last issued update to the serving endpoint. + ServedModels []ServedModelOutput `tfsdk:"served_models" tf:"optional"` + // The timestamp when the update to the pending config started. + StartTime types.Int64 `tfsdk:"start_time" tf:"optional"` + // The traffic config defining how invocations to the serving endpoint + // should be routed. + TrafficConfig *TrafficConfig `tfsdk:"traffic_config" tf:"optional"` +} + +type EndpointState struct { + // The state of an endpoint's config update. This informs the user if the + // pending_config is in progress, if the update failed, or if there is no + // update in progress. Note that if the endpoint's config_update state value + // is IN_PROGRESS, another update can not be made until the update completes + // or fails." + ConfigUpdate types.String `tfsdk:"config_update" tf:"optional"` + // The state of an endpoint, indicating whether or not the endpoint is + // queryable. An endpoint is READY if all of the served entities in its + // active configuration are ready. If any of the actively served entities + // are in a non-ready state, the endpoint state will be NOT_READY. + Ready types.String `tfsdk:"ready" tf:"optional"` +} + +type EndpointTag struct { + // Key field for a serving endpoint tag. + Key types.String `tfsdk:"key" tf:""` + // Optional value field for a serving endpoint tag. + Value types.String `tfsdk:"value" tf:"optional"` +} + +type EnvVariable struct { + Name types.String `tfsdk:"name" tf:"optional"` + + Value types.String `tfsdk:"value" tf:"optional"` + + ValueFrom types.String `tfsdk:"value_from" tf:"optional"` +} + +// Get metrics of a serving endpoint +type ExportMetricsRequest struct { + // The name of the serving endpoint to retrieve metrics for. This field is + // required. + Name types.String `tfsdk:"-"` +} + +type ExportMetricsResponse struct { + Contents io.ReadCloser `tfsdk:"-"` +} + +type ExternalModel struct { + // AI21Labs Config. Only required if the provider is 'ai21labs'. + Ai21labsConfig *Ai21LabsConfig `tfsdk:"ai21labs_config" tf:"optional"` + // Amazon Bedrock Config. Only required if the provider is 'amazon-bedrock'. + AmazonBedrockConfig *AmazonBedrockConfig `tfsdk:"amazon_bedrock_config" tf:"optional"` + // Anthropic Config. Only required if the provider is 'anthropic'. + AnthropicConfig *AnthropicConfig `tfsdk:"anthropic_config" tf:"optional"` + // Cohere Config. Only required if the provider is 'cohere'. + CohereConfig *CohereConfig `tfsdk:"cohere_config" tf:"optional"` + // Databricks Model Serving Config. Only required if the provider is + // 'databricks-model-serving'. + DatabricksModelServingConfig *DatabricksModelServingConfig `tfsdk:"databricks_model_serving_config" tf:"optional"` + // The name of the external model. + Name types.String `tfsdk:"name" tf:""` + // OpenAI Config. Only required if the provider is 'openai'. + OpenaiConfig *OpenAiConfig `tfsdk:"openai_config" tf:"optional"` + // PaLM Config. Only required if the provider is 'palm'. + PalmConfig *PaLmConfig `tfsdk:"palm_config" tf:"optional"` + // The name of the provider for the external model. Currently, the supported + // providers are 'ai21labs', 'anthropic', 'amazon-bedrock', 'cohere', + // 'databricks-model-serving', 'openai', and 'palm'.", + Provider types.String `tfsdk:"provider" tf:""` + // The task type of the external model. + Task types.String `tfsdk:"task" tf:""` +} + +type ExternalModelUsageElement struct { + // The number of tokens in the chat/completions response. + CompletionTokens types.Int64 `tfsdk:"completion_tokens" tf:"optional"` + // The number of tokens in the prompt. + PromptTokens types.Int64 `tfsdk:"prompt_tokens" tf:"optional"` + // The total number of tokens in the prompt and response. + TotalTokens types.Int64 `tfsdk:"total_tokens" tf:"optional"` +} + +type FoundationModel struct { + // The description of the foundation model. + Description types.String `tfsdk:"description" tf:"optional"` + // The display name of the foundation model. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // The URL to the documentation of the foundation model. + Docs types.String `tfsdk:"docs" tf:"optional"` + // The name of the foundation model. + Name types.String `tfsdk:"name" tf:"optional"` +} + +// Get an app deployment +type GetAppDeploymentRequest struct { + // The name of the app. + AppName types.String `tfsdk:"-"` + // The unique id of the deployment. + DeploymentId types.String `tfsdk:"-"` +} + +// Get app environment +type GetAppEnvironmentRequest struct { + // The name of the app. + Name types.String `tfsdk:"-"` +} + +// Get an app +type GetAppRequest struct { + // The name of the app. + Name types.String `tfsdk:"-"` +} + +// Get the schema for a serving endpoint +type GetOpenApiRequest struct { + // The name of the serving endpoint that the served model belongs to. This + // field is required. + Name types.String `tfsdk:"-"` +} + +// The response is an OpenAPI spec in JSON format that typically includes fields +// like openapi, info, servers and paths, etc. +type GetOpenApiResponse struct { +} + +// Get serving endpoint permission levels +type GetServingEndpointPermissionLevelsRequest struct { + // The serving endpoint for which to get or manage permissions. + ServingEndpointId types.String `tfsdk:"-"` +} + +type GetServingEndpointPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []ServingEndpointPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get serving endpoint permissions +type GetServingEndpointPermissionsRequest struct { + // The serving endpoint for which to get or manage permissions. + ServingEndpointId types.String `tfsdk:"-"` +} + +// Get a single serving endpoint +type GetServingEndpointRequest struct { + // The name of the serving endpoint. This field is required. + Name types.String `tfsdk:"-"` +} + +// List app deployments +type ListAppDeploymentsRequest struct { + // The name of the app. + AppName types.String `tfsdk:"-"` + // Upper bound for items returned. + PageSize types.Int64 `tfsdk:"-"` + // Pagination token to go to the next page of apps. Requests first page if + // absent. + PageToken types.String `tfsdk:"-"` +} + +type ListAppDeploymentsResponse struct { + // Deployment history of the app. + AppDeployments []AppDeployment `tfsdk:"app_deployments" tf:"optional"` + // Pagination token to request the next page of apps. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List apps +type ListAppsRequest struct { + // Upper bound for items returned. + PageSize types.Int64 `tfsdk:"-"` + // Pagination token to go to the next page of apps. Requests first page if + // absent. + PageToken types.String `tfsdk:"-"` +} + +type ListAppsResponse struct { + Apps []App `tfsdk:"apps" tf:"optional"` + // Pagination token to request the next page of apps. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +type ListEndpointsResponse struct { + // The list of endpoints. + Endpoints []ServingEndpoint `tfsdk:"endpoints" tf:"optional"` +} + +// Get the latest logs for a served model +type LogsRequest struct { + // The name of the serving endpoint that the served model belongs to. This + // field is required. + Name types.String `tfsdk:"-"` + // The name of the served model that logs will be retrieved for. This field + // is required. + ServedModelName types.String `tfsdk:"-"` +} + +type ModelDataPlaneInfo struct { + // Information required to query DataPlane API 'query' endpoint. + QueryInfo *oauth2.DataPlaneInfo `tfsdk:"query_info" tf:"optional"` +} + +type OpenAiConfig struct { + // This field is only required for Azure AD OpenAI and is the Microsoft + // Entra Client ID. + MicrosoftEntraClientId types.String `tfsdk:"microsoft_entra_client_id" tf:"optional"` + // The Databricks secret key reference for the Microsoft Entra Client Secret + // that is only required for Azure AD OpenAI. + MicrosoftEntraClientSecret types.String `tfsdk:"microsoft_entra_client_secret" tf:"optional"` + // This field is only required for Azure AD OpenAI and is the Microsoft + // Entra Tenant ID. + MicrosoftEntraTenantId types.String `tfsdk:"microsoft_entra_tenant_id" tf:"optional"` + // This is the base URL for the OpenAI API (default: + // "https://api.openai.com/v1"). For Azure OpenAI, this field is required, + // and is the base URL for the Azure OpenAI API service provided by Azure. + OpenaiApiBase types.String `tfsdk:"openai_api_base" tf:"optional"` + // The Databricks secret key reference for an OpenAI or Azure OpenAI API + // key. + OpenaiApiKey types.String `tfsdk:"openai_api_key" tf:"optional"` + // This is an optional field to specify the type of OpenAI API to use. For + // Azure OpenAI, this field is required, and adjust this parameter to + // represent the preferred security access validation protocol. For access + // token validation, use azure. For authentication using Azure Active + // Directory (Azure AD) use, azuread. + OpenaiApiType types.String `tfsdk:"openai_api_type" tf:"optional"` + // This is an optional field to specify the OpenAI API version. For Azure + // OpenAI, this field is required, and is the version of the Azure OpenAI + // service to utilize, specified by a date. + OpenaiApiVersion types.String `tfsdk:"openai_api_version" tf:"optional"` + // This field is only required for Azure OpenAI and is the name of the + // deployment resource for the Azure OpenAI service. + OpenaiDeploymentName types.String `tfsdk:"openai_deployment_name" tf:"optional"` + // This is an optional field to specify the organization in OpenAI or Azure + // OpenAI. + OpenaiOrganization types.String `tfsdk:"openai_organization" tf:"optional"` +} + +type PaLmConfig struct { + // The Databricks secret key reference for a PaLM API key. + PalmApiKey types.String `tfsdk:"palm_api_key" tf:""` +} + +type PatchServingEndpointTags struct { + // List of endpoint tags to add + AddTags []EndpointTag `tfsdk:"add_tags" tf:"optional"` + // List of tag keys to delete + DeleteTags []types.String `tfsdk:"delete_tags" tf:"optional"` + // The name of the serving endpoint who's tags to patch. This field is + // required. + Name types.String `tfsdk:"-"` +} + +type PayloadTable struct { + // The name of the payload table. + Name types.String `tfsdk:"name" tf:"optional"` + // The status of the payload table. + Status types.String `tfsdk:"status" tf:"optional"` + // The status message of the payload table. + StatusMessage types.String `tfsdk:"status_message" tf:"optional"` +} + +// Update rate limits of a serving endpoint +type PutRequest struct { + // The name of the serving endpoint whose rate limits are being updated. + // This field is required. + Name types.String `tfsdk:"-"` + // The list of endpoint rate limits. + RateLimits []RateLimit `tfsdk:"rate_limits" tf:"optional"` +} + +type PutResponse struct { + // The list of endpoint rate limits. + RateLimits []RateLimit `tfsdk:"rate_limits" tf:"optional"` +} + +type QueryEndpointInput struct { + // Pandas Dataframe input in the records orientation. + DataframeRecords []any `tfsdk:"dataframe_records" tf:"optional"` + // Pandas Dataframe input in the split orientation. + DataframeSplit *DataframeSplitInput `tfsdk:"dataframe_split" tf:"optional"` + // The extra parameters field used ONLY for __completions, chat,__ and + // __embeddings external & foundation model__ serving endpoints. This is a + // map of strings and should only be used with other external/foundation + // model query fields. + ExtraParams map[string]types.String `tfsdk:"extra_params" tf:"optional"` + // The input string (or array of strings) field used ONLY for __embeddings + // external & foundation model__ serving endpoints and is the only field + // (along with extra_params if needed) used by embeddings queries. + Input any `tfsdk:"input" tf:"optional"` + // Tensor-based input in columnar format. + Inputs any `tfsdk:"inputs" tf:"optional"` + // Tensor-based input in row format. + Instances []any `tfsdk:"instances" tf:"optional"` + // The max tokens field used ONLY for __completions__ and __chat external & + // foundation model__ serving endpoints. This is an integer and should only + // be used with other chat/completions query fields. + MaxTokens types.Int64 `tfsdk:"max_tokens" tf:"optional"` + // The messages field used ONLY for __chat external & foundation model__ + // serving endpoints. This is a map of strings and should only be used with + // other chat query fields. + Messages []ChatMessage `tfsdk:"messages" tf:"optional"` + // The n (number of candidates) field used ONLY for __completions__ and + // __chat external & foundation model__ serving endpoints. This is an + // integer between 1 and 5 with a default of 1 and should only be used with + // other chat/completions query fields. + N types.Int64 `tfsdk:"n" tf:"optional"` + // The name of the serving endpoint. This field is required. + Name types.String `tfsdk:"-"` + // The prompt string (or array of strings) field used ONLY for __completions + // external & foundation model__ serving endpoints and should only be used + // with other completions query fields. + Prompt any `tfsdk:"prompt" tf:"optional"` + // The stop sequences field used ONLY for __completions__ and __chat + // external & foundation model__ serving endpoints. This is a list of + // strings and should only be used with other chat/completions query fields. + Stop []types.String `tfsdk:"stop" tf:"optional"` + // The stream field used ONLY for __completions__ and __chat external & + // foundation model__ serving endpoints. This is a boolean defaulting to + // false and should only be used with other chat/completions query fields. + Stream types.Bool `tfsdk:"stream" tf:"optional"` + // The temperature field used ONLY for __completions__ and __chat external & + // foundation model__ serving endpoints. This is a float between 0.0 and 2.0 + // with a default of 1.0 and should only be used with other chat/completions + // query fields. + Temperature types.Float64 `tfsdk:"temperature" tf:"optional"` +} + +type QueryEndpointResponse struct { + // The list of choices returned by the __chat or completions + // external/foundation model__ serving endpoint. + Choices []V1ResponseChoiceElement `tfsdk:"choices" tf:"optional"` + // The timestamp in seconds when the query was created in Unix time returned + // by a __completions or chat external/foundation model__ serving endpoint. + Created types.Int64 `tfsdk:"created" tf:"optional"` + // The list of the embeddings returned by the __embeddings + // external/foundation model__ serving endpoint. + Data []EmbeddingsV1ResponseEmbeddingElement `tfsdk:"data" tf:"optional"` + // The ID of the query that may be returned by a __completions or chat + // external/foundation model__ serving endpoint. + Id types.String `tfsdk:"id" tf:"optional"` + // The name of the __external/foundation model__ used for querying. This is + // the name of the model that was specified in the endpoint config. + Model types.String `tfsdk:"model" tf:"optional"` + // The type of object returned by the __external/foundation model__ serving + // endpoint, one of [text_completion, chat.completion, list (of + // embeddings)]. + Object types.String `tfsdk:"object" tf:"optional"` + // The predictions returned by the serving endpoint. + Predictions []any `tfsdk:"predictions" tf:"optional"` + // The name of the served model that served the request. This is useful when + // there are multiple models behind the same endpoint with traffic split. + ServedModelName types.String `tfsdk:"-"` + // The usage object that may be returned by the __external/foundation + // model__ serving endpoint. This contains information about the number of + // tokens used in the prompt and response. + Usage *ExternalModelUsageElement `tfsdk:"usage" tf:"optional"` +} + +type RateLimit struct { + // Used to specify how many calls are allowed for a key within the + // renewal_period. + Calls types.Int64 `tfsdk:"calls" tf:""` + // Key field for a serving endpoint rate limit. Currently, only 'user' and + // 'endpoint' are supported, with 'endpoint' being the default if not + // specified. + Key types.String `tfsdk:"key" tf:"optional"` + // Renewal period field for a serving endpoint rate limit. Currently, only + // 'minute' is supported. + RenewalPeriod types.String `tfsdk:"renewal_period" tf:""` +} + +type Route struct { + // The name of the served model this route configures traffic for. + ServedModelName types.String `tfsdk:"served_model_name" tf:""` + // The percentage of endpoint traffic to send to this route. It must be an + // integer between 0 and 100 inclusive. + TrafficPercentage types.Int64 `tfsdk:"traffic_percentage" tf:""` +} + +type ServedEntityInput struct { + // The name of the entity to be served. The entity may be a model in the + // Databricks Model Registry, a model in the Unity Catalog (UC), or a + // function of type FEATURE_SPEC in the UC. If it is a UC object, the full + // name of the object should be given in the form of + // __catalog_name__.__schema_name__.__model_name__. + EntityName types.String `tfsdk:"entity_name" tf:"optional"` + // The version of the model in Databricks Model Registry to be served or + // empty if the entity is a FEATURE_SPEC. + EntityVersion types.String `tfsdk:"entity_version" tf:"optional"` + // An object containing a set of optional, user-specified environment + // variable key-value pairs used for serving this entity. Note: this is an + // experimental feature and subject to change. Example entity environment + // variables that refer to Databricks secrets: `{"OPENAI_API_KEY": + // "{{secrets/my_scope/my_key}}", "DATABRICKS_TOKEN": + // "{{secrets/my_scope2/my_key2}}"}` + EnvironmentVars map[string]types.String `tfsdk:"environment_vars" tf:"optional"` + // The external model to be served. NOTE: Only one of external_model and + // (entity_name, entity_version, workload_size, workload_type, and + // scale_to_zero_enabled) can be specified with the latter set being used + // for custom model serving for a Databricks registered model. When an + // external_model is present, the served entities list can only have one + // served_entity object. For an existing endpoint with external_model, it + // can not be updated to an endpoint without external_model. If the endpoint + // is created without external_model, users cannot update it to add + // external_model later. + ExternalModel *ExternalModel `tfsdk:"external_model" tf:"optional"` + // ARN of the instance profile that the served entity uses to access AWS + // resources. + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // The maximum tokens per second that the endpoint can scale up to. + MaxProvisionedThroughput types.Int64 `tfsdk:"max_provisioned_throughput" tf:"optional"` + // The minimum tokens per second that the endpoint can scale down to. + MinProvisionedThroughput types.Int64 `tfsdk:"min_provisioned_throughput" tf:"optional"` + // The name of a served entity. It must be unique across an endpoint. A + // served entity name can consist of alphanumeric characters, dashes, and + // underscores. If not specified for an external model, this field defaults + // to external_model.name, with '.' and ':' replaced with '-', and if not + // specified for other entities, it defaults to + // -. + Name types.String `tfsdk:"name" tf:"optional"` + // Whether the compute resources for the served entity should scale down to + // zero. + ScaleToZeroEnabled types.Bool `tfsdk:"scale_to_zero_enabled" tf:"optional"` + // The workload size of the served entity. The workload size corresponds to + // a range of provisioned concurrency that the compute autoscales between. A + // single unit of provisioned concurrency can process one request at a time. + // Valid workload sizes are "Small" (4 - 4 provisioned concurrency), + // "Medium" (8 - 16 provisioned concurrency), and "Large" (16 - 64 + // provisioned concurrency). If scale-to-zero is enabled, the lower bound of + // the provisioned concurrency for each workload size is 0. + WorkloadSize types.String `tfsdk:"workload_size" tf:"optional"` + // The workload type of the served entity. The workload type selects which + // type of compute to use in the endpoint. The default value for this + // parameter is "CPU". For deep learning workloads, GPU acceleration is + // available by selecting workload types like GPU_SMALL and others. See the + // available [GPU types]. + // + // [GPU types]: https://docs.databricks.com/machine-learning/model-serving/create-manage-serving-endpoints.html#gpu-workload-types + WorkloadType types.String `tfsdk:"workload_type" tf:"optional"` +} + +type ServedEntityOutput struct { + // The creation timestamp of the served entity in Unix time. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // The email of the user who created the served entity. + Creator types.String `tfsdk:"creator" tf:"optional"` + // The name of the entity served. The entity may be a model in the + // Databricks Model Registry, a model in the Unity Catalog (UC), or a + // function of type FEATURE_SPEC in the UC. If it is a UC object, the full + // name of the object is given in the form of + // __catalog_name__.__schema_name__.__model_name__. + EntityName types.String `tfsdk:"entity_name" tf:"optional"` + // The version of the served entity in Databricks Model Registry or empty if + // the entity is a FEATURE_SPEC. + EntityVersion types.String `tfsdk:"entity_version" tf:"optional"` + // An object containing a set of optional, user-specified environment + // variable key-value pairs used for serving this entity. Note: this is an + // experimental feature and subject to change. Example entity environment + // variables that refer to Databricks secrets: `{"OPENAI_API_KEY": + // "{{secrets/my_scope/my_key}}", "DATABRICKS_TOKEN": + // "{{secrets/my_scope2/my_key2}}"}` + EnvironmentVars map[string]types.String `tfsdk:"environment_vars" tf:"optional"` + // The external model that is served. NOTE: Only one of external_model, + // foundation_model, and (entity_name, entity_version, workload_size, + // workload_type, and scale_to_zero_enabled) is returned based on the + // endpoint type. + ExternalModel *ExternalModel `tfsdk:"external_model" tf:"optional"` + // The foundation model that is served. NOTE: Only one of foundation_model, + // external_model, and (entity_name, entity_version, workload_size, + // workload_type, and scale_to_zero_enabled) is returned based on the + // endpoint type. + FoundationModel *FoundationModel `tfsdk:"foundation_model" tf:"optional"` + // ARN of the instance profile that the served entity uses to access AWS + // resources. + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // The maximum tokens per second that the endpoint can scale up to. + MaxProvisionedThroughput types.Int64 `tfsdk:"max_provisioned_throughput" tf:"optional"` + // The minimum tokens per second that the endpoint can scale down to. + MinProvisionedThroughput types.Int64 `tfsdk:"min_provisioned_throughput" tf:"optional"` + // The name of the served entity. + Name types.String `tfsdk:"name" tf:"optional"` + // Whether the compute resources for the served entity should scale down to + // zero. + ScaleToZeroEnabled types.Bool `tfsdk:"scale_to_zero_enabled" tf:"optional"` + // Information corresponding to the state of the served entity. + State *ServedModelState `tfsdk:"state" tf:"optional"` + // The workload size of the served entity. The workload size corresponds to + // a range of provisioned concurrency that the compute autoscales between. A + // single unit of provisioned concurrency can process one request at a time. + // Valid workload sizes are "Small" (4 - 4 provisioned concurrency), + // "Medium" (8 - 16 provisioned concurrency), and "Large" (16 - 64 + // provisioned concurrency). If scale-to-zero is enabled, the lower bound of + // the provisioned concurrency for each workload size will be 0. + WorkloadSize types.String `tfsdk:"workload_size" tf:"optional"` + // The workload type of the served entity. The workload type selects which + // type of compute to use in the endpoint. The default value for this + // parameter is "CPU". For deep learning workloads, GPU acceleration is + // available by selecting workload types like GPU_SMALL and others. See the + // available [GPU types]. + // + // [GPU types]: https://docs.databricks.com/machine-learning/model-serving/create-manage-serving-endpoints.html#gpu-workload-types + WorkloadType types.String `tfsdk:"workload_type" tf:"optional"` +} + +type ServedEntitySpec struct { + // The name of the entity served. The entity may be a model in the + // Databricks Model Registry, a model in the Unity Catalog (UC), or a + // function of type FEATURE_SPEC in the UC. If it is a UC object, the full + // name of the object is given in the form of + // __catalog_name__.__schema_name__.__model_name__. + EntityName types.String `tfsdk:"entity_name" tf:"optional"` + // The version of the served entity in Databricks Model Registry or empty if + // the entity is a FEATURE_SPEC. + EntityVersion types.String `tfsdk:"entity_version" tf:"optional"` + // The external model that is served. NOTE: Only one of external_model, + // foundation_model, and (entity_name, entity_version) is returned based on + // the endpoint type. + ExternalModel *ExternalModel `tfsdk:"external_model" tf:"optional"` + // The foundation model that is served. NOTE: Only one of foundation_model, + // external_model, and (entity_name, entity_version) is returned based on + // the endpoint type. + FoundationModel *FoundationModel `tfsdk:"foundation_model" tf:"optional"` + // The name of the served entity. + Name types.String `tfsdk:"name" tf:"optional"` +} + +type ServedModelInput struct { + // An object containing a set of optional, user-specified environment + // variable key-value pairs used for serving this model. Note: this is an + // experimental feature and subject to change. Example model environment + // variables that refer to Databricks secrets: `{"OPENAI_API_KEY": + // "{{secrets/my_scope/my_key}}", "DATABRICKS_TOKEN": + // "{{secrets/my_scope2/my_key2}}"}` + EnvironmentVars map[string]types.String `tfsdk:"environment_vars" tf:"optional"` + // ARN of the instance profile that the served model will use to access AWS + // resources. + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // The name of the model in Databricks Model Registry to be served or if the + // model resides in Unity Catalog, the full name of model, in the form of + // __catalog_name__.__schema_name__.__model_name__. + ModelName types.String `tfsdk:"model_name" tf:""` + // The version of the model in Databricks Model Registry or Unity Catalog to + // be served. + ModelVersion types.String `tfsdk:"model_version" tf:""` + // The name of a served model. It must be unique across an endpoint. If not + // specified, this field will default to -. A + // served model name can consist of alphanumeric characters, dashes, and + // underscores. + Name types.String `tfsdk:"name" tf:"optional"` + // Whether the compute resources for the served model should scale down to + // zero. + ScaleToZeroEnabled types.Bool `tfsdk:"scale_to_zero_enabled" tf:""` + // The workload size of the served model. The workload size corresponds to a + // range of provisioned concurrency that the compute will autoscale between. + // A single unit of provisioned concurrency can process one request at a + // time. Valid workload sizes are "Small" (4 - 4 provisioned concurrency), + // "Medium" (8 - 16 provisioned concurrency), and "Large" (16 - 64 + // provisioned concurrency). If scale-to-zero is enabled, the lower bound of + // the provisioned concurrency for each workload size will be 0. + WorkloadSize types.String `tfsdk:"workload_size" tf:""` + // The workload type of the served model. The workload type selects which + // type of compute to use in the endpoint. The default value for this + // parameter is "CPU". For deep learning workloads, GPU acceleration is + // available by selecting workload types like GPU_SMALL and others. See the + // available [GPU types]. + // + // [GPU types]: https://docs.databricks.com/machine-learning/model-serving/create-manage-serving-endpoints.html#gpu-workload-types + WorkloadType types.String `tfsdk:"workload_type" tf:"optional"` +} + +type ServedModelOutput struct { + // The creation timestamp of the served model in Unix time. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // The email of the user who created the served model. + Creator types.String `tfsdk:"creator" tf:"optional"` + // An object containing a set of optional, user-specified environment + // variable key-value pairs used for serving this model. Note: this is an + // experimental feature and subject to change. Example model environment + // variables that refer to Databricks secrets: `{"OPENAI_API_KEY": + // "{{secrets/my_scope/my_key}}", "DATABRICKS_TOKEN": + // "{{secrets/my_scope2/my_key2}}"}` + EnvironmentVars map[string]types.String `tfsdk:"environment_vars" tf:"optional"` + // ARN of the instance profile that the served model will use to access AWS + // resources. + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // The name of the model in Databricks Model Registry or the full name of + // the model in Unity Catalog. + ModelName types.String `tfsdk:"model_name" tf:"optional"` + // The version of the model in Databricks Model Registry or Unity Catalog to + // be served. + ModelVersion types.String `tfsdk:"model_version" tf:"optional"` + // The name of the served model. + Name types.String `tfsdk:"name" tf:"optional"` + // Whether the compute resources for the Served Model should scale down to + // zero. + ScaleToZeroEnabled types.Bool `tfsdk:"scale_to_zero_enabled" tf:"optional"` + // Information corresponding to the state of the Served Model. + State *ServedModelState `tfsdk:"state" tf:"optional"` + // The workload size of the served model. The workload size corresponds to a + // range of provisioned concurrency that the compute will autoscale between. + // A single unit of provisioned concurrency can process one request at a + // time. Valid workload sizes are "Small" (4 - 4 provisioned concurrency), + // "Medium" (8 - 16 provisioned concurrency), and "Large" (16 - 64 + // provisioned concurrency). If scale-to-zero is enabled, the lower bound of + // the provisioned concurrency for each workload size will be 0. + WorkloadSize types.String `tfsdk:"workload_size" tf:"optional"` + // The workload type of the served model. The workload type selects which + // type of compute to use in the endpoint. The default value for this + // parameter is "CPU". For deep learning workloads, GPU acceleration is + // available by selecting workload types like GPU_SMALL and others. See the + // available [GPU types]. + // + // [GPU types]: https://docs.databricks.com/machine-learning/model-serving/create-manage-serving-endpoints.html#gpu-workload-types + WorkloadType types.String `tfsdk:"workload_type" tf:"optional"` +} + +type ServedModelSpec struct { + // The name of the model in Databricks Model Registry or the full name of + // the model in Unity Catalog. + ModelName types.String `tfsdk:"model_name" tf:"optional"` + // The version of the model in Databricks Model Registry or Unity Catalog to + // be served. + ModelVersion types.String `tfsdk:"model_version" tf:"optional"` + // The name of the served model. + Name types.String `tfsdk:"name" tf:"optional"` +} + +type ServedModelState struct { + // The state of the served entity deployment. DEPLOYMENT_CREATING indicates + // that the served entity is not ready yet because the deployment is still + // being created (i.e container image is building, model server is deploying + // for the first time, etc.). DEPLOYMENT_RECOVERING indicates that the + // served entity was previously in a ready state but no longer is and is + // attempting to recover. DEPLOYMENT_READY indicates that the served entity + // is ready to receive traffic. DEPLOYMENT_FAILED indicates that there was + // an error trying to bring up the served entity (e.g container image build + // failed, the model server failed to start due to a model loading error, + // etc.) DEPLOYMENT_ABORTED indicates that the deployment was terminated + // likely due to a failure in bringing up another served entity under the + // same endpoint and config version. + Deployment types.String `tfsdk:"deployment" tf:"optional"` + // More information about the state of the served entity, if available. + DeploymentStateMessage types.String `tfsdk:"deployment_state_message" tf:"optional"` +} + +type ServerLogsResponse struct { + // The most recent log lines of the model server processing invocation + // requests. + Logs types.String `tfsdk:"logs" tf:""` +} + +type ServingEndpoint struct { + // The config that is currently being served by the endpoint. + Config *EndpointCoreConfigSummary `tfsdk:"config" tf:"optional"` + // The timestamp when the endpoint was created in Unix time. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // The email of the user who created the serving endpoint. + Creator types.String `tfsdk:"creator" tf:"optional"` + // System-generated ID of the endpoint. This is used to refer to the + // endpoint in the Permissions API + Id types.String `tfsdk:"id" tf:"optional"` + // The timestamp when the endpoint was last updated by a user in Unix time. + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` + // The name of the serving endpoint. + Name types.String `tfsdk:"name" tf:"optional"` + // Information corresponding to the state of the serving endpoint. + State *EndpointState `tfsdk:"state" tf:"optional"` + // Tags attached to the serving endpoint. + Tags []EndpointTag `tfsdk:"tags" tf:"optional"` + // The task type of the serving endpoint. + Task types.String `tfsdk:"task" tf:"optional"` +} + +type ServingEndpointAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type ServingEndpointAccessControlResponse struct { + // All permissions. + AllPermissions []ServingEndpointPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type ServingEndpointDetailed struct { + // The config that is currently being served by the endpoint. + Config *EndpointCoreConfigOutput `tfsdk:"config" tf:"optional"` + // The timestamp when the endpoint was created in Unix time. + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // The email of the user who created the serving endpoint. + Creator types.String `tfsdk:"creator" tf:"optional"` + // Information required to query DataPlane APIs. + DataPlaneInfo *ModelDataPlaneInfo `tfsdk:"data_plane_info" tf:"optional"` + // Endpoint invocation url if route optimization is enabled for endpoint + EndpointUrl types.String `tfsdk:"endpoint_url" tf:"optional"` + // System-generated ID of the endpoint. This is used to refer to the + // endpoint in the Permissions API + Id types.String `tfsdk:"id" tf:"optional"` + // The timestamp when the endpoint was last updated by a user in Unix time. + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` + // The name of the serving endpoint. + Name types.String `tfsdk:"name" tf:"optional"` + // The config that the endpoint is attempting to update to. + PendingConfig *EndpointPendingConfig `tfsdk:"pending_config" tf:"optional"` + // The permission level of the principal making the request. + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // Boolean representing if route optimization has been enabled for the + // endpoint + RouteOptimized types.Bool `tfsdk:"route_optimized" tf:"optional"` + // Information corresponding to the state of the serving endpoint. + State *EndpointState `tfsdk:"state" tf:"optional"` + // Tags attached to the serving endpoint. + Tags []EndpointTag `tfsdk:"tags" tf:"optional"` + // The task type of the serving endpoint. + Task types.String `tfsdk:"task" tf:"optional"` +} + +type ServingEndpointPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type ServingEndpointPermissions struct { + AccessControlList []ServingEndpointAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type ServingEndpointPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type ServingEndpointPermissionsRequest struct { + AccessControlList []ServingEndpointAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The serving endpoint for which to get or manage permissions. + ServingEndpointId types.String `tfsdk:"-"` +} + +type StartAppRequest struct { + // The name of the app. + Name types.String `tfsdk:"-"` +} + +type StopAppRequest struct { + // The name of the app. + Name types.String `tfsdk:"-"` +} + +type StopAppResponse struct { +} + +type TrafficConfig struct { + // The list of routes that define traffic to each served entity. + Routes []Route `tfsdk:"routes" tf:"optional"` +} + +type UpdateAppRequest struct { + // The description of the app. + Description types.String `tfsdk:"description" tf:"optional"` + // The name of the app. The name must contain only lowercase alphanumeric + // characters and hyphens. It must be unique within the workspace. + Name types.String `tfsdk:"name" tf:""` +} + +type V1ResponseChoiceElement struct { + // The finish reason returned by the endpoint. + FinishReason types.String `tfsdk:"finishReason" tf:"optional"` + // The index of the choice in the __chat or completions__ response. + Index types.Int64 `tfsdk:"index" tf:"optional"` + // The logprobs returned only by the __completions__ endpoint. + Logprobs types.Int64 `tfsdk:"logprobs" tf:"optional"` + // The message response from the __chat__ endpoint. + Message *ChatMessage `tfsdk:"message" tf:"optional"` + // The text response from the __completions__ endpoint. + Text types.String `tfsdk:"text" tf:"optional"` +} diff --git a/internal/service/settings_tf/model.go b/internal/service/settings_tf/model.go new file mode 100755 index 0000000000..40234b3b0b --- /dev/null +++ b/internal/service/settings_tf/model.go @@ -0,0 +1,1104 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package settings_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type AutomaticClusterUpdateSetting struct { + AutomaticClusterUpdateWorkspace ClusterAutoRestartMessage `tfsdk:"automatic_cluster_update_workspace" tf:""` + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // update pattern to perform setting updates in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // PATCH request to identify the setting version you are updating. + Etag types.String `tfsdk:"etag" tf:"optional"` + // Name of the corresponding setting. This field is populated in the + // response, but it will not be respected even if it's set in the request + // body. The setting name in the path parameter will be respected instead. + // Setting name is required to be 'default' if the setting only has one + // instance per workspace. + SettingName types.String `tfsdk:"setting_name" tf:"optional"` +} + +type ClusterAutoRestartMessage struct { + CanToggle types.Bool `tfsdk:"can_toggle" tf:"optional"` + + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` + // Contains an information about the enablement status judging (e.g. whether + // the enterprise tier is enabled) This is only additional information that + // MUST NOT be used to decide whether the setting is enabled or not. This is + // intended to use only for purposes like showing an error message to the + // customer with the additional details. For example, using these details we + // can check why exactly the feature is disabled for this customer. + EnablementDetails *ClusterAutoRestartMessageEnablementDetails `tfsdk:"enablement_details" tf:"optional"` + + MaintenanceWindow *ClusterAutoRestartMessageMaintenanceWindow `tfsdk:"maintenance_window" tf:"optional"` + + RestartEvenIfNoUpdatesAvailable types.Bool `tfsdk:"restart_even_if_no_updates_available" tf:"optional"` +} + +// Contains an information about the enablement status judging (e.g. whether the +// enterprise tier is enabled) This is only additional information that MUST NOT +// be used to decide whether the setting is enabled or not. This is intended to +// use only for purposes like showing an error message to the customer with the +// additional details. For example, using these details we can check why exactly +// the feature is disabled for this customer. +type ClusterAutoRestartMessageEnablementDetails struct { + // The feature is force enabled if compliance mode is active + ForcedForComplianceMode types.Bool `tfsdk:"forced_for_compliance_mode" tf:"optional"` + // The feature is unavailable if the corresponding entitlement disabled (see + // getShieldEntitlementEnable) + UnavailableForDisabledEntitlement types.Bool `tfsdk:"unavailable_for_disabled_entitlement" tf:"optional"` + // The feature is unavailable if the customer doesn't have enterprise tier + UnavailableForNonEnterpriseTier types.Bool `tfsdk:"unavailable_for_non_enterprise_tier" tf:"optional"` +} + +type ClusterAutoRestartMessageMaintenanceWindow struct { + WeekDayBasedSchedule *ClusterAutoRestartMessageMaintenanceWindowWeekDayBasedSchedule `tfsdk:"week_day_based_schedule" tf:"optional"` +} + +type ClusterAutoRestartMessageMaintenanceWindowWeekDayBasedSchedule struct { + DayOfWeek types.String `tfsdk:"day_of_week" tf:"optional"` + + Frequency types.String `tfsdk:"frequency" tf:"optional"` + + WindowStartTime *ClusterAutoRestartMessageMaintenanceWindowWindowStartTime `tfsdk:"window_start_time" tf:"optional"` +} + +type ClusterAutoRestartMessageMaintenanceWindowWindowStartTime struct { + Hours types.Int64 `tfsdk:"hours" tf:"optional"` + + Minutes types.Int64 `tfsdk:"minutes" tf:"optional"` +} + +// SHIELD feature: CSP +type ComplianceSecurityProfile struct { + // Set by customers when they request Compliance Security Profile (CSP) + ComplianceStandards []types.String `tfsdk:"compliance_standards" tf:"optional"` + + IsEnabled types.Bool `tfsdk:"is_enabled" tf:"optional"` +} + +type ComplianceSecurityProfileSetting struct { + // SHIELD feature: CSP + ComplianceSecurityProfileWorkspace ComplianceSecurityProfile `tfsdk:"compliance_security_profile_workspace" tf:""` + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // update pattern to perform setting updates in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // PATCH request to identify the setting version you are updating. + Etag types.String `tfsdk:"etag" tf:"optional"` + // Name of the corresponding setting. This field is populated in the + // response, but it will not be respected even if it's set in the request + // body. The setting name in the path parameter will be respected instead. + // Setting name is required to be 'default' if the setting only has one + // instance per workspace. + SettingName types.String `tfsdk:"setting_name" tf:"optional"` +} + +// Details required to configure a block list or allow list. +type CreateIpAccessList struct { + IpAddresses []types.String `tfsdk:"ip_addresses" tf:"optional"` + // Label for the IP access list. This **cannot** be empty. + Label types.String `tfsdk:"label" tf:""` + // Type of IP access list. Valid values are as follows and are + // case-sensitive: + // + // * `ALLOW`: An allow list. Include this IP or range. * `BLOCK`: A block + // list. Exclude this IP or range. IP addresses in the block list are + // excluded even if they are included in an allow list. + ListType types.String `tfsdk:"list_type" tf:""` +} + +// An IP access list was successfully created. +type CreateIpAccessListResponse struct { + // Definition of an IP Access list + IpAccessList *IpAccessListInfo `tfsdk:"ip_access_list" tf:"optional"` +} + +type CreateNetworkConnectivityConfigRequest struct { + // The name of the network connectivity configuration. The name can contain + // alphanumeric characters, hyphens, and underscores. The length must be + // between 3 and 30 characters. The name must match the regular expression + // `^[0-9a-zA-Z-_]{3,30}$`. + Name types.String `tfsdk:"name" tf:""` + // The region for the network connectivity configuration. Only workspaces in + // the same region can be attached to the network connectivity + // configuration. + Region types.String `tfsdk:"region" tf:""` +} + +// Configuration details for creating on-behalf tokens. +type CreateOboTokenRequest struct { + // Application ID of the service principal. + ApplicationId types.String `tfsdk:"application_id" tf:""` + // Comment that describes the purpose of the token. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The number of seconds before the token expires. + LifetimeSeconds types.Int64 `tfsdk:"lifetime_seconds" tf:"optional"` +} + +// An on-behalf token was successfully created for the service principal. +type CreateOboTokenResponse struct { + TokenInfo *TokenInfo `tfsdk:"token_info" tf:"optional"` + // Value of the token. + TokenValue types.String `tfsdk:"token_value" tf:"optional"` +} + +type CreatePrivateEndpointRuleRequest struct { + // The sub-resource type (group ID) of the target resource. Note that to + // connect to workspace root storage (root DBFS), you need two endpoints, + // one for `blob` and one for `dfs`. + GroupId types.String `tfsdk:"group_id" tf:""` + // Your Network Connectvity Configuration ID. + NetworkConnectivityConfigId types.String `tfsdk:"-"` + // The Azure resource ID of the target resource. + ResourceId types.String `tfsdk:"resource_id" tf:""` +} + +type CreateTokenRequest struct { + // Optional description to attach to the token. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The lifetime of the token, in seconds. + // + // If the lifetime is not specified, this token remains valid indefinitely. + LifetimeSeconds types.Int64 `tfsdk:"lifetime_seconds" tf:"optional"` +} + +type CreateTokenResponse struct { + // The information for the new token. + TokenInfo *PublicTokenInfo `tfsdk:"token_info" tf:"optional"` + // The value of the new token. + TokenValue types.String `tfsdk:"token_value" tf:"optional"` +} + +// Account level policy for CSP +type CspEnablementAccount struct { + // Set by customers when they request Compliance Security Profile (CSP) + // Invariants are enforced in Settings policy. + ComplianceStandards []types.String `tfsdk:"compliance_standards" tf:"optional"` + // Enforced = it cannot be overriden at workspace level. + IsEnforced types.Bool `tfsdk:"is_enforced" tf:"optional"` +} + +type CspEnablementAccountSetting struct { + // Account level policy for CSP + CspEnablementAccount CspEnablementAccount `tfsdk:"csp_enablement_account" tf:""` + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // update pattern to perform setting updates in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // PATCH request to identify the setting version you are updating. + Etag types.String `tfsdk:"etag" tf:"optional"` + // Name of the corresponding setting. This field is populated in the + // response, but it will not be respected even if it's set in the request + // body. The setting name in the path parameter will be respected instead. + // Setting name is required to be 'default' if the setting only has one + // instance per workspace. + SettingName types.String `tfsdk:"setting_name" tf:"optional"` +} + +// This represents the setting configuration for the default namespace in the +// Databricks workspace. Setting the default catalog for the workspace +// determines the catalog that is used when queries do not reference a fully +// qualified 3 level name. For example, if the default catalog is set to +// 'retail_prod' then a query 'SELECT * FROM myTable' would reference the object +// 'retail_prod.default.myTable' (the schema 'default' is always assumed). This +// setting requires a restart of clusters and SQL warehouses to take effect. +// Additionally, the default namespace only applies when using Unity +// Catalog-enabled compute. +type DefaultNamespaceSetting struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // update pattern to perform setting updates in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // PATCH request to identify the setting version you are updating. + Etag types.String `tfsdk:"etag" tf:"optional"` + + Namespace StringMessage `tfsdk:"namespace" tf:""` + // Name of the corresponding setting. This field is populated in the + // response, but it will not be respected even if it's set in the request + // body. The setting name in the path parameter will be respected instead. + // Setting name is required to be 'default' if the setting only has one + // instance per workspace. + SettingName types.String `tfsdk:"setting_name" tf:"optional"` +} + +// Delete access list +type DeleteAccountIpAccessListRequest struct { + // The ID for the corresponding IP access list + IpAccessListId types.String `tfsdk:"-"` +} + +// Delete the default namespace setting +type DeleteDefaultNamespaceSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// The etag is returned. +type DeleteDefaultNamespaceSettingResponse struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"etag" tf:""` +} + +// Delete access list +type DeleteIpAccessListRequest struct { + // The ID for the corresponding IP access list + IpAccessListId types.String `tfsdk:"-"` +} + +// Delete a network connectivity configuration +type DeleteNetworkConnectivityConfigurationRequest struct { + // Your Network Connectvity Configuration ID. + NetworkConnectivityConfigId types.String `tfsdk:"-"` +} + +type DeleteNetworkConnectivityConfigurationResponse struct { +} + +// Delete Personal Compute setting +type DeletePersonalComputeSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// The etag is returned. +type DeletePersonalComputeSettingResponse struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"etag" tf:""` +} + +// Delete a private endpoint rule +type DeletePrivateEndpointRuleRequest struct { + // Your Network Connectvity Configuration ID. + NetworkConnectivityConfigId types.String `tfsdk:"-"` + // Your private endpoint rule ID. + PrivateEndpointRuleId types.String `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +// Delete the restrict workspace admins setting +type DeleteRestrictWorkspaceAdminsSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// The etag is returned. +type DeleteRestrictWorkspaceAdminsSettingResponse struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"etag" tf:""` +} + +// Delete a token +type DeleteTokenManagementRequest struct { + // The ID of the token to get. + TokenId types.String `tfsdk:"-"` +} + +// SHIELD feature: ESM +type EnhancedSecurityMonitoring struct { + IsEnabled types.Bool `tfsdk:"is_enabled" tf:"optional"` +} + +type EnhancedSecurityMonitoringSetting struct { + // SHIELD feature: ESM + EnhancedSecurityMonitoringWorkspace EnhancedSecurityMonitoring `tfsdk:"enhanced_security_monitoring_workspace" tf:""` + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // update pattern to perform setting updates in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // PATCH request to identify the setting version you are updating. + Etag types.String `tfsdk:"etag" tf:"optional"` + // Name of the corresponding setting. This field is populated in the + // response, but it will not be respected even if it's set in the request + // body. The setting name in the path parameter will be respected instead. + // Setting name is required to be 'default' if the setting only has one + // instance per workspace. + SettingName types.String `tfsdk:"setting_name" tf:"optional"` +} + +// Account level policy for ESM +type EsmEnablementAccount struct { + IsEnforced types.Bool `tfsdk:"is_enforced" tf:"optional"` +} + +type EsmEnablementAccountSetting struct { + // Account level policy for ESM + EsmEnablementAccount EsmEnablementAccount `tfsdk:"esm_enablement_account" tf:""` + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // update pattern to perform setting updates in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // PATCH request to identify the setting version you are updating. + Etag types.String `tfsdk:"etag" tf:"optional"` + // Name of the corresponding setting. This field is populated in the + // response, but it will not be respected even if it's set in the request + // body. The setting name in the path parameter will be respected instead. + // Setting name is required to be 'default' if the setting only has one + // instance per workspace. + SettingName types.String `tfsdk:"setting_name" tf:"optional"` +} + +// The exchange token is the result of the token exchange with the IdP +type ExchangeToken struct { + // The requested token. + Credential types.String `tfsdk:"credential" tf:"optional"` + // The end-of-life timestamp of the token. The value is in milliseconds + // since the Unix epoch. + CredentialEolTime types.Int64 `tfsdk:"credentialEolTime" tf:"optional"` + // User ID of the user that owns this token. + OwnerId types.Int64 `tfsdk:"ownerId" tf:"optional"` + // The scopes of access granted in the token. + Scopes []types.String `tfsdk:"scopes" tf:"optional"` + // The type of this exchange token + TokenType types.String `tfsdk:"tokenType" tf:"optional"` +} + +// Exchange a token with the IdP +type ExchangeTokenRequest struct { + // The partition of Credentials store + PartitionId PartitionId `tfsdk:"partitionId" tf:""` + // Array of scopes for the token request. + Scopes []types.String `tfsdk:"scopes" tf:""` + // A list of token types being requested + TokenType []types.String `tfsdk:"tokenType" tf:""` +} + +// Exhanged tokens were successfully returned. +type ExchangeTokenResponse struct { + Values []ExchangeToken `tfsdk:"values" tf:"optional"` +} + +// An IP access list was successfully returned. +type FetchIpAccessListResponse struct { + // Definition of an IP Access list + IpAccessList *IpAccessListInfo `tfsdk:"ip_access_list" tf:"optional"` +} + +// Get IP access list +type GetAccountIpAccessListRequest struct { + // The ID for the corresponding IP access list + IpAccessListId types.String `tfsdk:"-"` +} + +// Get the automatic cluster update setting +type GetAutomaticClusterUpdateSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// Get the compliance security profile setting +type GetComplianceSecurityProfileSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// Get the compliance security profile setting for new workspaces +type GetCspEnablementAccountSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// Get the default namespace setting +type GetDefaultNamespaceSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// Get the enhanced security monitoring setting +type GetEnhancedSecurityMonitoringSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// Get the enhanced security monitoring setting for new workspaces +type GetEsmEnablementAccountSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// Get access list +type GetIpAccessListRequest struct { + // The ID for the corresponding IP access list + IpAccessListId types.String `tfsdk:"-"` +} + +type GetIpAccessListResponse struct { + // Definition of an IP Access list + IpAccessList *IpAccessListInfo `tfsdk:"ip_access_list" tf:"optional"` +} + +// IP access lists were successfully returned. +type GetIpAccessListsResponse struct { + IpAccessLists []IpAccessListInfo `tfsdk:"ip_access_lists" tf:"optional"` +} + +// Get a network connectivity configuration +type GetNetworkConnectivityConfigurationRequest struct { + // Your Network Connectvity Configuration ID. + NetworkConnectivityConfigId types.String `tfsdk:"-"` +} + +// Get Personal Compute setting +type GetPersonalComputeSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// Get a private endpoint rule +type GetPrivateEndpointRuleRequest struct { + // Your Network Connectvity Configuration ID. + NetworkConnectivityConfigId types.String `tfsdk:"-"` + // Your private endpoint rule ID. + PrivateEndpointRuleId types.String `tfsdk:"-"` +} + +// Get the restrict workspace admins setting +type GetRestrictWorkspaceAdminsSettingRequest struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // delete pattern to perform setting deletions in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // DELETE request to identify the rule set version you are deleting. + Etag types.String `tfsdk:"-"` +} + +// Check configuration status +type GetStatusRequest struct { + Keys types.String `tfsdk:"-"` +} + +// Get token info +type GetTokenManagementRequest struct { + // The ID of the token to get. + TokenId types.String `tfsdk:"-"` +} + +type GetTokenPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []TokenPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Token with specified Token ID was successfully returned. +type GetTokenResponse struct { + TokenInfo *TokenInfo `tfsdk:"token_info" tf:"optional"` +} + +// Definition of an IP Access list +type IpAccessListInfo struct { + // Total number of IP or CIDR values. + AddressCount types.Int64 `tfsdk:"address_count" tf:"optional"` + // Creation timestamp in milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // User ID of the user who created this list. + CreatedBy types.Int64 `tfsdk:"created_by" tf:"optional"` + // Specifies whether this IP access list is enabled. + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` + + IpAddresses []types.String `tfsdk:"ip_addresses" tf:"optional"` + // Label for the IP access list. This **cannot** be empty. + Label types.String `tfsdk:"label" tf:"optional"` + // Universally unique identifier (UUID) of the IP access list. + ListId types.String `tfsdk:"list_id" tf:"optional"` + // Type of IP access list. Valid values are as follows and are + // case-sensitive: + // + // * `ALLOW`: An allow list. Include this IP or range. * `BLOCK`: A block + // list. Exclude this IP or range. IP addresses in the block list are + // excluded even if they are included in an allow list. + ListType types.String `tfsdk:"list_type" tf:"optional"` + // Update timestamp in milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // User ID of the user who updated this list. + UpdatedBy types.Int64 `tfsdk:"updated_by" tf:"optional"` +} + +// IP access lists were successfully returned. +type ListIpAccessListResponse struct { + IpAccessLists []IpAccessListInfo `tfsdk:"ip_access_lists" tf:"optional"` +} + +type ListNccAzurePrivateEndpointRulesResponse struct { + Items []NccAzurePrivateEndpointRule `tfsdk:"items" tf:"optional"` + // A token that can be used to get the next page of results. If null, there + // are no more results to show. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List network connectivity configurations +type ListNetworkConnectivityConfigurationsRequest struct { + // Pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` +} + +type ListNetworkConnectivityConfigurationsResponse struct { + Items []NetworkConnectivityConfiguration `tfsdk:"items" tf:"optional"` + // A token that can be used to get the next page of results. If null, there + // are no more results to show. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List private endpoint rules +type ListPrivateEndpointRulesRequest struct { + // Your Network Connectvity Configuration ID. + NetworkConnectivityConfigId types.String `tfsdk:"-"` + // Pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` +} + +type ListPublicTokensResponse struct { + // The information for each token. + TokenInfos []PublicTokenInfo `tfsdk:"token_infos" tf:"optional"` +} + +// List all tokens +type ListTokenManagementRequest struct { + // User ID of the user that created the token. + CreatedById types.Int64 `tfsdk:"-"` + // Username of the user that created the token. + CreatedByUsername types.String `tfsdk:"-"` +} + +// Tokens were successfully returned. +type ListTokensResponse struct { + // Token metadata of each user-created token in the workspace + TokenInfos []TokenInfo `tfsdk:"token_infos" tf:"optional"` +} + +// The stable AWS IP CIDR blocks. You can use these to configure the firewall of +// your resources to allow traffic from your Databricks workspace. +type NccAwsStableIpRule struct { + // The list of stable IP CIDR blocks from which Databricks network traffic + // originates when accessing your resources. + CidrBlocks []types.String `tfsdk:"cidr_blocks" tf:"optional"` +} + +type NccAzurePrivateEndpointRule struct { + // The current status of this private endpoint. The private endpoint rules + // are effective only if the connection state is `ESTABLISHED`. Remember + // that you must approve new endpoints on your resources in the Azure portal + // before they take effect. + // + // The possible values are: - INIT: (deprecated) The endpoint has been + // created and pending approval. - PENDING: The endpoint has been created + // and pending approval. - ESTABLISHED: The endpoint has been approved and + // is ready to use in your serverless compute resources. - REJECTED: + // Connection was rejected by the private link resource owner. - + // DISCONNECTED: Connection was removed by the private link resource owner, + // the private endpoint becomes informative and should be deleted for + // clean-up. + ConnectionState types.String `tfsdk:"connection_state" tf:"optional"` + // Time in epoch milliseconds when this object was created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // Whether this private endpoint is deactivated. + Deactivated types.Bool `tfsdk:"deactivated" tf:"optional"` + // Time in epoch milliseconds when this object was deactivated. + DeactivatedAt types.Int64 `tfsdk:"deactivated_at" tf:"optional"` + // The name of the Azure private endpoint resource. + EndpointName types.String `tfsdk:"endpoint_name" tf:"optional"` + // The sub-resource type (group ID) of the target resource. Note that to + // connect to workspace root storage (root DBFS), you need two endpoints, + // one for `blob` and one for `dfs`. + GroupId types.String `tfsdk:"group_id" tf:"optional"` + // The ID of a network connectivity configuration, which is the parent + // resource of this private endpoint rule object. + NetworkConnectivityConfigId types.String `tfsdk:"network_connectivity_config_id" tf:"optional"` + // The Azure resource ID of the target resource. + ResourceId types.String `tfsdk:"resource_id" tf:"optional"` + // The ID of a private endpoint rule. + RuleId types.String `tfsdk:"rule_id" tf:"optional"` + // Time in epoch milliseconds when this object was updated. + UpdatedTime types.Int64 `tfsdk:"updated_time" tf:"optional"` +} + +// The stable Azure service endpoints. You can configure the firewall of your +// Azure resources to allow traffic from your Databricks serverless compute +// resources. +type NccAzureServiceEndpointRule struct { + // The list of subnets from which Databricks network traffic originates when + // accessing your Azure resources. + Subnets []types.String `tfsdk:"subnets" tf:"optional"` + // The Azure region in which this service endpoint rule applies. + TargetRegion types.String `tfsdk:"target_region" tf:"optional"` + // The Azure services to which this service endpoint rule applies to. + TargetServices []types.String `tfsdk:"target_services" tf:"optional"` +} + +// The network connectivity rules that apply to network traffic from your +// serverless compute resources. +type NccEgressConfig struct { + // The network connectivity rules that are applied by default without + // resource specific configurations. You can find the stable network + // information of your serverless compute resources here. + DefaultRules *NccEgressDefaultRules `tfsdk:"default_rules" tf:"optional"` + // The network connectivity rules that configured for each destinations. + // These rules override default rules. + TargetRules *NccEgressTargetRules `tfsdk:"target_rules" tf:"optional"` +} + +// The network connectivity rules that are applied by default without resource +// specific configurations. You can find the stable network information of your +// serverless compute resources here. +type NccEgressDefaultRules struct { + // The stable AWS IP CIDR blocks. You can use these to configure the + // firewall of your resources to allow traffic from your Databricks + // workspace. + AwsStableIpRule *NccAwsStableIpRule `tfsdk:"aws_stable_ip_rule" tf:"optional"` + // The stable Azure service endpoints. You can configure the firewall of + // your Azure resources to allow traffic from your Databricks serverless + // compute resources. + AzureServiceEndpointRule *NccAzureServiceEndpointRule `tfsdk:"azure_service_endpoint_rule" tf:"optional"` +} + +// The network connectivity rules that configured for each destinations. These +// rules override default rules. +type NccEgressTargetRules struct { + AzurePrivateEndpointRules []NccAzurePrivateEndpointRule `tfsdk:"azure_private_endpoint_rules" tf:"optional"` +} + +type NetworkConnectivityConfiguration struct { + // The Databricks account ID that hosts the credential. + AccountId types.String `tfsdk:"account_id" tf:"optional"` + // Time in epoch milliseconds when this object was created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // The network connectivity rules that apply to network traffic from your + // serverless compute resources. + EgressConfig *NccEgressConfig `tfsdk:"egress_config" tf:"optional"` + // The name of the network connectivity configuration. The name can contain + // alphanumeric characters, hyphens, and underscores. The length must be + // between 3 and 30 characters. The name must match the regular expression + // `^[0-9a-zA-Z-_]{3,30}$`. + Name types.String `tfsdk:"name" tf:"optional"` + // Databricks network connectivity configuration ID. + NetworkConnectivityConfigId types.String `tfsdk:"network_connectivity_config_id" tf:"optional"` + // The region for the network connectivity configuration. Only workspaces in + // the same region can be attached to the network connectivity + // configuration. + Region types.String `tfsdk:"region" tf:"optional"` + // Time in epoch milliseconds when this object was updated. + UpdatedTime types.Int64 `tfsdk:"updated_time" tf:"optional"` +} + +// Partition by workspace or account +type PartitionId struct { + // The ID of the workspace. + WorkspaceId types.Int64 `tfsdk:"workspaceId" tf:"optional"` +} + +type PersonalComputeMessage struct { + // ON: Grants all users in all workspaces access to the Personal Compute + // default policy, allowing all users to create single-machine compute + // resources. DELEGATE: Moves access control for the Personal Compute + // default policy to individual workspaces and requires a workspace’s + // users or groups to be added to the ACLs of that workspace’s Personal + // Compute default policy before they will be able to create compute + // resources through that policy. + Value types.String `tfsdk:"value" tf:""` +} + +type PersonalComputeSetting struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // update pattern to perform setting updates in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // PATCH request to identify the setting version you are updating. + Etag types.String `tfsdk:"etag" tf:"optional"` + + PersonalCompute PersonalComputeMessage `tfsdk:"personal_compute" tf:""` + // Name of the corresponding setting. This field is populated in the + // response, but it will not be respected even if it's set in the request + // body. The setting name in the path parameter will be respected instead. + // Setting name is required to be 'default' if the setting only has one + // instance per workspace. + SettingName types.String `tfsdk:"setting_name" tf:"optional"` +} + +type PublicTokenInfo struct { + // Comment the token was created with, if applicable. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Server time (in epoch milliseconds) when the token was created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // Server time (in epoch milliseconds) when the token will expire, or -1 if + // not applicable. + ExpiryTime types.Int64 `tfsdk:"expiry_time" tf:"optional"` + // The ID of this token. + TokenId types.String `tfsdk:"token_id" tf:"optional"` +} + +// Details required to replace an IP access list. +type ReplaceIpAccessList struct { + // Specifies whether this IP access list is enabled. + Enabled types.Bool `tfsdk:"enabled" tf:""` + // The ID for the corresponding IP access list + IpAccessListId types.String `tfsdk:"-"` + + IpAddresses []types.String `tfsdk:"ip_addresses" tf:"optional"` + // Label for the IP access list. This **cannot** be empty. + Label types.String `tfsdk:"label" tf:""` + // Type of IP access list. Valid values are as follows and are + // case-sensitive: + // + // * `ALLOW`: An allow list. Include this IP or range. * `BLOCK`: A block + // list. Exclude this IP or range. IP addresses in the block list are + // excluded even if they are included in an allow list. + ListType types.String `tfsdk:"list_type" tf:""` +} + +type ReplaceResponse struct { +} + +type RestrictWorkspaceAdminsMessage struct { + Status types.String `tfsdk:"status" tf:""` +} + +type RestrictWorkspaceAdminsSetting struct { + // etag used for versioning. The response is at least as fresh as the eTag + // provided. This is used for optimistic concurrency control as a way to + // help prevent simultaneous writes of a setting overwriting each other. It + // is strongly suggested that systems make use of the etag in the read -> + // update pattern to perform setting updates in order to avoid race + // conditions. That is, get an etag from a GET request, and pass it with the + // PATCH request to identify the setting version you are updating. + Etag types.String `tfsdk:"etag" tf:"optional"` + + RestrictWorkspaceAdmins RestrictWorkspaceAdminsMessage `tfsdk:"restrict_workspace_admins" tf:""` + // Name of the corresponding setting. This field is populated in the + // response, but it will not be respected even if it's set in the request + // body. The setting name in the path parameter will be respected instead. + // Setting name is required to be 'default' if the setting only has one + // instance per workspace. + SettingName types.String `tfsdk:"setting_name" tf:"optional"` +} + +type RevokeTokenRequest struct { + // The ID of the token to be revoked. + TokenId types.String `tfsdk:"token_id" tf:""` +} + +type RevokeTokenResponse struct { +} + +type SetStatusResponse struct { +} + +type StringMessage struct { + // Represents a generic string value. + Value types.String `tfsdk:"value" tf:"optional"` +} + +type TokenAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type TokenAccessControlResponse struct { + // All permissions. + AllPermissions []TokenPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type TokenInfo struct { + // Comment that describes the purpose of the token, specified by the token + // creator. + Comment types.String `tfsdk:"comment" tf:"optional"` + // User ID of the user that created the token. + CreatedById types.Int64 `tfsdk:"created_by_id" tf:"optional"` + // Username of the user that created the token. + CreatedByUsername types.String `tfsdk:"created_by_username" tf:"optional"` + // Timestamp when the token was created. + CreationTime types.Int64 `tfsdk:"creation_time" tf:"optional"` + // Timestamp when the token expires. + ExpiryTime types.Int64 `tfsdk:"expiry_time" tf:"optional"` + // User ID of the user that owns the token. + OwnerId types.Int64 `tfsdk:"owner_id" tf:"optional"` + // ID of the token. + TokenId types.String `tfsdk:"token_id" tf:"optional"` +} + +type TokenPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type TokenPermissions struct { + AccessControlList []TokenAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type TokenPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type TokenPermissionsRequest struct { + AccessControlList []TokenAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` +} + +// Details required to update a setting. +type UpdateAutomaticClusterUpdateSettingRequest struct { + // This should always be set to true for Settings API. Added for AIP + // compliance. + AllowMissing types.Bool `tfsdk:"allow_missing" tf:""` + // Field mask is required to be passed into the PATCH request. Field mask + // specifies which fields of the setting payload will be updated. The field + // mask needs to be supplied as single string. To specify multiple fields in + // the field mask, use comma as the separator (no space). + FieldMask types.String `tfsdk:"field_mask" tf:""` + + Setting AutomaticClusterUpdateSetting `tfsdk:"setting" tf:""` +} + +// Details required to update a setting. +type UpdateComplianceSecurityProfileSettingRequest struct { + // This should always be set to true for Settings API. Added for AIP + // compliance. + AllowMissing types.Bool `tfsdk:"allow_missing" tf:""` + // Field mask is required to be passed into the PATCH request. Field mask + // specifies which fields of the setting payload will be updated. The field + // mask needs to be supplied as single string. To specify multiple fields in + // the field mask, use comma as the separator (no space). + FieldMask types.String `tfsdk:"field_mask" tf:""` + + Setting ComplianceSecurityProfileSetting `tfsdk:"setting" tf:""` +} + +// Details required to update a setting. +type UpdateCspEnablementAccountSettingRequest struct { + // This should always be set to true for Settings API. Added for AIP + // compliance. + AllowMissing types.Bool `tfsdk:"allow_missing" tf:""` + // Field mask is required to be passed into the PATCH request. Field mask + // specifies which fields of the setting payload will be updated. The field + // mask needs to be supplied as single string. To specify multiple fields in + // the field mask, use comma as the separator (no space). + FieldMask types.String `tfsdk:"field_mask" tf:""` + + Setting CspEnablementAccountSetting `tfsdk:"setting" tf:""` +} + +// Details required to update a setting. +type UpdateDefaultNamespaceSettingRequest struct { + // This should always be set to true for Settings API. Added for AIP + // compliance. + AllowMissing types.Bool `tfsdk:"allow_missing" tf:""` + // Field mask is required to be passed into the PATCH request. Field mask + // specifies which fields of the setting payload will be updated. The field + // mask needs to be supplied as single string. To specify multiple fields in + // the field mask, use comma as the separator (no space). + FieldMask types.String `tfsdk:"field_mask" tf:""` + // This represents the setting configuration for the default namespace in + // the Databricks workspace. Setting the default catalog for the workspace + // determines the catalog that is used when queries do not reference a fully + // qualified 3 level name. For example, if the default catalog is set to + // 'retail_prod' then a query 'SELECT * FROM myTable' would reference the + // object 'retail_prod.default.myTable' (the schema 'default' is always + // assumed). This setting requires a restart of clusters and SQL warehouses + // to take effect. Additionally, the default namespace only applies when + // using Unity Catalog-enabled compute. + Setting DefaultNamespaceSetting `tfsdk:"setting" tf:""` +} + +// Details required to update a setting. +type UpdateEnhancedSecurityMonitoringSettingRequest struct { + // This should always be set to true for Settings API. Added for AIP + // compliance. + AllowMissing types.Bool `tfsdk:"allow_missing" tf:""` + // Field mask is required to be passed into the PATCH request. Field mask + // specifies which fields of the setting payload will be updated. The field + // mask needs to be supplied as single string. To specify multiple fields in + // the field mask, use comma as the separator (no space). + FieldMask types.String `tfsdk:"field_mask" tf:""` + + Setting EnhancedSecurityMonitoringSetting `tfsdk:"setting" tf:""` +} + +// Details required to update a setting. +type UpdateEsmEnablementAccountSettingRequest struct { + // This should always be set to true for Settings API. Added for AIP + // compliance. + AllowMissing types.Bool `tfsdk:"allow_missing" tf:""` + // Field mask is required to be passed into the PATCH request. Field mask + // specifies which fields of the setting payload will be updated. The field + // mask needs to be supplied as single string. To specify multiple fields in + // the field mask, use comma as the separator (no space). + FieldMask types.String `tfsdk:"field_mask" tf:""` + + Setting EsmEnablementAccountSetting `tfsdk:"setting" tf:""` +} + +// Details required to update an IP access list. +type UpdateIpAccessList struct { + // Specifies whether this IP access list is enabled. + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` + // The ID for the corresponding IP access list + IpAccessListId types.String `tfsdk:"-"` + + IpAddresses []types.String `tfsdk:"ip_addresses" tf:"optional"` + // Label for the IP access list. This **cannot** be empty. + Label types.String `tfsdk:"label" tf:"optional"` + // Type of IP access list. Valid values are as follows and are + // case-sensitive: + // + // * `ALLOW`: An allow list. Include this IP or range. * `BLOCK`: A block + // list. Exclude this IP or range. IP addresses in the block list are + // excluded even if they are included in an allow list. + ListType types.String `tfsdk:"list_type" tf:"optional"` +} + +// Details required to update a setting. +type UpdatePersonalComputeSettingRequest struct { + // This should always be set to true for Settings API. Added for AIP + // compliance. + AllowMissing types.Bool `tfsdk:"allow_missing" tf:""` + // Field mask is required to be passed into the PATCH request. Field mask + // specifies which fields of the setting payload will be updated. The field + // mask needs to be supplied as single string. To specify multiple fields in + // the field mask, use comma as the separator (no space). + FieldMask types.String `tfsdk:"field_mask" tf:""` + + Setting PersonalComputeSetting `tfsdk:"setting" tf:""` +} + +type UpdateResponse struct { +} + +// Details required to update a setting. +type UpdateRestrictWorkspaceAdminsSettingRequest struct { + // This should always be set to true for Settings API. Added for AIP + // compliance. + AllowMissing types.Bool `tfsdk:"allow_missing" tf:""` + // Field mask is required to be passed into the PATCH request. Field mask + // specifies which fields of the setting payload will be updated. The field + // mask needs to be supplied as single string. To specify multiple fields in + // the field mask, use comma as the separator (no space). + FieldMask types.String `tfsdk:"field_mask" tf:""` + + Setting RestrictWorkspaceAdminsSetting `tfsdk:"setting" tf:""` +} diff --git a/internal/service/sharing_tf/model.go b/internal/service/sharing_tf/model.go new file mode 100755 index 0000000000..d0c7cff38e --- /dev/null +++ b/internal/service/sharing_tf/model.go @@ -0,0 +1,681 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package sharing_tf + +import ( + "github.com/databricks/databricks-sdk-go/service/catalog" + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type CentralCleanRoomInfo struct { + // All assets from all collaborators that are available in the clean room. + // Only one of table_info or notebook_info will be filled in. + CleanRoomAssets []CleanRoomAssetInfo `tfsdk:"clean_room_assets" tf:"optional"` + // All collaborators who are in the clean room. + Collaborators []CleanRoomCollaboratorInfo `tfsdk:"collaborators" tf:"optional"` + // The collaborator who created the clean room. + Creator *CleanRoomCollaboratorInfo `tfsdk:"creator" tf:"optional"` + // The cloud where clean room tasks will be run. + StationCloud types.String `tfsdk:"station_cloud" tf:"optional"` + // The region where clean room tasks will be run. + StationRegion types.String `tfsdk:"station_region" tf:"optional"` +} + +type CleanRoomAssetInfo struct { + // Time at which this asset was added, in epoch milliseconds. + AddedAt types.Int64 `tfsdk:"added_at" tf:"optional"` + // Details about the notebook asset. + NotebookInfo *CleanRoomNotebookInfo `tfsdk:"notebook_info" tf:"optional"` + // The collaborator who owns the asset. + Owner *CleanRoomCollaboratorInfo `tfsdk:"owner" tf:"optional"` + // Details about the table asset. + TableInfo *CleanRoomTableInfo `tfsdk:"table_info" tf:"optional"` + // Time at which this asset was updated, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` +} + +type CleanRoomCatalog struct { + // Name of the catalog in the clean room station. Empty for notebooks. + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // The details of the shared notebook files. + NotebookFiles []SharedDataObject `tfsdk:"notebook_files" tf:"optional"` + // The details of the shared tables. + Tables []SharedDataObject `tfsdk:"tables" tf:"optional"` +} + +type CleanRoomCatalogUpdate struct { + // The name of the catalog to update assets. + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // The updates to the assets in the catalog. + Updates *SharedDataObjectUpdate `tfsdk:"updates" tf:"optional"` +} + +type CleanRoomCollaboratorInfo struct { + // The global Unity Catalog metastore id of the collaborator. Also known as + // the sharing identifier. The identifier is of format + // __cloud__:__region__:__metastore-uuid__. + GlobalMetastoreId types.String `tfsdk:"global_metastore_id" tf:"optional"` + // The organization name of the collaborator. This is configured in the + // metastore for Delta Sharing and is used to identify the organization to + // other collaborators. + OrganizationName types.String `tfsdk:"organization_name" tf:"optional"` +} + +type CleanRoomInfo struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Time at which this clean room was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of clean room creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Catalog aliases shared by the current collaborator with asset details. + LocalCatalogs []CleanRoomCatalog `tfsdk:"local_catalogs" tf:"optional"` + // Name of the clean room. + Name types.String `tfsdk:"name" tf:"optional"` + // Username of current owner of clean room. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Central clean room details. + RemoteDetailedInfo *CentralCleanRoomInfo `tfsdk:"remote_detailed_info" tf:"optional"` + // Time at which this clean room was updated, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of clean room updater. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type CleanRoomNotebookInfo struct { + // The base64 representation of the notebook content in HTML. + NotebookContent types.String `tfsdk:"notebook_content" tf:"optional"` + // The name of the notebook. + NotebookName types.String `tfsdk:"notebook_name" tf:"optional"` +} + +type CleanRoomTableInfo struct { + // Name of parent catalog. + CatalogName types.String `tfsdk:"catalog_name" tf:"optional"` + // The array of __ColumnInfo__ definitions of the table's columns. + Columns []ColumnInfo `tfsdk:"columns" tf:"optional"` + // Full name of table, in form of + // __catalog_name__.__schema_name__.__table_name__ + FullName types.String `tfsdk:"full_name" tf:"optional"` + // Name of table, relative to parent schema. + Name types.String `tfsdk:"name" tf:"optional"` + // Name of parent schema relative to its parent catalog. + SchemaName types.String `tfsdk:"schema_name" tf:"optional"` +} + +type ColumnInfo struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + + Mask *ColumnMask `tfsdk:"mask" tf:"optional"` + // Name of Column. + Name types.String `tfsdk:"name" tf:"optional"` + // Whether field may be Null (default: true). + Nullable types.Bool `tfsdk:"nullable" tf:"optional"` + // Partition index for column. + PartitionIndex types.Int64 `tfsdk:"partition_index" tf:"optional"` + // Ordinal position of column (starting at position 0). + Position types.Int64 `tfsdk:"position" tf:"optional"` + // Format of IntervalType. + TypeIntervalType types.String `tfsdk:"type_interval_type" tf:"optional"` + // Full data type specification, JSON-serialized. + TypeJson types.String `tfsdk:"type_json" tf:"optional"` + // Name of type (INT, STRUCT, MAP, etc.). + TypeName types.String `tfsdk:"type_name" tf:"optional"` + // Digits of precision; required for DecimalTypes. + TypePrecision types.Int64 `tfsdk:"type_precision" tf:"optional"` + // Digits to right of decimal; Required for DecimalTypes. + TypeScale types.Int64 `tfsdk:"type_scale" tf:"optional"` + // Full data type specification as SQL/catalogString text. + TypeText types.String `tfsdk:"type_text" tf:"optional"` +} + +type ColumnMask struct { + // The full name of the column mask SQL UDF. + FunctionName types.String `tfsdk:"function_name" tf:"optional"` + // The list of additional table columns to be passed as input to the column + // mask function. The first arg of the mask function should be of the type + // of the column being masked and the types of the rest of the args should + // match the types of columns in 'using_column_names'. + UsingColumnNames []types.String `tfsdk:"using_column_names" tf:"optional"` +} + +type CreateCleanRoom struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of the clean room. + Name types.String `tfsdk:"name" tf:""` + // Central clean room details. + RemoteDetailedInfo CentralCleanRoomInfo `tfsdk:"remote_detailed_info" tf:""` +} + +type CreateProvider struct { + // The delta sharing authentication type. + AuthenticationType types.String `tfsdk:"authentication_type" tf:""` + // Description about the provider. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The name of the Provider. + Name types.String `tfsdk:"name" tf:""` + // This field is required when the __authentication_type__ is **TOKEN** or + // not provided. + RecipientProfileStr types.String `tfsdk:"recipient_profile_str" tf:"optional"` +} + +type CreateRecipient struct { + // The delta sharing authentication type. + AuthenticationType types.String `tfsdk:"authentication_type" tf:""` + // Description about the recipient. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The global Unity Catalog metastore id provided by the data recipient. + // This field is required when the __authentication_type__ is + // **DATABRICKS**. The identifier is of format + // __cloud__:__region__:__metastore-uuid__. + DataRecipientGlobalMetastoreId types.String `tfsdk:"data_recipient_global_metastore_id" tf:"optional"` + // IP Access List + IpAccessList *IpAccessList `tfsdk:"ip_access_list" tf:"optional"` + // Name of Recipient. + Name types.String `tfsdk:"name" tf:""` + // Username of the recipient owner. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Recipient properties as map of string key-value pairs. + PropertiesKvpairs *SecurablePropertiesKvPairs `tfsdk:"properties_kvpairs" tf:"optional"` + // The one-time sharing code provided by the data recipient. This field is + // required when the __authentication_type__ is **DATABRICKS**. + SharingCode types.String `tfsdk:"sharing_code" tf:"optional"` +} + +type CreateShare struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of the share. + Name types.String `tfsdk:"name" tf:""` + // Storage root URL for the share. + StorageRoot types.String `tfsdk:"storage_root" tf:"optional"` +} + +// Delete a clean room +type DeleteCleanRoomRequest struct { + // The name of the clean room. + Name types.String `tfsdk:"-"` +} + +// Delete a provider +type DeleteProviderRequest struct { + // Name of the provider. + Name types.String `tfsdk:"-"` +} + +// Delete a share recipient +type DeleteRecipientRequest struct { + // Name of the recipient. + Name types.String `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +// Delete a share +type DeleteShareRequest struct { + // The name of the share. + Name types.String `tfsdk:"-"` +} + +// Get a share activation URL +type GetActivationUrlInfoRequest struct { + // The one time activation url. It also accepts activation token. + ActivationUrl types.String `tfsdk:"-"` +} + +type GetActivationUrlInfoResponse struct { +} + +// Get a clean room +type GetCleanRoomRequest struct { + // Whether to include remote details (central) on the clean room. + IncludeRemoteDetails types.Bool `tfsdk:"-"` + // The name of the clean room. + Name types.String `tfsdk:"-"` +} + +// Get a provider +type GetProviderRequest struct { + // Name of the provider. + Name types.String `tfsdk:"-"` +} + +// Get a share recipient +type GetRecipientRequest struct { + // Name of the recipient. + Name types.String `tfsdk:"-"` +} + +type GetRecipientSharePermissionsResponse struct { + // An array of data share permissions for a recipient. + PermissionsOut []ShareToPrivilegeAssignment `tfsdk:"permissions_out" tf:"optional"` +} + +// Get a share +type GetShareRequest struct { + // Query for data to include in the share. + IncludeSharedData types.Bool `tfsdk:"-"` + // The name of the share. + Name types.String `tfsdk:"-"` +} + +type IpAccessList struct { + // Allowed IP Addresses in CIDR notation. Limit of 100. + AllowedIpAddresses []types.String `tfsdk:"allowed_ip_addresses" tf:"optional"` +} + +// List clean rooms +type ListCleanRoomsRequest struct { + // Maximum number of clean rooms to return. If not set, all the clean rooms + // are returned (not recommended). - when set to a value greater than 0, the + // page length is the minimum of this value and a server configured value; - + // when set to 0, the page length is set to a server configured value + // (recommended); - when set to a value less than 0, an invalid parameter + // error is returned; + MaxResults types.Int64 `tfsdk:"-"` + // Opaque pagination token to go to next page based on previous query. + PageToken types.String `tfsdk:"-"` +} + +type ListCleanRoomsResponse struct { + // An array of clean rooms. Remote details (central) are not included. + CleanRooms []CleanRoomInfo `tfsdk:"clean_rooms" tf:"optional"` + // Opaque token to retrieve the next page of results. Absent if there are no + // more pages. __page_token__ should be set to this value for the next + // request (for the next page of results). + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +type ListProviderSharesResponse struct { + // An array of provider shares. + Shares []ProviderShare `tfsdk:"shares" tf:"optional"` +} + +// List providers +type ListProvidersRequest struct { + // If not provided, all providers will be returned. If no providers exist + // with this ID, no results will be returned. + DataProviderGlobalMetastoreId types.String `tfsdk:"-"` +} + +type ListProvidersResponse struct { + // An array of provider information objects. + Providers []ProviderInfo `tfsdk:"providers" tf:"optional"` +} + +// List share recipients +type ListRecipientsRequest struct { + // If not provided, all recipients will be returned. If no recipients exist + // with this ID, no results will be returned. + DataRecipientGlobalMetastoreId types.String `tfsdk:"-"` +} + +type ListRecipientsResponse struct { + // An array of recipient information objects. + Recipients []RecipientInfo `tfsdk:"recipients" tf:"optional"` +} + +// List shares by Provider +type ListSharesRequest struct { + // Name of the provider in which to list shares. + Name types.String `tfsdk:"-"` +} + +type ListSharesResponse struct { + // An array of data share information objects. + Shares []ShareInfo `tfsdk:"shares" tf:"optional"` +} + +type Partition struct { + // An array of partition values. + Values []PartitionValue `tfsdk:"values" tf:"optional"` +} + +type PartitionValue struct { + // The name of the partition column. + Name types.String `tfsdk:"name" tf:"optional"` + // The operator to apply for the value. + Op types.String `tfsdk:"op" tf:"optional"` + // The key of a Delta Sharing recipient's property. For example + // `databricks-account-id`. When this field is set, field `value` can not be + // set. + RecipientPropertyKey types.String `tfsdk:"recipient_property_key" tf:"optional"` + // The value of the partition column. When this value is not set, it means + // `null` value. When this field is set, field `recipient_property_key` can + // not be set. + Value types.String `tfsdk:"value" tf:"optional"` +} + +type PrivilegeAssignment struct { + // The principal (user email address or group name). + Principal types.String `tfsdk:"principal" tf:"optional"` + // The privileges assigned to the principal. + Privileges []types.String `tfsdk:"privileges" tf:"optional"` +} + +type ProviderInfo struct { + // The delta sharing authentication type. + AuthenticationType types.String `tfsdk:"authentication_type" tf:"optional"` + // Cloud vendor of the provider's UC metastore. This field is only present + // when the __authentication_type__ is **DATABRICKS**. + Cloud types.String `tfsdk:"cloud" tf:"optional"` + // Description about the provider. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Time at which this Provider was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of Provider creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // The global UC metastore id of the data provider. This field is only + // present when the __authentication_type__ is **DATABRICKS**. The + // identifier is of format ::. + DataProviderGlobalMetastoreId types.String `tfsdk:"data_provider_global_metastore_id" tf:"optional"` + // UUID of the provider's UC metastore. This field is only present when the + // __authentication_type__ is **DATABRICKS**. + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // The name of the Provider. + Name types.String `tfsdk:"name" tf:"optional"` + // Username of Provider owner. + Owner types.String `tfsdk:"owner" tf:"optional"` + // The recipient profile. This field is only present when the + // authentication_type is `TOKEN`. + RecipientProfile *RecipientProfile `tfsdk:"recipient_profile" tf:"optional"` + // This field is only present when the authentication_type is `TOKEN` or not + // provided. + RecipientProfileStr types.String `tfsdk:"recipient_profile_str" tf:"optional"` + // Cloud region of the provider's UC metastore. This field is only present + // when the __authentication_type__ is **DATABRICKS**. + Region types.String `tfsdk:"region" tf:"optional"` + // Time at which this Provider was created, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of user who last modified Share. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type ProviderShare struct { + // The name of the Provider Share. + Name types.String `tfsdk:"name" tf:"optional"` +} + +type RecipientInfo struct { + // A boolean status field showing whether the Recipient's activation URL has + // been exercised or not. + Activated types.Bool `tfsdk:"activated" tf:"optional"` + // Full activation url to retrieve the access token. It will be empty if the + // token is already retrieved. + ActivationUrl types.String `tfsdk:"activation_url" tf:"optional"` + // The delta sharing authentication type. + AuthenticationType types.String `tfsdk:"authentication_type" tf:"optional"` + // Cloud vendor of the recipient's Unity Catalog Metstore. This field is + // only present when the __authentication_type__ is **DATABRICKS**`. + Cloud types.String `tfsdk:"cloud" tf:"optional"` + // Description about the recipient. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Time at which this recipient was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of recipient creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // The global Unity Catalog metastore id provided by the data recipient. + // This field is only present when the __authentication_type__ is + // **DATABRICKS**. The identifier is of format + // __cloud__:__region__:__metastore-uuid__. + DataRecipientGlobalMetastoreId types.String `tfsdk:"data_recipient_global_metastore_id" tf:"optional"` + // IP Access List + IpAccessList *IpAccessList `tfsdk:"ip_access_list" tf:"optional"` + // Unique identifier of recipient's Unity Catalog metastore. This field is + // only present when the __authentication_type__ is **DATABRICKS** + MetastoreId types.String `tfsdk:"metastore_id" tf:"optional"` + // Name of Recipient. + Name types.String `tfsdk:"name" tf:"optional"` + // Username of the recipient owner. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Recipient properties as map of string key-value pairs. + PropertiesKvpairs *SecurablePropertiesKvPairs `tfsdk:"properties_kvpairs" tf:"optional"` + // Cloud region of the recipient's Unity Catalog Metstore. This field is + // only present when the __authentication_type__ is **DATABRICKS**. + Region types.String `tfsdk:"region" tf:"optional"` + // The one-time sharing code provided by the data recipient. This field is + // only present when the __authentication_type__ is **DATABRICKS**. + SharingCode types.String `tfsdk:"sharing_code" tf:"optional"` + // This field is only present when the __authentication_type__ is **TOKEN**. + Tokens []RecipientTokenInfo `tfsdk:"tokens" tf:"optional"` + // Time at which the recipient was updated, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of recipient updater. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +type RecipientProfile struct { + // The token used to authorize the recipient. + BearerToken types.String `tfsdk:"bearer_token" tf:"optional"` + // The endpoint for the share to be used by the recipient. + Endpoint types.String `tfsdk:"endpoint" tf:"optional"` + // The version number of the recipient's credentials on a share. + ShareCredentialsVersion types.Int64 `tfsdk:"share_credentials_version" tf:"optional"` +} + +type RecipientTokenInfo struct { + // Full activation URL to retrieve the access token. It will be empty if the + // token is already retrieved. + ActivationUrl types.String `tfsdk:"activation_url" tf:"optional"` + // Time at which this recipient Token was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of recipient token creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Expiration timestamp of the token in epoch milliseconds. + ExpirationTime types.Int64 `tfsdk:"expiration_time" tf:"optional"` + // Unique ID of the recipient token. + Id types.String `tfsdk:"id" tf:"optional"` + // Time at which this recipient Token was updated, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of recipient Token updater. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +// Get an access token +type RetrieveTokenRequest struct { + // The one time activation url. It also accepts activation token. + ActivationUrl types.String `tfsdk:"-"` +} + +type RetrieveTokenResponse struct { + // The token used to authorize the recipient. + BearerToken types.String `tfsdk:"bearerToken" tf:"optional"` + // The endpoint for the share to be used by the recipient. + Endpoint types.String `tfsdk:"endpoint" tf:"optional"` + // Expiration timestamp of the token in epoch milliseconds. + ExpirationTime types.String `tfsdk:"expirationTime" tf:"optional"` + // These field names must follow the delta sharing protocol. + ShareCredentialsVersion types.Int64 `tfsdk:"shareCredentialsVersion" tf:"optional"` +} + +type RotateRecipientToken struct { + // The expiration time of the bearer token in ISO 8601 format. This will set + // the expiration_time of existing token only to a smaller timestamp, it + // cannot extend the expiration_time. Use 0 to expire the existing token + // immediately, negative number will return an error. + ExistingTokenExpireInSeconds types.Int64 `tfsdk:"existing_token_expire_in_seconds" tf:""` + // The name of the recipient. + Name types.String `tfsdk:"-"` +} + +// An object with __properties__ containing map of key-value properties attached +// to the securable. +type SecurablePropertiesKvPairs struct { + // A map of key-value properties attached to the securable. + Properties map[string]types.String `tfsdk:"properties" tf:""` +} + +type ShareInfo struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Time at which this share was created, in epoch milliseconds. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // Username of share creator. + CreatedBy types.String `tfsdk:"created_by" tf:"optional"` + // Name of the share. + Name types.String `tfsdk:"name" tf:"optional"` + // A list of shared data objects within the share. + Objects []SharedDataObject `tfsdk:"objects" tf:"optional"` + // Username of current owner of share. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Storage Location URL (full path) for the share. + StorageLocation types.String `tfsdk:"storage_location" tf:"optional"` + // Storage root URL for the share. + StorageRoot types.String `tfsdk:"storage_root" tf:"optional"` + // Time at which this share was updated, in epoch milliseconds. + UpdatedAt types.Int64 `tfsdk:"updated_at" tf:"optional"` + // Username of share updater. + UpdatedBy types.String `tfsdk:"updated_by" tf:"optional"` +} + +// Get recipient share permissions +type SharePermissionsRequest struct { + // The name of the Recipient. + Name types.String `tfsdk:"-"` +} + +type ShareToPrivilegeAssignment struct { + // The privileges assigned to the principal. + PrivilegeAssignments []PrivilegeAssignment `tfsdk:"privilege_assignments" tf:"optional"` + // The share name. + ShareName types.String `tfsdk:"share_name" tf:"optional"` +} + +type SharedDataObject struct { + // The time when this data object is added to the share, in epoch + // milliseconds. + AddedAt types.Int64 `tfsdk:"added_at" tf:"optional"` + // Username of the sharer. + AddedBy types.String `tfsdk:"added_by" tf:"optional"` + // Whether to enable cdf or indicate if cdf is enabled on the shared object. + CdfEnabled types.Bool `tfsdk:"cdf_enabled" tf:"optional"` + // A user-provided comment when adding the data object to the share. + // [Update:OPT] + Comment types.String `tfsdk:"comment" tf:"optional"` + // The content of the notebook file when the data object type is + // NOTEBOOK_FILE. This should be base64 encoded. Required for adding a + // NOTEBOOK_FILE, optional for updating, ignored for other types. + Content types.String `tfsdk:"content" tf:"optional"` + // The type of the data object. + DataObjectType types.String `tfsdk:"data_object_type" tf:"optional"` + // Whether to enable or disable sharing of data history. If not specified, + // the default is **DISABLED**. + HistoryDataSharingStatus types.String `tfsdk:"history_data_sharing_status" tf:"optional"` + // A fully qualified name that uniquely identifies a data object. + // + // For example, a table's fully qualified name is in the format of + // `..`. + Name types.String `tfsdk:"name" tf:""` + // Array of partitions for the shared data. + Partitions []Partition `tfsdk:"partitions" tf:"optional"` + // A user-provided new name for the data object within the share. If this + // new name is not provided, the object's original name will be used as the + // `shared_as` name. The `shared_as` name must be unique within a share. For + // tables, the new name must follow the format of `.
`. + SharedAs types.String `tfsdk:"shared_as" tf:"optional"` + // The start version associated with the object. This allows data providers + // to control the lowest object version that is accessible by clients. If + // specified, clients can query snapshots or changes for versions >= + // start_version. If not specified, clients can only query starting from the + // version of the object at the time it was added to the share. + // + // NOTE: The start_version should be <= the `current` version of the object. + StartVersion types.Int64 `tfsdk:"start_version" tf:"optional"` + // One of: **ACTIVE**, **PERMISSION_DENIED**. + Status types.String `tfsdk:"status" tf:"optional"` + // A user-provided new name for the data object within the share. If this + // new name is not provided, the object's original name will be used as the + // `string_shared_as` name. The `string_shared_as` name must be unique + // within a share. For notebooks, the new name should be the new notebook + // file name. + StringSharedAs types.String `tfsdk:"string_shared_as" tf:"optional"` +} + +type SharedDataObjectUpdate struct { + // One of: **ADD**, **REMOVE**, **UPDATE**. + Action types.String `tfsdk:"action" tf:"optional"` + // The data object that is being added, removed, or updated. + DataObject *SharedDataObject `tfsdk:"data_object" tf:"optional"` +} + +type UpdateCleanRoom struct { + // Array of shared data object updates. + CatalogUpdates []CleanRoomCatalogUpdate `tfsdk:"catalog_updates" tf:"optional"` + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The name of the clean room. + Name types.String `tfsdk:"-"` + // Username of current owner of clean room. + Owner types.String `tfsdk:"owner" tf:"optional"` +} + +type UpdatePermissionsResponse struct { +} + +type UpdateProvider struct { + // Description about the provider. + Comment types.String `tfsdk:"comment" tf:"optional"` + // Name of the provider. + Name types.String `tfsdk:"-"` + // New name for the provider. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // Username of Provider owner. + Owner types.String `tfsdk:"owner" tf:"optional"` + // This field is required when the __authentication_type__ is **TOKEN** or + // not provided. + RecipientProfileStr types.String `tfsdk:"recipient_profile_str" tf:"optional"` +} + +type UpdateRecipient struct { + // Description about the recipient. + Comment types.String `tfsdk:"comment" tf:"optional"` + // IP Access List + IpAccessList *IpAccessList `tfsdk:"ip_access_list" tf:"optional"` + // Name of the recipient. + Name types.String `tfsdk:"-"` + // New name for the recipient. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // Username of the recipient owner. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Recipient properties as map of string key-value pairs. When provided in + // update request, the specified properties will override the existing + // properties. To add and remove properties, one would need to perform a + // read-modify-write. + PropertiesKvpairs *SecurablePropertiesKvPairs `tfsdk:"properties_kvpairs" tf:"optional"` +} + +type UpdateResponse struct { +} + +type UpdateShare struct { + // User-provided free-form text description. + Comment types.String `tfsdk:"comment" tf:"optional"` + // The name of the share. + Name types.String `tfsdk:"-"` + // New name for the share. + NewName types.String `tfsdk:"new_name" tf:"optional"` + // Username of current owner of share. + Owner types.String `tfsdk:"owner" tf:"optional"` + // Storage root URL for the share. + StorageRoot types.String `tfsdk:"storage_root" tf:"optional"` + // Array of shared data object updates. + Updates []SharedDataObjectUpdate `tfsdk:"updates" tf:"optional"` +} + +type UpdateSharePermissions struct { + // Array of permission changes. + Changes []catalog.PermissionsChange `tfsdk:"changes" tf:"optional"` + // The name of the share. + Name types.String `tfsdk:"-"` +} diff --git a/internal/service/sql_tf/model.go b/internal/service/sql_tf/model.go new file mode 100755 index 0000000000..d546830751 --- /dev/null +++ b/internal/service/sql_tf/model.go @@ -0,0 +1,1816 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package sql_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type AccessControl struct { + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // * `CAN_VIEW`: Can view the query * `CAN_RUN`: Can run the query * + // `CAN_EDIT`: Can edit the query * `CAN_MANAGE`: Can manage the query + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type Alert struct { + // Timestamp when the alert was created. + CreatedAt types.String `tfsdk:"created_at" tf:"optional"` + // Alert ID. + Id types.String `tfsdk:"id" tf:"optional"` + // Timestamp when the alert was last triggered. + LastTriggeredAt types.String `tfsdk:"last_triggered_at" tf:"optional"` + // Name of the alert. + Name types.String `tfsdk:"name" tf:"optional"` + // Alert configuration options. + Options *AlertOptions `tfsdk:"options" tf:"optional"` + // The identifier of the workspace folder containing the object. + Parent types.String `tfsdk:"parent" tf:"optional"` + + Query *AlertQuery `tfsdk:"query" tf:"optional"` + // Number of seconds after being triggered before the alert rearms itself + // and can be triggered again. If `null`, alert will never be triggered + // again. + Rearm types.Int64 `tfsdk:"rearm" tf:"optional"` + // State of the alert. Possible values are: `unknown` (yet to be evaluated), + // `triggered` (evaluated and fulfilled trigger conditions), or `ok` + // (evaluated and did not fulfill trigger conditions). + State types.String `tfsdk:"state" tf:"optional"` + // Timestamp when the alert was last updated. + UpdatedAt types.String `tfsdk:"updated_at" tf:"optional"` + + User *User `tfsdk:"user" tf:"optional"` +} + +// Alert configuration options. +type AlertOptions struct { + // Name of column in the query result to compare in alert evaluation. + Column types.String `tfsdk:"column" tf:""` + // Custom body of alert notification, if it exists. See [here] for custom + // templating instructions. + // + // [here]: https://docs.databricks.com/sql/user/alerts/index.html + CustomBody types.String `tfsdk:"custom_body" tf:"optional"` + // Custom subject of alert notification, if it exists. This includes email + // subject, Slack notification header, etc. See [here] for custom templating + // instructions. + // + // [here]: https://docs.databricks.com/sql/user/alerts/index.html + CustomSubject types.String `tfsdk:"custom_subject" tf:"optional"` + // State that alert evaluates to when query result is empty. + EmptyResultState types.String `tfsdk:"empty_result_state" tf:"optional"` + // Whether or not the alert is muted. If an alert is muted, it will not + // notify users and notification destinations when triggered. + Muted types.Bool `tfsdk:"muted" tf:"optional"` + // Operator used to compare in alert evaluation: `>`, `>=`, `<`, `<=`, `==`, + // `!=` + Op types.String `tfsdk:"op" tf:""` + // Value used to compare in alert evaluation. Supported types include + // strings (eg. 'foobar'), floats (eg. 123.4), and booleans (true). + Value any `tfsdk:"value" tf:""` +} + +type AlertQuery struct { + // The timestamp when this query was created. + CreatedAt types.String `tfsdk:"created_at" tf:"optional"` + // Data source ID maps to the ID of the data source used by the resource and + // is distinct from the warehouse ID. [Learn more] + // + // [Learn more]: https://docs.databricks.com/api/workspace/datasources/list + DataSourceId types.String `tfsdk:"data_source_id" tf:"optional"` + // General description that conveys additional information about this query + // such as usage notes. + Description types.String `tfsdk:"description" tf:"optional"` + // Query ID. + Id types.String `tfsdk:"id" tf:"optional"` + // Indicates whether the query is trashed. Trashed queries can't be used in + // dashboards, or appear in search results. If this boolean is `true`, the + // `options` property for this query includes a `moved_to_trash_at` + // timestamp. Trashed queries are permanently deleted after 30 days. + IsArchived types.Bool `tfsdk:"is_archived" tf:"optional"` + // Whether the query is a draft. Draft queries only appear in list views for + // their owners. Visualizations from draft queries cannot appear on + // dashboards. + IsDraft types.Bool `tfsdk:"is_draft" tf:"optional"` + // Text parameter types are not safe from SQL injection for all types of + // data source. Set this Boolean parameter to `true` if a query either does + // not use any text type parameters or uses a data source type where text + // type parameters are handled safely. + IsSafe types.Bool `tfsdk:"is_safe" tf:"optional"` + // The title of this query that appears in list views, widget headings, and + // on the query page. + Name types.String `tfsdk:"name" tf:"optional"` + + Options *QueryOptions `tfsdk:"options" tf:"optional"` + // The text of the query to be run. + Query types.String `tfsdk:"query" tf:"optional"` + + Tags []types.String `tfsdk:"tags" tf:"optional"` + // The timestamp at which this query was last updated. + UpdatedAt types.String `tfsdk:"updated_at" tf:"optional"` + // The ID of the user who owns the query. + UserId types.Int64 `tfsdk:"user_id" tf:"optional"` +} + +// Describes metadata for a particular chunk, within a result set; this +// structure is used both within a manifest, and when fetching individual chunk +// data or links. +type BaseChunkInfo struct { + // The number of bytes in the result chunk. This field is not available when + // using `INLINE` disposition. + ByteCount types.Int64 `tfsdk:"byte_count" tf:"optional"` + // The position within the sequence of result set chunks. + ChunkIndex types.Int64 `tfsdk:"chunk_index" tf:"optional"` + // The number of rows within the result chunk. + RowCount types.Int64 `tfsdk:"row_count" tf:"optional"` + // The starting row offset within the result set. + RowOffset types.Int64 `tfsdk:"row_offset" tf:"optional"` +} + +// Cancel statement execution +type CancelExecutionRequest struct { + // The statement ID is returned upon successfully submitting a SQL + // statement, and is a required reference for all subsequent calls. + StatementId types.String `tfsdk:"-"` +} + +type CancelExecutionResponse struct { +} + +type Channel struct { + DbsqlVersion types.String `tfsdk:"dbsql_version" tf:"optional"` + + Name types.String `tfsdk:"name" tf:"optional"` +} + +// Channel information for the SQL warehouse at the time of query execution +type ChannelInfo struct { + // DBSQL Version the channel is mapped to + DbsqlVersion types.String `tfsdk:"dbsql_version" tf:"optional"` + // Name of the channel + Name types.String `tfsdk:"name" tf:"optional"` +} + +type ColumnInfo struct { + // The name of the column. + Name types.String `tfsdk:"name" tf:"optional"` + // The ordinal position of the column (starting at position 0). + Position types.Int64 `tfsdk:"position" tf:"optional"` + // The format of the interval type. + TypeIntervalType types.String `tfsdk:"type_interval_type" tf:"optional"` + // The name of the base data type. This doesn't include details for complex + // types such as STRUCT, MAP or ARRAY. + TypeName types.String `tfsdk:"type_name" tf:"optional"` + // Specifies the number of digits in a number. This applies to the DECIMAL + // type. + TypePrecision types.Int64 `tfsdk:"type_precision" tf:"optional"` + // Specifies the number of digits to the right of the decimal point in a + // number. This applies to the DECIMAL type. + TypeScale types.Int64 `tfsdk:"type_scale" tf:"optional"` + // The full SQL type specification. + TypeText types.String `tfsdk:"type_text" tf:"optional"` +} + +type CreateAlert struct { + // Name of the alert. + Name types.String `tfsdk:"name" tf:""` + // Alert configuration options. + Options AlertOptions `tfsdk:"options" tf:""` + // The identifier of the workspace folder containing the object. + Parent types.String `tfsdk:"parent" tf:"optional"` + // Query ID. + QueryId types.String `tfsdk:"query_id" tf:""` + // Number of seconds after being triggered before the alert rearms itself + // and can be triggered again. If `null`, alert will never be triggered + // again. + Rearm types.Int64 `tfsdk:"rearm" tf:"optional"` +} + +// Add visualization to a query +type CreateQueryVisualizationRequest struct { + // A short description of this visualization. This is not displayed in the + // UI. + Description types.String `tfsdk:"description" tf:"optional"` + // The name of the visualization that appears on dashboards and the query + // screen. + Name types.String `tfsdk:"name" tf:"optional"` + // The options object varies widely from one visualization type to the next + // and is unsupported. Databricks does not recommend modifying visualization + // settings in JSON. + Options any `tfsdk:"options" tf:""` + // The identifier returned by :method:queries/create + QueryId types.String `tfsdk:"query_id" tf:""` + // The type of visualization: chart, table, pivot table, and so on. + Type types.String `tfsdk:"type" tf:""` +} + +type CreateWarehouseRequest struct { + // The amount of time in minutes that a SQL warehouse must be idle (i.e., no + // RUNNING queries) before it is automatically stopped. + // + // Supported values: - Must be == 0 or >= 10 mins - 0 indicates no autostop. + // + // Defaults to 120 mins + AutoStopMins types.Int64 `tfsdk:"auto_stop_mins" tf:"optional"` + // Channel Details + Channel *Channel `tfsdk:"channel" tf:"optional"` + // Size of the clusters allocated for this warehouse. Increasing the size of + // a spark cluster allows you to run larger queries on it. If you want to + // increase the number of concurrent queries, please tune max_num_clusters. + // + // Supported values: - 2X-Small - X-Small - Small - Medium - Large - X-Large + // - 2X-Large - 3X-Large - 4X-Large + ClusterSize types.String `tfsdk:"cluster_size" tf:"optional"` + // warehouse creator name + CreatorName types.String `tfsdk:"creator_name" tf:"optional"` + // Configures whether the warehouse should use Photon optimized clusters. + // + // Defaults to false. + EnablePhoton types.Bool `tfsdk:"enable_photon" tf:"optional"` + // Configures whether the warehouse should use serverless compute + EnableServerlessCompute types.Bool `tfsdk:"enable_serverless_compute" tf:"optional"` + // Deprecated. Instance profile used to pass IAM role to the cluster + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // Maximum number of clusters that the autoscaler will create to handle + // concurrent queries. + // + // Supported values: - Must be >= min_num_clusters - Must be <= 30. + // + // Defaults to min_clusters if unset. + MaxNumClusters types.Int64 `tfsdk:"max_num_clusters" tf:"optional"` + // Minimum number of available clusters that will be maintained for this SQL + // warehouse. Increasing this will ensure that a larger number of clusters + // are always running and therefore may reduce the cold start time for new + // queries. This is similar to reserved vs. revocable cores in a resource + // manager. + // + // Supported values: - Must be > 0 - Must be <= min(max_num_clusters, 30) + // + // Defaults to 1 + MinNumClusters types.Int64 `tfsdk:"min_num_clusters" tf:"optional"` + // Logical name for the cluster. + // + // Supported values: - Must be unique within an org. - Must be less than 100 + // characters. + Name types.String `tfsdk:"name" tf:"optional"` + // Configurations whether the warehouse should use spot instances. + SpotInstancePolicy types.String `tfsdk:"spot_instance_policy" tf:"optional"` + // A set of key-value pairs that will be tagged on all resources (e.g., AWS + // instances and EBS volumes) associated with this SQL warehouse. + // + // Supported values: - Number of tags < 45. + Tags *EndpointTags `tfsdk:"tags" tf:"optional"` + // Warehouse type: `PRO` or `CLASSIC`. If you want to use serverless + // compute, you must set to `PRO` and also set the field + // `enable_serverless_compute` to `true`. + WarehouseType types.String `tfsdk:"warehouse_type" tf:"optional"` +} + +type CreateWarehouseResponse struct { + // Id for the SQL warehouse. This value is unique across all SQL warehouses. + Id types.String `tfsdk:"id" tf:"optional"` +} + +type CreateWidget struct { + // Dashboard ID returned by :method:dashboards/create. + DashboardId types.String `tfsdk:"dashboard_id" tf:""` + // Widget ID returned by :method:dashboardwidgets/create + Id types.String `tfsdk:"-"` + + Options WidgetOptions `tfsdk:"options" tf:""` + // If this is a textbox widget, the application displays this text. This + // field is ignored if the widget contains a visualization in the + // `visualization` field. + Text types.String `tfsdk:"text" tf:"optional"` + // Query Vizualization ID returned by :method:queryvisualizations/create. + VisualizationId types.String `tfsdk:"visualization_id" tf:"optional"` + // Width of a widget + Width types.Int64 `tfsdk:"width" tf:""` +} + +// A JSON representing a dashboard containing widgets of visualizations and text +// boxes. +type Dashboard struct { + // Whether the authenticated user can edit the query definition. + CanEdit types.Bool `tfsdk:"can_edit" tf:"optional"` + // Timestamp when this dashboard was created. + CreatedAt types.String `tfsdk:"created_at" tf:"optional"` + // In the web application, query filters that share a name are coupled to a + // single selection box if this value is `true`. + DashboardFiltersEnabled types.Bool `tfsdk:"dashboard_filters_enabled" tf:"optional"` + // The ID for this dashboard. + Id types.String `tfsdk:"id" tf:"optional"` + // Indicates whether a dashboard is trashed. Trashed dashboards won't appear + // in list views. If this boolean is `true`, the `options` property for this + // dashboard includes a `moved_to_trash_at` timestamp. Items in trash are + // permanently deleted after 30 days. + IsArchived types.Bool `tfsdk:"is_archived" tf:"optional"` + // Whether a dashboard is a draft. Draft dashboards only appear in list + // views for their owners. + IsDraft types.Bool `tfsdk:"is_draft" tf:"optional"` + // Indicates whether this query object appears in the current user's + // favorites list. This flag determines whether the star icon for favorites + // is selected. + IsFavorite types.Bool `tfsdk:"is_favorite" tf:"optional"` + // The title of the dashboard that appears in list views and at the top of + // the dashboard page. + Name types.String `tfsdk:"name" tf:"optional"` + + Options *DashboardOptions `tfsdk:"options" tf:"optional"` + // The identifier of the workspace folder containing the object. + Parent types.String `tfsdk:"parent" tf:"optional"` + // * `CAN_VIEW`: Can view the query * `CAN_RUN`: Can run the query * + // `CAN_EDIT`: Can edit the query * `CAN_MANAGE`: Can manage the query + PermissionTier types.String `tfsdk:"permission_tier" tf:"optional"` + // URL slug. Usually mirrors the query name with dashes (`-`) instead of + // spaces. Appears in the URL for this query. + Slug types.String `tfsdk:"slug" tf:"optional"` + + Tags []types.String `tfsdk:"tags" tf:"optional"` + // Timestamp when this dashboard was last updated. + UpdatedAt types.String `tfsdk:"updated_at" tf:"optional"` + + User *User `tfsdk:"user" tf:"optional"` + // The ID of the user who owns the dashboard. + UserId types.Int64 `tfsdk:"user_id" tf:"optional"` + + Widgets []Widget `tfsdk:"widgets" tf:"optional"` +} + +type DashboardEditContent struct { + DashboardId types.String `tfsdk:"-"` + // The title of this dashboard that appears in list views and at the top of + // the dashboard page. + Name types.String `tfsdk:"name" tf:"optional"` + // Sets the **Run as** role for the object. Must be set to one of `"viewer"` + // (signifying "run as viewer" behavior) or `"owner"` (signifying "run as + // owner" behavior) + RunAsRole types.String `tfsdk:"run_as_role" tf:"optional"` + + Tags []types.String `tfsdk:"tags" tf:"optional"` +} + +type DashboardOptions struct { + // The timestamp when this dashboard was moved to trash. Only present when + // the `is_archived` property is `true`. Trashed items are deleted after + // thirty days. + MovedToTrashAt types.String `tfsdk:"moved_to_trash_at" tf:"optional"` +} + +type DashboardPostContent struct { + // Indicates whether the dashboard filters are enabled + DashboardFiltersEnabled types.Bool `tfsdk:"dashboard_filters_enabled" tf:"optional"` + // Indicates whether this dashboard object should appear in the current + // user's favorites list. + IsFavorite types.Bool `tfsdk:"is_favorite" tf:"optional"` + // The title of this dashboard that appears in list views and at the top of + // the dashboard page. + Name types.String `tfsdk:"name" tf:""` + // The identifier of the workspace folder containing the object. + Parent types.String `tfsdk:"parent" tf:"optional"` + // Sets the **Run as** role for the object. Must be set to one of `"viewer"` + // (signifying "run as viewer" behavior) or `"owner"` (signifying "run as + // owner" behavior) + RunAsRole types.String `tfsdk:"run_as_role" tf:"optional"` + + Tags []types.String `tfsdk:"tags" tf:"optional"` +} + +// A JSON object representing a DBSQL data source / SQL warehouse. +type DataSource struct { + // Data source ID maps to the ID of the data source used by the resource and + // is distinct from the warehouse ID. [Learn more] + // + // [Learn more]: https://docs.databricks.com/api/workspace/datasources/list + Id types.String `tfsdk:"id" tf:"optional"` + // The string name of this data source / SQL warehouse as it appears in the + // Databricks SQL web application. + Name types.String `tfsdk:"name" tf:"optional"` + // Reserved for internal use. + PauseReason types.String `tfsdk:"pause_reason" tf:"optional"` + // Reserved for internal use. + Paused types.Int64 `tfsdk:"paused" tf:"optional"` + // Reserved for internal use. + SupportsAutoLimit types.Bool `tfsdk:"supports_auto_limit" tf:"optional"` + // Reserved for internal use. + Syntax types.String `tfsdk:"syntax" tf:"optional"` + // The type of data source. For SQL warehouses, this will be + // `databricks_internal`. + Type types.String `tfsdk:"type" tf:"optional"` + // Reserved for internal use. + ViewOnly types.Bool `tfsdk:"view_only" tf:"optional"` + // The ID of the associated SQL warehouse, if this data source is backed by + // a SQL warehouse. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +// Delete an alert +type DeleteAlertRequest struct { + AlertId types.String `tfsdk:"-"` +} + +// Remove a dashboard +type DeleteDashboardRequest struct { + DashboardId types.String `tfsdk:"-"` +} + +// Remove widget +type DeleteDashboardWidgetRequest struct { + // Widget ID returned by :method:dashboardwidgets/create + Id types.String `tfsdk:"-"` +} + +// Delete a query +type DeleteQueryRequest struct { + QueryId types.String `tfsdk:"-"` +} + +// Remove visualization +type DeleteQueryVisualizationRequest struct { + // Widget ID returned by :method:queryvizualisations/create + Id types.String `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +// Delete a warehouse +type DeleteWarehouseRequest struct { + // Required. Id of the SQL warehouse. + Id types.String `tfsdk:"-"` +} + +type DeleteWarehouseResponse struct { +} + +type EditAlert struct { + AlertId types.String `tfsdk:"-"` + // Name of the alert. + Name types.String `tfsdk:"name" tf:""` + // Alert configuration options. + Options AlertOptions `tfsdk:"options" tf:""` + // Query ID. + QueryId types.String `tfsdk:"query_id" tf:""` + // Number of seconds after being triggered before the alert rearms itself + // and can be triggered again. If `null`, alert will never be triggered + // again. + Rearm types.Int64 `tfsdk:"rearm" tf:"optional"` +} + +type EditWarehouseRequest struct { + // The amount of time in minutes that a SQL warehouse must be idle (i.e., no + // RUNNING queries) before it is automatically stopped. + // + // Supported values: - Must be == 0 or >= 10 mins - 0 indicates no autostop. + // + // Defaults to 120 mins + AutoStopMins types.Int64 `tfsdk:"auto_stop_mins" tf:"optional"` + // Channel Details + Channel *Channel `tfsdk:"channel" tf:"optional"` + // Size of the clusters allocated for this warehouse. Increasing the size of + // a spark cluster allows you to run larger queries on it. If you want to + // increase the number of concurrent queries, please tune max_num_clusters. + // + // Supported values: - 2X-Small - X-Small - Small - Medium - Large - X-Large + // - 2X-Large - 3X-Large - 4X-Large + ClusterSize types.String `tfsdk:"cluster_size" tf:"optional"` + // warehouse creator name + CreatorName types.String `tfsdk:"creator_name" tf:"optional"` + // Configures whether the warehouse should use Photon optimized clusters. + // + // Defaults to false. + EnablePhoton types.Bool `tfsdk:"enable_photon" tf:"optional"` + // Configures whether the warehouse should use serverless compute. + EnableServerlessCompute types.Bool `tfsdk:"enable_serverless_compute" tf:"optional"` + // Required. Id of the warehouse to configure. + Id types.String `tfsdk:"-"` + // Deprecated. Instance profile used to pass IAM role to the cluster + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // Maximum number of clusters that the autoscaler will create to handle + // concurrent queries. + // + // Supported values: - Must be >= min_num_clusters - Must be <= 30. + // + // Defaults to min_clusters if unset. + MaxNumClusters types.Int64 `tfsdk:"max_num_clusters" tf:"optional"` + // Minimum number of available clusters that will be maintained for this SQL + // warehouse. Increasing this will ensure that a larger number of clusters + // are always running and therefore may reduce the cold start time for new + // queries. This is similar to reserved vs. revocable cores in a resource + // manager. + // + // Supported values: - Must be > 0 - Must be <= min(max_num_clusters, 30) + // + // Defaults to 1 + MinNumClusters types.Int64 `tfsdk:"min_num_clusters" tf:"optional"` + // Logical name for the cluster. + // + // Supported values: - Must be unique within an org. - Must be less than 100 + // characters. + Name types.String `tfsdk:"name" tf:"optional"` + // Configurations whether the warehouse should use spot instances. + SpotInstancePolicy types.String `tfsdk:"spot_instance_policy" tf:"optional"` + // A set of key-value pairs that will be tagged on all resources (e.g., AWS + // instances and EBS volumes) associated with this SQL warehouse. + // + // Supported values: - Number of tags < 45. + Tags *EndpointTags `tfsdk:"tags" tf:"optional"` + // Warehouse type: `PRO` or `CLASSIC`. If you want to use serverless + // compute, you must set to `PRO` and also set the field + // `enable_serverless_compute` to `true`. + WarehouseType types.String `tfsdk:"warehouse_type" tf:"optional"` +} + +type EditWarehouseResponse struct { +} + +type EndpointConfPair struct { + Key types.String `tfsdk:"key" tf:"optional"` + + Value types.String `tfsdk:"value" tf:"optional"` +} + +type EndpointHealth struct { + // Details about errors that are causing current degraded/failed status. + Details types.String `tfsdk:"details" tf:"optional"` + // The reason for failure to bring up clusters for this warehouse. This is + // available when status is 'FAILED' and sometimes when it is DEGRADED. + FailureReason *TerminationReason `tfsdk:"failure_reason" tf:"optional"` + // Deprecated. split into summary and details for security + Message types.String `tfsdk:"message" tf:"optional"` + // Health status of the warehouse. + Status types.String `tfsdk:"status" tf:"optional"` + // A short summary of the health status in case of degraded/failed + // warehouses. + Summary types.String `tfsdk:"summary" tf:"optional"` +} + +type EndpointInfo struct { + // The amount of time in minutes that a SQL warehouse must be idle (i.e., no + // RUNNING queries) before it is automatically stopped. + // + // Supported values: - Must be == 0 or >= 10 mins - 0 indicates no autostop. + // + // Defaults to 120 mins + AutoStopMins types.Int64 `tfsdk:"auto_stop_mins" tf:"optional"` + // Channel Details + Channel *Channel `tfsdk:"channel" tf:"optional"` + // Size of the clusters allocated for this warehouse. Increasing the size of + // a spark cluster allows you to run larger queries on it. If you want to + // increase the number of concurrent queries, please tune max_num_clusters. + // + // Supported values: - 2X-Small - X-Small - Small - Medium - Large - X-Large + // - 2X-Large - 3X-Large - 4X-Large + ClusterSize types.String `tfsdk:"cluster_size" tf:"optional"` + // warehouse creator name + CreatorName types.String `tfsdk:"creator_name" tf:"optional"` + // Configures whether the warehouse should use Photon optimized clusters. + // + // Defaults to false. + EnablePhoton types.Bool `tfsdk:"enable_photon" tf:"optional"` + // Configures whether the warehouse should use serverless compute + EnableServerlessCompute types.Bool `tfsdk:"enable_serverless_compute" tf:"optional"` + // Optional health status. Assume the warehouse is healthy if this field is + // not set. + Health *EndpointHealth `tfsdk:"health" tf:"optional"` + // unique identifier for warehouse + Id types.String `tfsdk:"id" tf:"optional"` + // Deprecated. Instance profile used to pass IAM role to the cluster + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // the jdbc connection string for this warehouse + JdbcUrl types.String `tfsdk:"jdbc_url" tf:"optional"` + // Maximum number of clusters that the autoscaler will create to handle + // concurrent queries. + // + // Supported values: - Must be >= min_num_clusters - Must be <= 30. + // + // Defaults to min_clusters if unset. + MaxNumClusters types.Int64 `tfsdk:"max_num_clusters" tf:"optional"` + // Minimum number of available clusters that will be maintained for this SQL + // warehouse. Increasing this will ensure that a larger number of clusters + // are always running and therefore may reduce the cold start time for new + // queries. This is similar to reserved vs. revocable cores in a resource + // manager. + // + // Supported values: - Must be > 0 - Must be <= min(max_num_clusters, 30) + // + // Defaults to 1 + MinNumClusters types.Int64 `tfsdk:"min_num_clusters" tf:"optional"` + // Logical name for the cluster. + // + // Supported values: - Must be unique within an org. - Must be less than 100 + // characters. + Name types.String `tfsdk:"name" tf:"optional"` + // current number of active sessions for the warehouse + NumActiveSessions types.Int64 `tfsdk:"num_active_sessions" tf:"optional"` + // current number of clusters running for the service + NumClusters types.Int64 `tfsdk:"num_clusters" tf:"optional"` + // ODBC parameters for the SQL warehouse + OdbcParams *OdbcParams `tfsdk:"odbc_params" tf:"optional"` + // Configurations whether the warehouse should use spot instances. + SpotInstancePolicy types.String `tfsdk:"spot_instance_policy" tf:"optional"` + // State of the warehouse + State types.String `tfsdk:"state" tf:"optional"` + // A set of key-value pairs that will be tagged on all resources (e.g., AWS + // instances and EBS volumes) associated with this SQL warehouse. + // + // Supported values: - Number of tags < 45. + Tags *EndpointTags `tfsdk:"tags" tf:"optional"` + // Warehouse type: `PRO` or `CLASSIC`. If you want to use serverless + // compute, you must set to `PRO` and also set the field + // `enable_serverless_compute` to `true`. + WarehouseType types.String `tfsdk:"warehouse_type" tf:"optional"` +} + +type EndpointTagPair struct { + Key types.String `tfsdk:"key" tf:"optional"` + + Value types.String `tfsdk:"value" tf:"optional"` +} + +type EndpointTags struct { + CustomTags []EndpointTagPair `tfsdk:"custom_tags" tf:"optional"` +} + +type ExecuteStatementRequest struct { + // Applies the given byte limit to the statement's result size. Byte counts + // are based on internal data representations and might not match the final + // size in the requested `format`. If the result was truncated due to the + // byte limit, then `truncated` in the response is set to `true`. When using + // `EXTERNAL_LINKS` disposition, a default `byte_limit` of 100 GiB is + // applied if `byte_limit` is not explcitly set. + ByteLimit types.Int64 `tfsdk:"byte_limit" tf:"optional"` + // Sets default catalog for statement execution, similar to [`USE CATALOG`] + // in SQL. + // + // [`USE CATALOG`]: https://docs.databricks.com/sql/language-manual/sql-ref-syntax-ddl-use-catalog.html + Catalog types.String `tfsdk:"catalog" tf:"optional"` + // The fetch disposition provides two modes of fetching results: `INLINE` + // and `EXTERNAL_LINKS`. + // + // Statements executed with `INLINE` disposition will return result data + // inline, in `JSON_ARRAY` format, in a series of chunks. If a given + // statement produces a result set with a size larger than 25 MiB, that + // statement execution is aborted, and no result set will be available. + // + // **NOTE** Byte limits are computed based upon internal representations of + // the result set data, and might not match the sizes visible in JSON + // responses. + // + // Statements executed with `EXTERNAL_LINKS` disposition will return result + // data as external links: URLs that point to cloud storage internal to the + // workspace. Using `EXTERNAL_LINKS` disposition allows statements to + // generate arbitrarily sized result sets for fetching up to 100 GiB. The + // resulting links have two important properties: + // + // 1. They point to resources _external_ to the Databricks compute; + // therefore any associated authentication information (typically a personal + // access token, OAuth token, or similar) _must be removed_ when fetching + // from these links. + // + // 2. These are presigned URLs with a specific expiration, indicated in the + // response. The behavior when attempting to use an expired link is cloud + // specific. + Disposition types.String `tfsdk:"disposition" tf:"optional"` + // Statement execution supports three result formats: `JSON_ARRAY` + // (default), `ARROW_STREAM`, and `CSV`. + // + // Important: The formats `ARROW_STREAM` and `CSV` are supported only with + // `EXTERNAL_LINKS` disposition. `JSON_ARRAY` is supported in `INLINE` and + // `EXTERNAL_LINKS` disposition. + // + // When specifying `format=JSON_ARRAY`, result data will be formatted as an + // array of arrays of values, where each value is either the *string + // representation* of a value, or `null`. For example, the output of `SELECT + // concat('id-', id) AS strCol, id AS intCol, null AS nullCol FROM range(3)` + // would look like this: + // + // ``` [ [ "id-1", "1", null ], [ "id-2", "2", null ], [ "id-3", "3", null + // ], ] ``` + // + // When specifying `format=JSON_ARRAY` and `disposition=EXTERNAL_LINKS`, + // each chunk in the result contains compact JSON with no indentation or + // extra whitespace. + // + // When specifying `format=ARROW_STREAM` and `disposition=EXTERNAL_LINKS`, + // each chunk in the result will be formatted as Apache Arrow Stream. See + // the [Apache Arrow streaming format]. + // + // When specifying `format=CSV` and `disposition=EXTERNAL_LINKS`, each chunk + // in the result will be a CSV according to [RFC 4180] standard. All the + // columns values will have *string representation* similar to the + // `JSON_ARRAY` format, and `null` values will be encoded as “null”. + // Only the first chunk in the result would contain a header row with column + // names. For example, the output of `SELECT concat('id-', id) AS strCol, id + // AS intCol, null as nullCol FROM range(3)` would look like this: + // + // ``` strCol,intCol,nullCol id-1,1,null id-2,2,null id-3,3,null ``` + // + // [Apache Arrow streaming format]: https://arrow.apache.org/docs/format/Columnar.html#ipc-streaming-format + // [RFC 4180]: https://www.rfc-editor.org/rfc/rfc4180 + Format types.String `tfsdk:"format" tf:"optional"` + // When `wait_timeout > 0s`, the call will block up to the specified time. + // If the statement execution doesn't finish within this time, + // `on_wait_timeout` determines whether the execution should continue or be + // canceled. When set to `CONTINUE`, the statement execution continues + // asynchronously and the call returns a statement ID which can be used for + // polling with :method:statementexecution/getStatement. When set to + // `CANCEL`, the statement execution is canceled and the call returns with a + // `CANCELED` state. + OnWaitTimeout types.String `tfsdk:"on_wait_timeout" tf:"optional"` + // A list of parameters to pass into a SQL statement containing parameter + // markers. A parameter consists of a name, a value, and optionally a type. + // To represent a NULL value, the `value` field may be omitted or set to + // `null` explicitly. If the `type` field is omitted, the value is + // interpreted as a string. + // + // If the type is given, parameters will be checked for type correctness + // according to the given type. A value is correct if the provided string + // can be converted to the requested type using the `cast` function. The + // exact semantics are described in the section [`cast` function] of the SQL + // language reference. + // + // For example, the following statement contains two parameters, `my_name` + // and `my_date`: + // + // SELECT * FROM my_table WHERE name = :my_name AND date = :my_date + // + // The parameters can be passed in the request body as follows: + // + // { ..., "statement": "SELECT * FROM my_table WHERE name = :my_name AND + // date = :my_date", "parameters": [ { "name": "my_name", "value": "the + // name" }, { "name": "my_date", "value": "2020-01-01", "type": "DATE" } ] } + // + // Currently, positional parameters denoted by a `?` marker are not + // supported by the Databricks SQL Statement Execution API. + // + // Also see the section [Parameter markers] of the SQL language reference. + // + // [Parameter markers]: https://docs.databricks.com/sql/language-manual/sql-ref-parameter-marker.html + // [`cast` function]: https://docs.databricks.com/sql/language-manual/functions/cast.html + Parameters []StatementParameterListItem `tfsdk:"parameters" tf:"optional"` + // Applies the given row limit to the statement's result set, but unlike the + // `LIMIT` clause in SQL, it also sets the `truncated` field in the response + // to indicate whether the result was trimmed due to the limit or not. + RowLimit types.Int64 `tfsdk:"row_limit" tf:"optional"` + // Sets default schema for statement execution, similar to [`USE SCHEMA`] in + // SQL. + // + // [`USE SCHEMA`]: https://docs.databricks.com/sql/language-manual/sql-ref-syntax-ddl-use-schema.html + Schema types.String `tfsdk:"schema" tf:"optional"` + // The SQL statement to execute. The statement can optionally be + // parameterized, see `parameters`. + Statement types.String `tfsdk:"statement" tf:""` + // The time in seconds the call will wait for the statement's result set as + // `Ns`, where `N` can be set to 0 or to a value between 5 and 50. + // + // When set to `0s`, the statement will execute in asynchronous mode and the + // call will not wait for the execution to finish. In this case, the call + // returns directly with `PENDING` state and a statement ID which can be + // used for polling with :method:statementexecution/getStatement. + // + // When set between 5 and 50 seconds, the call will behave synchronously up + // to this timeout and wait for the statement execution to finish. If the + // execution finishes within this time, the call returns immediately with a + // manifest and result data (or a `FAILED` state in case of an execution + // error). If the statement takes longer to execute, `on_wait_timeout` + // determines what should happen after the timeout is reached. + WaitTimeout types.String `tfsdk:"wait_timeout" tf:"optional"` + // Warehouse upon which to execute a statement. See also [What are SQL + // warehouses?] + // + // [What are SQL warehouses?]: https://docs.databricks.com/sql/admin/warehouse-type.html + WarehouseId types.String `tfsdk:"warehouse_id" tf:""` +} + +type ExecuteStatementResponse struct { + // The result manifest provides schema and metadata for the result set. + Manifest *ResultManifest `tfsdk:"manifest" tf:"optional"` + // Contains the result data of a single chunk when using `INLINE` + // disposition. When using `EXTERNAL_LINKS` disposition, the array + // `external_links` is used instead to provide presigned URLs to the result + // data in cloud storage. Exactly one of these alternatives is used. (While + // the `external_links` array prepares the API to return multiple links in a + // single response. Currently only a single link is returned.) + Result *ResultData `tfsdk:"result" tf:"optional"` + // The statement ID is returned upon successfully submitting a SQL + // statement, and is a required reference for all subsequent calls. + StatementId types.String `tfsdk:"statement_id" tf:"optional"` + // The status response includes execution state and if relevant, error + // information. + Status *StatementStatus `tfsdk:"status" tf:"optional"` +} + +type ExternalLink struct { + // The number of bytes in the result chunk. This field is not available when + // using `INLINE` disposition. + ByteCount types.Int64 `tfsdk:"byte_count" tf:"optional"` + // The position within the sequence of result set chunks. + ChunkIndex types.Int64 `tfsdk:"chunk_index" tf:"optional"` + // Indicates the date-time that the given external link will expire and + // becomes invalid, after which point a new `external_link` must be + // requested. + Expiration types.String `tfsdk:"expiration" tf:"optional"` + // A presigned URL pointing to a chunk of result data, hosted by an external + // service, with a short expiration time (<= 15 minutes). As this URL + // contains a temporary credential, it should be considered sensitive and + // the client should not expose this URL in a log. + ExternalLink types.String `tfsdk:"external_link" tf:"optional"` + // HTTP headers that must be included with a GET request to the + // `external_link`. Each header is provided as a key-value pair. Headers are + // typically used to pass a decryption key to the external service. The + // values of these headers should be considered sensitive and the client + // should not expose these values in a log. + HttpHeaders map[string]types.String `tfsdk:"http_headers" tf:"optional"` + // When fetching, provides the `chunk_index` for the _next_ chunk. If + // absent, indicates there are no more chunks. The next chunk can be fetched + // with a :method:statementexecution/getStatementResultChunkN request. + NextChunkIndex types.Int64 `tfsdk:"next_chunk_index" tf:"optional"` + // When fetching, provides a link to fetch the _next_ chunk. If absent, + // indicates there are no more chunks. This link is an absolute `path` to be + // joined with your `$DATABRICKS_HOST`, and should be treated as an opaque + // link. This is an alternative to using `next_chunk_index`. + NextChunkInternalLink types.String `tfsdk:"next_chunk_internal_link" tf:"optional"` + // The number of rows within the result chunk. + RowCount types.Int64 `tfsdk:"row_count" tf:"optional"` + // The starting row offset within the result set. + RowOffset types.Int64 `tfsdk:"row_offset" tf:"optional"` +} + +// Get an alert +type GetAlertRequest struct { + AlertId types.String `tfsdk:"-"` +} + +// Retrieve a definition +type GetDashboardRequest struct { + DashboardId types.String `tfsdk:"-"` +} + +// Get object ACL +type GetDbsqlPermissionRequest struct { + // Object ID. An ACL is returned for the object with this UUID. + ObjectId types.String `tfsdk:"-"` + // The type of object permissions to check. + ObjectType types.String `tfsdk:"-"` +} + +// Get a query definition. +type GetQueryRequest struct { + QueryId types.String `tfsdk:"-"` +} + +type GetResponse struct { + AccessControlList []AccessControl `tfsdk:"access_control_list" tf:"optional"` + // An object's type and UUID, separated by a forward slash (/) character. + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + // A singular noun object type. + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +// Get status, manifest, and result first chunk +type GetStatementRequest struct { + // The statement ID is returned upon successfully submitting a SQL + // statement, and is a required reference for all subsequent calls. + StatementId types.String `tfsdk:"-"` +} + +type GetStatementResponse struct { + // The result manifest provides schema and metadata for the result set. + Manifest *ResultManifest `tfsdk:"manifest" tf:"optional"` + // Contains the result data of a single chunk when using `INLINE` + // disposition. When using `EXTERNAL_LINKS` disposition, the array + // `external_links` is used instead to provide presigned URLs to the result + // data in cloud storage. Exactly one of these alternatives is used. (While + // the `external_links` array prepares the API to return multiple links in a + // single response. Currently only a single link is returned.) + Result *ResultData `tfsdk:"result" tf:"optional"` + // The statement ID is returned upon successfully submitting a SQL + // statement, and is a required reference for all subsequent calls. + StatementId types.String `tfsdk:"statement_id" tf:"optional"` + // The status response includes execution state and if relevant, error + // information. + Status *StatementStatus `tfsdk:"status" tf:"optional"` +} + +// Get result chunk by index +type GetStatementResultChunkNRequest struct { + ChunkIndex types.Int64 `tfsdk:"-"` + // The statement ID is returned upon successfully submitting a SQL + // statement, and is a required reference for all subsequent calls. + StatementId types.String `tfsdk:"-"` +} + +// Get SQL warehouse permission levels +type GetWarehousePermissionLevelsRequest struct { + // The SQL warehouse for which to get or manage permissions. + WarehouseId types.String `tfsdk:"-"` +} + +type GetWarehousePermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []WarehousePermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get SQL warehouse permissions +type GetWarehousePermissionsRequest struct { + // The SQL warehouse for which to get or manage permissions. + WarehouseId types.String `tfsdk:"-"` +} + +// Get warehouse info +type GetWarehouseRequest struct { + // Required. Id of the SQL warehouse. + Id types.String `tfsdk:"-"` +} + +type GetWarehouseResponse struct { + // The amount of time in minutes that a SQL warehouse must be idle (i.e., no + // RUNNING queries) before it is automatically stopped. + // + // Supported values: - Must be == 0 or >= 10 mins - 0 indicates no autostop. + // + // Defaults to 120 mins + AutoStopMins types.Int64 `tfsdk:"auto_stop_mins" tf:"optional"` + // Channel Details + Channel *Channel `tfsdk:"channel" tf:"optional"` + // Size of the clusters allocated for this warehouse. Increasing the size of + // a spark cluster allows you to run larger queries on it. If you want to + // increase the number of concurrent queries, please tune max_num_clusters. + // + // Supported values: - 2X-Small - X-Small - Small - Medium - Large - X-Large + // - 2X-Large - 3X-Large - 4X-Large + ClusterSize types.String `tfsdk:"cluster_size" tf:"optional"` + // warehouse creator name + CreatorName types.String `tfsdk:"creator_name" tf:"optional"` + // Configures whether the warehouse should use Photon optimized clusters. + // + // Defaults to false. + EnablePhoton types.Bool `tfsdk:"enable_photon" tf:"optional"` + // Configures whether the warehouse should use serverless compute + EnableServerlessCompute types.Bool `tfsdk:"enable_serverless_compute" tf:"optional"` + // Optional health status. Assume the warehouse is healthy if this field is + // not set. + Health *EndpointHealth `tfsdk:"health" tf:"optional"` + // unique identifier for warehouse + Id types.String `tfsdk:"id" tf:"optional"` + // Deprecated. Instance profile used to pass IAM role to the cluster + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // the jdbc connection string for this warehouse + JdbcUrl types.String `tfsdk:"jdbc_url" tf:"optional"` + // Maximum number of clusters that the autoscaler will create to handle + // concurrent queries. + // + // Supported values: - Must be >= min_num_clusters - Must be <= 30. + // + // Defaults to min_clusters if unset. + MaxNumClusters types.Int64 `tfsdk:"max_num_clusters" tf:"optional"` + // Minimum number of available clusters that will be maintained for this SQL + // warehouse. Increasing this will ensure that a larger number of clusters + // are always running and therefore may reduce the cold start time for new + // queries. This is similar to reserved vs. revocable cores in a resource + // manager. + // + // Supported values: - Must be > 0 - Must be <= min(max_num_clusters, 30) + // + // Defaults to 1 + MinNumClusters types.Int64 `tfsdk:"min_num_clusters" tf:"optional"` + // Logical name for the cluster. + // + // Supported values: - Must be unique within an org. - Must be less than 100 + // characters. + Name types.String `tfsdk:"name" tf:"optional"` + // current number of active sessions for the warehouse + NumActiveSessions types.Int64 `tfsdk:"num_active_sessions" tf:"optional"` + // current number of clusters running for the service + NumClusters types.Int64 `tfsdk:"num_clusters" tf:"optional"` + // ODBC parameters for the SQL warehouse + OdbcParams *OdbcParams `tfsdk:"odbc_params" tf:"optional"` + // Configurations whether the warehouse should use spot instances. + SpotInstancePolicy types.String `tfsdk:"spot_instance_policy" tf:"optional"` + // State of the warehouse + State types.String `tfsdk:"state" tf:"optional"` + // A set of key-value pairs that will be tagged on all resources (e.g., AWS + // instances and EBS volumes) associated with this SQL warehouse. + // + // Supported values: - Number of tags < 45. + Tags *EndpointTags `tfsdk:"tags" tf:"optional"` + // Warehouse type: `PRO` or `CLASSIC`. If you want to use serverless + // compute, you must set to `PRO` and also set the field + // `enable_serverless_compute` to `true`. + WarehouseType types.String `tfsdk:"warehouse_type" tf:"optional"` +} + +type GetWorkspaceWarehouseConfigResponse struct { + // Optional: Channel selection details + Channel *Channel `tfsdk:"channel" tf:"optional"` + // Deprecated: Use sql_configuration_parameters + ConfigParam *RepeatedEndpointConfPairs `tfsdk:"config_param" tf:"optional"` + // Spark confs for external hive metastore configuration JSON serialized + // size must be less than <= 512K + DataAccessConfig []EndpointConfPair `tfsdk:"data_access_config" tf:"optional"` + // List of Warehouse Types allowed in this workspace (limits allowed value + // of the type field in CreateWarehouse and EditWarehouse). Note: Some types + // cannot be disabled, they don't need to be specified in + // SetWorkspaceWarehouseConfig. Note: Disabling a type may cause existing + // warehouses to be converted to another type. Used by frontend to save + // specific type availability in the warehouse create and edit form UI. + EnabledWarehouseTypes []WarehouseTypePair `tfsdk:"enabled_warehouse_types" tf:"optional"` + // Deprecated: Use sql_configuration_parameters + GlobalParam *RepeatedEndpointConfPairs `tfsdk:"global_param" tf:"optional"` + // GCP only: Google Service Account used to pass to cluster to access Google + // Cloud Storage + GoogleServiceAccount types.String `tfsdk:"google_service_account" tf:"optional"` + // AWS Only: Instance profile used to pass IAM role to the cluster + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // Security policy for warehouses + SecurityPolicy types.String `tfsdk:"security_policy" tf:"optional"` + // SQL configuration parameters + SqlConfigurationParameters *RepeatedEndpointConfPairs `tfsdk:"sql_configuration_parameters" tf:"optional"` +} + +// Get dashboard objects +type ListDashboardsRequest struct { + // Name of dashboard attribute to order by. + Order types.String `tfsdk:"-"` + // Page number to retrieve. + Page types.Int64 `tfsdk:"-"` + // Number of dashboards to return per page. + PageSize types.Int64 `tfsdk:"-"` + // Full text search term. + Q types.String `tfsdk:"-"` +} + +// Get a list of queries +type ListQueriesRequest struct { + // Name of query attribute to order by. Default sort order is ascending. + // Append a dash (`-`) to order descending instead. + // + // - `name`: The name of the query. + // + // - `created_at`: The timestamp the query was created. + // + // - `runtime`: The time it took to run this query. This is blank for + // parameterized queries. A blank value is treated as the highest value for + // sorting. + // + // - `executed_at`: The timestamp when the query was last run. + // + // - `created_by`: The user name of the user that created the query. + Order types.String `tfsdk:"-"` + // Page number to retrieve. + Page types.Int64 `tfsdk:"-"` + // Number of queries to return per page. + PageSize types.Int64 `tfsdk:"-"` + // Full text search term + Q types.String `tfsdk:"-"` +} + +type ListQueriesResponse struct { + // Whether there is another page of results. + HasNextPage types.Bool `tfsdk:"has_next_page" tf:"optional"` + // A token that can be used to get the next page of results. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + Res []QueryInfo `tfsdk:"res" tf:"optional"` +} + +// List Queries +type ListQueryHistoryRequest struct { + // A filter to limit query history results. This field is optional. + FilterBy *QueryFilter `tfsdk:"-"` + // Whether to include metrics about query. + IncludeMetrics types.Bool `tfsdk:"-"` + // Limit the number of results returned in one page. The default is 100. + MaxResults types.Int64 `tfsdk:"-"` + // A token that can be used to get the next page of results. The token can + // contains characters that need to be encoded before using it in a URL. For + // example, the character '+' needs to be replaced by %2B. + PageToken types.String `tfsdk:"-"` +} + +type ListResponse struct { + // The total number of dashboards. + Count types.Int64 `tfsdk:"count" tf:"optional"` + // The current page being displayed. + Page types.Int64 `tfsdk:"page" tf:"optional"` + // The number of dashboards per page. + PageSize types.Int64 `tfsdk:"page_size" tf:"optional"` + // List of dashboards returned. + Results []Dashboard `tfsdk:"results" tf:"optional"` +} + +// List warehouses +type ListWarehousesRequest struct { + // Service Principal which will be used to fetch the list of warehouses. If + // not specified, the user from the session header is used. + RunAsUserId types.Int64 `tfsdk:"-"` +} + +type ListWarehousesResponse struct { + // A list of warehouses and their configurations. + Warehouses []EndpointInfo `tfsdk:"warehouses" tf:"optional"` +} + +// If specified, allows multiple values to be selected for this parameter. Only +// applies to dropdown list and query-based dropdown list parameters. +type MultiValuesOptions struct { + // Character that prefixes each selected parameter value. + Prefix types.String `tfsdk:"prefix" tf:"optional"` + // Character that separates each selected parameter value. Defaults to a + // comma. + Separator types.String `tfsdk:"separator" tf:"optional"` + // Character that suffixes each selected parameter value. + Suffix types.String `tfsdk:"suffix" tf:"optional"` +} + +type OdbcParams struct { + Hostname types.String `tfsdk:"hostname" tf:"optional"` + + Path types.String `tfsdk:"path" tf:"optional"` + + Port types.Int64 `tfsdk:"port" tf:"optional"` + + Protocol types.String `tfsdk:"protocol" tf:"optional"` +} + +type Parameter struct { + // List of valid parameter values, newline delimited. Only applies for + // dropdown list parameters. + EnumOptions types.String `tfsdk:"enumOptions" tf:"optional"` + // If specified, allows multiple values to be selected for this parameter. + // Only applies to dropdown list and query-based dropdown list parameters. + MultiValuesOptions *MultiValuesOptions `tfsdk:"multiValuesOptions" tf:"optional"` + // The literal parameter marker that appears between double curly braces in + // the query text. + Name types.String `tfsdk:"name" tf:"optional"` + // The UUID of the query that provides the parameter values. Only applies + // for query-based dropdown list parameters. + QueryId types.String `tfsdk:"queryId" tf:"optional"` + // The text displayed in a parameter picking widget. + Title types.String `tfsdk:"title" tf:"optional"` + // Parameters can have several different types. + Type types.String `tfsdk:"type" tf:"optional"` + // The default value for this parameter. + Value any `tfsdk:"value" tf:"optional"` +} + +type Query struct { + // Describes whether the authenticated user is allowed to edit the + // definition of this query. + CanEdit types.Bool `tfsdk:"can_edit" tf:"optional"` + // The timestamp when this query was created. + CreatedAt types.String `tfsdk:"created_at" tf:"optional"` + // Data source ID maps to the ID of the data source used by the resource and + // is distinct from the warehouse ID. [Learn more] + // + // [Learn more]: https://docs.databricks.com/api/workspace/datasources/list + DataSourceId types.String `tfsdk:"data_source_id" tf:"optional"` + // General description that conveys additional information about this query + // such as usage notes. + Description types.String `tfsdk:"description" tf:"optional"` + // Query ID. + Id types.String `tfsdk:"id" tf:"optional"` + // Indicates whether the query is trashed. Trashed queries can't be used in + // dashboards, or appear in search results. If this boolean is `true`, the + // `options` property for this query includes a `moved_to_trash_at` + // timestamp. Trashed queries are permanently deleted after 30 days. + IsArchived types.Bool `tfsdk:"is_archived" tf:"optional"` + // Whether the query is a draft. Draft queries only appear in list views for + // their owners. Visualizations from draft queries cannot appear on + // dashboards. + IsDraft types.Bool `tfsdk:"is_draft" tf:"optional"` + // Whether this query object appears in the current user's favorites list. + // This flag determines whether the star icon for favorites is selected. + IsFavorite types.Bool `tfsdk:"is_favorite" tf:"optional"` + // Text parameter types are not safe from SQL injection for all types of + // data source. Set this Boolean parameter to `true` if a query either does + // not use any text type parameters or uses a data source type where text + // type parameters are handled safely. + IsSafe types.Bool `tfsdk:"is_safe" tf:"optional"` + + LastModifiedBy *User `tfsdk:"last_modified_by" tf:"optional"` + // The ID of the user who last saved changes to this query. + LastModifiedById types.Int64 `tfsdk:"last_modified_by_id" tf:"optional"` + // If there is a cached result for this query and user, this field includes + // the query result ID. If this query uses parameters, this field is always + // null. + LatestQueryDataId types.String `tfsdk:"latest_query_data_id" tf:"optional"` + // The title of this query that appears in list views, widget headings, and + // on the query page. + Name types.String `tfsdk:"name" tf:"optional"` + + Options *QueryOptions `tfsdk:"options" tf:"optional"` + // The identifier of the workspace folder containing the object. + Parent types.String `tfsdk:"parent" tf:"optional"` + // * `CAN_VIEW`: Can view the query * `CAN_RUN`: Can run the query * + // `CAN_EDIT`: Can edit the query * `CAN_MANAGE`: Can manage the query + PermissionTier types.String `tfsdk:"permission_tier" tf:"optional"` + // The text of the query to be run. + Query types.String `tfsdk:"query" tf:"optional"` + // A SHA-256 hash of the query text along with the authenticated user ID. + QueryHash types.String `tfsdk:"query_hash" tf:"optional"` + // Sets the **Run as** role for the object. Must be set to one of `"viewer"` + // (signifying "run as viewer" behavior) or `"owner"` (signifying "run as + // owner" behavior) + RunAsRole types.String `tfsdk:"run_as_role" tf:"optional"` + + Tags []types.String `tfsdk:"tags" tf:"optional"` + // The timestamp at which this query was last updated. + UpdatedAt types.String `tfsdk:"updated_at" tf:"optional"` + + User *User `tfsdk:"user" tf:"optional"` + // The ID of the user who owns the query. + UserId types.Int64 `tfsdk:"user_id" tf:"optional"` + + Visualizations []Visualization `tfsdk:"visualizations" tf:"optional"` +} + +type QueryEditContent struct { + // Data source ID maps to the ID of the data source used by the resource and + // is distinct from the warehouse ID. [Learn more] + // + // [Learn more]: https://docs.databricks.com/api/workspace/datasources/list + DataSourceId types.String `tfsdk:"data_source_id" tf:"optional"` + // General description that conveys additional information about this query + // such as usage notes. + Description types.String `tfsdk:"description" tf:"optional"` + // The title of this query that appears in list views, widget headings, and + // on the query page. + Name types.String `tfsdk:"name" tf:"optional"` + // Exclusively used for storing a list parameter definitions. A parameter is + // an object with `title`, `name`, `type`, and `value` properties. The + // `value` field here is the default value. It can be overridden at runtime. + Options any `tfsdk:"options" tf:"optional"` + // The text of the query to be run. + Query types.String `tfsdk:"query" tf:"optional"` + + QueryId types.String `tfsdk:"-"` + // Sets the **Run as** role for the object. Must be set to one of `"viewer"` + // (signifying "run as viewer" behavior) or `"owner"` (signifying "run as + // owner" behavior) + RunAsRole types.String `tfsdk:"run_as_role" tf:"optional"` + + Tags []types.String `tfsdk:"tags" tf:"optional"` +} + +// A filter to limit query history results. This field is optional. +type QueryFilter struct { + QueryStartTimeRange *TimeRange `tfsdk:"query_start_time_range" tf:"optional"` + // A list of statement IDs. + StatementIds []types.String `tfsdk:"statement_ids" tf:"optional"` + + Statuses []types.String `tfsdk:"statuses" tf:"optional"` + // A list of user IDs who ran the queries. + UserIds []types.Int64 `tfsdk:"user_ids" tf:"optional"` + // A list of warehouse IDs. + WarehouseIds []types.String `tfsdk:"warehouse_ids" tf:"optional"` +} + +type QueryInfo struct { + // Reserved for internal use. + CanSubscribeToLiveQuery types.Bool `tfsdk:"canSubscribeToLiveQuery" tf:"optional"` + // Channel information for the SQL warehouse at the time of query execution + ChannelUsed *ChannelInfo `tfsdk:"channel_used" tf:"optional"` + // Total execution time of the statement ( excluding result fetch time ). + Duration types.Int64 `tfsdk:"duration" tf:"optional"` + // Alias for `warehouse_id`. + EndpointId types.String `tfsdk:"endpoint_id" tf:"optional"` + // Message describing why the query could not complete. + ErrorMessage types.String `tfsdk:"error_message" tf:"optional"` + // The ID of the user whose credentials were used to run the query. + ExecutedAsUserId types.Int64 `tfsdk:"executed_as_user_id" tf:"optional"` + // The email address or username of the user whose credentials were used to + // run the query. + ExecutedAsUserName types.String `tfsdk:"executed_as_user_name" tf:"optional"` + // The time execution of the query ended. + ExecutionEndTimeMs types.Int64 `tfsdk:"execution_end_time_ms" tf:"optional"` + // Whether more updates for the query are expected. + IsFinal types.Bool `tfsdk:"is_final" tf:"optional"` + // A key that can be used to look up query details. + LookupKey types.String `tfsdk:"lookup_key" tf:"optional"` + // Metrics about query execution. + Metrics *QueryMetrics `tfsdk:"metrics" tf:"optional"` + // Whether plans exist for the execution, or the reason why they are missing + PlansState types.String `tfsdk:"plans_state" tf:"optional"` + // The time the query ended. + QueryEndTimeMs types.Int64 `tfsdk:"query_end_time_ms" tf:"optional"` + // The query ID. + QueryId types.String `tfsdk:"query_id" tf:"optional"` + // The time the query started. + QueryStartTimeMs types.Int64 `tfsdk:"query_start_time_ms" tf:"optional"` + // The text of the query. + QueryText types.String `tfsdk:"query_text" tf:"optional"` + // The number of results returned by the query. + RowsProduced types.Int64 `tfsdk:"rows_produced" tf:"optional"` + // URL to the query plan. + SparkUiUrl types.String `tfsdk:"spark_ui_url" tf:"optional"` + // Type of statement for this query + StatementType types.String `tfsdk:"statement_type" tf:"optional"` + // Query status with one the following values: * `QUEUED`: Query has been + // received and queued. * `RUNNING`: Query has started. * `CANCELED`: Query + // has been cancelled by the user. * `FAILED`: Query has failed. * + // `FINISHED`: Query has completed. + Status types.String `tfsdk:"status" tf:"optional"` + // The ID of the user who ran the query. + UserId types.Int64 `tfsdk:"user_id" tf:"optional"` + // The email address or username of the user who ran the query. + UserName types.String `tfsdk:"user_name" tf:"optional"` + // Warehouse ID. + WarehouseId types.String `tfsdk:"warehouse_id" tf:"optional"` +} + +type QueryList struct { + // The total number of queries. + Count types.Int64 `tfsdk:"count" tf:"optional"` + // The page number that is currently displayed. + Page types.Int64 `tfsdk:"page" tf:"optional"` + // The number of queries per page. + PageSize types.Int64 `tfsdk:"page_size" tf:"optional"` + // List of queries returned. + Results []Query `tfsdk:"results" tf:"optional"` +} + +// Metrics about query execution. +type QueryMetrics struct { + // Time spent loading metadata and optimizing the query, in milliseconds. + CompilationTimeMs types.Int64 `tfsdk:"compilation_time_ms" tf:"optional"` + // Time spent executing the query, in milliseconds. + ExecutionTimeMs types.Int64 `tfsdk:"execution_time_ms" tf:"optional"` + // Reserved for internal use. + MetadataTimeMs types.Int64 `tfsdk:"metadata_time_ms" tf:"optional"` + // Total amount of data sent over the network between executor nodes during + // shuffle, in bytes. + NetworkSentBytes types.Int64 `tfsdk:"network_sent_bytes" tf:"optional"` + // Timestamp of when the query was enqueued waiting while the warehouse was + // at max load. This field is optional and will not appear if the query + // skipped the overloading queue. + OverloadingQueueStartTimestamp types.Int64 `tfsdk:"overloading_queue_start_timestamp" tf:"optional"` + // Total execution time for all individual Photon query engine tasks in the + // query, in milliseconds. + PhotonTotalTimeMs types.Int64 `tfsdk:"photon_total_time_ms" tf:"optional"` + // Reserved for internal use. + PlanningTimeMs types.Int64 `tfsdk:"planning_time_ms" tf:"optional"` + // Timestamp of when the query was enqueued waiting for a cluster to be + // provisioned for the warehouse. This field is optional and will not appear + // if the query skipped the provisioning queue. + ProvisioningQueueStartTimestamp types.Int64 `tfsdk:"provisioning_queue_start_timestamp" tf:"optional"` + // Total number of bytes in all tables not read due to pruning + PrunedBytes types.Int64 `tfsdk:"pruned_bytes" tf:"optional"` + // Total number of files from all tables not read due to pruning + PrunedFilesCount types.Int64 `tfsdk:"pruned_files_count" tf:"optional"` + // Timestamp of when the underlying compute started compilation of the + // query. + QueryCompilationStartTimestamp types.Int64 `tfsdk:"query_compilation_start_timestamp" tf:"optional"` + // Reserved for internal use. + QueryExecutionTimeMs types.Int64 `tfsdk:"query_execution_time_ms" tf:"optional"` + // Total size of data read by the query, in bytes. + ReadBytes types.Int64 `tfsdk:"read_bytes" tf:"optional"` + // Size of persistent data read from the cache, in bytes. + ReadCacheBytes types.Int64 `tfsdk:"read_cache_bytes" tf:"optional"` + // Number of files read after pruning. + ReadFilesCount types.Int64 `tfsdk:"read_files_count" tf:"optional"` + // Number of partitions read after pruning. + ReadPartitionsCount types.Int64 `tfsdk:"read_partitions_count" tf:"optional"` + // Size of persistent data read from cloud object storage on your cloud + // tenant, in bytes. + ReadRemoteBytes types.Int64 `tfsdk:"read_remote_bytes" tf:"optional"` + // Time spent fetching the query results after the execution finished, in + // milliseconds. + ResultFetchTimeMs types.Int64 `tfsdk:"result_fetch_time_ms" tf:"optional"` + // true if the query result was fetched from cache, false otherwise. + ResultFromCache types.Bool `tfsdk:"result_from_cache" tf:"optional"` + // Total number of rows returned by the query. + RowsProducedCount types.Int64 `tfsdk:"rows_produced_count" tf:"optional"` + // Total number of rows read by the query. + RowsReadCount types.Int64 `tfsdk:"rows_read_count" tf:"optional"` + // Size of data temporarily written to disk while executing the query, in + // bytes. + SpillToDiskBytes types.Int64 `tfsdk:"spill_to_disk_bytes" tf:"optional"` + // Sum of execution time for all of the query’s tasks, in milliseconds. + TaskTotalTimeMs types.Int64 `tfsdk:"task_total_time_ms" tf:"optional"` + // Total execution time of the query from the client’s point of view, in + // milliseconds. + TotalTimeMs types.Int64 `tfsdk:"total_time_ms" tf:"optional"` + // Size pf persistent data written to cloud object storage in your cloud + // tenant, in bytes. + WriteRemoteBytes types.Int64 `tfsdk:"write_remote_bytes" tf:"optional"` +} + +type QueryOptions struct { + // The name of the catalog to execute this query in. + Catalog types.String `tfsdk:"catalog" tf:"optional"` + // The timestamp when this query was moved to trash. Only present when the + // `is_archived` property is `true`. Trashed items are deleted after thirty + // days. + MovedToTrashAt types.String `tfsdk:"moved_to_trash_at" tf:"optional"` + + Parameters []Parameter `tfsdk:"parameters" tf:"optional"` + // The name of the schema to execute this query in. + Schema types.String `tfsdk:"schema" tf:"optional"` +} + +type QueryPostContent struct { + // Data source ID maps to the ID of the data source used by the resource and + // is distinct from the warehouse ID. [Learn more] + // + // [Learn more]: https://docs.databricks.com/api/workspace/datasources/list + DataSourceId types.String `tfsdk:"data_source_id" tf:"optional"` + // General description that conveys additional information about this query + // such as usage notes. + Description types.String `tfsdk:"description" tf:"optional"` + // The title of this query that appears in list views, widget headings, and + // on the query page. + Name types.String `tfsdk:"name" tf:"optional"` + // Exclusively used for storing a list parameter definitions. A parameter is + // an object with `title`, `name`, `type`, and `value` properties. The + // `value` field here is the default value. It can be overridden at runtime. + Options any `tfsdk:"options" tf:"optional"` + // The identifier of the workspace folder containing the object. + Parent types.String `tfsdk:"parent" tf:"optional"` + // The text of the query to be run. + Query types.String `tfsdk:"query" tf:"optional"` + // Sets the **Run as** role for the object. Must be set to one of `"viewer"` + // (signifying "run as viewer" behavior) or `"owner"` (signifying "run as + // owner" behavior) + RunAsRole types.String `tfsdk:"run_as_role" tf:"optional"` + + Tags []types.String `tfsdk:"tags" tf:"optional"` +} + +type RepeatedEndpointConfPairs struct { + // Deprecated: Use configuration_pairs + ConfigPair []EndpointConfPair `tfsdk:"config_pair" tf:"optional"` + + ConfigurationPairs []EndpointConfPair `tfsdk:"configuration_pairs" tf:"optional"` +} + +// Restore a dashboard +type RestoreDashboardRequest struct { + DashboardId types.String `tfsdk:"-"` +} + +// Restore a query +type RestoreQueryRequest struct { + QueryId types.String `tfsdk:"-"` +} + +type RestoreResponse struct { +} + +// Contains the result data of a single chunk when using `INLINE` disposition. +// When using `EXTERNAL_LINKS` disposition, the array `external_links` is used +// instead to provide presigned URLs to the result data in cloud storage. +// Exactly one of these alternatives is used. (While the `external_links` array +// prepares the API to return multiple links in a single response. Currently +// only a single link is returned.) +type ResultData struct { + // The number of bytes in the result chunk. This field is not available when + // using `INLINE` disposition. + ByteCount types.Int64 `tfsdk:"byte_count" tf:"optional"` + // The position within the sequence of result set chunks. + ChunkIndex types.Int64 `tfsdk:"chunk_index" tf:"optional"` + // The `JSON_ARRAY` format is an array of arrays of values, where each + // non-null value is formatted as a string. Null values are encoded as JSON + // `null`. + DataArray [][]types.String `tfsdk:"data_array" tf:"optional"` + + ExternalLinks []ExternalLink `tfsdk:"external_links" tf:"optional"` + // When fetching, provides the `chunk_index` for the _next_ chunk. If + // absent, indicates there are no more chunks. The next chunk can be fetched + // with a :method:statementexecution/getStatementResultChunkN request. + NextChunkIndex types.Int64 `tfsdk:"next_chunk_index" tf:"optional"` + // When fetching, provides a link to fetch the _next_ chunk. If absent, + // indicates there are no more chunks. This link is an absolute `path` to be + // joined with your `$DATABRICKS_HOST`, and should be treated as an opaque + // link. This is an alternative to using `next_chunk_index`. + NextChunkInternalLink types.String `tfsdk:"next_chunk_internal_link" tf:"optional"` + // The number of rows within the result chunk. + RowCount types.Int64 `tfsdk:"row_count" tf:"optional"` + // The starting row offset within the result set. + RowOffset types.Int64 `tfsdk:"row_offset" tf:"optional"` +} + +// The result manifest provides schema and metadata for the result set. +type ResultManifest struct { + // Array of result set chunk metadata. + Chunks []BaseChunkInfo `tfsdk:"chunks" tf:"optional"` + + Format types.String `tfsdk:"format" tf:"optional"` + // The schema is an ordered list of column descriptions. + Schema *ResultSchema `tfsdk:"schema" tf:"optional"` + // The total number of bytes in the result set. This field is not available + // when using `INLINE` disposition. + TotalByteCount types.Int64 `tfsdk:"total_byte_count" tf:"optional"` + // The total number of chunks that the result set has been divided into. + TotalChunkCount types.Int64 `tfsdk:"total_chunk_count" tf:"optional"` + // The total number of rows in the result set. + TotalRowCount types.Int64 `tfsdk:"total_row_count" tf:"optional"` + // Indicates whether the result is truncated due to `row_limit` or + // `byte_limit`. + Truncated types.Bool `tfsdk:"truncated" tf:"optional"` +} + +// The schema is an ordered list of column descriptions. +type ResultSchema struct { + ColumnCount types.Int64 `tfsdk:"column_count" tf:"optional"` + + Columns []ColumnInfo `tfsdk:"columns" tf:"optional"` +} + +type ServiceError struct { + ErrorCode types.String `tfsdk:"error_code" tf:"optional"` + // A brief summary of the error condition. + Message types.String `tfsdk:"message" tf:"optional"` +} + +// Set object ACL +type SetRequest struct { + AccessControlList []AccessControl `tfsdk:"access_control_list" tf:"optional"` + // Object ID. The ACL for the object with this UUID is overwritten by this + // request's POST content. + ObjectId types.String `tfsdk:"-"` + // The type of object permission to set. + ObjectType types.String `tfsdk:"-"` +} + +type SetResponse struct { + AccessControlList []AccessControl `tfsdk:"access_control_list" tf:"optional"` + // An object's type and UUID, separated by a forward slash (/) character. + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + // A singular noun object type. + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type SetWorkspaceWarehouseConfigRequest struct { + // Optional: Channel selection details + Channel *Channel `tfsdk:"channel" tf:"optional"` + // Deprecated: Use sql_configuration_parameters + ConfigParam *RepeatedEndpointConfPairs `tfsdk:"config_param" tf:"optional"` + // Spark confs for external hive metastore configuration JSON serialized + // size must be less than <= 512K + DataAccessConfig []EndpointConfPair `tfsdk:"data_access_config" tf:"optional"` + // List of Warehouse Types allowed in this workspace (limits allowed value + // of the type field in CreateWarehouse and EditWarehouse). Note: Some types + // cannot be disabled, they don't need to be specified in + // SetWorkspaceWarehouseConfig. Note: Disabling a type may cause existing + // warehouses to be converted to another type. Used by frontend to save + // specific type availability in the warehouse create and edit form UI. + EnabledWarehouseTypes []WarehouseTypePair `tfsdk:"enabled_warehouse_types" tf:"optional"` + // Deprecated: Use sql_configuration_parameters + GlobalParam *RepeatedEndpointConfPairs `tfsdk:"global_param" tf:"optional"` + // GCP only: Google Service Account used to pass to cluster to access Google + // Cloud Storage + GoogleServiceAccount types.String `tfsdk:"google_service_account" tf:"optional"` + // AWS Only: Instance profile used to pass IAM role to the cluster + InstanceProfileArn types.String `tfsdk:"instance_profile_arn" tf:"optional"` + // Security policy for warehouses + SecurityPolicy types.String `tfsdk:"security_policy" tf:"optional"` + // SQL configuration parameters + SqlConfigurationParameters *RepeatedEndpointConfPairs `tfsdk:"sql_configuration_parameters" tf:"optional"` +} + +type SetWorkspaceWarehouseConfigResponse struct { +} + +// Start a warehouse +type StartRequest struct { + // Required. Id of the SQL warehouse. + Id types.String `tfsdk:"-"` +} + +type StartWarehouseResponse struct { +} + +type StatementParameterListItem struct { + // The name of a parameter marker to be substituted in the statement. + Name types.String `tfsdk:"name" tf:""` + // The data type, given as a string. For example: `INT`, `STRING`, + // `DECIMAL(10,2)`. If no type is given the type is assumed to be `STRING`. + // Complex types, such as `ARRAY`, `MAP`, and `STRUCT` are not supported. + // For valid types, refer to the section [Data types] of the SQL language + // reference. + // + // [Data types]: https://docs.databricks.com/sql/language-manual/functions/cast.html + Type types.String `tfsdk:"type" tf:"optional"` + // The value to substitute, represented as a string. If omitted, the value + // is interpreted as NULL. + Value types.String `tfsdk:"value" tf:"optional"` +} + +// The status response includes execution state and if relevant, error +// information. +type StatementStatus struct { + Error *ServiceError `tfsdk:"error" tf:"optional"` + // Statement execution state: - `PENDING`: waiting for warehouse - + // `RUNNING`: running - `SUCCEEDED`: execution was successful, result data + // available for fetch - `FAILED`: execution failed; reason for failure + // described in accomanying error message - `CANCELED`: user canceled; can + // come from explicit cancel call, or timeout with `on_wait_timeout=CANCEL` + // - `CLOSED`: execution successful, and statement closed; result no longer + // available for fetch + State types.String `tfsdk:"state" tf:"optional"` +} + +// Stop a warehouse +type StopRequest struct { + // Required. Id of the SQL warehouse. + Id types.String `tfsdk:"-"` +} + +type StopWarehouseResponse struct { +} + +type Success struct { + Message types.String `tfsdk:"message" tf:"optional"` +} + +type TerminationReason struct { + // status code indicating why the cluster was terminated + Code types.String `tfsdk:"code" tf:"optional"` + // list of parameters that provide additional information about why the + // cluster was terminated + Parameters map[string]types.String `tfsdk:"parameters" tf:"optional"` + // type of the termination + Type types.String `tfsdk:"type" tf:"optional"` +} + +type TimeRange struct { + // Limit results to queries that started before this time. + EndTimeMs types.Int64 `tfsdk:"end_time_ms" tf:"optional"` + // Limit results to queries that started after this time. + StartTimeMs types.Int64 `tfsdk:"start_time_ms" tf:"optional"` +} + +type TransferOwnershipObjectId struct { + // Email address for the new owner, who must exist in the workspace. + NewOwner types.String `tfsdk:"new_owner" tf:"optional"` +} + +// Transfer object ownership +type TransferOwnershipRequest struct { + // Email address for the new owner, who must exist in the workspace. + NewOwner types.String `tfsdk:"new_owner" tf:"optional"` + // The ID of the object on which to change ownership. + ObjectId TransferOwnershipObjectId `tfsdk:"-"` + // The type of object on which to change ownership. + ObjectType types.String `tfsdk:"-"` +} + +type UpdateResponse struct { +} + +type User struct { + Email types.String `tfsdk:"email" tf:"optional"` + + Id types.Int64 `tfsdk:"id" tf:"optional"` + + Name types.String `tfsdk:"name" tf:"optional"` +} + +// The visualization description API changes frequently and is unsupported. You +// can duplicate a visualization by copying description objects received _from +// the API_ and then using them to create a new one with a POST request to the +// same endpoint. Databricks does not recommend constructing ad-hoc +// visualizations entirely in JSON. +type Visualization struct { + CreatedAt types.String `tfsdk:"created_at" tf:"optional"` + // A short description of this visualization. This is not displayed in the + // UI. + Description types.String `tfsdk:"description" tf:"optional"` + // The UUID for this visualization. + Id types.String `tfsdk:"id" tf:"optional"` + // The name of the visualization that appears on dashboards and the query + // screen. + Name types.String `tfsdk:"name" tf:"optional"` + // The options object varies widely from one visualization type to the next + // and is unsupported. Databricks does not recommend modifying visualization + // settings in JSON. + Options any `tfsdk:"options" tf:"optional"` + + Query *Query `tfsdk:"query" tf:"optional"` + // The type of visualization: chart, table, pivot table, and so on. + Type types.String `tfsdk:"type" tf:"optional"` + + UpdatedAt types.String `tfsdk:"updated_at" tf:"optional"` +} + +type WarehouseAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type WarehouseAccessControlResponse struct { + // All permissions. + AllPermissions []WarehousePermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type WarehousePermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type WarehousePermissions struct { + AccessControlList []WarehouseAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type WarehousePermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type WarehousePermissionsRequest struct { + AccessControlList []WarehouseAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The SQL warehouse for which to get or manage permissions. + WarehouseId types.String `tfsdk:"-"` +} + +type WarehouseTypePair struct { + // If set to false the specific warehouse type will not be be allowed as a + // value for warehouse_type in CreateWarehouse and EditWarehouse + Enabled types.Bool `tfsdk:"enabled" tf:"optional"` + // Warehouse type: `PRO` or `CLASSIC`. + WarehouseType types.String `tfsdk:"warehouse_type" tf:"optional"` +} + +type Widget struct { + // The unique ID for this widget. + Id types.String `tfsdk:"id" tf:"optional"` + + Options *WidgetOptions `tfsdk:"options" tf:"optional"` + // The visualization description API changes frequently and is unsupported. + // You can duplicate a visualization by copying description objects received + // _from the API_ and then using them to create a new one with a POST + // request to the same endpoint. Databricks does not recommend constructing + // ad-hoc visualizations entirely in JSON. + Visualization *Visualization `tfsdk:"visualization" tf:"optional"` + // Unused field. + Width types.Int64 `tfsdk:"width" tf:"optional"` +} + +type WidgetOptions struct { + // Timestamp when this object was created + CreatedAt types.String `tfsdk:"created_at" tf:"optional"` + // Custom description of the widget + Description types.String `tfsdk:"description" tf:"optional"` + // Whether this widget is hidden on the dashboard. + IsHidden types.Bool `tfsdk:"isHidden" tf:"optional"` + // How parameters used by the visualization in this widget relate to other + // widgets on the dashboard. Databricks does not recommend modifying this + // definition in JSON. + ParameterMappings any `tfsdk:"parameterMappings" tf:"optional"` + // Coordinates of this widget on a dashboard. This portion of the API + // changes frequently and is unsupported. + Position *WidgetPosition `tfsdk:"position" tf:"optional"` + // Custom title of the widget + Title types.String `tfsdk:"title" tf:"optional"` + // Timestamp of the last time this object was updated. + UpdatedAt types.String `tfsdk:"updated_at" tf:"optional"` +} + +// Coordinates of this widget on a dashboard. This portion of the API changes +// frequently and is unsupported. +type WidgetPosition struct { + // reserved for internal use + AutoHeight types.Bool `tfsdk:"autoHeight" tf:"optional"` + // column in the dashboard grid. Values start with 0 + Col types.Int64 `tfsdk:"col" tf:"optional"` + // row in the dashboard grid. Values start with 0 + Row types.Int64 `tfsdk:"row" tf:"optional"` + // width of the widget measured in dashboard grid cells + SizeX types.Int64 `tfsdk:"sizeX" tf:"optional"` + // height of the widget measured in dashboard grid cells + SizeY types.Int64 `tfsdk:"sizeY" tf:"optional"` +} diff --git a/internal/service/vectorsearch_tf/model.go b/internal/service/vectorsearch_tf/model.go new file mode 100755 index 0000000000..3eb342a87f --- /dev/null +++ b/internal/service/vectorsearch_tf/model.go @@ -0,0 +1,443 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package vectorsearch_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type ColumnInfo struct { + // Name of the column. + Name types.String `tfsdk:"name" tf:"optional"` +} + +type CreateEndpoint struct { + // Type of endpoint. + EndpointType types.String `tfsdk:"endpoint_type" tf:""` + // Name of endpoint + Name types.String `tfsdk:"name" tf:""` +} + +type CreateVectorIndexRequest struct { + // Specification for Delta Sync Index. Required if `index_type` is + // `DELTA_SYNC`. + DeltaSyncIndexSpec *DeltaSyncVectorIndexSpecRequest `tfsdk:"delta_sync_index_spec" tf:"optional"` + // Specification for Direct Vector Access Index. Required if `index_type` is + // `DIRECT_ACCESS`. + DirectAccessIndexSpec *DirectAccessVectorIndexSpec `tfsdk:"direct_access_index_spec" tf:"optional"` + // Name of the endpoint to be used for serving the index + EndpointName types.String `tfsdk:"endpoint_name" tf:""` + // There are 2 types of Vector Search indexes: + // + // - `DELTA_SYNC`: An index that automatically syncs with a source Delta + // Table, automatically and incrementally updating the index as the + // underlying data in the Delta Table changes. - `DIRECT_ACCESS`: An index + // that supports direct read and write of vectors and metadata through our + // REST and SDK APIs. With this model, the user manages index updates. + IndexType types.String `tfsdk:"index_type" tf:""` + // Name of the index + Name types.String `tfsdk:"name" tf:""` + // Primary key of the index + PrimaryKey types.String `tfsdk:"primary_key" tf:""` +} + +type CreateVectorIndexResponse struct { + VectorIndex *VectorIndex `tfsdk:"vector_index" tf:"optional"` +} + +// Result of the upsert or delete operation. +type DeleteDataResult struct { + // List of primary keys for rows that failed to process. + FailedPrimaryKeys []types.String `tfsdk:"failed_primary_keys" tf:"optional"` + // Count of successfully processed rows. + SuccessRowCount types.Int64 `tfsdk:"success_row_count" tf:"optional"` +} + +// Request payload for deleting data from a vector index. +type DeleteDataVectorIndexRequest struct { + // Name of the vector index where data is to be deleted. Must be a Direct + // Vector Access Index. + IndexName types.String `tfsdk:"-"` + // List of primary keys for the data to be deleted. + PrimaryKeys []types.String `tfsdk:"primary_keys" tf:""` +} + +// Response to a delete data vector index request. +type DeleteDataVectorIndexResponse struct { + // Result of the upsert or delete operation. + Result *DeleteDataResult `tfsdk:"result" tf:"optional"` + // Status of the delete operation. + Status types.String `tfsdk:"status" tf:"optional"` +} + +// Delete an endpoint +type DeleteEndpointRequest struct { + // Name of the endpoint + EndpointName types.String `tfsdk:"-"` +} + +type DeleteEndpointResponse struct { +} + +// Delete an index +type DeleteIndexRequest struct { + // Name of the index + IndexName types.String `tfsdk:"-"` +} + +type DeleteIndexResponse struct { +} + +type DeltaSyncVectorIndexSpecRequest struct { + // The columns that contain the embedding source. + EmbeddingSourceColumns []EmbeddingSourceColumn `tfsdk:"embedding_source_columns" tf:"optional"` + // The columns that contain the embedding vectors. The format should be + // array[double]. + EmbeddingVectorColumns []EmbeddingVectorColumn `tfsdk:"embedding_vector_columns" tf:"optional"` + // [Optional] Automatically sync the vector index contents and computed + // embeddings to the specified Delta table. The only supported table name is + // the index name with the suffix `_writeback_table`. + EmbeddingWritebackTable types.String `tfsdk:"embedding_writeback_table" tf:"optional"` + // Pipeline execution mode. + // + // - `TRIGGERED`: If the pipeline uses the triggered execution mode, the + // system stops processing after successfully refreshing the source table in + // the pipeline once, ensuring the table is updated based on the data + // available when the update started. - `CONTINUOUS`: If the pipeline uses + // continuous execution, the pipeline processes new data as it arrives in + // the source table to keep vector index fresh. + PipelineType types.String `tfsdk:"pipeline_type" tf:"optional"` + // The name of the source table. + SourceTable types.String `tfsdk:"source_table" tf:"optional"` +} + +type DeltaSyncVectorIndexSpecResponse struct { + // The columns that contain the embedding source. + EmbeddingSourceColumns []EmbeddingSourceColumn `tfsdk:"embedding_source_columns" tf:"optional"` + // The columns that contain the embedding vectors. + EmbeddingVectorColumns []EmbeddingVectorColumn `tfsdk:"embedding_vector_columns" tf:"optional"` + // [Optional] Name of the Delta table to sync the vector index contents and + // computed embeddings to. + EmbeddingWritebackTable types.String `tfsdk:"embedding_writeback_table" tf:"optional"` + // The ID of the pipeline that is used to sync the index. + PipelineId types.String `tfsdk:"pipeline_id" tf:"optional"` + // Pipeline execution mode. + // + // - `TRIGGERED`: If the pipeline uses the triggered execution mode, the + // system stops processing after successfully refreshing the source table in + // the pipeline once, ensuring the table is updated based on the data + // available when the update started. - `CONTINUOUS`: If the pipeline uses + // continuous execution, the pipeline processes new data as it arrives in + // the source table to keep vector index fresh. + PipelineType types.String `tfsdk:"pipeline_type" tf:"optional"` + // The name of the source table. + SourceTable types.String `tfsdk:"source_table" tf:"optional"` +} + +type DirectAccessVectorIndexSpec struct { + // Contains the optional model endpoint to use during query time. + EmbeddingSourceColumns []EmbeddingSourceColumn `tfsdk:"embedding_source_columns" tf:"optional"` + + EmbeddingVectorColumns []EmbeddingVectorColumn `tfsdk:"embedding_vector_columns" tf:"optional"` + // The schema of the index in JSON format. + // + // Supported types are `integer`, `long`, `float`, `double`, `boolean`, + // `string`, `date`, `timestamp`. + // + // Supported types for vector column: `array`, `array`,`. + SchemaJson types.String `tfsdk:"schema_json" tf:"optional"` +} + +type EmbeddingSourceColumn struct { + // Name of the embedding model endpoint + EmbeddingModelEndpointName types.String `tfsdk:"embedding_model_endpoint_name" tf:"optional"` + // Name of the column + Name types.String `tfsdk:"name" tf:"optional"` +} + +type EmbeddingVectorColumn struct { + // Dimension of the embedding vector + EmbeddingDimension types.Int64 `tfsdk:"embedding_dimension" tf:"optional"` + // Name of the column + Name types.String `tfsdk:"name" tf:"optional"` +} + +type EndpointInfo struct { + // Timestamp of endpoint creation + CreationTimestamp types.Int64 `tfsdk:"creation_timestamp" tf:"optional"` + // Creator of the endpoint + Creator types.String `tfsdk:"creator" tf:"optional"` + // Current status of the endpoint + EndpointStatus *EndpointStatus `tfsdk:"endpoint_status" tf:"optional"` + // Type of endpoint. + EndpointType types.String `tfsdk:"endpoint_type" tf:"optional"` + // Unique identifier of the endpoint + Id types.String `tfsdk:"id" tf:"optional"` + // Timestamp of last update to the endpoint + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` + // User who last updated the endpoint + LastUpdatedUser types.String `tfsdk:"last_updated_user" tf:"optional"` + // Name of endpoint + Name types.String `tfsdk:"name" tf:"optional"` + // Number of indexes on the endpoint + NumIndexes types.Int64 `tfsdk:"num_indexes" tf:"optional"` +} + +// Status information of an endpoint +type EndpointStatus struct { + // Additional status message + Message types.String `tfsdk:"message" tf:"optional"` + // Current state of the endpoint + State types.String `tfsdk:"state" tf:"optional"` +} + +// Get an endpoint +type GetEndpointRequest struct { + // Name of the endpoint + EndpointName types.String `tfsdk:"-"` +} + +// Get an index +type GetIndexRequest struct { + // Name of the index + IndexName types.String `tfsdk:"-"` +} + +type ListEndpointResponse struct { + // An array of Endpoint objects + Endpoints []EndpointInfo `tfsdk:"endpoints" tf:"optional"` + // A token that can be used to get the next page of results. If not present, + // there are no more results to show. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` +} + +// List all endpoints +type ListEndpointsRequest struct { + // Token for pagination + PageToken types.String `tfsdk:"-"` +} + +// List indexes +type ListIndexesRequest struct { + // Name of the endpoint + EndpointName types.String `tfsdk:"-"` + // Token for pagination + PageToken types.String `tfsdk:"-"` +} + +type ListValue struct { + Values []Value `tfsdk:"values" tf:"optional"` +} + +type ListVectorIndexesResponse struct { + // A token that can be used to get the next page of results. If not present, + // there are no more results to show. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + VectorIndexes []MiniVectorIndex `tfsdk:"vector_indexes" tf:"optional"` +} + +// Key-value pair. +type MapStringValueEntry struct { + // Column name. + Key types.String `tfsdk:"key" tf:"optional"` + // Column value, nullable. + Value *Value `tfsdk:"value" tf:"optional"` +} + +type MiniVectorIndex struct { + // The user who created the index. + Creator types.String `tfsdk:"creator" tf:"optional"` + // Name of the endpoint associated with the index + EndpointName types.String `tfsdk:"endpoint_name" tf:"optional"` + // There are 2 types of Vector Search indexes: + // + // - `DELTA_SYNC`: An index that automatically syncs with a source Delta + // Table, automatically and incrementally updating the index as the + // underlying data in the Delta Table changes. - `DIRECT_ACCESS`: An index + // that supports direct read and write of vectors and metadata through our + // REST and SDK APIs. With this model, the user manages index updates. + IndexType types.String `tfsdk:"index_type" tf:"optional"` + // Name of the index + Name types.String `tfsdk:"name" tf:"optional"` + // Primary key of the index + PrimaryKey types.String `tfsdk:"primary_key" tf:"optional"` +} + +// Request payload for getting next page of results. +type QueryVectorIndexNextPageRequest struct { + // Name of the endpoint. + EndpointName types.String `tfsdk:"endpoint_name" tf:"optional"` + // Name of the vector index to query. + IndexName types.String `tfsdk:"-"` + // Page token returned from previous `QueryVectorIndex` or + // `QueryVectorIndexNextPage` API. + PageToken types.String `tfsdk:"page_token" tf:"optional"` +} + +type QueryVectorIndexRequest struct { + // List of column names to include in the response. + Columns []types.String `tfsdk:"columns" tf:""` + // JSON string representing query filters. + // + // Example filters: - `{"id <": 5}`: Filter for id less than 5. - `{"id >": + // 5}`: Filter for id greater than 5. - `{"id <=": 5}`: Filter for id less + // than equal to 5. - `{"id >=": 5}`: Filter for id greater than equal to 5. + // - `{"id": 5}`: Filter for id equal to 5. + FiltersJson types.String `tfsdk:"filters_json" tf:"optional"` + // Name of the vector index to query. + IndexName types.String `tfsdk:"-"` + // Number of results to return. Defaults to 10. + NumResults types.Int64 `tfsdk:"num_results" tf:"optional"` + // Query text. Required for Delta Sync Index using model endpoint. + QueryText types.String `tfsdk:"query_text" tf:"optional"` + // The query type to use. Choices are `ANN` and `HYBRID`. Defaults to `ANN`. + QueryType types.String `tfsdk:"query_type" tf:"optional"` + // Query vector. Required for Direct Vector Access Index and Delta Sync + // Index using self-managed vectors. + QueryVector []types.Float64 `tfsdk:"query_vector" tf:"optional"` + // Threshold for the approximate nearest neighbor search. Defaults to 0.0. + ScoreThreshold types.Float64 `tfsdk:"score_threshold" tf:"optional"` +} + +type QueryVectorIndexResponse struct { + // Metadata about the result set. + Manifest *ResultManifest `tfsdk:"manifest" tf:"optional"` + // [Optional] Token that can be used in `QueryVectorIndexNextPage` API to + // get next page of results. If more than 1000 results satisfy the query, + // they are returned in groups of 1000. Empty value means no more results. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + // Data returned in the query result. + Result *ResultData `tfsdk:"result" tf:"optional"` +} + +// Data returned in the query result. +type ResultData struct { + // Data rows returned in the query. + DataArray [][]types.String `tfsdk:"data_array" tf:"optional"` + // Number of rows in the result set. + RowCount types.Int64 `tfsdk:"row_count" tf:"optional"` +} + +// Metadata about the result set. +type ResultManifest struct { + // Number of columns in the result set. + ColumnCount types.Int64 `tfsdk:"column_count" tf:"optional"` + // Information about each column in the result set. + Columns []ColumnInfo `tfsdk:"columns" tf:"optional"` +} + +// Request payload for scanning data from a vector index. +type ScanVectorIndexRequest struct { + // Name of the vector index to scan. + IndexName types.String `tfsdk:"-"` + // Primary key of the last entry returned in the previous scan. + LastPrimaryKey types.String `tfsdk:"last_primary_key" tf:"optional"` + // Number of results to return. Defaults to 10. + NumResults types.Int64 `tfsdk:"num_results" tf:"optional"` +} + +// Response to a scan vector index request. +type ScanVectorIndexResponse struct { + // List of data entries + Data []Struct `tfsdk:"data" tf:"optional"` + // Primary key of the last entry. + LastPrimaryKey types.String `tfsdk:"last_primary_key" tf:"optional"` +} + +type Struct struct { + // Data entry, corresponding to a row in a vector index. + Fields []MapStringValueEntry `tfsdk:"fields" tf:"optional"` +} + +// Synchronize an index +type SyncIndexRequest struct { + // Name of the vector index to synchronize. Must be a Delta Sync Index. + IndexName types.String `tfsdk:"-"` +} + +type SyncIndexResponse struct { +} + +// Result of the upsert or delete operation. +type UpsertDataResult struct { + // List of primary keys for rows that failed to process. + FailedPrimaryKeys []types.String `tfsdk:"failed_primary_keys" tf:"optional"` + // Count of successfully processed rows. + SuccessRowCount types.Int64 `tfsdk:"success_row_count" tf:"optional"` +} + +// Request payload for upserting data into a vector index. +type UpsertDataVectorIndexRequest struct { + // Name of the vector index where data is to be upserted. Must be a Direct + // Vector Access Index. + IndexName types.String `tfsdk:"-"` + // JSON string representing the data to be upserted. + InputsJson types.String `tfsdk:"inputs_json" tf:""` +} + +// Response to an upsert data vector index request. +type UpsertDataVectorIndexResponse struct { + // Result of the upsert or delete operation. + Result *UpsertDataResult `tfsdk:"result" tf:"optional"` + // Status of the upsert operation. + Status types.String `tfsdk:"status" tf:"optional"` +} + +type Value struct { + BoolValue types.Bool `tfsdk:"bool_value" tf:"optional"` + + ListValue *ListValue `tfsdk:"list_value" tf:"optional"` + + NullValue types.String `tfsdk:"null_value" tf:"optional"` + + NumberValue types.Float64 `tfsdk:"number_value" tf:"optional"` + + StringValue types.String `tfsdk:"string_value" tf:"optional"` + + StructValue *Struct `tfsdk:"struct_value" tf:"optional"` +} + +type VectorIndex struct { + // The user who created the index. + Creator types.String `tfsdk:"creator" tf:"optional"` + + DeltaSyncIndexSpec *DeltaSyncVectorIndexSpecResponse `tfsdk:"delta_sync_index_spec" tf:"optional"` + + DirectAccessIndexSpec *DirectAccessVectorIndexSpec `tfsdk:"direct_access_index_spec" tf:"optional"` + // Name of the endpoint associated with the index + EndpointName types.String `tfsdk:"endpoint_name" tf:"optional"` + // There are 2 types of Vector Search indexes: + // + // - `DELTA_SYNC`: An index that automatically syncs with a source Delta + // Table, automatically and incrementally updating the index as the + // underlying data in the Delta Table changes. - `DIRECT_ACCESS`: An index + // that supports direct read and write of vectors and metadata through our + // REST and SDK APIs. With this model, the user manages index updates. + IndexType types.String `tfsdk:"index_type" tf:"optional"` + // Name of the index + Name types.String `tfsdk:"name" tf:"optional"` + // Primary key of the index + PrimaryKey types.String `tfsdk:"primary_key" tf:"optional"` + + Status *VectorIndexStatus `tfsdk:"status" tf:"optional"` +} + +type VectorIndexStatus struct { + // Index API Url to be used to perform operations on the index + IndexUrl types.String `tfsdk:"index_url" tf:"optional"` + // Number of rows indexed + IndexedRowCount types.Int64 `tfsdk:"indexed_row_count" tf:"optional"` + // Message associated with the index status + Message types.String `tfsdk:"message" tf:"optional"` + // Whether the index is ready for search + Ready types.Bool `tfsdk:"ready" tf:"optional"` +} diff --git a/internal/service/workspace_tf/model.go b/internal/service/workspace_tf/model.go new file mode 100755 index 0000000000..d11553b3a0 --- /dev/null +++ b/internal/service/workspace_tf/model.go @@ -0,0 +1,641 @@ +// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. +/* +These generated types are for terraform plugin framework to interact with the terraform state conveniently. + +These types follow the same structure as the types in go-sdk. +The only difference is that the primitive types are no longer using the go-native types, but with tfsdk types. +Plus the json tags get converted into tfsdk tags. +We use go-native types for lists and maps intentionally for the ease for converting these types into the go-sdk types. +*/ + +package workspace_tf + +import ( + "github.com/hashicorp/terraform-plugin-framework/types" +) + +type AclItem struct { + // The permission level applied to the principal. + Permission types.String `tfsdk:"permission" tf:""` + // The principal in which the permission is applied. + Principal types.String `tfsdk:"principal" tf:""` +} + +type AzureKeyVaultSecretScopeMetadata struct { + // The DNS of the KeyVault + DnsName types.String `tfsdk:"dns_name" tf:""` + // The resource id of the azure KeyVault that user wants to associate the + // scope with. + ResourceId types.String `tfsdk:"resource_id" tf:""` +} + +type CreateCredentials struct { + // Git provider. This field is case-insensitive. The available Git providers + // are gitHub, bitbucketCloud, gitLab, azureDevOpsServices, + // gitHubEnterprise, bitbucketServer, gitLabEnterpriseEdition and + // awsCodeCommit. + GitProvider types.String `tfsdk:"git_provider" tf:""` + // The username or email provided with your Git provider account, depending + // on which provider you are using. For GitHub, GitHub Enterprise Server, or + // Azure DevOps Services, either email or username may be used. For GitLab, + // GitLab Enterprise Edition, email must be used. For AWS CodeCommit, + // BitBucket or BitBucket Server, username must be used. For all other + // providers please see your provider's Personal Access Token authentication + // documentation to see what is supported. + GitUsername types.String `tfsdk:"git_username" tf:"optional"` + // The personal access token used to authenticate to the corresponding Git + // provider. For certain providers, support may exist for other types of + // scoped access tokens. [Learn more]. The personal access token used to + // authenticate to the corresponding Git + // + // [Learn more]: https://docs.databricks.com/repos/get-access-tokens-from-git-provider.html + PersonalAccessToken types.String `tfsdk:"personal_access_token" tf:"optional"` +} + +type CreateCredentialsResponse struct { + // ID of the credential object in the workspace. + CredentialId types.Int64 `tfsdk:"credential_id" tf:"optional"` + // Git provider. This field is case-insensitive. The available Git providers + // are gitHub, bitbucketCloud, gitLab, azureDevOpsServices, + // gitHubEnterprise, bitbucketServer, gitLabEnterpriseEdition and + // awsCodeCommit. + GitProvider types.String `tfsdk:"git_provider" tf:"optional"` + // The username or email provided with your Git provider account, depending + // on which provider you are using. For GitHub, GitHub Enterprise Server, or + // Azure DevOps Services, either email or username may be used. For GitLab, + // GitLab Enterprise Edition, email must be used. For AWS CodeCommit, + // BitBucket or BitBucket Server, username must be used. For all other + // providers please see your provider's Personal Access Token authentication + // documentation to see what is supported. + GitUsername types.String `tfsdk:"git_username" tf:"optional"` +} + +type CreateRepo struct { + // Desired path for the repo in the workspace. Almost any path in the + // workspace can be chosen. If repo is created in /Repos, path must be in + // the format /Repos/{folder}/{repo-name}. + Path types.String `tfsdk:"path" tf:"optional"` + // Git provider. This field is case-insensitive. The available Git providers + // are gitHub, bitbucketCloud, gitLab, azureDevOpsServices, + // gitHubEnterprise, bitbucketServer, gitLabEnterpriseEdition and + // awsCodeCommit. + Provider types.String `tfsdk:"provider" tf:""` + // If specified, the repo will be created with sparse checkout enabled. You + // cannot enable/disable sparse checkout after the repo is created. + SparseCheckout *SparseCheckout `tfsdk:"sparse_checkout" tf:"optional"` + // URL of the Git repository to be linked. + Url types.String `tfsdk:"url" tf:""` +} + +type CreateScope struct { + // The metadata for the secret scope if the type is `AZURE_KEYVAULT` + BackendAzureKeyvault *AzureKeyVaultSecretScopeMetadata `tfsdk:"backend_azure_keyvault" tf:"optional"` + // The principal that is initially granted `MANAGE` permission to the + // created scope. + InitialManagePrincipal types.String `tfsdk:"initial_manage_principal" tf:"optional"` + // Scope name requested by the user. Scope names are unique. + Scope types.String `tfsdk:"scope" tf:""` + // The backend type the scope will be created with. If not specified, will + // default to `DATABRICKS` + ScopeBackendType types.String `tfsdk:"scope_backend_type" tf:"optional"` +} + +type CreateScopeResponse struct { +} + +type CredentialInfo struct { + // ID of the credential object in the workspace. + CredentialId types.Int64 `tfsdk:"credential_id" tf:"optional"` + // Git provider. This field is case-insensitive. The available Git providers + // are gitHub, gitHubOAuth, bitbucketCloud, gitLab, azureDevOpsServices, + // gitHubEnterprise, bitbucketServer, gitLabEnterpriseEdition and + // awsCodeCommit. + GitProvider types.String `tfsdk:"git_provider" tf:"optional"` + // The username or email provided with your Git provider account, depending + // on which provider you are using. For GitHub, GitHub Enterprise Server, or + // Azure DevOps Services, either email or username may be used. For GitLab, + // GitLab Enterprise Edition, email must be used. For AWS CodeCommit, + // BitBucket or BitBucket Server, username must be used. For all other + // providers please see your provider's Personal Access Token authentication + // documentation to see what is supported. + GitUsername types.String `tfsdk:"git_username" tf:"optional"` +} + +type Delete struct { + // The absolute path of the notebook or directory. + Path types.String `tfsdk:"path" tf:""` + // The flag that specifies whether to delete the object recursively. It is + // `false` by default. Please note this deleting directory is not atomic. If + // it fails in the middle, some of objects under this directory may be + // deleted and cannot be undone. + Recursive types.Bool `tfsdk:"recursive" tf:"optional"` +} + +type DeleteAcl struct { + // The principal to remove an existing ACL from. + Principal types.String `tfsdk:"principal" tf:""` + // The name of the scope to remove permissions from. + Scope types.String `tfsdk:"scope" tf:""` +} + +type DeleteAclResponse struct { +} + +// Delete a credential +type DeleteGitCredentialRequest struct { + // The ID for the corresponding credential to access. + CredentialId types.Int64 `tfsdk:"-"` +} + +// Delete a repo +type DeleteRepoRequest struct { + // The ID for the corresponding repo to access. + RepoId types.Int64 `tfsdk:"-"` +} + +type DeleteResponse struct { +} + +type DeleteScope struct { + // Name of the scope to delete. + Scope types.String `tfsdk:"scope" tf:""` +} + +type DeleteScopeResponse struct { +} + +type DeleteSecret struct { + // Name of the secret to delete. + Key types.String `tfsdk:"key" tf:""` + // The name of the scope that contains the secret to delete. + Scope types.String `tfsdk:"scope" tf:""` +} + +type DeleteSecretResponse struct { +} + +// Export a workspace object +type ExportRequest struct { + // This specifies the format of the exported file. By default, this is + // `SOURCE`. + // + // The value is case sensitive. + // + // - `SOURCE`: The notebook is exported as source code. Directory exports + // will not include non-notebook entries. - `HTML`: The notebook is exported + // as an HTML file. - `JUPYTER`: The notebook is exported as a + // Jupyter/IPython Notebook file. - `DBC`: The notebook is exported in + // Databricks archive format. Directory exports will not include + // non-notebook entries. - `R_MARKDOWN`: The notebook is exported to R + // Markdown format. - `AUTO`: The object or directory is exported depending + // on the objects type. Directory exports will include notebooks and + // workspace files. + Format types.String `tfsdk:"-"` + // The absolute path of the object or directory. Exporting a directory is + // only supported for the `DBC`, `SOURCE`, and `AUTO` format. + Path types.String `tfsdk:"-"` +} + +type ExportResponse struct { + // The base64-encoded content. If the limit (10MB) is exceeded, exception + // with error code **MAX_NOTEBOOK_SIZE_EXCEEDED** is thrown. + Content types.String `tfsdk:"content" tf:"optional"` + // The file type of the exported file. + FileType types.String `tfsdk:"file_type" tf:"optional"` +} + +// Get secret ACL details +type GetAclRequest struct { + // The principal to fetch ACL information for. + Principal types.String `tfsdk:"-"` + // The name of the scope to fetch ACL information from. + Scope types.String `tfsdk:"-"` +} + +type GetCredentialsResponse struct { + Credentials []CredentialInfo `tfsdk:"credentials" tf:"optional"` +} + +// Get a credential entry +type GetGitCredentialRequest struct { + // The ID for the corresponding credential to access. + CredentialId types.Int64 `tfsdk:"-"` +} + +// Get repo permission levels +type GetRepoPermissionLevelsRequest struct { + // The repo for which to get or manage permissions. + RepoId types.String `tfsdk:"-"` +} + +type GetRepoPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []RepoPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get repo permissions +type GetRepoPermissionsRequest struct { + // The repo for which to get or manage permissions. + RepoId types.String `tfsdk:"-"` +} + +// Get a repo +type GetRepoRequest struct { + // The ID for the corresponding repo to access. + RepoId types.Int64 `tfsdk:"-"` +} + +// Get a secret +type GetSecretRequest struct { + // The key to fetch secret for. + Key types.String `tfsdk:"-"` + // The name of the scope to fetch secret information from. + Scope types.String `tfsdk:"-"` +} + +type GetSecretResponse struct { + // A unique name to identify the secret. + Key types.String `tfsdk:"key" tf:"optional"` + // The value of the secret in its byte representation. + Value types.String `tfsdk:"value" tf:"optional"` +} + +// Get status +type GetStatusRequest struct { + // The absolute path of the notebook or directory. + Path types.String `tfsdk:"-"` +} + +// Get workspace object permission levels +type GetWorkspaceObjectPermissionLevelsRequest struct { + // The workspace object for which to get or manage permissions. + WorkspaceObjectId types.String `tfsdk:"-"` + // The workspace object type for which to get or manage permissions. + WorkspaceObjectType types.String `tfsdk:"-"` +} + +type GetWorkspaceObjectPermissionLevelsResponse struct { + // Specific permission levels + PermissionLevels []WorkspaceObjectPermissionsDescription `tfsdk:"permission_levels" tf:"optional"` +} + +// Get workspace object permissions +type GetWorkspaceObjectPermissionsRequest struct { + // The workspace object for which to get or manage permissions. + WorkspaceObjectId types.String `tfsdk:"-"` + // The workspace object type for which to get or manage permissions. + WorkspaceObjectType types.String `tfsdk:"-"` +} + +type Import struct { + // The base64-encoded content. This has a limit of 10 MB. + // + // If the limit (10MB) is exceeded, exception with error code + // **MAX_NOTEBOOK_SIZE_EXCEEDED** is thrown. This parameter might be absent, + // and instead a posted file is used. + Content types.String `tfsdk:"content" tf:"optional"` + // This specifies the format of the file to be imported. + // + // The value is case sensitive. + // + // - `AUTO`: The item is imported depending on an analysis of the item's + // extension and the header content provided in the request. If the item is + // imported as a notebook, then the item's extension is automatically + // removed. - `SOURCE`: The notebook or directory is imported as source + // code. - `HTML`: The notebook is imported as an HTML file. - `JUPYTER`: + // The notebook is imported as a Jupyter/IPython Notebook file. - `DBC`: The + // notebook is imported in Databricks archive format. Required for + // directories. - `R_MARKDOWN`: The notebook is imported from R Markdown + // format. + Format types.String `tfsdk:"format" tf:"optional"` + // The language of the object. This value is set only if the object type is + // `NOTEBOOK`. + Language types.String `tfsdk:"language" tf:"optional"` + // The flag that specifies whether to overwrite existing object. It is + // `false` by default. For `DBC` format, `overwrite` is not supported since + // it may contain a directory. + Overwrite types.Bool `tfsdk:"overwrite" tf:"optional"` + // The absolute path of the object or directory. Importing a directory is + // only supported for the `DBC` and `SOURCE` formats. + Path types.String `tfsdk:"path" tf:""` +} + +type ImportResponse struct { +} + +// Lists ACLs +type ListAclsRequest struct { + // The name of the scope to fetch ACL information from. + Scope types.String `tfsdk:"-"` +} + +type ListAclsResponse struct { + // The associated ACLs rule applied to principals in the given scope. + Items []AclItem `tfsdk:"items" tf:"optional"` +} + +// Get repos +type ListReposRequest struct { + // Token used to get the next page of results. If not specified, returns the + // first page of results as well as a next page token if there are more + // results. + NextPageToken types.String `tfsdk:"-"` + // Filters repos that have paths starting with the given path prefix. If not + // provided repos from /Repos will be served. + PathPrefix types.String `tfsdk:"-"` +} + +type ListReposResponse struct { + // Token that can be specified as a query parameter to the GET /repos + // endpoint to retrieve the next page of results. + NextPageToken types.String `tfsdk:"next_page_token" tf:"optional"` + + Repos []RepoInfo `tfsdk:"repos" tf:"optional"` +} + +type ListResponse struct { + // List of objects. + Objects []ObjectInfo `tfsdk:"objects" tf:"optional"` +} + +type ListScopesResponse struct { + // The available secret scopes. + Scopes []SecretScope `tfsdk:"scopes" tf:"optional"` +} + +// List secret keys +type ListSecretsRequest struct { + // The name of the scope to list secrets within. + Scope types.String `tfsdk:"-"` +} + +type ListSecretsResponse struct { + // Metadata information of all secrets contained within the given scope. + Secrets []SecretMetadata `tfsdk:"secrets" tf:"optional"` +} + +// List contents +type ListWorkspaceRequest struct { + // UTC timestamp in milliseconds + NotebooksModifiedAfter types.Int64 `tfsdk:"-"` + // The absolute path of the notebook or directory. + Path types.String `tfsdk:"-"` +} + +type Mkdirs struct { + // The absolute path of the directory. If the parent directories do not + // exist, it will also create them. If the directory already exists, this + // command will do nothing and succeed. + Path types.String `tfsdk:"path" tf:""` +} + +type MkdirsResponse struct { +} + +type ObjectInfo struct { + // Only applicable to files. The creation UTC timestamp. + CreatedAt types.Int64 `tfsdk:"created_at" tf:"optional"` + // The language of the object. This value is set only if the object type is + // `NOTEBOOK`. + Language types.String `tfsdk:"language" tf:"optional"` + // Only applicable to files, the last modified UTC timestamp. + ModifiedAt types.Int64 `tfsdk:"modified_at" tf:"optional"` + // Unique identifier for the object. + ObjectId types.Int64 `tfsdk:"object_id" tf:"optional"` + // The type of the object in workspace. + // + // - `NOTEBOOK`: document that contains runnable code, visualizations, and + // explanatory text. - `DIRECTORY`: directory - `LIBRARY`: library - `FILE`: + // file - `REPO`: repository - `DASHBOARD`: Lakeview dashboard + ObjectType types.String `tfsdk:"object_type" tf:"optional"` + // The absolute path of the object. + Path types.String `tfsdk:"path" tf:"optional"` + // A unique identifier for the object that is consistent across all + // Databricks APIs. + ResourceId types.String `tfsdk:"resource_id" tf:"optional"` + // Only applicable to files. The file size in bytes can be returned. + Size types.Int64 `tfsdk:"size" tf:"optional"` +} + +type PutAcl struct { + // The permission level applied to the principal. + Permission types.String `tfsdk:"permission" tf:""` + // The principal in which the permission is applied. + Principal types.String `tfsdk:"principal" tf:""` + // The name of the scope to apply permissions to. + Scope types.String `tfsdk:"scope" tf:""` +} + +type PutAclResponse struct { +} + +type PutSecret struct { + // If specified, value will be stored as bytes. + BytesValue types.String `tfsdk:"bytes_value" tf:"optional"` + // A unique name to identify the secret. + Key types.String `tfsdk:"key" tf:""` + // The name of the scope to which the secret will be associated with. + Scope types.String `tfsdk:"scope" tf:""` + // If specified, note that the value will be stored in UTF-8 (MB4) form. + StringValue types.String `tfsdk:"string_value" tf:"optional"` +} + +type PutSecretResponse struct { +} + +type RepoAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type RepoAccessControlResponse struct { + // All permissions. + AllPermissions []RepoPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type RepoInfo struct { + // Branch that the local version of the repo is checked out to. + Branch types.String `tfsdk:"branch" tf:"optional"` + // SHA-1 hash representing the commit ID of the current HEAD of the repo. + HeadCommitId types.String `tfsdk:"head_commit_id" tf:"optional"` + // ID of the repo object in the workspace. + Id types.Int64 `tfsdk:"id" tf:"optional"` + // Desired path for the repo in the workspace. Almost any path in the + // workspace can be chosen. If repo is created in /Repos, path must be in + // the format /Repos/{folder}/{repo-name}. + Path types.String `tfsdk:"path" tf:"optional"` + // Git provider. This field is case-insensitive. The available Git providers + // are gitHub, bitbucketCloud, gitLab, azureDevOpsServices, + // gitHubEnterprise, bitbucketServer, gitLabEnterpriseEdition and + // awsCodeCommit. + Provider types.String `tfsdk:"provider" tf:"optional"` + + SparseCheckout *SparseCheckout `tfsdk:"sparse_checkout" tf:"optional"` + // URL of the Git repository to be linked. + Url types.String `tfsdk:"url" tf:"optional"` +} + +type RepoPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type RepoPermissions struct { + AccessControlList []RepoAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type RepoPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type RepoPermissionsRequest struct { + AccessControlList []RepoAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The repo for which to get or manage permissions. + RepoId types.String `tfsdk:"-"` +} + +type SecretMetadata struct { + // A unique name to identify the secret. + Key types.String `tfsdk:"key" tf:"optional"` + // The last updated timestamp (in milliseconds) for the secret. + LastUpdatedTimestamp types.Int64 `tfsdk:"last_updated_timestamp" tf:"optional"` +} + +type SecretScope struct { + // The type of secret scope backend. + BackendType types.String `tfsdk:"backend_type" tf:"optional"` + // The metadata for the secret scope if the type is `AZURE_KEYVAULT` + KeyvaultMetadata *AzureKeyVaultSecretScopeMetadata `tfsdk:"keyvault_metadata" tf:"optional"` + // A unique name to identify the secret scope. + Name types.String `tfsdk:"name" tf:"optional"` +} + +type SparseCheckout struct { + // List of patterns to include for sparse checkout. + Patterns []types.String `tfsdk:"patterns" tf:"optional"` +} + +type SparseCheckoutUpdate struct { + // List of patterns to include for sparse checkout. + Patterns []types.String `tfsdk:"patterns" tf:"optional"` +} + +type UpdateCredentials struct { + // The ID for the corresponding credential to access. + CredentialId types.Int64 `tfsdk:"-"` + // Git provider. This field is case-insensitive. The available Git providers + // are gitHub, bitbucketCloud, gitLab, azureDevOpsServices, + // gitHubEnterprise, bitbucketServer, gitLabEnterpriseEdition and + // awsCodeCommit. + GitProvider types.String `tfsdk:"git_provider" tf:"optional"` + // The username or email provided with your Git provider account, depending + // on which provider you are using. For GitHub, GitHub Enterprise Server, or + // Azure DevOps Services, either email or username may be used. For GitLab, + // GitLab Enterprise Edition, email must be used. For AWS CodeCommit, + // BitBucket or BitBucket Server, username must be used. For all other + // providers please see your provider's Personal Access Token authentication + // documentation to see what is supported. + GitUsername types.String `tfsdk:"git_username" tf:"optional"` + // The personal access token used to authenticate to the corresponding Git + // provider. For certain providers, support may exist for other types of + // scoped access tokens. [Learn more]. The personal access token used to + // authenticate to the corresponding Git + // + // [Learn more]: https://docs.databricks.com/repos/get-access-tokens-from-git-provider.html + PersonalAccessToken types.String `tfsdk:"personal_access_token" tf:"optional"` +} + +type UpdateRepo struct { + // Branch that the local version of the repo is checked out to. + Branch types.String `tfsdk:"branch" tf:"optional"` + // The ID for the corresponding repo to access. + RepoId types.Int64 `tfsdk:"-"` + // If specified, update the sparse checkout settings. The update will fail + // if sparse checkout is not enabled for the repo. + SparseCheckout *SparseCheckoutUpdate `tfsdk:"sparse_checkout" tf:"optional"` + // Tag that the local version of the repo is checked out to. Updating the + // repo to a tag puts the repo in a detached HEAD state. Before committing + // new changes, you must update the repo to a branch instead of the detached + // HEAD. + Tag types.String `tfsdk:"tag" tf:"optional"` +} + +type UpdateResponse struct { +} + +type WorkspaceObjectAccessControlRequest struct { + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` + // application ID of a service principal + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type WorkspaceObjectAccessControlResponse struct { + // All permissions. + AllPermissions []WorkspaceObjectPermission `tfsdk:"all_permissions" tf:"optional"` + // Display name of the user or service principal. + DisplayName types.String `tfsdk:"display_name" tf:"optional"` + // name of the group + GroupName types.String `tfsdk:"group_name" tf:"optional"` + // Name of the service principal. + ServicePrincipalName types.String `tfsdk:"service_principal_name" tf:"optional"` + // name of the user + UserName types.String `tfsdk:"user_name" tf:"optional"` +} + +type WorkspaceObjectPermission struct { + Inherited types.Bool `tfsdk:"inherited" tf:"optional"` + + InheritedFromObject []types.String `tfsdk:"inherited_from_object" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type WorkspaceObjectPermissions struct { + AccessControlList []WorkspaceObjectAccessControlResponse `tfsdk:"access_control_list" tf:"optional"` + + ObjectId types.String `tfsdk:"object_id" tf:"optional"` + + ObjectType types.String `tfsdk:"object_type" tf:"optional"` +} + +type WorkspaceObjectPermissionsDescription struct { + Description types.String `tfsdk:"description" tf:"optional"` + // Permission level + PermissionLevel types.String `tfsdk:"permission_level" tf:"optional"` +} + +type WorkspaceObjectPermissionsRequest struct { + AccessControlList []WorkspaceObjectAccessControlRequest `tfsdk:"access_control_list" tf:"optional"` + // The workspace object for which to get or manage permissions. + WorkspaceObjectId types.String `tfsdk:"-"` + // The workspace object type for which to get or manage permissions. + WorkspaceObjectType types.String `tfsdk:"-"` +}