cbs/cbsserver/ServerSrc/CCbsReceiverHelper.cpp
author hgs
Wed, 21 Jul 2010 18:26:52 +0300
changeset 33 8d5d7fcf9b59
child 35 6aefa3341fcc
permissions -rw-r--r--
201027
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2003-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:  This module contains the implementation of CCbsReceiverHelper class
hgs
parents:
diff changeset
    15
*                member functions.
hgs
parents:
diff changeset
    16
*
hgs
parents:
diff changeset
    17
*                CCbsReceiverHelper gets the messages from the receiver and
hgs
parents:
diff changeset
    18
*                sends them to the database. All received messages are
hgs
parents:
diff changeset
    19
*                sent to CCbsReceiverHelper instance by CCbsRecEtel.
hgs
parents:
diff changeset
    20
*                This class makes subscription and existence checks
hgs
parents:
diff changeset
    21
*                to these messages and also implements topic detection feature.
hgs
parents:
diff changeset
    22
*
hgs
parents:
diff changeset
    23
*/
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// INCLUDE FILES
hgs
parents:
diff changeset
    27
#include <barsc.h>              // Resource access
hgs
parents:
diff changeset
    28
#include <barsread.h>           // Resource access
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
#include <CbsServer.rsg>
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
#include "CbsCommon.h"
hgs
parents:
diff changeset
    33
#include "CbsUtils.h"
hgs
parents:
diff changeset
    34
#include "CbsServerPanic.h"
hgs
parents:
diff changeset
    35
#include "CCbsServer.h"
hgs
parents:
diff changeset
    36
#include "CCbsReceiverHelper.h"
hgs
parents:
diff changeset
    37
#include "CCbsDbImp.H"
hgs
parents:
diff changeset
    38
#include "CCbsDbImpSettings.H"
hgs
parents:
diff changeset
    39
#include "CCbsDbImpTopicList.h"
hgs
parents:
diff changeset
    40
#include "CCbsDbImpTopicMessages.h"
hgs
parents:
diff changeset
    41
#include "CCbsDbImpTopicCollection.h"
hgs
parents:
diff changeset
    42
#include "CCbsRecMessage.h"
hgs
parents:
diff changeset
    43
#ifndef SYMBIAN_ENABLE_SPLIT_HEADERS
hgs
parents:
diff changeset
    44
#include <viewcli.h>            // View server access
hgs
parents:
diff changeset
    45
#else
hgs
parents:
diff changeset
    46
#include <viewclipartner.h>
hgs
parents:
diff changeset
    47
#endif
hgs
parents:
diff changeset
    48
#include <AknNotifyStd.h>       // ECellBroadcastNotification
hgs
parents:
diff changeset
    49
#include <AknSoftNotifier.h>    // Soft Notification API
hgs
parents:
diff changeset
    50
#include <e32property.h>
hgs
parents:
diff changeset
    51
#include <coreapplicationuisdomainpskeys.h>
hgs
parents:
diff changeset
    52
// <-- QT PHONE START -->
hgs
parents:
diff changeset
    53
//#include <NcnListDomainPSKeys.h> 
hgs
parents:
diff changeset
    54
// <-- QT PHONE END -->
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
#include <data_caging_path_literals.hrh>
hgs
parents:
diff changeset
    57
#include "CbsLogger.h"
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
#include <centralrepository.h>  // for local variation
hgs
parents:
diff changeset
    60
#include "cbsinternalcrkeys.h"  // for local variation
hgs
parents:
diff changeset
    61
#include "cbsvariant.hrh"       // for local variation
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
// CONSTANTS
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
// UID of CBS UI application
hgs
parents:
diff changeset
    66
#define KUidCbsUiappDef 0x101F4CD3
hgs
parents:
diff changeset
    67
const TUid KUidCbsUiappApp = { KUidCbsUiappDef };
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
const TInt KCbsImmediateMessageIdInt = 313;
hgs
parents:
diff changeset
    70
const TUid KCbsImmediateMessageId = { KCbsImmediateMessageIdInt };
hgs
parents:
diff changeset
    71
// <-- QT PHONE START -->
hgs
parents:
diff changeset
    72
//const TInt KCbsMessageTone  = 2; // See SharedDataKeysVariant.h or NcnListInternalPSKeys.h
hgs
parents:
diff changeset
    73
// <-- QT PHONE END -->
hgs
parents:
diff changeset
    74
// DATA TYPES
hgs
parents:
diff changeset
    75
// CbsUi application view ID's
hgs
parents:
diff changeset
    76
enum TCbsUiViewIds
hgs
parents:
diff changeset
    77
    {
hgs
parents:
diff changeset
    78
    ECbsUiTopicViewId = 1,
hgs
parents:
diff changeset
    79
    ECbsUiTopicListViewId,
hgs
parents:
diff changeset
    80
    ECbsUiListAppColumnViewId,
hgs
parents:
diff changeset
    81
    ECbsUiMsgViewId,            //message view id
hgs
parents:
diff changeset
    82
    ECbsUiAddFromIndexViewId,
hgs
parents:
diff changeset
    83
    ECbsUiSettingsViewId
hgs
parents:
diff changeset
    84
    };
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
// These values specify a range of accepted topic number values (inclusive).
hgs
parents:
diff changeset
    87
const TUint KMinTopicNumber = 1;     // 000 is not accepted.
hgs
parents:
diff changeset
    88
const TUint KMaxTopicNumber = 999;
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
// LOCAL FUNCTION PROTOTYPES
hgs
parents:
diff changeset
    91
LOCAL_C void ParseMessageFormatL(
hgs
parents:
diff changeset
    92
    TLex& aLex, CCbsDbImpTopicCollection& aCollection );
hgs
parents:
diff changeset
    93
LOCAL_C void ParseIndexElementIntroL(
hgs
parents:
diff changeset
    94
    TLex& aLex, CCbsDbImpTopicCollection& aCollection );
hgs
parents:
diff changeset
    95
LOCAL_C void ParseServiceIntroL(
hgs
parents:
diff changeset
    96
    TLex& aLex, CCbsDbImpTopicCollection& aCollection );
hgs
parents:
diff changeset
    97
LOCAL_C void ParseMessageIdL(
hgs
parents:
diff changeset
    98
    TLex& aLex, TUint& aMessageId );
hgs
parents:
diff changeset
    99
LOCAL_C void ParseSubIndexIntroL(
hgs
parents:
diff changeset
   100
    TLex& aLex );
hgs
parents:
diff changeset
   101
LOCAL_C void ParseSubIndexIdL(
hgs
parents:
diff changeset
   102
    TLex& aLex );
hgs
parents:
diff changeset
   103
LOCAL_C void ParseNameCharactersCrLfL(
hgs
parents:
diff changeset
   104
    TLex& aLex, TPtrC& aName );
hgs
parents:
diff changeset
   105
hgs
parents:
diff changeset
   106
// ==================== LOCAL FUNCTIONS ====================
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   109
// ParseMessageFormatL
hgs
parents:
diff changeset
   110
// Parses an index message.
hgs
parents:
diff changeset
   111
// Returns: None
hgs
parents:
diff changeset
   112
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   113
//
hgs
parents:
diff changeset
   114
LOCAL_C void ParseMessageFormatL(
hgs
parents:
diff changeset
   115
    TLex& aLex,
hgs
parents:
diff changeset
   116
    CCbsDbImpTopicCollection& aCollection )
hgs
parents:
diff changeset
   117
    {
hgs
parents:
diff changeset
   118
    TInt identitiesCount( 0 );
hgs
parents:
diff changeset
   119
    while ( !aLex.Eos() )
hgs
parents:
diff changeset
   120
        {
hgs
parents:
diff changeset
   121
        ParseIndexElementIntroL( aLex, aCollection );
hgs
parents:
diff changeset
   122
        identitiesCount++;
hgs
parents:
diff changeset
   123
        }
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
    if ( identitiesCount == 0 )
hgs
parents:
diff changeset
   126
        {
hgs
parents:
diff changeset
   127
        User::Leave( KErrCorrupt );
hgs
parents:
diff changeset
   128
        }
hgs
parents:
diff changeset
   129
    }
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   132
// ParseIndexElementIntroL
hgs
parents:
diff changeset
   133
