mirror of
https://github.com/mainflux/mainflux.git
synced 2025-05-04 22:17:59 +08:00
63 lines
1.3 KiB
Go
63 lines
1.3 KiB
Go
![]() |
// Copyright (c) Mainflux
|
||
|
// SPDX-License-Identifier: Apache-2.0
|
||
|
|
||
|
package subscriber
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"os"
|
||
|
|
||
|
"github.com/gogo/protobuf/proto"
|
||
|
"github.com/mainflux/mainflux"
|
||
|
log "github.com/mainflux/mainflux/logger"
|
||
|
"github.com/mainflux/mainflux/twins"
|
||
|
"github.com/nats-io/go-nats"
|
||
|
)
|
||
|
|
||
|
const (
|
||
|
queue = "twins"
|
||
|
input = "channel.>"
|
||
|
)
|
||
|
|
||
|
// Subscriber is used to intercept messages and save corresponding twin states
|
||
|
type Subscriber struct {
|
||
|
natsClient *nats.Conn
|
||
|
logger log.Logger
|
||
|
svc twins.Service
|
||
|
channelID string
|
||
|
}
|
||
|
|
||
|
// NewSubscriber instances Subscriber strucure and subscribes to appropriate NATS topic
|
||
|
func NewSubscriber(nc *nats.Conn, chID string, svc twins.Service, logger log.Logger) *Subscriber {
|
||
|
s := Subscriber{
|
||
|
natsClient: nc,
|
||
|
logger: logger,
|
||
|
svc: svc,
|
||
|
channelID: chID,
|
||
|
}
|
||
|
|
||
|
if _, err := s.natsClient.QueueSubscribe(input, queue, s.handleMsg); err != nil {
|
||
|
logger.Error(fmt.Sprintf("Failed to subscribe to NATS: %s", err))
|
||
|
os.Exit(1)
|
||
|
}
|
||
|
|
||
|
return &s
|
||
|
}
|
||
|
|
||
|
func (s *Subscriber) handleMsg(m *nats.Msg) {
|
||
|
var msg mainflux.Message
|
||
|
if err := proto.Unmarshal(m.Data, &msg); err != nil {
|
||
|
s.logger.Warn(fmt.Sprintf("Unmarshalling failed: %s", err))
|
||
|
return
|
||
|
}
|
||
|
|
||
|
if msg.Channel == s.channelID {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
if err := s.svc.SaveStates(&msg); err != nil {
|
||
|
s.logger.Error(fmt.Sprintf("State save failed: %s", err))
|
||
|
return
|
||
|
}
|
||
|
}
|