cms/src/CCMSX509AttributeCertificate.cpp
changeset 0 164170e6151a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/cms/src/CCMSX509AttributeCertificate.cpp	Tue Jan 26 15:20:08 2010 +0200
@@ -0,0 +1,268 @@
+/*
+* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies). 
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "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: 
+*
+*/
+
+
+// INCLUDE FILES
+#include    "CCMSX509AttributeCertificate.h"
+#include "CCMSX509AttributeCertificateInfo.h"
+#include "CCMSX509AlgorithmIdentifier.h"
+#include <asn1dec.h>
+#include <asn1enc.h>
+
+
+// ============================ MEMBER FUNCTIONS ===============================
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::CCMSX509AttributeCertificate
+// C++ default constructor can NOT contain any code, that
+// might leave.
+// -----------------------------------------------------------------------------
+//
+EXPORT_C CCMSX509AttributeCertificate::CCMSX509AttributeCertificate()
+    {
+    }
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::ConstructL
+// Symbian 2nd phase constructor can leave.
+// -----------------------------------------------------------------------------
+//
+EXPORT_C void CCMSX509AttributeCertificate::ConstructL(
+    const CCMSX509AttributeCertificateInfo& aInfo,
+    const CCMSX509AlgorithmIdentifier& aAlgorithmIdentifier,
+    const TDesC8& aEncrypted )
+    {
+    BaseConstructL( aAlgorithmIdentifier, aEncrypted );
+    SetInfoL( aInfo );
+    }
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::ConstructL
+// Symbian 2nd phase constructor can leave.
+// -----------------------------------------------------------------------------
+//
+EXPORT_C void CCMSX509AttributeCertificate::ConstructL( )
+    {
+    // creating empty/default values
+    iInfo = CCMSX509AttributeCertificateInfo::NewL();
+    iAlgorithmIdentifier = CCMSX509AlgorithmIdentifier::NewL();
+    iEncrypted = KNullDesC8().AllocL();
+    }
+    
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::NewL
+// Two-phased constructor.
+// -----------------------------------------------------------------------------
+//
+EXPORT_C CCMSX509AttributeCertificate*
+CCMSX509AttributeCertificate::NewL()
+	{
+	// creating with empty values
+    CCMSX509AttributeCertificate* self =
+        new( ELeave ) CCMSX509AttributeCertificate();
+    CleanupStack::PushL( self );
+    self->ConstructL( );
+    CleanupStack::Pop( self );
+	return self;
+	}
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::NewL
+// Two-phased constructor.
+// -----------------------------------------------------------------------------
+//
+EXPORT_C CCMSX509AttributeCertificate*
+CCMSX509AttributeCertificate::NewL(
+    const CCMSX509AttributeCertificateInfo& aInfo,
+    const CCMSX509AlgorithmIdentifier& aAlgorithmIdentifier,
+    const TDesC8& aEncrypted )
+    {
+    CCMSX509AttributeCertificate* self =
+        new( ELeave ) CCMSX509AttributeCertificate();
+    CleanupStack::PushL( self );
+    self->ConstructL( aInfo, aAlgorithmIdentifier, aEncrypted );
+    CleanupStack::Pop();
+
+    return self;
+    }
+
+// Destructor
+CCMSX509AttributeCertificate::~CCMSX509AttributeCertificate()
+    {
+	delete iInfo;
+    }
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::DecodeL
+// Decrypts raw data to this instance
+// -----------------------------------------------------------------------------
+void CCMSX509AttributeCertificate::DecodeL( const TDesC8& aRawData )
+	{
+    CCMSX509AlgorithmIdentifier* algId = NULL;
+    HBufC8* encrypted = NULL;
+    TASN1DecGeneric infoDecoder =
+        DecodeSignatureL( aRawData, algId, encrypted );
+
+    CleanupStack::PushL( algId );
+    CleanupStack::PushL( encrypted );
+    
+    // decode info
+    CCMSX509AttributeCertificateInfo* info =
+        CCMSX509AttributeCertificateInfo::NewL( );
+    CleanupStack::PushL( info );
+    info->DecodeL( infoDecoder.Encoding() );
+
+    // all done, change state
+    delete iInfo;
+    iInfo = info;
+    delete iAlgorithmIdentifier;
+    iAlgorithmIdentifier = algId;
+    delete iEncrypted;
+    iEncrypted = encrypted;
+    CleanupStack::Pop( 3 ); // info, encrypted, algId
+	}
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::EncoderLC
+// Returns ASN1 encoder for this instance
+// -----------------------------------------------------------------------------
+
+CASN1EncBase* CCMSX509AttributeCertificate::EncoderLC() const
+	{
+    // encode AttributeCertificateInfo
+    CASN1EncBase* info = iInfo->EncoderLC( );
+
+    // sign
+    CASN1EncSequence* root = SignAndPopLC( info );
+
+    return root;
+    }
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::Info()
+// Getter for AttributeCertificateInfo
+// -----------------------------------------------------------------------------
+EXPORT_C const CCMSX509AttributeCertificateInfo&
+CCMSX509AttributeCertificate::Info() const
+	{
+	return *iInfo;
+	}
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::SetInfoL()
+// Setter for AttributeCertificateInfo
+// -----------------------------------------------------------------------------
+EXPORT_C void CCMSX509AttributeCertificate::SetInfoL(
+    const CCMSX509AttributeCertificateInfo& aInfo )
+	{
+    CCMSX509AttributeCertificateInfo* info = NULL;
+    const CCMSX509IssuerSerial* baseCertificateID = aInfo.BaseCertificateID();
+    if( baseCertificateID )
+        {
+        info = CCMSX509AttributeCertificateInfo::NewL(
+            *baseCertificateID,
+            aInfo.Issuer(),
+            aInfo.Signature(),
+            aInfo.SerialNumber(),
+            aInfo.NotBeforeTime(),
+            aInfo.NotAfterTime(),
+            aInfo.Attributes() );
+        }
+    else
+        {
+        info = CCMSX509AttributeCertificateInfo::NewL(
+            *aInfo.SubjectName(),
+            aInfo.Issuer(),
+            aInfo.Signature(),
+            aInfo.SerialNumber(),
+            aInfo.NotBeforeTime(),
+            aInfo.NotAfterTime(),
+            aInfo.Attributes() );
+        }
+    CleanupStack::PushL( info );
+
+    info->SetVersion( aInfo.Version() );
+
+    const TDesC8* issuerUniqueID = aInfo.IssuerUniqueID();
+    if( issuerUniqueID )
+        {
+        info->SetIssuerUniqueIDL( *issuerUniqueID );
+        }
+
+    delete iInfo;
+    iInfo = info;
+    CleanupStack::Pop( info );
+    
+	}
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::DecodeImplicitTagL
+// Decrypts raw data with implicit tag
+// -----------------------------------------------------------------------------
+void CCMSX509AttributeCertificate::DecodeImplicitTagL(
+    const TDesC8& aRawData,
+    const TTagType aImplicitTag )
+    {
+    CArrayPtr< TASN1DecGeneric >* items = NULL;
+
+    // Check the tag
+    TASN1DecGeneric decGen( aRawData );
+    decGen.InitL();
+    // Accept only given tag
+    if( decGen.Tag() != aImplicitTag )
+        {
+        User::Leave( KErrArgument );
+        }
+    TASN1DecSequence decSeq;
+    items = decSeq.DecodeDERLC( decGen );
+    DecodeArrayL( items );
+    CleanupStack::PopAndDestroy( items );
+    }
+
+// -----------------------------------------------------------------------------
+// CCMSX509AttributeCertificate::DecodeArrayL
+// Decodes data from an array of decoders
+// -----------------------------------------------------------------------------
+void CCMSX509AttributeCertificate::DecodeArrayL(
+    CArrayPtr< TASN1DecGeneric >* aItems )
+    {
+    CCMSX509AlgorithmIdentifier* algId = NULL;
+    HBufC8* encrypted = NULL;
+    TASN1DecGeneric infoDecoder =
+        DecodeSignatureArrayL( *aItems, algId, encrypted );
+
+    CleanupStack::PushL( algId );
+    CleanupStack::PushL( encrypted );
+    
+    // decode info
+    CCMSX509AttributeCertificateInfo* info =
+        CCMSX509AttributeCertificateInfo::NewL( );
+    CleanupStack::PushL( info );
+    info->DecodeL( infoDecoder.Encoding() );
+
+    // all done, change state
+    delete iInfo;
+    iInfo = info;
+    delete iAlgorithmIdentifier;
+    iAlgorithmIdentifier = algId;
+    delete iEncrypted;
+    iEncrypted = encrypted;
+    CleanupStack::Pop( 3 ); // info, encrypted, algId
+    }
+
+//  End of File