phoneengine/networkhandlingstarter/src/cnetworklistener.cpp
author hgs
Fri, 15 Oct 2010 12:58:46 +0300
changeset 78 baacf668fe89
parent 65 2a5d4ab426d3
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     1
/*
50
hgs
parents: 45
diff changeset
     2
 * Copyright (c) 2009-2010 Nokia Corporation and/or its subsidiary(-ies).
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     3
 * All rights reserved.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     4
 * This component and the accompanying materials are made available
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     5
 * under the terms of "Eclipse Public License v1.0"
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     6
 * which accompanies this distribution, and is available
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     7
 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     8
 *
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
     9
 * Initial Contributors:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    10
 * Nokia Corporation - initial contribution.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    11
 *
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    12
 * Contributors:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    13
 *
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    14
 * Description:  
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    15
 *
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    16
 */
45
6b911d05207e Revision: 201023
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 27
diff changeset
    17
#include <networkhandlingproxy.h>
6b911d05207e Revision: 201023
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents: 27
diff changeset
    18
#include <cnwsession.h>
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    19
#include <BTSapDomainPSKeys.h>
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    20
#include <startupdomainpskeys.h>
60
hgs
parents: 50
diff changeset
    21
#include <PsetContainer.h>
hgs
parents: 50
diff changeset
    22
#include <PsetNetwork.h>
hgs
parents: 50
diff changeset
    23
#include <PsetSAObserver.h>
65
hgs
parents: 60
diff changeset
    24
#include <centralrepository.h>
hgs
parents: 60
diff changeset
    25
#include <CoreApplicationUIsSDKCRKeys.h>
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    26
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    27
#include "cnetworklistener.h"
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    28
#include "mnetworklistenerobserver.h"
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    29
#include "networkhandlingstarterlogging.h"
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    30
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    31
// Constants
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    32
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    33
// 1-minute timeout before showing soft notification
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    34
const TInt KNetworkLostTimeout = 60*1000000;
60
hgs
parents: 50
diff changeset
    35
const TInt KSimRefreshAsynronationTimeout = 1000000;
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    36
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    37
// ======== MEMBER FUNCTIONS ========
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    38
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    39
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    40
    Constructor of CNetworkListener.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    41
 */
50
hgs
parents: 45
diff changeset
    42
CNetworkListener::CNetworkListener( MNetworkListenerObserver& aObserver )
hgs
parents: 45
diff changeset
    43
    :
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    44
    iRegistered(ETrue),
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    45
    iObserver(aObserver)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    46
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    47
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    48
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    49
    DPRINT << ": OUT";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    50
}
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    51
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    52
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    53
    Constructor of CNetworkListener.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    54
 */
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    55
void CNetworkListener::ConstructL()
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    56
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    57
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    58
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    59
    //Create network handling engine session.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    60
    iSession = CreateL(*this, iInfo);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    61
    iTimer = CPeriodic::NewL(CActive::EPriorityStandard);
50
hgs
parents: 45
diff changeset
    62
    QT_TRYCATCH_LEAVING(iDeviceInfo = new QSystemDeviceInfo())
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    63
    
60
hgs
parents: 50
diff changeset
    64
    iContainer = CPsetContainer::NewL();
hgs
parents: 50
diff changeset
    65
    iRefreshHandler = iContainer->CreateRefreshHandlerL();
hgs
parents: 50
diff changeset
    66
    iRefreshHandler->NotifyFileChangeL(
hgs
parents: 50
diff changeset
    67
            *this,
hgs
parents: 50
diff changeset
    68
            KCsp1Ef,
hgs
parents: 50
diff changeset
    69
            EFileChangeNotification );
hgs
parents: 50
diff changeset
    70
    iSettingsEngine = iContainer->CreateNetworkObjectL(*this);
hgs
parents: 50
diff changeset
    71
    
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    72
    DPRINT << ": OUT";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    73
}
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    74
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    75
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    76
    Constructor of CNetworkListener.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    77
 */
