📄 ip.c
字号:
long_return = 0; switch (vp->magic){ case IPFORWARDING:#if defined(HAVE_SYS_SYSCTL_H) && defined(CTL_NET) { int name[] = { CTL_NET, PF_INET, IPPROTO_IP, IPCTL_FORWARDING }; int result; size_t result_size = sizeof (int); if (sysctl (name, sizeof (name) / sizeof (int), &result, &result_size, 0, 0) == -1) { snmp_log(LOG_ERR, "sysctl(CTL_NET,PF_NET,IPPROTO_IP,IPCTL_FORWARDING)\n"); } else { if (result) { long_return = 1; /* GATEWAY */ } else { long_return = 2; /* HOST */ } } }#else /* not (HAVE_SYS_SYSCTL_H && CTL_NET) */#ifndef sparc auto_nlist(IP_FORWARDING_SYMBOL,(char *) &i, sizeof(i)); if (i) { long_return = 1; /* GATEWAY */ } else { long_return = 2; /* HOST */ }#endif /* sparc */#endif /* not (HAVE_SYS_SYSCTL_H && CTL_NET) */ return (u_char *) &long_return; case IPDEFAULTTTL: /* * Allow for a kernel w/o TCP. */ if (!auto_nlist(TCP_TTL_SYMBOL,(char *) &long_return, sizeof(long_return)))#if NO_DUMMY_VALUES return NULL;#else long_return = 60; /* XXX */#endif return (u_char *) &long_return; case IPINRECEIVES: long_return = ipstat.ips_total; return (u_char *) &long_return; case IPINHDRERRORS: long_return = ipstat.ips_badsum + ipstat.ips_tooshort + ipstat.ips_toosmall + ipstat.ips_badhlen + ipstat.ips_badlen; return (u_char *) &long_return; case IPINADDRERRORS: long_return = ipstat.ips_cantforward; return (u_char *) &long_return; case IPFORWDATAGRAMS: long_return = ipstat.ips_forward; return (u_char *) &long_return; case IPINUNKNOWNPROTOS: long_return = ipstat.ips_noproto; return (u_char *) &long_return; case IPINDISCARDS: long_return = ipstat.ips_fragdropped; return (u_char *) &long_return; case IPINDELIVERS: long_return = ipstat.ips_delivered; return (u_char *) &long_return; case IPOUTREQUESTS: long_return = ipstat.ips_localout; return (u_char *) &long_return; case IPOUTDISCARDS: long_return = ipstat.ips_odropped; return (u_char *) &long_return; case IPOUTNOROUTES: long_return = ipstat.ips_noroute; return (u_char *) &long_return; case IPREASMTIMEOUT: long_return = ipstat.ips_fragtimeout; return (u_char *) &long_return; case IPREASMREQDS: long_return = ipstat.ips_fragments; return (u_char *) &long_return; case IPREASMOKS: long_return = ipstat.ips_reassembled; return (u_char *) &long_return; case IPREASMFAILS: long_return = ipstat.ips_fragdropped + ipstat.ips_fragtimeout; return (u_char *) &long_return; case IPFRAGOKS: long_return = ipstat.ips_fragments - (ipstat.ips_fragdropped + ipstat.ips_fragtimeout); return (u_char *) &long_return; case IPFRAGFAILS:#if NO_DUMMY_VALUES return NULL;#endif return (u_char *) &long_return; case IPFRAGCREATES: long_return = ipstat.ips_ofragments; return (u_char *) &long_return; case IPROUTEDISCARDS: long_return = ipstat.ips_noroute; return (u_char *) &long_return; default: DEBUGMSGTL(("snmpd", "unknown sub-id %d in var_ip\n", vp->magic)); }}#endif /* HAVE_SYS_TCPIPSTATS_H */#else /* linux */ u_char *var_ip(struct variable *vp, oid *name, size_t *length, int exact, size_t *var_len, WriteMethod **write_method){ static struct ip_mib ipstat; if (header_ip(vp, name, length, exact, var_len, write_method) == MATCH_FAILED ) return NULL; linux_read_ip_stat (&ipstat); switch (vp->magic){ case IPFORWARDING: /* valid values are 1 == yup, 2 == nope: * a 0 is forbidden, so patch: */ if (! ipstat.IpForwarding) ipstat.IpForwarding = 2; return (u_char *) &ipstat.IpForwarding; case IPDEFAULTTTL: return (u_char *) &ipstat.IpDefaultTTL; case IPINRECEIVES: return (u_char *) &ipstat.IpInReceives; case IPINHDRERRORS: return (u_char *) &ipstat.IpInHdrErrors; case IPINADDRERRORS: return (u_char *) &ipstat.IpInAddrErrors; case IPFORWDATAGRAMS: return (u_char *) &ipstat.IpForwDatagrams; case IPINUNKNOWNPROTOS: return (u_char *) &ipstat.IpInUnknownProtos; case IPINDISCARDS: return (u_char *) &ipstat.IpInDiscards; case IPINDELIVERS: return (u_char *) &ipstat.IpInDelivers; case IPOUTREQUESTS: return (u_char *) &ipstat.IpOutRequests; case IPOUTDISCARDS: return (u_char *) &ipstat.IpOutDiscards; case IPOUTNOROUTES: return (u_char *) &ipstat.IpOutNoRoutes; case IPREASMTIMEOUT: return (u_char *) &ipstat.IpReasmTimeout; case IPREASMREQDS: return (u_char *) &ipstat.IpReasmReqds; case IPREASMOKS: return (u_char *) &ipstat.IpReasmOKs; case IPREASMFAILS: return (u_char *) &ipstat.IpReasmFails; case IPFRAGOKS: return (u_char *) &ipstat.IpFragOKs; case IPFRAGFAILS: return (u_char *) &ipstat.IpFragFails; case IPFRAGCREATES: return (u_char *) &ipstat.IpFragCreates; default: DEBUGMSGTL(("snmpd", "unknown sub-id %d in var_ip\n", vp->magic)); } return NULL;}#endif /* linux */#ifdef freebsd2static void Address_Scan_Init (void);static int Address_Scan_Next (short *, struct in_ifaddr *);#endif/* var_ipAddrEntry(... Arguments: vp IN - pointer to variable entry that points here name IN/OUT - IN/name requested, OUT/name found length IN/OUT - length of IN/OUT oid's exact IN - TRUE if an exact match was requested var_len OUT - length of variable or 0 if function returned write_method */u_char *var_ipAddrEntry(struct variable *vp, oid *name, size_t *length, int exact, size_t *var_len, WriteMethod **write_method){ /* * object identifier is of form: * 1.3.6.1.2.1.4.20.1.?.A.B.C.D, where A.B.C.D is IP address. * IPADDR starts at offset 10. */ oid lowest[14]; oid current[14], *op; u_char *cp; int lowinterface=0; short interface; static struct in_ifaddr in_ifaddr;#if !defined(linux) && !defined(sunV3) static struct in_ifaddr lowin_ifaddr;#else static struct ifnet lowin_ifnet;#endif static struct ifnet ifnet; /* fill in object part of name for current (less sizeof instance part) */ memcpy( (char *)current,(char *)vp->name, (int)vp->namelen * sizeof(oid));#ifndef freebsd2 Interface_Scan_Init();#else Address_Scan_Init();#endif for (;;) {#ifndef freebsd2 if (Interface_Scan_Next(&interface, NULL, &ifnet, &in_ifaddr) == 0) break;#ifdef STRUCT_IFNET_HAS_IF_ADDRLIST if ( ifnet.if_addrlist == 0 ) continue; /* No address found for interface */#endif#else if (Address_Scan_Next(&interface, &in_ifaddr) == 0) break;#endif /* freebsd2 */#if defined(linux) || defined(sunV3) cp = (u_char *)&(((struct sockaddr_in *) &(ifnet.if_addr))->sin_addr.s_addr);#else cp = (u_char *)&(((struct sockaddr_in *) &(in_ifaddr.ia_addr))->sin_addr.s_addr);#endif op = current + 10; *op++ = *cp++; *op++ = *cp++; *op++ = *cp++; *op++ = *cp++; if (exact){ if (snmp_oid_compare(current, 14, name, *length) == 0){ memcpy( (char *)lowest,(char *)current, 14 * sizeof(oid)); lowinterface = interface;#if defined(linux) || defined(sunV3) lowin_ifnet = ifnet;#else lowin_ifaddr = in_ifaddr;#endif break; /* no need to search further */ } } else { if ((snmp_oid_compare(current, 14, name, *length) > 0) && (!lowinterface || (snmp_oid_compare(current, 14, lowest, 14) < 0))){ /* * if new one is greater than input and closer to input than * previous lowest, save this one as the "next" one. */ lowinterface = interface;#if defined(linux) || defined(sunV3) lowin_ifnet = ifnet;#else lowin_ifaddr = in_ifaddr;#endif memcpy( (char *)lowest,(char *)current, 14 * sizeof(oid)); } } } if (!lowinterface) return(NULL); memcpy( (char *)name,(char *)lowest, 14 * sizeof(oid)); *length = 14; *write_method = 0; *var_len = sizeof(long_return); switch(vp->magic){ case IPADADDR:#if defined(linux) || defined(sunV3) return(u_char *) &((struct sockaddr_in *) &lowin_ifnet.if_addr)->sin_addr.s_addr;#else return(u_char *) &((struct sockaddr_in *) &lowin_ifaddr.ia_addr)->sin_addr.s_addr;#endif case IPADIFINDEX: long_return = lowinterface; return(u_char *) &long_return; case IPADNETMASK:#ifndef sunV3#ifdef linux return (u_char *)&((struct sockaddr_in *)&lowin_ifnet.ia_subnetmask)->sin_addr.s_addr;#else long_return = ntohl(lowin_ifaddr.ia_subnetmask); return(u_char *) &long_return;#endif#endif case IPADBCASTADDR: #if defined(linux) || defined(sunV3) long_return = ntohl(((struct sockaddr_in *) &lowin_ifnet.ifu_broadaddr)->sin_addr.s_addr) & 1;#else long_return = ntohl(((struct sockaddr_in *) &lowin_ifaddr.ia_broadaddr)->sin_addr.s_addr) & 1;#endif return(u_char *) &long_return; case IPADREASMMAX:#if NO_DUMMY_VALUES return NULL;#endif long_return = -1; return(u_char *) &long_return; default: DEBUGMSGTL(("snmpd", "unknown sub-id %d in var_ipAddrEntry\n", vp->magic)); } return NULL;}#ifdef freebsd2static struct in_ifaddr *in_ifaddraddr;static voidAddress_Scan_Init (void){ auto_nlist(IFADDR_SYMBOL, (char *)&in_ifaddraddr, sizeof(in_ifaddraddr));}/* NB: Index is the number of the corresponding interface, not of the address */static int Address_Scan_Next(Index, Retin_ifaddr)short *Index;struct in_ifaddr *Retin_ifaddr;{ struct in_ifaddr in_ifaddr; struct ifnet ifnet,*ifnetaddr; /* NOTA: same name as another one */ short iindex=1; while (in_ifaddraddr) { /* * Get the "in_ifaddr" structure */ klookup((unsigned long)in_ifaddraddr, (char *)&in_ifaddr, sizeof in_ifaddr); in_ifaddraddr = in_ifaddr.ia_next; if (Retin_ifaddr) *Retin_ifaddr = in_ifaddr; /* * Now, more difficult, find the index of the interface to which * this address belongs */ auto_nlist(IFNET_SYMBOL, (char *)&ifnetaddr, sizeof(ifnetaddr)); while (ifnetaddr && ifnetaddr != in_ifaddr.ia_ifp) { klookup((unsigned long)ifnetaddr, (char *)&ifnet, sizeof ifnet); ifnetaddr = ifnet.if_next; iindex++; } /* XXX - might not find it? */ if (Index) *Index = iindex; return(1); /* DONE */ } return(0); /* EOF */}#endif /* freebsd2 */#else /* solaris2 */u_char *var_ip(struct variable *vp, oid *name, size_t *length, int exact, size_t *var_len, WriteMethod **write_method){ mib2_ip_t ipstat; u_char *ret = (u_char *)&long_return; /* Successful completion */ if (header_ip(vp, name, length, exact, var_len, write_method) == MATCH_FAILED ) return(NULL); /* * Get the IP statistics from the kernel... */ if (getMibstat(MIB_IP, &ipstat, sizeof(mib2_ip_t), GET_FIRST, &Get_everything, NULL) < 0) return (NULL); /* Things are ugly ... */ switch (vp->magic){ case IPFORWARDING: long_return = ipstat.ipForwarding; break; case IPDEFAULTTTL: long_return = ipstat.ipDefaultTTL; break; case IPINRECEIVES: long_return = ipstat.ipInReceives; break; case IPINHDRERRORS: long_return = ipstat.ipInHdrErrors; break; case IPINADDRERRORS: long_return = ipstat.ipInAddrErrors; break; case IPFORWDATAGRAMS: long_return = ipstat.ipForwDatagrams; break; case IPINUNKNOWNPROTOS: long_return = ipstat.ipInUnknownProtos; break; case IPINDISCARDS: long_return = ipstat.ipInDiscards; break; case IPINDELIVERS: long_return = ipstat.ipInDelivers; break; case IPOUTREQUESTS: long_return = ipstat.ipOutRequests; break; case IPOUTDISCARDS: long_return = ipstat.ipOutDiscards; break; case IPOUTNOROUTES: long_return = ipstat.ipOutNoRoutes; break; case IPREASMTIMEOUT: long_return = ipstat.ipReasmTimeout; break; case IPREASMREQDS: long_return = ipstat.ipReasmReqds; break; case IPREASMOKS: long_return = ipstat.ipReasmOKs; break; case IPREASMFAILS: long_return = ipstat.ipReasmFails; break; case IPFRAGOKS: long_return = ipstat.ipFragOKs; break; case IPFRAGFAILS: long_return = ipstat.ipFragFails; break; case IPFRAGCREATES: long_return = ipstat.ipFragCreates; break; default: ret = NULL; /* Failure */ DEBUGMSGTL(("snmpd", "unknown sub-id %d in var_ip\n", vp->magic)); } return (ret);}static intIP_Cmp(void *addr, void *ep){ if (((mib2_ipAddrEntry_t *)ep)->ipAdEntAddr == *(IpAddress *)addr) return (0); else return (1);}u_char *var_ipAddrEntry(struct variable *vp, oid *name, size_t *length, int exact, size_t *var_len, WriteMethod **write_method){ /* * object identifier is of form: * 1.3.6.1.2.1.4.20.1.?.A.B.C.D, where A.B.C.D is IP address. * IPADDR starts at offset 10. */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -