2017-06-26 22:40:01 +00:00
|
|
|
package google
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2017-07-05 19:54:38 +00:00
|
|
|
"log"
|
2017-06-26 22:40:01 +00:00
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/helper/schema"
|
|
|
|
|
|
|
|
"golang.org/x/net/context"
|
|
|
|
)
|
|
|
|
|
|
|
|
func resourceBigtableTable() *schema.Resource {
|
|
|
|
return &schema.Resource{
|
|
|
|
Create: resourceBigtableTableCreate,
|
|
|
|
Read: resourceBigtableTableRead,
|
|
|
|
Delete: resourceBigtableTableDestroy,
|
|
|
|
|
|
|
|
Schema: map[string]*schema.Schema{
|
|
|
|
"name": {
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"instance_name": {
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Required: true,
|
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
"split_keys": {
|
|
|
|
Type: schema.TypeList,
|
|
|
|
Optional: true,
|
|
|
|
ForceNew: true,
|
|
|
|
Elem: &schema.Schema{Type: schema.TypeString},
|
|
|
|
},
|
|
|
|
|
|
|
|
"project": {
|
|
|
|
Type: schema.TypeString,
|
|
|
|
Optional: true,
|
2017-11-28 00:32:20 +00:00
|
|
|
Computed: true,
|
2017-06-26 22:40:01 +00:00
|
|
|
ForceNew: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceBigtableTableCreate(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
config := meta.(*Config)
|
|
|
|
ctx := context.Background()
|
|
|
|
|
|
|
|
project, err := getProject(d, config)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
instanceName := d.Get("instance_name").(string)
|
|
|
|
c, err := config.bigtableClientFactory.NewAdminClient(project, instanceName)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error starting admin client. %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
defer c.Close()
|
|
|
|
|
|
|
|
name := d.Get("name").(string)
|
|
|
|
if v, ok := d.GetOk("split_keys"); ok {
|
2017-09-05 21:37:02 +00:00
|
|
|
splitKeys := convertStringArr(v.([]interface{}))
|
2017-07-05 16:59:57 +00:00
|
|
|
// This method may return before the table's creation is complete - we may need to wait until
|
|
|
|
// it exists in the future.
|
2017-06-26 22:40:01 +00:00
|
|
|
err = c.CreatePresplitTable(ctx, name, splitKeys)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error creating presplit table. %s", err)
|
|
|
|
}
|
|
|
|
} else {
|
2017-07-05 16:59:57 +00:00
|
|
|
// This method may return before the table's creation is complete - we may need to wait until
|
|
|
|
// it exists in the future.
|
2017-06-26 22:40:01 +00:00
|
|
|
err = c.CreateTable(ctx, name)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error creating table. %s", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
d.SetId(name)
|
|
|
|
|
|
|
|
return resourceBigtableTableRead(d, meta)
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceBigtableTableRead(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
config := meta.(*Config)
|
|
|
|
ctx := context.Background()
|
|
|
|
|
|
|
|
project, err := getProject(d, config)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
instanceName := d.Get("instance_name").(string)
|
|
|
|
c, err := config.bigtableClientFactory.NewAdminClient(project, instanceName)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error starting admin client. %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
defer c.Close()
|
|
|
|
|
|
|
|
name := d.Id()
|
|
|
|
_, err = c.TableInfo(ctx, name)
|
|
|
|
if err != nil {
|
2017-06-28 19:49:12 +00:00
|
|
|
log.Printf("[WARN] Removing %s because it's gone", name)
|
|
|
|
d.SetId("")
|
|
|
|
return fmt.Errorf("Error retrieving table. Could not find %s in %s. %s", name, instanceName, err)
|
2017-06-26 22:40:01 +00:00
|
|
|
}
|
|
|
|
|
2017-11-28 00:32:20 +00:00
|
|
|
d.Set("project", project)
|
|
|
|
|
2017-06-26 22:40:01 +00:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func resourceBigtableTableDestroy(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
config := meta.(*Config)
|
|
|
|
ctx := context.Background()
|
|
|
|
|
|
|
|
project, err := getProject(d, config)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
instanceName := d.Get("instance_name").(string)
|
|
|
|
c, err := config.bigtableClientFactory.NewAdminClient(project, instanceName)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Error starting admin client. %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
defer c.Close()
|
|
|
|
|
|
|
|
name := d.Get("name").(string)
|
|
|
|
err = c.DeleteTable(ctx, name)
|
|
|
|
if err != nil {
|
2017-07-05 16:59:57 +00:00
|
|
|
return fmt.Errorf("Error deleting table. %s", err)
|
2017-06-26 22:40:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
d.SetId("")
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|