Commit 488b4237 by bergquist

feat(alerting): update state if not been updated for 15min

parent 925806df
...@@ -140,6 +140,7 @@ func GetAlertStates(c *middleware.Context) Response { ...@@ -140,6 +140,7 @@ func GetAlertStates(c *middleware.Context) Response {
// PUT /api/alerts/events/:id // PUT /api/alerts/events/:id
func PutAlertState(c *middleware.Context, cmd models.UpdateAlertStateCommand) Response { func PutAlertState(c *middleware.Context, cmd models.UpdateAlertStateCommand) Response {
cmd.AlertId = c.ParamsInt64(":alertId") cmd.AlertId = c.ParamsInt64(":alertId")
cmd.OrgId = c.OrgId
query := models.GetAlertByIdQuery{Id: cmd.AlertId} query := models.GetAlertByIdQuery{Id: cmd.AlertId}
if err := bus.Dispatch(&query); err != nil { if err := bus.Dispatch(&query); err != nil {
......
...@@ -28,6 +28,7 @@ func (this *UpdateAlertStateCommand) IsValidState() bool { ...@@ -28,6 +28,7 @@ func (this *UpdateAlertStateCommand) IsValidState() bool {
type UpdateAlertStateCommand struct { type UpdateAlertStateCommand struct {
AlertId int64 `json:"alertId" binding:"Required"` AlertId int64 `json:"alertId" binding:"Required"`
OrgId int64 `json:"orgId" binding:"Required"`
NewState string `json:"newState" binding:"Required"` NewState string `json:"newState" binding:"Required"`
Info string `json:"info"` Info string `json:"info"`
...@@ -42,3 +43,10 @@ type GetAlertsStateQuery struct { ...@@ -42,3 +43,10 @@ type GetAlertsStateQuery struct {
Result *[]AlertState Result *[]AlertState
} }
type GetLastAlertStateQuery struct {
AlertId int64
OrgId int64
Result *AlertState
}
...@@ -143,14 +143,12 @@ func (e *Engine) resultHandler() { ...@@ -143,14 +143,12 @@ func (e *Engine) resultHandler() {
} }
func (e *Engine) reactToState(result *AlertResult) { func (e *Engine) reactToState(result *AlertResult) {
query := &m.GetAlertByIdQuery{Id: result.AlertJob.Rule.Id} if shouldUpdateState(result) {
bus.Dispatch(query)
if query.Result.ShouldUpdateState(result.State) {
cmd := &m.UpdateAlertStateCommand{ cmd := &m.UpdateAlertStateCommand{
AlertId: result.AlertJob.Rule.Id, AlertId: result.AlertJob.Rule.Id,
NewState: result.State, NewState: result.State,
Info: result.Description, Info: result.Description,
OrgId: result.AlertJob.Rule.OrgId,
} }
if err := bus.Dispatch(cmd); err != nil { if err := bus.Dispatch(cmd); err != nil {
...@@ -161,3 +159,22 @@ func (e *Engine) reactToState(result *AlertResult) { ...@@ -161,3 +159,22 @@ func (e *Engine) reactToState(result *AlertResult) {
e.notifier.Notify(result) e.notifier.Notify(result)
} }
} }
func shouldUpdateState(result *AlertResult) bool {
query := &m.GetLastAlertStateQuery{
AlertId: result.AlertJob.Rule.Id,
OrgId: result.AlertJob.Rule.OrgId,
}
if err := bus.Dispatch(query); err != nil {
log.Error2("Failed to read last alert state", "error", err)
return false
}
now := time.Now()
noEarlierState := query.Result == nil
olderThen15Min := query.Result.Created.Before(now.Add(time.Minute * -15))
changedState := query.Result.NewState != result.State
return noEarlierState || changedState || olderThen15Min
}
...@@ -12,6 +12,23 @@ import ( ...@@ -12,6 +12,23 @@ import (
func init() { func init() {
bus.AddHandler("sql", SetNewAlertState) bus.AddHandler("sql", SetNewAlertState)
bus.AddHandler("sql", GetAlertStateLogByAlertId) bus.AddHandler("sql", GetAlertStateLogByAlertId)
bus.AddHandler("sql", GetLastAlertStateQuery)
}
func GetLastAlertStateQuery(cmd *m.GetLastAlertStateQuery) error {
states := make([]m.AlertState, 0)
if err := x.Where("alert_id = ? and org_id = ? ", cmd.AlertId, cmd.OrgId).Desc("created").Find(&states); err != nil {
return err
}
if len(states) == 0 {
cmd.Result = nil
return fmt.Errorf("invalid amount of alertstates. Expected 1 got %v", len(states))
}
cmd.Result = &states[0]
return nil
} }
func SetNewAlertState(cmd *m.UpdateAlertStateCommand) error { func SetNewAlertState(cmd *m.UpdateAlertStateCommand) error {
...@@ -30,17 +47,12 @@ func SetNewAlertState(cmd *m.UpdateAlertStateCommand) error { ...@@ -30,17 +47,12 @@ func SetNewAlertState(cmd *m.UpdateAlertStateCommand) error {
return fmt.Errorf("Could not find alert") return fmt.Errorf("Could not find alert")
} }
if alert.State == cmd.NewState {
cmd.Result = &m.Alert{}
return nil
}
alert.State = cmd.NewState alert.State = cmd.NewState
sess.Id(alert.Id).Update(&alert) sess.Id(alert.Id).Update(&alert)
alertState := m.AlertState{ alertState := m.AlertState{
AlertId: cmd.AlertId, AlertId: cmd.AlertId,
OrgId: cmd.AlertId, OrgId: cmd.OrgId,
NewState: cmd.NewState, NewState: cmd.NewState,
Info: cmd.Info, Info: cmd.Info,
Created: time.Now(), Created: time.Now(),
...@@ -54,12 +66,12 @@ func SetNewAlertState(cmd *m.UpdateAlertStateCommand) error { ...@@ -54,12 +66,12 @@ func SetNewAlertState(cmd *m.UpdateAlertStateCommand) error {
} }
func GetAlertStateLogByAlertId(cmd *m.GetAlertsStateQuery) error { func GetAlertStateLogByAlertId(cmd *m.GetAlertsStateQuery) error {
alertLogs := make([]m.AlertState, 0) states := make([]m.AlertState, 0)
if err := x.Where("alert_id = ?", cmd.AlertId).Desc("created").Find(&alertLogs); err != nil { if err := x.Where("alert_id = ?", cmd.AlertId).Desc("created").Find(&states); err != nil {
return err return err
} }
cmd.Result = &alertLogs cmd.Result = &states
return nil return nil
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment