|
@@ -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 {
|
|
|
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 {
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
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
|
|
|
}
|
|
}
|