This commit is contained in:
joy.zhou
2019-07-23 15:47:01 +08:00
parent 13fc3bb259
commit 637da9df50
14 changed files with 59 additions and 48 deletions

View File

@@ -12,11 +12,11 @@ import (
"sync" "sync"
"time" "time"
"github.com/fhmq/hmq/broker/lib/sessions"
"github.com/fhmq/hmq/broker/lib/topics"
"github.com/fhmq/hmq/plugins" "github.com/fhmq/hmq/plugins"
"github.com/eclipse/paho.mqtt.golang/packets" "github.com/eclipse/paho.mqtt.golang/packets"
"github.com/fhmq/hmq/lib/sessions"
"github.com/fhmq/hmq/lib/topics"
"github.com/fhmq/hmq/plugins/authhttp" "github.com/fhmq/hmq/plugins/authhttp"
"github.com/fhmq/hmq/plugins/kafka" "github.com/fhmq/hmq/plugins/kafka"
"github.com/fhmq/hmq/pool" "github.com/fhmq/hmq/pool"

View File

@@ -13,11 +13,11 @@ import (
"sync" "sync"
"time" "time"
"github.com/fhmq/hmq/broker/lib/sessions"
"github.com/fhmq/hmq/broker/lib/topics"
"github.com/fhmq/hmq/plugins" "github.com/fhmq/hmq/plugins"
"github.com/eclipse/paho.mqtt.golang/packets" "github.com/eclipse/paho.mqtt.golang/packets"
"github.com/fhmq/hmq/lib/sessions"
"github.com/fhmq/hmq/lib/topics"
"go.uber.org/zap" "go.uber.org/zap"
) )

View File

@@ -2,10 +2,8 @@ package kafka
import ( import (
"encoding/json" "encoding/json"
"errors"
"io/ioutil" "io/ioutil"
"regexp" "regexp"
"time"
"github.com/Shopify/sarama" "github.com/Shopify/sarama"
"github.com/fhmq/hmq/logger" "github.com/fhmq/hmq/logger"
@@ -32,6 +30,7 @@ type Config struct {
PublishTopic string `json:"onPublish"` PublishTopic string `json:"onPublish"`
UnsubscribeTopic string `json:"onUnsubscribe"` UnsubscribeTopic string `json:"onUnsubscribe"`
DisconnectTopic string `json:"onDisconnect"` DisconnectTopic string `json:"onDisconnect"`
RegexpMap map[string]string `json:"regexpMap"`
} }
//Init init kafak client //Init init kafak client
@@ -67,56 +66,63 @@ func connect() {
}() }()
} }
const (
_ThingModelTopicRegexp = `^/\$system/(.+)/(.+)/tmodel/(.*)$`
)
//Publish publish to kafka //Publish publish to kafka
func Publish(e *plugins.Elements) { func Publish(e *plugins.Elements) {
topic, key := "", e.ClientID key := e.ClientID
var topics []string
switch e.Action { switch e.Action {
case plugins.Connect: case plugins.Connect:
topic = config.ConnectTopic if config.ConnectTopic != "" {
topics = append(topics, config.ConnectTopic)
}
case plugins.Publish: case plugins.Publish:
topic = config.PublishTopic if config.PublishTopic != "" {
topics = append(topics, config.PublishTopic)
}
// foreach regexp map config
for reg, topic := range config.RegexpMap {
match, _ := regexp.MatchString(reg, e.Topic)
if match {
topics = append(topics, topic)
}
}
case plugins.Subscribe: case plugins.Subscribe:
topic = config.SubscribeTopic if config.SubscribeTopic != "" {
topics = append(topics, config.SubscribeTopic)
}
case plugins.Unsubscribe: case plugins.Unsubscribe:
topic = config.UnsubscribeTopic if config.UnsubscribeTopic != "" {
topics = append(topics, config.UnsubscribeTopic)
}
case plugins.Disconnect: case plugins.Disconnect:
topic = config.DisconnectTopic if config.DisconnectTopic != "" {
topics = append(topics, config.DisconnectTopic)
}
default: default:
log.Error("error action: ", zap.String("action", e.Action)) log.Error("error action: ", zap.String("action", e.Action))
return return
} }
// fmt.Println("publish kafka: ", topic, key)
err := publish(topic, key, e) err := publish(topics, key, e)
if err != nil { if err != nil {
log.Error("publish kafka error: ", zap.Error(err)) log.Error("publish kafka error: ", zap.Error(err))
} }
match, _ := regexp.MatchString(_ThingModelTopicRegexp, e.Topic)
if match && e.Action == plugins.Publish {
topic := "tmodel.msg.upstream"
err := publish(topic, key, e)
if err != nil {
log.Error("publish kafka error: ", zap.Error(err))
}
}
} }
func publish(topic, key string, msg *plugins.Elements) error { func publish(topics []string, key string, msg *plugins.Elements) error {
payload, err := json.Marshal(msg) payload, err := json.Marshal(msg)
if err != nil { if err != nil {
return err return err
} }
select {
case kafkaClient.Input() <- &sarama.ProducerMessage{ for _, topic := range topics {
kafkaClient.Input() <- &sarama.ProducerMessage{
Topic: topic, Topic: topic,
Key: sarama.ByteEncoder(key), Key: sarama.ByteEncoder(key),
Value: sarama.ByteEncoder(payload)}: Value: sarama.ByteEncoder(payload),
return nil
case <-time.After(1 * time.Minute):
return errors.New("send to kafka time out")
} }
}
return nil
} }

View File

@@ -6,5 +6,10 @@
"onPublish": "onPublish", "onPublish": "onPublish",
"onSubscribe": "onSubscribe", "onSubscribe": "onSubscribe",
"onDisconnect": "onDisconnect", "onDisconnect": "onDisconnect",
"onUnsubscribe": "onUnsubscribe" "onUnsubscribe": "onUnsubscribe",
"regexpMap": [
{
"^/(.+)/(.+)/upload/(.*)$": "upload"
}
]
} }

Binary file not shown.