From 963992bb68d523d4bc2069c129a01e49b009d435 Mon Sep 17 00:00:00 2001
From: houpeng80 <114376095+houpeng80@users.noreply.github.com>
Date: Mon, 20 Jan 2025 19:42:40 +0800
Subject: [PATCH] feat(GaussDB): add gaussdb opengauss tags (#6225)
---
.../gaussdb_opengauss_predefined_tags.md | 41 +++++++
docs/data-sources/gaussdb_opengauss_tags.md | 41 +++++++
huaweicloud/provider.go | 2 +
..._gaussdb_opengauss_predefined_tags_test.go | 35 ++++++
...huaweicloud_gaussdb_opengauss_tags_test.go | 109 +++++++++++++++++
...cloud_gaussdb_opengauss_predefined_tags.go | 110 ++++++++++++++++++
...urce_huaweicloud_gaussdb_opengauss_tags.go | 110 ++++++++++++++++++
7 files changed, 448 insertions(+)
create mode 100644 docs/data-sources/gaussdb_opengauss_predefined_tags.md
create mode 100644 docs/data-sources/gaussdb_opengauss_tags.md
create mode 100644 huaweicloud/services/acceptance/gaussdb/data_source_huaweicloud_gaussdb_opengauss_predefined_tags_test.go
create mode 100644 huaweicloud/services/acceptance/gaussdb/data_source_huaweicloud_gaussdb_opengauss_tags_test.go
create mode 100644 huaweicloud/services/gaussdb/data_source_huaweicloud_gaussdb_opengauss_predefined_tags.go
create mode 100644 huaweicloud/services/gaussdb/data_source_huaweicloud_gaussdb_opengauss_tags.go
diff --git a/docs/data-sources/gaussdb_opengauss_predefined_tags.md b/docs/data-sources/gaussdb_opengauss_predefined_tags.md
new file mode 100644
index 0000000000..264a7fa6dc
--- /dev/null
+++ b/docs/data-sources/gaussdb_opengauss_predefined_tags.md
@@ -0,0 +1,41 @@
+---
+subcategory: "GaussDB"
+layout: "huaweicloud"
+page_title: "HuaweiCloud: huaweicloud_gaussdb_opengauss_predefined_tags"
+description: |-
+ Use this data source to get the list of predefined tags.
+---
+
+# huaweicloud_gaussdb_opengauss_predefined_tags
+
+Use this data source to get the list of predefined tags.
+
+## Example Usage
+
+```hcl
+data "huaweicloud_gaussdb_opengauss_tags" "test" {}
+```
+
+## Argument Reference
+
+The following arguments are supported:
+
+* `region` - (Optional, String) Specifies the region in which to query the resource.
+ If omitted, the provider-level region will be used.
+
+## Attribute Reference
+
+In addition to all arguments above, the following attributes are exported:
+
+* `id` - The data source ID.
+
+* `tags` - The tags.
+
+ The [tags](#tags_struct) structure is documented below.
+
+
+The `tags` block supports:
+
+* `key` - Indicates the tag key.
+
+* `values` - Indicates the tag values.
diff --git a/docs/data-sources/gaussdb_opengauss_tags.md b/docs/data-sources/gaussdb_opengauss_tags.md
new file mode 100644
index 0000000000..8d06f4970d
--- /dev/null
+++ b/docs/data-sources/gaussdb_opengauss_tags.md
@@ -0,0 +1,41 @@
+---
+subcategory: "GaussDB"
+layout: "huaweicloud"
+page_title: "HuaweiCloud: huaweicloud_gaussdb_opengauss_tags"
+description: |-
+ Use this data source to get the all user tags in a project.
+---
+
+# huaweicloud_gaussdb_opengauss_tags
+
+Use this data source to get the all user tags in a project.
+
+## Example Usage
+
+```hcl
+data "huaweicloud_gaussdb_opengauss_tags" "test" {}
+```
+
+## Argument Reference
+
+The following arguments are supported:
+
+* `region` - (Optional, String) Specifies the region in which to query the resource.
+ If omitted, the provider-level region will be used.
+
+## Attribute Reference
+
+In addition to all arguments above, the following attributes are exported:
+
+* `id` - The data source ID.
+
+* `tags` - Indicates the tags of the project.
+
+ The [tags](#tags_struct) structure is documented below.
+
+
+The `tags` block supports:
+
+* `key` - Indicates the tag key.
+
+* `values` - Indicates the tag values.
diff --git a/huaweicloud/provider.go b/huaweicloud/provider.go
index f311817760..161702e3b9 100644
--- a/huaweicloud/provider.go
+++ b/huaweicloud/provider.go
@@ -855,6 +855,8 @@ func Provider() *schema.Provider {
"huaweicloud_gaussdb_opengauss_tasks": gaussdb.DataSourceOpenGaussTasks(),
"huaweicloud_gaussdb_opengauss_quotas": gaussdb.DataSourceGaussdbOpengaussQuotas(),
"huaweicloud_gaussdb_opengauss_upgrade_versions": gaussdb.DataSourceGaussdbOpengaussUpgradeVersions(),
+ "huaweicloud_gaussdb_opengauss_tags": gaussdb.DataSourceOpenGaussTags(),
+ "huaweicloud_gaussdb_opengauss_predefined_tags": gaussdb.DataSourceOpenGaussPredefinedTags(),
"huaweicloud_gaussdb_mysql_engine_versions": taurusdb.DataSourceGaussdbMysqlEngineVersions(),
"huaweicloud_gaussdb_mysql_configuration": taurusdb.DataSourceGaussdbMysqlConfiguration(),
diff --git a/huaweicloud/services/acceptance/gaussdb/data_source_huaweicloud_gaussdb_opengauss_predefined_tags_test.go b/huaweicloud/services/acceptance/gaussdb/data_source_huaweicloud_gaussdb_opengauss_predefined_tags_test.go
new file mode 100644
index 0000000000..bbcb4e9b4d
--- /dev/null
+++ b/huaweicloud/services/acceptance/gaussdb/data_source_huaweicloud_gaussdb_opengauss_predefined_tags_test.go
@@ -0,0 +1,35 @@
+package gaussdb
+
+import (
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
+
+ "github.com/huaweicloud/terraform-provider-huaweicloud/huaweicloud/services/acceptance"
+)
+
+func TestAccDataSourceOpenGaussPredefinedTags_basic(t *testing.T) {
+ dataSource := "data.huaweicloud_gaussdb_opengauss_predefined_tags.test"
+ dc := acceptance.InitDataSourceCheck(dataSource)
+
+ resource.ParallelTest(t, resource.TestCase{
+ PreCheck: func() {
+ acceptance.TestAccPreCheck(t)
+ },
+ ProviderFactories: acceptance.TestAccProviderFactories,
+ Steps: []resource.TestStep{
+ {
+ Config: testDataSourceOpenGaussPredefined_basic(),
+ Check: resource.ComposeTestCheckFunc(
+ dc.CheckResourceExists(),
+ resource.TestCheckResourceAttrSet(dataSource, "tags.0.key"),
+ resource.TestCheckResourceAttrSet(dataSource, "tags.0.values.#"),
+ ),
+ },
+ },
+ })
+}
+
+func testDataSourceOpenGaussPredefined_basic() string {
+ return `data "huaweicloud_gaussdb_opengauss_predefined_tags" "test" {}`
+}
diff --git a/huaweicloud/services/acceptance/gaussdb/data_source_huaweicloud_gaussdb_opengauss_tags_test.go b/huaweicloud/services/acceptance/gaussdb/data_source_huaweicloud_gaussdb_opengauss_tags_test.go
new file mode 100644
index 0000000000..d1f1aa0688
--- /dev/null
+++ b/huaweicloud/services/acceptance/gaussdb/data_source_huaweicloud_gaussdb_opengauss_tags_test.go
@@ -0,0 +1,109 @@
+package gaussdb
+
+import (
+ "fmt"
+ "testing"
+
+ "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
+
+ "github.com/huaweicloud/terraform-provider-huaweicloud/huaweicloud/services/acceptance"
+ "github.com/huaweicloud/terraform-provider-huaweicloud/huaweicloud/services/acceptance/common"
+)
+
+func TestAccDataSourceOpenGaussTags_basic(t *testing.T) {
+ dataSource := "data.huaweicloud_gaussdb_opengauss_tags.test"
+ rName := acceptance.RandomAccResourceName()
+ dc := acceptance.InitDataSourceCheck(dataSource)
+
+ resource.ParallelTest(t, resource.TestCase{
+ PreCheck: func() {
+ acceptance.TestAccPreCheck(t)
+ },
+ ProviderFactories: acceptance.TestAccProviderFactories,
+ Steps: []resource.TestStep{
+ {
+ Config: testDataSourceOpenGaussTags_basic(rName),
+ Check: resource.ComposeTestCheckFunc(
+ dc.CheckResourceExists(),
+ resource.TestCheckResourceAttrSet(dataSource, "tags.0.key"),
+ resource.TestCheckResourceAttrSet(dataSource, "tags.0.values.#"),
+ ),
+ },
+ },
+ })
+}
+
+func testDataSourceOpenGaussTags_base(name string) string {
+ return fmt.Sprintf(`
+%[1]s
+
+data "huaweicloud_availability_zones" "test" {}
+
+data "huaweicloud_gaussdb_opengauss_flavors" "test" {
+ version = "8.201"
+ ha_mode = "centralization_standard"
+}
+
+resource "huaweicloud_networking_secgroup_rule" "in_v4_tcp_opengauss" {
+ security_group_id = huaweicloud_networking_secgroup.test.id
+ ethertype = "IPv4"
+ direction = "ingress"
+ protocol = "tcp"
+ remote_ip_prefix = "0.0.0.0/0"
+}
+
+resource "huaweicloud_networking_secgroup_rule" "in_v4_tcp_opengauss_egress" {
+ security_group_id = huaweicloud_networking_secgroup.test.id
+ ethertype = "IPv4"
+ direction = "egress"
+ protocol = "tcp"
+ remote_ip_prefix = "0.0.0.0/0"
+}
+
+resource "huaweicloud_gaussdb_opengauss_instance" "test" {
+ depends_on = [
+ huaweicloud_networking_secgroup_rule.in_v4_tcp_opengauss,
+ huaweicloud_networking_secgroup_rule.in_v4_tcp_opengauss_egress
+ ]
+
+ vpc_id = huaweicloud_vpc.test.id
+ subnet_id = huaweicloud_vpc_subnet.test.id
+ security_group_id = huaweicloud_networking_secgroup.test.id
+ flavor = data.huaweicloud_gaussdb_opengauss_flavors.test.flavors[0].spec_code
+ name = "%[2]s"
+ password = "Huangwei!120521"
+ enterprise_project_id = "%[3]s"
+
+ availability_zone = join(",", [data.huaweicloud_availability_zones.test.names[0],
+ data.huaweicloud_availability_zones.test.names[1],
+ data.huaweicloud_availability_zones.test.names[2]])
+
+ ha {
+ mode = "centralization_standard"
+ replication_mode = "sync"
+ consistency = "eventual"
+ instance_mode = "basic"
+ }
+
+ volume {
+ type = "ULTRAHIGH"
+ size = 40
+ }
+
+ tags = {
+ key = "value"
+ owner = "terraform"
+ }
+}
+`, common.TestBaseNetwork(name), name, acceptance.HW_ENTERPRISE_PROJECT_ID_TEST)
+}
+
+func testDataSourceOpenGaussTags_basic(name string) string {
+ return fmt.Sprintf(`
+%s
+
+data "huaweicloud_gaussdb_opengauss_tags" "test" {
+ depends_on = [huaweicloud_gaussdb_opengauss_instance.test]
+}
+`, testDataSourceOpenGaussTags_base(name))
+}
diff --git a/huaweicloud/services/gaussdb/data_source_huaweicloud_gaussdb_opengauss_predefined_tags.go b/huaweicloud/services/gaussdb/data_source_huaweicloud_gaussdb_opengauss_predefined_tags.go
new file mode 100644
index 0000000000..52b496999d
--- /dev/null
+++ b/huaweicloud/services/gaussdb/data_source_huaweicloud_gaussdb_opengauss_predefined_tags.go
@@ -0,0 +1,110 @@
+package gaussdb
+
+import (
+ "context"
+ "strings"
+
+ "github.com/hashicorp/go-multierror"
+ "github.com/hashicorp/go-uuid"
+ "github.com/hashicorp/terraform-plugin-sdk/v2/diag"
+ "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
+
+ "github.com/chnsz/golangsdk"
+
+ "github.com/huaweicloud/terraform-provider-huaweicloud/huaweicloud/config"
+ "github.com/huaweicloud/terraform-provider-huaweicloud/huaweicloud/utils"
+)
+
+// @API GaussDB GET /v3/{project_id}/predefined-tags
+func DataSourceOpenGaussPredefinedTags() *schema.Resource {
+ return &schema.Resource{
+ ReadContext: dataSourceOpenGaussPredefinedTagsRead,
+
+ Schema: map[string]*schema.Schema{
+ "region": {
+ Type: schema.TypeString,
+ Optional: true,
+ Computed: true,
+ },
+ "tags": {
+ Type: schema.TypeList,
+ Computed: true,
+ Description: `Indicates the list of tags.`,
+ Elem: &schema.Resource{
+ Schema: map[string]*schema.Schema{
+ "key": {
+ Type: schema.TypeString,
+ Computed: true,
+ },
+ "values": {
+ Type: schema.TypeList,
+ Computed: true,
+ Elem: &schema.Schema{Type: schema.TypeString},
+ },
+ },
+ },
+ },
+ },
+ }
+}
+
+func dataSourceOpenGaussPredefinedTagsRead(_ context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics {
+ cfg := meta.(*config.Config)
+ region := cfg.GetRegion(d)
+
+ var mErr *multierror.Error
+
+ var (
+ httpUrl = "v3/{project_id}/predefined-tags"
+ product = "opengauss"
+ )
+ client, err := cfg.NewServiceClient(product, region)
+ if err != nil {
+ return diag.Errorf("error creating GaussDB Client: %s", err)
+ }
+
+ getPath := client.Endpoint + httpUrl
+ getPath = strings.ReplaceAll(getPath, "{project_id}", client.ProjectID)
+
+ getOpt := golangsdk.RequestOpts{
+ KeepResponseBody: true,
+ }
+ getResp, err := client.Request("GET", getPath, &getOpt)
+ if err != nil {
+ return diag.Errorf("error retrieving GaussDB OpenGauss predefined tags: %s", err)
+ }
+
+ getRespBody, err := utils.FlattenResponse(getResp)
+ if err != nil {
+ return diag.FromErr(err)
+ }
+
+ dataSourceId, err := uuid.GenerateUUID()
+ if err != nil {
+ return diag.Errorf("unable to generate ID: %s", err)
+ }
+ d.SetId(dataSourceId)
+
+ mErr = multierror.Append(
+ mErr,
+ d.Set("region", region),
+ d.Set("tags", flattenOpenGaussPredefinedTagsResponseBody(getRespBody)),
+ )
+ return diag.FromErr(mErr.ErrorOrNil())
+}
+
+func flattenOpenGaussPredefinedTagsResponseBody(resp interface{}) []interface{} {
+ if resp == nil {
+ return nil
+ }
+ curJson := utils.PathSearch("tags", resp, make([]interface{}, 0))
+ curArray := curJson.([]interface{})
+ rst := make([]interface{}, 0, len(curArray))
+ for _, v := range curArray {
+ rst = append(rst, map[string]interface{}{
+ "key": utils.PathSearch("key", v, nil),
+ "values": utils.PathSearch("values", v, nil),
+ })
+ }
+ return rst
+}
diff --git a/huaweicloud/services/gaussdb/data_source_huaweicloud_gaussdb_opengauss_tags.go b/huaweicloud/services/gaussdb/data_source_huaweicloud_gaussdb_opengauss_tags.go
new file mode 100644
index 0000000000..87ec968d63
--- /dev/null
+++ b/huaweicloud/services/gaussdb/data_source_huaweicloud_gaussdb_opengauss_tags.go
@@ -0,0 +1,110 @@
+package gaussdb
+
+import (
+ "context"
+ "strings"
+
+ "github.com/hashicorp/go-multierror"
+ "github.com/hashicorp/go-uuid"
+ "github.com/hashicorp/terraform-plugin-sdk/v2/diag"
+ "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
+
+ "github.com/chnsz/golangsdk"
+
+ "github.com/huaweicloud/terraform-provider-huaweicloud/huaweicloud/config"
+ "github.com/huaweicloud/terraform-provider-huaweicloud/huaweicloud/utils"
+)
+
+// @API GaussDB GET /v3/{project_id}/tags
+func DataSourceOpenGaussTags() *schema.Resource {
+ return &schema.Resource{
+ ReadContext: dataSourceOpenGaussTagsRead,
+
+ Schema: map[string]*schema.Schema{
+ "region": {
+ Type: schema.TypeString,
+ Optional: true,
+ Computed: true,
+ },
+ "tags": {
+ Type: schema.TypeList,
+ Computed: true,
+ Description: `Indicates the list of tags.`,
+ Elem: &schema.Resource{
+ Schema: map[string]*schema.Schema{
+ "key": {
+ Type: schema.TypeString,
+ Computed: true,
+ },
+ "values": {
+ Type: schema.TypeList,
+ Computed: true,
+ Elem: &schema.Schema{Type: schema.TypeString},
+ },
+ },
+ },
+ },
+ },
+ }
+}
+
+func dataSourceOpenGaussTagsRead(_ context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics {
+ cfg := meta.(*config.Config)
+ region := cfg.GetRegion(d)
+
+ var mErr *multierror.Error
+
+ var (
+ httpUrl = "v3/{project_id}/tags"
+ product = "opengauss"
+ )
+ client, err := cfg.NewServiceClient(product, region)
+ if err != nil {
+ return diag.Errorf("error creating GaussDB Client: %s", err)
+ }
+
+ getPath := client.Endpoint + httpUrl
+ getPath = strings.ReplaceAll(getPath, "{project_id}", client.ProjectID)
+
+ getOpt := golangsdk.RequestOpts{
+ KeepResponseBody: true,
+ }
+ getResp, err := client.Request("GET", getPath, &getOpt)
+ if err != nil {
+ return diag.Errorf("error retrieving GaussDB OpenGauss tags: %s", err)
+ }
+
+ getRespBody, err := utils.FlattenResponse(getResp)
+ if err != nil {
+ return diag.FromErr(err)
+ }
+
+ dataSourceId, err := uuid.GenerateUUID()
+ if err != nil {
+ return diag.Errorf("unable to generate ID: %s", err)
+ }
+ d.SetId(dataSourceId)
+
+ mErr = multierror.Append(
+ mErr,
+ d.Set("region", region),
+ d.Set("tags", flattenOpenGaussTagsResponseBody(getRespBody)),
+ )
+ return diag.FromErr(mErr.ErrorOrNil())
+}
+
+func flattenOpenGaussTagsResponseBody(resp interface{}) []interface{} {
+ if resp == nil {
+ return nil
+ }
+ curJson := utils.PathSearch("tags", resp, make([]interface{}, 0))
+ curArray := curJson.([]interface{})
+ rst := make([]interface{}, 0, len(curArray))
+ for _, v := range curArray {
+ rst = append(rst, map[string]interface{}{
+ "key": utils.PathSearch("key", v, nil),
+ "values": utils.PathSearch("values", v, nil),
+ })
+ }
+ return rst
+}