WinStd
Windows Win32 API using Standard C++
Loading...
Searching...
No Matches
Crypt.h
1/*
2 SPDX-License-Identifier: MIT
3 Copyright © 1991-2022 Amebis
4 Copyright © 2016 GÉANT
5*/
6
8
9#pragma once
10
11#include "Common.h"
12#include <assert.h>
13#include <WinCrypt.h>
14#include <algorithm>
15#include <string>
16#include <vector>
17
20
22template<class _Traits, class _Ax>
23static DWORD CertGetNameStringA(_In_ PCCERT_CONTEXT pCertContext, _In_ DWORD dwType, _In_ DWORD dwFlags, _In_opt_ void *pvTypePara, _Out_ std::basic_string<char, _Traits, _Ax> &sNameString)
24{
25 // Query the final string length first.
26 DWORD dwSize = ::CertGetNameStringA(pCertContext, dwType, dwFlags, pvTypePara, NULL, 0);
27
28 // Allocate buffer on heap to format the string data into and read it.
29 std::unique_ptr<char[]> szBuffer(new char[dwSize]);
30 dwSize = ::CertGetNameStringA(pCertContext, dwType, dwFlags, pvTypePara, szBuffer.get(), dwSize);
31 sNameString.assign(szBuffer.get(), dwSize - 1);
32 return dwSize;
33}
34
40template<class _Traits, class _Ax>
41static DWORD CertGetNameStringW(_In_ PCCERT_CONTEXT pCertContext, _In_ DWORD dwType, _In_ DWORD dwFlags, _In_opt_ void *pvTypePara, _Out_ std::basic_string<wchar_t, _Traits, _Ax> &sNameString)
42{
43 // Query the final string length first.
44 DWORD dwSize = ::CertGetNameStringW(pCertContext, dwType, dwFlags, pvTypePara, NULL, 0);
45
46 // Allocate buffer on heap to format the string data into and read it.
47 std::unique_ptr<wchar_t[]> szBuffer(new wchar_t[dwSize]);
48 dwSize = ::CertGetNameStringW(pCertContext, dwType, dwFlags, pvTypePara, szBuffer.get(), dwSize);
49 sNameString.assign(szBuffer.get(), dwSize - 1);
50 return dwSize;
51}
52
58template<class _Ty, class _Ax>
59static _Success_(return != 0) BOOL WINAPI CertGetCertificateContextProperty(_In_ PCCERT_CONTEXT pCertContext, _In_ DWORD dwPropId, _Out_ std::vector<_Ty, _Ax> &aData)
60{
62 DWORD dwSize = WINSTD_STACK_BUFFER_BYTES;
63
64 // Try with the stack buffer first.
65 if (CertGetCertificateContextProperty(pCertContext, dwPropId, buf, &dwSize)) {
66 // Copy from stack.
67 aData.assign((const _Ty*)buf, (const _Ty*)buf + (dwSize + sizeof(_Ty) - 1) / sizeof(_Ty));
68 return TRUE;
69 } else if (GetLastError() == ERROR_MORE_DATA) {
70 aData.resize((dwSize + sizeof(_Ty) - 1) / sizeof(_Ty));
71 if (CertGetCertificateContextProperty(pCertContext, dwPropId, aData.data(), &dwSize))
72 return TRUE;
73 }
74
75 return FALSE;
76}
77
83template<class _Ty, class _Ax>
84static _Success_(return != 0) BOOL CryptGetHashParam(_In_ HCRYPTHASH hHash, _In_ DWORD dwParam, _Out_ std::vector<_Ty, _Ax> &aData, _In_ DWORD dwFlags)
85{
87 DWORD dwSize = WINSTD_STACK_BUFFER_BYTES;
88
89 // Try with the stack buffer first.
90 if (CryptGetHashParam(hHash, dwParam, buf, &dwSize, dwFlags)) {
91 // Copy from stack.
92 aData.assign((const _Ty*)buf, (const _Ty*)buf + (dwSize + sizeof(_Ty) - 1) / sizeof(_Ty));
93 return TRUE;
94 } else if (GetLastError() == ERROR_MORE_DATA) {
95 aData.resize((dwSize + sizeof(_Ty) - 1) / sizeof(_Ty));
96 if (CryptGetHashParam(hHash, dwParam, reinterpret_cast<BYTE*>(aData.data()), &dwSize, dwFlags))
97 return TRUE;
98 }
99
100 return FALSE;
101}
102
108template<class T>
109static _Success_(return != 0) BOOL CryptGetHashParam(_In_ HCRYPTHASH hHash, _In_ DWORD dwParam, _Out_ T &data, _In_ DWORD dwFlags)
110{
111 DWORD dwSize = sizeof(T);
112 return CryptGetHashParam(hHash, dwParam, (BYTE*)&data, &dwSize, dwFlags);
113}
114
120template<class _Ty, class _Ax>
121static _Success_(return != 0) BOOL CryptGetKeyParam(_In_ HCRYPTKEY hKey, _In_ DWORD dwParam, _Out_ std::vector<_Ty, _Ax> &aData, _In_ DWORD dwFlags)
122{
124 DWORD dwSize = WINSTD_STACK_BUFFER_BYTES;
125
126 // Try with the stack buffer first.
127 if (CryptGetKeyParam(hKey, dwParam, buf, &dwSize, dwFlags)) {
128 // Copy from stack.
129 aData.assign((const _Ty*)buf, (const _Ty*)buf + (dwSize + sizeof(_Ty) - 1) / sizeof(_Ty));
130 return TRUE;
131 } else if (GetLastError() == ERROR_MORE_DATA) {
132 aData.resize((dwSize + sizeof(_Ty) - 1) / sizeof(_Ty));
133 if (CryptGetKeyParam(hKey, dwParam, reinterpret_cast<BYTE*>(aData.data()), &dwSize, dwFlags))
134 return TRUE;
135 }
136
137 return FALSE;
138}
139
145template<class T>
146static BOOL CryptGetKeyParam(_In_ HCRYPTKEY hKey, _In_ DWORD dwParam, _Out_ T &data, _In_ DWORD dwFlags)
147{
148 DWORD dwSize = sizeof(T);
149 return CryptGetKeyParam(hKey, dwParam, (BYTE*)&data, &dwSize, dwFlags);
150}
151
157template<class _Ty, class _Ax>
158static _Success_(return != 0) BOOL CryptExportKey(_In_ HCRYPTKEY hKey, _In_ HCRYPTKEY hExpKey, _In_ DWORD dwBlobType, _In_ DWORD dwFlags, _Out_ std::vector<_Ty, _Ax> &aData)
159{
160 DWORD dwKeyBLOBSize = 0;
161
162 if (CryptExportKey(hKey, hExpKey, dwBlobType, dwFlags, NULL, &dwKeyBLOBSize)) {
163 aData.resize((dwKeyBLOBSize + sizeof(_Ty) - 1) / sizeof(_Ty));
164 if (CryptExportKey(hKey, hExpKey, dwBlobType, dwFlags, reinterpret_cast<BYTE*>(aData.data()), &dwKeyBLOBSize))
165 return TRUE;
166 }
167
168 return FALSE;
169}
170
176template<class _Ty, class _Ax>
177static _Success_(return != 0) BOOL CryptEncrypt(_In_ HCRYPTKEY hKey, _In_opt_ HCRYPTHASH hHash, _In_ BOOL Final, _In_ DWORD dwFlags, _Inout_ std::vector<_Ty, _Ax> &aData)
178{
179 DWORD
180 dwDataLen = (DWORD)(aData.size() * sizeof(_Ty)),
181 dwBufLen = (DWORD)(aData.capacity() * sizeof(_Ty)),
182 dwEncLen = dwDataLen,
183 dwResult;
184
185 if (dwBufLen) {
186 aData.resize(dwBufLen);
187 if (CryptEncrypt(hKey, hHash, Final, dwFlags, reinterpret_cast<BYTE*>(aData.data()), &dwEncLen, dwBufLen)) {
188 // Encryption succeeded.
189 assert(dwEncLen <= dwBufLen);
190 if (dwEncLen < dwBufLen)
191 aData.resize((dwEncLen + sizeof(_Ty) - 1) / sizeof(_Ty));
192 return TRUE;
193 } else
194 dwResult = GetLastError();
195 } else if (CryptEncrypt(hKey, NULL, Final, dwFlags, NULL, &dwEncLen, 0)) {
196 // CryptEncrypt() always succeeds for output data size queries.
197 // dwEncLen contains required output data size. Continue as if the buffer was to small. Actually, the output buffer _was_ too small!
198 dwResult = ERROR_MORE_DATA;
199 } else
200 dwResult = GetLastError();
201
202 if (dwResult == ERROR_MORE_DATA) {
203 // Encrypted data will be longer. Reserve more space and retry.
204 aData.resize(((dwBufLen = dwEncLen) + sizeof(_Ty) - 1) / sizeof(_Ty));
205 dwEncLen = dwDataLen;
206 if (CryptEncrypt(hKey, hHash, Final, dwFlags, reinterpret_cast<BYTE*>(aData.data()), &dwEncLen, dwBufLen)) {
207 // Encryption succeeded.
208 assert(dwEncLen <= dwBufLen);
209 if (dwEncLen < dwBufLen)
210 aData.resize((dwEncLen + sizeof(_Ty) - 1) / sizeof(_Ty));
211 return TRUE;
212 }
213 } else {
214 // Resize back to data length.
215 aData.resize((dwDataLen + sizeof(_Ty) - 1) / sizeof(_Ty));
216 }
217
218 return FALSE;
219}
220
226template<class _Ty, class _Ax>
227static _Success_(return != 0) BOOL CryptDecrypt(_In_ HCRYPTKEY hKey, _In_opt_ HCRYPTHASH hHash, _In_ BOOL Final, _In_ DWORD dwFlags, _Inout_ std::vector<_Ty, _Ax> &aData)
228{
229 DWORD dwDataLen = (DWORD)(aData.size() * sizeof(_Ty));
230
231 if (CryptDecrypt(hKey, hHash, Final, dwFlags, reinterpret_cast<BYTE*>(aData.data()), &dwDataLen)) {
232 // Decryption succeeded.
233 aData.resize((dwDataLen + sizeof(_Ty) - 1) / sizeof(_Ty));
234 return TRUE;
235 }
236
237 return FALSE;
238}
239
241
242namespace winstd
243{
246
252 class cert_context : public dplhandle<PCCERT_CONTEXT, NULL>
253 {
255
256 public:
263 {
264 if (m_h != invalid)
266 }
267
276 bool operator==(_In_ const handle_type &other) const noexcept
277 {
278 // TODO: [Crypto] Make constant time.
279 return
280 m_h == other ||
281 m_h->cbCertEncoded == other->cbCertEncoded && memcmp(m_h->pbCertEncoded, other->pbCertEncoded, m_h->cbCertEncoded) == 0;
282 }
283
292 bool operator!=(_In_ const handle_type &other) const noexcept
293 {
294 return !operator==(other);
295 }
296
305 bool operator<(_In_ const handle_type &other) const noexcept
306 {
307 // TODO: [Crypto] Make constant time.
308 const int r = memcmp(m_h->pbCertEncoded, other->pbCertEncoded, std::min<DWORD>(m_h->cbCertEncoded, other->cbCertEncoded));
309 return r < 0 || r == 0 && m_h->cbCertEncoded < other->cbCertEncoded;
310 }
311
320 bool operator>(_In_ const handle_type &other) const noexcept
321 {
322 // TODO: [Crypto] Make constant time.
323 const int r = memcmp(m_h->pbCertEncoded, other->pbCertEncoded, std::min<DWORD>(m_h->cbCertEncoded, other->cbCertEncoded));
324 return r > 0 || r == 0 && m_h->cbCertEncoded > other->cbCertEncoded;
325 }
326
335 bool operator<=(_In_ const handle_type &other) const noexcept
336 {
337 return !operator>(other);
338 }
339
348 bool operator>=(_In_ const handle_type &other) const noexcept
349 {
350 return !operator<(other);
351 }
352
353 protected:
359 void free_internal() noexcept override
360 {
361 CertFreeCertificateContext(m_h);
362 }
363
373 handle_type duplicate_internal(_In_ handle_type h) const noexcept override
374 {
375 return CertDuplicateCertificateContext(h);
376 }
377 };
378
384 class cert_chain_context : public dplhandle<PCCERT_CHAIN_CONTEXT, NULL>
385 {
387
388 public:
395 {
396 if (m_h != invalid)
398 }
399
400 protected:
406 void free_internal() noexcept override
407 {
408 CertFreeCertificateChain(m_h);
409 }
410
420 handle_type duplicate_internal(_In_ handle_type h) const noexcept override
421 {
422 return CertDuplicateCertificateChain(h);
423 }
424 };
425
432 class cert_store : public handle<HCERTSTORE, NULL>
433 {
435
436 public:
442 virtual ~cert_store()
443 {
444 if (m_h != invalid)
446 }
447
448 protected:
454 void free_internal() noexcept override
455 {
456 CertCloseStore(m_h, 0);
457 }
458 };
459
465 class crypt_prov : public handle<HCRYPTPROV, NULL>
466 {
468
469 public:
475 virtual ~crypt_prov()
476 {
477 if (m_h != invalid)
479 }
480
481 protected:
487 void free_internal() noexcept override
488 {
489 CryptReleaseContext(m_h, 0);
490 }
491 };
492
498 class crypt_hash : public dplhandle<HCRYPTHASH, NULL>
499 {
501
502 public:
508 virtual ~crypt_hash()
509 {
510 if (m_h != invalid)
512 }
513
514 protected:
520 void free_internal() noexcept override
521 {
522 CryptDestroyHash(m_h);
523 }
524
534 handle_type duplicate_internal(_In_ handle_type h) const noexcept override
535 {
536 handle_type hNew;
537 return CryptDuplicateHash(h, NULL, 0, &hNew) ? hNew : invalid;
538 }
539 };
540
549 class crypt_key : public dplhandle<HCRYPTKEY, NULL>
550 {
552
553 public:
559 virtual ~crypt_key()
560 {
561 if (m_h != invalid)
563 }
564
573 bool create_exp1(_In_ HCRYPTPROV hProv, _In_ DWORD dwKeySpec)
574 {
575 if (dwKeySpec != AT_KEYEXCHANGE && dwKeySpec != AT_SIGNATURE) {
576 SetLastError(ERROR_INVALID_PARAMETER);
577 return false;
578 }
579
580 // Generate the private key.
581 handle_type h;
582 if (CryptGenKey(hProv, dwKeySpec, CRYPT_EXPORTABLE, &h)) {
583 // Export the private key, we'll convert it to a private exponent of one key.
584 std::vector<BYTE, sanitizing_allocator<BYTE>> key_blob;
585 if (CryptExportKey(h, 0, PRIVATEKEYBLOB, 0, key_blob)) {
586 CryptDestroyKey(h);
587
588 // Get the byte length of the key.
589 size_t
590 size_key = *reinterpret_cast<DWORD*>(&key_blob[12])/8,
591 size_prime = size_key/2;
592
593 // Modify the Exponent in Key BLOB format
594 // Key BLOB format is documented in SDK
595
596 // Convert pubexp in rsapubkey to 1
597 LPBYTE ptr = &key_blob[16];
598 *reinterpret_cast<DWORD*>(ptr) = 1;
599 ptr += sizeof(DWORD);
600
601 // Skip modulus, prime1, prime2
602 ptr += size_key;
603 ptr += size_prime;
604 ptr += size_prime;
605
606 // Convert exponent1 to 1
607 ptr[0] = 1;
608 memset(ptr + 1, 0, size_prime - 1);
609 ptr += size_prime;
610
611 // Convert exponent2 to 1
612 ptr[0] = 1;
613 memset(ptr + 1, 0, size_prime - 1);
614 ptr += size_prime;
615
616 // Skip coefficient
617 ptr += size_prime;
618
619 // Convert privateExponent to 1
620 ptr[0] = 1;
621 memset(ptr + 1, 0, size_key - 1);
622
623 // Import the exponent-of-one private key.
624 if (CryptImportKey(hProv, key_blob.data(), static_cast<DWORD>(key_blob.size()), 0, 0, &h)) {
625 attach(h);
626 return true;
627 }
628 } else
629 CryptDestroyKey(h);
630 }
631
632 return false;
633 }
634
635 protected:
641 void free_internal() noexcept override
642 {
643 CryptDestroyKey(m_h);
644 }
645
655 handle_type duplicate_internal(_In_ handle_type h) const noexcept override
656 {
657 handle_type hNew;
658 return CryptDuplicateKey(h, NULL, 0, &hNew) ? hNew : invalid;
659 }
660 };
661
665 #pragma warning(push)
666 #pragma warning(disable: 26432) // Copy constructor and assignment operator are also present, but not detected by code analysis as they are using base type source object reference.
667 class data_blob : public DATA_BLOB
668 {
669 public:
673 data_blob() noexcept
674 {
675 cbData = 0;
676 pbData = NULL;
677 }
678
682 data_blob(_In_count_(size) BYTE *data, _In_ DWORD size) noexcept
683 {
684 cbData = size;
685 pbData = data;
686 }
687
691 data_blob(_In_ const DATA_BLOB &other)
692 {
693 cbData = other.cbData;
694 if (cbData) {
695 pbData = static_cast<BYTE*>(LocalAlloc(LMEM_FIXED, other.cbData));
696 if (!pbData) throw win_runtime_error("LocalAlloc failed.");
697 memcpy(pbData, other.pbData, other.cbData);
698 } else
699 pbData = NULL;
700 }
701
705 data_blob(_Inout_ data_blob &&other) noexcept
706 {
707 cbData = other.cbData;
708 pbData = other.pbData;
709 other.cbData = 0;
710 other.pbData = NULL;
711 }
712
716 virtual ~data_blob()
717 {
718 if (pbData != NULL)
719 LocalFree(pbData);
720 }
721
725 data_blob& operator=(_In_ const DATA_BLOB &other)
726 {
727 if (this != &other) {
728 cbData = other.cbData;
729 if (pbData)
730 LocalFree(pbData);
731 if (cbData) {
732 pbData = static_cast<BYTE*>(LocalAlloc(LMEM_FIXED, other.cbData));
733 if (!pbData) throw win_runtime_error("LocalAlloc failed.");
734 memcpy(pbData, other.pbData, other.cbData);
735 } else
736 pbData = NULL;
737 }
738
739 return *this;
740 }
741
745 data_blob& operator=(_Inout_ data_blob &&other) noexcept
746 {
747 if (this != &other) {
748 cbData = other.cbData;
749 if (pbData)
750 LocalFree(pbData);
751 pbData = other.pbData;
752 other.cbData = 0;
753 other.pbData = NULL;
754 }
755
756 return *this;
757 }
758
762 DWORD size() const noexcept
763 {
764 return cbData;
765 }
766
770 const BYTE* data() const noexcept
771 {
772 return pbData;
773 }
774
778 BYTE* data() noexcept
779 {
780 return pbData;
781 }
782 };
783 #pragma warning(pop)
784
786}
787
790
791#pragma warning(push)
792#pragma warning(disable: 4505) // Don't warn on unused code
793
799static BOOL CertGetCertificateChain(_In_opt_ HCERTCHAINENGINE hChainEngine, _In_ PCCERT_CONTEXT pCertContext, _In_opt_ LPFILETIME pTime, _In_opt_ HCERTSTORE hAdditionalStore, _In_ PCERT_CHAIN_PARA pChainPara, _In_ DWORD dwFlags, _Reserved_ LPVOID pvReserved, _Inout_ winstd::cert_chain_context &ctx)
800{
801 PCCERT_CHAIN_CONTEXT pChainContext;
802 BOOL bResult = CertGetCertificateChain(hChainEngine, pCertContext, pTime, hAdditionalStore, pChainPara, dwFlags, pvReserved, &pChainContext);
803 if (bResult)
804 ctx.attach(pChainContext);
805 return bResult;
806}
807
809static BOOL CryptAcquireContextA(_Inout_ winstd::crypt_prov &prov, _In_opt_ LPCSTR szContainer, _In_opt_ LPCSTR szProvider, _In_ DWORD dwProvType, _In_ DWORD dwFlags)
810{
811 HCRYPTPROV h;
812 BOOL bResult = CryptAcquireContextA(&h, szContainer, szProvider, dwProvType, dwFlags);
813 if (bResult)
814 prov.attach(h);
815 return bResult;
816}
817
823static BOOL CryptAcquireContextW(_Inout_ winstd::crypt_prov &prov, _In_opt_ LPCWSTR szContainer, _In_opt_ LPCWSTR szProvider, _In_ DWORD dwProvType, _In_ DWORD dwFlags)
824{
825 HCRYPTPROV h;
826 BOOL bResult = CryptAcquireContextW(&h, szContainer, szProvider, dwProvType, dwFlags);
827 if (bResult)
828 prov.attach(h);
829 return bResult;
830}
831
837static BOOL CryptCreateHash(_In_ HCRYPTPROV hProv, _In_ ALG_ID Algid, _In_ HCRYPTKEY hKey, _In_ DWORD dwFlags, _Inout_ winstd::crypt_hash &hash)
838{
839 HCRYPTHASH h;
840 BOOL bResult = CryptCreateHash(hProv, Algid, hKey, dwFlags, &h);
841 if (bResult)
842 hash.attach(h);
843 return bResult;
844}
845
851static BOOL CryptGenKey(_In_ HCRYPTPROV hProv, _In_ ALG_ID Algid, _In_ DWORD dwFlags, _Inout_ winstd::crypt_key &key)
852{
853 HCRYPTKEY h;
854 BOOL bResult = CryptGenKey(hProv, Algid, dwFlags, &h);
855 if (bResult)
856 key.attach(h);
857 return bResult;
858}
859
865static bool CryptImportKey(_In_ HCRYPTPROV hProv, __in_bcount(dwDataLen) LPCBYTE pbData, _In_ DWORD dwDataLen, _In_ HCRYPTKEY hPubKey, _In_ DWORD dwFlags, _Inout_ winstd::crypt_key &key)
866{
867 HCRYPTKEY h;
868 BOOL bResult = CryptImportKey(hProv, pbData, dwDataLen, hPubKey, dwFlags, &h);
869 if (bResult)
870 key.attach(h);
871 return bResult;
872}
873
879static bool CryptImportPublicKeyInfo(_In_ HCRYPTPROV hCryptProv, _In_ DWORD dwCertEncodingType, _In_ PCERT_PUBLIC_KEY_INFO pInfo, _Inout_ winstd::crypt_key &key)
880{
881 HCRYPTKEY h;
882 BOOL bResult = CryptImportPublicKeyInfo(hCryptProv, dwCertEncodingType, pInfo, &h);
883 if (bResult)
884 key.attach(h);
885 return bResult;
886}
887
893static bool CryptDeriveKey(_In_ HCRYPTPROV hProv, _In_ ALG_ID Algid, _In_ HCRYPTHASH hBaseData, _In_ DWORD dwFlags, _Inout_ winstd::crypt_key &key)
894{
895 HCRYPTKEY h;
896 BOOL bResult = CryptDeriveKey(hProv, Algid, hBaseData, dwFlags, &h);
897 if (bResult)
898 key.attach(h);
899 return bResult;
900}
901
902#pragma warning(pop)
903
PCCERT_CHAIN_CONTEXT wrapper class.
Definition: Crypt.h:385
handle_type duplicate_internal(handle_type h) const noexcept override
Duplicates the certificate chain context.
Definition: Crypt.h:420
virtual ~cert_chain_context()
Destroys the certificate chain context.
Definition: Crypt.h:394
void free_internal() noexcept override
Destroys the certificate chain context.
Definition: Crypt.h:406
PCCERT_CONTEXT wrapper class.
Definition: Crypt.h:253
bool operator<=(const handle_type &other) const noexcept
Is certificate less than or equal?
Definition: Crypt.h:335
void free_internal() noexcept override
Destroys the certificate context.
Definition: Crypt.h:359
bool operator==(const handle_type &other) const noexcept
Is certificate equal to?
Definition: Crypt.h:276
handle_type duplicate_internal(handle_type h) const noexcept override
Duplicates the certificate context.
Definition: Crypt.h:373
bool operator>=(const handle_type &other) const noexcept
Is certificate greater than or equal?
Definition: Crypt.h:348
bool operator>(const handle_type &other) const noexcept
Is certificate greater than?
Definition: Crypt.h:320
bool operator<(const handle_type &other) const noexcept
Is certificate less than?
Definition: Crypt.h:305
bool operator!=(const handle_type &other) const noexcept
Is certificate not equal to?
Definition: Crypt.h:292
virtual ~cert_context()
Destroys the certificate context.
Definition: Crypt.h:262
HCERTSTORE wrapper class.
Definition: Crypt.h:433
virtual ~cert_store()
Closes the certificate store.
Definition: Crypt.h:442
void free_internal() noexcept override
Closes the certificate store.
Definition: Crypt.h:454
HCRYPTHASH wrapper class.
Definition: Crypt.h:499
void free_internal() noexcept override
Destroys the hash context.
Definition: Crypt.h:520
virtual ~crypt_hash()
Destroys the hash context.
Definition: Crypt.h:508
handle_type duplicate_internal(handle_type h) const noexcept override
Duplicates the hash context.
Definition: Crypt.h:534
HCRYPTKEY wrapper class.
Definition: Crypt.h:550
virtual ~crypt_key()
Destroys the key.
Definition: Crypt.h:559
bool create_exp1(HCRYPTPROV hProv, DWORD dwKeySpec)
Creates Exponent-of-one key.
Definition: Crypt.h:573
handle_type duplicate_internal(handle_type h) const noexcept override
Duplicates the key.
Definition: Crypt.h:655
void free_internal() noexcept override
Destroys the key.
Definition: Crypt.h:641
HCRYPTPROV wrapper class.
Definition: Crypt.h:466
virtual ~crypt_prov()
Releases the cryptographic context.
Definition: Crypt.h:475
void free_internal() noexcept override
Releases the cryptographic context.
Definition: Crypt.h:487
DATA_BLOB wrapper class.
Definition: Crypt.h:668
data_blob(const DATA_BLOB &other)
Duplicate an existing BLOB.
Definition: Crypt.h:691
virtual ~data_blob()
Destroys the BLOB.
Definition: Crypt.h:716
BYTE * data() noexcept
Get BLOB buffer.
Definition: Crypt.h:778
const BYTE * data() const noexcept
Get BLOB buffer.
Definition: Crypt.h:770
data_blob() noexcept
Initializes an empty BLOB.
Definition: Crypt.h:673
data_blob(data_blob &&other) noexcept
Move an existing BLOB.
Definition: Crypt.h:705
data_blob & operator=(data_blob &&other) noexcept
Move an existing BLOB.
Definition: Crypt.h:745
data_blob(BYTE *data, DWORD size) noexcept
Initializes a BLOB from existing data.
Definition: Crypt.h:682
DWORD size() const noexcept
Get BLOB size.
Definition: Crypt.h:762
data_blob & operator=(const DATA_BLOB &other)
Copy an existing BLOB.
Definition: Crypt.h:725
Base abstract template class to support object handle keeping for objects that support trivial handle...
Definition: Common.h:831
Base abstract template class to support generic object handle keeping.
Definition: Common.h:569
T handle_type
Datatype of the object handle this template class handles.
Definition: Common.h:574
handle_type m_h
Object handle.
Definition: Common.h:820
void attach(handle_type h) noexcept
Sets a new object handle for the class.
Definition: Common.h:783
Windows runtime error.
Definition: Common.h:1010
static bool CryptImportPublicKeyInfo(HCRYPTPROV hCryptProv, DWORD dwCertEncodingType, PCERT_PUBLIC_KEY_INFO pInfo, winstd::crypt_key &key)
Imports the public key.
Definition: Crypt.h:879
static BOOL WINAPI CertGetCertificateContextProperty(PCCERT_CONTEXT pCertContext, DWORD dwPropId, std::vector< _Ty, _Ax > &aData)
Retrieves the information contained in an extended property of a certificate context.
Definition: Crypt.h:59
static BOOL CertGetCertificateChain(HCERTCHAINENGINE hChainEngine, PCCERT_CONTEXT pCertContext, LPFILETIME pTime, HCERTSTORE hAdditionalStore, PCERT_CHAIN_PARA pChainPara, DWORD dwFlags, LPVOID pvReserved, winstd::cert_chain_context &ctx)
The CertGetCertificateChain function builds a certificate chain context starting from an end certific...
Definition: Crypt.h:799
static BOOL CryptGetHashParam(HCRYPTHASH hHash, DWORD dwParam, std::vector< _Ty, _Ax > &aData, DWORD dwFlags)
Retrieves data that governs the operations of a hash object. The actual hash value can be retrieved b...
Definition: Crypt.h:84
static DWORD CertGetNameStringW(PCCERT_CONTEXT pCertContext, DWORD dwType, DWORD dwFlags, void *pvTypePara, std::basic_string< wchar_t, _Traits, _Ax > &sNameString)
Obtains the subject or issuer name from a certificate CERT_CONTEXT structure and stores it in a std::...
Definition: Crypt.h:41
static BOOL CryptAcquireContextA(winstd::crypt_prov &prov, LPCSTR szContainer, LPCSTR szProvider, DWORD dwProvType, DWORD dwFlags)
Acquires the cryptographic context.
Definition: Crypt.h:809
static DWORD CertGetNameStringA(PCCERT_CONTEXT pCertContext, DWORD dwType, DWORD dwFlags, void *pvTypePara, std::basic_string< char, _Traits, _Ax > &sNameString)
Obtains the subject or issuer name from a certificate CERT_CONTEXT structure and stores it in a std::...
Definition: Crypt.h:23
static BOOL CryptGenKey(HCRYPTPROV hProv, ALG_ID Algid, DWORD dwFlags, winstd::crypt_key &key)
Generates the key.
Definition: Crypt.h:851
static BOOL CryptExportKey(HCRYPTKEY hKey, HCRYPTKEY hExpKey, DWORD dwBlobType, DWORD dwFlags, std::vector< _Ty, _Ax > &aData)
Exports a cryptographic key or a key pair from a cryptographic service provider (CSP) in a secure man...
Definition: Crypt.h:158
static BOOL CryptGetKeyParam(HCRYPTKEY hKey, DWORD dwParam, std::vector< _Ty, _Ax > &aData, DWORD dwFlags)
Retrieves data that governs the operations of a key.
Definition: Crypt.h:121
static BOOL CryptCreateHash(HCRYPTPROV hProv, ALG_ID Algid, HCRYPTKEY hKey, DWORD dwFlags, winstd::crypt_hash &hash)
Creates the hash context.
Definition: Crypt.h:837
static BOOL CryptAcquireContextW(winstd::crypt_prov &prov, LPCWSTR szContainer, LPCWSTR szProvider, DWORD dwProvType, DWORD dwFlags)
Acquires the cryptographic context.
Definition: Crypt.h:823
static BOOL CryptEncrypt(HCRYPTKEY hKey, HCRYPTHASH hHash, BOOL Final, DWORD dwFlags, std::vector< _Ty, _Ax > &aData)
Encrypts data.
Definition: Crypt.h:177
static bool CryptDeriveKey(HCRYPTPROV hProv, ALG_ID Algid, HCRYPTHASH hBaseData, DWORD dwFlags, winstd::crypt_key &key)
Generates cryptographic session keys derived from a base data value.
Definition: Crypt.h:893
static BOOL CryptDecrypt(HCRYPTKEY hKey, HCRYPTHASH hHash, BOOL Final, DWORD dwFlags, std::vector< _Ty, _Ax > &aData)
Decrypts data previously encrypted by using the CryptEncrypt function.
Definition: Crypt.h:227
static bool CryptImportKey(HCRYPTPROV hProv, __in_bcount(dwDataLen) LPCBYTE pbData, DWORD dwDataLen, HCRYPTKEY hPubKey, DWORD dwFlags, winstd::crypt_key &key)
Imports the key.
Definition: Crypt.h:865
#define WINSTD_STACK_BUFFER_BYTES
Size of the stack buffer in bytes used for initial system function call.
Definition: Common.h:93
#define WINSTD_DPLHANDLE_IMPL(C, INVAL)
Implements default constructors and operators to prevent their auto-generation by compiler.
Definition: Common.h:175
#define WINSTD_HANDLE_IMPL(C, INVAL)
Implements default constructors and operators to prevent their auto-generation by compiler.
Definition: Common.h:163
static const T invalid
Invalid handle value.
Definition: Common.h:579