// Parses part of an index message.
hgs
parents:
diff changeset
   134
// Returns: None
hgs
parents:
diff changeset
   135
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   136
//
hgs
parents:
diff changeset
   137
LOCAL_C void ParseIndexElementIntroL(
hgs
parents:
diff changeset
   138
    TLex& aLex,
hgs
parents:
diff changeset
   139
    CCbsDbImpTopicCollection& aCollection )
hgs
parents:
diff changeset
   140
    {
hgs
parents:
diff changeset
   141
    TBool hasSubIndexId( EFalse );
hgs
parents:
diff changeset
   142
hgs
parents:
diff changeset
   143
    // subindex-id (optional for service-intro)
hgs
parents:
diff changeset
   144
    if ( aLex.Peek().IsAlpha() )
hgs
parents:
diff changeset
   145
        {
hgs
parents:
diff changeset
   146
        hasSubIndexId = ETrue;
hgs
parents:
diff changeset
   147
        ParseSubIndexIdL( aLex );
hgs
parents:
diff changeset
   148
        }
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
    // subindex-intro | service-intro
hgs
parents:
diff changeset
   151
    // We'll take a peek to discover, which one
hgs
parents:
diff changeset
   152
    if ( hasSubIndexId && aLex.Peek() == EKeySpace )
hgs
parents:
diff changeset
   153
        {
hgs
parents:
diff changeset
   154
        ParseSubIndexIntroL( aLex );
hgs
parents:
diff changeset
   155
        }
hgs
parents:
diff changeset
   156
    else
hgs
parents:
diff changeset
   157
        {
hgs
parents:
diff changeset
   158
        ParseServiceIntroL( aLex, aCollection );
hgs
parents:
diff changeset
   159
        }
hgs
parents:
diff changeset
   160
    }
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   163
// ParseServiceIntroL
hgs
parents:
diff changeset
   164
// Parses part of an index message.
hgs
parents:
diff changeset
   165
// Returns: None
hgs
parents:
diff changeset
   166
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   167
//
hgs
parents:
diff changeset
   168
LOCAL_C void ParseServiceIntroL(
hgs
parents:
diff changeset
   169
    TLex& aLex,
hgs
parents:
diff changeset
   170
    CCbsDbImpTopicCollection& aCollection )
hgs
parents:
diff changeset
   171
    {
hgs
parents:
diff changeset
   172
    // We'll store the results here
hgs
parents:
diff changeset
   173
    TCbsDbTopicIdentity identity;
hgs
parents:
diff changeset
   174
hgs
parents:
diff changeset
   175
    // message-id
hgs
parents:
diff changeset
   176
    TUint messageId;
hgs
parents:
diff changeset
   177
    ParseMessageIdL( aLex, messageId );
hgs
parents:
diff changeset
   178
    identity.iNumber = TUint16( messageId );
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
    // delimeter
hgs
parents:
diff changeset
   181
    TChar delimeter( aLex.Get() );
hgs
parents:
diff changeset
   182
    if ( delimeter != ' ' && delimeter != '.' )
hgs
parents:
diff changeset
   183
        {
hgs
parents:
diff changeset
   184
        User::Leave( KErrCorrupt );
hgs
parents:
diff changeset
   185
        }
hgs
parents:
diff changeset
   186
hgs
parents:
diff changeset
   187
    // service-name
hgs
parents:
diff changeset
   188
    TPtrC serviceName;
hgs
parents:
diff changeset
   189
    ParseNameCharactersCrLfL( aLex, serviceName );
hgs
parents:
diff changeset
   190
    // drop crlf
hgs
parents:
diff changeset
   191
    serviceName.Set( serviceName.Left( serviceName.Length()-2 ) );
hgs
parents:
diff changeset
   192
hgs
parents:
diff changeset
   193
    // If the delimeter is ' ', store the identity. Otherwise
hgs
parents:
diff changeset
   194
    // it only refers to a subindex page, so we skip it
hgs
parents:
diff changeset
   195
    if ( delimeter == ' ' )
hgs
parents:
diff changeset
   196
        {
hgs
parents:
diff changeset
   197
        // Copy max. KCbsDbTopicNameLength characters
hgs
parents:
diff changeset
   198
        identity.iName = serviceName.Left( KCbsDbTopicNameLength );
hgs
parents:
diff changeset
   199
        // Store the topic identity into the database
hgs
parents:
diff changeset
   200
        aCollection.AddTopicIdentityL( identity );
hgs
parents:
diff changeset
   201
        }
hgs
parents:
diff changeset
   202
    }
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   205
// ParseMessageIdL
hgs
parents:
diff changeset
   206
// Parses part of an index message.
hgs
parents:
diff changeset
   207
// Returns: None
hgs
parents:
diff changeset
   208
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   209
//
hgs
parents:
diff changeset
   210
LOCAL_C void ParseMessageIdL(
hgs
parents:
diff changeset
   211
    TLex& aLex,
hgs
parents:
diff changeset
   212
    TUint& aMessageId )
hgs
parents:
diff changeset
   213
    {
hgs
parents:
diff changeset
   214
    if ( aLex.Val( aMessageId ) != KErrNone
hgs
parents:
diff changeset
   215
        || aMessageId < KMinTopicNumber
hgs
parents:
diff changeset
   216
        || aMessageId > KMaxTopicNumber )
hgs
parents:
diff changeset
   217
        {
hgs
parents:
diff changeset
   218
        User::Leave( KErrCorrupt );
hgs
parents:
diff changeset
   219
        }
hgs
parents:
diff changeset
   220
    }
hgs
parents:
diff changeset
   221
hgs
parents:
diff changeset
   222
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   223
// ParseSubIndexIntroL
hgs
parents:
diff changeset
   224
// Parses part of an index message.
hgs
parents:
diff changeset
   225
// subindex-intro = " " subindex-name crlf
hgs
parents:
diff changeset
   226
// subindex-name  = name-character+
hgs
parents:
diff changeset
   227
// Returns: None
hgs
parents:
diff changeset
   228
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   229
//
hgs
parents:
diff changeset
   230
LOCAL_C void ParseSubIndexIntroL(
hgs
parents:
diff changeset
   231
    TLex& aLex )
hgs
parents:
diff changeset
   232
    {
hgs
parents:
diff changeset
   233
    if ( aLex.Get() != EKeySpace )
hgs
parents:
diff changeset
   234
        {
hgs
parents:
diff changeset
   235
        User::Leave( KErrCorrupt );
hgs
parents:
diff changeset
   236
        }
hgs
parents:
diff changeset
   237
hgs
parents:
diff changeset
   238
    // subindex-name crlf
hgs
parents:
diff changeset
   239
    TPtrC subIndexName;
hgs
parents:
diff changeset
   240
    ParseNameCharactersCrLfL( aLex, subIndexName );
hgs
parents:
diff changeset
   241
    }
hgs
parents:
diff changeset
   242
hgs
parents:
diff changeset
   243
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   244
// ParseSubIndexIdL
hgs
parents:
diff changeset
   245
// Parses part of an index message.
hgs
parents:
diff changeset
   246
// subindex-id = subindex-character+
hgs
parents:
diff changeset
   247
// Returns: None
hgs
parents:
diff changeset
   248
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   249
//
hgs
parents:
diff changeset
   250
LOCAL_C void ParseSubIndexIdL(
hgs
parents:
diff changeset
   251
    TLex& aLex )
