alicloud/data_source_alicloud_ram_users.go (263 lines of code) (raw):
package alicloud
import (
"log"
"regexp"
"time"
"github.com/aliyun/alibaba-cloud-sdk-go/sdk/requests"
"github.com/aliyun/alibaba-cloud-sdk-go/services/ram"
"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 dataSourceAlicloudRamUsers() *schema.Resource {
return &schema.Resource{
Read: dataSourceAlicloudRamUsersRead,
Schema: map[string]*schema.Schema{
"name_regex": {
Type: schema.TypeString,
Optional: true,
ForceNew: true,
},
"group_name": {
Type: schema.TypeString,
Optional: true,
ForceNew: true,
},
"policy_name": {
Type: schema.TypeString,
Optional: true,
ForceNew: true,
ValidateFunc: StringLenBetween(0, 128),
},
"policy_type": {
Type: schema.TypeString,
Optional: true,
ForceNew: true,
ValidateFunc: StringInSlice([]string{"System", "Custom"}, false),
},
"output_file": {
Type: schema.TypeString,
Optional: true,
},
"ids": {
Type: schema.TypeList,
Optional: true,
Elem: &schema.Schema{Type: schema.TypeString},
Computed: true,
},
"names": {
Type: schema.TypeList,
Computed: true,
Elem: &schema.Schema{Type: schema.TypeString},
},
// Computed values
"users": {
Type: schema.TypeList,
Computed: true,
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
"id": {
Type: schema.TypeString,
Computed: true,
},
"name": {
Type: schema.TypeString,
Computed: true,
},
"create_date": {
Type: schema.TypeString,
Computed: true,
},
"last_login_date": {
Removed: "Field 'last_login_date' has been removed from provider version 1.79.0.",
Type: schema.TypeString,
Computed: true,
},
},
},
},
},
}
}
func dataSourceAlicloudRamUsersRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
ramService := RamService{client}
var allUsers []interface{}
allUsersMap := make(map[string]interface{})
groupFilterUsersMap := make(map[string]interface{})
policyFilterUsersMap := make(map[string]interface{})
var dataMap []map[string]interface{}
groupName, groupNameOk := d.GetOk("group_name")
policyName, policyNameOk := d.GetOk("policy_name")
policyType, policyTypeOk := d.GetOk("policy_type")
nameRegex, nameRegexOk := d.GetOk("name_regex")
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)
}
}
if policyTypeOk && !policyNameOk {
return WrapError(Error("You must set 'policy_name' at one time when you set 'policy_type'."))
}
// all users
request := ram.CreateListUsersRequest()
request.RegionId = client.RegionId
request.MaxItems = requests.NewInteger(1000)
for {
var raw interface{}
var err error
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(client.GetRetryTimeout(d.Timeout(schema.TimeoutRead)), func() *resource.RetryError {
raw, err = client.WithRamClient(func(ramClient *ram.Client) (interface{}, error) {
return ramClient.ListUsers(request)
})
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(request.GetActionName(), raw, request.RpcRequest, request)
return nil
})
if err != nil {
return WrapErrorf(err, DataDefaultErrorMsg, "alicloud_ram_users", request.GetActionName(), AlibabaCloudSdkGoERROR)
}
response, _ := raw.(*ram.ListUsersResponse)
for _, v := range response.Users.User {
if nameRegexOk {
r, err := regexp.Compile(nameRegex.(string))
if err != nil {
return WrapError(err)
}
if !r.MatchString(v.UserName) {
continue
}
}
if len(idsMap) > 0 {
if _, ok := idsMap[v.UserId]; !ok {
continue
}
}
allUsersMap[v.UserName] = v
}
if !response.IsTruncated {
break
}
request.Marker = response.Marker
}
// users for group
if groupNameOk {
request := ram.CreateListUsersForGroupRequest()
request.GroupName = groupName.(string)
users := []ram.User{}
var raw interface{}
var err error
for {
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(client.GetRetryTimeout(d.Timeout(schema.TimeoutRead)), func() *resource.RetryError {
raw, err = client.WithRamClient(func(ramClient *ram.Client) (interface{}, error) {
return ramClient.ListUsersForGroup(request)
})
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(request.GetActionName(), raw, request.RpcRequest, request)
return nil
})
if err != nil {
return WrapErrorf(err, DataDefaultErrorMsg, "alicloud_ram_users", request.GetActionName(), AlibabaCloudSdkGoERROR)
}
response, _ := raw.(*ram.ListUsersForGroupResponse)
users = append(users, response.Users.User...)
if !response.IsTruncated {
break
}
request.Marker = response.Marker
}
for _, v := range users {
groupFilterUsersMap[v.UserName] = v
}
if len(groupFilterUsersMap) > 0 {
dataMap = append(dataMap, groupFilterUsersMap)
}
}
// users which attach with this policy
if policyNameOk {
pType := "System"
if policyTypeOk {
pType = policyType.(string)
}
request := ram.CreateListEntitiesForPolicyRequest()
request.PolicyName = policyName.(string)
request.PolicyType = pType
var raw interface{}
var err error
wait := incrementalWait(3*time.Second, 3*time.Second)
err = resource.Retry(client.GetRetryTimeout(d.Timeout(schema.TimeoutRead)), func() *resource.RetryError {
raw, err = client.WithRamClient(func(ramClient *ram.Client) (interface{}, error) {
return ramClient.ListEntitiesForPolicy(request)
})
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(request.GetActionName(), raw, request.RpcRequest, request)
return nil
})
if err != nil {
return WrapErrorf(err, DataDefaultErrorMsg, "alicloud_ram_users", request.GetActionName(), AlibabaCloudSdkGoERROR)
}
response, _ := raw.(*ram.ListEntitiesForPolicyResponse)
for _, v := range response.Users.User {
policyFilterUsersMap[v.UserName] = v
}
if len(policyFilterUsersMap) > 0 {
dataMap = append(dataMap, policyFilterUsersMap)
}
}
// GetIntersection of each map
allUsers = ramService.GetIntersection(dataMap, allUsersMap, groupNameOk, policyNameOk)
return ramUsersDescriptionAttributes(d, allUsers)
}
func ramUsersDescriptionAttributes(d *schema.ResourceData, users []interface{}) error {
var ids []string
var names []string
var s []map[string]interface{}
for _, v := range users {
user, ok := v.(ram.User)
if !ok {
return WrapError(Error("wrong interface convince"))
}
mapping := map[string]interface{}{
"id": user.UserId,
"name": user.UserName,
"create_date": user.CreateDate,
}
log.Printf("[DEBUG] alicloud_ram_users - adding user: %v", mapping)
ids = append(ids, user.UserId)
names = append(names, user.UserName)
s = append(s, mapping)
}
d.SetId(dataResourceIdHash(ids))
if err := d.Set("users", s); err != nil {
return WrapError(err)
}
if err := d.Set("ids", ids); err != nil {
return WrapError(err)
}
if err := d.Set("names", names); err != nil {
return WrapError(err)
}
// create a json file in current directory and write data source to it.
if output, ok := d.GetOk("output_file"); ok && output.(string) != "" {
writeToFile(output.(string), s)
}
return nil
}