123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- /* MQTT (over TCP) Example
- This example code is in the Public Domain (or CC0 licensed, at your option.)
- Unless required by applicable law or agreed to in writing, this
- software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
- CONDITIONS OF ANY KIND, either express or implied.
- */
- #include <stdio.h>
- #include <stdint.h>
- #include <stddef.h>
- #include <string.h>
- #include "esp_wifi.h"
- #include "esp_system.h"
- #include "nvs_flash.h"
- #include "esp_event.h"
- #include "esp_netif.h"
- //#include "protocol_examples_common.h"
- #include "freertos/FreeRTOS.h"
- #include "freertos/task.h"
- #include "freertos/semphr.h"
- #include "freertos/queue.h"
- #include "lwip/sockets.h"
- #include "lwip/dns.h"
- #include "lwip/netdb.h"
- #include "esp_log.h"
- #include "mqtt_client.h"
- #include "wifi.h"
- #include "receiver.h"
- #include "toshiba_ir.h"
- static const char *TAG = "MQTT";
- #ifdef MQTT_ENABLED
- static esp_mqtt_client_handle_t client;
- static bool connected = false;
- static esp_err_t mqtt_event_handler_cb(esp_mqtt_event_handle_t event)
- {
-
- esp_mqtt_client_handle_t client = event->client;
- int msg_id;
- // your_context_t *context = event->context;
- switch (event->event_id) {
- case MQTT_EVENT_CONNECTED:
- connected = true;
- ESP_LOGI(TAG, "MQTT_EVENT_CONNECTED");
- msg_id = esp_mqtt_client_subscribe(client, "hall/ac/ir_cmd_tx", 0);
- ESP_LOGI(TAG, "Sent subscribe successful, msg_id=%d", msg_id);
- break;
- case MQTT_EVENT_DISCONNECTED:
- connected = false;
- ESP_LOGI(TAG, "MQTT_EVENT_DISCONNECTED");
- break;
-
- case MQTT_EVENT_SUBSCRIBED:
- ESP_LOGI(TAG, "MQTT_EVENT_SUBSCRIBED, msg_id=%d", event->msg_id);
- break;
- case MQTT_EVENT_UNSUBSCRIBED:
- ESP_LOGI(TAG, "MQTT_EVENT_UNSUBSCRIBED, msg_id=%d", event->msg_id);
- break;
- case MQTT_EVENT_PUBLISHED:
- ESP_LOGI(TAG, "MQTT_EVENT_PUBLISHED, msg_id=%d", event->msg_id);
- break;
- case MQTT_EVENT_DATA:
- ESP_LOGI(TAG, "MQTT_EVENT_DATA Topic: <%.*s>", event->topic_len, event->topic);
- //printf("DATA=%.*s\r\n", event->data_len, event->data);
- if( strncmp(event->topic,"hall/ac/ir_cmd_tx",event->topic_len) == 0 ) {
- uint8_t data[kToshibaNumberOfBytes];
- if( event->data_len != kToshibaNumberOfBytes*2 ) {
- ESP_LOGE("MQTT","Wrong length in MQTT-data %u",event->data_len);
- break;
- }
-
- bool exitRx = false;
- for(uint8_t i=0;i<kToshibaNumberOfBytes*2;i++) {
- const unsigned char c = event->data[i];
- if( c<'0' || c>'F' || (c>'9' && c<'A') ) {
- ESP_LOGE("MQTT","Wrong chars in MQTT-data");
- exitRx = true;
- break;
- }
- }
- if( exitRx ) break;
-
- char *cp = event->data;
- for(uint8_t i=0;i<kToshibaNumberOfBytes;i++) {
- int n = sscanf(cp, "%02X", (unsigned int*)&data[i]);
- if( n != 1 ) {
- ESP_LOGE("MQTT","Wrong chars (sscanf) in MQTT-data");
- break;
- }
- cp+=2;
- }
- ESP_LOGI("MQTT","Received a Toshiba IR Code for transmit");
- xQueueSend( toshibaTxQueue, &data, 0 );
- }
- break;
- case MQTT_EVENT_ERROR:
- ESP_LOGI(TAG, "MQTT_EVENT_ERROR");
- break;
- default:
- ESP_LOGI(TAG, "Other event id:%d", event->event_id);
- break;
- }
- return ESP_OK;
- }
- static void mqtt_event_handler(void *handler_args, esp_event_base_t base, int32_t event_id, void *event_data) {
- ESP_LOGD(TAG, "Event dispatched from event loop base=%s, event_id=%d", base, event_id);
- mqtt_event_handler_cb(event_data);
- }
- void mqttTask(void *pvParameters) {
- ESP_LOGI("MQTT", "mqttTask starting. Core:%d\n",xPortGetCoreID());
- #ifdef WIFI_ENABLED
- // Wait for tcpip-comm
- while( commIsUpAndRunning == false ) vTaskDelay(10000 / portTICK_PERIOD_MS);
- #endif
- esp_mqtt_client_config_t mqtt_cfg = {
- .uri = "mqtt://192.168.1.110:1883",
- .password = CONFIG_ESP_MQTT_PASSWORD,
- .username = CONFIG_ESP_MQTT_UNAME
- };
- client = esp_mqtt_client_init(&mqtt_cfg);
- esp_mqtt_client_register_event(client, ESP_EVENT_ANY_ID, mqtt_event_handler, client);
- esp_mqtt_client_start(client);
- ESP_LOGI("TX", "toshibaTxTask() starting.");
- }
- void mqtt_init(void)
- {
- xTaskCreatePinnedToCore(mqttTask, "MQTT-Task", 1024*10, NULL, 2, NULL,0);
- }
- void sendMQTTMessage(const char * topic, const char * data) {
- if( connected ) {
- int msg_id;
-
- #ifdef MQTT_DEBUG
- char topic_debug_str[100];
- sprintf(topic_debug_str,"debug_ir_env/%s",topic);
- msg_id = esp_mqtt_client_publish(client, topic_debug_str, data, 0, 1, 0);
- #else
- msg_id = esp_mqtt_client_publish(client, topic, data, 0, 1, 0);
- #endif
- ESP_LOGI(TAG, "sent publish successful, msg_id=%d %s %s", msg_id, topic, data);
- }
- else {
- ESP_LOGI(TAG, "Not connected to MQTT");
- }
- }
- #else
- void sendMQTTMessage(const char * topic, const char * data) {
- ESP_LOGI(TAG, "sent publish FAKE, msg_id=- %s %s", topic, data);
- }
- #endif
|