messaging.h 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. #include "sdkconfig.h"
  2. #include "freertos/ringbuf.h"
  3. #include "cJSON.h"
  4. #pragma once
  5. typedef enum {
  6. MESSAGING_INFO,
  7. MESSAGING_WARNING,
  8. MESSAGING_ERROR
  9. } messaging_types;
  10. typedef enum {
  11. MESSAGING_CLASS_OTA,
  12. MESSAGING_CLASS_SYSTEM,
  13. MESSAGING_CLASS_STATS
  14. } messaging_classes;
  15. typedef struct messaging_list_t *messaging_handle_t;
  16. typedef struct {
  17. time_t sent_time;
  18. messaging_types type;
  19. messaging_classes msg_class;
  20. size_t msg_size;
  21. char message[];
  22. } single_message_t;
  23. cJSON * messaging_retrieve_messages(RingbufHandle_t buf_handle);
  24. messaging_handle_t messaging_register_subscriber(uint8_t max_count, char * name);
  25. esp_err_t messaging_post_to_queue(messaging_handle_t subscriber_handle, single_message_t * message, size_t message_size);
  26. void messaging_post_message(messaging_types type,messaging_classes msg_class, const char * fmt, ...);
  27. cJSON * messaging_retrieve_messages(RingbufHandle_t buf_handle);
  28. single_message_t * messaging_retrieve_message(RingbufHandle_t buf_handle);
  29. void log_send_messaging(messaging_types msgtype,const char *fmt, ...);
  30. esp_err_t messaging_type_to_err_type(messaging_types type);
  31. void messaging_service_init();
  32. #define REALLOC_CAT(e,n) e=realloc(e,strlen(n)); e=strcat(e,n)
  33. #define LOG_SEND(y, ...) \
  34. { \
  35. ESP_LOG_LEVEL_LOCAL(messaging_type_to_err_type(y),TAG, ##__VA_ARGS__); \
  36. messaging_post_message(y, MESSAGING_CLASS_SYSTEM, ##__VA_ARGS__); }
  37. #define LOG_SEND_ERROR( ...) LOG_SEND(MESSAGING_ERROR,##__VA_ARGS__)
  38. #define LOG_SEND_INFO( ...) LOG_SEND(MESSAGING_INFO,##__VA_ARGS__)
  39. #define LOG_SEND_WARN( ...) LOG_SEND(MESSAGING_WARNING,##__VA_ARGS__)