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 } |
|