2022-04-11 13:52:20 +02:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
MF-1718 - Use static code analysis in CI (#1729)
* 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>
2023-04-22 08:14:35 -07:00
|
|
|
if err := b.svc.Publish(context.Background(), &m); err != nil {
|
|
|
|
b.logger.Error(fmt.Sprintf("got error while publishing messages: %s", err))
|
|
|
|
}
|
2022-04-11 13:52:20 +02:00
|
|
|
}
|