⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 defaultprovidermanager.cpp

📁 Pegasus is an open-source implementationof the DMTF CIM and WBEM standards. It is designed to be por
💻 CPP
📖 第 1 页 / 共 2 页
字号:
//%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 + -