sysstatemgmt/systemstatemgr/ssm/src/ssmswppolicycli.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 31 Mar 2010 23:31:40 +0300
branchRCL_3
changeset 7 1fc153c72b60
parent 0 4e1aa6a622a0
permissions -rw-r--r--
Revision: 201011 Kit: 201013

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

#include "ssmswppolicycli.h"
#include "ssmswppolicysrv.h"
#include "ssmswppolicyconst.h"
#include "ssmdebug.h"

/**
 Constructs the client-side ssmswppolicy server session.
*/
RSsmSwpPolicySession::RSsmSwpPolicySession()
	: RSessionBase(), iVersion(KSsmSwpPolicyCliVersionMajor, KSsmSwpPolicyCliVersionMinor, KSsmSwpPolicyCliVersionBuild)
	{
	} //lint !e1401 not initialized by constructor (iSpare)
	
/**
 Connects to the ssmswppolicy server. If the server is not found, this function will attempt to start it
 and retry connecting to it.

@leave KErrNoMemory if no memory.
*/
void RSsmSwpPolicySession::ConnectL()
	{
	// Guard against multiple calls.
	if(KNullHandle != iHandle)
		{
		DEBUGPRINT1(_L("RSsmSwpPolicySession: Client already has a Connected session"));
		User::Leave(KErrAlreadyExists);
		}

	const TInt err = CreateSession(KSsmSwpPolicySrvName, iVersion, KSsmSwpPolicySrvMsgSlots);
	if((KErrNotFound == err) || (KErrServerTerminated == err))
		{
		User::LeaveIfError(CSsmSwpPolicyServer::StartSsmSwpPolicySrv(KSsmSwpPolicySrvName));
		User::LeaveIfError(CreateSession(KSsmSwpPolicySrvName, iVersion, KSsmSwpPolicySrvMsgSlots));
		DEBUGPRINT1(_L("RSsmSwpPolicySession Connect Completed with KErrNone"));
		}
	else
		{
		DEBUGPRINT2(_L("RSsmSwpPolicySession Connect Completed with %d"), err);
		User::LeaveIfError(err);
		}
	}

#ifdef TEST_SSM_SERVER
/**
 For testing purposes
 Connects to ssmswppolicy server with the specified name. If the server is not found, this function will attempt to start it
 and retry connecting to it.
 
@param aServerName The name of the ssmswppolicy server to connect to
@leave KErrNoMemory if no memory.
*/
void RSsmSwpPolicySession::ConnectL(const TDesC& aServerName)
	{
	// Guard against multiple calls.
	if(KNullHandle != iHandle)
		{
		User::Leave(KErrAlreadyExists);
		}

	const TInt err = CreateSession(aServerName, iVersion, KSsmSwpPolicySrvMsgSlots);
	if((KErrNotFound == err) || (KErrServerTerminated == err))
		{
		User::LeaveIfError(CSsmSwpPolicyServer::StartSsmSwpPolicySrv(aServerName));
		User::LeaveIfError(CreateSession(aServerName, iVersion, KSsmSwpPolicySrvMsgSlots));
		DEBUGPRINT1(_L("RSsmSwpPolicySession Connect Completed with KErrNone"));
		}
	else
		{
		DEBUGPRINT2(_L("RSsmSwpPolicySession Connect Completed with %d"), err);
		User::LeaveIfError(err);
		}
	}
#endif	// TEST_SSM_SERVER

/**
Closes the RSession handle.
*/
void RSsmSwpPolicySession::Close()
	{
	RSessionBase::Close();
	}

/**
Sets the swppolicy dll handle and initializes the swppolicy. The policyhandle which is loaded in 
swppolicyresovler is passed to the swppolicyserver, where it is used to open the handle to swppolicy
and forward the calls from policy frame to the swppolicy.

@param aPolicyHandle The swppolicy policyhandle
@param aStatus		 Request Status
*/
void RSsmSwpPolicySession::CallSetDllHandleAndInitialize(TInt aPolicyHandle, TRequestStatus& aStatus)
	{
	DEBUGPRINT1(_L("RSsmSwpPolicySession: Sets the swppolicy Dll Hanlde and Initializes it"));
	SendReceive(ESsmPolicySrvSetSwpPolicyDllHandleAndInitialize, TIpcArgs(aPolicyHandle), aStatus);
	}

