| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- package main
- import (
- "context"
- "log"
- "cloud.google.com/go/bigtable"
- "google.golang.org/api/option"
- )
- // sliceContains reports whether the provided string is present in the given slice of strings.
- func sliceContains(list []string, target string) bool {
- for _, s := range list {
- if s == target {
- return true
- }
- }
- return false
- }
- // RunSetup will create a table and column families, if they do not already exist.
- func RunSetup(project string, instance string, keyFilePath string) {
- ctx := context.Background()
- // Set up admin client, tables, and column families.
- adminClient, err := bigtable.NewAdminClient(ctx, project, instance, option.WithCredentialsFile(keyFilePath))
- if err != nil {
- log.Fatalf("Could not create admin client: %v", err)
- }
- tables, err := adminClient.Tables(ctx)
- if err != nil {
- log.Fatalf("Could not fetch table list: %v", err)
- }
- if !sliceContains(tables, tableName) {
- log.Printf("Creating table %s", tableName)
- if err := adminClient.CreateTable(ctx, tableName); err != nil {
- log.Fatalf("Could not create table %s: %v", tableName, err)
- }
- }
- tblInfo, err := adminClient.TableInfo(ctx, tableName)
- if err != nil {
- log.Fatalf("Could not read info for table %s: %v", tableName, err)
- }
- for _, familyName := range columnFamilies {
- if !sliceContains(tblInfo.Families, familyName) {
- if err := adminClient.CreateColumnFamily(ctx, tableName, familyName); err != nil {
- log.Fatalf("Could not create column family %s: %v", familyName, err)
- }
- }
- }
- if err = adminClient.Close(); err != nil {
- log.Fatalf("Could not close admin client: %v", err)
- }
- }
|