alicloud/resource_alicloud_rocketmq_acl.go (226 lines of code) (raw):
// Package alicloud. This file is generated automatically. Please do not modify it manually, thank you!
package alicloud
import (
"fmt"
"log"
"strings"
"time"
"github.com/aliyun/terraform-provider-alicloud/alicloud/connectivity"
"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
)
func resourceAliCloudRocketmqAcl() *schema.Resource {
return &schema.Resource{
Create: resourceAliCloudRocketmqAclCreate,
Read: resourceAliCloudRocketmqAclRead,
Update: resourceAliCloudRocketmqAclUpdate,
Delete: resourceAliCloudRocketmqAclDelete,
Importer: &schema.ResourceImporter{
State: schema.ImportStatePassthrough,
},
Timeouts: &schema.ResourceTimeout{
Create: schema.DefaultTimeout(5 * time.Minute),
Update: schema.DefaultTimeout(5 * time.Minute),
Delete: schema.DefaultTimeout(5 * time.Minute),
},
Schema: map[string]*schema.Schema{
"actions": {
Type: schema.TypeList,
Required: true,
Elem: &schema.Schema{Type: schema.TypeString},
},
"decision": {
Type: schema.TypeString,
Required: true,
ValidateFunc: StringInSlice([]string{"Deny", "Allow"}, false),
},
"instance_id": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
},
"ip_whitelists": {
Type: schema.TypeList,
Optional: true,
Computed: true,
Elem: &schema.Schema{Type: schema.TypeString},
},
"resource_name": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
},
"resource_type": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
ValidateFunc: StringInSlice([]string{"Group", "Topic"}, false),
},
"username": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
},
},
}
}
func resourceAliCloudRocketmqAclCreate(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
instanceId := d.Get("instance_id")
username := d.Get("username")
action := fmt.Sprintf("/instances/%s/acl/account/%s", instanceId, username)
var request map[string]interface{}
var response map[string]interface{}
query := make(map[string]*string)
body := make(map[string]interface{})
var err error
request = make(map[string]interface{})
request["resourceType"] = d.Get("resource_type")
request["resourceName"] = d.Get("resource_name")
request["decision"] = d.Get("decision")
if v, ok := d.GetOk("ip_whitelists"); ok {
ipWhitelistsMapsArray := v.([]interface{})
request["ipWhitelists"] = ipWhitelistsMapsArray
}
if v, ok := d.GetOk("actions"); ok {
actionsMapsArray := v.([]interface{})
request["actions"] = actionsMapsArray
}
body = request
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutCreate), func() *resource.RetryError {
response, err = client.RoaPost("RocketMQ", "2022-08-01", action, query, nil, body, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
return nil
})
addDebug(action, response, request)
if err != nil {
return WrapErrorf(err, DefaultErrorMsg, "alicloud_rocketmq_acl", action, AlibabaCloudSdkGoERROR)
}
d.SetId(fmt.Sprintf("%v:%v:%v:%v", instanceId, username, request["resourceType"], request["resourceName"]))
return resourceAliCloudRocketmqAclRead(d, meta)
}
func resourceAliCloudRocketmqAclRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
rocketmqServiceV2 := RocketmqServiceV2{client}
objectRaw, err := rocketmqServiceV2.DescribeRocketmqAcl(d.Id())
if err != nil {
if !d.IsNewResource() && NotFoundError(err) {
log.Printf("[DEBUG] Resource alicloud_rocketmq_acl DescribeRocketmqAcl Failed!!! %s", err)
d.SetId("")
return nil
}
return WrapError(err)
}
d.Set("decision", objectRaw["decision"])
d.Set("instance_id", objectRaw["instanceId"])
d.Set("resource_name", objectRaw["resourceName"])
d.Set("resource_type", objectRaw["resourceType"])
d.Set("username", objectRaw["username"])
actionsRaw := make([]interface{}, 0)
if objectRaw["actions"] != nil {
actionsRaw = objectRaw["actions"].([]interface{})
}
d.Set("actions", actionsRaw)
ipWhitelistsRaw := make([]interface{}, 0)
if objectRaw["ipWhitelists"] != nil {
ipWhitelistsRaw = objectRaw["ipWhitelists"].([]interface{})
}
d.Set("ip_whitelists", ipWhitelistsRaw)
return nil
}
func resourceAliCloudRocketmqAclUpdate(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
var request map[string]interface{}
var response map[string]interface{}
var query map[string]*string
var body map[string]interface{}
update := false
var err error
parts := strings.Split(d.Id(), ":")
instanceId := parts[0]
username := parts[1]
action := fmt.Sprintf("/instances/%s/acl/account/%s", instanceId, username)
request = make(map[string]interface{})
query = make(map[string]*string)
body = make(map[string]interface{})
request["resourceType"] = parts[2]
request["resourceName"] = parts[3]
if d.HasChange("ip_whitelists") {
update = true
}
if v, ok := d.GetOk("ip_whitelists"); ok {
ipWhitelistsMapsArray := v.([]interface{})
request["ipWhitelists"] = ipWhitelistsMapsArray
}
if d.HasChange("actions") {
update = true
}
if v, ok := d.GetOk("actions"); ok {
actionsMapsArray := v.([]interface{})
request["actions"] = actionsMapsArray
}
if d.HasChange("decision") {
update = true
}
request["decision"] = d.Get("decision")
body = request
if update {
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutUpdate), func() *resource.RetryError {
response, err = client.RoaPatch("RocketMQ", "2022-08-01", action, query, nil, body, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
return nil
})
addDebug(action, response, request)
if err != nil {
return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR)
}
}
return resourceAliCloudRocketmqAclRead(d, meta)
}
func resourceAliCloudRocketmqAclDelete(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
parts := strings.Split(d.Id(), ":")
instanceId := parts[0]
username := parts[1]
action := fmt.Sprintf("/instances/%s/acl/account/%s", instanceId, username)
var request map[string]interface{}
var response map[string]interface{}
query := make(map[string]*string)
var err error
request = make(map[string]interface{})
query["resourceType"] = StringPointer(parts[2])
query["resourceName"] = StringPointer(parts[3])
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError {
response, err = client.RoaDelete("RocketMQ", "2022-08-01", action, query, nil, nil, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
return nil
})
addDebug(action, response, request)
if err != nil {
if NotFoundError(err) {
return nil
}
return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR)
}
return nil
}