hgs
parents:
diff changeset
   252
    {
hgs
parents:
diff changeset
   253
    // check that there is at least one subindex-character
hgs
parents:
diff changeset
   254
    if ( !aLex.Peek().IsAlpha() )
hgs
parents:
diff changeset
   255
        {
hgs
parents:
diff changeset
   256
        User::Leave( KErrCorrupt );
hgs
parents:
diff changeset
   257
        }
hgs
parents:
diff changeset
   258
hgs
parents:
diff changeset
   259
    // subindex-id
hgs
parents:
diff changeset
   260
    while ( aLex.Peek().IsAlpha() )
hgs
parents:
diff changeset
   261
        {
hgs
parents:
diff changeset
   262
        aLex.Inc();
hgs
parents:
diff changeset
   263
        }
hgs
parents:
diff changeset
   264
    }
hgs
parents:
diff changeset
   265
hgs
parents:
diff changeset
   266
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   267
// ParseNameCharactersCrLfL
hgs
parents:
diff changeset
   268
// Parses part of an index message.
hgs
parents:
diff changeset
   269
// name-character+ crlf
hgs
parents:
diff changeset
   270
// Returns: None
hgs
parents:
diff changeset
   271
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   272
//
hgs
parents:
diff changeset
   273
LOCAL_C void ParseNameCharactersCrLfL(
hgs
parents:
diff changeset
   274
    TLex& aLex,
hgs
parents:
diff changeset
   275
    TPtrC& aName )
hgs
parents:
diff changeset
   276
    {
hgs
parents:
diff changeset
   277
    aLex.Mark();
hgs
parents:
diff changeset
   278
hgs
parents:
diff changeset
   279
    // check that we have at least one name-character
hgs
parents:
diff changeset
   280
    TChar currCharacter( aLex.Get() );
hgs
parents:
diff changeset
   281
    if( currCharacter == EKeyLineFeed
hgs
parents:
diff changeset
   282
        || currCharacter == EKeyEnter
hgs
parents:
diff changeset
   283
        || currCharacter == 0 )
hgs
parents:
diff changeset
   284
        {
hgs
parents:
diff changeset
   285
        User::Leave( KErrCorrupt );
hgs
parents:
diff changeset
   286
        }
hgs
parents:
diff changeset
   287
hgs
parents:
diff changeset
   288
    // scan until LF or EOS
hgs
parents:
diff changeset
   289
    while( currCharacter != EKeyLineFeed && currCharacter != 0 )
hgs
parents:
diff changeset
   290
        {
hgs
parents:
diff changeset
   291
        currCharacter = aLex.Get();
hgs
parents:
diff changeset
   292
        }
hgs
parents:
diff changeset
   293
hgs
parents:
diff changeset
   294
    // CR-LF is ok, EOS is not
hgs
parents:
diff changeset
   295
    if( currCharacter == EKeyLineFeed )
hgs
parents:
diff changeset
   296
        {
hgs
parents:
diff changeset
   297
        aName.Set( aLex.MarkedToken() );
hgs
parents:
diff changeset
   298
        }
hgs
parents:
diff changeset
   299
    else
hgs
parents:
diff changeset
   300
        {
hgs
parents:
diff changeset
   301
        User::Leave( KErrCorrupt );
hgs
parents:
diff changeset
   302
        }
hgs
parents:
diff changeset
   303
    }
hgs
parents:
diff changeset
   304
hgs
parents:
diff changeset
   305
// ================= MEMBER FUNCTIONS =======================
hgs
parents:
diff changeset
   306
hgs
parents:
diff changeset
   307
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   308
// CCbsReceiverHelper::CCbsReceiverHelper
hgs
parents:
diff changeset
   309
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
   310
// might leave.
hgs
parents:
diff changeset
   311
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   312
//
hgs
parents:
diff changeset
   313
CCbsReceiverHelper::CCbsReceiverHelper(
hgs
parents:
diff changeset
   314
    CCbsDbImp& aDatabase )
hgs
parents:
diff changeset
   315
    : iDatabase( aDatabase )
hgs
parents:
diff changeset
   316
    {
hgs
parents:
diff changeset
   317
    }
hgs
parents:
diff changeset
   318
hgs
parents:
diff changeset
   319
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   320
// CCbsReceiverHelper::ConstructL
hgs
parents:
diff changeset
   321
// Symbian 2nd phase constructor can leave.
hgs
parents:
diff changeset
   322
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   323
//
hgs
parents:
diff changeset
   324
void CCbsReceiverHelper::ConstructL()
hgs
parents:
diff changeset
   325
    {
hgs
parents:
diff changeset
   326
    CBSLOGSTRING("CBSSERVER: >>> CCbsReceiverHelper::ConstructL()");
hgs
parents:
diff changeset
   327
hgs
parents:
diff changeset
   328
    iVwsSession = CVwsSessionWrapper::NewL();
hgs
parents:
diff changeset
   329
hgs
parents:
diff changeset
   330
    // Array for SIM Topic numbers. This way we know which topics
hgs
parents:
diff changeset
   331
    // to delete also from the SIM card (when deleting all topics).
hgs
parents:
diff changeset
   332
    iSimTopics = new ( ELeave ) CArrayFixFlat<TInt>( 1 );
hgs
parents:
diff changeset
   333
    
hgs
parents:
diff changeset
   334
    // Fetch local variation bits from CenRep    
hgs
parents:
diff changeset
   335
    CRepository* repository = CRepository::NewL( KCRUidCbsVariation );    
hgs
parents:
diff changeset
   336
    TInt err = repository->Get( KCbsVariationFlags, iLVBits );
hgs
parents:
diff changeset
   337
    if ( err )
hgs
parents:
diff changeset
   338
        {
hgs
parents:
diff changeset
   339
        iLVBits = 0;
hgs
parents:
diff changeset
   340
        }  
hgs
parents:
diff changeset
   341
    CBSLOGSTRING2("CBSSERVER: CCbsRecEtel::ConstructL(): CenRep error: %d", err );
hgs
parents:
diff changeset
   342
    delete repository;
hgs
parents:
diff changeset
   343
hgs
parents:
diff changeset
   344
    CBSLOGSTRING("CBSSERVER: <<< CCbsReceiverHelper::ConstructL()");
hgs
parents:
diff changeset
   345
    }
hgs
parents:
diff changeset
   346
hgs
parents:
diff changeset
   347
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   348
// CCbsReceiverHelper::NewL
hgs
parents:
diff changeset
   349
// Two-phased constructor.
hgs
parents:
diff changeset
   350
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   351
//
hgs
parents:
diff changeset
   352
CCbsReceiverHelper* CCbsReceiverHelper::NewL(
hgs
parents:
diff changeset
   353
    CCbsDbImp& aDatabase )
hgs
parents:
diff changeset
   354
    {
hgs
parents:
diff changeset
   355
    // Normal two phase construction.
hgs
parents:
diff changeset
   356
    CCbsReceiverHelper* self = new ( ELeave ) CCbsReceiverHelper( aDatabase );
hgs
parents:
diff changeset
   357
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
   358
    self->ConstructL();
hgs
parents:
diff changeset
   359
    CleanupStack::Pop();
hgs
parents:
diff changeset
   360
    return self;
hgs
parents:
diff changeset
   361
    }
hgs
parents:
diff changeset
   362
hgs
parents:
diff changeset
   363
// Destructor
hgs
parents:
diff changeset
   364
CCbsReceiverHelper::~CCbsReceiverHelper()
hgs
parents:
diff changeset
   365
    {
hgs
parents:
diff changeset
   366
    CBSLOGSTRING("CBSSERVER: >>> CCbsReceiverHelper::~CCbsReceiverHelper()");
hgs
parents:
diff changeset
   367
hgs
parents:
diff changeset
   368
    delete iSimTopics;
hgs
parents:
diff changeset
   369
    delete iVwsSession;
hgs
parents:
diff changeset
   370
hgs
parents:
diff changeset
   371
    CBSLOGSTRING("CBSSERVER: <<< CCbsReceiverHelper::~CCbsReceiverHelper()");
hgs
parents:
diff changeset
   372
    }
