terraform-provider-greenhost/digitalocean/resource_digitalocean_datab...

200 lines
5.0 KiB
Go

package digitalocean
import (
"context"
"fmt"
"log"
"strings"
"github.com/digitalocean/godo"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/validation"
)
func resourceDigitalOceanDatabaseConnectionPool() *schema.Resource {
return &schema.Resource{
Create: resourceDigitalOceanDatabaseConnectionPoolCreate,
Read: resourceDigitalOceanDatabaseConnectionPoolRead,
Delete: resourceDigitalOceanDatabaseConnectionPoolDelete,
Importer: &schema.ResourceImporter{
State: resourceDigitalOceanDatabaseConnectionPoolImport,
},
Schema: map[string]*schema.Schema{
"cluster_id": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validation.NoZeroValues,
},
"name": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validation.StringLenBetween(3, 63),
},
"user": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validation.NoZeroValues,
},
"mode": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validation.StringInSlice([]string{
"session",
"transaction",
"statement"}, false),
},
"size": {
Type: schema.TypeInt,
Required: true,
ForceNew: true,
ValidateFunc: validation.NoZeroValues,
},
"db_name": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: validation.NoZeroValues,
},
"host": {
Type: schema.TypeString,
Computed: true,
},
"private_host": {
Type: schema.TypeString,
Computed: true,
},
"port": {
Type: schema.TypeInt,
Computed: true,
},
"uri": {
Type: schema.TypeString,
Computed: true,
Sensitive: true,
},
"private_uri": {
Type: schema.TypeString,
Computed: true,
Sensitive: true,
},
"password": {
Type: schema.TypeString,
Computed: true,
Sensitive: true,
},
},
}
}
func resourceDigitalOceanDatabaseConnectionPoolCreate(d *schema.ResourceData, meta interface{}) error {
client := meta.(*CombinedConfig).godoClient()
clusterID := d.Get("cluster_id").(string)
opts := &godo.DatabaseCreatePoolRequest{
Name: d.Get("name").(string),
User: d.Get("user").(string),
Mode: d.Get("mode").(string),
Size: d.Get("size").(int),
Database: d.Get("db_name").(string),
}
log.Printf("[DEBUG] DatabaseConnectionPool create configuration: %#v", opts)
pool, _, err := client.Databases.CreatePool(context.Background(), clusterID, opts)
if err != nil {
return fmt.Errorf("Error creating DatabaseConnectionPool: %s", err)
}
d.SetId(createConnectionPoolID(clusterID, pool.Name))
log.Printf("[INFO] DatabaseConnectionPool Name: %s", pool.Name)
return resourceDigitalOceanDatabaseConnectionPoolRead(d, meta)
}
func resourceDigitalOceanDatabaseConnectionPoolRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*CombinedConfig).godoClient()
clusterID, poolName := splitConnectionPoolID(d.Id())
pool, resp, err := client.Databases.GetPool(context.Background(), clusterID, poolName)
if err != nil {
// If the pool is somehow already destroyed, mark as
// successfully gone
if resp.StatusCode == 404 {
d.SetId("")
return nil
}
return fmt.Errorf("Error retrieving DatabaseConnectionPool: %s", err)
}
d.SetId(createConnectionPoolID(clusterID, pool.Name))
d.Set("cluster_id", clusterID)
d.Set("name", pool.Name)
d.Set("user", pool.User)
d.Set("mode", pool.Mode)
d.Set("size", pool.Size)
d.Set("db_name", pool.Database)
// Computed values
d.Set("host", pool.Connection.Host)
d.Set("private_host", pool.PrivateConnection.Host)
d.Set("port", pool.Connection.Port)
d.Set("uri", pool.Connection.URI)
d.Set("private_uri", pool.PrivateConnection.URI)
d.Set("password", pool.Connection.Password)
return nil
}
func resourceDigitalOceanDatabaseConnectionPoolImport(d *schema.ResourceData, meta interface{}) ([]*schema.ResourceData, error) {
if strings.Contains(d.Id(), ",") {
s := strings.Split(d.Id(), ",")
d.SetId(createConnectionPoolID(s[0], s[1]))
d.Set("cluster_id", s[0])
d.Set("name", s[1])
}
return []*schema.ResourceData{d}, nil
}
func resourceDigitalOceanDatabaseConnectionPoolDelete(d *schema.ResourceData, meta interface{}) error {
client := meta.(*CombinedConfig).godoClient()
clusterID, poolName := splitConnectionPoolID(d.Id())
log.Printf("[INFO] Deleting DatabaseConnectionPool: %s", poolName)
_, err := client.Databases.DeletePool(context.Background(), clusterID, poolName)
if err != nil {
return fmt.Errorf("Error deleting DatabaseConnectionPool: %s", err)
}
d.SetId("")
return nil
}
func createConnectionPoolID(clusterID string, poolName string) string {
return fmt.Sprintf("%s/%s", clusterID, poolName)
}
func splitConnectionPoolID(id string) (string, string) {
splitID := strings.Split(id, "/")
clusterID := splitID[0]
poolName := splitID[1]
return clusterID, poolName
}