telephonyserverplugins/simtsy/inc/CSimPhone.h
author ivan.fildichev@opencode.com
Thu, 04 Nov 2010 20:30:45 +0200
branchopencode
changeset 85 96b4f933d69a
parent 24 6638e7f4bd8f
permissions -rw-r--r--
Bugfixes and added new tests

// Copyright (c) 2001-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:
// This file contains the definitions of the Simulator TSY phone class.
// 
//

/**
 @file
 @internalAll
*/

#ifndef __SIMPHONE_H__
#define __SIMPHONE_H__

#include <f32file.h>
#include <et_phone.h>
#include "CSimLine.h"
#include "CSimDataLine.h"
#include "CSimVoiceLine.h"
#include "csimtimer.h"
#include "SimConstants.h"
#include "CSimPhoneSecurity.h"
#include "CSimPhoneUSimApp.h"
#include "CSimReduceTimers.h"
#include "CSimPhoneSmartCardApp.h"
#include "CSimPhoneInitialise.h"
#include "CSimPhoneIMSAuth.h"
#include "CSimUsimR6.h"

#include <etelmm.h>
#include <etelmmerr.h>
#include <etelpckt.h>
#include <etelsat.h>
#include <pcktcs.h>
#include "SimTsy.h"

// Macro to create an extended error code.
#define EXTENDEDERROR(aNormal,aExtended)	((aExtended << 16) | (aNormal & 0x0000ffff))

// Timer Values
const TInt KSetCallProcessingSuspendStateTimeout=1;

// Panics
enum TSimPanic
	{
	ELineNotPreInstantiated,
	ESubsessionNotPreInstantiated,
	ECallStatusUnknownIllegal,
	ETimeOutEventActionFailed,
	EIllegalConfigFileIdentifier,
	ENotificationAlreadyPending,
	EIllegalStateInconsistancy,
	EIllegalAnswerNextIncomingCallInconsistancy,
	EIllegalNoCallObjectAssignedForNextIncomingCall,
	EPhoneModeUnknownIllegal,
	ENetworkModeUnknownIllegal,
	EIllegalHexCharacterInConfigFilePdu,
	EIllegalOddNumberOfCharactersInConfigFilePdu,
	EIllegalSmsRxEvent,
	EIllegalSmsTxEvent,
	EPhonebookNameOrNumberTooLarge,
	EOwnNumberNameOrNumberTooLarge,
	EIllegalCallNotRegisteredWithLine,
	EIlegalValueForSmsExpectedErrorInConfigFile,
	ENotificationReqAlreadyOutstanding,
	EIllegalCallBackId,
	ECommWriterNotConstructed,
	ECommReaderNotConstructed,
	EVoiceCallIllegalStatus,
	ECallEventIllegal,
	EIllegalCancelRequest,
	EIllegalDtmfEvent,
	EIllegalDtmfReq,
	EIllegalVoiceCallEvent,
	EPacketMSClassUnKnown,
	EOjectNotConstructed,
	EConstraintsOverlapping,
	EMobileSmsMessagingPhoneNotSetToAReceiveMode,
	EFailedToDefineProperty,
	EFailedToSetProperty,
	ETlsAlreadySet,
	ETlsNotSet,
	ECdmaModeRequired, 
	EGeneral,
	EUnableToDefineProperties,
	EInvalidParameterFormatInConfigFile,
	EIllegalAnswerRemoteHangupCallInconsistency,
	EIllegalNullPtrParameter
	};

GLREF_C void SimPanic(TSimPanic aPanicNumber, TInt aLineNumber = -1);

const TUint KDefaultNumberOfSlots=5;	// < Default number of slots that the ETel Server should allocate for buffered requests.

