alicloud/data_source_alicloud_bastionhost_users.go (259 lines of code) (raw):

package alicloud import ( "fmt" "regexp" "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 dataSourceAlicloudBastionhostUsers() *schema.Resource { return &schema.Resource{ Read: dataSourceAlicloudBastionhostUsersRead, Schema: map[string]*schema.Schema{ "display_name": { Type: schema.TypeString, Optional: true, ForceNew: true, }, "instance_id": { Type: schema.TypeString, Required: true, ForceNew: true, }, "mobile": { Type: schema.TypeString, Optional: true, ForceNew: true, }, "source": { Type: schema.TypeString, Optional: true, ForceNew: true, ValidateFunc: validation.StringInSlice([]string{"Local", "Ram"}, false), }, "source_user_id": { Type: schema.TypeString, Optional: true, ForceNew: true, }, "status": { Type: schema.TypeString, Optional: true, ForceNew: true, ValidateFunc: validation.StringInSlice([]string{"Expired", "Frozen", "Normal"}, false), }, "ids": { Type: schema.TypeList, Optional: true, ForceNew: true, Elem: &schema.Schema{Type: schema.TypeString}, Computed: true, }, "name_regex": { Type: schema.TypeString, Optional: true, ValidateFunc: validation.ValidateRegexp, ForceNew: true, }, "names": { Type: schema.TypeList, Elem: &schema.Schema{Type: schema.TypeString}, Computed: true, }, "user_name": { Type: schema.TypeString, Optional: true, ForceNew: true, }, "output_file": { Type: schema.TypeString, Optional: true, }, "users": { Type: schema.TypeList, Computed: true, Elem: &schema.Resource{ Schema: map[string]*schema.Schema{ "comment": { Type: schema.TypeString, Computed: true, }, "display_name": { Type: schema.TypeString, Computed: true, }, "email": { Type: schema.TypeString, Computed: true, }, "instance_id": { Type: schema.TypeString, Computed: true, }, "mobile": { Type: schema.TypeString, Computed: true, }, "mobile_country_code": { Type: schema.TypeString, Computed: true, }, "source": { Type: schema.TypeString, Computed: true, }, "source_user_id": { Type: schema.TypeString, Computed: true, }, "status": { Type: schema.TypeString, Computed: true, }, "id": { Type: schema.TypeString, Computed: true, }, "user_id": { Type: schema.TypeString, Computed: true, }, "user_name": { Type: schema.TypeString, Computed: true, }, }, }, }, }, } } func dataSourceAlicloudBastionhostUsersRead(d *schema.ResourceData, meta interface{}) error { client := meta.(*connectivity.AliyunClient) action := "ListUsers" request := make(map[string]interface{}) if v, ok := d.GetOk("display_name"); ok { request["DisplayName"] = v } request["InstanceId"] = d.Get("instance_id") if v, ok := d.GetOk("mobile"); ok { request["Mobile"] = v } request["RegionId"] = client.RegionId if v, ok := d.GetOk("source"); ok { request["Source"] = v } if v, ok := d.GetOk("source_user_id"); ok { request["SourceUserId"] = v } if v, ok := d.GetOk("status"); ok { request["UserState"] = v } if v, ok := d.GetOk("user_name"); ok { request["UserName"] = v } request["PageSize"] = PageSizeLarge request["PageNumber"] = 1 var objects []map[string]interface{} var userNameRegex *regexp.Regexp if v, ok := d.GetOk("name_regex"); ok { r, err := regexp.Compile(v.(string)) if err != nil { return WrapError(err) } userNameRegex = r } idsMap := make(map[string]string) if v, ok := d.GetOk("ids"); ok { for _, vv := range v.([]interface{}) { if vv == nil { continue } idsMap[vv.(string)] = vv.(string) } } var response map[string]interface{} var err error for { wait := incrementalWait(3*time.Second, 3*time.Second) err = resource.Retry(5*time.Minute, func() *resource.RetryError { response, err = client.RpcPost("Yundun-bastionhost", "2019-12-09", action, nil, 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_bastionhost_users", action, AlibabaCloudSdkGoERROR) } resp, err := jsonpath.Get("$.Users", response) if err != nil { return WrapErrorf(err, FailedGetAttributeMsg, action, "$.Users", response) } result, _ := resp.([]interface{}) for _, v := range result { item := v.(map[string]interface{}) if userNameRegex != nil && !userNameRegex.MatchString(fmt.Sprint(item["UserName"])) { continue } if len(idsMap) > 0 { if _, ok := idsMap[fmt.Sprint(item["UserId"])]; !ok { continue } } objects = append(objects, item) } if len(result) < PageSizeLarge { break } request["PageNumber"] = request["PageNumber"].(int) + 1 } ids := make([]string, 0) names := make([]interface{}, 0) s := make([]map[string]interface{}, 0) for _, object := range objects { mapping := map[string]interface{}{ "comment": object["Comment"], "display_name": object["DisplayName"], "email": object["Email"], "instance_id": request["InstanceId"], "mobile": object["Mobile"], "mobile_country_code": object["MobileCountryCode"], "source": object["Source"], "source_user_id": object["SourceUserId"], "id": fmt.Sprint(object["UserId"]), "user_id": fmt.Sprint(object["UserId"]), "user_name": object["UserName"], } if object["UserState"] != nil { for _, userState := range object["UserState"].([]interface{}) { mapping["status"] = fmt.Sprint(userState) } } ids = append(ids, fmt.Sprint(mapping["id"])) names = append(names, object["UserName"]) s = append(s, mapping) } d.SetId(dataResourceIdHash(ids)) if err := d.Set("ids", ids); err != nil { return WrapError(err) } if err := d.Set("names", names); err != nil { return WrapError(err) } if err := d.Set("users", s); err != nil { return WrapError(err) } if output, ok := d.GetOk("output_file"); ok && output.(string) != "" { writeToFile(output.(string), s) } return nil }