| author | Shabe Razvi <shaber@symbian.org> | 
| Mon, 16 Nov 2009 14:42:37 +0000 | |
| branch | RCL_1 | 
| changeset 24 | c09e56b72f1c | 
| parent 0 | 2c201484c85f | 
| permissions | -rw-r--r-- | 
| 0 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 1 | /* | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 2 | * Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies). | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 3 | * All rights reserved. | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 4 | * This component and the accompanying materials are made available | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 5 | * under the terms of the License "Eclipse Public License v1.0" | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 6 | * which accompanies this distribution, and is available | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 7 | * at the URL "http://www.eclipse.org/legal/epl-v10.html". | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 8 | * | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 9 | * Initial Contributors: | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 10 | * Nokia Corporation - initial contribution. | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 11 | * | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 12 | * Contributors: | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 13 | * | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 14 | * Description: | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 15 | * | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 16 | */ | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 17 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 18 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 19 | #include <random.h> | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 20 | #include <padding.h> | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 21 | #include "tpaddingPKCS1.h" | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 22 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 23 | CTestPadPKCS1::CTestPadPKCS1() | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 24 | {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 25 | SetTestStepName(KPadPKCS1); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 26 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 27 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 28 | CTestPadPKCS1::~CTestPadPKCS1() | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 29 | {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 30 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 31 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 32 | TVerdict CTestPadPKCS1::doTestStepL() | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 33 | {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 34 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 35 | __UHEAP_MARK; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 36 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 37 |    INFO_PRINTF1(_L("Test of PKCS1 signature padding"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 38 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 39 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 40 |    INFO_PRINTF1(_L("Blocksize 512"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 41 | TestPKCS1SignaturePadding(512); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 42 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 43 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 44 |    INFO_PRINTF1(_L("Blocksize 1024"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 45 | TestPKCS1SignaturePadding(1024); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 46 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 47 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 48 |    INFO_PRINTF1(_L("Blocksize 2048"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 49 | TestPKCS1SignaturePadding(2048); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 50 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 51 |    INFO_PRINTF1(_L("Test of PKCS1 encryption padding"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 52 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 53 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 54 |    INFO_PRINTF1(_L("Blocksize 512"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 55 | TestPKCS1EncryptionPadding(512); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 56 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 57 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 58 |    INFO_PRINTF1(_L("Blocksize 1024"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 59 | TestPKCS1EncryptionPadding(1024); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 60 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 61 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 62 |    INFO_PRINTF1(_L("Blocksize 2048"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 63 | TestPKCS1EncryptionPadding(2048); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 64 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 65 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 66 | __UHEAP_MARKEND; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 67 | return TestStepResult(); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 68 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 69 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 70 | void CTestPadPKCS1::TestPKCS1SignaturePadding(TInt aBlockSize) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 71 | {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 72 | CPaddingPKCS1Signature *padding = CPaddingPKCS1Signature::NewLC(aBlockSize); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 73 | /* | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 74 | * The length of the data D shall not be more than k-11 octets, | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 75 | * which is positive since the length k of the modulus is at | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 76 | * least 12 octets. | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 77 | */ | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 78 | TInt noDataBytes = aBlockSize-11; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 79 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 80 | for (TInt i = 0; i <= noDataBytes; i++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 81 |    {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 82 | HBufC8 *inData = HBufC8::NewLC(noDataBytes); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 83 | HBufC8 *outData = HBufC8::NewLC(aBlockSize); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 84 | TPtr8 in(inData->Des()); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 85 | TPtr8 out(outData->Des()); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 86 | TInt j; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 87 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 88 | for (j = 0; j < i; j++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 89 |       {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 90 | 	 TInt text('a'+j%25);
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 91 | in.Append(text); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 92 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 93 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 94 | TRAPD(err, padding->DoPadL(in, out)); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 95 | TEST(err == KErrNone); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 96 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 97 | // check the padding. | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 98 | // should have the following syntax: | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 99 | // 00 || 01 || PS || 00 || D where PS is the padding octects of value 0xff | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 100 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 101 | TEST(out[0] == 0 && out[1] == 1); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 102 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 103 | TInt endOfPadding = aBlockSize - 1 - in.Length(); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 104 | for (j = 2; j < endOfPadding; j++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 105 |       {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 106 | TEST(out[j]==0xff); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 107 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 108 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 109 | // Check for the delimiter | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 110 | TEST(out[endOfPadding] == 0); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 111 | // Check that the rest of the data is not corrupted | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 112 | TInt startOfData = aBlockSize - in.Length(); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 113 | TEST(in == out.Mid(startOfData)); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 114 | CleanupStack::PopAndDestroy(2, inData); // inData, outData | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 115 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 116 |    TestStepResult() ? INFO_PRINTF1(_L("Test failed")) : INFO_PRINTF1(_L("Test passed"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 117 | CleanupStack::PopAndDestroy(); // padding | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 118 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 119 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 120 | void CTestPadPKCS1::TestPKCS1EncryptionPadding(TInt aBlockSize) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 121 | {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 122 | CPaddingPKCS1Encryption *padding = CPaddingPKCS1Encryption::NewLC(aBlockSize); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 123 | /* | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 124 | * The length of the data D shall not be more than k-11 octets, | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 125 | * which is positive since the length k of the modulus is at | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 126 | * least 12 octets. | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 127 | */ | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 128 | TInt noDataBytes = aBlockSize-11; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 129 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 130 | for (TInt i = 0; i <= noDataBytes; i++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 131 |    {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 132 | HBufC8 *inData = HBufC8::NewLC(noDataBytes); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 133 | HBufC8 *outData = HBufC8::NewLC(aBlockSize); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 134 | TPtr8 in(inData->Des()); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 135 | TPtr8 out(outData->Des()); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 136 | TInt j; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 137 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 138 | for (j = 0; j < i; j++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 139 |       {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 140 | 	 TInt text('a'+j%25);
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 141 | in.Append(text); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 142 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 143 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 144 | TRAPD(err, padding->DoPadL(in, out)); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 145 | TEST(err == KErrNone); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 146 | // check the padding. | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 147 | // should have the following syntax: | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 148 | // 00 || 02 || PS || 00 || D where PS is the padding octects containing random data | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 149 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 150 | TEST(out[0] == 0 && out[1] == 2); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 151 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 152 | TInt endOfPadding = aBlockSize - 1 - in.Length(); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 153 | for (j = 2; j < endOfPadding; j++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 154 |       {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 155 | TEST(out[j]!=0); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 156 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 157 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 158 | // Check for the delimiter | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 159 | TEST(out[endOfPadding] == 0); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 160 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 161 | // Check that the rest of the data is not corrupted | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 162 | TInt startOfData = aBlockSize - in.Length(); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 163 | TEST(in == out.Mid(startOfData)); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 164 | CleanupStack::PopAndDestroy(2, inData); // inData, outData | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 165 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 166 |    TestStepResult() ? INFO_PRINTF1(_L("Test failed")) : INFO_PRINTF1(_L("Test passed"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 167 | CleanupStack::PopAndDestroy(); // padding | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 168 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 169 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 170 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 171 | CTestUnpadPKCS1::CTestUnpadPKCS1() | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 172 | {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 173 | SetTestStepName(KUnpadPKCS1); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 174 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 175 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 176 | CTestUnpadPKCS1::~CTestUnpadPKCS1() | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 177 | {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 178 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 179 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 180 | TVerdict CTestUnpadPKCS1::doTestStepL() | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 181 | {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 182 | __UHEAP_MARK; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 183 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 184 |    INFO_PRINTF1(_L("Test of PKCS1 signature unpadding"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 185 |    INFO_PRINTF1(_L("Blocksize 512"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 186 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 187 | TestPKCS1SignatureUnpadding(512); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 188 |    INFO_PRINTF1(_L("Blocksize 1024"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 189 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 190 | TestPKCS1SignatureUnpadding(1024); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 191 |    INFO_PRINTF1(_L("Blocksize 2048"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 192 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 193 | TestPKCS1SignatureUnpadding(2048); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 194 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 195 |    INFO_PRINTF1(_L("Test of PKCS1 encryption unpadding"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 196 |    INFO_PRINTF1(_L("Blocksize 512"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 197 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 198 | TestPKCS1EncryptionUnpadding(512); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 199 |    INFO_PRINTF1(_L("Blocksize 1024"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 200 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 201 | TestPKCS1EncryptionUnpadding(1024); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 202 |    INFO_PRINTF1(_L("Blocksize 2048"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 203 | SetTestStepResult(EPass); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 204 | TestPKCS1EncryptionUnpadding(2048); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 205 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 206 | __UHEAP_MARKEND; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 207 | return TestStepResult(); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 208 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 209 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 210 | void CTestUnpadPKCS1::TestPKCS1SignatureUnpadding(TInt aBlockSize) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 211 | {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 212 | CPaddingPKCS1Signature *padding = CPaddingPKCS1Signature::NewLC(aBlockSize); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 213 | /* | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 214 | * The length of the data D shall not be more than k-11 octets, | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 215 | * which is positive since the length k of the modulus is at | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 216 | * least 12 octets. | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 217 | */ | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 218 | TInt noDataBytes = aBlockSize-11; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 219 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 220 | for (TInt i = 0; i <= noDataBytes; i++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 221 |    {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 222 | HBufC8 *inData = HBufC8::NewLC(aBlockSize); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 223 | HBufC8 *outData = HBufC8::NewLC(noDataBytes); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 224 | HBufC8 *compData = HBufC8::NewLC(noDataBytes); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 225 | TPtr8 in(inData->Des()); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 226 | TPtr8 out(outData->Des()); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 227 | TPtr8 comp(compData->Des()); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 228 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 229 | TInt endOfPadding = aBlockSize - 1 - i; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 230 | in.SetLength(endOfPadding+1); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 231 | in[0] = 0; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 232 | in[1] = 1; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 233 | TInt j; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 234 | for (j = 2; j < endOfPadding; j++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 235 |       {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 236 | in[j] = 0xff; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 237 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 238 | in[endOfPadding] = 0; // delimiter | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 239 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 240 | for (j = 0; j < i; j++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 241 |       {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 242 | 	 TInt text('a'+j%25);
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 243 | in.Append(text); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 244 | comp.Append(text); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 245 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 246 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 247 | TRAPD(err, padding->UnPadL(in, out)); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 248 | TEST(err == KErrNone); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 249 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 250 | TEST(out == comp); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 251 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 252 | TEST(out.Length() == i); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 253 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 254 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 255 | CleanupStack::PopAndDestroy(3, inData); // inData, outData, compData | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 256 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 257 |    TestStepResult() ? INFO_PRINTF1(_L("Test failed")) : INFO_PRINTF1(_L("Test passed"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 258 | CleanupStack::PopAndDestroy(); // padding | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 259 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 260 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 261 | void CTestUnpadPKCS1::TestPKCS1EncryptionUnpadding(TInt aBlockSize) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 262 | {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 263 | CPaddingPKCS1Encryption *padding = CPaddingPKCS1Encryption::NewLC(aBlockSize); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 264 | /* | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 265 | * "The length of the data D shall not be more than k-11 octets, | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 266 | * which is positive since the length k of the modulus is at | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 267 | * least 12 octets." | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 268 | */ | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 269 | TInt noDataBytes = aBlockSize-11; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 270 | for (TInt i = 0; i <= noDataBytes; i++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 271 |    {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 272 | HBufC8 *inData = HBufC8::NewLC(aBlockSize); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 273 | HBufC8 *outData = HBufC8::NewLC(noDataBytes); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 274 | HBufC8 *compData = HBufC8::NewLC(noDataBytes); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 275 | TPtr8 in(inData->Des()); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 276 | TPtr8 out(outData->Des()); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 277 | TPtr8 comp(compData->Des()); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 278 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 279 | TInt endOfPadding = aBlockSize - 1 - i; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 280 | in.SetLength(endOfPadding+1); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 281 | in[0] = 0; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 282 | in[1] = 2; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 283 | TBuf8<256> rnd(256); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 284 | GenerateRandomBytesL(rnd); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 285 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 286 | TInt k = 2; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 287 | TInt j = 0; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 288 | while (k < endOfPadding) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 289 |       {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 290 | if (rnd[j%256]) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 291 |          {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 292 | in[k++] = rnd[j%256]; | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 293 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 294 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 295 | if (++j%256 == 0) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 296 |          {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 297 | GenerateRandomBytesL(rnd); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 298 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 299 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 300 | in[endOfPadding] = 0; // delimiter | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 301 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 302 | for (j = 0; j < i; j++) | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 303 |       {
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 304 | 	 TInt text('a'+j%25);
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 305 | in.Append(text); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 306 | comp.Append(text); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 307 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 308 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 309 | TRAPD(err, padding->UnPadL(in, out)); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 310 | TEST(err == KErrNone); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 311 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 312 | TEST(out == comp); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 313 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 314 | TEST(out.Length() == i); | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 315 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 316 | |
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 317 | CleanupStack::PopAndDestroy(3, inData); // inData, outData, compData | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 318 | } | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 319 |    TestStepResult() ? INFO_PRINTF1(_L("Test failed")) : INFO_PRINTF1(_L("Test passed"));
 | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 320 | CleanupStack::PopAndDestroy(); // padding | 
| 
2c201484c85f
Move the Security package to EPL, and add the implementations of the cryptographic algorithms
 Santosh Patil <santosh.v.patil@nokia.com> parents: diff
changeset | 321 | } |