gssettingsuis/Gs/GSNetworkPlugin/Src/PSMNetworkPlugin.cpp
author hgs
Thu, 04 Nov 2010 13:38:47 +0800
changeset 68 13e71d907dc3
permissions -rw-r--r--
201044
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
68
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Stub imlementation
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
// INCLUDE FILES
hgs
parents:
diff changeset
    20
#include <psmsettingsprovider.h>
hgs
parents:
diff changeset
    21
#include <psmsrvdomaincrkeys.h>
hgs
parents:
diff changeset
    22
#include <featmgr.h>
hgs
parents:
diff changeset
    23
#include <CoreApplicationUIsSDKCRKeys.h> // KCRUidCoreApplicationUIs, TCoreAppUIsNetworkConnectionAllowed
hgs
parents:
diff changeset
    24
#include "PSMNetworkPlugin.h"
hgs
parents:
diff changeset
    25
#include "GSNetworkPluginModel.h"
hgs
parents:
diff changeset
    26
#include "GsLogger.h"
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// CONSTANT DEFINITIONS
hgs
parents:
diff changeset
    29
const TUint32 KPSMNetworkPluginStorageId = 0x2000B593;
hgs
parents:
diff changeset
    30
// default value for network mode change key
hgs
parents:
diff changeset
    31
const TInt KPowersavingNetworkmodeNoChanged = 0; 
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
enum TPSMNetworkPluginKeys
hgs
parents:
diff changeset
    34
    {
hgs
parents:
diff changeset
    35
    ENetworkMode = 1,
hgs
parents:
diff changeset
    36
    };
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
//
hgs
parents:
diff changeset
    39
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
    40
// CPSMNetworkPlugin::CPSMNetworkPlugin()
hgs
parents:
diff changeset
    41
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
    42
//
hgs
parents:
diff changeset
    43
CPSMNetworkPlugin::CPSMNetworkPlugin( TPsmPluginCTorParams& aInitParams ) :
hgs
parents:
diff changeset
    44
    CPsmPluginBase( aInitParams )
hgs
parents:
diff changeset
    45
	{
hgs
parents:
diff changeset
    46
	}
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    49
// CPSMNetworkPlugin::ConstructL()
hgs
parents:
diff changeset
    50
// Symbian 2nd phase constructor can leave.
hgs
parents:
diff changeset
    51
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    52
//
hgs
parents:
diff changeset
    53
void CPSMNetworkPlugin::ConstructL()
hgs
parents:
diff changeset
    54
    {
hgs
parents:
diff changeset
    55
    __GSLOGSTRING( "[GS]-->[CPSMNetworkPlugin::ConstructL]" );
hgs
parents:
diff changeset
    56
    
hgs
parents:
diff changeset
    57
    iModel = CGSNetworkPluginModel::NewL( NULL,NULL );
hgs
parents:
diff changeset
    58
    iPsmRepository = CRepository::NewL( KCRUidPowerSaveMode );
hgs
parents:
diff changeset
    59
    // Read from CenRep so iPsmMode gets correct init value
hgs
parents:
diff changeset
    60
    TInt psmMode;
hgs
parents:
diff changeset
    61
    iPsmRepository->Get( KPsmCurrentMode, psmMode );
hgs
parents:
diff changeset
    62
    iPsmMode = ( TPsmsrvMode )psmMode;
hgs
parents:
diff changeset
    63
    
hgs
parents:
diff changeset
    64
    __GSLOGSTRING( "[GS]<--[CPSMNetworkPlugin::ConstructL]" );
hgs
parents:
diff changeset
    65
    }
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
//
hgs
parents:
diff changeset
    68
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
    69
// CPSMNetworkPlugin::NewL()
hgs
parents:
diff changeset
    70
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
    71
//
hgs
parents:
diff changeset
    72
// Two-phased constructor.
hgs
parents:
diff changeset
    73
CPSMNetworkPlugin* CPSMNetworkPlugin::NewL( TPsmPluginCTorParams& aInitParams )
hgs
parents:
diff changeset
    74
	{
hgs
parents:
diff changeset
    75
	CPSMNetworkPlugin* self = new ( ELeave ) CPSMNetworkPlugin( aInitParams );
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
	CleanupStack::PushL( self );
hgs
parents:
diff changeset
    78
    self->ConstructL();
hgs
parents:
diff changeset
    79
    CleanupStack::Pop( self );
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
    return self;
hgs
parents:
diff changeset
    82
	}
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
    85
