mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-27 13:48:49 +08:00

* Fix linting errors Signed-off-by: Rodney Osodo <28790446+rodneyosodo@users.noreply.github.com> * feat(linters): add ineffassign linter This commit adds the `ineffassign` linter to the project's `.golangci.yml` configuration file. The `ineffassign` linter helps identify and flag assignments to variables that are never used, helping to improve code quality and maintainability. Signed-off-by: Rodney Osodo <28790446+rodneyosodo@users.noreply.github.com> * Add extra linters Signed-off-by: Rodney Osodo <28790446+rodneyosodo@users.noreply.github.com> * feat(golangci): Add header check - Added goheader check to ensure all files have license headers - Added build tags for "nats" in the .golangci.yml file to include the necessary dependencies for the "nats" package during the build process. - Also, increased the maximum number of issues per linter and the maximum number of same issues reported by the linter to improve the code quality analysis. Signed-off-by: Rodney Osodo <28790446+rodneyosodo@users.noreply.github.com> * feat(.golangci.yml): Add new linters Add the following new linters to the .golangci.yml configuration file: - asasalint - asciicheck - bidichk - contextcheck - decorder - dogsled - errchkjson - errname - execinquery - exportloopref - ginkgolinter - gocheckcompilerdirectives These linters will help improve code quality and catch potential issues during the code review process. Signed-off-by: Rodney Osodo <28790446+rodneyosodo@users.noreply.github.com> --------- Signed-off-by: Rodney Osodo <28790446+rodneyosodo@users.noreply.github.com>
63 lines
1.5 KiB
Go
63 lines
1.5 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package mqtt
|
|
|
|
// LoraSubscribe subscribe to lora server messages.
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"fmt"
|
|
"time"
|
|
|
|
mqtt "github.com/eclipse/paho.mqtt.golang"
|
|
"github.com/mainflux/mainflux/logger"
|
|
"github.com/mainflux/mainflux/lora"
|
|
)
|
|
|
|
// 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))
|
|
}
|
|
}
|