satengine/satserver/EventMonitors/src/csatbrowserwsmonitor.cpp
author hgs
Fri, 15 Oct 2010 13:21:28 +0300
changeset 53 25b8d29b7c59
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2008 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:  Monitor for browser termination
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
// INCLUDE FILES
hgs
parents:
diff changeset
    20
#include    <etelsat.h>
hgs
parents:
diff changeset
    21
#include    <apgtask.h>
53
hgs
parents: 33
diff changeset
    22
// Legacy symbian browser UID
hgs
parents: 33
diff changeset
    23
const static TInt KWmlcHandler = 0x10008D39;   // WML Browser
33
hgs
parents:
diff changeset
    24
#include    "CSatBrowserThreadMonitor.h"
hgs
parents:
diff changeset
    25
#include    "csatbrowserwsmonitor.h"
hgs
parents:
diff changeset
    26
#include    "SatLog.h"
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// ======== MEMBER FUNCTIONS ========
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    31
// CSatBrowserWSMonitor::CSatBrowserWSMonitor
hgs
parents:
diff changeset
    32
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
    33
// might leave.
hgs
parents:
diff changeset
    34
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    35
//
hgs
parents:
diff changeset
    36
CSatBrowserWSMonitor::CSatBrowserWSMonitor() :
hgs
parents:
diff changeset
    37
    CActive( CActive::EPriorityStandard )
hgs
parents:
diff changeset
    38
    {
hgs
parents:
diff changeset
    39
    LOG( SIMPLE,
hgs
parents:
diff changeset
    40
        "SATEVENTMONITORS: CSatBrowserWSMonitor::CSatBrowserWSMonitor calling" )
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
    CActiveScheduler::Add( this );
hgs
parents:
diff changeset
    43
hgs
parents:
diff changeset
    44
    LOG( SIMPLE,
hgs
parents:
diff changeset
    45
        "SATEVENTMONITORS: CSatBrowserWSMonitor::CSatBrowserWSMonitor exiting" )
hgs
parents:
diff changeset
    46
    }
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
// Destructor
hgs
parents:
diff changeset
    49
CSatBrowserWSMonitor::~CSatBrowserWSMonitor()
hgs
parents:
diff changeset
    50
    {
hgs
parents:
diff changeset
    51
    LOG( SIMPLE,
hgs
parents:
diff changeset
    52
    "SATEVENTMONITORS: CSatBrowserWSMonitor::~CSatBrowserWSMonitor calling" )
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
    // Cancel any outstanding requests.
hgs
parents:
diff changeset
    55
    Cancel();
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
    if ( iThreadMonitor )
hgs
parents:
diff changeset
    58
        {
hgs
parents:
diff changeset
    59
        iThreadMonitor->DoCancelMonitor();
hgs
parents:
diff changeset
    60
        delete iThreadMonitor;
hgs
parents:
diff changeset
    61
        iThreadMonitor = NULL;
hgs
parents:
diff changeset
    62
        }
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
    iObserver = NULL;
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
    iWg.Close();
hgs
parents:
diff changeset
    67
    iWsSession.Close();
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
    LOG( SIMPLE,
hgs
parents:
diff changeset
    70
    "SATEVENTMONITORS: CSatBrowserWSMonitor::~CSatBrowserWSMonitor exiting" )
hgs
parents:
diff changeset
    71
    }
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    74
// CSatBrowserWSMonitor::NewL
hgs
parents:
diff changeset
    75
// Two-phased constructor.
hgs
parents:
diff changeset
    76
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    77
//
hgs
parents:
diff changeset
    78
