2020-09-30 16:53:55 +02:00

1013 lines
25 KiB
C++

#include <afxdisp.h> // AfxThrowOleException
#include <objbase.h>
#include <basetyps.h>
#include "dbg.h"
#include "regkey.h"
#include "util.h"
#include "macros.h"
USE_HANDLE_MACROS("GUIDHELP(regkey.cpp)")
using namespace AMC;
DECLARE_INFOLEVEL(AMCCore);
DECLARE_HEAPCHECKING;
// ISSUE-2002/04/01-JonN handle NULL pointer parameters -- omnibus issue
//____________________________________________________________________________
//
// Member: CRegKey::CreateKeyEx
//
// Synopsis: Same meaning as for RegCreateKeyEx API.
//
// Arguments: [hKeyAncestor] -- IN
// [lpszKeyName] -- IN
// [security] -- IN
// [pdwDisposition] -- OUT
// [dwOption] -- IN
// [pSecurityAttributes] -- OUT
//
// Returns: void
//
// History: 5/24/1996 RaviR Created
//____________________________________________________________________________
//
void
CRegKey::CreateKeyEx(
HKEY hKeyAncestor,
LPCTSTR lpszKeyName,
REGSAM security,
DWORD * pdwDisposition,
DWORD dwOption,
LPSECURITY_ATTRIBUTES pSecurityAttributes)
{
ASSERT(lpszKeyName != NULL);
ASSERT(m_hKey == 0); // already called CreateEx on this object
// NTRAID#NTBUG9-654900-2002/07/08-artm initialize dwDisposition
DWORD dwDisposition = 0;
m_lastError = ::RegCreateKeyEx(hKeyAncestor, lpszKeyName, 0, _T(""),
dwOption, security, pSecurityAttributes,
&m_hKey, &dwDisposition);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld creating key \"%s\" under ancestor 0x%x\n",
m_lastError, lpszKeyName, hKeyAncestor );
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
if (pdwDisposition != NULL)
{
*pdwDisposition = dwDisposition;
}
}
//____________________________________________________________________________
//
// Member: CRegKey::OpenKeyEx
//
// Synopsis: Same meaning as RegOpenKeyEx
//
// Arguments: [hKeyAncestor] -- IN
// [lpszKeyName] -- IN
// [security] -- IN
//
// Returns: BOOL (FALSE if key not found, TRUE otherwise.)
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
BOOL
CRegKey::OpenKeyEx(
HKEY hKeyAncestor,
LPCTSTR lpszKeyName,
REGSAM security)
{
ASSERT(m_hKey == 0);
m_lastError = ::RegOpenKeyEx(hKeyAncestor, lpszKeyName,
0, security, &m_hKey);
if (m_lastError == ERROR_SUCCESS)
{
return TRUE;
}
else if (m_lastError != ERROR_FILE_NOT_FOUND)
{
TRACE("CRegKey error %ld opening key \"%s\" under ancestor 0x%x\n",
m_lastError, lpszKeyName, hKeyAncestor );
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
return FALSE;
}
//____________________________________________________________________________
//
// Member: CRegKey::GetKeySecurity
//
// Synopsis: Same meaning as for RegGetKeySecurity API.
//
// Arguments: [SecInf] -- IN descriptor contents
// [pSecDesc] -- OUT address of descriptor for key
// [lpcbSecDesc] -- IN/OUT address of size of buffer for descriptor
//
// Returns: HRESULT.
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
//
BOOL
CRegKey::GetKeySecurity(
SECURITY_INFORMATION SecInf,
PSECURITY_DESCRIPTOR pSecDesc,
LPDWORD lpcbSecDesc)
{
ASSERT(pSecDesc != NULL);
ASSERT(lpcbSecDesc != NULL);
ASSERT(m_hKey != NULL);
m_lastError = ::RegGetKeySecurity(m_hKey, SecInf, pSecDesc, lpcbSecDesc);
if (m_lastError == ERROR_SUCCESS)
{
return TRUE;
}
else if (m_lastError != ERROR_INSUFFICIENT_BUFFER)
{
TRACE("CRegKey error %ld reading security of key 0x%x\n",
m_lastError, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
return FALSE;
}
//____________________________________________________________________________
//
// Member: CRegKey::CloseKey
//
// Synopsis: Same meaning as for RegCloseKey API.
//
// Returns: void
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
void
CRegKey::CloseKey()
{
ASSERT(m_hKey != 0);
m_lastError = ::RegCloseKey(m_hKey);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld closing key 0x%x\n",
m_lastError, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
else
{
// reset the object
m_hKey = 0;
m_lastError = ERROR_SUCCESS;
}
}
//____________________________________________________________________________
//
// Member: CRegKey::DeleteKey
//
// Synopsis: Delete all the keys and subkeys
//
// Arguments: [lpszKeyName] -- IN
//
// Returns: void
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
//
void
CRegKey::DeleteKey(
LPCTSTR lpszKeyName)
{
ASSERT(m_hKey != NULL);
ASSERT(lpszKeyName != NULL);
m_lastError = NTRegDeleteKey(m_hKey , lpszKeyName);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld recursively deleting key \"%s\" under key 0x%x\n",
m_lastError, lpszKeyName, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
}
//____________________________________________________________________________
//
// Member: CRegKey::SetValueEx
//
// Synopsis: Same meaning as for RegSetValueEx API.
//
// Arguments: [lpszValueName] -- IN
// [dwType] -- IN
// [pData] -- OUT
// [nLen] -- IN
//
// Returns: void
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
void
CRegKey::SetValueEx(
LPCTSTR lpszValueName,
DWORD dwType,
const void *pData,
DWORD nLen)
{
ASSERT(lpszValueName != NULL);
ASSERT(pData != NULL);
ASSERT(m_hKey != NULL);
#if DBG==1
switch (dwType)
{
case REG_BINARY:
case REG_DWORD:
case REG_DWORD_BIG_ENDIAN:
case REG_EXPAND_SZ:
case REG_LINK:
case REG_MULTI_SZ:
case REG_NONE:
case REG_RESOURCE_LIST:
case REG_SZ:
break;
default:
ASSERT(FALSE); // unknown type
}
#endif
m_lastError = ::RegSetValueEx(m_hKey, lpszValueName, 0, dwType,
(CONST BYTE *)pData, nLen);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld setting value \"%s\" of key 0x%x\n",
m_lastError, lpszValueName, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
}
//____________________________________________________________________________
//
// Member: IsValuePresent
//
// Arguments: [lpszValueName] -- IN
//
// Returns: BOOL.
//
// History: 3/21/1997 RaviR Created
//____________________________________________________________________________
//
BOOL CRegKey::IsValuePresent(LPCTSTR lpszValueName)
{
DWORD cbData; // ISSUE-2002/04/01-JonN pass NULL for this parameter
m_lastError = ::RegQueryValueEx(m_hKey, lpszValueName, 0, NULL,
NULL, &cbData);
return (m_lastError == ERROR_SUCCESS);
}
//____________________________________________________________________________
//
// Member: CRegKey::QueryValueEx
//
// Synopsis: Same meaning as for RegQueryValueEx API.
//
// Arguments: [lpszValueName] -- IN
// [pType] -- IN
// [pData] -- IN
// [pLen] -- IN
//
// Returns: void
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
void
CRegKey::QueryValueEx(
LPCTSTR lpszValueName,
LPDWORD pType,
PVOID pData,
LPDWORD pLen)
{
ASSERT(pLen != NULL);
ASSERT(m_hKey != NULL);
m_lastError = ::RegQueryValueEx(m_hKey, lpszValueName, 0, pType,
(LPBYTE)pData, pLen);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %d querying data value \"%ws\" of key 0x%x\n",
m_lastError, lpszValueName, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
}
//____________________________________________________________________________
//
// Member: CRegKey::QueryDword
//
// Synopsis: Query's for DWORD type data.
//
// Arguments: [lpszValueName] -- IN
// [pdwData] -- IN
//
// Returns: void
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
void
CRegKey::QueryDword(
LPCTSTR lpszValueName,
LPDWORD pdwData)
{
ASSERT(m_hKey);
DWORD dwType = REG_DWORD;
DWORD dwSize = sizeof(DWORD);
m_lastError = ::RegQueryValueEx(m_hKey, lpszValueName, 0, &dwType,
(LPBYTE)pdwData, &dwSize);
if (m_lastError != ERROR_FILE_NOT_FOUND && dwType != REG_DWORD)
{
m_lastError = ERROR_INVALID_DATATYPE;
}
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld querying dword value \"%s\" of key 0x%x\n",
m_lastError, lpszValueName, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
}
//____________________________________________________________________________
//
// Member: CRegKey::QueryGUID
//
// Synopsis: Query's for GUID type data, stored as REG_SZ.
//
// Arguments: [lpszValueName] -- IN
// [pguid] -- OUT
//
// Returns: void
//
// History: 8/27/1996 JonN Created
//
//____________________________________________________________________________
void
CRegKey::QueryGUID(
LPCTSTR lpszValueName,
GUID* pguid)
{
ASSERT(m_hKey);
ASSERT( NULL != pguid );
CStr str;
QueryString( lpszValueName, str );
// CODEWORK m_lastError should not be HRESULT
m_lastError = GUIDFromCStr( str, pguid );
if (FAILED(m_lastError))
{
TRACE("CRegKey error %ld querying guid value \"%s\" of key 0x%x\n",
m_lastError, lpszValueName, m_hKey);
////AfxThrowOleException( m_lastError );
}
}
void
CRegKey::SetGUID(
LPCTSTR lpszValueName,
const GUID& guid)
{
ASSERT(m_hKey);
CStr str;
// CODEWORK m_lastError should not be HRESULT
m_lastError = GUIDToCStr( str, guid );
if (FAILED(m_lastError))
{
TRACE("CRegKey error %ld setting guid value \"%s\" of key 0x%x\n",
m_lastError, lpszValueName, m_hKey);
// ISSUE-2002/04/01-JonN should return here?
////AfxThrowOleException( m_lastError );
}
SetString( lpszValueName, str );
}
//____________________________________________________________________________
//
// Member: CRegKey::QueryString
//
// Synopsis: Query's for string type data.
//
// Arguments: [lpszValueName] -- IN
// [pBuffer] -- OUT
// [pdwBufferByteLen] -- IN/OUT
// [pdwType] -- OUT
//
// Returns: BOOL, returns FALSE if the buffer provided is insufficient.
//
// History: 5/24/1996 RaviR Created
//
//____________________________________________________________________________
BOOL
CRegKey::QueryString(
LPCTSTR lpszValueName,
LPTSTR pBuffer,
DWORD * pdwBufferByteLen,
DWORD * pdwType)
{
ASSERT(pBuffer != NULL);
ASSERT(pdwBufferByteLen != NULL);
ASSERT(m_hKey != NULL);
DWORD dwType = REG_NONE; // JonN 11/21/00 PREFIX 179991
m_lastError = ::RegQueryValueEx(m_hKey, lpszValueName, 0, &dwType,
(LPBYTE)pBuffer, pdwBufferByteLen);
if (pdwType != NULL)
{
*pdwType = dwType;
}
if (m_lastError != ERROR_FILE_NOT_FOUND &&
dwType != REG_SZ && dwType != REG_EXPAND_SZ)
{
m_lastError = ERROR_INVALID_DATATYPE;
}
if (m_lastError == ERROR_SUCCESS)
{
return TRUE;
}
else if (m_lastError != ERROR_MORE_DATA)
{
TRACE("CRegKey error %ld querying bufferstring value \"%s\" of key 0x%x\n",
m_lastError, lpszValueName, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
return FALSE;
}
//____________________________________________________________________________
//
// Member: CRegKey::QueryString
//
// Synopsis: Query's for string type data.
//
// Arguments: [lpszValueName] -- IN
// [ppStrValue] -- OUT
// [pdwType] -- OUT
//
// Returns: void
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
void
CRegKey::QueryString(
LPCTSTR lpszValueName,
LPTSTR * ppStrValue,
DWORD * pdwType)
{
DWORD dwType = REG_SZ;
DWORD dwLen = 0;
// Determine how big the data is
this->QueryValueEx(lpszValueName, &dwType, NULL, &dwLen);
if (pdwType != NULL)
{
*pdwType = dwType;
}
if (dwType != REG_SZ && dwType != REG_EXPAND_SZ)
{
m_lastError = ERROR_INVALID_DATATYPE;
TRACE("CRegKey error %ld querying allocstring value \"%s\" of key 0x%x\n",
m_lastError, lpszValueName, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
DWORD charLen = dwLen/sizeof(TCHAR);
LPTSTR pBuffer = new TCHAR[charLen + 1];
// ISSUE-2002/04/01-JonN clear buffer
if (dwLen != 0)
{
#if DBG==1
try
{
this->QueryValueEx(lpszValueName, &dwType, pBuffer, &dwLen);
}
catch ( HRESULT result )
{
CHECK_HRESULT( result );
}
#else // ! DBG==1
this->QueryValueEx(lpszValueName, &dwType, pBuffer, &dwLen);
#endif // ! DBG==1
}
pBuffer[charLen] = TEXT('\0');
*ppStrValue = pBuffer;
}
//____________________________________________________________________________
//
// Member: CRegKey::QueryString
//
// Synopsis: Query's for string type data.
//
// Arguments: [lpszValueName] -- IN
// [str] -- OUT
// [pdwType] -- OUT
//
// Returns: void
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
void
CRegKey::QueryString(
LPCTSTR lpszValueName,
CStr& str,
DWORD * pdwType)
{
DWORD dwType = REG_SZ;
DWORD dwLen=0;
// Determine how big the data is
this->QueryValueEx(lpszValueName, &dwType, NULL, &dwLen);
if (pdwType != NULL)
{
*pdwType = dwType;
}
if (dwType != REG_SZ && dwType != REG_EXPAND_SZ)
{
m_lastError = ERROR_INVALID_DATATYPE;
TRACE("CRegKey error %ld querying CString value \"%s\" of key 0x%x\n",
m_lastError, lpszValueName, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
DWORD charLen = dwLen/sizeof(TCHAR);
LPTSTR pBuffer = str.GetBuffer(charLen + 1);
// ISSUE-2002/04/01-JonN clear buffer
if (dwLen != 0)
{
#if DBG==1
try
{
this->QueryValueEx(lpszValueName, &dwType, pBuffer, &dwLen);
}
catch ( HRESULT result )
{
CHECK_HRESULT( result );
}
#else // ! DBG==1
this->QueryValueEx(lpszValueName, &dwType, pBuffer, &dwLen);
#endif // ! DBG==1
}
pBuffer[charLen] = TEXT('\0');
str.ReleaseBuffer();
}
//____________________________________________________________________________
//
// Member: CRegKey::EnumKeyEx
//
// Synopsis: Same meaning as for RegEnumKeyEx API.
//
// Arguments: [iSubkey] -- IN
// [lpszName] -- OUT place to store the name
// [dwLen] -- IN
// [lpszLastModified] -- IN
//
// Returns: BOOL. Returns FALSE if no more items found.
//
// History: 5/22/1996 RaviR Created
//
//____________________________________________________________________________
BOOL
CRegKey::EnumKeyEx(
DWORD iSubkey,
LPTSTR lpszName,
LPDWORD lpcchName,
PFILETIME lpszLastModified)
{
ASSERT(lpszName != NULL);
ASSERT(lpcchName != NULL);
ASSERT(*lpcchName != 0);
ASSERT(m_hKey != NULL); // key probably not opened
m_lastError = ::RegEnumKeyEx(m_hKey, iSubkey, lpszName, lpcchName,
NULL, NULL, NULL, lpszLastModified);
if (m_lastError == ERROR_SUCCESS)
{
return TRUE;
}
else if (m_lastError != ERROR_NO_MORE_ITEMS)
{
TRACE("CRegKey error %ld enumerating child %i of key 0x%x\n",
m_lastError, iSubkey, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
return FALSE;
}
//____________________________________________________________________________
//
// Member: CRegKey::EnumValue
//
// Synopsis: Same meaning as for RegEnumValue API.
//
// Arguments: [iValue] -- IN
// [lpszValue] -- OUT
// [lpcchValue] -- OUT
// [lpdwType] -- OUT
// [lpbData] -- OUT
// [lpcbData] -- OUT
//
// Returns: HRESULT. Returns ERROR_NO_MORE_ITEMS if no more items found,
// or ERROR_MORE_DATA if the buffer is too small.
//
// History: 6/6/1996 RaviR Created
// 2/20/02 JonN Security Push -- now returns HRESULT
//
//____________________________________________________________________________
HRESULT
CRegKey::EnumValue(
DWORD iValue,
LPTSTR lpszValue,
LPDWORD lpcchValue,
LPDWORD lpdwType,
LPBYTE lpbData,
LPDWORD lpcbData)
{
// JonN 2/20/02 Security Push
if (NULL == m_hKey)
{
ASSERT(FALSE);
return E_FAIL;
}
if ( IsBadWritePtr( lpcchValue, sizeof(DWORD) )
|| IsBadWritePtr( lpszValue, (*lpcchValue) * sizeof(TCHAR) ) )
{ // lpdwType, lpbData, lpcbData may be NULL
ASSERT(FALSE);
return E_POINTER;
}
m_lastError = ::RegEnumValue(m_hKey, iValue, lpszValue, lpcchValue,
NULL, lpdwType, lpbData, lpcbData);
// JonN 2/20/02 Security Push: handle ERROR_MORE_DATA properly
if ( m_lastError != ERROR_SUCCESS
&& m_lastError != ERROR_MORE_DATA
&& m_lastError != ERROR_NO_MORE_ITEMS )
{
TRACE("CRegKey error %ld enumerating value %i of key 0x%x\n",
m_lastError, iValue, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
return m_lastError;
}
//____________________________________________________________________________
//
// Member: CRegKey::SaveKey
//
// Synopsis: Same meaning as for RegSaveKey API.
//
// Arguments: [lpszFile] -- IN filename to save to.
// [lpsa] -- IN security structure
//
// Returns: void
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
//
void
CRegKey::SaveKey(
LPCTSTR lpszFile,
LPSECURITY_ATTRIBUTES lpsa)
{
ASSERT(lpszFile != NULL);
ASSERT(m_hKey != NULL);
m_lastError = ::RegSaveKey(m_hKey, lpszFile, lpsa);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld saving key 0x%x to file \"%s\"\n",
m_lastError, m_hKey, lpszFile);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
}
//____________________________________________________________________________
//
// Member: CRegKey::RestoreKey
//
// Synopsis: Same meaning as for RegRestoreKey API.
//
// Arguments: [lpszFile] -- IN filename containing saved tree
// [fdw] -- IN optional flags
//
// Returns: void
//
// History: 6/6/1996 RaviR Created
//
//____________________________________________________________________________
//
void
CRegKey::RestoreKey(
LPCTSTR lpszFile,
DWORD fdw)
{
ASSERT(lpszFile != NULL);
ASSERT(m_hKey != NULL);
m_lastError = ::RegRestoreKey(m_hKey, lpszFile, fdw);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld restoring key 0x%x from file \"%s\"\n",
m_lastError, m_hKey, lpszFile);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
}
//____________________________________________________________________________
//
// Member: CRegKey::NTRegDeleteKey, static
//
// Synopsis: Recursively deletes all the sub keys & finally the
// given start key itself.
//
// Arguments: [hStartKey] -- IN
// [pKeyName] -- IN
//
// Returns: LONG.
//
// History: 5/22/1996 RaviR Created
//
//____________________________________________________________________________
LONG
CRegKey::NTRegDeleteKey(
HKEY hStartKey,
LPCTSTR pKeyName)
{
ASSERT(pKeyName != NULL);
ASSERT(*pKeyName != TEXT('\0'));
DWORD dwSubKeyLength;
TCHAR szSubKey[MAX_PATH+2];
HKEY hKey;
LONG lr = ERROR_SUCCESS;
lr = ::RegOpenKeyEx(hStartKey, pKeyName, 0, KEY_ALL_ACCESS, &hKey);
if (lr != ERROR_SUCCESS)
{
return lr;
}
while (lr == ERROR_SUCCESS)
{
dwSubKeyLength = MAX_PATH;
lr = ::RegEnumKeyEx(hKey, 0, szSubKey, &dwSubKeyLength,
NULL, NULL, NULL, NULL);
if (lr == ERROR_NO_MORE_ITEMS)
{
lr = ::RegCloseKey(hKey);
if (lr == ERROR_SUCCESS)
{
lr = ::RegDeleteKey(hStartKey, pKeyName);
break;
}
}
else if (lr == ERROR_SUCCESS)
{
lr = NTRegDeleteKey(hKey, szSubKey);
}
else
{
// Dont reset lr here!
::RegCloseKey(hKey);
}
}
return lr;
}
////////////////////////////////////////////////////////////////////////////
//
// CRegKey formerly inline methods
//
CRegKey::CRegKey(HKEY hKey)
:
m_hKey(hKey),
m_lastError(ERROR_SUCCESS)
{
;
}
CRegKey::~CRegKey()
{
if (m_hKey != NULL)
{
this->CloseKey();
}
}
HKEY CRegKey::AttachKey(HKEY hKey)
{
HKEY hKeyOld = m_hKey;
m_hKey = hKey;
m_lastError = ERROR_SUCCESS;
return hKeyOld;
}
void CRegKey::DeleteValue(LPCTSTR lpszValueName)
{
ASSERT(m_hKey); // Key probably not opened or failed to open
m_lastError = ::RegDeleteValue(m_hKey, lpszValueName);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld deleting value \"%s\" from key 0x%x \n",
m_lastError, lpszValueName, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
}
void CRegKey::FlushKey(void)
{
ASSERT(m_hKey);
m_lastError = ::RegFlushKey(m_hKey);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld flushing key 0x%x \n",
m_lastError, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
}
void CRegKey::SetString(LPCTSTR lpszValueName, LPCTSTR lpszString)
{
ASSERT(lpszString);
// NATHAN CHECK
#ifndef UNICODE
//#error This will not work without UNICODE
#endif
this->SetValueEx(lpszValueName, REG_SZ, lpszString, lstrlen(lpszString)*sizeof(TCHAR));
}
void CRegKey::SetString(LPCTSTR lpszValueName, CStr& str)
{
this->SetValueEx(lpszValueName, REG_SZ, (LPCTSTR)str, (DWORD) str.GetLength());
}
void CRegKey::SetDword(LPCTSTR lpszValueName, DWORD dwData)
{
this->SetValueEx(lpszValueName, REG_DWORD, &dwData, sizeof(DWORD));
}
void CRegKey::ConnectRegistry(LPTSTR pszComputerName, HKEY hKey)
{
ASSERT(pszComputerName != NULL);
ASSERT(hKey == HKEY_LOCAL_MACHINE || hKey == HKEY_USERS);
ASSERT(m_hKey == NULL);
m_lastError = ::RegConnectRegistry(pszComputerName, hKey, &m_hKey);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld connecting to key 0x%x on remote machine \"%s\"\n",
m_lastError, m_hKey, pszComputerName);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
}
void CRegKey::SetKeySecurity(SECURITY_INFORMATION SecInf,
PSECURITY_DESCRIPTOR pSecDesc)
{
ASSERT(pSecDesc != NULL);
ASSERT(m_hKey != NULL);
m_lastError = ::RegSetKeySecurity(m_hKey, SecInf, pSecDesc);
if (m_lastError != ERROR_SUCCESS)
{
TRACE("CRegKey error %ld setting security on key 0x%x \n",
m_lastError, m_hKey);
AfxThrowOleException(PACKAGE_NOT_FOUND);
}
}