version 1.8, 2006/08/11 19:47:07
|
version 1.28, 2012/08/03 03:27:09
|
|
|
//%2006//////////////////////////////////////////////////////////////////////// |
//%LICENSE//////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development |
// Licensed to The Open Group (TOG) under one or more contributor license |
// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. |
// agreements. Refer to the OpenPegasusNOTICE.txt file distributed with |
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.; |
// this work for additional information regarding copyright ownership. |
// IBM Corp.; EMC Corporation, The Open Group. |
// Each contributor licenses this file to you under the OpenPegasus Open |
// Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.; |
// Source License; you may not use this file except in compliance with the |
// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. |
// License. |
// Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; |
|
// EMC Corporation; VERITAS Software Corporation; The Open Group. |
|
// Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.; |
|
// EMC Corporation; Symantec Corporation; The Open Group. |
|
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a copy |
// Permission is hereby granted, free of charge, to any person obtaining a |
// of this software and associated documentation files (the "Software"), to |
// copy of this software and associated documentation files (the "Software"), |
// deal in the Software without restriction, including without limitation the |
// to deal in the Software without restriction, including without limitation |
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or |
// the rights to use, copy, modify, merge, publish, distribute, sublicense, |
// sell copies of the Software, and to permit persons to whom the Software is |
// and/or sell copies of the Software, and to permit persons to whom the |
// furnished to do so, subject to the following conditions: |
// Software is furnished to do so, subject to the following conditions: |
// | // |
// THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN |
// The above copyright notice and this permission notice shall be included |
// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED |
// in all copies or substantial portions of the Software. |
// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT |
|
// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR |
|
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT |
|
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
|
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
|
// | // |
//============================================================================== |
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
|
// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
|
// CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
|
// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
|
// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
|
// |
|
////////////////////////////////////////////////////////////////////////// |
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
#include <Pegasus/Common/Packer.h> |
#include <Pegasus/Repository/Packer.h> |
#include <Pegasus/Common/Tracer.h> | #include <Pegasus/Common/Tracer.h> |
#include "snmpDeliverTrap_netsnmp.h" | #include "snmpDeliverTrap_netsnmp.h" |
| |
|
|
| |
void snmpDeliverTrap_netsnmp::initialize() | void snmpDeliverTrap_netsnmp::initialize() |
{ | { |
|
PEG_METHOD_ENTER(TRC_IND_HANDLER, "snmpDeliverTrap_netsnmp::initialize"); |
PEG_METHOD_ENTER (TRC_IND_HANDLER, |
|
"snmpDeliverTrap_netsnmp::initialize"); |
|
| |
// Defined default MIB modules (in net-snmp-config.h) do not need to be | // Defined default MIB modules (in net-snmp-config.h) do not need to be |
// loaded and loading them can cause some stderr; | // loaded and loading them can cause some stderr; |
// use environment variable MIBS to override the default MIB modules. | // use environment variable MIBS to override the default MIB modules. |
// If there is no MIBS environment variable, add it in. | // If there is no MIBS environment variable, add it in. |
char *envVar; |
|
envVar = getenv("MIBS"); |
|
| |
if (envVar == NULL) |
setenv("MIBS", "", 0); |
{ |
|
putenv("MIBS="); |
|
} |
|
| |
// Initialize the mib reader | // Initialize the mib reader |
netsnmp_set_mib_directory(""); | netsnmp_set_mib_directory(""); |
|
|
// Initializes the SNMP library | // Initializes the SNMP library |
init_snmp("snmpIndicationHandler"); | init_snmp("snmpIndicationHandler"); |
| |
|
// don't load/save persistent file |
|
#ifdef NETSNMP_DS_LIB_DONT_PERSIST_STATE |
|
netsnmp_ds_set_boolean(NETSNMP_DS_LIBRARY_ID, |
|
NETSNMP_DS_LIB_DONT_PERSIST_STATE, 1); |
|
#endif |
|
|
// windows32 specific initialization (is a NOOP on unix) | // windows32 specific initialization (is a NOOP on unix) |
SOCK_STARTUP; | SOCK_STARTUP; |
| |
PEG_METHOD_EXIT (); | PEG_METHOD_EXIT (); |
|
|
} | } |
| |
void snmpDeliverTrap_netsnmp::terminate() | void snmpDeliverTrap_netsnmp::terminate() |
{ | { |
|
PEG_METHOD_ENTER(TRC_IND_HANDLER, "snmpDeliverTrap_netsnmp::terminate"); |
| |
PEG_METHOD_ENTER (TRC_IND_HANDLER, |
// Shuts down the application, and appropriate clean up |
"snmpDeliverTrap_netsnmp::terminate"); |
snmp_shutdown("snmpIndicationHandler"); |
| |
SOCK_CLEANUP; | SOCK_CLEANUP; |
| |
|
|
const Uint32& portNumber, | const Uint32& portNumber, |
const Uint16& snmpVersion, | const Uint16& snmpVersion, |
const String& engineID, | const String& engineID, |
|
const Uint8& snmpSecLevel, |
|
const Uint8& snmpSecAuthProto, |
|
const Array<Uint8>& snmpSecAuthKey, |
|
const Uint8& snmpSecPrivProto, |
|
const Array<Uint8>& snmpSecPrivKey, |
const Array<String>& vbOids, | const Array<String>& vbOids, |
const Array<String>& vbTypes, | const Array<String>& vbTypes, |
const Array<String>& vbValues) | const Array<String>& vbValues) |
{ | { |
| |
PEG_METHOD_ENTER (TRC_IND_HANDLER, |
PEG_METHOD_ENTER(TRC_IND_HANDLER, "snmpDeliverTrap_netsnmp::deliverTrap"); |
"snmpDeliverTrap_netsnmp::deliverTrap"); |
|
| |
void *sessionHandle; | void *sessionHandle; |
struct snmp_session *sessionPtr; | struct snmp_session *sessionPtr; |
|
|
struct snmp_pdu *snmpPdu; | struct snmp_pdu *snmpPdu; |
| |
// Creates a SNMP session | // Creates a SNMP session |
_createSession(targetHost, portNumber, securityName, |
_createSession( |
sessionHandle, sessionPtr); |
targetHost, |
|
targetHostFormat, |
|
portNumber, |
|
securityName, |
|
snmpVersion, |
|
engineID, |
|
snmpSecLevel, |
|
snmpSecAuthProto, |
|
snmpSecAuthKey, |
|
snmpSecPrivProto, |
|
snmpSecPrivKey, |
|
sessionHandle, |
|
sessionPtr); |
| |
try | try |
{ | { |
|
|
_destroySession(sessionHandle); | _destroySession(sessionHandle); |
| |
PEG_METHOD_EXIT (); | PEG_METHOD_EXIT (); |
|
|
throw; | throw; |
} | } |
| |
|
|
} | } |
catch (Exception& e) | catch (Exception& e) |
{ | { |
PEG_TRACE_STRING (TRC_DISCARDED_DATA, Tracer::LEVEL2, |
Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
e.getMessage ()); |
MessageLoaderParms( |
|
|
Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, |
|
Logger::WARNING, |
|
_MSG_PACK_CIM_PROPERTY_TO_PDU_FAILED_KEY, | _MSG_PACK_CIM_PROPERTY_TO_PDU_FAILED_KEY, |
_MSG_PACK_CIM_PROPERTY_TO_PDU_FAILED, | _MSG_PACK_CIM_PROPERTY_TO_PDU_FAILED, |
e.getMessage()); |
e.getMessage())); |
} | } |
catch (...) | catch (...) |
{ | { |
PEG_TRACE_STRING (TRC_DISCARDED_DATA, Tracer::LEVEL2, |
PEG_TRACE_CSTRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, |
"Snmp Indication Handler failed to pack a CIM " | "Snmp Indication Handler failed to pack a CIM " |
"Property into the SNMP PDU: Unknown exception."); | "Property into the SNMP PDU: Unknown exception."); |
} | } |
|
|
| |
free(errStr); | free(errStr); |
| |
|
snmp_free_pdu(snmpPdu); |
|
|
_destroySession(sessionHandle); | _destroySession(sessionHandle); |
| |
PEG_METHOD_EXIT (); | PEG_METHOD_EXIT (); |
| |
throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED, | throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED, |
MessageLoaderParms(_MSG_SESSION_SEND_FAILED_KEY, |
MessageLoaderParms(_MSG_SESSION_SEND_FAILED_KEY, exceptionStr)); |
exceptionStr)); |
|
} | } |
| |
_destroySession(sessionHandle); | _destroySession(sessionHandle); |
| |
PEG_METHOD_EXIT (); | PEG_METHOD_EXIT (); |
|
|
} | } |
| |
// Creates a SNMP session | // Creates a SNMP session |
void snmpDeliverTrap_netsnmp::_createSession( | void snmpDeliverTrap_netsnmp::_createSession( |
const String & targetHost, | const String & targetHost, |
|
Uint16 targetHostFormat, |
Uint32 portNumber, | Uint32 portNumber, |
const String & securityName, | const String & securityName, |
|
Uint16 snmpVersion, |
|
const String& engineID, |
|
const Uint8& snmpSecLevel, |
|
const Uint8& snmpSecAuthProto, |
|
const Array<Uint8>& snmpSecAuthKey, |
|
const Uint8& snmpSecPrivProto, |
|
const Array<Uint8>& snmpSecPrivKey, |
void *&sessionHandle, | void *&sessionHandle, |
snmp_session *&sessionPtr) | snmp_session *&sessionPtr) |
{ | { |
|
|
CString targetHostCStr = targetHost.getCString(); | CString targetHostCStr = targetHost.getCString(); |
| |
// peername has format: targetHost:portNumber | // peername has format: targetHost:portNumber |
snmpSession.peername = (char *)malloc((size_t)(strlen(targetHostCStr)+ |
snmpSession.peername = |
1+32)); |
(char*)calloc(1,strlen(targetHostCStr) + 1 + 32); |
sprintf(snmpSession.peername, "%s:%u", (const char*)targetHostCStr, |
|
|
if (targetHostFormat == _IPV6_ADDRESS) |
|
{ |
|
sprintf(snmpSession.peername, "udp6:[%s]:%u", |
|
(const char*)targetHostCStr, |
portNumber); | portNumber); |
|
} |
|
else |
|
{ |
|
sprintf(snmpSession.peername, "%s:%u", |
|
(const char*)targetHostCStr, |
|
portNumber); |
|
} |
| |
sessionHandle = snmp_sess_open(&snmpSession); | sessionHandle = snmp_sess_open(&snmpSession); |
} | } |
|
|
| |
free(errStr); | free(errStr); |
| |
|
free(snmpSession.peername); |
|
|
PEG_METHOD_EXIT (); | PEG_METHOD_EXIT (); |
| |
throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED, | throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED, |
MessageLoaderParms(_MSG_SESSION_OPEN_FAILED_KEY, |
MessageLoaderParms(_MSG_SESSION_OPEN_FAILED_KEY, exceptionStr)); |
exceptionStr)); |
|
|
|
} | } |
| |
try | try |
|
|
| |
free(errStr); | free(errStr); |
| |
throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED, |
free(snmpSession.peername); |
MessageLoaderParms(_MSG_GET_SESSION_POINTER_FAILED_KEY, |
|
|
throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, MessageLoaderParms( |
|
_MSG_GET_SESSION_POINTER_FAILED_KEY, |
exceptionStr)); | exceptionStr)); |
} | } |
| |
|
free(snmpSession.peername); |
|
|
|
switch (snmpVersion) |
|
{ |
|
case _SNMPv1_TRAP: |
|
{ |
|
sessionPtr->version = SNMP_VERSION_1; |
|
_addCommunity(sessionPtr,securityName); |
|
break; |
|
|
|
} |
|
case _SNMPv2C_TRAP: |
|
{ |
|
sessionPtr->version = SNMP_VERSION_2c; |
|
_addCommunity(sessionPtr,securityName); |
|
break; |
|
} |
|
#ifdef PEGASUS_ENABLE_NET_SNMPV3 |
|
case _SNMPv3_TRAP: |
|
{ |
|
sessionPtr->version = SNMP_VERSION_3; |
|
CString securityNameCStr = securityName.getCString(); |
|
size_t securityNameLen = strlen(securityNameCStr); |
|
SNMP_FREE(sessionPtr->securityName); |
|
sessionPtr->securityName = (char *)calloc(1,securityNameLen+1); |
|
sessionPtr->securityNameLen = securityNameLen; |
|
memcpy(sessionPtr->securityName, (const char*)securityNameCStr, |
|
securityNameLen); |
|
|
|
CString engineIdCStr = engineID.getCString(); |
|
size_t engineIdHexLen = strlen(engineIdCStr); |
|
size_t engineIdBinLen = 0; |
|
u_char *engineIdBin = (u_char *)calloc(1,engineIdHexLen); |
|
free(sessionPtr->securityEngineID); |
|
if(!snmp_hex_to_binary(&engineIdBin, &engineIdHexLen, |
|
&engineIdBinLen, 1,engineIdCStr)) |
|
{ |
|
PEG_TRACE_CSTRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, |
|
"Snmp Indication Handler failed to generate binary" |
|
" engine ID for sending the SNMPv3 trap."); |
|
throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, |
|
MessageLoaderParms( |
|
"Handler.snmpIndicationHandler." |
|
"snmpIndicationHandler." |
|
"FAILED_TO_DELIVER_TRAP", |
|
"Failed to deliver trap.")); |
|
} |
|
sessionPtr->securityEngineIDLen = engineIdBinLen; |
|
sessionPtr->securityEngineID = engineIdBin; |
|
|
|
switch(snmpSecLevel) |
|
{ |
|
case 1: |
|
sessionPtr->securityLevel = SNMP_SEC_LEVEL_NOAUTH; |
|
break; |
|
case 2: |
|
sessionPtr->securityLevel = SNMP_SEC_LEVEL_AUTHNOPRIV; |
|
break; |
|
case 3: |
|
sessionPtr->securityLevel = SNMP_SEC_LEVEL_AUTHPRIV; |
|
break; |
|
default: |
|
//use the dedault in the net-snmp conf file. |
|
break; |
|
} |
|
|
|
SNMP_FREE(sessionPtr->securityAuthProto); |
|
if(snmpSecAuthProto == 1) // MD5 |
|
{ |
|
sessionPtr->securityAuthProto = snmp_duplicate_objid( |
|
usmHMACMD5AuthProtocol, |
|
USM_AUTH_PROTO_MD5_LEN); |
|
sessionPtr->securityAuthProtoLen = USM_AUTH_PROTO_MD5_LEN; |
|
} |
|
else if(snmpSecAuthProto == 2)// SHA |
|
{ |
|
sessionPtr->securityAuthProto = snmp_duplicate_objid( |
|
usmHMACSHA1AuthProtocol, |
|
USM_AUTH_PROTO_SHA_LEN); |
|
sessionPtr->securityAuthProtoLen = USM_AUTH_PROTO_SHA_LEN; |
|
} |
|
// use the default in net-snmp conf files. |
|
|
|
if(snmpSecAuthKey.size() > 0) |
|
{ |
|
for(Uint32 i=0;i<snmpSecAuthKey.size();i++) |
|
{ |
|
sessionPtr->securityAuthKey[i] = snmpSecAuthKey[i]; |
|
} |
|
sessionPtr->securityAuthKeyLen = snmpSecAuthKey.size(); |
|
} |
|
|
|
SNMP_FREE(sessionPtr->securityPrivProto); |
|
//Privacy |
|
if(snmpSecPrivProto == 1) //DES |
|
{ |
|
sessionPtr->securityPrivProto = snmp_duplicate_objid( |
|
usmDESPrivProtocol, |
|
USM_PRIV_PROTO_DES_LEN); |
|
sessionPtr->securityPrivProtoLen = USM_PRIV_PROTO_DES_LEN; |
|
} |
|
else if(snmpSecPrivProto == 2) // AES |
|
{ |
|
sessionPtr->securityPrivProto = snmp_duplicate_objid( |
|
usmAESPrivProtocol, |
|
USM_PRIV_PROTO_AES_LEN); |
|
sessionPtr->securityPrivProtoLen = USM_PRIV_PROTO_AES_LEN; |
|
} |
|
// use the defaults in net-snmp conf files |
|
|
|
// Privacy Key |
|
if(snmpSecPrivKey.size() > 0) |
|
{ |
|
for(Uint32 j=0;j<snmpSecPrivKey.size();j++) |
|
{ |
|
sessionPtr->securityPrivKey[j] = snmpSecPrivKey[j]; |
|
} |
|
sessionPtr->securityPrivKeyLen = snmpSecPrivKey.size(); |
|
} |
|
break; |
|
} |
|
#endif // ifdef PEGASUS_ENABLE_NET_SNMPV3 |
|
default: |
|
{ |
|
PEG_METHOD_EXIT(); |
|
throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_NOT_SUPPORTED, |
|
MessageLoaderParms( |
|
_MSG_VERSION_NOT_SUPPORTED_KEY, |
|
_MSG_VERSION_NOT_SUPPORTED)); |
|
} |
|
} |
|
|
|
} |
|
catch (...) |
|
{ |
|
_destroySession(sessionHandle); |
|
|
|
PEG_METHOD_EXIT(); |
|
throw; |
|
} |
|
|
|
PEG_METHOD_EXIT(); |
|
} |
|
|
|
void snmpDeliverTrap_netsnmp::_addCommunity( |
|
struct snmp_session*& sessionPtr, |
|
const String& securityName) |
|
{ |
|
PEG_METHOD_ENTER(TRC_IND_HANDLER, |
|
"snmpDeliverTrap_netsnmp::_addCommunity"); |
|
|
// Community Name, default is public | // Community Name, default is public |
String communityName; | String communityName; |
if (securityName.size() == 0) | if (securityName.size() == 0) |
|
|
communityName = securityName; | communityName = securityName; |
} | } |
| |
free(snmpSession.peername); |
|
|
|
free(sessionPtr->community); | free(sessionPtr->community); |
| |
CString communityNameCStr = communityName.getCString(); | CString communityNameCStr = communityName.getCString(); |
size_t communityNameLen = strlen(communityNameCStr); | size_t communityNameLen = strlen(communityNameCStr); |
| |
sessionPtr->community = (u_char*)malloc(communityNameLen); |
sessionPtr->community = (u_char*)calloc(1,communityNameLen+1); |
| |
memcpy(sessionPtr->community, (const char *)communityNameCStr, | memcpy(sessionPtr->community, (const char *)communityNameCStr, |
communityNameLen); | communityNameLen); |
sessionPtr->community_len = communityNameLen; |
|
} |
|
catch (...) |
|
{ |
|
_destroySession(sessionHandle); |
|
|
|
PEG_METHOD_EXIT (); |
|
throw; |
|
} |
|
| |
|
sessionPtr->community_len = communityNameLen; |
PEG_METHOD_EXIT (); | PEG_METHOD_EXIT (); |
} | } |
| |
|
|
snmp_session *&sessionPtr, | snmp_session *&sessionPtr, |
snmp_pdu *& snmpPdu) | snmp_pdu *& snmpPdu) |
{ | { |
|
PEG_METHOD_ENTER(TRC_IND_HANDLER, "snmpDeliverTrap_netsnmp::_createPdu"); |
PEG_METHOD_ENTER (TRC_IND_HANDLER, |
|
"snmpDeliverTrap_netsnmp::_createPdu"); |
|
| |
oid _SYSTEM_UP_TIME_OID [] = {1,3,6,1,2,1,1,3,0}; | oid _SYSTEM_UP_TIME_OID [] = {1,3,6,1,2,1,1,3,0}; |
oid _SNMPTRAP_OID [] = {1,3,6,1,6,3,1,1,4,1,0}; | oid _SNMPTRAP_OID [] = {1,3,6,1,6,3,1,1,4,1,0}; |
|
|
{ | { |
case _SNMPv1_TRAP: | case _SNMPv1_TRAP: |
{ | { |
|
|
sessionPtr->version = SNMP_VERSION_1; |
|
|
|
// Create the PDU | // Create the PDU |
snmpPdu = snmp_pdu_create(SNMP_MSG_TRAP); | snmpPdu = snmp_pdu_create(SNMP_MSG_TRAP); |
| |
|
|
if (!snmpPdu) | if (!snmpPdu) |
{ | { |
PEG_METHOD_EXIT (); | PEG_METHOD_EXIT (); |
|
|
throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED, | throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED, |
MessageLoaderParms(_MSG_PDU_CREATE_FAILED_KEY, |
MessageLoaderParms( |
|
_MSG_PDU_CREATE_FAILED_KEY, |
_MSG_PDU_CREATE_FAILED)); | _MSG_PDU_CREATE_FAILED)); |
} | } |
| |
|
|
} | } |
catch (CIMException& e) | catch (CIMException& e) |
{ | { |
PEG_TRACE_STRING (TRC_DISCARDED_DATA, Tracer::LEVEL2, |
Logger::put_l( |
e.getMessage ()); |
Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, |
MessageLoaderParms( |
Logger::WARNING, |
|
_MSG_PACK_TRAP_INFO_INTO_PDU_FAILED_KEY, | _MSG_PACK_TRAP_INFO_INTO_PDU_FAILED_KEY, |
_MSG_PACK_TRAP_INFO_INTO_PDU_FAILED, | _MSG_PACK_TRAP_INFO_INTO_PDU_FAILED, |
e.getMessage()); |
e.getMessage())); |
} | } |
| |
break; | break; |
} | } |
case _SNMPv2C_TRAP: | case _SNMPv2C_TRAP: |
|
case _SNMPv3_TRAP: |
{ | { |
sessionPtr->version = SNMP_VERSION_2c; |
|
|
|
// Create the PDU | // Create the PDU |
snmpPdu = snmp_pdu_create(SNMP_MSG_TRAP2); | snmpPdu = snmp_pdu_create(SNMP_MSG_TRAP2); |
| |
|
|
PEG_METHOD_EXIT (); | PEG_METHOD_EXIT (); |
| |
throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED, | throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED, |
MessageLoaderParms(_MSG_PDU_CREATE_FAILED_KEY, |
MessageLoaderParms( |
|
_MSG_PDU_CREATE_FAILED_KEY, |
_MSG_PDU_CREATE_FAILED)); | _MSG_PDU_CREATE_FAILED)); |
} | } |
| |
|
|
sprintf(sysUpTime, "%ld", get_uptime()); | sprintf(sysUpTime, "%ld", get_uptime()); |
| |
Sint32 retCode; | Sint32 retCode; |
retCode = snmp_add_var(snmpPdu, _SYSTEM_UP_TIME_OID, |
retCode = snmp_add_var( |
OID_LENGTH(_SYSTEM_UP_TIME_OID), 't', |
snmpPdu, |
|
_SYSTEM_UP_TIME_OID, |
|
OID_LENGTH(_SYSTEM_UP_TIME_OID), |
|
't', |
sysUpTime); | sysUpTime); |
| |
|
|
// Failed to add sysUpTime to the pdu | // Failed to add sysUpTime to the pdu |
if (retCode != 0) | if (retCode != 0) |
{ | { |
String errMsg = snmp_api_errstring(retCode); | String errMsg = snmp_api_errstring(retCode); |
| |
PEG_TRACE_STRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, |
Logger::put_l( |
"Failed to add sysUpTime to pdu: " + |
Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
errMsg); |
MessageLoaderParms( |
Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, |
|
Logger::WARNING, |
|
_MSG_ADD_SYSUPTIME_TO_PDU_FAILED_KEY, | _MSG_ADD_SYSUPTIME_TO_PDU_FAILED_KEY, |
_MSG_ADD_SYSUPTIME_TO_PDU_FAILED, | _MSG_ADD_SYSUPTIME_TO_PDU_FAILED, |
errMsg); |
errMsg)); |
} | } |
| |
// Add snmp trap to the PDU | // Add snmp trap to the PDU |
retCode = snmp_add_var(snmpPdu, _SNMPTRAP_OID, OID_LENGTH( |
retCode = snmp_add_var( |
_SNMPTRAP_OID), 'o', trapOid.getCString()); |
snmpPdu, |
|
_SNMPTRAP_OID, |
|
OID_LENGTH(_SNMPTRAP_OID), |
|
'o', |
|
trapOid.getCString()); |
| |
// Failed to add snmp trap to the pdu | // Failed to add snmp trap to the pdu |
if (retCode != 0) | if (retCode != 0) |
{ | { |
String errMsg = snmp_api_errstring(retCode); | String errMsg = snmp_api_errstring(retCode); |
| |
PEG_TRACE_STRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, |
Logger::put_l( |
"Failed to add snmp trap to pdu: " + |
Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
errMsg); |
MessageLoaderParms( |
Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, |
|
Logger::WARNING, |
|
_MSG_ADD_SNMP_TRAP_TO_PDU_FAILED_KEY, | _MSG_ADD_SNMP_TRAP_TO_PDU_FAILED_KEY, |
_MSG_ADD_SNMP_TRAP_TO_PDU_FAILED, | _MSG_ADD_SNMP_TRAP_TO_PDU_FAILED, |
errMsg); |
errMsg)); |
} | } |
| |
break; | break; |
|
|
PEG_METHOD_EXIT (); | PEG_METHOD_EXIT (); |
| |
throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_NOT_SUPPORTED, | throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_NOT_SUPPORTED, |
MessageLoaderParms(_MSG_VERSION_NOT_SUPPORTED_KEY, |
MessageLoaderParms( |
|
_MSG_VERSION_NOT_SUPPORTED_KEY, |
_MSG_VERSION_NOT_SUPPORTED)); | _MSG_VERSION_NOT_SUPPORTED)); |
} | } |
} | } |
|
|
CString trapOidCStr = trapOid.getCString(); | CString trapOidCStr = trapOid.getCString(); |
| |
char * trapOidCopy = strdup(trapOidCStr); | char * trapOidCopy = strdup(trapOidCStr); |
|
char* numericEntOid = (char*) malloc(strlen(trapOidCStr)+1); |
| |
#if !defined(PEGASUS_PLATFORM_WIN32_IX86_MSVC) |
try |
|
{ |
|
|
|
#if !defined(PEGASUS_OS_TYPE_WINDOWS) && !defined(PEGASUS_OS_ZOS) |
char *last; | char *last; |
for (const char* p = strtok_r(trapOidCopy, ".", &last); p; | for (const char* p = strtok_r(trapOidCopy, ".", &last); p; |
p=strtok_r(NULL, ".", &last)) | p=strtok_r(NULL, ".", &last)) |
|
|
| |
enterpriseOidLength = MAX_OID_LEN; | enterpriseOidLength = MAX_OID_LEN; |
| |
char * numericEntOid = (char *) malloc(strlen(trapOidCStr)); |
|
if (Contains(standard_traps, trapOid)) | if (Contains(standard_traps, trapOid)) |
{ | { |
// | // |
|
|
| |
} | } |
| |
|
SNMP_FREE(snmpPdu->enterprise); |
snmpPdu->enterprise = (oid*) malloc(enterpriseOidLength * sizeof(oid)); | snmpPdu->enterprise = (oid*) malloc(enterpriseOidLength * sizeof(oid)); |
memcpy(snmpPdu->enterprise, enterpriseOid, | memcpy(snmpPdu->enterprise, enterpriseOid, |
enterpriseOidLength * sizeof(oid)); | enterpriseOidLength * sizeof(oid)); |
| |
snmpPdu->enterprise_length = enterpriseOidLength; | snmpPdu->enterprise_length = enterpriseOidLength; |
|
} |
|
catch (...) |
|
{ |
|
free(trapOidCopy); |
|
free(numericEntOid); |
|
|
|
PEG_METHOD_EXIT(); |
|
throw; |
|
} |
| |
free(trapOidCopy); | free(trapOidCopy); |
free(numericEntOid); | free(numericEntOid); |