-
Notifications
You must be signed in to change notification settings - Fork 18
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add table azure_databricks_workspace
- Loading branch information
1 parent
c68fe63
commit a2f939f
Showing
3 changed files
with
308 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,224 @@ | ||
package azure | ||
|
||
import ( | ||
"context" | ||
|
||
"github.com/Azure/azure-sdk-for-go/services/databricks/mgmt/2018-04-01/databricks" | ||
"github.com/turbot/steampipe-plugin-sdk/v5/grpc/proto" | ||
"github.com/turbot/steampipe-plugin-sdk/v5/plugin/transform" | ||
|
||
"github.com/turbot/steampipe-plugin-sdk/v5/plugin" | ||
) | ||
|
||
//// TABLE DEFINITION | ||
|
||
func tableAzureDatabricksWorkspace(_ context.Context) *plugin.Table { | ||
return &plugin.Table{ | ||
Name: "azure_databricks_workspace", | ||
Description: "Azure Databricks Workspace", | ||
Get: &plugin.GetConfig{ | ||
KeyColumns: plugin.AllColumns([]string{"name", "resource_group"}), | ||
Hydrate: getDatabricksWorkspace, | ||
IgnoreConfig: &plugin.IgnoreConfig{ | ||
ShouldIgnoreErrorFunc: isNotFoundError([]string{"ResourceNotFound", "ResourceGroupNotFound", "400"}), | ||
}, | ||
}, | ||
List: &plugin.ListConfig{ | ||
Hydrate: listDatabricksWorkspaces, | ||
}, | ||
Columns: azureColumns([]*plugin.Column{ | ||
{ | ||
Name: "name", | ||
Description: "The resource name.", | ||
Type: proto.ColumnType_STRING, | ||
}, | ||
{ | ||
Name: "id", | ||
Description: "Fully qualified resource Id for the resource.", | ||
Type: proto.ColumnType_STRING, | ||
Transform: transform.FromGo(), | ||
}, | ||
{ | ||
Name: "sku", | ||
Description: "The SKU of the resource.", | ||
Type: proto.ColumnType_JSON, | ||
}, | ||
{ | ||
Name: "type", | ||
Description: "The type of the resource.", | ||
Type: proto.ColumnType_STRING, | ||
}, | ||
{ | ||
Name: "location", | ||
Description: "The geo-location where the resource lives.", | ||
Type: proto.ColumnType_STRING, | ||
}, | ||
{ | ||
Name: "managed_resource_group_id", | ||
Description: "The managed resource group Id.", | ||
Type: proto.ColumnType_STRING, | ||
Transform: transform.FromField("WorkspaceProperties.ManagedResourceGroupID"), | ||
}, | ||
{ | ||
Name: "parameters", | ||
Description: "The workspace's custom parameters.", | ||
Type: proto.ColumnType_JSON, | ||
Transform: transform.FromField("WorkspaceProperties.Parameters"), | ||
}, | ||
{ | ||
Name: "provisioning_state", | ||
Description: "The workspace provisioning state.", | ||
Type: proto.ColumnType_STRING, | ||
Transform: transform.FromField("WorkspaceProperties.ProvisioningState"), | ||
}, | ||
{ | ||
Name: "ui_definition_uri", | ||
Description: "The blob URI where the UI definition file is located.", | ||
Type: proto.ColumnType_STRING, | ||
Transform: transform.FromField("WorkspaceProperties.UIDefinitionURI"), | ||
}, | ||
{ | ||
Name: "authorizations", | ||
Description: "The workspace provider authorizations.", | ||
Type: proto.ColumnType_JSON, | ||
Transform: transform.FromField("WorkspaceProperties.Authorizations"), | ||
}, | ||
{ | ||
Name: "created_by", | ||
Description: "Indicates the Object ID, PUID and Application ID of entity that created the workspace.", | ||
Type: proto.ColumnType_JSON, | ||
Transform: transform.FromField("WorkspaceProperties.CreatedBy"), | ||
}, | ||
{ | ||
Name: "updated_by", | ||
Description: "Indicates the Object ID, PUID and Application ID of entity that last updated the workspace.", | ||
Type: proto.ColumnType_JSON, | ||
Transform: transform.FromField("WorkspaceProperties.UpdatedBy"), | ||
}, | ||
{ | ||
Name: "created_date_time", | ||
Description: "Specifies the date and time when the workspace is created.", | ||
Type: proto.ColumnType_TIMESTAMP, | ||
Transform: transform.FromField("WorkspaceProperties.CreatedDateTime").Transform(convertDateToTime), | ||
}, | ||
{ | ||
Name: "workspace_id", | ||
Description: "The unique identifier of the databricks workspace in databricks control plane.", | ||
Type: proto.ColumnType_STRING, | ||
Transform: transform.FromField("WorkspaceProperties.WorkspaceID"), | ||
}, | ||
{ | ||
Name: "workspace_url", | ||
Description: "The workspace URL which is of the format 'adb-{workspaceId}.{random}.azuredatabricks.net'.", | ||
Type: proto.ColumnType_STRING, | ||
Transform: transform.FromField("WorkspaceProperties.WorkspaceURL"), | ||
}, | ||
{ | ||
Name: "storage_account_identity", | ||
Description: "The details of Managed Identity of Storage Account", | ||
Type: proto.ColumnType_JSON, | ||
Transform: transform.FromField("WorkspaceProperties.StorageAccountIdentity"), | ||
}, | ||
|
||
// Steampipe standard columns | ||
{ | ||
Name: "title", | ||
Description: ColumnDescriptionTitle, | ||
Type: proto.ColumnType_STRING, | ||
Transform: transform.FromField("Name"), | ||
}, | ||
{ | ||
Name: "tags", | ||
Description: ColumnDescriptionTags, | ||
Type: proto.ColumnType_JSON, | ||
}, | ||
{ | ||
Name: "akas", | ||
Description: ColumnDescriptionAkas, | ||
Type: proto.ColumnType_JSON, | ||
Transform: transform.FromField("ID").Transform(idToAkas), | ||
}, | ||
|
||
// Azure standard columns | ||
{ | ||
Name: "region", | ||
Description: ColumnDescriptionRegion, | ||
Type: proto.ColumnType_STRING, | ||
Transform: transform.FromField("Location").Transform(toLower), | ||
}, | ||
{ | ||
Name: "resource_group", | ||
Description: ColumnDescriptionResourceGroup, | ||
Type: proto.ColumnType_STRING, | ||
Transform: transform.FromField("ID").Transform(extractResourceGroupFromID), | ||
}, | ||
}), | ||
} | ||
} | ||
|
||
//// LIST FUNCTION | ||
|
||
func listDatabricksWorkspaces(ctx context.Context, d *plugin.QueryData, _ *plugin.HydrateData) (interface{}, error) { | ||
plugin.Logger(ctx).Trace("listDatabricksWorkspaces") | ||
session, err := GetNewSession(ctx, d, "MANAGEMENT") | ||
if err != nil { | ||
return nil, err | ||
} | ||
subscriptionID := session.SubscriptionID | ||
|
||
workspaceClient := databricks.NewWorkspacesClientWithBaseURI(session.ResourceManagerEndpoint, subscriptionID) | ||
workspaceClient.Authorizer = session.Authorizer | ||
|
||
result, err := workspaceClient.ListBySubscription(ctx) | ||
if err != nil { | ||
plugin.Logger(ctx).Error("azure_databricks_workspace.listDatabricksWorkspaces", "ListBySubscription", err) | ||
return nil, err | ||
} | ||
for _, workspace := range result.Values() { | ||
d.StreamListItem(ctx, workspace) | ||
} | ||
|
||
for result.NotDone() { | ||
err = result.NextWithContext(ctx) | ||
if err != nil { | ||
plugin.Logger(ctx).Error("azure_databricks_workspace.listDatabricksWorkspaces", "ListBySubscription_pagination", err) | ||
return nil, err | ||
} | ||
for _, device := range result.Values() { | ||
d.StreamListItem(ctx, device) | ||
} | ||
|
||
} | ||
return nil, err | ||
} | ||
|
||
//// HYDRATE FUNCTIONS | ||
|
||
func getDatabricksWorkspace(ctx context.Context, d *plugin.QueryData, h *plugin.HydrateData) (interface{}, error) { | ||
plugin.Logger(ctx).Trace("getDatabricksWorkspace") | ||
|
||
workspaceName := d.EqualsQuals["name"].GetStringValue() | ||
resourceGroup := d.EqualsQuals["resource_group"].GetStringValue() | ||
|
||
// Return nil, if no input provide | ||
if workspaceName == "" || resourceGroup == "" { | ||
return nil, nil | ||
} | ||
|
||
// Create session | ||
session, err := GetNewSession(ctx, d, "MANAGEMENT") | ||
if err != nil { | ||
return nil, err | ||
} | ||
subscriptionID := session.SubscriptionID | ||
|
||
workspaceClient := databricks.NewWorkspacesClientWithBaseURI(session.ResourceManagerEndpoint, subscriptionID) | ||
workspaceClient.Authorizer = session.Authorizer | ||
|
||
op, err := workspaceClient.Get(ctx, resourceGroup, workspaceName) | ||
if err != nil { | ||
return nil, err | ||
} | ||
|
||
return op, nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
# Table: azure_databricks_workspace | ||
|
||
A workspace is an environment for accessing all of your Azure Databricks assets. A workspace organizes objects (notebooks, libraries, dashboards, and experiments) into folders and provides access to data objects and computational resources. | ||
|
||
## Examples | ||
|
||
### Basic info | ||
|
||
```sql | ||
select | ||
name, | ||
id, | ||
workspace_id, | ||
workspace_url, | ||
created_date_time, | ||
sku | ||
from | ||
azure_databricks_workspace; | ||
``` | ||
|
||
### List workspaces created in the last 30 days | ||
|
||
```sql | ||
select | ||
name, | ||
id, | ||
workspace_id, | ||
workspace_url, | ||
created_date_time, | ||
sku | ||
from | ||
azure_databricks_workspace | ||
where | ||
created_date_time >= now() - interval '30' day; | ||
``` | ||
|
||
### List failed workspaces | ||
|
||
```sql | ||
select | ||
name, | ||
id, | ||
workspace_id, | ||
workspace_url, | ||
created_date_time, | ||
sku | ||
from | ||
azure_databricks_workspace; | ||
where | ||
provisioning_state = 'Failed'; | ||
``` | ||
|
||
### List all encrypted workspaces | ||
|
||
```sql | ||
select | ||
name, | ||
id, | ||
workspace_id, | ||
workspace_url, | ||
created_date_time, | ||
sku | ||
from | ||
azure_databricks_workspace | ||
where | ||
parameters -> 'Encryption' is not null; | ||
``` | ||
|
||
### List workspaces that allow public IP | ||
|
||
```sql | ||
select | ||
name, | ||
id, | ||
workspace_id, | ||
workspace_url, | ||
created_date_time, | ||
sku | ||
from | ||
azure_databricks_workspace | ||
where | ||
parameters -> 'enableNoPublicIp' ->> 'value' = 'false'; | ||
``` |