log.h 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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. extern char name_login_telnet[50];
  11. extern bool telnet_act;
  12. typedef __packed enum {
  13. LOG_SYSTEM_BOOT = 0x00, // device booted
  14. LOG_SYSTEM_DEFCONFIG, // default config applied
  15. LOG_UPDATE_SOFT,
  16. LOG_TURN_ON, //
  17. LOG_PSW_CHANGE, //
  18. LOG_SETTING_SAVE, //
  19. #ifdef HARDWARE_BT6706
  20. LOG_LOGIN_TELNET, //
  21. #endif
  22. LOG_LOGIN, //
  23. LOG_TEST_UPS, //
  24. LOG_SHUTDOWN_UPS,
  25. LOG_ALARM_DIO,
  26. LOG_DO0_STATE,
  27. LOG_DO1_STATE,
  28. #ifdef HARDWARE_BT6706
  29. LOG_DO2_STATE,
  30. LOG_ALARM_VAC_OUTPUT,
  31. #endif
  32. LOG_ALARM_TEMP,
  33. LOG_ALARM_LINE,
  34. LOG_ALARM_LOW_BAT,
  35. LOG_ALARM_POWER,
  36. LOG_ALARM_UPS,
  37. LOG_ALARM_AKB,
  38. LOG_VALUE,
  39. LOG_NONE,
  40. } log_type_t;
  41. typedef __packed struct {
  42. uint32_t timestamp;
  43. log_type_t type:8;
  44. char data[50];
  45. } log_entry_t;
  46. #define LOG_ENTRY_VERSION 1
  47. extern void log_init(bool format);
  48. extern int log_test(void);
  49. extern int log_append(log_entry_t *entry);
  50. extern int log_fetch(log_entry_t *entry, uint32_t timeout);
  51. extern int log_rewind(log_entry_t *entry, uint32_t timeout);
  52. extern int log_discard(log_entry_t *entry, uint32_t timeout);
  53. void log_add(char *log_data);
  54. void log_event_data(log_type_t type, char *data);
  55. /**
  56. * @brief Возвращает true если журнал проинициализирован
  57. */
  58. bool LOG_IsInit();
  59. /**
  60. * @brief Отключает журнал для безопасной перезагрузки
  61. */
  62. bool LOG_Disable(void);
  63. /**
  64. * @brief Возвращает общее количество страниц
  65. */
  66. uint32_t LOG_GetPageCount(void);
  67. uint32_t LOG_GetTotalSTRCount(void);
  68. void LOG_GetPage(char *str, uint32_t page);
  69. void LOG_GetPage_tabs(char *str, uint32_t page);
  70. uint32_t LOG_GetData(int ptr, char *str, uint32_t size, bool start);
  71. uint32_t History_GetPageCount(void);
  72. uint32_t History_GetTotalSTRCount(void);
  73. void History_GetPage(char *str, uint32_t page);
  74. uint32_t History_GetData(int ptr, char *str, uint32_t size, bool start);
  75. void History_GetPage_tabs(char *str, uint32_t page);
  76. #endif /* LOG_H */