omadrm/drmengine/roap/src/MeteringReportRespParser.cpp
changeset 0 95b198f216e5
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/omadrm/drmengine/roap/src/MeteringReportRespParser.cpp	Thu Dec 17 08:52:27 2009 +0200
@@ -0,0 +1,176 @@
+/*
+* Copyright (c) 2007-2008 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:  MeteringReportResponse Parser
+*
+*/
+
+
+
+// INCLUDE FILES
+#include <e32base.h>
+#include "Base64.h"
+#include "RoapParser.h"
+#include "MeteringReportResp.h"
+#include "MeteringReportRespParser.h"
+
+using namespace Roap;
+
+// LOCAL CONSTANTS AND MACROS
+_LIT8(KStatus, "status");
+
+// ============================ MEMBER FUNCTIONS ===============================
+
+// -----------------------------------------------------------------------------
+// TRegistrationRespParser::TRegistrationRespParser
+// C++ default constructor can NOT contain any code, that
+// might leave.
+// -----------------------------------------------------------------------------
+//
+TMeteringRespParser::TMeteringRespParser(
+    CMeteringResp* aResponse)
+    {
+    iResponse = aResponse;
+    }
+
+// -----------------------------------------------------------------------------
+// TMeteringRespParser::OnStartElementL
+// -----------------------------------------------------------------------------
+//
+void TMeteringRespParser::OnStartElementL(
+    CRoapParser& aParser,
+    TInt aState,
+    const RTagInfo& /*aElement*/,
+    const RAttributeArray& aAttributes)
+    {
+    HBufC8* buffer = NULL;
+
+    switch (aState)
+        {
+        case EMeteringReportResponseState:
+            buffer = aParser.GetAttributeValueL(aAttributes, KStatus);
+            if ( buffer )
+                {
+                CleanupStack::PushL( buffer );
+
+                // In case of a malformer request
+                _LIT8(KStatus, "MalFormedRequest");
+                if ( buffer->Compare( KStatus ) == 0 )
+                    {
+                    iResponse->iStatus = EMalformedRequest;
+                    }
+                else
+                    {
+                    iResponse->iStatus = aParser.ConvertRoapStatus( *buffer );
+                    }
+                CleanupStack::PopAndDestroy( buffer );
+                }
+            else
+                {
+                iResponse->iStatus = EUnknownStatus;
+                }
+            break;
+        default:
+            break;
+        }
+    }
+
+// -----------------------------------------------------------------------------
+// TMeteringRespParser::OnEndElementL
+// -----------------------------------------------------------------------------
+//
+void TMeteringRespParser::OnEndElementL(
+    CRoapParser& aParser,
+    TInt aState,
+    const RTagInfo& /*aElement*/)
+    {
+    HBufC8* buffer = NULL;
+
+    if ( !aParser.iContent )
+        {
+        return;
+        }
+
+    switch (aState)
+        {
+        case EDeviceIdState:
+            buffer = Base64DecodeL( *aParser.iContent );
+            CleanupStack::PushL( buffer );
+            if ( buffer->Length() != SHA1_HASH )
+                {
+                CleanupStack::PopAndDestroy( buffer );
+                User::Leave( KErrCorrupt );
+                }
+            iResponse->iDeviceId.Copy( *buffer );
+            CleanupStack::PopAndDestroy( buffer );
+            break;
+        case ERiIdState:
+            buffer = Base64DecodeL( *aParser.iContent );
+            CleanupStack::PushL( buffer );
+            if ( buffer->Length() != SHA1_HASH )
+                {
+                User::Leave( KErrCorrupt );
+                }
+            iResponse->iRiId.Copy( *buffer );
+            CleanupStack::PopAndDestroy( buffer );
+            buffer=NULL;
+            break;
+        case ENonceState:
+            if( aParser.iContent->Length() )
+                {
+                buffer = Base64DecodeL( *aParser.iContent );
+                CleanupStack::PushL( buffer );
+                if ( buffer->Length() != KDeviceNonceLength )
+                    {
+                    User::Leave( KErrCorrupt );
+                    }
+                CleanupStack::Pop( buffer );
+                iResponse->iDeviceNonce = buffer;
+                buffer=NULL;
+                }
+            else
+                {
+                User::Leave( KErrCorrupt );
+                }
+            break;
+        case ESignatureState:
+            iResponse->iSignature = Base64DecodeL( *aParser.iContent );
+            break;
+        case ECertificateState:
+            buffer = Base64DecodeL( *aParser.iContent );
+            CleanupStack::PushL( buffer );
+            iResponse->iCertificateChain.AppendL( buffer );
+            CleanupStack::Pop( buffer );
+            break;
+        case EOcspResponseState:
+            buffer = Base64DecodeL(*aParser.iContent);
+            CleanupStack::PushL(buffer);
+            iResponse->iOcspResponse.AppendL(buffer);
+            CleanupStack::Pop( buffer );
+            break;
+        case EPostResponseUrlState:
+            if ( aParser.iContent )
+                {
+                iResponse->iPrUrl = aParser.iContent->AllocL();
+                }
+            else
+                {
+                User::Leave( KErrCorrupt );
+                }
+            break;
+        default:
+            break;
+        }
+    }
+
+//  End of File