os/security/crypto/weakcryptospi/inc/pkcs12kdf.h
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
/*
sl@0
     2
* Copyright (c) 2002-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
/**
sl@0
    20
 @file
sl@0
    21
 @publishedPartner
sl@0
    22
 @released
sl@0
    23
*/
sl@0
    24
sl@0
    25
sl@0
    26
#ifndef __PKCS12KDF_H__
sl@0
    27
#define __PKCS12KDF_H__
sl@0
    28
sl@0
    29
#include <e32std.h>
sl@0
    30
sl@0
    31
class PKCS12KDF
sl@0
    32
/**
sl@0
    33
	Namespace class contains static functions which
sl@0
    34
	are used to generate a key for PKCS#12 operations.
sl@0
    35
	
sl@0
    36
	See Section B from PKCS 12 v1.0.
sl@0
    37
 */
sl@0
    38
	{
sl@0
    39
public:
sl@0
    40
	enum TIDByteType
sl@0
    41
	/**
sl@0
    42
		ID byte value used to generate (en|de)cryption key,
sl@0
    43
		IV, or MAC key.  See SB.3 of spec.
sl@0
    44
	 */
sl@0
    45
		{
sl@0
    46
		/** Generates a key for (en|de)cryption. */
sl@0
    47
		EIDByteEncryptKey = 1,
sl@0
    48
		/** Generates an initialization vector. */
sl@0
    49
		EIDByteIV = 2,
sl@0
    50
		/** Generates a key for MAC-ing. */
sl@0
    51
		EIDByteMACKey = 3
sl@0
    52
		};
sl@0
    53
public:
sl@0
    54
	IMPORT_C static void DeriveKeyL(
sl@0
    55
		TDes8& aKey, TIDByteType aIDType,
sl@0
    56
		const TDesC8& aPasswd, const TDesC8& aSalt, const TUint aIterations);
sl@0
    57
	IMPORT_C static HBufC8* GeneratePasswordLC(const TDesC& aDes);
sl@0
    58
sl@0
    59
private:
sl@0
    60
	static void Process6cL(TDes8& Ij, const TDesC8& B, TInt v);
sl@0
    61
sl@0
    62
#ifdef _DEBUG
sl@0
    63
	enum TPanic
sl@0
    64
		{
sl@0
    65
		EDKEmptyPswd = 0x10, EDKOddPswdByteCount, EDKBadNullTerminator
sl@0
    66
		};
sl@0
    67
	static void Panic(TPanic aPanic);
sl@0
    68
#endif
sl@0
    69
sl@0
    70
	// not implemented - prevents instantiation
sl@0
    71
	PKCS12KDF();
sl@0
    72
	};
sl@0
    73
sl@0
    74
#endif	// #ifndef __PKCS12KDF_H__
sl@0
    75