summaryrefslogtreecommitdiff
path: root/cleopatre/application/spidnetsnmp/agent/mibgroup/smux/snmp_rip2.c
diff options
context:
space:
mode:
Diffstat (limited to 'cleopatre/application/spidnetsnmp/agent/mibgroup/smux/snmp_rip2.c')
-rw-r--r--cleopatre/application/spidnetsnmp/agent/mibgroup/smux/snmp_rip2.c184
1 files changed, 0 insertions, 184 deletions
diff --git a/cleopatre/application/spidnetsnmp/agent/mibgroup/smux/snmp_rip2.c b/cleopatre/application/spidnetsnmp/agent/mibgroup/smux/snmp_rip2.c
deleted file mode 100644
index 7e14d13267..0000000000
--- a/cleopatre/application/spidnetsnmp/agent/mibgroup/smux/snmp_rip2.c
+++ /dev/null
@@ -1,184 +0,0 @@
-/*
- * $Id: snmp_rip2.c 6918 2002-04-20 07:30:29Z hardaker $
- */
-
-/*
- * Smux module authored by Rohit Dube.
- */
-
-#include <net-snmp/net-snmp-config.h>
-
-#include <stdio.h>
-#if HAVE_STDLIB_H
-#include <stdlib.h>
-#endif
-#if HAVE_STRING_H
-#include <string.h>
-#else
-#include <strings.h>
-#endif
-#if HAVE_UNISTD_H
-#include <unistd.h>
-#endif
-#if HAVE_ERR_H
-#include <err.h>
-#endif
-#if TIME_WITH_SYS_TIME
-# include <sys/time.h>
-# include <time.h>
-#else
-# if HAVE_SYS_TIME_H
-# include <sys/time.h>
-# else
-# include <time.h>
-# endif
-#endif
-#include <errno.h>
-#include <netdb.h>
-
-#include <sys/stat.h>
-#include <sys/socket.h>
-#if HAVE_SYS_FILIO_H
-#include <sys/filio.h>
-#endif
-
-#if HAVE_NETINET_IN_H
-#include <netinet/in.h>
-#endif
-
-#include <net-snmp/net-snmp-includes.h>
-#include <net-snmp/agent/net-snmp-agent-includes.h>
-#include "smux.h"
-#include "snmp_rip2.h"
-
-static oid max_rip_mib[] =
- { 1, 3, 6, 1, 2, 1, 23, 3, 1, 9, 255, 255, 255, 255 };
-static oid min_rip_mib[] = { 1, 3, 6, 1, 2, 1, 23, 1, 1, 0 };
-extern u_char smux_type;
-
-struct variable13 rip2_variables[] = {
- {RIP2GLOBALROUTECHANGES, ASN_COUNTER, RONLY, var_rip2, 2, {1, 1}},
- {RIP2GLOBALQUERIES, ASN_COUNTER, RONLY, var_rip2, 2, {1, 2}},
- {RIP2IFSTATADDRESS, ASN_IPADDRESS, RONLY, var_rip2, 3, {2, 1, 1}},
- {RIP2IFSTATRCVBADPKTS, ASN_COUNTER, RONLY, var_rip2, 3, {2, 1, 2}},
- {RIP2IFSTATRCVBADROUTES, ASN_COUNTER, RONLY, var_rip2, 3, {2, 1, 3}},
- {RIP2IFSTATSENTUPDATES, ASN_COUNTER, RONLY, var_rip2, 3, {2, 1, 4}},
- {RIP2IFSTATSTATUS, ASN_INTEGER, RWRITE, var_rip2, 3, {2, 1, 5}},
- {RIP2IFCONFADDRESS, ASN_IPADDRESS, RONLY, var_rip2, 3, {3, 1, 1}},
- {RIP2IFCONFDOMAIN, ASN_OCTET_STR, RWRITE, var_rip2, 3, {3, 1, 2}},
- {RIP2IFCONFAUTHTYPE, ASN_INTEGER, RWRITE, var_rip2, 3, {3, 1, 3}},
- {RIP2IFCONFAUTHKEY, ASN_OCTET_STR, RWRITE, var_rip2, 3, {3, 1, 4}},
- {RIP2IFCONFSEND, ASN_INTEGER, RWRITE, var_rip2, 3, {3, 1, 5}},
- {RIP2IFCONFRECEIVE, ASN_INTEGER, RWRITE, var_rip2, 3, {3, 1, 6}},
- {RIP2IFCONFDEFAULTMETRIC, ASN_INTEGER, RWRITE, var_rip2, 3, {3, 1, 7}},
- {RIP2IFCONFSTATUS, ASN_INTEGER, RWRITE, var_rip2, 3, {3, 1, 8}},
- {RIP2IFCONFSRCADDRESS, ASN_IPADDRESS, RWRITE, var_rip2, 3, {3, 1, 9}},
- {RIP2PEERADDRESS, ASN_IPADDRESS, RONLY, var_rip2, 3, {4, 1, 1}},
- {RIP2PEERDOMAIN, ASN_OCTET_STR, RONLY, var_rip2, 3, {4, 1, 2}},
- {RIP2PEERLASTUPDATE, ASN_TIMETICKS, RONLY, var_rip2, 3, {4, 1, 3}},
- {RIP2PEERVERSION, ASN_INTEGER, RONLY, var_rip2, 3, {4, 1, 4}},
- {RIP2PEERRCVBADPKTS, ASN_COUNTER, RONLY, var_rip2, 3, {4, 1, 5}},
- {RIP2PEERRCVBADROUTES, ASN_COUNTER, RONLY, var_rip2, 3, {4, 1, 6}}
-};
-
-oid rip2_variables_oid[] = { MIB, 23 };
-
-void
-init_snmp_rip2(void)
-{
- REGISTER_MIB("smux/snmp_rip2", rip2_variables, variable13,
- rip2_variables_oid);
-}
-
-u_char *
-var_rip2(struct variable *vp,
- oid * name,
- int *length, int exact, int *var_len, WriteMethod ** write_method)
-{
- u_char *var;
- int result;
-
- DEBUGMSGTL(("smux/snmp_rip2",
- "[var_rip2] var len %d, oid requested Len %d-", *var_len,
- *length));
- DEBUGMSGOID(("smux/snmp_rip2", name, *length));
- DEBUGMSG(("smux/snmp_rip2", "\n"));
-
- /*
- * Pass on the request to Gated.
- * If the request sent out was a get next, check to see if
- * it lies in the rip2 range. If it doesn't, return NULL.
- * In either case, make sure that errors are checked on the
- * returned packets.
- */
-
- /*
- * No writes for now
- */
- *write_method = NULL;
-
- /*
- * Donot allow access to the peer stuff as it crashes gated.
- * However A GetNext on the last 23.3.1.9 variable will force gated into
- * the peer stuff and cause it to crash.
- * The only way to fix this is to either solve the Gated problem, or
- * remove the peer variables from Gated itself and cause it to return
- * NULL at the crossing. Currently doing the later.
- */
-
- /*
- * Reject GET and GETNEXT for anything above rip2ifconf range
- */
- result = snmp_oid_compare(name, *length, max_rip_mib,
- sizeof(max_rip_mib) / sizeof(u_int));
-
- if (result >= 0) {
- DEBUGMSGTL(("smux/snmp_rip2", "Over shot\n"));
- return NULL;
- }
-
- /*
- * for GETs we need to be in the rip2 range so reject anything below
- */
- result = snmp_oid_compare(name, *length, min_rip_mib,
- sizeof(min_rip_mib) / sizeof(u_int));
- if (exact && (result < 0)) {
- DEBUGMSGTL(("smux/snmp_rip2",
- "Exact but doesn't match length %d, size %d\n",
- *length, sizeof(min_rip_mib)));
- return NULL;
- }
-
- /*
- * On return, 'var' points to the value returned which is of length
- * '*var_len'. 'name' points to the new (same as the one passed in for
- * GETs) oid which has 'length' suboids.
- * 'smux_type' contains the type of the variable.
- */
- var = smux_snmp_process(exact, name, length, var_len);
-
- DEBUGMSGTL(("smux/snmp_rip2",
- "[var_rip2] var len %d, oid obtained Len %d-", *var_len,
- *length));
- DEBUGMSGOID(("smux/snmp_rip2", name, *length));
- DEBUGMSG(("smux/snmp_rip2", "\n"));
-
- vp->type = smux_type;
-
- /*
- * XXX Need a mechanism to return errors in gated's responses
- */
-
- if (var == NULL)
- return NULL;
-
- /*
- * Any resullt returned should be within the rip2 tree.
- * rip_mib - static u_int rip_mib[] = {1, 3, 6, 1, 2, 1, 23};
- */
- if (memcmp(rip_mib, name, sizeof(rip_mib)) != 0) {
- return NULL;
- } else {
- return var;
- }
-}