satengine/satserver/Commands/MoSmControlCmd/src/CMoSmControlHandler.cpp
author hgs
Fri, 03 Sep 2010 13:59:20 +0300
changeset 46 2fa1fa551b0b
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201035
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2007 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:  Handles MO ShortMessage Control command
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
hgs
parents:
diff changeset
    20
// INCLUDE FILES
hgs
parents:
diff changeset
    21
#include    "MSatApi.h"
hgs
parents:
diff changeset
    22
#include    "MSatUtils.h"
hgs
parents:
diff changeset
    23
#include    "MSatUiSession.h"
hgs
parents:
diff changeset
    24
#include    "MSatSUiClientHandler.h"
hgs
parents:
diff changeset
    25
#include    "CMoSmControlHandler.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
// CMoSmControlHandler::CMoSmControlHandler
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
//lint -e{1403, 1769} Can not be initialized, harmless.
hgs
parents:
diff changeset
    37
CMoSmControlHandler::CMoSmControlHandler() :
hgs
parents:
diff changeset
    38
    CSatCommandHandler(),
hgs
parents:
diff changeset
    39
    iMoSmControlData(),
hgs
parents:
diff changeset
    40
    iMoSmControlPckg( iMoSmControlData ),
hgs
parents:
diff changeset
    41
    iMoSmControlSendData(),
hgs
parents:
diff changeset
    42
    iMoSmControlSendPckg( iMoSmControlSendData ),
hgs
parents:
diff changeset
    43
    iMoSmControlUiRespData(),
hgs
parents:
diff changeset
    44
    iMoSmControlUiRespPckg( iMoSmControlUiRespData )
