-
Notifications
You must be signed in to change notification settings - Fork 187
Expand file tree
/
Copy pathdatabase_instance.go
More file actions
70 lines (59 loc) · 2.45 KB
/
Copy pathdatabase_instance.go
File metadata and controls
70 lines (59 loc) · 2.45 KB
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
package dresources
import (
"context"
"time"
"github.com/databricks/cli/bundle/config/resources"
"github.com/databricks/databricks-sdk-go"
"github.com/databricks/databricks-sdk-go/service/database"
)
type ResourceDatabaseInstance struct {
client *databricks.WorkspaceClient
}
func (*ResourceDatabaseInstance) New(client *databricks.WorkspaceClient) *ResourceDatabaseInstance {
return &ResourceDatabaseInstance{client: client}
}
func (*ResourceDatabaseInstance) PrepareState(input *resources.DatabaseInstance) *database.DatabaseInstance {
return &input.DatabaseInstance
}
func (d *ResourceDatabaseInstance) DoRead(ctx context.Context, id string) (*database.DatabaseInstance, error) {
return d.client.Database.GetDatabaseInstanceByName(ctx, id)
}
func (d *ResourceDatabaseInstance) DoCreate(ctx context.Context, config *database.DatabaseInstance) (string, *database.DatabaseInstance, error) {
waiter, err := d.client.Database.CreateDatabaseInstance(ctx, database.CreateDatabaseInstanceRequest{
DatabaseInstance: *config,
})
if err != nil {
return "", nil, err
}
return waiter.Response.Name, nil, nil
}
func (d *ResourceDatabaseInstance) DoUpdate(ctx context.Context, id string, config *database.DatabaseInstance, _ *PlanEntry) (*database.DatabaseInstance, error) {
request := database.UpdateDatabaseInstanceRequest{
DatabaseInstance: *config,
Name: config.Name,
UpdateMask: "*",
}
request.DatabaseInstance.Uid = id
_, err := d.client.Database.UpdateDatabaseInstance(ctx, request)
return nil, err
}
func (d *ResourceDatabaseInstance) WaitAfterCreate(ctx context.Context, id string, config *database.DatabaseInstance) (*database.DatabaseInstance, error) {
waiter := &database.WaitGetDatabaseInstanceDatabaseAvailable[database.DatabaseInstance]{
Response: config,
Name: config.Name,
Poll: func(timeout time.Duration, callback func(*database.DatabaseInstance)) (*database.DatabaseInstance, error) {
return d.client.Database.WaitGetDatabaseInstanceDatabaseAvailable(ctx, config.Name, timeout, callback)
},
}
// _ is remoteState, should we return it here?
_, err := waiter.GetWithTimeout(20 * time.Minute)
return nil, err
}
func (d *ResourceDatabaseInstance) DoDelete(ctx context.Context, name string, _ *database.DatabaseInstance) error {
return d.client.Database.DeleteDatabaseInstance(ctx, database.DeleteDatabaseInstanceRequest{
Name: name,
Purge: true,
Force: false,
ForceSendFields: nil,
})
}