CSatBrowserWSMonitor* CSatBrowserWSMonitor::NewL()
hgs
parents:
diff changeset
    79
    {
hgs
parents:
diff changeset
    80
    LOG( SIMPLE,
hgs
parents:
diff changeset
    81
        "SATEVENTMONITORS: CSatBrowserWSMonitor::NewL calling" )
hgs
parents:
diff changeset
    82
hgs
parents:
diff changeset
    83
    CSatBrowserWSMonitor* self =
hgs
parents:
diff changeset
    84
        new ( ELeave ) CSatBrowserWSMonitor();
hgs
parents:
diff changeset
    85
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
    86
    self->ConstructL();
hgs
parents:
diff changeset
    87
    CleanupStack::Pop( /*self*/ );
hgs
parents:
diff changeset
    88
hgs
parents:
diff changeset
    89
    LOG( SIMPLE,
hgs
parents:
diff changeset
    90
        "SATEVENTMONITORS: CSatBrowserWSMonitor::NewL exiting" )
hgs
parents:
diff changeset
    91
    return self;
hgs
parents:
diff changeset
    92
    }
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    95
// CSatBrowserWSMonitor::ConstructL
hgs
parents:
diff changeset
    96
// Symbian 2nd phase constructor can leave.
hgs
parents:
diff changeset
    97
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    98
//
hgs
parents:
diff changeset
    99
void CSatBrowserWSMonitor::ConstructL()
hgs
parents:
diff changeset
   100
    {
hgs
parents:
diff changeset
   101
    LOG( SIMPLE,
hgs
parents:
diff changeset
   102
        "SATEVENTMONITORS: CSatBrowserWSMonitor::ConstructL calling" )
hgs
parents:
diff changeset
   103
    // Window session is created when event is requested
hgs
parents:
diff changeset
   104
    LOG( SIMPLE,
hgs
parents:
diff changeset
   105
        "SATEVENTMONITORS: CSatBrowserWSMonitor::ConstructL exiting" )
hgs
parents:
diff changeset
   106
    }
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   109
// CSatBrowserWSMonitor::DoCancelMonitor
hgs
parents:
diff changeset
   110
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   111
//
hgs
parents:
diff changeset
   112
