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
}