alicloud/resource_alicloud_esa_origin_pool.go (407 lines of code) (raw):
package alicloud
import (
"encoding/json"
"fmt"
"log"
"strconv"
"strings"
"time"
"github.com/PaesslerAG/jsonpath"
"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 resourceAliCloudEsaOriginPool() *schema.Resource {
return &schema.Resource{
Create: resourceAliCloudEsaOriginPoolCreate,
Read: resourceAliCloudEsaOriginPoolRead,
Update: resourceAliCloudEsaOriginPoolUpdate,
Delete: resourceAliCloudEsaOriginPoolDelete,
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{
"enabled": {
Type: schema.TypeBool,
Optional: true,
},
"origin_pool_id": {
Type: schema.TypeInt,
Computed: true,
},
"origin_pool_name": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
},
"origins": {
Type: schema.TypeList,
Optional: true,
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
"type": {
Type: schema.TypeString,
Optional: true,
},
"address": {
Type: schema.TypeString,
Optional: true,
},
"header": {
Type: schema.TypeString,
Optional: true,
DiffSuppressFunc: func(k, old, new string, d *schema.ResourceData) bool {
equal, _ := compareJsonTemplateAreEquivalent(old, new)
return equal
},
},
"enabled": {
Type: schema.TypeBool,
Optional: true,
},
"origin_id": {
Type: schema.TypeInt,
Computed: true,
},
"auth_conf": {
Type: schema.TypeList,
Optional: true,
MaxItems: 1,
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
"secret_key": {
Type: schema.TypeString,
Optional: true,
Sensitive: true,
//DiffSuppressFunc: func(k, old, new string, d *schema.ResourceData) bool {
// return comparePrefixSuffix(old, new, 5)
//},
},
"version": {
Type: schema.TypeString,
Optional: true,
},
"region": {
Type: schema.TypeString,
Optional: true,
},
"auth_type": {
Type: schema.TypeString,
Optional: true,
},
"access_key": {
Type: schema.TypeString,
Optional: true,
},
},
},
},
"weight": {
Type: schema.TypeInt,
Optional: true,
},
"name": {
Type: schema.TypeString,
Optional: true,
},
},
},
},
"site_id": {
Type: schema.TypeInt,
Required: true,
ForceNew: true,
},
},
}
}
func resourceAliCloudEsaOriginPoolCreate(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
action := "CreateOriginPool"
var request map[string]interface{}
var response map[string]interface{}
query := make(map[string]interface{})
var err error
request = make(map[string]interface{})
if v, ok := d.GetOk("site_id"); ok {
request["SiteId"] = v
}
request["RegionId"] = client.RegionId
if v, ok := d.GetOk("origins"); ok {
originsMapsArray := make([]interface{}, 0)
for _, dataLoop := range v.([]interface{}) {
dataLoopTmp := dataLoop.(map[string]interface{})
dataLoopMap := make(map[string]interface{})
dataLoopMap["Address"] = dataLoopTmp["address"]
dataLoopMap["Header"] = parseHeader(dataLoopTmp["header"].(string))
dataLoopMap["Type"] = dataLoopTmp["type"]
localData1 := make(map[string]interface{})
version1, _ := jsonpath.Get("$[0].version", dataLoopTmp["auth_conf"])
if version1 != nil && version1 != "" {
localData1["Version"] = version1
}
authType1, _ := jsonpath.Get("$[0].auth_type", dataLoopTmp["auth_conf"])
if authType1 != nil && authType1 != "" {
localData1["AuthType"] = authType1
}
accessKey1, _ := jsonpath.Get("$[0].access_key", dataLoopTmp["auth_conf"])
if accessKey1 != nil && accessKey1 != "" {
localData1["AccessKey"] = accessKey1
}
secretKey1, _ := jsonpath.Get("$[0].secret_key", dataLoopTmp["auth_conf"])
if secretKey1 != nil && secretKey1 != "" {
localData1["SecretKey"] = secretKey1
}
region1, _ := jsonpath.Get("$[0].region", dataLoopTmp["auth_conf"])
if region1 != nil && region1 != "" {
localData1["Region"] = region1
}
dataLoopMap["AuthConf"] = localData1
dataLoopMap["Weight"] = dataLoopTmp["weight"]
dataLoopMap["Enabled"] = dataLoopTmp["enabled"]
dataLoopMap["Name"] = dataLoopTmp["name"]
originsMapsArray = append(originsMapsArray, dataLoopMap)
}
originsMapsJson, err := json.Marshal(originsMapsArray)
if err != nil {
return WrapError(err)
}
request["Origins"] = string(originsMapsJson)
}
request["Name"] = d.Get("origin_pool_name")
if v, ok := d.GetOkExists("enabled"); ok {
request["Enabled"] = v
}
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutCreate), func() *resource.RetryError {
response, err = client.RpcPost("ESA", "2024-09-10", action, query, request, 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_esa_origin_pool", action, AlibabaCloudSdkGoERROR)
}
d.SetId(fmt.Sprintf("%v:%v", request["SiteId"], response["Id"]))
return resourceAliCloudEsaOriginPoolRead(d, meta)
}
func resourceAliCloudEsaOriginPoolRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
esaServiceV2 := EsaServiceV2{client}
objectRaw, err := esaServiceV2.DescribeEsaOriginPool(d.Id())
if err != nil {
if !d.IsNewResource() && NotFoundError(err) {
log.Printf("[DEBUG] Resource alicloud_esa_origin_pool DescribeEsaOriginPool Failed!!! %s", err)
d.SetId("")
return nil
}
return WrapError(err)
}
d.Set("enabled", objectRaw["Enabled"])
d.Set("origin_pool_name", objectRaw["Name"])
d.Set("origin_pool_id", objectRaw["Id"])
d.Set("site_id", objectRaw["SiteId"])
secretKeyMap := make(map[string]interface{})
if origins, ok := d.GetOk("origins"); ok {
for _, dataLoop := range origins.([]interface{}) {
dataLoopTmp := dataLoop.(map[string]interface{})
originName := fmt.Sprint(dataLoopTmp["name"])
if !IsNil(dataLoopTmp["auth_conf"]) {
secretKey1, _ := jsonpath.Get("$[0].secret_key", dataLoopTmp["auth_conf"])
if secretKey1 != nil && secretKey1 != "" {
secretKeyMap[originName] = secretKey1
}
}
}
}
originsRaw := objectRaw["Origins"]
originsMaps := make([]map[string]interface{}, 0)
if originsRaw != nil {
for _, originsChildRaw := range originsRaw.([]interface{}) {
originsMap := make(map[string]interface{})
originsChildRaw := originsChildRaw.(map[string]interface{})
originsMap["address"] = originsChildRaw["Address"]
originsMap["enabled"] = originsChildRaw["Enabled"]
originsMap["header"] = convertObjectToJsonString(originsChildRaw["Header"])
originsMap["name"] = originsChildRaw["Name"]
originsMap["origin_id"] = originsChildRaw["Id"]
originsMap["type"] = originsChildRaw["Type"]
originsMap["weight"] = originsChildRaw["Weight"]
authConfMaps := make([]map[string]interface{}, 0)
authConfMap := make(map[string]interface{})
authConfRaw := make(map[string]interface{})
if originsChildRaw["AuthConf"] != nil {
authConfRaw = originsChildRaw["AuthConf"].(map[string]interface{})
}
if len(authConfRaw) > 0 {
authConfMap["access_key"] = authConfRaw["AccessKey"]
authConfMap["auth_type"] = authConfRaw["AuthType"]
authConfMap["region"] = authConfRaw["Region"]
authConfMap["secret_key"] = authConfRaw["SecretKey"]
originName := fmt.Sprint(originsMap["name"])
if sk, ok := secretKeyMap[originName]; ok {
authConfMap["secret_key"] = sk
}
authConfMap["version"] = authConfRaw["Version"]
authConfMaps = append(authConfMaps, authConfMap)
}
originsMap["auth_conf"] = authConfMaps
originsMaps = append(originsMaps, originsMap)
}
}
if err := d.Set("origins", originsMaps); err != nil {
return err
}
return nil
}
func resourceAliCloudEsaOriginPoolUpdate(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
update := false
var err error
parts := strings.Split(d.Id(), ":")
action := "UpdateOriginPool"
request = make(map[string]interface{})
query = make(map[string]interface{})
request["SiteId"] = parts[0]
request["Id"] = parts[1]
request["RegionId"] = client.RegionId
if d.HasChange("origins") {
update = true
if v, ok := d.GetOk("origins"); ok || d.HasChange("origins") {
originsMapsArray := make([]interface{}, 0)
for _, dataLoop := range v.([]interface{}) {
dataLoopTmp := dataLoop.(map[string]interface{})
dataLoopMap := make(map[string]interface{})
dataLoopMap["Address"] = dataLoopTmp["address"]
dataLoopMap["Header"] = parseHeader(dataLoopTmp["header"].(string))
dataLoopMap["Type"] = dataLoopTmp["type"]
if !IsNil(dataLoopTmp["auth_conf"]) {
localData1 := make(map[string]interface{})
version1, _ := jsonpath.Get("$[0].version", dataLoopTmp["auth_conf"])
if version1 != nil && version1 != "" {
localData1["Version"] = version1
}
authType1, _ := jsonpath.Get("$[0].auth_type", dataLoopTmp["auth_conf"])
if authType1 != nil && authType1 != "" {
localData1["AuthType"] = authType1
}
accessKey1, _ := jsonpath.Get("$[0].access_key", dataLoopTmp["auth_conf"])
if accessKey1 != nil && accessKey1 != "" {
localData1["AccessKey"] = accessKey1
}
secretKey1, _ := jsonpath.Get("$[0].secret_key", dataLoopTmp["auth_conf"])
if secretKey1 != nil && secretKey1 != "" {
localData1["SecretKey"] = secretKey1
}
region1, _ := jsonpath.Get("$[0].region", dataLoopTmp["auth_conf"])
if region1 != nil && region1 != "" {
localData1["Region"] = region1
}
dataLoopMap["AuthConf"] = localData1
}
dataLoopMap["Weight"] = dataLoopTmp["weight"]
dataLoopMap["Enabled"] = dataLoopTmp["enabled"]
dataLoopMap["Name"] = dataLoopTmp["name"]
originsMapsArray = append(originsMapsArray, dataLoopMap)
}
originsMapsJson, err := json.Marshal(originsMapsArray)
if err != nil {
return WrapError(err)
}
request["Origins"] = string(originsMapsJson)
}
}
if d.HasChange("enabled") {
update = true
request["Enabled"] = d.Get("enabled")
}
if update {
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutUpdate), func() *resource.RetryError {
response, err = client.RpcPost("ESA", "2024-09-10", action, query, request, 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 resourceAliCloudEsaOriginPoolRead(d, meta)
}
func resourceAliCloudEsaOriginPoolDelete(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
parts := strings.Split(d.Id(), ":")
action := "DeleteOriginPool"
var request map[string]interface{}
var response map[string]interface{}
query := make(map[string]interface{})
var err error
request = make(map[string]interface{})
request["SiteId"] = parts[0]
request["Id"] = parts[1]
request["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError {
response, err = client.RpcPost("ESA", "2024-09-10", action, query, request, 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
}
func parseHeader(input string) interface{} {
if b, err := strconv.ParseBool(input); err == nil {
return b
}
if i, err := strconv.Atoi(input); err == nil {
return i
}
if f, err := strconv.ParseFloat(input, 64); err == nil {
return f
}
var obj map[string]interface{}
if err := json.Unmarshal([]byte(input), &obj); err == nil {
return obj
}
var arr []interface{}
if err := json.Unmarshal([]byte(input), &arr); err == nil {
return arr
}
return input
}
func comparePrefixSuffix(s1, s2 string, length int) bool {
if len(s1) < length || len(s2) < length {
return false
}
return s1[:length] == s2[:length] && s1[len(s1)-length:] == s2[len(s2)-length:]
}