snmpgetnext.c
上传用户:wxp200602
上传日期:2007-10-30
资源大小:4028k
文件大小:6k
源码类别:

SNMP编程

开发平台:

Unix_Linux

  1. /*
  2.  * snmpgetnext.c - send snmp GETNEXT requests to a network entity.
  3.  *
  4.  */
  5. /***********************************************************************
  6. Copyright 1988, 1989, 1991, 1992 by Carnegie Mellon University
  7.                       All Rights Reserved
  8. Permission to use, copy, modify, and distribute this software and its
  9. documentation for any purpose and without fee is hereby granted,
  10. provided that the above copyright notice appear in all copies and that
  11. both that copyright notice and this permission notice appear in
  12. supporting documentation, and that the name of CMU not be
  13. used in advertising or publicity pertaining to distribution of the
  14. software without specific, written prior permission.
  15. CMU DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
  16. ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
  17. CMU BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
  18. ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
  19. WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
  20. ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
  21. SOFTWARE.
  22. ******************************************************************/
  23. #include <net-snmp/net-snmp-config.h>
  24. #if HAVE_STDLIB_H
  25. #include <stdlib.h>
  26. #endif
  27. #if HAVE_UNISTD_H
  28. #include <unistd.h>
  29. #endif
  30. #if HAVE_STRING_H
  31. #include <string.h>
  32. #else
  33. #include <strings.h>
  34. #endif
  35. #include <sys/types.h>
  36. #if HAVE_NETINET_IN_H
  37. #include <netinet/in.h>
  38. #endif
  39. #include <stdio.h>
  40. #include <ctype.h>
  41. #if TIME_WITH_SYS_TIME
  42. # ifdef WIN32
  43. #  include <sys/timeb.h>
  44. # else
  45. #  include <sys/time.h>
  46. # endif
  47. # include <time.h>
  48. #else
  49. # if HAVE_SYS_TIME_H
  50. #  include <sys/time.h>
  51. # else
  52. #  include <time.h>
  53. # endif
  54. #endif
  55. #if HAVE_SYS_SELECT_H
  56. #include <sys/select.h>
  57. #endif
  58. #if HAVE_WINSOCK_H
  59. #include <winsock.h>
  60. #endif
  61. #if HAVE_NETDB_H
  62. #include <netdb.h>
  63. #endif
  64. #if HAVE_ARPA_INET_H
  65. #include <arpa/inet.h>
  66. #endif
  67. #include <net-snmp/net-snmp-includes.h>
  68. #define NETSNMP_DS_APP_DONT_FIX_PDUS 0
  69. static void
  70. optProc(int argc, char *const *argv, int opt)
  71. {
  72.     switch (opt) {
  73.     case 'C':
  74.         while (*optarg) {
  75.             switch (*optarg++) {
  76.             case 'f':
  77.                 netsnmp_ds_toggle_boolean(NETSNMP_DS_APPLICATION_ID, 
  78.   NETSNMP_DS_APP_DONT_FIX_PDUS);
  79.                 break;
  80.             default:
  81.                 fprintf(stderr, "Unknown flag passed to -C: %cn",
  82.                         optarg[-1]);
  83.                 exit(1);
  84.             }
  85.         }
  86.         break;
  87.     }
  88. }
  89. void
  90. usage(void)
  91. {
  92.     fprintf(stderr, "USAGE: snmpgetnext ");
  93.     snmp_parse_args_usage(stderr);
  94.     fprintf(stderr, " OID [OID]...nn");
  95.     snmp_parse_args_descriptions(stderr);
  96.     fprintf(stderr,
  97.             "  -C APPOPTSttSet various application specific behaviours:n");
  98.     fprintf(stderr,
  99.             "ttt  f:  do not fix errors and retry the requestn");
  100. }
  101. int
  102. main(int argc, char *argv[])
  103. {
  104.     netsnmp_session session, *ss;
  105.     netsnmp_pdu    *pdu, *response;
  106.     netsnmp_variable_list *vars;
  107.     int             arg;
  108.     int             count;
  109.     int             current_name = 0;
  110.     char           *names[SNMP_MAX_CMDLINE_OIDS];
  111.     oid             name[MAX_OID_LEN];
  112.     size_t          name_length;
  113.     int             status;
  114.     int             failures = 0;
  115.     int             exitval = 0;
  116.     /*
  117.      * get the common command line arguments 
  118.      */
  119.     switch (arg = snmp_parse_args(argc, argv, &session, "C:", &optProc)) {
  120.     case -2:
  121.         exit(0);
  122.     case -1:
  123.         usage();
  124.         exit(1);
  125.     default:
  126.         break;
  127.     }
  128.     if (arg >= argc) {
  129.         fprintf(stderr, "Missing object namen");
  130.         usage();
  131.         exit(1);
  132.     }
  133.     if ((argc - arg) > SNMP_MAX_CMDLINE_OIDS) {
  134.         fprintf(stderr, "Too many object identifiers specified. ");
  135.         fprintf(stderr, "Only %d allowed in one request.n", SNMP_MAX_CMDLINE_OIDS);
  136.         usage();
  137.         exit(1);
  138.     }
  139.     /*
  140.      * get the object names 
  141.      */
  142.     for (; arg < argc; arg++)
  143.         names[current_name++] = argv[arg];
  144.     SOCK_STARTUP;
  145.     /*
  146.      * open an SNMP session 
  147.      */
  148.     ss = snmp_open(&session);
  149.     if (ss == NULL) {
  150.         /*
  151.          * diagnose snmp_open errors with the input netsnmp_session pointer 
  152.          */
  153.         snmp_sess_perror("snmpgetnext", &session);
  154.         SOCK_CLEANUP;
  155.         exit(1);
  156.     }
  157.     /*
  158.      * create PDU for GET request and add object names to request 
  159.      */
  160.     pdu = snmp_pdu_create(SNMP_MSG_GETNEXT);
  161.     for (count = 0; count < current_name; count++) {
  162.         name_length = MAX_OID_LEN;
  163.         if (snmp_parse_oid(names[count], name, &name_length) == NULL) {
  164.             snmp_perror(names[count]);
  165.             failures++;
  166.         } else
  167.             snmp_add_null_var(pdu, name, name_length);
  168.     }
  169.     if (failures) {
  170.         SOCK_CLEANUP;
  171.         exit(1);
  172.     }
  173.     /*
  174.      * do the request 
  175.      */
  176.   retry:
  177.     status = snmp_synch_response(ss, pdu, &response);
  178.     if (status == STAT_SUCCESS) {
  179.         if (response->errstat == SNMP_ERR_NOERROR) {
  180.             for (vars = response->variables; vars;
  181.                  vars = vars->next_variable)
  182.                 print_variable(vars->name, vars->name_length, vars);
  183.         } else {
  184.             fprintf(stderr, "Error in packet.nReason: %sn",
  185.                     snmp_errstring(response->errstat));
  186.             if (response->errindex != 0) {
  187.                 fprintf(stderr, "Failed object: ");
  188.                 for (count = 1, vars = response->variables;
  189.                      vars && count != response->errindex;
  190.                      vars = vars->next_variable, count++);
  191.                 if (vars)
  192.                     fprint_objid(stderr, vars->name, vars->name_length);
  193.                 fprintf(stderr, "n");
  194.                 exitval = 2;
  195.             }
  196.             /*
  197.              * retry if the errored variable was successfully removed 
  198.              */
  199.             if (!netsnmp_ds_get_boolean(NETSNMP_DS_APPLICATION_ID, 
  200. NETSNMP_DS_APP_DONT_FIX_PDUS)) {
  201.                 pdu = snmp_fix_pdu(response, SNMP_MSG_GETNEXT);
  202.                 snmp_free_pdu(response);
  203.                 response = NULL;
  204.                 if (pdu != NULL)
  205.                     goto retry;
  206.             }
  207.         }
  208.     } else if (status == STAT_TIMEOUT) {
  209.         fprintf(stderr, "Timeout: No Response from %s.n",
  210.                 session.peername);
  211.         exitval = 1;
  212.     } else {                    /* status == STAT_ERROR */
  213.         snmp_sess_perror("snmpgetnext", ss);
  214.         exitval = 1;
  215.     }
  216.     if (response)
  217.         snmp_free_pdu(response);
  218.     snmp_close(ss);
  219.     SOCK_CLEANUP;
  220.     return exitval;
  221. }