📄 defaultprovidermanager.cpp
字号:
//%2006//////////////////////////////////////////////////////////////////////////// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;// IBM Corp.; EMC Corporation, The Open Group.// Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.// 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// of this software and associated documentation files (the "Software"), to// deal in the Software without restriction, including without limitation the// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or// sell copies of the Software, and to permit persons to whom the Software is// furnished to do so, subject to the following conditions:// // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN// ALL COPIES OR SUBSTANTIAL PORTIONS OF 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 "DefaultProviderManager.h"#include <Pegasus/Common/CIMMessage.h>#include <Pegasus/Common/OperationContext.h>#include <Pegasus/Common/Time.h>#include <Pegasus/Common/Tracer.h>#include <Pegasus/Common/StatisticalData.h>#include <Pegasus/Common/Logger.h>#include <Pegasus/Common/MessageLoader.h>#include <Pegasus/Common/FileSystem.h>#include <Pegasus/Common/PegasusVersion.h>#include <Pegasus/Common/Constants.h>#include <Pegasus/Query/QueryExpression/QueryExpression.h>#include <Pegasus/ProviderManager2/QueryExpressionFactory.h>#include <Pegasus/ProviderManager2/OperationResponseHandler.h>PEGASUS_NAMESPACE_BEGIN//// Default Provider Manager//DefaultProviderManager::DefaultProviderManager(){ _subscriptionInitComplete = false;}DefaultProviderManager::~DefaultProviderManager(){ PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, "DefaultProviderManager::~DefaultProviderManager"); _shutdownAllProviders(); for (ProviderTable::Iterator i = _providers.start(); i != 0; i++) { ProviderMessageHandler* provider = i.value(); delete provider; } for (ModuleTable::Iterator j = _modules.start(); j != 0; j++) { ProviderModule* module = j.value(); delete module; } PEG_METHOD_EXIT();}Message* DefaultProviderManager::processMessage(Message* message){ PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, "DefaultProviderManager::processMessage()"); CIMRequestMessage* request = dynamic_cast<CIMRequestMessage*>(message); PEGASUS_ASSERT(request != 0); CIMResponseMessage* response = 0; try { // pass the request message to a handler method based on message type switch(request->getType()) { case CIM_GET_INSTANCE_REQUEST_MESSAGE: case CIM_ENUMERATE_INSTANCES_REQUEST_MESSAGE: case CIM_ENUMERATE_INSTANCE_NAMES_REQUEST_MESSAGE: case CIM_CREATE_INSTANCE_REQUEST_MESSAGE: case CIM_MODIFY_INSTANCE_REQUEST_MESSAGE: case CIM_DELETE_INSTANCE_REQUEST_MESSAGE: case CIM_EXEC_QUERY_REQUEST_MESSAGE: case CIM_ASSOCIATORS_REQUEST_MESSAGE: case CIM_ASSOCIATOR_NAMES_REQUEST_MESSAGE: case CIM_REFERENCES_REQUEST_MESSAGE: case CIM_REFERENCE_NAMES_REQUEST_MESSAGE: case CIM_GET_PROPERTY_REQUEST_MESSAGE: case CIM_SET_PROPERTY_REQUEST_MESSAGE: case CIM_INVOKE_METHOD_REQUEST_MESSAGE: case CIM_CREATE_SUBSCRIPTION_REQUEST_MESSAGE: case CIM_MODIFY_SUBSCRIPTION_REQUEST_MESSAGE: case CIM_DELETE_SUBSCRIPTION_REQUEST_MESSAGE: case CIM_EXPORT_INDICATION_REQUEST_MESSAGE: { // resolve provider name ProviderName name = _resolveProviderName( request->operationContext.get(ProviderIdContainer::NAME)); // get cached or load new provider module ProviderOperationCounter poc( _getProvider(name.getPhysicalName(), name.getLogicalName())); response = poc.GetProvider().processMessage(request); break; } case CIM_DISABLE_MODULE_REQUEST_MESSAGE: response = _handleDisableModuleRequest(request); break; case CIM_ENABLE_MODULE_REQUEST_MESSAGE: response = _handleEnableModuleRequest(request); break; case CIM_STOP_ALL_PROVIDERS_REQUEST_MESSAGE: // tell the provider manager to shutdown all the providers _shutdownAllProviders(); response = request->buildResponse(); break; case CIM_SUBSCRIPTION_INIT_COMPLETE_REQUEST_MESSAGE: response = _handleSubscriptionInitCompleteRequest(request); break;// Note: The PG_Provider AutoStart property is not yet supported#if 0 case CIM_INITIALIZE_PROVIDER_REQUEST_MESSAGE: { // resolve provider name ProviderName name = _resolveProviderName( request->operationContext.get(ProviderIdContainer::NAME)); // get cached or load new provider module ProviderOperationCounter poc( _getProvider(name.getPhysicalName(), name.getLogicalName())); break; }#endif default: PEGASUS_ASSERT(0); break; } } catch (CIMException& e) { PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, "CIMException: " + e.getMessage()); response = request->buildResponse(); response->cimException = PEGASUS_CIM_EXCEPTION_LANG( e.getContentLanguages(), e.getCode(), e.getMessage()); } catch (Exception& e) { PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, "Exception: " + e.getMessage()); response = request->buildResponse(); response->cimException = PEGASUS_CIM_EXCEPTION_LANG( e.getContentLanguages(), CIM_ERR_FAILED, e.getMessage()); } catch (...) { PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL2, "Exception: Unknown"); response = request->buildResponse(); response->cimException = PEGASUS_CIM_EXCEPTION( CIM_ERR_FAILED, "Unknown error."); } PEG_METHOD_EXIT(); return response;}CIMResponseMessage* DefaultProviderManager::_handleDisableModuleRequest( CIMRequestMessage* message){ PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, "DefaultProviderManager::_handleDisableModuleRequest"); CIMDisableModuleRequestMessage* request = dynamic_cast<CIMDisableModuleRequestMessage*>(message); PEGASUS_ASSERT(request != 0); Array<Uint16> operationalStatus; CIMException cimException; try { // get provider module name String moduleName; CIMInstance mInstance = request->providerModule; Uint32 pos = mInstance.findProperty(CIMName("Name")); PEGASUS_ASSERT(pos != PEG_NOT_FOUND); mInstance.getProperty(pos).getValue().get(moduleName); // // Unload providers // Array<CIMInstance> providerInstances = request->providers; for (Uint32 i = 0, n = providerInstances.size(); i < n; i++) { String pName; providerInstances[i].getProperty( providerInstances[i].findProperty("Name")). getValue().get(pName); Sint16 ret_value = _disableProvider(pName); if (ret_value == 0) { // disable failed since there are pending requests, // stop trying to disable other providers in this module. operationalStatus.append(CIM_MSE_OPSTATUS_VALUE_OK); break; } else if (ret_value != 1) // Not success { // disable failed for other reason, throw exception throw PEGASUS_CIM_EXCEPTION_L( CIM_ERR_FAILED, MessageLoaderParms( "ProviderManager.ProviderManagerService." "DISABLE_PROVIDER_FAILED", "Failed to disable the provider.")); } } } catch (CIMException& e) { PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, "Exception: " + e.getMessage()); cimException = e; } catch (Exception& e) { PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, "Exception: " + e.getMessage()); cimException = CIMException(CIM_ERR_FAILED, e.getMessage()); } catch (...) { PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, "Exception: Unknown"); cimException = PEGASUS_CIM_EXCEPTION_L( CIM_ERR_FAILED, MessageLoaderParms( "ProviderManager.ProviderManagerService.UNKNOWN_ERROR", "Unknown Error")); } if (cimException.getCode() == CIM_ERR_SUCCESS) { // Status is set to OK if a provider was busy if (operationalStatus.size() == 0) { operationalStatus.append(CIM_MSE_OPSTATUS_VALUE_STOPPED); } } else { // If exception occurs, module is not stopped operationalStatus.append(CIM_MSE_OPSTATUS_VALUE_OK); } CIMDisableModuleResponseMessage* response = dynamic_cast<CIMDisableModuleResponseMessage*>( request->buildResponse()); PEGASUS_ASSERT(response != 0); response->operationalStatus = operationalStatus; PEG_METHOD_EXIT(); return response;}CIMResponseMessage* DefaultProviderManager::_handleEnableModuleRequest( CIMRequestMessage* message){ PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, "DefaultProviderManager::_handleEnableModuleRequest"); CIMEnableModuleRequestMessage* request = dynamic_cast<CIMEnableModuleRequestMessage*>(message); PEGASUS_ASSERT(request != 0); Array<Uint16> operationalStatus; operationalStatus.append(CIM_MSE_OPSTATUS_VALUE_OK); CIMEnableModuleResponseMessage* response = dynamic_cast<CIMEnableModuleResponseMessage*>( request->buildResponse()); PEGASUS_ASSERT(response != 0); response->operationalStatus = operationalStatus; PEG_METHOD_EXIT(); return response;}CIMResponseMessage*DefaultProviderManager::_handleSubscriptionInitCompleteRequest( CIMRequestMessage* message){ PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, "DefaultProviderManager::_handleSubscriptionInitCompleteRequest"); CIMSubscriptionInitCompleteRequestMessage* request = dynamic_cast<CIMSubscriptionInitCompleteRequestMessage*>(message); PEGASUS_ASSERT(request != 0); CIMSubscriptionInitCompleteResponseMessage* response = dynamic_cast<CIMSubscriptionInitCompleteResponseMessage*>( request->buildResponse()); PEGASUS_ASSERT(response != 0); _subscriptionInitComplete = true; // Make a copy of the table so it is not locked during the provider calls Array<ProviderMessageHandler*> providerList; { AutoMutex lock(_providerTableMutex); for (ProviderTable::Iterator i = _providers.start(); i != 0; i++) { providerList.append(i.value()); } } // // Notify all providers that subscription initialization is complete // for (Uint32 j = 0; j < providerList.size(); j++) { AutoMutex lock(providerList[j]->status.getStatusMutex()); if (providerList[j]->status.isInitialized()) { providerList[j]->subscriptionInitComplete(); } } PEG_METHOD_EXIT(); return response;}ProviderName DefaultProviderManager::_resolveProviderName( const ProviderIdContainer& providerId){ String providerName; String fileName; String interfaceName; CIMValue genericValue; genericValue = providerId.getProvider().getProperty( providerId.getProvider().findProperty("Name")).getValue(); genericValue.get(providerName); genericValue = providerId.getModule().getProperty( providerId.getModule().findProperty("Location")).getValue(); genericValue.get(fileName); // ATTN: This attribute is probably not required genericValue = providerId.getModule().getProperty( providerId.getModule().findProperty("InterfaceType")).getValue(); genericValue.get(interfaceName); String resolvedFileName = _resolvePhysicalName(fileName); if (resolvedFileName == String::EMPTY) { // Provider library not found String moduleName; genericValue = providerId.getModule().getProperty( providerId.getModule().findProperty("Name")).getValue(); genericValue.get(moduleName); throw Exception(MessageLoaderParms( "ProviderManager.ProviderManagerService.PROVIDER_FILE_NOT_FOUND", "File \"$0\" was not found for provider module \"$1\".", FileSystem::buildLibraryFileName(fileName), moduleName)); } return ProviderName(providerName, resolvedFileName, interfaceName, 0);}ProviderOperationCounter DefaultProviderManager::_getProvider( const String& moduleFileName, const String& providerName){ PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, "DefaultProviderManager::_getProvider"); ProviderMessageHandler* pr = _lookupProvider(providerName); if (!pr->status.isInitialized()) { _initProvider(pr, moduleFileName); } AutoMutex lock(pr->status.getStatusMutex()); if (!pr->status.isInitialized()) { PEG_METHOD_EXIT(); throw PEGASUS_CIM_EXCEPTION( CIM_ERR_FAILED, "provider initialization failed"); } ProviderOperationCounter poc(pr);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -