Skip to content

Commit

Permalink
Merge pull request #18 from instana/API_implementation_Infra_Alert_Co…
Browse files Browse the repository at this point in the history
…nfig

Add API implementation for Infra Alert Config
  • Loading branch information
parekh-raj authored Nov 11, 2024
2 parents ebd12dd + 59e2a0b commit e2eac03
Show file tree
Hide file tree
Showing 8 changed files with 82 additions and 2 deletions.
4 changes: 4 additions & 0 deletions instana/restapi/Instana-api.go
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,10 @@ func (api *baseInstanaAPI) WebsiteAlertConfig() RestResource[*WebsiteAlertConfig
return NewCreatePOSTUpdatePOSTRestResource(WebsiteAlertConfigResourcePath, NewCustomPayloadFieldsUnmarshallerAdapter(NewDefaultJSONUnmarshaller(&WebsiteAlertConfig{})), api.client)
}

func (api *baseInstanaAPI) InfraAlertConfig() RestResource[*InfraAlertConfig] {
return NewCreatePOSTUpdatePOSTRestResource(InfraAlertConfigResourcePath, NewCustomPayloadFieldsUnmarshallerAdapter(NewDefaultJSONUnmarshaller(&InfraAlertConfig{})), api.client)
}

func (api *baseInstanaAPI) Groups() RestResource[*Group] {
return NewCreatePOSTUpdatePUTRestResource(GroupsResourcePath, NewDefaultJSONUnmarshaller(&Group{}), api.client)
}
Expand Down
7 changes: 6 additions & 1 deletion instana/restapi/aggregation.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,12 @@ const (
DistinctCountAggregation = Aggregation("DISTINCT_COUNT")
//SumPositiveAggregation constant value for the sum positive aggregation type
SumPositiveAggregation = Aggregation("SUM_POSITIVE")
PerSecondAggregation = Aggregation("PER_SECOND")
IncreaseAggregation = Aggregation("INCREASE")
)

// SupportedAggregations list of all supported Aggregation
var SupportedAggregations = Aggregations{SumAggregation, MeanAggregation, MaxAggregation, MinAggregation, Percentile25Aggregation, Percentile50Aggregation, Percentile75Aggregation, Percentile90Aggregation, Percentile95Aggregation, Percentile98Aggregation, Percentile99Aggregation, Percentile99_9Aggregation, Percentile99_99Aggregation, DistributionAggregation, DistinctCountAggregation, SumPositiveAggregation}
var SupportedAggregations = Aggregations{SumAggregation, MeanAggregation, MaxAggregation, MinAggregation, Percentile25Aggregation,
Percentile50Aggregation, Percentile75Aggregation, Percentile90Aggregation, Percentile95Aggregation, Percentile98Aggregation,
Percentile99Aggregation, Percentile99_9Aggregation, Percentile99_99Aggregation, DistributionAggregation,
DistinctCountAggregation, SumPositiveAggregation, PerSecondAggregation, IncreaseAggregation}
3 changes: 2 additions & 1 deletion instana/restapi/aggregation_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
)

func TestShouldReturnSupportedAggregationsAsStringSlice(t *testing.T) {
expected := []string{"SUM", "MEAN", "MAX", "MIN", "P25", "P50", "P75", "P90", "P95", "P98", "P99", "P99_9", "P99_99", "DISTRIBUTION", "DISTINCT_COUNT", "SUM_POSITIVE"}
expected := []string{"SUM", "MEAN", "MAX", "MIN", "P25", "P50", "P75", "P90", "P95", "P98", "P99", "P99_9", "P99_99",
"DISTRIBUTION", "DISTINCT_COUNT", "SUM_POSITIVE", "PER_SECOND", "INCREASE"}
require.Equal(t, expected, SupportedAggregations.ToStringSlice())
}
28 changes: 28 additions & 0 deletions instana/restapi/infra-alert-configs.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
package restapi

const InfraAlertConfigResourcePath = EventSettingsBasePath + "/infra-alert-configs"

type InfraAlertConfig struct {
ID string `json:"id"`
Name string `json:"name"`
Description string `json:"description"`
TagFilterExpression *TagFilter `json:"tagFilterExpression"`
GroupBy []string `json:"groupBy"`
AlertChannelIDs []string `json:"alertChannelIds"`
Granularity Granularity `json:"granularity"`
TimeThreshold InfraTimeThreshold `json:"timeThreshold"`
CustomerPayloadFields []CustomPayloadField[any] `json:"customPayloadFields"`
Rules []RuleWithThreshold[InfraAlertRule] `json:"rules"`
}

func (config *InfraAlertConfig) GetIDForResourcePath() string {
return config.ID
}

func (config *InfraAlertConfig) GetCustomerPayloadFields() []CustomPayloadField[any] {
return config.CustomerPayloadFields
}

func (config *InfraAlertConfig) SetCustomerPayloadFields(fields []CustomPayloadField[any]) {
config.CustomerPayloadFields = fields
}
10 changes: 10 additions & 0 deletions instana/restapi/infra-alert-rule.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
package restapi

type InfraAlertRule struct {
AlertType string `json:"alertType"`
MetricName string `json:"metricName"`
EntityType string `json:"entityType"`
Aggregation *Aggregation `json:"aggregation"`
CrossSeriesAggregation *Aggregation `json:"crossSeriesAggregation"`
Regex bool `json:"regex"`
}
6 changes: 6 additions & 0 deletions instana/restapi/infra-time-threshold.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
package restapi

type InfraTimeThreshold struct {
Type string `json:"type"`
TimeWindow *int64 `json:"timeWindow"`
}
18 changes: 18 additions & 0 deletions instana/restapi/rule-with-threshold.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
package restapi

type RuleWithThreshold[R InfraAlertRule | ApplicationAlertRule | WebsiteAlertRule] struct {
ThresholdOperator ThresholdOperator `json:"thresholdOperator"`
Rule R `json:"rule"`
Thresholds map[AlertSeverity]ThresholdRule `json:"thresholds"`
}

type AlertSeverity string
type AlertSeverities []AlertSeverity

const (
WarningSeverity = AlertSeverity("WARNING")
CriticalSeverity = AlertSeverity("CRITICAL")
)

// SupportedAlertSeverities : will be used as part of validation in a follow-up.
var SupportedAlertSeverities = AlertSeverities{WarningSeverity, CriticalSeverity}
8 changes: 8 additions & 0 deletions instana/restapi/threshold.go
Original file line number Diff line number Diff line change
Expand Up @@ -72,3 +72,11 @@ type TimeThreshold struct {
Requests *int32 `json:"requests"`
Violations *int32 `json:"violations"`
}

type ThresholdRule struct {
Type string `json:"type"`
Value *float64 `json:"value"`
Seasonality *ThresholdSeasonality `json:"seasonality"`
Baseline *[][]float64 `json:"baseline"`
DeviationFactor *float32 `json:"deviationFactor"`
}

0 comments on commit e2eac03

Please sign in to comment.