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

164 lines
3.7 KiB
C

/*++
Copyright (c) 1995 Microsoft Corporation
Module Name:
secinit.h
Abstract:
Contains prototypes for indirected security functions
Author:
Sophia Chung (sophiac) 7-Feb-1996
Revision History:
--*/
#if !defined(_SECINIT_)
#define _SECINIT_
#if defined(__cplusplus)
extern "C" {
#endif
#include <sspi.h>
#if defined(__cplusplus)
}
#endif
extern CCritSec InitializationSecLock;
extern PSecurityFunctionTable GlobalSecFuncTable;
extern WIN_VERIFY_TRUST_FN pWinVerifyTrust;
extern WT_HELPER_PROV_DATA_FROM_STATE_DATA_FN pWTHelperProvDataFromStateData;
extern HCERTSTORE g_hMyCertStore;
#define g_EnumerateSecurityPackages \
(*(GlobalSecFuncTable->EnumerateSecurityPackagesA))
#define g_AcquireCredentialsHandle \
(*(GlobalSecFuncTable->AcquireCredentialsHandleA))
#define g_FreeCredentialsHandle \
(*(GlobalSecFuncTable->FreeCredentialHandle))
#define g_InitializeSecurityContext \
(*(GlobalSecFuncTable->InitializeSecurityContextA))
#define g_DeleteSecurityContext \
(*(GlobalSecFuncTable->DeleteSecurityContext))
#define g_QueryContextAttributes \
(*(GlobalSecFuncTable->QueryContextAttributesA))
#define g_FreeContextBuffer \
(*(GlobalSecFuncTable->FreeContextBuffer))
#define g_SealMessage \
(*((SEAL_MESSAGE_FN)GlobalSecFuncTable->Reserved3))
#define g_UnsealMessage \
(*((UNSEAL_MESSAGE_FN)GlobalSecFuncTable->Reserved4))
LONG WINAPI WinVerifySecureChannel(HWND hwnd, WINTRUST_DATA *pWTD);
// Don't use WinVerifyTrust directly to verify secure channel connections.
// Use the wininet wrapper WinVerifySecureChannel instead.
#define g_WinVerifyTrust \
pWinVerifyTrust
typedef PSecurityFunctionTable (APIENTRY *INITSECURITYINTERFACE) (VOID);
#define CRYPT_INSTALL_DEFAULT_CONTEXT_NAME "CryptInstallDefaultContext"
typedef BOOL
(WINAPI * CRYPT_INSTALL_DEFAULT_CONTEXT_FN)
(
IN HCRYPTPROV hCryptProv,
IN DWORD dwDefaultType,
IN const void *pvDefaultPara,
IN DWORD dwFlags,
IN void *pvReserved,
OUT HCRYPTDEFAULTCONTEXT *phDefaultContext
);
#define CRYPT_UNINSTALL_DEFAULT_CONTEXT_NAME "CryptUninstallDefaultContext"
typedef BOOL
(WINAPI * CRYPT_UNINSTALL_DEFAULT_CONTEXT_FN)
(
HCRYPTDEFAULTCONTEXT hDefaultContext,
IN DWORD dwFlags,
IN void *pvReserved
);
typedef PCCERT_CHAIN_CONTEXT
(WINAPI *CERT_FIND_CHAIN_IN_STORE_FN)
(
IN HCERTSTORE hCertStore,
IN DWORD dwCertEncodingType,
IN DWORD dwFindFlags,
IN DWORD dwFindType,
IN const void *pvFindPara,
IN PCCERT_CHAIN_CONTEXT pPrevChainContext
);
#define CERT_FIND_CHAIN_IN_STORE_NAME "CertFindChainInStore"
typedef VOID
(WINAPI *CERT_FREE_CERTIFICATE_CHAIN_FN)
(
IN PCCERT_CHAIN_CONTEXT pChainContext
);
#define CERT_FREE_CERTIFICATE_CHAIN_NAME "CertFreeCertificateChain"
extern CRYPT_INSTALL_DEFAULT_CONTEXT_FN g_CryptInstallDefaultContext;
extern CRYPT_UNINSTALL_DEFAULT_CONTEXT_FN g_CryptUninstallDefaultContext;
extern CERT_FIND_CHAIN_IN_STORE_FN g_CertFindChainInStore;
extern CERT_FREE_CERTIFICATE_CHAIN_FN g_CertFreeCertificateChain;
extern HCRYPTPROV GlobalFortezzaCryptProv;
#define LOCK_SECURITY() (InitializationSecLock.Lock())
#define UNLOCK_SECURITY() (InitializationSecLock.Unlock())
//
// prototypes
//
BOOL
SecurityInitialize(
VOID
);
VOID
SecurityTerminate(
VOID
);
DWORD
LoadSecurity(
VOID
);
VOID
UnloadSecurity(
VOID
);
DWORD
LoadWinTrust(
VOID
);
BOOL
IsFortezzaInstalled(
VOID
);
#endif // _SECINIT_