log.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. #ifndef LOG_H
  2. #define LOG_H
  3. #include "main.h"
  4. #define FILE_BUF_MAX_LEN 10*STRING_SIZE_HISTORY // Размер временного буфера для отправки/копирования Лог файла
  5. #define FILE_BUF_MAX_LEN_LOG 10*STRING_SIZE // Размер временного буфера для отправки/копирования Лог файла
  6. #define STRING_SIZE 64
  7. #define STRING_SIZE_HISTORY 100
  8. extern char logFileBuf[FILE_BUF_MAX_LEN];
  9. extern char name_login[50];
  10. typedef __packed enum {
  11. LOG_SYSTEM_BOOT = 0x00, // device booted
  12. LOG_SYSTEM_DEFCONFIG, // default config applied
  13. LOG_UPDATE_SOFT,
  14. LOG_TURN_ON, //
  15. LOG_PSW_CHANGE, //
  16. LOG_SETTING_SAVE, //
  17. #if defined HARDWARE_BT6707 || HARDWARE_BT6709
  18. LOG_LOGIN_TELNET, //
  19. #ifdef HARDWARE_BT6709
  20. LOG_LOGIN_SSH,
  21. #endif // HARDWARE_BT6709
  22. #endif
  23. LOG_LOGIN, //
  24. LOG_TEST_UPS, //
  25. LOG_SHUTDOWN_UPS,
  26. #ifndef HARDWARE_BT6709
  27. LOG_ALARM_DIO,
  28. LOG_DO0_STATE,
  29. LOG_DO1_STATE,
  30. #if defined HARDWARE_BT6707
  31. LOG_DO2_STATE,
  32. #endif
  33. #endif
  34. #if defined HARDWARE_BT6707 || HARDWARE_BT6709
  35. LOG_ALARM_VAC_LOW_OUTPUT,
  36. LOG_ALARM_VAC_HIGH_OUTPUT,
  37. #endif
  38. LOG_ALARM_HIGH_TEMP,
  39. LOG_ALARM_LOW_TEMP,
  40. LOG_ALARM_LINE,
  41. LOG_ALARM_LOW_BAT,
  42. LOG_ALARM_POWER,
  43. LOG_ALARM_UPS,
  44. LOG_ALARM_AKB,
  45. #ifdef HARDWARE_BT6709
  46. LOG_ALARM_CHANGE_AKB,
  47. #endif
  48. LOG_VALUE,
  49. LOG_NONE,
  50. } log_type_t;
  51. typedef __packed struct {
  52. uint32_t timestamp;
  53. log_type_t type:8;
  54. char data[50];
  55. } log_entry_t;
  56. #define LOG_ENTRY_VERSION 1
  57. extern void log_init(bool format);
  58. extern int log_test(void);
  59. extern int log_append(log_entry_t *entry);
  60. extern int log_fetch(log_entry_t *entry, uint32_t timeout);
  61. extern int log_rewind(log_entry_t *entry, uint32_t timeout);
  62. extern int log_discard(log_entry_t *entry, uint32_t timeout);
  63. void log_add(char *log_data);
  64. void log_event_data(log_type_t type, char *data);
  65. /**
  66. * @brief Возвращает true если журнал проинициализирован
  67. */
  68. bool LOG_IsInit();
  69. /**
  70. * @brief Отключает журнал для безопасной перезагрузки
  71. */
  72. bool LOG_Disable(void);
  73. /**
  74. * @brief Возвращает общее количество страниц
  75. */
  76. uint32_t LOG_GetPageCount(void);
  77. uint32_t LOG_GetTotalSTRCount(void);
  78. void LOG_GetPage(char *str, uint32_t page);
  79. void LOG_GetPage_tabs(char *str, uint32_t page);
  80. uint32_t LOG_GetData(int ptr, char *str, uint32_t size, bool start);
  81. uint32_t History_GetPageCount(void);
  82. uint32_t History_GetTotalSTRCount(void);
  83. void History_GetPage(char *str, uint32_t page);
  84. uint32_t History_GetData(int ptr, char *str, uint32_t size, bool start);
  85. void History_GetPage_tabs(char *str, uint32_t page);
  86. #endif /* LOG_H */