crypto/weakcrypto/source/asymmetric/rsakeys.cpp
author hgs
Thu, 12 Aug 2010 21:07:10 +0530
changeset 90 8c545fea2798
parent 72 de46a57f75fb
permissions -rw-r--r--
201031_01
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
72
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     1
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     2
* Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     3
* All rights reserved.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     8
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     9
* Initial Contributors:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    11
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    12
* Contributors:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    13
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    14
* Description: 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    15
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    16
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    17
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    18
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    19
#include <asymmetrickeys.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    20
#include <bigint.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    21
#include "../common/inlines.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    22
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    23
const TUint KFermat4 = 65537;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    24
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    25
/* CRSAParameters */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    26
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    27
EXPORT_C const TInteger& CRSAParameters::N(void) const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    28
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    29
	return iN;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    30
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    31
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    32
EXPORT_C CRSAParameters::~CRSAParameters(void)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    33
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    34
	iN.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    35
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    36
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    37
EXPORT_C CRSAParameters::CRSAParameters(RInteger& aN) : iN(aN)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    38
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    39
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    40
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    41
EXPORT_C CRSAParameters::CRSAParameters(void)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    42
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    43
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    44
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    45
/* CRSAPublicKey */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    46
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    47
EXPORT_C CRSAPublicKey* CRSAPublicKey::NewL(RInteger& aN, RInteger& aE)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    48
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    49
	CRSAPublicKey* self = NewLC(aN, aE);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    50
	CleanupStack::Pop();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    51
	return self;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    52
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    53
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    54
EXPORT_C CRSAPublicKey* CRSAPublicKey::NewLC(RInteger& aN, RInteger& aE)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    55
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    56
	CRSAPublicKey* self = new(ELeave) CRSAPublicKey(aN, aE);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    57
	CleanupStack::PushL(self);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    58
	self->ConstructL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    59
	return self;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    60
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    61
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    62
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    63
void CRSAPublicKey::ConstructL()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    64
	{ 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    65
	// Check that the modulus and exponent are positive integers 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    66
	// as specified by RSA
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    67
	if(!N().IsPositive() || !E().IsPositive() || (E() <= 1))
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    68
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    69
		// If we need to leave during construction we must release ownership
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    70
		// of the RInteger parameters that were passed in.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    71
		// These parameters should be on the cleanup stack so if we don't 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    72
		// release ownership they will be deleted twice, causing a panic
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    73
		iN = RInteger();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    74
		iE = RInteger();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    75
		User::Leave(KErrArgument);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    76
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    77
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    78
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    79
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    80
EXPORT_C const TInteger& CRSAPublicKey::E(void) const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    81
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    82
	return iE;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    83
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    84
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    85
EXPORT_C CRSAPublicKey::CRSAPublicKey()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    86
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    87
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    88
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    89
EXPORT_C CRSAPublicKey::CRSAPublicKey(RInteger& aN, RInteger& aE)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    90
	: CRSAParameters(aN), iE(aE)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    91
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    92
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    93
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    94
EXPORT_C CRSAPublicKey::~CRSAPublicKey(void)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    95
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    96
	iE.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    97
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    98
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    99
/* CRSAPrivateKeyType */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   100
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   101
CRSAPrivateKey::CRSAPrivateKey(const TRSAPrivateKeyType aKeyType, RInteger& aN)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   102
:	CRSAParameters(aN), iKeyType(aKeyType)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   103
{}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   104
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   105
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   106
/* CRSAPrivateKeyStandard */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   107
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   108
EXPORT_C CRSAPrivateKeyStandard* CRSAPrivateKeyStandard::NewL(RInteger& aN, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   109
	RInteger& aD)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   110
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   111
	CRSAPrivateKeyStandard* self = NewLC(aN, aD);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   112
	CleanupStack::Pop();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   113
	return self;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   114
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   115
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   116
EXPORT_C CRSAPrivateKeyStandard* CRSAPrivateKeyStandard::NewLC(RInteger& aN,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   117
	RInteger& aD)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   118
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   119
	CRSAPrivateKeyStandard* self = new(ELeave) CRSAPrivateKeyStandard(aN, aD);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   120
	CleanupStack::PushL(self);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   121
	self->ConstructL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   122
	return self;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   123
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   124
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   125
void CRSAPrivateKeyStandard::ConstructL()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   126
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   127
	// Check that the modulus and exponent are positive integers
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   128
	if(!N().IsPositive() || !D().IsPositive() || (D() <= 1))
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   129
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   130
		// If we need to leave during construction we must release ownership
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   131
		// of the RInteger parameters that were passed in.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   132
		// These parameters should be on the cleanup stack so if we don't 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   133
		// release ownership they will be deleted twice, causing a panic
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   134
		iN = RInteger();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   135
		iD = RInteger();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   136
		User::Leave(KErrArgument);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   137
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   138
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   139
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   140
EXPORT_C const TInteger& CRSAPrivateKeyStandard::D(void) const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   141
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   142
	return iD;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   143
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   144
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   145
EXPORT_C CRSAPrivateKeyStandard::CRSAPrivateKeyStandard(RInteger& aN, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   146
	RInteger& aD) : CRSAPrivateKey(EStandard, aN), iD(aD)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   147
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   148
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   149
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   150
EXPORT_C CRSAPrivateKeyStandard::~CRSAPrivateKeyStandard()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   151
	{	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   152
	iD.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   153
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   154
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   155
/* CRSAPrivateKeyCRT */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   156
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   157
EXPORT_C CRSAPrivateKeyCRT* CRSAPrivateKeyCRT::NewL(RInteger& aN, RInteger& aP,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   158
	RInteger& aQ, RInteger& aDP, RInteger& aDQ, RInteger& aQInv)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   159
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   160
	CRSAPrivateKeyCRT* self = NewLC(aN, aP, aQ, aDP, aDQ, aQInv);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   161
	CleanupStack::Pop();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   162
	return self;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   163
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   164
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   165
EXPORT_C CRSAPrivateKeyCRT* CRSAPrivateKeyCRT::NewLC(RInteger& aN, RInteger& aP, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   166
	RInteger& aQ, RInteger& aDP, RInteger& aDQ, RInteger& aQInv)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   167
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   168
	CRSAPrivateKeyCRT* self = new(ELeave) CRSAPrivateKeyCRT(aN, aP, aQ, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   169
		aDP, aDQ, aQInv);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   170
	CleanupStack::PushL(self);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   171
	self->ConstructL();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   172
	return self;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   173
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   174
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   175
EXPORT_C CRSAPrivateKeyCRT::CRSAPrivateKeyCRT(RInteger& aN, RInteger& aP, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   176
	RInteger& aQ, RInteger& aDP, RInteger& aDQ, RInteger& aQInv) 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   177
	: CRSAPrivateKey(EStandardCRT, aN), iP(aP), iQ(aQ), iDP(aDP), iDQ(aDQ), 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   178
		iQInv(aQInv)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   179
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   180
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   181
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   182
void CRSAPrivateKeyCRT::ConstructL()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   183
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   184
	// Check that all parameters are positive integers
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   185
	if(!P().IsPositive() || !Q().IsPositive() || !DP().IsPositive() 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   186
		|| !DQ().IsPositive() || !QInv().IsPositive())
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   187
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   188
		// If we need to leave during construction we must release ownership
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   189
		// of the RInteger parameters that were passed in.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   190
		// These parameters should be on the cleanup stack so if we don't 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   191
		// release ownership they will be deleted twice, causing a panic
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   192
		iN = RInteger();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   193
		iP = RInteger();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   194
		iQ = RInteger();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   195
		iDP = RInteger();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   196
		iDQ = RInteger();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   197
		iQInv = RInteger();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   198
		User::Leave(KErrArgument);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   199
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   200
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   201
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   202
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   203
EXPORT_C CRSAPrivateKeyCRT::~CRSAPrivateKeyCRT()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   204
	{	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   205
	iP.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   206
	iQ.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   207
	iDP.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   208
	iDQ.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   209
	iQInv.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   210
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   211
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   212
EXPORT_C const TInteger& CRSAPrivateKeyCRT::P(void) const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   213
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   214
	return iP;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   215
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   216
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   217
EXPORT_C const TInteger& CRSAPrivateKeyCRT::Q(void) const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   218
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   219
	return iQ;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   220
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   221
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   222
EXPORT_C const TInteger& CRSAPrivateKeyCRT::DP(void) const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   223
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   224
	return iDP;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   225
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   226
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   227
EXPORT_C const TInteger& CRSAPrivateKeyCRT::DQ(void) const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   228
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   229
	return iDQ;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   230
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   231
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   232
EXPORT_C const TInteger& CRSAPrivateKeyCRT::QInv(void) const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   233
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   234
	return iQInv;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   235
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   236
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   237
/* CRSAKeyPair */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   238
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   239
EXPORT_C CRSAKeyPair* CRSAKeyPair::NewL(TUint aModulusBits, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   240
	TRSAPrivateKeyType aKeyType /*= EStandardCRT*/)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   241
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   242
	CRSAKeyPair* self = NewLC(aModulusBits, aKeyType);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   243
	CleanupStack::Pop();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   244
	return self;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   245
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   246
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   247
EXPORT_C CRSAKeyPair* CRSAKeyPair::NewLC(TUint aModulusBits, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   248
	TRSAPrivateKeyType aKeyType /*= EStandardCRT*/)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   249
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   250
	CRSAKeyPair* self = new(ELeave) CRSAKeyPair();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   251
	CleanupStack::PushL(self);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   252
	self->ConstructL(aModulusBits, aKeyType, KFermat4);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   253
	return self;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   254
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   255
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   256
EXPORT_C const CRSAPublicKey& CRSAKeyPair::PublicKey(void) const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   257
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   258
	return *iPublic;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   259
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   260
	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   261
EXPORT_C const CRSAPrivateKey& CRSAKeyPair::PrivateKey(void) const
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   262
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   263
	return *iPrivate;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   264
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   265
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   266
EXPORT_C CRSAKeyPair::~CRSAKeyPair(void) 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   267
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   268
	delete iPublic;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   269
	delete iPrivate;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   270
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   271
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   272
EXPORT_C CRSAKeyPair::CRSAKeyPair(void)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   273
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   274
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   275
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   276
void CRSAKeyPair::ConstructL(TUint aModulusBits, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   277
	TRSAPrivateKeyType aKeyType, TUint aPublicExponent)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   278
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   279
	RInteger e = RInteger::NewL(aPublicExponent);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   280
	CleanupStack::PushL(e);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   281
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   282
	RInteger p;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   283
	RInteger q;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   284
	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   285
	//these make sure n is a least aModulusBits long
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   286
    TInt pbits=(aModulusBits+1)/2;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   287
    TInt qbits=aModulusBits-pbits;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   288
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   289
	//generate a prime p such that GCD(e,p-1) == 1
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   290
	for (;;)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   291
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   292
		p = RInteger::NewPrimeL(pbits,TInteger::ETop2BitsSet);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   293
		CleanupStack::PushL(p);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   294
		--p;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   295
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   296
		RInteger gcd = e.GCDL(p);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   297
		if( gcd == 1 )
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   298
			{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   299
			++p;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   300
			gcd.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   301
			//p is still on cleanup stack
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   302
			break;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   303
			}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   304
		CleanupStack::PopAndDestroy(&p);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   305
		gcd.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   306
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   307
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   308
	//generate a prime q such that GCD(e,q-1) == 1 && (p != q)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   309
	for (;;)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   310
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   311
		q = RInteger::NewPrimeL(qbits,TInteger::ETop2BitsSet);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   312
		CleanupStack::PushL(q);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   313
		--q;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   314
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   315
		RInteger gcd = e.GCDL(q);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   316
		if( gcd == 1 )
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   317
			{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   318
			++q;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   319
			if( p != q )
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   320
				{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   321
				gcd.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   322
				//q is still on cleanup stack
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   323
				break;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   324
				}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   325
			}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   326
		CleanupStack::PopAndDestroy(&q);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   327
		gcd.Close();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   328
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   329
		
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   330
	//make sure p > q
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   331
    if ( p < q)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   332
        {
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   333
		TClassSwap(p,q);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   334
        }
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   335
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   336
	//calculate n = p * q 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   337
	RInteger n = p.TimesL(q);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   338
	CleanupStack::PushL(n);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   339
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   340
	--p;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   341
	--q;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   342
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   343
	//temp = (p-1)(q-1)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   344
	RInteger temp = p.TimesL(q);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   345
	CleanupStack::PushL(temp);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   346
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   347
	//e * d = 1 mod ((p-1)(q-1)) 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   348
	//d = e^(-1) mod ((p-1)(q-1))
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   349
	RInteger d = e.InverseModL(temp);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   350
	CleanupStack::PopAndDestroy(&temp); //temp
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   351
	CleanupStack::PushL(d);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   352
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   353
	if (aKeyType==EStandardCRT)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   354
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   355
		//calculate dP = d mod (p-1) 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   356
		RInteger dP = d.ModuloL(p); //p is still p-1
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   357
		CleanupStack::PushL(dP);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   358
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   359
		//calculate dQ = d mod (q-1) 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   360
		RInteger dQ = d.ModuloL(q); //q is still q-1
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   361
		CleanupStack::PushL(dQ);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   362
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   363
		++p;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   364
		++q;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   365
		//calculate inverse of qInv = q^(-1)mod(p)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   366
		RInteger qInv = q.InverseModL(p);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   367
		CleanupStack::PushL(qInv);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   368
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   369
		iPrivate = CRSAPrivateKeyCRT::NewL(n,p,q,dP,dQ,qInv);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   370
		
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   371
		CleanupStack::Pop(3, &dP); //qInv, dQ, dP
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   372
		CleanupStack::PopAndDestroy(&d); //d	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   373
		CleanupStack::Pop(3, &p); //n, q, p
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   374
		//e is still on cleanup stack
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   375
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   376
	else if (aKeyType==EStandard)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   377
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   378
		iPrivate = CRSAPrivateKeyStandard::NewL(n,d);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   379
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   380
		CleanupStack::Pop(2, &n); //d, n
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   381
		CleanupStack::PopAndDestroy(2, &p); //q, p
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   382
		//e is still on cleanup stack
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   383
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   384
	else
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   385
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   386
		User::Leave(KErrNotSupported);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   387
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   388
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   389
	//make a copy of n for the public parameters
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   390
	RInteger n1 = RInteger::NewL(PrivateKey().N());
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   391
	CleanupStack::PushL(n1);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   392
	iPublic = CRSAPublicKey::NewL(n1,e); 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   393
	CleanupStack::Pop(2, &e); //n1, e
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   394
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   395