authorisation/userpromptservice/policies/source/promptrequest.cpp
changeset 8 35751d3474b7
child 61 641f389e9157
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/authorisation/userpromptservice/policies/source/promptrequest.cpp	Thu Sep 10 14:01:51 2009 +0300
@@ -0,0 +1,214 @@
+/*
+* Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "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 <ups/promptrequest.h>
+
+using namespace UserPromptService;
+
+EXPORT_C CPromptRequest* CPromptRequest::NewL(
+		const TSecureId& aClientSid, const TVendorId& aClientVid, const TThreadId& aClientThreadId, TProcessId &aClientProcessId,
+		const TSecureId& aServerSid, const TServiceId& aServiceId, RBuf& aDestination, RBuf8& aOpaqueData, 
+		TBool aSecurityResult)
+/**
+Creates a new prompt request object.\n
+
+The ownership of the aDestination and aOpaqueData RBufs is transfered
+to this class. The callers RBufs will be empty after this call.
+
+
+@param aClientSid		The SID of the client process requesting the service.
+@param aClientVid		The VID of the client process requesting the service.
+@param aClientThreadId	The id of the thread within the client process requesting the service.
+@param aServerSid		The SID of the system server that provides the service.
+@param aServiceId		The UID of the requested service.
+@param aDestination		The data that the service acts on E.g. A phone number, IAP, domain name
+@param aOpaqueData		Opaque data structure populated by the system server. Typically, this 
+						contains extra information about the requested service.	
+@param aSecurityResult	ETrue if client passed system server's security check; otherwise, EFalse.										
+
+@return					A pointer to the new prompt request object.
+*/
+	{
+	CPromptRequest* self = CPromptRequest::NewLC(
+		aClientSid, aClientVid, aClientThreadId, aClientProcessId, 
+		aServerSid, aServiceId, aDestination, aOpaqueData, aSecurityResult);
+	CleanupStack::Pop(self);
+	return self;
+	}
+
+EXPORT_C CPromptRequest* CPromptRequest::NewLC(
+		const TSecureId& aClientSid, const TVendorId& aClientVid, const TThreadId& aClientThreadId, TProcessId &aClientProcessId,
+		const TSecureId& aServerSid, const TServiceId& aServiceId, RBuf& aDestination, RBuf8& aOpaqueData, 
+		TBool aSecurityResult)
+/**
+Creates a new prompt request object and places the pointer on the cleanup stack.\n
+
+The ownership of the aDestination and aOpaqueData RBufs is transfered
+to this class. The callers RBufs will be empty after this call.
+
+@param aClientSid		The SID of the client process requesting the service.
+@param aClientVid		The VID of the client process requesting the service.
+@param aClientThreadId	The id of the thread within the client process requesting the service.
+@param aServerSid		The SID of the system server that provides the service.
+@param aServiceId		The UID of the requested service.
+@param aDestination		The data that the service acts on E.g. A phone number, IAP, domain name
+@param aOpaqueData		Opaque data structure populated by the system server. Typically, this 
+						contains extra information about the requested service.	
+@param aSecurityResult	ETrue if client passed system server's security check; otherwise, EFalse.
+
+@return					A pointer to the new prompt request object.
+*/
+	{
+	CPromptRequest* self = new(ELeave) 
+		CPromptRequest(aClientSid, aClientVid, aClientThreadId, aClientProcessId,
+		aServerSid, aServiceId, aDestination, aOpaqueData, aSecurityResult);
+	CleanupStack::PushL(self);
+	return self;
+	}
+	
+CPromptRequest::CPromptRequest(
+	const TSecureId& aClientSid, const TVendorId& aClientVid, const TThreadId& aClientThreadId, TProcessId &aClientProcessId,
+	const TSecureId& aServerSid, const TServiceId& aServiceId, 
+	RBuf& aDestination, RBuf8& aOpaqueData, 
+	TBool aSecurityResult)
+/**
+Constructor
+@param aClientSid			The client's SID
+@param aClientVid			The client's VID
+@param aClientThreadId		The client's thread id.
+@param aServerId			The system server's SID.
+@param aServiceId			The id of the service.
+@param aDestination			The destination.
+@param aOpaqueData			The opaque data.
+@param aSecurityResult		Whether the client passed the system server's security check
+*/
+:	iClientSid(aClientSid), iClientVid(aClientVid), iClientThreadId(aClientThreadId), iClientProcessId(aClientProcessId),
+	iServerSid(aServerSid), iServiceId(aServiceId),
+	iSecurityResult(aSecurityResult)
+	{
+	iDestination.Close();
+	iDestination.Swap(aDestination);
+	iOpaqueData.Close();
+	iOpaqueData.Swap(aOpaqueData);	
+	}
+			
+EXPORT_C const TSecureId& CPromptRequest::ClientSid() const
+/**
+Gets the SID of the client process requesting the service.
+@return The client's SID.
+*/
+	{	
+	return iClientSid;
+	}
+
+EXPORT_C TBool CPromptRequest::IsClientSidProtected() const
+/**
+Determines whether the SID of the client process is in the protected range. 
+If the SID is not protected then it is likely that identify of the client process
+cannot reliable verified because it may an unsigned application. If so, a warning
+should be displayed in the prompt dialog.
+
+@return ETrue if the SID is in the protected range; otherwise EFalse is returned.
+*/
+	{
+	return ! (iClientSid.iId & 0x80000000);
+	}
+	
+EXPORT_C const TVendorId& CPromptRequest::ClientVid() const
+/**
+Gets the VID of the client process requesting the service.
+@return The client's VID.
+*/
+	{
+	return iClientVid;
+	}
+	
+EXPORT_C const TThreadId& CPromptRequest::ClientThreadId() const
+/**
+Gets the TThreadId of the client which issued the request to the system server.
+This thread ID may be invalid if the thread has exited (we do NOT hold an open RThread to keep around).
+@return The client's thread id.
+*/
+	{
+	return iClientThreadId;
+	}	
+
+EXPORT_C const TProcessId& CPromptRequest::ClientProcessId() const
+/**
+Gets the TProcessId of the client which issued the request to the system server.
+This process ID may be invalid if the process has exited (we do NOT hold an open RProcess to keep around).
+@return The client's process id.
+*/
+	{
+	return iClientProcessId;
+	}	
+
+EXPORT_C const TSecureId& CPromptRequest::ServerSid() const
+/**
+Gets the SID of the system server that provides the service.
+@return The system server's SID.
+*/
+	{
+	return iServerSid;
+	}
+	
+EXPORT_C const TServiceId& CPromptRequest::ServiceId() const
+/**
+Gets the UID of the requested service.
+@return The service UID.
+*/
+	{
+	return iServiceId;
+	}
+	
+EXPORT_C const TDesC& CPromptRequest::Destination() const
+/**
+Gets the data that the service acts on e.g. the phone number to dial.
+@return A reference to a descriptor containing the destination string.
+*/
+	{
+	return iDestination;
+	}
+
+EXPORT_C const TDesC8& CPromptRequest::OpaqueData() const
+/**
+Gets the opaque data structure provided by the system server. 
+@return A reference to a descriptor containing the opaque data.
+*/
+	{
+	return iOpaqueData;
+	}	
+
+EXPORT_C TBool CPromptRequest::SecurityResult() const
+/**
+Whether the client processed the system server's security check.
+@return ETrue, if the client process passed the system server's 
+security check; otherwise, EFalse is returned.
+*/
+	{
+	return iSecurityResult;
+	}
+	
+EXPORT_C CPromptRequest::~CPromptRequest()
+/**
+Destructor
+*/
+	{
+	iDestination.Close();
+	iOpaqueData.Close();
+	}