crypto/weakcrypto/test/tasymmetric/tdsasignfb.cpp
author hgs
Thu, 24 Jun 2010 15:39:07 +0530
changeset 72 de46a57f75fb
permissions -rw-r--r--
201023_02
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) 1998-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 "tdsasignfb.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    20
#include "t_input.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    21
#include "t_output.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    22
#include <asymmetric.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    23
#include <random.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    24
#include <padding.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    25
#include <bigint.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    26
#include "tbrokenrandom.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    27
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    28
CTestAction* CDSASignFB::NewL(RFs& aFs, CConsoleBase& aConsole, Output& aOut, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    29
	const TTestActionSpec& aTestActionSpec)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    30
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    31
	CTestAction* self = CDSASignFB::NewLC(aFs, aConsole,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    32
		aOut, aTestActionSpec);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    33
	CleanupStack::Pop();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    34
	return self;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    35
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    36
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    37
CTestAction* CDSASignFB::NewLC(RFs& aFs, CConsoleBase& aConsole, Output& aOut, 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    38
	const TTestActionSpec& aTestActionSpec)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    39
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    40
	CDSASignFB* self = new(ELeave) CDSASignFB(aFs, aConsole, aOut);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    41
	CleanupStack::PushL(self);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    42
	self->ConstructL(aTestActionSpec);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    43
	return self;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    44
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    45
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    46
CDSASignFB::~CDSASignFB()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    47
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    48
	delete iBody;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    49
	delete iSeed;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    50
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    51
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    52
CDSASignFB::CDSASignFB(RFs& aFs, CConsoleBase& aConsole, Output& aOut)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    53
	: CTestAction(aConsole, aOut), iFs(aFs)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    54
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    55
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    56
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    57
void CDSASignFB::ConstructL(const TTestActionSpec& aTestActionSpec)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    58
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    59
	CTestAction::ConstructL(aTestActionSpec);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    60
	iBody = HBufC8::NewL(aTestActionSpec.iActionBody.Length());
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    61
	iBody->Des().Copy(aTestActionSpec.iActionBody);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    62
	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    63
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    64
	iSeed = Input::ParseElementHexL(*iBody, _L8("<seed>"));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    65
	iKeyBits = Input::ParseIntElement(*iBody, _L8("<keybits>"), _L8("</keybits>"));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    66
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    67
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    68
void CDSASignFB::DoPerformPrerequisite(TRequestStatus& aStatus)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    69
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    70
	TRequestStatus* status = &aStatus;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    71
	User::RequestComplete(status, KErrNone);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    72
	iActionState = CTestAction::EAction;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    73
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    74
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    75
void CDSASignFB::DoPerformPostrequisite(TRequestStatus& aStatus)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    76
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    77
	TRequestStatus* status = &aStatus;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    78
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    79
	iFinished = ETrue;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    80
	User::RequestComplete(status, KErrNone);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    81
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    82
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    83
void CDSASignFB::DoReportAction(void)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    84
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    85
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    86
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    87
void CDSASignFB::DoCheckResult(TInt)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    88
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    89
	if (iResult)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    90
		iConsole.Printf(_L("."));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    91
	else
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    92
		iConsole.Printf(_L("X"));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    93
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    94
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    95
void CDSASignFB::PerformAction(TRequestStatus& aStatus)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    96
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    97
	__UHEAP_MARK;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    98
	TRequestStatus* status = &aStatus;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    99
	iResult = EFalse;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   100
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   101
	CRandomSetSource* rng = new(ELeave)CRandomSetSource(*iSeed);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   102
	SetThreadRandomLC(rng);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   103
	CDSAKeyPair* dsaPair = CDSAKeyPair::NewLC(iKeyBits);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   104
	CDSASigner* signer = CDSASigner::NewLC(dsaPair->PrivateKey());
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   105
	CDSAVerifier* verifier = CDSAVerifier::NewLC(dsaPair->PublicKey());
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   106
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   107
	TBuf8<128> message(128);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   108
	TRandom::RandomL(message);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   109
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   110
	const CDSASignature* signature = signer->SignL(message);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   111
	CleanupStack::PushL(const_cast<CDSASignature*>(signature));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   112
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   113
	if(verifier->VerifyL(message, *signature))
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   114
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   115
		iResult = ETrue;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   116
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   117
	else
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   118
		{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   119
		iOut.writeString(_L("Failure in dsasignfb with following data:\n"));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   120
		iOut.writeString(_L("input data: "));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   121
		iOut.writeOctetStringL(message);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   122
		iOut.writeString(_L("\n"));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   123
		iOut.writeString(_L("seed: "));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   124
		iOut.writeOctetStringL(*iSeed);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   125
		iOut.writeString(_L("\n"));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   126
		}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   127
	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   128
	CleanupStack::PopAndDestroy(const_cast<CDSASignature*>(signature));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   129
	CleanupStack::PopAndDestroy(verifier);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   130
	CleanupStack::PopAndDestroy(signer);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   131
	CleanupStack::PopAndDestroy(dsaPair);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   132
	CleanupStack::PopAndDestroy(); //SetThreadRandomLC
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   133
	
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   134
	User::RequestComplete(status, KErrNone);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   135
	iActionState = CTestAction::EPostrequisite;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   136
	__UHEAP_MARKEND;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   137
	}
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   138
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   139
void CDSASignFB::Hex(HBufC8& aString)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   140
    {
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   141
    TPtr8 ptr=aString.Des();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   142
    if (aString.Length()%2)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   143
        {
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   144
        ptr.SetLength(0);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   145
        return;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   146
        }
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   147
    TInt i;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   148
    for (i=0;i<aString.Length();i+=2)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   149
        {
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   150
        TUint8 tmp;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   151
        tmp=(TUint8)(aString[i]-(aString[i]>'9'?('A'-10):'0'));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   152
        tmp*=16;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   153
        tmp|=(TUint8)(aString[i+1]-(aString[i+1]>'9'?('A'-10):'0'));
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   154
        ptr[i/2]=tmp;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   155
        }
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   156
    ptr.SetLength(aString.Length()/2);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   157
    }
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   158