authorisation/userpromptservice/policies/inc/dialogcreator.h
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:40:57 +0100
branchRCL_3
changeset 62 a71299154b21
parent 8 35751d3474b7
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201035 Kit: 201035

/*
* 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: 
* Interface definition for UPS dialog creator ECOM plug-in.
*
*/


/**
 @file
 @publishedPartner
 @released
*/

#ifndef DIALOGCREATOR_H
#define DIALOGCREATOR_H

#include <e32base.h>
#include <e32cmn.h>
#include <ups/policy.h>
#include <ups/ups.hrh>

namespace UserPromptService
	{
	class CClientEntity;
	class CFingerprint;
	class CPromptRequest;
	
	/**
	Abstract base class for dialog creator ECOM plug-ins.
	
	Dialog creators are responsible for generating and displaying prompt dialogs. Normally,
	the notifier framework (RNotifier) would be used to interact with the user interface layer.\n
	
	In addition to the data supplied by the system server the dialog creator may
	also include data from other servers such as AppArc or the SIS registry.
	Since retrieving this extra information may take an unpredictable amount of time the dialog
	creator PrepareDialog method is asynchronous to ensure the user prompt service is 
	not blocked.

	- A new dialog creator object is created for each request that requires a prompt. The object
	is destroyed after DisplayDialog has been called.
	*/			
	class CDialogCreator : public CActive
		{
	public:					
		IMPORT_C static CDialogCreator* NewL(const TUid& aDialogCreatorImplementationId);
		
		/**
		 Asynchronously retrieves and prepares the data needed to display the dialog.
		 
		 The const parameters aRequest, aPolicy, aFingerprints, aDialogCreatorParams persist
		 until after the the dialog creator has been destroyed; therefore, the dialog creator
		 may safely use pointers to this data internally.\n
		 
		 @param aRequest				The parameters supplied by the system server.
		 @param aPolicy					The policy being evaluated.
		 @param aFingerprints			The array of finger prints generated by the policy evaluator.\n
										This may be empty if the policy does not allow the Always or Never options.
		 @param aClientEntity			Identifies the entity within the client process that requested the service.\n
										NULL if the client processs is not an execution host.
		 @param	aDialogCreatorParams	Opaque data generated by the policy evaluator.
		 @param aStatus					The request object to complete once the dialog is ready.
		*/
		virtual void PrepareDialog(
			const CPromptRequest& aRequest, 
			const CPolicy& aPolicy,			
			const RPointerArray<CFingerprint>& aFingerprints,
			const CClientEntity* aClientEntity,
			const TAny* aDialogCreatorParams,
			TRequestStatus& aStatus) = 0;

		/**
		Asynchronously, displays the dialog created by PrepareDialog and interprets the result.	

		Note that the UPS server expects aOptionSelected to match one of the enabled options specified 
		in the policy entry which was passed into PrepareDialog. If no legal option is selected, it will be treated
		as a ENo.

		@param aOptionSelected	The option selected by the user.\n
								(OUT parameter)
		@param aFingerprint		A reference to a pointer used to return	the fingerprint to use in the new
								decision record if the Always or Never button was selected.\n
								Ownership is NOT transferred to the caller.\n
								(OUT parameter)
		@param aEvaluatorInfo	The value to write to the decision record's evaluatorInfo field if
								the Always or Never option was selected. The default 
								value for this field is 0x00000000 for a new record or the
								previous value if the policy evaluator forced a prompt to be
								displayed and a decision record already existed.\n
								(IN/OUT parameter)
		@param aStatus			The request object to complete once the dialog has been closed.
								
		 */
		virtual void DisplayDialog(
			CPolicy::TOptions& aOptionSelected,
			const CFingerprint*& aFingerprint,
			TUint& aEvaluatorInfo,
			TRequestStatus& aStatus) = 0;
					
		IMPORT_C TInt GetExtension(TUint aExtensionId, TAny*& a0, TAny* a1);		
		IMPORT_C ~CDialogCreator();		
	protected:
		IMPORT_C CDialogCreator();
		IMPORT_C virtual TInt Extension_(TUint aExtensionId, TAny*& a0, TAny* a1);
	private:
		TAny* iReserved;
		TUid iDtor_ID_Key;		// Required by ECOM
		};		
	}	

#endif // DIALGOCREATOR_H