telephonyserverplugins/common_tsy/commontsy/inc/mmpacket/Cmmpacketcontexttsy.h
changeset 0 3553901f7fa8
child 24 6638e7f4bd8f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/telephonyserverplugins/common_tsy/commontsy/inc/mmpacket/Cmmpacketcontexttsy.h	Tue Feb 02 01:41:59 2010 +0200
@@ -0,0 +1,897 @@
+/*
+* 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 "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 CMMPACKETCONTEXTTSY_H
+#define CMMPACKETCONTEXTTSY_H
+
+//  INCLUDES
+#include "Cmmpacketservicetsy.h"
+#include "cmmpacketcontextgsmwcdmaext.h"
+#include "Cmmpacketqostsy.h"
+
+// FORWARD DECLARATIONS
+class CMmTsyReqHandleStore;
+class CMmPacketQoSTsy;
+class CMmPacketServiceTsy;
+class CMmPacketContextGsmWcdmaExt;
+
+// CLASS DECLARATION
+
+/**
+*  CMmPacketContextTsy contains GPRS context related functionality. 
+*/
+NONSHARABLE_CLASS( CMmPacketContextTsy ) : public CSubSessionExtBase
+    {
+    public: // Constructor and destructor    
+
+        /**
+         * The type of the context
+         */
+    	enum TPacketContextType
+            {
+            /**
+             * Packet Context
+             */
+            EContextTypePacketContext,
+            /**
+             * MBMS Context
+             */
+            EContextTypeMBMS
+            };    
+
+        /**
+         * NewL method is used to create a new instance of CMmPacketContextTsy
+         * class.
+         * 
+         *                  
+         * @param aMmPacketService Pointer to the Packet Service object
+         * @param aHostCID Name of existing context
+         * @param aName Context name
+         * @param aMessageManager Pointer to the Message Manager object
+         * @param aProxyId Proxy id
+         */
+        static CMmPacketContextTsy* NewL
+                (
+                CMmPacketServiceTsy* const aMmPacketService,
+                const TInfoName& aHostCID,
+                const TDes& aName,
+                const TUint8 aProxyId = 0x00
+                );
+
+        /**
+         * Destructor
+         */
+        ~CMmPacketContextTsy();
+
+        /**
+         * Initialisation method that is called from ETel Server.
+         *         
+         *
+         */
+        virtual void Init();
+
+        /**
+         * TRAP's all CMmPacketContextTsy related MM API requests in case that
+         * they fail. This method functions only as a centralized TRAP for the
+         * DoExtFuncL method that does the actual mapping of IPC number to
+         * TSY method call.
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle from ETel server
+         * @param aIpc IPC number of the request
+         * @param aPackage Reference to the input parameters.
+         * @return KErrNone/KErrNotSupported
+         */
+        virtual TInt ExtFunc( const TTsyReqHandle aTsyReqHandle, 
+            const TInt aIpc, const TDataPackage& aPackage );    
+
+        /**
+         * Returns request mode for given IPC number
+         *          
+         *         *         
+         * @param aIpc IPC number of the request
+         * @return CTelObject::TReqMode Request mode
+         */
+        virtual CTelObject::TReqMode ReqModeL( const TInt aIpc );
+
+        /**
+         * Returns number of slots to be used for a given IPC
+         *          
+         *         *         
+         * @param aIpc IPC number of the request
+         * @return TInt Number of slots for this request
+         */
+        virtual TInt NumberOfSlotsL( const TInt aIpc );
+
+        /**
+         * Cancels request that's IPC number and request handle are given as
+         * parameters
+         *         
+         *   
+         * @param aIpc: IPC number of the request
+         * @param aTsyReqHandle Request handle from ETel server
+         * @return KErrNone/KErrNotSupported
+         */
+        virtual TInt CancelService( const TInt aIpc, 
+            const TTsyReqHandle aTsyReqHandle );
+
+        /**
+         * Register given notification
+         *         
+         *
+         * @param aIpc IPC number of the request
+         * @return TInt Result of the request
+         */
+        virtual TInt RegisterNotification( const TInt aIpc );
+
+        /**
+         * Deregister given notification
+         *         
+         *
+         * @param aIpc IPC number of the request
+         * @return TInt Result of the request
+         */
+        virtual TInt DeregisterNotification( const TInt aIpc );
+    
+        /**
+         * Create new QoS object and returns a pointer to it
+         *         
+         *
+         * @return aName On return contains the name of opened object
+         * @return CTelObject* Opened object 
+         */
+        virtual CTelObject* OpenNewObjectL( TDes& aNewName );
+
+        /**
+         * Return a pointer to QoS if it exists
+         *         
+         *
+         * @param aName Object name that should be opened
+         * @return CTelObject* Opened object 
+         */
+        virtual CTelObject* OpenNewObjectByNameL( const TDesC& aName );
+
+        /**
+         * Complete the context initialisation
+         *         
+         *
+         * @param aResult Result of the request
+         */
+        void CompleteInitialiseContext( const TInt aResult );
+
+        /**
+         * Complete the context activation.
+         *         
+         *
+         * @param aResult Result of the request
+         */
+        void CompleteActivate( const TInt aResult );
+
+        /**
+         * Complete the context deactivation
+         *         
+         *
+         * @param aResult Result of the request
+         */
+        void CompleteDeactivate( const TInt aResult );
+ 
+        /**
+         * Complete the context delete
+         *         
+         *
+         * @param aResult Result of the request
+         */
+        void CompleteDelete( const TInt aResult );
+
+        /**
+         * Complete the config changed notification
+         *         
+         *
+         * @param aResult Result of the request
+         */
+        void CompleteNotifyConfigChanged();
+        
+        /**
+         * Complete the connection speed change notification
+         *         
+         *
+         * @param aConnectionSpeed Contains connections speed
+         */
+        virtual void CompleteNotifyConnectionSpeedChange(
+            TInt const aConnectionSpeed );
+        
+        /**
+         * Complete the status change notification
+         *         
+         *
+         * @param aContextStatus Contains status of the context
+         */
+        void CompleteNotifyStatusChange(
+            const RPacketContext::TContextStatus aContextStatus );
+        
+        /**
+         * Complete the context configuration
+         *         
+         *
+         * @param aResult Result of the request
+         * @param aIsAddMediaAuthorizationCalled indicator to check if
+         *        Response is for AddMediaAuthorizationL
+         */
+        void CompleteSetConfig( const TInt aResult,
+                        TBool aIsAddMediaAuthorizationCalled = EFalse );
+
+        /**
+         * Complete the get data volume transferred request.
+         *         
+         *
+         * @param aResult Result of the request
+         */
+        void CompleteGetDataVolumeTransferred( const TInt aResult );
+
+        /**
+         * Sets the amount of data transmitted & received over the
+         * airlink since the context was activated. 
+         *         
+         *
+         * @param aResult Contains context configuration
+         * @param dataVolume Contains transmitted & received data
+         */
+        virtual void SetDataVolume( const TInt aResult,
+            RPacketContext::TDataVolume dataVolume );
+
+        /**
+         * Set the last error cause.
+         *         
+         *
+         * @param aErrorCause Contains the last error cause
+         */
+        void SetLastErrorCause( const TInt aErrorCause );
+
+        /**
+         * Get the context status.
+         *         
+         *
+         * return RPacketContext::TContextStatus
+         */
+        RPacketContext::TContextStatus ContextStatus() const;
+
+        /**
+         * Suspend the context. Called from Packet Service Tsy to notify client
+         *         
+         *
+         */
+        void ContextSuspended();
+
+        /**
+         * Resume the suspended context. This function is called from 
+         * Packet Service Tsy to notify client
+         *         
+         *
+         */
+        void ContextResumed();
+
+        /**
+         * Return a pointer to CMmPacketContextGsmWcdmaExt
+         *         
+         *
+         * @return Pointer to extension
+         */
+        virtual CMmPacketContextGsmWcdmaExt* PacketContextGsmWcdmaExt() const;
+
+        /**
+         * Return a pointer to CMmPacketQoSTsy
+         *         
+         *
+         * @return CMmPacketQoSTsy* Pointer 
+         */
+        CMmPacketQoSTsy* PacketQoSTsy() const;
+
+        /**
+         * Remove a pointer to CMmPacketQoSTsy
+         *         
+         *
+         */
+        void RemoveQoS();
+
+        /**
+         * Check if this is a dial-up context, otherwise EFalse.
+         *         
+         *
+         * @param aContextName Contains the name of this context
+         * @return TBool ETrue/EFalse
+         */
+        TBool IsDialUpContext( const TInfoName* const aContextName = NULL
+            ) const;
+
+        /**
+         * Return the HostCID class member
+         *         
+         *
+         * @return TInfoName iHostCID containing host context name or none
+         */
+        TInfoName HostCID() const;
+
+        /**
+         * Completes contecxt Modification to client.
+         *         
+         *
+         * @param aResult Result of the request
+         */
+        void CompleteModifyActiveContext( const TInt aResult );
+
+        /**
+         * Return the contextName
+         *         
+         *
+         * @return TInfoName iContextName containing context name
+         */
+        TInfoName ContextName() const;
+
+        /**
+         * Reset the externally created dial-up context.
+         *         
+         *
+         */
+        void ResetDialUpContext();
+        
+        /** 
+         * C++ default constructor.
+         */
+        CMmPacketContextTsy();
+        
+
+        /**
+         * Returns type of context based on context name
+         *
+         * @param aInfoName Name of the context
+         * @return TInt Type of context
+         */
+        virtual TPacketContextType ContextType() const;
+
+#ifdef SYMBIAN_ADAPTIVE_TCP_RECEIVE_WINDOW
+        /**
+         * Completes connection information change notification to the client and
+         * updates new connection info to CTSY cache if information is changed.
+         *         
+         *
+         * @param aDataPackage: new connection information
+         */
+        void CompleteNotifyConnectionInfoChange(
+            TConnectionInfoBase* const aInfo );    
+#endif // SYMBIAN_ADAPTIVE_TCP_RECEIVE_WINDOW
+
+#ifdef REQHANDLE_TIMER
+        /**
+         * Call the needed complete method due the timer expiration.
+         *         
+         *
+         * @param aReqHandleType  
+         * @param aError                      
+         */
+        void Complete
+                (
+                const TInt aReqHandleType,
+                const TInt aError 
+                );
+#endif //REQHANDLE_TIMER
+
+    private: // New functions
+      
+
+    
+        /**
+         * Class attributes are created in ConstructL.
+         */
+        void ConstructL();
+
+        /**
+         * Initialises extension modules for CMmPacketContextTsy.
+         * 
+         *                
+         */
+        void InitModulesL();
+
+        /**
+         * Initialise miscellaneous internal attributes.
+         * 
+         *                
+         */
+        void InitInternalAttributes();
+        
+        /**
+         * TRAP's all CMmPacketContextTsy related MM Packet API requests in 
+         * case that they fail. This method functions only as a centralized
+         * TRAP for the DoExtFuncL method that does the actual mapping of IPC 
+         * number to TSY method call.
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle from ETel server
+         * @param aIpc IPC number of the request
+         * @param aPackage Reference to the input parameters.
+         * @return KErrNone/KErrNotSupported
+         */
+        TInt DoExtFuncL( const TTsyReqHandle aTsyReqHandle,
+            const TInt aIpc, const TDataPackage& aPackage );
+
+        /**
+         * Initialise a context
+         *
+         * @param aDataChannel to be populated and returned to client  
+         * @return TInt Success/failure value
+         */
+        TInt InitialiseContextL(RPacketContext::TDataChannelV2* aDataChannel);
+        
+        /**
+         * Activate a context
+         *         
+         *
+         * @return TInt Success/failure value
+         */
+        TInt ActivateL();
+
+        /**
+         * Deactivate a context
+         *         
+         *
+         * @return TInt Success/failure value
+         */
+        TInt DeactivateL();
+
+        /**
+         * Deletes a context
+         *         
+         *
+         * @return TInt Success/failure value
+         */
+        TInt DeleteL();
+    
+        /**
+         * Get the context configuration info
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle
+         * @return aConfig Contains Context configuration info on return
+         * @return TInt Success/failure value
+         */
+        TInt GetConfig( const TTsyReqHandle aTsyReqHandle,
+            TPacketDataConfigBase* const aConfig );
+
+        /**
+         * Get the current connection speed availability
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle
+         * @return aRate Contains connection speed on return
+         * @return TInt Success/failure value
+         */
+        TInt GetConnectionSpeed( const TTsyReqHandle aTsyReqHandle,
+            TUint* const aRate );
+
+        /**
+         * Get the data volume transferred
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle
+         * @return aVolume Contains data volume transferred on return
+         * @return TInt Success/failure value
+         */
+        TInt GetDataVolumeTransferredL( const TTsyReqHandle aTsyReqHandle,
+            RPacketContext::TDataVolume* const aVolume );
+
+        /**
+         * Get the last error cause occurred
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle
+         * @return aError Contains last error value on return
+         * @return TInt Success/failure value
+         */
+        TInt GetLastErrorCause( const TTsyReqHandle aTsyReqHandle,
+            TInt* const aError );
+
+        /**
+         * Get the QoS profile name
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle
+         * @return aQoSProfile Contains QoS profile name on return
+         * @return TInt Success/failure value
+         */
+        TInt GetProfileName( const TTsyReqHandle aTsyReqHandle,
+            TInfoName* const aQoSProfile );
+
+        /**
+         * Get the current status of the context
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle
+         * @return aContextStatus Contains current status of the context
+         * @return TInt KErrNone
+         */
+        TInt GetStatus( const TTsyReqHandle aTsyReqHandle,
+            RPacketContext::TContextStatus* const aContextStatus );
+
+        /**
+         * Allows clients to be notified of any change in context 
+         * configuration. Allows a client to be notified whenever a change in 
+         * the configuration of the current context is detected and passes 
+         * back the updated  configuration. Note that once the notification 
+         * completes, the clients must then re-post the notification if they 
+         * wish to continue receiving the notification.
+         *         
+         *
+         * @return aConfig Contains context configuration info on return
+         * @return TInt Success/failure value
+         */
+        TInt NotifyConfigChanged( TPacketDataConfigBase* const aConfig );
+
+        /**
+         * Allows clients to be notified of any change in the connection speed
+         *
+         *         
+         * @return aRate Contains the connection speed on return
+         * @return TInt Success/failure value
+         */
+        TInt NotifyConnectionSpeedChange( TUint* const aRate );
+
+        /**
+         * Allows clients to be notified of any change in the context status
+         *
+         *         
+         * @return aContextStatus Contains the status of the context on return
+         * @return TInt Success/failure value
+         */
+        TInt NotifyStatusChange( RPacketContext::TContextStatus* const
+            aContextStatus );
+
+        
+        /**
+         * Set context configuration
+         *
+         *         
+         * @param aConfig Contains context configuration
+         * @return TInt Success/failure value.
+         */
+        TInt SetConfigL( TPacketDataConfigBase* const aConfig );
+
+        /**
+         * Overloads original ReqCompleted for logging purposes
+         *
+         *         
+         * @param aTsyReqHandle TSY request handle
+         * @param aError error value
+         */
+        virtual void ReqCompleted( const TTsyReqHandle aTsyReqHandle,
+            const TInt aError );
+        
+        /**
+         * Set/Modify packet filter(s) to secondary context
+         *
+         *         
+         * @param aTsyReqHandle TSY request handle
+         * @param aPacketFilter Contains packet filter(s) info
+         * @return TInt Success/failure value.
+         */
+        TInt AddPacketFilterL( const TTsyReqHandle aTsyReqHandle,
+            TDes8* const aPacketFilter );
+#ifdef USING_CTSY_DISPATCHER
+        /**
+         * Remove packet filter from context
+         *
+         *         
+         * @param aID Contains packet filter ID to be removed
+         * @return TInt Success/failure value.
+         */
+        TInt RemovePacketFilter( TInt* aID );
+#else
+        /**
+         * Remove packet filter from context
+         *
+         *         
+         * @param aTsyReqHandle TSY request handle
+         * @param aID Contains packet filter ID to be removed
+         * @return TInt Success/failure value.
+         */
+        TInt RemovePacketFilter( const TTsyReqHandle aTsyReqHandle, TInt* aID );
+#endif
+        /**
+         * Method invokes MS-initiated modification of an active context in the 
+         * network
+         *         
+         *
+         * @return TInt Success/failure value.
+         */
+        TInt ModifyActiveContextL();
+
+
+        /**
+         * Enumerate context packet filters
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle
+         * @param aCount Contains packet filter count in return
+         * @return KErrNone
+         */
+        TInt EnumeratePacketFilters( const TTsyReqHandle aTsyReqHandle,
+            TInt *aCount );
+
+        /**
+         * Gets filter info specified by index
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle
+         * @param aIndex of the wanted filter index
+         * @param aPacketFilterInfo Contains packet filter information
+         * @return KErrNone
+         */
+        TInt GetPacketFilterInfo( const TTsyReqHandle aTsyReqHandle,
+            TInt* aIndex, TPacketBase* aPacketFilterInfo );
+
+        /**
+         * Get the DNS info for Etel side request
+         *         
+         *
+         * @param aTsyReqHandle TSY request handle
+         * @param aDnsInfo Contains DNS information in return
+         * @return KErrNone.
+         */
+        TInt GetDnsInfo( const TTsyReqHandle aTsyReqHandle,
+            TDes8* const aDnsInfo );
+
+          /**
+         * Adds authorization params 
+         *         
+         *
+         * @param aTsyReqHandle request handle
+         * @param aMediaAuthorization params to be added
+         * @return KErrNone or error code
+         */     
+        TInt AddMediaAuthorizationL( const TTsyReqHandle aTsyReqHandle,
+        	TDes8* aMediaAuthorization );
+        
+        /**
+         * Removes authorization params 
+         *         
+         *
+         * @param aTsyReqHandle request handle
+         * @param aMediaAuthorization params to be removed
+         * @return KErrNone
+         */  
+        TInt RemoveMediaAuthorization( const TTsyReqHandle aTsyReqHandle,
+         RPacketContext::TAuthorizationToken* const aAuthorizationToken );
+            
+#ifdef SYMBIAN_ADAPTIVE_TCP_RECEIVE_WINDOW
+        /**
+         * Get current connection information. 
+         *         
+         *
+         * @param aTsyReqHandle request handle
+         * @param aInfo configuration info object that will be filled by TSY
+         * @return KErrNone
+         */  
+        TInt GetConnectionInfo( const TTsyReqHandle aTsyReqHandle,
+            TConnectionInfoBase* const aInfo );
+          
+        /**
+         * Notify client when connection information changes.
+         *         
+         *
+         * @param aInfo configuration info object that will be filled by TSY
+         * @return KErrNone
+         */              
+        TInt NotifyConnectionInfoChange( TConnectionInfoBase* const aInfo );            
+           
+        /**
+         * Fill connection info structure. 
+         *         
+         *
+         * @param aInfo configuration info object that will be filled by TSY
+         * @return KErrNone or KErrNotFound
+         */              
+        TInt FillConnectionInfo( TConnectionInfoBase* const aInfo );                              
+#endif // SYMBIAN_ADAPTIVE_TCP_RECEIVE_WINDOW
+
+#ifdef REQHANDLE_TIMER
+
+        /**
+         * Choose the type of response, automatic or common.
+         * 
+         *  
+         * @param aReqHandleType
+         * @param aTsyReqHandle                         
+         */
+        void SetTypeOfResponse( const TInt aReqHandleType, 
+                const TTsyReqHandle aTsyReqHandle );
+
+#endif //REQHANDLE_TIMER
+
+    public: //Data
+    
+        // TPacketContextRequestTypes enumerates indexes to Packet's request
+        // handle table. Request handles are stored there while waiting for 
+        // completion of the request.
+        enum TPacketContextRequestTypes
+            {
+            EMultimodePacketContextReqHandleUnknown,
+            EMultimodePacketContextInitialiseContext,
+            EMultimodePacketContextActivate,
+            EMultimodePacketContextDeactivate,
+            EMultimodePacketContextDelete,
+            EMultimodePacketContextNotifyConfigChanged,
+            EMultimodePacketContextNotifyConnectionSpeedChange,
+            EMultimodePacketContextNotifyStatusChange,
+            EMultimodePacketContextSetConfig,
+            EMultimodePacketContextGetDataVolumeTransferred,
+            EMultimodePacketContextGetPacketFilterInfo,
+            EMultimodePacketContextEnumeratePacketFilters,
+            EMultimodePacketContextAddPacketFilter,
+            EMultimodePacketContextRemovePacketFilter,
+            EMultimodePacketContextModifyActiveContext,
+            EMultimodePacketContextNotifyConfigChanged99,
+            EMultimodePacketContextAddMediaAuthorization,
+#ifdef SYMBIAN_ADAPTIVE_TCP_RECEIVE_WINDOW
+            EMultimodePacketContextNotifyConnectionInfoChange,
+#endif // SYMBIAN_ADAPTIVE_TCP_RECEIVE_WINDOW
+            // Max number of requests
+            // ADD NEW REQUESTS BEFORE THIS!
+            EMaxNumOfPacketContextRequests
+
+            };
+
+    private: // Data
+
+        /**
+         * Req handle type
+         */        
+        TPacketContextRequestTypes iReqHandleType;
+
+        /**
+         *  Pointer to the Req handle store
+         *  Own.        
+         */        
+        CMmTsyReqHandleStore* iTsyReqHandleStore;
+        
+        /**
+         *  Table for packet context request handles
+         */        
+        TTsyReqHandle iPacketContextReqHandles[EMaxNumOfPacketContextRequests];
+        
+        /**
+         *  Pointer to the Packet Service TSY
+         *  Not own.        
+         */
+        CMmPacketServiceTsy* iMmPacketService;                                                
+        
+        /**
+         *  Pointer to the gsm extension
+         */        
+        CMmPacketContextGsmWcdmaExt* iMmPacketContextGsmWcdmaExt;                                                
+
+        /**
+         *  Pointer to the QoS Profile
+         *  Not own.        
+         */
+        CMmPacketQoSTsy* iQoSProfile;                                                
+
+        /**
+         *  Notify Config Changed
+         *  Not own.        
+         */
+        TPacketDataConfigBase* iRetNotifyConfig;
+        
+        /**
+         *  Notify Config Changed
+         *  Not own.        
+         */        
+        TPacketDataConfigBase* iRetNotifyConfig2;
+
+        /**
+         *  Notify Connection Speed Change
+         *  Not own.        
+         */
+        TUint* iRetNotifyConnectionSpeed;
+        
+        /**
+         *  Notify Connection Speed
+         */        
+        TUint iNotifyConnectionSpeed;
+
+        /**
+         *  Connection Speed
+         */
+        TUint iConnectionSpeed;                                             
+
+        /**
+         *  Notify Context Status Change
+         *  Not own.        
+         */
+        RPacketContext::TContextStatus* iRetNotifyStatus;                                               
+
+        /**
+         * Context status   
+         */
+        RPacketContext::TContextStatus iContextStatus;
+
+        /**
+         *  Get Data Volume Transferred
+         *  Not own.        
+         */
+        RPacketContext::TDataVolume* iRetDataVolume;                                                
+
+        /**
+         *  Data Volume Transferred
+         */
+        RPacketContext::TDataVolume iDataVolume;                                                
+
+        /**
+         *  QoS Profile name
+         */
+
+        TInfoName iQoSProfileName;                                                
+
+        /**
+         *  Context name      
+         */
+
+        TInfoName iContextName;                                                
+
+        /**
+         * Proxy Id       
+         */
+
+        TUint8 iProxyId;                                                
+
+        /**
+         * Context status before suspending       
+         */
+
+        RPacketContext::TContextStatus iContextStatusBeforeSuspending;        
+
+        /**
+         *  Last error cause      
+         */
+
+        TInt iLastErrorCause;       
+
+        /**
+         *  Is this Dial-Up Context    
+         */
+        TBool iIsDialUpContext;
+
+        /**
+         *  Name of existing context      
+         */
+        TInfoName iHostCID;
+        
+        /**
+         *  Connection information received from LTSY.     
+         */ 
+        RPacketContext::TConnectionInfoV1 iConnectionInfo;
+           
+        /**
+         *  Pointer to connection info held by client, to be populated when
+         *  notification request is completed.
+         *  Not own.        
+         */            
+        TConnectionInfoBase* iRetNotifyConnectionInfo;       
+    };
+
+#endif // CMMPACKETCONTEXTTSY_H
+   
+// End of File