| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- package alerting
- import (
- m "github.com/grafana/grafana/pkg/models"
- "github.com/grafana/grafana/pkg/services/alerting/graphite"
- )
- type Executor interface {
- Execute(rule *m.AlertJob, responseQueue chan *AlertResult)
- }
- type ExecutorImpl struct{}
- type compareFn func(float64, float64) bool
- type aggregationFn func(*m.TimeSeries) float64
- var operators map[string]compareFn = map[string]compareFn{
- ">": func(num1, num2 float64) bool { return num1 > num2 },
- ">=": func(num1, num2 float64) bool { return num1 >= num2 },
- "<": func(num1, num2 float64) bool { return num1 < num2 },
- "<=": func(num1, num2 float64) bool { return num1 <= num2 },
- "": func(num1, num2 float64) bool { return false },
- }
- var aggregator map[string]aggregationFn = map[string]aggregationFn{
- "avg": func(series *m.TimeSeries) float64 { return series.Avg },
- "sum": func(series *m.TimeSeries) float64 { return series.Sum },
- "min": func(series *m.TimeSeries) float64 { return series.Min },
- "max": func(series *m.TimeSeries) float64 { return series.Max },
- "mean": func(series *m.TimeSeries) float64 { return series.Mean },
- }
- func (this *ExecutorImpl) Execute(rule *m.AlertJob, responseQueue chan *AlertResult) {
- response, err := graphite.GraphiteClient{}.GetSeries(rule)
- if err != nil {
- responseQueue <- &AlertResult{State: "PENDING", Id: rule.Rule.Id}
- }
- responseQueue <- this.ValidateRule(rule.Rule, response)
- }
- func (this *ExecutorImpl) ValidateRule(rule m.AlertRule, series m.TimeSeriesSlice) *AlertResult {
- for _, serie := range series {
- if aggregator[rule.Aggregator] == nil {
- continue
- }
- var aggValue = aggregator[rule.Aggregator](serie)
- if operators[rule.CritOperator](aggValue, float64(rule.CritLevel)) {
- return &AlertResult{State: m.AlertStateCritical, Id: rule.Id, ActualValue: aggValue}
- }
- if operators[rule.WarnOperator](aggValue, float64(rule.WarnLevel)) {
- return &AlertResult{State: m.AlertStateWarn, Id: rule.Id, ActualValue: aggValue}
- }
- }
- return &AlertResult{State: m.AlertStateOk, Id: rule.Id}
- }
|