os/security/cryptoservices/certificateandkeymgmt/pkcs7/pkcs7digestinfo.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) 2005-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 "pkcs7digestinfo.h"
sl@0
    20
#include "pkcs7asn1.h"
sl@0
    21
sl@0
    22
EXPORT_C CPKCS7DigestInfo* CPKCS7DigestInfo::NewL(const TDesC8& aRawData)
sl@0
    23
	{
sl@0
    24
	CPKCS7DigestInfo* self = new (ELeave) CPKCS7DigestInfo();
sl@0
    25
	CleanupStack::PushL(self);
sl@0
    26
	self->ConstructL(aRawData);
sl@0
    27
	CleanupStack::Pop(self);
sl@0
    28
	return self;	
sl@0
    29
	}
sl@0
    30
	
sl@0
    31
CPKCS7DigestInfo::~CPKCS7DigestInfo()
sl@0
    32
	{
sl@0
    33
    }
sl@0
    34
sl@0
    35
CPKCS7DigestInfo::CPKCS7DigestInfo()
sl@0
    36
	{
sl@0
    37
	}
sl@0
    38
	
sl@0
    39
EXPORT_C const TDesC8& CPKCS7DigestInfo::Digest() const
sl@0
    40
	{
sl@0
    41
	return iDigest;
sl@0
    42
	}
sl@0
    43
sl@0
    44
EXPORT_C TAlgorithmId CPKCS7DigestInfo::Algorithm() const
sl@0
    45
	{
sl@0
    46
	return iAlgorithmId;
sl@0
    47
	}
sl@0
    48
sl@0
    49
EXPORT_C const TPtrC8& CPKCS7DigestInfo::EncodedParams() const
sl@0
    50
	{
sl@0
    51
	return iEncodedParams;
sl@0
    52
	}
sl@0
    53
	
sl@0
    54
void CPKCS7DigestInfo::ConstructL(const TDesC8& aDigestData)
sl@0
    55
	{
sl@0
    56
    CArrayPtr<TASN1DecGeneric>* digestInfo = PKCS7ASN1::DecodeSequenceLC(aDigestData);
sl@0
    57
sl@0
    58
	// Check if both the digestAlgorithm and the Digest are present.
sl@0
    59
	if ( digestInfo->Count() != 2 )
sl@0
    60
		{
sl@0
    61
	    User::Leave(KErrArgument);
sl@0
    62
		}
sl@0
    63
sl@0
    64
	// DIGEST ALGORITHM
sl@0
    65
	// Get the algorithm identifier and the encoded parameters present in the sequence.
sl@0
    66
	const TASN1DecGeneric* digestInfoAt0 = digestInfo->At(0);
sl@0
    67
	if(digestInfoAt0->Tag() != EASN1Sequence || digestInfoAt0->Class() != EUniversal)
sl@0
    68
		{
sl@0
    69
		User::Leave(KErrArgument);
sl@0
    70
		}
sl@0
    71
	CX509AlgorithmIdentifier* digestAlg = CX509AlgorithmIdentifier::NewLC(digestInfo->At(0)->Encoding());
sl@0
    72
	TAlgorithmId algorithmId = digestAlg->Algorithm();
sl@0
    73
	switch(algorithmId)
sl@0
    74
		{
sl@0
    75
		case EMD2:
sl@0
    76
			{
sl@0
    77
			iAlgorithmId = EMD2;
sl@0
    78
			}
sl@0
    79
			break;
sl@0
    80
		case EMD5:
sl@0
    81
			{
sl@0
    82
			iAlgorithmId = EMD5;
sl@0
    83
			}
sl@0
    84
			break;
sl@0
    85
		case ESHA1:
sl@0
    86
			{
sl@0
    87
			iAlgorithmId = ESHA1;	
sl@0
    88
			}
sl@0
    89
			break;
sl@0
    90
		default:
sl@0
    91
			User::Leave(KErrNotSupported);
sl@0
    92
		}
sl@0
    93
	
sl@0
    94
	iEncodedParams.Set(digestAlg->EncodedParams()); 
sl@0
    95
		
sl@0
    96
	// DIGEST  
sl@0
    97
	const TASN1DecGeneric* digestInfoAt1 = digestInfo->At(1);
sl@0
    98
	if(digestInfoAt1->Tag() != EASN1OctetString || digestInfoAt1->Class() != EUniversal)
sl@0
    99
		{
sl@0
   100
		User::Leave(KErrArgument);
sl@0
   101
		}
sl@0
   102
	TASN1DecGeneric octetStringDecoder(*(digestInfo->At(1)));
sl@0
   103
	octetStringDecoder.InitL();
sl@0
   104
	iDigest.Set(octetStringDecoder.GetContentDER());
sl@0
   105
	
sl@0
   106
	CleanupStack::PopAndDestroy(2,digestInfo);// digestInfo, digestAlg
sl@0
   107
    }