summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: a4e9dee)
raw | patch | inline | side by side (parent: a4e9dee)
author | Florian Forster <ff@octo.it> | |
Wed, 23 Jun 2010 16:13:48 +0000 (18:13 +0200) | ||
committer | Florian Forster <octo@leeloo.lan.home.verplant.org> | |
Wed, 23 Jun 2010 16:13:48 +0000 (18:13 +0200) |
src/action_show_graph.c | patch | blob | history | |
src/utils_cgi.c | patch | blob | history | |
src/utils_cgi.h | patch | blob | history |
index 9b2229a4d6432f3714d07cccbdbe94c3c95c2678..0e0e89a6a8d14735ac02e0f1fbac98c5f3d71307 100644 (file)
--- a/src/action_show_graph.c
+++ b/src/action_show_graph.c
return (0);
} /* }}} int show_breadcrump */
+static int show_time_selector (__attribute__((unused)) void *user_data) /* {{{ */
+{
+ param_list_t *pl;
+
+ pl = param_create (/* query string = */ NULL);
+ param_set (pl, "begin", NULL);
+ param_set (pl, "end", NULL);
+ param_set (pl, "button", NULL);
+
+ printf ("<form action=\"%s\" method=\"get\">\n", script_name ());
+
+ param_print_hidden (pl);
+
+ printf (" <select name=\"begin\">\n"
+ " <option value=\"-3600\">Hour</option>\n"
+ " <option value=\"-86400\">Day</option>\n"
+ " <option value=\"-604800\">Week</option>\n"
+ " <option value=\"-2678400\">Month</option>\n"
+ " <option value=\"-31622400\">Year</option>\n"
+ " </select>\n"
+ " <input type=\"submit\" name=\"button\" value=\"Go\" />\n");
+
+ printf ("</form>\n");
+
+ param_destroy (pl);
+
+ return (0);
+} /* }}} int show_time_selector */
+
static int show_instance_list_cb (graph_instance_t *inst, /* {{{ */
void *user_data)
{
show_graph_data_t *data = user_data;
char title[128];
char descr[128];
- char params[1024];
+ param_list_t *pl;
+ char *params;
+ char params_html[1024];
show_breadcrump (data);
inst_describe (data->cfg, data->inst, descr, sizeof (descr));
html_escape_buffer (descr, sizeof (descr));
- memset (params, 0, sizeof (params));
- inst_get_params (data->cfg, data->inst, params, sizeof (params));
- html_escape_buffer (params, sizeof (params));
+ pl = param_create (/* query string = */ NULL);
+ param_set (pl, "action", "graph");
+ param_set (pl, "button", NULL);
+
+ params = param_as_string (pl);
+ if (params == NULL)
+ {
+ printf ("<div class=\"error\">param_as_string failed.</div>\n");
+ param_destroy (pl);
+ return (-1);
+ }
+
+ memset (params_html, 0, sizeof (params_html));
+ html_escape_copy (params_html, params, sizeof (params_html));
- printf ("<div class=\"graph-img\"><img src=\"%s?action=graph;%s\" "
+ printf ("<div class=\"graph-img\"><img src=\"%s?%s\" "
"title=\"%s / %s\" /></div>\n",
script_name (), params, title, descr);
+ param_destroy (pl);
+ free (params);
return (0);
} /* }}} int show_instance */
pg_callbacks.top_right = html_print_search_box;
pg_callbacks.middle_center = show_instance;
pg_callbacks.middle_left = show_instance_list;
+ pg_callbacks.middle_right = show_time_selector;
html_print_page (html_title, &pg_callbacks, &pg_data);
}
diff --git a/src/utils_cgi.c b/src/utils_cgi.c
index b96e15aeb53340c14918184cbfe1bdfd26d0ea5d..92bda3e960fdd8946c67d8f0af03def2589084a4 100644 (file)
--- a/src/utils_cgi.c
+++ b/src/utils_cgi.c
return (0);
} /* }}} int param_set */
-const char *param_as_string (param_list_t *pl) /* {{{ */
+char *param_as_string (param_list_t *pl) /* {{{ */
{
char buffer[4096];
char key[2048];
diff --git a/src/utils_cgi.h b/src/utils_cgi.h
index 973d3f36c5822c230d3f6c0e8c7ab930dca75f25..2cd8bc95294f46886fefa3e07ffc2a06257e3af1 100644 (file)
--- a/src/utils_cgi.h
+++ b/src/utils_cgi.h
const char *param_get (param_list_t *pl, const char *name);
int param_set (param_list_t *pl,
const char *name, const char *value);
-const char *param_as_string (param_list_t *pl);
+char *param_as_string (param_list_t *pl);
int param_print_hidden (param_list_t *pl);
char *uri_escape (const char *string);