os/security/crypto/weakcryptospi/source/padding/paddingshim.cpp
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
/*
sl@0
     2
* Copyright (c) 2006-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     3
* All rights reserved.
sl@0
     4
* This component and the accompanying materials are made available
sl@0
     5
* under the terms of the License "Eclipse Public License v1.0"
sl@0
     6
* which accompanies this distribution, and is available
sl@0
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     8
*
sl@0
     9
* Initial Contributors:
sl@0
    10
* Nokia Corporation - initial contribution.
sl@0
    11
*
sl@0
    12
* Contributors:
sl@0
    13
*
sl@0
    14
* Description: 
sl@0
    15
*
sl@0
    16
*/
sl@0
    17
sl@0
    18
sl@0
    19
#include "paddingshim.h"
sl@0
    20
#include <cryptospi/cryptospidef.h>
sl@0
    21
sl@0
    22
// CPaddingNoneShim
sl@0
    23
CPaddingNoneShim* CPaddingNoneShim::NewL(TInt aBlockBytes)
sl@0
    24
	{
sl@0
    25
	CPaddingNoneShim* self = CPaddingNoneShim::NewLC(aBlockBytes);
sl@0
    26
	CleanupStack::Pop(self);
sl@0
    27
	return self;
sl@0
    28
	}
sl@0
    29
CPaddingNoneShim* CPaddingNoneShim::NewLC(TInt aBlockBytes)
sl@0
    30
	{
sl@0
    31
	CPaddingNoneShim* self = new(ELeave) CPaddingNoneShim(aBlockBytes);
sl@0
    32
	CleanupStack::PushL(self);
sl@0
    33
	return self;
sl@0
    34
	}
sl@0
    35
	
sl@0
    36
TInt CPaddingNoneShim::Extension_(TUint aExtensionId, TAny*& a0, TAny* /*a1*/)
sl@0
    37
	{
sl@0
    38
	TInt err(KErrNone);
sl@0
    39
	if (aExtensionId == CryptoSpi::KPaddingInterface)
sl@0
    40
		{
sl@0
    41
		TUid* uid(static_cast<TUid*>(a0));
sl@0
    42
		*uid = CryptoSpi::KPaddingModeNoneUid;
sl@0
    43
		}
sl@0
    44
	else 
sl@0
    45
		{
sl@0
    46
		err = KErrExtensionNotSupported;
sl@0
    47
		}
sl@0
    48
	return err;
sl@0
    49
	}
sl@0
    50
sl@0
    51
CPaddingNoneShim::CPaddingNoneShim(TInt aBlockBytes) :
sl@0
    52
	CPaddingNone(aBlockBytes)
sl@0
    53
	{
sl@0
    54
	}
sl@0
    55
sl@0
    56
// CPaddingPKCS1SignatureShim
sl@0
    57
CPaddingPKCS1SignatureShim* CPaddingPKCS1SignatureShim::NewL(TInt aBlockBytes)
sl@0
    58
	{
sl@0
    59
	CPaddingPKCS1SignatureShim* self = CPaddingPKCS1SignatureShim::NewLC(aBlockBytes);
sl@0
    60
	CleanupStack::Pop(self);
sl@0
    61
	return self;
sl@0
    62
	}
sl@0
    63
CPaddingPKCS1SignatureShim* CPaddingPKCS1SignatureShim::NewLC(TInt aBlockBytes)
sl@0
    64
	{
sl@0
    65
	CPaddingPKCS1SignatureShim* self = new(ELeave) CPaddingPKCS1SignatureShim(aBlockBytes);
sl@0
    66
	CleanupStack::PushL(self);
sl@0
    67
	return self;
sl@0
    68
	}
sl@0
    69
	
sl@0
    70
TInt CPaddingPKCS1SignatureShim::Extension_(TUint aExtensionId, TAny*& a0, TAny* /*a1*/)
sl@0
    71
	{
sl@0
    72
	TInt err(KErrNone);
sl@0
    73
	if (aExtensionId == CryptoSpi::KPaddingInterface)
sl@0
    74
		{
sl@0
    75
		TUid* uid(static_cast<TUid*>(a0));
sl@0
    76
		*uid = CryptoSpi::KPaddingModePkcs1_v1_5_SignatureUid;
sl@0
    77
		}
sl@0
    78
	else 
sl@0
    79
		{
sl@0
    80
		err = KErrExtensionNotSupported;
sl@0
    81
		}
sl@0
    82
	return err;
sl@0
    83
	}
sl@0
    84
sl@0
    85
CPaddingPKCS1SignatureShim::CPaddingPKCS1SignatureShim(TInt aBlockBytes) :
sl@0
    86
	CPaddingPKCS1Signature(aBlockBytes)
sl@0
    87
	{
sl@0
    88
	}
sl@0
    89
	
sl@0
    90
// CPaddingPKCS1EncryptionShim
sl@0
    91
CPaddingPKCS1EncryptionShim* CPaddingPKCS1EncryptionShim::NewL(TInt aBlockBytes)
sl@0
    92
	{
sl@0
    93
	CPaddingPKCS1EncryptionShim* self = CPaddingPKCS1EncryptionShim::NewLC(aBlockBytes);
sl@0
    94
	CleanupStack::Pop(self);
sl@0
    95
	return self;
sl@0
    96
	}
sl@0
    97
