2021-03-09 10:02:46 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "../acl_cpp_define.hpp"
|
|
|
|
|
|
|
|
namespace acl {
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* all the mqtt types were defined below.
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
typedef enum {
|
|
|
|
MQTT_RESERVED_MIN = 0,
|
|
|
|
MQTT_CONNECT = 1,
|
|
|
|
MQTT_CONNACK = 2,
|
|
|
|
MQTT_PUBLISH = 3,
|
|
|
|
MQTT_PUBACK = 4,
|
|
|
|
MQTT_PUBREC = 5,
|
|
|
|
MQTT_PUBREL = 6,
|
|
|
|
MQTT_PUBCOMP = 7,
|
|
|
|
MQTT_SUBSCRIBE = 8,
|
|
|
|
MQTT_SUBACK = 9,
|
|
|
|
MQTT_UNSUBSCRIBE = 10,
|
|
|
|
MQTT_UNSUBACK = 11,
|
|
|
|
MQTT_PINGREQ = 12,
|
|
|
|
MQTT_PINGRESP = 13,
|
|
|
|
MQTT_DISCONNECT = 14,
|
|
|
|
MQTT_RESERVED_MAX = 15,
|
|
|
|
} mqtt_type_t;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
MQTT_NONE,
|
|
|
|
MQTT_NEED,
|
|
|
|
MQTT_MAYBE,
|
|
|
|
} mqtt_option_t;
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* all the qos type of mqtt
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
typedef enum {
|
|
|
|
MQTT_QOS0 = 0x0,
|
|
|
|
MQTT_QOS1 = 0x1,
|
|
|
|
MQTT_QOS2 = 0x2,
|
|
|
|
} mqtt_qos_t;
|
|
|
|
|
|
|
|
struct mqtt_constrain {
|
|
|
|
mqtt_type_t type;
|
|
|
|
unsigned char flags:4;
|
|
|
|
mqtt_option_t id;
|
|
|
|
mqtt_option_t payload;
|
|
|
|
const char* desc;
|
|
|
|
};
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* get description of the specified mqtt type.
|
|
|
|
* @param type {mqtt_type_t}
|
|
|
|
* @return {const char*}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
const char* mqtt_type_desc(mqtt_type_t type);
|
2021-03-12 17:26:49 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* get description of the specified mqtt qos.
|
|
|
|
* @param qos {mqtt_qos_t}
|
|
|
|
* @return {const char*}
|
|
|
|
*/
|
2021-03-11 19:03:22 +08:00
|
|
|
const char* mqtt_qos_desc(mqtt_qos_t qos);
|
2021-03-09 10:02:46 +08:00
|
|
|
|
|
|
|
class string;
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* mqtt message header class, used for building or parsing mqtt header data.
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
class ACL_CPP_API mqtt_header {
|
|
|
|
public:
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* mqtt header constructor, usually for building mqtt message.
|
|
|
|
* @param type {mqtt_type_t}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
mqtt_header(mqtt_type_t type);
|
2021-03-12 17:26:49 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* mqtt header constructor, usually for parsing mqtt message.
|
|
|
|
* @param header {const mqtt_header&} will be copied internal.
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
mqtt_header(const mqtt_header& header);
|
2021-03-12 17:26:49 +08:00
|
|
|
|
2021-03-09 10:02:46 +08:00
|
|
|
virtual ~mqtt_header(void);
|
|
|
|
|
|
|
|
public:
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* build mqtt header data after initializing the header object
|
|
|
|
* by calling the setting methods below like set_xxx.
|
|
|
|
* @param out {string&} store mqtt header data.
|
|
|
|
* @return {bool} return true if build header successfully.
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
bool build_header(string& out);
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* parsing mqtt header data in streaming mode.
|
|
|
|
* @param data {const char*} the mqtt header data, not NULL.
|
|
|
|
* @param dlen {int} the length of data, must > 0
|
|
|
|
* @return {int} return the length of the left data not consumed:
|
|
|
|
* > 0: the header has completed and the length of left data can
|
|
|
|
* be used as mqtt body or next mqtt message;
|
|
|
|
* 0: the data input has been consumed, you can call finished() to
|
|
|
|
* check if the mqtt header has completed.
|
|
|
|
* -1: some error happened when parsing the input data.
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
int update(const char* data, int dlen);
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* check if the mqtt header has completed.
|
|
|
|
* @return {bool}
|
|
|
|
*/
|
2021-03-10 17:21:29 +08:00
|
|
|
bool finished(void) const {
|
2021-03-09 10:02:46 +08:00
|
|
|
return finished_;
|
|
|
|
}
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* reset the status of the mqtt header object for reusing the object.
|
|
|
|
*/
|
2021-03-10 17:21:29 +08:00
|
|
|
void reset(void);
|
|
|
|
|
2021-03-09 10:02:46 +08:00
|
|
|
public:
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* set the mqtt message type in mqtt header
|
|
|
|
* @param type {mqtt_type_t}
|
|
|
|
* @return {mqtt_header&}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
mqtt_header& set_type(mqtt_type_t type);
|
2021-03-12 17:26:49 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* set the mqtt header flags.
|
|
|
|
* @param flags {char}
|
|
|
|
* @return {mqtt_header&}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
mqtt_header& set_header_flags(char flags);
|
2021-03-12 17:26:49 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* set the length of the mqtt message body.
|
|
|
|
* @param len {unsigned}
|
|
|
|
* @return {mqtt_header&}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
mqtt_header& set_remaing_length(unsigned len);
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* set the qos of the mqtt message.
|
|
|
|
* @param qos {mqtt_qos_t}
|
|
|
|
* @return {mqtt_header&}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
mqtt_header& set_qos(mqtt_qos_t qos);
|
2021-03-12 17:26:49 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* set if the mqtt message be sent duplicated.
|
|
|
|
* @param yes {bool}
|
|
|
|
* @return {mqtt_header&}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
mqtt_header& set_dup(bool yes);
|
2021-03-12 17:26:49 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* set the remain flag in mqtt header.
|
|
|
|
* @param yes {bool}
|
|
|
|
* @return {mqtt_header&}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
mqtt_header& set_remain(bool yes);
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* get the mqtt message type.
|
|
|
|
* @return {mqtt_type_t}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
mqtt_type_t get_type(void) const {
|
|
|
|
return type_;
|
|
|
|
}
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* get the mqtt header flags.
|
|
|
|
* @return {unsigned char}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
unsigned char get_header_flags(void) const {
|
|
|
|
return hflags_;
|
|
|
|
}
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* get the length of the mqtt message body.
|
|
|
|
* @return {unsigned}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
unsigned get_remaining_length(void) const {
|
|
|
|
return dlen_;
|
|
|
|
}
|
|
|
|
|
2021-03-12 17:26:49 +08:00
|
|
|
/**
|
|
|
|
* get the mqtt message's qos.
|
|
|
|
* @return {mqtt_qos_t}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
mqtt_qos_t get_qos(void) const;
|
2021-03-12 17:26:49 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* check if the duplicated flag has been set in header.
|
|
|
|
* @return {bool}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
bool is_dup(void) const;
|
2021-03-12 17:26:49 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* check if the remain flag has been set in header.
|
|
|
|
* @return {bool}
|
|
|
|
*/
|
2021-03-09 10:02:46 +08:00
|
|
|
bool is_remain(void) const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
unsigned status_;
|
|
|
|
bool finished_;
|
|
|
|
|
|
|
|
mqtt_type_t type_;
|
|
|
|
unsigned char hflags_:4;
|
|
|
|
unsigned dlen_;
|
|
|
|
|
|
|
|
char hbuf_[4];
|
|
|
|
unsigned hlen_;
|
|
|
|
|
|
|
|
public:
|
2021-03-12 17:26:49 +08:00
|
|
|
// parsing mqtt header in streaming mode, return the length of left
|
|
|
|
// data that not consumed.
|
|
|
|
|
2021-03-09 10:02:46 +08:00
|
|
|
int update_header_type(const char* data, int dlen);
|
|
|
|
int update_header_len(const char* data, int dlen);
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace acl
|