Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

68 lines
1.5 KiB

//-----------------------------------------------------------------------------
//
// File: pkcrypto.h
//
// Microsoft Digital Rights Management
// Copyright (C) Microsoft Corporation, 1998 - 1999, All Rights Reserved
//
// Description:
// public key crypto library
//
// Author: marcuspe
//
//-----------------------------------------------------------------------------
#ifndef __DRMPKCRYPTO_H__
#define __DRMPKCRYPTO_H__
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
#include <wtypes.h>
#define LNGQDW 5
/*
typedef struct {
DWORD y[2*LNGQDW];
} PUBKEY;
typedef struct {
DWORD x[LNGQDW];
} PRIVKEY;
*/
#define PK_ENC_PUBLIC_KEY_LEN (2 * LNGQDW * sizeof(DWORD))
#define PK_ENC_PRIVATE_KEY_LEN ( LNGQDW * sizeof(DWORD))
#define PK_ENC_PLAINTEXT_LEN ((LNGQDW-1) * sizeof(DWORD))
#define PK_ENC_CIPHERTEXT_LEN (4 * LNGQDW * sizeof(DWORD))
#define PK_ENC_SIGNATURE_LEN (2 * LNGQDW * sizeof(DWORD))
typedef struct {
BYTE y[ PK_ENC_PUBLIC_KEY_LEN ];
} PUBKEY;
typedef struct {
BYTE x[ PK_ENC_PRIVATE_KEY_LEN ];
} PRIVKEY;
class CDRMPKCrypto {
private:
char *pkd;
public:
CDRMPKCrypto();
~CDRMPKCrypto();
HRESULT PKinit();
HRESULT PKencrypt( PUBKEY *pk, BYTE *in, BYTE *out );
HRESULT PKdecrypt( PRIVKEY *pk, BYTE *in, BYTE *out );
HRESULT PKsign( PRIVKEY *privkey, BYTE *buffer, DWORD lbuf, BYTE *sign );
BOOL PKverify( PUBKEY *pubkey, BYTE *buffer, DWORD lbuf, BYTE *sign );
HRESULT PKGenKeyPair( PUBKEY *pPub, PRIVKEY *pPriv );
};
#endif