#include "action_list_graphs.h"
#include "common.h"
#include "graph.h"
-#include "graph_ident.h"
-#include "graph_instance.h"
#include "graph_list.h"
#include "utils_cgi.h"
#include <fcgiapp.h>
#include <fcgi_stdio.h>
-#define RESULT_LIMIT 50
-
-struct callback_data_s
-{
- graph_config_t *cfg;
- int graph_index;
- int graph_limit;
- _Bool graph_more;
- int inst_index;
- int inst_limit;
- _Bool inst_more;
- const char *search_term;
-};
-typedef struct callback_data_s callback_data_t;
-
-static int print_graph_inst_html (graph_config_t *cfg, /* {{{ */
- graph_instance_t *inst,
- void *user_data)
-{
- callback_data_t *data = user_data;
- char params[1024];
- char desc[1024];
-
- if (data->cfg != cfg)
- {
- data->graph_index++;
- if (data->graph_index >= data->graph_limit)
- {
- data->graph_more = 1;
- return (1);
- }
-
- if (data->cfg != NULL)
- printf (" </ul></li>\n");
-
- memset (desc, 0, sizeof (desc));
- graph_get_title (cfg, desc, sizeof (desc));
- html_escape_buffer (desc, sizeof (desc));
-
- printf (" <li class=\"graph\">%s\n"
- " <ul class=\"instance_list\">\n", desc);
-
- data->cfg = cfg;
- data->inst_index = -1;
- data->inst_more = 0;
- }
-
- data->inst_index++;
- if (data->inst_index >= data->inst_limit)
- {
- if (!data->inst_more)
- {
- char *search_term_html = html_escape (data->search_term);
- char param_search_term[1024];
-
- memset (params, 0, sizeof (params));
- graph_get_params (cfg, params, sizeof (params));
- html_escape_buffer (params, sizeof (params));
-
- param_search_term[0] = 0;
- if (search_term_html != NULL)
- {
- snprintf (param_search_term, sizeof (param_search_term), ";q=%s",
- search_term_html);
- param_search_term[sizeof (param_search_term) - 1] = 0;
- }
-
- free (search_term_html);
-
- printf (" <li class=\"instance more\"><a href=\"%s"
- "?action=show_graph;%s%s\">More …</a></li>\n",
- script_name (), params, param_search_term);
-
- data->inst_more = 1;
- }
- return (0);
- }
-
- memset (params, 0, sizeof (params));
- inst_get_params (cfg, inst, params, sizeof (params));
- html_escape_buffer (params, sizeof (params));
-
- memset (desc, 0, sizeof (desc));
- inst_describe (cfg, inst, desc, sizeof (desc));
- html_escape_buffer (desc, sizeof (desc));
-
- printf (" <li class=\"instance\"><a href=\"%s?action=show_instance;%s\">%s</a></li>\n",
- script_name (), params, desc);
-
- return (0);
-} /* }}} int print_graph_inst_html */
-
-static int print_graph_html (graph_config_t *cfg, /* {{{ */
+static int print_one_graph (graph_config_t *cfg, /* {{{ */
__attribute__((unused)) void *user_data)
{
char params[1024];
char title[1024];
+ size_t num_instances;
- if (graph_num_instances (cfg) < 1)
+ num_instances = graph_num_instances (cfg);
+ if (num_instances < 1)
return (0);
memset (title, 0, sizeof (title));
html_escape_buffer (params, sizeof (params));
printf (" <li class=\"graph\"><a href=\"%s?action=show_graph;%s\">"
- "%s</a></li>\n",
- script_name (), params, title);
+ "%s</a> <span class=\"num_instances\">(%lu %s)</span></li>\n",
+ script_name (), params, title,
+ (unsigned long) num_instances,
+ (num_instances == 1) ? "instance" : "instances");
return (0);
-} /* }}} int print_graph_html */
-
-struct page_data_s
-{
- const char *search_term;
-};
-typedef struct page_data_s page_data_t;
+} /* }}} int print_one_graph */
-static int print_search_result (void *user_data) /* {{{ */
+static int print_all_graphs (__attribute__((unused)) void *user_data) /* {{{ */
{
- page_data_t *pg_data = user_data;
- callback_data_t cb_data = { /* cfg = */ NULL,
- /* graph_index = */ -1, /* graph_limit = */ 20, /* graph_more = */ 0,
- /* inst_index = */ -1, /* inst_limit = */ 5, /* inst more = */ 0,
- /* search_term = */ pg_data->search_term };
-
- if (pg_data->search_term != NULL)
- {
- char *search_term_html = html_escape (pg_data->search_term);
- printf (" <h2>Search results for "%s"</h2>\n",
- search_term_html);
- free (search_term_html);
- }
-
printf (" <ul id=\"search-output\" class=\"graph_list\">\n");
- if (pg_data->search_term == NULL)
- {
- gl_graph_get_all (print_graph_html, /* user_data = */ &cb_data);
- }
- else
- {
- char *term_lc = strtolower_copy (pg_data->search_term);
-
- if (strncmp ("host:", term_lc, strlen ("host:")) == 0)
- gl_search_field (GIF_HOST, term_lc + strlen ("host:"),
- print_graph_inst_html, /* user_data = */ &cb_data);
- else if (strncmp ("plugin:", term_lc, strlen ("plugin:")) == 0)
- gl_search_field (GIF_PLUGIN, term_lc + strlen ("plugin:"),
- print_graph_inst_html, /* user_data = */ &cb_data);
- else if (strncmp ("plugin_instance:", term_lc, strlen ("plugin_instance:")) == 0)
- gl_search_field (GIF_PLUGIN_INSTANCE, term_lc + strlen ("plugin_instance:"),
- print_graph_inst_html, /* user_data = */ &cb_data);
- else if (strncmp ("type:", term_lc, strlen ("type:")) == 0)
- gl_search_field (GIF_TYPE, term_lc + strlen ("type:"),
- print_graph_inst_html, /* user_data = */ &cb_data);
- else if (strncmp ("type_instance:", term_lc, strlen ("type_instance:")) == 0)
- gl_search_field (GIF_TYPE_INSTANCE, term_lc + strlen ("type_instance:"),
- print_graph_inst_html, /* user_data = */ &cb_data);
- else
- gl_search (term_lc,
- print_graph_inst_html, /* user_data = */ &cb_data);
-
- free (term_lc);
- }
-
- if (cb_data.cfg != NULL)
- printf (" </ul></li>\n");
-
- if (cb_data.graph_more)
- {
- printf (" <li class=\"graph more\">More ...</li>\n");
- }
-
+ gl_graph_get_all (print_one_graph, /* user_data = */ NULL);
printf (" </ul>\n");
return (0);
-} /* }}} int print_search_result */
-
-static int print_host_list_callback (const char *host, void *user_data) /* {{{ */
-{
- char *host_html;
-
- /* Make compiler happy */
- user_data = NULL;
-
- if (host == NULL)
- return (EINVAL);
-
- host_html = html_escape (host);
- if (host_html == NULL)
- return (ENOMEM);
-
- printf (" <li class=\"host\"><a href=\"%s?action=list_graphs;q=host:%s\">"
- "%s</a></li>\n",
- script_name (), host_html, host_html);
-
- return (0);
-} /* }}} int print_host_list_callback */
+} /* }}} int print_all_graphs */
-static int print_host_list (__attribute__((unused)) void *user_data) /* {{{ */
+int action_list_graphs (void) /* {{{ */
{
- printf ("<div><h3>List of hosts</h3>\n"
- "<ul id=\"host-list\">\n");
- gl_foreach_host (print_host_list_callback, /* user data = */ NULL);
- printf ("</ul></div>\n");
-
- return (0);
-} /* }}} int print_host_list */
+ gl_update ();
-static int list_graphs_html (const char *term) /* {{{ */
-{
- page_data_t pg_data;
page_callbacks_t pg_callbacks = PAGE_CALLBACKS_INIT;
char title[512];
- if (term != NULL)
- snprintf (title, sizeof (title), "Graphs matching \"%s\"",
- term);
- else
- strncpy (title, "List of all graphs", sizeof (title));
+ strncpy (title, "List of all graphs", sizeof (title));
title[sizeof (title) - 1] = 0;
- memset (&pg_data, 0, sizeof (pg_data));
- pg_data.search_term = term;
-
pg_callbacks.top_right = html_print_search_box;
- pg_callbacks.middle_left = print_host_list;
- pg_callbacks.middle_center = print_search_result;
+ pg_callbacks.middle_center = print_all_graphs;
- html_print_page (title, &pg_callbacks, &pg_data);
+ html_print_page (title, &pg_callbacks, /* user data = */ NULL);
return (0);
-} /* }}} int list_graphs_html */
-
-int action_list_graphs (void) /* {{{ */
-{
- char *search;
- int status;
-
- gl_update ();
-
- search = strtolower_copy (param ("q"));
- status = list_graphs_html (search);
- free (search);
-
- return (status);
} /* }}} int action_list_graphs */
/* vim: set sw=2 sts=2 et fdm=marker : */