authenticationservices/authenticationserver/test/reftestplugin/tpinplugindlg/tpinplugindlg.h
changeset 29 ece3df019add
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/authenticationservices/authenticationserver/test/reftestplugin/tpinplugindlg/tpinplugindlg.h	Tue Nov 24 09:06:03 2009 +0200
@@ -0,0 +1,161 @@
+/*
+* Copyright (c) 2006-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: 
+*
+*/
+
+
+#ifndef __TPINPLUGINDLG_H__
+#define __TPINPLUGINDLG_H__
+
+#include <e32base.h>
+#include <pinplugindialogdefs.h>
+
+const TUint KTPinPluginDlgNotiferUid = 0x200032E7;
+
+#ifdef _T_PINPLUGINDLG_TEXTSHELL
+
+#include <twintnotifier.h>
+
+/** Method at ordinal 1 to get a list of notifiers from this dll. */
+IMPORT_C CArrayPtr<MNotifierBase2>* NotifierArray();
+
+#else
+
+#include <eiknotapi.h>
+#include <ecom/ImplementationProxy.h>
+#define MNotifierBase2 MEikSrvNotifierBase2
+
+IMPORT_C const TImplementationProxy* ImplementationGroupProxy(TInt& aTableCount);
+CArrayPtr<MNotifierBase2>* NotifierArray();
+
+#endif
+
+/**
+ It reads the Input datas from t_pinplugindlg_in.dat and constructs
+ TInputDetails to use in CTestPinPluginDlgNotifier.
+ */
+class TInputDetails
+	{
+ public:
+ 	/**
+ 	 Constructs the object while the request is Train/ReTrain.
+ 	 */
+	TInputDetails(TPinPluginDialogOperation aOp, TInt aIndex, TInt aNewPinLength, TPinPluginDialogResult aCommandOutput);
+	/**
+ 	 Constructs the object while the request is Identify.
+ 	 */
+	TInputDetails(TPinPluginDialogOperation aOp, TPinValue& aPinValue, TPinPluginDialogResult aCommandOutput);
+	/** Returns the current process Dialog Notification Operation */
+	TPinPluginDialogNotification Operation() const { return iOp; }
+	/** Returns the current process Pin Value Selected/Entered. */
+	const TPinValue& PinValue() const { return iPinValue; }
+	/** Returns the current process selected index. */
+	TInt Index() const { return iIndex; }
+	/** Returns the current process New pin Length given. */
+	TInt NewPinLength() const { return iNewPinLength; }
+	/** Returns the current process Dialog output. */
+	TPinPluginDialogResult CommandOutput() const { return iCommandOutput; }
+ private:
+	TPinPluginDialogNotification iOp;
+	TPinValue iPinValue;
+	TInt iIndex;
+	TInt iNewPinLength;
+	TPinPluginDialogResult iCommandOutput;
+	TPinPluginInfoMessage iExpectedMsg;
+	};
+
+/**
+ This is a test implementation of the pinplugin dialog notifier. This version
+ responds to dialogs with data read from c:\t_pinplugindlg_in.dat. This contains
+ the expected input for the dialog. It keeps a number of dialog displayed
+ and pin selected for the Train/ReTrain or pin given in Identify Dialog and
+ displayed info message in c:\t_pinplugindlg_out.dat.
+ */
+class CTestPinPluginDlgNotifier : public CBase, public MNotifierBase2
+	{
+public:
+	static CTestPinPluginDlgNotifier* NewL();
+
+private:
+	void ConstructL();
+	CTestPinPluginDlgNotifier();
+
+	/**
+	 Read the Number of Dialog displayed already from t_pinplugindlg_out.dat.
+	 */
+	TInt ReadDialogCountL();
+	/**
+	 Read the PinValue Selected/Entered in the last dialog request from
+	 t_pinplugindlg_out.dat.
+	 */
+	TPinValue ReadPinValueL();
+	/**
+	 Write the dialog count to the output file t_pinplugindlg_out.dat.
+	 
+	 @param aCount		The Count of the Current Dialog.
+	 */
+	void WriteDialogCountL(TInt aCount);
+	/**
+	 Write the PinValue to the output file t_pinplugindlg_out.dat.
+
+ 	 @param aPinValue		The pinvalue to be write.
+	 */
+	void WritePinL(const TPinValue& aPinValue);
+	/**
+	 Write the info message to the output file t_pinplugindlg_out.dat.
+	 
+	 @param aMessage		The message to be write.
+	 */
+	void WriteMsgL(const TPinPluginInfoMessage& aMessage);
+	
+	/**
+	 Read an input specification.
+	 
+	 @param aOperation		Consturct the InputDetails for the aOperation.
+	 */
+	TInputDetails* ReadInputDetailsL(TUint aOperation);
+	
+	/**
+	 Construct the output Details from aDetail and complete the RMessagePtr2
+	 with the details.
+	 
+	 @param aDetail		The input Details read from .dat file for this dialog
+	 @param aBuffer		Data that can be passed from the client-side.
+	 @param aReplySlot	Identifies which message argument to use for the reply.
+	 @param aMessage	Encapsulates a client request.
+	 */
+	void DoSelectPinL(const TInputDetails& aDetail, const TDesC8& aBuffer, TInt aReplySlot, const RMessagePtr2& aMessage);
+	void DoIdentifyPinL(const TInputDetails& aDetail, const TDesC8& aBuffer, TInt aReplySlot, const RMessagePtr2& aMessage);
+	void DoInfoPinL(const TDesC8& aBuffer, TInt aReplySlot, const RMessagePtr2& aMessage);
+public: 		// from MEikSrvNotifierBase2
+	void DoStartL( const TDesC8& aBuffer, TInt aReplySlot, const RMessagePtr2& aMessage );
+
+private:     	// from MEikSrvNotifierBase2
+	void Release();
+	TNotifierInfo RegisterL();
+	TNotifierInfo Info() const;
+	
+	virtual void StartL( const TDesC8& aBuffer, TInt aReplySlot, const RMessagePtr2& aMessage );
+	virtual TPtrC8 StartL( const TDesC8& aBuffer );
+	
+	void Cancel();
+	TPtrC8 UpdateL( const TDesC8& aBuffer );
+
+private:
+	RFs iFs;
+	TNotifierInfo iInfo;
+	};
+
+#endif // __TPINPLUGINDLG_H__