README ¶
MQTT
MQTT is an Internet of Things connectivity protocol featuring a lightweight publish/subscribe messaging transport. It is useful for its small code footprint and minimal network bandwidth usage.
This repository contains the Gobot adaptor/driver to connect to MQTT servers. It uses the Paho MQTT Golang client package (https://eclipse.org/paho/) created and maintained by the Eclipse Foundation (https://github.com/eclipse) thank you!
For more info about the MQTT machine to machine messaging standard, go to http://mqtt.org/
How to Install
Install running:
go get -d -u gobot.io/x/gobot/... && go install gobot.io/x/gobot/platforms/mqtt
How to Use
Before running the example, make sure you have an MQTT message broker running somewhere you can connect to
package main
import (
"gobot.io/x/gobot"
"gobot.io/x/gobot/platforms/mqtt"
"fmt"
"time"
)
func main() {
mqttAdaptor := mqtt.NewAdaptor("tcp://0.0.0.0:1883", "pinger")
work := func() {
mqttAdaptor.On("hello", func(msg mqtt.Message) {
fmt.Println(msg)
})
mqttAdaptor.On("hola", func(msg mqtt.Message) {
fmt.Println(msg)
})
data := []byte("o")
gobot.Every(1*time.Second, func() {
mqttAdaptor.Publish("hello", data)
})
gobot.Every(5*time.Second, func() {
mqttAdaptor.Publish("hola", data)
})
}
robot := gobot.NewRobot("mqttBot",
[]gobot.Connection{mqttAdaptor},
work,
)
robot.Start()
}
Supported Features
- Publish messages
- Respond to incoming message events
Contributing
For our contribution guidelines, please go to https://gobot.io/x/gobot/blob/master/CONTRIBUTING.md
License
Copyright (c) 2013-2017 The Hybrid Group. Licensed under the Apache 2.0 license.
Documentation ¶
Overview ¶
Package mqtt provides Gobot adaptor for the mqtt message service.
Installing:
go get gobot.io/x/gobot/platforms/mqtt
For further information refer to mqtt README: https://github.com/hybridgroup/gobot/blob/master/platforms/mqtt/README.md
Index ¶
- Constants
- type Adaptor
- func (a *Adaptor) AutoReconnect() bool
- func (a *Adaptor) ClientCert() string
- func (a *Adaptor) ClientKey() string
- func (a *Adaptor) Connect() (err error)
- func (a *Adaptor) Disconnect() (err error)
- func (a *Adaptor) Finalize() (err error)
- func (a *Adaptor) Name() string
- func (a *Adaptor) On(event string, f func(msg Message)) bool
- func (a *Adaptor) Port() string
- func (a *Adaptor) Publish(topic string, message []byte) bool
- func (a *Adaptor) ServerCert() string
- func (a *Adaptor) SetAutoReconnect(val bool)
- func (a *Adaptor) SetClientCert(val string)
- func (a *Adaptor) SetClientKey(val string)
- func (a *Adaptor) SetName(n string)
- func (a *Adaptor) SetServerCert(val string)
- func (a *Adaptor) SetUseSSL(val bool)
- func (a *Adaptor) UseSSL() bool
- type Driver
- func (m *Driver) Connection() gobot.Connection
- func (m *Driver) Halt() error
- func (m *Driver) Name() string
- func (m *Driver) On(n string, f func(msg interface{})) error
- func (m *Driver) Publish(data interface{}) bool
- func (m *Driver) SetName(name string)
- func (m *Driver) SetTopic(topic string)
- func (m *Driver) Start() error
- func (m *Driver) Topic() string
- type Message
Constants ¶
const ( // Data event when data is available for Driver Data = "data" // Error event when error occurs in Driver Error = "error" )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Adaptor ¶ added in v1.0.0
type Adaptor struct { Host string // contains filtered or unexported fields }
Adaptor is the Gobot Adaptor for MQTT
func NewAdaptor ¶ added in v1.0.0
NewAdaptor creates a new mqtt adaptor with specified host and client id
func NewAdaptorWithAuth ¶ added in v1.0.0
NewAdaptorWithAuth creates a new mqtt adaptor with specified host, client id, username, and password.
func (*Adaptor) AutoReconnect ¶ added in v1.2.0
AutoReconnect returns the MQTT AutoReconnect setting
func (*Adaptor) ClientCert ¶ added in v1.2.0
ClientCert returns the MQTT client SSL cert file
func (*Adaptor) Disconnect ¶ added in v1.0.0
Disconnect returns true if connection to mqtt is closed
func (*Adaptor) Finalize ¶ added in v1.0.0
Finalize returns true if connection to mqtt is finalized successfully
func (*Adaptor) On ¶ added in v1.0.0
On subscribes to a topic, and then calls the message handler function when data is received
func (*Adaptor) ServerCert ¶ added in v1.2.0
ServerCert returns the MQTT server SSL cert file
func (*Adaptor) SetAutoReconnect ¶ added in v1.2.0
SetAutoReconnect sets the MQTT AutoReconnect setting
func (*Adaptor) SetClientCert ¶ added in v1.2.0
SetClientCert sets the MQTT server SSL cert file
func (*Adaptor) SetClientKey ¶ added in v1.2.0
SetClientKey sets the MQTT client SSL key file
func (*Adaptor) SetServerCert ¶ added in v1.2.0
SetServerCert sets the MQTT server SSL cert file
type Driver ¶ added in v1.2.0
Driver for mqtt
func (*Driver) Connection ¶ added in v1.2.0
func (m *Driver) Connection() gobot.Connection
Connection returns Connections used by the Driver
func (*Driver) On ¶ added in v1.2.0
On subscribes to data updates for the current device topic, and then calls the message handler function when data is received