--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/realtimenetprots/sipfw/SIP/TransactionUser/src/UserAgentTimer.h Tue Feb 02 01:03:15 2010 +0200
@@ -0,0 +1,183 @@
+/*
+* Copyright (c) 2005-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:
+* Name : UserAgentTimer.h
+* Part of : TransactionUser
+* Version : SIP/4.0
+*
+*/
+
+
+
+
+/**
+ @internalComponent
+*/
+
+// INCLUDES
+#ifndef USERAGENTTIMER_H
+#define USERAGENTTIMER_H
+
+#include "TimerBase.h"
+
+// FORWARD DECLARATIONS
+class CUserAgent;
+
+
+// CLASS DECLARATION
+
+class CUserAgentTimer : public CTimerBase
+ {
+public:
+ virtual ~CUserAgentTimer() {}
+
+
+ /**
+ * Handle the timer expiration.
+ *
+ * @pre
+ * @post
+ *
+ * @see
+ *
+ * @param aUserAgent UserAgent whose timer expired. Ownership is not
+ * transferred.
+ * @param aTimerId Timer identifier
+ * @return value -
+ */
+ virtual void ExpiredL(CUserAgent* aUserAgent, TTimerId aTimerId) = 0;
+
+protected:
+ /**
+ * Creates a timer and starts it.
+ *
+ * Note: since there isn't a StartL() function in the CUserAgentTimer,
+ * then if a timer is stopped, it can't be restarted.
+ *
+ * @pre
+ * @post
+ *
+ * @see
+ *
+ * @param aTimerMgr Timer subsystem
+ * @param aObserver Callback for handling timer expiration. Ownership is
+ * not transferred.
+ * @param aDuration Timer duration in milliseconds
+ * @return value -
+ */
+ CUserAgentTimer(MTimerManager& aTimerMgr,
+ MExpirationHandler* aObserver,
+ TUint32 aDuration);
+ };
+
+
+
+/*
+ * This timer is used for stopping UserAgent. When the timer expires, UserAgent
+ * is stopped with the given aReason value.
+ */
+class CTimerStopUA : public CUserAgentTimer
+ {
+public:
+ //Creates and starts the timer
+ static CTimerStopUA* NewL(MTimerManager& aTimerMgr,
+ MExpirationHandler* aObserver,
+ TUint32 aDuration,
+ TInt aReason);
+ void ExpiredL(CUserAgent* aUserAgent, TTimerId aTimerId);
+
+private:
+ CTimerStopUA(MTimerManager& aTimerMgr,
+ MExpirationHandler* aObserver,
+ TUint32 aDuration,
+ TInt aReason);
+
+ //Reason value which is passed to CUserAgent::Stop() when the timer expires
+ TInt iReason;
+ };
+
+
+
+/*
+ * InviteUAS uses this timer for retransmitting the 2xx response until it
+ * receives ACK.
+ */
+class CTimerRetransmit2xx : public CUserAgentTimer
+ {
+public:
+ //Creates and starts the timer
+ static CTimerRetransmit2xx* NewL(MTimerManager& aTimerMgr,
+ MExpirationHandler* aObserver,
+ TUint32 aDuration);
+
+ void ExpiredL(CUserAgent* aUserAgent, TTimerId aTimerId);
+
+private:
+ CTimerRetransmit2xx(MTimerManager& aTimerMgr,
+ MExpirationHandler* aObserver,
+ TUint32 aDuration);
+ };
+
+
+
+/*
+ * UAS uses this timer for send error response to remote endpoint when
+ * AssocMgr does not return MTransactionOwner of response in time.
+ */
+class CTimerOwnerResolver : public CUserAgentTimer
+ {
+public:
+ //Creates and starts the timer
+ static CTimerOwnerResolver* NewL(MTimerManager& aTimerMgr,
+ MExpirationHandler* aObserver,
+ TUint32 aDuration);
+
+ void ExpiredL(CUserAgent* aUserAgent, TTimerId aTimerId);
+
+private:
+ CTimerOwnerResolver(MTimerManager& aTimerMgr,
+ MExpirationHandler* aObserver,
+ TUint32 aDuration);
+ };
+
+
+
+/*
+ * InviteUAC uses this timer when SIPSec processed the received SIP response
+ * synchronously.
+ * SIP stack should send the the ACK to the error response before the updated
+ * INVITE is sent. Using a dummy timer with duration zero, introduces an
+ * asynchronous break before UAC processes the SIP response further, causing
+ * the control to return back to the transaction which received the response,
+ * before InviteUAC may create a new transaction for sending the updated INVITE.
+ * This way the old transaction sends the ACK before the new transaction sends
+ * the INVITE.
+ */
+class CTimerAsyncSIPSec : public CUserAgentTimer
+ {
+public:
+ //Creates and starts the timer
+ static CTimerAsyncSIPSec* NewL(MTimerManager& aTimerMgr,
+ MExpirationHandler* aObserver);
+
+ void ExpiredL(CUserAgent* aUserAgent, TTimerId aTimerId);
+
+private:
+ CTimerAsyncSIPSec(MTimerManager& aTimerMgr,
+ MExpirationHandler* aObserver);
+ };
+
+#endif // end of USERAGENTTIMER_H
+
+// End of File