| /* |
| * Copyright (C) 2002 Travis Michielsen |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Lesser General Public |
| * License as published by the Free Software Foundation; either |
| * version 2.1 of the License, or (at your option) any later version. |
| * |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * Lesser General Public License for more details. |
| * |
| * You should have received a copy of the GNU Lesser General Public |
| * License along with this library; if not, write to the Free Software |
| * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| */ |
| |
| #ifndef __WINE_WINCRYPT_H |
| #define __WINE_WINCRYPT_H |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| /* some typedefs for function parameters */ |
| typedef unsigned int ALG_ID; |
| typedef unsigned long HCRYPTPROV; |
| typedef unsigned long HCRYPTKEY; |
| typedef unsigned long HCRYPTHASH; |
| typedef void *HCERTSTORE; |
| typedef void *HCRYPTMSG; |
| |
| /* CSP Structs */ |
| |
| typedef struct _PROV_ENUMALGS { |
| ALG_ID aiAlgid; |
| DWORD dwBitLen; |
| DWORD dwNameLen; |
| CHAR szName[20]; |
| } PROV_ENUMALGS; |
| |
| typedef struct _PROV_ENUMALGS_EX { |
| ALG_ID aiAlgid; |
| DWORD dwDefaultLen; |
| DWORD dwMinLen; |
| DWORD dwMaxLen; |
| DWORD dwProtocols; |
| DWORD dwNameLen; |
| CHAR szName[20]; |
| DWORD dwLongNameLen; |
| CHAR szLongName[40]; |
| } PROV_ENUMALGS_EX; |
| |
| typedef struct _CRYPTOAPI_BLOB { |
| DWORD cbData; |
| BYTE* pbData; |
| } CRYPT_INTEGER_BLOB, *PCRYPT_INTEGER_BLOB, |
| CRYPT_UINT_BLOB, *PCRYPT_UINT_BLOB, |
| CRYPT_OBJID_BLOB, *PCRYPT_OBJID_BLOB, |
| CERT_NAME_BLOB, *PCERT_NAME_BLOB, |
| CERT_RDN_VALUE_BLOB, *PCERT_RDN_VALUE_BLOB, |
| CERT_BLOB, *PCERT_BLOB, |
| CRL_BLOB, *PCRL_BLOB, |
| DATA_BLOB, *PDATA_BLOB, |
| CRYPT_DATA_BLOB, *PCRYPT_DATA_BLOB, |
| CRYPT_HASH_BLOB, *PCRYPT_HASH_BLOB, |
| CRYPT_DIGEST_BLOB, *PCRYPT_DIGEST_BLOB, |
| CRYPT_DER_BLOB, *PCRYPT_DER_BLOB, |
| CRYPT_ATTR_BLOB, *PCRYPT_ATTR_BLOB; |
| |
| typedef struct _CRYPTPROTECT_PROMPTSTRUCT{ |
| DWORD cbSize; |
| DWORD dwPromptFlags; |
| HWND hwndApp; |
| LPCWSTR szPrompt; |
| } CRYPTPROTECT_PROMPTSTRUCT, *PCRYPTPROTECT_PROMPTSTRUCT; |
| |
| typedef struct _CRYPT_ALGORITHM_IDENTIFIER { |
| LPSTR pszObjId; |
| CRYPT_OBJID_BLOB Parameters; |
| } CRYPT_ALGORITHM_IDENTIFIER, *PCRYPT_ALGORITHM_IDENTIFIER; |
| |
| typedef struct _CRYPT_ATTRIBUTE_TYPE_VALUE { |
| LPSTR pszObjId; |
| CRYPT_OBJID_BLOB Value; |
| } CRYPT_ATTRIBUTE_TYPE_VALUE, *PCRYPT_ATTRIBUTE_TYPE_VALUE; |
| |
| typedef struct _PUBLICKEYSTRUC { |
| BYTE bType; |
| BYTE bVersion; |
| WORD reserved; |
| ALG_ID aiKeyAlg; |
| } BLOBHEADER, PUBLICKEYSTRUC; |
| |
| typedef struct _RSAPUBKEY { |
| DWORD magic; |
| DWORD bitlen; |
| DWORD pubexp; |
| } RSAPUBKEY; |
| |
| typedef struct _CRYPT_BIT_BLOB { |
| DWORD cbData; |
| BYTE *pbData; |
| DWORD cUnusedBits; |
| } CRYPT_BIT_BLOB, *PCRYPT_BIT_BLOB; |
| |
| typedef struct _CERT_PUBLIC_KEY_INFO { |
| CRYPT_ALGORITHM_IDENTIFIER Algorithm; |
| CRYPT_BIT_BLOB PublicKey; |
| } CERT_PUBLIC_KEY_INFO, *PCERT_PUBLIC_KEY_INFO; |
| |
| typedef struct _CERT_EXTENSION { |
| LPSTR pszObjId; |
| BOOL fCritical; |
| CRYPT_OBJID_BLOB Value; |
| } CERT_EXTENSION, *PCERT_EXTENSION; |
| |
| typedef struct _CERT_INFO { |
| DWORD dwVersion; |
| CRYPT_INTEGER_BLOB SerialNumber; |
| CRYPT_ALGORITHM_IDENTIFIER SignatureAlgorithm; |
| CERT_NAME_BLOB Issuer; |
| FILETIME NotBefore; |
| FILETIME NotAfter; |
| CERT_NAME_BLOB Subject; |
| CERT_PUBLIC_KEY_INFO SubjectPublicKeyInfo; |
| CRYPT_BIT_BLOB IssuerUniqueId; |
| CRYPT_BIT_BLOB SubjectUniqueId; |
| DWORD cExtension; |
| PCERT_EXTENSION rgExtension; |
| } CERT_INFO, *PCERT_INFO; |
| |
| typedef struct _CERT_CONTEXT { |
| DWORD dwCertEncodingType; |
| BYTE *pbCertEncoded; |
| DWORD cbCertEncoded; |
| PCERT_INFO pCertInfo; |
| HCERTSTORE hCertStore; |
| } CERT_CONTEXT, *PCERT_CONTEXT; |
| typedef const CERT_CONTEXT *PCCERT_CONTEXT; |
| |
| typedef struct _CRL_ENTRY { |
| CRYPT_INTEGER_BLOB SerialNumber; |
| FILETIME RevocationDate; |
| DWORD cExtension; |
| PCERT_EXTENSION rgExtension; |
| } CRL_ENTRY, *PCRL_ENTRY; |
| |
| typedef struct _CRL_INFO { |
| DWORD dwVersion; |
| CRYPT_ALGORITHM_IDENTIFIER SignatureAlgorithm; |
| CERT_NAME_BLOB Issuer; |
| FILETIME ThisUpdate; |
| FILETIME NextUpdate; |
| DWORD cCRLEntry; |
| PCRL_ENTRY rgCRLEntry; |
| DWORD cExtension; |
| PCERT_EXTENSION rgExtension; |
| } CRL_INFO, *PCRL_INFO; |
| |
| typedef struct _CRL_CONTEXT { |
| DWORD dwCertEncodingType; |
| BYTE *pbCrlEncoded; |
| DWORD cbCrlEncoded; |
| PCRL_INFO pCrlInfo; |
| HCERTSTORE hCertStore; |
| } CRL_CONTEXT, *PCRL_CONTEXT; |
| typedef const CRL_CONTEXT *PCCRL_CONTEXT; |
| |
| typedef struct _VTableProvStruc { |
| DWORD Version; |
| FARPROC pFuncVerifyImage; |
| FARPROC pFuncReturnhWnd; |
| DWORD dwProvType; |
| BYTE *pbContextInfo; |
| DWORD cbContextInfo; |
| LPSTR pszProvName; |
| } VTableProvStruc, *PVTableProvStruc; |
| |
| typedef struct _CRYPT_ATTRIBUTE { |
| LPSTR pszObjId; |
| DWORD cValue; |
| CRYPT_DATA_BLOB rgValue; |
| } CRYPT_ATTRIBUTE, *PCRYPT_ATTRIBUTE; |
| |
| typedef struct _CRYPT_ATTRIBUTES { |
| DWORD cAttr; |
| PCRYPT_ATTRIBUTE rgAttr; |
| } CRYPT_ATTRIBUTES, *PCRYPT_ATTRIBUTES; |
| |
| typedef struct _CTL_USAGE { |
| DWORD cUsageIdentifier; |
| LPSTR *rgpszUsageIdentifier; |
| } CTL_USAGE, *PCTL_USAGE, CERT_ENHKEY_USAGE, *PCERT_ENHKEY_USAGE; |
| |
| typedef struct _CTL_ENTRY { |
| CRYPT_DATA_BLOB SubjectIdentifier; |
| DWORD cAttribute; |
| PCRYPT_ATTRIBUTE rgAttribute; |
| } CTL_ENTRY, *PCTL_ENTRY; |
| |
| typedef struct _CTL_INFO { |
| DWORD dwVersion; |
| CTL_USAGE SubjectUsage; |
| CRYPT_DATA_BLOB ListIdentifier; |
| CRYPT_INTEGER_BLOB SequenceNumber; |
| FILETIME ThisUpdate; |
| FILETIME NextUpdate; |
| CRYPT_ALGORITHM_IDENTIFIER SubjectAlgorithm; |
| DWORD cCTLEntry; |
| PCTL_ENTRY rgCTLEntry; |
| DWORD cExtension; |
| PCERT_EXTENSION rgExtension; |
| } CTL_INFO, *PCTL_INFO; |
| |
| typedef struct _CTL_CONTEXT { |
| DWORD dwMsgAndCertEncodingType; |
| BYTE *pbCtlEncoded; |
| DWORD cbCtlEncoded; |
| PCTL_INFO pCtlInfo; |
| HCERTSTORE hCertStore; |
| HCRYPTMSG hCryptMsg; |
| BYTE *pbCtlContext; |
| DWORD cbCtlContext; |
| } CTL_CONTEXT, *PCTL_CONTEXT; |
| typedef const CTL_CONTEXT *PCCTL_CONTEXT; |
| |
| typedef struct _CERT_REVOCATION_CRL_INFO { |
| DWORD cbSize; |
| PCCRL_CONTEXT pBaseCrlContext; |
| PCCRL_CONTEXT pDeltaCrlContext; |
| PCRL_ENTRY pCrlEntry; |
| BOOL fDeltaCrlEntry; |
| } CERT_REVOCATION_CRL_INFO, *PCERT_REVOCATION_CRL_INFO; |
| |
| typedef struct _CERT_REVOCATION_INFO { |
| DWORD cbSize; |
| DWORD dwRevocationResult; |
| LPCSTR pszRevocationOid; |
| LPVOID pvOidSpecificInfo; |
| BOOL fHasFreshnessTime; |
| DWORD dwFreshnessTime; |
| PCERT_REVOCATION_CRL_INFO pCrlInfo; |
| } CERT_REVOCATION_INFO, *PCERT_REVOCATION_INFO; |
| |
| typedef struct _CERT_TRUST_LIST_INFO { |
| DWORD cbSize; |
| PCTL_ENTRY pCtlEntry; |
| PCCTL_CONTEXT pCtlContext; |
| } CERT_TRUST_LIST_INFO, *PCERT_TRUST_LIST_INFO; |
| |
| typedef struct _CERT_TRUST_STATUS { |
| DWORD dwErrorStatus; |
| DWORD dwInfoStatus; |
| } CERT_TRUST_STATUS, *PCERT_TRUST_STATUS; |
| |
| typedef struct _CERT_CHAIN_ELEMENT { |
| DWORD cbSize; |
| PCCERT_CONTEXT pCertContext; |
| CERT_TRUST_STATUS TrustStatus; |
| PCERT_REVOCATION_INFO pRevocationInfo; |
| PCERT_ENHKEY_USAGE pIssuanceUsage; |
| PCERT_ENHKEY_USAGE pApplicationUsage; |
| LPCWSTR pwszExtendedErrorInfo; |
| } CERT_CHAIN_ELEMENT, *PCERT_CHAIN_ELEMENT; |
| |
| typedef struct _CERT_SIMPLE_CHAIN { |
| DWORD cbSize; |
| CERT_TRUST_STATUS TrustStatus; |
| DWORD cElement; |
| PCERT_CHAIN_ELEMENT *rgpElement; |
| PCERT_TRUST_LIST_INFO pTrustListInfo; |
| BOOL fHasRevocationFreshnessTime; |
| DWORD dwRevocationFreshnessTime; |
| } CERT_SIMPLE_CHAIN, *PCERT_SIMPLE_CHAIN; |
| |
| typedef struct _CERT_CHAIN_CONTEXT CERT_CHAIN_CONTEXT, *PCERT_CHAIN_CONTEXT; |
| typedef const CERT_CHAIN_CONTEXT *PCCERT_CHAIN_CONTEXT; |
| |
| struct _CERT_CHAIN_CONTEXT { |
| DWORD cbSize; |
| CERT_TRUST_STATUS TrustStatus; |
| DWORD cChain; |
| PCERT_SIMPLE_CHAIN *rgpChain; |
| DWORD cLowerQualityChainContext; |
| PCCERT_CHAIN_CONTEXT *rgbLowerQualityChainContext; |
| BOOL fHasRevocationFreshnessTime; |
| DWORD dwRevocationFreshnessTime; |
| }; |
| |
| typedef struct _CERT_CHAIN_POLICY_PARA { |
| DWORD cbSize; |
| DWORD dwFlags; |
| void *pvExtraPolicyPara; |
| } CERT_CHAIN_POLICY_PARA, *PCERT_CHAIN_POLICY_PARA; |
| |
| typedef struct _CERT_CHAIN_POLICY_STATUS { |
| DWORD cbSize; |
| DWORD dwError; |
| LONG lChainIndex; |
| LONG lElementIndex; |
| void *pvExtraPolicyStatus; |
| } CERT_CHAIN_POLICY_STATUS, *PCERT_CHAIN_POLICY_STATUS; |
| |
| typedef struct _CERT_SYSTEM_STORE_INFO { |
| DWORD cbSize; |
| } CERT_SYSTEM_STORE_INFO, *PCERT_SYSTEM_STORE_INFO; |
| |
| typedef struct _CERT_PHYSICAL_STORE_INFO { |
| DWORD cbSize; |
| LPSTR pszOpenStoreProvider; |
| DWORD dwOpenEncodingType; |
| DWORD dwOpenFlags; |
| CRYPT_DATA_BLOB OpenParameters; |
| DWORD dwFlags; |
| DWORD dwPriority; |
| } CERT_PHYSICAL_STORE_INFO, *PCERT_PHYSICAL_STORE_INFO; |
| |
| typedef struct _CERT_SYSTEM_STORE_RELOCATE_PARA { |
| union { |
| HKEY hKeyBase; |
| VOID *pvBase; |
| } DUMMYUNIONNAME; |
| union { |
| void *pvSystemStore; |
| LPCSTR pszSystemStore; |
| LPCWSTR pwszSystemStore; |
| } DUMMYUNIONNAME2; |
| } CERT_SYSTEM_STORE_RELOCATE_PARA, *PCERT_SYSTEM_STORE_RELOCATE_PARA; |
| |
| typedef BOOL (WINAPI *PFN_CERT_ENUM_SYSTEM_STORE_LOCATION)( |
| LPCWSTR pwszStoreLocation, DWORD dwFlags, void *pvReserved, void *pvArg); |
| |
| typedef BOOL (WINAPI *PFN_CERT_ENUM_SYSTEM_STORE)(const void *pvSystemStore, |
| DWORD dwFlags, PCERT_SYSTEM_STORE_INFO pStoreInfo, void *pvReserved, |
| void *pvArg); |
| |
| typedef BOOL (WINAPI *PFN_CERT_ENUM_PHYSICAL_STORE)(const void *pvSystemStore, |
| DWORD dwFlags, LPCWSTR pwszStoreName, PCERT_PHYSICAL_STORE_INFO pStoreInfo, |
| void *pvReserved, void *pvArg); |
| |
| /* Algorithm IDs */ |
| |
| #define GET_ALG_CLASS(x) (x & (7 << 13)) |
| #define GET_ALG_TYPE(x) (x & (15 << 9)) |
| #define GET_ALG_SID(x) (x & (511)) |
| |
| /* Algorithm Classes */ |
| #define ALG_CLASS_ANY (0) |
| #define ALG_CLASS_SIGNATURE (1 << 13) |
| #define ALG_CLASS_MSG_ENCRYPT (2 << 13) |
| #define ALG_CLASS_DATA_ENCRYPT (3 << 13) |
| #define ALG_CLASS_HASH (4 << 13) |
| #define ALG_CLASS_KEY_EXCHANGE (5 << 13) |
| /* Algorithm types */ |
| #define ALG_TYPE_ANY (0) |
| #define ALG_TYPE_DSS (1 << 9) |
| #define ALG_TYPE_RSA (2 << 9) |
| #define ALG_TYPE_BLOCK (3 << 9) |
| #define ALG_TYPE_STREAM (4 << 9) |
| |
| /* SIDs */ |
| #define ALG_SID_ANY (0) |
| /* RSA SIDs */ |
| #define ALG_SID_RSA_ANY 0 |
| #define ALG_SID_RSA_PKCS 1 |
| #define ALG_SID_RSA_MSATWORK 2 |
| #define ALG_SID_RSA_ENTRUST 3 |
| #define ALG_SID_RSA_PGP 4 |
| /* DSS SIDs */ |
| #define ALG_SID_DSS_ANY 0 |
| #define ALG_SID_DSS_PKCS 1 |
| #define ALG_SID_DSS_DMS 2 |
| |
| /* DES SIDs */ |
| #define ALG_SID_DES 1 |
| #define ALG_SID_3DES 3 |
| #define ALG_SID_DESX 4 |
| #define ALG_SID_IDEA 5 |
| #define ALG_SID_CAST 6 |
| #define ALG_SID_SAFERSK64 7 |
| #define ALG_SID_SAFERSK128 8 |
| #define ALG_SID_3DES_112 9 |
| /* RC2 SIDs */ |
| #define ALG_SID_RC4 1 |
| #define ALG_SID_RC2 2 |
| #define ALG_SID_SEAL 2 |
| /* Hash SIDs */ |
| #define ALG_SID_MD2 1 |
| #define ALG_SID_MD4 2 |
| #define ALG_SID_MD5 3 |
| #define ALG_SID_SHA 4 |
| #define ALG_SID_MAC 5 |
| #define ALG_SID_RIPEMD 6 |
| #define ALG_SID_RIPEMD160 7 |
| #define ALG_SID_SSL3SHAMD5 8 |
| #define ALG_SID_HMAC 9 |
| |
| /* Algorithm Definitions */ |
| #define CALG_MD2 (ALG_CLASS_HASH | ALG_TYPE_ANY | ALG_SID_MD2) |
| #define CALG_MD4 (ALG_CLASS_HASH | ALG_TYPE_ANY | ALG_SID_MD4) |
| #define CALG_MD5 (ALG_CLASS_HASH | ALG_TYPE_ANY | ALG_SID_MD5) |
| #define CALG_SHA (ALG_CLASS_HASH | ALG_TYPE_ANY | ALG_SID_SHA) |
| #define CALG_MAC (ALG_CLASS_HASH | ALG_TYPE_ANY | ALG_SID_MAC) |
| #define CALG_SSL3_SHAMD5 (ALG_CLASS_HASH | ALG_TYPE_ANY | ALG_SID_SSL3SHAMD5) |
| #define CALG_HMAC (ALG_CLASS_HASH | ALG_TYPE_ANY | ALG_SID_HMAC) |
| #define CALG_RSA_SIGN (ALG_CLASS_SIGNATURE | ALG_TYPE_RSA | ALG_SID_RSA_ANY) |
| #define CALG_DSS_SIGN (ALG_CLASS_SIGNATURE | ALG_TYPE_DSS | ALG_SID_DSS_ANY) |
| #define CALG_RSA_KEYX (ALG_CLASS_KEY_EXCHANGE | ALG_TYPE_RSA | ALG_SID_RSA_ANY) |
| #define CALG_DES (ALG_CLASS_DATA_ENCRYPT | ALG_TYPE_BLOCK | ALG_SID_DES) |
| #define CALG_RC2 (ALG_CLASS_DATA_ENCRYPT | ALG_TYPE_BLOCK | ALG_SID_RC2) |
| #define CALG_3DES (ALG_CLASS_DATA_ENCRYPT | ALG_TYPE_BLOCK | ALG_SID_3DES) |
| #define CALG_3DES_112 (ALG_CLASS_DATA_ENCRYPT | ALG_TYPE_BLOCK | ALG_SID_3DES_112) |
| #define CALG_RC4 (ALG_CLASS_DATA_ENCRYPT | ALG_TYPE_STREAM | ALG_SID_RC4) |
| #define CALG_SEAL (ALG_CLASS_DATA_ENCRYPT | ALG_TYPE_STREAM | ALG_SID_SEAL) |
| |
| /* Protocol Flags */ |
| #define CRYPT_FLAG_PCT1 0x0001 |
| #define CRYPT_FLAG_SSL2 0x0002 |
| #define CRYPT_FLAG_SSL3 0x0004 |
| #define CRYPT_FLAG_TLS1 0x0008 |
| #define CRYPT_FLAG_IPSEC 0x0010 |
| #define CRYPT_FLAG_SIGNING 0x0020 |
| |
| /* Provider names */ |
| #define MS_DEF_PROV_A "Microsoft Base Cryptographic Provider v1.0" |
| #if defined(__GNUC__) |
| # define MS_DEF_PROV_W (const WCHAR []){ 'M','i','c','r','o','s','o','f','t',' ', \ |
| 'B','a','s','e',' ','C','r','y','p','t','o','g','r','a','p','h','i','c',' ', \ |
| 'P','r','o','v','i','d','e','r',' ','v','1','.','0',0 } |
| #elif defined(_MSC_VER) |
| # define MS_DEF_PROV_W L"Microsoft Base Cryptographic Provider v1.0" |
| #else |
| static const WCHAR MS_DEF_PROV_W[] = { 'M','i','c','r','o','s','o','f','t',' ', |
| 'B','a','s','e',' ','C','r','y','p','t','o','g','r','a','p','h','i','c',' ', |
| 'P','r','o','v','i','d','e','r',' ','v','1','.','0',0 }; |
| #endif |
| #define MS_DEF_PROV WINELIB_NAME_AW(MS_DEF_PROV_) |
| |
| #define MS_ENHANCED_PROV_A "Microsoft Enhanced Cryptographic Provider v1.0" |
| #if defined(__GNUC__) |
| # define MS_ENHANCED_PROV_W (const WCHAR []){ 'M','i','c','r','o','s','o','f','t',' ', \ |
| 'E','n','h','a','n','c','e','d',' ','C','r','y','p','t','o','g','r','a','p','h','i','c',' ', \ |
| 'P','r','o','v','i','d','e','r',' ','v','1','.','0',0 } |
| #elif defined(_MSC_VER) |
| # define MS_ENHANCED_PROV_W L"Microsoft Enhanced Cryptographic Provider v1.0" |
| #else |
| static const WCHAR MS_ENHANCED_PROV_W[] = { 'M','i','c','r','o','s','o','f','t',' ', |
| 'E','n','h','a','n','c','e','d',' ','C','r','y','p','t','o','g','r','a','p','h','i','c',' ', |
| 'P','r','o','v','i','d','e','r',' ','v','1','.','0',0 }; |
| #endif |
| #define MS_ENHANCED_PROV WINELIB_NAME_AW(MS_ENHANCED_PROV_) |
| |
| #define MS_STRONG_PROV_A "Microsoft Strong Cryptographic Provider" |
| #if defined(__GNUC__) |
| # define MS_STRONG_PROV_W (const WCHAR []){ 'M','i','c','r','o','s','o','f','t',' ', \ |
| 'S','t','r','o','n','g',' ','C','r','y','p','t','o','g','r','a','p','h','i','c',' ', \ |
| 'P','r','o','v','i','d','e','r',0 } |
| #elif defined(_MSC_VER) |
| # define MS_STRONG_PROV_W L"Microsoft Strong Cryptographic Provider" |
| #else |
| static const WCHAR MS_STRONG_PROV_W[] = { 'M','i','c','r','o','s','o','f','t',' ', |
| 'S','t','r','o','n','g',' ','C','r','y','p','t','o','g','r','a','p','h','i','c',' ', |
| 'P','r','o','v','i','d','e','r',0 }; |
| #endif |
| #define MS_STRONG_PROV WINELIB_NAME_AW(MS_STRONG_PROV_) |
| |
| #define MS_DEF_RSA_SIG_PROV_A "Microsoft RSA Signature Cryptographic Provider" |
| #if defined(__GNUC__) |
| # define MS_DEF_RSA_SIG_PROV_W (const WCHAR []){ 'M','i','c','r','o','s','o','f','t',' ', \ |
| 'R','S','A',' ','S','i','g','n','a','t','u','r','e',' ', \ |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 } |
| #elif defined(_MSC_VER) |
| # define MS_DEF_RSA_SIG_PROV_W L"Microsoft RSA Signature Cryptographic Provider" |
| #else |
| static const WCHAR MS_DEF_RSA_SIG_PROV_W[] = { 'M','i','c','r','o','s','o','f','t',' ', |
| 'R','S','A',' ','S','i','g','n','a','t','u','r','e',' ', |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 }; |
| #endif |
| #define MS_DEF_RSA_SIG_PROV WINELIB_NAME_AW(MS_DEF_RSA_SIG_PROV_) |
| |
| #define MS_DEF_RSA_SCHANNEL_PROV_A "Microsoft RSA SChannel Cryptographic Provider" |
| #if defined(__GNUC__) |
| # define MS_DEF_RSA_SCHANNEL_PROV_W (const WCHAR []){ 'M','i','c','r','o','s','o','f','t',' ', \ |
| 'R','S','A',' ','S','C','h','a','n','n','e','l',' ', \ |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 } |
| #elif defined(_MSC_VER) |
| # define MS_DEF_RSA_SCHANNEL_PROV_W L"Microsoft RSA SChannel Cryptographic Provider" |
| #else |
| static const WCHAR MS_DEF_RSA_SCHANNEL_PROV_W[] = { 'M','i','c','r','o','s','o','f','t',' ', |
| 'R','S','A',' ','S','C','h','a','n','n','e','l',' ', |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 }; |
| #endif |
| #define MS_DEF_RSA_SCHANNEL_PROV WINELIB_NAME_AW(MS_DEF_RSA_SCHANNEL_PROV_) |
| |
| #define MS_DEF_DSS_PROV_A "Microsoft Base DSS Cryptographic Provider" |
| #if defined(__GNUC__) |
| # define MS_DEF_DSS_PROV_W (const WCHAR []){ 'M','i','c','r','o','s','o','f','t',' ', \ |
| 'B','a','s','e',' ','D','S','S',' ', \ |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 } |
| #elif defined(_MSC_VER) |
| # define MS_DEF_DSS_PROV_W L"Microsoft Base DSS Cryptographic Provider" |
| #else |
| static const WCHAR MS_DEF_DSS_PROV_W[] = { 'M','i','c','r','o','s','o','f','t',' ', |
| 'B','a','s','e',' ','D','S','S',' ', |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 }; |
| #endif |
| #define MS_DEF_DSS_PROV WINELIB_NAME_AW(MS_DEF_DSS_PROV_) |
| |
| #define MS_DEF_DSS_DH_PROV_A "Microsoft Base DSS and Diffie-Hellman Cryptographic Provider" |
| #if defined(__GNUC__) |
| # define MS_DEF_DSS_DH_PROV_W (const WCHAR []){ 'M','i','c','r','o','s','o','f','t',' ', \ |
| 'B','a','s','e',' ','D','S','S',' ','a','n','d',' ', \ |
| 'D','i','f','f','i','e','-','H','e','l','l','m','a','n',' ', \ |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 } |
| #elif defined(_MSC_VER) |
| # define MS_DEF_DSS_DH_PROV_W L"Microsoft Base DSS and Diffie-Hellman Cryptographic Provider" |
| #else |
| static const WCHAR MS_DEF_DSS_DH_PROV_W[] = { 'M','i','c','r','o','s','o','f','t',' ', |
| 'B','a','s','e',' ','D','S','S',' ','a','n','d',' ', |
| 'D','i','f','f','i','e','-','H','e','l','l','m','a','n',' ', |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 }; |
| #endif |
| #define MS_DEF_DSS_DH_PROV WINELIB_NAME_AW(MS_DEF_DSS_DH_PROV_) |
| |
| #define MS_ENH_DSS_DH_PROV_A "Microsoft Enhanced DSS and Diffie-Hellman Cryptographic Provider" |
| #if defined(__GNUC__) |
| # define MS_ENH_DSS_DH_PROV_W (const WCHAR []){ 'M','i','c','r','o','s','o','f','t',' ', \ |
| 'E','n','h','a','n','c','e','d',' ','D','S','S',' ','a','n','d',' ', \ |
| 'D','i','f','f','i','e','-','H','e','l','l','m','a','n',' ', \ |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 } |
| #elif defined(_MSC_VER) |
| # define MS_ENH_DSS_DH_PROV_W L"Microsoft Enhanced DSS and Diffie-Hellman Cryptographic Provider" |
| #else |
| static const WCHAR MS_ENH_DSS_DH_PROV_W[] = { 'M','i','c','r','o','s','o','f','t',' ', |
| 'E','n','h','a','n','c','e','d',' ','D','S','S',' ','a','n','d',' ', |
| 'D','i','f','f','i','e','-','H','e','l','l','m','a','n',' ', |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 }; |
| #endif |
| #define MS_ENH_DSS_DH_PROV WINELIB_NAME_AW(MS_ENH_DSS_DH_PROV_) |
| |
| #define MS_DEF_DH_SCHANNEL_PROV_A "Microsoft DH SChannel Cryptographic Provider" |
| #if defined(__GNUC__) |
| # define MS_DEF_DH_SCHANNEL_PROV_W (const WCHAR []){ 'M','i','c','r','o','s','o','f','t',' ', \ |
| 'D','H',' ','S','C','h','a','n','n','e','l',' ', \ |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 } |
| #elif defined(_MSC_VER) |
| # define MS_DEF_DH_SCHANNEL_PROV_W L"Microsoft DH SChannel Cryptographic Provider" |
| #else |
| static const WCHAR MS_DEF_DH_SCHANNEL_PROV_W[] = { 'M','i','c','r','o','s','o','f','t',' ', |
| 'D','H',' ','S','C','h','a','n','n','e','l',' ', |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 }; |
| #endif |
| #define MS_DEF_DH_SCHANNEL_PROV WINELIB_NAME_AW(MS_DEF_DH_SCHANNEL_PROV_) |
| |
| #define MS_SCARD_PROV_A "Microsoft Base Smart Card Cryptographic Provider" |
| #if defined(__GNUC__) |
| # define MS_SCARD_PROV_W (const WCHAR []){ 'M','i','c','r','o','s','o','f','t',' ', \ |
| 'B','a','s','e',' ','S','m','a','r','t',' ','C','a','r','d',' ', \ |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 } |
| #elif defined(_MSC_VER) |
| # define MS_SCARD_PROV_W L"Microsoft Base Smart Card Cryptographic Provider" |
| #else |
| static const WCHAR MS_SCARD_PROV_W[] = { 'M','i','c','r','o','s','o','f','t',' ', |
| 'B','a','s','e',' ','S','m','a','r','t',' ','C','a','r','d',' ', |
| 'C','r','y','p','t','o','g','r','a','p','h','i','c',' ','P','r','o','v','i','d','e','r',0 }; |
| #endif |
| #define MS_SCARD_PROV WINELIB_NAME_AW(MS_SCARD_PROV_) |
| |
| /* Key Specs*/ |
| #define AT_KEYEXCHANGE 1 |
| #define AT_SIGNATURE 2 |
| |
| /* Provider Types */ |
| #define PROV_RSA_FULL 1 |
| #define PROV_RSA_SIG 2 |
| #define PROV_DSS 3 |
| #define PROV_FORTEZZA 4 |
| #define PROV_MS_EXCHANGE 5 |
| #define PROV_SSL 6 |
| #define PROV_RSA_SCHANNEL 12 |
| #define PROV_DSS_DH 13 |
| #define PROV_EC_ECDSA_SIG 14 |
| #define PROV_EC_ECNRA_SIG 15 |
| #define PROV_EC_ECDSA_FULL 16 |
| #define PROV_EC_ECNRA_FULL 17 |
| #define PROV_DH_SCHANNEL 18 |
| #define PROV_SPYRUS_LYNKS 20 |
| #define PROV_RNG 21 |
| #define PROV_INTEL_SEC 22 |
| #define PROV_REPLACE_OWF 23 |
| #define PROV_RSA_AES 24 |
| |
| /* FLAGS Section */ |
| |
| /* Provider Parameters */ |
| #define PP_ENUMALGS 1 |
| #define PP_ENUMCONTAINERS 2 |
| #define PP_IMPTYPE 3 |
| #define PP_NAME 4 |
| #define PP_VERSION 5 |
| #define PP_CONTAINER 6 |
| |
| #define CRYPT_FIRST 1 |
| #define CRYPT_NEXT 2 |
| |
| #define CRYPT_IMPL_HARDWARE 1 |
| #define CRYPT_IMPL_SOFTWARE 2 |
| #define CRYPT_IMPL_MIXED 3 |
| #define CRYPT_IMPL_UNKNOWN 4 |
| |
| /* CryptAcquireContext */ |
| #define CRYPT_VERIFYCONTEXT 0xF0000000 |
| #define CRYPT_NEWKEYSET 0x00000008 |
| #define CRYPT_MACHINE_KEYSET 0x00000000 |
| #define CRYPT_DELETEKEYSET 0x00000010 |
| #define CRYPT_SILENT 0x00000000 |
| |
| /* Crypt{Get|Set}Provider */ |
| #define CRYPT_MACHINE_DEFAULT 0x00000001 |
| #define CRYPT_USER_DEFAULT 0x00000002 |
| #define CRYPT_DELETE_DEFAULT 0x00000004 |
| |
| /* Crypt{Get/Set}ProvParam */ |
| #define PP_CLIENT_HWND 1 |
| #define PP_ENUMALGS 1 |
| #define PP_ENUMCONTAINERS 2 |
| #define PP_IMPTYPE 3 |
| #define PP_NAME 4 |
| #define PP_VERSION 5 |
| #define PP_CONTAINER 6 |
| #define PP_CHANGE_PASSWORD 7 |
| #define PP_KEYSET_SEC_DESCR 8 |
| #define PP_KEY_TYPE_SUBTYPE 10 |
| #define PP_CONTEXT_INFO 11 |
| #define PP_KEYEXCHANGE_KEYSIZE 12 |
| #define PP_SIGNATURE_KEYSIZE 13 |
| #define PP_KEYEXCHANGE_ALG 14 |
| #define PP_SIGNATURE_ALG 15 |
| #define PP_PROVTYPE 16 |
| #define PP_KEYSTORAGE 17 |
| #define PP_SYM_KEYSIZE 19 |
| #define PP_SESSION_KEYSIZE 20 |
| #define PP_UI_PROMPT 21 |
| #define PP_ENUMALGS_EX 22 |
| #define PP_DELETEKEY 24 |
| #define PP_ENUMMANDROOTS 25 |
| #define PP_ENUMELECTROOTS 26 |
| #define PP_KEYSET_TYPE 27 |
| #define PP_ADMIN_PIN 31 |
| #define PP_KEYEXCHANGE_PIN 32 |
| #define PP_SIGNATURE_PIN 33 |
| #define PP_SIG_KEYSIZE_INC 34 |
| #define PP_KEYX_KEYSIZE_INC 35 |
| #define PP_UNIQUE_CONTAINER 36 |
| #define PP_SGC_INFO 37 |
| #define PP_USE_HARDWARE_RNG 38 |
| #define PP_KEYSPEC 39 |
| #define PP_ENUMEX_SIGNING_PROT 40 |
| |
| /* CryptSignHash/CryptVerifySignature */ |
| #define CRYPT_NOHASHOID 0x00000001 |
| #define CRYPT_TYPE2_FORMAT 0x00000002 |
| #define CRYPT_X931_FORMAT 0x00000004 |
| |
| /* Crypt{Get,Set}HashParam */ |
| #define HP_ALGID 0x0001 |
| #define HP_HASHVAL 0x0002 |
| #define HP_HASHSIZE 0x0004 |
| #define HP_HMAC_INFO 0x0005 |
| #define HP_TLS1PRF_LABEL 0x0006 |
| #define HP_TLS1PRF_SEED 0x0007 |
| |
| /* Crypt{Get,Set}KeyParam */ |
| #define CRYPT_MODE_CBC 1 |
| #define CRYPT_MODE_ECB 2 |
| #define CRYPT_MODE_OFB 3 |
| #define CRYPT_MODE_CFB 4 |
| |
| #define CRYPT_ENCRYPT 0x0001 |
| #define CRYPT_DECRYPT 0x0002 |
| #define CRYPT_EXPORT 0x0004 |
| #define CRYPT_READ 0x0008 |
| #define CRYPT_WRITE 0x0010 |
| #define CRYPT_MAC 0x0020 |
| |
| /* Crypt*Key */ |
| #define CRYPT_EXPORTABLE 0x00000001 |
| #define CRYPT_USER_PROTECTED 0x00000002 |
| #define CRYPT_CREATE_SALT 0x00000004 |
| #define CRYPT_UPDATE_KEY 0x00000008 |
| #define CRYPT_NO_SALT 0x00000010 |
| #define CRYPT_PREGEN 0x00000040 |
| #define CRYPT_ARCHIVABLE 0x00004000 |
| #define CRYPT_SSL2_FALLBACK 0x00000002 |
| #define CRYPT_DESTROYKEY 0x00000004 |
| #define CRYPT_OAEP 0x00000040 |
| |
| /* Blob Types */ |
| #define SIMPLEBLOB 0x1 |
| #define PUBLICKEYBLOB 0x6 |
| #define PRIVATEKEYBLOB 0x7 |
| #define PLAINTEXTKEYBLOB 0x8 |
| #define OPAQUEKEYBLOB 0x9 |
| #define PUBLICKEYBLOBEX 0xA |
| #define SYMMETRICWRAPKEYBLOB 0xB |
| |
| /* cert store provider types */ |
| #define CERT_STORE_PROV_MSG ((LPCSTR)1) |
| #define CERT_STORE_PROV_MEMORY ((LPCSTR)2) |
| #define CERT_STORE_PROV_FILE ((LPCSTR)3) |
| #define CERT_STORE_PROV_REG ((LPCSTR)4) |
| #define CERT_STORE_PROV_PKCS7 ((LPCSTR)5) |
| #define CERT_STORE_PROV_SERIALIZED ((LPCSTR)6) |
| #define CERT_STORE_PROV_FILENAME_A ((LPCSTR)7) |
| #define CERT_STORE_PROV_FILENAME_W ((LPCSTR)8) |
| #define CERT_STORE_PROV_SYSTEM_A ((LPCSTR)9) |
| #define CERT_STORE_PROV_SYSTEM_W ((LPCSTR)10) |
| #define CERT_STORE_PROV_SYSTEM CERT_STORE_PROV_SYSTEM_W |
| #define CERT_STORE_PROV_COLLECTION ((LPCSTR)11) |
| #define CERT_STORE_PROV_SYSTEM_REGISTRY_A ((LPCSTR)12) |
| #define CERT_STORE_PROV_SYSTEM_REGISTRY_W ((LPCSTR)13) |
| #define CERT_STORE_PROV_SYSTEM_REGISTRY CERT_STORE_PROV_SYSTEM_REGISTRY_W |
| #define CERT_STORE_PROV_PHYSICAL_W ((LPCSTR)14) |
| #define CERT_STORE_PROV_PHYSICAL CERT_STORE_PROV_PHYSICAL_W |
| #define CERT_STORE_PROV_SMART_CARD_W ((LPCSTR)15) |
| #define CERT_STORE_PROV_SMART_CARD CERT_STORE_PROV_SMART_CARD_W |
| #define CERT_STORE_PROV_LDAP_W ((LPCSTR)16) |
| #define CERT_STORE_PROV_LDAP CERT_STORE_PROV_LDAP_W |
| |
| #define sz_CERT_STORE_PROV_MEMORY "Memory" |
| #define sz_CERT_STORE_PROV_FILENAME_W "File" |
| #define sz_CERT_STORE_PROV_FILENAME sz_CERT_STORE_PROV_FILENAME_W |
| #define sz_CERT_STORE_PROV_SYSTEM_W "System" |
| #define sz_CERT_STORE_PROV_SYSTEM sz_CERT_STORE_PROV_SYSTEM_W |
| #define sz_CERT_STORE_PROV_PKCS7 "PKCS7" |
| #define sz_CERT_STORE_PROV_SERIALIZED "Serialized" |
| #define sz_CERT_STORE_PROV_COLLECTION "Collection" |
| #define sz_CERT_STORE_PROV_SYSTEM_REGISTRY_W "SystemRegistry" |
| #define sz_CERT_STORE_PROV_SYSTEM_REGISTRY sz_CERT_STORE_PROV_SYSTEM_REGISTRY_W |
| #define sz_CERT_STORE_PROV_PHYSICAL_W "Physical" |
| #define sz_CERT_STORE_PROV_PHYSICAL sz_CERT_STORE_PROV_PHYSICAL_W |
| #define sz_CERT_STORE_PROV_SMART_CARD_W "SmartCard" |
| #define sz_CERT_STORE_PROV_SMART_CARD sz_CERT_STORE_PROV_SMART_CARD_W |
| #define sz_CERT_STORE_PROV_LDAP_W "Ldap" |
| #define sz_CERT_STORE_PROV_LDAP sz_CERT_STORE_PROV_LDAP_W |
| |
| /* types for CertOpenStore dwEncodingType */ |
| #define X509_ASN_ENCODING 0x00000001 |
| #define X509_NDR_ENCODING 0x00000002 |
| #define PKCS_7_ASN_ENCODING 0x00010000 |
| #define PKCS_7_NDR_ENCODING 0x00020000 |
| |
| /* system store locations */ |
| #define CERT_SYSTEM_STORE_LOCATION_MASK 0x00ff0000 |
| #define CERT_SYSTEM_STORE_LOCATION_SHIFT 16 |
| |
| /* system store location ids */ |
| /* hkcu */ |
| #define CERT_SYSTEM_STORE_CURRENT_USER_ID 1 |
| /* hklm */ |
| #define CERT_SYSTEM_STORE_LOCAL_MACHINE_ID 2 |
| /* hklm\Software\Microsoft\Cryptography\Services */ |
| #define CERT_SYSTEM_STORE_CURRENT_SERVICE_ID 4 |
| #define CERT_SYSTEM_STORE_SERVICES_ID 5 |
| /* HKEY_USERS */ |
| #define CERT_SYSTEM_STORE_USERS_ID 6 |
| /* hkcu\Software\Microsoft\Policies\Microsoft\SystemCertificates */ |
| #define CERT_SYSTEM_STORE_CURRENT_USER_GROUP_POLICY_ID 7 |
| /* hklm\Software\Microsoft\Policies\Microsoft\SystemCertificates */ |
| #define CERT_SYSTEM_STORE_LOCAL_MACHINE_GROUP_POLICY_ID 8 |
| /* hklm\Software\Microsoft\EnterpriseCertificates */ |
| #define CERT_SYSTEM_STORE_LOCAL_MACHINE_ENTERPRISE_ID 9 |
| |
| /* system store location values */ |
| #define CERT_SYSTEM_STORE_CURRENT_USER \ |
| (CERT_SYSTEM_STORE_CURRENT_USER_ID << CERT_SYSTEM_STORE_LOCATION_SHIFT) |
| #define CERT_SYSTEM_STORE_LOCAL_MACHINE \ |
| (CERT_SYSTEM_STORE_LOCAL_MACHINE_ID << CERT_SYSTEM_STORE_LOCATION_SHIFT) |
| #define CERT_SYSTEM_STORE_CURRENT_SERVICE \ |
| (CERT_SYSTEM_STORE_CURRENT_SERVICE_ID << CERT_SYSTEM_STORE_LOCATION_SHIFT) |
| #define CERT_SYSTEM_STORE_SERVICE \ |
| (CERT_SYSTEM_STORE_SERVICES_ID << CERT_SYSTEM_STORE_LOCATION_SHIFT) |
| #define CERT_SYSTEM_STORE_USERS \ |
| (CERT_SYSTEM_STORE_USERS_ID << CERT_SYSTEM_STORE_LOCATION_SHIFT) |
| #define CERT_SYSTEM_STORE_CURRENT_USER_GROUP_POLICY \ |
| (CERT_SYSTEM_STORE_CURRENT_USER_GROUP_POLICY_ID << CERT_SYSTEM_STORE_LOCATION_SHIFT) |
| #define CERT_SYSTEM_STORE_LOCAL_MACHINE_GROUP_POLICY \ |
| (CERT_SYSTEM_STORE_LOCAL_MACHINE_GROUP_POLICY_ID << CERT_SYSTEM_STORE_LOCATION_SHIFT) |
| #define CERT_SYSTEM_STORE_LOCAL_MACHINE_ENTERPRISE \ |
| (CERT_SYSTEM_STORE_LOCAL_MACHINE_ENTERPRISE_ID << CERT_SYSTEM_STORE_LOCATION_SHIFT) |
| |
| /* flags for CertOpenStore dwFlags */ |
| #define CERT_STORE_NO_CRYPT_RELEASE_FLAG 0x00000001 |
| #define CERT_STORE_SET_LOCALIZED_NAME_FLAG 0x00000002 |
| #define CERT_STORE_DEFER_CLOSE_UNTIL_LAST_FREE_FLAG 0x00000004 |
| #define CERT_STORE_DELETE_FLAG 0x00000010 |
| #define CERT_STORE_UNSAFE_PHYSICAL_FLAG 0x00000020 |
| #define CERT_STORE_SHARE_STORE_FLAG 0x00000040 |
| #define CERT_STORE_SHARE_CONTEXT_FLAG 0x00000080 |
| #define CERT_STORE_MANIFOLD_FLAG 0x00000100 |
| #define CERT_STORE_ENUM_ARCHIVED_FLAG 0x00000200 |
| #define CERT_STORE_UPDATE_KEYID_FLAG 0x00000400 |
| #define CERT_STORE_BACKUP_RESTORE_FLAG 0x00000800 |
| #define CERT_STORE_MAXIMUM_ALLOWED_FLAG 0x00001000 |
| #define CERT_STORE_CREATE_NEW_FLAG 0x00002000 |
| #define CERT_STORE_OPEN_EXISTING_FLAG 0x00004000 |
| #define CERT_STORE_READONLY_FLAG 0x00008000 |
| |
| /* physical store dwFlags, also used by CertAddStoreToCollection as |
| * dwUpdateFlags |
| */ |
| #define CERT_PHYSICAL_STORE_ADD_ENABLE_FLAG 0x1 |
| #define CERT_PHYSICAL_STORE_OPEN_DISABLE_FLAG 0x2 |
| #define CERT_PHYSICAL_STORE_REMOVE_OPEN_DISABLE_FLAG 0x4 |
| #define CERT_PHYSICAL_STORE_INSERT_COMPUTER_NAME_ENABLE_FLAG 0x8 |
| |
| /* dwFlag values for CertEnumPhysicalStore callback */ |
| #define CERT_PHYSICAL_STORE_PREDEFINED_ENUM_FLAG 0x1 |
| |
| /* predefined store names */ |
| #if defined(__GNUC__) |
| # define CERT_PHYSICAL_STORE_DEFAULT_NAME (const WCHAR[])\ |
| {'.','D','e','f','a','u','l','t','0'} |
| # define CERT_PHYSICAL_STORE_GROUP_POLICY_NAME (const WCHAR[])\ |
| {'.','G','r','o','u','p','P','o','l','i','c','y',0} |
| # define CERT_PHYSICAL_STORE_LOCAL_MACHINE_NAME (const WCHAR[])\ |
| {'.','L','o','c','a','l','M','a','c','h','i','n','e',0} |
| # define CERT_PHYSICAL_STORE_DS_USER_CERTIFICATE_NAME (const WCHAR[])\ |
| {'.','U','s','e','r','C','e','r','t','i','f','i','c','a','t','e',0} |
| # define CERT_PHYSICAL_STORE_LOCAL_MACHINE_GROUP_POLICY_NAME (const WCHAR[])\ |
| {'.','L','o','c','a','l','M','a','c','h','i','n','e','G','r','o','u','p',\ |
| 'P','o','l','i','c','y',0} |
| # define CERT_PHYSICAL_STORE_ENTERPRISE_NAME (const WCHAR[])\ |
| {'.','E','n','t','e','r','p','r','i','s','e',0} |
| # define CERT_PHYSICAL_STORE_AUTH_ROOT_NAME (const WCHAR[])\ |
| {'.','A','u','t','h','R','o','o','t',0} |
| #elif defined(_MSC_VER) |
| # define CERT_PHYSICAL_STORE_DEFAULT_NAME \ |
| L".Default" |
| # define CERT_PHYSICAL_STORE_GROUP_POLICY_NAME \ |
| L".GroupPolicy" |
| # define CERT_PHYSICAL_STORE_LOCAL_MACHINE_NAME \ |
| L".LocalMachine" |
| # define CERT_PHYSICAL_STORE_DS_USER_CERTIFICATE_NAME \ |
| L".UserCertificate" |
| # define CERT_PHYSICAL_STORE_LOCAL_MACHINE_GROUP_POLICY_NAME \ |
| L".LocalMachineGroupPolicy" |
| # define CERT_PHYSICAL_STORE_ENTERPRISE_NAME \ |
| L".Enterprise" |
| # define CERT_PHYSICAL_STORE_AUTH_ROOT_NAME \ |
| L".AuthRoot" |
| #else |
| static const WCHAR CERT_PHYSICAL_STORE_DEFAULT_NAME[] = |
| {'.','D','e','f','a','u','l','t','0'}; |
| static const WCHAR CERT_PHYSICAL_STORE_GROUP_POLICY_NAME[] = |
| {'.','G','r','o','u','p','P','o','l','i','c','y',0}; |
| static const WCHAR CERT_PHYSICAL_STORE_LOCAL_MACHINE_NAME[] = |
| {'.','L','o','c','a','l','M','a','c','h','i','n','e',0}; |
| static const WCHAR CERT_PHYSICAL_STORE_DS_USER_CERTIFICATE_NAME[] = |
| {'.','U','s','e','r','C','e','r','t','i','f','i','c','a','t','e',0}; |
| static const WCHAR CERT_PHYSICAL_STORE_LOCAL_MACHINE_GROUP_POLICY_NAME[] = |
| {'.','L','o','c','a','l','M','a','c','h','i','n','e','G','r','o','u','p', |
| 'P','o','l','i','c','y',0}; |
| static const WCHAR CERT_PHYSICAL_STORE_ENTERPRISE_NAME[] = |
| {'.','E','n','t','e','r','p','r','i','s','e',0}; |
| static const WCHAR CERT_PHYSICAL_STORE_AUTH_ROOT_NAME[] = |
| {'.','A','u','t','h','R','o','o','t',0}; |
| #endif |
| |
| /* cert system store flags */ |
| #define CERT_SYSTEM_STORE_MASK 0xffff0000 |
| #define CERT_SYSTEM_STORE_RELOCATE_FLAG 0x80000000 |
| |
| /* CertFindChainInStore dwFindType types */ |
| #define CERT_CHAIN_FIND_BY_ISSUER 1 |
| |
| /* function declarations */ |
| /* advapi32.dll */ |
| BOOL WINAPI CryptAcquireContextA(HCRYPTPROV *phProv, LPCSTR pszContainer, |
| LPCSTR pszProvider, DWORD dwProvType, |
| DWORD dwFlags); |
| BOOL WINAPI CryptAcquireContextW (HCRYPTPROV *phProv, LPCWSTR pszContainer, |
| LPCWSTR pszProvider, DWORD dwProvType, DWORD dwFlags); |
| #define CryptAcquireContext WINELIB_NAME_AW(CryptAcquireContext) |
| BOOL WINAPI CryptGenRandom (HCRYPTPROV hProv, DWORD dwLen, BYTE *pbBuffer); |
| BOOL WINAPI CryptContextAddRef (HCRYPTPROV hProv, DWORD *pdwReserved, DWORD dwFlags); |
| BOOL WINAPI CryptCreateHash (HCRYPTPROV hProv, ALG_ID Algid, HCRYPTKEY hKey, |
| DWORD dwFlags, HCRYPTHASH *phHash); |
| BOOL WINAPI CryptDecrypt (HCRYPTKEY hKey, HCRYPTHASH hHash, BOOL Final, |
| DWORD dwFlags, BYTE *pbData, DWORD *pdwDataLen); |
| BOOL WINAPI CryptDeriveKey (HCRYPTPROV hProv, ALG_ID Algid, HCRYPTHASH hBaseData, |
| DWORD dwFlags, HCRYPTKEY *phKey); |
| BOOL WINAPI CryptDestroyHash (HCRYPTHASH hHash); |
| BOOL WINAPI CryptDestroyKey (HCRYPTKEY hKey); |
| BOOL WINAPI CryptDuplicateKey (HCRYPTKEY hKey, DWORD *pdwReserved, DWORD dwFlags, HCRYPTKEY *phKey); |
| BOOL WINAPI CryptDuplicateHash (HCRYPTHASH hHash, DWORD *pdwReserved, |
| DWORD dwFlags, HCRYPTHASH *phHash); |
| BOOL WINAPI CryptEncrypt (HCRYPTKEY hKey, HCRYPTHASH hHash, BOOL Final, |
| DWORD dwFlags, BYTE *pbData, DWORD *pdwDataLen, DWORD dwBufLen); |
| BOOL WINAPI CryptEnumProvidersA (DWORD dwIndex, DWORD *pdwReserved, |
| DWORD dwFlags, DWORD *pdwProvType, LPSTR pszProvName, DWORD *pcbProvName); |
| BOOL WINAPI CryptEnumProvidersW (DWORD dwIndex, DWORD *pdwReserved, |
| DWORD dwFlags, DWORD *pdwProvType, LPWSTR pszProvName, DWORD *pcbProvName); |
| #define CryptEnumProviders WINELIB_NAME_AW(CryptEnumProviders) |
| BOOL WINAPI CryptEnumProviderTypesA (DWORD dwIndex, DWORD *pdwReserved, |
| DWORD dwFlags, DWORD *pdwProvType, LPSTR pszTypeName, DWORD *pcbTypeName); |
| BOOL WINAPI CryptEnumProviderTypesW (DWORD dwIndex, DWORD *pdwReserved, |
| DWORD dwFlags, DWORD *pdwProvType, LPWSTR pszTypeName, DWORD *pcbTypeName); |
| #define CryptEnumProviderTypes WINELIB_NAME_AW(CryptEnumProviderTypes) |
| BOOL WINAPI CryptExportKey (HCRYPTKEY hKey, HCRYPTKEY hExpKey, DWORD dwBlobType, |
| DWORD dwFlags, BYTE *pbData, DWORD *pdwDataLen); |
| BOOL WINAPI CryptGenKey (HCRYPTPROV hProv, ALG_ID Algid, DWORD dwFlags, HCRYPTKEY *phKey); |
| BOOL WINAPI CryptGetKeyParam (HCRYPTKEY hKey, DWORD dwParam, BYTE *pbData, |
| DWORD *pdwDataLen, DWORD dwFlags); |
| BOOL WINAPI CryptGetHashParam (HCRYPTHASH hHash, DWORD dwParam, BYTE *pbData, |
| DWORD *pdwDataLen, DWORD dwFlags); |
| BOOL WINAPI CryptGetProvParam (HCRYPTPROV hProv, DWORD dwParam, BYTE *pbData, |
| DWORD *pdwDataLen, DWORD dwFlags); |
| BOOL WINAPI CryptGetDefaultProviderA (DWORD dwProvType, DWORD *pdwReserved, |
| DWORD dwFlags, LPSTR pszProvName, DWORD *pcbProvName); |
| BOOL WINAPI CryptGetDefaultProviderW (DWORD dwProvType, DWORD *pdwReserved, |
| DWORD dwFlags, LPWSTR pszProvName, DWORD *pcbProvName); |
| #define CryptGetDefaultProvider WINELIB_NAME_AW(CryptGetDefaultProvider) |
| BOOL WINAPI CryptGetUserKey (HCRYPTPROV hProv, DWORD dwKeySpec, HCRYPTKEY *phUserKey); |
| BOOL WINAPI CryptHashData (HCRYPTHASH hHash, BYTE *pbData, DWORD dwDataLen, DWORD dwFlags); |
| BOOL WINAPI CryptHashSessionKey (HCRYPTHASH hHash, HCRYPTKEY hKey, DWORD dwFlags); |
| BOOL WINAPI CryptImportKey (HCRYPTPROV hProv, BYTE *pbData, DWORD dwDataLen, |
| HCRYPTKEY hPubKey, DWORD dwFlags, HCRYPTKEY *phKey); |
| BOOL WINAPI CryptRegisterOIDFunction(DWORD,LPCSTR,LPCSTR,LPCWSTR,LPCSTR); |
| |
| BOOL WINAPI CryptReleaseContext (HCRYPTPROV hProv, DWORD dwFlags); |
| BOOL WINAPI CryptSignHashA (HCRYPTHASH hHash, DWORD dwKeySpec, LPCSTR sDescription, |
| DWORD dwFlags, BYTE *pbSignature, DWORD *pdwSigLen); |
| BOOL WINAPI CryptSignHashW (HCRYPTHASH hHash, DWORD dwKeySpec, LPCWSTR sDescription, |
| DWORD dwFlags, BYTE *pbSignature, DWORD *pdwSigLen); |
| #define CryptSignHash WINELIB_NAME_AW(CryptSignHash) |
| BOOL WINAPI CryptSetHashParam (HCRYPTHASH hHash, DWORD dwParam, BYTE *pbData, DWORD dwFlags); |
| BOOL WINAPI CryptSetKeyParam (HCRYPTKEY hKey, DWORD dwParam, BYTE *pbData, DWORD dwFlags); |
| BOOL WINAPI CryptSetProviderA (LPCSTR pszProvName, DWORD dwProvType); |
| BOOL WINAPI CryptSetProviderW (LPCWSTR pszProvName, DWORD dwProvType); |
| #define CryptSetProvider WINELIB_NAME_AW(CryptSetProvider) |
| BOOL WINAPI CryptSetProviderExA (LPCSTR pszProvName, DWORD dwProvType, DWORD *pdwReserved, DWORD dwFlags); |
| BOOL WINAPI CryptSetProviderExW (LPCWSTR pszProvName, DWORD dwProvType, DWORD *pdwReserved, DWORD dwFlags); |
| #define CryptSetProviderEx WINELIB_NAME_AW(CryptSetProviderEx) |
| BOOL WINAPI CryptSetProvParam (HCRYPTPROV hProv, DWORD dwParam, BYTE *pbData, DWORD dwFlags); |
| BOOL WINAPI CryptVerifySignatureA (HCRYPTHASH hHash, BYTE *pbSignature, DWORD dwSigLen, |
| HCRYPTKEY hPubKey, LPCSTR sDescription, DWORD dwFlags); |
| BOOL WINAPI CryptVerifySignatureW (HCRYPTHASH hHash, BYTE *pbSignature, DWORD dwSigLen, |
| HCRYPTKEY hPubKey, LPCWSTR sDescription, DWORD dwFlags); |
| #define CryptVerifySignature WINELIB_NAME_AW(CryptVerifySignature) |
| |
| /* cert store functions */ |
| HCERTSTORE WINAPI CertOpenStore(LPCSTR lpszStoreProvider, DWORD dwEncodingType, |
| HCRYPTPROV hCryptProv, DWORD dwFlags, const void *pvPara); |
| |
| HCERTSTORE WINAPI CertOpenSystemStoreA(HCRYPTPROV hProv, |
| LPCSTR szSubSystemProtocol); |
| HCERTSTORE WINAPI CertOpenSystemStoreW(HCRYPTPROV hProv, |
| LPCWSTR szSubSystemProtocol); |
| #define CertOpenSystemStore WINELIB_NAME_AW(CertOpenSystemStore) |
| |
| PCCERT_CONTEXT WINAPI CertEnumCertificatesInStore(HCERTSTORE hCertStore, PCCERT_CONTEXT pPrev); |
| |
| BOOL WINAPI CertEnumSystemStoreLocation(DWORD dwFlags, void *pvArg, |
| PFN_CERT_ENUM_SYSTEM_STORE_LOCATION pfnEnum); |
| |
| BOOL WINAPI CertEnumSystemStore(DWORD dwFlags, void *pvSystemStoreLocationPara, |
| void *pvArg, PFN_CERT_ENUM_SYSTEM_STORE pfnEnum); |
| |
| BOOL WINAPI CertEnumPhysicalStore(const void *pvSystemStore, DWORD dwFlags, |
| void *pvArg, PFN_CERT_ENUM_PHYSICAL_STORE pfnEnum); |
| |
| BOOL WINAPI CertSaveStore(HCERTSTORE hCertStore, DWORD dwMsgAndCertEncodingType, |
| DWORD dwSaveAs, DWORD dwSaveTo, void* pvSaveToPara, DWORD dwFlags); |
| |
| PCCRL_CONTEXT WINAPI CertCreateCRLContext( DWORD dwCertEncodingType, |
| const BYTE* pbCrlEncoded, DWORD cbCrlEncoded); |
| |
| BOOL WINAPI CertAddStoreToCollection(HCERTSTORE hCollectionStore, |
| HCERTSTORE hSiblingStore, DWORD dwUpdateFlags, DWORD dwPriority); |
| |
| void WINAPI CertRemoveStoreFromCollection(HCERTSTORE hCollectionStore, |
| HCERTSTORE hSiblingStore); |
| |
| PCCERT_CHAIN_CONTEXT WINAPI CertFindChainInStore(HCERTSTORE hCertStore, |
| DWORD dwCertEncodingType, DWORD dwFindFlags, DWORD dwFindType, |
| const void *pvFindPara, PCCERT_CHAIN_CONTEXT pPrevChainContext); |
| |
| BOOL WINAPI CertVerifyCertificateChainPolicy(LPCSTR szPolicyOID, |
| PCCERT_CHAIN_CONTEXT pChainContext, PCERT_CHAIN_POLICY_PARA pPolicyPara, |
| PCERT_CHAIN_POLICY_STATUS pPolicyStatus); |
| |
| BOOL WINAPI CertCloseStore( HCERTSTORE hCertStore, DWORD dwFlags ); |
| |
| BOOL WINAPI CertFreeCertificateContext( PCCERT_CONTEXT pCertContext ); |
| |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| #endif |