Skip to content

Commit 488b423

Browse files
committed
feat(alerting): update state if not been updated for 15min
1 parent 925806d commit 488b423

File tree

4 files changed

+51
-13
lines changed

4 files changed

+51
-13
lines changed

pkg/api/alerting.go

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -140,6 +140,7 @@ func GetAlertStates(c *middleware.Context) Response {
140140
// PUT /api/alerts/events/:id
141141
func PutAlertState(c *middleware.Context, cmd models.UpdateAlertStateCommand) Response {
142142
cmd.AlertId = c.ParamsInt64(":alertId")
143+
cmd.OrgId = c.OrgId
143144

144145
query := models.GetAlertByIdQuery{Id: cmd.AlertId}
145146
if err := bus.Dispatch(&query); err != nil {

pkg/models/alert_state.go

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -28,6 +28,7 @@ func (this *UpdateAlertStateCommand) IsValidState() bool {
2828

2929
type UpdateAlertStateCommand struct {
3030
AlertId int64 `json:"alertId" binding:"Required"`
31+
OrgId int64 `json:"orgId" binding:"Required"`
3132
NewState string `json:"newState" binding:"Required"`
3233
Info string `json:"info"`
3334

@@ -42,3 +43,10 @@ type GetAlertsStateQuery struct {
4243

4344
Result *[]AlertState
4445
}
46+
47+
type GetLastAlertStateQuery struct {
48+
AlertId int64
49+
OrgId int64
50+
51+
Result *AlertState
52+
}

pkg/services/alerting/engine.go

Lines changed: 21 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -143,14 +143,12 @@ func (e *Engine) resultHandler() {
143143
}
144144

145145
func (e *Engine) reactToState(result *AlertResult) {
146-
query := &m.GetAlertByIdQuery{Id: result.AlertJob.Rule.Id}
147-
bus.Dispatch(query)
148-
149-
if query.Result.ShouldUpdateState(result.State) {
146+
if shouldUpdateState(result) {
150147
cmd := &m.UpdateAlertStateCommand{
151148
AlertId: result.AlertJob.Rule.Id,
152149
NewState: result.State,
153150
Info: result.Description,
151+
OrgId: result.AlertJob.Rule.OrgId,
154152
}
155153

156154
if err := bus.Dispatch(cmd); err != nil {
@@ -161,3 +159,22 @@ func (e *Engine) reactToState(result *AlertResult) {
161159
e.notifier.Notify(result)
162160
}
163161
}
162+
163+
func shouldUpdateState(result *AlertResult) bool {
164+
query := &m.GetLastAlertStateQuery{
165+
AlertId: result.AlertJob.Rule.Id,
166+
OrgId: result.AlertJob.Rule.OrgId,
167+
}
168+
169+
if err := bus.Dispatch(query); err != nil {
170+
log.Error2("Failed to read last alert state", "error", err)
171+
return false
172+
}
173+
174+
now := time.Now()
175+
noEarlierState := query.Result == nil
176+
olderThen15Min := query.Result.Created.Before(now.Add(time.Minute * -15))
177+
changedState := query.Result.NewState != result.State
178+
179+
return noEarlierState || changedState || olderThen15Min
180+
}

pkg/services/sqlstore/alert_state.go

Lines changed: 21 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,23 @@ import (
1212
func init() {
1313
bus.AddHandler("sql", SetNewAlertState)
1414
bus.AddHandler("sql", GetAlertStateLogByAlertId)
15+
bus.AddHandler("sql", GetLastAlertStateQuery)
16+
}
17+
18+
func GetLastAlertStateQuery(cmd *m.GetLastAlertStateQuery) error {
19+
states := make([]m.AlertState, 0)
20+
21+
if err := x.Where("alert_id = ? and org_id = ? ", cmd.AlertId, cmd.OrgId).Desc("created").Find(&states); err != nil {
22+
return err
23+
}
24+
25+
if len(states) == 0 {
26+
cmd.Result = nil
27+
return fmt.Errorf("invalid amount of alertstates. Expected 1 got %v", len(states))
28+
}
29+
30+
cmd.Result = &states[0]
31+
return nil
1532
}
1633

1734
func SetNewAlertState(cmd *m.UpdateAlertStateCommand) error {
@@ -30,17 +47,12 @@ func SetNewAlertState(cmd *m.UpdateAlertStateCommand) error {
3047
return fmt.Errorf("Could not find alert")
3148
}
3249

33-
if alert.State == cmd.NewState {
34-
cmd.Result = &m.Alert{}
35-
return nil
36-
}
37-
3850
alert.State = cmd.NewState
3951
sess.Id(alert.Id).Update(&alert)
4052

4153
alertState := m.AlertState{
4254
AlertId: cmd.AlertId,
43-
OrgId: cmd.AlertId,
55+
OrgId: cmd.OrgId,
4456
NewState: cmd.NewState,
4557
Info: cmd.Info,
4658
Created: time.Now(),
@@ -54,12 +66,12 @@ func SetNewAlertState(cmd *m.UpdateAlertStateCommand) error {
5466
}
5567

5668
func GetAlertStateLogByAlertId(cmd *m.GetAlertsStateQuery) error {
57-
alertLogs := make([]m.AlertState, 0)
69+
states := make([]m.AlertState, 0)
5870

59-
if err := x.Where("alert_id = ?", cmd.AlertId).Desc("created").Find(&alertLogs); err != nil {
71+
if err := x.Where("alert_id = ?", cmd.AlertId).Desc("created").Find(&states); err != nil {
6072
return err
6173
}
6274

63-
cmd.Result = &alertLogs
75+
cmd.Result = &states
6476
return nil
6577
}

0 commit comments

Comments
 (0)