alicloud/resource_alicloud_esa_scheduled_preload_job.go (154 lines of code) (raw):

// Package alicloud. This file is generated automatically. Please do not modify it manually, thank you! package alicloud import ( "fmt" "log" "strings" "time" "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 resourceAliCloudEsaScheduledPreloadJob() *schema.Resource { return &schema.Resource{ Create: resourceAliCloudEsaScheduledPreloadJobCreate, Read: resourceAliCloudEsaScheduledPreloadJobRead, Update: resourceAliCloudEsaScheduledPreloadJobUpdate, Delete: resourceAliCloudEsaScheduledPreloadJobDelete, 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{ "create_time": { Type: schema.TypeString, Computed: true, }, "insert_way": { Type: schema.TypeString, Required: true, ForceNew: true, ValidateFunc: StringInSlice([]string{"textBox", "oss"}, false), }, "oss_url": { Type: schema.TypeString, Optional: true, }, "scheduled_preload_job_id": { Type: schema.TypeString, Computed: true, }, "scheduled_preload_job_name": { Type: schema.TypeString, Required: true, ForceNew: true, }, "site_id": { Type: schema.TypeInt, Required: true, ForceNew: true, }, "url_list": { Type: schema.TypeString, Optional: true, }, }, } } func resourceAliCloudEsaScheduledPreloadJobCreate(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) action := "CreateScheduledPreloadJob" 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("url_list"); ok { request["UrlList"] = v } if v, ok := d.GetOk("oss_url"); ok { request["OssUrl"] = v } request["InsertWay"] = d.Get("insert_way") request["Name"] = d.Get("scheduled_preload_job_name") 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_job", action, AlibabaCloudSdkGoERROR) } d.SetId(fmt.Sprintf("%v:%v", response["SiteId"], response["Id"])) return resourceAliCloudEsaScheduledPreloadJobRead(d, meta) } func resourceAliCloudEsaScheduledPreloadJobRead(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) esaServiceV2 := EsaServiceV2{client} objectRaw, err := esaServiceV2.DescribeEsaScheduledPreloadJob(d.Id()) if err != nil { if !d.IsNewResource() && NotFoundError(err) { log.Printf("[DEBUG] Resource alicloud_esa_scheduled_preload_job DescribeEsaScheduledPreloadJob Failed!!! %s", err) d.SetId("") return nil } return WrapError(err) } d.Set("create_time", objectRaw["CreatedAt"]) d.Set("insert_way", objectRaw["InsertWay"]) d.Set("scheduled_preload_job_name", objectRaw["Name"]) d.Set("scheduled_preload_job_id", objectRaw["Id"]) d.Set("site_id", objectRaw["SiteId"]) return nil } func resourceAliCloudEsaScheduledPreloadJobUpdate(d *schema.ResourceData, meta interface{}) error { log.Printf("[INFO] Cannot update resource Alicloud Resource Scheduled Preload Job.") return nil } func resourceAliCloudEsaScheduledPreloadJobDelete(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) parts := strings.Split(d.Id(), ":") action := "DeleteScheduledPreloadJob" 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 }