hgs
parents:
diff changeset
    45
    {
hgs
parents:
diff changeset
    46
    LOG( SIMPLE, "MOSMCONTROL: \
hgs
parents:
diff changeset
    47
        CMoSmControlHandler::CMoSmControlHandler calling - exiting" )
hgs
parents:
diff changeset
    48
    }
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    51
// CMoSmControlHandler::ConstructL
hgs
parents:
diff changeset
    52
// Symbian 2nd phase constructor can leave.
hgs
parents:
diff changeset
    53
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    54
//
hgs
parents:
diff changeset
    55
void CMoSmControlHandler::ConstructL()
hgs
parents:
diff changeset
    56
    {
hgs
parents:
diff changeset
    57
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::ConstructL calling" )
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
    // Register notification observer
hgs
parents:
diff changeset
    60
    iUtils->RegisterServiceRequestL(
hgs
parents:
diff changeset
    61
        ESatSProactiveNotification,
hgs
parents:
diff changeset
    62
        ESatSProactiveNotificationResponse,
hgs
parents:
diff changeset
    63
        this );
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::ConstructL exiting" )
hgs
parents:
diff changeset
    66
    }
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    69
// CMoSmControlHandler::NewL
hgs
parents:
diff changeset
    70
// Two-phased constructor.
hgs
parents:
diff changeset
    71
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    72
//
hgs
parents:
diff changeset
    73
CMoSmControlHandler* CMoSmControlHandler::NewL( MSatUtils* aUtils )
hgs
parents:
diff changeset
    74
    {
hgs
parents:
diff changeset
    75
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::NewL calling" )
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
    CMoSmControlHandler* self = new( ELeave ) CMoSmControlHandler();
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
    80
    self->BaseConstructL( aUtils );
hgs
parents:
diff changeset
    81
    self->ConstructL();
hgs
parents:
diff changeset
    82
    CleanupStack::Pop( self );
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::NewL exiting" )
hgs
parents:
diff changeset
    85
    return self;
hgs
parents:
diff changeset
    86
    }
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
hgs
parents:
diff changeset
    89
// Destructor
hgs
parents:
diff changeset
    90
CMoSmControlHandler::~CMoSmControlHandler()
hgs
parents:
diff changeset
    91
    {
hgs
parents:
diff changeset
    92
    LOG( SIMPLE,
hgs
parents:
diff changeset
    93
        "MOSMCONTROL: CMoSmControlHandler::~CMoSmControlHandler calling" )
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
    Cancel();
hgs
parents:
diff changeset
    96
hgs
parents:
diff changeset
    97
    LOG( SIMPLE,
hgs
parents:
diff changeset
    98
        "MOSMCONTROL: CMoSmControlHandler::~CMoSmControlHandler exiting" )
hgs
parents:
diff changeset
    99
    }
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   102
// CMoSmControlHandler::ClientResponse
hgs
parents:
diff changeset
   103
// Handles responses from client.
hgs
parents:
diff changeset
   104
// (other items were commented in a header).
hgs
parents:
diff changeset
   105
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   106
//
hgs
parents:
diff changeset
   107
void CMoSmControlHandler::ClientResponse()
hgs
parents:
diff changeset
   108
    {
hgs
parents:
diff changeset
   109
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::ClientResponse calling" )
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
    // Start to receive more commands. We have to start again here because
hgs
parents:
diff changeset
   112
    // we don't send terminal response, wich does this automatically.
hgs
parents:
diff changeset
   113
    Start();
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
    // Inform the system that we are finished executing. If there is proactive
hgs
parents:
diff changeset
   116
    // SendSm command pending, it is notified and it continues from here.
hgs
parents:
diff changeset
   117
    iUtils->NotifyEvent( MSatUtils::EMoSmControlDone );
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
    // If we launched UI, close it.
hgs
parents:
diff changeset
   120
    if ( !iUtils->SatUiHandler().UiLaunchedByUser() )
hgs
parents:
diff changeset
   121
        {
hgs
parents:
diff changeset
   122
        LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::ClientResponse \
hgs
parents:
diff changeset
   123
             ESimSessionEndCallBack" )
hgs
parents:
diff changeset
   124
        iUtils->NotifyEvent( MSatUtils::ESimSessionEndCallBack );
hgs
parents:
diff changeset
   125
        }
hgs
parents:
diff changeset
   126
hgs
parents:
diff changeset
   127
    else
hgs
parents:
diff changeset
   128
        {
hgs
parents:
diff changeset
   129
        LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::ClientResponse \
hgs
parents:
diff changeset
   130
             EDelaySimSessionEnd" )
hgs
parents:
diff changeset
   131
        // Inform the session that we are done here.
hgs
parents:
diff changeset
   132
        iUtils->NotifyEvent( MSatUtils::EDelaySimSessionEnd );
hgs
parents:
diff changeset
   133
        }
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
    // We do not send TerminalResponse to SIM.
hgs
parents:
diff changeset
   136
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::ClientResponse exiting" )
hgs
parents:
diff changeset
   137
    }
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   140
// CMoSmControlHandler::DoCancel
hgs
parents:
diff changeset
   141
// Cancels the SAT request
hgs
parents:
diff changeset
   142
// (other items were commented in a header).
hgs
parents:
diff changeset
   143
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   144
//
hgs
parents:
diff changeset
   145
void CMoSmControlHandler::DoCancel()
hgs
parents:
diff changeset
   146
    {
hgs
parents:
diff changeset
   147
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::DoCancel calling" )
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
    iUtils->USatAPI().NotifyMoSmControlCancel();
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::DoCancel exiting" )
hgs
parents:
diff changeset
   152
    }
hgs
parents:
diff changeset
   153
hgs
parents:
diff changeset
   154
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   155
// CMoSmControlHandler::IssueUSATRequest
hgs
parents:
diff changeset
   156
// (other items were commented in a header).
hgs
parents:
diff changeset
   157
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   158
//
hgs
parents:
diff changeset
   159
void CMoSmControlHandler::IssueUSATRequest( TRequestStatus& aStatus )
hgs
parents:
diff changeset
   160
    {
hgs
parents:
diff changeset
   161
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::IssueUSATRequest calling" )
hgs
parents:
diff changeset
   162
hgs
parents:
diff changeset
   163
    // Clear the IPC package.
hgs
parents:
diff changeset
   164
    new (&iMoSmControlData) RSat::TMoSmControlV1();
hgs
parents:
diff changeset
   165
    iNeedUiSession = EFalse;
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
    iUtils->USatAPI().NotifyMoSmControl( aStatus, iMoSmControlPckg );
hgs
parents:
diff changeset
   168
hgs
parents:
diff changeset
   169
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::IssueUSATRequest exiting" )
hgs
parents:
diff changeset
   170
    }
hgs
parents:
diff changeset
   171
hgs
parents:
diff changeset
   172
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   173
// CMoSmControlHandler::CommandAllowed
hgs
parents:
diff changeset
   174
// (other items were commented in a header).
hgs
parents:
diff changeset
   175
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   176
//
hgs
parents:
diff changeset
   177
TBool CMoSmControlHandler::CommandAllowed()
hgs
parents:
diff changeset
   178
    {
hgs
parents:
diff changeset
   179
    LOG( SIMPLE, 
hgs
parents:
diff changeset
   180
        "MOSMCONTROL: CMoSmControlHandler::CommandAllowed calling - exiting" )
hgs
parents:
diff changeset
   181
    return ETrue;
hgs
parents:
diff changeset
   182
    }
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   185
// CMoSmControlHandler::NeedUiSession
hgs
parents:
diff changeset
   186
// (other items were commented in a header).
hgs
parents:
diff changeset
   187
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   188
//
hgs
parents:
diff changeset
   189
TBool CMoSmControlHandler::NeedUiSession()
hgs
parents:
diff changeset
   190
    {
hgs
parents:
diff changeset
   191
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::NeedUiSession calling" )
hgs
parents:
diff changeset
   192
    // UI is not needed, if control is AllowedWithMod and AlphaId is NULL or
hgs
parents:
diff changeset
   193
    // control is Allowed and AlphaId is not provided
hgs
parents:
diff changeset
   194
hgs
parents:
diff changeset
   195
    const RSat::TAlphaIdStatus alphaId( iMoSmControlData.iAlphaId.iStatus );
hgs
parents:
diff changeset
   196
    const RSat::TControlResult control( iMoSmControlData.iResult );
hgs
parents:
diff changeset
   197
    
hgs
parents:
diff changeset
   198
    const TBool alphaIdNull( RSat::EAlphaIdNull == alphaId ||
hgs
parents:
diff changeset
   199
                             RSat::EAlphaIdNotSet == alphaId );
hgs
parents:
diff changeset
   200
hgs
parents:
diff changeset
   201
    const TBool controlAllowed( 
hgs
parents:
diff changeset
   202
                RSat::EAllowedNoModification == control ||
hgs
parents:
diff changeset
   203
                RSat::EControlResultNotSet == control );
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
    if ( RSat::EAllowedWithModifications == control && 
hgs
parents:
diff changeset
   206
         alphaIdNull )
hgs
parents:
diff changeset
   207
        {
hgs
parents:
diff changeset
   208
        LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::NeedUiSession \
hgs
parents:
diff changeset
   209
        RSat::EAllowedWithModifications == control" )
hgs
parents:
diff changeset
   210
        iNeedUiSession = EFalse;
hgs
parents:
diff changeset
   211
        }
hgs
parents:
diff changeset
   212
    else if ( controlAllowed && ( RSat::EAlphaIdProvided != alphaId ) )
hgs
parents:
diff changeset
   213
        {
hgs
parents:
diff changeset
   214
        LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::NeedUiSession \
hgs
parents:
diff changeset
   215
        RSat::EAlphaIdProvided != alphaId" )
hgs
parents:
diff changeset
   216
        iNeedUiSession = EFalse;
hgs
parents:
diff changeset
   217
        }
hgs
parents:
diff changeset
   218
    else
hgs
parents:
diff changeset
   219
        {
hgs
parents:
diff changeset
   220
        iNeedUiSession = ETrue;
hgs
parents:
diff changeset
   221
        }
hgs
parents:
diff changeset
   222
hgs
parents:
diff changeset
   223
    LOG2( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::NeedUiSession exiting,\
hgs
parents:
diff changeset
   224
          iNeedUiSession:%d", iNeedUiSession )
hgs
parents:
diff changeset
   225
    return iNeedUiSession;
hgs
parents:
diff changeset
   226
    }
hgs
parents:
diff changeset
   227
hgs
parents:
diff changeset
   228
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   229
// CMoSmControlHandler::HandleCommand
hgs
parents:
diff changeset
   230
// (other items were commented in a header).
hgs
parents:
diff changeset
   231
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   232
//
hgs
parents:
diff changeset
   233
void CMoSmControlHandler::HandleCommand()
hgs
parents:
diff changeset
   234
    {
hgs
parents:
diff changeset
   235
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::HandleCommand calling" )
hgs
parents:
diff changeset
   236
hgs
parents:
diff changeset
   237
    // Notify other commands that we are executing.
hgs
parents:
diff changeset
   238
    iUtils->NotifyEvent( MSatUtils::EMoSmControlExecuting );
hgs
parents:
diff changeset
   239
    LOG2( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::HandleCommand \
hgs
parents:
diff changeset
   240
          iNeedUiSession:%d", iNeedUiSession )
hgs
parents:
diff changeset
   241
    if ( iNeedUiSession )
hgs
parents:
diff changeset
   242
        {
hgs
parents:
diff changeset
   243
        // Clear send data.
hgs
parents:
diff changeset
   244
        TSatNotificationV1 temp;
hgs
parents:
diff changeset
   245
        iMoSmControlSendData = temp;
hgs
parents:
diff changeset
   246
        
hgs
parents:
diff changeset
   247
        // Enums to UI related parameters
hgs
parents:
diff changeset
   248
        TSatAlphaIdStatus satAlphaIdStatus;
hgs
parents:
diff changeset
   249
        TSatControlResult satControlResult;
hgs
parents:
diff changeset
   250
        LOG2( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::HandleCommand \
hgs
parents:
diff changeset
   251
              iMoSmControlData.iAlphaId.iStatus:%d", 
hgs
parents:
diff changeset
   252
              iMoSmControlData.iAlphaId.iStatus )
hgs
parents:
diff changeset
   253
        // Map RSat value
hgs
parents:
diff changeset
   254
        switch ( iMoSmControlData.iAlphaId.iStatus )
hgs
parents:
diff changeset
   255
            {
hgs
parents:
diff changeset
   256
            case RSat::EAlphaIdProvided :
hgs
parents:
diff changeset
   257
                {
hgs
parents:
diff changeset
   258
                satAlphaIdStatus = ESatAlphaIdNotNull;
hgs
parents:
diff changeset
   259
                break;
hgs
parents:
diff changeset
   260
                }
hgs
parents:
diff changeset
   261
hgs
parents:
diff changeset
   262
            case RSat::EAlphaIdNotPresent :
hgs
parents:
diff changeset
   263
                {
hgs
parents:
diff changeset
   264
                satAlphaIdStatus = ESatAlphaIdNotProvided;
hgs
parents:
diff changeset
   265
                break;
hgs
parents:
diff changeset
   266
                }
hgs
parents:
diff changeset
   267
hgs
parents:
diff changeset
   268
            // Use this also as a default value
hgs
parents:
diff changeset
   269
            case RSat::EAlphaIdNull :
hgs
parents:
diff changeset
   270
            case RSat::EAlphaIdNotSet :
hgs
parents:
diff changeset
   271
            default :
hgs
parents:
diff changeset
   272
                {
hgs
parents:
diff changeset
   273
                satAlphaIdStatus = ESatAlphaIdNull;
hgs
parents:
diff changeset
   274
                break;
hgs
parents:
diff changeset
   275
                }
hgs
parents:
diff changeset
   276
            }
hgs
parents:
diff changeset
   277
        LOG2( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::HandleCommand \
hgs
parents:
diff changeset
   278
              iMoSmControlData.iResult:%d", iMoSmControlData.iResult )
hgs
parents:
diff changeset
   279
        // Map RSat value
hgs
parents:
diff changeset
   280
        switch ( iMoSmControlData.iResult )
hgs
parents:
diff changeset
   281
            {
hgs
parents:
diff changeset
   282
            case RSat::ENotAllowed :
hgs
parents:
diff changeset
   283
                {
hgs
parents:
diff changeset
   284
                satControlResult = ESatNotAllowed;
hgs
parents:
diff changeset
   285
                break;
hgs
parents:
diff changeset
   286
                }
hgs
parents:
diff changeset
   287
hgs
parents:
diff changeset
   288
            case RSat::EAllowedWithModifications :
hgs
parents:
diff changeset
   289
                {
hgs
parents:
diff changeset
   290
                satControlResult = ESatAllowedWithModifications;
hgs
parents:
diff changeset
   291
                break;
hgs
parents:
diff changeset
   292
                }
hgs
parents:
diff changeset
   293
hgs
parents:
diff changeset
   294
            // Use this also as a default value
hgs
parents:
diff changeset
   295
            case RSat::EAllowedNoModification :
hgs
parents:
diff changeset
   296
            case RSat::EControlResultNotSet :
hgs
parents:
diff changeset
   297
            default :
hgs
parents:
diff changeset
   298
                {
hgs
parents:
diff changeset
   299
                satControlResult = ESatAllowedNoModification;
hgs
parents:
diff changeset
   300
                break;
hgs
parents:
diff changeset
   301
                }
hgs
parents:
diff changeset
   302
            }
hgs
parents:
diff changeset
   303
hgs
parents:
diff changeset
   304
        // Build the IPC package.
hgs
parents:
diff changeset
   305
        iMoSmControlSendData.iCommand = ESatSMoSmControlNotify;
hgs
parents:
diff changeset
   306
        iMoSmControlSendData.iText = iMoSmControlData.iAlphaId.iAlphaId;
hgs
parents:
diff changeset
   307
        iMoSmControlSendData.iAlphaIdStatus = satAlphaIdStatus;
hgs
parents:
diff changeset
   308
        iMoSmControlSendData.iControlResult = satControlResult;
hgs
parents:
diff changeset
   309
hgs
parents:
diff changeset
   310
        // Register notification observer
hgs
parents:
diff changeset
   311
        TRAPD( regErr, iUtils->RegisterServiceRequestL(
hgs
parents:
diff changeset
   312
            ESatSProactiveNotification,
hgs
parents:
diff changeset
   313
            ESatSProactiveNotificationResponse,
hgs
parents:
diff changeset
   314
            this )
hgs
parents:
diff changeset
   315
            ); // TRAPD
hgs
parents:
diff changeset
   316
        LOG2( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::HandleCommand \
hgs
parents:
diff changeset
   317
              regErr:%d", regErr )
hgs
parents:
diff changeset
   318
        // No need to check error value, since we cannot send terminal response
hgs
parents:
diff changeset
   319
        // for this command
hgs
parents:
diff changeset
   320
        if ( KErrNone == regErr )
hgs
parents:
diff changeset
   321
            {
hgs
parents:
diff changeset
   322
            // Get UISession.
hgs
parents:
diff changeset
   323
            MSatUiSession* uiSession = iUtils->SatUiHandler().UiSession();
hgs
parents:
diff changeset
   324
hgs
parents:
diff changeset
   325
            // Send command to SatClient.
hgs
parents:
diff changeset
   326
            uiSession->SendCommand( &iMoSmControlSendPckg,
hgs
parents:
diff changeset
   327
                &iMoSmControlUiRespPckg, ESatSProactiveNotification );
hgs
parents:
diff changeset
   328
            }
hgs
parents:
diff changeset
   329
        }
hgs
parents:
diff changeset
   330
hgs
parents:
diff changeset
   331
    else
hgs
parents:
diff changeset
   332
        {
hgs
parents:
diff changeset
   333
        // Restart request since we don't get client response
hgs
parents:
diff changeset
   334
        Start();
hgs
parents:
diff changeset
   335
hgs
parents:
diff changeset
   336
        // Inform the system that we are finished executing. If there is 
hgs
parents:
diff changeset
   337
        // proactive
hgs
parents:
diff changeset
   338
        // SendSm command pending, it is notified and it continues from here.
hgs
parents:
diff changeset
   339
        iUtils->NotifyEvent( MSatUtils::EMoSmControlDone );
hgs
parents:
diff changeset
   340
hgs
parents:
diff changeset
   341
        // Inform the session that we are done here.
hgs
parents:
diff changeset
   342
        iUtils->NotifyEvent( MSatUtils::EDelaySimSessionEnd );
hgs
parents:
diff changeset
   343
        }
hgs
parents:
diff changeset
   344
hgs
parents:
diff changeset
   345
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::HandleCommand exiting" )
hgs
parents:
diff changeset
   346
    }
hgs
parents:
diff changeset
   347
hgs
parents:
diff changeset
   348
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   349
// CMoSmControlHandler::UiLaunchFailed
hgs
parents:
diff changeset
   350
// (other items were commented in a header).
hgs
parents:
diff changeset
   351
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   352
//
hgs
parents:
diff changeset
   353
void CMoSmControlHandler::UiLaunchFailed()
hgs
parents:
diff changeset
   354
    {
hgs
parents:
diff changeset
   355
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::UiLaunchFailed calling" )
hgs
parents:
diff changeset
   356
hgs
parents:
diff changeset
   357
    // We cannot send terminal response to UICC since it doesn't
hgs
parents:
diff changeset
   358
    // expect terminal response from MoSmControl command...
hgs
parents:
diff changeset
   359
hgs
parents:
diff changeset
   360
    // Inform the session that we are done here.
hgs
parents:
diff changeset
   361
    iUtils->NotifyEvent( MSatUtils::EDelaySimSessionEnd );
hgs
parents:
diff changeset
   362
hgs
parents:
diff changeset
   363
    // Start to receive more commands.
hgs
parents:
diff changeset
   364
    Start();
hgs
parents:
diff changeset
   365
hgs
parents:
diff changeset
   366
    LOG( SIMPLE, "MOSMCONTROL: CMoSmControlHandler::UiLaunchFailed exiting" )
hgs
parents:
diff changeset
   367
    }
hgs
parents:
diff changeset
   368
hgs
parents:
diff changeset
   369
//  End of File