Zephyr Project API 4.0.99
A Scalable Open Source RTOS
|
Data Structures | |
struct | mqtt_sn_data |
Abstracts memory buffers. More... | |
union | mqtt_sn_evt_param |
Event metadata. More... | |
struct | mqtt_sn_evt |
MQTT-SN event structure to be handled by the event callback. More... | |
struct | mqtt_sn_transport |
Structure to describe an MQTT-SN transport. More... | |
struct | mqtt_sn_client |
Structure describing an MQTT-SN client. More... | |
Macros | |
#define | MQTT_SN_DATA_STRING_LITERAL(literal) ((struct mqtt_sn_data){literal, sizeof(literal) - 1}) |
Initialize memory buffer from C literal string. | |
#define | MQTT_SN_DATA_BYTES(...) ((struct mqtt_sn_data){(uint8_t[]){__VA_ARGS__}, sizeof((uint8_t[]){__VA_ARGS__})}) |
Initialize memory buffer from single bytes. | |
Typedefs | |
typedef void(* | mqtt_sn_evt_cb_t) (struct mqtt_sn_client *client, const struct mqtt_sn_evt *evt) |
Asynchronous event notification callback registered by the application. | |
Enumerations | |
enum | mqtt_sn_qos { MQTT_SN_QOS_0 , MQTT_SN_QOS_1 , MQTT_SN_QOS_2 , MQTT_SN_QOS_M1 } |
Quality of Service. More... | |
enum | mqtt_sn_topic_type { MQTT_SN_TOPIC_TYPE_NORMAL , MQTT_SN_TOPIC_TYPE_PREDEF , MQTT_SN_TOPIC_TYPE_SHORT } |
MQTT-SN topic types. More... | |
enum | mqtt_sn_return_code { MQTT_SN_CODE_ACCEPTED = 0x00 , MQTT_SN_CODE_REJECTED_CONGESTION = 0x01 , MQTT_SN_CODE_REJECTED_TOPIC_ID = 0x02 , MQTT_SN_CODE_REJECTED_NOTSUP = 0x03 } |
MQTT-SN return codes. More... | |
enum | mqtt_sn_evt_type { MQTT_SN_EVT_CONNECTED , MQTT_SN_EVT_DISCONNECTED , MQTT_SN_EVT_ASLEEP , MQTT_SN_EVT_AWAKE , MQTT_SN_EVT_PUBLISH , MQTT_SN_EVT_PINGRESP , MQTT_SN_EVT_ADVERTISE , MQTT_SN_EVT_GWINFO , MQTT_SN_EVT_SEARCHGW } |
Event types that can be emitted by the library. More... | |
Functions | |
int | mqtt_sn_client_init (struct mqtt_sn_client *client, const struct mqtt_sn_data *client_id, struct mqtt_sn_transport *transport, mqtt_sn_evt_cb_t evt_cb, void *tx, size_t txsz, void *rx, size_t rxsz) |
Initialize a client. | |
void | mqtt_sn_client_deinit (struct mqtt_sn_client *client) |
Deinitialize the client. | |
int | mqtt_sn_add_gw (struct mqtt_sn_client *client, uint8_t gw_id, struct mqtt_sn_data gw_addr) |
Manually add a Gateway, bypasing the normal search process. | |
int | mqtt_sn_search (struct mqtt_sn_client *client, uint8_t radius) |
Initiate the MQTT-SN GW Search process. | |
int | mqtt_sn_connect (struct mqtt_sn_client *client, bool will, bool clean_session) |
Connect the client. | |
int | mqtt_sn_disconnect (struct mqtt_sn_client *client) |
Disconnect the client. | |
int | mqtt_sn_sleep (struct mqtt_sn_client *client, uint16_t duration) |
Set the client into sleep state. | |
int | mqtt_sn_subscribe (struct mqtt_sn_client *client, enum mqtt_sn_qos qos, struct mqtt_sn_data *topic_name) |
Subscribe to a given topic. | |
int | mqtt_sn_unsubscribe (struct mqtt_sn_client *client, enum mqtt_sn_qos qos, struct mqtt_sn_data *topic_name) |
Unsubscribe from a topic. | |
int | mqtt_sn_publish (struct mqtt_sn_client *client, enum mqtt_sn_qos qos, struct mqtt_sn_data *topic_name, bool retain, struct mqtt_sn_data *data) |
Publish a value. | |
int | mqtt_sn_input (struct mqtt_sn_client *client) |
Check the transport for new incoming data. | |
int | mqtt_sn_get_topic_name (struct mqtt_sn_client *client, uint16_t id, struct mqtt_sn_data *topic_name) |
Get topic name by topic ID. | |
#define MQTT_SN_DATA_BYTES | ( | ... | ) | ((struct mqtt_sn_data){(uint8_t[]){__VA_ARGS__}, sizeof((uint8_t[]){__VA_ARGS__})}) |
#include <include/zephyr/net/mqtt_sn.h>
Initialize memory buffer from single bytes.
Use it as follows:
struct mqtt_sn_data data = MQTT_SN_DATA_BYTES(0x13, 0x37);
#define MQTT_SN_DATA_STRING_LITERAL | ( | literal | ) | ((struct mqtt_sn_data){literal, sizeof(literal) - 1}) |
#include <include/zephyr/net/mqtt_sn.h>
Initialize memory buffer from C literal string.
Use it as follows:
struct mqtt_sn_data topic = MQTT_SN_DATA_STRING_LITERAL("/zephyr");
[in] | literal | Literal string from which to generate mqtt_sn_data object. |
typedef void(* mqtt_sn_evt_cb_t) (struct mqtt_sn_client *client, const struct mqtt_sn_evt *evt) |
#include <include/zephyr/net/mqtt_sn.h>
Asynchronous event notification callback registered by the application.
[in] | client | Identifies the client for which the event is notified. |
[in] | evt | Event description along with result and associated parameters (if any). |
enum mqtt_sn_evt_type |
#include <include/zephyr/net/mqtt_sn.h>
Event types that can be emitted by the library.
enum mqtt_sn_qos |
#include <include/zephyr/net/mqtt_sn.h>
Quality of Service.
QoS 0-2 work the same as basic MQTT, QoS -1 is an MQTT-SN addition. QOS -1 is not supported yet.
Enumerator | |
---|---|
MQTT_SN_QOS_0 | QOS 0. |
MQTT_SN_QOS_1 | QOS 1. |
MQTT_SN_QOS_2 | QOS 2. |
MQTT_SN_QOS_M1 | QOS -1. |
enum mqtt_sn_return_code |
#include <include/zephyr/net/mqtt_sn.h>
MQTT-SN return codes.
enum mqtt_sn_topic_type |
#include <include/zephyr/net/mqtt_sn.h>
MQTT-SN topic types.
int mqtt_sn_add_gw | ( | struct mqtt_sn_client * | client, |
uint8_t | gw_id, | ||
struct mqtt_sn_data | gw_addr | ||
) |
#include <include/zephyr/net/mqtt_sn.h>
Manually add a Gateway, bypasing the normal search process.
This function manually creates a gateway that is stored internal to the library.
client | The MQTT-SN client to connect. |
gw_id | Single byte Gateway Identifier |
gw_addr | Address data structure to be used by the transport layer. |
void mqtt_sn_client_deinit | ( | struct mqtt_sn_client * | client | ) |
#include <include/zephyr/net/mqtt_sn.h>
Deinitialize the client.
This removes all topics and publishes, and also de-inits the transport.
client | The MQTT-SN client to deinitialize. |
int mqtt_sn_client_init | ( | struct mqtt_sn_client * | client, |
const struct mqtt_sn_data * | client_id, | ||
struct mqtt_sn_transport * | transport, | ||
mqtt_sn_evt_cb_t | evt_cb, | ||
void * | tx, | ||
size_t | txsz, | ||
void * | rx, | ||
size_t | rxsz | ||
) |
#include <include/zephyr/net/mqtt_sn.h>
Initialize a client.
client | The MQTT-SN client to initialize. |
client_id | The ID to be used by the client. |
transport | The transport to be used by the client. |
evt_cb | The event callback function for the client. |
tx | Pointer to the transmit buffer. |
txsz | Size of the transmit buffer. |
rx | Pointer to the receive buffer. |
rxsz | Size of the receive buffer. |
int mqtt_sn_connect | ( | struct mqtt_sn_client * | client, |
bool | will, | ||
bool | clean_session | ||
) |
#include <include/zephyr/net/mqtt_sn.h>
Connect the client.
client | The MQTT-SN client to connect. |
will | Flag indicating if a Will message should be sent. |
clean_session | Flag indicating if a clean session should be started. |
int mqtt_sn_disconnect | ( | struct mqtt_sn_client * | client | ) |
#include <include/zephyr/net/mqtt_sn.h>
Disconnect the client.
client | The MQTT-SN client to disconnect. |
int mqtt_sn_get_topic_name | ( | struct mqtt_sn_client * | client, |
uint16_t | id, | ||
struct mqtt_sn_data * | topic_name | ||
) |
#include <include/zephyr/net/mqtt_sn.h>
Get topic name by topic ID.
[in] | client | The MQTT-SN client that uses this topic. |
[in] | id | Topic identifier. |
[out] | topic_name | Will be assigned to topic name. |
int mqtt_sn_input | ( | struct mqtt_sn_client * | client | ) |
#include <include/zephyr/net/mqtt_sn.h>
Check the transport for new incoming data.
Call this function periodically, or if you have good reason to believe there is any data. If the client's transport struct contains a poll-function, this function is non-blocking.
client | The MQTT-SN client to check for incoming data. |
int mqtt_sn_publish | ( | struct mqtt_sn_client * | client, |
enum mqtt_sn_qos | qos, | ||
struct mqtt_sn_data * | topic_name, | ||
bool | retain, | ||
struct mqtt_sn_data * | data | ||
) |
#include <include/zephyr/net/mqtt_sn.h>
Publish a value.
If the topic is not yet registered with the gateway, the library takes care of it.
client | The MQTT-SN client that should publish. |
qos | The desired quality of service for the publish. |
topic_name | The name of the topic to publish to. |
retain | Flag indicating if the message should be retained by the broker. |
data | The data to be published. |
int mqtt_sn_search | ( | struct mqtt_sn_client * | client, |
uint8_t | radius | ||
) |
#include <include/zephyr/net/mqtt_sn.h>
Initiate the MQTT-SN GW Search process.
client | The MQTT-SN client to connect. |
radius | Broadcast radius for the search message. |
int mqtt_sn_sleep | ( | struct mqtt_sn_client * | client, |
uint16_t | duration | ||
) |
#include <include/zephyr/net/mqtt_sn.h>
Set the client into sleep state.
client | The MQTT-SN client to be put to sleep. |
duration | Sleep duration (in seconds). |
int mqtt_sn_subscribe | ( | struct mqtt_sn_client * | client, |
enum mqtt_sn_qos | qos, | ||
struct mqtt_sn_data * | topic_name | ||
) |
#include <include/zephyr/net/mqtt_sn.h>
Subscribe to a given topic.
client | The MQTT-SN client that should subscribe. |
qos | The desired quality of service for the subscription. |
topic_name | The name of the topic to subscribe to. |
int mqtt_sn_unsubscribe | ( | struct mqtt_sn_client * | client, |
enum mqtt_sn_qos | qos, | ||
struct mqtt_sn_data * | topic_name | ||
) |
#include <include/zephyr/net/mqtt_sn.h>
Unsubscribe from a topic.
client | The MQTT-SN client that should unsubscribe. |
qos | The quality of service used when subscribing. |
topic_name | The name of the topic to unsubscribe from. |