crypto/weakcryptospi/test/tsymmetric/cryptotestaction.cpp
changeset 8 35751d3474b7
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/crypto/weakcryptospi/test/tsymmetric/cryptotestaction.cpp	Thu Sep 10 14:01:51 2009 +0300
@@ -0,0 +1,275 @@
+/*
+* Copyright (c) 1998-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 "cryptotestaction.h"
+#include <securityerr.h>
+#include <cryptostrength.h>
+#include "../common/inlines.h"
+#include "t_output.h"
+
+CCryptoTestAction::CCryptoTestAction(RFs& aFs, CConsoleBase& aConsole, Output& aOut)
+:	CTestAction(aConsole, aOut), iFs(aFs), iEffectiveKeyLen(128)
+{}
+
+CCryptoTestAction::~CCryptoTestAction()
+{
+	delete iBody;
+}
+
+void CCryptoTestAction::ConstructL(const TTestActionSpec& aTestActionSpec)
+{
+	CTestAction::ConstructL(aTestActionSpec);
+	iBody = HBufC8::NewL(aTestActionSpec.iActionBody.Length());
+	iBody->Des().Copy(aTestActionSpec.iActionBody);	
+}
+
+void CCryptoTestAction::DoPerformPrerequisite(TRequestStatus& aStatus)
+{
+	TRequestStatus* status = &aStatus;
+	
+	TRAPD(r, DoPerformPrerequisiteL());
+	if ((r != iExpectedWeakResult) && (TCrypto::Strength() == TCrypto::EWeak))
+		{
+		r = KErrUnknown;
+		}
+	User::RequestComplete(status, r);
+	if (KErrNone==r)
+		{
+		iActionState = CTestAction::EAction;
+		}
+	else if (r==KErrKeyNotWeakEnough)
+		{
+		iResult = ETrue;
+		iConsole.Printf(_L("Crypto libraries returned KErrKeyNotWeakEnough!  Passing test automatically.\n\r"));
+		iOut.writeString(_L("Crypto libraries returned KErrKeyNotWeakEnough!  Passing test automatically.\r\n"));
+		iActionState = CTestAction::EPostrequisite;
+		}
+	else if (r==KErrWeakKey)
+ 		{
+ 		iResult = ETrue;
+ 		iConsole.Printf(_L("Crypto libraries returned KErrWeakKey!  Passing test automatically.\n\r"));
+ 		iOut.writeString(_L("Crypto libraries returned KErrWeakKey!  Passing test automatically.\r\n"));
+ 		iActionState = CTestAction::EPostrequisite;
+ 		}
+	else
+		{
+		iActionState = CTestAction::EPostrequisite;
+		}
+}
+
+void CCryptoTestAction::DoPerformPostrequisite(TRequestStatus& aStatus)
+{
+	TRequestStatus* status = &aStatus;
+	TRAPD(r, DoPerformPostrequisiteL());
+	delete iKey;
+	delete iInput;
+	delete iOutput;
+	delete iIV;
+	delete iEResult;
+	delete iDResult;
+
+	iFinished = ETrue;
+	User::RequestComplete(status, r);
+}
+
+void CCryptoTestAction::DoReportAction(void)
+{}
+
+void CCryptoTestAction::DoCheckResult(TInt)
+{
+	if (iResult==EFalse)
+		iConsole.Printf(_L("X"));
+	else
+		iConsole.Printf(_L("."));
+}
+
+void CCryptoTestAction::PerformAction(TRequestStatus& aStatus)
+{
+	TRequestStatus* status = &aStatus;
+
+	TRAPD(res, DoPerformActionL());
+	if (res==KErrNoMemory)
+		{
+		User::Leave(res);	//	For OOM testing
+		}
+	iActionState = CTestAction::EPostrequisite;
+	User::RequestComplete(status, res);
+}
+
+
+void CCryptoTestAction::DoInputParseL(TDesC8& aScriptBuffer)
+{
+	TInt err = KErrNone;
+	TInt pos = 0;
+
+	TPtrC8 keyTemp = Input::ParseElement(aScriptBuffer, KKeyStart, KKeyEnd, pos=0, err);
+	iKey = HBufC8::NewL(keyTemp.Length());
+	*iKey = keyTemp;
+	Hex(*iKey);
+
+	TPtrC8 inputTemp = Input::ParseElement(aScriptBuffer, KInputStart, KInputEnd, pos=0, err);
+	iInput = HBufC8::NewL(inputTemp.Length());
+	*iInput = inputTemp;
+	Hex(*iInput);
+
+	TPtrC8 ivTemp = Input::ParseElement(aScriptBuffer, KIVStart, KIVEnd, pos=0, err);
+	iIV = HBufC8::NewL(ivTemp.Length());
+	*iIV = ivTemp;
+	Hex(*iIV);
+
+	TPtrC8 outputTemp = Input::ParseElement(aScriptBuffer, KOutputStart, KOutputEnd, pos=0, err);
+	iOutput = HBufC8::NewL(outputTemp.Length());
+	*iOutput = outputTemp;
+	Hex(*iOutput);
+
+	TPtrC8 cipherType = Input::ParseElement(aScriptBuffer, KCipherTypeStart, KCipherTypeEnd, pos=0, err);
+	iExpectedWeakResult = KErrNone;
+	if( cipherType == _L8("DESECB") )
+	{
+		iCipherType = EDESECB;
+	}
+	else if( cipherType == _L8("DESCBC") )
+	{
+		iCipherType = EDESCBC;
+	}
+	else if( cipherType == _L8("3DESECB") )
+	{
+		iCipherType = E3DESECB;
+		iExpectedWeakResult = KErrKeyNotWeakEnough;
+	}
+	else if( cipherType == _L8("3DESCBC") )
+	{
+		iCipherType = E3DESCBC;
+		iExpectedWeakResult = KErrKeyNotWeakEnough;
+	}
+	else if( cipherType == _L8("AESECB") )
+	{
+		iCipherType = EAESECB;
+		iExpectedWeakResult = KErrKeyNotWeakEnough;
+	}
+	else if (cipherType==_L8("AESENC_ECB") )
+	{
+		iCipherType = EAESMonteCarloEncryptECB;	
+		iExpectedWeakResult = KErrKeyNotWeakEnough;
+	}
+	else if (cipherType==_L8("AESDEC_ECB") )
+	{
+		iCipherType = EAESMonteCarloDecryptECB;	
+		iExpectedWeakResult = KErrKeyNotWeakEnough;
+	}
+	else if (cipherType==_L8("AESENC_CBC") )
+	{
+		iCipherType = EAESMonteCarloEncryptCBC;	
+		iExpectedWeakResult = KErrKeyNotWeakEnough;
+	}
+	else if (cipherType==_L8("AESDEC_CBC") )
+	{
+		iCipherType = EAESMonteCarloDecryptCBC;		
+		iExpectedWeakResult = KErrKeyNotWeakEnough;
+	}
+	else if( cipherType == _L8("RC2ECB") )
+	{
+		iCipherType = ERC2ECB;
+		// weak enough if either aKey or aEffectiveKeyLen is weak
+		TInt minKeySize = Min(iEffectiveKeyLen, BytesToBits(iKey->Size()));
+		TRAP(iExpectedWeakResult, TCrypto::IsSymmetricWeakEnoughL(minKeySize));
+	}
+	else if( cipherType == _L8("RC2CBC") )
+	{
+		iCipherType = ERC2CBC;
+		// weak enough if either aKey or aEffectiveKeyLen is weak
+		TInt minKeySize = Min(iEffectiveKeyLen, BytesToBits(iKey->Size()));
+		TRAP(iExpectedWeakResult, TCrypto::IsSymmetricWeakEnoughL(minKeySize));
+	}
+	else if( cipherType == _L8("RC4") )
+	{
+		iCipherType = ERC4;
+		TRAP(iExpectedWeakResult, TCrypto::IsSymmetricWeakEnoughL(BytesToBits(iKey->Size())));
+	}
+	else if( cipherType == _L8("NULL") )
+	{
+		iCipherType = ECipherNull;
+	}
+ 	else if( cipherType == _L8("DESECB_WKT"))
+ 	{
+ 		iCipherType = EDESECB;	
+ 		iExpectedWeakResult = KErrWeakKey;
+ 	}
+ 	else if( cipherType == _L8("DESCBC_WKT"))
+ 	{
+ 		iCipherType = EDESCBC;	
+ 		iExpectedWeakResult = KErrWeakKey;
+ 	}
+	else 
+	{
+		TBuf<64> cipherName(0);
+		cipherName.Copy(cipherType);
+		TBuf<256> formattable;
+		formattable.Format(_L("\nBad Cipher Type: %S"), &cipherName);
+		iConsole.Printf(formattable);
+
+		iActionState = CTestAction::EPostrequisite;
+		User::Leave(KErrNotSupported);
+	}
+
+	if ( (iCipherType==ERC2ECB) || (iCipherType==ERC2CBC) )
+	{
+		TPtrC8 effKeyLenTemp = Input::ParseElement(aScriptBuffer, KEffKeyLenStart, KEffKeyLenEnd, pos=0, err);
+
+		if (effKeyLenTemp.Length() != 0)
+		{
+			TLex8 lex;
+			lex.Assign(effKeyLenTemp);
+			User::LeaveIfError(lex.Val(iEffectiveKeyLen));
+		}
+	}
+
+	TPtrC8 iterationsTemp = Input::ParseElement(aScriptBuffer, KIterationsStart, KIterationsEnd, pos=0, err);	
+	TLex8 lex;
+	lex.Assign(iterationsTemp);
+	err = lex.Val(iIterationTime);
+
+	TPtrC8 randTemp = Input::ParseElement(aScriptBuffer, KRandDataSizeStart, KRandDataSizeEnd, pos=0, err);	
+	TLex8 randlex;
+	randlex.Assign(randTemp);
+	err = randlex.Val(iRandDataSize);	
+
+	delete iBody;
+	iBody = NULL;
+}
+
+void CCryptoTestAction::Hex(HBufC8& aString)
+    {
+    TPtr8 ptr=aString.Des();
+    if (aString.Length()%2)
+        {
+        ptr.SetLength(0);
+        return;
+        }
+    TInt i;
+    for (i=0;i<aString.Length();i+=2)
+        {
+        TUint8 tmp;
+        tmp=(TUint8)(aString[i]-(aString[i]>'9'?('A'-10):'0'));
+        tmp*=16;
+        tmp|=(TUint8)(aString[i+1]-(aString[i+1]>'9'?('A'-10):'0'));
+        ptr[i/2]=tmp;
+        }
+    ptr.SetLength(aString.Length()/2);
+    }
+