version 1.11, 2006/11/29 14:04:49
|
version 1.22, 2008/12/02 09:01:37
|
|
|
//%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. |
|
// |
|
////////////////////////////////////////////////////////////////////////// |
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
|
|
// 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_ENTER(TRC_IND_HANDLER, "snmpDeliverTrap_netsnmp::terminate"); | PEG_METHOD_ENTER(TRC_IND_HANDLER, "snmpDeliverTrap_netsnmp::terminate"); |
| |
|
// Shuts down the application, and appropriate clean up |
|
snmp_shutdown("snmpIndicationHandler"); |
|
|
SOCK_CLEANUP; | SOCK_CLEANUP; |
| |
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
|
|
struct snmp_pdu* snmpPdu; | struct snmp_pdu* snmpPdu; |
| |
// Creates a SNMP session | // Creates a SNMP session |
_createSession(targetHost, portNumber, securityName, |
_createSession(targetHost, targetHostFormat, portNumber, securityName, |
sessionHandle, sessionPtr); | sessionHandle, sessionPtr); |
| |
try | try |
|
|
} | } |
catch (Exception& e) | catch (Exception& e) |
{ | { |
PEG_TRACE_STRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, e.getMessage()); |
Logger::put_l(Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
|
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(); |
|
|
// 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, |
void*& sessionHandle, | void*& sessionHandle, |
|
|
// peername has format: targetHost:portNumber | // peername has format: targetHost:portNumber |
snmpSession.peername = | snmpSession.peername = |
(char*)malloc((size_t)(strlen(targetHostCStr) + 1 + 32)); | (char*)malloc((size_t)(strlen(targetHostCStr) + 1 + 32)); |
|
|
|
if (targetHostFormat == _IPV6_ADDRESS) |
|
{ |
|
sprintf(snmpSession.peername, "udp6:[%s]:%u", |
|
(const char*)targetHostCStr, |
|
portNumber); |
|
} |
|
else |
|
{ |
sprintf(snmpSession.peername, "%s:%u", | sprintf(snmpSession.peername, "%s:%u", |
(const char*)targetHostCStr, | (const char*)targetHostCStr, |
portNumber); | 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, |
|
|
| |
free(errStr); | free(errStr); |
| |
|
free(snmpSession.peername); |
|
|
throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, MessageLoaderParms( | throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, MessageLoaderParms( |
_MSG_GET_SESSION_POINTER_FAILED_KEY, | _MSG_GET_SESSION_POINTER_FAILED_KEY, |
exceptionStr)); | exceptionStr)); |
|
|
} | } |
catch (CIMException& e) | catch (CIMException& e) |
{ | { |
PEG_TRACE_STRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, |
|
e.getMessage()); |
|
Logger::put_l( | Logger::put_l( |
Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, | Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
|
MessageLoaderParms( |
_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; |
|
|
{ | { |
String errMsg = snmp_api_errstring(retCode); | String errMsg = snmp_api_errstring(retCode); |
| |
PEG_TRACE_STRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, |
|
"Failed to add sysUpTime to pdu: " + errMsg); |
|
Logger::put_l( | Logger::put_l( |
Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, | Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
|
MessageLoaderParms( |
_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 |
|
|
{ | { |
String errMsg = snmp_api_errstring(retCode); | String errMsg = snmp_api_errstring(retCode); |
| |
PEG_TRACE_STRING(TRC_DISCARDED_DATA, Tracer::LEVEL2, |
|
"Failed to add snmp trap to pdu: " + errMsg); |
|
Logger::put_l( | Logger::put_l( |
Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, | Logger::STANDARD_LOG, System::CIMSERVER, Logger::WARNING, |
|
MessageLoaderParms( |
_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; |
|
|
try | try |
{ | { |
| |
#if !defined(PEGASUS_PLATFORM_WIN32_IX86_MSVC) && !defined(PEGASUS_OS_ZOS) |
#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)) |