supl/locationsuplfw/gateway/src/epos_csuplsessionretryq.cpp
author hgs
Fri, 06 Aug 2010 19:34:22 +0530
changeset 39 3efc7a0e8755
child 42 02ba3f1733c6
permissions -rw-r--r--
201031
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
39
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* ==============================================================================
hgs
parents:
diff changeset
     3
*  Name        : epos_csuplsessionretryq.cpp
hgs
parents:
diff changeset
     4
*  Part of     : SUPL Framework / SUPL Server
hgs
parents:
diff changeset
     5
*  Description : Class to handle retries of failed requests. It waits for all the current sessions to end and then
hgs
parents:
diff changeset
     6
*  				 notifies the failed sessions that they can retry.
hgs
parents:
diff changeset
     7
*  Version     :
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
*  Copyright (c) 2010 Nokia Corporation.
hgs
parents:
diff changeset
    10
*  This material, including documentation and any related
hgs
parents:
diff changeset
    11
*  computer programs, is protected by copyright controlled by
hgs
parents:
diff changeset
    12
*  Nokia Corporation. All rights are reserved. Copying,
hgs
parents:
diff changeset
    13
*  including reproducing, storing, adapting or translating, any
hgs
parents:
diff changeset
    14
*  or all of this material requires the prior written consent of
hgs
parents:
diff changeset
    15
*  Nokia Corporation. This material also contains confidential
hgs
parents:
diff changeset
    16
*  information which may not be disclosed to others without the
hgs
parents:
diff changeset
    17
*  prior written consent of Nokia Corporation.
hgs
parents:
diff changeset
    18
* ==============================================================================
hgs
parents:
diff changeset
    19
*/
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
// INCLUDE FILES
hgs
parents:
diff changeset
    22
#include <e32base.h>
hgs
parents:
diff changeset
    23
#include <e32debug.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
#include "epos_csuplsessionretryq.h"
hgs
parents:
diff changeset
    26
#include "epos_csuplsessionrequest.h"
hgs
parents:
diff changeset
    27
#include "epos_csuplglobal.h"
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
//#ifdef _DEBUG
hgs
parents:
diff changeset
    30
_LIT(KTraceFileName, "SUPL_GW::epos_csuplsessionretryq.cpp");
hgs
parents:
diff changeset
    31
//#endif
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
// CONSTANTS
hgs
parents:
diff changeset
    34
const TTimeIntervalSeconds KRecentConnectionInterval(5);
hgs
parents:
diff changeset
    35
const TTimeIntervalMicroSeconds32 KSmallDelay(2000000);
hgs
parents:
diff changeset
    36
const TTimeIntervalMicroSeconds32 KReissueRequestDelay(5000000);
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
// ================= MEMBER FUNCTIONS =======================
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
    41
// might leave.
hgs
parents:
diff changeset
    42
//
hgs
parents:
diff changeset
    43
CSuplSessionRetryQ::CSuplSessionRetryQ()
hgs
parents:
diff changeset
    44
    : CTimer(EPriorityNormal)
hgs
parents:
diff changeset
    45
    {
hgs
parents:
diff changeset
    46
    DEBUG_TRACE("CSuplSessionRetryQ", __LINE__)
hgs
parents:
diff changeset
    47
    CActiveScheduler::Add(this);
hgs
parents:
diff changeset
    48
    }
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
// Destructor
hgs
parents:
diff changeset
    51
CSuplSessionRetryQ::~CSuplSessionRetryQ()
hgs
parents:
diff changeset
    52
    {
hgs
parents:
diff changeset
    53
    DEBUG_TRACE("~CSuplSessionRetryQ", __LINE__)
hgs
parents:
diff changeset
    54
    Cancel();
hgs
parents:
diff changeset
    55
	iSessionRequests.Close();
hgs
parents:
diff changeset
    56
    }
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
// Two-phased constructor
hgs
parents:
diff changeset
    59
CSuplSessionRetryQ* CSuplSessionRetryQ::NewL()
hgs
parents:
diff changeset
    60
    {
hgs
parents:
diff changeset
    61
    DEBUG_TRACE("NewL", __LINE__)
hgs
parents:
diff changeset
    62
    CSuplSessionRetryQ* self = new (ELeave) CSuplSessionRetryQ();
hgs
parents:
diff changeset
    63
    CleanupStack::PushL(self);
hgs
parents:
diff changeset
    64
    self->ConstructL();
hgs
parents:
diff changeset
    65
    CleanupStack::Pop();
hgs
parents:
diff changeset
    66
    return self;
hgs
parents:
diff changeset
    67
    }
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
// EPOC default constructor
hgs
parents:
diff changeset
    70
