116 lines
4.3 KiB
C++
116 lines
4.3 KiB
C++
/*==========================================================================
|
|
*
|
|
* Copyright (C) 1999 Microsoft Corporation. All Rights Reserved.
|
|
*
|
|
* File: creg.h
|
|
* Content: definition of the CRegistry class
|
|
*
|
|
* History:
|
|
* Date By Reason
|
|
* ==== == ======
|
|
* 07/16/99 rodtoll Created
|
|
* 08/18/99 rodtoll Added Register/UnRegister that can be used to
|
|
* allow COM objects to register themselves.
|
|
* 08/25/99 rodtoll Updated to provide read/write of binary (blob) data
|
|
* 10/07/99 rodtoll Updated to work in Unicode
|
|
* 10/27/99 pnewson added Open() call that takes a GUID
|
|
* 01/18/00 mjn Added GetMaxKeyLen function
|
|
* 01/24/00 mjn Added GetValueSize function
|
|
* 04/05/2000 jtk Changed GetVauleSize to GetValueLength and modified to return WCHAR lengths
|
|
* 04/21/2000 rodtoll Bug #32889 - Does not run on Win2k on non-admin account
|
|
* rodtoll Bug #32952 - Does not run on Win95 GOLD w/o IE4 -- modified
|
|
* to allow reads of REG_BINARY when expecting REG_DWORD
|
|
* 07/09/2000 rodtoll Added signature bytes
|
|
* 08/28/2000 masonb Voice Merge: Modified platform checks to use osind.cpp layer (removed CRegistry::CheckUnicodePlatform)
|
|
* 04/13/2001 VanceO Moved granting registry permissions into common, and
|
|
* added DeleteValue and EnumValues.
|
|
* 06/19/2001 RichGr DX8.0 added special security rights for "everyone" - remove them if
|
|
* they exist with new RemoveAllAccessSecurityPermissions() method.
|
|
*
|
|
***************************************************************************/
|
|
|
|
#ifndef __CREGISTRY_H
|
|
#define __CREGISTRY_H
|
|
|
|
// Useful definition
|
|
#define MAX_REGISTRY_STRING_SIZE _MAX_PATH+1
|
|
|
|
#define DPN_KEY_ALL_ACCESS ((KEY_ALL_ACCESS & ~WRITE_DAC) & ~WRITE_OWNER)
|
|
|
|
|
|
#define VSIG_CREGISTRY 'GERV'
|
|
#define VSIG_CREGISTRY_FREE 'GER_'
|
|
|
|
// CRegistry
|
|
//
|
|
// This class handles reading/writing to the windows registry. Each instance
|
|
// of the CRegistry class is attached to a single registry handle, which is
|
|
// an open handle to a point in the registry tree.
|
|
//
|
|
class CRegistry
|
|
{
|
|
|
|
public:
|
|
|
|
CRegistry();
|
|
CRegistry( const CRegistry ®istry );
|
|
CRegistry( const HKEY branch, LPWSTR pathName, BOOL fReadOnly = TRUE, BOOL create = FALSE );
|
|
|
|
~CRegistry();
|
|
|
|
BOOL EnumKeys( LPWSTR lpwStrName, LPDWORD lpdwStringLen, DWORD index = 0 );
|
|
BOOL EnumValues( LPWSTR lpwStrName, LPDWORD lpdwStringLen, DWORD index = 0 );
|
|
|
|
BOOL Open( const HKEY branch, const LPCWSTR pathName, BOOL fReadOnly = TRUE, BOOL create = FALSE, BOOL fCustomSAM = FALSE, REGSAM samCustom = NULL);
|
|
BOOL Open( const HKEY branch, const GUID* lpguid, BOOL fReadOnly = TRUE, BOOL create = FALSE, BOOL fCustomSAM = FALSE, REGSAM samCustom = NULL);
|
|
BOOL Close();
|
|
|
|
BOOL IsOpen() { return m_isOpen; };
|
|
|
|
BOOL DeleteSubKey( LPCWSTR keyName );
|
|
BOOL DeleteSubKey( const GUID *pGuidName );
|
|
|
|
BOOL DeleteValue( LPCWSTR valueName );
|
|
|
|
BOOL ReadGUID( LPCWSTR keyName, GUID &guid );
|
|
BOOL WriteGUID( LPCWSTR keyName, const GUID &guid );
|
|
|
|
BOOL WriteString( LPCWSTR keyName, const LPCWSTR lpwstrValue );
|
|
BOOL ReadString( LPCWSTR keyName, LPWSTR lpwstrValue, LPDWORD lpdwLength );
|
|
|
|
BOOL WriteDWORD( LPCWSTR keyName, DWORD value );
|
|
BOOL ReadDWORD( LPCWSTR keyName, DWORD &result );
|
|
|
|
BOOL WriteBOOL( LPCWSTR keyName, BOOL value );
|
|
BOOL ReadBOOL( LPCWSTR keyName, BOOL &result );
|
|
|
|
BOOL ReadBlob( LPCWSTR keyName, LPBYTE lpbBuffer, LPDWORD lpdwSize );
|
|
BOOL WriteBlob( LPCWSTR keyName, LPBYTE lpbBuffer, DWORD dwSize );
|
|
|
|
BOOL GetMaxKeyLen( DWORD &dwMaxKeyLen );
|
|
BOOL GetValueLength( const LPCWSTR keyName, DWORD *const pdwValueLength );
|
|
|
|
BOOL GrantAllAccessSecurityPermissions();
|
|
BOOL RemoveAllAccessSecurityPermissions();
|
|
|
|
static BOOL Register( LPCWSTR lpszProgID, LPCWSTR lpszDesc, LPCWSTR lpszProgName, GUID guidCLSID, LPCWSTR lpszVerIndProgID );
|
|
static BOOL UnRegister( GUID guidCLSID );
|
|
|
|
// Data access functions
|
|
operator HKEY() const { return m_regHandle; };
|
|
HKEY GetBaseHandle() const { return m_baseHandle; };
|
|
HKEY GetHandle() const { return m_regHandle; };
|
|
|
|
protected:
|
|
|
|
DWORD m_dwSignature; // Signature
|
|
BOOL m_fReadOnly;
|
|
|
|
BOOL m_isOpen; // BOOL indicating if the object is open
|
|
HKEY m_regHandle; // Handle to the registry which is represented by this object
|
|
HKEY m_baseHandle; // Handle to the root of the part of the registry
|
|
// this object is in. E.g. HKEY_LOCAL_MACHINE
|
|
};
|
|
|
|
#endif
|