// CPSMNetworkPlugin::~CPSMNetworkPlugin()
hgs
parents:
diff changeset
    86
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
    87
//
hgs
parents:
diff changeset
    88
// Destructor.
hgs
parents:
diff changeset
    89
CPSMNetworkPlugin::~CPSMNetworkPlugin()
hgs
parents:
diff changeset
    90
	{
hgs
parents:
diff changeset
    91
    __GSLOGSTRING( "[CPSMNetworkPlugin::~CPSMNetworkPlugin]" );
hgs
parents:
diff changeset
    92
    delete iModel;
hgs
parents:
diff changeset
    93
    iModel = NULL;
hgs
parents:
diff changeset
    94
    delete iPsmRepository;
hgs
parents:
diff changeset
    95
    iPsmRepository = NULL;
hgs
parents:
diff changeset
    96
	}
hgs
parents:
diff changeset
    97
hgs
parents:
diff changeset
    98
// ---------------------------------------------------------
hgs
parents:
diff changeset
    99
// CPSMNetworkPlugin::IsPhoneOfflineL
hgs
parents:
diff changeset
   100
//
hgs
parents:
diff changeset
   101
// Checks if phone is in offline mode or not.
hgs
parents:
diff changeset
   102
// Return ETrue if phone is in offline mode.
hgs
parents:
diff changeset
   103
// Return EFalse if phone is not in offline mode.
hgs
parents:
diff changeset
   104
// ---------------------------------------------------------
hgs
parents:
diff changeset
   105
//
hgs
parents:
diff changeset
   106
TBool CPSMNetworkPlugin::IsPhoneOfflineL() const
hgs
parents:
diff changeset
   107
    {
hgs
parents:
diff changeset
   108
    if ( FeatureManager::FeatureSupported( KFeatureIdOfflineMode ) )
hgs
parents:
diff changeset
   109
        {
hgs
parents:
diff changeset
   110
        CRepository* repository = CRepository::NewLC( KCRUidCoreApplicationUIs );
hgs
parents:
diff changeset
   111
        TInt connAllowed = 1;
hgs
parents:
diff changeset
   112
        repository->Get( KCoreAppUIsNetworkConnectionAllowed, connAllowed );
hgs
parents:
diff changeset
   113
        CleanupStack::PopAndDestroy();  // repository
hgs
parents:
diff changeset
   114
        if ( !connAllowed )
hgs
parents:
diff changeset
   115
            {
hgs
parents:
diff changeset
   116
            return ETrue;
hgs
parents:
diff changeset
   117
            }
hgs
parents:
diff changeset
   118
        }
hgs
parents:
diff changeset
   119
    return EFalse;
hgs
parents:
diff changeset
   120
    }
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
   123
// CPSMNetworkPlugin::NotifyModeChange()
hgs
parents:
diff changeset
   124
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
   125
//
hgs
parents:
diff changeset
   126
void CPSMNetworkPlugin::NotifyModeChange( const TInt aMode )
hgs
parents:
diff changeset
   127
    {
hgs
parents:
diff changeset
   128
    TInt err = KErrNone;
hgs
parents:
diff changeset
   129
    TRAP( err, DoModeChangeL( aMode ) );
hgs
parents:
diff changeset
   130
    if ( KErrNone != err)
hgs
parents:
diff changeset
   131
        {}
hgs
parents:
diff changeset
   132
    __GSLOGSTRING2( "[CPSMNetworkPlugin::NotifyModeChange]: Mode:%d Err:%d", aMode, err );
hgs
parents:
diff changeset
   133
    }
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
hgs
parents:
diff changeset
   136
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
   137
// CPSMNetworkPlugin::NotifyModeChange()
hgs
parents:
diff changeset
   138
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
   139
//
hgs
parents:
diff changeset
   140
