/
policy_set_definition_data_source.go
114 lines (95 loc) · 3.16 KB
/
policy_set_definition_data_source.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
package policy
import (
"encoding/json"
"fmt"
"time"
"github.com/Azure/azure-sdk-for-go/services/resources/mgmt/2019-09-01/policy"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
"github.com/hashicorp/terraform-plugin-sdk/helper/validation"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/internal/clients"
"github.com/terraform-providers/terraform-provider-azurerm/azurerm/internal/timeouts"
)
func dataSourceArmPolicySetDefinition() *schema.Resource {
return &schema.Resource{
Read: dataSourceArmPolicySetDefinitionRead,
Timeouts: &schema.ResourceTimeout{
Read: schema.DefaultTimeout(5 * time.Minute),
},
Schema: map[string]*schema.Schema{
"display_name": {
Type: schema.TypeString,
Optional: true,
Computed: true,
ValidateFunc: validation.StringIsNotEmpty,
ExactlyOneOf: []string{"name", "display_name"},
},
"name": {
Type: schema.TypeString,
Optional: true,
Computed: true,
ValidateFunc: validation.StringIsNotEmpty,
ExactlyOneOf: []string{"name", "display_name"},
},
"management_group_name": {
Type: schema.TypeString,
Optional: true,
},
"description": {
Type: schema.TypeString,
Computed: true,
},
"metadata": {
Type: schema.TypeString,
Computed: true,
},
"parameters": {
Type: schema.TypeString,
Computed: true,
},
"policy_definitions": {
Type: schema.TypeString,
Computed: true,
},
"policy_type": {
Type: schema.TypeString,
Computed: true,
},
},
}
}
func dataSourceArmPolicySetDefinitionRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*clients.Client).Policy.SetDefinitionsClient
ctx, cancel := timeouts.ForRead(meta.(*clients.Client).StopContext, d)
defer cancel()
name := d.Get("name").(string)
displayName := d.Get("display_name").(string)
managementGroupID := d.Get("management_group_name").(string)
var setDefinition policy.SetDefinition
var err error
// we marked `display_name` and `name` as `ExactlyOneOf`, therefore there will only be one of display_name and name that have non-empty value here
if displayName != "" {
setDefinition, err = getPolicySetDefinitionByDisplayName(ctx, client, displayName, managementGroupID)
if err != nil {
return fmt.Errorf("failed to read Policy Set Definition (Display Name %q): %+v", displayName, err)
}
}
if name != "" {
setDefinition, err = getPolicySetDefinitionByName(ctx, client, name, managementGroupID)
if err != nil {
return fmt.Errorf("failed to read Policy Set Definition %q: %+v", name, err)
}
}
d.SetId(*setDefinition.ID)
d.Set("name", setDefinition.Name)
d.Set("display_name", setDefinition.DisplayName)
d.Set("description", setDefinition.Description)
d.Set("policy_type", setDefinition.PolicyType)
d.Set("metadata", flattenJSON(setDefinition.Metadata))
d.Set("parameters", flattenJSON(setDefinition.Parameters))
definitionBytes, err := json.Marshal(setDefinition.PolicyDefinitions)
if err != nil {
return fmt.Errorf("unable to flatten JSON for `policy_defintions`: %+v", err)
}
d.Set("policy_definitions", string(definitionBytes))
return nil
}