(file) Return to snmpIndicationHandler.cpp CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Handler / snmpIndicationHandler

Diff for /pegasus/src/Pegasus/Handler/snmpIndicationHandler/snmpIndicationHandler.cpp between version 1.33 and 1.37

version 1.33, 2006/08/15 17:24:21 version 1.37, 2007/05/25 20:48:46
Line 49 
Line 49 
 #include "snmpDeliverTrap_stub.h" #include "snmpDeliverTrap_stub.h"
 #endif #endif
  
 // l10n  
 #include <Pegasus/Common/MessageLoader.h> #include <Pegasus/Common/MessageLoader.h>
  
 PEGASUS_USING_STD; PEGASUS_USING_STD;
Line 117 
Line 116 
     Array<String> propTYPEs;     Array<String> propTYPEs;
     Array<String> propVALUEs;     Array<String> propVALUEs;
  
     CIMProperty prop;      Array<String> mapStr;
     CIMQualifier trapQualifier;  
   
     Uint32 qualifierPos;  
   
     String propValue;  
   
     String mapstr1;  
     String mapstr2;  
  
     PEG_METHOD_ENTER (TRC_IND_HANDLER,     PEG_METHOD_ENTER (TRC_IND_HANDLER,
         "snmpIndicationHandler::handleIndication");         "snmpIndicationHandler::handleIndication");
  
     try     try
     {     {
           PEG_TRACE ((TRC_INDICATION_GENERATION, Tracer::LEVEL3,
               "snmpIndicationHandler %s:%s.%s processing %s Indication",
              (const char*)(nameSpace.getCString()),
              (const char*)(handler.getClassName().getString().getCString()),
              (const char*)(handler.getProperty(
              handler.findProperty(PEGASUS_PROPERTYNAME_NAME)).
              getValue().toString().getCString()),
              (const char*)(indication.getClassName().getString().
              getCString())));
         CIMClass indicationClass = _repository->getClass(         CIMClass indicationClass = _repository->getClass(
             nameSpace, indication.getClassName(), false, true,             nameSpace, indication.getClassName(), false, true,
             false, CIMPropertyList());             false, CIMPropertyList());
Line 140 
Line 140 
  
         for (Uint32 i=0; i < propertyCount; i++)         for (Uint32 i=0; i < propertyCount; i++)
         {         {
             prop = indication.getProperty(i);              CIMProperty prop = indication.getProperty(i);
  
             if (!prop.isUninitialized())              Uint32 propDeclPos = indicationClass.findProperty(prop.getName());
               if (propDeclPos != PEG_NOT_FOUND)
             {             {
                 CIMName propName = prop.getName();                  CIMProperty propDecl = indicationClass.getProperty(propDeclPos);
                 Uint32 propPos = indicationClass.findProperty(propName);  
                 if (propPos != PEG_NOT_FOUND)  
                 {  
                     CIMProperty trapProp = indicationClass.getProperty(propPos);  
  
                     qualifierPos = trapProp.findQualifier(CIMName ("MappingStrings"));                  Uint32 qualifierPos =
                       propDecl.findQualifier(CIMName("MappingStrings"));
                     if (qualifierPos != PEG_NOT_FOUND)                     if (qualifierPos != PEG_NOT_FOUND)
                     {                     {
                         trapQualifier = trapProp.getQualifier(qualifierPos);                      //
                       // We are looking for following fields:
                       // MappingStrings {"OID.IETF | SNMP." oidStr,
                       //     "DataType.IETF |" dataType}
                       // oidStr is the object identifier (e.g. "1.3.6.1.2.1.5..."
                       // dataType is either Integer, or OctetString,
                       // or OID
                       // Following is one example:
                       // MappingStrings {"OID.IETF | SNMP.1.3.6.6.3.1.1.5.2",
                       //    "DataType.IETF | Integer"}
                       //
  
                         mapstr1.clear();                      propDecl.getQualifier(qualifierPos).getValue().get(
                         mapstr1 = trapQualifier.getValue().toString();                          mapStr);
  
                         if ((mapstr1.find("OID.IETF") != PEG_NOT_FOUND) &&                      String oidStr, dataType;
                             (mapstr1.find("DataType.IETF") != PEG_NOT_FOUND))                      String mapStr1, mapStr2;
                         {                      Boolean isValidAuthority = false;
                             if (mapstr1.subString(0, 8) == "OID.IETF")                      Boolean isValidDataType = false;
   
                       for (Uint32 j=0; j < mapStr.size(); j++)
                             {                             {
                                 mapstr1 = mapstr1.subString(mapstr1.find("SNMP.")+5);                          Uint32 barPos = mapStr[j].find("|");
                                 if (mapstr1.find("|") != PEG_NOT_FOUND)  
                           if (barPos != PEG_NOT_FOUND)
                                 {                                 {
                                     mapstr2.clear();                              mapStr1 = mapStr[j].subString(0, barPos);
                                     mapstr2 = mapstr1.subString(0,                              mapStr2 = mapStr[j].subString(barPos + 1);
                                         mapstr1.find("DataType.IETF")-1);  
                                     propOIDs.append(mapstr2);  
  
                                     propValue.clear();                              _trimWhitespace(mapStr1);
                                     propValue = prop.getValue().toString();                              _trimWhitespace(mapStr2);
                                     propVALUEs.append(propValue);  
  
                                     mapstr2 = mapstr1.subString(mapstr1.find("|")+2);                              if ((mapStr1 == "OID.IETF") &&
                                     mapstr2 = mapstr2.subString(0, mapstr2.size()-1);                                  (String::compare(mapStr2,
                                     propTYPEs.append(mapstr2);                                   String("SNMP."), 5) == 0))
                               {
                                   isValidAuthority = true;
                                   oidStr = mapStr2.subString(5);
                                 }                                 }
                               else if (mapStr1 == "DataType.IETF")
                               {
                                   isValidDataType = true;
                                   dataType = mapStr2;
                               }
   
                               if (isValidAuthority && isValidDataType)
                               {
                                   propOIDs.append(oidStr);
                                   propTYPEs.append(dataType);
                                   propVALUEs.append(prop.getValue().toString());
   
                                   break;
                             }                             }
                         }                         }
                     }                     }
Line 191 
Line 215 
         // and passing this instance as it is to deliverTrap() call         // and passing this instance as it is to deliverTrap() call
  
         Uint32 targetHostPos = handler.findProperty(CIMName ("TargetHost"));         Uint32 targetHostPos = handler.findProperty(CIMName ("TargetHost"));
         Uint32 targetHostFormatPos = handler.findProperty(CIMName ("TargetHostFormat"));          Uint32 targetHostFormatPos =
         Uint32 otherTargetHostFormatPos = handler.findProperty(CIMName (              handler.findProperty(CIMName("TargetHostFormat"));
                                       "OtherTargetHostFormat"));          Uint32 otherTargetHostFormatPos =
               handler.findProperty(CIMName("OtherTargetHostFormat"));
         Uint32 portNumberPos = handler.findProperty(CIMName ("PortNumber"));         Uint32 portNumberPos = handler.findProperty(CIMName ("PortNumber"));
         Uint32 snmpVersionPos = handler.findProperty(CIMName ("SNMPVersion"));         Uint32 snmpVersionPos = handler.findProperty(CIMName ("SNMPVersion"));
         Uint32 securityNamePos =  handler.findProperty(CIMName ("SNMPSecurityName"));          Uint32 securityNamePos =
               handler.findProperty(CIMName("SNMPSecurityName"));
         Uint32 engineIDPos =  handler.findProperty(CIMName ("SNMPEngineID"));         Uint32 engineIDPos =  handler.findProperty(CIMName ("SNMPEngineID"));
  
         if ((targetHostPos != PEG_NOT_FOUND) &&          if (targetHostPos == PEG_NOT_FOUND)
             (targetHostFormatPos != PEG_NOT_FOUND) &&          {
             (snmpVersionPos != PEG_NOT_FOUND))              PEG_TRACE((TRC_DISCARDED_DATA, Tracer::LEVEL3,
                   "Target host is not set for IndicationHandlerSNMPMapper %s"
                   " Indication.",
                   (const char*)(indication.getClassName().getString().
                   getCString())));
               PEG_METHOD_EXIT();
               throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, MessageLoaderParms(
                   "Handler.snmpIndicationHandler.snmpIndicationHandler."
                   "INVALID_SNMP_INSTANCE",
                   "Invalid IndicationHandlerSNMPMapper instance"));
           }
           if (targetHostFormatPos == PEG_NOT_FOUND)
           {
               PEG_TRACE((TRC_DISCARDED_DATA, Tracer::LEVEL3,
                   "Target host format is not set for IndicationHandlerSNMPMapper"
                   " %s Indication.",
                   (const char*)(indication.getClassName().getString().
                   getCString())));
               PEG_METHOD_EXIT();
               throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, MessageLoaderParms(
                   "Handler.snmpIndicationHandler.snmpIndicationHandler."
                   "INVALID_SNMP_INSTANCE",
                   "Invalid IndicationHandlerSNMPMapper instance"));
           }
           if (snmpVersionPos == PEG_NOT_FOUND)
           {
               PEG_TRACE((TRC_DISCARDED_DATA, Tracer::LEVEL3,
                   "SNMP Version is not set for IndicationHandlerSNMPMapper %s"
                   " Indication.",
                   (const char*)(indication.getClassName().getString().
                   getCString())));
               PEG_METHOD_EXIT();
               throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, MessageLoaderParms(
                   "Handler.snmpIndicationHandler.snmpIndicationHandler."
                   "INVALID_SNMP_INSTANCE",
                   "Invalid IndicationHandlerSNMPMapper instance"));
           }
           else
         {         {
             // properties from the handler instance             // properties from the handler instance
             String targetHost;             String targetHost;
Line 213 
Line 276 
             Uint32 portNumber;             Uint32 portNumber;
  
             String trapOid;             String trapOid;
               Boolean trapOidAvailable = false;
               String exceptionStr;
             //             //
             //  Get snmpTrapOid from context             //  Get snmpTrapOid from context
             //             //
             if (context.contains(SnmpTrapOidContainer::NAME))             if (context.contains(SnmpTrapOidContainer::NAME))
             {             {
                 SnmpTrapOidContainer trapContainer = context.get                  SnmpTrapOidContainer trapContainer =
                     (SnmpTrapOidContainer::NAME);                      context.get(SnmpTrapOidContainer::NAME);
  
                 trapOid = trapContainer.getSnmpTrapOid();                 trapOid = trapContainer.getSnmpTrapOid();
                   trapOidAvailable = true;
             }             }
             else             else
             {             {
                 // get trapOid from indication Class                 // get trapOid from indication Class
  
                 Uint32 pos = indicationClass.findQualifier(CIMName ("MappingStrings"));                  Uint32 pos =
                       indicationClass.findQualifier(CIMName("MappingStrings"));
                 if (pos != PEG_NOT_FOUND)                 if (pos != PEG_NOT_FOUND)
                 {                 {
                     trapOid = indicationClass.getQualifier(pos).getValue().toString();                      Array<String> classMapStr;
                       indicationClass.getQualifier(pos).getValue().
                           get(classMapStr);
  
                     trapOid = trapOid.subString(11, PEG_NOT_FOUND);                      for (Uint32 i=0; i < classMapStr.size(); i++)
                       {
                           Uint32 barPos = classMapStr[i].find("|");
  
                     if ((String::compare(trapOid, "SNMP.", 5)) == 0)                          if (barPos != PEG_NOT_FOUND)
                     {                     {
                         trapOid = trapOid.subString(5, (trapOid.size()-6));                              String authorityName =
                                   classMapStr[i].subString(0, barPos);
                               String oidStr = classMapStr[i].subString(
                                   barPos+1, PEG_NOT_FOUND);
   
                               _trimWhitespace(authorityName);
                               _trimWhitespace(oidStr);
   
                               if ((authorityName == "OID.IETF") &&
                                   (String::compare(oidStr,
                                    String("SNMP."), 5) == 0))
                               {
                                   trapOid = oidStr.subString(5);
                                   trapOidAvailable = true;
                                   break;
                     }                     }
                     else                          }
                       }
   
                       if (!trapOidAvailable)
                     {                     {
                           exceptionStr = "No MappingStrings for snmp trap"
                               "is specified for class: ";
   
                           exceptionStr.append(
                               indication.getClassName().getString());
   
                         PEG_TRACE_STRING(TRC_IND_HANDLER, Tracer::LEVEL4,                         PEG_TRACE_STRING(TRC_IND_HANDLER, Tracer::LEVEL4,
                                          "Invalid MappingStrings Value " + trapOid);                              exceptionStr);
                         PEG_METHOD_EXIT();                         PEG_METHOD_EXIT();
                         // l10n  
                         // throw PEGASUS_CIM_EXCEPTION(CIM_ERR_FAILED, "Invalid MappingStrings Value");  
                         throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED,                         throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED,
                                                    MessageLoaderParms("Handler.snmpIndicationHandler.snmpIndicationHandler.INVALID_MS_VALUE",                              MessageLoaderParms(
                                                                        "Invalid MappingStrings Value"));                                  "Handler.snmpIndicationHandler."
                                   "snmpIndicationHandler.NO_MS_FOR_SNMP_TRAP",
                                   exceptionStr));
                     }                     }
                 }                 }
                 else                 else
                 {                 {
                     PEG_TRACE_STRING(TRC_IND_HANDLER, Tracer::LEVEL4,                      PEG_TRACE_CSTRING(TRC_IND_HANDLER, Tracer::LEVEL4,
                                  "Qualifier MappingStrings can not be found.");                                  "Qualifier MappingStrings can not be found.");
                     PEG_METHOD_EXIT();                     PEG_METHOD_EXIT();
                     //L10N_ TODO DONE                      MessageLoaderParms parms(
                     //throw PEGASUS_CIM_EXCEPTION(CIM_ERR_FAILED, "Qualifier MappingStrings can not be found");                          "Handler.snmpIndicationHandler.snmpIndicationHandler."
                     MessageLoaderParms parms("Handler.snmpIndicationHandler.snmpIndicationHandler.QUALIFIER_MAPPINGS_NOT_FOUND",                              "QUALIFIER_MAPPINGS_NOT_FOUND",
                                                                  "Qualifier MappingStrings can not be found");                                                                  "Qualifier MappingStrings can not be found");
                     throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, parms);                     throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, parms);
                 }                 }
             }             }
  
             handler.getProperty(targetHostPos).getValue().get(targetHost);             handler.getProperty(targetHostPos).getValue().get(targetHost);
             handler.getProperty(targetHostFormatPos).getValue().get(targetHostFormat);              handler.getProperty(targetHostFormatPos).getValue().get(
                   targetHostFormat);
             if (otherTargetHostFormatPos != PEG_NOT_FOUND)             if (otherTargetHostFormatPos != PEG_NOT_FOUND)
             {             {
                 handler.getProperty(otherTargetHostFormatPos).getValue().get                  handler.getProperty(otherTargetHostFormatPos).getValue().get(
                     (otherTargetHostFormat);                      otherTargetHostFormat);
             }             }
             if (portNumberPos != PEG_NOT_FOUND)             if (portNumberPos != PEG_NOT_FOUND)
             {             {
Line 283 
Line 379 
             handler.getProperty(snmpVersionPos).getValue().get(snmpVersion);             handler.getProperty(snmpVersionPos).getValue().get(snmpVersion);
             if (securityNamePos != PEG_NOT_FOUND)             if (securityNamePos != PEG_NOT_FOUND)
             {             {
                 handler.getProperty(securityNamePos).getValue().get(securityName);                  handler.getProperty(securityNamePos).getValue().get(
                       securityName);
             }             }
             if (engineIDPos != PEG_NOT_FOUND)             if (engineIDPos != PEG_NOT_FOUND)
             {             {
                 handler.getProperty(engineIDPos).getValue().get(engineID);                 handler.getProperty(engineIDPos).getValue().get(engineID);
             }             }
  
               PEG_TRACE ((TRC_INDICATION_GENERATION, Tracer::LEVEL3,
                  "snmpIndicationHandler sending %s Indication trap %s to target"
                  " host %s target port %d",
                  (const char*)(indication.getClassName().getString().
                  getCString()),
                  (const char*)(trapOid.getCString()),
                  (const char*)(targetHost.getCString()),portNumber));
             _snmpTrapSender->deliverTrap(             _snmpTrapSender->deliverTrap(
                 trapOid,                 trapOid,
                 securityName,                 securityName,
Line 302 
Line 406 
                 propOIDs,                 propOIDs,
                 propTYPEs,                 propTYPEs,
                 propVALUEs);                 propVALUEs);
         }  
         else  
         {  
             PEG_TRACE_STRING(TRC_IND_HANDLER, Tracer::LEVEL4,  
                 "Invalid IndicationHandlerSNMPMapper instance.");  
             PEG_METHOD_EXIT();  
           // l10n  
  
           // throw PEGASUS_CIM_EXCEPTION(CIM_ERR_FAILED,          PEG_TRACE ((TRC_INDICATION_GENERATION, Tracer::LEVEL3,
           // "Invalid IndicationHandlerSNMPMapper instance");             "%s Indication trap %s sent to target host %s target port %d "
              "successfully",
           throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED,             (const char*)(indication.getClassName().getString().getCString()),
                                      MessageLoaderParms("Handler.snmpIndicationHandler.snmpIndicationHandler.INVALID_SNMP_INSTANCE",             (const char*)(trapOid.getCString()),
                                                         "Invalid IndicationHandlerSNMPMapper instance"));             (const char*)(targetHost.getCString()),portNumber));
         }         }
     }     }
     catch (CIMException & c)     catch (CIMException & c)
     {     {
         PEG_TRACE_STRING(TRC_IND_HANDLER, Tracer::LEVEL4, c.getMessage());         PEG_TRACE_STRING(TRC_IND_HANDLER, Tracer::LEVEL4, c.getMessage());
         PEG_METHOD_EXIT();         PEG_METHOD_EXIT();
   
         throw PEGASUS_CIM_EXCEPTION (CIM_ERR_FAILED, c.getMessage());         throw PEGASUS_CIM_EXCEPTION (CIM_ERR_FAILED, c.getMessage());
     }     }
     catch (Exception& e)     catch (Exception& e)