void CPSMNetworkPlugin::DoModeChangeL( const TInt aMode )
hgs
parents:
diff changeset
   141
    {
hgs
parents:
diff changeset
   142
	TPsmsrvMode newMode = ( TPsmsrvMode )aMode;
hgs
parents:
diff changeset
   143
    if ( !IsPhoneOfflineL() && 
hgs
parents:
diff changeset
   144
         FeatureManager::FeatureSupported( KFeatureIdProtocolWcdma ) &&
hgs
parents:
diff changeset
   145
         iModel->IsNetworkModeVisible() && IsChangeNetworkModeL ( iPsmMode, newMode ) )
hgs
parents:
diff changeset
   146
        {
hgs
parents:
diff changeset
   147
        RConfigInfoArray infoArray;
hgs
parents:
diff changeset
   148
    
hgs
parents:
diff changeset
   149
        TPsmsrvConfigInfo info1;
hgs
parents:
diff changeset
   150
        info1.iConfigId = ENetworkMode;
hgs
parents:
diff changeset
   151
        info1.iConfigType = EConfigTypeInt;
hgs
parents:
diff changeset
   152
        info1.iIntValue = iModel->GetNetworkMode();
hgs
parents:
diff changeset
   153
        infoArray.Append( info1 );
hgs
parents:
diff changeset
   154
        
hgs
parents:
diff changeset
   155
        __GSLOGSTRING1( "[CPSMNetworkPlugin::NotifyModeChangeL] Switching to mode:%d", aMode );
hgs
parents:
diff changeset
   156
    
hgs
parents:
diff changeset
   157
        __GSLOGSTRING1( "[CPSMNetworkPlugin::NotifyModeChangeL]: oldValue info1: %d", infoArray[0].iIntValue );
hgs
parents:
diff changeset
   158
    
hgs
parents:
diff changeset
   159
        iSettingsProvider.BackupAndGetSettingsL( infoArray, KPSMNetworkPluginStorageId );
hgs
parents:
diff changeset
   160
        
hgs
parents:
diff changeset
   161
        __GSLOGSTRING1( "[CPSMNetworkPlugin::NotifyModeChangeL]: newValue info1: %d", infoArray[0].iIntValue );
hgs
parents:
diff changeset
   162
    
hgs
parents:
diff changeset
   163
        // Don't change the network mode if there is ongoing phone call
hgs
parents:
diff changeset
   164
        // since this will disconnect it
hgs
parents:
diff changeset
   165
        if ( !iModel->IsCallActive() )
hgs
parents:
diff changeset
   166
            {
hgs
parents:
diff changeset
   167
            iModel->SetNetworkModeL ( infoArray[0].iIntValue  );
hgs
parents:
diff changeset
   168
            }
hgs
parents:
diff changeset
   169
        
hgs
parents:
diff changeset
   170
        infoArray.Reset();       
hgs
parents:
diff changeset
   171
        }
hgs
parents:
diff changeset
   172
    }
hgs
parents:
diff changeset
   173
hgs
parents:
diff changeset
   174
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
   175
// CPSMNetworkPlugin::IsChangeNetworkMode
hgs
parents:
diff changeset
   176
// ----------------------------------------------------------------------------------
hgs
parents:
diff changeset
   177
//
hgs
parents:
diff changeset
   178
TBool CPSMNetworkPlugin::IsChangeNetworkModeL( TPsmsrvMode& aOldMode, TPsmsrvMode aNewMode )
hgs
parents:
diff changeset
   179
    {
hgs
parents:
diff changeset
   180
    // get the value of network mode change key  
hgs
parents:
diff changeset
   181
    TInt modeChange = iModel->GetPsmNetworkModeChangeL();    
hgs
parents:
diff changeset
   182
    TPsmsrvMode oldMode = aOldMode;
hgs
parents:
diff changeset
   183
    aOldMode = aNewMode;
hgs
parents:
diff changeset
   184
    if ( ( oldMode == EPsmsrvModeNormal && aNewMode == EPsmsrvPartialMode )
hgs
parents:
diff changeset
   185
         || ( oldMode == EPsmsrvModePowerSave && aNewMode == EPsmsrvPartialMode )
hgs
parents:
diff changeset
   186
         || ( KPowersavingNetworkmodeNoChanged == modeChange ) )
hgs
parents:
diff changeset
   187
        {
hgs
parents:
diff changeset
   188
        return EFalse;
hgs
parents:
diff changeset
   189
        }
hgs
parents:
diff changeset
   190
    else
hgs
parents:
diff changeset
   191
        {
hgs
parents:
diff changeset
   192
        return ETrue;
hgs
parents:
diff changeset
   193
        }
hgs
parents:
diff changeset
   194
    }
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
//End of File
hgs
parents:
diff changeset
   197
hgs
parents:
diff changeset
   198