Commit 3d628724 authored by 李科's avatar 李科

fix: 完善预警规则设置字段

parent cd9bb6ae
......@@ -15,6 +15,7 @@ type AlertRules struct {
DurationUnit string `json:"duration_unit" xorm:"'duration_unit'"` // 持续时间单位 s m h
CheckPeriod int `json:"check_period" xorm:"'check_period'"` // 检查周期 单位:分钟
NotifyMethod string `json:"notify_method" xorm:"'notify_method'"` // 预警通知方式 all dingtalk sms
NotifyRecipients string `json:"notify_recipients" xorm:"notify_recipients"` // 预警推送用户
NotifyPushCount int `json:"notify_push_count" xorm:"'notify_push_count'"` // 消息推送次数
NotifyPushFrequency int `json:"notify_push_frequency" xorm:"'notify_push_frequency'"` // 消息推送频率 分钟
IsEnabled int `json:"is_enabled" xorm:"'is_enabled'"` // 是否开启 0:关闭 1:启动
......@@ -39,3 +40,9 @@ type AlertCondition struct {
ThresholdsMin int `json:"thresholds_min" form:"thresholds_min" binding:"required"`
RiskLevel int `json:"risk_level" form:"risk_level" binding:"required"`
}
type NotifyRecipients struct {
SystemAccount string `json:"system_account" form:"system_account" binding:"required"`
Name string `json:"user_name" form:"user_name" binding:"required"`
Phone string `json:"phone" form:"phone" binding:"required"`
}
This diff is collapsed.
......@@ -4,6 +4,10 @@ import "gitlab.wodcloud.com/smart-operation/so-operation-api/src/bean/entity"
type AlertRulesItem struct {
entity.AlertRules `xorm:"extends"`
AlertCondition []entity.AlertCondition `json:"alert_condition" form:"alert_condition" binding:"required"`
AlertRange []entity.RulesAlertRange `json:"alert_range" form:"alert_range" binding:"required,dive"`
NotifyMethod []string `json:"notify_method" form:"notify_method" binding:"max=2,dive,oneof=dingtalk sms"`
NotifyRecipients []entity.NotifyRecipients `json:"notify_recipients" form:"notify_recipients" binding:"dive"`
}
type AlertRulesList struct {
......
......@@ -28,11 +28,14 @@ func (m *AlertClassSvc) Add(session *xorm.Session, req request.AddAlertClass) (c
}
_ = copier.Copy(&data, &req)
max, err := m.SortOrderMax(data.ParentId)
if err != nil {
return
var max int
if data.SortOrder >= 0 {
max, err = m.SortOrderMax(data.ParentId)
if err != nil {
return
}
data.SortOrder = max + 1
}
data.SortOrder = max + 1
_, err = session.Insert(&data)
classId = data.ClassId
return
......
......@@ -9,6 +9,7 @@ import (
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/common/client"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/pkg/beagle/jsontime"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/pkg/beagle/resp"
"gitlab.wodcloud.com/smart-operation/so-operation-api/src/util"
"xorm.io/xorm"
)
......@@ -31,9 +32,13 @@ func (m *AlertRulesSvc) Add(req request.AddAlertRules) error {
UpdatedAt: now,
}
_ = copier.Copy(&data, &req)
data.AlertCondition = util.ConvertToString(req.AlertCondition)
data.AlertRange = util.ConvertToString(req.AlertRange)
data.NotifyMethod = util.ConvertToString(req.NotifyMethod)
data.NotifyRecipients = util.ConvertToString(req.NotifyRecipients)
switch req.DetectionType {
case 1:
_, err = db.Update(&data)
_, err = db.Insert(&data)
if err != nil {
return err
}
......@@ -100,6 +105,10 @@ func (m *AlertRulesSvc) Update(req request.UpdateAlertRules) error {
UpdatedAt: now,
}
_ = copier.Copy(&data, &req)
data.AlertCondition = util.ConvertToString(req.AlertCondition)
data.AlertRange = util.ConvertToString(req.AlertRange)
data.NotifyMethod = util.ConvertToString(req.NotifyMethod)
data.NotifyRecipients = util.ConvertToString(req.NotifyRecipients)
session := db.NewSession()
var dbAlertRules entity.AlertRules
......
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