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.