void CSuplSessionRetryQ::ConstructL()
hgs
parents:
diff changeset
    71
    {
hgs
parents:
diff changeset
    72
    DEBUG_TRACE("ConstructL", __LINE__)
hgs
parents:
diff changeset
    73
    CTimer::ConstructL();
hgs
parents:
diff changeset
    74
    }
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
void CSuplSessionRetryQ::AddToQueueL(CSuplSessionRequest& aSessionRequest)
hgs
parents:
diff changeset
    78
	{
hgs
parents:
diff changeset
    79
    TBuf<256> msg(_L("AddToQueueL, count = "));
hgs
parents:
diff changeset
    80
    msg.AppendNum(iSessionRequests.Count()+1);
hgs
parents:
diff changeset
    81
    SuplGlobal::Trace(msg, KTraceFileName, __LINE__);   
hgs
parents:
diff changeset
    82
	// if there is no open connection and there is nothing else in the queue then check when it's possible to 
hgs
parents:
diff changeset
    83
	// re-issue, otherwise just leave in the queue
hgs
parents:
diff changeset
    84
    if(iSessionRequests.Count() == 0 && iSessionCount == 0)
hgs
parents:
diff changeset
    85
		{
hgs
parents:
diff changeset
    86
		TTime now;
hgs
parents:
diff changeset
    87
		now.UniversalTime();
hgs
parents:
diff changeset
    88
		// if there was some recent connection made that was closed then ask for re-issue straight away
hgs
parents:
diff changeset
    89
		if(iSomeSessionEnded && now - KRecentConnectionInterval < iTimeOfLastEndedSession)
hgs
parents:
diff changeset
    90
			{
hgs
parents:
diff changeset
    91
			DEBUG_TRACE("Re-issuing request straight away", __LINE__)
hgs
parents:
diff changeset
    92
			RDebug::Printf("[LBS][SUPL]Re-issuing request straight away");	
hgs
parents:
diff changeset
    93
			After(KSmallDelay);
hgs
parents:
diff changeset
    94
			}
hgs
parents:
diff changeset
    95
		// if there is no previous request then wait a little before re-issuing request
hgs
parents:
diff changeset
    96
		else
hgs
parents:
diff changeset
    97
			{
hgs
parents:
diff changeset
    98
			DEBUG_TRACE("Re-issuing request after a delay", __LINE__)
hgs
parents:
diff changeset
    99
			RDebug::Printf("[LBS][SUPL]Re-issuing request after a delay");	
hgs
parents:
diff changeset
   100
			After(KReissueRequestDelay);
hgs
parents:
diff changeset
   101
			}
hgs
parents:
diff changeset
   102
		}
hgs
parents:
diff changeset
   103
	iSessionRequests.AppendL(&aSessionRequest);
hgs
parents:
diff changeset
   104
	}
hgs
parents:
diff changeset
   105
hgs
parents:
diff changeset
   106
