accessoryservices/remotecontrolfw/targetselectorplugin/public/clientinfo.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 00:53:00 +0200
changeset 0 4e1aa6a622a0
permissions -rw-r--r--
Revision: 201003

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

/**
 @file
 @publishedPartner
 @released
*/

#ifndef CLIENTINFO_H
#define CLIENTINFO_H

#include <e32base.h>

/**
Contains information (of interest to the TSP) about a client of RemCon.
Includes the client's process ID and the client's current send message 
(RMessage2) which is triggering a request (AddressOutgoingCommand or 
PermitOutgoingCommand) on the TSP. Via the RMessage2, the TSP can access the 
client's secure ID and also do capability checks on the client.
The process ID is also used by the server to police creation of target 
sessions (only 1 is allowed per client process).
*/
class TClientInfo
	{
public:
	/** Link between elements of this type in a TSglQue. If this member 
	changes offset, remconserver must be rebuilt. */
	TSglQueLink iLink;
	TSglQueLink iLink2;

public:
	/** Constructor. */
	IMPORT_C TClientInfo();

	/** Destructor. */
	IMPORT_C ~TClientInfo();

public:
	/** 
	Accessor for process ID.
	@return The process ID.
	*/
	IMPORT_C TProcessId& ProcessId();

	/** 
	Accessor for process ID.
	@return The process ID.
	*/
	IMPORT_C TProcessId ProcessId() const;

	/**
	Accessor for message.
	@return The message.
	*/
	IMPORT_C RMessage2& Message();

	/**
	Accessor for the client's current Send message. 
	This is provided for the TSP to access the client's current Send message 
	for capability checks only. The TSP must not Complete this message. Note 
	that this message is only valid if AddressOutgoingCommand or 
	PermitOutgoingCommand are being used (i.e. the client currently has a Send 
	outstanding). 
	For AddressIncomingCommand, the message returned will be invalid and must 
	not be used by the TSP.
	@return The message.
	*/
	IMPORT_C const RMessage2& Message() const;

	/**
	Accessor for the secure ID.
	@return The secure ID.
	*/
	IMPORT_C TSecureId SecureId() const;

	/**
	Accessor for the secure ID.
	@return The secure ID.
	*/
	IMPORT_C TSecureId& SecureId();

private:
	/** The process ID. */
	TProcessId iProcessId;

	/** The client's current send message. */
	RMessage2 iMessage;

	/** The secure ID. */
	TSecureId iSecureId;
	
	// The previous BC pad has been used for iLink2. Further extensions will need to be implemented by moving data out
	// into an extension class
	
	};

class TClientInfoConstIter: TSglQueIter<TClientInfo>
	{
public:
	inline TClientInfoConstIter(TSglQue<TClientInfo>& aQue);
	inline void SetToFirst();
	inline void Set(TClientInfo& aLink);
	inline operator const TClientInfo*();	
	inline const TClientInfo* operator++(TInt);
	};

inline TClientInfoConstIter::TClientInfoConstIter(TSglQue<TClientInfo>& aQue): TSglQueIter<TClientInfo>(aQue)
	{ }

inline void TClientInfoConstIter::SetToFirst()
	{
	TSglQueIter<TClientInfo>::SetToFirst();
	}

inline void TClientInfoConstIter::Set(TClientInfo& aLink)
	{ DoSet(&aLink); }

inline TClientInfoConstIter::operator const TClientInfo*()
	{ return((const TClientInfo*)DoCurrent()); }

inline const TClientInfo* TClientInfoConstIter::operator ++(TInt)
	{ return((const TClientInfo *)DoPostInc()); }

#endif // CLIENTINFO_H