⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ip.c

📁 非常不错的网管开发包
💻 C
📖 第 1 页 / 共 3 页
字号:
    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 + -