134 lines
3.4 KiB
C
134 lines
3.4 KiB
C
|
/* dh_key.h */
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
#define DH_MAX_LENGTH 0x00000200 // in bytes, 512 bytes, 4096 bits
|
||
|
#define DH_KEYSIZE_INC 0x40
|
||
|
|
||
|
/*********************************/
|
||
|
/* Definitions */
|
||
|
/*********************************/
|
||
|
#define DH_PUBLIC_MAGIC 0x31484400
|
||
|
#define DH_PRIVATE_MAGIC 0x32484400
|
||
|
#define DH_PUBLIC_MAGIC_VER3 0x33484400
|
||
|
#define DH_PRIV_MAGIC_VER3 0x34484400
|
||
|
|
||
|
/*********************************/
|
||
|
/* Structure Definitions */
|
||
|
/*********************************/
|
||
|
|
||
|
typedef dsa_private_t DHKey_t; // use a DSA key since X 9.42 requires key
|
||
|
// gen like DSA
|
||
|
|
||
|
/*
|
||
|
typedef struct {
|
||
|
ALG_ID Algid; // algorithm type of the key (SF or EPHEM)
|
||
|
DH_PRIV_KEY Priv;
|
||
|
} DHKey_t;
|
||
|
*/
|
||
|
|
||
|
/*********************************/
|
||
|
/* Function Definitions */
|
||
|
/*********************************/
|
||
|
|
||
|
// Initialize DH key
|
||
|
DWORD
|
||
|
initKeyDH(
|
||
|
IN Context_t *pContext,
|
||
|
IN OUT DHKey_t *pDH,
|
||
|
IN ALG_ID Algid,
|
||
|
IN DWORD dwFlags,
|
||
|
IN BOOL fAnyLength);
|
||
|
|
||
|
DHKey_t *allocDHKey ();
|
||
|
void freeKeyDH (DHKey_t *dh);
|
||
|
|
||
|
// Get the DH parameters
|
||
|
DWORD getDHParams (
|
||
|
IN DHKey_t *dh,
|
||
|
IN DWORD param,
|
||
|
OUT BYTE *data,
|
||
|
OUT DWORD *len
|
||
|
);
|
||
|
|
||
|
// Set the DH parameters
|
||
|
DWORD setDHParams (
|
||
|
IN OUT DHKey_t *pDH,
|
||
|
IN DWORD dwParam,
|
||
|
IN CONST BYTE *pbData,
|
||
|
IN OUT Context_t *pContext
|
||
|
);
|
||
|
|
||
|
// Generate a dh key
|
||
|
DWORD dhGenerateKey (
|
||
|
IN Context_t *pContext,
|
||
|
IN OUT DHKey_t *pDH);
|
||
|
|
||
|
DWORD dhDeriveKey (DHKey_t *dh, BYTE *data, DWORD len);
|
||
|
|
||
|
// Export the DH key in blob format
|
||
|
DWORD exportDHKey (
|
||
|
IN Context_t *pContext,
|
||
|
IN DHKey_t *pDH,
|
||
|
IN ALG_ID Algid,
|
||
|
IN DWORD dwFlags,
|
||
|
IN DWORD dwReserved,
|
||
|
IN DWORD dwBlobType,
|
||
|
OUT BYTE *pbData,
|
||
|
OUT DWORD *pcbData,
|
||
|
IN BOOL fInternal
|
||
|
);
|
||
|
|
||
|
DWORD DHPrivBlobToKey(
|
||
|
IN Context_t *pContext,
|
||
|
IN BLOBHEADER *pBlob,
|
||
|
IN DWORD cbBlob,
|
||
|
IN DWORD dwKeysetType,
|
||
|
OUT Key_t *pPrivKey
|
||
|
);
|
||
|
|
||
|
// Import the blob into DH key
|
||
|
DWORD importDHKey(
|
||
|
IN OUT Key_t *pPrivKey,
|
||
|
IN Context_t *pContext,
|
||
|
IN BYTE *pbBlob,
|
||
|
IN DWORD cbBlob,
|
||
|
OUT Key_t *pKey,
|
||
|
IN DWORD dwKeysetType,
|
||
|
IN BOOL fInternal
|
||
|
);
|
||
|
|
||
|
void copyDHPubKey(
|
||
|
IN DHKey_t *pDH1,
|
||
|
IN DHKey_t *pDH2
|
||
|
);
|
||
|
|
||
|
DWORD copyDHKey(
|
||
|
IN DHKey_t *pDH1,
|
||
|
IN DHKey_t *pDH2,
|
||
|
IN ALG_ID Algid,
|
||
|
IN Context_t *pContext
|
||
|
);
|
||
|
|
||
|
//
|
||
|
// Function : UseDHKey
|
||
|
//
|
||
|
// Description : This function creates an ephemeral DH key and then generates
|
||
|
// two agreed keys, thus simulating a DH exchange. If the
|
||
|
// agreed keys are not the same then the function fails.
|
||
|
//
|
||
|
|
||
|
DWORD UseDHKey(
|
||
|
IN Context_t *pContext,
|
||
|
IN PEXPO_OFFLOAD_STRUCT pOffloadInfo,
|
||
|
IN DHKey_t *pDH
|
||
|
);
|
||
|
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|