-
Notifications
You must be signed in to change notification settings - Fork 0
/
resource_user_group_association.go
110 lines (91 loc) · 3.01 KB
/
resource_user_group_association.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
package jumpcloud
import (
"context"
"strings"
jcapiv2 "github.com/TheJumpCloud/jcapi-go/v2"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
)
func resourceUserGroupAssociation() *schema.Resource {
return &schema.Resource{
CreateContext: resourceUserGroupAssociationCreate,
ReadContext: resourceUserGroupAssociationRead,
UpdateContext: nil,
DeleteContext: resourceUserGroupAssociationDelete,
Schema: map[string]*schema.Schema{
"groupid": {
Description: "The ID of the `resource_user_group` resource.",
Type: schema.TypeString,
Required: true,
ForceNew: true,
},
"appid": {
Description: "The ID of the application to associate to the group.",
Type: schema.TypeString,
Required: true,
ForceNew: true,
},
},
Importer: &schema.ResourceImporter{
StateContext: userGroupAssociationImporter,
},
}
}
func userGroupAssociationImporter(_ context.Context, d *schema.ResourceData, m interface{}) ([]*schema.ResourceData, error) {
s := strings.Split(d.Id(), "/")
d.Set("groupid", s[0])
d.Set("appid", s[1])
return []*schema.ResourceData{d}, nil
}
func modifyUserGroupAssociation(ctx context.Context, client *jcapiv2.APIClient, d *schema.ResourceData, action string) error {
payload := jcapiv2.UserGroupGraphManagementReq{
Op: action,
Type_: "application",
Id: d.Get("appid").(string),
}
req := map[string]interface{}{
"body": payload,
}
_, err := client.UserGroupAssociationsApi.GraphUserGroupAssociationsPost(ctx, d.Get("groupid").(string), "", "", req)
return err
}
func resourceUserGroupAssociationCreate(ctx context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics {
config := meta.(*jcapiv2.Configuration)
client := jcapiv2.NewAPIClient(config)
err := modifyUserGroupAssociation(ctx, client, d, "add")
if err != nil {
return diag.FromErr(err)
}
return resourceUserGroupAssociationRead(ctx, d, meta)
}
func resourceUserGroupAssociationRead(ctx context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics {
config := meta.(*jcapiv2.Configuration)
client := jcapiv2.NewAPIClient(config)
optionals := map[string]interface{}{
"groupId": d.Get("groupid").(string),
"limit": int32(100),
}
graphconnect, _, err := client.UserGroupAssociationsApi.GraphUserGroupAssociationsList(
ctx, d.Get("groupid").(string), "", "", []string{"application"}, optionals)
if err != nil {
return diag.FromErr(err)
}
for _, v := range graphconnect {
if v.To.Id == d.Get("appid") {
resourceId := d.Get("groupid").(string) + "/" + d.Get("appid").(string)
d.SetId(resourceId)
return nil
}
}
d.SetId("")
return nil
}
func resourceUserGroupAssociationDelete(ctx context.Context, d *schema.ResourceData, meta interface{}) diag.Diagnostics {
config := meta.(*jcapiv2.Configuration)
client := jcapiv2.NewAPIClient(config)
err := modifyUserGroupAssociation(ctx, client, d, "remove")
if err != nil {
return diag.FromErr(err)
}
return nil
}