Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- /*
- This example uses FreeRTOS softwaretimers as there is no built-in Ticker library
- */
- #include <WiFi.h>
- //extern "C" {
- #include <FreeRTOS.h>
- #include <freertos/timers.h>
- //}
- #include <AsyncMqttClient.h>
- #define WIFI_SSID "yourSSID"
- #define WIFI_PASSWORD "yourpass"
- #define MQTT_HOST IPAddress(192, 168, 1, 10)
- #define MQTT_PORT 1883
- AsyncMqttClient mqttClient;
- TimerHandle_t mqttReconnectTimer;
- TimerHandle_t wifiReconnectTimer;
- void connectToWifi() {
- Serial.println("Connecting to Wi-Fi...");
- WiFi.begin(WIFI_SSID, WIFI_PASSWORD);
- }
- void connectToMqtt() {
- Serial.println("Connecting to MQTT...");
- mqttClient.connect();
- }
- void WiFiEvent(WiFiEvent_t event) {
- Serial.printf("[WiFi-event] event: %d\n", event);
- switch(event) {
- case SYSTEM_EVENT_STA_GOT_IP:
- Serial.println("WiFi connected");
- Serial.println("IP address: ");
- Serial.println(WiFi.localIP());
- connectToMqtt();
- break;
- case SYSTEM_EVENT_STA_DISCONNECTED:
- Serial.println("WiFi lost connection");
- xTimerStop(mqttReconnectTimer, 0); // ensure we don't reconnect to MQTT while reconnecting to Wi-Fi
- xTimerStart(wifiReconnectTimer, 0);
- break;
- //DAK added events below to satisfy compiler for enumerated event handler in 'switch' function.
- case SYSTEM_EVENT_WIFI_READY:
- Serial.println("WIFI Ready!");
- break;
- case SYSTEM_EVENT_SCAN_DONE:
- break;
- case SYSTEM_EVENT_STA_START:
- break;
- case SYSTEM_EVENT_STA_STOP:
- break;
- case SYSTEM_EVENT_STA_CONNECTED:
- break;
- case SYSTEM_EVENT_STA_AUTHMODE_CHANGE:
- Serial.println("Authmode has CHANGED!");
- break;
- case SYSTEM_EVENT_STA_LOST_IP:
- Serial.println("Lost the IP");
- break;
- case SYSTEM_EVENT_STA_WPS_ER_SUCCESS:
- break;
- case SYSTEM_EVENT_STA_WPS_ER_FAILED:
- break;
- case SYSTEM_EVENT_STA_WPS_ER_TIMEOUT:
- break;
- case SYSTEM_EVENT_STA_WPS_ER_PIN:
- break;
- case SYSTEM_EVENT_AP_START:
- break;
- case SYSTEM_EVENT_AP_STOP:
- break;
- case SYSTEM_EVENT_AP_STACONNECTED:
- break;
- case SYSTEM_EVENT_AP_STADISCONNECTED:
- break;
- case SYSTEM_EVENT_AP_PROBEREQRECVED:
- break;
- case SYSTEM_EVENT_GOT_IP6:
- break;
- case SYSTEM_EVENT_ETH_START:
- break;
- case SYSTEM_EVENT_ETH_STOP:
- break;
- case SYSTEM_EVENT_ETH_CONNECTED:
- break;
- case SYSTEM_EVENT_ETH_DISCONNECTED:
- break;
- case SYSTEM_EVENT_ETH_GOT_IP:
- break;
- case SYSTEM_EVENT_MAX:
- break;
- }
- }
- void onMqttConnect(bool sessionPresent) {
- Serial.println("Connected to MQTT.");
- Serial.print("Session present: ");
- Serial.println(sessionPresent);
- uint16_t packetIdSub = mqttClient.subscribe("test/lol", 2);
- Serial.print("Subscribing at QoS 2, packetId: ");
- Serial.println(packetIdSub);
- mqttClient.publish("test/lol", 0, true, "test 1");
- Serial.println("Publishing at QoS 0");
- uint16_t packetIdPub1 = mqttClient.publish("test/lol", 1, true, "test 2");
- Serial.print("Publishing at QoS 1, packetId: ");
- Serial.println(packetIdPub1);
- uint16_t packetIdPub2 = mqttClient.publish("test/lol", 2, true, "test 3");
- Serial.print("Publishing at QoS 2, packetId: ");
- Serial.println(packetIdPub2);
- }
- void onMqttDisconnect(AsyncMqttClientDisconnectReason reason) {
- Serial.println("Disconnected from MQTT.");
- if (WiFi.isConnected()) {
- xTimerStart(mqttReconnectTimer, 0);
- }
- }
- void onMqttSubscribe(uint16_t packetId, uint8_t qos) {
- Serial.println("Subscribe acknowledged.");
- Serial.print(" packetId: ");
- Serial.println(packetId);
- Serial.print(" qos: ");
- Serial.println(qos);
- }
- void onMqttUnsubscribe(uint16_t packetId) {
- Serial.println("Unsubscribe acknowledged.");
- Serial.print(" packetId: ");
- Serial.println(packetId);
- }
- void onMqttMessage(char* topic, char* payload, AsyncMqttClientMessageProperties properties, size_t len, size_t index, size_t total) {
- Serial.println("Publish received.");
- Serial.print(" topic: ");
- Serial.println(topic);
- Serial.print(" qos: ");
- Serial.println(properties.qos);
- Serial.print(" dup: ");
- Serial.println(properties.dup);
- Serial.print(" retain: ");
- Serial.println(properties.retain);
- Serial.print(" len: ");
- Serial.println(len);
- Serial.print(" index: ");
- Serial.println(index);
- Serial.print(" total: ");
- Serial.println(total);
- }
- void onMqttPublish(uint16_t packetId) {
- Serial.println("Publish acknowledged.");
- Serial.print(" packetId: ");
- Serial.println(packetId);
- }
- void setup() {
- Serial.begin(115200);
- Serial.println();
- Serial.println();
- mqttReconnectTimer = xTimerCreate("mqttTimer", pdMS_TO_TICKS(2000), pdFALSE, (void*)0, reinterpret_cast<TimerCallbackFunction_t>(connectToMqtt));
- wifiReconnectTimer = xTimerCreate("wifiTimer", pdMS_TO_TICKS(2000), pdFALSE, (void*)0, reinterpret_cast<TimerCallbackFunction_t>(connectToWifi));
- WiFi.onEvent(WiFiEvent);
- mqttClient.onConnect(onMqttConnect);
- mqttClient.onDisconnect(onMqttDisconnect);
- mqttClient.onSubscribe(onMqttSubscribe);
- mqttClient.onUnsubscribe(onMqttUnsubscribe);
- mqttClient.onMessage(onMqttMessage);
- mqttClient.onPublish(onMqttPublish);
- mqttClient.setServer(MQTT_HOST, MQTT_PORT);
- connectToWifi();
- }
- void loop() {
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement