Skip to content

Commit

Permalink
RDS: Improves the invoking api method and supports refreshing credent…
Browse files Browse the repository at this point in the history
…ial automatically
  • Loading branch information
xiaozhu36 committed Feb 1, 2025
1 parent c8488dc commit e454909
Show file tree
Hide file tree
Showing 42 changed files with 352 additions and 1,205 deletions.
27 changes: 0 additions & 27 deletions alicloud/connectivity/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -501,33 +501,6 @@ func (client *AliyunClient) NewVpcClient() (*rpc.Client, error) {
return conn, nil
}

func (client *AliyunClient) NewRdsClient() (*rpc.Client, error) {
productCode := "rds"
endpoint := "rds.aliyuncs.com"
if v, ok := client.config.Endpoints.Load(productCode); !ok || v.(string) == "" {
if err := client.loadEndpoint(productCode); err != nil {
log.Printf("[WARN] %s", err.Error())
log.Printf("[WARN] loading rds endpoint failed and using %s instead.", endpoint)
}
}
if v, ok := client.config.Endpoints.Load(productCode); ok && v.(string) != "" {
endpoint = v.(string)
}
if endpoint == "" {
return nil, fmt.Errorf("[ERROR] missing the product %s endpoint.", productCode)
}

sdkConfig := client.teaSdkConfig
sdkConfig.SetEndpoint(endpoint)

conn, err := rpc.NewClient(&sdkConfig)
if err != nil {
return nil, fmt.Errorf("unable to initialize the %s client: %#v", productCode, err)
}

return conn, nil
}