CPaddingPKCS1EncryptionShim* CPaddingPKCS1EncryptionShim::NewLC(TInt aBlockBytes)
sl@0
    98
	{
sl@0
    99
	CPaddingPKCS1EncryptionShim* self = new(ELeave) CPaddingPKCS1EncryptionShim(aBlockBytes);
sl@0
   100
	CleanupStack::PushL(self);
sl@0
   101
	return self;
sl@0
   102
	}
sl@0
   103
	
sl@0
   104
TInt CPaddingPKCS1EncryptionShim::Extension_(TUint aExtensionId, TAny*& a0, TAny* /*a1*/)
sl@0
   105
	{
sl@0
   106
	TInt err(KErrNone);
sl@0
   107
	if (aExtensionId == CryptoSpi::KPaddingInterface)
sl@0
   108
		{
sl@0
   109
		TUid* uid(static_cast<TUid*>(a0));
sl@0
   110
		*uid = CryptoSpi::KPaddingModePkcs1_v1_5_EncryptionUid;
sl@0
   111
		}
sl@0
   112
	else 
sl@0
   113
		{
sl@0
   114
		err = KErrExtensionNotSupported;
sl@0
   115
		}
sl@0
   116
	return err;
sl@0
   117
	}
sl@0
   118
sl@0
   119
CPaddingPKCS1EncryptionShim::CPaddingPKCS1EncryptionShim(TInt aBlockBytes) :
sl@0
   120
	CPaddingPKCS1Encryption(aBlockBytes)
sl@0
   121
	{
sl@0
   122
	}
sl@0
   123
	
sl@0
   124
// CPaddingSSLv3Shim
sl@0
   125
CPaddingSSLv3Shim* CPaddingSSLv3Shim::NewL(TInt aBlockBytes)
sl@0
   126
	{
sl@0
   127
	CPaddingSSLv3Shim* self = CPaddingSSLv3Shim::NewLC(aBlockBytes);
sl@0
   128
	CleanupStack::Pop(self);
sl@0
   129
	return self;
sl@0
   130
	}
sl@0
   131
CPaddingSSLv3Shim* CPaddingSSLv3Shim::NewLC(TInt aBlockBytes)
sl@0
   132
	{
sl@0
   133
	CPaddingSSLv3Shim* self = new(ELeave) CPaddingSSLv3Shim(aBlockBytes);
sl@0
   134
	CleanupStack::PushL(self);
sl@0
   135
	return self;
sl@0
   136
	}
sl@0
   137
	
sl@0
   138
TInt CPaddingSSLv3Shim::Extension_(TUint aExtensionId, TAny*& a0, TAny* /*a1*/)
sl@0
   139
	{
sl@0
   140
	TInt err(KErrNone);
sl@0
   141
	if (aExtensionId == CryptoSpi::KPaddingInterface)
sl@0
   142
		{
sl@0
   143
		TUid* uid(static_cast<TUid*>(a0));
sl@0
   144
		*uid = CryptoSpi::KPaddingModeSSLv3Uid;
sl@0
   145
		}
sl@0
   146
	else 
sl@0
   147
		{
sl@0
   148
		err = KErrExtensionNotSupported;
sl@0
   149
		}
sl@0
   150
	return err;
sl@0
   151
	}
sl@0
   152
sl@0
   153
CPaddingSSLv3Shim::CPaddingSSLv3Shim(TInt aBlockBytes) :
sl@0
   154
	CPaddingSSLv3(aBlockBytes)
sl@0
   155
	{
sl@0
   156
	}	
sl@0
   157
	
sl@0
   158
// CPaddingPKCS7Shim
sl@0
   159
CPaddingPKCS7Shim* CPaddingPKCS7Shim::NewL(TInt aBlockBytes)
sl@0
   160
	{
sl@0
   161
	CPaddingPKCS7Shim* self = CPaddingPKCS7Shim::NewLC(aBlockBytes);
sl@0
   162
	CleanupStack::Pop(self);
sl@0
   163
	return self;
sl@0
   164
	}
sl@0
   165
CPaddingPKCS7Shim* CPaddingPKCS7Shim::NewLC(TInt aBlockBytes)
sl@0
   166
	{
sl@0
   167
	CPaddingPKCS7Shim* self = new(ELeave) CPaddingPKCS7Shim(aBlockBytes);
sl@0
   168
	CleanupStack::PushL(self);
sl@0
   169
	return self;
sl@0
   170
	}
sl@0
   171
	
sl@0
   172
TInt CPaddingPKCS7Shim::Extension_(TUint aExtensionId, TAny*& a0, TAny* /*a1*/)
sl@0
   173
	{
sl@0
   174
	TInt err(KErrNone);
sl@0
   175
	if (aExtensionId == CryptoSpi::KPaddingInterface)
sl@0
   176
		{
sl@0
   177
		TUid* uid(static_cast<TUid*>(a0));
sl@0
   178
		*uid = CryptoSpi::KPaddingModePKCS7Uid;
sl@0
   179
		}
sl@0
   180
	else 
sl@0
   181
		{
sl@0
   182
		err = KErrExtensionNotSupported;
sl@0
   183
		}
sl@0
   184
	return err;	
sl@0
   185
	}
sl@0
   186
sl@0
   187
CPaddingPKCS7Shim::CPaddingPKCS7Shim(TInt aBlockBytes) :
sl@0
   188
	CPaddingPKCS7(aBlockBytes)
sl@0
   189
	{
sl@0
   190
	}