783 lines
31 KiB
C
783 lines
31 KiB
C
//+-------------------------------------------------------------------------
|
|
//
|
|
// Microsoft Windows
|
|
//
|
|
// Copyright (C) Microsoft Corporation, 1996 - 1999
|
|
//
|
|
// File: mscat.h
|
|
//
|
|
// Contents: Microsoft Internet Security Catalog API
|
|
//
|
|
// History: 29-Apr-1997 pberkman created
|
|
// 09-Sep-1997 pberkman add CATAdmin functions
|
|
//
|
|
//--------------------------------------------------------------------------
|
|
|
|
|
|
#ifndef MSCAT_H
|
|
#define MSCAT_H
|
|
|
|
|
|
#if _MSC_VER > 1000
|
|
#pragma once
|
|
#endif
|
|
|
|
#include "mssip.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C"
|
|
{
|
|
#endif
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// defines:
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
#define szOID_CATALOG_LIST "1.3.6.1.4.1.311.12.1.1"
|
|
#define szOID_CATALOG_LIST_MEMBER "1.3.6.1.4.1.311.12.1.2"
|
|
|
|
#define CRYPTCAT_FILEEXT L"CAT"
|
|
|
|
#define CRYPTCAT_MAX_MEMBERTAG 64
|
|
|
|
//
|
|
// fdwOpenFlags
|
|
//
|
|
#define CRYPTCAT_OPEN_CREATENEW 0x00000001 // creates/overwrites
|
|
#define CRYPTCAT_OPEN_ALWAYS 0x00000002 // opens/creates
|
|
#define CRYPTCAT_OPEN_EXISTING 0x00000004 // opens only
|
|
|
|
#define CRYPTCAT_OPEN_VERIFYSIGHASH 0x10000000 // verifies the signature (not the certs!)
|
|
|
|
//
|
|
// fdwMemberFlags (used internal -- do not fill)
|
|
//
|
|
|
|
//
|
|
// dwAttrTypeAndAction
|
|
//
|
|
#define CRYPTCAT_ATTR_AUTHENTICATED 0x10000000
|
|
#define CRYPTCAT_ATTR_UNAUTHENTICATED 0x20000000
|
|
|
|
#define CRYPTCAT_ATTR_NAMEASCII 0x00000001 // ascii string
|
|
#define CRYPTCAT_ATTR_NAMEOBJID 0x00000002 // crypt obj id
|
|
|
|
#define CRYPTCAT_ATTR_DATAASCII 0x00010000 // do not decode simple ascii chars
|
|
#define CRYPTCAT_ATTR_DATABASE64 0x00020000 // base 64
|
|
#define CRYPTCAT_ATTR_DATAREPLACE 0x00040000 // this data is a replacment for an existing attr
|
|
|
|
//
|
|
// dwLocalError - CDF Parse
|
|
//
|
|
#define CRYPTCAT_E_AREA_HEADER 0x00000000
|
|
#define CRYPTCAT_E_AREA_MEMBER 0x00010000
|
|
#define CRYPTCAT_E_AREA_ATTRIBUTE 0x00020000
|
|
|
|
#define CRYPTCAT_E_CDF_UNSUPPORTED 0x00000001
|
|
#define CRYPTCAT_E_CDF_DUPLICATE 0x00000002
|
|
#define CRYPTCAT_E_CDF_TAGNOTFOUND 0x00000004
|
|
|
|
#define CRYPTCAT_E_CDF_MEMBER_FILE_PATH 0x00010001
|
|
#define CRYPTCAT_E_CDF_MEMBER_INDIRECTDATA 0x00010002
|
|
#define CRYPTCAT_E_CDF_MEMBER_FILENOTFOUND 0x00010004
|
|
|
|
#define CRYPTCAT_E_CDF_BAD_GUID_CONV 0x00020001
|
|
#define CRYPTCAT_E_CDF_ATTR_TOOFEWVALUES 0x00020002
|
|
#define CRYPTCAT_E_CDF_ATTR_TYPECOMBO 0x00020004
|
|
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// structures:
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include <pshpack8.h>
|
|
|
|
typedef struct CRYPTCATSTORE_
|
|
{
|
|
DWORD cbStruct; // = sizeof(CRYPTCATSTORE)
|
|
DWORD dwPublicVersion;
|
|
LPWSTR pwszP7File;
|
|
HCRYPTPROV hProv;
|
|
DWORD dwEncodingType;
|
|
DWORD fdwStoreFlags;
|
|
HANDLE hReserved; // pStack(members) (null if init/pbData) INTERNAL!
|
|
|
|
// 18-Sep-1997 pberkman: added
|
|
HANDLE hAttrs; // pStack(Catalog attrs) INTERNAL!
|
|
|
|
} CRYPTCATSTORE;
|
|
|
|
typedef struct CRYPTCATMEMBER_
|
|
{
|
|
DWORD cbStruct; // = sizeof(CRYPTCATMEMBER)
|
|
LPWSTR pwszReferenceTag;
|
|
LPWSTR pwszFileName; // used only by the CDF APIs
|
|
GUID gSubjectType; // may be zeros -- see sEncodedMemberInfo
|
|
DWORD fdwMemberFlags;
|
|
struct SIP_INDIRECT_DATA_ *pIndirectData; // may be null -- see sEncodedIndirectData
|
|
DWORD dwCertVersion; // may be zero -- see sEncodedMemberInfo
|
|
DWORD dwReserved; // used by enum -- DO NOT USE!
|
|
HANDLE hReserved; // pStack(attrs) (null if init) INTERNAL!
|
|
|
|
// 30-Sep-1997 pberkman: added
|
|
CRYPT_ATTR_BLOB sEncodedIndirectData; // lazy decode
|
|
CRYPT_ATTR_BLOB sEncodedMemberInfo; // lazy decode
|
|
|
|
} CRYPTCATMEMBER;
|
|
|
|
typedef struct CRYPTCATATTRIBUTE_
|
|
{
|
|
DWORD cbStruct; // = sizeof(CRYPTCATATTRIBUTE)
|
|
LPWSTR pwszReferenceTag;
|
|
DWORD dwAttrTypeAndAction;
|
|
DWORD cbValue;
|
|
BYTE *pbValue; // encoded CAT_NAMEVALUE struct
|
|
DWORD dwReserved; // used by enum -- DO NOT USE!
|
|
|
|
} CRYPTCATATTRIBUTE;
|
|
|
|
typedef struct CRYPTCATCDF_
|
|
{
|
|
DWORD cbStruct; // = sizeof(CRYPTCATCDF)
|
|
HANDLE hFile;
|
|
DWORD dwCurFilePos;
|
|
DWORD dwLastMemberOffset;
|
|
BOOL fEOF;
|
|
LPWSTR pwszResultDir;
|
|
HANDLE hCATStore;
|
|
|
|
} CRYPTCATCDF;
|
|
|
|
typedef struct CATALOG_INFO_
|
|
{
|
|
DWORD cbStruct; // set to sizeof(CATALOG_INFO)
|
|
|
|
WCHAR wszCatalogFile[MAX_PATH];
|
|
|
|
} CATALOG_INFO;
|
|
|
|
typedef HANDLE HCATADMIN;
|
|
typedef HANDLE HCATINFO;
|
|
|
|
#include <poppack.h>
|
|
|
|
typedef void (WINAPI *PFN_CDF_PARSE_ERROR_CALLBACK)(IN DWORD dwErrorArea,
|
|
IN DWORD dwLocalError,
|
|
IN WCHAR *pwszLine);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Prototypes:
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Open:
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// open the catalog for Get/Put operations.
|
|
//
|
|
// Return:
|
|
// INVALID_HANDLE_VALUE: an error occured while opening Catalog
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern HANDLE WINAPI CryptCATOpen(IN LPWSTR pwszFileName,
|
|
IN DWORD fdwOpenFlags,
|
|
IN OPTIONAL HCRYPTPROV hProv,
|
|
IN OPTIONAL DWORD dwPublicVersion,
|
|
IN OPTIONAL DWORD dwEncodingType);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Close:
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// close the catalog handle.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern BOOL WINAPI CryptCATClose(IN HANDLE hCatalog);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// StoreFromHandle:
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// retrieve the CRYPTCATSTORE from the store handle.
|
|
//
|
|
// *** DO NOT FREE THE POINTER OR ANY OF ITS MEMBERS! ***
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATSTORE * WINAPI CryptCATStoreFromHandle(IN HANDLE hCatalog);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// HandleFromStore:
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// retrieve the handle from a CRYPTCATSTORE pointer.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern HANDLE WINAPI CryptCATHandleFromStore(IN CRYPTCATSTORE *pCatStore);
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// PersistStore
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Persist the information in the current Catalog Store to an unsigned
|
|
// Catalog File. It is REQUIRED to fill in the pwszP7File member
|
|
// of CRYPTCATSTORE prior to this call!
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern BOOL WINAPI CryptCATPersistStore(IN HANDLE hCatalog);
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATGetCatAttrInfo
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
//
|
|
// *** DO NOT FREE THE POINTER OR ANY OF ITS MEMBERS! ***
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATATTRIBUTE * WINAPI CryptCATGetCatAttrInfo(IN HANDLE hCatalog,
|
|
IN LPWSTR pwszReferenceTag);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATPutCatAttrInfo
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Allocates and adds the attribute to the catalog. Returns a pointer
|
|
// to the allocated attribute.
|
|
//
|
|
// *** DO NOT FREE THE POINTER OR ANY OF ITS MEMBERS! ***
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATATTRIBUTE * WINAPI CryptCATPutCatAttrInfo(IN HANDLE hCatalog,
|
|
IN LPWSTR pwszReferenceTag,
|
|
IN DWORD dwAttrTypeAndAction,
|
|
IN DWORD cbData,
|
|
IN BYTE *pbData);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATEnumerateCatAttr
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Enumerates through the list of attributes associated with the catalog.
|
|
// Returns a pointer to the attribute. This return should be passed in
|
|
// as the 'PrevAttr' to continue the enumeration. On the first call,
|
|
// the 'PrevAttr' should be set to NULL.
|
|
//
|
|
// *** DO NOT FREE THE POINTER OR ANY OF ITS MEMBERS! ***
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATATTRIBUTE * WINAPI CryptCATEnumerateCatAttr(IN HANDLE hCatalog,
|
|
IN CRYPTCATATTRIBUTE *pPrevAttr);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATGetMemberInfo
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Retrieve the Tag info (member info) structure from the catalog
|
|
// PKCS#7, fill the CRYPTCATMEMBER structure, and return. -- Opens a
|
|
// member context.
|
|
//
|
|
// *** DO NOT FREE THE POINTER OR ANY OF ITS MEMBERS! ***
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATMEMBER * WINAPI CryptCATGetMemberInfo(IN HANDLE hCatalog,
|
|
IN LPWSTR pwszReferenceTag);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATGetAttr:
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// get pwszReferenceTag attribute information for a member.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATATTRIBUTE * WINAPI CryptCATGetAttrInfo(IN HANDLE hCatalog,
|
|
IN CRYPTCATMEMBER *pCatMember,
|
|
IN LPWSTR pwszReferenceTag);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATPutMemberInfo
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Allocates and adds the member to the catalog. Returns a pointer
|
|
// to the allocated member.
|
|
//
|
|
// *** DO NOT FREE THE POINTER OR ANY OF ITS MEMBERS! ***
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
// CRYPT_E_EXISTS: the reference tag already exists
|
|
// CRYPT_E_NOT_FOUND: the attr was not found
|
|
//
|
|
extern CRYPTCATMEMBER * WINAPI CryptCATPutMemberInfo(IN HANDLE hCatalog,
|
|
IN OPTIONAL LPWSTR pwszFileName,
|
|
IN LPWSTR pwszReferenceTag,
|
|
IN GUID *pgSubjectType,
|
|
IN DWORD dwCertVersion,
|
|
IN DWORD cbSIPIndirectData,
|
|
IN BYTE *pbSIPIndirectData);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATPutAttrInfo
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Allocates and adds the attribute to the member. Returns a pointer
|
|
// to the allocated attribute.
|
|
//
|
|
// *** DO NOT FREE THE POINTER OR ANY OF ITS MEMBERS! ***
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATATTRIBUTE * WINAPI CryptCATPutAttrInfo(IN HANDLE hCatalog,
|
|
IN CRYPTCATMEMBER *pCatMember,
|
|
IN LPWSTR pwszReferenceTag,
|
|
IN DWORD dwAttrTypeAndAction,
|
|
IN DWORD cbData,
|
|
IN BYTE *pbData);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATEnumerateMember
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Enumerates through the list of members in the store. Returns a pointer
|
|
// to the member. This return should be passed in as the 'PrevMember' to
|
|
// continue the enumeration. On the first call, the 'PrevMember' should
|
|
// be set to NULL.
|
|
//
|
|
// *** DO NOT FREE THE POINTER OR ANY OF ITS MEMBERS! ***
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATMEMBER * WINAPI CryptCATEnumerateMember(IN HANDLE hCatalog,
|
|
IN CRYPTCATMEMBER *pPrevMember);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATEnumerateAttr
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Enumerates through the list of attributes associated with the member.
|
|
// Returns a pointer to the attribute. This return should be passed in
|
|
// as the 'PrevAttr' to continue the enumeration. On the first call,
|
|
// the 'PrevAttr' should be set to NULL.
|
|
//
|
|
// *** DO NOT FREE THE POINTER OR ANY OF ITS MEMBERS! ***
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATATTRIBUTE * WINAPI CryptCATEnumerateAttr(IN HANDLE hCatalog,
|
|
IN CRYPTCATMEMBER *pCatMember,
|
|
IN CRYPTCATATTRIBUTE *pPrevAttr);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATCDFOpen
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Opens the specified CDF file and initialized the structure
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
// ERROR_FILE_NOT_FOUND: the CDF file was not found
|
|
//
|
|
extern CRYPTCATCDF * WINAPI CryptCATCDFOpen(IN LPWSTR pwszFilePath,
|
|
IN OPTIONAL PFN_CDF_PARSE_ERROR_CALLBACK pfnParseError);
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATCDFClose
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Closes the CDF file and deallocates the structure
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern BOOL WINAPI CryptCATCDFClose(IN CRYPTCATCDF *pCDF);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATCDFEnumCatAttributes
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Enumerates Catalog level attributes within the "[CatalogFiles]"
|
|
// section of the CDF.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATATTRIBUTE * WINAPI CryptCATCDFEnumCatAttributes(CRYPTCATCDF *pCDF,
|
|
CRYPTCATATTRIBUTE *pPrevAttr,
|
|
PFN_CDF_PARSE_ERROR_CALLBACK pfnParseError);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATCDFEnumMembers
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Enumerates files within the "[CatalogFiles]" section of the CDF.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATMEMBER * WINAPI CryptCATCDFEnumMembers(IN CRYPTCATCDF *pCDF,
|
|
IN CRYPTCATMEMBER *pPrevMember,
|
|
IN OPTIONAL PFN_CDF_PARSE_ERROR_CALLBACK pfnParseError);
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATCDFEnumAttributes
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Enumerates the files attributes within the "[CatalogFiles]" section
|
|
// of the CDF.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
extern CRYPTCATATTRIBUTE *WINAPI CryptCATCDFEnumAttributes(IN CRYPTCATCDF *pCDF,
|
|
IN CRYPTCATMEMBER *pMember,
|
|
IN CRYPTCATATTRIBUTE *pPrevAttr,
|
|
IN OPTIONAL PFN_CDF_PARSE_ERROR_CALLBACK pfnParseError);
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// IsCatalogFile
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Call this function to determine if the file is a Catalog File. Both
|
|
// parameters are optional. HOWEVER, one of them MUST be passed!
|
|
//
|
|
// Return:
|
|
// TRUE if it is.
|
|
// FALSE if it isn't or an error occured.
|
|
//
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
// ERROR_NOT_ENOUGH_MEMORY: a memory allocation failed
|
|
// {file errors} a file error occured
|
|
//
|
|
extern BOOL WINAPI IsCatalogFile(IN OPTIONAL HANDLE hFile,
|
|
IN OPTIONAL WCHAR *pwszFileName);
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATAdminAcquireContext
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Opens a new Admin Context based on the pgSubsystem Id.
|
|
//
|
|
// the Guid passed in will be converted to a string and used as the
|
|
// sub-directory under %SystemRoot%\CatRoot to store all Catalog files
|
|
// for this app/sub-system.
|
|
//
|
|
// if a NULL is passed in to the pgSubsystem parameter, all finds will be
|
|
// "global" and any Adds will be under the "default" Subsystem.
|
|
//
|
|
// Return:
|
|
// TRUE if phCatAdmin points to a valid context.
|
|
// FALSE if an error occurs.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
// ERROR_NOT_ENOUGH_MEMORY: a memory allocation failed
|
|
// ERROR_DATABASE_FAILURE: an error occured while processing
|
|
// the database.
|
|
//
|
|
// Comments:
|
|
// The dwFlags parameter is reserved for future use. Must
|
|
// be set to NULL.
|
|
//
|
|
//
|
|
extern BOOL WINAPI CryptCATAdminAcquireContext(OUT HCATADMIN *phCatAdmin,
|
|
IN const GUID *pgSubsystem,
|
|
IN DWORD dwFlags);
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATAdminReleaseContext
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Releases (frees) all information related to the Admin Context
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
// Comments:
|
|
// The dwFlags parameter is reserved for future use. Must
|
|
// be set to NULL.
|
|
//
|
|
extern BOOL WINAPI CryptCATAdminReleaseContext(IN HCATADMIN hCatAdmin,
|
|
IN DWORD dwFlags);
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATAdminReleaseCatalogContext
|
|
// -----------------------------------------------------------------------
|
|
// Usage:
|
|
// Call this function to release memory associated with the Catalog
|
|
// Info Context.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
// Comments:
|
|
// the dwFlags parameter is reserved for future use and must be assigned
|
|
// to NULL.
|
|
//
|
|
extern BOOL WINAPI CryptCATAdminReleaseCatalogContext(IN HCATADMIN hCatAdmin,
|
|
IN HCATINFO hCatInfo,
|
|
IN DWORD dwFlags);
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATAdminEnumCatalogFromHash
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Call this function to retrieve the Catalog Info handle of the Catalog
|
|
// file that currently "points" to the specified Member Hash.
|
|
//
|
|
// if hCatInfo is NULL, the first catalog found that contains the
|
|
// hash will be returned.
|
|
//
|
|
// if hCatInfo is not NULL, the content must be initialized to NULL prior
|
|
// to going into the enum loop -- this starts the first/next search.
|
|
// This function uses this parameter to determine the last catalog returned.
|
|
//
|
|
// if hCatInfo is not NULL, and the loop is terminated prior to this
|
|
// function returning NULL, the application must call
|
|
// CryptCATAdminReleaseCatalogContext to free all memory associated with
|
|
// ppPrevContext.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
// ERROR_NOT_ENOUGH_MEMORY: a memory allocation failed
|
|
// ERROR_DATABASE_FAILURE: an error occurred while processing
|
|
// the database.
|
|
//
|
|
extern HCATINFO WINAPI CryptCATAdminEnumCatalogFromHash(IN HCATADMIN hCatAdmin,
|
|
IN BYTE *pbHash,
|
|
IN DWORD cbHash,
|
|
IN DWORD dwFlags,
|
|
IN OUT HCATINFO *phPrevCatInfo);
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATAdminCalcHashFromFileHandle
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Call this function to calculate the has based on an open file handle.
|
|
//
|
|
// Return:
|
|
// TRUE if the pbHash was filled with the calculated hash.
|
|
// FALSE if an error occured
|
|
//
|
|
// To obtain the size required for pbHash, set pbHash to NULL. The
|
|
// correct size will be returned in pcbHash, the return value will
|
|
// be TRUE and a call to GetLastError() will equal ERROR_INSUFFICIENT_BUFFER.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
// ERROR_INSUFFICIENT_BUFFER: the *pbHash was not big enough.
|
|
// ERROR_NOT_ENOUGH_MEMORY: a memory allocation failed
|
|
//
|
|
// Comments:
|
|
// the dwFlags parameter is reserved for future use and must be assigned
|
|
// to NULL.
|
|
//
|
|
extern BOOL WINAPI CryptCATAdminCalcHashFromFileHandle(IN HANDLE hFile,
|
|
IN OUT DWORD *pcbHash,
|
|
OUT OPTIONAL BYTE *pbHash,
|
|
IN DWORD dwFlags);
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATAdminAddCatalog
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Call this function to add a catalog file to the CAT Maintenance
|
|
// subsystem.
|
|
//
|
|
// if the pwszSelectedBaseName is NULL, the Catalog Admin system will
|
|
// generate a file base name for you. Otherwise, this parameter is
|
|
// used as the file name (base & extension only) of the copied Catalog
|
|
// file.
|
|
//
|
|
// Call CryptCATAdminReleaseCatalogContext to free the memory associated
|
|
// with the Catalog Context returned if not NULL.
|
|
//
|
|
// Return:
|
|
// On success, the HCATINFO of the catalog that was successfully added
|
|
// is returned. On failure, NULL is returned.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
// ERROR_NOT_ENOUGH_MEMORY: a memory allocation failed
|
|
// ERROR_BAD_FORMAT: the file is not a catalog file.
|
|
// ERROR_DATABASE_FAILURE: an error occurred while processing
|
|
// the database.
|
|
//
|
|
// Comments:
|
|
// the dwFlags parameter is reserved for future use and must be assigned
|
|
// to NULL.
|
|
//
|
|
extern HCATINFO WINAPI CryptCATAdminAddCatalog(IN HCATADMIN hCatAdmin,
|
|
IN WCHAR *pwszCatalogFile,
|
|
IN OPTIONAL WCHAR *pwszSelectBaseName,
|
|
IN DWORD dwFlags);
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATAdminRemoveCatalog
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// Call this function to remove a catalog file from the CAT Maintenance
|
|
// subsystem.
|
|
//
|
|
// Return:
|
|
// On success, TRUE is returned. FALSE if an error occurs.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
// Comments:
|
|
// pwszCatalogFile must point to a string that contains only the name
|
|
// of the catalog file, ex. "foo.cat", and not a fully qualified path
|
|
// name
|
|
//
|
|
extern BOOL WINAPI CryptCATAdminRemoveCatalog(IN HCATADMIN hCatAdmin,
|
|
IN LPCWSTR pwszCatalogFile,
|
|
IN DWORD dwFlags);
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATCatalogInfoFromContext
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// call this function to retrieve information relating to the
|
|
// Catalog info handle passed from the Add Catalog function.
|
|
//
|
|
// Return:
|
|
// On success, TRUE is returned and the CATALOG_INFO structure
|
|
// is filled in.
|
|
// FALSE if an error occurs.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
//
|
|
// Comments:
|
|
// the dwFlags parameter is reserved for future use and must be assigned
|
|
// to NULL.
|
|
//
|
|
extern BOOL WINAPI CryptCATCatalogInfoFromContext(IN HCATINFO hCatInfo,
|
|
IN OUT CATALOG_INFO *psCatInfo,
|
|
IN DWORD dwFlags);
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATAdminResolveCatalogPath
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// call this function to retrieve the fully qualified path to the
|
|
// catalog specified by pwszCatalogFile
|
|
//
|
|
// Return:
|
|
// On success, TRUE is returned and the CATALOG_INFO structure
|
|
// is filled in.
|
|
// FALSE if an error occurs.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
// ERROR_NOT_ENOUGH_MEMORY: if the fully qualified path is longer
|
|
// than MAX_PATH
|
|
//
|
|
// Comments:
|
|
// the dwFlags parameter is reserved for future use and must be assigned
|
|
// to NULL.
|
|
//
|
|
extern BOOL WINAPI CryptCATAdminResolveCatalogPath(IN HCATADMIN hCatAdmin,
|
|
IN WCHAR *pwszCatalogFile,
|
|
IN OUT CATALOG_INFO *psCatInfo,
|
|
IN DWORD dwFlags);
|
|
|
|
//////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// CryptCATAdminPauseServiceForBackup
|
|
// --------------------------------------------------------------------------
|
|
// Usage:
|
|
// call this function to pause the catalog sub-system in preparation
|
|
// for backing up the catalog sub-systems files.
|
|
//
|
|
// Return:
|
|
// On success, TRUE is returned. FALSE if an error occurs.
|
|
//
|
|
// Errors:
|
|
// ERROR_INVALID_PARAMETER: an input parameter is incorrect
|
|
// ERROR_TIMEOUT: if clients are accessing database files
|
|
// and fail to relinquish them in a timely
|
|
// manner.
|
|
//
|
|
// Comments:
|
|
// the dwFlags parameter is reserved for future use and must be assigned
|
|
// to NULL. Set fResume to FALSE when pausing the catalog service, and
|
|
// set it to TRUE to resume service.
|
|
//
|
|
extern BOOL WINAPI CryptCATAdminPauseServiceForBackup(IN DWORD dwFlags,
|
|
IN BOOL fResume);
|
|
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif // MSCAT_H
|
|
|