50
hgs
parents: 45
diff changeset
    78
CNetworkListener* CNetworkListener::NewL( MNetworkListenerObserver& aObserver )
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    79
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    80
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    81
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    82
    CNetworkListener* self = new(ELeave) CNetworkListener(aObserver);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    83
    CleanupStack::PushL( self );
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    84
    self->ConstructL();
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    85
    CleanupStack::Pop( self );
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    86
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    87
    DPRINT << ": OUT";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    88
    return self;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    89
 }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    90
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    91
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    92
    Destructor of CNetworkListener.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    93
 */
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    94
CNetworkListener::~CNetworkListener()
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    95
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    96
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    97
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    98
    delete iSession;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    99
    delete iTimer;
50
hgs
parents: 45
diff changeset
   100
    delete iDeviceInfo;
60
hgs
parents: 50
diff changeset
   101
    delete iSettingsEngine;
hgs
parents: 50
diff changeset
   102
    delete iRefreshHandler;
hgs
parents: 50
diff changeset
   103
    delete iContainer;    
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   104
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   105
    DPRINT << ": OUT";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   106
}
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   107
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   108
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   109
    CNetworkListener::HandleNetworkMessage.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   110
 */
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   111
void CNetworkListener::HandleNetworkMessage(const TNWMessages aMessage)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   112
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   113
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   114
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   115
    if(aMessage == ENWMessageNetworkRegistrationStatusChange) {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   116
        switch(iInfo.iRegistrationStatus) {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   117
            case ENWNotRegisteredNoService:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   118
                // Fall-through
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   119
            case ENWNotRegisteredEmergencyOnly:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   120
                // Fall-through
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   121
            case ENWNotRegisteredSearching:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   122
                // Fall-through
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   123
            case ENWRegistrationDenied:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   124
                HandleNetworkLost();
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   125
                break;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   126
            
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   127
            case ENWRegisteredBusy:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   128
                // Fall-through
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   129
            case ENWRegisteredOnHomeNetwork:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   130
                // Fall-through
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   131
            case ENWRegisteredRoaming:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   132
                HandleNetworkFound();
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   133
                break;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   134
            
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   135
            case ENWRegistrationUnknown:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   136
                // Take no action
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   137
            default:
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   138
                break;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   139
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   140
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   141
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   142
    DPRINT << ": OUT";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   143
}
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   144
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   145
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   146
    CNetworkListener::HandleNetworkError.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   147
 */
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   148
void CNetworkListener::HandleNetworkError( 
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   149
    const TNWOperation /*aOperation*/, TInt /*aErrorCode*/)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   150
    {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   151
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   152
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   153
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   154
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   155
    CNetworkListener::NWLostDelayCallBack.
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   156
 */
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   157
TInt CNetworkListener::NWLostDelayCallBack(TAny* aParam)
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   158
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   159
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   160
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   161
    CNetworkListener* self = 
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   162
        reinterpret_cast< CNetworkListener* >( aParam );
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   163
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   164
    if ( self ) {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   165
        self->iTimer->Cancel();
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   166
        self->iObserver.ShowNote();
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   167
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   168
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   169
    DPRINT << ": OUT";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   170
    return KErrNone;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   171
}
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   172
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   173
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   174
    CNetworkListener::HandleNetworkFound
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   175
 */
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   176
void CNetworkListener::HandleNetworkFound()
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   177
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   178
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   179
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   180
    if (!iRegistered) {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   181
        iTimer->Cancel();
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   182
        iObserver.RemoveNote();
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   183
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   184
    iRegistered = ETrue;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   185
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   186
    DPRINT << ": OUT";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   187
}
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   188
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   189
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   190
    CNetworkListener::HandleNetworkLost
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   191
 */
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   192
void CNetworkListener::HandleNetworkLost()
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   193
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   194
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   195
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   196
    if (iInfo.iSelectionSetting == ENWNetworkSelectionManual) {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   197
        // See if we were registered before
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   198
        if (iRegistered) {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   199
            iRegistered = EFalse;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   200
65
hgs
parents: 60
diff changeset
   201
            if (IsNetworkConnectionAllowed() &&
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   202
                !IsBluetoothSAPConnected() &&
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   203
                IsSimOk()) {
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   204
                // Start 60 second timer and when expired show the
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   205
                // notifier
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   206
                iTimer->Cancel();
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   207
                iTimer->Start(KNetworkLostTimeout,
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   208
                              KNetworkLostTimeout,
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   209
                              TCallBack( NWLostDelayCallBack, this ));
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   210
             }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   211
        }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   212
    }
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   213
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   214
    DPRINT << ": OUT";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   215
}
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   216
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   217
/*!
65
hgs
parents: 60
diff changeset
   218
    CNetworkListener::IsNetworkConnectionAllowed
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   219
 */
65
hgs
parents: 60
diff changeset
   220
TBool CNetworkListener::IsNetworkConnectionAllowed() const
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   221
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   222
    DPRINT << ": IN";
65
hgs
parents: 60
diff changeset
   223
    // Key indicates whether network connections are allowed.
hgs
parents: 60
diff changeset
   224
    // E.g. is Offline Mode active or not.
hgs
parents: 60
diff changeset
   225
    TInt nwConnectionAllowed( ECoreAppUIsNetworkConnectionAllowed );
hgs
parents: 60
diff changeset
   226
    CRepository* repository = CRepository::NewL( KCRUidCoreApplicationUIs );
hgs
parents: 60
diff changeset
   227
    repository->Get(KCoreAppUIsNetworkConnectionAllowed,nwConnectionAllowed);
hgs
parents: 60
diff changeset
   228
    delete repository;
hgs
parents: 60
diff changeset
   229
    repository = NULL;
hgs
parents: 60
diff changeset
   230
hgs
parents: 60
diff changeset
   231
    DPRINT << ": OUT, nwConnectionAllowed: " << nwConnectionAllowed;
hgs
parents: 60
diff changeset
   232
    return nwConnectionAllowed == ECoreAppUIsNetworkConnectionAllowed;
hgs
parents: 60
diff changeset
   233
}
hgs
parents: 60
diff changeset
   234
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   235
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   236
    CNetworkListener::IsBluetoothSAPConnected
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   237
 */
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   238
TBool CNetworkListener::IsBluetoothSAPConnected() const
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   239
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   240
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   241
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   242
    TInt btSapState( EBTSapNotConnected );
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   243
    TInt err = RProperty::Get(KPSUidBluetoothSapConnectionState,
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   244
                              KBTSapConnectionState,
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   245
                              btSapState );
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   246
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   247
    DPRINT << ": OUT";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   248
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   249
    return btSapState != EBTSapNotConnected && err == KErrNone;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   250
}
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   251
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   252
/*!
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   253
    CNetworkListener::IsSimOk
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   254
 */
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   255
TBool CNetworkListener::IsSimOk() const
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   256
{
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   257
    DPRINT << ": IN";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   258
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   259
    TInt simState(ESimStatusUninitialized);
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   260
    TInt err = RProperty::Get(KPSUidStartup,
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   261
                              KPSSimStatus,
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   262
                              simState );
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   263
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   264
    DPRINT << ": OUT";
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   265
    
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   266
    return simState == ESimUsable && err == KErrNone;
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   267
}
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   268
60
hgs
parents: 50
diff changeset
   269
