X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=action_list_graphs.c;h=0663b98dbbcfd6f1aad2bd06fc8cf423a0e31e77;hb=477b8a38dc1b3d0ae5e726f765722c962b2fcb46;hp=8c78ac10428e508ccd9c494923b0acbb72bc1bb8;hpb=5cc627425e6502b8a025cee810c14136e69071cc;p=collection4.git diff --git a/action_list_graphs.c b/action_list_graphs.c index 8c78ac1..0663b98 100644 --- a/action_list_graphs.c +++ b/action_list_graphs.c @@ -3,55 +3,118 @@ #include #include +#include "action_list_graphs.h" +#include "graph_list.h" +#include "utils_params.h" + #include #include -#include "graph_list.h" - -static int print_graph (const graph_list_t *gl, void *user_data) /* {{{ */ +static int print_graph_inst_json (__attribute__((unused)) graph_config_t *cfg, /* {{{ */ + graph_instance_t *inst, + void *user_data) { _Bool *first; + graph_ident_t *ident; + char *json; - if ((gl == NULL) || (user_data == NULL)) - return (EINVAL); - - first = (_Bool *) user_data; - if (!*first) - printf (",\n"); - *first = 0; + first = user_data; - printf (" {"); + ident = gl_instance_get_selector (inst); + if (ident == NULL) + return (-1); - printf ("\"host\":\"%s\"", gl->host); - - printf (",\"plugin\":\"%s\"", gl->plugin); - if (gl->plugin_instance != NULL) - printf (",\"plugin_instance\":\"%s\"", gl->plugin_instance); - else - printf (",\"plugin_instance\":null"); + json = ident_to_json (ident); + if (json == NULL) + { + ident_destroy (ident); + return (ENOMEM); + } - printf (",\"type\":\"%s\"", gl->type); - if (gl->type_instance != NULL) - printf (",\"type_instance\":\"%s\"", gl->type_instance); + if (*first) + printf ("%s", json); else - printf (",\"type_instance\":null"); + printf (",\n%s", json); - printf ("}"); + *first = 0; + ident_destroy (ident); return (0); -} /* }}} int print_graph */ +} /* }}} int print_graph_inst_json */ -int action_list_graphs (void) /* {{{ */ +static int print_graph_json (graph_config_t *cfg, /* {{{ */ + void *user_data) { - _Bool first = 1; + return (gl_graph_instance_get_all (cfg, print_graph_inst_json, user_data)); +} /* }}} int print_graph_json */ - printf ("Content-Type: text/plain\n\n"); +static int list_graphs_json (void) /* {{{ */ +{ + _Bool first = 1; - gl_update (); + printf ("Content-Type: application/json\n\n"); printf ("[\n"); - gl_foreach (print_graph, /* user_data = */ &first); + gl_graph_get_all (print_graph_json, /* user_data = */ &first); printf ("\n]"); + + return (0); +} /* }}} int list_graphs_json */ + +static int print_graph_inst_html (graph_config_t *cfg, /* {{{ */ + graph_instance_t *inst, + __attribute__((unused)) void *user_data) +{ + char buffer[1024]; + + memset (buffer, 0, sizeof (buffer)); + gl_instance_get_params (cfg, inst, buffer, sizeof (buffer)); + + printf ("
  • %s
  • \n", buffer, buffer); + + return (0); +} /* }}} int print_graph_inst_html */ + +static int print_graph_html (graph_config_t *cfg, /* {{{ */ + __attribute__((unused)) void *user_data) +{ + char buffer[1024]; + + memset (buffer, 0, sizeof (buffer)); + gl_graph_get_title (cfg, buffer, sizeof (buffer)); + + printf ("
  • %s\n
      \n", buffer); + gl_graph_instance_get_all (cfg, print_graph_inst_html, /* user_data = */ NULL); + printf ("
    \n"); + + return (0); +} /* }}} int print_graph_html */ + +static int list_graphs_html (void) /* {{{ */ +{ + printf ("Content-Type: text/html\n\n"); + + printf ("
      \n"); + gl_graph_get_all (print_graph_html, /* user_data = */ NULL); + printf ("
    \n"); + + return (0); +} /* }}} int list_graphs_html */ + +int action_list_graphs (void) /* {{{ */ +{ + const char *format; + + gl_update (); + + format = param ("format"); + if (format == NULL) + format = "html"; + + if (strcmp ("json", format) == 0) + return (list_graphs_json ()); + else + return (list_graphs_html ()); } /* }}} int action_list_graphs */ /* vim: set sw=2 sts=2 et fdm=marker : */