alicloud/resource_alicloud_cloud_phone_policy.go (366 lines of code) (raw):
// Package alicloud. This file is generated automatically. Please do not modify it manually, thank you!
package alicloud
import (
"encoding/json"
"fmt"
"log"
"regexp"
"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 resourceAliCloudCloudPhonePolicy() *schema.Resource {
return &schema.Resource{
Create: resourceAliCloudCloudPhonePolicyCreate,
Read: resourceAliCloudCloudPhonePolicyRead,
Update: resourceAliCloudCloudPhonePolicyUpdate,
Delete: resourceAliCloudCloudPhonePolicyDelete,
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{
"camera_redirect": {
Type: schema.TypeString,
Optional: true,
Computed: true,
ValidateFunc: StringInSlice([]string{"on", "off"}, false),
},
"clipboard": {
Type: schema.TypeString,
Optional: true,
Computed: true,
ValidateFunc: StringInSlice([]string{"read", "write", "readwrite", "off"}, false),
},
"lock_resolution": {
Type: schema.TypeString,
Optional: true,
Computed: true,
ValidateFunc: StringInSlice([]string{"on", "off"}, false),
},
"net_redirect_policy": {
Type: schema.TypeList,
Optional: true,
Computed: true,
MaxItems: 1,
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
"proxy_user_name": {
Type: schema.TypeString,
Optional: true,
},
"port": {
Type: schema.TypeString,
Optional: true,
ValidateFunc: StringMatch(regexp.MustCompile("^\\d+$"), "Transparent proxy port. The Port value range is 1\\~ 65535."),
},
"net_redirect": {
Type: schema.TypeString,
Optional: true,
Computed: true,
ValidateFunc: StringInSlice([]string{"on", "off"}, false),
},
"proxy_password": {
Type: schema.TypeString,
Optional: true,
},
"proxy_type": {
Type: schema.TypeString,
Optional: true,
ValidateFunc: StringInSlice([]string{"socks5"}, false),
},
"host_addr": {
Type: schema.TypeString,
Optional: true,
ValidateFunc: StringMatch(regexp.MustCompile("^(\\d{0,3}\\.){3}\\d{0,3}$"), "The transparent proxy IP address. The format is IPv4 address."),
},
"custom_proxy": {
Type: schema.TypeString,
Optional: true,
Computed: true,
ValidateFunc: StringInSlice([]string{"on", "off"}, false),
},
},
},
},
"policy_group_name": {
Type: schema.TypeString,
Optional: true,
Computed: true,
},
"resolution_height": {
Type: schema.TypeInt,
Optional: true,
Computed: true,
ValidateFunc: IntInSlice([]int{0, 640, 720, 940, 1280, 1920}),
},
"resolution_width": {
Type: schema.TypeInt,
Optional: true,
Computed: true,
ValidateFunc: IntInSlice([]int{0, 480, 536, 720, 800, 1080}),
},
},
}
}
func resourceAliCloudCloudPhonePolicyCreate(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
action := "CreatePolicyGroup"
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.GetOkExists("resolution_width"); ok {
request["ResolutionWidth"] = v
}
if v, ok := d.GetOk("policy_group_name"); ok {
request["PolicyGroupName"] = v
}
if v, ok := d.GetOk("clipboard"); ok {
request["Clipboard"] = v
}
objectDataLocalMap := make(map[string]interface{})
if v := d.Get("net_redirect_policy"); !IsNil(v) {
hostAddr1, _ := jsonpath.Get("$[0].host_addr", v)
if hostAddr1 != nil && hostAddr1 != "" {
objectDataLocalMap["HostAddr"] = hostAddr1
}
netRedirect1, _ := jsonpath.Get("$[0].net_redirect", v)
if netRedirect1 != nil && netRedirect1 != "" {
objectDataLocalMap["NetRedirect"] = netRedirect1
}
proxyPassword1, _ := jsonpath.Get("$[0].proxy_password", v)
if proxyPassword1 != nil && proxyPassword1 != "" {
objectDataLocalMap["ProxyPassword"] = proxyPassword1
}
proxyUserName1, _ := jsonpath.Get("$[0].proxy_user_name", v)
if proxyUserName1 != nil && proxyUserName1 != "" {
objectDataLocalMap["ProxyUserName"] = proxyUserName1
}
customProxy1, _ := jsonpath.Get("$[0].custom_proxy", v)
if customProxy1 != nil && customProxy1 != "" {
objectDataLocalMap["CustomProxy"] = customProxy1
}
port1, _ := jsonpath.Get("$[0].port", v)
if port1 != nil && port1 != "" {
objectDataLocalMap["Port"] = port1
}
proxyType1, _ := jsonpath.Get("$[0].proxy_type", v)
if proxyType1 != nil && proxyType1 != "" {
objectDataLocalMap["ProxyType"] = proxyType1
}
objectDataLocalMapJson, err := json.Marshal(objectDataLocalMap)
if err != nil {
return WrapError(err)
}
request["NetRedirectPolicy"] = string(objectDataLocalMapJson)
}
if v, ok := d.GetOk("camera_redirect"); ok {
request["CameraRedirect"] = v
}
if v, ok := d.GetOk("lock_resolution"); ok {
request["LockResolution"] = v
}
if v, ok := d.GetOkExists("resolution_height"); ok {
request["ResolutionHeight"] = v
}
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutCreate), func() *resource.RetryError {
response, err = client.RpcPost("eds-aic", "2023-09-30", 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_cloud_phone_policy", action, AlibabaCloudSdkGoERROR)
}
d.SetId(fmt.Sprint(response["PolicyGroupId"]))
return resourceAliCloudCloudPhonePolicyRead(d, meta)
}
func resourceAliCloudCloudPhonePolicyRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
cloudPhoneServiceV2 := CloudPhoneServiceV2{client}
objectRaw, err := cloudPhoneServiceV2.DescribeCloudPhonePolicy(d.Id())
if err != nil {
if !d.IsNewResource() && NotFoundError(err) {
log.Printf("[DEBUG] Resource alicloud_cloud_phone_policy DescribeCloudPhonePolicy Failed!!! %s", err)
d.SetId("")
return nil
}
return WrapError(err)
}
d.Set("camera_redirect", objectRaw["CameraRedirect"])
d.Set("clipboard", objectRaw["Clipboard"])
d.Set("lock_resolution", objectRaw["LockResolution"])
d.Set("policy_group_name", objectRaw["PolicyGroupName"])
d.Set("resolution_height", objectRaw["SessionResolutionHeight"])
d.Set("resolution_width", objectRaw["SessionResolutionWidth"])
netRedirectPolicyMaps := make([]map[string]interface{}, 0)
netRedirectPolicyMap := make(map[string]interface{})
netRedirectPolicyRaw := make(map[string]interface{})
if objectRaw["NetRedirectPolicy"] != nil {
netRedirectPolicyRaw = objectRaw["NetRedirectPolicy"].(map[string]interface{})
}
if len(netRedirectPolicyRaw) > 0 {
netRedirectPolicyMap["custom_proxy"] = netRedirectPolicyRaw["CustomProxy"]
netRedirectPolicyMap["host_addr"] = netRedirectPolicyRaw["HostAddr"]
netRedirectPolicyMap["net_redirect"] = netRedirectPolicyRaw["NetRedirect"]
netRedirectPolicyMap["port"] = netRedirectPolicyRaw["Port"]
netRedirectPolicyMap["proxy_password"] = netRedirectPolicyRaw["ProxyPassword"]
netRedirectPolicyMap["proxy_type"] = netRedirectPolicyRaw["ProxyType"]
netRedirectPolicyMap["proxy_user_name"] = netRedirectPolicyRaw["ProxyUserName"]
netRedirectPolicyMaps = append(netRedirectPolicyMaps, netRedirectPolicyMap)
}
if err := d.Set("net_redirect_policy", netRedirectPolicyMaps); err != nil {
return err
}
return nil
}
func resourceAliCloudCloudPhonePolicyUpdate(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
action := "ModifyPolicyGroup"
request = make(map[string]interface{})
query = make(map[string]interface{})
request["PolicyGroupId"] = d.Id()
if d.HasChange("resolution_width") {
update = true
}
if v, ok := d.GetOk("resolution_width"); ok || d.HasChange("resolution_width") {
request["ResolutionWidth"] = v
}
if d.HasChange("policy_group_name") {
update = true
}
if v, ok := d.GetOk("policy_group_name"); ok || d.HasChange("policy_group_name") {
request["PolicyGroupName"] = v
}
if d.HasChange("clipboard") {
update = true
}
if v, ok := d.GetOk("clipboard"); ok || d.HasChange("clipboard") {
request["Clipboard"] = v
}
if d.HasChange("net_redirect_policy") {
update = true
}
objectDataLocalMap := make(map[string]interface{})
if v := d.Get("net_redirect_policy"); v != nil {
hostAddr1, _ := jsonpath.Get("$[0].host_addr", v)
if hostAddr1 != nil && (d.HasChange("net_redirect_policy.0.host_addr") || hostAddr1 != "") {
objectDataLocalMap["HostAddr"] = hostAddr1
}
netRedirect1, _ := jsonpath.Get("$[0].net_redirect", v)
if netRedirect1 != nil && (d.HasChange("net_redirect_policy.0.net_redirect") || netRedirect1 != "") {
objectDataLocalMap["NetRedirect"] = netRedirect1
}
proxyPassword1, _ := jsonpath.Get("$[0].proxy_password", v)
if proxyPassword1 != nil && (d.HasChange("net_redirect_policy.0.proxy_password") || proxyPassword1 != "") {
objectDataLocalMap["ProxyPassword"] = proxyPassword1
}
proxyUserName1, _ := jsonpath.Get("$[0].proxy_user_name", v)
if proxyUserName1 != nil && (d.HasChange("net_redirect_policy.0.proxy_user_name") || proxyUserName1 != "") {
objectDataLocalMap["ProxyUserName"] = proxyUserName1
}
customProxy1, _ := jsonpath.Get("$[0].custom_proxy", v)
if customProxy1 != nil && (d.HasChange("net_redirect_policy.0.custom_proxy") || customProxy1 != "") {
objectDataLocalMap["CustomProxy"] = customProxy1
}
port1, _ := jsonpath.Get("$[0].port", v)
if port1 != nil && (d.HasChange("net_redirect_policy.0.port") || port1 != "") {
objectDataLocalMap["Port"] = port1
}
proxyType1, _ := jsonpath.Get("$[0].proxy_type", v)
if proxyType1 != nil && (d.HasChange("net_redirect_policy.0.proxy_type") || proxyType1 != "") {
objectDataLocalMap["ProxyType"] = proxyType1
}
objectDataLocalMapJson, err := json.Marshal(objectDataLocalMap)
if err != nil {
return WrapError(err)
}
request["NetRedirectPolicy"] = string(objectDataLocalMapJson)
}
if d.HasChange("camera_redirect") {
update = true
}
if v, ok := d.GetOk("camera_redirect"); ok || d.HasChange("camera_redirect") {
request["CameraRedirect"] = v
}
if d.HasChange("lock_resolution") {
update = true
}
if v, ok := d.GetOk("lock_resolution"); ok || d.HasChange("lock_resolution") {
request["LockResolution"] = v
}
if d.HasChange("resolution_height") {
update = true
}
if v, ok := d.GetOk("resolution_height"); ok || d.HasChange("resolution_height") {
request["ResolutionHeight"] = v
}
if update {
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutUpdate), func() *resource.RetryError {
response, err = client.RpcPost("eds-aic", "2023-09-30", 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 resourceAliCloudCloudPhonePolicyRead(d, meta)
}
func resourceAliCloudCloudPhonePolicyDelete(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
action := "DeletePolicyGroup"
var request map[string]interface{}
var response map[string]interface{}
query := make(map[string]interface{})
var err error
request = make(map[string]interface{})
request["PolicyGroupIds.1"] = d.Id()
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError {
response, err = client.RpcPost("eds-aic", "2023-09-30", 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
}