X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Futils_format_json.c;h=65c886b6fc28239183be31d8a10a896ec5f7800c;hb=a04ffbda508739433df0975328100e33e7986c87;hp=a91931601fe74ed63bea95c153ecc333de8c0814;hpb=0384380080a39adb252a4d5dd3a6bf5c27f8faf8;p=collectd.git diff --git a/src/utils_format_json.c b/src/utils_format_json.c index a9193160..65c886b6 100644 --- a/src/utils_format_json.c +++ b/src/utils_format_json.c @@ -23,6 +23,7 @@ #include "plugin.h" #include "common.h" +#include "utils_cache.h" #include "utils_format_json.h" static int escape_string (char *buffer, size_t buffer_size, /* {{{ */ @@ -72,10 +73,11 @@ static int escape_string (char *buffer, size_t buffer_size, /* {{{ */ } /* }}} int buffer_add_string */ static int values_to_json (char *buffer, size_t buffer_size, /* {{{ */ - const data_set_t *ds, const value_list_t *vl) + const data_set_t *ds, const value_list_t *vl, int store_rates) { size_t offset = 0; int i; + gauge_t *rates = NULL; memset (buffer, 0, buffer_size); @@ -84,11 +86,17 @@ static int values_to_json (char *buffer, size_t buffer_size, /* {{{ */ status = ssnprintf (buffer + offset, buffer_size - offset, \ __VA_ARGS__); \ if (status < 1) \ + { \ + sfree(rates); \ return (-1); \ + } \ else if (((size_t) status) >= (buffer_size - offset)) \ + { \ + sfree(rates); \ return (-ENOMEM); \ + } \ else \ - offset += ((size_t) status); \ + offset += ((size_t) status); \ } while (0) BUFFER_ADD ("["); @@ -98,7 +106,28 @@ static int values_to_json (char *buffer, size_t buffer_size, /* {{{ */ BUFFER_ADD (","); if (ds->ds[i].type == DS_TYPE_GAUGE) - BUFFER_ADD ("%g", vl->values[i].gauge); + { + if(isfinite (vl->values[i].gauge)) + BUFFER_ADD ("%g", vl->values[i].gauge); + else + BUFFER_ADD ("null"); + } + else if (store_rates) + { + if (rates == NULL) + rates = uc_get_rate (ds, vl); + if (rates == NULL) + { + WARNING ("utils_format_json: uc_get_rate failed."); + sfree(rates); + return (-1); + } + + if(isfinite (rates[i])) + BUFFER_ADD ("%g", rates[i]); + else + BUFFER_ADD ("null"); + } else if (ds->ds[i].type == DS_TYPE_COUNTER) BUFFER_ADD ("%llu", vl->values[i].counter); else if (ds->ds[i].type == DS_TYPE_DERIVE) @@ -109,6 +138,7 @@ static int values_to_json (char *buffer, size_t buffer_size, /* {{{ */ { ERROR ("format_json: Unknown data source type: %i", ds->ds[i].type); + sfree (rates); return (-1); } } /* for ds->ds_num */ @@ -117,13 +147,87 @@ static int values_to_json (char *buffer, size_t buffer_size, /* {{{ */ #undef BUFFER_ADD DEBUG ("format_json: values_to_json: buffer = %s;", buffer); - + sfree(rates); return (0); } /* }}} int values_to_json */ -static int value_list_to_json (char *buffer, size_t buffer_size, /* {{{ */ +static int dstypes_to_json (char *buffer, size_t buffer_size, /* {{{ */ + const data_set_t *ds, const value_list_t *vl) +{ + size_t offset = 0; + int i; + + memset (buffer, 0, buffer_size); + +#define BUFFER_ADD(...) do { \ + int status; \ + status = ssnprintf (buffer + offset, buffer_size - offset, \ + __VA_ARGS__); \ + if (status < 1) \ + return (-1); \ + else if (((size_t) status) >= (buffer_size - offset)) \ + return (-ENOMEM); \ + else \ + offset += ((size_t) status); \ +} while (0) + + BUFFER_ADD ("["); + for (i = 0; i < ds->ds_num; i++) + { + if (i > 0) + BUFFER_ADD (","); + + BUFFER_ADD ("\"%s\"", DS_TYPE_TO_STRING (ds->ds[i].type)); + } /* for ds->ds_num */ + BUFFER_ADD ("]"); + +#undef BUFFER_ADD + + DEBUG ("format_json: dstypes_to_json: buffer = %s;", buffer); + + return (0); +} /* }}} int dstypes_to_json */ + +static int dsnames_to_json (char *buffer, size_t buffer_size, /* {{{ */ const data_set_t *ds, const value_list_t *vl) { + size_t offset = 0; + int i; + + memset (buffer, 0, buffer_size); + +#define BUFFER_ADD(...) do { \ + int status; \ + status = ssnprintf (buffer + offset, buffer_size - offset, \ + __VA_ARGS__); \ + if (status < 1) \ + return (-1); \ + else if (((size_t) status) >= (buffer_size - offset)) \ + return (-ENOMEM); \ + else \ + offset += ((size_t) status); \ +} while (0) + + BUFFER_ADD ("["); + for (i = 0; i < ds->ds_num; i++) + { + if (i > 0) + BUFFER_ADD (","); + + BUFFER_ADD ("\"%s\"", ds->ds[i].name); + } /* for ds->ds_num */ + BUFFER_ADD ("]"); + +#undef BUFFER_ADD + + DEBUG ("format_json: dsnames_to_json: buffer = %s;", buffer); + + return (0); +} /* }}} int dsnames_to_json */ + +static int value_list_to_json (char *buffer, size_t buffer_size, /* {{{ */ + const data_set_t *ds, const value_list_t *vl, int store_rates) +{ char temp[512]; size_t offset = 0; int status; @@ -145,13 +249,23 @@ static int value_list_to_json (char *buffer, size_t buffer_size, /* {{{ */ * a square bracket in `format_json_finalize'. */ BUFFER_ADD (",{"); - status = values_to_json (temp, sizeof (temp), ds, vl); + status = values_to_json (temp, sizeof (temp), ds, vl, store_rates); if (status != 0) return (status); BUFFER_ADD ("\"values\":%s", temp); + status = dstypes_to_json (temp, sizeof (temp), ds, vl); + if (status != 0) + return (status); + BUFFER_ADD (",\"dstypes\":%s", temp); + + status = dsnames_to_json (temp, sizeof (temp), ds, vl); + if (status != 0) + return (status); + BUFFER_ADD (",\"dsnames\":%s", temp); + BUFFER_ADD (",\"time\":%lu", (unsigned long) vl->time); - BUFFER_ADD (",\"interval\":%i", vl->interval); + BUFFER_ADD (",\"interval\":%.3f", CDTIME_T_TO_DOUBLE (vl->interval)); #define BUFFER_ADD_KEYVAL(key, value) do { \ status = escape_string (temp, sizeof (temp), (value)); \ @@ -179,12 +293,12 @@ static int value_list_to_json (char *buffer, size_t buffer_size, /* {{{ */ static int format_json_value_list_nocheck (char *buffer, /* {{{ */ size_t *ret_buffer_fill, size_t *ret_buffer_free, const data_set_t *ds, const value_list_t *vl, - size_t temp_size) + int store_rates, size_t temp_size) { char temp[temp_size]; int status; - status = value_list_to_json (temp, sizeof (temp), ds, vl); + status = value_list_to_json (temp, sizeof (temp), ds, vl, store_rates); if (status != 0) return (status); temp_size = strlen (temp); @@ -250,7 +364,7 @@ int format_json_finalize (char *buffer, /* {{{ */ int format_json_value_list (char *buffer, /* {{{ */ size_t *ret_buffer_fill, size_t *ret_buffer_free, - const data_set_t *ds, const value_list_t *vl) + const data_set_t *ds, const value_list_t *vl, int store_rates) { if ((buffer == NULL) || (ret_buffer_fill == NULL) || (ret_buffer_free == NULL) @@ -262,7 +376,7 @@ int format_json_value_list (char *buffer, /* {{{ */ return (format_json_value_list_nocheck (buffer, ret_buffer_fill, ret_buffer_free, ds, vl, - (*ret_buffer_free) - 2)); + store_rates, (*ret_buffer_free) - 2)); } /* }}} int format_json_value_list */ /* vim: set sw=2 sts=2 et fdm=marker : */