mirror of
https://gitee.com/XM-GO/PandaX.git
synced 2026-04-23 02:48:34 +08:00
64 lines
1.7 KiB
Go
64 lines
1.7 KiB
Go
package nodes
|
|
|
|
import (
|
|
"github.com/sirupsen/logrus"
|
|
"pandax/pkg/rule_engine/message"
|
|
"time"
|
|
)
|
|
|
|
type messageGeneratorNode struct {
|
|
bareNode
|
|
Script string `json:"script" yaml:"script"`
|
|
PeriodSecond int64 `json:"periodSecond" yaml:"periodSecond"` //周期
|
|
MessageCount int64 `json:"messageCount" yaml:"messageCount"`
|
|
}
|
|
|
|
type messageGeneratorNodeFactory struct{}
|
|
|
|
func (f messageGeneratorNodeFactory) Name() string { return "MessageGeneratorNode" }
|
|
func (f messageGeneratorNodeFactory) Category() string { return NODE_CATEGORY_ACTION }
|
|
func (f messageGeneratorNodeFactory) Labels() []string { return []string{"Success", "Failure"} }
|
|
func (f messageGeneratorNodeFactory) Create(id string, meta Metadata) (Node, error) {
|
|
node := &messageGeneratorNode{
|
|
bareNode: newBareNode(f.Name(), id, meta, f.Labels()),
|
|
}
|
|
return decodePath(meta, node)
|
|
}
|
|
|
|
func (n *messageGeneratorNode) Handle(msg *message.Message) error {
|
|
logrus.Infof("%s handle message '%s'", n.Name(), msg.MsgType)
|
|
|
|
successLabelNode := n.GetLinkedNode("Success")
|
|
failureLabelNode := n.GetLinkedNode("Failure")
|
|
|
|
ticker := time.NewTicker(time.Duration(n.PeriodSecond) * time.Second)
|
|
count := 0
|
|
|
|
go func() {
|
|
for {
|
|
<-ticker.C
|
|
count++
|
|
if int64(count) == n.MessageCount {
|
|
ticker.Stop()
|
|
return
|
|
}
|
|
scriptEngine := NewScriptEngine(*msg, "Generate", n.Script)
|
|
generate, err := scriptEngine.ScriptGenerate()
|
|
if err != nil {
|
|
if failureLabelNode != nil {
|
|
go failureLabelNode.Handle(msg)
|
|
}
|
|
return
|
|
}
|
|
msg.Msg = generate["msg"].(message.Msg)
|
|
msg.Metadata = generate["metadata"].(message.Metadata)
|
|
msg.MsgType = generate["msgType"].(string)
|
|
if successLabelNode != nil {
|
|
go successLabelNode.Handle(msg)
|
|
}
|
|
}
|
|
}()
|
|
|
|
return nil
|
|
}
|