mirror of
https://github.com/minio/minio.git
synced 2025-01-24 05:03:16 -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
952 B
Go
45 lines
952 B
Go
package packets
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
)
|
|
|
|
//PubrecPacket is an internal representation of the fields of the
|
|
//Pubrec MQTT packet
|
|
type PubrecPacket struct {
|
|
FixedHeader
|
|
MessageID uint16
|
|
}
|
|
|
|
func (pr *PubrecPacket) String() string {
|
|
str := fmt.Sprintf("%s", pr.FixedHeader)
|
|
str += " "
|
|
str += fmt.Sprintf("MessageID: %d", pr.MessageID)
|
|
return str
|
|
}
|
|
|
|
func (pr *PubrecPacket) Write(w io.Writer) error {
|
|
var err error
|
|
pr.FixedHeader.RemainingLength = 2
|
|
packet := pr.FixedHeader.pack()
|
|
packet.Write(encodeUint16(pr.MessageID))
|
|
_, err = packet.WriteTo(w)
|
|
|
|
return err
|
|
}
|
|
|
|
//Unpack decodes the details of a ControlPacket after the fixed
|
|
//header has been read
|
|
func (pr *PubrecPacket) Unpack(b io.Reader) error {
|
|
pr.MessageID = decodeUint16(b)
|
|
|
|
return nil
|
|
}
|
|
|
|
//Details returns a Details struct containing the Qos and
|
|
//MessageID of this ControlPacket
|
|
func (pr *PubrecPacket) Details() Details {
|
|
return Details{Qos: pr.Qos, MessageID: pr.MessageID}
|
|
}
|