cryptoservices/certificateandkeymgmt/inc/pkcs7excert.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 15 Sep 2010 00:37:27 +0300
branchRCL_3
changeset 63 94225563cd41
parent 8 35751d3474b7
permissions -rw-r--r--
Revision: 201035 Kit: 201035

/*
* Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description: 
*
*/


/**
 @file
 @internalTechnology
 @released
*/


#ifndef __PKCS7_EXTENDED_CERTIFICATE_OR_CERTIFICATE_H__
#define __PKCS7_EXTENDED_CERTIFICATE_OR_CERTIFICATE_H__

#include <e32base.h>

class CX509Certificate;
class CASN1EncEncoding;


/**
An instance of a member of the RFC2315 ExtendedCertificatesAndCertificates.
At present, only X509 certificates are supported.
(not PKCS#6 extended certificates).
@internalTechnology
*/
class CPKCS7ExtendedCertificateOrCertificate : public CBase
	{
public:
	/**
	Creates an ExtendedCertificatesAndCertificates as defined in RFC2315.
	@param aRawData The encoded CertificateChoices object to be decoded.
	@return The fully constructed object.
	*/			
	static CPKCS7ExtendedCertificateOrCertificate* NewL(const TDesC8& aRawData);
	
	/**
	Destructor
	*/
	~CPKCS7ExtendedCertificateOrCertificate();
		
	/**
	Returns the x509 certificate reference if the certificate is a X509 certificate.
	Callers need to check whether the certificate's type is X509 beforehand.
	@return The x509 certificate reference.
	*/
	IMPORT_C const CX509Certificate& Certificate(void) const;

private:
	/**
	Default Constructor
	*/
	CPKCS7ExtendedCertificateOrCertificate();
	
	/**
	Copy Constructor
	@param the source object to be copied
	*/	
	CPKCS7ExtendedCertificateOrCertificate(const CPKCS7ExtendedCertificateOrCertificate&);
	
	/**
	Second phase constructor for decoding.
	@param aRawData the raw data to be decoded.
	*/
	void ConstructL(const TDesC8& aRawData);
	
private:	
	/**
	The X509 certificate pointer
	*/
	CX509Certificate* iCertificate;
	};


	
#endif