os/security/cryptoservices/certificateandkeymgmt/inc/pkcs7excert.h
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) 2003-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
 @internalTechnology
sl@0
    22
 @released
sl@0
    23
*/
sl@0
    24
sl@0
    25
sl@0
    26
#ifndef __PKCS7_EXTENDED_CERTIFICATE_OR_CERTIFICATE_H__
sl@0
    27
#define __PKCS7_EXTENDED_CERTIFICATE_OR_CERTIFICATE_H__
sl@0
    28
sl@0
    29
#include <e32base.h>
sl@0
    30
sl@0
    31
class CX509Certificate;
sl@0
    32
class CASN1EncEncoding;
sl@0
    33
sl@0
    34
sl@0
    35
/**
sl@0
    36
An instance of a member of the RFC2315 ExtendedCertificatesAndCertificates.
sl@0
    37
At present, only X509 certificates are supported.
sl@0
    38
(not PKCS#6 extended certificates).
sl@0
    39
@internalTechnology
sl@0
    40
*/
sl@0
    41
class CPKCS7ExtendedCertificateOrCertificate : public CBase
sl@0
    42
	{
sl@0
    43
public:
sl@0
    44
	/**
sl@0
    45
	Creates an ExtendedCertificatesAndCertificates as defined in RFC2315.
sl@0
    46
	@param aRawData The encoded CertificateChoices object to be decoded.
sl@0
    47
	@return The fully constructed object.
sl@0
    48
	*/			
sl@0
    49
	static CPKCS7ExtendedCertificateOrCertificate* NewL(const TDesC8& aRawData);
sl@0
    50
	
sl@0
    51
	/**
sl@0
    52
	Destructor
sl@0
    53
	*/
sl@0
    54
	~CPKCS7ExtendedCertificateOrCertificate();
sl@0
    55
		
sl@0
    56
	/**
sl@0
    57
	Returns the x509 certificate reference if the certificate is a X509 certificate.
sl@0
    58
	Callers need to check whether the certificate's type is X509 beforehand.
sl@0
    59
	@return The x509 certificate reference.
sl@0
    60
	*/
sl@0
    61
	IMPORT_C const CX509Certificate& Certificate(void) const;
sl@0
    62
sl@0
    63
private:
sl@0
    64
	/**
sl@0
    65
	Default Constructor
sl@0
    66
	*/
sl@0
    67
	CPKCS7ExtendedCertificateOrCertificate();
sl@0
    68
	
sl@0
    69
	/**
sl@0
    70
	Copy Constructor
sl@0
    71
	@param the source object to be copied
sl@0
    72
	*/	
sl@0
    73
	CPKCS7ExtendedCertificateOrCertificate(const CPKCS7ExtendedCertificateOrCertificate&);
sl@0
    74
	
sl@0
    75
	/**
sl@0
    76
	Second phase constructor for decoding.
sl@0
    77
	@param aRawData the raw data to be decoded.
sl@0
    78
	*/
sl@0
    79
	void ConstructL(const TDesC8& aRawData);
sl@0
    80
	
sl@0
    81
private:	
sl@0
    82
	/**
sl@0
    83
	The X509 certificate pointer
sl@0
    84
	*/
sl@0
    85
	CX509Certificate* iCertificate;
sl@0
    86
	};
sl@0
    87
sl@0
    88
sl@0
    89
	
sl@0
    90
#endif