|
|
/*++
Copyright (C) Microsoft Corporation, 1996 - 1999
Module Name:
cspDirect
Abstract:
This file provides direct linkage to a CSP, so it does not have to be in a separate DLL. This facilitates code generation and debugging.
Author:
Doug Barlow (dbarlow) 5/8/1996
Environment:
Win32
Notes:
?Notes?
--*/
#ifndef WIN32_LEAN_AND_MEAN
#define WIN32_LEAN_AND_MEAN
#endif
#include <windows.h>
#include "cspUtils.h"
#ifdef _CSPDIRECT_H_
#ifdef CSP_BREAK
#define entrypoint breakpoint
#else
#define entrypoint
#endif
static int WINAPI SayYes( IN LPCTSTR szImage, IN LPBYTE pbSignature) { return TRUE; }
static int WINAPI GetWnd( HWND *phWnd) { if (NULL != phWnd) *phWnd = NULL; return (int)NULL; }
static HCRYPTPROV g_hProv = NULL;
CSPBOOL CSPAcquireContextA( HCRYPTPROV *phProv, LPCSTR pszContainer, LPCSTR pszProvider, DWORD dwProvType, DWORD dwFlags) { #ifdef UNICODE
return CRYPT_FAILED; #else
BOOL fSts; VTableProvStruc VTable;
VTable.Version = 3; VTable.FuncVerifyImage = (FARPROC)SayYes; VTable.FuncReturnhWnd = (FARPROC)GetWnd; VTable.dwProvType = dwProvType; VTable.pbContextInfo = NULL; VTable.cbContextInfo = 0; VTable.pszProvName = const_cast<LPTSTR>(pszProvider); entrypoint; fSts = CPAcquireContext( phProv, pszContainer, dwFlags, &VTable); g_hProv = *phProv; return fSts; #endif
}
CSPBOOL CSPAcquireContextW( HCRYPTPROV *phProv, LPCWSTR pszContainer, LPCWSTR pszProvider, DWORD dwProvType, DWORD dwFlags) { #ifdef UNICODE
BOOL fSts; VTableProvStruc VTable;
VTable.Version = 3; VTable.FuncVerifyImage = (FARPROC)SayYes; VTable.FuncReturnhWnd = (FARPROC)GetWnd; VTable.dwProvType = dwProvType; VTable.pbContextInfo = NULL; VTable.cbContextInfo = 0; VTable.pszProvName = pszProvider; entrypoint; fSts = CPAcquireContext( phProv, pszContainer, dwFlags, &VTable); g_hProv = *phProv; return fSts; #else
return CRYPT_FAILED; #endif
}
CSPBOOL CSPReleaseContext( HCRYPTPROV hProv, DWORD dwFlags) { ASSERT(g_hProv == hProv); g_hProv = NULL; entrypoint; return CPReleaseContext( hProv, dwFlags); }
CSPBOOL CSPGenKey( HCRYPTPROV hProv, ALG_ID Algid, DWORD dwFlags, HCRYPTKEY *phKey) { ASSERT(g_hProv == hProv); entrypoint; return CPGenKey( hProv, Algid, dwFlags, phKey); }
CSPBOOL CSPDeriveKey( HCRYPTPROV hProv, ALG_ID Algid, HCRYPTHASH hBaseData, DWORD dwFlags, HCRYPTKEY *phKey) { ASSERT(g_hProv == hProv); entrypoint; return CPDeriveKey( hProv, Algid, hBaseData, dwFlags, phKey); }
CSPBOOL CSPDestroyKey( HCRYPTKEY hKey) { entrypoint; return CPDestroyKey( g_hProv, hKey); }
CSPBOOL CSPSetKeyParam( HCRYPTKEY hKey, DWORD dwParam, BYTE *pbData, DWORD dwFlags) { entrypoint; return CPSetKeyParam( g_hProv, hKey, dwParam, pbData, dwFlags); }
CSPBOOL CSPGetKeyParam( HCRYPTKEY hKey, DWORD dwParam, BYTE *pbData, DWORD *pdwDataLen, DWORD dwFlags) { entrypoint; return CPGetKeyParam( g_hProv, hKey, dwParam, pbData, pdwDataLen, dwFlags); }
CSPBOOL CSPSetHashParam( HCRYPTHASH hHash, DWORD dwParam, BYTE *pbData, DWORD dwFlags) { entrypoint; return CPSetHashParam( g_hProv, hHash, dwParam, pbData, dwFlags); }
CSPBOOL CSPGetHashParam( HCRYPTHASH hHash, DWORD dwParam, BYTE *pbData, DWORD *pdwDataLen, DWORD dwFlags) { entrypoint; return CPGetHashParam( g_hProv, hHash, dwParam, pbData, pdwDataLen, dwFlags); }
CSPBOOL CSPSetProvParam( HCRYPTPROV hProv, DWORD dwParam, BYTE *pbData, DWORD dwFlags) { ASSERT(g_hProv == hProv); entrypoint; return CPSetProvParam( hProv, dwParam, pbData, dwFlags); }
CSPBOOL CSPGetProvParam( HCRYPTPROV hProv, DWORD dwParam, BYTE *pbData, DWORD *pdwDataLen, DWORD dwFlags) { ASSERT(g_hProv == hProv); entrypoint; return CPGetProvParam( hProv, dwParam, pbData, pdwDataLen, dwFlags); }
CSPBOOL CSPGenRandom( HCRYPTPROV hProv, DWORD dwLen, BYTE *pbBuffer) { ASSERT(g_hProv == hProv); entrypoint; return CPGenRandom( hProv, dwLen, pbBuffer); }
CSPBOOL CSPGetUserKey( HCRYPTPROV hProv, DWORD dwKeySpec, HCRYPTKEY *phUserKey) { ASSERT(g_hProv == hProv); entrypoint; return CPGetUserKey( hProv, dwKeySpec, phUserKey); }
CSPBOOL CSPExportKey( HCRYPTKEY hKey, HCRYPTKEY hExpKey, DWORD dwBlobType, DWORD dwFlags, BYTE *pbData, DWORD *pdwDataLen) { entrypoint; return CPExportKey( g_hProv, hKey, hExpKey, dwBlobType, dwFlags, pbData, pdwDataLen); }
CSPBOOL CSPImportKey( HCRYPTPROV hProv, CONST BYTE *pbData, DWORD dwDataLen, HCRYPTKEY hPubKey, DWORD dwFlags, HCRYPTKEY *phKey) { ASSERT(g_hProv == hProv); entrypoint; return CPImportKey( hProv, pbData, dwDataLen, hPubKey, dwFlags, phKey); }
CSPBOOL CSPEncrypt( HCRYPTKEY hKey, HCRYPTHASH hHash, BOOL Final, DWORD dwFlags, BYTE *pbData, DWORD *pdwDataLen, DWORD dwBufLen) { entrypoint; return CPEncrypt( g_hProv, hKey, hHash, Final, dwFlags, pbData, pdwDataLen, dwBufLen); }
CSPBOOL CSPDecrypt( HCRYPTKEY hKey, HCRYPTHASH hHash, BOOL Final, DWORD dwFlags, BYTE *pbData, DWORD *pdwDataLen) { entrypoint; return CPDecrypt( g_hProv, hKey, hHash, Final, dwFlags, pbData, pdwDataLen); }
CSPBOOL CSPCreateHash( HCRYPTPROV hProv, ALG_ID Algid, HCRYPTKEY hKey, DWORD dwFlags, HCRYPTHASH *phHash) { ASSERT(g_hProv == hProv); entrypoint; return CPCreateHash( hProv, Algid, hKey, dwFlags, phHash); }
CSPBOOL CSPHashData( HCRYPTHASH hHash, CONST BYTE *pbData, DWORD dwDataLen, DWORD dwFlags) { entrypoint; return CPHashData( g_hProv, hHash, pbData, dwDataLen, dwFlags); }
CSPBOOL CSPHashSessionKey( HCRYPTHASH hHash, HCRYPTKEY hKey, DWORD dwFlags) { entrypoint; return CPHashSessionKey( g_hProv, hHash, hKey, dwFlags); }
/*
CSPBOOL CSPGetHashValue( HCRYPTHASH hHash, DWORD dwFlags, BYTE *pbHash, DWORD *pdwHashLen) { entrypoint; return CPGetHashValue( g_hProv, hHash, dwFlags, pbHash, pdwHashLen); } */
CSPBOOL CSPDestroyHash( HCRYPTHASH hHash) { entrypoint; return CPDestroyHash( g_hProv, hHash); }
CSPBOOL CSPSignHashA( HCRYPTHASH hHash, DWORD dwKeySpec, LPCSTR sDescription, DWORD dwFlags, BYTE *pbSignature, DWORD *pdwSigLen) { #ifdef UNICODE
return CRYPT_FAILED; #else
entrypoint; return CPSignHash( g_hProv, hHash, dwKeySpec, sDescription, dwFlags, pbSignature, pdwSigLen); #endif
}
CSPBOOL CSPSignHashW( HCRYPTHASH hHash, DWORD dwKeySpec, LPCWSTR sDescription, DWORD dwFlags, BYTE *pbSignature, DWORD *pdwSigLen) { #ifdef UNICODE
entrypoint; return CPSignHash( g_hProv, hHash, dwKeySpec, sDescription, dwFlags, pbSignature, pdwSigLen); #else
return CRYPT_FAILED; #endif
}
CSPBOOL CSPVerifySignatureA( HCRYPTHASH hHash, CONST BYTE *pbSignature, DWORD dwSigLen, HCRYPTKEY hPubKey, LPCSTR sDescription, DWORD dwFlags) { #ifdef UNICODE
return CRYPT_FAILED; #else
entrypoint; return CPVerifySignature( g_hProv, hHash, pbSignature, dwSigLen, hPubKey, sDescription, dwFlags); #endif
}
CSPBOOL CSPVerifySignatureW( HCRYPTHASH hHash, CONST BYTE *pbSignature, DWORD dwSigLen, HCRYPTKEY hPubKey, LPCWSTR sDescription, DWORD dwFlags) { #ifdef UNICODE
entrypoint; return CPVerifySignature( g_hProv, hHash, pbSignature, dwSigLen, hPubKey, sDescription, dwFlags); #else
return CRYPT_FAILED; #endif
}
CSPBOOL CSPSetProviderA( LPCSTR pszProvName, DWORD dwProvType) { entrypoint; return TRUE; }
CSPBOOL CSPSetProviderW( LPCWSTR pszProvName, DWORD dwProvType) { entrypoint; return TRUE; }
#endif // defined(_CSPDIRECT_H_)
|