telephonyserverplugins/ctsydispatchlayer/exportinc/mltsydispatchsiminterface.h
author William Roberts <williamr@symbian.org>
Wed, 28 Apr 2010 13:58:40 +0100
branchRCL_3
changeset 22 35fa72f4c306
parent 0 3553901f7fa8
child 24 6638e7f4bd8f
permissions -rw-r--r--
Remerge fix for Bug 1398

// Copyright (c) 2008-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 all the interfaces classes that can be implemented by
// the Licensee LTSY relating to Sim related features.
//




/**
 @file
 @internalAll 
*/


#ifndef MLTSYDISPATCHSIMINTERFACE_H_
#define MLTSYDISPATCHSIMINTERFACE_H_

#include <ctsy/ltsy/mltsydispatchinterface.h>
#include <etelmm.h>
#include <ctsy/rmmcustomapi.h>


class MLtsyDispatchSimGetApnControlListServiceStatus : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimGetApnControlListServiceStatusApiId = KDispatchSimFuncUnitId + 1;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneGetAPNControlListServiceStatus
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimGetApnControlListServiceStatusComp()
	 *
	 * Implementation of this interface should get the current Apn Control List Service status from the LTSY.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleGetApnControlListServiceStatusReqL() = 0;

	}; // class MLtsyDispatchSimGetApnControlListServiceStatus



class MLtsyDispatchSimDeleteApnName : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimDeleteApnNameApiId = KDispatchSimFuncUnitId + 2;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneDeleteAPNName
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimDeleteApnNameComp()
	 *
	 * Implementation of this interface should delete the given entry from the APN control list.
	 *
	 * @param aIndex The index of the entry to delete.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleDeleteApnNameReqL(TUint32 aIndex) = 0;

	}; // class MLtsyDispatchSimDeleteApnName



class MLtsyDispatchSimEnumerateApnEntries : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimEnumerateApnEntriesApiId = KDispatchSimFuncUnitId + 3;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneEnumerateAPNEntries
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimEnumerateApnEntriesComp()
	 *
	 * Implementation of this interface should enumerate the available APN names in the Access Control list.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleEnumerateApnEntriesReqL() = 0;

	}; // class MLtsyDispatchSimEnumerateApnEntries



class MLtsyDispatchSimChangeSecurityCode : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimChangeSecurityCodeApiId = KDispatchSimFuncUnitId + 4;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneChangeSecurityCode
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimChangeSecurityCodeComp()
	 *
	 * Implementation of this interface should allow a client to change a security code.
	 *
	 * @param aSecCode The security code to be changed.
	 * @param aPasswds The old and the new values of the security code.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleChangeSecurityCodeReqL(RMobilePhone::TMobilePhoneSecurityCode aSecCode,
			   								  const RMobilePhone::TMobilePhonePasswordChangeV1& aPasswds) = 0;

	}; // class MLtsyDispatchSimChangeSecurityCode



class MLtsyDispatchSimSetFdnSetting : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimSetFdnSettingApiId = KDispatchSimFuncUnitId + 5;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneSetFdnSetting
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimSetFdnSettingComp()
	 *
	 * Implementation of this interface should activate or deactivate the Fixed Dialling Numbers (FDN) service
	 * PIN2 must have been verified prior to changing the Fixed Dialling Numbers setting.
	 *
	 * @param aFdnSetting The FDN setting value.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleSetFdnSettingReqL(RMobilePhone::TMobilePhoneFdnSetting aFdnSetting) = 0;

	}; // class MLtsyDispatchSimSetFdnSetting



class MLtsyDispatchSimGetCustomerServiceProfile : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimGetCustomerServiceProfileApiId = KDispatchSimFuncUnitId + 6;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneGetCustomerServiceProfile
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimGetCustomerServiceProfileComp()
	 *
	 * Implementation of this interface should retrieve the whole Customer Service Profile file from LTSY.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleGetCustomerServiceProfileReqL() = 0;

	}; // class MLtsyDispatchSimGetCustomerServiceProfile