hgs
parents:
diff changeset
   373
hgs
parents:
diff changeset
   374
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   375
// CCbsReceiverHelper::CCbsReceiverHelper
hgs
parents:
diff changeset
   376
// Processes a message received by the receiver.
hgs
parents:
diff changeset
   377
//
hgs
parents:
diff changeset
   378
// This function is called when a message is received.
hgs
parents:
diff changeset
   379
//
hgs
parents:
diff changeset
   380
// Assumptions;
hgs
parents:
diff changeset
   381
// 1.  The message doesn't have it's permanent or read
hgs
parents:
diff changeset
   382
//     flags raised - method leaves with KErrNotSupported
hgs
parents:
diff changeset
   383
//     if this is the case.
hgs
parents:
diff changeset
   384
// 2.  If an index message (root or subindex) is passed as
hgs
parents:
diff changeset
   385
//     a parameter, the language indication prefix, if any,
hgs
parents:
diff changeset
   386
//     has been removed before HandleReceivedMessageL() is called.
hgs
parents:
diff changeset
   387
//
hgs
parents:
diff changeset
   388
// Assumption (2) holds because language indications are removed
hgs
parents:
diff changeset
   389
// by Receiver module in an instance of CCbsRecDecoder.
hgs
parents:
diff changeset
   390
// Message may not be accepted if it is somehow invalid
hgs
parents:
diff changeset
   391
// or the reception has been disabled.
hgs
parents:
diff changeset
   392
// This function also handles the detection of new topics
hgs
parents:
diff changeset
   393
// and the processing of an index message.
hgs
parents:
diff changeset
   394
// (other items were commented in a header).
hgs
parents:
diff changeset
   395
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   396
//
hgs
parents:
diff changeset
   397
void CCbsReceiverHelper::HandleReceivedMessageL(
hgs
parents:
diff changeset
   398
    CCbsMessage& aMessage )
hgs
parents:
diff changeset
   399
    {
hgs
parents:
diff changeset
   400
    CBSLOGSTRING("CBSSERVER: >>> CCbsReceiverHelper::HandleReceivedMessageL()");
hgs
parents:
diff changeset
   401
hgs
parents:
diff changeset
   402
    if ( aMessage.IsIndexMessage() )
hgs
parents:
diff changeset
   403
        {
hgs
parents:
diff changeset
   404
        CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::HandleReceivedMessageL(): Index msg.");
hgs
parents:
diff changeset
   405
hgs
parents:
diff changeset
   406
        // It is assumed that a language indication prefix,
hgs
parents:
diff changeset
   407
        // if any, has already been removed from the message.
hgs
parents:
diff changeset
   408
        aMessage.RemoveIndexHeaderL();
hgs
parents:
diff changeset
   409
hgs
parents:
diff changeset
   410
        TBool isChildSubindex( aMessage.IsChildSubindex() );
hgs
parents:
diff changeset
   411
hgs
parents:
diff changeset
   412
        // Parse the index message
hgs
parents:
diff changeset
   413
        HandleIndexMessageL( aMessage.Contents(), isChildSubindex );
hgs
parents:
diff changeset
   414
hgs
parents:
diff changeset
   415
        // Child subindex messages won't be displayed to the user.
hgs
parents:
diff changeset
   416
        if ( isChildSubindex )
hgs
parents:
diff changeset
   417
            {
hgs
parents:
diff changeset
   418
            return;
hgs
parents:
diff changeset
   419
            }
hgs
parents:
diff changeset
   420
        }
hgs
parents:
diff changeset
   421
hgs
parents:
diff changeset
   422
    TUint16 topicNumber( aMessage.TopicNumber() );
hgs
parents:
diff changeset
   423
    CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::HandleReceivedMessageL(): topic number: %d.", topicNumber );
hgs
parents:
diff changeset
   424
hgs
parents:
diff changeset
   425
    TCbsDbTopic topic;
hgs
parents:
diff changeset
   426
    iDatabase.TopicListL().FindTopicByNumberL( topicNumber, topic );
hgs
parents:
diff changeset
   427
    CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::HandleReceivedMessageL(): iDatabase.TopicListL().FindTopicByNumberL(..) called OK." );
hgs
parents:
diff changeset
   428
hgs
parents:
diff changeset
   429
    // If subscribed, handle the message
hgs
parents:
diff changeset
   430
    if ( topic.iSubscribed )
hgs
parents:
diff changeset
   431
        {
hgs
parents:
diff changeset
   432
        CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::HandleReceivedMessageL(): Topic subscribed, processing." );
hgs
parents:
diff changeset
   433
hgs
parents:
diff changeset
   434
        // Create and initialize message
hgs
parents:
diff changeset
   435
        TCbsDbMessage message;
hgs
parents:
diff changeset
   436
hgs
parents:
diff changeset
   437
        TTime now;
hgs
parents:
diff changeset
   438
        now.UniversalTime();
hgs
parents:
diff changeset
   439
        message.iDateTime = now.Int64();
hgs
parents:
diff changeset
   440
        message.iKey = aMessage.Key();
hgs
parents:
diff changeset
   441
        message.iLanguage = aMessage.Language();
hgs
parents:
diff changeset
   442
        message.iLength = aMessage.Contents().Length();
hgs
parents:
diff changeset
   443
        message.iPermanent = EFalse;
hgs
parents:
diff changeset
   444
        message.iRead = EFalse;
hgs
parents:
diff changeset
   445
        TPtrC ptr( aMessage.Contents() );
hgs
parents:
diff changeset
   446
hgs
parents:
diff changeset
   447
        iDatabase.TopicMessagesL().AddMessageL( topicNumber, message, ptr );
hgs
parents:
diff changeset
   448
        CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::HandleReceivedMessageL(): Msg added OK." );
hgs
parents:
diff changeset
   449
hgs
parents:
diff changeset
   450
        if ( aMessage.RequiresImmediateDisplay() )
hgs
parents:
diff changeset
   451
            {
hgs
parents:
diff changeset
   452
            CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::HandleReceivedMessageL(): Calling LaunchMessageImmediateDisplay()... " );
hgs
parents:
diff changeset
   453
hgs
parents:
diff changeset
   454
            // If the operator indicates that this message must be displayed
hgs
parents:
diff changeset
   455
            // immediately, request a view switch of CBS UI application.
hgs
parents:
diff changeset
   456
            LaunchMessageImmediateDisplay( message );
hgs
parents:
diff changeset
   457
hgs
parents:
diff changeset
   458
            CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::HandleReceivedMessageL(): LaunchMessageImmediateDisplay() called OK." );
hgs
parents:
diff changeset
   459
            }
hgs
parents:
diff changeset
   460
        else if ( topic.iHotmarked )
hgs
parents:
diff changeset
   461
            {
hgs
parents:
diff changeset
   462
            // The message is of a hotmarked topic => Show a soft notification.
hgs
parents:
diff changeset
   463
            CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::HandleReceivedMessageL(): Calling LaunchMessageSoftNotification()... " );
hgs
parents:
diff changeset
   464
            LaunchMessageSoftNotificationL( ETrue );
hgs
parents:
diff changeset
   465
            CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::HandleReceivedMessageL(): LaunchMessageSoftNotification() called OK." );
hgs
parents:
diff changeset
   466
            }
hgs
parents:
diff changeset
   467
        } // if ( topic.iSubscribed )
hgs
parents:
diff changeset
   468
    else
hgs
parents:
diff changeset
   469
        {
hgs
parents:
diff changeset
   470
        CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::HandleReceivedMessageL(): Topic NOT subscribed, msg not processed." );
hgs
parents:
diff changeset
   471
        }
hgs
parents:
diff changeset
   472
hgs
parents:
diff changeset
   473
    CBSLOGSTRING("CBSSERVER: <<< CCbsReceiverHelper::HandleReceivedMessageL()");
hgs
parents:
diff changeset
   474
    }
