1
0
mirror of https://github.com/mainflux/mainflux.git synced 2025-05-06 19:29:15 +08:00

78 lines
1.6 KiB
Go
Raw Normal View History

package nats
import (
"fmt"
"github.com/gogo/protobuf/proto"
"github.com/mainflux/mainflux"
log "github.com/mainflux/mainflux/logger"
"github.com/mainflux/mainflux/normalizer"
nats "github.com/nats-io/go-nats"
)
const (
queue = "normalizers"
input = "channel.*"
outputUnknown = "out.unknown"
senML = "application/senml+json"
)
type pubsub struct {
nc *nats.Conn
svc normalizer.Service
logger log.Logger
}
// Subscribe to appropriate NATS topic and normalizes received messages.
func Subscribe(svc normalizer.Service, nc *nats.Conn, logger log.Logger) {
ps := pubsub{
nc: nc,
svc: svc,
logger: logger,
}
ps.nc.QueueSubscribe(input, queue, ps.handleMsg)
}
func (ps pubsub) handleMsg(m *nats.Msg) {
var msg mainflux.RawMessage
if err := proto.Unmarshal(m.Data, &msg); err != nil {
ps.logger.Warn(fmt.Sprintf("Unmarshalling failed: %s", err))
return
}
if err := ps.publish(msg); err != nil {
ps.logger.Warn(fmt.Sprintf("Publishing failed: %s", err))
return
}
}
func (ps pubsub) publish(msg mainflux.RawMessage) error {
output := mainflux.OutputSenML
normalized, err := ps.svc.Normalize(msg)
if err != nil {
switch ct := normalized.ContentType; ct {
case senML:
return err
case "":
output = outputUnknown
default:
output = fmt.Sprintf("out.%s", ct)
}
}
for _, v := range normalized.Messages {
data, err := proto.Marshal(&v)
if err != nil {
ps.logger.Warn(fmt.Sprintf("Marshalling failed: %s", err))
return err
}
if err := ps.nc.Publish(output, data); err != nil {
ps.logger.Warn(fmt.Sprintf("Publishing failed: %s", err))
return err
}
}
return nil
}