crypto/weakcryptospi/source/common/keyconverter.cpp
author Mikko Sunikka <mikko.sunikka@nokia.com>
Fri, 06 Nov 2009 13:21:00 +0200
changeset 17 cd501b96611d
child 49 2f10d260163b
permissions -rw-r--r--
Revision: 200945 Kit: 200945

/*
* Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description: 
*
*/


#include "keyconverter.h"
#include <cryptospi/cryptoparams.h>
#include <cryptospi/cryptospidef.h>
#include "keys.h"
#include "keypair.h"

using namespace CryptoSpi;

/* CKeyConverter */

CKey* KeyConverter::CreateKeyL(const CDHPrivateKey& aPrivateKey)
	{
	/*
	 * setup key attributes
	 */
	TKeyProperty keyProperty;
	keyProperty.iAlgorithmUid = KDHAgreementUid;

	/*
	 * extract key parameters from the compatibility dh key object
	 */
	CCryptoParams* keyParameters = CCryptoParams::NewLC();
	keyParameters->AddL(aPrivateKey.N(), KDhKeyParameterNUid);
	keyParameters->AddL(aPrivateKey.G(), KDhKeyParameterGUid);
	keyParameters->AddL(aPrivateKey.x(), KDhKeyParameterxUid);

	/*
	 * create a CKey from the parameters
	 */
	CKey* newPrivateKey = CKey::NewL(keyProperty, *keyParameters);

	CleanupStack::PopAndDestroy(1, keyParameters);
	return newPrivateKey;
	}

CKey* KeyConverter::CreateKeyL(const CDHPublicKey& aPublicKey)
	{
	/*
	 * setup key attributes
	 */
	TKeyProperty keyProperty;
	keyProperty.iAlgorithmUid = KDHAgreementUid;

	/*
	 * extract key parameters from the compatibility dh key object
	 */
	CCryptoParams* keyParameters = CCryptoParams::NewLC();
	keyParameters->AddL(aPublicKey.N(), KDhKeyParameterNUid);
	keyParameters->AddL(aPublicKey.G(), KDhKeyParameterGUid);
	keyParameters->AddL(aPublicKey.X(), KDhKeyParameterXUid);

	/*
	 * create a CKey from the parameters
	 */
	CKey* newPublicKey = CKey::NewL(keyProperty, *keyParameters);

	CleanupStack::PopAndDestroy(1, keyParameters);
	return newPublicKey;
	}

CKey* KeyConverter::CreateKeyL(const CDSAPrivateKey& aPrivateKey)
	{
	TKeyProperty keyProperty = {KDsaSignerUid, KNullUid, KDsaPrivateKeyUid, KNonEmbeddedKeyUid};

	CCryptoParams* keyParameters = CCryptoParams::NewLC();
	keyParameters->AddL(aPrivateKey.P(), KDsaKeyParameterPUid);
	keyParameters->AddL(aPrivateKey.Q(), KDsaKeyParameterQUid);
	keyParameters->AddL(aPrivateKey.G(), KDsaKeyParameterGUid);
	keyParameters->AddL(aPrivateKey.X(), KDsaKeyParameterXUid);
		
	CKey* newPrivateKey = CKey::NewL(keyProperty, *keyParameters);
	CleanupStack::PopAndDestroy(keyParameters);
	return newPrivateKey;
	}
	
CKey* KeyConverter::CreateKeyL(const CDSAPublicKey& aPublicKey)
	{
	TKeyProperty keyProperty = {KDsaSignerUid, KNullUid, KDsaPublicKeyUid, KNonEmbeddedKeyUid};

	CCryptoParams* keyParameters = CCryptoParams::NewLC();
	keyParameters->AddL(aPublicKey.P(), KDsaKeyParameterPUid);
	keyParameters->AddL(aPublicKey.Q(), KDsaKeyParameterQUid);
	keyParameters->AddL(aPublicKey.G(), KDsaKeyParameterGUid);
	keyParameters->AddL(aPublicKey.Y(), KDsaKeyParameterYUid);

	CKey* newPublicKey = CKey::NewL(keyProperty, *keyParameters);
	CleanupStack::PopAndDestroy(keyParameters);
	return newPublicKey;
	}

