Code

"show graph" action: Implement a time selector.
authorFlorian Forster <ff@octo.it>
Wed, 23 Jun 2010 16:13:48 +0000 (18:13 +0200)
committerFlorian Forster <octo@leeloo.lan.home.verplant.org>
Wed, 23 Jun 2010 16:13:48 +0000 (18:13 +0200)
src/action_show_graph.c
src/utils_cgi.c
src/utils_cgi.h

index 9b2229a4d6432f3714d07cccbdbe94c3c95c2678..0e0e89a6a8d14735ac02e0f1fbac98c5f3d71307 100644 (file)
@@ -85,6 +85,35 @@ static int show_breadcrump (show_graph_data_t *data) /* {{{ */
   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)
 {
@@ -145,7 +174,9 @@ static int show_instance (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);
 
@@ -157,14 +188,27 @@ static int show_instance (void *user_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 */
 
@@ -206,6 +250,7 @@ int action_show_graph (void) /* {{{ */
     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);
   }
index b96e15aeb53340c14918184cbfe1bdfd26d0ea5d..92bda3e960fdd8946c67d8f0af03def2589084a4 100644 (file)
@@ -344,7 +344,7 @@ int param_set (param_list_t *pl, const char *name, /* {{{ */
   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];
index 973d3f36c5822c230d3f6c0e8c7ab930dca75f25..2cd8bc95294f46886fefa3e07ffc2a06257e3af1 100644 (file)
@@ -40,7 +40,7 @@ void param_destroy (param_list_t *pl);
 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);