version 1.8, 2006/08/11 19:47:07
|
version 1.12, 2007/01/11 16:21:59
|
|
|
| |
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; |
|
|
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, |
|
"snmpDeliverTrap_netsnmp::terminate"); |
|
| |
SOCK_CLEANUP; | SOCK_CLEANUP; |
| |
|
|
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; |
|
|
_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, |
PEG_TRACE_STRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, e.getMessage()); |
e.getMessage ()); |
|
| |
Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, | Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, |
Logger::WARNING, | Logger::WARNING, |
|
|
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 |
|
|
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*)malloc((size_t)(strlen(targetHostCStr) + 1 + 32)); |
sprintf(snmpSession.peername, "%s:%u", (const char*)targetHostCStr, |
sprintf(snmpSession.peername, "%s:%u", |
|
(const char*)targetHostCStr, |
portNumber); | portNumber); |
| |
sessionHandle = snmp_sess_open(&snmpSession); | sessionHandle = snmp_sess_open(&snmpSession); |
|
|
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, |
throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, MessageLoaderParms( |
MessageLoaderParms(_MSG_GET_SESSION_POINTER_FAILED_KEY, |
_MSG_GET_SESSION_POINTER_FAILED_KEY, |
exceptionStr)); | exceptionStr)); |
} | } |
| |
|
|
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}; |
|
|
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)); |
} | } |
| |
|
|
{ | { |
PEG_TRACE_STRING (TRC_DISCARDED_DATA, Tracer::LEVEL2, | PEG_TRACE_STRING (TRC_DISCARDED_DATA, Tracer::LEVEL2, |
e.getMessage ()); | e.getMessage ()); |
Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, |
Logger::put_l( |
Logger::WARNING, |
Logger::STANDARD_LOG, System::CIMSERVER, 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()); |
|
|
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, | PEG_TRACE_STRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, |
"Failed to add sysUpTime to pdu: " + |
"Failed to add sysUpTime to pdu: " + errMsg); |
errMsg); |
Logger::put_l( |
Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, |
Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
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, | PEG_TRACE_STRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, |
"Failed to add snmp trap to pdu: " + |
"Failed to add snmp trap to pdu: " + errMsg); |
errMsg); |
Logger::put_l( |
Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, |
Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
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); |
|
|
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)); |
|
|
|
try |
|
{ |
| |
#if !defined(PEGASUS_PLATFORM_WIN32_IX86_MSVC) |
#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)) |
{ | { |
// | // |
|
|
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); |