aclk.h 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. // SPDX-License-Identifier: GPL-3.0-or-later
  2. #ifndef ACLK_H
  3. #define ACLK_H
  4. #include "daemon/common.h"
  5. #ifdef ENABLE_ACLK
  6. #include "aclk_util.h"
  7. #include "aclk_rrdhost_state.h"
  8. // How many MQTT PUBACKs we need to get to consider connection
  9. // stable for the purposes of TBEB (truncated binary exponential backoff)
  10. #define ACLK_PUBACKS_CONN_STABLE 3
  11. #endif /* ENABLE_ACLK */
  12. extern int aclk_connected;
  13. extern int aclk_ctx_based;
  14. extern int aclk_disable_runtime;
  15. extern int aclk_stats_enabled;
  16. extern int aclk_kill_link;
  17. extern usec_t aclk_session_us;
  18. extern time_t aclk_session_sec;
  19. extern time_t aclk_block_until;
  20. extern int disconnect_req;
  21. #ifdef ENABLE_ACLK
  22. void *aclk_main(void *ptr);
  23. extern netdata_mutex_t aclk_shared_state_mutex;
  24. #define ACLK_SHARED_STATE_LOCK netdata_mutex_lock(&aclk_shared_state_mutex)
  25. #define ACLK_SHARED_STATE_UNLOCK netdata_mutex_unlock(&aclk_shared_state_mutex)
  26. extern struct aclk_shared_state {
  27. // To wait for `disconnect` message PUBACK
  28. // when shutting down
  29. // at the same time if > 0 we know link is
  30. // shutting down
  31. int mqtt_shutdown_msg_id;
  32. int mqtt_shutdown_msg_rcvd;
  33. } aclk_shared_state;
  34. void aclk_host_state_update(RRDHOST *host, int cmd);
  35. void aclk_send_node_instances(void);
  36. void aclk_send_bin_msg(char *msg, size_t msg_len, enum aclk_topics subtopic, const char *msgname);
  37. #endif /* ENABLE_ACLK */
  38. char *aclk_state(void);
  39. char *aclk_state_json(void);
  40. void add_aclk_host_labels(void);
  41. void aclk_queue_node_info(RRDHOST *host, bool immediate);
  42. #endif /* ACLK_H */