class MLtsyDispatchSimGetSubscriberId : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimGetSubscriberIdApiId = KDispatchSimFuncUnitId + 7;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneGetSubscriberId
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimGetSubscriberIdComp()
	 *
	 * Implementation of this interface should get the subscriber's identity as described by its IMSI from the LTSY.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleGetSubscriberIdReqL() = 0;

	}; // class MLtsyDispatchSimGetSubscriberId



class MLtsyDispatchSimAppendApnName : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimAppendApnNameApiId = KDispatchSimFuncUnitId + 8;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneAppendAPNName
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimAppendApnNameComp()
	 *
	 * Implementation of this interface should append the given entry to the end of the APN control list.
	 *
	 * @param aEntry The entry to append to the APN list.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleAppendApnNameReqL(const RMobilePhone::TAPNEntryV3& aEntry) = 0;

	}; // class MLtsyDispatchSimAppendApnName



class MLtsyDispatchSimGetActiveIccApplicationType : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimGetActiveIccApplicationTypeApiId = KDispatchSimFuncUnitId + 9;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMmTsySimGetICCType
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimGetActiveIccApplicationTypeComp()
	 *
	 * This handler is called by the CTSY to retrieve the current active ICC application type.
	 * Types are defined in MLtsyDispatchSimGetActiveIccApplicationType::TIccType.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	
	enum TIccType
	    {
	    EIccTypeSim2GGsm,
	    EIccTypeSim3G,
	    EIccTypeSimUnknown
	    };
	
	virtual TInt HandleGetActiveIccApplicationTypeReqL() = 0;

	}; // class MLtsyDispatchSimGetActiveIccApplicationType



class MLtsyDispatchSimSetIccMessageWaitingIndicators : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimSetIccMessageWaitingIndicatorsApiId = KDispatchSimFuncUnitId + 10;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneSetIccMessageWaitingIndicators
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimSetIccMessageWaitingIndicatorsComp()
	 *
	 * Implementation of this interface should set the message waiting indicators on the current ICC.
	 *
	 * @param aIndicators The message waiting indicators to set.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleSetIccMessageWaitingIndicatorsReqL(const RMobilePhone::TMobilePhoneMessageWaitingV1& aIndicators) = 0;

	}; // class MLtsyDispatchSimSetIccMessageWaitingIndicators



class MLtsyDispatchSimSetApnControlListServiceStatus : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimSetApnControlListServiceStatusApiId = KDispatchSimFuncUnitId + 11;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneSetAPNControlListServiceStatus
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimSetApnControlListServiceStatusComp()
	 *
	 * Implementation of this interface should set the status of the APN Control List Service.
	 *
	 * @param aStatus The service status to set.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleSetApnControlListServiceStatusReqL(RMobilePhone::TAPNControlListServiceStatus aStatus) = 0;

	}; // class MLtsyDispatchSimSetApnControlListServiceStatus



class MLtsyDispatchSimGetApnName : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimGetApnNameApiId = KDispatchSimFuncUnitId + 12;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneGetAPNname
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimGetApnNameComp()
	 *
	 * Implementation of this interface should get the APN entry from the APN list at the index specified.
	 *
	 * @param aIndex The index of the APN entry to get from LTSY.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleGetApnNameReqL(TUint32 aIndex) = 0;

	}; // class MLtsyDispatchSimGetApnName



class MLtsyDispatchSimSimRefreshDone : public MLtsyDispatchInterface
	{
public:
	
	static const TInt KLtsyDispatchSimSimRefreshDoneApiId = KDispatchSimFuncUnitId + 13;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMmTsySimRefreshDoneIPC
	 * request from the CTSY.
	 *
	 * It is a request call that has no complete.
	 *
	 *
	 * Implementation of this interface indicates to the LTSY the SIM refresh has finished.
	 *
	 *
	 * @param aError An error code relating to the result of the refresh.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleSimRefreshDoneReqL(TInt aError) = 0;

	}; // class MLtsyDispatchSimSimRefreshDone

