health.h 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. // SPDX-License-Identifier: GPL-3.0-or-later
  2. #ifndef NETDATA_HEALTH_H
  3. #define NETDATA_HEALTH_H 1
  4. #include "daemon/common.h"
  5. extern unsigned int default_health_enabled;
  6. #define HEALTH_ENTRY_FLAG_PROCESSED 0x00000001
  7. #define HEALTH_ENTRY_FLAG_UPDATED 0x00000002
  8. #define HEALTH_ENTRY_FLAG_EXEC_RUN 0x00000004
  9. #define HEALTH_ENTRY_FLAG_EXEC_FAILED 0x00000008
  10. #define HEALTH_ENTRY_FLAG_SILENCED 0x00000010
  11. #define HEALTH_ENTRY_RUN_ONCE 0x00000020
  12. #define HEALTH_ENTRY_FLAG_EXEC_IN_PROGRESS 0x00000040
  13. #define HEALTH_ENTRY_FLAG_IS_REPEATING 0x00000080
  14. #define HEALTH_ENTRY_FLAG_SAVED 0x10000000
  15. #define HEALTH_ENTRY_FLAG_ACLK_QUEUED 0x20000000
  16. #define HEALTH_ENTRY_FLAG_NO_CLEAR_NOTIFICATION 0x80000000
  17. #ifndef HEALTH_LISTEN_PORT
  18. #define HEALTH_LISTEN_PORT 19998
  19. #endif
  20. #ifndef HEALTH_LISTEN_BACKLOG
  21. #define HEALTH_LISTEN_BACKLOG 4096
  22. #endif
  23. #define HEALTH_SILENCERS_MAX_FILE_LEN 10000
  24. extern char *silencers_filename;
  25. extern SIMPLE_PATTERN *conf_enabled_alarms;
  26. extern DICTIONARY *health_rrdvars;
  27. void health_init(void);
  28. void health_reload(void);
  29. void health_aggregate_alarms(RRDHOST *host, BUFFER *wb, BUFFER* context, RRDCALC_STATUS status);
  30. void health_alarms2json(RRDHOST *host, BUFFER *wb, int all);
  31. void health_alarms_values2json(RRDHOST *host, BUFFER *wb, int all);
  32. void health_alarm_log2json(RRDHOST *host, BUFFER *wb, uint32_t after, char *chart);
  33. void health_api_v1_chart_variables2json(RRDSET *st, BUFFER *buf);
  34. void health_api_v1_chart_custom_variables2json(RRDSET *st, BUFFER *buf);
  35. int health_alarm_log_open(RRDHOST *host);
  36. void health_alarm_log_save(RRDHOST *host, ALARM_ENTRY *ae);
  37. void health_alarm_log_load(RRDHOST *host);
  38. ALARM_ENTRY* health_create_alarm_entry(
  39. RRDHOST *host,
  40. uint32_t alarm_id,
  41. uint32_t alarm_event_id,
  42. const uuid_t config_hash_id,
  43. time_t when,
  44. STRING *name,
  45. STRING *chart,
  46. STRING *chart_context,
  47. STRING *family,
  48. STRING *classification,
  49. STRING *component,
  50. STRING *type,
  51. STRING *exec,
  52. STRING *recipient,
  53. time_t duration,
  54. NETDATA_DOUBLE old_value,
  55. NETDATA_DOUBLE new_value,
  56. RRDCALC_STATUS old_status,
  57. RRDCALC_STATUS new_status,
  58. STRING *source,
  59. STRING *units,
  60. STRING *info,
  61. int delay,
  62. uint32_t flags);
  63. void health_alarm_log_add_entry(RRDHOST *host, ALARM_ENTRY *ae);
  64. void health_readdir(RRDHOST *host, const char *user_path, const char *stock_path, const char *subpath);
  65. char *health_user_config_dir(void);
  66. char *health_stock_config_dir(void);
  67. void health_alarm_log_free(RRDHOST *host);
  68. void health_alarm_log_free_one_nochecks_nounlink(ALARM_ENTRY *ae);
  69. void *health_cmdapi_thread(void *ptr);
  70. void health_label_log_save(RRDHOST *host);
  71. char *health_edit_command_from_source(const char *source);
  72. void sql_refresh_hashes(void);
  73. void health_add_host_labels(void);
  74. #endif //NETDATA_HEALTH_H