本文整理汇总了Golang中git/eclipse/org/gitroot/paho/org/eclipse/paho/mqtt/golang/git.Message.Topic方法的典型用法代码示例。如果您正苦于以下问题:Golang Message.Topic方法的具体用法?Golang Message.Topic怎么用?Golang Message.Topic使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类git/eclipse/org/gitroot/paho/org/eclipse/paho/mqtt/golang/git.Message
的用法示例。
在下文中一共展示了Message.Topic方法的13个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: MsgRecvfun
func MsgRecvfun(client *MQTT.Client, msg MQTT.Message) {
appUpChan <- msg.Topic()
fmt.Printf("appUp")
fmt.Printf("topic:[%s] ", msg.Topic())
fmt.Printf("Mesg:%s\n", msg.Payload())
}
示例2: mqttMsgToWolfMsg
func mqttMsgToWolfMsg(msg MQTT.Message) models.IncomingPacket {
inMsg := models.IncomingPacket{}
inMsg.Message = string(msg.Payload())
inMsg.Topic = msg.Topic()
inMsg.QoS = int(msg.Qos())
return inMsg
}
示例3: handleMessage
// messageHandler is called when a new message arrives
func handleMessage(client *MQTT.Client, msg MQTT.Message) {
// Unmarshal JSON to RxPacket
var packet shared.RxPacket
err := json.Unmarshal(msg.Payload(), &packet)
if err != nil {
log.WithField("topic", msg.Topic()).WithError(err).Warn("Failed to unmarshal JSON.")
return
}
// Filter messages by gateway
if gateway != "" && packet.GatewayEui != gateway {
return
}
// Decode payload
data, err := base64.StdEncoding.DecodeString(packet.Data)
if err != nil {
log.WithField("topic", msg.Topic()).WithError(err).Warn("Failed to decode Payload.")
return
}
ctx := log.WithFields(log.Fields{
"devAddr": packet.NodeEui,
})
if showMeta {
ctx = ctx.WithFields(log.Fields{
"gatewayEui": packet.GatewayEui,
"time": packet.Time,
"frequency": *packet.Frequency,
"dataRate": packet.DataRate,
"rssi": *packet.Rssi,
"snr": *packet.Snr,
})
}
if showRaw {
ctx = ctx.WithField("data", fmt.Sprintf("%x", data))
}
if showTiming {
rawData, err := base64.StdEncoding.DecodeString(packet.Data)
if err == nil {
airtime, err := util.CalculatePacketTime(len(rawData), packet.DataRate)
if err == nil {
ctx = ctx.WithField("airtime", fmt.Sprintf("%.1f ms", airtime))
}
}
}
// Check for unprintable characters
unprintable, _ := regexp.Compile(`[^[:print:]]`)
if unprintable.Match(data) {
ctx.Debug("Received Message")
} else {
ctx.WithField("message", fmt.Sprintf("%s", data)).Info("Received Message")
}
}
示例4: onMessageReceived
func onMessageReceived(client *MQTT.MqttClient, message MQTT.Message) {
fmt.Printf("Received message on topic: %s\n", message.Topic())
fmt.Printf("Message: %s\n", message.Payload())
if string(message.Payload()) == "ぬるぽ" {
Publish(client, "say", "ガッ")
}
}
示例5: onMessageReceived
func (b *Broker) onMessageReceived(client *MQTT.Client, m MQTT.Message) {
log.Debugf("topic:%s / msg:%s", m.Topic(), m.Payload())
msg := message.Message{
Sender: b.Name,
Type: message.TypeSubscribed,
Body: m.Payload(),
Topic: m.Topic(),
}
b.GwChan <- msg
}
示例6: actionHandler
func actionHandler(client *MQTT.Client, message MQTT.Message) {
fmt.Println("Received action message on", message.Topic(), "-", string(message.Payload()))
action := strings.ToLower(string(message.Payload()))
switch action {
case "off":
host.LedsOff()
case "on":
host.LedsOn()
case "toggle":
host.LedsToggle()
case "slide":
host.LedsCycle(3)
}
}
示例7: onMessageReceived
func (m *MqttClient) onMessageReceived(client *MQTT.Client, message MQTT.Message) {
log.Infof("topic:%s", message.Topic())
// Remove topic root
ct := strings.TrimRight(m.Config.Topic, "#")
topic := strings.Replace(message.Topic(), ct, "", 1)
chun := Message{
Topic: topic,
Payload: message.Payload(),
}
m.mqttChan <- chun
}
示例8: messageHandler
func (d *Device) messageHandler(client *MQTT.Client, msg MQTT.Message) {
fmt.Printf("TOPIC: %s\n", msg.Topic())
fmt.Printf("MSG: %x\n", msg.Payload())
msgtype := msg.Topic()
fmt.Println(msgtype)
switch msgtype {
case "c":
d.commandHandler(client, msg)
case "s":
d.statusHandler(client, msg)
default:
fmt.Println("unsuported message type :", msgtype)
}
}
示例9: BrokerHandler
// BrokerHandler -
func (c *Connection) BrokerHandler(client *MQTT.Client, msg MQTT.Message) {
c.Info(
"Received new mqtt (worker: %s) - (message: %s) for (topic: %s). Building event now ...",
c.Name(), msg.Payload(), msg.Topic(),
)
event, err := events.NewEvent(msg)
if err != nil {
c.Error("Could not handle received event due to (err: %s)", err)
return
}
c.Info("Event successfully created (data: %v)", event)
c.events <- event
}
示例10: messageReceived
func messageReceived(client *MQTT.Client, msg MQTT.Message) {
topics := strings.Split(msg.Topic(), "/")
msgFrom := topics[len(topics)-1]
fmt.Print(msgFrom + ": " + string(msg.Payload()))
}
示例11: onMessageReceived
func onMessageReceived(client *MQTT.MqttClient, message MQTT.Message) {
log.Infof("topic:%s / msg:%s", message.Topic(), message.Payload())
fmt.Println(string(message.Payload()))
}
示例12: onMessageReceived
func onMessageReceived(client *MQTT.MqttClient, message MQTT.Message) {
fmt.Printf("Received message on topic: %s\n", message.Topic())
fmt.Printf("Message: %s\n", message.Payload())
}
示例13: brokerClientsHandler
func brokerClientsHandler(client *MQTT.Client, msg MQTT.Message) {
brokerClients <- true
fmt.Printf("BrokerClientsHandler ")
fmt.Printf("[%s] ", msg.Topic())
fmt.Printf("%s\n", msg.Payload())
}