class MLtsyDispatchSimGetServiceTable : public MLtsyDispatchInterface
	{
public:
	
	static const TInt KLtsyDispatchSimGetServiceTableApiId = KDispatchSimFuncUnitId + 14;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneGetServiceTable
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking CCtsyDispatcherCallback::CallbackSimGetServiceTableComp()
	 *
	 * Implementation of this interface should read the EFust or EFsst service tables as specified by aServiceTable.
	 *
	 * @param aServiceTable Specifies the service table to retrieve.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleGetServiceTableReqL(RMobilePhone::TMobilePhoneServiceTable aServiceTable) = 0;

	}; // class MLtsyDispatchSimGetServiceTable

class MLtsyDispatchSimGetIccMessageWaitingIndicators : public MLtsyDispatchInterface
	{
public:
	
	static const TInt KLtsyDispatchSimGetIccMessageWaitingIndicatorsApiId = KDispatchSimFuncUnitId + 15;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the EMobilePhoneGetIccMessageWaitingIndicators
	 * request from the CTSY.
	 *
	 * It is a request call that is completed by invoking CCtsyDispatcherCallback::CallbackSimGetIccMessageWaitingIndicatorsComp()
	 *
	 * Implementation of this interface should get the ICC message waiting indicators from the (U)SIM field EFmwis.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleGetIccMessageWaitingIndicatorsReqL() = 0;

	}; // class MLtsyDispatcSimGetIccMessageWaitingIndicators

class MLtsyDispatchSimSimLockActivate : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimSimLockActivateApiId = KDispatchSimFuncUnitId + 16;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomSimLockActivateIPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimSimLockActivateComp()
	 * 
	 * Implementation of this interface should send a SIM Lock Activation request.
	 *
	 * @param aPassword The password used for the SIM Lock activation.
	 * @param aLockNumber The lock number that defines SIM Lock types.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleSimLockActivateReqL(const TDesC& aPassword, RMmCustomAPI::TLockNumber aLockNumber) = 0;

	}; // class MLtsyDispatchSimSimLockActivate


class MLtsyDispatchSimSimLockDeActivate : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimSimLockDeActivateApiId = KDispatchSimFuncUnitId + 17;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomSimLockDeActivateIPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimSimLockDeActivateComp()
	 * 
	 * Implementation of this interface should send a SIM Lock Deactivation request. 
	 * 
	 * @param aPassword The password used for the SIM Lock deactivation.
	 * @param aLockNumber The lock number that defines SIM Lock types.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleSimLockDeActivateReqL(const TDesC& aPassword, RMmCustomAPI::TLockNumber aLockNumber) = 0;

	}; // class MLtsyDispatchSimSimLockDeActivate


class MLtsyDispatchSimGetAnswerToReset : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimGetAnswerToResetApiId = KDispatchSimFuncUnitId + 18;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomGetATRIPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimGetAnswerToResetComp()
	 * 
	 * Implementation of this interface should retrieve the answer to reset. 
	 *
	 * @param aAnswerToReset The answer to reset information which contains details of the request.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleGetAnswerToResetReqL(const TDesC8& aAnswerToReset) = 0;

	}; // class MLtsyDispatchSimGetAnswerToReset


class MLtsyDispatchSimGetSimCardReaderStatus : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimGetSimCardReaderStatusApiId = KDispatchSimFuncUnitId + 19;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomGetSimCardReaderStatusIPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimGetSimCardReaderStatusComp()
	 * 
	 * Implementation of this interface should retrieve the card reader status.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleGetSimCardReaderStatusReqL() = 0;

	}; // class MLtsyDispatchSimGetSimCardReaderStatus


