This commit is contained in:
XM-GO
2023-08-22 15:17:14 +08:00
parent 85f4f328f4
commit 4344771547
143 changed files with 13004 additions and 6957 deletions

View File

@@ -1,10 +1,13 @@
package nodes
import (
"github.com/sirupsen/logrus"
"log"
"pandax/pkg/global"
"pandax/pkg/rule_engine/message"
)
type SaveTimeSeriesNode struct {
type saveTimeSeriesNode struct {
bareNode
}
@@ -14,29 +17,35 @@ func (f saveTimeSeriesNodeFactory) Name() string { return "SaveTimeSeriesNod
func (f saveTimeSeriesNodeFactory) Category() string { return NODE_CATEGORY_ACTION }
func (f saveTimeSeriesNodeFactory) Labels() []string { return []string{"Success", "Failure"} }
func (f saveTimeSeriesNodeFactory) Create(id string, meta Metadata) (Node, error) {
return nil, nil
node := &saveTimeSeriesNode{
bareNode: newBareNode(f.Name(), id, meta, f.Labels()),
}
return decodePath(meta, node)
}
func (n *SaveTimeSeriesNode) Handle(msg message.Message) error {
successLableNode := n.GetLinkedNode("Success")
failureLableNode := n.GetLinkedNode("Failure")
if msg.GetType() != message.EventTelemetryType {
if failureLableNode != nil {
return failureLableNode.Handle(msg)
func (n *saveTimeSeriesNode) Handle(msg message.Message) error {
logrus.Infof("%s handle message '%s'", n.Name(), msg.GetType())
successLabelNode := n.GetLinkedNode("Success")
failureLabelNode := n.GetLinkedNode("Failure")
if msg.GetType() != message.TelemetryMes {
if failureLabelNode != nil {
return failureLabelNode.Handle(msg)
} else {
return nil
}
}
/*deviceName := msg.GetMetadata().GetValues()["deviceName"].(string)
namespace := msg.GetMetadata().GetValues()["namespace"].(string)
marshal, err := json.Marshal(msg.GetMsg())*/
// todo 添加设备上报遥测
if successLableNode != nil {
return successLableNode.Handle(msg)
} else {
return nil
//deviceId := msg.GetMetadata().GetValues()["deviceId"].(string)
deviceName := msg.GetMetadata().GetValues()["deviceName"].(string)
log.Println("telemetry", msg.GetMsg())
err := global.TdDb.InsertDevice(deviceName+"_telemetry", msg.GetMsg())
log.Println(err)
if err != nil {
if failureLabelNode != nil {
return failureLabelNode.Handle(msg)
}
}
if successLabelNode != nil {
return successLabelNode.Handle(msg)
}
return nil
}