📄 luminous.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 + -