hgs
parents:
diff changeset
   475
hgs
parents:
diff changeset
   476
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   477
// CCbsReceiverHelper::CheckForNewTopicL
hgs
parents:
diff changeset
   478
// Checks if aMessage's topic is in the topic list.
hgs
parents:
diff changeset
   479
//
hgs
parents:
diff changeset
   480
// If the topic detection is enabled and the topic of this
hgs
parents:
diff changeset
   481
// message is not in the topic list, the topic is added
hgs
parents:
diff changeset
   482
// to the list. The method will then return ETrue.
hgs
parents:
diff changeset
   483
// Otherwise EFalse is returned.
hgs
parents:
diff changeset
   484
// (other items were commented in a header).
hgs
parents:
diff changeset
   485
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   486
//
hgs
parents:
diff changeset
   487
TBool CCbsReceiverHelper::CheckForNewTopicL(
hgs
parents:
diff changeset
   488
    const CCbsMessage& aMessage )
hgs
parents:
diff changeset
   489
    {
hgs
parents:
diff changeset
   490
    // Check if the topic detection is on and if so, add topic if the topic
hgs
parents:
diff changeset
   491
    // is a new topic.
hgs
parents:
diff changeset
   492
    TBool detection;
hgs
parents:
diff changeset
   493
    TBool result( EFalse );
hgs
parents:
diff changeset
   494
hgs
parents:
diff changeset
   495
    iDatabase.SettingsL().GetTopicDetectionStatus( detection );
hgs
parents:
diff changeset
   496
hgs
parents:
diff changeset
   497
    if ( detection && HandleTopicDetectedL( aMessage.TopicNumber() ) )
hgs
parents:
diff changeset
   498
        {
hgs
parents:
diff changeset
   499
        // If a new topic added, we do not send the message to
hgs
parents:
diff changeset
   500
        // the database so return ETrue.
hgs
parents:
diff changeset
   501
        result = ETrue;
hgs
parents:
diff changeset
   502
        }
hgs
parents:
diff changeset
   503
    else
hgs
parents:
diff changeset
   504
        {
hgs
parents:
diff changeset
   505
        // Topic detection disabled or topic already in the database
hgs
parents:
diff changeset
   506
        result = EFalse;
hgs
parents:
diff changeset
   507
        }
hgs
parents:
diff changeset
   508
hgs
parents:
diff changeset
   509
    return result;
hgs
parents:
diff changeset
   510
    }
hgs
parents:
diff changeset
   511
hgs
parents:
diff changeset
   512
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   513
// CCbsReceiverHelper::CheckForSubscriptionAndExistenceL
hgs
parents:
diff changeset
   514
// Checks if the topic of this message is listed and subscribed.
hgs
parents:
diff changeset
   515
// Returns ETrue only if the message does not exist in the
hgs
parents:
diff changeset
   516
// database and the message's topic is subscribed.
hgs
parents:
diff changeset
   517
// (other items were commented in a header).
hgs
parents:
diff changeset
   518
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   519
//
hgs
parents:
diff changeset
   520
TBool CCbsReceiverHelper::CheckForSubscriptionAndExistenceL(
hgs
parents:
diff changeset
   521
    const CCbsMessage& aMessage )
hgs
parents:
diff changeset
   522
    {
hgs
parents:
diff changeset
   523
    // Check if the message belongs to some subscribed topic.
hgs
parents:
diff changeset
   524
    TCbsDbTopic topic;
hgs
parents:
diff changeset
   525
    TUint16 topicNumber( 0 );
hgs
parents:
diff changeset
   526
hgs
parents:
diff changeset
   527
    // Index messages are stored in topic 0.
hgs
parents:
diff changeset
   528
    if ( !aMessage.IsIndexMessage() )
hgs
parents:
diff changeset
   529
        {
hgs
parents:
diff changeset
   530
        topicNumber = aMessage.TopicNumber();
hgs
parents:
diff changeset
   531
        }
hgs
parents:
diff changeset
   532
hgs
parents:
diff changeset
   533
    TRAPD( errorCode, iDatabase.TopicListL().FindTopicByNumberL( topicNumber, topic ) );
hgs
parents:
diff changeset
   534
hgs
parents:
diff changeset
   535
    if ( errorCode == KErrNotFound )
hgs
parents:
diff changeset
   536
        {
hgs
parents:
diff changeset
   537
        return EFalse;
hgs
parents:
diff changeset
   538
        }
hgs
parents:
diff changeset
   539
    User::LeaveIfError( errorCode );
hgs
parents:
diff changeset
   540
hgs
parents:
diff changeset
   541
    return topic.iSubscribed;
hgs
parents:
diff changeset
   542
    }
hgs
parents:
diff changeset
   543
hgs
parents:
diff changeset
   544
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   545
// CCbsReceiverHelper::LanguageOfMessageSubscribedL
hgs
parents:
diff changeset
   546
// Checks if aMessage's language has been subscribed by the user.
hgs
parents:
diff changeset
   547
// ETrue is returned either if the language specified has been
hgs
parents:
diff changeset
   548
// subscribed, message language is "Other" or the user has
hgs
parents:
diff changeset
   549
// prefers to receive messages of all languages.
hgs
parents:
diff changeset
   550
// (other items were commented in a header).
hgs
parents:
diff changeset
   551
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   552
//
hgs
parents:
diff changeset
   553
TBool CCbsReceiverHelper::LanguageOfMessageSubscribedL(
hgs
parents:
diff changeset
   554
    const CCbsMessage& aMessage )
hgs
parents:
diff changeset
   555
    {
hgs
parents:
diff changeset
   556
    CBSLOGSTRING("CBSSERVER: >>> CCbsReceiverHelper::LanguageOfMessageSubscribedL" );
hgs
parents:
diff changeset
   557
hgs
parents:
diff changeset
   558
    TCbsDbLanguages languages;
hgs
parents:
diff changeset
   559
    iDatabase.SettingsL().GetLanguages( languages );
hgs
parents:
diff changeset
   560
hgs
parents:
diff changeset
   561
    if ( aMessage.Language() < 0 || aMessage.Language() >= ECbsCount )
hgs
parents:
diff changeset
   562
        {
hgs
parents:
diff changeset
   563
        return EFalse;
hgs
parents:
diff changeset
   564
        }
hgs
parents:
diff changeset
   565
hgs
parents:
diff changeset
   566
    TCbsDbLanguage language( aMessage.Language() );
hgs
parents:
diff changeset
   567
    CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::LanguageOfMessageSubscribedL: language: %d.", language );
hgs
parents:
diff changeset
   568
hgs
parents:
diff changeset
   569
    TBool subscribed( languages.iLanguages[ECbsAll] ||
hgs
parents:
diff changeset
   570
        languages.iLanguages[ECbsOther] && language == ECbsOther ||
hgs
parents:
diff changeset
   571
        !languages.iLanguages[ECbsOther] && languages.iLanguages[language] );
hgs
parents:
diff changeset
   572
hgs
parents:
diff changeset
   573
    CBSLOGSTRING2("CBSSERVER: <<< CCbsReceiverHelper::LanguageOfMessageSubscribedL, returning %d.", subscribed );
hgs
parents:
diff changeset
   574
    return subscribed;
hgs
parents:
diff changeset
   575
    }
hgs
parents:
diff changeset
   576
hgs
parents:
diff changeset
   577
// ---------------------------------------------------------
hgs
parents:
diff changeset
   578
// AddSimTopicL()
hgs
parents:
diff changeset
   579
//
hgs
parents:
diff changeset
   580
