-
Notifications
You must be signed in to change notification settings - Fork 141
/
Copy pathdata_source_tc_cam_roles.go
156 lines (143 loc) · 4.32 KB
/
data_source_tc_cam_roles.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
package cam
import (
"context"
"log"
tccommon "github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/common"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
cam "github.com/tencentcloud/tencentcloud-sdk-go/tencentcloud/cam/v20190116"
"github.com/tencentcloudstack/terraform-provider-tencentcloud/tencentcloud/internal/helper"
)
func DataSourceTencentCloudCamRoles() *schema.Resource {
return &schema.Resource{
Read: dataSourceTencentCloudCamRolesRead,
Schema: map[string]*schema.Schema{
"role_id": {
Type: schema.TypeString,
Optional: true,
Description: "ID of the CAM role to be queried.",
},
"description": {
Type: schema.TypeString,
Optional: true,
Description: "The description of the CAM role to be queried.",
},
"name": {
Type: schema.TypeString,
Optional: true,
Description: "Name of the CAM policy to be queried.",
},
"result_output_file": {
Type: schema.TypeString,
Optional: true,
Description: "Used to save results.",
},
"role_list": {
Type: schema.TypeList,
Computed: true,
Description: "A list of CAM roles. Each element contains the following attributes:",
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
"role_id": {
Type: schema.TypeString,
Computed: true,
Description: "Id of CAM role.",
},
"name": {
Type: schema.TypeString,
Computed: true,
Description: "Name of CAM role.",
},
"document": {
Type: schema.TypeString,
Computed: true,
Description: "Policy document of CAM role.",
},
"description": {
Type: schema.TypeString,
Computed: true,
Description: "Description of CAM role.",
},
"console_login": {
Type: schema.TypeBool,
Computed: true,
Description: "Indicate whether the CAM role can be login or not.",
},
"create_time": {
Type: schema.TypeString,
Computed: true,
Description: "The create time of the CAM role.",
},
"update_time": {
Type: schema.TypeString,
Computed: true,
Description: "The last update time of the CAM role.",
},
},
},
},
},
}
}
func dataSourceTencentCloudCamRolesRead(d *schema.ResourceData, meta interface{}) error {
defer tccommon.LogElapsed("data_source.tencentcloud_cam_roles.read")()
logId := tccommon.GetLogId(tccommon.ContextNil)
ctx := context.WithValue(context.TODO(), tccommon.LogIdKey, logId)
params := make(map[string]interface{})
if v, ok := d.GetOk("role_id"); ok {
params["role_id"] = v.(string)
}
if v, ok := d.GetOk("name"); ok {
params["name"] = v.(string)
}
if v, ok := d.GetOk("description"); ok {
params["description"] = v.(string)
}
camService := CamService{
client: meta.(tccommon.ProviderMeta).GetAPIV3Conn(),
}
var roles []*cam.RoleInfo
err := resource.Retry(tccommon.ReadRetryTimeout, func() *resource.RetryError {
results, e := camService.DescribeRolesByFilter(ctx, params)
if e != nil {
return tccommon.RetryError(e)
}
roles = results
return nil
})
if err != nil {
log.Printf("[CRITAL]%s read CAM roles failed, reason:%s\n", logId, err.Error())
return err
}
roleList := make([]map[string]interface{}, 0, len(roles))
ids := make([]string, 0, len(roles))
for _, role := range roles {
mapping := map[string]interface{}{
"role_id": *role.RoleId,
"name": *role.RoleName,
"document": *role.PolicyDocument,
"description": *role.Description,
"create_time": *role.AddTime,
"update_time": *role.UpdateTime,
}
if int(*role.ConsoleLogin) == 1 {
mapping["console_login"] = true
} else {
mapping["console_login"] = false
}
roleList = append(roleList, mapping)
ids = append(ids, *role.RoleId)
}
d.SetId(helper.DataResourceIdsHash(ids))
if e := d.Set("role_list", roleList); e != nil {
log.Printf("[CRITAL]%s provider set CAM role list fail, reason:%s\n", logId, e.Error())
return e
}
output, ok := d.GetOk("result_output_file")
if ok && output.(string) != "" {
if e := tccommon.WriteToFile(output.(string), roleList); e != nil {
return e
}
}
return nil
}