Skip to content

Commit

Permalink
[Exporter] Improve support of databricks_model_serving (#4324)
Browse files Browse the repository at this point in the history
## Changes
<!-- Summary of your changes that are easy to understand -->

## Tests
<!-- 
How is this tested? Please see the checklist below and also describe any
other relevant tests
-->

- [x] `make test` run locally
- [ ] relevant change in `docs/` folder
- [ ] covered with integration tests in `internal/acceptance`
- [ ] using Go SDK
- [ ] using TF Plugin Framework

Co-authored-by: Tanmay Rustagi <[email protected]>
  • Loading branch information
alexott and tanmay-db authored Dec 17, 2024
1 parent d2bb4e5 commit 909b189
Showing 1 changed file with 24 additions and 9 deletions.
33 changes: 24 additions & 9 deletions exporter/importables.go
Original file line number Diff line number Diff line change
Expand Up @@ -250,7 +250,8 @@ var resourcesMap map[string]importable = map[string]importable{
Ignore: generateIgnoreObjectWithEmptyAttributeValue("databricks_instance_pool", "instance_pool_name"),
},
"databricks_instance_profile": {
Service: "access",
Service: "access",
WorkspaceLevel: true,
Name: func(ic *importContext, d *schema.ResourceData) string {
arn := d.Get("instance_profile_arn").(string)
splits := strings.Split(arn, "/")
Expand Down Expand Up @@ -774,12 +775,8 @@ var resourcesMap map[string]importable = map[string]importable{
return d.Get("name").(string)
},
List: func(ic *importContext) error {
w, err := ic.Client.WorkspaceClient()
if err != nil {
return err
}
builtInClusterPolicies := ic.getBuiltinPolicyFamilies()
it := w.ClusterPolicies.List(ic.Context, compute.ListClusterPoliciesRequest{})
it := ic.workspaceClient.ClusterPolicies.List(ic.Context, compute.ListClusterPoliciesRequest{})
i := 0
for it.HasNext(ic.Context) {
policy, err := it.Next(ic.Context)
Expand Down Expand Up @@ -2390,6 +2387,7 @@ var resourcesMap map[string]importable = map[string]importable{
}
if se.ExternalModel.OpenaiConfig != nil {
ic.emitSecretsFromSecretPathString(se.ExternalModel.OpenaiConfig.OpenaiApiKey)
ic.emitSecretsFromSecretPathString(se.ExternalModel.OpenaiConfig.MicrosoftEntraClientSecret)
}
if se.ExternalModel.PalmConfig != nil {
ic.emitSecretsFromSecretPathString(se.ExternalModel.PalmConfig.PalmApiKey)
Expand All @@ -2404,6 +2402,15 @@ var resourcesMap map[string]importable = map[string]importable{
ID: mse.Config.AutoCaptureConfig.CatalogName + "." + mse.Config.AutoCaptureConfig.SchemaName,
})
}
// TODO: add auto-capture for AI Gateway
if mse.AiGateway != nil && mse.AiGateway.InferenceTableConfig != nil &&
mse.AiGateway.InferenceTableConfig.CatalogName != "" &&
mse.AiGateway.InferenceTableConfig.SchemaName != "" {
ic.Emit(&resource{
Resource: "databricks_schema",
ID: mse.AiGateway.InferenceTableConfig.CatalogName + "." + mse.AiGateway.InferenceTableConfig.SchemaName,
})
}
return nil
},
Ignore: func(ic *importContext, r *resource) bool {
Expand Down Expand Up @@ -2441,14 +2448,22 @@ var resourcesMap map[string]importable = map[string]importable{
extModelBlockCoordinate := strings.Replace(pathString, ".scale_to_zero_enabled", ".external_model", 1)
return d.Get(extModelBlockCoordinate+".#").(int) == 0
}
return pathString == "config.0.auto_capture_config.0.enabled"
return pathString == "config.0.auto_capture_config.0.enabled" || pathString == "ai_gateway.0.inference_table_config.0.enabled"
},
Depends: []reference{
{Path: "config.served_entities.entity_name", Resource: "databricks_registered_model"},
{Path: "config.served_entities.instance_profile_arn", Resource: "databricks_instance_profile",
Match: "instance_profile_arn"},
{Path: "config.auto_capture_config.catalog_name", Resource: "databricks_catalog"},
{Path: "config.auto_capture_config.schema_name", Resource: "databricks_schema", Match: "name",
IsValidApproximation: createIsMatchingCatalogAndSchema("config.0.auto_capture_config.0.catalog_name", "config.0.auto_capture_config.0.schema_name"),
SkipDirectLookup: true},
IsValidApproximation: createIsMatchingCatalogAndSchema("config.0.auto_capture_config.0.catalog_name",
"config.0.auto_capture_config.0.schema_name"),
SkipDirectLookup: true},
{Path: "ai_gateway.inference_table_config.catalog_name", Resource: "databricks_catalog"},
{Path: "ai_gateway.inference_table_config.schema_name", Resource: "databricks_schema", Match: "name",
IsValidApproximation: createIsMatchingCatalogAndSchema("ai_gateway.0.inference_table_config.0.catalog_name",
"ai_gateway.0.inference_table_config.0.schema_name"),
SkipDirectLookup: true},
},
},
"databricks_mlflow_webhook": {
Expand Down

0 comments on commit 909b189

Please sign in to comment.