func (client *AliyunClient) NewPolarDBClient() (*rpc.Client, error) {
productCode := "polardb"
endpoint := ""
Expand Down
10 changes: 2 additions & 8 deletions alicloud/data_source_alicloud_db_instance_class_infos.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import (
"time"

"github.com/PaesslerAG/jsonpath"
util "github.com/alibabacloud-go/tea-utils/service"
"github.com/aliyun/terraform-provider-alicloud/alicloud/connectivity"
"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
Expand Down Expand Up @@ -114,15 +113,10 @@ func dataSourceAlicloudDBInstanceClassInfosRead(d *schema.ResourceData, meta int
}
var ids []string
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
var err error
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
21 changes: 5 additions & 16 deletions alicloud/data_source_alicloud_db_instance_classes.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ import (
"time"

"github.com/PaesslerAG/jsonpath"
util "github.com/alibabacloud-go/tea-utils/service"
"github.com/aliyun/terraform-provider-alicloud/alicloud/connectivity"
"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
Expand Down Expand Up @@ -164,6 +163,7 @@ func dataSourceAlicloudDBInstanceClassesRead(d *schema.ResourceData, meta interf
dbInstanceStorageType, dbInstanceStorageTypeOk = d.GetOk("storage_type")
}
category, categoryOk := d.GetOk("category")
var err error

availableZones := make([]map[string]interface{}, 0)
s := make([]map[string]interface{}, 0)
Expand Down Expand Up @@ -193,15 +193,9 @@ func dataSourceAlicloudDBInstanceClassesRead(d *schema.ResourceData, meta interf
}
}
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down Expand Up @@ -284,17 +278,12 @@ func dataSourceAlicloudDBInstanceClassesRead(d *schema.ResourceData, meta interf
targetStorageType = v.(string)
}
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)

for _, engine := range engines {
request["Engine"] = engine
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down Expand Up @@ -388,7 +377,7 @@ func dataSourceAlicloudDBInstanceClassesRead(d *schema.ResourceData, meta interf
var response map[string]interface{}
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
7 changes: 2 additions & 5 deletions alicloud/data_source_alicloud_db_instance_engines.go
Original file line number Diff line number Diff line change
Expand Up @@ -147,17 +147,14 @@ func dataSourceAlicloudDBInstanceEnginesRead(d *schema.ResourceData, meta interf
var ids []string
var s []map[string]interface{}
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
var err error
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
for _, engine := range engines {
request["Engine"] = engine
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
7 changes: 2 additions & 5 deletions alicloud/data_source_alicloud_db_instances.go
Original file line number Diff line number Diff line change
Expand Up @@ -453,10 +453,7 @@ func dataSourceAlicloudDBInstancesRead(d *schema.ResourceData, meta interface{})
}

var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
var err error

var objects []interface{}

Expand Down Expand Up @@ -485,7 +482,7 @@ func dataSourceAlicloudDBInstancesRead(d *schema.ResourceData, meta interface{})
runtime.SetAutoretry(true)
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
7 changes: 2 additions & 5 deletions alicloud/data_source_alicloud_db_zones.go
Original file line number Diff line number Diff line change
Expand Up @@ -133,17 +133,14 @@ func dataSourceAlicloudDBZonesRead(d *schema.ResourceData, meta interface{}) err
var ids []string
var s []map[string]interface{}
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
var err error
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
for _, engine := range engines {
request["Engine"] = engine
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
10 changes: 2 additions & 8 deletions alicloud/data_source_alicloud_instance_keywords.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import (
"time"

"github.com/PaesslerAG/jsonpath"
util "github.com/alibabacloud-go/tea-utils/service"
"github.com/aliyun/terraform-provider-alicloud/alicloud/connectivity"
"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
Expand Down Expand Up @@ -52,15 +51,10 @@ func dataSourceAlicloudInstanceKeywordsRead(d *schema.ResourceData, meta interfa
var ids []string
var keywords []string
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
var err error
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
7 changes: 2 additions & 5 deletions alicloud/data_source_alicloud_rds_accounts.go
Original file line number Diff line number Diff line change
Expand Up @@ -134,14 +134,11 @@ func dataSourceAlicloudRdsAccountsRead(d *schema.ResourceData, meta interface{})
}
status, statusOk := d.GetOk("status")
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
var err error
for {
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
return WrapErrorf(err, DataDefaultErrorMsg, "alicloud_rds_accounts", action, AlibabaCloudSdkGoERROR)
}
Expand Down
7 changes: 2 additions & 5 deletions alicloud/data_source_alicloud_rds_backups.go
Original file line number Diff line number Diff line change
Expand Up @@ -183,16 +183,13 @@ func dataSourceAlicloudRdsBackupsRead(d *schema.ResourceData, meta interface{})
}
}
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
var err error
for {
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
11 changes: 2 additions & 9 deletions alicloud/data_source_alicloud_rds_character_set_names.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,6 @@ import (

"github.com/PaesslerAG/jsonpath"

util "github.com/alibabacloud-go/tea-utils/service"

"github.com/aliyun/terraform-provider-alicloud/alicloud/connectivity"
"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
Expand Down Expand Up @@ -48,15 +46,10 @@ func dataSourceAlicloudRdsRdsCharacterSetNamesRead(d *schema.ResourceData, meta
}
var response map[string]interface{}
var names []string
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
var err error
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
7 changes: 2 additions & 5 deletions alicloud/data_source_alicloud_rds_class_details.go
Original file line number Diff line number Diff line change
Expand Up @@ -98,13 +98,10 @@ func dataSourceAlicloudRdsRdsClassDetailsRead(d *schema.ResourceData, meta inter
id = v.(string)
}
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
var err error
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
addDebug(action, response, request)
if err != nil {
return WrapErrorf(err, DataDefaultErrorMsg, "alicloud_rds_class_details", action, AlibabaCloudSdkGoERROR)
Expand Down
10 changes: 2 additions & 8 deletions alicloud/data_source_alicloud_rds_collation_time_zones.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,6 @@ import (
"time"

"github.com/PaesslerAG/jsonpath"
util "github.com/alibabacloud-go/tea-utils/service"
"github.com/aliyun/terraform-provider-alicloud/alicloud/connectivity"
"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
Expand Down Expand Up @@ -60,15 +59,10 @@ func dataSourceAlicloudRdsCollationTimeZonesRead(d *schema.ResourceData, meta in

var ids []string
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
var err error
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
9 changes: 3 additions & 6 deletions alicloud/data_source_alicloud_rds_cross_region_backups.go
Original file line number Diff line number Diff line change
Expand Up @@ -202,16 +202,13 @@ func dataSourceAlicloudRdsCrossRegionBackupsRead(d *schema.ResourceData, meta in
}
}
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
var err error
for {
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down Expand Up @@ -259,7 +256,7 @@ func dataSourceAlicloudRdsCrossRegionBackupsRead(d *schema.ResourceData, meta in
runtime.SetAutoretry(true)
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
11 changes: 2 additions & 9 deletions alicloud/data_source_alicloud_rds_cross_regions.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,6 @@ import (

"github.com/PaesslerAG/jsonpath"

util "github.com/alibabacloud-go/tea-utils/service"

"github.com/aliyun/terraform-provider-alicloud/alicloud/connectivity"
"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
Expand Down Expand Up @@ -52,15 +50,10 @@ func dataSourceAlicloudRdsCrossRegionsRead(d *schema.ResourceData, meta interfac
var response map[string]interface{}
var s []map[string]interface{}
var ids []string
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
var err error
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
7 changes: 2 additions & 5 deletions alicloud/data_source_alicloud_rds_modify_parameter_logs.go
Original file line number Diff line number Diff line change
Expand Up @@ -84,16 +84,13 @@ func dataSourceAlicloudRdsModifyParameterLogsRead(d *schema.ResourceData, meta i
request["PageNumber"] = 1
var objects []map[string]interface{}
var response map[string]interface{}
conn, err := client.NewRdsClient()
if err != nil {
return WrapError(err)
}
var err error
for {
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(5*time.Minute, func() *resource.RetryError {
response, err = conn.DoRequest(StringPointer(action), nil, StringPointer("POST"), StringPointer("2014-08-15"), StringPointer("AK"), nil, request, &runtime)
response, err = client.RpcPost("Rds", "2014-08-15", action, nil, request, true)
if err != nil {
if NeedRetry(err) {
wait()
Expand Down
Loading

0 comments on commit e454909

Please sign in to comment.