1 /**
2  * WinPR: Windows Portable Runtime
3  * Cryptography API: Next Generation
4  *
5  * Copyright 2012 Marc-Andre Moreau <marcandre.moreau@gmail.com>
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  *     http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  */
19 
20 #ifndef WINPR_BCRYPT_H
21 #define WINPR_BCRYPT_H
22 
23 #include <winpr/winpr.h>
24 #include <winpr/wtypes.h>
25 
26 typedef PVOID BCRYPT_HANDLE;
27 typedef PVOID BCRYPT_ALG_HANDLE;
28 typedef PVOID BCRYPT_KEY_HANDLE;
29 typedef PVOID BCRYPT_HASH_HANDLE;
30 typedef PVOID BCRYPT_SECRET_HANDLE;
31 
32 #define BCRYPT_RSA_ALGORITHM L"RSA"
33 #define BCRYPT_RSA_SIGN_ALGORITHM L"RSA_SIGN"
34 #define BCRYPT_DH_ALGORITHM L"DH"
35 #define BCRYPT_DSA_ALGORITHM L"DSA"
36 #define BCRYPT_RC2_ALGORITHM L"RC2"
37 #define BCRYPT_RC4_ALGORITHM L"RC4"
38 #define BCRYPT_AES_ALGORITHM L"AES"
39 #define BCRYPT_DES_ALGORITHM L"DES"
40 #define BCRYPT_DESX_ALGORITHM L"DESX"
41 #define BCRYPT_3DES_ALGORITHM L"3DES"
42 #define BCRYPT_3DES_112_ALGORITHM L"3DES_112"
43 #define BCRYPT_MD2_ALGORITHM L"MD2"
44 #define BCRYPT_MD4_ALGORITHM L"MD4"
45 #define BCRYPT_MD5_ALGORITHM L"MD5"
46 #define BCRYPT_SHA1_ALGORITHM L"SHA1"
47 #define BCRYPT_SHA256_ALGORITHM L"SHA256"
48 #define BCRYPT_SHA384_ALGORITHM L"SHA384"
49 #define BCRYPT_SHA512_ALGORITHM L"SHA512"
50 #define BCRYPT_AES_GMAC_ALGORITHM L"AES-GMAC"
51 #define BCRYPT_ECDSA_P256_ALGORITHM L"ECDSA_P256"
52 #define BCRYPT_ECDSA_P384_ALGORITHM L"ECDSA_P384"
53 #define BCRYPT_ECDSA_P521_ALGORITHM L"ECDSA_P521"
54 #define BCRYPT_ECDH_P256_ALGORITHM L"ECDH_P256"
55 #define BCRYPT_ECDH_P384_ALGORITHM L"ECDH_P384"
56 #define BCRYPT_ECDH_P521_ALGORITHM L"ECDH_P521"
57 #define BCRYPT_RNG_ALGORITHM L"RNG"
58 #define BCRYPT_RNG_FIPS186_DSA_ALGORITHM L"FIPS186DSARNG"
59 #define BCRYPT_RNG_DUAL_EC_ALGORITHM L"DUALECRNG"
60 
61 #define MS_PRIMITIVE_PROVIDER L"Microsoft Primitive Provider"
62 
63 #define BCRYPT_ALG_HANDLE_HMAC_FLAG 0x00000008
64 #define BCRYPT_PROV_DISPATCH 0x00000001
65 
66 #define BCRYPT_OBJECT_LENGTH L"ObjectLength"
67 #define BCRYPT_ALGORITHM_NAME L"AlgorithmName"
68 #define BCRYPT_PROVIDER_HANDLE L"ProviderHandle"
69 #define BCRYPT_CHAINING_MODE L"ChainingMode"
70 #define BCRYPT_BLOCK_LENGTH L"BlockLength"
71 #define BCRYPT_KEY_LENGTH L"KeyLength"
72 #define BCRYPT_KEY_OBJECT_LENGTH L"KeyObjectLength"
73 #define BCRYPT_KEY_STRENGTH L"KeyStrength"
74 #define BCRYPT_KEY_LENGTHS L"KeyLengths"
75 #define BCRYPT_BLOCK_SIZE_LIST L"BlockSizeList"
76 #define BCRYPT_EFFECTIVE_KEY_LENGTH L"EffectiveKeyLength"
77 #define BCRYPT_HASH_LENGTH L"HashDigestLength"
78 #define BCRYPT_HASH_OID_LIST L"HashOIDList"
79 #define BCRYPT_PADDING_SCHEMES L"PaddingSchemes"
80 #define BCRYPT_SIGNATURE_LENGTH L"SignatureLength"
81 #define BCRYPT_HASH_BLOCK_LENGTH L"HashBlockLength"
82 #define BCRYPT_AUTH_TAG_LENGTH L"AuthTagLength"
83 #define BCRYPT_PRIMITIVE_TYPE L"PrimitiveType"
84 #define BCRYPT_IS_KEYED_HASH L"IsKeyedHash"
85 
86 #ifdef __cplusplus
87 extern "C"
88 {
89 #endif
90 
91 	WINPR_API NTSTATUS BCryptOpenAlgorithmProvider(BCRYPT_ALG_HANDLE* phAlgorithm, LPCWSTR pszAlgId,
92 	                                               LPCWSTR pszImplementation, ULONG dwFlags);
93 
94 	WINPR_API NTSTATUS BCryptCloseAlgorithmProvider(BCRYPT_ALG_HANDLE hAlgorithm, ULONG dwFlags);
95 
96 	WINPR_API NTSTATUS BCryptGetProperty(BCRYPT_HANDLE hObject, LPCWSTR pszProperty,
97 	                                     PUCHAR pbOutput, ULONG cbOutput, ULONG* pcbResult,
98 	                                     ULONG dwFlags);
99 
100 	WINPR_API NTSTATUS BCryptCreateHash(BCRYPT_ALG_HANDLE hAlgorithm, BCRYPT_HASH_HANDLE* phHash,
101 	                                    PUCHAR pbHashObject, ULONG cbHashObject, PUCHAR pbSecret,
102 	                                    ULONG cbSecret, ULONG dwFlags);
103 
104 	WINPR_API NTSTATUS BCryptDestroyHash(BCRYPT_HASH_HANDLE hHash);
105 
106 	WINPR_API NTSTATUS BCryptHashData(BCRYPT_HASH_HANDLE hHash, PUCHAR pbInput, ULONG cbInput,
107 	                                  ULONG dwFlags);
108 
109 	WINPR_API NTSTATUS BCryptFinishHash(BCRYPT_HASH_HANDLE hHash, PUCHAR pbOutput, ULONG cbOutput,
110 	                                    ULONG dwFlags);
111 
112 	WINPR_API NTSTATUS BCryptGenRandom(BCRYPT_ALG_HANDLE hAlgorithm, PUCHAR pbBuffer,
113 	                                   ULONG cbBuffer, ULONG dwFlags);
114 
115 	WINPR_API NTSTATUS BCryptGenerateSymmetricKey(BCRYPT_ALG_HANDLE hAlgorithm,
116 	                                              BCRYPT_KEY_HANDLE* phKey, PUCHAR pbKeyObject,
117 	                                              ULONG cbKeyObject, PUCHAR pbSecret,
118 	                                              ULONG cbSecret, ULONG dwFlags);
119 
120 	WINPR_API NTSTATUS BCryptGenerateKeyPair(BCRYPT_ALG_HANDLE hAlgorithm, BCRYPT_KEY_HANDLE* phKey,
121 	                                         ULONG dwLength, ULONG dwFlags);
122 
123 	WINPR_API NTSTATUS BCryptImportKey(BCRYPT_ALG_HANDLE hAlgorithm, BCRYPT_KEY_HANDLE hImportKey,
124 	                                   LPCWSTR pszBlobType, BCRYPT_KEY_HANDLE* phKey,
125 	                                   PUCHAR pbKeyObject, ULONG cbKeyObject, PUCHAR pbInput,
126 	                                   ULONG cbInput, ULONG dwFlags);
127 
128 	WINPR_API NTSTATUS BCryptDestroyKey(BCRYPT_KEY_HANDLE hKey);
129 
130 	WINPR_API NTSTATUS BCryptEncrypt(BCRYPT_KEY_HANDLE hKey, PUCHAR pbInput, ULONG cbInput,
131 	                                 VOID* pPaddingInfo, PUCHAR pbIV, ULONG cbIV, PUCHAR pbOutput,
132 	                                 ULONG cbOutput, ULONG* pcbResult, ULONG dwFlags);
133 
134 	WINPR_API NTSTATUS BCryptDecrypt(BCRYPT_KEY_HANDLE hKey, PUCHAR pbInput, ULONG cbInput,
135 	                                 VOID* pPaddingInfo, PUCHAR pbIV, ULONG cbIV, PUCHAR pbOutput,
136 	                                 ULONG cbOutput, ULONG* pcbResult, ULONG dwFlags);
137 
138 #ifdef __cplusplus
139 }
140 #endif
141 #endif /* WINPR_BCRYPT_MEMORY_H */
142