mirror of
https://gitee.com/XM-GO/PandaX.git
synced 2026-04-23 02:48:34 +08:00
iot init
This commit is contained in:
@@ -1,18 +1,20 @@
|
||||
package nodes
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"github.com/kakuilan/kgo"
|
||||
"github.com/sirupsen/logrus"
|
||||
"pandax/apps/device/entity"
|
||||
"pandax/apps/device/services"
|
||||
"pandax/pkg/global"
|
||||
"pandax/pkg/rule_engine/message"
|
||||
"time"
|
||||
)
|
||||
|
||||
type createAlarmNode struct {
|
||||
bareNode
|
||||
Script string `json:"script" yaml:"script"`
|
||||
AlarmType string `json:"alarmType" yaml:"alarmType"`
|
||||
AlarmSeverity int64 `json:"alarmSeverity" yaml:"alarmSeverity"`
|
||||
Propagate string `json:"propagate" yaml:"propagate"`
|
||||
/* AlarmStartTime string `json:"alarmStartTime" yaml:"alarmStartTime"`
|
||||
AlarmEndTime string `json:"alarmEndTime" yaml:"alarmEndTime"`*/
|
||||
AlarmSeverity string `json:"alarmSeverity" yaml:"alarmSeverity"`
|
||||
}
|
||||
|
||||
type createAlarmNodeFactory struct{}
|
||||
@@ -30,20 +32,46 @@ func (f createAlarmNodeFactory) Create(id string, meta Metadata) (Node, error) {
|
||||
func (n *createAlarmNode) Handle(msg message.Message) error {
|
||||
logrus.Infof("%s handle message '%s'", n.Name(), msg.GetType())
|
||||
|
||||
node1 := n.GetLinkedNode("Created")
|
||||
//node2 := n.GetLinkedNode("Updated")
|
||||
node3 := n.GetLinkedNode("Failure")
|
||||
created := n.GetLinkedNode("Created")
|
||||
updated := n.GetLinkedNode("Updated")
|
||||
failure := n.GetLinkedNode("Failure")
|
||||
|
||||
scriptEngine := NewScriptEngine(msg, "Details", n.Script)
|
||||
details, err := scriptEngine.ScriptAlarmDetails()
|
||||
if err != nil {
|
||||
if node3 != nil {
|
||||
return node3.Handle(msg)
|
||||
alarm := services.DeviceAlarmModelDao.FindOneByType(msg.GetMetadata().GetKeyValue("deviceId").(string), n.AlarmType, "0")
|
||||
if alarm.DeviceId != "" {
|
||||
marshal, _ := json.Marshal(msg.GetMsg())
|
||||
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 = kgo.KStr.Uniqid("a")
|
||||
alarm.DeviceId = msg.GetMetadata().GetKeyValue("deviceId").(string)
|
||||
alarm.ProductId = msg.GetMetadata().GetKeyValue("productId").(string)
|
||||
alarm.Name = msg.GetMetadata().GetKeyValue("deviceName").(string)
|
||||
alarm.Level = n.AlarmSeverity
|
||||
alarm.State = global.ALARMING
|
||||
alarm.Type = n.AlarmType
|
||||
alarm.Time = time.Now()
|
||||
marshal, _ := json.Marshal(msg.GetMsg())
|
||||
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)
|
||||
}
|
||||
}
|
||||
}
|
||||
// TODO 创建告警
|
||||
logrus.Info(details)
|
||||
node1.Handle(msg)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user