// Adds the given topic (aNumber, aName) into the DB.
hgs
parents:
diff changeset
   581
// ---------------------------------------------------------
hgs
parents:
diff changeset
   582
void CCbsReceiverHelper::AddSimTopicL( 
hgs
parents:
diff changeset
   583
    const TUint aNumber,
hgs
parents:
diff changeset
   584
    const TDesC& aName )
hgs
parents:
diff changeset
   585
    {
hgs
parents:
diff changeset
   586
    CBSLOGSTRING("CBSSERVER: >>> CCbsReceiverHelper::AddSimTopicL()");
hgs
parents:
diff changeset
   587
hgs
parents:
diff changeset
   588
    TCbsDbTopic topic;
hgs
parents:
diff changeset
   589
    if ( aName == KNullDesC )       // Topic name not given, use "SIM topics".
hgs
parents:
diff changeset
   590
        {
hgs
parents:
diff changeset
   591
        // Establish file server session.
hgs
parents:
diff changeset
   592
        RFs fs;
hgs
parents:
diff changeset
   593
        User::LeaveIfError( fs.Connect() );
hgs
parents:
diff changeset
   594
        CleanupClosePushL( fs );
hgs
parents:
diff changeset
   595
hgs
parents:
diff changeset
   596
        // Open localized resource file.
hgs
parents:
diff changeset
   597
        RResourceFile resourceFile;
hgs
parents:
diff changeset
   598
        CbsUtils::FindAndOpenDefaultResourceFileLC(
hgs
parents:
diff changeset
   599
            fs, resourceFile ); // on CS
hgs
parents:
diff changeset
   600
hgs
parents:
diff changeset
   601
        // Read "SIM topic"-string.
hgs
parents:
diff changeset
   602
        TResourceReader reader;
hgs
parents:
diff changeset
   603
        reader.SetBuffer( resourceFile.AllocReadLC(
hgs
parents:
diff changeset
   604
            R_TEXT_SIM_TOPIC ) ); // on CS
hgs
parents:
diff changeset
   605
hgs
parents:
diff changeset
   606
        HBufC* text = reader.ReadHBufCL();
hgs
parents:
diff changeset
   607
        topic.iName = *text;
hgs
parents:
diff changeset
   608
        CleanupStack::PopAndDestroy(3);  // fs, resourceFile, readerBuf
hgs
parents:
diff changeset
   609
hgs
parents:
diff changeset
   610
        CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::AddSimTopicL(): Topic name read from resources.");
hgs
parents:
diff changeset
   611
        }
hgs
parents:
diff changeset
   612
    else // Use the given topic name.
hgs
parents:
diff changeset
   613
        {
hgs
parents:
diff changeset
   614
        topic.iName = aName;
hgs
parents:
diff changeset
   615
        }
hgs
parents:
diff changeset
   616
hgs
parents:
diff changeset
   617
    topic.iNumber = TUint16( aNumber );
hgs
parents:
diff changeset
   618
    topic.iHotmarked = EFalse;
hgs
parents:
diff changeset
   619
    topic.iProtected = EFalse;
hgs
parents:
diff changeset
   620
    
hgs
parents:
diff changeset
   621
    // Variated feature    
hgs
parents:
diff changeset
   622
    if ( iLVBits & KCbsLVFlagTopicSubscription )
hgs
parents:
diff changeset
   623
        {
hgs
parents:
diff changeset
   624
        topic.iSubscribed = ETrue;
hgs
parents:
diff changeset
   625
        }
hgs
parents:
diff changeset
   626
    else
hgs
parents:
diff changeset
   627
        {
hgs
parents:
diff changeset
   628
        topic.iSubscribed = EFalse;
hgs
parents:
diff changeset
   629
        }
hgs
parents:
diff changeset
   630
hgs
parents:
diff changeset
   631
    // Leaves, if the topic already exists, so we trap that
hgs
parents:
diff changeset
   632
    // error. All other errors are passed as a normal leave.
hgs
parents:
diff changeset
   633
    CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::AddSimTopicL(): Topic %d from SIM to topic list...", topic.iNumber );
hgs
parents:
diff changeset
   634
    // Try to add topic to topic list, topic not detected automatically
hgs
parents:
diff changeset
   635
    TRAPD( err, iDatabase.TopicListL().AddTopicL( topic, EFalse ) );
hgs
parents:
diff changeset
   636
    CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::AddSimTopicL(): AddTopicL() TRAPped error: %d.", err );
hgs
parents:
diff changeset
   637
hgs
parents:
diff changeset
   638
    if( err != KErrAlreadyExists && err != KErrArgument )
hgs
parents:
diff changeset
   639
        {
hgs
parents:
diff changeset
   640
        CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::AddSimTopicL(): Leave if error != -11 || -6");
hgs
parents:
diff changeset
   641
        User::LeaveIfError( err );
hgs
parents:
diff changeset
   642
        }
hgs
parents:
diff changeset
   643
hgs
parents:
diff changeset
   644
    // Append to SIM Topic array
hgs
parents:
diff changeset
   645
    iSimTopics->AppendL( topic.iNumber );
hgs
parents:
diff changeset
   646
    CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::AddSimTopicL(): Topic %d appended to array.", topic.iNumber ); 
hgs
parents:
diff changeset
   647
    
hgs
parents:
diff changeset
   648
    // Leave so that caller is informed e.g. if topic already exists
hgs
parents:
diff changeset
   649
    User::LeaveIfError( err );
hgs
parents:
diff changeset
   650
    CBSLOGSTRING("CBSSERVER: <<< CCbsReceiverHelper::AddSimTopicL()" );
hgs
parents:
diff changeset
   651
    
hgs
parents:
diff changeset
   652
    }
hgs
parents:
diff changeset
   653
hgs
parents:
diff changeset
   654
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   655
// CCbsReceiverHelper::SimTopics
hgs
parents:
diff changeset
   656
// Returns topics currently added from the SIM card.
hgs
parents:
diff changeset
   657
// (other items were commented in a header).
hgs
parents:
diff changeset
   658
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   659
//
hgs
parents:
diff changeset
   660
CArrayFixFlat<TInt>& CCbsReceiverHelper::SimTopics() const
hgs
parents:
diff changeset
   661
    {
hgs
parents:
diff changeset
   662
    return *iSimTopics;
hgs
parents:
diff changeset
   663
    }
hgs
parents:
diff changeset
   664
hgs
parents:
diff changeset
   665
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   666
// CCbsReceiverHelper::DeleteFromSimTopicCache
hgs
parents:
diff changeset
   667
// Deletes the topic number from local SIM Topic array.
hgs
parents:
diff changeset
   668
// (other items were commented in a header).
hgs
parents:
diff changeset
   669
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   670
//
hgs
parents:
diff changeset
   671
