networkprotocolmodules/suplcontrolplaneprotocols/suplrrlpprotocol/inc/suplrrlpstatemachine.h
author hgs
Tue, 13 Jul 2010 12:25:28 +0100
changeset 48 81c9bee26a45
permissions -rw-r--r--
201025_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
48
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     1
// Copyright (c) 2006-2009 Nokia Corporation and/or its subsidiary(-ies).
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     2
// All rights reserved.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     7
//
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     8
// Initial Contributors:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    10
//
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    11
// Contributors:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    12
//
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    13
// Description:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    14
// csuplrrlpfsm.h
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    15
// This file defines the class for the RRLP protocol state machine.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    16
// 
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    17
//
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    18
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    19
/**
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    20
 @file
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    21
 @internalTechnology
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    22
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    23
*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    24
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    25
#ifndef __CSUPLRRLPFSM_H__
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    26
#define __CSUPLRRLPFSM_H__
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    27
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    28
#include <lbspositioninfo.h>
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    29
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    30
#include "rrlpmessagebase.h"
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    31
#include "rrlpmeasureposrequest.h"
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    32
#include "rrlpprotocolerror.h"
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    33
#include "suplpositioningprotocolfsm.h"
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    34
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    35
// Forwards
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    36
class CRrlpAssistanceData;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    37
class CRrlpAssistanceDataAck;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    38
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    39
/**  This class implementes the RRLP protocol.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    40
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    41
Only those messages and parameters required by SUPL for AGPS positioning
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    42
are supported. Optional parameters not related to AGPS are not implemented.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    43
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    44
@see CStateMachineBase
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    45
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    46
The class also implements a timer observer interface defined by MLbsCallbackTimerObserver
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    47
@see MLbsCallbackTimerObserver
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    48
*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    49
class CSuplRrlpFsm : public CSuplPositioningProtocolFsm, public MLbsCallbackTimerObserver
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    50
	{
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    51
public:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    52
	// Constructors
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    53
	IMPORT_C static CSuplRrlpFsm* NewL(MSuplPositioningProtocolFsmObserver& aObserver,RLbsAssistanceDataBuilderSet& aDataBuilder);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    54
	virtual ~CSuplRrlpFsm();
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    55
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    56
	// Methods derived from base class (must be implemented)
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    57
	IMPORT_C void ProcessPositioningMessage(CSuplPosPayload* aMessage);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    58
	IMPORT_C void CancelMachine(const TCancelSource& aCancelSource, TInt aReason);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    59
	IMPORT_C void AssistanceDataRequest(const TLbsAssistanceDataGroup& aMask);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    60
	IMPORT_C void LocationResp(TInt aReason, const TPositionInfoBase& aPosInfo);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    61
	IMPORT_C bool IsAssistDataRequestAllowed();
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    62
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    63
protected:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    64
	// CActive
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    65
	void RunL();
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    66
	void DoCancel();
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    67
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    68
private:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    69
	/** RRLP states (when used with SUPL)
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    70
	These identify the current state within the
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    71
	RRLP procedure.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    72
	*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    73
	enum TRrlpState
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    74
		{
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    75
		/** Not valid */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    76
		EStateNull,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    77
		/** Assistance Data Message received (more on the way)*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    78
		EStateAssitDataChunkRecvd,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    79
		/** Assitance Data Message received (no more assistance data messages on the way) */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    80
		EStateAssitDataAcknowledged,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    81
		/** Measure Position Request message received from the network */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    82
		EStateMeasureReqRecvd,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    83
		/** A positioning request has been sent to SUPL */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    84
		EStateRequestHandled,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    85
		/** A request for additional Assistance Data from LBS is sent to the network */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    86
		EStateMoreAssistDataRequested,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    87
		/** Location response sent to network */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    88
		EStateMeasureRespSent,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    89
		/** An error or a cancel has occured */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    90
		EStateErrorRecvd
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    91
		};
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    92
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    93
	/** Timer ID's
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    94
	 */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    95
	enum TTimerIds
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    96
		{
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    97
		EAssitanceDataChunk,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    98
		ERequest,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
    99
		EResponseDelay,
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   100
		EMeasureRequestWithAssistanceDataDelay
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   101
		};
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   102
private:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   103
	// Constructor
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   104
	CSuplRrlpFsm(MSuplPositioningProtocolFsmObserver& aObserver, RLbsAssistanceDataBuilderSet& aDataBuilder);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   105
	void ConstructL();
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   106
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   107
	// MLbsCallbackTimerObserver methods
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   108
	void OnTimerEventL(TInt aTimerId);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   109
	TInt OnTimerError(TInt aTimerId, TInt aError);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   110
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   111
	// Protocol Timers.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   112
	void StartAssitanceDataChunkTimer();
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   113
	void ReceivedAssistanceDataChunkTimer();
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   114
	void StartRequestTimer();   
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   115
	void ReceivedRequestTimer();
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   116
	void StartPosResultTimer(TTimeIntervalMicroSeconds aMicroSeconds); 
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   117
	void ReceivedPosResultTimer();
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   118
	// Other timers
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   119
	void StartMeasureRequestWithAssitanceDataTimer(TInt aTime);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   120
	void ReceivedMeasureRequestWithAssitanceDataTimer();
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   121
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   122
	// Handler functions
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   123
	void HandleAssistanceDataMessage(CRrlpAssistanceData* aData);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   124
	void HandleMeasurementPositionRequest(CRrlpMeasurePositionRequest* aData);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   125
	void HandleProtocolError(CRrlpProtocolError* aError);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   126
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   127
	// Others
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   128
	TBool TransistionTo(TRrlpState aState);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   129
	void TransistionToError(TInt aError);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   130
	void AddReference(CRrlpMessageBase& aMessage);
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   131
private:
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   132
	/** Current RRLP state
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   133
	*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   134
	TRrlpState iCurrentState;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   135
	TRrlpState iNextState;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   136
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   137
	/** Last reference number received
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   138
	*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   139
	TRrlpReference iLastReferenceNumber;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   140
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   141
	/** Timer in between RRLP messages
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   142
		(it is a protocol error when this timer expires and more assistance data is expected)
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   143
	*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   144
	static const TInt KAssistanceDataChunkTimeout; 
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   145
	CLbsCallbackTimer* iAssistanceDataChunkTimer;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   146
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   147
	/** Timer for RRLP Measure Position Request after Assitance Data message
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   148
		(it is not always a protocol error when this timer expires)
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   149
	*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   150
	const static TInt KRequestTimeout; 
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   151
	CLbsCallbackTimer* iRequestTimer;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   152
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   153
	/** Timer for overseeing that LBS responds within the expected delay
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   154
	    (the delay is specified in the RRLP Measure Position Request, this
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   155
	    timer lasts longer to give LBS's response a chance to arrive before expiry)
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   156
	*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   157
	const static TInt KResponseDelayAddition;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   158
	const static TInt KResponseDelayTimeout; 
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   159
	CLbsCallbackTimer* iResponseDelayTimer;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   160
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   161
	/** Timer for allowing assistance data to be processed by LBS if received
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   162
	    in the Measurement Request
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   163
	 */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   164
	const static TInt KMeasureRequestWithAssistanceDataDelay;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   165
	CLbsCallbackTimer* iMeasureRequestWithAssitanceDataDelayTimer;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   166
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   167
	/** Flag to show location request has been sent to LBS.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   168
	*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   169
	TBool iIsLocReqSentToLbs;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   170
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   171
	/** Location request quality.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   172
	*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   173
	TLbsNetPosRequestQuality iLocReqQuality;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   174
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   175
	/** Location request positioning method.
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   176
	*/
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   177
	TLbsNetPosRequestMethod iPosMethod;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   178
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   179
	/** Assistance data 
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   180
	 */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   181
	RLbsAssistanceDataBuilderSet& iAssistanceData;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   182
	
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   183
	/** Assistance data mask
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   184
	 */
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   185
	TLbsAssistanceDataGroup iAssistanceDataMask;
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   186
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   187
	};
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   188
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   189
#endif // __CSUPLRRLPFSM_H__
81c9bee26a45 201025_02
hgs
parents:
diff changeset
   190