Line 334 
Line 430 
     }     }
     catch (...)     catch (...)
     {     {
         PEG_TRACE_STRING(TRC_IND_HANDLER, Tracer::LEVEL4,          PEG_TRACE_CSTRING(TRC_IND_HANDLER, Tracer::LEVEL4,
                 "Failed to deliver trap.");                 "Failed to deliver trap.");
         PEG_METHOD_EXIT();         PEG_METHOD_EXIT();
  
         throw PEGASUS_CIM_EXCEPTION_L (CIM_ERR_FAILED,          throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_FAILED, MessageLoaderParms(
                 MessageLoaderParms("Handler.snmpIndicationHandler.snmpIndicationHandler.FAILED_TO_DELIVER_TRAP",              "Handler.snmpIndicationHandler.snmpIndicationHandler."
                   "FAILED_TO_DELIVER_TRAP",
                                    "Failed to deliver trap."));                                    "Failed to deliver trap."));
     }     }
       PEG_METHOD_EXIT();
   }
   
   void snmpIndicationHandler::_trimWhitespace(
       String & nameStr)
   {
       PEG_METHOD_ENTER(TRC_IND_HANDLER,
           "snmpIndicationHandler::_trimWhitespace");
   
       Uint32 ps = 0;
       // skip begining whitespace
       for (ps = 0; ps < nameStr.size(); ps++)
       {
           if (nameStr[ps] != ' ')
           {
               break;
           }
       }
   
       if (ps != 0)
       {
           nameStr.remove(0, ps);
       }
   
       // skip the appended whitespace
       for (ps = nameStr.size(); ps != 0; ps--)
       {
           if (nameStr[ps-1] != ' ')
           {
               break;
           }
       }
   
       if (ps !=  nameStr.size())
       {
           nameStr.remove(ps);
       }
  
     PEG_METHOD_EXIT();     PEG_METHOD_EXIT();
 } }


Legend:
Removed from v.1.33  
changed lines
  Added in v.1.37

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2