From b1af5b3746344ec64467a3ef124ef9f63956d1ab Mon Sep 17 00:00:00 2001 From: YuyaKoda <29038315+ponkio-o@users.noreply.github.com> Date: Mon, 20 Mar 2023 11:10:37 +0900 Subject: [PATCH] change: added ValidateFunc for sigsci_site_alert (#142) --- provider/lib.go | 7 +++++++ provider/resource_site_alert.go | 20 ++++++++++++++++++++ 2 files changed, 27 insertions(+) diff --git a/provider/lib.go b/provider/lib.go index ddcc17b..7355170 100644 --- a/provider/lib.go +++ b/provider/lib.go @@ -343,6 +343,13 @@ func existsInString(needle string, haystack ...string) bool { return false } +func existsInRange(needle int, min, max int) bool { + if needle >= min && needle <= max { + return true + } + return false +} + func expandRuleConditions(conditionsResource *schema.Set) []sigsci.Condition { var conditions []sigsci.Condition for _, genericElement := range conditionsResource.List() { diff --git a/provider/resource_site_alert.go b/provider/resource_site_alert.go index 63cc2f0..0b75668 100644 --- a/provider/resource_site_alert.go +++ b/provider/resource_site_alert.go @@ -1,6 +1,8 @@ package provider import ( + "errors" + "github.com/hashicorp/terraform-plugin-sdk/helper/schema" "github.com/signalsciences/go-sigsci" ) @@ -33,11 +35,23 @@ func resourceSiteAlert() *schema.Resource { Type: schema.TypeInt, Description: "The number of minutes of past traffic to examine. Must be 1, 10 or 60.", Required: true, + ValidateFunc: func(val interface{}, key string) (warns []string, errs []error) { + if existsInInt(val.(int), 1, 10, 60) { + return nil, nil + } + return nil, []error{errors.New("interval must be 1, 10, or 60")} + }, }, "threshold": { Type: schema.TypeInt, Description: "The number of occurrences of the tag in the interval needed to trigger the alert. Min 1, Max 10000", Required: true, + ValidateFunc: func(val interface{}, key string) (warns []string, errs []error) { + if existsInRange(val.(int), 1, 10000) { + return nil, nil + } + return nil, []error{errors.New("threshold must be between 1 and 10000")} + }, }, "enabled": { Type: schema.TypeBool, @@ -48,6 +62,12 @@ func resourceSiteAlert() *schema.Resource { Type: schema.TypeString, Description: "A flag that describes what happens when the alert is triggered. 'info' creates an incident in the dashboard. 'flagged' creates an incident and blocks traffic for 24 hours. Must be info or flagged.", Required: true, + ValidateFunc: func(val interface{}, key string) (warns []string, errs []error) { + if existsInString(val.(string), "info", "flagged") { + return nil, nil + } + return nil, []error{errors.New("action must be 'info' or 'flagged'")} + }, }, "skip_notifications": { Type: schema.TypeBool,