2020-09-30 17:12:32 +02:00

192 lines
4.0 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>
extern CRITICAL_SECTION InitializationSecLock;
extern PSecurityFunctionTable GlobalSecFuncTable;
extern WIN_VERIFY_TRUST_FN pWinVerifyTrust;
extern WT_HELPER_PROV_DATA_FROM_STATE_DATA_FN pWTHelperProvDataFromStateData;
extern SSL_CRACK_CERTIFICATE_FN pSslCrackCertificate;
extern SSL_FREE_CERTIFICATE_FN pSslFreeCertificate;
extern HCERTSTORE g_hMyCertStore;
extern BOOL g_bOpenMyCertStore;
extern BOOL g_fDoSpecialMagicForSGCCerts;
#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
#define g_SslCrackCertificate \
pSslCrackCertificate
#define g_SslFreeCertificate pSslFreeCertificate
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() EnterCriticalSection( &InitializationSecLock )
#define UNLOCK_SECURITY() LeaveCriticalSection( &InitializationSecLock )
// prototypes
VOID
SecurityInitialize(
VOID
);
VOID
SecurityTerminate(
VOID
);
DWORD
ReopenMyCertStore(
VOID
);
DWORD
CloseMyCertStore(
VOID
);
DWORD
LoadSecurity(
VOID
);
VOID
UnloadSecurity(
VOID
);
DWORD
LoadWinTrust(
VOID
);
BOOL
IsFortezzaInstalled(
VOID
);
BOOL AttemptedFortezzaLogin(
VOID
);
DWORD FortezzaLogOn(
HWND hwnd
);
#if defined(__cplusplus)
}
#endif
#endif // _SECINIT_