Alerting: Fix notification channel migration and handle case when Alertmanager default configuration is absent (#35086)

* Fix dashboard alert and nootifier migration for MySQL

* Fix POSTing Alertmanager configuration if no current configuration exists

in case the default configuration has not be stored yet
or has failed to get stored

* Change CreatedAt field type
This commit is contained in:
Sofia Papagiannaki 2021-06-04 15:52:41 +03:00 committed by GitHub
parent c13f247a94
commit 15c55b0115
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 12 additions and 11 deletions

View File

@ -192,11 +192,14 @@ func (srv AlertmanagerSrv) RoutePostAlertingConfig(c *models.ReqContext, body ap
}
}
currentConfig, err := notifier.Load([]byte(query.Result.AlertmanagerConfiguration))
if err != nil {
return ErrResp(http.StatusInternalServerError, err, "failed to load lastest configuration")
currentReceiverMap := make(map[string]*apimodels.PostableGrafanaReceiver)
if query.Result != nil {
currentConfig, err := notifier.Load([]byte(query.Result.AlertmanagerConfiguration))
if err != nil {
return ErrResp(http.StatusInternalServerError, err, "failed to load lastest configuration")
}
currentReceiverMap = currentConfig.GetGrafanaReceiverMap()
}
currentReceiverMap := currentConfig.GetGrafanaReceiverMap()
// Copy the previously known secure settings
for i, r := range body.AlertmanagerConfig.Receivers {

View File

@ -1,7 +1,5 @@
package models
import "time"
const AlertConfigurationVersion = 1
// AlertConfiguration represents a single version of the Alerting Engine Configuration.
@ -10,7 +8,7 @@ type AlertConfiguration struct {
AlertmanagerConfiguration string
ConfigurationVersion string
CreatedAt time.Time `xorm:"created"`
CreatedAt int64 `xorm:"created"`
Default bool
}

View File

@ -2,6 +2,7 @@ package ualert
import (
"encoding/json"
"fmt"
"time"
)
@ -30,7 +31,7 @@ SELECT id,
name,
message,
frequency,
for,
%s,
state,
settings
FROM
@ -43,7 +44,7 @@ FROM
// ParsedSettings property of the dash alert.
func (m *migration) slurpDashAlerts() ([]dashAlert, error) {
dashAlerts := []dashAlert{}
err := m.sess.SQL(slurpDashSQL).Find(&dashAlerts)
err := m.sess.SQL(fmt.Sprintf(slurpDashSQL, m.mg.Dialect.Quote("for"))).Find(&dashAlerts)
if err != nil {
return nil, err

View File

@ -4,7 +4,6 @@ import (
"encoding/json"
"fmt"
"os"
"time"
pb "github.com/prometheus/alertmanager/silence/silencepb"
"xorm.io/xorm"
@ -288,7 +287,7 @@ type AlertConfiguration struct {
AlertmanagerConfiguration string
ConfigurationVersion string
CreatedAt time.Time `xorm:"created"`
CreatedAt int64 `xorm:"created"`
}
type rmMigration struct {