void CCbsReceiverHelper::DeleteFromSimTopicCache( const TUint16 aNumber )
hgs
parents:
diff changeset
   672
    {
hgs
parents:
diff changeset
   673
    CBSLOGSTRING("CBSSERVER: >>> CCbsReceiverHelper::DeleteFromSimTopicCache()");
hgs
parents:
diff changeset
   674
    CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::DeleteFromSimTopicCache(): Topic number: %d", aNumber );
hgs
parents:
diff changeset
   675
    CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::DeleteFromSimTopicCache(): Topic count in cache (1): %d", iSimTopics->Count() );
hgs
parents:
diff changeset
   676
hgs
parents:
diff changeset
   677
    // Check if this topic is a SIM Topic (can be found in the array)
hgs
parents:
diff changeset
   678
    TKeyArrayFix key( 0, ECmpTUint16 );
hgs
parents:
diff changeset
   679
    TInt index;
hgs
parents:
diff changeset
   680
    TUint16 topicNumber( aNumber );
hgs
parents:
diff changeset
   681
    TInt result( iSimTopics->FindIsq( topicNumber, key, index ) );
hgs
parents:
diff changeset
   682
hgs
parents:
diff changeset
   683
    CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::DeleteFromSimTopicCache(): FindIsq() result: %d", result );
hgs
parents:
diff changeset
   684
    CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::DeleteFromSimTopicCache(): FindIsq() result, position: %d", index );
hgs
parents:
diff changeset
   685
hgs
parents:
diff changeset
   686
    // Delete the topic from the array
hgs
parents:
diff changeset
   687
    if ( result == KErrNone )
hgs
parents:
diff changeset
   688
        {
hgs
parents:
diff changeset
   689
        CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::DeleteFromSimTopicCache(): Topic no. %d found from cache.", aNumber );
hgs
parents:
diff changeset
   690
        iSimTopics->Delete( index );
hgs
parents:
diff changeset
   691
        CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::DeleteFromSimTopicCache(): Topic deleted from cache, index: %d", index );
hgs
parents:
diff changeset
   692
        iSimTopics->Compress();
hgs
parents:
diff changeset
   693
        CBSLOGSTRING("CBSSERVER: CCbsReceiverHelper::DeleteFromSimTopicCache(): SIM Topic array compressed.");
hgs
parents:
diff changeset
   694
        }
hgs
parents:
diff changeset
   695
hgs
parents:
diff changeset
   696
    CBSLOGSTRING2("CBSSERVER: CCbsReceiverHelper::DeleteFromSimTopicCache(): Topic count in cache (2): %d", iSimTopics->Count() );
hgs
parents:
diff changeset
   697
    CBSLOGSTRING("CBSSERVER: <<< CCbsReceiverHelper::DeleteFromSimTopicCache()");
hgs
parents:
diff changeset
   698
    }
hgs
parents:
diff changeset
   699
hgs
parents:
diff changeset
   700
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   701
// CCbsReceiverHelper::Database
hgs
parents:
diff changeset
   702
// Returns a reference to the CCbsDbImp instance.
hgs
parents:
diff changeset
   703
// If a topic of the same number already exists
hgs
parents:
diff changeset
   704
// in DB, does nothing.
hgs
parents:
diff changeset
   705
// (other items were commented in a header).
hgs
parents:
diff changeset
   706
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   707
//
hgs
parents:
diff changeset
   708
CCbsDbImp& CCbsReceiverHelper::Database() const
hgs
parents:
diff changeset
   709
    {
hgs
parents:
diff changeset
   710
    return iDatabase;
hgs
parents:
diff changeset
   711
    }
hgs
parents:
diff changeset
   712
hgs
parents:
diff changeset
   713
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   714
// CCbsReceiverHelper::TopicsDetected
hgs
parents:
diff changeset
   715
// Returns the number of detected topics.
hgs
parents:
diff changeset
   716
// (other items were commented in a header).
hgs
parents:
diff changeset
   717
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   718
//
hgs
parents:
diff changeset
   719
TUint CCbsReceiverHelper::TopicsDetected() const
hgs
parents:
diff changeset
   720
    {
hgs
parents:
diff changeset
   721
    return iTopicsDetected;
hgs
parents:
diff changeset
   722
    }
hgs
parents:
diff changeset
   723
hgs
parents:
diff changeset
   724
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   725
// CCbsReceiverHelper::ClearTopicsDetectedCounter
hgs
parents:
diff changeset
   726
// Sets the counter for detected topics to zero.
hgs
parents:
diff changeset
   727
// (other items were commented in a header).
hgs
parents:
diff changeset
   728
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   729
//
hgs
parents:
diff changeset
   730
void CCbsReceiverHelper::ClearTopicsDetectedCounter()
hgs
parents:
diff changeset
   731
    {
hgs
parents:
diff changeset
   732
    // Clear the variable indicating the amount of detected topics.
hgs
parents:
diff changeset
   733
    iTopicsDetected = 0;
hgs
parents:
diff changeset
   734
    }
hgs
parents:
diff changeset
   735
hgs
parents:
diff changeset
   736
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   737
// CCbsReceiverHelper::HandleTopicDetectedL
hgs
parents:
diff changeset
   738
// Handles detected topic.
hgs
parents:
diff changeset
   739
// (other items were commented in a header).
hgs
parents:
diff changeset
   740
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   741
//
hgs
parents:
diff changeset
   742
TBool CCbsReceiverHelper::HandleTopicDetectedL(
hgs
parents:
diff changeset
   743
    const TCbsDbTopicNumber& iTopicNumber )
hgs
parents:
diff changeset
   744
    {
hgs
parents:
diff changeset
   745
    // Create new topic and initialise it.
hgs
parents:
diff changeset
   746
    TCbsDbTopic topic;
hgs
parents:
diff changeset
   747
    topic.iNumber = iTopicNumber;
hgs
parents:
diff changeset
   748
    topic.iName = KNullDesC;
hgs
parents:
diff changeset
   749
    topic.iProtected = EFalse;
hgs
parents:
diff changeset
   750
    topic.iSubscribed = EFalse;
hgs
parents:
diff changeset
   751
    topic.iHotmarked = EFalse;
hgs
parents:
diff changeset
   752
hgs
parents:
diff changeset
   753
    TBool result( ETrue );
hgs
parents:
diff changeset
   754
hgs
parents:
diff changeset
   755
    // Try to add the topic. If succeeded,
hgs
parents:
diff changeset
   756
    // increase counter iTopicsDetected.
hgs
parents:
diff changeset
   757
    TRAPD( error, iDatabase.TopicListL().AddTopicL( topic, ETrue ) );
hgs
parents:
diff changeset
   758
hgs
parents:
diff changeset
   759
    if ( error == KErrAlreadyExists )
hgs
parents:
diff changeset
   760
        {
hgs
parents:
diff changeset
   761
        result = EFalse;
hgs
parents:
diff changeset
   762
        }
hgs
parents:
diff changeset
   763
    else if ( error != KErrNone && error != KErrAlreadyExists )
hgs
parents:
diff changeset
   764
        {
hgs
parents:
diff changeset
   765
        User::Leave( error );
hgs
parents:
diff changeset
   766
        }
hgs
parents:
diff changeset
   767
    else
hgs
parents:
diff changeset
   768
        {
hgs
parents:
diff changeset
   769
        // Update the detected topics counter
hgs
parents:
diff changeset
   770
        iTopicsDetected++;
hgs
parents:
diff changeset
   771
        }
hgs
parents:
diff changeset
   772
    return result;
hgs
parents:
diff changeset
   773
    }
hgs
parents:
diff changeset
   774
hgs
parents:
diff changeset
   775
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   776
// CCbsReceiverHelper::HandleIndexMessageL
hgs
parents:
diff changeset
   777
// Processes an index message and builds a new topic collection
hgs
parents:
diff changeset
   778
// (other items were commented in a header).
hgs
parents:
diff changeset
   779
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   780
//
hgs
parents:
diff changeset
   781
void CCbsReceiverHelper::HandleIndexMessageL(
hgs
parents:
diff changeset
   782
    const TDesC& aContents,
hgs
parents:
diff changeset
   783
    const TBool aIsChildSubIndex )
