/
resource_digitalocean_database_db.go
109 lines (90 loc) · 2.95 KB
/
resource_digitalocean_database_db.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
package digitalocean
import (
"context"
"fmt"
"log"
"strings"
"github.com/digitalocean/godo"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
"github.com/hashicorp/terraform-plugin-sdk/helper/validation"
)
func resourceDigitalOceanDatabaseDB() *schema.Resource {
return &schema.Resource{
Create: resourceDigitalOceanDatabaseDBCreate,
Read: resourceDigitalOceanDatabaseDBRead,
Delete: resourceDigitalOceanDatabaseDBDelete,
Importer: &schema.ResourceImporter{
State: resourceDigitalOceanDatabaseDBImport,
},
Schema: map[string]*schema.Schema{
"name": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validation.NoZeroValues,
},
"cluster_id": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validation.NoZeroValues,
},
},
}
}
func resourceDigitalOceanDatabaseDBCreate(d *schema.ResourceData, meta interface{}) error {
client := meta.(*CombinedConfig).godoClient()
clusterID := d.Get("cluster_id").(string)
opts := &godo.DatabaseCreateDBRequest{
Name: d.Get("name").(string),
}
log.Printf("[DEBUG] Database DB create configuration: %#v", opts)
db, _, err := client.Databases.CreateDB(context.Background(), clusterID, opts)
if err != nil {
return fmt.Errorf("Error creating Database DB: %s", err)
}
d.SetId(makeDatabaseDBID(clusterID, db.Name))
log.Printf("[INFO] Database DB Name: %s", db.Name)
return resourceDigitalOceanDatabaseDBRead(d, meta)
}
func resourceDigitalOceanDatabaseDBRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*CombinedConfig).godoClient()
clusterID := d.Get("cluster_id").(string)
name := d.Get("name").(string)
// Check if the database DB still exists
_, resp, err := client.Databases.GetDB(context.Background(), clusterID, name)
if err != nil {
// If the database DB is somehow already destroyed, mark as
// successfully gone
if resp != nil && resp.StatusCode == 404 {
d.SetId("")
return nil
}
return fmt.Errorf("Error retrieving Database DB: %s", err)
}
return nil
}
func resourceDigitalOceanDatabaseDBDelete(d *schema.ResourceData, meta interface{}) error {
client := meta.(*CombinedConfig).godoClient()
clusterID := d.Get("cluster_id").(string)
name := d.Get("name").(string)
log.Printf("[INFO] Deleting Database DB: %s", d.Id())
_, err := client.Databases.DeleteDB(context.Background(), clusterID, name)
if err != nil {
return fmt.Errorf("Error deleting Database DB: %s", err)
}
d.SetId("")
return nil
}
func resourceDigitalOceanDatabaseDBImport(d *schema.ResourceData, meta interface{}) ([]*schema.ResourceData, error) {
if strings.Contains(d.Id(), ",") {
s := strings.Split(d.Id(), ",")
d.SetId(makeDatabaseDBID(s[0], s[1]))
d.Set("cluster_id", s[0])
d.Set("name", s[1])
}
return []*schema.ResourceData{d}, nil
}
func makeDatabaseDBID(clusterID string, name string) string {
return fmt.Sprintf("%s/database/%s", clusterID, name)
}