/*!
hgs
parents: 50
diff changeset
   270
    CNetworkListener::AllowRefresh
hgs
parents: 50
diff changeset
   271
 */
hgs
parents: 50
diff changeset
   272
TBool CNetworkListener::AllowRefresh(
hgs
parents: 50
diff changeset
   273
                const TSatRefreshType aType,
hgs
parents: 50
diff changeset
   274
                const TSatElementaryFiles aFiles )
hgs
parents: 50
diff changeset
   275
{
hgs
parents: 50
diff changeset
   276
    DPRINT << "aType: " << aType;
hgs
parents: 50
diff changeset
   277
    DPRINT << "aFiles: " << aFiles;
hgs
parents: 50
diff changeset
   278
    
hgs
parents: 50
diff changeset
   279
    TBool allowRefresh = ETrue;
hgs
parents: 50
diff changeset
   280
    if ( iSettingsEngine->IsCallActive() == CPsetSAObserver::EPSetCallActive )
hgs
parents: 50
diff changeset
   281
        {
hgs
parents: 50
diff changeset
   282
        allowRefresh = EFalse;
hgs
parents: 50
diff changeset
   283
        }
hgs
parents: 50
diff changeset
   284
hgs
parents: 50
diff changeset
   285
    DPRINT << ": OUT allowRefresh " << allowRefresh;
hgs
parents: 50
diff changeset
   286
    
hgs
parents: 50
diff changeset
   287
    return allowRefresh;
hgs
parents: 50
diff changeset
   288
}
hgs
parents: 50
diff changeset
   289
