NT4/private/windows/base/ntcrypto/inc/rsa.h

273 lines
7.8 KiB
C
Raw Normal View History

2001-01-01 00:00:00 +01:00
/* rsa.h
*
* RSA library functions.
*
* Copyright (C) RSA Data Security, Inc. created 1990. This is an
* unpublished work protected as such under copyright law. This work
* contains proprietary, confidential, and trade secret information of
* RSA Data Security, Inc. Use, disclosure or reproduction without the
* express written authorization of RSA Data Security, Inc. is
* prohibited.
*
*/
#ifdef __cplusplus
extern "C" {
#endif
#define RSA1 ((DWORD)'R'+((DWORD)'S'<<8)+((DWORD)'A'<<16)+((DWORD)'1'<<24))
#define RSA2 ((DWORD)'R'+((DWORD)'S'<<8)+((DWORD)'A'<<16)+((DWORD)'2'<<24))
// Key header structures.
//
// These structs define the fixed data at the beginning of an RSA key.
// They are followed by a variable length of data, sized by the stlen
// field.
typedef struct {
DWORD magic; /* Should always be RSA1 */
DWORD keylen; // size of modulus buffer
DWORD bitlen; // # of bits in modulus
DWORD datalen; // max number of bytes to be encoded
DWORD pubexp; //public exponent
} BSAFE_PUB_KEY, FAR *LPBSAFE_PUB_KEY;
typedef struct {
DWORD magic; /* Should always be RSA2 */
DWORD keylen; // size of modulus buffer
DWORD bitlen; // bit size of key
DWORD datalen; // max number of bytes to be encoded
DWORD pubexp; // public exponent
} BSAFE_PRV_KEY, FAR *LPBSAFE_PRV_KEY;
typedef struct {
BYTE *modulus;
BYTE *prvexp;
BYTE *prime1;
BYTE *prime2;
BYTE *exp1;
BYTE *exp2;
BYTE *coef;
BYTE *invmod;
BYTE *invpr1;
BYTE *invpr2;
} BSAFE_KEY_PARTS, FAR *LPBSAFE_KEY_PARTS;
typedef const BYTE far *cLPBYTE; // const LPBYTE resolves wrong
/* BSafeEncPublic
*
* BSafeEncPublic(key, part_in, part_out)
*
* RSA encrypt a buffer of size key->keylen, filled with data of size
* key->datalen with the public key pointed to by key, returning the
* encrypted data in part_out.
*
* Parameters
*
* LPBSAFE_PUB_KEY key - points to a public key in BSAFE_KEY
* format.
*
* LPBYTE part_in - points to a BYTE array of size key->keylen
* holding the data to be encrypted. The
* data in the buffer should be no larger
* than key->datalen. All other bytes should
* be zero.
*
* LPBYTE part_out - points to a BYTE array of size keylen
* to receive the encrypted data.
*
* Returns
*
* TRUE - encryption succeeded.
* FALSE - encryption failed.
*
*/
BOOL BSafeEncPublic(const LPBSAFE_PUB_KEY key,
cLPBYTE part_in,
LPBYTE part_out);
/* BSafeDecPrivate
*
* BSafeDecPrivate(key, part_in, part_out)
*
* RSA decrypt a buffer of size keylen, containing key->datalen bytes
* of data with the private key pointed to by key, returning the
* decrypted data in part_out.
*
* Parameters
*
* LPBSAFE_PRV_KEY key - points to a private key in BSAFE_KEY
* format.
*
* LPBYTE part_in - points to a BYTE array of size key->keylen
* holding the data to be decrypted. The data
* in the buffer should be no longer than
* key->datalen. All other bytes should be zero.
*
* LPBYTE part_out - points to a BYTE array of size GRAINSIZE
* to receive the decrypted data.
*
* Returns
*
* TRUE - decryption succeeded.
* FALSE - decryption failed.
*
*/
BOOL BSafeDecPrivate(const LPBSAFE_PRV_KEY key,
cLPBYTE part_in,
LPBYTE part_out);
/* BSafeMakeKeyPair
*
* BSafeMakeKeyPair(public_key, private_key, bits)
*
* Generate an RSA key pair.
*
* Parameters
*
* LPBSAFE_PUB_KEY public_key - points to the memory to recieve
* the public key. This pointer must
* point to at least the number of bytes
* specified as the public key size by
* BSafeComputeKeySizes.
*
* LPBSAFE_PRV_KEY private_key - points to the memory to recieve
* the private key. This pointer must
* point to at least the number of bytes
* specified as the private key size
* by BSafeComputeKeySizes.
*
* DWORD bits - length of the requested key in bits.
* This value must be even and greater than 63
*
* Returns
*
* TRUE - keys were successfully generated
* FALSE - not enough memory to generate keys
*
*/
BOOL BSafeMakeKeyPair(LPBSAFE_PUB_KEY public_key,
LPBSAFE_PRV_KEY private_key,
DWORD bits);
/* BSafeFreePubKey
*
* BSafeFreePubKey(public_key)
*
* Free the data associated with a public key
*
* Parameters
*
* LPBSAFE_PUB_KEY public_key - points to a BSAFE_PUB_KEY
* structure to free.
*
* Returns
*
* nothing
*
*/
void BSafeFreePubKey(LPBSAFE_PUB_KEY public_key);
/* BSafeFreePrvKey
*
* BSafeFreePrvKey(public_key)
*
* Free the data associated with a private key
*
* Parameters
*
* LPBSAFE_PRV_KEY private_key - points to a BSAFE_PRV_KEY
* structure to free.
*
* Returns
*
* nothing
*
*/
void BSafeFreePrvKey(LPBSAFE_PRV_KEY private_key);
/* BSafeComputeKeySizes
*
* BSafeComputeKeySizes( LPDWORD PubKeySize,
* LPDWORD PrivKeySize,
* LPDWORD bits )
*
* Computes the required memory to hold a public and private key of
* a specified number of bits.
*
* Parameters:
*
* LPDWORD PubKeySize - pointer to DWORD to return the public
* key size, in bytes.
*
* LPDWORD PrivKeySize - pointer to DWORD to return the private
* key size, in bytes.
*
* LPDWORD bits - pointer to DWORD specifying number of bits
* in the RSA modulus.
*
* Returns:
*
* TRUE if *bits is a valid RSA modulus size.
* FALSE if *bits is an invalid RSA modulus size.
*
*/
BOOL BSafeComputeKeySizes(LPDWORD PublicKeySize,
LPDWORD PrivateKeySize,
LPDWORD bits);
/* BSafeGetPrvKeyParts
*
* BOOL BSafeGetPrvKeyParts( LPBSAFE_PRV_KEY key,
* LPBSAFE_KEY_PARTS parts)
*
* Returns pointers to the parts of a private key, and the length of
* the modulus in bytes.
*
* Parameters:
*
* LPBSAFE_PRV_KEY key - the key to disassemble
* LPBSAFE_KEY_PARTS parts - the structure to fill in
*
* Returns -
* FALSE if the key is not valid.
*/
BOOL BSafeGetPrvKeyParts(LPBSAFE_PRV_KEY key,
LPBSAFE_KEY_PARTS parts);
/* BSafeGetPubKeyModulus
*
* BYTE *BSafeGetPubKeyModulus(LPBSAFE_PUB_KEY key)
*
* Returns pointer to the modulus of a public key
*
* Parameters:
*
* LPBSAFE_PUB_KEY key - the key to disassemble
*
* Returns -
*
* Pointer to the parts, VOID on error.
* Fails if the key is not valid.
*/
BYTE *BSafeGetPubKeyModulus(LPBSAFE_PUB_KEY key);
#ifdef __cplusplus
}
#endif