void CSatBrowserWSMonitor::DoCancelMonitor()
hgs
parents:
diff changeset
   113
    {
hgs
parents:
diff changeset
   114
    LOG( SIMPLE, "SATEVENTMONITORS: CSatBrowserWSMonitor::\
hgs
parents:
diff changeset
   115
        DoCancelMonitor calling" )
hgs
parents:
diff changeset
   116
hgs
parents:
diff changeset
   117
    Cancel();
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
    LOG( SIMPLE, "SATEVENTMONITORS: CSatBrowserWSMonitor::\
hgs
parents:
diff changeset
   120
        DoCancelMonitor exiting" )
hgs
parents:
diff changeset
   121
    }
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   124
// CSatBrowserWSMonitor::StartMonitor
hgs
parents:
diff changeset
   125
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   126
//
hgs
parents:
diff changeset
   127
TInt CSatBrowserWSMonitor::StartMonitor(
hgs
parents:
diff changeset
   128
    MSatBrowserWSObserver* aObserver )
hgs
parents:
diff changeset
   129
    {
hgs
parents:
diff changeset
   130
    LOG( SIMPLE,
hgs
parents:
diff changeset
   131
        "SATEVENTMONITORS: CSatBrowserWSMonitor::StartMonitor calling" )
hgs
parents:
diff changeset
   132
    TInt err( KErrNone );
hgs
parents:
diff changeset
   133
    
hgs
parents:
diff changeset
   134
    if ( !iWGCreated )
hgs
parents:
diff changeset
   135
        {
hgs
parents:
diff changeset
   136
        // First time called, create needed services
hgs
parents:
diff changeset
   137
        LOG( SIMPLE,"SATEVENTMONITORS: CSatBrowserWSMonitor::StartMonitor \
hgs
parents:
diff changeset
   138
            connect to WsSession " )
hgs
parents:
diff changeset
   139
        err = iWsSession.Connect();
hgs
parents:
diff changeset
   140
        if ( KErrNone == err )
hgs
parents:
diff changeset
   141
            {
hgs
parents:
diff changeset
   142
            // Creates a window group
hgs
parents:
diff changeset
   143
            TRAP( err, CreateWGL() );
hgs
parents:
diff changeset
   144
            }
hgs
parents:
diff changeset
   145
        }
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
    iObserver = aObserver;
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
    if ( !err )
hgs
parents:
diff changeset
   150
        {
hgs
parents:
diff changeset
   151
        // All fine, start monitoring
hgs
parents:
diff changeset
   152
        Start();
hgs
parents:
diff changeset
   153
        }
hgs
parents:
diff changeset
   154
        
hgs
parents:
diff changeset
   155
    LOG2( SIMPLE,
hgs
parents:
diff changeset
   156
        "SATEVENTMONITORS: CSatBrowserWSMonitor::StartMonitor exiting err=%d",\
hgs
parents:
diff changeset
   157
            err )
hgs
parents:
diff changeset
   158
    
hgs
parents:
diff changeset
   159
    return err;
hgs
parents:
diff changeset
   160
    }
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   163
// CSatBrowserWSMonitor::Start
hgs
parents:
diff changeset
   164
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   165
//
hgs
parents:
diff changeset
   166
void CSatBrowserWSMonitor::Start()
hgs
parents:
diff changeset
   167
    {
hgs
parents:
diff changeset
   168
    LOG( SIMPLE, "SATEVENTMONITORS: CSatBrowserWSMonitor::Start calling" )
hgs
parents:
diff changeset
   169
hgs
parents:
diff changeset
   170
    Cancel();
hgs
parents:
diff changeset
   171
hgs
parents:
diff changeset
   172
    // It migth be null already
hgs
parents:
diff changeset
   173
    if ( iThreadMonitor )
hgs
parents:
diff changeset
   174
        {
hgs
parents:
diff changeset
   175
        LOG( SIMPLE, 
hgs
parents:
diff changeset
   176
        "SATEVENTMONITORS: CSatBrowserWSMonitor::Start iThreadMonitor true" )
hgs
parents:
diff changeset
   177
        delete iThreadMonitor;
hgs
parents:
diff changeset
   178
        iThreadMonitor = NULL;
hgs
parents:
diff changeset
   179
        }
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
    iWsSession.EventReady( &iStatus );
hgs
parents:
diff changeset
   182
    SetActive();
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
    LOG( SIMPLE, "SATEVENTMONITORS: CSatBrowserWSMonitor::Start exiting" )
hgs
parents:
diff changeset
   185
    }
hgs
parents:
diff changeset
   186
hgs
parents:
diff changeset
   187
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   188
// CSatBrowserWSMonitor::RunL
hgs
parents:
diff changeset
   189
// Checks is the WML Browser launched and creates browser thread monitor to
hgs
parents:
diff changeset
   190
// monitor browsers thread death.
hgs
parents:
diff changeset
   191
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   192
//
hgs
parents:
diff changeset
   193
void CSatBrowserWSMonitor::RunL()
hgs
parents:
diff changeset
   194
    {
hgs
parents:
diff changeset
   195
    LOG( SIMPLE,
hgs
parents:
diff changeset
   196
        "SATEVENTMONITORS: CSatBrowserWSMonitor::RunL calling" )
hgs
parents:
diff changeset
   197
hgs
parents:
diff changeset
   198
    // Get the status of this object.
hgs
parents:
diff changeset
   199
    const TInt errCode( iStatus.Int() );
hgs
parents:
diff changeset
   200
    LOG2( SIMPLE,
hgs
parents:
diff changeset
   201
    "SATEVENTMONITORS: CSatBrowserWSMonitor::RunL errCode: %d",
hgs
parents:
diff changeset
   202
    errCode )
hgs
parents:
diff changeset
   203
    if ( KErrNone == errCode )
hgs
parents:
diff changeset
   204
        {
hgs
parents:
diff changeset
   205
        // UID Code for WML Browser in S60.
hgs
parents:
diff changeset
   206
        const TUid uidWmlBrowser( TUid::Uid( KWmlcHandler ) );
hgs
parents:
diff changeset
   207
        TWsEvent event;
hgs
parents:
diff changeset
   208
        iWsSession.GetEvent( event );
hgs
parents:
diff changeset
   209
        TApaTaskList taskList( iWsSession );
hgs
parents:
diff changeset
   210
hgs
parents:
diff changeset
   211
        if ( taskList.FindApp( uidWmlBrowser ).Exists() )
hgs
parents:
diff changeset
   212
            {
hgs
parents:
diff changeset
   213
            LOG( SIMPLE,
hgs
parents:
diff changeset
   214
            "SATEVENTMONITORS: CSatBrowserWSMonitor::RunL task exists" )
hgs
parents:
diff changeset
   215
            const TApaTask task = taskList.FindApp( uidWmlBrowser );
hgs
parents:
diff changeset
   216
            const TThreadId threadID = task.ThreadId();
hgs
parents:
diff changeset
   217
            RThread thread;
hgs
parents:
diff changeset
   218
            User::LeaveIfError ( thread.Open( threadID, EOwnerProcess ) );
hgs
parents:
diff changeset
   219
hgs
parents:
diff changeset
   220
            // Create Browser thread monitor.
hgs
parents:
diff changeset
   221
            iThreadMonitor = CSatBrowserThreadMonitor::NewL( thread );
hgs
parents:
diff changeset
   222
hgs
parents:
diff changeset
   223
            // Call the active object to monitor for this threads death.
hgs
parents:
diff changeset
   224
            iThreadMonitor->StartMonitor( this );
hgs
parents:
diff changeset
   225
            }
hgs
parents:
diff changeset
   226
        else
hgs
parents:
diff changeset
   227
            {
hgs
parents:
diff changeset
   228
            LOG( SIMPLE,
hgs
parents:
diff changeset
   229
            "SATEVENTMONITORS: CSatBrowserWSMonitor::RunL start" )
hgs
parents:
diff changeset
   230
            // Renew the request.
hgs
parents:
diff changeset
   231
            Start();
hgs
parents:
diff changeset
   232
            }
hgs
parents:
diff changeset
   233
        }
hgs
parents:
diff changeset
   234
    else if ( KErrCancel != errCode )
hgs
parents:
diff changeset
   235
        {
hgs
parents:
diff changeset
   236
        // Renew the request.
hgs
parents:
diff changeset
   237
        Start();
hgs
parents:
diff changeset
   238
        }
hgs
parents:
diff changeset
   239
    else
hgs
parents:
diff changeset
   240
        {
hgs
parents:
diff changeset
   241
        LOG( SIMPLE,
hgs
parents:
diff changeset
   242
            "SATEVENTMONITORS: CSatBrowserWSMonitor::RunL cancelled" )
hgs
parents:
diff changeset
   243
        }
hgs
parents:
diff changeset
   244
hgs
parents:
diff changeset
   245
    LOG( SIMPLE,
hgs
parents:
diff changeset
   246
        "SATEVENTMONITORS: CSatBrowserWSMonitor::RunL exiting" )
hgs
parents:
diff changeset
   247
    }
hgs
parents:
diff changeset
   248
hgs
parents:
diff changeset
   249
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   250
// CSatBrowserWSMonitor::DoCancel
hgs
parents:
diff changeset
   251
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   252
//
hgs
parents:
diff changeset
   253
void CSatBrowserWSMonitor::DoCancel()
hgs
parents:
diff changeset
   254
    {
hgs
parents:
diff changeset
   255
    LOG( SIMPLE,
hgs
parents:
diff changeset
   256
        "SATEVENTMONITORS: CSatBrowserWSMonitor::DoCancel calling" )
hgs
parents:
diff changeset
   257
hgs
parents:
diff changeset
   258
    if ( iThreadMonitor )
hgs
parents:
diff changeset
   259
        {
hgs
parents:
diff changeset
   260
        LOG( SIMPLE,
hgs
parents:
diff changeset
   261
        "SATEVENTMONITORS: CSatBrowserWSMonitor::DoCancel iThreadMonitor true" )
hgs
parents:
diff changeset
   262
        iThreadMonitor->DoCancelMonitor();
hgs
parents:
diff changeset
   263
        }
hgs
parents:
diff changeset
   264
hgs
parents:
diff changeset
   265
    // Cancel the outstanding request.
hgs
parents:
diff changeset
   266
    iWsSession.EventReadyCancel();
hgs
parents:
diff changeset
   267
hgs
parents:
diff changeset
   268
    LOG( SIMPLE,
hgs
parents:
diff changeset
   269
        "SATEVENTMONITORS: CSatBrowserWSMonitor::DoCancel exiting" )
hgs
parents:
diff changeset
   270
    }
hgs
parents:
diff changeset
   271
hgs
parents:
diff changeset
   272
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   273
// CSatBrowserWSMonitor::NotifyBrowserTerminated
hgs
parents:
diff changeset
   274
// Sends event download notification to SAT Engine.
hgs
parents:
diff changeset
   275
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   276
//
hgs
parents:
diff changeset
   277
void CSatBrowserWSMonitor::NotifyBrowserTerminated(
hgs
parents:
diff changeset
   278
    const RSat::TBrowserTerminationCause aCause )
hgs
parents:
diff changeset
   279
    {
hgs
parents:
diff changeset
   280
    LOG( SIMPLE, "SATEVENTMONITORS: CSatBrowserWSMonitor::\
hgs
parents:
diff changeset
   281
        NotifyBrowserTerminated calling" )
hgs
parents:
diff changeset
   282
hgs
parents:
diff changeset
   283
    // Notify termination to observer.
hgs
parents:
diff changeset
   284
    iObserver->NotifyBrowserTerminated( aCause );
hgs
parents:
diff changeset
   285
hgs
parents:
diff changeset
   286
    LOG( SIMPLE, "SATEVENTMONITORS: CSatBrowserWSMonitor::\
hgs
parents:
diff changeset
   287
        NotifyBrowserTerminated exiting" )
hgs
parents:
diff changeset
   288
    }
hgs
parents:
diff changeset
   289
hgs
parents:
diff changeset
   290
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   291
// CSatBrowserWSMonitor::CreateWGL
hgs
parents:
diff changeset
   292
// Creates a window group and hides it form the UI.
hgs
parents:
diff changeset
   293
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   294
//
hgs
parents:
diff changeset
   295
void CSatBrowserWSMonitor::CreateWGL()
hgs
parents:
diff changeset
   296
    {
hgs
parents:
diff changeset
   297
    LOG( SIMPLE,
hgs
parents:
diff changeset
   298
        "SATEVENTMONITORS: CSatBrowserWSMonitor::CreateWGL calling" )
hgs
parents:
diff changeset
   299
hgs
parents:
diff changeset
   300
    // -1 means the window will never be visible.
hgs
parents:
diff changeset
   301
    const TInt KWindowGroupPriority( -1 );
hgs
parents:
diff changeset
   302
hgs
parents:
diff changeset
   303
    RWindowGroup wg( iWsSession );
hgs
parents:
diff changeset
   304
    // Make a handle from the address of window group obj.
hgs
parents:
diff changeset
   305
    User::LeaveIfError( wg.Construct( reinterpret_cast<TUint32>( &wg ) ) );
hgs
parents:
diff changeset
   306
    // Enable group changed events.
hgs
parents:
diff changeset
   307
    User::LeaveIfError( wg.EnableGroupChangeEvents() );
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
    // Get the ordinal pos of this window group.
hgs
parents:
diff changeset
   310
    const TInt ordPos( wg.OrdinalPosition() );
hgs
parents:
diff changeset
   311
    // Set SAT so its never shown in the UI.
hgs
parents:
diff changeset
   312
    wg.SetOrdinalPosition( ordPos , KWindowGroupPriority );
hgs
parents:
diff changeset
   313
hgs
parents:
diff changeset
   314
    // Needs to be a member variable. Must be closed in destructor.
hgs
parents:
diff changeset
   315
    // Otherwise can't monitor what has been opened.
hgs
parents:
diff changeset
   316
    iWg = wg;
hgs
parents:
diff changeset
   317
hgs
parents:
diff changeset
   318
    // Set SAT Server hidden now.
hgs
parents:
diff changeset
   319
    iWsSession.Flush();
hgs
parents:
diff changeset
   320
    iWGCreated = ETrue;
hgs
parents:
diff changeset
   321
    LOG( SIMPLE,
hgs
parents:
diff changeset
   322
        "SATEVENTMONITORS: CSatBrowserWSMonitor::CreateWGL exiting" )
hgs
parents:
diff changeset
   323
    }
hgs
parents:
diff changeset
   324
hgs
parents:
diff changeset
   325
// End of file