mmsharing/mmshavailability/src/musavainviteresponder.cpp
changeset 22 496ad160a278
parent 0 f0cf47e981f9
child 38 ac48f0cc9f9c
equal deleted inserted replaced
15:ccd8e69b5392 22:496ad160a278
       
     1 /*
       
     2 * Copyright (c) 2005-2006 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:   Provide interface for the client requestin availability class.
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 
       
    20 #include "musavainviteresponder.h"
       
    21 #include "musavainviteresponderobserver.h"
       
    22 #include "muslogger.h"
       
    23 
       
    24 #include <e32cmn.h>
       
    25 #include <sipresponseelements.h>
       
    26 #include <sipmessageelements.h>
       
    27 #include <sipstrings.h>
       
    28 #include <siptransactionbase.h>
       
    29 #include <sipheaderbase.h>
       
    30 #include <sipservertransaction.h>
       
    31 
       
    32 const TUint KMUSAVA486 = 486; // Busy
       
    33 const TUint KMUSAVA603 = 603; // Decline/Reject
       
    34 
       
    35 _LIT8( KMusAvaStatusBusy, "Busy Here" );
       
    36 _LIT8( KMusAvaStatusDecline, "Decline" );
       
    37 
       
    38 
       
    39 // -------------------------------------------------------------------------
       
    40 //  Two-phased constructor.
       
    41 // -------------------------------------------------------------------------
       
    42 //
       
    43 CMusAvaInviteResponder* CMusAvaInviteResponder::NewL(
       
    44                                 CSIPServerTransaction* aTransaction,
       
    45                                 MMusAvaInviteResponderObserver& aObserver )
       
    46     {
       
    47     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaInviteResponder::NewL()" )
       
    48 
       
    49     CMusAvaInviteResponder* self = CMusAvaInviteResponder::NewLC(
       
    50                                                 aTransaction,
       
    51                                                 aObserver );
       
    52     CleanupStack::Pop( self );
       
    53 
       
    54     MUS_LOG( "mus: [MUSAVA]  <- CMusAvaInviteResponder::NewL()" )
       
    55     return self;
       
    56     }
       
    57 
       
    58 
       
    59 // -------------------------------------------------------------------------
       
    60 //  Destructor.
       
    61 // -------------------------------------------------------------------------
       
    62 //
       
    63 CMusAvaInviteResponder::~CMusAvaInviteResponder()
       
    64     {
       
    65     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaInviteResponder::~CMusAvaInviteResponder()" )
       
    66     delete iTransaction;
       
    67     MUS_LOG( "mus: [MUSAVA]  <- CMusAvaInviteResponder::~CMusAvaInviteResponder()" )
       
    68     }
       
    69 
       
    70 // -------------------------------------------------------------------------
       
    71 //  Two-phased constructor.
       
    72 // -------------------------------------------------------------------------
       
    73 //
       
    74 CMusAvaInviteResponder* CMusAvaInviteResponder::NewLC(
       
    75                                 CSIPServerTransaction* aTransaction,
       
    76                                 MMusAvaInviteResponderObserver& aObserver )
       
    77     {
       
    78     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaInviteResponder::NewLC()" )
       
    79     CMusAvaInviteResponder* self = new( ELeave ) CMusAvaInviteResponder(
       
    80                                                         aTransaction,
       
    81                                                         aObserver );
       
    82     CleanupStack::PushL( self );
       
    83 
       
    84     MUS_LOG( "mus: [MUSAVA]  <- CMusAvaInviteResponder::NewLC()" )
       
    85     return self;
       
    86     }
       
    87 
       
    88 // -------------------------------------------------------------------------
       
    89 //  Constructor.
       
    90 // -------------------------------------------------------------------------
       
    91 //
       
    92 CMusAvaInviteResponder::CMusAvaInviteResponder(
       
    93                                 CSIPServerTransaction* aTransAction,
       
    94                                 MMusAvaInviteResponderObserver& aObserver )
       
    95     : iObserver( aObserver ), iTransaction( aTransAction )
       
    96     {
       
    97     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaInviteResponder::CMusAvaInviteResponder()" )
       
    98     MUS_LOG( "mus: [MUSAVA]  <- CMusAvaInviteResponder::CMusAvaInviteResponder()" )
       
    99     }
       
   100 
       
   101 // -------------------------------------------------------------------------
       
   102 //
       
   103 // -------------------------------------------------------------------------
       
   104 //
       
   105 void CMusAvaInviteResponder::AnswerL()
       
   106     {
       
   107     if( iObserver.ApplicationState()  ==
       
   108         MMusAvaSettingsObserver::EApplicationIsRunning )
       
   109         {
       
   110         SendResponseL( KMUSAVA486, KMusAvaStatusBusy );
       
   111         }
       
   112     else
       
   113         {
       
   114         SendResponseL( KMUSAVA603, KMusAvaStatusDecline );
       
   115         }
       
   116     }
       
   117 
       
   118 // ------------------------------------------------------------------------
       
   119 // Send response to request.
       
   120 // ------------------------------------------------------------------------
       
   121 void CMusAvaInviteResponder::SendResponseL( TUint aStatusCode,
       
   122                                             const TDesC8& aReasonPhrase )
       
   123     {
       
   124     MUS_LOG( "mus: [MUSAVA] -> CMusAvaInviteResponder::SendResponseL()" )
       
   125     MUS_LOG1( "mus: [MUSAVA]     aStatusCode == <%d>", aStatusCode )
       
   126 
       
   127     RStringF responseString = SIPStrings::Pool().OpenFStringL( aReasonPhrase );
       
   128     CleanupClosePushL( responseString );
       
   129     CSIPResponseElements* respElem =
       
   130         CSIPResponseElements::NewL( aStatusCode, responseString );
       
   131     CleanupStack::PopAndDestroy(); //responseString
       
   132     CleanupStack::PushL( respElem );
       
   133 
       
   134     ResponseL( respElem );
       
   135     CleanupStack::Pop( respElem );
       
   136 
       
   137     MUS_LOG( "mus: [MUSAVA]  <- CMusAvaInviteResponder::SendResponseL()" )
       
   138     }
       
   139 
       
   140 
       
   141 // ------------------------------------------------------------------------
       
   142 // Returns response status.
       
   143 // ------------------------------------------------------------------------
       
   144 TBool CMusAvaInviteResponder::ResponseComplete()
       
   145     {
       
   146    
       
   147 	MUS_LOG( "mus: [MUSAVA]	-> CMusAvaInviteResponder::ResponseComplete()" )
       
   148 	TBool res = EFalse;
       
   149 
       
   150 	CSIPTransactionBase::TState state = CSIPTransactionBase::ETerminated;
       
   151 	TRAPD( err, state = iTransaction->StateL() );
       
   152 	
       
   153 	if( err != KErrNone ) 
       
   154 		{
       
   155 		MUS_LOG1( "mus: [MUSAVA]	   serverTran.StateL, err #%d", err )
       
   156 		return res;
       
   157 		}
       
   158 
       
   159 	if ( state == CSIPTransactionBase::ECompleted || 
       
   160 		 state == CSIPTransactionBase::EConfirmed || 
       
   161 		 state == CSIPTransactionBase::ETerminated && 
       
   162 	     iTransaction->ResponseAllowed() )	
       
   163 	    {
       
   164 	    res = ETrue;
       
   165 	    }
       
   166 
       
   167 	MUS_LOG( "mus: [MUSAVA]	<- CMusAvaInviteResponder::ResponseComplete()" )
       
   168 	return res;
       
   169     }
       
   170 
       
   171 // ------------------------------------------------------------------------
       
   172 // Send Response to reques.
       
   173 // ------------------------------------------------------------------------
       
   174 void CMusAvaInviteResponder::ResponseL(
       
   175                                 CSIPResponseElements* aResponseElements )
       
   176     {
       
   177     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaInviteResponder::ResponseL" )
       
   178     CSIPServerTransaction& serverTran =
       
   179         static_cast<CSIPServerTransaction&>( *iTransaction );
       
   180     
       
   181     if ( iTransaction->IsSIPClientTransaction() )
       
   182         {
       
   183         User::Leave( KErrNotReady );
       
   184         }
       
   185     
       
   186     else if ( ( serverTran.StateL() == CSIPTransactionBase::ETrying ||
       
   187          serverTran.StateL() == CSIPTransactionBase::EProceeding ) &&
       
   188          serverTran.ResponseAllowed() )
       
   189         {
       
   190         MUS_LOG( "   Send response" )
       
   191         serverTran.SendResponseL( aResponseElements );
       
   192         }
       
   193     else
       
   194         {
       
   195         User::Leave( KErrNotReady );
       
   196         MUS_LOG( "mus: [MUSAVA]  Not allow to sent response " )
       
   197         MUS_LOG( "mus: [MUSAVA]  <- CMusAvaInviteResponder::ResponseL" )
       
   198         }
       
   199     }
       
   200 
       
   201