snmp_rip2.c
上传用户:wxp200602
上传日期:2007-10-30
资源大小:4028k
文件大小:6k
- /*
- * $Id: snmp_rip2.c,v 5.0 2002/04/20 07:30:06 hardaker Exp $
- */
- /*
- * 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 shotn"));
- 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 %dn",
- *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;
- }
- }