From af4633a82b7c7c82bdde3c73087fb749130761c1 Mon Sep 17 00:00:00 2001 From: Robert Ross Date: Wed, 23 Oct 2024 17:40:27 -0400 Subject: [PATCH] Set ID to nothing if the policy is gone on the API --- CHANGELOG.md | 5 +++++ provider/escalation_policy_resource.go | 10 ++++++++++ 2 files changed, 15 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0f5d4adc..31f580ba 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,8 @@ +## 0.13.1 + +BUG FIXES: +* Fixes a bug where escalation policy resources were not being removed from state if deleted outside of Terraform + ## 0.13.0 ENHANCEMENTS: diff --git a/provider/escalation_policy_resource.go b/provider/escalation_policy_resource.go index 7ac2fe70..16484d58 100644 --- a/provider/escalation_policy_resource.go +++ b/provider/escalation_policy_resource.go @@ -2,6 +2,8 @@ package provider import ( "context" + "errors" + "fmt" "github.com/davecgh/go-spew/spew" "github.com/firehydrant/terraform-provider-firehydrant/firehydrant" @@ -106,6 +108,14 @@ func readResourceFireHydrantEscalationPolicy(ctx context.Context, d *schema.Reso escalationPolicy, err := firehydrantAPIClient.EscalationPolicies().Get(ctx, teamID, id) if err != nil { + if errors.Is(err, firehydrant.ErrorNotFound) { + tflog.Debug(ctx, fmt.Sprintf("Escalation Policy %s no longer exists", id), map[string]interface{}{ + "id": id, + }) + d.SetId("") + return nil + } + return diag.Errorf("Error reading escalation policy %s: %v", id, err) }