Fixed indentation and updated functions
This commit is contained in:
@@ -12,41 +12,44 @@
|
|||||||
#include "mqtt.h"
|
#include "mqtt.h"
|
||||||
#include "mug.h"
|
#include "mug.h"
|
||||||
|
|
||||||
|
#define LOGGER_LEVEL_INFO
|
||||||
|
#include "log.h"
|
||||||
|
|
||||||
|
//Function prototypes
|
||||||
static void mqtt_pub_request_cb(void*, err_t);
|
static void mqtt_pub_request_cb(void*, err_t);
|
||||||
void example_publish(mqtt_client_t* , void*);
|
static void example_publish(mqtt_client_t* , void*);
|
||||||
static void mqtt_incoming_publish_cb(void*, const char*, u32_t);
|
static void mqtt_incoming_publish_cb(void*, const char*, u32_t);
|
||||||
static void mqtt_incoming_data_cb(void*, const u8_t*, u16_t, u8_t);
|
static void mqtt_incoming_data_cb(void*, const u8_t*, u16_t, u8_t);
|
||||||
static void mqtt_sub_request_cb(void*, err_t);
|
static void mqtt_sub_request_cb(void*, err_t);
|
||||||
static void mqtt_connection_cb(mqtt_client_t*, void*, mqtt_connection_status_t);
|
static void mqtt_connection_cb(mqtt_client_t*, void*, mqtt_connection_status_t);
|
||||||
void example_do_connect(mqtt_client_t*);
|
static void example_do_connect(mqtt_client_t*);
|
||||||
|
|
||||||
|
//global variable used in mqtt_incoming_publish_cb and mqtt_incoming_data_cb to give an easy to use ID to the subscribed topics
|
||||||
|
static int inpub_id;
|
||||||
|
static const char *TAG = "mug";
|
||||||
|
|
||||||
static void mqtt_pub_request_cb(void *arg, err_t result) {
|
static void mqtt_pub_request_cb(void *arg, err_t result) {
|
||||||
if(result != ERR_OK) {
|
if(result != ERR_OK) {
|
||||||
printf("Publish result: %d\n", result);
|
LOG_INFO(TAG, "Publish result: %d\n", result);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int teller = 0;
|
static void example_publish(mqtt_client_t *client, void *arg) {
|
||||||
void example_publish(mqtt_client_t *client, void *arg) {
|
|
||||||
printf("testing publish\n");
|
printf("testing publish\n");
|
||||||
const char *pub_payload[20];
|
const char *pub_payload[20];
|
||||||
err_t err;
|
err_t err;
|
||||||
u8_t qos = 2;
|
u8_t qos = 2;
|
||||||
u8_t retain = 0;
|
u8_t retain = 0;
|
||||||
itoa(teller, &pub_payload, 10);
|
|
||||||
err = mqtt_publish(client, "pushbutton_event", pub_payload, strlen(pub_payload), qos, retain, mqtt_pub_request_cb, arg);
|
err = mqtt_publish(client, "getImageList", pub_payload, sizeof(pub_payload), qos, retain, mqtt_pub_request_cb, arg);
|
||||||
if(err != ERR_OK) {
|
if(err != ERR_OK) {
|
||||||
printf("Publish err: %d\n", err);
|
printf("Publish err: %d\n", err);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int inpub_id;
|
|
||||||
static void mqtt_incoming_publish_cb(void *arg, const char *topic, u32_t tot_len) {
|
static void mqtt_incoming_publish_cb(void *arg, const char *topic, u32_t tot_len) {
|
||||||
printf("Incoming publish at topic %s with total length %u\n", topic, (unsigned int)tot_len);
|
printf("Incoming publish at topic %s with total length %u\n", topic, (unsigned int)tot_len);
|
||||||
|
//check for which topic a publish was received
|
||||||
//check for which topic a publish was received for
|
|
||||||
if(strcmp(topic, "/input/setText") == 0) {
|
if(strcmp(topic, "/input/setText") == 0) {
|
||||||
inpub_id = 0;
|
inpub_id = 0;
|
||||||
} else if(strcmp(topic, "/input/setImage") == 0) {
|
} else if(strcmp(topic, "/input/setImage") == 0) {
|
||||||
@@ -63,25 +66,30 @@ static void mqtt_incoming_publish_cb(void *arg, const char *topic, u32_t tot_len
|
|||||||
|
|
||||||
static void mqtt_incoming_data_cb(void *arg, const u8_t *data, u16_t len, u8_t flags) {
|
static void mqtt_incoming_data_cb(void *arg, const u8_t *data, u16_t len, u8_t flags) {
|
||||||
printf("Incoming publish payload with length %d, flags %u\n", len, (unsigned int)flags);
|
printf("Incoming publish payload with length %d, flags %u\n", len, (unsigned int)flags);
|
||||||
|
|
||||||
if(flags & MQTT_DATA_FLAG_LAST) {
|
if(flags & MQTT_DATA_FLAG_LAST) {
|
||||||
if (inpub_id == 0) {
|
switch(inpub_id) {
|
||||||
|
case 0:
|
||||||
//places text on the lcd
|
//places text on the lcd
|
||||||
} else if (inpub_id == 1) {
|
break;
|
||||||
|
case 1:
|
||||||
//places an image on the lcd
|
//places an image on the lcd
|
||||||
} else if (inpub_id == 2) {
|
break;
|
||||||
|
case 2:
|
||||||
//changes the text color on the lcd
|
//changes the text color on the lcd
|
||||||
} else if (inpub_id == 3) {
|
break;
|
||||||
|
case 3:
|
||||||
//changes the background color
|
//changes the background color
|
||||||
} else {
|
break;
|
||||||
printf("mqtt_incoming_data_cb: Ignoring payload...\n");
|
default:
|
||||||
|
LOG_INFO(TAG, "Publish received on wrong topic, incoming data ignored.");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void mqtt_sub_request_cb(void *arg, err_t result) {
|
static void mqtt_sub_request_cb(void *arg, err_t result) {
|
||||||
printf("Subscribe result: %d\n", result);
|
LOG_INFO(TAG, "Subscribe result: %d\n", result);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void mqtt_connection_cb(mqtt_client_t *client, void *arg, mqtt_connection_status_t status) {
|
static void mqtt_connection_cb(mqtt_client_t *client, void *arg, mqtt_connection_status_t status) {
|
||||||
@@ -95,11 +103,11 @@ static void mqtt_connection_cb(mqtt_client_t *client, void *arg, mqtt_connection
|
|||||||
|
|
||||||
//subscribe to the topics setText, setImage, setColor and setTextcolor
|
//subscribe to the topics setText, setImage, setColor and setTextcolor
|
||||||
err = mqtt_subscribe(client, "/input/#", 1, mqtt_sub_request_cb, arg);
|
err = mqtt_subscribe(client, "/input/#", 1, mqtt_sub_request_cb, arg);
|
||||||
|
|
||||||
if(err != ERR_OK) {
|
if(err != ERR_OK) {
|
||||||
printf("mqtt_subscribe return: %d\n", err);
|
printf("mqtt_subscribe return: %d\n", err);
|
||||||
}
|
}
|
||||||
//publish list of images here
|
//publish list of images here
|
||||||
|
example_publish(client, NULL);
|
||||||
} else {
|
} else {
|
||||||
printf("mqtt_connection_cb: Disconnected, reason: %d\n", status);
|
printf("mqtt_connection_cb: Disconnected, reason: %d\n", status);
|
||||||
|
|
||||||
@@ -108,7 +116,7 @@ static void mqtt_connection_cb(mqtt_client_t *client, void *arg, mqtt_connection
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void example_do_connect(mqtt_client_t *client) {
|
static void example_do_connect(mqtt_client_t *client) {
|
||||||
printf("testing the connection\n");
|
printf("testing the connection\n");
|
||||||
struct mqtt_connect_client_info_t ci;
|
struct mqtt_connect_client_info_t ci;
|
||||||
err_t err;
|
err_t err;
|
||||||
@@ -128,7 +136,7 @@ void example_do_connect(mqtt_client_t *client) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void mug_init() {
|
void mug_init(void) {
|
||||||
mqtt_client_t *client = mqtt_client_new();
|
mqtt_client_t *client = mqtt_client_new();
|
||||||
if(client != NULL) {
|
if(client != NULL) {
|
||||||
printf("Starting connection test\n");
|
printf("Starting connection test\n");
|
||||||
|
|||||||
Reference in New Issue
Block a user