This repository has been archived by the owner on Jul 3, 2023. It is now read-only.
/
pingfederate_application_session_policy.go
114 lines (90 loc) · 4.14 KB
/
pingfederate_application_session_policy.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 framework
import (
"context"
"fmt"
"github.com/hashicorp/terraform-plugin-framework/types"
pf "github.com/iwarapter/pingfederate-sdk-go/pingfederate/models"
"github.com/iwarapter/pingfederate-sdk-go/services/session"
"github.com/hashicorp/terraform-plugin-framework/path"
"github.com/hashicorp/terraform-plugin-framework/resource"
)
// Ensure the implementation satisfies the expected interfaces.
var (
_ resource.Resource = &pingfederateApplicationSessionPolicyResource{}
_ resource.ResourceWithConfigure = &pingfederateApplicationSessionPolicyResource{}
_ resource.ResourceWithImportState = &pingfederateApplicationSessionPolicyResource{}
)
type pingfederateApplicationSessionPolicyResource struct {
client *pfClient
}
func NewApplicationSessionPolicyResource() resource.Resource {
return &pingfederateApplicationSessionPolicyResource{}
}
func (r *pingfederateApplicationSessionPolicyResource) Schema(ctx context.Context, request resource.SchemaRequest, response *resource.SchemaResponse) {
response.Schema = resourceApplicationSessionPolicy()
}
// Configure adds the client configured client to the resource.
func (r *pingfederateApplicationSessionPolicyResource) Configure(_ context.Context, req resource.ConfigureRequest, resp *resource.ConfigureResponse) {
if req.ProviderData == nil {
return
}
r.client = req.ProviderData.(*pfClient)
}
// Metadata returns the resource type name.
func (r *pingfederateApplicationSessionPolicyResource) Metadata(_ context.Context, req resource.MetadataRequest, resp *resource.MetadataResponse) {
resp.TypeName = req.ProviderTypeName + "_application_session_policy"
}
func (r *pingfederateApplicationSessionPolicyResource) Create(ctx context.Context, req resource.CreateRequest, resp *resource.CreateResponse) {
var data ApplicationSessionPolicyData
resp.Diagnostics.Append(req.Plan.Get(ctx, &data)...)
if resp.Diagnostics.HasError() {
return
}
body, _, err := r.client.Session.UpdateApplicationPolicyWithContext(ctx, &session.UpdateApplicationPolicyInput{
Body: *expandApplicationSessionPolicy(data),
})
if err != nil {
resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Unable to create ApplicationSessionPolicy, got error: %s", err))
return
}
resp.Diagnostics.Append(resp.State.Set(ctx, addApplicationSessionPolicyId(body))...)
}
func (r *pingfederateApplicationSessionPolicyResource) Read(ctx context.Context, req resource.ReadRequest, resp *resource.ReadResponse) {
var data ApplicationSessionPolicyData
resp.Diagnostics.Append(req.State.Get(ctx, &data)...)
if resp.Diagnostics.HasError() {
return
}
body, _, err := r.client.Session.GetApplicationPolicyWithContext(ctx)
if err != nil {
resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Unable to get ApplicationSessionPolicy, got error: %s", err))
return
}
resp.Diagnostics.Append(resp.State.Set(ctx, addApplicationSessionPolicyId(body))...)
}
func (r *pingfederateApplicationSessionPolicyResource) Update(ctx context.Context, req resource.UpdateRequest, resp *resource.UpdateResponse) {
var data ApplicationSessionPolicyData
resp.Diagnostics.Append(req.Plan.Get(ctx, &data)...)
if resp.Diagnostics.HasError() {
return
}
body, _, err := r.client.Session.UpdateApplicationPolicyWithContext(ctx, &session.UpdateApplicationPolicyInput{
Body: *expandApplicationSessionPolicy(data),
})
if err != nil {
resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Unable to update ApplicationSessionPolicy, got error: %s", err))
return
}
resp.Diagnostics.Append(resp.State.Set(ctx, addApplicationSessionPolicyId(body))...)
}
func (r *pingfederateApplicationSessionPolicyResource) Delete(ctx context.Context, req resource.DeleteRequest, resp *resource.DeleteResponse) {
resp.State.RemoveResource(ctx)
}
func (r *pingfederateApplicationSessionPolicyResource) ImportState(ctx context.Context, req resource.ImportStateRequest, resp *resource.ImportStateResponse) {
resource.ImportStatePassthroughID(ctx, path.Root("id"), req, resp)
}
func addApplicationSessionPolicyId(body *pf.ApplicationSessionPolicy) ApplicationSessionPolicyData {
save := *flattenApplicationSessionPolicy(body)
save.Id = types.StringValue("settings")
return save
}