messaging.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  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. esp_err_t messaging_type_to_err_type(messaging_types type);
  30. void messaging_service_init();
  31. #define LOG_SEND(y, ...) \
  32. { \
  33. ESP_LOG_LEVEL_LOCAL(messaging_type_to_err_type(y),TAG, ##__VA_ARGS__); \
  34. messaging_post_message(y, MESSAGING_CLASS_SYSTEM, ##__VA_ARGS__); }
  35. #define LOG_SEND_ERROR( ...) LOG_SEND(MESSAGING_ERROR,##__VA_ARGS__)
  36. #define LOG_SEND_INFO( ...) LOG_SEND(MESSAGING_INFO,##__VA_ARGS__)
  37. #define LOG_SEND_WARN( ...) LOG_SEND(MESSAGING_WARNING,##__VA_ARGS__)