natplugins/natptraversalcontroller/src/tnattraversalpendingrequest.cpp
changeset 0 1bce908db942
equal deleted inserted replaced
-1:000000000000 0:1bce908db942
       
     1 /*
       
     2 * Copyright (c) 2007 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description: 
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 #include "tnattraversalpendingrequest.h"
       
    20 #include "sipnattraversalrequestobserver.h"
       
    21 #include "mnattraversalpendingrequestcontainer.h"
       
    22 #include "nattraversallog.h"
       
    23 
       
    24 // -----------------------------------------------------------------------------
       
    25 // TNATTraversalPendingRequest::TNATTraversalPendingRequest
       
    26 // -----------------------------------------------------------------------------
       
    27 //
       
    28 TNATTraversalPendingRequest::TNATTraversalPendingRequest(
       
    29     const TUint32& aRequestId,
       
    30     MSIPNATTraversalRequestObserver* aObserver,
       
    31     MNATTraversalPendingRequestContainer& aContainer)
       
    32  : iRequestId(aRequestId),
       
    33    iObserver(aObserver),
       
    34    iContainer(aContainer),
       
    35    iDeltaTimerCallBack(TNATTraversalPendingRequest::TimerExpired,this),
       
    36    iDeltaTimerEntry(iDeltaTimerCallBack)
       
    37     {
       
    38     }
       
    39 
       
    40 // -----------------------------------------------------------------------------
       
    41 // TNATTraversalPendingRequest::RequestId
       
    42 // -----------------------------------------------------------------------------
       
    43 //
       
    44 const TUint32& TNATTraversalPendingRequest::RequestId() const
       
    45     {
       
    46     return iRequestId;
       
    47     }
       
    48 
       
    49 // -----------------------------------------------------------------------------
       
    50 // TNATTraversalPendingRequest::DeltaTimerEntry
       
    51 // -----------------------------------------------------------------------------
       
    52 //
       
    53 TDeltaTimerEntry& TNATTraversalPendingRequest::DeltaTimerEntry()
       
    54     {
       
    55     // If the original instance was created from stack and then copied,
       
    56     // the callback for the copy is not valid. Setting it correctly.
       
    57     TCallBack callback(TNATTraversalPendingRequest::TimerExpired,this);
       
    58     iDeltaTimerEntry.Set(callback);
       
    59     return iDeltaTimerEntry;
       
    60     }
       
    61 
       
    62 // -----------------------------------------------------------------------------
       
    63 // TNATTraversalPendingRequest::CompleteRequest
       
    64 // -----------------------------------------------------------------------------
       
    65 //
       
    66 void TNATTraversalPendingRequest::CompleteRequest()
       
    67     {
       
    68     if (iObserver)
       
    69         {
       
    70         iObserver->RequestComplete(iRequestId,KErrNone);
       
    71         }
       
    72     }
       
    73 
       
    74 // -----------------------------------------------------------------------------
       
    75 // TNATTraversalPendingRequest::TimerExpired
       
    76 // A callback for CDeltaTimer
       
    77 // -----------------------------------------------------------------------------
       
    78 //
       
    79 TInt TNATTraversalPendingRequest::TimerExpired(TAny* aPtr)
       
    80     {
       
    81     NATTRAVERSAL_LOG("TNATTraversalPendingRequest::TimerExpired")
       
    82     _LIT(KPanicCategory,"NAT Traversal Controller");
       
    83     __ASSERT_ALWAYS(aPtr, User::Panic(KPanicCategory,KErrBadHandle));
       
    84     TNATTraversalPendingRequest* self =
       
    85         reinterpret_cast<TNATTraversalPendingRequest*>(aPtr);
       
    86     self->RequestCompleted();
       
    87     return ETrue;
       
    88     }
       
    89 
       
    90 // -----------------------------------------------------------------------------
       
    91 // TNATTraversalPendingRequest::RequestOrder
       
    92 // -----------------------------------------------------------------------------
       
    93 //
       
    94 TInt TNATTraversalPendingRequest::RequestOrder(
       
    95     const TNATTraversalPendingRequest& aFirst,
       
    96     const TNATTraversalPendingRequest& aSecond)
       
    97     {
       
    98     if (aFirst.RequestId() < aSecond.RequestId())
       
    99         {
       
   100         return -1;
       
   101         }
       
   102     return (aFirst.RequestId() > aSecond.RequestId());
       
   103     }
       
   104 
       
   105 // -----------------------------------------------------------------------------
       
   106 // TNATTraversalPendingRequest::RequestCompleted
       
   107 // -----------------------------------------------------------------------------
       
   108 //
       
   109 void TNATTraversalPendingRequest::RequestCompleted()
       
   110     {
       
   111     iContainer.RequestCompleted(iRequestId);
       
   112     }