Feature mute enhancement (#1041)
* [feature(#1029)] alert mute enhancement * handle error of proxy user Add
This commit is contained in:
parent
7359a69223
commit
5bc8f0b9b1
|
@ -35,31 +35,36 @@ func matchMute(event *models.AlertCurEvent, mute *models.AlertMute, clock ...int
|
|||
return matchTags(tg, mute.ITags)
|
||||
}
|
||||
|
||||
func matchTag(value string, filter models.TagFilter) bool {
|
||||
switch filter.Func {
|
||||
case "==":
|
||||
return filter.Value == value
|
||||
case "!=":
|
||||
return filter.Value != value
|
||||
case "in":
|
||||
_, has := filter.Vset[value]
|
||||
return has
|
||||
case "not in":
|
||||
_, has := filter.Vset[value]
|
||||
return !has
|
||||
case "=~":
|
||||
return filter.Regexp.MatchString(value)
|
||||
case "!~":
|
||||
return !filter.Regexp.MatchString(value)
|
||||
}
|
||||
// unexpect func
|
||||
return false
|
||||
}
|
||||
|
||||
func matchTags(eventTagsMap map[string]string, itags []models.TagFilter) bool {
|
||||
for i := 0; i < len(itags); i++ {
|
||||
filter := itags[i]
|
||||
value, exists := eventTagsMap[filter.Key]
|
||||
if !exists {
|
||||
for _, filter := range itags {
|
||||
value, has := eventTagsMap[filter.Key]
|
||||
if !has {
|
||||
return false
|
||||
}
|
||||
|
||||
if filter.Func == "==" {
|
||||
// ==
|
||||
if filter.Value != value {
|
||||
return false
|
||||
}
|
||||
} else if filter.Func == "in" {
|
||||
// in
|
||||
if _, has := filter.Vset[value]; !has {
|
||||
return false
|
||||
}
|
||||
} else {
|
||||
// =~
|
||||
if !filter.Regexp.MatchString(value) {
|
||||
if !matchTag(value, filter) {
|
||||
return false
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return true
|
||||
}
|
||||
|
|
|
@ -48,6 +48,9 @@ func handleProxyUser(c *gin.Context) *models.User {
|
|||
UpdateBy: "system",
|
||||
}
|
||||
err = user.Add()
|
||||
if err != nil {
|
||||
ginx.Bomb(http.StatusInternalServerError, err.Error())
|
||||
}
|
||||
}
|
||||
return user
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue