mirror of
https://github.com/netdata/netdata.git
synced 2025-04-22 04:31:08 +00:00

* split rrdfunctions streaming and progress * simplified internal inline functions API * split rrdfunctions inflight management * split rrd functions exporters * renames * base dyncfg structure * config pluginsd * intercept dyncfg function calls * loading and saving of dyncfg metadata and data * save metadata and payload to a single file; added code to update the plugins with jobs and saved configs * basic working unit test * added payload to functions execution * removed old dyncfg code that is not needed any more * more cleanup * cleanup sender for functions with payload * dyncfg functions are not exposed as functions * remaining work to avoid indexing the \0 terminating character in dictionary keys * added back old dyncfg plugins.d commands as noop, to allow plugins continue working * working api; working streaming; * updated plugins.d documentation * aclk and http api requests share the same header parsing logic * added source type internal * fixed crashes * added god mode for tests * fixes * fixed messages * save host machine guids to configs * cleaner manipulation of supported commands * the functions event loop for external plugins can now process dyncfg requests * unified internal and external plugins dyncfg API * Netdata serves schema requests from /etc/netdata/schema.d and /var/lib/netdata/conf.d/schema.d * cleanup and various fixes; fixed bug in previous dyncfg implementation on streaming that was sending the paylod in a way that allowed other streaming commands to be multiplexed * internals go to a separate header file * fix duplicate ACLK requests sent by aclk queue mechanism * use fstat instead of stat * working api * plugin actions renamed to create and delete; dyncfg files are removed only from user actions * prevent deadlock by using the react callback * fix for string_strndupz() * better dyncfg unittests * more tests at the unittests * properly detect dyncfg functions * hide config functions from the UI * tree response improvements * send the initial update with payload * determine tty using stdout, not stderr * changes to statuses, cleanup and the code to bring all business logic into interception * do not crash when the status is empty * functions now propagate the source of the requests to plugins * avoid warning about unused functions * in the count at items for attention, do not count the orphan entries * save source into dyncfg * make the list null terminated * fixed invalid comparison * prevent memory leak on duplicated headers; log x-forwarded-for * more unit tests * added dyncfg unittests into the default unittests * more unit tests and fixes * more unit tests and fixes * fix dictionary unittests * config functions require admin access
36 lines
1 KiB
C
36 lines
1 KiB
C
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
#ifndef NETDATA_RRDFUNCTIONS_INTERNALS_H
|
|
#define NETDATA_RRDFUNCTIONS_INTERNALS_H
|
|
|
|
#include "rrd.h"
|
|
|
|
#include "rrdcollector-internals.h"
|
|
|
|
typedef enum __attribute__((packed)) {
|
|
RRD_FUNCTION_LOCAL = (1 << 0),
|
|
RRD_FUNCTION_GLOBAL = (1 << 1),
|
|
RRD_FUNCTION_DYNCFG = (1 << 2),
|
|
|
|
// this is 8-bit
|
|
} RRD_FUNCTION_OPTIONS;
|
|
|
|
struct rrd_host_function {
|
|
bool sync; // when true, the function is called synchronously
|
|
RRD_FUNCTION_OPTIONS options; // RRD_FUNCTION_OPTIONS
|
|
HTTP_ACCESS access;
|
|
STRING *help;
|
|
STRING *tags;
|
|
int timeout; // the default timeout of the function
|
|
int priority;
|
|
|
|
rrd_function_execute_cb_t execute_cb;
|
|
void *execute_cb_data;
|
|
|
|
struct rrd_collector *collector;
|
|
};
|
|
|
|
size_t rrd_functions_sanitize(char *dst, const char *src, size_t dst_len);
|
|
int rrd_functions_find_by_name(RRDHOST *host, BUFFER *wb, const char *name, size_t key_length, const DICTIONARY_ITEM **item);
|
|
|
|
#endif //NETDATA_RRDFUNCTIONS_INTERNALS_H
|