version 1.70, 2008/03/18 15:32:50
|
version 1.80, 2009/12/15 11:39:40
|
|
|
//%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 "JMPIProviderManager.h" | #include "JMPIProviderManager.h" |
|
|
| |
#include "Convert.h" | #include "Convert.h" |
| |
|
|
|
// |
|
// The following tests were added to allow the provider to supply a |
|
// CIMObjectPath in the response. Before this, the path was always |
|
// rebuild by the response functions from the instance. This resulted |
|
// in cases where the key properties were not in the returned instance |
|
// (ex. excluded by the property list) so that the path could not be built. |
|
// The preferred behavior is for the provider to build the path on response. |
|
// However, to cover existing providers the alternate of allowing the |
|
// ProviderManager has been kept if the path in the instance is not considered |
|
// to exist. |
|
// PLEASE: provider writers build/set a proper path into returned objects |
|
// See bug 8062 |
|
|
|
/* |
|
local function to implement the CIMObjectPath required for a response |
|
object. |
|
If there is a path defined in the instance, we simply return this path. |
|
If not, we use the class to build a path from the instance. |
|
Note that we are depending on some value in the keybindings to determine |
|
if we have a path. |
|
*/ |
|
|
|
void _fixCIMObjectPath(CIMInstance* instance, CIMClass& cls) |
|
{ |
|
CIMObjectPath op = instance->getPath(); |
|
const Array<CIMKeyBinding> kb = op.getKeyBindings(); |
|
if (kb.size() == 0) |
|
{ |
|
CIMObjectPath iop = instance->buildPath(cls); |
|
/* Fix for 4237*/ |
|
iop.setNameSpace(op.getNameSpace()); |
|
instance->setPath(iop); |
|
} |
|
} |
|
|
void JMPIProviderManager::debugPrintMethodPointers (JNIEnv *env, jclass jc) | void JMPIProviderManager::debugPrintMethodPointers (JNIEnv *env, jclass jc) |
{ | { |
PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, | PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, |
|
|
for (int i = 0; i < (int)(sizeof (methodNames)/sizeof (methodNames[0])); i++) | for (int i = 0; i < (int)(sizeof (methodNames)/sizeof (methodNames[0])); i++) |
{ | { |
jmethodID id = env->GetMethodID(jc,methodNames[i][1], methodNames[i][2]); | jmethodID id = env->GetMethodID(jc,methodNames[i][1], methodNames[i][2]); |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL3, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL4, |
"Method: %s, %s, id = %p", | "Method: %s, %s, id = %p", |
methodNames[i][0],methodNames[i][1],id)); | methodNames[i][0],methodNames[i][1],id)); |
| |
|
|
jmidToString); | jmidToString); |
const char *pszResult = env->GetStringUTFChars(jstringResult, 0); | const char *pszResult = env->GetStringUTFChars(jstringResult, 0); |
| |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL3, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL4, |
"Introspect java object: %s",pszResult)); | "Introspect java object: %s",pszResult)); |
| |
env->ReleaseStringUTFChars (jstringResult, pszResult); | env->ReleaseStringUTFChars (jstringResult, pszResult); |
|
|
} | } |
else | else |
{ | { |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL3, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
"inferfaceType not found."); | "inferfaceType not found."); |
fRet = false; | fRet = false; |
} | } |
|
|
} | } |
else | else |
{ | { |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL3, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
"inferfaceVersion not found."); | "inferfaceVersion not found."); |
fRet = false; | fRet = false; |
} | } |
|
|
response = handleSubscriptionInitCompleteRequest (request); | response = handleSubscriptionInitCompleteRequest (request); |
break; | break; |
| |
|
case CIM_INDICATION_SERVICE_DISABLED_REQUEST_MESSAGE: |
|
response = handleIndicationServiceDisabledRequest (request); |
|
break; |
|
|
default: | default: |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"Unsupported Request %d", | "Unsupported Request %d", |
request->getType() | request->getType() |
)); | )); |
|
|
| |
#define HandlerCatch(handler) \ | #define HandlerCatch(handler) \ |
catch(CIMException & e) \ | catch(CIMException & e) \ |
{ PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, \ |
{ PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1,"CIMException: %s", \ |
"Exception: " + e.getMessage()); \ |
(const char*)e.getMessage().getCString())); \ |
handler.setStatus(e.getCode(), e.getContentLanguages(), \ | handler.setStatus(e.getCode(), e.getContentLanguages(), \ |
e.getMessage()); \ | e.getMessage()); \ |
} \ | } \ |
catch(Exception & e) \ | catch(Exception & e) \ |
{ PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, \ |
{ PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1,"Exception: %s", \ |
"Exception: " + e.getMessage()); \ |
(const char*)e.getMessage().getCString())); \ |
handler.setStatus(CIM_ERR_FAILED, e.getContentLanguages(), \ | handler.setStatus(CIM_ERR_FAILED, e.getContentLanguages(), \ |
e.getMessage()); \ | e.getMessage()); \ |
} \ | } \ |
catch(...) \ | catch(...) \ |
{ PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, \ |
{ PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, \ |
"Exception: Unknown"); \ | "Exception: Unknown"); \ |
handler.setStatus(CIM_ERR_FAILED, "Unknown error."); \ | handler.setStatus(CIM_ERR_FAILED, "Unknown error."); \ |
} | } |
| |
static jobjectArray getList(JvmVector *jv, JNIEnv *env, CIMPropertyList &list) | static jobjectArray getList(JvmVector *jv, JNIEnv *env, CIMPropertyList &list) |
{ | { |
Uint32 s=list.size(); |
|
jobjectArray pl=NULL; | jobjectArray pl=NULL; |
if (s) { |
if (!list.isNull()) |
|
{ |
|
Uint32 s=list.size(); |
jstring initial=env->NewString(NULL,0); | jstring initial=env->NewString(NULL,0); |
pl=(jobjectArray)env->NewObjectArray(s,jv->StringClassRef,initial); | pl=(jobjectArray)env->NewObjectArray(s,jv->StringClassRef,initial); |
for (Uint32 i=0; i<s; i++) { |
for (Uint32 i=0; i<s; i++) |
|
{ |
env->SetObjectArrayElement | env->SetObjectArrayElement |
(pl,i,env->NewStringUTF(list[i].getString().getCString())); | (pl,i,env->NewStringUTF(list[i].getString().getCString())); |
} | } |
|
|
| |
try | try |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL3, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL4, |
"handleGetInstanceRequest: " | "handleGetInstanceRequest: " |
"name space = %s class name = %s", | "name space = %s class name = %s", |
(const char*)request->nameSpace.getString().getCString(), | (const char*)request->nameSpace.getString().getCString(), |
|
|
| |
if (!env) | if (!env) |
{ | { |
PEG_TRACE_CSTRING( TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING( TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleGetInstanceRequest:" | "handleGetInstanceRequest:" |
"Could not initialize the JVM (Java Virtual Machine) " | "Could not initialize the JVM (Java Virtual Machine) " |
"runtime environment."); | "runtime environment."); |
|
|
if (id != NULL) | if (id != NULL) |
{ | { |
eMethodFound = METHOD_INSTANCEPROVIDER; | eMethodFound = METHOD_INSTANCEPROVIDER; |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleGetInstanceRequest: " | "handleGetInstanceRequest: " |
"Found METHOD_INSTANCEPROVIDER."); | "Found METHOD_INSTANCEPROVIDER."); |
} | } |
|
|
if (id != NULL) | if (id != NULL) |
{ | { |
eMethodFound = METHOD_CIMINSTANCEPROVIDER; | eMethodFound = METHOD_CIMINSTANCEPROVIDER; |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleGetInstanceRequest: " | "handleGetInstanceRequest: " |
"Found METHOD_CIMINSTANCEPROVIDER."); | "Found METHOD_CIMINSTANCEPROVIDER."); |
} | } |
|
|
| |
if (id == NULL) | if (id == NULL) |
{ | { |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleGetInstanceRequest: No method provider found!"); | "handleGetInstanceRequest: No method provider found!"); |
| |
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleGetInstanceRequest: " | "handleGetInstanceRequest: " |
"Caught CIMExcetion(METHOD_CIMINSTANCEPROVIDER) " | "Caught CIMExcetion(METHOD_CIMINSTANCEPROVIDER) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleGetInstanceRequest: " | "handleGetInstanceRequest: " |
"Caught CIMExcetion (METHOD_INSTANCEPROVIDER2) " | "Caught CIMExcetion (METHOD_INSTANCEPROVIDER2) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleGetInstanceRequest: " | "handleGetInstanceRequest: " |
"Caught CIMExcetion (METHOD_INSTANCEPROVIDER) " | "Caught CIMExcetion (METHOD_INSTANCEPROVIDER) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
| |
case METHOD_UNKNOWN: | case METHOD_UNKNOWN: |
{ | { |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleGetInstanceRequest: Unknown method provider!"); | "handleGetInstanceRequest: Unknown method provider!"); |
break; | break; |
} | } |
|
|
| |
if (!env) | if (!env) |
{ | { |
PEG_TRACE_CSTRING( TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING( TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstanceRequest: " | "handleEnumerateInstanceRequest: " |
"Could not initialize the JVM (Java Virtual Machine) " | "Could not initialize the JVM (Java Virtual Machine) " |
"runtime environment."); | "runtime environment."); |
|
|
| |
if (id == NULL) | if (id == NULL) |
{ | { |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstances: No method provider found!"); | "handleEnumerateInstances: No method provider found!"); |
| |
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstances: " | "handleEnumerateInstances: " |
"Caught CIMExcetion(METHOD_CIMINSTANCEPROVIDER) " | "Caught CIMExcetion(METHOD_CIMINSTANCEPROVIDER) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstances: " | "handleEnumerateInstances: " |
"Caught CIMExcetion " | "Caught CIMExcetion " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
throw; | throw; |
} | } |
| |
const CIMObjectPath& op = ciRet->getPath(); |
|
CIMObjectPath iop = ciRet->buildPath(cls); |
|
|
|
JMPIjvm::checkException(env); | JMPIjvm::checkException(env); |
| |
handler.deliver(*ciRet); | handler.deliver(*ciRet); |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstances: " | "handleEnumerateInstances: " |
"Caught CIMExcetion(METHOD_CIMINSTANCEPROVIDER) " | "Caught CIMExcetion(METHOD_CIMINSTANCEPROVIDER) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstancesRequest: " | "handleEnumerateInstancesRequest: " |
"Caught CIMExcetion " | "Caught CIMExcetion " |
"cimom_handle->getClass(%s): %s ", | "cimom_handle->getClass(%s): %s ", |
|
|
throw; | throw; |
} | } |
| |
const CIMObjectPath& op = ciRet->getPath(); |
|
CIMObjectPath iop = ciRet->buildPath(cls); |
|
|
|
JMPIjvm::checkException(env); | JMPIjvm::checkException(env); |
| |
handler.deliver(*ciRet); | handler.deliver(*ciRet); |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstancesRequest: " | "handleEnumerateInstancesRequest: " |
"Caught CIMExcetion(METHOD_INSTANCEPROVIDER2) " | "Caught CIMExcetion(METHOD_INSTANCEPROVIDER2) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstancesRequest: " | "handleEnumerateInstancesRequest: " |
"Caught CIMExcetion " | "Caught CIMExcetion " |
"cimom_handle->getClass(%s): %s ", | "cimom_handle->getClass(%s): %s ", |
|
|
throw; | throw; |
} | } |
| |
const CIMObjectPath& op = ciRet->getPath(); |
_fixCIMObjectPath(ciRet, cls); |
CIMObjectPath iop = ciRet->buildPath(cls); |
|
| |
JMPIjvm::checkException(env); | JMPIjvm::checkException(env); |
| |
iop.setNameSpace(op.getNameSpace()); |
|
|
|
ciRet->setPath(iop); |
|
/* Fix for 4237*/ |
|
|
|
handler.deliver(*ciRet); | handler.deliver(*ciRet); |
} | } |
} | } |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstancesRequest: " | "handleEnumerateInstancesRequest: " |
"Caught CIMExcetion(METHOD_INSTANCEPROVIDER) " | "Caught CIMExcetion(METHOD_INSTANCEPROVIDER) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstancesRequest: " | "handleEnumerateInstancesRequest: " |
"Caught CIMExcetion " | "Caught CIMExcetion " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
throw; | throw; |
} | } |
|
_fixCIMObjectPath(ciRet, cls); |
const CIMObjectPath& op = ciRet->getPath(); |
|
CIMObjectPath iop = ciRet->buildPath(cls); |
|
| |
JMPIjvm::checkException(env); | JMPIjvm::checkException(env); |
| |
iop.setNameSpace(op.getNameSpace()); |
|
|
|
ciRet->setPath(iop); |
|
/* Fix for 4237*/ |
|
|
|
handler.deliver(*ciRet); | handler.deliver(*ciRet); |
} | } |
} | } |
|
|
| |
case METHOD_UNKNOWN: | case METHOD_UNKNOWN: |
{ | { |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstancesRequest: Unknown method provider!"); | "handleEnumerateInstancesRequest: Unknown method provider!"); |
break; | break; |
} | } |
|
|
JNIEnv *env = NULL; | JNIEnv *env = NULL; |
| |
try { | try { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL3, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL4, |
"handleEnumerateInstanceNamesRequest: " | "handleEnumerateInstanceNamesRequest: " |
"name space = %s class name = %s", | "name space = %s class name = %s", |
(const char*)request->nameSpace.getString().getCString(), | (const char*)request->nameSpace.getString().getCString(), |
|
|
| |
if (id == NULL) | if (id == NULL) |
{ | { |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstanceNamesRequest: " | "handleEnumerateInstanceNamesRequest: " |
"No method provider found!"); | "No method provider found!"); |
| |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstanceNamesRequest: " | "handleEnumerateInstanceNamesRequest: " |
"Caught CIMExcetion(METHOD_CIMINSTANCEPROVIDER) " | "Caught CIMExcetion(METHOD_CIMINSTANCEPROVIDER) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstanceNamesRequest: " | "handleEnumerateInstanceNamesRequest: " |
"Caught CIMExcetion(METHOD_CIMINSTANCEPROVIDER2) " | "Caught CIMExcetion(METHOD_CIMINSTANCEPROVIDER2) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstanceNamesRequest: " | "handleEnumerateInstanceNamesRequest: " |
"Caught CIMExcetion(METHOD_INSTANCEPROVIDER2) " | "Caught CIMExcetion(METHOD_INSTANCEPROVIDER2) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
} | } |
catch (CIMException e) | catch (CIMException e) |
{ | { |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE((TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstanceNamesRequest: " | "handleEnumerateInstanceNamesRequest: " |
"Caught CIMExcetion(METHOD_INSTANCEPROVIDER) " | "Caught CIMExcetion(METHOD_INSTANCEPROVIDER) " |
"during cimom_handle->getClass(%s): %s ", | "during cimom_handle->getClass(%s): %s ", |
|
|
| |
case METHOD_UNKNOWN: | case METHOD_UNKNOWN: |
{ | { |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleEnumerateInstanceNamesRequest: " | "handleEnumerateInstanceNamesRequest: " |
"Unknown method provider!"); | "Unknown method provider!"); |
break; | break; |
|
|
| |
if (!env) | if (!env) |
{ | { |
PEG_TRACE_CSTRING( TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING( TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleCreateInstanceRequest: " | "handleCreateInstanceRequest: " |
"Could not initialize the JVM (Java Virtual Machine) " | "Could not initialize the JVM (Java Virtual Machine) " |
"runtime environment."); | "runtime environment."); |
|
|
| |
if (id == NULL) | if (id == NULL) |
{ | { |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleCreateInstanceRequest: No method provider found!"); | "handleCreateInstanceRequest: No method provider found!"); |
| |
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
|
|
| |
case METHOD_UNKNOWN: | case METHOD_UNKNOWN: |
{ | { |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING(TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleCreateInstanceRequest: Unknown method provider!"); | "handleCreateInstanceRequest: Unknown method provider!"); |
break; | break; |
} | } |
|
|
| |
if (!env) | if (!env) |
{ | { |
PEG_TRACE_CSTRING( TRC_PROVIDERMANAGER, Tracer::LEVEL2, |
PEG_TRACE_CSTRING( TRC_PROVIDERMANAGER, Tracer::LEVEL1, |
"handleModifyInstanceRequest: " | "handleModifyInstanceRequest: " |
"Could not initialize the JVM (Java Virtual Machine) " | "Could not initialize the JVM (Java Virtual Machine) " |
"runtime environment."); | "runtime environment."); |
|
|
throw; | throw; |
} | } |
| |
const CIMObjectPath& op = ciRet->getPath(); |
_fixCIMObjectPath(ciRet, cls); |
CIMObjectPath iop = ciRet->buildPath(cls); |
|
| |
JMPIjvm::checkException(env); | JMPIjvm::checkException(env); |
| |
iop.setNameSpace(op.getNameSpace()); |
|
ciRet->setPath(iop); |
|
|
|
handler.deliver(*ciRet); | handler.deliver(*ciRet); |
} | } |
} | } |
|
|
throw; | throw; |
} | } |
| |
const CIMObjectPath& op = ciRet->getPath(); |
_fixCIMObjectPath(ciRet, cls); |
CIMObjectPath iop = ciRet->buildPath(cls); |
|
| |
JMPIjvm::checkException(env); | JMPIjvm::checkException(env); |
| |
iop.setNameSpace(op.getNameSpace()); |
|
ciRet->setPath(iop); |
|
|
|
handler.deliver(*ciRet); | handler.deliver(*ciRet); |
} | } |
} | } |
|
|
throw; | throw; |
} | } |
| |
const CIMObjectPath& op = ciRet->getPath(); |
_fixCIMObjectPath(ciRet, cls); |
CIMObjectPath iop = ciRet->buildPath(cls); |
|
| |
JMPIjvm::checkException(env); | JMPIjvm::checkException(env); |
| |
iop.setNameSpace(op.getNameSpace()); |
|
ciRet->setPath(iop); |
|
|
|
handler.deliver(*ciRet); | handler.deliver(*ciRet); |
} | } |
} | } |
|
|
throw; | throw; |
} | } |
| |
const CIMObjectPath& op = ciRet->getPath(); |
_fixCIMObjectPath(ciRet, cls); |
CIMObjectPath iop = ciRet->buildPath(cls); |
|
| |
JMPIjvm::checkException(env); | JMPIjvm::checkException(env); |
| |
iop.setNameSpace(op.getNameSpace()); |
|
ciRet->setPath(iop); |
|
|
|
handler.deliver(*ciRet); | handler.deliver(*ciRet); |
} | } |
} | } |
|
|
throw; | throw; |
} | } |
| |
const CIMObjectPath& op = ciRet->getPath(); |
_fixCIMObjectPath(ciRet, cls); |
CIMObjectPath iop = ciRet->buildPath(cls); |
|
| |
JMPIjvm::checkException(env); | JMPIjvm::checkException(env); |
| |
iop.setNameSpace(op.getNameSpace()); |
CIMObject coRet(*ciRet); |
ciRet->setPath(iop); |
handler.deliver(coRet); |
|
|
handler.deliver(*ciRet); |
|
} | } |
} | } |
handler.complete(); | handler.complete(); |
|
|
iop.setNameSpace(op.getNameSpace()); | iop.setNameSpace(op.getNameSpace()); |
ciRet->setPath(iop); | ciRet->setPath(iop); |
| |
handler.deliver(*ciRet); |
CIMObject coRet(*ciRet); |
|
handler.deliver(coRet); |
} | } |
} | } |
handler.complete(); | handler.complete(); |
|
|
iop.setNameSpace(op.getNameSpace()); | iop.setNameSpace(op.getNameSpace()); |
ciRet->setPath(iop); | ciRet->setPath(iop); |
| |
handler.deliver(*ciRet); |
CIMObject coRet(*ciRet); |
|
handler.deliver(coRet); |
} | } |
} | } |
handler.complete(); | handler.complete(); |
|
|
iop.setNameSpace(op.getNameSpace()); | iop.setNameSpace(op.getNameSpace()); |
ciRet->setPath(iop); | ciRet->setPath(iop); |
| |
handler.deliver(*ciRet); |
CIMObject coRet(*ciRet); |
|
handler.deliver(coRet); |
} | } |
} | } |
handler.complete(); | handler.complete(); |
|
|
String& providerName, | String& providerName, |
String& location) | String& location) |
{ | { |
Uint32 pos = pInstance.findProperty(CIMName ("Name")); |
Uint32 pos = pInstance.findProperty(PEGASUS_PROPERTYNAME_NAME); |
pInstance.getProperty(pos).getValue().get(providerName); | pInstance.getProperty(pos).getValue().get(providerName); |
| |
pos = pmInstance.findProperty(CIMName ("Location")); | pos = pmInstance.findProperty(CIMName ("Location")); |
|
|
// get provider module name | // get provider module name |
String moduleName; | String moduleName; |
CIMInstance mInstance = request->providerModule; | CIMInstance mInstance = request->providerModule; |
Uint32 pos = mInstance.findProperty(CIMName ("Name")); |
Uint32 pos = mInstance.findProperty(PEGASUS_PROPERTYNAME_NAME); |
| |
if(pos != PEG_NOT_FOUND) | if(pos != PEG_NOT_FOUND) |
{ | { |
|
|
return(response); | return(response); |
} | } |
| |
|
Message* JMPIProviderManager::handleIndicationServiceDisabledRequest( |
|
Message* message) |
|
{ |
|
PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, |
|
"JMPIProviderManager::_handleIndicationServiceDisabledRequest"); |
|
|
|
CIMIndicationServiceDisabledRequestMessage* request = |
|
dynamic_cast<CIMIndicationServiceDisabledRequestMessage*>(message); |
|
PEGASUS_ASSERT(request != 0); |
|
|
|
CIMIndicationServiceDisabledResponseMessage* response = |
|
dynamic_cast<CIMIndicationServiceDisabledResponseMessage*>( |
|
request->buildResponse()); |
|
PEGASUS_ASSERT(response != 0); |
|
|
|
_subscriptionInitComplete = false; |
|
|
|
PEG_METHOD_EXIT (); |
|
return response; |
|
} |
|
|
Message * JMPIProviderManager::handleSubscriptionInitCompleteRequest( | Message * JMPIProviderManager::handleSubscriptionInitCompleteRequest( |
const Message * message) | const Message * message) |
{ | { |
|
|
CIMValue genericValue; | CIMValue genericValue; |
| |
genericValue = providerId.getModule().getProperty( | genericValue = providerId.getModule().getProperty( |
providerId.getModule().findProperty("Name")).getValue(); |
providerId.getModule().findProperty( |
|
PEGASUS_PROPERTYNAME_NAME)).getValue(); |
genericValue.get(moduleName); | genericValue.get(moduleName); |
| |
genericValue = providerId.getProvider().getProperty( | genericValue = providerId.getProvider().getProperty( |
providerId.getProvider().findProperty("Name")).getValue(); |
providerId.getProvider().findProperty( |
|
PEGASUS_PROPERTYNAME_NAME)).getValue(); |
genericValue.get(providerName); | genericValue.get(providerName); |
| |
genericValue = providerId.getModule().getProperty( | genericValue = providerId.getModule().getProperty( |