diff options
author | Julien Dessaux | 2023-09-25 00:06:41 +0200 |
---|---|---|
committer | Julien Dessaux | 2023-09-25 00:13:49 +0200 |
commit | 68326c685fb6257220845195fd9cb5cbb3907f06 (patch) | |
tree | 93ffe1bbf10371e95fd46d02b3b5e531001f4622 /internal | |
parent | Fixed various documentation entries (diff) | |
download | terraform-provider-eventline-68326c685fb6257220845195fd9cb5cbb3907f06.tar.gz terraform-provider-eventline-68326c685fb6257220845195fd9cb5cbb3907f06.tar.bz2 terraform-provider-eventline-68326c685fb6257220845195fd9cb5cbb3907f06.zip |
Fixed identity resource RawData idempotency
Diffstat (limited to 'internal')
-rw-r--r-- | internal/provider/identity_resource.go | 9 | ||||
-rw-r--r-- | internal/provider/utils.go | 17 |
2 files changed, 25 insertions, 1 deletions
diff --git a/internal/provider/identity_resource.go b/internal/provider/identity_resource.go index 8804f54..4df4219 100644 --- a/internal/provider/identity_resource.go +++ b/internal/provider/identity_resource.go @@ -143,7 +143,14 @@ func (r *IdentityResource) Read(ctx context.Context, req resource.ReadRequest, r data.Connector = types.StringValue(identity.Connector) data.Id = types.StringValue(identity.Id.String()) data.Name = types.StringValue(identity.Name) - data.RawData = types.StringValue(string(identity.RawData)) + rawDataEquals, err := JSONRawDataEqual(identity.RawData, json.RawMessage(data.RawData.ValueString())) + if err != nil { + resp.Diagnostics.AddError("JSONRawDataequal", fmt.Sprintf("Unable to compare identities RawData, got error: %s", err)) + return + } + if !rawDataEquals { + data.RawData = types.StringValue(string(identity.RawData)) + } data.Status = types.StringValue(string(identity.Status)) data.Type = types.StringValue(identity.Type) resp.Diagnostics.Append(resp.State.Set(ctx, &data)...) diff --git a/internal/provider/utils.go b/internal/provider/utils.go new file mode 100644 index 0000000..3b1b665 --- /dev/null +++ b/internal/provider/utils.go @@ -0,0 +1,17 @@ +package provider + +import ( + "encoding/json" + "reflect" +) + +func JSONRawDataEqual(a, b json.RawMessage) (bool, error) { + var j, j2 interface{} + if err := json.Unmarshal([]byte(a), &j); err != nil { + return false, err + } + if err := json.Unmarshal([]byte(b), &j2); err != nil { + return false, err + } + return reflect.DeepEqual(j2, j), nil +} |