mirror of
https://github.com/minio/minio.git
synced 2024-12-26 15:15:55 -05:00
8293f546af
This implementation is similar to AMQP notifications: * Notifications are published on a single topic as a JSON feed * Topic is configurable, as is the QoS. Uses the paho.mqtt.golang library for the mqtt connection, and supports connections over tcp and websockets, with optional secure tls support. * Additionally the minio server configuration has been bumped up so mqtt configuration can be added. * Configuration migration code is added with tests. MQTT is an ISO standard M2M/IoT messaging protocol and was originally designed for applications for limited bandwidth networks. Today it's use is growing in the IoT space.
45 lines
961 B
Go
45 lines
961 B
Go
package packets
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
)
|
|
|
|
//UnsubackPacket is an internal representation of the fields of the
|
|
//Unsuback MQTT packet
|
|
type UnsubackPacket struct {
|
|
FixedHeader
|
|
MessageID uint16
|
|
}
|
|
|
|
func (ua *UnsubackPacket) String() string {
|
|
str := fmt.Sprintf("%s", ua.FixedHeader)
|
|
str += " "
|
|
str += fmt.Sprintf("MessageID: %d", ua.MessageID)
|
|
return str
|
|
}
|
|
|
|
func (ua *UnsubackPacket) Write(w io.Writer) error {
|
|
var err error
|
|
ua.FixedHeader.RemainingLength = 2
|
|
packet := ua.FixedHeader.pack()
|
|
packet.Write(encodeUint16(ua.MessageID))
|
|
_, err = packet.WriteTo(w)
|
|
|
|
return err
|
|
}
|
|
|
|
//Unpack decodes the details of a ControlPacket after the fixed
|
|
//header has been read
|
|
func (ua *UnsubackPacket) Unpack(b io.Reader) error {
|
|
ua.MessageID = decodeUint16(b)
|
|
|
|
return nil
|
|
}
|
|
|
|
//Details returns a Details struct containing the Qos and
|
|
//MessageID of this ControlPacket
|
|
func (ua *UnsubackPacket) Details() Details {
|
|
return Details{Qos: 0, MessageID: ua.MessageID}
|
|
}
|