hgs
parents: 50
diff changeset
   290
/*!
hgs
parents: 50
diff changeset
   291
    CNetworkListener::Refresh
hgs
parents: 50
diff changeset
   292
 */
hgs
parents: 50
diff changeset
   293
void CNetworkListener::Refresh(
hgs
parents: 50
diff changeset
   294
                const TSatRefreshType aType,
hgs
parents: 50
diff changeset
   295
                const TSatElementaryFiles aFiles )
hgs
parents: 50
diff changeset
   296
{
hgs
parents: 50
diff changeset
   297
    DPRINT << ": IN";
hgs
parents: 50
diff changeset
   298
    
hgs
parents: 50
diff changeset
   299
    if ((aType != EFileChangeNotification) ||
hgs
parents: 50
diff changeset
   300
        ((aType == EFileChangeNotification) &&
hgs
parents: 50
diff changeset
   301
        (aFiles & KCsp1Ef)))
hgs
parents: 50
diff changeset
   302
        {
hgs
parents: 50
diff changeset
   303
        MPsetNetworkSelect::TSelectMode mode;
hgs
parents: 50
diff changeset
   304
        iSettingsEngine->GetNetworkSelectMode(mode);
hgs
parents: 50
diff changeset
   305
        DPRINT << "mode " << mode;
hgs
parents: 50
diff changeset
   306
        if (mode == MPsetNetworkSelect::ENetSelectModeManual) {
hgs
parents: 50
diff changeset
   307
            TPSetChangedCspSetting changedCspSettings;
hgs
parents: 50
diff changeset
   308
            TPSetChangedCspSetting newValues;
hgs
parents: 50
diff changeset
   309
            TInt err = iRefreshHandler->ChangedCspSettings(changedCspSettings, newValues);
hgs
parents: 50
diff changeset
   310
            if ((changedCspSettings & EPSetNetSelSup) && 
hgs
parents: 50
diff changeset
   311
                !(newValues & EPSetNetSelSup) &&
hgs
parents: 50
diff changeset
   312
                (err == KErrNone)) {
hgs
parents: 50
diff changeset
   313
                DPRINT << "Network selection not supported ";
hgs
parents: 50
diff changeset
   314
                // Network selection mode can't change during SIM refresh,
hgs
parents: 50
diff changeset
   315
                // start 1 second timer.
hgs
parents: 50
diff changeset
   316
                iTimer->Cancel();
hgs
parents: 50
diff changeset
   317
                iTimer->Start(KSimRefreshAsynronationTimeout,
hgs
parents: 50
diff changeset
   318
                              KSimRefreshAsynronationTimeout,
hgs
parents: 50
diff changeset
   319
                              TCallBack( NWSimRefreshCallBack, this ));
hgs
parents: 50
diff changeset
   320
            }
hgs
parents: 50
diff changeset
   321
        }
hgs
parents: 50
diff changeset
   322
    }
hgs
parents: 50
diff changeset
   323
    
hgs
parents: 50
diff changeset
   324
    DPRINT << ": OUT";
hgs
parents: 50
diff changeset
   325
}
hgs
parents: 50
diff changeset
   326
