alicloud/service_alicloud_arms_v2.go (711 lines of code) (raw):
package alicloud
import (
"fmt"
"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"
)
type ArmsServiceV2 struct {
client *connectivity.AliyunClient
}
// DescribeArmsPrometheusMonitoring <<< Encapsulated get interface for Arms PrometheusMonitoring.
func (s *ArmsServiceV2) DescribeArmsPrometheusMonitoring(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
parts := strings.Split(id, ":")
if len(parts) != 3 {
err = WrapError(fmt.Errorf("invalid Resource Id %s. Expected parts' length %d, got %d", id, 3, len(parts)))
}
action := "GetPrometheusMonitoring"
request = make(map[string]interface{})
query = make(map[string]interface{})
query["ClusterId"] = parts[0]
query["MonitoringName"] = parts[1]
query["Type"] = parts[2]
request["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", action, query, request, false)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
code, _ := jsonpath.Get("$.Code", response)
if InArray(fmt.Sprint(code), []string{"404"}) {
return object, WrapErrorf(NotFoundErr("PrometheusMonitoring", id), NotFoundMsg, ProviderERROR, fmt.Sprint(response["RequestId"]))
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(NotFoundErr("PrometheusMonitoring", id), NotFoundMsg, ProviderERROR, fmt.Sprint(response["RequestId"]))
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsPrometheusMonitoringStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsPrometheusMonitoring(id)
if err != nil {
if NotFoundError(err) {
return object, "", nil
}
return nil, "", WrapError(err)
}
currentStatus := fmt.Sprint(object[field])
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsPrometheusMonitoring >>> Encapsulated.
// DescribeArmsRemoteWrite <<< Encapsulated get interface for Arms RemoteWrite.
func (s *ArmsServiceV2) DescribeArmsRemoteWrite(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
parts := strings.Split(id, ":")
if len(parts) != 2 {
err = WrapError(fmt.Errorf("invalid Resource Id %s. Expected parts' length %d, got %d", id, 2, len(parts)))
}
action := "GetPrometheusRemoteWrite"
request = make(map[string]interface{})
query = make(map[string]interface{})
query["ClusterId"] = parts[0]
query["RemoteWriteName"] = parts[1]
request["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", action, query, request, false)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
code, _ := jsonpath.Get("$.Code", response)
if InArray(fmt.Sprint(code), []string{"404"}) {
return object, WrapErrorf(NotFoundErr("RemoteWrite", id), NotFoundMsg, ProviderERROR, fmt.Sprint(response["RequestId"]))
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(err, FailedGetAttributeMsg, id, "$.Data", response)
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsRemoteWriteStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsRemoteWrite(id)
if err != nil {
if NotFoundError(err) {
return object, "", nil
}
return nil, "", WrapError(err)
}
currentStatus := fmt.Sprint(object[field])
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsRemoteWrite >>> Encapsulated.
// DescribeArmsEnvironment <<< Encapsulated get interface for Arms Environment.
func (s *ArmsServiceV2) DescribeArmsEnvironment(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
action := "DescribeEnvironment"
request = make(map[string]interface{})
query = make(map[string]interface{})
query["EnvironmentId"] = id
query["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", action, query, request, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
code, _ := jsonpath.Get("$.Code", response)
if InArray(fmt.Sprint(code), []string{"404"}) {
return object, WrapErrorf(NotFoundErr("Environment", id), NotFoundMsg, response)
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(err, FailedGetAttributeMsg, id, "$.Data", response)
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsEnvironmentStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsEnvironment(id)
if err != nil {
if NotFoundError(err) {
return object, "", nil
}
return nil, "", WrapError(err)
}
v, err := jsonpath.Get(field, object)
currentStatus := fmt.Sprint(v)
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsEnvironment >>> Encapsulated.
// SetResourceTags <<< Encapsulated tag function for Arms.
func (s *ArmsServiceV2) SetResourceTags(d *schema.ResourceData, resourceType string) error {
if d.HasChange("tags") {
var action string
var err error
client := s.client
var request map[string]interface{}
var response map[string]interface{}
query := make(map[string]interface{})
added, removed := parsingTags(d)
removedTagKeys := make([]string, 0)
for _, v := range removed {
if !ignoredTags(v, "") {
removedTagKeys = append(removedTagKeys, v)
}
}
if len(removedTagKeys) > 0 {
action = "UntagResources"
request = make(map[string]interface{})
query = make(map[string]interface{})
request["ResourceId.1"] = d.Id()
request["RegionId"] = client.RegionId
for i, key := range removedTagKeys {
request[fmt.Sprintf("TagKey.%d", i+1)] = key
}
request["ResourceType"] = resourceType
for i, key := range removedTagKeys {
request[fmt.Sprintf("TagKey.%d", i+1)] = key
}
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutUpdate), func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", 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)
}
}
if len(added) > 0 {
action = "TagResources"
request = make(map[string]interface{})
query = make(map[string]interface{})
request["ResourceId.1"] = d.Id()
request["RegionId"] = client.RegionId
count := 1
for key, value := range added {
request[fmt.Sprintf("Tag.%d.Key", count)] = key
request[fmt.Sprintf("Tag.%d.Value", count)] = value
count++
}
request["ResourceType"] = resourceType
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutUpdate), func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", 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 nil
}
// SetResourceTags >>> tag function encapsulated.
// DescribeArmsPrometheus <<< Encapsulated get interface for Arms Prometheus.
func (s *ArmsServiceV2) DescribeArmsPrometheus(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
action := "GetPrometheusInstance"
request = make(map[string]interface{})
query = make(map[string]interface{})
query["ClusterId"] = id
request["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", action, query, request, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
code, _ := jsonpath.Get("$.Code", response)
if InArray(fmt.Sprint(code), []string{"404"}) {
return object, WrapErrorf(NotFoundErr("Prometheus", id), NotFoundMsg, response)
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(err, FailedGetAttributeMsg, id, "$.Data", response)
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsPrometheusStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsPrometheus(id)
if err != nil {
if NotFoundError(err) {
return object, "", nil
}
return nil, "", WrapError(err)
}
v, err := jsonpath.Get(field, object)
currentStatus := fmt.Sprint(v)
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsPrometheus >>> Encapsulated.
// DescribeArmsEnvFeature <<< Encapsulated get interface for Arms EnvFeature.
func (s *ArmsServiceV2) DescribeArmsEnvFeature(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
parts := strings.Split(id, ":")
if len(parts) != 2 {
err = WrapError(fmt.Errorf("invalid Resource Id %s. Expected parts' length %d, got %d", id, 2, len(parts)))
}
action := "DescribeEnvironmentFeature"
request = make(map[string]interface{})
query = make(map[string]interface{})
query["FeatureName"] = parts[1]
query["EnvironmentId"] = parts[0]
request["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", action, query, request, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
code, _ := jsonpath.Get("$.Code", response)
if InArray(fmt.Sprint(code), []string{"404", "14000"}) {
return object, WrapErrorf(NotFoundErr("EnvFeature", id), NotFoundMsg, response)
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(err, FailedGetAttributeMsg, id, "$.Data", response)
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsEnvFeatureStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsEnvFeature(id)
if err != nil {
if NotFoundError(err) {
return object, "", nil
}
return nil, "", WrapError(err)
}
v, err := jsonpath.Get(field, object)
currentStatus := fmt.Sprint(v)
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsEnvFeature >>> Encapsulated.
// DescribeArmsAddonRelease <<< Encapsulated get interface for Arms AddonRelease.
func (s *ArmsServiceV2) DescribeArmsAddonRelease(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
parts := strings.Split(id, ":")
if len(parts) != 2 {
err = WrapError(fmt.Errorf("invalid Resource Id %s. Expected parts' length %d, got %d", id, 2, len(parts)))
}
action := "DescribeAddonRelease"
request = make(map[string]interface{})
query = make(map[string]interface{})
query["ReleaseName"] = parts[1]
query["EnvironmentId"] = parts[0]
request["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", action, query, request, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
code, _ := jsonpath.Get("$.Code", response)
if InArray(fmt.Sprint(code), []string{"404"}) {
return object, WrapErrorf(NotFoundErr("AddonRelease", id), NotFoundMsg, response)
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(err, FailedGetAttributeMsg, id, "$.Data", response)
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsAddonReleaseStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsAddonRelease(id)
if err != nil {
if NotFoundError(err) {
return nil, "", nil
}
return nil, "", WrapError(err)
}
v, err := jsonpath.Get(field, object)
currentStatus := fmt.Sprint(v)
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsAddonRelease >>> Encapsulated.
// DescribeArmsEnvPodMonitor <<< Encapsulated get interface for Arms EnvPodMonitor.
func (s *ArmsServiceV2) DescribeArmsEnvPodMonitor(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
parts := strings.Split(id, ":")
if len(parts) != 3 {
err = WrapError(fmt.Errorf("invalid Resource Id %s. Expected parts' length %d, got %d", id, 3, len(parts)))
}
action := "DescribeEnvPodMonitor"
request = make(map[string]interface{})
query = make(map[string]interface{})
query["PodMonitorName"] = parts[2]
query["EnvironmentId"] = parts[0]
query["Namespace"] = parts[1]
request["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", action, query, request, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
code, _ := jsonpath.Get("$.Code", response)
if InArray(fmt.Sprint(code), []string{"404"}) {
return object, WrapErrorf(NotFoundErr("EnvPodMonitor", id), NotFoundMsg, response)
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(err, FailedGetAttributeMsg, id, "$.Data", response)
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsEnvPodMonitorStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsEnvPodMonitor(id)
if err != nil {
if NotFoundError(err) {
return object, "", nil
}
return nil, "", WrapError(err)
}
v, err := jsonpath.Get(field, object)
currentStatus := fmt.Sprint(v)
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsEnvPodMonitor >>> Encapsulated.
// DescribeArmsEnvServiceMonitor <<< Encapsulated get interface for Arms EnvServiceMonitor.
func (s *ArmsServiceV2) DescribeArmsEnvServiceMonitor(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
parts := strings.Split(id, ":")
if len(parts) != 3 {
err = WrapError(fmt.Errorf("invalid Resource Id %s. Expected parts' length %d, got %d", id, 3, len(parts)))
}
action := "DescribeEnvServiceMonitor"
request = make(map[string]interface{})
query = make(map[string]interface{})
query["ServiceMonitorName"] = parts[2]
query["EnvironmentId"] = parts[0]
query["Namespace"] = parts[1]
request["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", action, query, request, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
code, _ := jsonpath.Get("$.Code", response)
if InArray(fmt.Sprint(code), []string{"404"}) {
return object, WrapErrorf(NotFoundErr("EnvServiceMonitor", id), NotFoundMsg, response)
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(err, FailedGetAttributeMsg, id, "$.Data", response)
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsEnvServiceMonitorStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsEnvServiceMonitor(id)
if err != nil {
if NotFoundError(err) {
return object, "", nil
}
return nil, "", WrapError(err)
}
v, err := jsonpath.Get(field, object)
currentStatus := fmt.Sprint(v)
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsEnvServiceMonitor >>> Encapsulated.
// DescribeArmsEnvCustomJob <<< Encapsulated get interface for Arms EnvCustomJob.
func (s *ArmsServiceV2) DescribeArmsEnvCustomJob(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
parts := strings.Split(id, ":")
if len(parts) != 2 {
err = WrapError(fmt.Errorf("invalid Resource Id %s. Expected parts' length %d, got %d", id, 2, len(parts)))
}
action := "DescribeEnvCustomJob"
request = make(map[string]interface{})
query = make(map[string]interface{})
query["CustomJobName"] = parts[1]
query["EnvironmentId"] = parts[0]
request["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", action, query, request, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
code, _ := jsonpath.Get("$.Code", response)
if InArray(fmt.Sprint(code), []string{"404"}) {
return object, WrapErrorf(NotFoundErr("EnvCustomJob", id), NotFoundMsg, response)
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(err, FailedGetAttributeMsg, id, "$.Data", response)
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsEnvCustomJobStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsEnvCustomJob(id)
if err != nil {
if NotFoundError(err) {
return object, "", nil
}
return nil, "", WrapError(err)
}
v, err := jsonpath.Get(field, object)
currentStatus := fmt.Sprint(v)
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsEnvCustomJob >>> Encapsulated.
// DescribeArmsSyntheticTask <<< Encapsulated get interface for Arms SyntheticTask.
func (s *ArmsServiceV2) DescribeArmsSyntheticTask(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
action := "GetTimingSyntheticTask"
request = make(map[string]interface{})
query = make(map[string]interface{})
query["TaskId"] = id
query["RegionId"] = client.RegionId
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcGet("ARMS", "2019-08-08", action, query, request)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
if err != nil {
if IsExpectedErrors(err, []string{"ParameterIllegal"}) {
return object, WrapErrorf(NotFoundErr("SyntheticTask", id), NotFoundMsg, response)
}
addDebug(action, response, request)
return object, WrapErrorf(err, DefaultErrorMsg, id, action, AlibabaCloudSdkGoERROR)
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(err, FailedGetAttributeMsg, id, "$.Data", response)
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsSyntheticTaskStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsSyntheticTask(id)
if err != nil {
if NotFoundError(err) {
return object, "", nil
}
return nil, "", WrapError(err)
}
v, err := jsonpath.Get(field, object)
currentStatus := fmt.Sprint(v)
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsSyntheticTask >>> Encapsulated.
// DescribeArmsGrafanaWorkspace <<< Encapsulated get interface for Arms GrafanaWorkspace.
func (s *ArmsServiceV2) DescribeArmsGrafanaWorkspace(id string) (object map[string]interface{}, err error) {
client := s.client
var request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
request = make(map[string]interface{})
query = make(map[string]interface{})
request["GrafanaWorkspaceId"] = id
request["RegionId"] = client.RegionId
action := "GetGrafanaWorkspace"
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(1*time.Minute, func() *resource.RetryError {
response, err = client.RpcPost("ARMS", "2019-08-08", 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 object, WrapErrorf(err, DefaultErrorMsg, id, action, AlibabaCloudSdkGoERROR)
}
v, err := jsonpath.Get("$.Data", response)
if err != nil {
return object, WrapErrorf(err, FailedGetAttributeMsg, id, "$.Data", response)
}
currentStatus := v.(map[string]interface{})["status"]
if fmt.Sprint(currentStatus) == "DeleteSucceed" {
return object, WrapErrorf(NotFoundErr("GrafanaWorkspace", id), NotFoundMsg, response)
}
return v.(map[string]interface{}), nil
}
func (s *ArmsServiceV2) ArmsGrafanaWorkspaceStateRefreshFunc(id string, field string, failStates []string) resource.StateRefreshFunc {
return func() (interface{}, string, error) {
object, err := s.DescribeArmsGrafanaWorkspace(id)
if err != nil {
if NotFoundError(err) {
return object, "", nil
}
return nil, "", WrapError(err)
}
v, err := jsonpath.Get(field, object)
currentStatus := fmt.Sprint(v)
if strings.HasPrefix(field, "#") {
v, _ := jsonpath.Get(strings.TrimPrefix(field, "#"), object)
if v != nil {
currentStatus = "#CHECKSET"
}
}
for _, failState := range failStates {
if currentStatus == failState {
return object, currentStatus, WrapError(Error(FailedToReachTargetStatus, currentStatus))
}
}
return object, currentStatus, nil
}
}
// DescribeArmsGrafanaWorkspace >>> Encapsulated.