mirror of
https://github.com/mainflux/mainflux.git
synced 2025-05-01 13:48:56 +08:00

* things, twins, and logger lint fixed Signed-off-by: aryan <aryangodara03@gmail.com> * all services updated, auth jwt not working, ineffectual assignment issue Signed-off-by: aryan <aryangodara03@gmail.com> * handle error from grpc server in endpointtest Signed-off-by: aryan <aryangodara03@gmail.com> * temp commit, auth/jwt needs to be resolved Signed-off-by: aryan <aryangodara03@gmail.com> * revert back to jwt v4 temporarily Signed-off-by: aryan <aryangodara03@gmail.com> * updated jwt tokenizer Signed-off-by: aryan <aryangodara03@gmail.com> * resolve EOF error for httptest requests Signed-off-by: aryan <aryangodara03@gmail.com> * fix auth jwt, update to registeredclaims Signed-off-by: aryan <aryangodara03@gmail.com> * fix ineffective assignment, auth/api/grpc endpoint failing Signed-off-by: aryan <aryangodara03@gmail.com> * temp commit, remove later Signed-off-by: aryan <aryangodara03@gmail.com> * fix grpc server setup Signed-off-by: aryan <aryangodara03@gmail.com> * resolve golangci tests, remove debug statements Signed-off-by: aryan <aryangodara03@gmail.com> * update golangci version and modify linters used Signed-off-by: aryan <aryangodara03@gmail.com> * fix failing tests Signed-off-by: aryan <aryangodara03@gmail.com> * fix grpc server for setup tests Signed-off-by: aryan <aryangodara03@gmail.com> * fix logging and errors inlined Signed-off-by: aryan <aryangodara03@gmail.com> * fix remarks, update grpc setup_test Signed-off-by: aryan <aryangodara03@gmail.com> * fix setup_test Signed-off-by: aryan <aryangodara03@gmail.com> * update setup_test grpc Signed-off-by: aryan <aryangodara03@gmail.com> * fix data race Signed-off-by: aryan <aryangodara03@gmail.com> * update setup_test grpc Signed-off-by: aryan <aryangodara03@gmail.com> * fix grpc setup down to single simple function Signed-off-by: aryan <aryangodara03@gmail.com> * fix linting issues Signed-off-by: aryan <aryangodara03@gmail.com> * resolve pr comments Signed-off-by: aryan <aryangodara03@gmail.com> * fix tests, handle returned errors, go mod tidy vendor Signed-off-by: aryan <aryangodara03@gmail.com> * fix errors from new linters Signed-off-by: aryan <aryangodara03@gmail.com> --------- Signed-off-by: aryan <aryangodara03@gmail.com>
61 lines
1.4 KiB
Go
61 lines
1.4 KiB
Go
package mqtt
|
|
|
|
// LoraSubscribe subscribe to lora server messages
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/mainflux/mainflux/logger"
|
|
"github.com/mainflux/mainflux/lora"
|
|
|
|
mqtt "github.com/eclipse/paho.mqtt.golang"
|
|
)
|
|
|
|
// Subscriber represents the MQTT broker.
|
|
type Subscriber interface {
|
|
// Subscribes to given subject and receives events.
|
|
Subscribe(string) error
|
|
}
|
|
|
|
type broker struct {
|
|
svc lora.Service
|
|
client mqtt.Client
|
|
logger logger.Logger
|
|
timeout time.Duration
|
|
}
|
|
|
|
// NewBroker returns new MQTT broker instance.
|
|
func NewBroker(svc lora.Service, client mqtt.Client, t time.Duration, log logger.Logger) Subscriber {
|
|
return broker{
|
|
svc: svc,
|
|
client: client,
|
|
logger: log,
|
|
timeout: t,
|
|
}
|
|
}
|
|
|
|
// Subscribe subscribes to the Lora MQTT message broker
|
|
func (b broker) Subscribe(subject string) error {
|
|
s := b.client.Subscribe(subject, 0, b.handleMsg)
|
|
if err := s.Error(); s.WaitTimeout(b.timeout) && err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// handleMsg triggered when new message is received on Lora MQTT broker
|
|
func (b broker) handleMsg(c mqtt.Client, msg mqtt.Message) {
|
|
m := lora.Message{}
|
|
if err := json.Unmarshal(msg.Payload(), &m); err != nil {
|
|
b.logger.Warn(fmt.Sprintf("Failed to unmarshal message: %s", err.Error()))
|
|
return
|
|
}
|
|
|
|
if err := b.svc.Publish(context.Background(), &m); err != nil {
|
|
b.logger.Error(fmt.Sprintf("got error while publishing messages: %s", err))
|
|
}
|
|
}
|