|
|
8a419f |
842279 - Incomplete command line in UCD-SNMP-MIB::extCommand
|
|
|
8a419f |
|
|
|
8a419f |
commit e8e44b3faecdba5daedfb45d815fae65117d1b22
|
|
|
8a419f |
Author: Jan Safranek <jsafranek@users.sourceforge.net>
|
|
|
8a419f |
Date: Mon Sep 10 13:25:38 2012 +0200
|
|
|
8a419f |
|
|
|
8a419f |
CHANGES: snmpd: fixed value of UCD-SNMP-MIB::extCommand to contain full command line.
|
|
|
8a419f |
|
|
|
8a419f |
MIB description of UCD-SNMP-MIB::extCommand suggests it should contail full command line.
|
|
|
8a419f |
Also in Net-SNMP 5.3.2.2, whole command line was shown.
|
|
|
8a419f |
|
|
|
8a419f |
diff --git a/agent/mibgroup/agent/extend.c b/agent/mibgroup/agent/extend.c
|
|
|
8a419f |
index 085d762..0b2c660 100644
|
|
|
8a419f |
--- a/agent/mibgroup/agent/extend.c
|
|
|
8a419f |
+++ b/agent/mibgroup/agent/extend.c
|
|
|
8a419f |
@@ -44,6 +44,9 @@ unsigned int num_compatability_entries = 0;
|
|
|
8a419f |
unsigned int max_compatability_entries = 50;
|
|
|
8a419f |
netsnmp_old_extend *compatability_entries;
|
|
|
8a419f |
|
|
|
8a419f |
+char *cmdlinebuf;
|
|
|
8a419f |
+size_t cmdlinesize;
|
|
|
8a419f |
+
|
|
|
8a419f |
WriteMethod fixExec2Error;
|
|
|
8a419f |
FindVarMethod var_extensible_old;
|
|
|
8a419f |
oid old_extensible_variables_oid[] = { NETSNMP_UCDAVIS_MIB, NETSNMP_SHELLMIBNUM, 1 };
|
|
|
8a419f |
@@ -1354,6 +1357,23 @@ handle_nsExtendOutput2Table(netsnmp_mib_handler *handler,
|
|
|
8a419f |
*
|
|
|
8a419f |
*************************/
|
|
|
8a419f |
|
|
|
8a419f |
+char * _get_cmdline(netsnmp_extend *extend)
|
|
|
8a419f |
+{
|
|
|
8a419f |
+ size_t size;
|
|
|
8a419f |
+
|
|
|
8a419f |
+ size = strlen(extend->command) + strlen(extend->args) + 2;
|
|
|
8a419f |
+ if (size > cmdlinesize) {
|
|
|
8a419f |
+ cmdlinebuf = realloc(cmdlinebuf, size);
|
|
|
8a419f |
+ if (!cmdlinebuf) {
|
|
|
8a419f |
+ cmdlinesize = 0;
|
|
|
8a419f |
+ return NULL;
|
|
|
8a419f |
+ }
|
|
|
8a419f |
+ cmdlinesize = size;
|
|
|
8a419f |
+ }
|
|
|
8a419f |
+ sprintf(cmdlinebuf, "%s %s", extend->command, extend->args);
|
|
|
8a419f |
+ return cmdlinebuf;
|
|
|
8a419f |
+}
|
|
|
8a419f |
+
|
|
|
8a419f |
u_char *
|
|
|
8a419f |
var_extensible_old(struct variable * vp,
|
|
|
8a419f |
oid * name,
|
|
|
8a419f |
@@ -1364,6 +1384,7 @@ var_extensible_old(struct variable * vp,
|
|
|
8a419f |
netsnmp_old_extend *exten = NULL;
|
|
|
8a419f |
static long long_ret;
|
|
|
8a419f |
unsigned int idx;
|
|
|
8a419f |
+ char *cmdline;
|
|
|
8a419f |
|
|
|
8a419f |
if (header_simple_table
|
|
|
8a419f |
(vp, name, length, exact, var_len, write_method, num_compatability_entries))
|
|
|
8a419f |
@@ -1382,8 +1403,10 @@ var_extensible_old(struct variable * vp,
|
|
|
8a419f |
*var_len = strlen(exten->exec_entry->token);
|
|
|
8a419f |
return ((u_char *) (exten->exec_entry->token));
|
|
|
8a419f |
case SHELLCOMMAND:
|
|
|
8a419f |
- *var_len = strlen(exten->exec_entry->command);
|
|
|
8a419f |
- return ((u_char *) (exten->exec_entry->command));
|
|
|
8a419f |
+ cmdline = _get_cmdline(exten->exec_entry);
|
|
|
8a419f |
+ if (cmdline)
|
|
|
8a419f |
+ *var_len = strlen(cmdline);
|
|
|
8a419f |
+ return ((u_char *) cmdline);
|
|
|
8a419f |
case ERRORFLAG: /* return code from the process */
|
|
|
8a419f |
netsnmp_cache_check_and_reload( exten->exec_entry->cache );
|
|
|
8a419f |
long_ret = exten->exec_entry->result;
|
|
|
8a419f |
@@ -1406,8 +1429,10 @@ var_extensible_old(struct variable * vp,
|
|
|
8a419f |
|
|
|
8a419f |
case ERRORFIXCMD:
|
|
|
8a419f |
if (exten->efix_entry) {
|
|
|
8a419f |
- *var_len = strlen(exten->efix_entry->command);
|
|
|
8a419f |
- return ((u_char *) exten->efix_entry->command);
|
|
|
8a419f |
+ cmdline = _get_cmdline(exten->efix_entry);
|
|
|
8a419f |
+ if (cmdline)
|
|
|
8a419f |
+ *var_len = strlen(cmdline);
|
|
|
8a419f |
+ return ((u_char *) cmdline);
|
|
|
8a419f |
} else {
|
|
|
8a419f |
*var_len = 0;
|
|
|
8a419f |
return ((u_char *) &long_return); /* Just needs to be non-null! */
|