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

📄 luminous.cpp

📁 winddk src目录下的WDM源码压缩!
💻 CPP
字号:
/*++

Copyright (c) Microsoft Corporation.  All rights reserved.

    THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
    KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
    IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
    PURPOSE.


Module Name:

    Luminous.c

Abstract:

    Library for managing the state of all firefly devices

Environment:

    User Mode library

Revision History:

    Eliyas Yakub  - Created Oct 18th, 2002

--*/
#include "luminous.h"

CLuminous::CLuminous(
    VOID
    )
{
    m_pIWbemServices = NULL;
    m_pIWbemClassObject = NULL;
    m_bCOMInitialized = FALSE;
}


CLuminous::~CLuminous(
    VOID
    )
{
    Close();
}


BOOL
CLuminous::Open(
    VOID
    )
{
    HRESULT           hResult;
    BOOL                bRet = FALSE;
    
    if (m_pIWbemServices) {

        return TRUE;
    }

    do {
        //
        // Initialize COM library. Must be done before invoking any
        // other COM function.
        //

        hResult = CoInitialize( NULL );

        if ( FAILED (hResult)) {
            _tprintf( TEXT("Error %lx: Failed to initialize COM library\n"), hResult );
            break;
        }  

        m_bCOMInitialized = TRUE;
        
        m_pIWbemServices = ConnectToNamespace( NAME_SPACE);
        if (!m_pIWbemServices ) {
            _tprintf( TEXT("Could not connect name.\n") );   
            break;
        }

        m_pIWbemClassObject = GetInstanceReference( m_pIWbemServices, CLASS_NAME);
        if ( !m_pIWbemClassObject ) {
            _tprintf( TEXT("Could not find the instance.\n") );
            break;
        }

        bRet = TRUE;
        
    }while (FALSE);

    if(!bRet) {
        if(m_pIWbemClassObject) {
            m_pIWbemClassObject->Release();
            m_pIWbemClassObject = NULL;
        }            
        if(m_pIWbemServices) {
            m_pIWbemServices->Release();
            m_pIWbemServices = NULL;
        }
        if(m_bCOMInitialized) {
            CoUninitialize();
            m_bCOMInitialized = FALSE;
        }
    }        
    
    return bRet;
}

VOID
CLuminous::Close(
    VOID
    )
{
    if (m_pIWbemServices) {
        m_pIWbemServices->Release();
        m_pIWbemServices = NULL;
    }

    if (m_pIWbemClassObject) {
        m_pIWbemClassObject->Release();
        m_pIWbemClassObject = NULL;
    }
    
    if(m_bCOMInitialized) {
        CoUninitialize();
        m_bCOMInitialized = FALSE;
    }  

}


BOOL
CLuminous::Get(
    IN BOOL *Enabled
    )
{

    VARIANT     varPropVal;
    BSTR          bstrPropertyName = NULL;
    HRESULT     hResult;
    CIMTYPE     cimType;
    BOOL          bRet= FALSE;
    
    if (!m_pIWbemServices || !m_pIWbemClassObject) {
        return FALSE;
    }

    VariantInit( &varPropVal );

    bstrPropertyName = AnsiToBstr( PROPERTY_NAME, -1 );

    if ( !bstrPropertyName ) {
        _tprintf( TEXT("Error out of memory.\n") );
        VariantClear( &varPropVal );
        return FALSE ;
    }

    //
    // Get the property value.
    //

    hResult = m_pIWbemClassObject->Get(
                             bstrPropertyName,
                             0,
                             &varPropVal,
                             &cimType,
                             NULL );

    if ( hResult != WBEM_S_NO_ERROR ) {

        _tprintf( TEXT("Error %lX: Failed to read property value of %s.\n"),
                        hResult, PROPERTY_NAME);

    } else {
        if(varPropVal.vt == VT_BOOL) {
            *Enabled = varPropVal.boolVal;
            bRet = TRUE;
        }
    }

    if(bstrPropertyName) {
        SysFreeString( bstrPropertyName );
    }

    VariantClear( &varPropVal );

    return bRet;
    
}

