summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 6108316)
raw | patch | inline | side by side (parent: 6108316)
author | Sebastian Harl <sh@tokkee.org> | |
Sun, 5 Jun 2016 16:39:36 +0000 (18:39 +0200) | ||
committer | Sebastian Harl <sh@tokkee.org> | |
Sun, 25 Sep 2016 10:42:45 +0000 (12:42 +0200) |
Implement the generic interface for GETVAL and switch the GETVAL
implementation to use the generic interface.
implementation to use the generic interface.
diff --git a/src/unixsock.c b/src/unixsock.c
index 897ebfc5aef8df149a18e131d1b8b0d3b2b1587b..73037e49b2e2b7a05739139c92911e1d3a33734d 100644 (file)
--- a/src/unixsock.c
+++ b/src/unixsock.c
if (strcasecmp (fields[0], "getval") == 0)
{
- handle_getval (fhout, buffer);
+ cmd_handle_getval (fhout, buffer);
}
else if (strcasecmp (fields[0], "getthreshold") == 0)
{
diff --git a/src/utils_cmd_getval.c b/src/utils_cmd_getval.c
index cd88760a3746f01e4dee0a25f121987553e48ae8..76af189477c9205f5e2a125e228789c95b78b7e4 100644 (file)
--- a/src/utils_cmd_getval.c
+++ b/src/utils_cmd_getval.c
#include "utils_parse_option.h"
#include "utils_cmd_getval.h"
+cmd_status_t cmd_parse_getval (size_t argc, char **argv,
+ cmd_getval_t *ret_getval, cmd_error_handler_t *err)
+{
+ char *identifier_copy;
+ int status;
+
+ if (argc != 1)
+ {
+ if (argc == 0)
+ cmd_error (CMD_PARSE_ERROR, err, "Missing identifier.");
+ else
+ cmd_error (CMD_PARSE_ERROR, err,
+ "Garbage after identifier: `%s'.", argv[1]);
+ return (CMD_PARSE_ERROR);
+ }
+
+ /* parse_identifier() modifies its first argument,
+ * returning pointers into it */
+ identifier_copy = sstrdup (argv[0]);
+
+ status = parse_identifier (argv[0], &ret_getval->identifier.host,
+ &ret_getval->identifier.plugin, &ret_getval->identifier.plugin_instance,
+ &ret_getval->identifier.type, &ret_getval->identifier.type_instance);
+ if (status != 0)
+ {
+ DEBUG ("cmd_parse_getval: Cannot parse identifier `%s'.", identifier_copy);
+ cmd_error (CMD_PARSE_ERROR, err,
+ "Cannot parse identifier `%s'.", identifier_copy);
+ sfree (identifier_copy);
+ return (CMD_PARSE_ERROR);
+ }
+
+ ret_getval->raw_identifier = identifier_copy;
+ return (CMD_OK);
+} /* cmd_status_t cmd_parse_getval */
+
#define print_to_socket(fh, ...) \
do { \
if (fprintf (fh, __VA_ARGS__) < 0) { \
char errbuf[1024]; \
- WARNING ("handle_getval: failed to write to socket #%i: %s", \
+ WARNING ("cmd_handle_getval: failed to write to socket #%i: %s", \
fileno (fh), sstrerror (errno, errbuf, sizeof (errbuf))); \
return -1; \
} \
fflush(fh); \
} while (0)
-int handle_getval (FILE *fh, char *buffer)
+cmd_status_t cmd_handle_getval (FILE *fh, char *buffer)
{
- char *command;
- char *identifier;
- char *identifier_copy;
+ cmd_error_handler_t err = { cmd_error_fh, fh };
+ cmd_status_t status;
+ cmd_t cmd;
- char *hostname;
- char *plugin;
- char *plugin_instance;
- char *type;
- char *type_instance;
gauge_t *values;
size_t values_num;
const data_set_t *ds;
- int status;
if ((fh == NULL) || (buffer == NULL))
return (-1);
- DEBUG ("utils_cmd_getval: handle_getval (fh = %p, buffer = %s);",
+ DEBUG ("utils_cmd_getval: cmd_handle_getval (fh = %p, buffer = %s);",
(void *) fh, buffer);
- command = NULL;
- status = parse_string (&buffer, &command);
- if (status != 0)
- {
- print_to_socket (fh, "-1 Cannot parse command.\n");
- return (-1);
- }
- assert (command != NULL);
-
- if (strcasecmp ("GETVAL", command) != 0)
+ if ((status = cmd_parse (buffer, &cmd, &err)) != CMD_OK)
+ return (status);
+ if (cmd.type != CMD_GETVAL)
{
- print_to_socket (fh, "-1 Unexpected command: `%s'.\n", command);
- return (-1);
+ cmd_error (CMD_UNKNOWN_COMMAND, &err,
+ "Unexpected command: `%s'.", CMD_TO_STRING (cmd.type));
+ cmd_destroy (&cmd);
+ return (CMD_UNKNOWN_COMMAND);
}
- identifier = NULL;
- status = parse_string (&buffer, &identifier);
- if (status != 0)
- {
- print_to_socket (fh, "-1 Cannot parse identifier.\n");
- return (-1);
- }
- assert (identifier != NULL);
-
- if (*buffer != 0)
- {
- print_to_socket (fh, "-1 Garbage after end of command: %s\n", buffer);
- return (-1);
- }
-
- /* parse_identifier() modifies its first argument,
- * returning pointers into it */
- identifier_copy = sstrdup (identifier);
-
- status = parse_identifier (identifier_copy, &hostname,
- &plugin, &plugin_instance,
- &type, &type_instance);
- if (status != 0)
- {
- DEBUG ("handle_getval: Cannot parse identifier `%s'.", identifier);
- print_to_socket (fh, "-1 Cannot parse identifier `%s'.\n", identifier);
- sfree (identifier_copy);
- return (-1);
- }
-
- ds = plugin_get_ds (type);
+ ds = plugin_get_ds (cmd.cmd.getval.identifier.type);
if (ds == NULL)
{
- DEBUG ("handle_getval: plugin_get_ds (%s) == NULL;", type);
- print_to_socket (fh, "-1 Type `%s' is unknown.\n", type);
- sfree (identifier_copy);
+ DEBUG ("cmd_handle_getval: plugin_get_ds (%s) == NULL;",
+ cmd.cmd.getval.identifier.type);
+ cmd_error (CMD_ERROR, &err, "Type `%s' is unknown.\n",
+ cmd.cmd.getval.identifier.type);
+ cmd_destroy (&cmd);
return (-1);
}
values = NULL;
values_num = 0;
- status = uc_get_rate_by_name (identifier, &values, &values_num);
+ status = uc_get_rate_by_name (cmd.cmd.getval.raw_identifier, &values, &values_num);
if (status != 0)
{
- print_to_socket (fh, "-1 No such value\n");
- sfree (identifier_copy);
- return (-1);
+ cmd_error (CMD_ERROR, &err, "No such value.");
+ cmd_destroy (&cmd);
+ return (CMD_ERROR);
}
if (ds->ds_num != values_num)
ERROR ("ds[%s]->ds_num = %zu, "
"but uc_get_rate_by_name returned %zu values.",
ds->type, ds->ds_num, values_num);
- print_to_socket (fh, "-1 Error reading value from cache.\n");
+ cmd_error (CMD_ERROR, &err, "Error reading value from cache.");
sfree (values);
- sfree (identifier_copy);
- return (-1);
+ cmd_destroy (&cmd);
+ return (CMD_ERROR);
}
print_to_socket (fh, "%zu Value%s found\n", values_num,
}
sfree (values);
- sfree (identifier_copy);
+ cmd_destroy (&cmd);
+
+ return (CMD_OK);
+} /* cmd_status_t cmd_handle_getval */
+
+void cmd_destroy_getval (cmd_getval_t *getval)
+{
+ if (getval == NULL)
+ return;
- return (0);
-} /* int handle_getval */
+ sfree (getval->raw_identifier);
+} /* void cmd_destroy_getval */
/* vim: set sw=2 sts=2 ts=8 : */
diff --git a/src/utils_cmd_getval.h b/src/utils_cmd_getval.h
index 5e12f692b2416d99c2ab6b30ed689dc41756c4a8..0efaed64f1f7ff6b1702710275748c69ac8c8add 100644 (file)
--- a/src/utils_cmd_getval.h
+++ b/src/utils_cmd_getval.h
#include <stdio.h>
-int handle_getval (FILE *fh, char *buffer);
+#include "utils_cmds.h"
+
+cmd_status_t cmd_parse_getval (size_t argc, char **argv,
+ cmd_getval_t *ret_getval, cmd_error_handler_t *err);
+
+cmd_status_t cmd_handle_getval (FILE *fh, char *buffer);
+
+void cmd_destroy_getval (cmd_getval_t *getval);
#endif /* UTILS_CMD_GETVAL_H */
diff --git a/src/utils_cmd_putval.c b/src/utils_cmd_putval.c
index ea3a16ce71d0c6f8310d82f6c79c247a1feed396..d3d2b63001fca7e5202dd093b1ca7155c0c9dd36 100644 (file)
--- a/src/utils_cmd_putval.c
+++ b/src/utils_cmd_putval.c
return (CMD_ERROR);
}
- ret_putval->identifier = identifier_copy;
- if (ret_putval->identifier == NULL)
+ ret_putval->raw_identifier = identifier_copy;
+ if (ret_putval->raw_identifier == NULL)
{
cmd_error (CMD_ERROR, err, "malloc failed.");
cmd_destroy_putval (ret_putval);
if (putval == NULL)
return;
- sfree (putval->identifier);
+ sfree (putval->raw_identifier);
for (i = 0; i < putval->vl_num; ++i)
{
diff --git a/src/utils_cmds.c b/src/utils_cmds.c
index 7648435b86692d80abcc832e3d9f86fb8a49ea2f..9ff9d4d6b1828e2ee2fc76d9cbfeb4a76ffdc114 100644 (file)
--- a/src/utils_cmds.c
+++ b/src/utils_cmds.c
#include "utils_cmds.h"
#include "utils_cmd_flush.h"
+#include "utils_cmd_getval.h"
#include "utils_cmd_listval.h"
#include "utils_cmd_putval.h"
#include "utils_parse_option.h"
return cmd_parse_flush (argc - 1, argv + 1,
&ret_cmd->cmd.flush, err);
}
+ else if (strcasecmp ("GETVAL", command) == 0)
+ {
+ ret_cmd->type = CMD_GETVAL;
+ return cmd_parse_getval (argc - 1, argv + 1,
+ &ret_cmd->cmd.getval, err);
+ }
else if (strcasecmp ("LISTVAL", command) == 0)
{
ret_cmd->type = CMD_LISTVAL;
case CMD_FLUSH:
cmd_destroy_flush (&cmd->cmd.flush);
break;
+ case CMD_GETVAL:
+ cmd_destroy_getval (&cmd->cmd.getval);
+ break;
case CMD_LISTVAL:
cmd_destroy_listval (&cmd->cmd.listval);
break;
diff --git a/src/utils_cmds.h b/src/utils_cmds.h
index 12bf6a85870f1359a55739b9590de1dedee2d7f1..62cf8a9204cc72a028688f54ec01560b9eb575d7 100644 (file)
--- a/src/utils_cmds.h
+++ b/src/utils_cmds.h
typedef enum {
CMD_UNKNOWN = 0,
CMD_FLUSH = 1,
- CMD_LISTVAL = 2,
- CMD_PUTVAL = 3,
+ CMD_GETVAL = 2,
+ CMD_LISTVAL = 3,
+ CMD_PUTVAL = 4,
} cmd_type_t;
#define CMD_TO_STRING(type) \
((type) == CMD_FLUSH) ? "FLUSH" \
+ : ((type) == CMD_GETVAL) ? "GETVAL" \
: ((type) == CMD_LISTVAL) ? "LISTVAL" \
: ((type) == CMD_PUTVAL) ? "PUTVAL" \
: "UNKNOWN"
size_t identifiers_num;
} cmd_flush_t;
+typedef struct {
+ char *raw_identifier;
+ identifier_t identifier;
+} cmd_getval_t;
+
typedef struct {
} cmd_listval_t;
typedef struct {
/* The raw identifier as provided by the user. */
- char *identifier;
+ char *raw_identifier;
/* An array of the fully parsed identifier and all value lists, and their
* options as provided by the user. */
cmd_type_t type;
union {
cmd_flush_t flush;
+ cmd_getval_t getval;
cmd_listval_t listval;
cmd_putval_t putval;
} cmd;