hgs
parents: 50
diff changeset
   327
/*!
hgs
parents: 50
diff changeset
   328
    CNetworkListener::HandleNetworkInfoReceivedL
hgs
parents: 50
diff changeset
   329
 */
hgs
parents: 50
diff changeset
   330
void CNetworkListener::HandleNetworkInfoReceivedL( 
hgs
parents: 50
diff changeset
   331
        const CNetworkInfoArray* /*aInfoArray*/, const TInt /*aResult*/ )
hgs
parents: 50
diff changeset
   332
{
hgs
parents: 50
diff changeset
   333
    DPRINT;
hgs
parents: 50
diff changeset
   334
}
hgs
parents: 50
diff changeset
   335
hgs
parents: 50
diff changeset
   336
/*!
hgs
parents: 50
diff changeset
   337
    CNetworkListener::HandleCurrentNetworkInfoL
hgs
parents: 50
diff changeset
   338
 */
hgs
parents: 50
diff changeset
   339
void CNetworkListener::HandleCurrentNetworkInfoL( 
hgs
parents: 50
diff changeset
   340
        const MPsetNetworkSelect::TCurrentNetworkInfo& /*aCurrentInfo*/, 
hgs
parents: 50
diff changeset
   341
        const TInt /*aResult*/ )
hgs
parents: 50
diff changeset
   342
{
hgs
parents: 50
diff changeset
   343
    DPRINT;
hgs
parents: 50
diff changeset
   344
}
hgs
parents: 50
diff changeset
   345
hgs
parents: 50
diff changeset
   346
/*!
hgs
parents: 50
diff changeset
   347
    CNetworkListener::HandleNetworkChangedL
hgs
parents: 50
diff changeset
   348
 */
hgs
parents: 50
diff changeset
   349
void CNetworkListener::HandleNetworkChangedL( 
hgs
parents: 50
diff changeset
   350
        const MPsetNetworkSelect::TNetworkInfo& /*aCurrentInfo*/,
hgs
parents: 50
diff changeset
   351
        const MPsetNetworkSelect::TCurrentNetworkStatus /*aStatus*/, 
hgs
parents: 50
diff changeset
   352
        const TInt /*aResult*/ )
hgs
parents: 50
diff changeset
   353
{
hgs
parents: 50
diff changeset
   354
    /**
hgs
parents: 50
diff changeset
   355
    *  DEPRECATED.
hgs
parents: 50
diff changeset
   356
    */
hgs
parents: 50
diff changeset
   357
}
hgs
parents: 50
diff changeset
   358
hgs
parents: 50
diff changeset
   359
/*!
hgs
parents: 50
diff changeset
   360
    CNetworkListener::HandleNetworkChangedL
hgs
parents: 50
diff changeset
   361
 */
hgs
parents: 50
diff changeset
   362
void CNetworkListener::HandleNetworkChangedL( 
hgs
parents: 50
diff changeset
   363
        const MPsetNetworkSelect::TNetworkInfo& /*aCurrentInfo*/,
hgs
parents: 50
diff changeset
   364
        const RMobilePhone::TMobilePhoneRegistrationStatus& /*aStatus*/, 
hgs
parents: 50
diff changeset
   365
        const TInt /*aResult*/ )
hgs
parents: 50
diff changeset
   366
{
hgs
parents: 50
diff changeset
   367
    DPRINT;
hgs
parents: 50
diff changeset
   368
}
hgs
parents: 50
diff changeset
   369
hgs
parents: 50
diff changeset
   370
/*!
hgs
parents: 50
diff changeset
   371
    CNetworkListener::HandleSearchingNetworksL
hgs
parents: 50
diff changeset
   372
 */
hgs
parents: 50
diff changeset
   373
void CNetworkListener::HandleSearchingNetworksL( TServiceRequest /*aRequest*/ )
hgs
parents: 50
diff changeset
   374
{
hgs
parents: 50
diff changeset
   375
    DPRINT;
hgs
parents: 50
diff changeset
   376
}
hgs
parents: 50
diff changeset
   377