void CSuplSessionRetryQ::RemoveFromQueueL(CSuplSessionRequest& aSessionRequest)
hgs
parents:
diff changeset
   107
	{
hgs
parents:
diff changeset
   108
	TInt index = 0;
hgs
parents:
diff changeset
   109
	index = iSessionRequests.Find(&aSessionRequest);
hgs
parents:
diff changeset
   110
	if(index != KErrNotFound)
hgs
parents:
diff changeset
   111
		{
hgs
parents:
diff changeset
   112
		iSessionRequests.Remove(index);
hgs
parents:
diff changeset
   113
		
hgs
parents:
diff changeset
   114
	    TBuf<256> msg(_L("Removed from queue, count = "));
hgs
parents:
diff changeset
   115
	    msg.AppendNum(iSessionRequests.Count());
hgs
parents:
diff changeset
   116
	    SuplGlobal::Trace(msg, KTraceFileName, __LINE__);   
hgs
parents:
diff changeset
   117
		
hgs
parents:
diff changeset
   118
		}
hgs
parents:
diff changeset
   119
	}
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
void CSuplSessionRetryQ::SessionStarted()
hgs
parents:
diff changeset
   122
	{
hgs
parents:
diff changeset
   123
    ++iSessionCount;
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
    
hgs
parents:
diff changeset
   126
    TBuf<256> msg(_L("SessionStarted, session count = "));
hgs
parents:
diff changeset
   127
    msg.AppendNum(iSessionCount);
hgs
parents:
diff changeset
   128
    SuplGlobal::Trace(msg, KTraceFileName, __LINE__);   
hgs
parents:
diff changeset
   129
	}
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
void CSuplSessionRetryQ::SessionEnded()
hgs
parents:
diff changeset
   132
	{
hgs
parents:
diff changeset
   133
	--iSessionCount;
hgs
parents:
diff changeset
   134
	
hgs
parents:
diff changeset
   135
    TBuf<256> msg(_L("SessionEnded, session count = "));
hgs
parents:
diff changeset
   136
    msg.AppendNum(iSessionCount);
hgs
parents:
diff changeset
   137
    SuplGlobal::Trace(msg, KTraceFileName, __LINE__);   
hgs
parents:
diff changeset
   138
	
hgs
parents:
diff changeset
   139
	
hgs
parents:
diff changeset
   140
	if(iSessionCount == 0 && iSessionRequests.Count() > 0)
hgs
parents:
diff changeset
   141
		{
hgs
parents:
diff changeset
   142
		DEBUG_TRACE("Re-issuing request straight away", __LINE__)
hgs
parents:
diff changeset
   143
		After(KSmallDelay);
hgs
parents:
diff changeset
   144
		}
hgs
parents:
diff changeset
   145
	// If a connection just closed remember the time-stamp so later it can be decided when to re-issue
hgs
parents:
diff changeset
   146
	iSomeSessionEnded = ETrue;
hgs
parents:
diff changeset
   147
	iTimeOfLastEndedSession.UniversalTime();
hgs
parents:
diff changeset
   148
	}
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
// ---------------------------------------------------------
hgs
parents:
diff changeset
   151
// CSuplSessionRetryQ::RunL
hgs
parents:
diff changeset
   152
//
hgs
parents:
diff changeset
   153
// (other items were commented in a header).
hgs
parents:
diff changeset
   154
// ---------------------------------------------------------
hgs
parents:
diff changeset
   155
//
hgs
parents:
diff changeset
   156
void CSuplSessionRetryQ::RunL()
hgs
parents:
diff changeset
   157
    {
hgs
parents:
diff changeset
   158
    TBuf<256> msg(_L("RunL, session count = "));
hgs
parents:
diff changeset
   159
    msg.AppendNum(iSessionCount);
hgs
parents:
diff changeset
   160
    msg.Append(_L(", queue count = "));
hgs
parents:
diff changeset
   161
    msg.AppendNum(iSessionRequests.Count());
hgs
parents:
diff changeset
   162
    SuplGlobal::Trace(msg, KTraceFileName, __LINE__);   
hgs
parents:
diff changeset
   163
   
hgs
parents:
diff changeset
   164
	// If a connection is already open, wait until it finishes
hgs
parents:
diff changeset
   165
	if(iSessionCount == 0 && iSessionRequests.Count() > 0)
hgs
parents:
diff changeset
   166
		{
hgs
parents:
diff changeset
   167
		DEBUG_TRACE("Re-issuing request now", __LINE__)
hgs
parents:
diff changeset
   168
		// re-issue request for the first item in the queue
hgs
parents:
diff changeset
   169
		TRAPD(err, iSessionRequests[0]->ReIssueRequestL());
hgs
parents:
diff changeset
   170
		while(err!=KErrNone && iSessionRequests.Count() > 1)
hgs
parents:
diff changeset
   171
			{
hgs
parents:
diff changeset
   172
			// if for some reason re-issuing doesn't work then just try the next requestor and forget about the first one
hgs
parents:
diff changeset
   173
			DEBUG_TRACE("Re-issue failed, trying next one in the queue", __LINE__)
hgs
parents:
diff changeset
   174
			iSessionRequests.Remove(0);
hgs
parents:
diff changeset
   175
			TRAP(err, iSessionRequests[0]->ReIssueRequestL());
hgs
parents:
diff changeset
   176
			}
hgs
parents:
diff changeset
   177
		if(err!=KErrNone)
hgs
parents:
diff changeset
   178
			{
hgs
parents:
diff changeset
   179
			DEBUG_TRACE("Re-issue failed", __LINE__)
hgs
parents:
diff changeset
   180
			}
hgs
parents:
diff changeset
   181
		iSessionRequests.Remove(0);
hgs
parents:
diff changeset
   182
		}
hgs
parents:
diff changeset
   183
    }
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185