index 6a7ce4fe2538c4bfbe249a16654eafba714504fb..7973a08edfd9081806ef28dae8b6093c2a98e882 100644 (file)
--- a/src/action_list_graphs.c
+++ b/src/action_list_graphs.c
+/**
+ * collection4 - action_list_graphs.c
+ * Copyright (C) 2010 Florian octo Forster
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301 USA
+ *
+ * Authors:
+ * Florian octo Forster <ff at octo.it>
+ **/
+
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include "common.h"
#include "graph.h"
#include "graph_ident.h"
+#include "graph_instance.h"
#include "graph_list.h"
#include "utils_cgi.h"
int inst_index;
int inst_limit;
_Bool inst_more;
+ const char *search_term;
};
typedef struct callback_data_s callback_data_t;
{
if (!data->inst_more)
{
- printf (" <li class=\"instance more\">More ...</li>\n");
+ 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);
inst_describe (cfg, inst, desc, sizeof (desc));
html_escape_buffer (desc, sizeof (desc));
- printf (" <li class=\"instance\"><a href=\"%s?action=show_graph;%s\">%s</a></li>\n",
+ 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, /* {{{ */
+ __attribute__((unused)) void *user_data)
+{
+ char params[1024];
+ char title[1024];
+
+ if (graph_num_instances (cfg) < 1)
+ return (0);
+
+ memset (title, 0, sizeof (title));
+ graph_get_title (cfg, title, sizeof (title));
+ html_escape_buffer (title, sizeof (title));
+
+ memset (params, 0, sizeof (params));
+ graph_get_params (cfg, params, sizeof (params));
+ 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);
+
+ return (0);
+} /* }}} int print_graph_html */
+
struct page_data_s
{
const char *search_term;
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 };
+ /* inst_index = */ -1, /* inst_limit = */ 5, /* inst more = */ 0,
+ /* search_term = */ pg_data->search_term };
if (pg_data->search_term != NULL)
{
printf (" <ul id=\"search-output\" class=\"graph_list\">\n");
if (pg_data->search_term == NULL)
- gl_instance_get_all (print_graph_inst_html, /* user_data = */ &cb_data);
+ {
+ gl_graph_get_all (print_graph_html, /* user_data = */ &cb_data);
+ }
else
{
char *term_lc = strtolower_copy (pg_data->search_term);
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);
return (0);
} /* }}} int print_search_result */
-struct print_host_list_data_s
-{
- str_array_t *array;
- char *last_host;
-};
-typedef struct print_host_list_data_s print_host_list_data_t;
-
-static int print_host_list_callback (graph_config_t *cfg, /* {{{ */
- graph_instance_t *inst, void *user_data)
+static int print_host_list_callback (const char *host, void *user_data) /* {{{ */
{
- print_host_list_data_t *data = user_data;
- graph_ident_t *ident;
- const char *host;
-
- /* make compiler happy */
- cfg = NULL;
+ char *host_html;
- ident = inst_get_selector (inst);
- if (ident == NULL)
- return (-1);
+ /* Make compiler happy */
+ user_data = NULL;
- host = ident_get_host (ident);
if (host == NULL)
- {
- ident_destroy (ident);
- return (-1);
- }
-
- if (IS_ALL (host))
- return (0);
+ return (EINVAL);
+
+ host_html = html_escape (host);
+ if (host_html == NULL)
+ return (ENOMEM);
- if ((data->last_host != NULL)
- && (strcmp (data->last_host, host) == 0))
- {
- ident_destroy (ident);
- return (0);
- }
+ printf (" <li class=\"host\"><a href=\"%s?action=list_graphs;q=host:%s\">"
+ "%s</a></li>\n",
+ script_name (), host_html, host_html);
- free (data->last_host);
- data->last_host = strdup (host);
-
- array_append (data->array, host);
-
- ident_destroy (ident);
return (0);
} /* }}} int print_host_list_callback */
static int print_host_list (__attribute__((unused)) void *user_data) /* {{{ */
{
- print_host_list_data_t data;
- int hosts_argc;
- char **hosts_argv;
- int i;
-
- data.array = array_create ();
- data.last_host = NULL;
-
- gl_instance_get_all (print_host_list_callback, &data);
-
- free (data.last_host);
- data.last_host = NULL;
-
- array_sort (data.array);
-
- hosts_argc = array_argc (data.array);
- hosts_argv = array_argv (data.array);
-
- if (hosts_argc < 1)
- {
- array_destroy (data.array);
- return (0);
- }
-
printf ("<div><h3>List of hosts</h3>\n"
"<ul id=\"host-list\">\n");
- for (i = 0; i < hosts_argc; i++)
- {
- char *host = hosts_argv[i];
- char *host_html;
-
- if ((data.last_host != NULL) && (strcmp (data.last_host, host) == 0))
- continue;
- data.last_host = host;
-
- host_html = html_escape (host);
-
- printf (" <li><a href=\"%s?action=list_graphs&q=host:%s\">%s</a></li>\n",
- script_name (), host_html, host_html);
-
- free (host_html);
- }
+ gl_foreach_host (print_host_list_callback, /* user data = */ NULL);
printf ("</ul></div>\n");
- array_destroy (data.array);
-
return (0);
} /* }}} int print_host_list */
char title[512];
if (term != NULL)
- snprintf (title, sizeof (title), "c4: Graphs matching \"%s\"", term);
+ snprintf (title, sizeof (title), "Graphs matching \"%s\"",
+ term);
else
- strncpy (title, "c4: 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));