webservices/wsoviplugin/src/wsovicredentialcollectorhandler.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 07 Jan 2010 16:19:19 +0200
changeset 0 62f9d29f7211
permissions -rw-r--r--
Revision: 200951 Kit: 201001

/*
* Copyright (c) 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:       
*
*/










#include "wsovicredentialcollectorhandler.h"
#include "senlogger.h"
#include <SenDateUtils.h>
using namespace OAuth;
using namespace WSOviResponse;
// Create instance of concrete ECOM interface implementation
CWSOviCredentialCollectorHandler* CWSOviCredentialCollectorHandler::NewL(TAny* aHandlerCtx)
    {
    
    MSenHandlerContext* handlerCtx =
        reinterpret_cast<MSenHandlerContext*>(aHandlerCtx);
    CWSOviCredentialCollectorHandler* self = 
            new(ELeave)CWSOviCredentialCollectorHandler(*handlerCtx);
    CleanupStack::PushL (self);
    self->ConstructL();
    CleanupStack::Pop(self);
    return self;
    }

// Constructor
CWSOviCredentialCollectorHandler::CWSOviCredentialCollectorHandler(MSenHandlerContext& aCtx)
:CSenMessageHandler(aCtx)
    {
    }

// Destructor
CWSOviCredentialCollectorHandler::~CWSOviCredentialCollectorHandler()
    {
        TLSLOG(KSenCoreServiceManagerLogChannelBase  , KMinLogLevel,(_L("CWSOviCredentialCollectorHandler::\
                         ~CWSOviCredentialCollectorHandler()")));
    }

// Second phase construction.
void CWSOviCredentialCollectorHandler::ConstructL()
    {
    }
    
TInt CWSOviCredentialCollectorHandler::InvokeL(MSenMessageContext& aCtx)
    {
    TLSLOG(KSenCoreServiceManagerLogChannelBase  , KMinLogLevel,(_L("CWSOviCredentialCollectorHandler::InvokeL(MSenMessageContext& aCtx)")));
    
    const TDesC8* token = aCtx.GetDesC8L(WSOviContextKeys::KToken());
    if (token && aCtx.Direction()==SenContext::EOutgoing)
        {
        TPtrC8 tokenPtr(token->Mid(KTokenTag().Length()));
        tokenPtr.Set(tokenPtr.Left(tokenPtr.Length() - KTokenTagEnd().Length()));
        
        RMapDescriptors& headerProperties = ((CWSOviMessageContext&)aCtx).OAuthProperies();
        headerProperties.Insert(&KParToken, tokenPtr.AllocL());    
        TLSLOG(KSenCoreServiceManagerLogChannelBase  , KMinLogLevel,(_L("CWSOviCredentialCollectorHandler::InvokeL\
                                (MSenMessageContext& aCtx) -  \
                                Token added to OAuth parameters")));
        ((CWSOviMessageContext&)aCtx).Update(WSOviContextKeys::KToken(), tokenPtr);
        return KErrNone;                                
        }
    else
        {
        TLSLOG(KSenCoreServiceManagerLogChannelBase  , KMinLogLevel,(_L("CWSOviCredentialCollectorHandler::InvokeL\
                                (MSenMessageContext& aCtx) -  \
                                Token in message context not exists")));
        return KErrNotFound;
        }
    }

TInt CWSOviCredentialCollectorHandler::InitL(MSenHandlerContext& aCtx)
    {
    iHandlerContext = aCtx;
    return KErrNone;
    }
    
SenHandler::THandlerDirection CWSOviCredentialCollectorHandler::Direction() const
    {
    TLSLOG(KSenCoreServiceManagerLogChannelBase  , KMinLogLevel,(_L("CWSOviCredentialCollectorHandler::Direction()")));
    return SenHandler::EOutgoing;
    };
SenHandler::THandlerPhase CWSOviCredentialCollectorHandler::Phase()
    {
    TLSLOG(KSenCoreServiceManagerLogChannelBase  , KMinLogLevel,(_L("CWSOviCredentialCollectorHandler::Phase()")));
    return SenHandler::EMessage;
    };    

// END OF FILE