forked from databricks/databricks-sdk-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
account_client.go
executable file
·330 lines (295 loc) · 16.7 KB
/
account_client.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package databricks
import (
"errors"
"github.com/databricks/databricks-sdk-go/client"
"github.com/databricks/databricks-sdk-go/config"
"github.com/databricks/databricks-sdk-go/service/billing"
"github.com/databricks/databricks-sdk-go/service/catalog"
"github.com/databricks/databricks-sdk-go/service/iam"
"github.com/databricks/databricks-sdk-go/service/oauth2"
"github.com/databricks/databricks-sdk-go/service/provisioning"
"github.com/databricks/databricks-sdk-go/service/settings"
)
type AccountClient struct {
Config *config.Config
// These APIs manage access rules on resources in an account. Currently,
// only grant rules are supported. A grant rule specifies a role assigned to
// a set of principals. A list of rules attached to a resource is called a
// rule set.
AccessControl iam.AccountAccessControlInterface
// This API allows you to download billable usage logs for the specified
// account and date range. This feature works with all account types.
BillableUsage billing.BillableUsageInterface
// These APIs manage credential configurations for this workspace.
// Databricks needs access to a cross-account service IAM role in your AWS
// account so that Databricks can deploy clusters in the appropriate VPC for
// the new workspace. A credential configuration encapsulates this role
// information, and its ID is used when creating a new workspace.
Credentials provisioning.CredentialsInterface
// These APIs enable administrators to manage custom OAuth app integrations,
// which is required for adding/using Custom OAuth App Integration like
// Tableau Cloud for Databricks in AWS cloud.
CustomAppIntegration oauth2.CustomAppIntegrationInterface
// These APIs manage encryption key configurations for this workspace
// (optional). A key configuration encapsulates the AWS KMS key information
// and some information about how the key configuration can be used. There
// are two possible uses for key configurations:
//
// * Managed services: A key configuration can be used to encrypt a
// workspace's notebook and secret data in the control plane, as well as
// Databricks SQL queries and query history. * Storage: A key configuration
// can be used to encrypt a workspace's DBFS and EBS data in the data plane.
//
// In both of these cases, the key configuration's ID is used when creating
// a new workspace. This Preview feature is available if your account is on
// the E2 version of the platform. Updating a running workspace with
// workspace storage encryption requires that the workspace is on the E2
// version of the platform. If you have an older workspace, it might not be
// on the E2 version of the platform. If you are not sure, contact your
// Databricks representative.
EncryptionKeys provisioning.EncryptionKeysInterface
// Groups simplify identity management, making it easier to assign access to
// Databricks account, data, and other securable objects.
//
// It is best practice to assign access to workspaces and access-control
// policies in Unity Catalog to groups, instead of to users individually.
// All Databricks account identities can be assigned as members of groups,
// and members inherit permissions that are assigned to their group.
Groups iam.AccountGroupsInterface
// The Accounts IP Access List API enables account admins to configure IP
// access lists for access to the account console.
//
// Account IP Access Lists affect web application access and REST API access
// to the account console and account APIs. If the feature is disabled for
// the account, all access is allowed for this account. There is support for
// allow lists (inclusion) and block lists (exclusion).
//
// When a connection is attempted: 1. **First, all block lists are
// checked.** If the connection IP address matches any block list, the
// connection is rejected. 2. **If the connection was not rejected by block
// lists**, the IP address is compared with the allow lists.
//
// If there is at least one allow list for the account, the connection is
// allowed only if the IP address matches an allow list. If there are no
// allow lists for the account, all IP addresses are allowed.
//
// For all allow lists and block lists combined, the account supports a
// maximum of 1000 IP/CIDR values, where one CIDR counts as a single value.
//
// After changes to the account-level IP access lists, it can take a few
// minutes for changes to take effect.
IpAccessLists settings.AccountIpAccessListsInterface
// These APIs manage log delivery configurations for this account. The two
// supported log types for this API are _billable usage logs_ and _audit
// logs_. This feature is in Public Preview. This feature works with all
// account ID types.
//
// Log delivery works with all account types. However, if your account is on
// the E2 version of the platform or on a select custom plan that allows
// multiple workspaces per account, you can optionally configure different
// storage destinations for each workspace. Log delivery status is also
// provided to know the latest status of log delivery attempts. The
// high-level flow of billable usage delivery:
//
// 1. **Create storage**: In AWS, [create a new AWS S3 bucket] with a
// specific bucket policy. Using Databricks APIs, call the Account API to
// create a [storage configuration object](:method:Storage/Create) that uses
// the bucket name. 2. **Create credentials**: In AWS, create the
// appropriate AWS IAM role. For full details, including the required IAM
// role policies and trust relationship, see [Billable usage log delivery].
// Using Databricks APIs, call the Account API to create a [credential
// configuration object](:method:Credentials/Create) that uses the IAM
// role"s ARN. 3. **Create log delivery configuration**: Using Databricks
// APIs, call the Account API to [create a log delivery
// configuration](:method:LogDelivery/Create) that uses the credential and
// storage configuration objects from previous steps. You can specify if the
// logs should include all events of that log type in your account (_Account
// level_ delivery) or only events for a specific set of workspaces
// (_workspace level_ delivery). Account level log delivery applies to all
// current and future workspaces plus account level logs, while workspace
// level log delivery solely delivers logs related to the specified
// workspaces. You can create multiple types of delivery configurations per
// account.
//
// For billable usage delivery: * For more information about billable usage
// logs, see [Billable usage log delivery]. For the CSV schema, see the
// [Usage page]. * The delivery location is
// `<bucket-name>/<prefix>/billable-usage/csv/`, where `<prefix>` is the
// name of the optional delivery path prefix you set up during log delivery
// configuration. Files are named
// `workspaceId=<workspace-id>-usageMonth=<month>.csv`. * All billable usage
// logs apply to specific workspaces (_workspace level_ logs). You can
// aggregate usage for your entire account by creating an _account level_
// delivery configuration that delivers logs for all current and future
// workspaces in your account. * The files are delivered daily by
// overwriting the month's CSV file for each workspace.
//
// For audit log delivery: * For more information about about audit log
// delivery, see [Audit log delivery], which includes information about the
// used JSON schema. * The delivery location is
// `<bucket-name>/<delivery-path-prefix>/workspaceId=<workspaceId>/date=<yyyy-mm-dd>/auditlogs_<internal-id>.json`.
// Files may get overwritten with the same content multiple times to achieve
// exactly-once delivery. * If the audit log delivery configuration included
// specific workspace IDs, only _workspace-level_ audit logs for those
// workspaces are delivered. If the log delivery configuration applies to
// the entire account (_account level_ delivery configuration), the audit
// log delivery includes workspace-level audit logs for all workspaces in
// the account as well as account-level audit logs. See [Audit log delivery]
// for details. * Auditable events are typically available in logs within 15
// minutes.
//
// [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
// [Usage page]: https://docs.databricks.com/administration-guide/account-settings/usage.html
// [create a new AWS S3 bucket]: https://docs.databricks.com/administration-guide/account-api/aws-storage.html
LogDelivery billing.LogDeliveryInterface
// These APIs manage metastore assignments to a workspace.
MetastoreAssignments catalog.AccountMetastoreAssignmentsInterface
// These APIs manage Unity Catalog metastores for an account. A metastore
// contains catalogs that can be associated with workspaces
Metastores catalog.AccountMetastoresInterface
// These APIs provide configurations for the network connectivity of your
// workspaces for serverless compute resources.
NetworkConnectivity settings.NetworkConnectivityInterface
// These APIs manage network configurations for customer-managed VPCs
// (optional). Its ID is used when creating a new workspace if you use
// customer-managed VPCs.
Networks provisioning.NetworksInterface
// These APIs enable administrators to view all the available published
// OAuth applications in Databricks. Administrators can add the published
// OAuth applications to their account through the OAuth Published App
// Integration APIs.
OAuthPublishedApps oauth2.OAuthPublishedAppsInterface
// These APIs manage private access settings for this account.
PrivateAccess provisioning.PrivateAccessInterface
// These APIs enable administrators to manage published OAuth app
// integrations, which is required for adding/using Published OAuth App
// Integration like Tableau Desktop for Databricks in AWS cloud.
PublishedAppIntegration oauth2.PublishedAppIntegrationInterface
// These APIs enable administrators to manage service principal secrets.
//
// You can use the generated secrets to obtain OAuth access tokens for a
// service principal, which can then be used to access Databricks Accounts
// and Workspace APIs. For more information, see [Authentication using OAuth
// tokens for service principals],
//
// In addition, the generated secrets can be used to configure the
// Databricks Terraform Provider to authenticate with the service principal.
// For more information, see [Databricks Terraform Provider].
//
// [Authentication using OAuth tokens for service principals]: https://docs.databricks.com/dev-tools/authentication-oauth.html
// [Databricks Terraform Provider]: https://github.com/databricks/terraform-provider-databricks/blob/master/docs/index.md#authenticating-with-service-principal
ServicePrincipalSecrets oauth2.ServicePrincipalSecretsInterface
// Identities for use with jobs, automated tools, and systems such as
// scripts, apps, and CI/CD platforms. Databricks recommends creating
// service principals to run production jobs or modify production data. If
// all processes that act on production data run with service principals,
// interactive users do not need any write, delete, or modify privileges in
// production. This eliminates the risk of a user overwriting production
// data by accident.
ServicePrincipals iam.AccountServicePrincipalsInterface
// Accounts Settings API allows users to manage settings at the account
// level.
Settings settings.AccountSettingsInterface
// These APIs manage storage configurations for this workspace. A root
// storage S3 bucket in your account is required to store objects like
// cluster logs, notebook revisions, and job results. You can also use the
// root storage S3 bucket for storage of non-production DBFS data. A storage
// configuration encapsulates this bucket information, and its ID is used
// when creating a new workspace.
Storage provisioning.StorageInterface
// These APIs manage storage credentials for a particular metastore.
StorageCredentials catalog.AccountStorageCredentialsInterface
// These APIs manage usage dashboards for this account. Usage dashboards
// enable you to gain insights into your usage with pre-built dashboards:
// visualize breakdowns, analyze tag attributions, and identify cost
// drivers.
UsageDashboards billing.UsageDashboardsInterface
// User identities recognized by Databricks and represented by email
// addresses.
//
// Databricks recommends using SCIM provisioning to sync users and groups
// automatically from your identity provider to your Databricks account.
// SCIM streamlines onboarding a new employee or team by using your identity
// provider to create users and groups in Databricks account and give them
// the proper level of access. When a user leaves your organization or no
// longer needs access to Databricks account, admins can terminate the user
// in your identity provider and that user’s account will also be removed
// from Databricks account. This ensures a consistent offboarding process
// and prevents unauthorized users from accessing sensitive data.
Users iam.AccountUsersInterface
// These APIs manage VPC endpoint configurations for this account.
VpcEndpoints provisioning.VpcEndpointsInterface
// The Workspace Permission Assignment API allows you to manage workspace
// permissions for principals in your account.
WorkspaceAssignment iam.WorkspaceAssignmentInterface
// These APIs manage workspaces for this account. A Databricks workspace is
// an environment for accessing all of your Databricks assets. The workspace
// organizes objects (notebooks, libraries, and experiments) into folders,
// and provides access to data and computational resources such as clusters
// and jobs.
//
// These endpoints are available if your account is on the E2 version of the
// platform or on a select custom plan that allows multiple workspaces per
// account.
Workspaces provisioning.WorkspacesInterface
// These APIs manage budget configurations for this account. Budgets enable
// you to monitor usage across your account. You can set up budgets to
// either track account-wide spending, or apply filters to track the
// spending of specific teams, projects, or workspaces.
Budgets billing.BudgetsInterface
}
var ErrNotAccountClient = errors.New("invalid Databricks Account configuration")
// NewAccountClient creates new Databricks SDK client for Accounts or returns
// error in case configuration is wrong
func NewAccountClient(c ...*Config) (*AccountClient, error) {
var cfg *config.Config
if len(c) == 1 {
// first config
cfg = (*config.Config)(c[0])
} else {
// default config
cfg = &config.Config{}
}
err := cfg.EnsureResolved()
if err != nil {
return nil, err
}
if cfg.AccountID == "" || !cfg.IsAccountClient() {
return nil, ErrNotAccountClient
}
apiClient, err := client.New(cfg)
if err != nil {
return nil, err
}
return &AccountClient{
Config: cfg,
AccessControl: iam.NewAccountAccessControl(apiClient),
BillableUsage: billing.NewBillableUsage(apiClient),
Credentials: provisioning.NewCredentials(apiClient),
CustomAppIntegration: oauth2.NewCustomAppIntegration(apiClient),
EncryptionKeys: provisioning.NewEncryptionKeys(apiClient),
Groups: iam.NewAccountGroups(apiClient),
IpAccessLists: settings.NewAccountIpAccessLists(apiClient),
LogDelivery: billing.NewLogDelivery(apiClient),
MetastoreAssignments: catalog.NewAccountMetastoreAssignments(apiClient),
Metastores: catalog.NewAccountMetastores(apiClient),
NetworkConnectivity: settings.NewNetworkConnectivity(apiClient),
Networks: provisioning.NewNetworks(apiClient),
OAuthPublishedApps: oauth2.NewOAuthPublishedApps(apiClient),
PrivateAccess: provisioning.NewPrivateAccess(apiClient),
PublishedAppIntegration: oauth2.NewPublishedAppIntegration(apiClient),
ServicePrincipalSecrets: oauth2.NewServicePrincipalSecrets(apiClient),
ServicePrincipals: iam.NewAccountServicePrincipals(apiClient),
Settings: settings.NewAccountSettings(apiClient),
Storage: provisioning.NewStorage(apiClient),
StorageCredentials: catalog.NewAccountStorageCredentials(apiClient),
UsageDashboards: billing.NewUsageDashboards(apiClient),
Users: iam.NewAccountUsers(apiClient),
VpcEndpoints: provisioning.NewVpcEndpoints(apiClient),
WorkspaceAssignment: iam.NewWorkspaceAssignment(apiClient),
Workspaces: provisioning.NewWorkspaces(apiClient),
Budgets: billing.NewBudgets(apiClient),
}, nil
}