1
0
mirror of https://github.com/mainflux/mainflux.git synced 2025-05-04 22:17:59 +08:00
Dušan Borovčanin 44f5a7241f NOISSUE - Expose SenML subject from Normalizer service (#330)
* Expose SenML subject from Normalizer service

Signed-off-by: Dušan Borovčanin <dusan.borovcanin@mainflux.com>

* Export shared NATS subjects

Signed-off-by: Dušan Borovčanin <dusan.borovcanin@mainflux.com>
2018-06-19 00:37:04 +02:00

43 lines
899 B
Go

package writers
import (
"fmt"
"github.com/gogo/protobuf/proto"
"github.com/mainflux/mainflux"
log "github.com/mainflux/mainflux/logger"
nats "github.com/nats-io/go-nats"
)
type consumer struct {
nc *nats.Conn
logger log.Logger
repo MessageRepository
}
// Start method starts to consume normalized messages received from NATS.
func Start(nc *nats.Conn, logger log.Logger, repo MessageRepository) error {
c := consumer{
nc: nc,
logger: logger,
repo: repo,
}
_, err := nc.Subscribe(mainflux.OutputSenML, c.consume)
return err
}
func (c *consumer) consume(m *nats.Msg) {
msg := &mainflux.Message{}
if err := proto.Unmarshal(m.Data, msg); err != nil {
c.logger.Warn(fmt.Sprintf("Failed to unmarshal received message: %s", err))
return
}
if err := c.repo.Save(*msg); err != nil {
c.logger.Warn(fmt.Sprintf("Failed to save message: %s", err))
return
}
}