hgs
parents:
diff changeset
   784
    {
hgs
parents:
diff changeset
   785
    // Previous topic identities are cleared if a root index message
hgs
parents:
diff changeset
   786
    // is received.
hgs
parents:
diff changeset
   787
    if ( !aIsChildSubIndex )
hgs
parents:
diff changeset
   788
        {
hgs
parents:
diff changeset
   789
        iDatabase.TopicCollectionL().Clear();
hgs
parents:
diff changeset
   790
        }
hgs
parents:
diff changeset
   791
    // Parses topic identities from the index message.
hgs
parents:
diff changeset
   792
    // The identities are stored in the current topic collection.
hgs
parents:
diff changeset
   793
    // If the index message is corrupt, it should still be stored,
hgs
parents:
diff changeset
   794
    // so trap the error.
hgs
parents:
diff changeset
   795
    TLex lex( aContents );
hgs
parents:
diff changeset
   796
    TRAPD( error, ParseMessageFormatL( lex, iDatabase.TopicCollectionL() ) );
hgs
parents:
diff changeset
   797
    switch ( error )
hgs
parents:
diff changeset
   798
        {
hgs
parents:
diff changeset
   799
        case KErrNone:
hgs
parents:
diff changeset
   800
            // If the message all went fine, apply.
hgs
parents:
diff changeset
   801
            // The topic identities are written into persistent memory.
hgs
parents:
diff changeset
   802
            iDatabase.TopicCollectionL().Apply();
hgs
parents:
diff changeset
   803
            break;
hgs
parents:
diff changeset
   804
hgs
parents:
diff changeset
   805
        case KErrCorrupt:
hgs
parents:
diff changeset
   806
            // Do not react on corrupt messages.
hgs
parents:
diff changeset
   807
            break;
hgs
parents:
diff changeset
   808
hgs
parents:
diff changeset
   809
        default:
hgs
parents:
diff changeset
   810
            // All other errors will prevent saving the message.
hgs
parents:
diff changeset
   811
            User::Leave( error );
hgs
parents:
diff changeset
   812
            break;
hgs
parents:
diff changeset
   813
        }
hgs
parents:
diff changeset
   814
    }
hgs
parents:
diff changeset
   815
hgs
parents:
diff changeset
   816
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   817
// CCbsReceiverHelper::ParseTopicIdentitiesL
hgs
parents:
diff changeset
   818
// Parses all topic identities from aText which is assumed to be
hgs
parents:
diff changeset
   819
// an index message's content.
hgs
parents:
diff changeset
   820
// (other items were commented in a header).
hgs
parents:
diff changeset
   821
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   822
//
hgs
parents:
diff changeset
   823
void CCbsReceiverHelper::ParseTopicIdentitiesL(
hgs
parents:
diff changeset
   824
        const TDesC& aText )
hgs
parents:
diff changeset
   825
    {
hgs
parents:
diff changeset
   826
    // Create a lexer and pass it to the parser
hgs
parents:
diff changeset
   827
    TLex lex( aText );
hgs
parents:
diff changeset
   828
hgs
parents:
diff changeset
   829
    ParseMessageFormatL( lex, iDatabase.TopicCollectionL() );
hgs
parents:
diff changeset
   830
    }
hgs
parents:
diff changeset
   831
hgs
parents:
diff changeset
   832
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   833
// CCbsReceiverHelper::LaunchMessageSoftNotificationL
hgs
parents:
diff changeset
   834
// Requests to launch a soft notification.
hgs
parents:
diff changeset
   835
// (other items were commented in a header).
hgs
parents:
diff changeset
   836
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   837
//
hgs
parents:
diff changeset
   838
void CCbsReceiverHelper::LaunchMessageSoftNotificationL( const TBool aPlayTone )
hgs
parents:
diff changeset
   839
    {
hgs
parents:
diff changeset
   840
    TInt numberOfHotMsgs( 0 );
hgs
parents:
diff changeset
   841
    numberOfHotMsgs = iDatabase.TopicListL().UnreadHotmarkedMessageCount();
hgs
parents:
diff changeset
   842
hgs
parents:
diff changeset
   843
    CAknSoftNotifier* notifier = CAknSoftNotifier::NewLC(); // on CS
hgs
parents:
diff changeset
   844
hgs
parents:
diff changeset
   845
    TurnLightsOn();
hgs
parents:
diff changeset
   846
hgs
parents:
diff changeset
   847
    if ( aPlayTone )
hgs
parents:
diff changeset
   848
        {
hgs
parents:
diff changeset
   849
        PlayCbsTone();
hgs
parents:
diff changeset
   850
        }
hgs
parents:
diff changeset
   851
hgs
parents:
diff changeset
   852
    notifier->SetNotificationCountL( ECellBroadcastNotification, numberOfHotMsgs );
hgs
parents:
diff changeset
   853
    CleanupStack::PopAndDestroy( notifier );
hgs
parents:
diff changeset
   854
    }
hgs
parents:
diff changeset
   855
hgs
parents:
diff changeset
   856
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   857
// CCbsReceiverHelper::LaunchMessageImmediateDisplay
hgs
parents:
diff changeset
   858
// Requests to show the message immediately.
hgs
parents:
diff changeset
   859
// (other items were commented in a header).
hgs
parents:
diff changeset
   860
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   861
//
hgs
parents:
diff changeset
   862
void CCbsReceiverHelper::LaunchMessageImmediateDisplay(
hgs
parents:
diff changeset
   863
    const TCbsDbMessage& aMessage )
hgs
parents:
diff changeset
   864
    {
hgs
parents:
diff changeset
   865
    TUid uiViewUid( TUid::Uid( ECbsUiMsgViewId ) );
hgs
parents:
diff changeset
   866
    TVwsViewId id( KUidCbsUiappApp, uiViewUid );
hgs
parents:
diff changeset
   867
    TPckgBuf<TCbsMessageHandle> pckg( aMessage.iHandle );
hgs
parents:
diff changeset
   868
hgs
parents:
diff changeset
   869
    // Ignore result value.
hgs
parents:
diff changeset
   870
    iVwsSession->CreateActivateViewEvent( id, KCbsImmediateMessageId, pckg );
hgs
parents:
diff changeset
   871
    }
hgs
parents:
diff changeset
   872
hgs
parents:
diff changeset
   873
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   874
// CCbsReceiverHelper::TurnLightsOn
hgs
parents:
diff changeset
   875
// Turns lights on
hgs
parents:
diff changeset
   876
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   877
//
hgs
parents:
diff changeset
   878
void CCbsReceiverHelper::TurnLightsOn()
hgs
parents:
diff changeset
   879
    {
hgs
parents:
diff changeset
   880
     // Change the bit on and off. SysAp will detect that
hgs
parents:
diff changeset
   881
     // the lights should be switched on for the specified time.
hgs
parents:
diff changeset
   882
     RProperty::Set(KPSUidCoreApplicationUIs, KLightsControl, ELightsOn);
hgs
parents:
diff changeset
   883
     RProperty::Set(KPSUidCoreApplicationUIs, KLightsControl, ELightsOff);
hgs
parents:
diff changeset
   884
    }
hgs
parents:
diff changeset
   885
hgs
parents:
diff changeset
   886
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   887
// CCbsReceiverHelper::PlayCbsTone
hgs
parents:
diff changeset
   888
// Plays a tone
hgs
parents:
diff changeset
   889
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   890
//
hgs
parents:
diff changeset
   891
void CCbsReceiverHelper::PlayCbsTone()
hgs
parents:
diff changeset
   892
    {
hgs
parents:
diff changeset
   893
    // <-- QT PHONE START -->
hgs
parents:
diff changeset
   894
    /*
hgs
parents:
diff changeset
   895
    RProperty::Define( KPSUidNcnList, KNcnPlayAlertTone, RProperty::EInt,
hgs
parents:
diff changeset
   896
        ECapability_None , ECapabilityWriteDeviceData );
hgs
parents:
diff changeset
   897
    RProperty::Set( KPSUidNcnList, KNcnPlayAlertTone, KCbsMessageTone );
hgs
parents:
diff changeset
   898
    */
hgs
parents:
diff changeset
   899
    // <-- QT PHONE END-->
hgs
parents:
diff changeset
   900
    }
hgs
parents:
diff changeset
   901
hgs
parents:
diff changeset
   902
// ================= OTHER EXPORTED FUNCTIONS ==============
hgs
parents:
diff changeset
   903
hgs
parents:
diff changeset
   904
//  End of File
hgs
parents:
diff changeset
   905