This repository has been archived by the owner on Jul 3, 2023. It is now read-only.
/
pingfederate_redirect_validation_settings.go
111 lines (90 loc) · 4.28 KB
/
pingfederate_redirect_validation_settings.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
package framework
import (
"context"
"fmt"
pf "github.com/iwarapter/pingfederate-sdk-go/pingfederate/models"
"github.com/hashicorp/terraform-plugin-framework/types"
"github.com/hashicorp/terraform-plugin-framework/path"
"github.com/hashicorp/terraform-plugin-framework/resource"
"github.com/iwarapter/pingfederate-sdk-go/services/redirectValidation"
)
// Ensure the implementation satisfies the expected interfaces.
var (
_ resource.Resource = &pingfederateRedirectValidationSettingsResource{}
_ resource.ResourceWithConfigure = &pingfederateRedirectValidationSettingsResource{}
_ resource.ResourceWithImportState = &pingfederateRedirectValidationSettingsResource{}
)
type pingfederateRedirectValidationSettingsResource struct {
client *pfClient
}
func NewRedirectValidationResource() resource.Resource {
return &pingfederateRedirectValidationSettingsResource{}
}
func (r *pingfederateRedirectValidationSettingsResource) Schema(ctx context.Context, request resource.SchemaRequest, response *resource.SchemaResponse) {
response.Schema = resourceRedirectValidationSettings()
}
// Configure adds the client configured client to the resource.
func (r *pingfederateRedirectValidationSettingsResource) 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 *pingfederateRedirectValidationSettingsResource) Metadata(_ context.Context, req resource.MetadataRequest, resp *resource.MetadataResponse) {
resp.TypeName = req.ProviderTypeName + "_redirect_validation_settings"
}
func (r *pingfederateRedirectValidationSettingsResource) Create(ctx context.Context, req resource.CreateRequest, resp *resource.CreateResponse) {
var data RedirectValidationSettingsData
resp.Diagnostics.Append(req.Plan.Get(ctx, &data)...)
if resp.Diagnostics.HasError() {
return
}
body, _, err := r.client.RedirectValidation.UpdateRedirectValidationSettingsWithContext(ctx, &redirectValidation.UpdateRedirectValidationSettingsInput{
Body: *expandRedirectValidationSettings(data),
})
if err != nil {
resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Unable to create RedirectValidation, got error: %s", err))
return
}
resp.Diagnostics.Append(resp.State.Set(ctx, addRedirectValidationSettingsId(body))...)
}
func (r *pingfederateRedirectValidationSettingsResource) Read(ctx context.Context, req resource.ReadRequest, resp *resource.ReadResponse) {
var data RedirectValidationSettingsData
resp.Diagnostics.Append(req.State.Get(ctx, &data)...)
if resp.Diagnostics.HasError() {
return
}
body, _, err := r.client.RedirectValidation.GetRedirectValidationSettingsWithContext(ctx)
if err != nil {
resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Unable to get RedirectValidation, got error: %s", err))
return
}
resp.Diagnostics.Append(resp.State.Set(ctx, addRedirectValidationSettingsId(body))...)
}
func (r *pingfederateRedirectValidationSettingsResource) Update(ctx context.Context, req resource.UpdateRequest, resp *resource.UpdateResponse) {
var data RedirectValidationSettingsData
resp.Diagnostics.Append(req.Plan.Get(ctx, &data)...)
if resp.Diagnostics.HasError() {
return
}
body, _, err := r.client.RedirectValidation.UpdateRedirectValidationSettingsWithContext(ctx, &redirectValidation.UpdateRedirectValidationSettingsInput{
Body: *expandRedirectValidationSettings(data),
})
if err != nil {
resp.Diagnostics.AddError("Client Error", fmt.Sprintf("Unable to update RedirectValidation, got error: %s", err))
return
}
resp.Diagnostics.Append(resp.State.Set(ctx, addRedirectValidationSettingsId(body))...)
}
func (r *pingfederateRedirectValidationSettingsResource) Delete(ctx context.Context, _ resource.DeleteRequest, resp *resource.DeleteResponse) {
resp.State.RemoveResource(ctx)
}
func (r *pingfederateRedirectValidationSettingsResource) ImportState(ctx context.Context, req resource.ImportStateRequest, resp *resource.ImportStateResponse) {
resource.ImportStatePassthroughID(ctx, path.Root("id"), req, resp)
}
func addRedirectValidationSettingsId(body *pf.RedirectValidationSettings) RedirectValidationSettingsData {
save := *flattenRedirectValidationSettings(body)
save.Id = types.StringValue("settings")
return save
}