mirror of
https://gitee.com/XM-GO/PandaX.git
synced 2026-04-23 02:48:34 +08:00
32 lines
890 B
Go
32 lines
890 B
Go
package nodes
|
|
|
|
import (
|
|
"github.com/sirupsen/logrus"
|
|
"pandax/pkg/rule_engine/message"
|
|
)
|
|
|
|
type externalKafkaNode struct {
|
|
bareNode
|
|
Server string `json:"server" yaml:"server"`
|
|
Topic string `json:"topic" yaml:"topic"`
|
|
KafkaCli string
|
|
}
|
|
|
|
type externalKafkaNodeFactory struct{}
|
|
|
|
func (f externalKafkaNodeFactory) Name() string { return "KafkaNode" }
|
|
func (f externalKafkaNodeFactory) Category() string { return NODE_CATEGORY_EXTERNAL }
|
|
func (f externalKafkaNodeFactory) Labels() []string { return []string{"Success", "Failure"} }
|
|
func (f externalKafkaNodeFactory) Create(id string, meta Metadata) (Node, error) {
|
|
node := &externalKafkaNode{
|
|
bareNode: newBareNode(f.Name(), id, meta, f.Labels()),
|
|
}
|
|
return decodePath(meta, node)
|
|
}
|
|
|
|
func (n *externalKafkaNode) Handle(msg message.Message) error {
|
|
logrus.Infof("%s handle message '%s'", n.Name(), msg.GetType())
|
|
|
|
return nil
|
|
}
|