BOOL
CLuminous::Set(
    IN BOOL Enabled
    )
{
    VARIANT     varPropVal;
    BSTR          bstrPropertyName = NULL;
    HRESULT     hResult;
    CIMTYPE     cimType;
    BOOL         bRet = FALSE;
    LPTSTR      lpProperty = PROPERTY_NAME;

    if (!m_pIWbemServices || !m_pIWbemClassObject) {
        return FALSE;
    }

    VariantInit( &varPropVal );

    bstrPropertyName = AnsiToBstr( lpProperty, -1 );

    if ( !bstrPropertyName ) {
        _tprintf( TEXT("Error out of memory.\n") );
        goto End ;
    }

    //
    // Get the property value.
    //

    hResult = m_pIWbemClassObject->Get(
                             bstrPropertyName,
                             0,
                             &varPropVal,
                             &cimType,
                             NULL );

    if ( hResult != WBEM_S_NO_ERROR ) {

        _tprintf( TEXT("Error %lX: Failed to read property value of %s.\n"),
                            hResult, lpProperty );
        goto End;

    } 

    if(varPropVal.vt == VT_BOOL) {
        varPropVal.boolVal = (VARIANT_BOOL)Enabled;
        
        //
        // Set the property value
        //

        hResult = m_pIWbemClassObject->Put(
                                    bstrPropertyName,
                                    0,
                                    &varPropVal,
                                    cimType
                                    );


        if ( hResult == WBEM_S_NO_ERROR ) {
            hResult = m_pIWbemServices->PutInstance(
                                            m_pIWbemClassObject,
                                            WBEM_FLAG_UPDATE_ONLY,
                                            NULL,
                                            NULL );

            if ( hResult != WBEM_S_NO_ERROR ) {
                _tprintf( TEXT("Failed to save the instance,")
                                    TEXT(" %s will not be updated.\n"),
                                    lpProperty );
            } else {
                bRet = TRUE;
            }
        }
        else {

            _tprintf( TEXT("Error %lX: Failed to set property value of %s.\n"),
            hResult, lpProperty );
        }
    }
    
End:

    if(bstrPropertyName) {
        SysFreeString( bstrPropertyName );
    }

    VariantClear( &varPropVal );

    return bRet;
}

//
// The function connects to the namespace specified by the user.
//

IWbemServices *ConnectToNamespace (LPTSTR chNamespace)
{
    IWbemServices *pIWbemServices = NULL;
    IWbemLocator  *pIWbemLocator = NULL;
    BSTR          bstrNamespace;
    HRESULT       hResult;

    //
    // Create an instance of WbemLocator interface.
    //

    hResult = CoCreateInstance(
                           CLSID_WbemLocator,
                           NULL,
                           CLSCTX_INPROC_SERVER,
                           IID_IWbemLocator,
                           (LPVOID *)&pIWbemLocator );

    if ( hResult != S_OK ) {
        _tprintf( TEXT("Error %lX: Could not create instance of IWbemLocator interface.\n"),
           hResult );
        return NULL;
    }

    //
    // Namespaces are passed to COM in BSTRs.
    //

    bstrNamespace = AnsiToBstr( chNamespace,   -1 );

    if ( bstrNamespace == NULL ) {
        _tprintf( TEXT("Out of memory.\n") );
        pIWbemLocator->Release( );
        return NULL;
    }

    //
    // Using the locator, connect to COM in the given namespace.
    //

    hResult = pIWbemLocator->ConnectServer(
                  bstrNamespace,
                  NULL,   // NULL means current account, for simplicity.
                  NULL,   // NULL means current password, for simplicity.
                  0L,     // locale
                  0L,     // securityFlags
                  NULL,   // authority (domain for NTLM)
                  NULL,   // context
                  &pIWbemServices ); // Returned IWbemServices.

    //
    // Done with Namespace.
    //

    SysFreeString( bstrNamespace );

    if ( hResult != WBEM_S_NO_ERROR) {
        _tprintf( TEXT("Error %lX: Failed to connect to namespace %s.\n"),
                            hResult, chNamespace );

        pIWbemLocator->Release( );
        return NULL;
    }

    //
    // Switch the security level to IMPERSONATE so that provider(s)
    // will grant access to system-level objects, and so that
    // CALL authorization will be used.
    //

    hResult = CoSetProxyBlanket(
                   (IUnknown *)pIWbemServices, // proxy
                   RPC_C_AUTHN_WINNT,        // authentication service
                   RPC_C_AUTHZ_NONE,         // authorization service
                   NULL,                     // server principle name
                   RPC_C_AUTHN_LEVEL_CALL,   // authentication level
                   RPC_C_IMP_LEVEL_IMPERSONATE, // impersonation level
                   NULL,                     // identity of the client
                   0 );                      // capability flags

    if ( hResult != S_OK ) {
        _tprintf( TEXT("Error %lX: Failed to impersonate.\n"), hResult );

        pIWbemLocator->Release();
        pIWbemServices->Release();
        return NULL;
    }

    pIWbemLocator->Release();
    return pIWbemServices;
}

