2015-06-03 00:13:43 +00:00
|
|
|
/* Benjamin DELPY `gentilkiwi`
|
|
|
|
http://blog.gentilkiwi.com
|
|
|
|
benjamin@gentilkiwi.com
|
2015-08-25 09:19:01 +00:00
|
|
|
Licence : https://creativecommons.org/licenses/by/4.0/
|
2015-06-03 00:13:43 +00:00
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "globals.h"
|
2015-06-07 21:19:28 +00:00
|
|
|
#include "kull_m_string.h"
|
2015-08-25 09:19:01 +00:00
|
|
|
#include "kull_m_crypto_system.h"
|
2016-09-10 21:07:33 +00:00
|
|
|
#include "kull_m_file.h"
|
2015-06-03 00:13:43 +00:00
|
|
|
|
2016-01-16 23:36:41 +00:00
|
|
|
#define CALG_CRC32 (ALG_CLASS_HASH | ALG_TYPE_ANY | 0)
|
|
|
|
|
2015-06-03 00:13:43 +00:00
|
|
|
#define AES_256_KEY_SIZE (256/8)
|
|
|
|
#define AES_128_KEY_SIZE (128/8)
|
|
|
|
#define AES_BLOCK_SIZE 16
|
|
|
|
|
|
|
|
typedef struct _GENERICKEY_BLOB {
|
|
|
|
BLOBHEADER Header;
|
|
|
|
DWORD dwKeyLen;
|
|
|
|
} GENERICKEY_BLOB, *PGENERICKEY_BLOB;
|
|
|
|
|
2015-06-18 00:18:17 +00:00
|
|
|
typedef struct _RSA_GENERICKEY_BLOB {
|
|
|
|
BLOBHEADER Header;
|
|
|
|
RSAPUBKEY RsaKey; // works with RSA2 ;)
|
|
|
|
} RSA_GENERICKEY_BLOB, *PRSA_GENERICKEY_BLOB;
|
|
|
|
|
2015-06-14 00:46:21 +00:00
|
|
|
#define PVK_FILE_VERSION_0 0
|
|
|
|
#define PVK_MAGIC 0xb0b5f11e // bob's file
|
|
|
|
#define PVK_NO_ENCRYPT 0
|
|
|
|
#define PVK_RC4_PASSWORD_ENCRYPT 1
|
|
|
|
#define PVK_RC2_CBC_PASSWORD_ENCRYPT 2
|
|
|
|
|
2016-09-10 21:07:33 +00:00
|
|
|
#ifndef IPSEC_FLAG_CHECK
|
|
|
|
#define IPSEC_FLAG_CHECK 0xf42a19b6
|
|
|
|
#endif
|
|
|
|
|
2015-06-14 00:46:21 +00:00
|
|
|
typedef struct _PVK_FILE_HDR {
|
|
|
|
DWORD dwMagic;
|
|
|
|
DWORD dwVersion;
|
|
|
|
DWORD dwKeySpec;
|
|
|
|
DWORD dwEncryptType;
|
|
|
|
DWORD cbEncryptData;
|
|
|
|
DWORD cbPvk;
|
|
|
|
} PVK_FILE_HDR, *PPVK_FILE_HDR;
|
|
|
|
|
2015-07-14 23:13:21 +00:00
|
|
|
typedef struct _KIWI_HARD_KEY {
|
|
|
|
ULONG cbSecret;
|
|
|
|
BYTE data[ANYSIZE_ARRAY]; // etc...
|
|
|
|
} KIWI_HARD_KEY, *PKIWI_HARD_KEY;
|
|
|
|
|
|
|
|
typedef struct _KIWI_BCRYPT_KEY {
|
|
|
|
ULONG size;
|
|
|
|
ULONG tag; // 'MSSK'
|
|
|
|
ULONG type;
|
|
|
|
ULONG unk0;
|
|
|
|
ULONG unk1;
|
|
|
|
ULONG bits;
|
|
|
|
KIWI_HARD_KEY hardkey;
|
|
|
|
} KIWI_BCRYPT_KEY, *PKIWI_BCRYPT_KEY;
|
|
|
|
|
2015-06-07 21:19:28 +00:00
|
|
|
BOOL kull_m_crypto_hash(ALG_ID algid, LPCVOID data, DWORD dataLen, LPVOID hash, DWORD hashWanted);
|
2017-06-07 00:37:32 +00:00
|
|
|
BOOL kull_m_crypto_hkey(HCRYPTPROV hProv, ALG_ID calgid, LPCVOID key, DWORD keyLen, DWORD flags, HCRYPTKEY *hKey, HCRYPTPROV *hSessionProv);
|
2015-06-03 00:13:43 +00:00
|
|
|
BOOL kull_m_crypto_hmac(DWORD calgid, LPCVOID key, DWORD keyLen, LPCVOID message, DWORD messageLen, LPVOID hash, DWORD hashWanted);
|
2015-06-14 00:46:21 +00:00
|
|
|
BOOL kull_m_crypto_pkcs5_pbkdf2_hmac(DWORD calgid, LPCVOID password, DWORD passwordLen, LPCVOID salt, DWORD saltLen, DWORD iterations, BYTE *key, DWORD keyLen, BOOL isDpapiInternal);
|
2015-06-03 00:13:43 +00:00
|
|
|
BOOL kull_m_crypto_aesCTSEncryptDecrypt(DWORD aesCalgId, PVOID data, DWORD szData, PVOID key, DWORD szKey, PVOID pbIV, BOOL encrypt);
|
2015-06-07 21:19:28 +00:00
|
|
|
BOOL kull_m_crypto_DeriveKeyRaw(ALG_ID hashId, LPVOID hash, DWORD hashLen, LPVOID key, DWORD keyLen);
|
|
|
|
BOOL kull_m_crypto_close_hprov_delete_container(HCRYPTPROV hProv);
|
|
|
|
BOOL kull_m_crypto_hkey_session(ALG_ID calgid, LPCVOID key, DWORD keyLen, DWORD flags, HCRYPTKEY *hSessionKey, HCRYPTPROV *hSessionProv);
|
2015-06-14 00:46:21 +00:00
|
|
|
DWORD kull_m_crypto_hash_len(ALG_ID hashId);
|
|
|
|
DWORD kull_m_crypto_cipher_blocklen(ALG_ID hashId);
|
|
|
|
DWORD kull_m_crypto_cipher_keylen(ALG_ID hashId);
|
2015-08-25 09:19:01 +00:00
|
|
|
NTSTATUS kull_m_crypto_get_dcc(PBYTE dcc, PBYTE ntlm, PUNICODE_STRING Username, DWORD realIterations);
|
2016-08-08 01:35:01 +00:00
|
|
|
BOOL kull_m_crypto_genericAES128Decrypt(LPCVOID pKey, LPCVOID pIV, LPCVOID pData, DWORD dwDataLen, LPVOID *pOut, DWORD *dwOutLen);
|
2015-06-03 00:13:43 +00:00
|
|
|
|
2016-09-10 21:07:33 +00:00
|
|
|
BOOL kull_m_crypto_exportPfx(HCERTSTORE hStore, LPCWSTR filename);
|
|
|
|
BOOL kull_m_crypto_DerAndKeyToPfx(LPCVOID der, DWORD derLen, LPCVOID key, DWORD keyLen, BOOL isPvk, LPCWSTR filename);
|
|
|
|
BOOL kull_m_crypto_DerAndKeyInfoToPfx(LPCVOID der, DWORD derLen, PCRYPT_KEY_PROV_INFO pInfo, LPCWSTR filename);
|
|
|
|
BOOL kull_m_crypto_DerAndKeyInfoToStore(LPCVOID der, DWORD derLen, PCRYPT_KEY_PROV_INFO pInfo, DWORD systemStore, LPCWSTR store, BOOL force);
|
|
|
|
|
2015-06-03 00:13:43 +00:00
|
|
|
typedef struct _KULL_M_CRYPTO_DUAL_STRING_DWORD {
|
|
|
|
PCWSTR name;
|
|
|
|
DWORD id;
|
|
|
|
} KULL_M_CRYPTO_DUAL_STRING_DWORD, *PKULL_M_CRYPTO_DUAL_STRING_DWORD;
|
|
|
|
|
|
|
|
typedef struct _KULL_M_CRYPTO_DUAL_STRING_STRING {
|
|
|
|
PCWSTR name;
|
|
|
|
PCWSTR realname;
|
|
|
|
} KULL_M_CRYPTO_DUAL_STRING_STRING, *PKULL_M_CRYPTO_DUAL_STRING_STRING;
|
|
|
|
|
2016-01-12 02:13:12 +00:00
|
|
|
#define CERT_cert_file_element 32
|
|
|
|
#define CERT_crl_file_element 33
|
|
|
|
#define CERT_ctl_file_element 34
|
|
|
|
#define CERT_keyid_file_element 35
|
|
|
|
|
2015-06-03 00:13:43 +00:00
|
|
|
DWORD kull_m_crypto_system_store_to_dword(PCWSTR name);
|
|
|
|
DWORD kull_m_crypto_provider_type_to_dword(PCWSTR name);
|
2016-01-12 02:13:12 +00:00
|
|
|
PCWSTR kull_m_crypto_provider_type_to_name(const DWORD dwProvType);
|
2015-06-03 00:13:43 +00:00
|
|
|
PCWCHAR kull_m_crypto_provider_to_realname(PCWSTR name);
|
|
|
|
PCWCHAR kull_m_crypto_keytype_to_str(const DWORD keyType);
|
2016-01-12 02:13:12 +00:00
|
|
|
PCWCHAR kull_m_crypto_algid_to_name(ALG_ID algid);
|
2017-03-19 15:03:54 +00:00
|
|
|
ALG_ID kull_m_crypto_name_to_algid(PCWSTR name);
|
|
|
|
PCWCHAR kull_m_crypto_cert_prop_id_to_name(const DWORD propId);
|
2017-08-01 02:45:47 +00:00
|
|
|
void kull_m_crypto_kp_permissions_descr(const DWORD keyPermissions);
|
|
|
|
PCWCHAR kull_m_crypto_kp_mode_to_str(const DWORD keyMode);
|
2017-08-13 15:27:10 +00:00
|
|
|
PCWCHAR kull_m_crypto_bcrypt_interface_to_str(const DWORD interf);
|
|
|
|
PCWCHAR kull_m_crypto_bcrypt_cipher_alg_to_str(const DWORD alg);
|
|
|
|
PCWCHAR kull_m_crypto_bcrypt_asym_alg_to_str(const DWORD alg);
|
|
|
|
PCWCHAR kull_m_crypto_bcrypt_mode_to_str(const DWORD keyMode);
|
|
|
|
|
2017-03-19 15:03:54 +00:00
|
|
|
|
|
|
|
typedef struct _MIMI_PUBLICKEY
|
|
|
|
{
|
|
|
|
ALG_ID sessionType;
|
|
|
|
DWORD cbPublicKey;
|
|
|
|
BYTE *pbPublicKey;
|
|
|
|
} MIMI_PUBLICKEY, *PMIMI_PUBLICKEY;
|
|
|
|
|
|
|
|
typedef struct _KIWI_DH {
|
|
|
|
HCRYPTPROV hProvParty;
|
|
|
|
HCRYPTKEY hPrivateKey;
|
|
|
|
MIMI_PUBLICKEY publicKey;
|
|
|
|
HCRYPTKEY hSessionKey;
|
|
|
|
} KIWI_DH, *PKIWI_DH;
|
|
|
|
|
|
|
|
PKIWI_DH kull_m_crypto_dh_Delete(PKIWI_DH dh);
|
|
|
|
PKIWI_DH kull_m_crypto_dh_Create(ALG_ID targetSessionKeyType);
|
|
|
|
BOOL kull_m_crypto_dh_CreateSessionKey(PKIWI_DH dh, PMIMI_PUBLICKEY publicKey);
|
|
|
|
BOOL kull_m_crypto_dh_simpleEncrypt(HCRYPTKEY key, LPVOID data, DWORD dataLen, LPVOID *out, DWORD *outLen);
|
|
|
|
BOOL kull_m_crypto_dh_simpleDecrypt(HCRYPTKEY key, LPVOID data, DWORD dataLen, LPVOID *out, DWORD *outLen);
|