mirror of
https://gitee.com/XM-GO/PandaX.git
synced 2026-04-23 02:48:34 +08:00
80 lines
2.3 KiB
Go
80 lines
2.3 KiB
Go
package nodes
|
|
|
|
import (
|
|
"encoding/json"
|
|
"github.com/sirupsen/logrus"
|
|
"pandax/apps/device/entity"
|
|
"pandax/apps/device/services"
|
|
"pandax/pkg/global"
|
|
"pandax/pkg/rule_engine/message"
|
|
"pandax/pkg/tool"
|
|
"time"
|
|
)
|
|
|
|
type createAlarmNode struct {
|
|
bareNode
|
|
AlarmType string `json:"alarmType" yaml:"alarmType"`
|
|
AlarmSeverity string `json:"alarmSeverity" yaml:"alarmSeverity"`
|
|
}
|
|
|
|
type createAlarmNodeFactory struct{}
|
|
|
|
func (f createAlarmNodeFactory) Name() string { return "CreateAlarmNode" }
|
|
func (f createAlarmNodeFactory) Category() string { return NODE_CATEGORY_ACTION }
|
|
func (f createAlarmNodeFactory) Labels() []string { return []string{"Created", "Updated", "Failure"} }
|
|
func (f createAlarmNodeFactory) Create(id string, meta Metadata) (Node, error) {
|
|
node := &createAlarmNode{
|
|
bareNode: newBareNode(f.Name(), id, meta, f.Labels()),
|
|
}
|
|
return decodePath(meta, node)
|
|
}
|
|
|
|
func (n *createAlarmNode) Handle(msg *message.Message) error {
|
|
logrus.Infof("%s handle message '%s'", n.Name(), msg.MsgType)
|
|
|
|
created := n.GetLinkedNode("Created")
|
|
updated := n.GetLinkedNode("Updated")
|
|
failure := n.GetLinkedNode("Failure")
|
|
|
|
alarm := services.DeviceAlarmModelDao.FindOneByType(msg.Metadata.GetValue("deviceId").(string), n.AlarmType, "0")
|
|
if alarm.DeviceId != "" {
|
|
marshal, _ := json.Marshal(msg.Msg)
|
|
alarm.Details = string(marshal)
|
|
err := services.DeviceAlarmModelDao.Update(*alarm)
|
|
if err != nil {
|
|
if failure != nil {
|
|
return failure.Handle(msg)
|
|
}
|
|
} else {
|
|
if updated != nil {
|
|
return updated.Handle(msg)
|
|
}
|
|
}
|
|
} else {
|
|
alarm = &entity.DeviceAlarm{}
|
|
alarm.Id = tool.GenerateID()
|
|
alarm.DeviceId = msg.Metadata.GetValue("deviceId").(string)
|
|
alarm.ProductId = msg.Metadata.GetValue("productId").(string)
|
|
alarm.Name = msg.Metadata.GetValue("deviceName").(string)
|
|
alarm.Level = n.AlarmSeverity
|
|
alarm.State = global.ALARMING
|
|
alarm.Type = n.AlarmType
|
|
alarm.Time = time.Now()
|
|
alarm.OrgId = msg.Metadata.GetValue("orgId").(int64)
|
|
alarm.Owner = msg.Metadata.GetValue("owner").(string)
|
|
marshal, _ := json.Marshal(msg.Msg)
|
|
alarm.Details = string(marshal)
|
|
err := services.DeviceAlarmModelDao.Insert(*alarm)
|
|
if err != nil {
|
|
if failure != nil {
|
|
return failure.Handle(msg)
|
|
}
|
|
} else {
|
|
if created != nil {
|
|
return created.Handle(msg)
|
|
}
|
|
}
|
|
}
|
|
return nil
|
|
}
|