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

📄 if.c

📁 ucd-snmp源代码
💻 C
📖 第 1 页 / 共 2 页
字号:
/*****************************************************************	Copyright 1989, 1991, 1992 by Carnegie Mellon University                      All Rights ReservedPermission to use, copy, modify, and distribute this software and its documentation for any purpose and without fee is hereby granted, provided that the above copyright notice appear in all copies and thatboth that copyright notice and this permission notice appear in supporting documentation, and that the name of CMU not beused in advertising or publicity pertaining to distribution of thesoftware without specific, written prior permission.  CMU DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDINGALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALLCMU BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES ORANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THISSOFTWARE.******************************************************************//* * Copyright (c) 1983,1988 Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted * provided that this notice is preserved and that due credit is given * to the University of California at Berkeley. The name of the University * may not be used to endorse or promote products derived from this * software without specific prior written permission. This software * is provided ``as is'' without express or implied warranty. */#include <config.h>#if HAVE_STDLIB_H#include <stdlib.h>#endif#if HAVE_UNISTD_H#include <unistd.h>#endif#if HAVE_STRING_H#include <string.h>#else#include <strings.h>#endif#include <sys/types.h>#if TIME_WITH_SYS_TIME# ifdef WIN32#  include <sys/timeb.h># else#  include <sys/time.h># endif# include <time.h>#else# if HAVE_SYS_TIME_H#  include <sys/time.h># else#  include <time.h># endif#endif#if HAVE_SYS_SELECT_H#include <sys/select.h>#endif#if HAVE_NETINET_IN_H#include <netinet/in.h>#endif#include <stdio.h>#include <signal.h>#if HAVE_WINSOCK_H#include <winsock.h>#endif#if HAVE_SYS_SOCKET_H#include <sys/socket.h>#endif#if HAVE_NETDB_H#include <netdb.h>#endif#include "main.h"#include "asn1.h"#include "snmp.h"#include "snmp_api.h"#include "snmp_impl.h"#include "snmp_client.h"#include "mib.h"#include "snmp_debug.h"#include "../../snmplib/system.h"#include "netstat.h"#define	YES	1#define	NO	0static void sidewaysintpr(unsigned int);static void timerSet(int interval_seconds);static void timerPause(void);static oid oid_ifname[] =	{1, 3, 6, 1, 2, 1, 2, 2, 1, 2, 1};static oid oid_ifinucastpkts[] ={1, 3, 6, 1, 2, 1, 2, 2, 1,11, 1};static oid oid_cfg_nnets[] =	{1, 3, 6, 1, 2, 1, 2, 1, 0};static oid oid_ipadentaddr[] =	{1, 3, 6, 1, 2, 1, 4,20, 1, 1, 0, 0, 0, 0};#define IFINDEX		1#define IFNAME		2#define IFMTU		4#define IFOPERSTATUS	8#define INOCTETS	10#define INUCASTPKTS	11#define INNUCASTPKTS	12#define INERRORS	14#define OUTOCTETS	16#define OUTUCASTPKTS	17#define OUTNUCASTPKTS	18#define OUTERRORS	20#define OUTQLEN		21#define IPADDR		1#define	IPIFINDEX	2#define IPNETMASK	3/* * Print a description of the network interfaces. */voidintpr(int interval){	oid varname[MAX_OID_LEN], *instance, *ifentry;	size_t varname_len;	int ifnum, cfg_nnets;	oid curifip [4];	struct variable_list *var;	struct snmp_pdu *request, *response;	int status;	int ifindex, oldindex = 0;	struct _if_info {	    char name[128];	    char ip[128], route[128];	    int mtu;	    int ifindex;	    char s_ipkts[20], s_ierrs[20], s_opkts[20], s_oerrs[20], s_outq[20];	    unsigned long ipkts, opkts;	    int operstatus;	    u_long netmask;	    struct in_addr ifip, ifroute;	} *if_table, *cur_if;	int max_name = 4, max_ip = 7, max_route = 7, max_ipkts = 5,	    max_ierrs = 5, max_opkts = 5, max_oerrs = 5, max_outq = 5;	int i;	if (interval) {		sidewaysintpr((unsigned)interval);		return;	}	var = getvarbyname(Session, oid_cfg_nnets, sizeof(oid_cfg_nnets) / sizeof(oid));	if (var && var->val.integer) {	    cfg_nnets = *var->val.integer;	    snmp_free_var(var);	}	else {	    fprintf (stderr, "No response when requesting number of interfaces.\n");	    return;	}	DEBUGMSGTL (("netstat:if", "cfg_nnets = %d\n", cfg_nnets));	memset (curifip, 0, sizeof (curifip));	if_table = (struct _if_info *) calloc (cfg_nnets, sizeof (*if_table));	cur_if = if_table;	for (ifnum = 1; ifnum <= cfg_nnets; ifnum++) {		register char *cp;		request = snmp_pdu_create (SNMP_MSG_GETNEXT);		memmove (varname, oid_ipadentaddr, sizeof (oid_ipadentaddr));		varname_len = sizeof (oid_ipadentaddr) / sizeof (oid);		instance = varname + 9;		memmove (varname + 10, curifip, sizeof (curifip));		*instance = IPIFINDEX;		snmp_add_null_var (request, varname, varname_len);		*instance = IPADDR;		snmp_add_null_var (request, varname, varname_len);		*instance = IPNETMASK;		snmp_add_null_var (request, varname, varname_len);		status = snmp_synch_response (Session, request, &response);		if (status != STAT_SUCCESS || response->errstat != SNMP_ERR_NOERROR) {		    fprintf (stderr, "SNMP request failed after %d out of %d interfaces (IP)\n", ifnum, cfg_nnets);		    if (snmp_get_do_debugging()) {			fprintf(stderr, "status = %d, errstat = %ld, errindex = %ld\n",				status, response->errstat, response->errindex);		    }		    cfg_nnets = ifnum;		    break;		}		for (var = response->variables; var; var = var->next_variable) {		    if (snmp_get_do_debugging()) {			print_variable (var->name, var->name_length, var);		    }		    switch (var->name [9]) {		    case IPIFINDEX:			ifindex = *var->val.integer;			for (cur_if = if_table;                             cur_if < (if_table + cfg_nnets) &&                                 cur_if->ifindex != ifindex &&                                 cur_if->ifindex != 0; cur_if++) ; 			if (cur_if >= (if_table + cfg_nnets)) {                            fprintf(stderr, "Inconsistent reponse from server. Aborting.\n");                            exit (0);			}			cur_if->ifindex = ifindex;			break;		    case IPADDR:			memmove (curifip, var->name+10, sizeof (curifip));			memmove (&cur_if->ifip, var->val.string, sizeof (u_long));			break;		    case IPNETMASK:			memmove (&cur_if->netmask, var->val.string, sizeof (u_long));		    }		}		cur_if->ifroute.s_addr = cur_if->ifip.s_addr & cur_if->netmask;		if (cur_if->ifroute.s_addr)			strcpy(cur_if->route, netname (cur_if->ifroute, cur_if->netmask));		else strcpy(cur_if->route, "none");		if ((i = strlen(cur_if->route)) > max_route) max_route = i;		if (cur_if->ifip.s_addr)			strcpy(cur_if->ip, routename (cur_if->ifip));		else strcpy(cur_if->ip, "none");		if ((i = strlen(cur_if->ip)) > max_ip) max_ip = i;		snmp_free_pdu (response);		memmove (varname, oid_ifname, sizeof(oid_ifname));		varname_len = sizeof(oid_ifname) / sizeof(oid);		ifentry = varname + 9;		instance = varname + 10;		request = snmp_pdu_create (SNMP_MSG_GETNEXT);		*instance = oldindex;		*ifentry = IFINDEX;		snmp_add_null_var (request, varname, varname_len);		*ifentry = IFNAME;		snmp_add_null_var (request, varname, varname_len);		*ifentry = IFMTU;		snmp_add_null_var (request, varname, varname_len);		*ifentry = IFOPERSTATUS;		snmp_add_null_var (request, varname, varname_len);		*ifentry = INUCASTPKTS;		snmp_add_null_var (request, varname, varname_len);		*ifentry = INNUCASTPKTS;		snmp_add_null_var (request, varname, varname_len);		*ifentry = INERRORS;		snmp_add_null_var (request, varname, varname_len);		*ifentry = OUTUCASTPKTS;		snmp_add_null_var (request, varname, varname_len);		*ifentry = OUTNUCASTPKTS;		snmp_add_null_var (request, varname, varname_len);		*ifentry = OUTERRORS;		snmp_add_null_var (request, varname, varname_len);		*ifentry = OUTQLEN;		snmp_add_null_var (request, varname, varname_len);		while ((status = snmp_synch_response (Session, request, &response)) == STAT_SUCCESS) {		    if (response->errstat != SNMP_ERR_NOSUCHNAME)			break;		    if ((request = snmp_fix_pdu(response, SNMP_MSG_GETNEXT)) == NULL)			break;		    snmp_free_pdu(response);		}		if (status != STAT_SUCCESS || response->errstat != SNMP_ERR_NOERROR) {		    fprintf (stderr, "SNMP request failed after %d out of %d interfaces (IF)\n", ifnum, cfg_nnets);		    cfg_nnets = ifnum;		    break;		}		cur_if = if_table + ifnum - 1;		for (var = response->variables; var; var = var->next_variable) {		    if (snmp_get_do_debugging()) {			print_variable (var->name, var->name_length, var);		    }		    if (!var->val.integer) continue;		    if (memcmp(var->name, oid_ifname, 8*sizeof(oid))) continue;		    switch (var->name [9]) {		    case IFINDEX:			ifindex = *var->val.integer;			for (cur_if = if_table; cur_if->ifindex != ifindex && cur_if->ifindex != 0; cur_if++) ;			if (cur_if >= (if_table + cfg_nnets))			{				fprintf (stderr, "Inconsistent reponse from server. Aborting\n");				exit (0);			}			cur_if->ifindex = ifindex;			break;		    case OUTQLEN:			sprintf(cur_if->s_outq, "%lu", *var->val.integer);			i = strlen(cur_if->s_outq);			if (i > max_outq) max_outq = i;			break;		    case OUTERRORS:			sprintf(cur_if->s_oerrs, "%lu", *var->val.integer);			i = strlen(cur_if->s_oerrs);			if (i > max_oerrs) max_oerrs = i;			break;		    case INERRORS:			sprintf(cur_if->s_ierrs, "%lu", *var->val.integer);			i = strlen(cur_if->s_ierrs);			if (i > max_ierrs) max_ierrs = i;			break;		    case IFMTU:			cur_if->mtu = *var->val.integer; break;		    case INUCASTPKTS:			cur_if->ipkts += *var->val.integer;			sprintf(cur_if->s_ipkts, "%lu", cur_if->ipkts);			i = strlen(cur_if->s_ipkts);			if (i > max_ipkts) max_ipkts = i;			break;		    case INNUCASTPKTS:			cur_if->ipkts += *var->val.integer;			sprintf(cur_if->s_ipkts, "%lu", cur_if->ipkts);			i = strlen(cur_if->s_ipkts);			if (i > max_ipkts) max_ipkts = i;			break;		    case OUTUCASTPKTS:			cur_if->opkts += *var->val.integer;			sprintf(cur_if->s_opkts, "%lu", cur_if->opkts);			i = strlen(cur_if->s_opkts);			if (i > max_opkts) max_opkts = i;			break;		    case OUTNUCASTPKTS:			cur_if->opkts += *var->val.integer;			sprintf(cur_if->s_opkts, "%lu", cur_if->opkts);			i = strlen(cur_if->s_opkts);			if (i > max_opkts) max_opkts = i;			break;		    case IFNAME:			oldindex = var->name[10];			if (var->val_len >= sizeof(cur_if->name))			    var->val_len = sizeof(cur_if->name) - 1;			memmove (cur_if->name, var->val.string, var->val_len);			cur_if->name [var->val_len] = 0;			if ((i = strlen(cur_if->name)+1) > max_name) max_name = i;			break;		    case IFOPERSTATUS:			cur_if->operstatus = *var->val.integer; break;		    }		}		snmp_free_pdu (response);		if (intrface != NULL && strcmp(cur_if->name, intrface) != 0) {			cur_if->name [0] = 0;			continue;		}		if (cur_if->operstatus != MIB_IFSTATUS_UP) {			cp = strchr(cur_if->name, '\0');			*cp++ = '*';			*cp = '\0';		}	}	printf("%*.*s %5.5s %*.*s %*.*s %*s %*s %*s %*s %*s",		-max_name, max_name, "Name", "Mtu",		-max_route, max_route, "Network",		-max_ip, max_ip, "Address",		max_ipkts, "Ipkts",		max_ierrs, "Ierrs",		max_opkts, "Opkts",		max_oerrs, "Oerrs",		max_outq, "Queue");	putchar('\n');	for (ifnum = 0, cur_if = if_table; ifnum < cfg_nnets; ifnum++, cur_if++) {		if (cur_if->name [0] == 0) continue;		printf("%*.*s %5d ", -max_name, max_name, cur_if->name, cur_if->mtu);		printf("%*.*s ", -max_route, max_route, cur_if->route);		printf("%*.*s ", -max_ip, max_ip, cur_if->ip);		printf("%*s %*s %*s %*s %*s",			max_ipkts, cur_if->s_ipkts, max_ierrs, cur_if->s_ierrs,			max_opkts, cur_if->s_opkts, max_oerrs, cur_if->s_oerrs,			max_outq, cur_if->s_outq);		putchar('\n');	}	free(if_table);}/* * Print a description of the network interfaces. */voidintpro(int interval){	oid varname[MAX_OID_LEN], *instance, *ifentry;	size_t varname_len;	int ifnum, cfg_nnets;	oid curifip [4];	struct variable_list *var;	struct snmp_pdu *request, *response;	int status;	int ifindex, oldindex = 0;	struct _if_info {	    int ifindex;	    char name[128];	    char ip[128], route[128];	    char ioctets[20], ierrs[20], ooctets[20], oerrs[20], outqueue[20];	    int operstatus;	    u_long netmask;	    struct in_addr ifip, ifroute;	} *if_table, *cur_if;	int max_name = 4, max_route = 7, max_ip = 7, max_ioctets = 7, max_ooctets = 7;	int i;	if (interval) {		sidewaysintpr((unsigned)interval);		return;	}	var = getvarbyname(Session, oid_cfg_nnets, sizeof(oid_cfg_nnets) / sizeof(oid));	if (var && var->val.integer) {

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -