facets.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. // SPDX-License-Identifier: GPL-3.0-or-later
  2. #ifndef FACETS_H
  3. #define FACETS_H 1
  4. #include "../libnetdata.h"
  5. #define FACET_VALUE_UNSET "-"
  6. typedef enum __attribute__((packed)) {
  7. FACETS_ANCHOR_DIRECTION_FORWARD,
  8. FACETS_ANCHOR_DIRECTION_BACKWARD,
  9. } FACETS_ANCHOR_DIRECTION;
  10. typedef enum __attribute__((packed)) {
  11. FACETS_TRANSFORM_VALUE,
  12. FACETS_TRANSFORM_HISTOGRAM,
  13. FACETS_TRANSFORM_FACET,
  14. FACETS_TRANSFORM_DATA,
  15. FACETS_TRANSFORM_FACET_SORT,
  16. } FACETS_TRANSFORMATION_SCOPE;
  17. typedef enum __attribute__((packed)) {
  18. FACET_KEY_OPTION_FACET = (1 << 0), // filterable values
  19. FACET_KEY_OPTION_NO_FACET = (1 << 1), // non-filterable value
  20. FACET_KEY_OPTION_NEVER_FACET = (1 << 2), // never enable this field as facet
  21. FACET_KEY_OPTION_STICKY = (1 << 3), // should be sticky in the table
  22. FACET_KEY_OPTION_VISIBLE = (1 << 4), // should be in the default table
  23. FACET_KEY_OPTION_FTS = (1 << 5), // the key is filterable by full text search (FTS)
  24. FACET_KEY_OPTION_MAIN_TEXT = (1 << 6), // full width and wrap
  25. FACET_KEY_OPTION_RICH_TEXT = (1 << 7),
  26. FACET_KEY_OPTION_REORDER = (1 << 8), // give the key a new order id on first encounter
  27. FACET_KEY_OPTION_TRANSFORM_VIEW = (1 << 9), // when registering the transformation, do it only at the view, not on all data
  28. } FACET_KEY_OPTIONS;
  29. typedef enum __attribute__((packed)) {
  30. FACET_ROW_SEVERITY_DEBUG, // lowest - not important
  31. FACET_ROW_SEVERITY_NORMAL, // the default
  32. FACET_ROW_SEVERITY_NOTICE, // bold
  33. FACET_ROW_SEVERITY_WARNING, // yellow + bold
  34. FACET_ROW_SEVERITY_CRITICAL, // red + bold
  35. } FACET_ROW_SEVERITY;
  36. typedef struct facet_row_key_value {
  37. const char *tmp;
  38. uint32_t tmp_len;
  39. bool empty;
  40. BUFFER *wb;
  41. } FACET_ROW_KEY_VALUE;
  42. typedef struct facet_row {
  43. usec_t usec;
  44. DICTIONARY *dict;
  45. FACET_ROW_SEVERITY severity;
  46. struct facet_row *prev, *next;
  47. } FACET_ROW;
  48. typedef struct facets FACETS;
  49. typedef struct facet_key FACET_KEY;
  50. typedef void (*facets_key_transformer_t)(FACETS *facets __maybe_unused, BUFFER *wb, FACETS_TRANSFORMATION_SCOPE scope, void *data);
  51. typedef void (*facet_dynamic_row_t)(FACETS *facets, BUFFER *json_array, FACET_ROW_KEY_VALUE *rkv, FACET_ROW *row, void *data);
  52. typedef FACET_ROW_SEVERITY (*facet_row_severity_t)(FACETS *facets, FACET_ROW *row, void *data);
  53. FACET_KEY *facets_register_dynamic_key_name(FACETS *facets, const char *key, FACET_KEY_OPTIONS options, facet_dynamic_row_t cb, void *data);
  54. FACET_KEY *facets_register_key_name_transformation(FACETS *facets, const char *key, FACET_KEY_OPTIONS options, facets_key_transformer_t cb, void *data);
  55. void facets_register_row_severity(FACETS *facets, facet_row_severity_t cb, void *data);
  56. typedef enum __attribute__((packed)) {
  57. FACETS_OPTION_ALL_FACETS_VISIBLE = (1 << 0), // all facets should be visible by default in the table
  58. FACETS_OPTION_ALL_KEYS_FTS = (1 << 1), // all keys are searchable by full text search
  59. FACETS_OPTION_DONT_SEND_FACETS = (1 << 2), // "facets" object will not be included in the report
  60. FACETS_OPTION_DONT_SEND_HISTOGRAM = (1 << 3), // "histogram" object will not be included in the report
  61. FACETS_OPTION_DATA_ONLY = (1 << 4),
  62. FACETS_OPTION_DONT_SEND_EMPTY_VALUE_FACETS = (1 << 5), // empty facet values will not be included in the report
  63. FACETS_OPTION_SORT_FACETS_ALPHABETICALLY = (1 << 6),
  64. FACETS_OPTION_SHOW_DELTAS = (1 << 7),
  65. } FACETS_OPTIONS;
  66. FACETS *facets_create(uint32_t items_to_return, FACETS_OPTIONS options, const char *visible_keys, const char *facet_keys, const char *non_facet_keys);
  67. void facets_destroy(FACETS *facets);
  68. void facets_accepted_param(FACETS *facets, const char *param);
  69. void facets_rows_begin(FACETS *facets);
  70. bool facets_row_finished(FACETS *facets, usec_t usec);
  71. FACET_KEY *facets_register_key_name(FACETS *facets, const char *key, FACET_KEY_OPTIONS options);
  72. void facets_set_query(FACETS *facets, const char *query);
  73. void facets_set_items(FACETS *facets, uint32_t items);
  74. void facets_set_anchor(FACETS *facets, usec_t start_ut, usec_t stop_ut, FACETS_ANCHOR_DIRECTION direction);
  75. void facets_enable_slice_mode(FACETS *facets);
  76. FACET_KEY *facets_register_facet_id(FACETS *facets, const char *key_id, FACET_KEY_OPTIONS options);
  77. void facets_register_facet_id_filter(FACETS *facets, const char *key_id, char *value_id, FACET_KEY_OPTIONS options);
  78. void facets_set_timeframe_and_histogram_by_id(FACETS *facets, const char *key_id, usec_t after_ut, usec_t before_ut);
  79. void facets_set_timeframe_and_histogram_by_name(FACETS *facets, const char *key_name, usec_t after_ut, usec_t before_ut);
  80. void facets_add_key_value(FACETS *facets, const char *key, const char *value);
  81. void facets_add_key_value_length(FACETS *facets, const char *key, size_t key_len, const char *value, size_t value_len);
  82. void facets_report(FACETS *facets, BUFFER *wb, DICTIONARY *used_hashes_registry);
  83. void facets_accepted_parameters_to_json_array(FACETS *facets, BUFFER *wb, bool with_keys);
  84. void facets_set_current_row_severity(FACETS *facets, FACET_ROW_SEVERITY severity);
  85. void facets_set_additional_options(FACETS *facets, FACETS_OPTIONS options);
  86. bool facets_key_name_is_filter(FACETS *facets, const char *key);
  87. bool facets_key_name_is_facet(FACETS *facets, const char *key);
  88. bool facets_key_name_value_length_is_selected(FACETS *facets, const char *key, size_t key_length, const char *value, size_t value_length);
  89. void facets_add_possible_value_name_to_key(FACETS *facets, const char *key, size_t key_length, const char *value, size_t value_length);
  90. void facets_sort_and_reorder_keys(FACETS *facets);
  91. usec_t facets_row_oldest_ut(FACETS *facets);
  92. usec_t facets_row_newest_ut(FACETS *facets);
  93. uint32_t facets_rows(FACETS *facets);
  94. void facets_table_config(BUFFER *wb);
  95. #endif