alicloud/data_source_alicloud_ims_oidc_providers.go (198 lines of code) (raw):
// Package alicloud. This file is generated automatically. Please do not modify it manually, thank you!
package alicloud
import (
"fmt"
"regexp"
"time"
"github.com/PaesslerAG/jsonpath"
util "github.com/alibabacloud-go/tea-utils/service"
"github.com/aliyun/terraform-provider-alicloud/alicloud/connectivity"
"github.com/blues/jsonata-go"
"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 dataSourceAliCloudImsOidcProviders() *schema.Resource {
return &schema.Resource{
Read: dataSourceAliCloudImsOidcProviderRead,
Schema: map[string]*schema.Schema{
"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,
},
"providers": {
Type: schema.TypeList,
Computed: true,
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
"arn": {
Type: schema.TypeString,
Computed: true,
},
"client_ids": {
Type: schema.TypeSet,
Computed: true,
Elem: &schema.Schema{Type: schema.TypeString},
},
"create_time": {
Type: schema.TypeString,
Computed: true,
},
"description": {
Type: schema.TypeString,
Computed: true,
},
"fingerprints": {
Type: schema.TypeSet,
Computed: true,
Elem: &schema.Schema{Type: schema.TypeString},
},
"issuance_limit_time": {
Type: schema.TypeInt,
Computed: true,
},
"issuer_url": {
Type: schema.TypeString,
Computed: true,
},
"oidc_provider_name": {
Type: schema.TypeString,
Computed: true,
},
"update_time": {
Type: schema.TypeString,
Computed: true,
},
"id": {
Type: schema.TypeString,
Computed: true,
},
},
},
},
"output_file": {
Type: schema.TypeString,
Optional: true,
ForceNew: true,
},
},
}
}
func dataSourceAliCloudImsOidcProviderRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
var objects []map[string]interface{}
var nameRegex *regexp.Regexp
if v, ok := d.GetOk("name_regex"); ok {
r, err := regexp.Compile(v.(string))
if err != nil {
return WrapError(err)
}
nameRegex = 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 request map[string]interface{}
var response map[string]interface{}
var query map[string]interface{}
action := "ListOIDCProviders"
var err error
request = make(map[string]interface{})
query = make(map[string]interface{})
runtime := util.RuntimeOptions{}
runtime.SetAutoretry(true)
request["MaxResults"] = PageSizeLarge
for {
wait := incrementalWait(3*time.Second, 5*time.Second)
err = resource.Retry(d.Timeout(schema.TimeoutUpdate), func() *resource.RetryError {
response, err = client.RpcPost("Ims", "2019-08-15", action, query, request, true)
if err != nil {
if NeedRetry(err) {
wait()
return resource.RetryableError(err)
}
return resource.NonRetryableError(err)
}
addDebug(action, response, request)
return nil
})
if err != nil {
return WrapErrorf(err, DefaultErrorMsg, d.Id(), action, AlibabaCloudSdkGoERROR)
}
resp, _ := jsonpath.Get("$.OIDCProviders.OIDCProvider[*]", response)
result, _ := resp.([]interface{})
for _, v := range result {
item := v.(map[string]interface{})
if nameRegex != nil && !nameRegex.MatchString(fmt.Sprint(item["OIDCProviderName"])) {
continue
}
if len(idsMap) > 0 {
if _, ok := idsMap[fmt.Sprint(item["OIDCProviderName"])]; !ok {
continue
}
}
objects = append(objects, item)
}
if nextToken, ok := response["NextToken"].(string); ok && nextToken != "" {
request["NextToken"] = nextToken
} else {
break
}
}
ids := make([]string, 0)
names := make([]interface{}, 0)
s := make([]map[string]interface{}, 0)
for _, objectRaw := range objects {
mapping := map[string]interface{}{}
mapping["id"] = objectRaw["OIDCProviderName"]
mapping["arn"] = objectRaw["Arn"]
mapping["create_time"] = objectRaw["CreateDate"]
mapping["description"] = objectRaw["Description"]
mapping["issuance_limit_time"] = objectRaw["IssuanceLimitTime"]
mapping["issuer_url"] = objectRaw["IssuerUrl"]
mapping["update_time"] = objectRaw["UpdateDate"]
mapping["oidc_provider_name"] = objectRaw["OIDCProviderName"]
e := jsonata.MustCompile("$split($.ClientIds, \",\")\n")
evaluation, _ := e.Eval(objectRaw)
mapping["client_ids"] = evaluation
e = jsonata.MustCompile("$split($.Fingerprints, \",\")\n")
evaluation, _ = e.Eval(objectRaw)
mapping["fingerprints"] = evaluation
ids = append(ids, fmt.Sprint(mapping["id"]))
names = append(names, objectRaw["OidcProviderName"])
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("providers", s); err != nil {
return WrapError(err)
}
if output, ok := d.GetOk("output_file"); ok && output.(string) != "" {
writeToFile(output.(string), s)
}
return nil
}