// RSA convertors ///////////////////////////////////////////////////////////////////////////
CKey* KeyConverter::CreateKeyL(const CRSAPrivateKeyCRT& aPrivateKey)
	{
	TKeyProperty keyProperty = {KRsaCipherUid,
		NULL,
		KRsaPrivateKeyCRTUid,
		KNonEmbeddedKeyUid };

	CCryptoParams* keyParameters = CCryptoParams::NewLC();
	keyParameters->AddL(aPrivateKey.N(), KRsaKeyParameterNUid);
	keyParameters->AddL(aPrivateKey.P(), KRsaKeyParameterPUid);
	keyParameters->AddL(aPrivateKey.Q(), KRsaKeyParameterQUid);
	keyParameters->AddL(aPrivateKey.QInv(), KRsaKeyParameterQInvUid);
	keyParameters->AddL(aPrivateKey.DP(), KRsaKeyParameterDPUid);
	keyParameters->AddL(aPrivateKey.DQ(), KRsaKeyParameterDQUid);
		
	CKey* newPrivateKey = CKey::NewL(keyProperty, *keyParameters);
	CleanupStack::PopAndDestroy(keyParameters);
	return newPrivateKey;
	}
	
CKey* KeyConverter::CreateKeyL(const CRSAPrivateKeyStandard& aPrivateKey)
	{
	TKeyProperty keyProperty = {KRsaCipherUid,
		NULL,
		KRsaPrivateKeyStandardUid,
		KNonEmbeddedKeyUid };

	CCryptoParams* keyParameters = CCryptoParams::NewLC();
	keyParameters->AddL(aPrivateKey.N(), KRsaKeyParameterNUid);
	keyParameters->AddL(aPrivateKey.D(), KRsaKeyParameterDUid);
		
	CKey* newPrivateKey = CKey::NewL(keyProperty, *keyParameters);
	CleanupStack::PopAndDestroy(keyParameters);
	return newPrivateKey;
	}
	
CKey* KeyConverter::CreateKeyL(const CRSAPublicKey& aPublicKey)
	{
	TKeyProperty keyProperty = {KRsaCipherUid,
		NULL,
		KRsaPublicKeyUid,
		KNonEmbeddedKeyUid };

	CCryptoParams* keyParameters = CCryptoParams::NewLC();	
	keyParameters->AddL(aPublicKey.N(), KRsaKeyParameterNUid);
	keyParameters->AddL(aPublicKey.E(), KRsaKeyParameterEUid);

	CKey* newPublicKey = CKey::NewL(keyProperty, *keyParameters);
	CleanupStack::PopAndDestroy(keyParameters);
	return newPublicKey;
	}

CKey* KeyConverter::CreateKeyL(const CRSAPrivateKey& aPrivateKey)
	{
	// Determine which type of private key
	if (aPrivateKey.PrivateKeyType() == EStandard)
		{
		const CRSAPrivateKeyStandard* stdKey = static_cast<const CRSAPrivateKeyStandard*>(&aPrivateKey);
		return KeyConverter::CreateKeyL(*stdKey);
		}
	else if (aPrivateKey.PrivateKeyType() == EStandardCRT)
		{
		const CRSAPrivateKeyCRT* crtKey = static_cast<const CRSAPrivateKeyCRT*>(&aPrivateKey);
		return KeyConverter::CreateKeyL(*crtKey);
		}
	return NULL;  // Keep the compiler happy
	}

// Methods which are not supported or not exposed out of library can be excluded from the coverage.
#ifdef _BullseyeCoverage
#pragma suppress_warnings on
#pragma BullseyeCoverage off
#pragma suppress_warnings off
#endif

CKeyPair* KeyConverter::CreateKeyPairL(const CDSAKeyPair& /*aKeyPair*/)
	{
	return NULL;	
	}

CKeyPair* KeyConverter::CreateKeyPairL(const CRSAKeyPair& aKeyPair)
	{
	CKey* newPrivateKey = KeyConverter::CreateKeyL(aKeyPair.PrivateKey());
	CleanupStack::PushL(newPrivateKey);
	CKey* newPublicKey = KeyConverter::CreateKeyL(aKeyPair.PublicKey());
	CleanupStack::PushL(newPublicKey);
	CKeyPair* newKeyPair = CKeyPair::NewL(newPublicKey, newPrivateKey);
	CleanupStack::Pop(2, newPrivateKey);
	return newKeyPair;
	}

CKeyPair* KeyConverter::CreateKeyPairL(const CDHKeyPair& aKeyPair)
	{
	CKey* newPrivateKey = KeyConverter::CreateKeyL(aKeyPair.PrivateKey());
	CleanupStack::PushL(newPrivateKey);
	CKey* newPublicKey = KeyConverter::CreateKeyL(aKeyPair.PublicKey());
	CleanupStack::PushL(newPublicKey);
	CKeyPair* newKeyPair = CKeyPair::NewL(newPublicKey, newPrivateKey);
	CleanupStack::Pop(2, newPrivateKey);
	return newKeyPair;
	}