int wpdu::load_vbs(snmp_pdu *raw_pdu, const Pdu& pdu) { int status = 0; // load up the payload // for all Vbs in list, add them to the pdu int vb_count; Vb tempvb; Oid tempoid; SmiLPOID smioid; SmiVALUE smival; vb_count = pdu.get_vb_count(); for (int z = 0; z < vb_count; z++) { pdu.get_vb( tempvb, z); tempvb.get_oid( tempoid); smioid = tempoid.oidval(); // what are we trying to convert here (vb oid part or value part) status = convert_vb_to_smival( tempvb, &smival ); if ( status != SNMP_CLASS_SUCCESS) return status; // add the var to the raw pdu cmu_snmp::add_var(raw_pdu, smioid->ptr, (int) smioid->len, &smival); free_smival_descriptor( &smival); } return status; }
walkapp::walkapp(int argc, char *argv[]): valid_(0) { Oid req, def_oid("1.3.6.1.2.1.1.1.0"); // default begin walk with MIBII if ( argc < 2) return; address_ = argv[argc - 1]; if ( !address_.valid()) { cout << "ERROR: Invalid IPv4 address or DNS hostname: " \ << argv[argc] << "\n"; return; } ACE_Argv_Type_Converter to_tchar (argc, argv); ACE_Get_Opt get_opt (argc, to_tchar.get_TCHAR_argv (), ACE_TEXT ("o:c:r:t:")); for (int c; (c = get_opt ()) != -1; ) switch (c) { case 'o': req = ACE_TEXT_ALWAYS_CHAR (get_opt.opt_arg()); if (req.valid() == 0) cout << "ERROR: oid value: " << ACE_TEXT_ALWAYS_CHAR (get_opt.opt_arg()) << "is not valid. using default.\n"; break; case 'c': community_ = ACE_TEXT_ALWAYS_CHAR (get_opt.opt_arg()); target_.set_read_community(community_); break; case 'r': target_.set_retry(ACE_OS::atoi (get_opt.opt_arg())); break; case 't': target_.set_timeout(ACE_OS::atoi (get_opt.opt_arg())); break; default: break; } Vb vb; // construct a Vb object if (req.valid()) vb.set_oid( req); // set the Oid portion of the Vb else { vb.set_oid( def_oid); // set the Oid portion of the Vb } pdu_ += vb; vb.get_oid(oid_); // store for later use valid_ = 1; }
MibIter::MibIter(Snmp* snmp, Pdu& pdu, UdpTarget *target): snmp_(snmp), target_(target), pdu_(pdu), first_(0), valid_(0) { // verify we have a valid oid to begin iterating with Oid oid; Vb vb; pdu.get_vb(vb, 0); vb.get_oid(oid); if (oid.valid()) valid_ = 1; }
getapp::getapp(int argc, char *argv[]): valid_(0) { Oid req, def_oid("1.3.6.1.2.1.1.1.0"); // default is sysDescr if ( argc < 2) return; address_ = argv[argc - 1]; if ( !address_.valid()) { cout << "ERROR: Invalid IPv4 address or DNS hostname: " \ << argv[argc] << "\n"; return; } ACE_Get_Opt get_opt (argc, argv, "o:c:r:t:p:"); for (int c; (c = get_opt ()) != -1; ) switch (c) { case 'o': req = get_opt.optarg; if (req.valid() == 0) cout << "ERROR: oid value: " <<get_opt.optarg \ << "is not valid. using default.\n"; break; case 'c': community_ = get_opt.optarg; target_.set_read_community(community_); break; case 'r': target_.set_retry(ACE_OS::atoi (get_opt.optarg)); break; case 't': target_.set_timeout(ACE_OS::atoi (get_opt.optarg)); break; default: break; } Vb vb; // construct a Vb object if (req.valid()) vb.set_oid( req); // set the Oid portion of the Vb else { vb.set_oid( def_oid); // set the Oid portion of the Vb } pdu_ += vb; vb.get_oid(oid_); // store for later use valid_ = 1; }
// this routine makes up the brains of the agent // it knows only the MIB II system group set of variables for a get operation int agent_impl::get_response(Vb& vb) { // these objects represent the MIB II system group per RFC 1213 static Oid sysDescr("1.3.6.1.2.1.1.1.0"), sysObjectID("1.3.6.1.2.1.1.2.0"), sysUpTime("1.3.6.1.2.1.1.3.0"), sysContact("1.3.6.1.2.1.1.4.0"), sysName("1.3.6.1.2.1.1.5.0"), sysLocation("1.3.6.1.2.1.1.6.0"), sysServices("1.3.6.1.2.1.1.7.0"); Oid oid; vb.get_oid(oid); if (oid == sysDescr) { OctetStr desc("ASNMP Prototype Agent 1.0"); vb.set_value(desc); } else if (oid == sysObjectID) { // the IANA gives assigns Enterprise Numbers // see ftp://ftp.isi.edu/in-notes/iana/assignments/enterprise-numbers // for the official list of enterprise numbers. Then under this tree // assign a unique subtree to identify this agent Oid id("1.3.6.1.4.1.2533.9.1"); vb.set_value(id); } else if (oid == sysUpTime) { ACE_Time_Value tv; agent_clock_.elapsed_time (tv); TimeTicks tt(tv.msec()); vb.set_value(tt); } else if (oid == sysContact) { OctetStr contact("*****@*****.**"); vb.set_value(contact); } else if (oid == sysName) { OctetStr fqdn("foo.org"); // extract this from the gethostbyname() TODO vb.set_value(fqdn); } else if (oid == sysLocation) { OctetStr loc(""); vb.set_value(loc); } else if (oid == sysServices) { SnmpInt32 svcs(72); vb.set_value(svcs); } else return 1; // noSuchName return 0; }
// return vb of next oid in agent tree, return 1 else return 0, reason set int MibIter::next(Vb& vb, char *& reason) { int rc; if (valid_ == 0) // not valid object return -1; // 1. poll for value if (first_ == 0) { rc = snmp_->get( pdu_, *target_); first_++; } else { rc = snmp_->get_next( pdu_, *target_); } if (rc != SNMP_CLASS_SUCCESS) { reason = const_cast <char*> (snmp_->error_string()); return 0; } // 2. check for problems if (pdu_.get_error_status()) { reason = const_cast <char*> (pdu_.agent_error_reason()); return 0; } // 3. return vb to caller pdu_.get_vb(vb, 0); Oid nextoid; vb.get_oid(nextoid); // and setup next oid to get Vb nextvb(nextoid); pdu_.delete_all_vbs(); pdu_ += nextvb; // can't do set_vb as there are no entries to replace return 1; // ok }
// Send a report message. int v3MP::send_report(unsigned char* scopedPDU, int scopedPDULength, struct snmp_pdu *pdu, int errorCode, int sLevel, int sModel, OctetStr &sName, UdpAddress &destination, Snmp *snmp_session) { debugprintf(2, "v3MP::send_report: Sending report message."); unsigned char *data; int dataLength; int pdu_type = 0; unsigned char cEngineID[MAXLENGTH_ENGINEID+1]; unsigned char cName[MAXLENGTH_CONTEXT_NAME+1]; int cEngineIDLength = MAXLENGTH_ENGINEID+1; int cNameLength = MAXLENGTH_CONTEXT_NAME+1; debugprintf(2, "v3MP::send_report: securityLevel %d",sLevel); if (scopedPDULength != MAX_SNMP_PACKET) { // try to get scopedPDU and PDU data = asn1_parse_scoped_pdu(scopedPDU, &scopedPDULength, cEngineID, &cEngineIDLength, cName, &cNameLength); if (data == NULL) { debugprintf(1, "mp: Error while trying to parse scopedPDU!"); cEngineID[0] = '\0'; cEngineIDLength = 0; cName[0] = '\0'; cNameLength = 0; // Dont send encrypted report if decryption failed: //if (sLevel == SNMP_SECURITY_LEVEL_AUTH_PRIV) // sLevel = SNMP_SECURITY_LEVEL_AUTH_NOPRIV; } else { // data != NULL dataLength = scopedPDULength; // parse data of scopedPDU snmp_parse_data_pdu(pdu, data, dataLength); pdu_type = pdu->command; if (!data) { debugprintf(0, "mp: Error while trying to parse PDU!"); } } // end of: if (data == NULL) } // end if (scopedPDULength != MAX_SNMP_PACKET) else { // scopedPDULength == MAX_SNMP_PACKET cEngineID[0] = '\0'; cEngineIDLength = 0; cName[0] = '\0'; cNameLength = 0; pdu->reqid = 0; } clear_pdu(pdu); // Clear pdu and free all content debugprintf(4, "pdu->reqid = %ld",pdu->reqid); pdu->errstat = 0; pdu->errindex = 0; pdu->command = REPORT_MSG; Vb counterVb; Oid counterOid; SmiLPOID smioid; SmiVALUE smival; switch (errorCode) { case SNMPv3_MP_INVALID_MESSAGE: case SNMPv3_USM_PARSE_ERROR: { counterVb.set_oid(oidSnmpInvalidMsgs); counterVb.set_value(Counter32(get_stats_invalid_msgs())); break; } case SNMPv3_USM_NOT_IN_TIME_WINDOW: case SNMPv3_MP_NOT_IN_TIME_WINDOW: { counterVb.set_oid(oidUsmStatsNotInTimeWindows); counterVb.set_value(Counter32(usm->get_stats_not_in_time_windows())); break; } case SNMPv3_USM_DECRYPTION_ERROR: { counterVb.set_oid(oidUsmStatsDecryptionErrors); counterVb.set_value(Counter32(usm->get_stats_decryption_errors())); //sLevel = SNMP_SECURITY_LEVEL_NOAUTH_NOPRIV; break; } case SNMPv3_USM_AUTHENTICATION_ERROR: case SNMPv3_USM_AUTHENTICATION_FAILURE: { counterVb.set_oid(oidUsmStatsWrongDigests); counterVb.set_value(Counter32(usm->get_stats_wrong_digests())); //sLevel = SNMP_SECURITY_LEVEL_NOAUTH_NOPRIV; break; } case SNMPv3_USM_UNKNOWN_ENGINEID: case SNMPv3_MP_INVALID_ENGINEID: { //sLevel = SNMP_SECURITY_LEVEL_NOAUTH_NOPRIV; counterVb.set_oid(oidUsmStatsUnknownEngineIDs); counterVb.set_value(Counter32(usm->get_stats_unknown_engine_ids())); break; } case SNMPv3_MP_UNSUPPORTED_SECURITY_MODEL: { counterVb.set_oid(oidSnmpUnknownSecurityModels); counterVb.set_value(Counter32(get_stats_unknown_security_models())); sModel = SNMP_SECURITY_MODEL_USM; sLevel = SNMP_SECURITY_LEVEL_NOAUTH_NOPRIV; break; } case SNMPv3_USM_UNKNOWN_SECURITY_NAME: { counterVb.set_oid(oidUsmStatsUnknownUserNames); counterVb.set_value(Counter32(usm->get_stats_unknown_user_names())); sLevel = SNMP_SECURITY_LEVEL_NOAUTH_NOPRIV; debugprintf(2, "Report: SecurityName: %s",sName.get_printable()); break; } case SNMPv3_USM_UNSUPPORTED_SECURITY_LEVEL: { counterVb.set_oid(oidUsmStatsUnsupportedSecLevels); counterVb.set_value(Counter32(usm->get_stats_unsupported_sec_levels())); sLevel = SNMP_SECURITY_LEVEL_NOAUTH_NOPRIV; break; } default: { counterVb.set_oid(oidSnmpInvalidMsgs); counterVb.set_value(Counter32(get_stats_invalid_msgs())); sModel = SNMP_SECURITY_MODEL_USM; sLevel = SNMP_SECURITY_LEVEL_NOAUTH_NOPRIV; sName.set_data(0, 0); debugprintf(2, "ErrorCode was %i in snmp_parse", errorCode); } } // end switch counterVb.get_oid(counterOid); smioid = counterOid.oidval(); int status = convertVbToSmival(counterVb, &smival); if (status != SNMP_CLASS_SUCCESS) { return SNMPv3_MP_ERROR; } snmp_add_var(pdu, smioid->ptr, (int) smioid->len, &smival); freeSmivalDescriptor(&smival); Buffer<unsigned char> sendbuffer(MAX_SNMP_PACKET); int sendbufferlen= MAX_SNMP_PACKET; status = snmp_build( pdu, sendbuffer.get_ptr(), &sendbufferlen, own_engine_id_oct, sName, sModel, sLevel, OctetStr(cEngineID, cEngineIDLength), OctetStr(cName, cNameLength)); if (status != SNMPv3_MP_OK) { debugprintf(2, "v3MP::send_report: error serializing message (mpSnmpBuild returns: %i).", status); return SNMPv3_MP_ERROR; } SnmpSocket send_fd = INVALID_SOCKET; if (pdu_type == sNMP_PDU_INFORM) { debugprintf(4, "Received a snmpInform pdu."); if (snmp_session->get_eventListHolder()->notifyEventList()) send_fd = snmp_session->get_eventListHolder()->notifyEventList()->get_notify_fd(); } status = snmp_session->send_raw_data(sendbuffer.get_ptr(), (size_t)sendbufferlen,// pdu to send destination, // target address send_fd); // the fd to use if ( status != 0) { debugprintf(1, "v3MP::send_report: error sending message (%i)", status); return SNMPv3_MP_ERROR; } debugprintf(3, "v3MP::send_report: Report sent."); return SNMPv3_MP_OK; }
int CSVBaseSNMP::GetBulkRequest(MonitorResult &ResultList) { WriteLog("\n\n*****************************"); WriteLog("GetBulkRequest!"); static const int BULK_BUFF = 10; int nResult = 0; char chPrvOID[MAX_BUFF_LEN] = {0}; bool bEnd = false; Pdu pdu; // construct a Pdu object Vb vb; // construct a Vb object vb.set_oid( oid); // set the Oid portion of the Vb pdu += vb; // add the vb to the Pdu SnmpTarget *target; if(version ==version3) {//If SNMP Version Is 3 nResult = InitUTarget(); //Init UTarget pdu.set_security_level( m_lSecurityLevel); //Set the Security Level portion of Pdu pdu.set_context_name (m_szContextName); //Set the Context Name portion of Pdu pdu.set_context_engine_id(m_szContextEngineID); //Set the Context Engine ID portion of Pdu target = &m_Utarget; //Set SNMP Target } else { target = &m_Ctarget; //Set SNMP Target } try { if(m_pSnmp) { int nIndex = 0, i = 0; while (( nResult = m_pSnmp->get_bulk(pdu, *target, 0, BULK_BUFF)) == SNMP_CLASS_SUCCESS) { if(bEnd) break; for (i = 0; i < pdu.get_vb_count(); i ++) { pdu.get_vb( vb, i); if (pdu.get_type() == REPORT_MSG) { Oid tmp; vb.get_oid(tmp); return -5; } // look for var bind exception, applies to v2 only if ( vb.get_syntax() != sNMP_SYNTAX_ENDOFMIBVIEW) { string szOID = vb.get_printable_oid(); WriteLog(szOID.c_str()); int nPosition = static_cast<int>(szOID.find(m_szStartID)); if(nPosition < 0) { bEnd = true; break; } if(static_cast<int>(strlen(chPrvOID)) > 0) {//如果上次OID不为空 if(strcmp(vb.get_printable_oid(), chPrvOID) == 0) {//比较OID名称是否相同,相同则退出循环 bEnd = true; break; } } //结果赋值 if(static_cast<int>(strlen(vb.get_printable_oid())) < MAX_BUFF_LEN) strcpy(chPrvOID, vb.get_printable_oid()); SNMP_Monitor_Result result; result.m_szOID = vb.get_printable_oid(); if(strcmp(result.m_szOID.substr(0,19).c_str(),"1.3.6.1.2.1.2.2.1.2")==0) { char str[100]; vb.get_value(str); result.m_szValue=str; WriteLog(str); } else result.m_szValue = vb.get_printable_value(); //nPosition = static_cast<int>(result.m_szOID.find(m_szStartID.c_str()) + m_szStartID.length()); //if(nPosition > 0) //{ result.m_szIndex = result.m_szOID.substr(m_szStartID.length() + 1); result.m_szOID = result.m_szOID.substr(0, m_szStartID.length()); //PrintDebugString("index is " + result.m_szIndex); //} WriteLog(result.m_szIndex.c_str()); WriteLog(result.m_szValue.c_str()); ResultList[nIndex] = result; nIndex ++; } else { m_szErrorMsg = "End of MIB Reached"; return -4; } } // last vb becomes seed of next rquest pdu.set_vblist(&vb, 1); } } } catch(...) { DWORD dwError = GetLastError(); char szMsg[512] = {0}; int nlen = sprintf(szMsg, "Error Number is %08X --*GetBulkRequest*---", dwError); DumpLog("snmpmonitor-bulk.log", szMsg, nlen); } if(nResult == SNMP_ERROR_NO_SUCH_NAME) { nResult = 0; } return nResult; }
int CSVBaseSNMP::GetRequest(MonitorResult &ResultList) { WriteLog("\n\n*****************************"); WriteLog("GetRequest!"); int nResult = 0; Pdu pdu; // construct a Pdu object Vb vb; // construct a Vb object vb.set_oid( oid); // set the Oid portion of the Vb pdu += vb; // add the vb to the Pdu SnmpTarget *target; if(version == version3) {//If SNMP Version Is 3 nResult = InitUTarget(); //Init UTarget pdu.set_security_level( m_lSecurityLevel); //Set the Security Level portion of Pdu pdu.set_context_name(m_szContextName); //Set the Context Name portion of Pdu pdu.set_context_engine_id(m_szContextEngineID); //Set the Context Engine ID portion of Pdu target = &m_Utarget; //Set SNMP Target } else { target = &m_Ctarget; //Set SNMP Target } try { //cout << address << endl; //cout << oid.get_printable() << endl; if(m_pSnmp) { nResult = m_pSnmp->get( pdu,*target); //Get Reques if(nResult != 0) {//当有错误发生时候 m_szErrorMsg = m_pSnmp->error_msg(nResult); return nResult; } for ( int i = 0; i < pdu.get_vb_count(); i ++) { pdu.get_vb(vb, i); if (pdu.get_type() == REPORT_MSG) { Oid tmp; vb.get_oid(tmp); return -5; } // look for var bind exception, applies to v2 only if ( vb.get_syntax() != sNMP_SYNTAX_ENDOFMIBVIEW) { SNMP_Monitor_Result result; result.m_szOID = vb.get_printable_oid(); result.m_szValue = vb.get_printable_value(); size_t nPosition = result.m_szOID.rfind("."); if(nPosition > 0) { result.m_szIndex = result.m_szOID.substr(nPosition); result.m_szOID = result.m_szOID.substr(0, nPosition - 1); } WriteLog(result.m_szIndex.c_str()); WriteLog(result.m_szValue.c_str()); ResultList[i] = result; } else { m_szErrorMsg = "End of MIB Reached"; return -4; } } } } catch(...) { DWORD dwError = GetLastError(); char szMsg[512] = {0}; int nlen = sprintf(szMsg, "Error Number is %08X --*GetRequest*---", dwError); DumpLog("snmpmonitor-request", szMsg, nlen); } return nResult; }
const list<pair<string,string> > & SnmpDG::GetMibTable(const snmp_version version, const SnmpPara& spr, const string oid) const { m_mib_table.clear(); if(!m_inited_success) { return m_mib_table; } Snmp::socket_startup(); // Initialize socket subsystem UdpAddress address( spr.ip.c_str()); Oid myoid(oid.c_str()); // default is sysDescr if( !myoid.valid()) {// check validity of user oid return m_mib_table; } Pdu pdu; // construct a Pdu object Vb vb; // construct a Vb object(SNMP++ Variable Binding) vb.set_oid(myoid);//oid.c_str()); pdu += vb; CTarget ctarget(address); ctarget.set_version( version ); ctarget.set_retry(spr.retry); ctarget.set_timeout(spr.timeout); ctarget.set_readcommunity(spr.community.c_str()); SnmpTarget *target; target = &ctarget; int status; Snmp snmp(status, 0, false); if (status == SNMP_CLASS_SUCCESS) { DWORD dwStartTime_ttl = GetTickCount(); DWORD dwStartTime = 0, dwEndTime = 0; while ( (status = snmp.get_next(pdu, *target)) == SNMP_CLASS_SUCCESS) //get_next命令是按列遍历oid { pdu.get_vb(vb, 0); Oid oid_tmp = vb.get_oid();//.get_printable_oid();该表项的oid string str_oid_tmp = oid_tmp.get_printable(); if(oid_tmp.nCompare(myoid.len(), myoid) != 0)//判断是否已越界,如果是则结束循环 { break; } bool bNew = true; string value_tmp = vb.get_printable_value(); for(std::list<pair<string,string> >::iterator item = m_mib_table.begin(); item != m_mib_table.end(); item++) { if(item->first == str_oid_tmp)//value_tmp)//去掉重复的oid { bNew = false; cout << "ip:" + spr.ip + ",repeat oid:" + str_oid_tmp; break; } } if(bNew) { dwStartTime = GetTickCount(); m_mib_table.push_back(make_pair(str_oid_tmp,value_tmp)); vb.set_oid(oid_tmp); vb.set_null(); pdu.set_vb(vb,0); } else { // if ( GetTickCount() - dwStartTime > 10000 ) //10s //{ // cout << "Timeout because read repeat data " << endl; break; //} } if ( GetTickCount() - dwStartTime_ttl > 300000 ) //5min { cout << "Timeout because read operation " << endl; break; } } } else { cout << "SNMP++ Session Create Fail, " << snmp.error_msg(status) << "\n"; SetLastError(status); } Snmp::socket_cleanup(); // Shut down socket subsystem return m_mib_table; }
///////////////////////////////////////////////////////////////////////////// // 函数:GetBulkRequest // // 说明:得到表格变量的结果 // // 参数:无 // // 返回值: // // 成功返回0,否则返回一个非0 值 // ///////////////////////////////////////////////////////////////////////////// int BasicSNMP::GetBulkRequest() { //puts("BasicSNMP::GetBulkRequest"); int nResult = 0; char chPrvOID[MAX_BUFF_LEN] = {0}; bool bEnd = false; Pdu pdu; // construct a Pdu object Vb vb; // construct a Vb object vb.set_oid( oid); // set the Oid portion of the Vb pdu += vb; // add the vb to the Pdu DestroyResultList(); SnmpTarget *target;// = &ctarget; if(version ==version3) {//If SNMP Version Is 3 nResult = InitUTarget();//Init UTarget pdu.set_security_level( m_nSecurityLevel);//Set the Security Level portion of Pdu pdu.set_context_name (contextName);//Set the Context Name portion of Pdu pdu.set_context_engine_id(contextEngineID);//Set the Context Engine ID portion of Pdu target = &utarget; //Set SNMP Target } else { target = &ctarget; //Set SNMP Target } OIDResult *pTemp = new OIDResult(); OIDResult *pPrevResult = pTemp; //pTemp->pNext = NULL; pResult = pTemp; try { //SnmpTarget *target = &ctarget; while (( nResult = pSnmp->get_next(pdu, *target))== SNMP_CLASS_SUCCESS) { if(bEnd) { break; } for ( int z=0;z<pdu.get_vb_count(); z++) { pdu.get_vb( vb,z); if (pdu.get_type() == REPORT_MSG) { Oid tmp; vb.get_oid(tmp); return -5; } // look for var bind exception, applies to v2 only if ( vb.get_syntax() != sNMP_SYNTAX_ENDOFMIBVIEW) { char chOID[MAX_BUFF_LEN] = {0}; sprintf(chOID, "%s", vb.get_printable_oid()); char *pDest = strstr(chOID, chOIDStart); if(pDest == NULL) {//OID名称是否包含开始OID bEnd = true; break; } if(strlen(chPrvOID)>0) {//如果上次OID不为空 if(strcmp(vb.get_printable_oid(), chPrvOID) == 0) {//比较OID名称是否相同,相同则退出循环 bEnd = true; break; } } //结果赋值 strcpy(chPrvOID, vb.get_printable_oid()); strcpy(pTemp->chOID, vb.get_printable_oid()); strcpy(pTemp->chValue,vb.get_printable_value()); char *pIndex; pIndex=pTemp->chOID+strlen(oid.get_printable())+1; //pTemp->nLen = static_cast<int>(strlen(pTemp->chValue)); //char *pdest = strrchr(pTemp->chOID, '.'); //int nLast = (int)(pdest - pTemp->chOID + 1); //memcpy(pTemp->chIndex, (pTemp->chOID)+nLast, strlen(pTemp->chOID) - nLast); strcpy(pTemp->chIndex,pIndex); //pTemp->chIndex[strlen(pTemp->chOID) - nLast] = '\0'; } else { memset(chErrMsg, 0 , MAX_BUFF_LEN); strcpy(chErrMsg, "End of MIB Reached"); return -4; } if(pTemp->pNext == NULL) { pPrevResult = pTemp; pTemp->pNext = new OIDResult(); if(pTemp->pNext) pTemp = pTemp->pNext; //pTemp->pNext = NULL; } } // last vb becomes seed of next rquest pdu.set_vblist(&vb, 1); } if(nResult == 0) { if(pTemp->pNext == NULL) { free(pTemp); pTemp = NULL; pPrevResult->pNext = NULL; } } } catch(...) { DWORD dwError = GetLastError(); char szMsg[512] = {0}; int nlen = sprintf(szMsg, "Error Number is %08X --*GetBulkRequest*---", dwError); DumpLog("snmpmonitor-bulk.log", szMsg, nlen); //cout << "Error Number is " << dwError << "---*GetRequest*---" << endl; } if(nResult == SNMP_ERROR_NO_SUCH_NAME) { nResult = 0; pPrevResult->pNext = NULL; } return nResult; }
///////////////////////////////////////////////////////////////////////////// // 函数:GetRequest // // 说明:得到简单变量的结果 // // 参数:无 // // 返回值: // // 成功返回0,否则返回一个非0 值 // ///////////////////////////////////////////////////////////////////////////// int BasicSNMP::GetRequest() { static const char chFile[] = "smmpmonitor.log"; int nResult = 0; Pdu pdu; // construct a Pdu object Vb vb; // construct a Vb object vb.set_oid( oid); // set the Oid portion of the Vb pdu += vb; // add the vb to the Pdu DestroyResultList(); SnmpTarget *target;// = &ctarget; if(version ==version3) {//If SNMP Version Is 3 nResult = InitUTarget();//Init UTarget pdu.set_security_level( m_nSecurityLevel);//Set the Security Level portion of Pdu pdu.set_context_name (contextName);//Set the Context Name portion of Pdu pdu.set_context_engine_id(contextEngineID);//Set the Context Engine ID portion of Pdu target = &utarget; //Set SNMP Target } else { target = &ctarget; //Set SNMP Target } OIDResult *pTemp = new OIDResult();//construct OIDResult Struct pTemp->pNext = NULL; pResult = pTemp; try { nResult = pSnmp->get( pdu,*target);//Get Reques if(nResult != 0) {//当有错误发生时候 strcpy(chErrMsg, pSnmp->error_msg(nResult)); return nResult; } for ( int z = 0; z < pdu.get_vb_count(); z++) { pdu.get_vb( vb,z); if (pdu.get_type() == REPORT_MSG) { Oid tmp; vb.get_oid(tmp); return -5; } // look for var bind exception, applies to v2 only if ( vb.get_syntax() != sNMP_SYNTAX_ENDOFMIBVIEW) { //Set OIDResult Value if(static_cast<int>(strlen(vb.get_printable_oid())) < MAX_BUFF_LEN) strcpy(pTemp->chOID, vb.get_printable_oid()); if(static_cast<int>(strlen(vb.get_printable_value())) < MAX_BUFF_LEN) { strcpy(pTemp->chValue, vb.get_printable_value()); //pTemp->nLen = static_cast<int>(strlen(pTemp->chValue)); } char *pdest = strrchr(pTemp->chOID, '.'); if(pdest) { (*pdest) = '\0'; pdest ++; strcpy(pTemp->chIndex, pdest); } //if(pdest) //{ // int nLast = (int)(pdest - pTemp->chOID + 1); // memcpy(pTemp->chIndex, (pTemp->chOID)+nLast, strlen(pTemp->chOID) - nLast); // pTemp->chIndex[strlen(pTemp->chOID) - nLast] = '\0'; //} } else { memset(chErrMsg, 0 , MAX_BUFF_LEN); strcpy(chErrMsg, "End of MIB Reached"); return -4; } } } catch(...) { DWORD dwError = GetLastError(); char szMsg[512] = {0}; int nlen = sprintf(szMsg, "Error Number is %08X --*GetRequest*---", dwError); DumpLog(chFile, szMsg, nlen); //cout << "Error Number is " << dwError << "---*GetRequest*---" << endl; } return nResult; }
///////////////////////////////////////////////////////////////////////////// // 函数:GetNextRequest // // 说明:以当前OID变量为开始,得到下一个简单变量的结果 // // 参数:无 // // 返回值: // // 成功返回0,否则返回一个非0 值 // ///////////////////////////////////////////////////////////////////////////// int BasicSNMP::GetNextRequest() { int nResult = 0; Pdu pdu; // construct a Pdu object Vb vb; // construct a Vb object vb.set_oid( oid); // set the Oid portion of the Vb pdu += vb; // add the vb to the Pdu DestroyResultList(); SnmpTarget *target;// = &ctarget; if(version ==version3) {//If SNMP Version Is 3 nResult = InitUTarget();//Init UTarget pdu.set_security_level( m_nSecurityLevel);//Set the Security Level portion of Pdu pdu.set_context_name (contextName);//Set the Context Name portion of Pdu pdu.set_context_engine_id(contextEngineID);//Set the Context Engine ID portion of Pdu target = &utarget; //Set SNMP Target } else { target = &ctarget; //Set SNMP Target } OIDResult *pTemp = new OIDResult(); pTemp->pNext = NULL; pResult = pTemp; //SnmpTarget *target = &ctarget; nResult = pSnmp->get_next( pdu,*target); if(nResult != 0) {//当有错误发生时候 strcpy(chErrMsg, pSnmp->error_msg(nResult)); } for ( int z=0;z<pdu.get_vb_count(); z++) { pdu.get_vb( vb,z); if (pdu.get_type() == REPORT_MSG) { Oid tmp; vb.get_oid(tmp); return -5; } // look for var bind exception, applies to v2 only if ( vb.get_syntax() != sNMP_SYNTAX_ENDOFMIBVIEW) { strcpy(pTemp->chOID, vb.get_printable_oid()); strcpy(pTemp->chValue,vb.get_printable_value()); //pTemp->nLen = static_cast<int>(strlen(pTemp->chValue)); char *pdest = strrchr(pTemp->chOID, '.'); int nLast = (int)(pdest - pTemp->chOID + 1); memcpy(pTemp->chIndex, (pTemp->chOID)+nLast, strlen(pTemp->chOID) - nLast); pTemp->chIndex[strlen(pTemp->chOID) - nLast] = '\0'; oid = pTemp->chOID; } else { // memset(chErrMsg, 0 , MAX_BUFF_LEN); // strcpy(chErrMsg, "End of MIB Reached"); return -4; } } return nResult; }
int main_bulk_jun( int argc, char **argv) { { cout << "Usage:\n"; cout << "snmpBulk IpAddress | DNSName [Oid [Oid...]] [options]\n"; cout << "Oid: sysDescr object is default\n"; cout << "options: -v1 , use SNMPV1, default\n"; cout << " -v2 , use SNMPV2\n"; #ifdef _SNMPv3 cout << " -v3 , use SNMPV3\n"; #endif cout << " -pPort , remote port to use\n"; cout << " -CCommunity_name, specify community default is 'public' \n"; cout << " -rN , retries default is N = 1 retry\n"; cout << " -tN , timeout in hundredths of seconds; default is N = 100\n"; cout << " -nN , non-repeaters default is N = 0\n"; cout << " -mN , max-repetitions default is N = 1\n"; #ifdef _SNMPv3 cout << " -snSecurityName, " << endl; cout << " -slN , securityLevel to use, default N = 3 = authPriv" << endl; cout << " -smN , securityModel to use, only default N = 3 = USM possible\n"; cout << " -cnContextName, default """"" << endl; cout << " -ceContextEngineID, default """"" << endl; cout << " -md5 , use MD5 authentication protocol\n"; cout << " -sha , use SHA authentication protocol\n"; cout << " -des , use DES privacy protocol\n"; cout << " -idea, use IDEA privacy protocol\n"; cout << " -aes128, use AES128 privacy protocol\n"; cout << " -aes192, use AES192 privacy protocol\n"; cout << " -aes256, use AES256 privacy protocol\n"; cout << " -uaAuthPassword\n"; cout << " -upPrivPassword\n"; #endif } //---------[ check the arg count ]---------------------------------------- if ( argc < 2) { return 1; } Snmp::socket_startup(); // Initialize socket subsystem //---------[ make a GenAddress and Oid object to retrieve ]--------------- UdpAddress address( argv[1]); // make a SNMP++ Generic address if ( !address.valid()) { // check validity of address cout << "Invalid Address or DNS Name, " << argv[1] << "\n"; return 1; } Pdu pdu; // construct a Pdu object Vb vb; // construct a Vb object if ( argc >= 3) { // if 3 args, then use the callers Oid int i=2; while ((strstr(argv[i],"-")==0) && (i<argc)) { Oid oid(argv[i]); if ( !oid.valid()) { // check validity of user oid cout << "Invalid Oid, " << argv[2] << "\n"; return -2; } vb.set_oid(oid); pdu += vb; i++; } } else { Oid oid("1.3.6.1.2.1.1.1"); // default is sysDescr vb.set_oid(oid); pdu += vb; // add the vb to the Pdu } //jun add { Oid oid ("1.3.6.1.2.1.1.6.0"); vb.set_oid(oid); pdu += vb; Oid oid2("1.3.6.1.2.1.1.3.0"); vb.set_oid(oid2); pdu += vb; Oid oid3("1.3.6.1.2.1.1.5.0"); vb.set_oid(oid3); pdu += vb; Oid oidx("1.3.6.1.2.1.1.5"); vb.set_oid(oidx); pdu += vb; Oid oid4("1.3.6.1.2.1.25.5.1.1"); vb.set_oid(oid4); pdu += vb; } //---------[ determine options to use ]----------------------------------- snmp_version version=version1; // default is v1 int retries=1; // default retries is 1 int timeout=100; // default is 1 second u_short port=161; // default snmp port is 161 OctetStr community("public"); // community name int non_reps=2; // non repeaters default is 0 int max_reps=20; // maximum repetitions default is 1 #ifdef _SNMPv3 OctetStr privPassword(""); OctetStr authPassword(""); OctetStr securityName(""); int securityModel = SecurityModel_USM; int securityLevel = SecurityLevel_authPriv; OctetStr contextName(""); OctetStr contextEngineID(""); long authProtocol = SNMPv3_usmNoAuthProtocol; long privProtocol = SNMPv3_usmNoPrivProtocol; v3MP *v3_MP; #endif char *ptr; for(int x=1;x<argc;x++) { // parse for version if ( strstr( argv[x],"-v2")!= 0) { version = version2c; continue; } if ( strstr( argv[x],"-r")!= 0) { // parse for retries ptr = argv[x]; ptr++; ptr++; retries = atoi(ptr); if (( retries<0)|| (retries>5)) retries=1; continue; } if ( strstr( argv[x], "-t")!=0) { // parse for timeout ptr = argv[x]; ptr++; ptr++; timeout = atoi( ptr); if (( timeout < 100)||( timeout>500)) timeout=100; continue; } if ( strstr( argv[x],"-n")!=0) { // parse for non repeaters ptr = argv[x];ptr++;ptr++; non_reps=atoi( ptr); if (( non_reps < 0)||( non_reps>10)) non_reps=0; } if ( strstr( argv[x],"-m")!=0) { // parse for max repetitions ptr = argv[x];ptr++;ptr++; max_reps=atoi( ptr); if ( max_reps < 0) max_reps=1; } if ( strstr( argv[x],"-C")!=0) { ptr = argv[x]; ptr++; ptr++; community = ptr; continue; } if ( strstr( argv[x],"-p")!=0) { ptr = argv[x]; ptr++; ptr++; sscanf(ptr, "%hu", &port); continue; } #ifdef _SNMPv3 if ( strstr( argv[x],"-v3")!= 0) { version = version3; continue; } if ( strstr( argv[x],"-idea") != 0) { ptr = argv[x]; ptr++; ptr++; privProtocol = SNMPv3_usmIDEAPrivProtocol; continue; } if ( strstr( argv[x],"-aes128") != 0) { ptr = argv[x]; ptr++; ptr++; privProtocol = SNMPv3_usmAES128PrivProtocol; continue; } if ( strstr( argv[x],"-aes192") != 0) { ptr = argv[x]; ptr++; ptr++; privProtocol = SNMPv3_usmAES192PrivProtocol; continue; } if ( strstr( argv[x],"-aes256") != 0) { ptr = argv[x]; ptr++; ptr++; privProtocol = SNMPv3_usmAES256PrivProtocol; continue; } if ( strstr( argv[x],"-sha") != 0) { ptr = argv[x]; ptr++; ptr++; authProtocol = SNMPv3_usmHMACSHAAuthProtocol; continue; } if ( strstr( argv[x],"-des") != 0) { ptr = argv[x]; ptr++; ptr++; privProtocol = SNMPv3_usmDESPrivProtocol; continue; } if ( strstr( argv[x],"-md5") != 0) { ptr = argv[x]; ptr++; ptr++; authProtocol = SNMPv3_usmHMACMD5AuthProtocol; continue; } if ( strstr( argv[x],"-sn")!=0) { ptr = argv[x]; ptr+=3; securityName = ptr; continue; } if ( strstr( argv[x], "-sl")!=0) { ptr = argv[x]; ptr+=3; securityLevel = atoi( ptr); if (( securityLevel < SecurityLevel_noAuthNoPriv) || ( securityLevel > SecurityLevel_authPriv)) securityLevel = SecurityLevel_authPriv; continue; } if ( strstr( argv[x], "-sm")!=0) { ptr = argv[x]; ptr+=3; securityModel = atoi( ptr); if (( securityModel < SecurityModel_v1) || ( securityModel > SecurityModel_USM)) securityModel = SecurityModel_USM; continue; } if ( strstr( argv[x],"-cn")!=0) { ptr = argv[x]; ptr+=3; contextName = ptr; continue; } if ( strstr( argv[x],"-ce")!=0) { ptr = argv[x]; ptr+=3; contextEngineID = ptr; continue; } if ( strstr( argv[x],"-ua")!=0) { ptr = argv[x]; ptr+=3; authPassword = ptr; continue; } if ( strstr( argv[x],"-up")!=0) { ptr = argv[x]; ptr+=3; privPassword = ptr; continue; } #endif } //----------[ create a SNMP++ session ]----------------------------------- int status; // bind to any port and use IPv6 if needed Snmp snmp(status, 0, (address.get_ip_version() == Address::version_ipv6)); if ( status != SNMP_CLASS_SUCCESS) { cout << "SNMP++ Session Create Fail, " << snmp.error_msg(status) << "\n"; return 1; } //---------[ init SnmpV3 ]-------------------------------------------- #ifdef _SNMPv3 if (version == version3) { char *engineId = "snmpBulk"; char *filename = "snmpv3_boot_counter"; unsigned int snmpEngineBoots = 0; int status; status = getBootCounter(filename, engineId, snmpEngineBoots); if ((status != SNMPv3_OK) && (status < SNMPv3_FILEOPEN_ERROR)) { cout << "Error loading snmpEngineBoots counter: " << status << endl; return 1; } snmpEngineBoots++; status = saveBootCounter(filename, engineId, snmpEngineBoots); if (status != SNMPv3_OK) { cout << "Error saving snmpEngineBoots counter: " << status << endl; return 1; } int construct_status; v3_MP = new v3MP(engineId, snmpEngineBoots, construct_status); USM *usm = v3_MP->get_usm(); usm->add_usm_user(securityName, authProtocol, privProtocol, authPassword, privPassword); } else { // MUST create a dummy v3MP object if _SNMPv3 is enabled! int construct_status; v3_MP = new v3MP("dummy", 0, construct_status); } #endif //--------[ build up SNMP++ object needed ]------------------------------- address.set_port(port); CTarget ctarget( address); // make a target using the address #ifdef _SNMPv3 UTarget utarget( address); if (version == version3) { utarget.set_version( version); // set the SNMP version SNMPV1 or V2 or V3 utarget.set_retry( retries); // set the number of auto retries utarget.set_timeout( timeout); // set timeout utarget.set_security_model( securityModel); utarget.set_security_name( securityName); pdu.set_security_level( securityLevel); pdu.set_context_name (contextName); pdu.set_context_engine_id(contextEngineID); } else { #endif ctarget.set_version( version); // set the SNMP version SNMPV1 or V2 ctarget.set_retry( retries); // set the number of auto retries ctarget.set_timeout( timeout); // set timeout ctarget.set_readcommunity( community); // set the read community name #ifdef _SNMPv3 } #endif //-------[ issue the request, blocked mode ]----------------------------- cout << "SNMP++ GetBulk to " << argv[1] << " SNMPV" #ifdef _SNMPv3 << ((version==version3) ? (version) : (version+1)) #else << (version+1) #endif << " Retries=" << retries << " Timeout=" << timeout << "ms" << " Non Reptrs=" << non_reps << " Max Reps=" << max_reps << endl; #ifdef _SNMPv3 if (version == version3) cout << endl << "securityName= " << securityName.get_printable() << ", securityLevel= " << securityLevel << ", securityModel= " << securityModel << endl << "contextName= " << contextName.get_printable() << ", contextEngineID= " << contextEngineID.get_printable() << endl; else #endif cout << " Community=" << community.get_printable() << endl << flush; SnmpTarget *target; #ifdef _SNMPv3 if (version == version3) target = &utarget; else #endif target = &ctarget; Pdu pdu2 = pdu; if (( status = snmp.get_bulk( pdu,*target,non_reps,max_reps))== SNMP_CLASS_SUCCESS) { for ( int z=0;z<pdu.get_vb_count();z++) { pdu.get_vb( vb,z); #ifdef _SNMPv3 if (pdu.get_type() == REPORT_MSG) { Oid tmp; vb.get_oid(tmp); cout << "Received a reportPdu: " << snmp.error_msg( tmp) << endl << vb.get_printable_oid() << " = " << vb.get_printable_value() << endl; } #endif cout << "Oid = " << vb.get_printable_oid() << "\n"; if ( vb.get_syntax() != sNMP_SYNTAX_ENDOFMIBVIEW) { cout << "Value = " << vb.get_printable_value() << "\n\n"; } else { cout << "End of MIB view.\n\n"; } } } else cout << "SNMP++ GetBulk Error, " << snmp.error_msg( status) << "\n"; pdu = pdu2; //-------------------- if (( status = snmp.get_bulk( pdu,*target,non_reps,max_reps))== SNMP_CLASS_SUCCESS) { for ( int z=0;z<pdu.get_vb_count();z++) { pdu.get_vb( vb,z); #ifdef _SNMPv3 if (pdu.get_type() == REPORT_MSG) { Oid tmp; vb.get_oid(tmp); cout << "Received a reportPdu: " << snmp.error_msg( tmp) << endl << vb.get_printable_oid() << " = " << vb.get_printable_value() << endl; } #endif cout << "Oid = " << vb.get_printable_oid() << "\n"; if ( vb.get_syntax() != sNMP_SYNTAX_ENDOFMIBVIEW) { cout << "Value = " << vb.get_printable_value() << "\n\n"; } else { cout << "End of MIB view.\n\n"; } } } else cout << "SNMP++ GetBulk Error, " << snmp.error_msg( status) << "\n"; //------------- Snmp::socket_cleanup(); // Shut down socket subsystem }
int SnmpMessage::load(const Pdu &cpdu, const OctetStr &community, const snmp_version version, const OctetStr* engine_id, const OctetStr* security_name, const int security_model) { int status; const Pdu *pdu = &cpdu; Pdu temppdu; // make sure pdu is valid if ( !pdu->valid()) return SNMP_CLASS_INVALID_PDU; // create a raw pdu snmp_pdu *raw_pdu; raw_pdu = snmp_pdu_create( (int) pdu->get_type()); Oid enterprise; // load it up raw_pdu->reqid = pdu->get_request_id(); #ifdef _SNMPv3 raw_pdu->msgid = pdu->get_message_id(); #endif raw_pdu->errstat= (unsigned long) pdu->get_error_status(); raw_pdu->errindex= (unsigned long) pdu->get_error_index(); // if its a V1 trap then load up other values // for v2, use normal pdu format if (raw_pdu->command == sNMP_PDU_V1TRAP) { // DON'T forget about the v1 trap agent address (changed by Frank Fock) GenAddress gen_addr; IpAddress ip_addr; int addr_set = FALSE; if (pdu->get_v1_trap_address(gen_addr)) { /* User did set the v1 trap address */ if ((gen_addr.get_type() != Address::type_ip) && (gen_addr.get_type() != Address::type_udp) ) { LOG_BEGIN(ERROR_LOG | 4); LOG("SNMPMessage: Bad v1 trap address type in pdu"); LOG(gen_addr.get_type()); LOG_END; snmp_free_pdu( raw_pdu); return SNMP_CLASS_INVALID_PDU; } ip_addr = gen_addr; if (!ip_addr.valid()) { LOG_BEGIN(ERROR_LOG | 1); LOG("SNMPMessage: Copied v1 trap address not valid"); LOG_END; snmp_free_pdu( raw_pdu); return SNMP_CLASS_RESOURCE_UNAVAIL; } addr_set = TRUE; } else { /* User did not set the v1 trap address */ char addrString[256]; if (gethostname(addrString, 255) == 0) { ip_addr = addrString; addr_set = TRUE; } } struct sockaddr_in agent_addr; // agent address socket struct // prepare the agent address memset(&agent_addr, 0, sizeof(agent_addr)); agent_addr.sin_family = AF_INET; if (addr_set) { agent_addr.sin_addr.s_addr = inet_addr(((IpAddress &)ip_addr).IpAddress::get_printable()); LOG_BEGIN(INFO_LOG | 7); LOG("SNMPMessage: Setting v1 trap address"); LOG(((IpAddress &)ip_addr).IpAddress::get_printable()); LOG_END; } raw_pdu->agent_addr = agent_addr; //-----[ compute generic trap value ]------------------------------- // determine the generic value // 0 - cold start // 1 - warm start // 2 - link down // 3 - link up // 4 - authentication failure // 5 - egpneighborloss // 6 - enterprise specific Oid trapid; pdu->get_notify_id( trapid); if ( !trapid.valid() || trapid.len() < 2 ) { snmp_free_pdu( raw_pdu); return SNMP_CLASS_INVALID_NOTIFYID; } raw_pdu->specific_type=0; if ( trapid == coldStart) raw_pdu->trap_type = 0; // cold start else if ( trapid == warmStart) raw_pdu->trap_type = 1; // warm start else if( trapid == linkDown) raw_pdu->trap_type = 2; // link down else if ( trapid == linkUp) raw_pdu->trap_type = 3; // link up else if ( trapid == authenticationFailure ) raw_pdu->trap_type = 4; // authentication failure else if ( trapid == egpNeighborLoss) raw_pdu->trap_type = 5; // egp neighbor loss else { raw_pdu->trap_type = 6; // enterprise specific // last oid subid is the specific value // if 2nd to last subid is "0", remove it // enterprise is always the notify oid prefix raw_pdu->specific_type = (int) trapid[(int) (trapid.len()-1)]; trapid.trim(1); if ( trapid[(int)(trapid.len()-1)] == 0 ) trapid.trim(1); enterprise = trapid; } if ( raw_pdu->trap_type !=6) pdu->get_notify_enterprise( enterprise); if ( enterprise.len() >0) { // note!! // these are hooks into an SNMP++ oid // and therefor the raw_pdu enterprise // should not free them. null them out!! SmiLPOID rawOid; rawOid = enterprise.oidval(); raw_pdu->enterprise = rawOid->ptr; raw_pdu->enterprise_length = (int) rawOid->len; } // timestamp TimeTicks timestamp; pdu->get_notify_timestamp( timestamp); raw_pdu->time = ( unsigned long) timestamp; } // if its a v2 trap then we need to make a few adjustments // vb #1 is the timestamp // vb #2 is the id, represented as an Oid if (( raw_pdu->command == sNMP_PDU_TRAP) || ( raw_pdu->command == sNMP_PDU_INFORM)) { Vb tempvb; temppdu = *pdu; temppdu.trim(temppdu.get_vb_count()); // vb #1 is the timestamp TimeTicks timestamp; tempvb.set_oid(SNMP_MSG_OID_SYSUPTIME); // sysuptime pdu->get_notify_timestamp( timestamp); tempvb.set_value ( timestamp); temppdu += tempvb; // vb #2 is the id Oid trapid; tempvb.set_oid(SNMP_MSG_OID_TRAPID); pdu->get_notify_id( trapid); tempvb.set_value( trapid); temppdu += tempvb; // append the remaining vbs for (int z=0; z<pdu->get_vb_count(); z++) { pdu->get_vb( tempvb,z); temppdu += tempvb; } pdu = &temppdu; // reassign the pdu to the temp one } // load up the payload // for all Vbs in list, add them to the pdu int vb_count; Vb tempvb; Oid tempoid; SmiLPOID smioid; SmiVALUE smival; vb_count = pdu->get_vb_count(); for (int z=0;z<vb_count;z++) { pdu->get_vb( tempvb,z); tempvb.get_oid( tempoid); smioid = tempoid.oidval(); // clear the value portion, in case its // not already been done so by the app writer // only do it in the case its a get,next or bulk if ((raw_pdu->command == sNMP_PDU_GET) || (raw_pdu->command == sNMP_PDU_GETNEXT) || (raw_pdu->command == sNMP_PDU_GETBULK)) tempvb.set_null(); status = convertVbToSmival( tempvb, &smival ); if ( status != SNMP_CLASS_SUCCESS) { snmp_free_pdu( raw_pdu); return status; } // add the vb to the raw pdu snmp_add_var( raw_pdu, smioid->ptr, (int) smioid->len, &smival); freeSmivalDescriptor( &smival); } // ASN1 encode the pdu #ifdef _SNMPv3 if (version == version3) { if ((!engine_id) || (!security_name)) { LOG_BEGIN(ERROR_LOG | 4); LOG("SNMPMessage: Need security name and engine id for v3 message"); LOG_END; // prevention of SNMP++ Enterprise Oid death if ( enterprise.len() >0) { raw_pdu->enterprise = 0; raw_pdu->enterprise_length=0; } snmp_free_pdu( raw_pdu); return SNMP_CLASS_INVALID_TARGET; } status = v3MP::I->snmp_build(raw_pdu, databuff, (int *)&bufflen, *engine_id, *security_name, security_model, pdu->get_security_level(), pdu->get_context_engine_id(), pdu->get_context_name()); if (status == SNMPv3_MP_OK) { if ((pdu->get_type() == sNMP_PDU_RESPONSE) && ((int)pdu->get_maxsize_scopedpdu() < pdu->get_asn1_length())) { LOG_BEGIN(ERROR_LOG | 1); LOG("SNMPMessage: *BUG*: Serialized response pdu is too big (len) (max)"); LOG(pdu->get_asn1_length()); LOG(pdu->get_maxsize_scopedpdu()); LOG_END; // prevention of SNMP++ Enterprise Oid death if ( enterprise.len() >0) { raw_pdu->enterprise = 0; raw_pdu->enterprise_length=0; } snmp_free_pdu( raw_pdu); return SNMP_ERROR_TOO_BIG; } } } else #endif status = snmp_build( raw_pdu, databuff, (int *) &bufflen, version, community.data(), (int) community.len()); LOG_BEGIN(DEBUG_LOG | 4); LOG("SNMPMessage: return value for build message"); LOG(status); LOG_END; if ((status != 0) #ifdef _SNMPv3 && ((version != version3) || (status != SNMPv3_MP_OK)) #endif ) { valid_flag = false; // prevention of SNMP++ Enterprise Oid death if ( enterprise.len() >0) { raw_pdu->enterprise = 0; raw_pdu->enterprise_length=0; } snmp_free_pdu( raw_pdu); #ifdef _SNMPv3 if (version == version3) return status; else #endif // NOTE: This is an assumption - in most cases during normal // operation the reason is a tooBig - another could be a // damaged variable binding. return SNMP_ERROR_TOO_BIG; } valid_flag = true; // prevention of SNMP++ Enterprise Oid death if ( enterprise.len() >0) { raw_pdu->enterprise = 0; raw_pdu->enterprise_length=0; } snmp_free_pdu( raw_pdu); return SNMP_CLASS_SUCCESS; }
void* runable(void *data) { //--------[ build up SNMP++ object needed ]------------------------------- ssync.lock(); printf("HELLO:%s\n", community.get_printable()); int t = *((int*)data); Pdu pdu; // construct a Pdu object Vb vb; // construct a Vb object vb.set_oid("1"); // set the Oid portion of the Vb pdu += vb; // add the vb to the Pdu CTarget ctarget(address[t]); // make a target using the address #ifdef _SNMPv3 UTarget utarget(address[t]); if (version == version3) { utarget.set_version( version); // set the SNMP version SNMPV1 or V2 or V3 utarget.set_retry( retries); // set the number of auto retries utarget.set_timeout( timeout); // set timeout utarget.set_security_model( securityModel); utarget.set_security_name( securityName); pdu.set_security_level( securityLevel); pdu.set_context_name (contextName); pdu.set_context_engine_id(contextEngineID); } else { #endif ctarget.set_version( version); // set the SNMP version SNMPV1 or V2 or V3 ctarget.set_retry( retries); // set the number of auto retries ctarget.set_timeout( timeout); // set timeout ctarget.set_readcommunity( community); // set the read community to use ctarget.set_writecommunity( community); #ifdef _SNMPv3 } #endif //-------[ issue the request, blocked mode ]----------------------------- cout << "(" << t << "): " << "SNMP++ snmpWalk to " << address[t].get_printable() << " SNMPV" #ifdef _SNMPv3 << ((version==version3) ? (version) : (version+1)) #else << (version+1) #endif << " Retries=" << retries << " Timeout=" << timeout <<"ms"; #ifdef _SNMPv3 if (version == version3) cout << endl << "securityName= " << securityName.get_printable() << ", securityLevel= " << securityLevel << ", securityModel= " << securityModel << endl << "contextName= " << contextName.get_printable() << ", contextEngineID= " << contextEngineID.get_printable() << endl; else #endif cout << " Community=" << community.get_printable() << endl << flush; SnmpTarget *target; #ifdef _SNMPv3 if (version == version3) target = &utarget; else #endif target = &ctarget; int status = 0; int requests = 0; int objects = 0; ssync.unlock(); while (( status = snmp->get_bulk( pdu,*target,0,BULK_MAX)) == SNMP_CLASS_SUCCESS) { requests++; ssync.lock(); for ( int z=0;z<pdu.get_vb_count(); z++) { pdu.get_vb( vb,z); #ifdef _SNMPv3 if (pdu.get_type() == REPORT_MSG) { Oid tmp; vb.get_oid(tmp); cout << "(" << t << "): " << "Received a reportPdu: " << snmp->error_msg( tmp) << endl << vb.get_printable_oid() << " = " << vb.get_printable_value() << endl; ssync.unlock(); return 0; } #endif objects++; // look for var bind exception, applies to v2 only if ( vb.get_syntax() != sNMP_SYNTAX_ENDOFMIBVIEW) { cout << "(" << t << "): " << vb.get_printable_oid() << " = "; cout << vb.get_printable_value() << "\n"; } else { cout << "(" << t << "): " << "End of MIB Reached\n"; cout << "(" << t << "): " << "Total # of Requests = " << requests << "\n"; cout << "(" << t << "): " << "Total # of Objects = " << objects << "\n"; ssync.unlock(); return 0; } } ssync.unlock(); // last vb becomes seed of next rquest pdu.set_vblist(&vb, 1); } if ( status != SNMP_ERROR_NO_SUCH_NAME) cout << "(" << t << "): " << "SNMP++ snmpWalk Error, " << snmp->error_msg( status) << "\n"; cout << "(" << t << "): " << "Total # of Requests = " << requests << "\n"; cout << "(" << t << "): " << "Total # of Objects = " << objects << "\n"; return 0; } // end Walk