alicloud/resource_alicloud_esa_scheduled_preload_execution.go (214 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" "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 resourceAliCloudEsaScheduledPreloadExecution() *schema.Resource { return &schema.Resource{ Create: resourceAliCloudEsaScheduledPreloadExecutionCreate, Read: resourceAliCloudEsaScheduledPreloadExecutionRead, Update: resourceAliCloudEsaScheduledPreloadExecutionUpdate, Delete: resourceAliCloudEsaScheduledPreloadExecutionDelete, 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{ "end_time": { Type: schema.TypeString, Optional: true, }, "interval": { Type: schema.TypeInt, Required: true, }, "scheduled_preload_execution_id": { Type: schema.TypeString, Computed: true, }, "scheduled_preload_job_id": { Type: schema.TypeString, Required: true, ForceNew: true, }, "slice_len": { Type: schema.TypeInt, Required: true, }, "start_time": { Type: schema.TypeString, Optional: true, }, "status": { Type: schema.TypeString, Computed: true, }, }, } } func resourceAliCloudEsaScheduledPreloadExecutionCreate(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) action := "CreateScheduledPreloadExecutions" 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("scheduled_preload_job_id"); ok { request["Id"] = v } request["RegionId"] = client.RegionId objectDataLocalMap := make(map[string]interface{}) if v, ok := d.GetOkExists("interval"); ok { objectDataLocalMap["Interval"] = v } if v, ok := d.GetOkExists("start_time"); ok { objectDataLocalMap["StartTime"] = v } if v, ok := d.GetOkExists("slice_len"); ok { objectDataLocalMap["SliceLen"] = v } if v, ok := d.GetOkExists("end_time"); ok { objectDataLocalMap["EndTime"] = v } ExecutionsMap := make([]interface{}, 0) ExecutionsMap = append(ExecutionsMap, objectDataLocalMap) objectDataLocalMapJson, err := json.Marshal(ExecutionsMap) if err != nil { return WrapError(err) } request["Executions"] = string(objectDataLocalMapJson) 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_scheduled_preload_execution", action, AlibabaCloudSdkGoERROR) } SuccessExecutionsJobIdVar, _ := jsonpath.Get("$.SuccessExecutions[0].JobId", response) SuccessExecutionsIdVar, _ := jsonpath.Get("$.SuccessExecutions[0].Id", response) d.SetId(fmt.Sprintf("%v:%v", SuccessExecutionsJobIdVar, SuccessExecutionsIdVar)) return resourceAliCloudEsaScheduledPreloadExecutionRead(d, meta) } func resourceAliCloudEsaScheduledPreloadExecutionRead(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) esaServiceV2 := EsaServiceV2{client} objectRaw, err := esaServiceV2.DescribeEsaScheduledPreloadExecution(d.Id()) if err != nil { if !d.IsNewResource() && NotFoundError(err) { log.Printf("[DEBUG] Resource alicloud_esa_scheduled_preload_execution DescribeEsaScheduledPreloadExecution Failed!!! %s", err) d.SetId("") return nil } return WrapError(err) } d.Set("end_time", objectRaw["EndTime"]) d.Set("interval", objectRaw["Interval"]) d.Set("slice_len", objectRaw["SliceLen"]) d.Set("start_time", objectRaw["StartTime"]) d.Set("status", objectRaw["Status"]) d.Set("scheduled_preload_execution_id", objectRaw["Id"]) d.Set("scheduled_preload_job_id", objectRaw["JobId"]) return nil } func resourceAliCloudEsaScheduledPreloadExecutionUpdate(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 := "UpdateScheduledPreloadExecution" request = make(map[string]interface{}) query = make(map[string]interface{}) request["Id"] = parts[1] request["RegionId"] = client.RegionId if d.HasChange("interval") { update = true } request["Interval"] = d.Get("interval") if d.HasChange("start_time") { update = true request["StartTime"] = d.Get("start_time") } if d.HasChange("slice_len") { update = true } request["SliceLen"] = d.Get("slice_len") if d.HasChange("end_time") { update = true request["EndTime"] = d.Get("end_time") } 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 resourceAliCloudEsaScheduledPreloadExecutionRead(d, meta) } func resourceAliCloudEsaScheduledPreloadExecutionDelete(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) parts := strings.Split(d.Id(), ":") action := "DeleteScheduledPreloadExecution" var request map[string]interface{} var response map[string]interface{} query := make(map[string]interface{}) var err error request = make(map[string]interface{}) 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 }