mirror of
https://github.com/netdata/netdata.git
synced 2025-04-22 12:32:32 +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
42 lines
1.4 KiB
C
42 lines
1.4 KiB
C
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
#include "rrdfunctions-inline.h"
|
|
|
|
struct rrd_function_inline {
|
|
rrd_function_execute_inline_cb_t cb;
|
|
};
|
|
|
|
static int rrd_function_run_inline(struct rrd_function_execute *rfe, void *data) {
|
|
|
|
// IMPORTANT: this function MUST call the result_cb even on failures
|
|
|
|
struct rrd_function_inline *fi = data;
|
|
|
|
int code;
|
|
|
|
if(rfe->is_cancelled.cb && rfe->is_cancelled.cb(rfe->is_cancelled.data))
|
|
code = HTTP_RESP_CLIENT_CLOSED_REQUEST;
|
|
else
|
|
code = fi->cb(rfe->result.wb, rfe->function);
|
|
|
|
if(code == HTTP_RESP_CLIENT_CLOSED_REQUEST || (rfe->is_cancelled.cb && rfe->is_cancelled.cb(rfe->is_cancelled.data))) {
|
|
buffer_flush(rfe->result.wb);
|
|
code = HTTP_RESP_CLIENT_CLOSED_REQUEST;
|
|
}
|
|
|
|
if(rfe->result.cb)
|
|
rfe->result.cb(rfe->result.wb, code, rfe->result.data);
|
|
|
|
return code;
|
|
}
|
|
|
|
void rrd_function_add_inline(RRDHOST *host, RRDSET *st, const char *name, int timeout, int priority, const char *help, const char *tags,
|
|
HTTP_ACCESS access, rrd_function_execute_inline_cb_t execute_cb) {
|
|
|
|
rrd_collector_started(); // this creates a collector that runs for as long as netdata runs
|
|
|
|
struct rrd_function_inline *fi = callocz(1, sizeof(struct rrd_function_inline));
|
|
fi->cb = execute_cb;
|
|
|
|
rrd_function_add(host, st, name, timeout, priority, help, tags, access, true, rrd_function_run_inline, fi);
|
|
}
|