mmsharing/mmshavailability/src/musavanetworkregistrationstatus.cpp
changeset 15 ccd8e69b5392
parent 2 b31261fd4e04
child 20 e8be2c2e049d
child 22 496ad160a278
equal deleted inserted replaced
2:b31261fd4e04 15:ccd8e69b5392
     1 /*
       
     2 * Copyright (c) 2005-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:   Provide interface for the client requestin availability class.
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 
       
    20 #include "musavanetworkregistrationstatus.h"
       
    21 #include "musavatelephonystatusobserver.h"
       
    22 #include "musavaavailability.h"
       
    23 #include "musunittesting.h"
       
    24 #include "muslogger.h"
       
    25 
       
    26 #include <e32base.h>
       
    27 #include <mmtsy_names.h>
       
    28 
       
    29 // -------------------------------------------------------------------------
       
    30 //  Two-phased constructor.
       
    31 // -------------------------------------------------------------------------
       
    32 //
       
    33 CMusAvaNetworkRegistrationStatus* CMusAvaNetworkRegistrationStatus::NewL()
       
    34     {
       
    35     CMusAvaNetworkRegistrationStatus* self = 
       
    36     new( ELeave ) CMusAvaNetworkRegistrationStatus();
       
    37     CleanupStack::PushL( self );
       
    38     self->ConstructL();
       
    39     CleanupStack::Pop( self );
       
    40 
       
    41     return self;
       
    42     }
       
    43 
       
    44 
       
    45 // -------------------------------------------------------------------------
       
    46 //  Destructor.
       
    47 // -------------------------------------------------------------------------
       
    48 //
       
    49 CMusAvaNetworkRegistrationStatus::~CMusAvaNetworkRegistrationStatus()
       
    50     {
       
    51     iObserver.Reset();
       
    52     iObserver.Close();
       
    53     iPhone.Close();
       
    54     iTelServer.UnloadPhoneModule( KMmTsyModuleName );
       
    55     iTelServer.Close();
       
    56     }
       
    57 
       
    58     
       
    59 // -------------------------------------------------------------------------
       
    60 // Test Current network registration status
       
    61 // -------------------------------------------------------------------------
       
    62 //
       
    63 void CMusAvaNetworkRegistrationStatus::NetworkRegistration( 
       
    64                     RMobilePhone::TMobilePhoneRegistrationStatus& aStatus )
       
    65     {
       
    66     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaNetworkRegistrationStatus::\
       
    67     NetworkRegistrationStatus()" )
       
    68     
       
    69     TRequestStatus status; 
       
    70     iPhone.GetNetworkRegistrationStatus( status, aStatus );    
       
    71     #ifndef UNIT_TESTING
       
    72     User::WaitForRequest( status );
       
    73     #endif
       
    74     MUS_LOG1( "mus: [MUSAVA]     RMobilePhone::\
       
    75     GetNetworkRegistrationStatus %d", aStatus )
       
    76     
       
    77     MUS_LOG( "mus: [MUSAVA]  <- CMusAvaNetworkRegistrationStatus::\
       
    78     NetworkRegistrationStatus()" )
       
    79     }
       
    80 
       
    81 // -------------------------------------------------------------------------
       
    82 //  Reads the telephony status.
       
    83 // -------------------------------------------------------------------------
       
    84 //
       
    85 void CMusAvaNetworkRegistrationStatus::TelephonyStatus()
       
    86     {
       
    87     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaNetworkRegistrationStatus::TelephonyStatus()" )
       
    88     MUS_LOG( "mus: [MUSAVA] NotifyNetworkRegistrationStatusChange" )
       
    89     iPhone.NotifyNetworkRegistrationStatusChange( iStatus, iRegistrationStatus );
       
    90     SetActive();
       
    91     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaNetworkRegistrationStatus::TelephonyStatus()" )
       
    92     }
       
    93 
       
    94 // -------------------------------------------------------------------------
       
    95 // 
       
    96 // -------------------------------------------------------------------------
       
    97 //    
       
    98 void CMusAvaNetworkRegistrationStatus::NetworkRegistrationStatus( 
       
    99                     RMobilePhone::TMobilePhoneRegistrationStatus aRegStatus )
       
   100     {
       
   101     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaNetworkRegistrationStatus::RegistrationStatus()" )
       
   102     MUS_LOG1( "TRegistrationStatus = ", aRegStatus )
       
   103 
       
   104     for( TInt i=0; i<iObserver.Count(); i++ )
       
   105         {
       
   106         iObserver[i]->NetworkRegistrationStatus( aRegStatus );
       
   107         }
       
   108     MUS_LOG( "mus: [MUSAVA]  <- CMusAvaNetworkRegistrationStatus::NetworkRegistrationStatus()" )
       
   109     }
       
   110 
       
   111 // -------------------------------------------------------------------------
       
   112 //  Reads the call status property value and subscribes again.
       
   113 // -------------------------------------------------------------------------
       
   114 //
       
   115 void CMusAvaNetworkRegistrationStatus::RunL()
       
   116     {
       
   117     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaNetworkRegistrationStatus::RunL()" )
       
   118     if( iStatus==KErrNone )
       
   119         {
       
   120         NetworkRegistrationStatus( iRegistrationStatus );
       
   121         }
       
   122     //Subscribes registration status again.  
       
   123     MUS_LOG( "mus: [MUSAVA]  Subscribes registration status again" )
       
   124     TelephonyStatus();
       
   125     MUS_LOG( "mus: [MUSAVA]  -> CMusAvaNetworkRegistrationStatus::RunL()" )
       
   126     }
       
   127 
       
   128 // -------------------------------------------------------------------------
       
   129 //  Constructor function.
       
   130 // -------------------------------------------------------------------------
       
   131 //
       
   132 CMusAvaNetworkRegistrationStatus::CMusAvaNetworkRegistrationStatus( )
       
   133     {
       
   134    
       
   135     }
       
   136 
       
   137 // -------------------------------------------------------------------------
       
   138 //  Second phase constructor.
       
   139 // -------------------------------------------------------------------------
       
   140 //
       
   141 void CMusAvaNetworkRegistrationStatus::ConstructL()
       
   142     {
       
   143     RTelServer::TPhoneInfo phoneInfo;
       
   144     User::LeaveIfError( iTelServer.Connect() ); 
       
   145     User::LeaveIfError( iTelServer.LoadPhoneModule( KMmTsyModuleName ) );
       
   146 	User::LeaveIfError( iTelServer.GetPhoneInfo( 0, phoneInfo ) );
       
   147 	User::LeaveIfError( iPhone.Open( iTelServer, phoneInfo.iName ) );
       
   148     User::LeaveIfError( iPhone.Initialise() );
       
   149     }