mmshplugins/mmshaoplugin/src/muscallconferenceeventmonitor.cpp
changeset 0 f0cf47e981f9
child 31 33a5d2bbf6fc
equal deleted inserted replaced
-1:000000000000 0:f0cf47e981f9
       
     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:  Monitor the status of CS Conference call
       
    15 *
       
    16 */
       
    17  
       
    18 
       
    19 #include "mussesseioninformationapi.h"
       
    20 #include "muslogger.h"
       
    21 #include "muscallconferenceeventmonitor.h"
       
    22 
       
    23 #include <etelmm.h>
       
    24 #include <e32svr.h>
       
    25 #include <mmtsy_names.h>
       
    26 #include <e32property.h>
       
    27 
       
    28 
       
    29 // -----------------------------------------------------------------------------
       
    30 // Symbian two-phase constructor.
       
    31 // -----------------------------------------------------------------------------
       
    32 //
       
    33 CMusCallConferenceEventMonitor* CMusCallConferenceEventMonitor::NewL( RMobilePhone& aPhone,
       
    34                               RMobileLine& aLine,
       
    35                               RPointerArray<CMusCallMonitor>& aCallMonitorArray )
       
    36     {
       
    37     MUS_LOG( "mus: [MUSAO]  -> CMusCallConferenceEventMonitor::NewL" )
       
    38     CMusCallConferenceEventMonitor* self = new (ELeave) 
       
    39                               CMusCallConferenceEventMonitor(aLine,aCallMonitorArray);
       
    40     CleanupStack::PushL( self );
       
    41     self->ConstructL( aPhone );
       
    42     CleanupStack::Pop( self );
       
    43     MUS_LOG( "mus: [MUSAO]  <- CMusCallConferenceEventMonitor::NewL" )
       
    44     return self;
       
    45     }
       
    46 
       
    47 
       
    48 // -----------------------------------------------------------------------------
       
    49 // C++ destructor.
       
    50 // -----------------------------------------------------------------------------
       
    51 //
       
    52 CMusCallConferenceEventMonitor::~CMusCallConferenceEventMonitor()
       
    53     {
       
    54     MUS_LOG( "mus: [MUSAO]  -> \
       
    55                         CMusCallConferenceEventMonitor::~CMusCallConferenceEventMonitor" )        
       
    56     Cancel();
       
    57     iConfCall.Close();        
       
    58     MUS_LOG( "mus: [MUSAO]  <- \
       
    59                         CMusCallConferenceEventMonitor::~CMusCallConferenceEventMonitor" )
       
    60     }
       
    61 
       
    62 // -----------------------------------------------------------------------------
       
    63 // Symbian second-phase constructor.
       
    64 // -----------------------------------------------------------------------------
       
    65 //
       
    66 void CMusCallConferenceEventMonitor::ConstructL( RMobilePhone& aPhone )
       
    67     {
       
    68     MUS_LOG( "mus: [MUSAO]  -> CMusCallConferenceEventMonitor::ConstructL" )   
       
    69     CActiveScheduler::Add( this );            
       
    70     User::LeaveIfError(iConfCall.Open(aPhone));    
       
    71     iConfCall.NotifyConferenceEvent(iStatus,iConfEvent,iCallName);   
       
    72     SetActive();        
       
    73     MUS_LOG( "mus: [MUSAO]  <- CMusCallConferenceEventMonitor::ConstructL" )
       
    74     }
       
    75 
       
    76 
       
    77 // -----------------------------------------------------------------------------
       
    78 // C++ constructor.
       
    79 // -----------------------------------------------------------------------------
       
    80 //
       
    81 CMusCallConferenceEventMonitor::CMusCallConferenceEventMonitor(RMobileLine& aLine,
       
    82                             RPointerArray<CMusCallMonitor>& aCallMonitorArray) 
       
    83         : CActive( EPriorityNormal ),
       
    84           iLine(aLine),
       
    85           iCallMonitorArray(aCallMonitorArray)
       
    86           
       
    87         
       
    88     {    
       
    89     }
       
    90 
       
    91 
       
    92 // --------------------------------------------------------------------------------
       
    93 // CMusCallConferenceEventMonitor::RunL()
       
    94 // Implemented for CActive.It will be called any NotifyMobileLineStatusChange
       
    95 // Event happens.
       
    96 // --------------------------------------------------------------------------------
       
    97 //
       
    98 void CMusCallConferenceEventMonitor::RunL()
       
    99     {
       
   100     MUS_LOG( "mus: [MUSAO]  -> CMusCallConferenceEventMonitor::RunL" )    
       
   101     iConfCall.NotifyConferenceEvent(iStatus,iConfEvent,iCallName); 
       
   102     SetActive();       
       
   103     MUS_LOG1( "mus: [MUSAO]  Conference->iConfEvent =  %d", iConfEvent ) 
       
   104     switch(iConfEvent)    
       
   105         {         
       
   106             case RMobileConferenceCall::EConferenceCallAdded:
       
   107                  SetStateL( NMusSessionInformationApi::EConferenceCall );                           	
       
   108                  break;
       
   109             case RMobileConferenceCall::EConferenceCallRemoved:	                 
       
   110                  MonitorCallL();
       
   111                  break;
       
   112             case RMobileConferenceCall::EConferenceBuilt:
       
   113                  SetStateL( NMusSessionInformationApi::EConferenceCall ); 
       
   114                  break;
       
   115             case RMobileConferenceCall::EConferenceTerminated:
       
   116                  MonitorCallL();
       
   117                  break;
       
   118             case RMobileConferenceCall::EConferenceSwapped:
       
   119                  SetStateL( NMusSessionInformationApi::EConferenceCall );	
       
   120                  break;
       
   121             case RMobileConferenceCall::EConferenceSplit:
       
   122                  SetStateL( NMusSessionInformationApi::EConferenceCall );	
       
   123                  break;
       
   124             default:
       
   125                  break;
       
   126         }
       
   127     MUS_LOG( "mus: [MUSAO]  <- CMusCallConferenceEventMonitor::RunL" )
       
   128     }
       
   129 
       
   130 
       
   131 // --------------------------------------------------------------------------------
       
   132 // CMusCallConferenceEventMonitor::DoCancel()
       
   133 // Implemented for CActive.
       
   134 // Will be called when Cancel() method is called.
       
   135 // --------------------------------------------------------------------------------
       
   136 //
       
   137 void CMusCallConferenceEventMonitor::DoCancel()
       
   138     {
       
   139     MUS_LOG( "mus: [MUSAO]  -> CMusCallConferenceEventMonitor::DoCancel" )
       
   140     iConfCall.CancelAsyncRequest( EMobileConferenceCallNotifyConferenceEvent );
       
   141     MUS_LOG( "mus: [MUSAO]  <- CMusCallConferenceEventMonitor::DoCancel" )
       
   142     }
       
   143 
       
   144 // --------------------------------------------------------------------------------
       
   145 // CMusCallConferenceEventMonitor::RunError( TInt aError )
       
   146 // Implemented for CActive.
       
   147 // Will be called automatically by framework when RunL Leaves.
       
   148 // --------------------------------------------------------------------------------
       
   149 //
       
   150 
       
   151 TInt CMusCallConferenceEventMonitor::RunError( TInt aError )
       
   152     {
       
   153     MUS_LOG1( "mus: [MUSAO]  -> CMusCallConferenceEventMonitor::RunError, aError %d", \
       
   154                                                                           aError )
       
   155     aError = KErrNone;
       
   156     MUS_LOG( "mus: [MUSAO]  <- CMusCallConferenceEventMonitor::RunError" )    
       
   157     return aError;
       
   158     }
       
   159 
       
   160 // --------------------------------------------------------------------------------
       
   161 // CMusCallConferenceEventMonitor::SetStateL( TInt aError )
       
   162 // Sets the Call State to Property
       
   163 // --------------------------------------------------------------------------------
       
   164 //
       
   165 void CMusCallConferenceEventMonitor::SetStateL(
       
   166                                       NMusSessionInformationApi::TMusCallEvent aVal)
       
   167     {
       
   168     MUS_LOG1( "mus: [MUSAO]  -> CMusCallConferenceEventMonitor::SetStateL, aVal %d",\
       
   169                                                                               aVal )
       
   170     TInt currentVal;
       
   171     User::LeaveIfError(RProperty::Get( NMusSessionInformationApi::KCategoryUid,
       
   172                      NMusSessionInformationApi::KMusCallEvent,currentVal));
       
   173     if(currentVal != (TInt)aVal)
       
   174         {
       
   175         User::LeaveIfError(RProperty::Set( NMusSessionInformationApi::KCategoryUid,
       
   176                      NMusSessionInformationApi::KMusCallEvent,
       
   177                      aVal ));    
       
   178         }
       
   179     else
       
   180         {
       
   181          // No point of reporting it .
       
   182         }    
       
   183     MUS_LOG( "mus: [MUSAO]  <- CMusCallConferenceEventMonitor::SetStateL" )    
       
   184     }
       
   185 
       
   186 // --------------------------------------------------------------------------------
       
   187 // CMusCallConferenceEventMonitor::MonitorCallL() 
       
   188 // If the call in conference is dropped that has to be removed.
       
   189 // from call monitoring array.and start monitoring.
       
   190 // --------------------------------------------------------------------------------
       
   191 //
       
   192 void CMusCallConferenceEventMonitor::MonitorCallL()
       
   193     {
       
   194     MUS_LOG( "mus: [MUSAO]  -> CMusCallConferenceEventMonitor::MonitorCallL")
       
   195     TInt callCount;
       
   196     iLine.EnumerateCall(callCount);
       
   197     MUS_LOG1( "mus: [MUSAO]  -> callCount = %d",callCount)    
       
   198     RLine::TCallInfo callInfo;
       
   199     for(TInt i=0;i<callCount;i++)
       
   200         {
       
   201         MUS_LOG( "mus: [MUSAO]  -----------------------------------\n" )
       
   202         iLine.GetCallInfo(i,callInfo);
       
   203         MUS_LOG1( "mus: [MUSAO]  Call index = %d",i)
       
   204         MUS_LOG_TDESC("mus: [MUSAO]  Call Name",callInfo.iCallName);
       
   205         MUS_LOG1( "mus: [MUSAO]  Call Status = %d",callInfo.iStatus );        
       
   206         if(callInfo.iStatus == RCall::EStatusIdle)
       
   207             {
       
   208             for ( TInt j = 0; j < iCallMonitorArray.Count(); j++ )
       
   209                 {
       
   210                 if( iCallMonitorArray[j]->IsEqual( callInfo.iCallName ) )
       
   211                     {
       
   212                     iCallMonitorArray[0]->StopMonitor();   
       
   213                     delete iCallMonitorArray[j];
       
   214                     iCallMonitorArray.Remove(j);                     
       
   215                     break;
       
   216                     }
       
   217                 }
       
   218             }                   
       
   219         MUS_LOG( "mus: [MUSAO]  -----------------------------------\n" ) 
       
   220         }        
       
   221     MUS_LOG( "mus: [MUSAO]  -> CMusCallConferenceEventMonitor::CheckCallStatus")
       
   222     }
       
   223 
       
   224 // End of file
       
   225 
       
   226