/**
Cancels the Initialization of the swppolicy, if any Initialization request is pending.
@return KErrNone, if successful; otherwise one of the other system-wide error codes. 
*/
TInt RSsmSwpPolicySession::CallInitializeCancel()
	{
	DEBUGPRINT1(_L("RSsmSwpPolicySession: Cancel Initialization of the swp policy"));
	return (SendReceive(ESsmPolicySrvInitializeCancel));
	}

/**
Prepares the commandlist in swppolicy
@param aSwp		Swp value
@param aStatus	Request Status 
*/
void RSsmSwpPolicySession::CallPrepareCommandList(const TSsmSwp& aSwp, TRequestStatus& aStatus)
	{
	DEBUGPRINT1(_L("RSsmSwpPolicySession: Call Prepare command list in swppolicy"));
	const TPckgC<TSsmSwp> swpBuf(aSwp);
	SendReceive(ESsmPolicySrvPrepareCommandList, TIpcArgs(&swpBuf), aStatus);
	}

/**
Cancels the preparation of the commandlist, if any preparecommandlist request is pending.
@return KErrNone, if successful; otherwise one of the other system-wide error codes. 
*/
TInt RSsmSwpPolicySession::CallPrepareCommandListCancel()
	{
	DEBUGPRINT1(_L("RSsmSwpPolicySession: Cancel prepare command list in swppolicy"));
	return (SendReceive(ESsmPolicySrvPrepareCommandListCancel));
	}

/**
Returns the commandlist to the client from swppolicy.
@return A pointer to commandlist
*/
CSsmCommandList* RSsmSwpPolicySession::CallCommandListL()
	{
	// Ensure any memory that might already have been allocated is disposed of. 
	// Transfer the streamed cmd list from the CBuf.
	RBuf8 cmdListBuf;
	cmdListBuf.CreateL(KSsmSwpPolicyStreamBufMaxSize);
	CleanupClosePushL(cmdListBuf);

	TInt err = SendReceive(ESsmPolicySrvCommandList, TIpcArgs(&cmdListBuf));
	DEBUGPRINT2(_L("RSsmSwpPolicySession: CallCommandList completed with %d"), err);

	CSsmCommandList* cmdList = NULL;

	if(err == KErrNone)
		{
		// Supply RBuf to the readstream. Stream and reconstruct the command list.
		RDesReadStream readStream(cmdListBuf);
		CleanupClosePushL(readStream);
		cmdList = CSsmCommandList::NewLC();
		cmdList->InternalizeL( readStream);
		CleanupStack::Pop(cmdList);
		CleanupStack::PopAndDestroy(&readStream);
		}

	CleanupStack::PopAndDestroy(&cmdListBuf);
	return cmdList;
	}

/*
Handles the value returned by Cle.
@param aSwp			swp value
@param aError		Error returned by cle as result of the command execution
@param aSeverity	Severity of the command
@param aStatus		Request Status
*/
void RSsmSwpPolicySession::CallHandleCleReturnValue(const TSsmSwp& aSwp, TInt aError, TInt aSeverity, TRequestStatus& aStatus)
	{
	const TPckgC<TSsmSwp> swpBuf(aSwp);
	DEBUGPRINT1(_L("RSsmSwpPolicySession: Call HandleCleReturn Value of the swppolicy"));
	SendReceive(ESsmPolicySrvHandleCleReturnValue, TIpcArgs(&swpBuf, aError, aSeverity), aStatus);
	}

/**
Cancels the HandleCleReturnValue, if any HandleCleReturnValue request is pending.
@return KErrNone, if successful; otherwise one of the other system-wide error codes. 
*/
TInt RSsmSwpPolicySession::CallHandleCleReturnValueCancel()
	{
	DEBUGPRINT1(_L("RSsmSwpPolicySession: Cancel Call HandleCleReturn Value of the swppolicy"));
	return (SendReceive(ESsmPolicySrvHandleCleReturnValueCancel));
	}