// Copyright (c) 2000-2009 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:
//
// Local includes
//
#include "CUAAppHandler.h"
// System includes
//
#include <push/pushlog.h>
#include <push/pushmessage.h>
#include <push/pluginkiller.h>
#include "pushdispatcher.h"
#include <push/ccontenthandlerbase.h>
// Constants
_LIT(KReserved, "Reserved");
void CUAAppHandler::CPushHandlerBase_Reserved1()
	{
	User::Panic(KReserved, KErrNotSupported);
	}
void CUAAppHandler::CPushHandlerBase_Reserved2()
	{
	User::Panic(KReserved, KErrNotSupported);
	}
/** CUAAppHandler Constructor.
 * 
 */ 
CUAAppHandler::CUAAppHandler()
: CPushHandlerBase()
	{
	CActiveScheduler::Add(this);
	}
/** CUAAppHandler Static Factory Construction.
 * 
 */
CUAAppHandler* CUAAppHandler::NewL()
	{
	CUAAppHandler* self = new (ELeave) CUAAppHandler;
	return self;
	}
/**
 * Default Destructor.
 */
CUAAppHandler::~CUAAppHandler()
	{
	__LOG_PTR_DEBUG("CUAAppHandler:: Destructor Called"); 
	}
/** Asynchronous Handling of Push Message.
 *
 *	@param aPushMsg  the received push message
 *	@param aStatus Status to be signalled when handling is complete
 */
void CUAAppHandler::HandleMessageL(CPushMessage* aPushMsg, TRequestStatus& aStatus)
	{
	 __LOG_PTR_DEBUG("CUAAppHandler:: HandleMessageL Async Func. Called"); 	
	SetConfirmationStatus(aStatus);
	TPtrC contentType;
	aPushMsg->GetContentType(contentType);
	CContentHandlerBase& contentHandlerPi = PushContentTypeDispatcher::GetHandlerL(contentType, *iLog, *iManager);
	iContentHandlerPi = &contentHandlerPi;
	iContentHandlerPi->HandleMessageL(aPushMsg, iStatus);
	SetActive();
	}
/**
 * Cancel any outstanding requests.
 */
void CUAAppHandler::CancelHandleMessage()
	{
	if(*iConfirmStatus==KRequestPending)
		{
		iContentHandlerPi->CancelHandleMessage();
		}
	}
/**
 *  HandleMessageL - Sync. Version
 *
 * 1. Get Content-Type from Msg
 * 2. Load the specific Content handler
 * 3. Pass the Push message to Content the handler
 * 4. Invoke the Killer object to delete the Plugin Owner
 *
 * @param aPushMsg the Push Message to be handled
 */
void CUAAppHandler::HandleMessageL(CPushMessage* aPushMsg)
	{
	 __LOG_PTR_DEBUG("CUAAppHandler:: HandleMessageL Sync Func. Called"); 	
	TPtrC contentType;
	aPushMsg->GetContentType(contentType);
	TRAPD( error, 
		CleanupStack::PushL(aPushMsg);
		CContentHandlerBase& contentHandlerPi = PushContentTypeDispatcher::GetHandlerL(contentType, *iLog, *iManager);
		CleanupStack::Pop(aPushMsg);
		iContentHandlerPi = &contentHandlerPi;
		);
	if( error == KErrNone )
		{
		TRAP( error, 
			iContentHandlerPi->HandleMessageL(aPushMsg));
		}
	iPluginKiller->KillPushPlugin();
	}
/**
 * Cancel the handling of the message.
 * No Object need to be canceled in the case of CUnknownAppHandler.
 */
void CUAAppHandler::DoCancel()
	{
	__LOG_PTR_DEBUG("CUAAppHandler:: DoCancel Called");
	}
/** CUAAppHandler State machine.
 *
 * Complete Active Object Returning the comfirmation status
 * and Suicide.
 */
void CUAAppHandler::RunL()
	{
	__LOG_PTR_DEBUG("CUAAppHandler:: RunL Called");
	SignalConfirmationStatus(KErrNone);
	iPluginKiller->KillPushPlugin();
	}