//+-------------------------------------------------------------------------- // // Microsoft Windows // Copyright (C) Microsoft Corporation, 1994 - 1997. // // File: rsoputil.cpp // // Contents: helper functions for working with the RSOP databases // // History: 10-18-1999 stevebl Created // //--------------------------------------------------------------------------- #include "precomp.hxx" #include #include "rsoputil.h" // Something in the build environment is causing this // to be #defined to a version before 0x0500 and // that causes the ConvertStringSecurityDescriptor... function // to be undefined. #undef _WIN32_WINNT #define _WIN32_WINNT 0x0500 #include "sddl.h" //+-------------------------------------------------------------------------- // // Function: SetParameter // // Synopsis: sets a paramter's value in a WMI parameter list // // Arguments: [pInst] - instance on which to set the value // [szParam] - the name of the parameter // [xData] - the data // // History: 10-08-1999 stevebl Created // // Notes: There may be several flavors of this procedure, one for // each data type. // //--------------------------------------------------------------------------- HRESULT SetParameter(IWbemClassObject * pInst, TCHAR * szParam, TCHAR * szData) { VARIANT var; HRESULT hr = S_OK; var.vt = VT_BSTR; var.bstrVal = SysAllocString(szData); hr = pInst->Put(szParam, 0, &var, 0); SysFreeString(var.bstrVal); return hr; } //+-------------------------------------------------------------------------- // // Function: GetParameter // // Synopsis: retrieves a parameter value from a WMI paramter list // // Arguments: [pInst] - instance to get the paramter value from // [szParam] - the name of the paramter // [xData] - [out] data // // History: 10-08-1999 stevebl Created // // Notes: There are several flavors of this procedure, one for each // data type. // //--------------------------------------------------------------------------- HRESULT GetParameter(IWbemClassObject * pInst, TCHAR * szParam, TCHAR * &szData) { VARIANT var; HRESULT hr = S_OK; VariantInit(&var); if (szData) { delete szData; szData = NULL; } hr = pInst->Get(szParam, 0, &var, 0, 0); if (SUCCEEDED(hr) && var.vt != VT_NULL) { if (var.bstrVal) { ULONG ulNoChars; ulNoChars = _tcslen(var.bstrVal) + 1; szData = (TCHAR *) OLEALLOC(sizeof(TCHAR) * ulNoChars); if (szData) { hr = StringCchCopy(szData, ulNoChars, var.bstrVal); if (FAILED(hr)) { OLESAFE_DELETE(szData); } } else { hr = E_OUTOFMEMORY; } } } VariantClear(&var); return hr; } HRESULT GetParameter(IWbemClassObject * pInst, TCHAR * szParam, CString &szData) { VARIANT var; HRESULT hr = S_OK; VariantInit(&var); if (szData) { szData = ""; } hr = pInst->Get(szParam, 0, &var, 0, 0); if (SUCCEEDED(hr) && var.vt != VT_NULL) { if (var.bstrVal) { szData = var.bstrVal; } } VariantClear(&var); return hr; } HRESULT GetParameterBSTR(IWbemClassObject * pInst, TCHAR * szParam, BSTR &bstrData) { VARIANT var; HRESULT hr = S_OK; VariantInit(&var); if (bstrData) { SysFreeString(bstrData); } hr = pInst->Get(szParam, 0, &var, 0, 0); if (SUCCEEDED(hr) && var.vt != VT_NULL) { bstrData = SysAllocStringLen(var.bstrVal, SysStringLen(var.bstrVal)); if (NULL == bstrData) { hr = E_OUTOFMEMORY; } } VariantClear(&var); return hr; } HRESULT GetParameter(IWbemClassObject * pInst, TCHAR * szParam, BOOL &fData) { VARIANT var; HRESULT hr = S_OK; VariantInit(&var); hr = pInst->Get(szParam, 0, &var, 0, 0); if (SUCCEEDED(hr) && var.vt != VT_NULL) { fData = var.bVal; } VariantClear(&var); return hr; } HRESULT GetParameter(IWbemClassObject * pInst, TCHAR * szParam, HRESULT &hrData) { VARIANT var; HRESULT hr = S_OK; VariantInit(&var); hr = pInst->Get(szParam, 0, &var, 0, 0); if (SUCCEEDED(hr) && var.vt != VT_NULL) { hrData = (HRESULT) var.lVal; } VariantClear(&var); return hr; } HRESULT GetParameter(IWbemClassObject * pInst, TCHAR * szParam, ULONG &ulData) { VARIANT var; HRESULT hr = S_OK; VariantInit(&var); hr = pInst->Get(szParam, 0, &var, 0, 0); if (SUCCEEDED(hr) && var.vt != VT_NULL) { ulData = var.ulVal; } VariantClear(&var); return hr; } HRESULT GetParameter(IWbemClassObject * pInst, TCHAR * szParam, GUID &guid) { TCHAR * sz = NULL; memset(&guid, 0, sizeof(GUID)); HRESULT hr = GetParameter(pInst, szParam, sz); if (SUCCEEDED(hr)) { hr = CLSIDFromString(sz, &guid); } if (sz) { OLESAFE_DELETE(sz); } return hr; } HRESULT GetParameter(IWbemClassObject * pInst, TCHAR * szParam, unsigned int &ui) { VARIANT var; HRESULT hr = S_OK; VariantInit(&var); ui = 0; hr = pInst->Get(szParam, 0, &var, 0, 0); if (SUCCEEDED(hr) && var.vt != VT_NULL) { ui = (HRESULT) var.uiVal; } VariantClear(&var); return hr; } // array variation - gets an array of guids and a count HRESULT GetParameter(IWbemClassObject * pInst, TCHAR *szParam, UINT &uiCount, GUID * &rgGuid) { VARIANT var; HRESULT hr = S_OK; VariantInit(&var); hr = pInst->Get(szParam, 0, &var, 0, 0); if (SUCCEEDED(hr) && var.vt == (VT_ARRAY | VT_BSTR)) { // build the array SAFEARRAY * parray = var.parray; uiCount = parray->rgsabound[0].cElements; if (uiCount > 0) { rgGuid = (GUID *)OLEALLOC(sizeof(GUID) * uiCount); if (rgGuid) { BSTR * rgData = (BSTR *)parray->pvData; UINT ui = uiCount; while (ui--) { hr = CLSIDFromString(rgData[ui], &rgGuid[ui]); if (FAILED(hr)) { return hr; } } } else { uiCount = 0; hr = E_OUTOFMEMORY; } } } VariantClear(&var); return hr; } // array variation - gets an array of strings and a count HRESULT GetParameter(IWbemClassObject * pInst, TCHAR *szParam, UINT &uiCount, TCHAR ** &rgszData) { VARIANT var; HRESULT hr = S_OK; VariantInit(&var); hr = pInst->Get(szParam, 0, &var, 0, 0); if (SUCCEEDED(hr) && var.vt == (VT_ARRAY | VT_BSTR)) { // build the array SAFEARRAY * parray = var.parray; uiCount = parray->rgsabound[0].cElements; if (uiCount > 0) { rgszData = (TCHAR **)OLEALLOC(sizeof(TCHAR *) * uiCount); if (rgszData) { BSTR * rgData = (BSTR *)parray->pvData; UINT ui = uiCount; while (ui--) { // // Allocate memory and copy the string // OLESAFE_COPYSTRING(rgszData[ui], rgData[ui]); if ( ! rgszData[ui] ) { // // If we failed one allocation, free all the preceding // allocations // for (int iCurrent = ui + 1; iCurrent < uiCount; iCurrent++ ) { OLESAFE_DELETE( rgszData[iCurrent] ); } OLESAFE_DELETE( rgszData ); uiCount = 0; hr = E_OUTOFMEMORY; break; } } } else { uiCount = 0; hr = E_OUTOFMEMORY; } } } VariantClear(&var); return hr; } HRESULT GetParameter(IWbemClassObject * pInst, TCHAR * szParam, PSECURITY_DESCRIPTOR &psd) { VARIANT var; HRESULT hr = S_OK; if (psd) { LocalFree(psd); psd = NULL; } VariantInit(&var); hr = pInst->Get(szParam, 0, &var, 0, 0); if (SUCCEEDED(hr) && var.vt != VT_NULL) { PSECURITY_DESCRIPTOR psdTemp; BOOL f = ConvertStringSecurityDescriptorToSecurityDescriptor( var.bstrVal, //(LPCTSTR)var.parray->pvData, SDDL_REVISION_1, &psd, NULL); if (!f) { // it failed // could call GetLastError here to figure out why // but at the moment I don't really care } if (!IsValidSecurityDescriptor(psd)) { LocalFree(psd); psd = NULL; } } VariantClear(&var); return hr; } HRESULT GetGPOFriendlyName(IWbemServices *pIWbemServices, LPTSTR lpGPOID, BSTR pLanguage, LPTSTR *pGPOName) { BSTR pQuery = NULL, pName = NULL; LPTSTR lpQuery = NULL; IEnumWbemClassObject * pEnum = NULL; IWbemClassObject *pObjects[2]; HRESULT hr; ULONG ulRet; VARIANT varGPOName; // // Set the default // *pGPOName = NULL; // // Build the query // ULONG ulNoChars = lstrlen(lpGPOID) + 50; lpQuery = (LPTSTR) LocalAlloc (LPTR, ulNoChars * sizeof(TCHAR)); if (!lpQuery) { hr = HRESULT_FROM_WIN32(ERROR_OUTOFMEMORY); goto Exit; } WCHAR szQuery[] = L"SELECT name, id FROM RSOP_GPO where id=\"%s\""; hr = StringCchPrintf (lpQuery, ulNoChars, szQuery, lpGPOID); if (FAILED(hr)) { goto Exit; } pQuery = SysAllocString (lpQuery); if (!pQuery) { hr = HRESULT_FROM_WIN32(ERROR_OUTOFMEMORY); goto Exit; } // // Allocate BSTRs for the property names we want to retreive // pName = SysAllocString (TEXT("name")); if (!pName) { hr = HRESULT_FROM_WIN32(ERROR_OUTOFMEMORY); goto Exit; } // // Execute the query // hr = pIWbemServices->ExecQuery (pLanguage, pQuery, WBEM_FLAG_FORWARD_ONLY | WBEM_FLAG_RETURN_IMMEDIATELY, NULL, &pEnum); if (FAILED(hr)) { goto Exit; } // // Loop through the results // hr = pEnum->Next(WBEM_INFINITE, 1, pObjects, &ulRet); if (FAILED(hr)) { goto Exit; } // // Check for the "data not available case" // if (ulRet == 0) { hr = S_OK; goto Exit; } // // Get the name // hr = pObjects[0]->Get (pName, 0, &varGPOName, NULL, NULL); if (FAILED(hr)) { goto Exit; } // // Save the name // ULONG ulNoCharsGPOName; ulNoCharsGPOName = lstrlen(varGPOName.bstrVal) + 1; *pGPOName = (LPTSTR) LocalAlloc (LPTR, ulNoCharsGPOName * sizeof(TCHAR)); if (!(*pGPOName)) { goto Exit; } hr = StringCchCopy (*pGPOName, ulNoCharsGPOName, varGPOName.bstrVal); ASSERT(SUCCEEDED(hr)); VariantClear (&varGPOName); hr = S_OK; Exit: if (pEnum) { pEnum->Release(); } if (pQuery) { SysFreeString (pQuery); } if (lpQuery) { LocalFree (lpQuery); } if (pName) { SysFreeString (pName); } return hr; }