class MLtsyDispatchSimGetSimAuthenticationEapSimData : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimGetSimAuthenticationEapSimDataApiId = KDispatchSimFuncUnitId + 20;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomGetSimAuthenticationDataIPC for 
 	 * Extensible Authentication Protocol Subscriber Identity Module authentication method
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimGetSimAuthenticationEapSimDataComp()
	 * 
	 * Implementation of this interface should retrieve Sim Authentication Data for EapSim authentication method.
	 *
	 * @param aRandomParameters The random parameters from the client.
	 * @param aRFStateInfo The RF state info.
	 * 
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleGetSimAuthenticationEapSimDataReqL(const TDesC8& aRandomParameters, TInt aRFStateInfo) = 0;

	}; // class MLtsyDispatchSimGetSimAuthenticationEapSimData

class MLtsyDispatchSimGetSimAuthenticationEapAkaData : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimGetSimAuthenticationEapAkaDataApiId = KDispatchSimFuncUnitId + 21;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomGetSimAuthenticationDataIPC for 
	 * Extensible Authentication Protocol UMTS Authentication and Key Agreement authentication method
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimGetSimAuthenticationEapAkaDataComp()
	 * 
	 * Implementation of this interface should retrieve Sim Authentication Data for EapAka authentication method.
	 *
	 * @param aRandomParameters The random parameters from the client.
	 * @param aAUTN The AUTN parameter. AUTN is an authentication value generated by
	 *        the Authentication Centre, which, together with the random parameters, authenticates the server to the peer, 128 bits.
	 * @param aRFStateInfo The RF state info.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 */
	virtual TInt HandleGetSimAuthenticationEapAkaDataReqL(const TDesC8& aRandomParameters, const TDesC8& aAUTN, TInt aRFStateInfo) = 0;

	}; // class MLtsyDispatchSimGetSimAuthenticationEapAkaData

class MLtsyDispatchSimPowerSimOff : public MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimPowerSimOffApiId = KDispatchSimFuncUnitId + 22;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomPowerSimOffIPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimPowerSimOffComp()
	 * 
	 * Implementation of this interface should send a Power SIM Off request to the APDU server.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 * 
	 * @see RMmCustomAPI::PowerSimOff()
	 */
	virtual TInt HandlePowerSimOffReqL() = 0;

	}; // class MLtsyDispatchSimPowerSimOff


class MLtsyDispatchSimPowerSimOn : virtual MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimPowerSimOnApiId = KDispatchSimFuncUnitId + 23;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomPowerSimOnIPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimPowerSimOnComp()
	 * 
	 * Implementation of this interface should send a Power SIM On request to the APDU server.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 * 
	 * @see RMmCustomAPI::PowerSimOn()
	 */
	virtual TInt HandlePowerSimOnReqL() = 0;

	}; // class MLtsyDispatchSimPowerSimOn


class MLtsyDispatchSimReadSimFile : virtual MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimReadSimFileApiId = KDispatchSimFuncUnitId + 24;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomReadSimFileIPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimReadSimFileComp()
	 * 
	 * Implementation of this interface should request to read full or partial contents of a 
	 * given SIM file. The path, size and offset for the requested SIM file are provided.
	 * 
	 *
	 * @param aPath The absolute file path of the SIM file in the file system of the SIM.
	 * see ETSI TS 131 102 Under "Files of USIM"
	 * @param aOffset The value of the Offset, the offset is related with the type of SIM file being read.
	 * @param aSize The amount of bytes to be read from the SIM file.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 * 
	 * @see RMmCustomAPI::ReadSimFile()
	 */
	virtual TInt HandleReadSimFileReqL(const TDesC8& aPath, TUint16 aOffset, TUint16 aSize) = 0;

	}; // class MLtsyDispatchSimReadSimFile


