providers/ionoscloud/dbaas_pgsql_database.go (49 lines of code) (raw):
package ionoscloud
import (
"context"
"log"
"github.com/GoogleCloudPlatform/terraformer/providers/ionoscloud/helpers"
"github.com/GoogleCloudPlatform/terraformer/terraformutils"
)
type DBaaSPgSQLDatabaseGenerator struct {
Service
}
func (g *DBaaSPgSQLDatabaseGenerator) InitResources() error {
client := g.generateClient()
dbaasPgSQLClient := client.DBaaSPgSQLApiClient
resourceType := "ionoscloud_pg_database"
response, _, err := dbaasPgSQLClient.ClustersApi.ClustersGet(context.TODO()).Execute()
if err != nil {
return err
}
if response.Items == nil {
log.Printf("[WARNING] expected a response containing PgSQL DB clusters but received 'nil' instead")
}
clusters := *response.Items
for _, cluster := range clusters {
databasesResponse, _, err := dbaasPgSQLClient.DatabasesApi.DatabasesList(context.TODO(), *cluster.Id).Execute()
if err != nil {
return err
}
if databasesResponse.Items == nil {
log.Printf("[WARNING] expected a response containing PgSQL databases but received 'nil' instead, skipping search for PgSQL cluster with ID: %v", *cluster.Id)
continue
}
databases := *databasesResponse.Items
for _, database := range databases {
if database.Properties == nil || database.Properties.Name == nil {
log.Printf("[WARNING] 'nil' values in the response for PgSQL database with ID: %v, skipping this resource", *database.Id)
continue
}
g.Resources = append(g.Resources, terraformutils.NewResource(
*database.Id,
*database.Properties.Name+"-"+*database.Id,
resourceType,
helpers.Ionos,
map[string]string{helpers.ClusterID: *cluster.Id, helpers.NameArg: *database.Properties.Name},
[]string{},
map[string]interface{}{}))
}
}
return nil
}