hgs
parents: 50
diff changeset
   378
/*!
hgs
parents: 50
diff changeset
   379
    CNetworkListener::HandleRequestingSelectedNetworkL
hgs
parents: 50
diff changeset
   380
 */
hgs
parents: 50
diff changeset
   381
void CNetworkListener::HandleRequestingSelectedNetworkL( TBool /*aOngoing*/ )
hgs
parents: 50
diff changeset
   382
{
hgs
parents: 50
diff changeset
   383
    DPRINT; 
hgs
parents: 50
diff changeset
   384
}
hgs
parents: 50
diff changeset
   385
hgs
parents: 50
diff changeset
   386
/*!
hgs
parents: 50
diff changeset
   387
    CNetworkListener::HandleCallActivatedL
hgs
parents: 50
diff changeset
   388
 */
hgs
parents: 50
diff changeset
   389
void CNetworkListener::HandleCallActivatedL()
hgs
parents: 50
diff changeset
   390
{
hgs
parents: 50
diff changeset
   391
    DPRINT;
hgs
parents: 50
diff changeset
   392
}
hgs
parents: 50
diff changeset
   393
hgs
parents: 50
diff changeset
   394
/*!
hgs
parents: 50
diff changeset
   395
    CNetworkListener::HandleNetworkErrorL
hgs
parents: 50
diff changeset
   396
 */
hgs
parents: 50
diff changeset
   397
void CNetworkListener::HandleNetworkErrorL( 
hgs
parents: 50
diff changeset
   398
        const MPsetNetworkInfoObserver::TServiceRequest /*aRequest*/,
hgs
parents: 50
diff changeset
   399
        const TInt /*aError*/ )
hgs
parents: 50
diff changeset
   400
{
hgs
parents: 50
diff changeset
   401
    DPRINT;
hgs
parents: 50
diff changeset
   402
}
hgs
parents: 50
diff changeset
   403
hgs
parents: 50
diff changeset
   404
/*!
hgs
parents: 50
diff changeset
   405
    CNetworkListener::NWSimRefreshCallBack.
hgs
parents: 50
diff changeset
   406
 */
hgs
parents: 50
diff changeset
   407
TInt CNetworkListener::NWSimRefreshCallBack(TAny* aParam)
hgs
parents: 50
diff changeset
   408
{
hgs
parents: 50
diff changeset
   409
    DPRINT << ": IN";
hgs
parents: 50
diff changeset
   410
    
hgs
parents: 50
diff changeset
   411
    CNetworkListener* self = 
hgs
parents: 50
diff changeset
   412
        reinterpret_cast< CNetworkListener* >( aParam );
hgs
parents: 50
diff changeset
   413
    
hgs
parents: 50
diff changeset
   414
    if ( self ) {
hgs
parents: 50
diff changeset
   415
        self->iTimer->Cancel();
hgs
parents: 50
diff changeset
   416
        //Change the network mode to Automatic.
hgs
parents: 50
diff changeset
   417
        MPsetNetworkSelect::TNetworkInfo info;
hgs
parents: 50
diff changeset
   418
        info.iMode = MPsetNetworkSelect::ENetSelectModeAutomatic;
hgs
parents: 50
diff changeset
   419
        DPRINT << ": set network mode to automatic";
hgs
parents: 50
diff changeset
   420
        TRAP_IGNORE(self->iSettingsEngine->SelectNetworkL(info));
hgs
parents: 50
diff changeset
   421
    }
hgs
parents: 50
diff changeset
   422
    
hgs
parents: 50
diff changeset
   423
    DPRINT << ": OUT";
hgs
parents: 50
diff changeset
   424
    return KErrNone;
hgs
parents: 50
diff changeset
   425
}
hgs
parents: 50
diff changeset
   426
27
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   427
// End of file
2f8f8080a020 Revision: 201015
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   428