class MLtsyDispatchSimSendApduRequest : virtual MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimSendApduRequestApiId = KDispatchSimFuncUnitId + 25;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomSendAPDUReqIPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimSendApduRequestComp()
	 * 
	 * Implementation of this interface should pass the send APDU request to the baseband.
	 * 
	 * The service type, card reader number and application type is the address information 
	 * and the data is an envelope. The client side and baseband are responsible for the 
	 * consistency of the data buffer's content (i.e. they have to have an agreement on the contents).
	 * 
	 *
	 * @param aServiceType The value for the service type of the request.
	 * @param aCardReaderNumber The value for the card reader number of the request.
	 * @param aApplicationType The value for the application type of the request.
	 * @param aCommandData The transparent data to be conveyed to the Baseband.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 * 
	 * @see RMmCustomAPI::SendAPDUReq()
	 */
	virtual TInt HandleSimSendApduRequestReqL(TUint8 aServiceType, TUint8 aCardReaderNumber, TUint8 aApplicationType, const TDesC8& aCommandData) = 0;

	}; // class MLtsyDispatchSimSendApduRequest

class MLtsyDispatchSimSendApduRequestV2 : virtual MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimSendApduRequestV2ApiId = KDispatchSimFuncUnitId + 26;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomSendAPDUReqV2IPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimSendApduRequestV2Comp()
	 * 
	 * Implementation of this interface should pass the send APDU request to the baseband.
	 * 
	 * The client side and baseband are responsible for the consistency of the data buffer's content 
	 * (i.e. they have to have an agreement on the contents).
	 * 
	 *
	 * @param aCardReaderId The value for the card reader Id of the request.
	 * @param aCommandData The transparent data to be conveyed to the Baseband.
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 * 
	 * @see RMmCustomAPI::SendAPDUReq()
	 */
	virtual TInt HandleSimSendApduRequestV2ReqL(TUint8 aCardReaderId, const TDesC8& aCommandData) = 0;

	}; // class MLtsyDispatchSimSendApduRequest

class MLtsyDispatchSimSimWarmReset : virtual MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimSimWarmResetApiId = KDispatchSimFuncUnitId + 27;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomSimWarmResetIPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimSimWarmResetComp()
	 * 
	 * Implementation of this interface should handle the reqest for a SIM warm reset.
	 * 
	 * See ETSI TS 102 221 under "Reset procedures"
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 * 
	 * @see RMmCustomAPI::SimWarmReset()
	 */
	virtual TInt HandleSimWarmResetReqL() = 0;

	}; // class MLtsyDispatchSimSimWarmReset


class MLtsyDispatchSimSetSimMessageStatusRead : virtual MLtsyDispatchInterface
	{
public:

	static const TInt KLtsyDispatchSimSetSimMessageStatusReadApiId = KDispatchSimFuncUnitId + 28;

	/**
	 * The CTSY Dispatcher shall invoke this function on receiving the ECustomSetSimMessageStatusReadIPC
	 * request from the CTSY.
	 * 
	 * It is a request call that is completed by invoking
	 * CCtsyDispatcherCallback::CallbackSimSetSimMessageStatusReadComp()
	 * 
	 * No error code is returned to the ETel client - if no SMS message with matching timestamp is identified
	 * on the SIM then this error will be silently ignored.
	 *
	 * @param aTimestamp timestamp that uniquely identifies a particular message in the message store.
	 * @param aTimezoneDiff the difference, expressed in quarters of an hour, between the service centre local time and GMT
	 *
	 * @return KErrNone on success, otherwise another error code indicating the
	 * failure.
	 * 
	 * @see RMmCustomAPI::SetSimMessageStatusRead()
	 */
	virtual TInt HandleSetSimMessageStatusReadReqL(const TTime& aTimestamp, TInt aTimezoneDiff) = 0;

	}; // class MLtsyDispatchSimSetSimMessageStatusRead


#endif /*MLTSYDISPATCHSIMINTERFACE_H_*/