/**
* This class 'CSimPhone' is the Phone class for Simulator TSY.  
* The CSimPhone class main responsibility is to handle all the functionality associated 
* with the RPhone class in the Core API and the RMobilePhone class in the Multimode API.
* It will create and own most of the resources the phone will require during its session. 
* These include creating both voice and data lines, CConfigReader objects, CSimSysAgent objects,
* CSimSmsMessaging object, CSimPhoneStore object, CSimPhoneBook object, and CSimPacket object.
*
*/
class CSimCall;
class CSimVoiceLine;
class CSimSmsMessaging;
class CSimPhBkStore;
class CSimPhBkUSimStore;
class CSimONStore;
class CSimSignalStrength;
class CSimNetworkStatus;
class CSimIndicator;
class CSimBatteryCharger;
class CSimDtmf;
class CTestConfig;
class CTestConfigSection;
class CSimPacketService;
class CSimSat;
class CSimTimer;
class CSimCallBarring;
class CSimCallForwarding;
class CSimCallWaiting;
class CSimSmartCardEapManager;
class CSimSmartCardAuth;
class CSimPhone : public CPhoneBase
	{
public:
	static CSimPhone* NewL(CPhoneBase*& aPhoneBaseRef);
	CSimPhone(CPhoneBase*& aPhoneBaseRef);
	~CSimPhone();
//
	static void CloseObj(TAny* aObj);
	virtual CTelObject::TReqMode ReqModeL(const TInt aIpc);

// MTelObjectTSY pure virtual
	virtual TInt RegisterNotification(const TInt aIpc);
	virtual TInt DeregisterNotification(const TInt aIpc);
	virtual void Init();
	virtual CTelObject* OpenNewObjectByNameL(const TDesC& aName);
	virtual CTelObject* OpenNewObjectL(TDes& aNewName);

// MPhoneBaseTSY pure virtuals
	virtual TInt GetInfo(const TTsyReqHandle aTsyReqHandle, RPhone::TPhoneInfo* aPhoneNotifyInfo);
	virtual TInt NotifyCapsChange(const TTsyReqHandle aTsyReqHandle, RPhone::TCaps* aCaps);
	virtual TInt NotifyCapsChangeCancel(const TTsyReqHandle aTsyReqHandle);
	virtual TInt ControlledInitialisation(const TTsyReqHandle aTsyReqHandle);
	virtual TInt ControlledInitialisationCancel(const TTsyReqHandle aTsyReqHandle);
    virtual TInt NotifyModemDetected(const TTsyReqHandle aTsyReqHandle, RPhone::TModemDetection* aDetection);
    virtual TInt NotifyModemDetectedCancel(const TTsyReqHandle aTsyReqHandle);
    virtual TInt GetCaps(const TTsyReqHandle aTsyReqHandle,RPhone::TCaps* aCaps);
	virtual TInt GetStatus(const TTsyReqHandle aTsyReqHandle,RPhone::TStatus* aStatus);
	virtual TInt EnumerateLines(const TTsyReqHandle aTsyReqHandle,TInt*);
	virtual TInt GetLineInfo(const TTsyReqHandle aTsyReqHandle,TLineInfoIndex* aLineInfo);
	virtual TInt CancelService(const TInt aIpc,const TTsyReqHandle aTsyReqHandle);
	virtual TInt NumberOfSlotsL(const TInt aIpc);


// MSubSessionExtBaseTSY pure virtual
	virtual TInt ExtFunc(const TTsyReqHandle aTsyReqHandle,const TInt aIpc,const TDataPackage& aPackage);

	const CTestConfigSection* CfgFile();		// < Accessor function for the configuration file.
	const CTestConfigSection* DefaultCfgFile();		// < Accessor function for the default configuration file.

	CSimReduceTimers* GetReduceTimersSubject();

	RMobilePhone::TAID GetActiveUSim();
	TBool IsICCLocked();
	TBool IsPIN2Locked();
	TBool IsHiddenEnabled();
	RMobilePhone::TMobilePhoneSubscriberId GetImsi();

	void SecurityEvent(RMobilePhone::TMobilePhoneSecurityEvent aEvent);

	TInt FindActiveVoiceCall(CSimVoiceCall*& aCall);

	TInt ValidateChangeState(CSimLine* aOriginatingLine, RMobileCall::TMobileCallStatus aState);
	TInt ValidateChangeState(RPacketService::TStatus aState);

	TInt GetMultimodeCaps(const TTsyReqHandle aTsyReqHandle,TUint32* aCaps);
	TInt GetIccAccessCaps(const TTsyReqHandle aReqHandle, TUint32* aCaps);
	TInt GetCurrentMode(TTsyReqHandle aReqHandle,TDes8* aPckg1);
	void UpdateNetworkMode(RMobilePhone::TMobilePhoneNetworkMode aNetworkMode);
	
	TInt GetTestNumber(TInt& aTestNumber);	
	TInt SetTestNumberInUse(TInt aTestNumber);	
	inline RPhone::TMode Mode() const {return iMode; }

	RMobilePhone::TMobilePhoneNetworkMode NetworkMode();
	void SetTestNumberAndReadConfigurationFileL();

	// Methods added to allow indicator object to retrieve information
	// from other objects owned by the phone
	RMobilePhone::TMobilePhoneBatteryStatus BatteryStatus();
	RMobilePhone::TMobilePhoneRegistrationStatus RegistrationStatus();
	void CheckIndicatorNotification();

	// Simulated TSY version checking
	TInt iSimTsyVersion;
	// data  structures deriving from TMultimodeType (the majority of cases)
	TInt CheckSimTsyVersion(RMobilePhone::TMultimodeType& aDataStruct);
	// data  structures deriving from TPacketBase 
	TInt CheckSimTsyVersion(TPacketBase& aDataStruct);
	// data  structures deriving from TCallParams 
	TInt CheckSimTsyVersion(RCall::TCallParams& aDataStruct);
	// data  structures deriving from CBase (usually one-off cases)
	TInt CheckSimTsyVersion(RMobilePhone::CImsAuthorizationInfoV5& aDataStruct);
	TInt CheckSimTsyVersion(RPacketContext::CTFTMediaAuthorizationV3& aDataStruct);
	
	// Callback function invoked by the observer object
	void HandleTestNumberChangedL();
	TInt CheckConfigFile();
	
protected:
	void ConstructL();

private:

	void FindAndCreatePhBkStoresL();
	void CreateONStoreL();
	void InitPhoneStatus();
	TInt GetPhoneStoreInfo(TTsyReqHandle aReqHandle,TDes8* aPckg1,TDes16* aPckg2);
	TInt GetPhoneStoreInfo(TTsyReqHandle aReqHandle,TDes8* aPckg1,
								  RMobilePhone::TPhoneStoreNameAndIccType* aTable);
	TInt GetSubscriberInfo(TTsyReqHandle aReqHandle,TDes8* aPckg1);
	void GetPhoneIdAndCaps();
	TInt GetIdentityCaps(TTsyReqHandle aReqHandle, TUint32& aCaps);
	TInt GetPhoneId(TTsyReqHandle aReqHandle,RMobilePhone::TMobilePhoneIdentityV1* aPhoneId);

	TInt SetCallProcessingSuspendState(const TTsyReqHandle aReqHandle, const TBool* aSuspend);
	TInt SetCallProcessingSuspendStateCancel(const TTsyReqHandle aTsyReqHandle);
	
	// Service Table IPC support functionality
	TInt EnumerateAPNEntries(TTsyReqHandle aReqHandle, TUint32* aIndex);
	TInt GetAPNname(TTsyReqHandle aReqHandle, TUint32& aIndex, RMobilePhone::TAPNEntryV3Pckg& aRetrieved);
	TInt AppendAPNName(TTsyReqHandle aReqHandle, RMobilePhone::TAPNEntryV3Pckg& aEntry);
	TInt DeleteAPNName(TTsyReqHandle aReqHandle, TUint32& aIndex);
	TInt NotifyAPNListChanged(TTsyReqHandle aReqHandle);
	TInt SetAPNControlListServiceStatus(TTsyReqHandle aReqHandle, RMobilePhone::TAPNControlListServiceStatus& aAPNControlListServiceStatus);
	TInt GetAPNControlListServiceStatus(TTsyReqHandle aReqHandle, RMobilePhone::TAPNControlListServiceStatus& aAPNControlListServiceStatus);
	TInt NotifyAPNControlListServiceStatusChange(TTsyReqHandle aReqHandle, RMobilePhone::TAPNControlListServiceStatus& aAPNControlListServiceStatus);
	TInt GetServiceTable(TTsyReqHandle aReqHandle, RMobilePhone::TMobilePhoneServiceTable aTable, TDes8* aSst);	
	// Service Table utility functions
	void PopulateServiceTableL(TInt aMaxSupported, const TDesC8& aLookup, RMobilePhone::TMobilePhoneServiceTableV1** aTable);						
	void PopulateServiceTableV8L(const TDesC8& aLookup,RMobilePhone::TMobilePhoneServiceTableV8** aTableV8 );						
	TBool ServiceEnabled(RMobilePhone::TMobilePhoneServiceTableV1* aTable, TInt aOffset, TUint8 aModifier);
	TInt CopyServiceTable(RMobilePhone::TMobilePhoneServiceTableV1* aFrom, RMobilePhone::TMobilePhoneServiceTableV1* aTo);
	TInt CopyServiceTableV8(RMobilePhone::TMobilePhoneServiceTableV8* aFrom, RMobilePhone::TMobilePhoneServiceTableV8* aTo);

	void ReadConfigurationFileL();
	TInt NotifyModeChange(const TTsyReqHandle aTsyReqHandle, RMobilePhone::TMobilePhoneNetworkMode* aCaps);
	TInt NotifyModeChangeCancel(const TTsyReqHandle aTsyReqHandle);

	void TimerCallBackNetworkMode();
	TNotifyData iNotifyNetworkModeChange;
	TInt iNetworkModeIndex;

	struct TNetworkModeBundle
		{
		TInt iDuration;										//< Duration of dynamic caps value
		RMobilePhone::TMobilePhoneNetworkMode iNetworkMode;	//< Dynamic Caps value that will be maintained through period iDuration
		};
	CArrayFixFlat<TNetworkModeBundle>* iNetworkModeArray; //< List of Network Mode changes

	CPhoneBase*&								iPhoneBaseRef;
	TNotifyData									iAPNListNotify;
	TNotifyData									iAPNStatusNotify;

	RArray<RMobilePhone::TAPNEntryV3>			iAPNList;			//< Pointer to the object that holds the Access Point Name List
	const TInt 									iAPNServiceOffset;

// 	from the TMobilePhoneServiceTable enum
	RMobilePhone::TMobilePhoneServiceTableV1*	iUSIMServiceTable;  		//< USIM service table from active USIM application on UICC.
	RMobilePhone::TMobilePhoneServiceTableV8*	iUSIMServiceTableV8;  		//< USIM service table from active USIM application on UICC.
	RMobilePhone::TMobilePhoneServiceTableV1*	iUSIMEnabledServiceTable;  	//< USIM Enabled Services Table to be used in conjunction with the USIM Service 
	RMobilePhone::TMobilePhoneServiceTableV1*	iSIMServiceTable;  			//< SIM service table on SIM (or from GSM application on UICC).
	
	RFs											iFs;				//< Connection to file server for config file access
	CSimSmsMessaging* 							iSmsMessaging;		//< pointer to the SmsMessaging object
	CSimLine*									iActiveLine;		//< Pointer to the currently active line

	CSimVoiceLine*								iVoiceLine;			//< Pointer to the voice line
	CSimDataLine*								iDataLine;			//< Pointer to the Data line

	CSimSignalStrength*							iSignalStrength;	//< Pointer to the object that handles Signal Strength
	CSimNetworkStatus*							iNetworkStatus;		//< Pointer to the object that handles Network Information and Status
	CSimDtmf*									iDtmf;				//< Pointer to the object that handles DTMF transmission
	CArrayFixFlat<CSimPhBkStore*>*				iPhBkStores;
	CArrayFixFlat<CSimPhBkUSimStore*>*			iPhBkUSimStores;

	CSimONStore*								iONStore;
	
	CTestConfig*             					iConfigFile;        //< Pointer to the Configuration file reader
	CTestConfigSection*                         iConfigSection;     //< Pointer to the Configuration section for current test. 
	TBuf8<KMaxName>          					iSectionName;
	CSimSat*                 					iSat;               //< Pointer to the Sat object
	CSimPacketService*       					iPacketService;     //< Pointer to the Packet object
	CSimIndicator*           					iIndicator;         //< Pointer to the Indicator object
	CSimBatteryCharger*	     					iBatteryCharger;    //< Pointer to the Battery Charger object
	CSimPhoneSecurity*	     					iPhoneSecurity;     //< Pointer to the Phone Security object
	CSimPhoneUSimApp*	     					iPhoneUSimApp;      //< Pointer to the Phone USimApp object
	CSimPhoneSmartCardApp*   					iPhoneSmartCardApp; //< Pointer to the Phone SmartCardApp object
	CSimPhoneIMSAuth*        					iPhoneIMSAuth;      //< Pointer to the IMS Authorization/Authentication object
	CSimSmartCardAuth*       					iPhoneScAuth;       //< Pointer to the object used for SmartCardAuthenticate requests
	CSimSmartCardEapManager* 					iPhoneScEapMan;     //< Pointer to the Smart Card EAP sub-session object

	CSimReduceTimers*							iReduceTimers;      //< Pointer to the object used for reducing all simtsy timers; see KPSSimTsyTimersReduceTime
	CSimUsimR6* 								iUsimRelease6;   	//< Pointer to the object that handles USIM Release6 features
	
	RPhone::TModemDetection						iModemDetection;	//< Modem detection
	RPhone::TMode								iMode;				//< Phone mode
	RMobilePhone::TMobilePhoneNetworkMode		iNtwkMode;			//< current network mode

	struct TSimTsySubsriberId
	{
	RMobilePhone::TMobilePhoneSubscriberId		iIMSI;					//< Pointer to the subscriber ID
	TInt										iError;
	};
	TSimTsySubsriberId iSubscriberId;
	
	CSimCallBarring*							iCallBarring;
	CSimCallForwarding*							iCallForwarding;
	CSimCallWaiting*							iCallWaiting;
	CSimPhoneInitialise*						iSimPhoneInitialise;

	struct TSimTsyPhoneId
		{
		TBuf<RMobilePhone::KPhoneManufacturerIdSize> iManufacturerId;	//Manufacturer identity
		TBuf<RMobilePhone::KPhoneModelIdSize> iModelId;	//Model identity
		TBuf<RMobilePhone::KPhoneRevisionIdSize> iRevisionId;	//Revision identity
		TBuf<RMobilePhone::KPhoneSerialNumberSize> iSerialId;	//IMEI (or ESN) identity
		TInt iError;			//Error code for failure
		};
	
	TSimTsyPhoneId iPhoneId;
	TUint32 iPhoneIdCaps;

	// timer and callback classes for NetworkMode
	CSimTimer* iNetworkModeTimer;   								//< Timer for the Network Mode change simulation
	class CNetworkModeTimerCallBack : public MTimerCallBack
		{
	public:
		CNetworkModeTimerCallBack();
		void TimerCallBack(TInt /*aId*/);
		void SetHandle(CSimPhone* aPhone);
	private:
		CSimPhone *iPhone;
		};
	CNetworkModeTimerCallBack iTimerCallBackNetworkMode;


	// timer and callback classes for SetCallProcessingSuspendState
	CSimTimer* iSetCallProcessingSuspendStateTimer;
	class CSetCallProcessingSuspendStateTimerCallBack : public MTimerCallBack
		{
	public:
		CSetCallProcessingSuspendStateTimerCallBack();
		void TimerCallBack(TInt aId);
		void SetHandle(CSimPhone* aPhone, const TTsyReqHandle aHandle);
	private:
		CSimPhone *iPhone;
		TTsyReqHandle iHandle;
		};
	
	// Observer class monitoring test number property
	NONSHARABLE_CLASS(CSimTestNumberObserver) : public CActive
	    {
	public:
	    static CSimTestNumberObserver* NewL(CSimPhone& aSimPhone);
	    virtual ~CSimTestNumberObserver();
	        
	private:    // methods from CActive
	    virtual void RunL();
	    virtual void DoCancel();
	        
	private:
	    CSimTestNumberObserver(CSimPhone& aSimPhone);
	    void ConstructL();
	    void Start();
	    
	private:
	    CSimPhone& iSimPhone;   // Reference to sim phone object (owner object)
	    RProperty iProperty;   // Property describing the event we require notification of
	    };
	
private:
    CSetCallProcessingSuspendStateTimerCallBack iTimerCallBackSetCallProcessingSuspendState;
    CSimTestNumberObserver* iTestNumberObserver; 
	};

#endif