alicloud/resource_alicloud_ram_group.go (287 lines of code) (raw):

// Package alicloud. This file is generated automatically. Please do not modify it manually, thank you! package alicloud import ( "fmt" "github.com/PaesslerAG/jsonpath" "log" "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 resourceAliCloudRamGroup() *schema.Resource { return &schema.Resource{ Create: resourceAliCloudRamGroupCreate, Read: resourceAliCloudRamGroupRead, Update: resourceAliCloudRamGroupUpdate, Delete: resourceAliCloudRamGroupDelete, 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{ "comments": { Type: schema.TypeString, Optional: true, }, "create_time": { Type: schema.TypeString, Computed: true, }, "group_name": { Type: schema.TypeString, Optional: true, Computed: true, ForceNew: true, }, "name": { Type: schema.TypeString, Optional: true, Computed: true, ForceNew: true, Deprecated: "Field `name` has been deprecated from provider version 1.245.0. New field `group_name` instead.", }, "force": { Type: schema.TypeBool, Optional: true, }, }, } } func resourceAliCloudRamGroupCreate(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) action := "CreateGroup" 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("group_name"); ok { request["GroupName"] = v } else if v, ok := d.GetOk("name"); ok { request["GroupName"] = v } if v, ok := d.GetOk("comments"); ok { request["Comments"] = v } 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, DataDefaultErrorMsg, "alicloud_ram_group", action, AlibabaCloudSdkGoERROR) } id, _ := jsonpath.Get("$.Group.GroupName", response) d.SetId(fmt.Sprint(id)) return resourceAliCloudRamGroupRead(d, meta) } func resourceAliCloudRamGroupRead(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) ramServiceV2 := RamServiceV2{client} objectRaw, err := ramServiceV2.DescribeRamGroup(d.Id()) if err != nil { if !d.IsNewResource() && NotFoundError(err) { log.Printf("[DEBUG] Resource alicloud_ram_group DescribeRamGroup Failed!!! %s", err) d.SetId("") return nil } return WrapError(err) } d.Set("comments", objectRaw["Comments"]) d.Set("create_time", objectRaw["CreateDate"]) d.Set("group_name", objectRaw["GroupName"]) d.Set("name", objectRaw["GroupName"]) return nil } func resourceAliCloudRamGroupUpdate(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 action := "UpdateGroup" request = make(map[string]interface{}) query = make(map[string]interface{}) request["GroupName"] = d.Id() if d.HasChange("comments") { update = true } if v, ok := d.GetOk("comments"); ok { request["NewComments"] = 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) } } return resourceAliCloudRamGroupRead(d, meta) } func resourceAliCloudRamGroupDelete(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) var request map[string]interface{} var response map[string]interface{} query := make(map[string]interface{}) var err error if d.Get("force").(bool) { // list and delete users which in this group action := "ListUsersForGroup" userNames := make([]string, 0) listUsersForGroupReq := map[string]interface{}{ "GroupName": d.Id(), } for { 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, listUsersForGroupReq, true) if err != nil { if NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(action, response, listUsersForGroupReq) if err != nil { return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } resp, err := jsonpath.Get("$.Users.User", response) if err != nil { return WrapErrorf(err, FailedGetAttributeMsg, action, "$.Users.User", response) } result, _ := resp.([]interface{}) for _, v := range result { item := v.(map[string]interface{}) userNames = append(userNames, fmt.Sprint(item["UserName"])) } if !response["IsTruncated"].(bool) { break } listUsersForGroupReq["Marker"] = response["Marker"] } if len(userNames) > 0 { for _, userName := range userNames { action = "RemoveUserFromGroup" removeUserFromGroupReq := map[string]interface{}{ "GroupName": d.Id(), "UserName": userName, } 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, removeUserFromGroupReq, true) if err != nil { if NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(action, response, removeUserFromGroupReq) if err != nil && !IsExpectedErrors(err, []string{"EntityNotExist"}) { return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } } } // list and detach policies which attach this group action = "ListPoliciesForGroup" listPoliciesForGroupReq := map[string]interface{}{ "GroupName": d.Id(), } 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, listPoliciesForGroupReq, true) if err != nil { if NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(action, response, listPoliciesForGroupReq) if err != nil { return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } resp, err := jsonpath.Get("$.Policies.Policy", response) if err != nil { return WrapErrorf(err, FailedGetAttributeMsg, action, "$.Policies.Policy", response) } result, _ := resp.([]interface{}) if len(result) > 0 { for _, v := range result { action = "DetachPolicyFromGroup" detachPolicyFromGroupReq := map[string]interface{}{ "GroupName": d.Id(), "PolicyName": v.(map[string]interface{})["PolicyName"], "PolicyType": v.(map[string]interface{})["PolicyType"], } err = resource.Retry(d.Timeout(schema.TimeoutDelete), func() *resource.RetryError { response, err = client.RpcPost("Ram", "2015-05-01", action, query, detachPolicyFromGroupReq, true) if err != nil { if NeedRetry(err) { wait() return resource.RetryableError(err) } return resource.NonRetryableError(err) } return nil }) addDebug(action, response, detachPolicyFromGroupReq) if err != nil && !IsExpectedErrors(err, []string{"EntityNotExist"}) { return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } } } } action := "DeleteGroup" request = make(map[string]interface{}) request["GroupName"] = d.Id() 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.Group.User", "DeleteConflict.Group.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.Group"}) || NotFoundError(err) { return nil } return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR) } return nil }