mirror of
https://github.com/minio/minio.git
synced 2024-12-26 23:25:54 -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"
|
|
)
|
|
|
|
//PubackPacket is an internal representation of the fields of the
|
|
//Puback MQTT packet
|
|
type PubackPacket struct {
|
|
FixedHeader
|
|
MessageID uint16
|
|
}
|
|
|
|
func (pa *PubackPacket) String() string {
|
|
str := fmt.Sprintf("%s", pa.FixedHeader)
|
|
str += " "
|
|
str += fmt.Sprintf("MessageID: %d", pa.MessageID)
|
|
return str
|
|
}
|
|
|
|
func (pa *PubackPacket) Write(w io.Writer) error {
|
|
var err error
|
|
pa.FixedHeader.RemainingLength = 2
|
|
packet := pa.FixedHeader.pack()
|
|
packet.Write(encodeUint16(pa.MessageID))
|
|
_, err = packet.WriteTo(w)
|
|
|
|
return err
|
|
}
|
|
|
|
//Unpack decodes the details of a ControlPacket after the fixed
|
|
//header has been read
|
|
func (pa *PubackPacket) Unpack(b io.Reader) error {
|
|
pa.MessageID = decodeUint16(b)
|
|
|
|
return nil
|
|
}
|
|
|
|
//Details returns a Details struct containing the Qos and
|
|
//MessageID of this ControlPacket
|
|
func (pa *PubackPacket) Details() Details {
|
|
return Details{Qos: pa.Qos, MessageID: pa.MessageID}
|
|
}
|