alicloud/resource_alicloud_ram_policy.go (535 lines of code) (raw):

// Package alicloud. This file is generated automatically. Please do not modify it manually, thank you! package alicloud import ( "fmt" "log" "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" "github.com/hashicorp/terraform-plugin-sdk/helper/validation" ) func resourceAliCloudRamPolicy() *schema.Resource { return &schema.Resource{ Create: resourceAliCloudRamPolicyCreate, Read: resourceAliCloudRamPolicyRead, Update: resourceAliCloudRamPolicyUpdate, Delete: resourceAliCloudRamPolicyDelete, Importer: &schema.ResourceImporter{ State: schema.ImportStatePassthrough, }, Timeouts: &schema.ResourceTimeout{ Create: schema.DefaultTimeout(5 * time.Minute), Update: schema.DefaultTimeout(5 * time.Minute), Delete: schema.DefaultTimeout(26 * time.Minute), }, Schema: map[string]*schema.Schema{ "create_time": { Type: schema.TypeString, Computed: true, }, "description": { Type: schema.TypeString, Optional: true, }, "policy_document": { Type: schema.TypeString, Optional: true, Computed: true, ValidateFunc: validation.ValidateJsonString, DiffSuppressFunc: func(k, old, new string, d *schema.ResourceData) bool { equal, _ := compareJsonTemplateAreEquivalent(old, new) return equal }, ConflictsWith: []string{"document", "version", "statement"}, }, "policy_name": { Type: schema.TypeString, Optional: true, Computed: true, ForceNew: true, ConflictsWith: []string{"name"}, }, "rotate_strategy": { Type: schema.TypeString, Optional: true, ValidateFunc: StringInSlice([]string{"None", "DeleteOldestNonDefaultVersionWhenLimitExceeded"}, false), }, "tags": tagsSchema(), "force": { Type: schema.TypeBool, Optional: true, }, "type": { Type: schema.TypeString, Computed: true, }, "attachment_count": { Type: schema.TypeInt, Computed: true, }, "version_id": { Type: schema.TypeString, Computed: true, }, "default_version": { Type: schema.TypeString, Computed: true, }, "name": { Type: schema.TypeString, Optional: true, Computed: true, ForceNew: true, Deprecated: "Field 'name' has been deprecated from provider version 1.114.0. New field 'policy_name' instead.", ConflictsWith: []string{"policy_name"}, }, "version": { Type: schema.TypeString, Optional: true, Default: "1", ConflictsWith: []string{"document"}, // can only be '1' so far. ValidateFunc: StringInSlice([]string{"1"}, false), Deprecated: "Field 'version' has been deprecated from version 1.49.0, and use field 'document' to replace. ", }, "document": { Type: schema.TypeString, Optional: true, Computed: true, ValidateFunc: validation.ValidateJsonString, DiffSuppressFunc: func(k, old, new string, d *schema.ResourceData) bool { equal, _ := compareJsonTemplateAreEquivalent(old, new) return equal }, Deprecated: "Field 'document' has been deprecated from provider version 1.114.0. New field 'policy_document' instead.", ConflictsWith: []string{"policy_document", "version", "statement"}, }, "statement": { Type: schema.TypeSet, Optional: true, Computed: true, Deprecated: "Field 'statement' has been deprecated from version 1.49.0, and use field 'document' to replace. ", Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ "effect": { Type: schema.TypeString, Required: true, ValidateFunc: StringInSlice([]string{"Allow", "Deny"}, false), }, "action": { Type: schema.TypeList, Required: true, Elem: &schema.Schema{ Type: schema.TypeString, }, }, "resource": { Type: schema.TypeList, Required: true, Elem: &schema.Schema{ Type: schema.TypeString, }, }, }, }, ConflictsWith: []string{"document"}, }, }, } } func resourceAliCloudRamPolicyCreate(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) action := "CreatePolicy" 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("policy_name"); ok { request["PolicyName"] = v } else if v, ok := d.GetOk("name"); ok { request["PolicyName"] = v } if v, ok := d.GetOk("description"); ok { request["Description"] = v } if v, ok := d.GetOk("policy_document"); ok { request["PolicyDocument"] = v } else if v, ok := d.GetOk("document"); ok { request["PolicyDocument"] = v } else if v, ok := d.GetOk("statement"); ok { ramServiceV2 := RamServiceV2{client} doc, err := ramServiceV2.AssemblePolicyDocument(v.(*schema.Set).List(), d.Get("version").(string)) if err != nil { return WrapError(err) } request["PolicyDocument"] = doc } else { return WrapError(Error("One of 'policy_document', 'document', 'statement' must be specified.")) } if v, ok := d.GetOk("tags"); ok { tagsMap := ConvertTags(v.(map[string]interface{})) tagsMapJSON, err := convertListMapToJsonString(tagsMap) if err != nil { return WrapError(err) } request["Tag"] = tagsMapJSON } wait := incrementalWait(3*time.Second, 5*time.Second) err = resource.Retry(d.Timeout(schema.TimeoutCreate), func() *resource.RetryError { response, err = client.RpcPost("Ram", "2015-05-01", 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_ram_policy", action, AlibabaCloudSdkGoERROR) } responsePolicy := response["Policy"].(map[string]interface{}) d.SetId(fmt.Sprint(responsePolicy["PolicyName"])) return resourceAliCloudRamPolicyRead(d, meta) } func resourceAliCloudRamPolicyRead(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) ramServiceV2 := RamServiceV2{client} objectRaw, err := ramServiceV2.DescribeRamPolicy(d.Id()) if err != nil { if !d.IsNewResource() && NotFoundError(err) { log.Printf("[DEBUG] Resource alicloud_ram_policy DescribeRamPolicy Failed!!! %s", err) d.SetId("") return nil } return WrapError(err) } defaultPolicyVersionRawObj, _ := jsonpath.Get("$.DefaultPolicyVersion", objectRaw) defaultPolicyVersionRaw := make(map[string]interface{}) if defaultPolicyVersionRawObj != nil { defaultPolicyVersionRaw = defaultPolicyVersionRawObj.(map[string]interface{}) } d.Set("policy_document", defaultPolicyVersionRaw["PolicyDocument"]) d.Set("document", defaultPolicyVersionRaw["PolicyDocument"]) d.Set("version_id", defaultPolicyVersionRaw["VersionId"]) statement, version, err := ramServiceV2.ParsePolicyDocument(defaultPolicyVersionRaw["PolicyDocument"].(string)) if err != nil { return WrapError(err) } d.Set("version", version) d.Set("statement", statement) policyRawObj, _ := jsonpath.Get("$.Policy", objectRaw) policyRaw := make(map[string]interface{}) if policyRawObj != nil { policyRaw = policyRawObj.(map[string]interface{}) } d.Set("create_time", policyRaw["CreateDate"]) d.Set("description", policyRaw["Description"]) d.Set("policy_name", policyRaw["PolicyName"]) d.Set("name", policyRaw["PolicyName"]) d.Set("default_version", policyRaw["DefaultVersion"]) d.Set("attachment_count", policyRaw["AttachmentCount"]) d.Set("type", policyRaw["PolicyType"]) objectRaw, err = ramServiceV2.DescribePolicyListTagResources(d.Id()) if err != nil && !NotFoundError(err) { return WrapError(err) } tagsMaps := objectRaw["TagResources"] d.Set("tags", tagsToMap(tagsMaps)) return nil } func resourceAliCloudRamPolicyUpdate(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 d.Partial(true) var err error action := "CreatePolicyVersion" request = make(map[string]interface{}) query = make(map[string]interface{}) request["PolicyName"] = d.Id() request["SetAsDefault"] = true if d.HasChange("policy_document") { update = true request["PolicyDocument"] = d.Get("policy_document") } if d.HasChange("document") { update = true request["PolicyDocument"] = d.Get("document") } if d.HasChange("statement") || d.HasChange("version") { update = true ramServiceV2 := RamServiceV2{client} document, err := ramServiceV2.AssemblePolicyDocument(d.Get("statement").(*schema.Set).List(), d.Get("version").(string)) if err != nil { return WrapError(err) } request["PolicyDocument"] = document } if v, ok := d.GetOk("rotate_strategy"); ok { request["RotateStrategy"] = 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("Ram", "2015-05-01", 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) } } update = false action = "UpdatePolicyDescription" request = make(map[string]interface{}) query = make(map[string]interface{}) request["PolicyName"] = d.Id() if d.HasChange("description") { update = true request["NewDescription"] = d.Get("description") } if update { wait := incrementalWait(3*time.Second, 5*time.Second) err = resource.Retry(d.Timeout(schema.TimeoutUpdate), func() *resource.RetryError { response, err = client.RpcPost("Ram", "2015-05-01", 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 d.HasChange("tags") { ramServiceV2 := RamServiceV2{client} if err := ramServiceV2.SetResourceTags(d, "policy"); err != nil { return WrapError(err) } } d.Partial(false) return resourceAliCloudRamPolicyRead(d, meta) } func resourceAliCloudRamPolicyDelete(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) action := "DeletePolicy" var request map[string]interface{} var response map[string]interface{} query := make(map[string]interface{}) var err error request = make(map[string]interface{}) request["PolicyName"] = d.Id() request["CascadingDelete"] = true if d.Get("force").(bool) { listRequest := map[string]interface{}{ "PolicyName": d.Id(), "PolicyType": "Custom", } listAction := "ListEntitiesForPolicy" wait := incrementalWait(3*time.Second, 3*time.Second) err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError { response, err = client.RpcPost("Ram", "2015-05-01", listAction, nil, listRequest, true) if err != nil { if NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(listAction, response, listRequest) if err != nil { return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } userResp, err := jsonpath.Get("$.Users.User", response) if err != nil { return WrapErrorf(err, FailedGetAttributeMsg, action, "$.Users.User", response) } if userResp != nil && len(userResp.([]interface{})) > 0 { for _, v := range userResp.([]interface{}) { userAction := "DetachPolicyFromUser" userRequest := map[string]interface{}{ "PolicyName": d.Id(), "UserName": v.(map[string]interface{})["UserName"], "PolicyType": "Custom", } wait := incrementalWait(3*time.Second, 3*time.Second) err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError { response, err = client.RpcPost("Ram", "2015-05-01", userAction, nil, userRequest, true) if err != nil { if NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(action, response, userRequest) if err != nil { if IsExpectedErrors(err, []string{"EntityNotExist"}) || NotFoundError(err) { return nil } return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } } } groupResp, err := jsonpath.Get("$.Groups.Group", response) if err != nil { return WrapErrorf(err, FailedGetAttributeMsg, action, "$.Groups.Group", response) } if groupResp != nil && len(groupResp.([]interface{})) > 0 { for _, v := range groupResp.([]interface{}) { groupAction := "DetachPolicyFromGroup" groupRequest := map[string]interface{}{ "PolicyName": d.Id(), "GroupName": v.(map[string]interface{})["GroupName"], "PolicyType": "Custom", } wait := incrementalWait(3*time.Second, 3*time.Second) err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError { response, err = client.RpcPost("Ram", "2015-05-01", groupAction, nil, groupRequest, true) if err != nil { if NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(action, response, groupRequest) if err != nil { if IsExpectedErrors(err, []string{"EntityNotExist"}) || NotFoundError(err) { return nil } return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } } } roleResp, err := jsonpath.Get("$.Roles.Role", response) if err != nil { return WrapErrorf(err, FailedGetAttributeMsg, action, "$.Roles.Role", response) } if roleResp != nil && len(roleResp.([]interface{})) > 0 { for _, v := range roleResp.([]interface{}) { roleAction := "DetachPolicyFromRole" roleRequest := map[string]interface{}{ "PolicyName": d.Id(), "RoleName": v.(map[string]interface{})["RoleName"], "PolicyType": "Custom", } wait := incrementalWait(3*time.Second, 3*time.Second) err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError { response, err = client.RpcPost("Ram", "2015-05-01", roleAction, nil, roleRequest, true) if err != nil { if NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(action, response, roleRequest) if err != nil { if IsExpectedErrors(err, []string{"EntityNotExist"}) || NotFoundError(err) { return nil } return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } } } listVersionsRequest := map[string]interface{}{ "PolicyName": d.Id(), "PolicyType": "Custom", } listVersionsAction := "ListPolicyVersions" wait = incrementalWait(3*time.Second, 3*time.Second) err = resource.Retry(client.GetRetryTimeout(d.Timeout(schema.TimeoutDelete)), func() *resource.RetryError { response, err = client.RpcPost("Ram", "2015-05-01", listVersionsAction, nil, listVersionsRequest, true) if err != nil { if NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(action, response, listVersionsRequest) if err != nil { if IsExpectedErrors(err, []string{"EntityNotExist.Policy"}) || NotFoundError(err) { return nil } return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } versionsResp, er := jsonpath.Get("$.PolicyVersions.PolicyVersion", response) if er != nil { return WrapErrorf(er, FailedGetAttributeMsg, action, "$.PolicyVersions.PolicyVersion", response) } // More than one means there are other versions besides the default version if versionsResp != nil && len(versionsResp.([]interface{})) > 1 { for _, v := range versionsResp.([]interface{}) { if !v.(map[string]interface{})["IsDefaultVersion"].(bool) { versionAction := "DeletePolicyVersion" versionRequest := map[string]interface{}{ "PolicyName": d.Id(), "VersionId": v.(map[string]interface{})["VersionId"], } wait := incrementalWait(3*time.Second, 3*time.Second) err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError { response, err = client.RpcPost("Ram", "2015-05-01", versionAction, nil, versionRequest, false) if err != nil { if NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(versionAction, response, versionRequest) } } } } wait := incrementalWait(3*time.Second, 5*time.Second) err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError { response, err = client.RpcPost("Ram", "2015-05-01", action, query, request, true) if err != nil { if IsExpectedErrors(err, []string{"DeleteConflict.Policy.Group", "DeleteConflict.Policy.User", "DeleteConflict.Policy.Version", "DeleteConflict.Role.Policy"}) || NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(action, response, request) if err != nil { if IsExpectedErrors(err, []string{"EntityNotExist"}) || NotFoundError(err) { return nil } return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } return nil }