//
// The function returns an interface pointer to the instance given its
// list-index.
//

IWbemClassObject *GetInstanceReference (
                                    IWbemServices *pIWbemServices,
                                    LPTSTR lpClassName)
{
    IWbemClassObject     *pInst = NULL;
    IEnumWbemClassObject *pEnumInst;
    BSTR                 bstrClassName;
    BOOL                 bFound;
    ULONG                ulCount;
    HRESULT              hResult;


    bstrClassName = AnsiToBstr( lpClassName, -1 );

    if ( bstrClassName == NULL ) {
        _tprintf( TEXT("Out of memory.\n") );
        return NULL;
    }

    // 
    // Get Instance Enumerator Interface.
    //

    pEnumInst = NULL;

    hResult = pIWbemServices->CreateInstanceEnum(
                                bstrClassName,          // Name of the root class.
                                WBEM_FLAG_SHALLOW |     // Enumerate at current root only.
                                WBEM_FLAG_FORWARD_ONLY, // Forward-only enumeration.
                                NULL,                   // Context.
                                &pEnumInst );          // pointer to class enumerator

    if ( hResult != WBEM_S_NO_ERROR || pEnumInst == NULL ) {
        _tprintf( TEXT("Error %lX: Failed to get a reference")
        TEXT(" to instance enumerator.\n"), hResult );
    }
    else {
        //
        // Get pointer to the instance.
        //

        hResult = WBEM_S_NO_ERROR;
        bFound = FALSE;
        
        while ( (hResult == WBEM_S_NO_ERROR) && (bFound == FALSE) ) {

            hResult = pEnumInst->Next(
                                        2000,      // two seconds timeout
                                        1,         // return just one instance.
                                        &pInst,    // pointer to instance.
                                        &ulCount); // Number of instances returned.

            if ( ulCount > 0 ) {

                bFound = TRUE;
                break;
            }
        }

        if ( bFound == FALSE && pInst) {
            pInst->Release(  );
            pInst = NULL;
        }
    }

    //
    // Done with the instance enumerator.
    //

    if(pEnumInst) {
        pEnumInst->Release( );
    }
    SysFreeString( bstrClassName );

    return pInst;
}

//
// The function converts an ANSI string into BSTR and returns it in an
// allocated memory. The memory must be freed by the caller using free()
// function. If nLenSrc is -1, the string is null terminated.
//

BSTR AnsiToBstr (LPTSTR lpSrc, int nLenSrc)
{
    BSTR lpDest;

    //
    // In case of ANSI version, we need to change the ANSI string to UNICODE since
    // BSTRs are essentially UNICODE strings.
    //

#ifndef UNICODE
    int  nLenDest;

    nLenDest = MultiByteToWideChar( CP_ACP, 0, lpSrc, nLenSrc, NULL, 0);

    lpDest = SysAllocStringLen( NULL, nLenDest );

    if ( lpDest ) {
        MultiByteToWideChar( CP_ACP, 0, lpSrc, nLenSrc, lpDest, nLenDest );
    }

    //
    // In case of UNICODE version, we simply allocate memory and copy the string.
    //

#else
    if ( lpSrc == NULL ) {
        nLenSrc = 0;
    }
    else {
        if ( nLenSrc == -1 ) {
            nLenSrc = _tcslen( lpSrc ) + 1;
        }
    }

    lpDest = SysAllocStringLen( lpSrc, nLenSrc );
#endif

    return lpDest;
}




⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -