cbsatplugin/atmisccmdplugin/src/atmisccmdplugin.cpp
author hgs
Mon, 12 Jul 2010 19:25:26 +0300
changeset 45 b0aebde9b1fb
parent 32 19bd632b5100
child 47 9e2a905b887f
permissions -rw-r--r--
201027_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
26
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 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:  Main handler for incoming requests
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#include "atmisccmdplugin.h"
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
#include "clckcommandhandler.h"
hgs
parents:
diff changeset
    21
#include "cpwdcommandhandler.h"
hgs
parents:
diff changeset
    22
#include "cpincommandhandler.h"
hgs
parents:
diff changeset
    23
#include "cusdcommandhandler.h"
hgs
parents:
diff changeset
    24
#include "cnumcommandhandler.h"
hgs
parents:
diff changeset
    25
#include "cfuncommandhandler.h"
hgs
parents:
diff changeset
    26
#include "cbccommandhandler.h"
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    27
#ifdef PROTOCOL_TDSCDMA
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    28
#include "hvercommandhandler.h"
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    29
#include "cgsncommandhandler.h"
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    30
#include "cgmrcommandhandler.h"
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    31
#include "cgmicommandhandler.h"
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    32
#include "cmgwcommandhandler.h"
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    33
#include "cmgdcommandhandler.h"
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    34
#include "telephonywrapper.h"
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    35
#endif
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    36
26
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
#include "atmisccmdpluginconsts.h"
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    39
#include "cmserror.h"
26
hgs
parents:
diff changeset
    40
#include "debug.h"
hgs
parents:
diff changeset
    41
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    42
#include <exterror.h>           // Additional RMobilePhone error code
26
hgs
parents:
diff changeset
    43
hgs
parents:
diff changeset
    44
// +CME error code
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    45
_LIT8(KCMEMemoryFailure, "+CME ERROR: 23\r\n"); // Memory failure.\r\n
32
hgs
parents: 31
diff changeset
    46
_LIT8(KCMEIncorrectPassword, "+CME ERROR: 16\r\n"); // Incorrect password.\r\n
hgs
parents: 31
diff changeset
    47
_LIT8(KCMEPUKRequired, "+CME ERROR: 12\r\n"); // PUK required.\r\n
hgs
parents: 31
diff changeset
    48
_LIT8(KCMENotAllowed, "+CME ERROR: 3\r\n"); // Operation not allowed.\r\n
hgs
parents: 31
diff changeset
    49
_LIT8(KCMEPhoneError, "+CME ERROR: 0\r\n"); // Phone failure.\r\n
hgs
parents: 31
diff changeset
    50
_LIT8(KCMEPhoneUnknown, "+CME ERROR: 100\r\n"); // unknown error
26
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
const TInt KErrorReplyLength = 9;  // CR+LF+"ERROR"+CR+LF
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    53
const TInt KEditorReplyLength = 4;  // CR+LF+'>'+' '
26
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
CATMiscCmdPlugin* CATMiscCmdPlugin::NewL()
hgs
parents:
diff changeset
    56
    {
hgs
parents:
diff changeset
    57
    CATMiscCmdPlugin* self = new (ELeave) CATMiscCmdPlugin();
hgs
parents:
diff changeset
    58
    CleanupStack::PushL(self);
hgs
parents:
diff changeset
    59
    self->ConstructL();
hgs
parents:
diff changeset
    60
    CleanupStack::Pop(self);
hgs
parents:
diff changeset
    61
    return self;
hgs
parents:
diff changeset
    62
    }
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
CATMiscCmdPlugin::~CATMiscCmdPlugin()
hgs
parents:
diff changeset
    65
	{
hgs
parents:
diff changeset
    66
    iReplyBuffer.Close();
hgs
parents:
diff changeset
    67
    
hgs
parents:
diff changeset
    68
    delete iCLCKHandler;
hgs
parents:
diff changeset
    69
    delete iCPWDHandler;
hgs
parents:
diff changeset
    70
    delete iCPINHandler;
hgs
parents:
diff changeset
    71
    delete iCUSDHandler;
hgs
parents:
diff changeset
    72
    delete iCNUMHandler;
hgs
parents:
diff changeset
    73
    delete iCFUNHandler;
hgs
parents:
diff changeset
    74
    delete iCBCHandler;
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    75
#ifdef PROTOCOL_TDSCDMA
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    76
	delete iHVERHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    77
	delete iCGSNHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    78
    delete iCGMRHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    79
    delete iCGMIHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    80
    delete iCMGWHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    81
    delete iCMGDHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    82
#endif    
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
    83
	
26
hgs
parents:
diff changeset
    84
    iPhone.Close();
hgs
parents:
diff changeset
    85
    iTelServer.Close();
hgs
parents:
diff changeset
    86
	}
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
CATMiscCmdPlugin::CATMiscCmdPlugin() : 
hgs
parents:
diff changeset
    89
    CATExtPluginBase()
hgs
parents:
diff changeset
    90
    {
hgs
parents:
diff changeset
    91
    }
hgs
parents:
diff changeset
    92
hgs
parents:
diff changeset
    93
void CATMiscCmdPlugin::ConstructL()
hgs
parents:
diff changeset
    94
    {
hgs
parents:
diff changeset
    95
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
    96
    ConnectToEtelL(iTelServer, iPhone);
hgs
parents:
diff changeset
    97
    
hgs
parents:
diff changeset
    98
    iCLCKHandler = CCLCKCommandHandler::NewL(this, iCommandParser, iPhone);
hgs
parents:
diff changeset
    99
    iCPWDHandler = CCPWDCommandHandler::NewL(this, iCommandParser, iPhone);
hgs
parents:
diff changeset
   100
    iCUSDHandler = CCUSDCommandHandler::NewL(this, iCommandParser, iPhone);
hgs
parents:
diff changeset
   101
    iCPINHandler = CCPINCommandHandler::NewL(this, iCommandParser, iPhone);
hgs
parents:
diff changeset
   102
    iCNUMHandler = CCNUMCommandHandler::NewL(this, iCommandParser, iPhone, iTelServer);
hgs
parents:
diff changeset
   103
    iCFUNHandler = CCFUNCommandHandler::NewL(this, iCommandParser, iPhone);
hgs
parents:
diff changeset
   104
    iCBCHandler = CCBCCommandHandler::NewL(this, iCommandParser, iPhone);
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   105
    
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   106
#ifdef PROTOCOL_TDSCDMA
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   107
	iHVERHandler = CHVERCommandHandler::NewL(this, iCommandParser, iPhone);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   108
    iCGSNHandler = CCGSNCommandHandler::NewL(this, iCommandParser, iPhone);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   109
    iCGMRHandler = CCGMRCommandHandler::NewL(this, iCommandParser, iPhone);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   110
    iCGMIHandler = CCGMICommandHandler::NewL(this, iCommandParser, iPhone);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   111
    iCMGWHandler = CCMGWCommandHandler::NewL(this, iCommandParser, iPhone);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   112
    iCMGDHandler = CCMGDCommandHandler::NewL(this, iCommandParser, iPhone); 
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   113
   
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   114
    // Get telephony information - Model, IMEI, Manufacturer
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   115
    CTelephonyWrapper* telephonyWrapper = CTelephonyWrapper::NewL();
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   116
    TInt result = telephonyWrapper->SynchronousGetPhoneId();
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   117
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   118
    if (KErrNone == result)
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   119
        {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   120
        static_cast<CHVERCommandHandler*>(iHVERHandler)->SetHWVersion(telephonyWrapper->GetPhoneModel());
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   121
        static_cast<CCGSNCommandHandler*>(iCGSNHandler)->SetSerialNum(telephonyWrapper->GetPhoneSerialNum());
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   122
        static_cast<CCGMICommandHandler*>(iCGMIHandler)->SetManufacturer(telephonyWrapper->GetPhoneManufacturer());
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   123
        }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   124
    else // The result is used to determine whether to display CME error or not
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   125
        {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   126
        static_cast<CHVERCommandHandler*>(iHVERHandler)->SetTelephonyError(result);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   127
        static_cast<CCGSNCommandHandler*>(iCGSNHandler)->SetTelephonyError(result);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   128
        static_cast<CCGMICommandHandler*>(iCGMIHandler)->SetTelephonyError(result);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   129
        }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   130
    delete telephonyWrapper;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   131
#endif    
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   132
    
26
hgs
parents:
diff changeset
   133
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   134
   	}
hgs
parents:
diff changeset
   135
hgs
parents:
diff changeset
   136
/**
hgs
parents:
diff changeset
   137
 * @see CATExtPluginBase::ReportConnectionName
hgs
parents:
diff changeset
   138
 */
hgs
parents:
diff changeset
   139
void CATMiscCmdPlugin::ReportConnectionName( const TDesC8& /*aName*/ )
hgs
parents:
diff changeset
   140
    {
hgs
parents:
diff changeset
   141
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   142
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   143
    }
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
/**
hgs
parents:
diff changeset
   146
 * @see CATExtPluginBase::IsCommandSupported
hgs
parents:
diff changeset
   147
 */
hgs
parents:
diff changeset
   148
TBool CATMiscCmdPlugin::IsCommandSupported( const TDesC8& aCmd )
hgs
parents:
diff changeset
   149
    {
hgs
parents:
diff changeset
   150
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   151
    iHcCmd = NULL;
hgs
parents:
diff changeset
   152
    iHcReply = NULL;
hgs
parents:
diff changeset
   153
    iCurrentHandler = NULL;
hgs
parents:
diff changeset
   154
    TBool supported = ETrue;
hgs
parents:
diff changeset
   155
    
hgs
parents:
diff changeset
   156
    Trace(KDebugPrintS, "aCmd: ", &aCmd);
hgs
parents:
diff changeset
   157
    
hgs
parents:
diff changeset
   158
    iCommandParser.ParseAtCommand(aCmd);
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
    Trace(KDebugPrintD, "Command: ", iCommandParser.Command());
hgs
parents:
diff changeset
   161
    // TODO: check if the type is supported?
hgs
parents:
diff changeset
   162
    // iCommandParser.CommandHandlerType() != TAtCommandParser::ECmdHandlerTypeUndefined
hgs
parents:
diff changeset
   163
    switch (iCommandParser.Command())
hgs
parents:
diff changeset
   164
        {
hgs
parents:
diff changeset
   165
        case (TAtCommandParser::ECmdAtClck):
hgs
parents:
diff changeset
   166
            {
hgs
parents:
diff changeset
   167
            iCurrentHandler = iCLCKHandler;
hgs
parents:
diff changeset
   168
            break;
hgs
parents:
diff changeset
   169
            }
hgs
parents:
diff changeset
   170
        case (TAtCommandParser::ECmdAtCpwd):
hgs
parents:
diff changeset
   171
            {
hgs
parents:
diff changeset
   172
            iCurrentHandler = iCPWDHandler;
hgs
parents:
diff changeset
   173
            break;
hgs
parents:
diff changeset
   174
            }
hgs
parents:
diff changeset
   175
        case (TAtCommandParser::ECmdAtCpin):
hgs
parents:
diff changeset
   176
            {
hgs
parents:
diff changeset
   177
            iCurrentHandler = iCPINHandler;
hgs
parents:
diff changeset
   178
            break;
hgs
parents:
diff changeset
   179
            }
hgs
parents:
diff changeset
   180
        case (TAtCommandParser::ECmdAtCusd):
hgs
parents:
diff changeset
   181
            {
hgs
parents:
diff changeset
   182
            iCurrentHandler = iCUSDHandler;
hgs
parents:
diff changeset
   183
            break;
hgs
parents:
diff changeset
   184
            }   
hgs
parents:
diff changeset
   185
        case (TAtCommandParser::ECmdAtCnum):
hgs
parents:
diff changeset
   186
            {
hgs
parents:
diff changeset
   187
            iCurrentHandler = iCNUMHandler;
hgs
parents:
diff changeset
   188
            break;
hgs
parents:
diff changeset
   189
            }
hgs
parents:
diff changeset
   190
        case (TAtCommandParser::ECmdAtCfun):
hgs
parents:
diff changeset
   191
            {
hgs
parents:
diff changeset
   192
            iCurrentHandler = iCFUNHandler;
hgs
parents:
diff changeset
   193
            break;
hgs
parents:
diff changeset
   194
            }
hgs
parents:
diff changeset
   195
        case (TAtCommandParser::ECmdAtCbc):
hgs
parents:
diff changeset
   196
            {
hgs
parents:
diff changeset
   197
            iCurrentHandler = iCBCHandler;
hgs
parents:
diff changeset
   198
            break;
hgs
parents:
diff changeset
   199
            }
32
hgs
parents: 31
diff changeset
   200
        case (TAtCommandParser::ECmdAtCmee):
hgs
parents: 31
diff changeset
   201
            {
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   202
            iCurrentHandler = NULL;	
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   203
            break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   204
			}
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   205
#ifdef PROTOCOL_TDSCDMA
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   206
        case (TAtCommandParser::ECmdAtHver):
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   207
            {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   208
            iCurrentHandler = iHVERHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   209
            break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   210
            }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   211
        case (TAtCommandParser::ECmdAtCgsn):
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   212
            {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   213
            iCurrentHandler = iCGSNHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   214
            break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   215
            }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   216
        case (TAtCommandParser::ECmdAtCgmr):
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   217
            {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   218
            iCurrentHandler = iCGMRHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   219
            break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   220
            }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   221
        case (TAtCommandParser::ECmdAtCgmi):
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   222
            {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   223
            iCurrentHandler = iCGMIHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   224
            break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   225
            }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   226
        case (TAtCommandParser::ECmdAtCmgw):
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   227
            {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   228
            iCurrentHandler = iCMGWHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   229
            break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   230
            }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   231
		case (TAtCommandParser::ECmdAtCmgd):
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   232
            {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   233
            iCurrentHandler = iCMGDHandler;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   234
            break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   235
            }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   236
		case (TAtCommandParser::ECmdAtCmgf):
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   237
            {
32
hgs
parents: 31
diff changeset
   238
            iCurrentHandler = NULL;
hgs
parents: 31
diff changeset
   239
            break;
hgs
parents: 31
diff changeset
   240
            }
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   241
#endif
26
hgs
parents:
diff changeset
   242
        case (TAtCommandParser::EUnknown):
hgs
parents:
diff changeset
   243
        default:
hgs
parents:
diff changeset
   244
            {
hgs
parents:
diff changeset
   245
            supported = EFalse;
hgs
parents:
diff changeset
   246
            break;
hgs
parents:
diff changeset
   247
            }
hgs
parents:
diff changeset
   248
        }
hgs
parents:
diff changeset
   249
    Trace(KDebugPrintD, "supported: ", supported);
hgs
parents:
diff changeset
   250
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   251
    return supported;
hgs
parents:
diff changeset
   252
	}
hgs
parents:
diff changeset
   253
hgs
parents:
diff changeset
   254
/**
hgs
parents:
diff changeset
   255
 * @see CATExtPluginBase::HandleCommand
hgs
parents:
diff changeset
   256
 */
hgs
parents:
diff changeset
   257
void CATMiscCmdPlugin::HandleCommand( const TDesC8& aCmd,
hgs
parents:
diff changeset
   258
                                     RBuf8& aReply,
hgs
parents:
diff changeset
   259
                                     TBool aReplyNeeded )
hgs
parents:
diff changeset
   260
	{
hgs
parents:
diff changeset
   261
	TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   262
	
32
hgs
parents: 31
diff changeset
   263
	if(iCommandParser.Command() == TAtCommandParser::ECmdAtCmee)
hgs
parents: 31
diff changeset
   264
	    {
hgs
parents: 31
diff changeset
   265
        HandleCMEECommand();
hgs
parents: 31
diff changeset
   266
        HandleCommandCompleted( KErrNone, EReplyTypeOk);
hgs
parents: 31
diff changeset
   267
	    }
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   268
#ifdef PROTOCOL_TDSCDMA
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   269
	else if (iCommandParser.Command() == TAtCommandParser::ECmdAtCmgf)
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   270
	    {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   271
        HandleCMGFCommand();
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   272
        HandleCommandCompleted( KErrNone, EReplyTypeOk);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   273
	    }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   274
#endif
32
hgs
parents: 31
diff changeset
   275
	else if (iCurrentHandler != NULL)
26
hgs
parents:
diff changeset
   276
	    {
hgs
parents:
diff changeset
   277
	    iHcCmd = &aCmd;
hgs
parents:
diff changeset
   278
	    iHcReply = &aReply;
32
hgs
parents: 31
diff changeset
   279
	    // No need to parse the command again as assumed that
hgs
parents: 31
diff changeset
   280
	    // it is always called from CATMiscCmdPlugin::IsCommandSupported()
26
hgs
parents:
diff changeset
   281
	    iCurrentHandler->HandleCommand( aCmd, aReply, aReplyNeeded );
hgs
parents:
diff changeset
   282
	    }
hgs
parents:
diff changeset
   283
	TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   284
    }
hgs
parents:
diff changeset
   285
hgs
parents:
diff changeset
   286
/**
hgs
parents:
diff changeset
   287
 * @see CATExtPluginBase::HandleCommandCancel
hgs
parents:
diff changeset
   288
 */
hgs
parents:
diff changeset
   289
void CATMiscCmdPlugin::HandleCommandCancel()
hgs
parents:
diff changeset
   290
    {
hgs
parents:
diff changeset
   291
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   292
    if (iCurrentHandler != NULL)
hgs
parents:
diff changeset
   293
	    {
hgs
parents:
diff changeset
   294
	    iCurrentHandler->HandleCommandCancel();
hgs
parents:
diff changeset
   295
	    }
hgs
parents:
diff changeset
   296
	TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   297
    }
hgs
parents:
diff changeset
   298
hgs
parents:
diff changeset
   299
/**
hgs
parents:
diff changeset
   300
 * @see CATExtPluginBase::NextReplyPartLength
hgs
parents:
diff changeset
   301
 */
hgs
parents:
diff changeset
   302
TInt CATMiscCmdPlugin::NextReplyPartLength()
hgs
parents:
diff changeset
   303
    {
hgs
parents:
diff changeset
   304
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   305
    TInt length = iReplyBuffer.Length();
hgs
parents:
diff changeset
   306
    if ( length >= KDefaultCmdBufLength )
hgs
parents:
diff changeset
   307
        {
hgs
parents:
diff changeset
   308
        length = KDefaultCmdBufLength;
hgs
parents:
diff changeset
   309
        }
hgs
parents:
diff changeset
   310
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   311
    return length;
hgs
parents:
diff changeset
   312
    }
hgs
parents:
diff changeset
   313
hgs
parents:
diff changeset
   314
/**
hgs
parents:
diff changeset
   315
 * @see CATExtPluginBase::GetNextPartOfReply
hgs
parents:
diff changeset
   316
 */
hgs
parents:
diff changeset
   317
TInt CATMiscCmdPlugin::GetNextPartOfReply( RBuf8& aNextReply )
hgs
parents:
diff changeset
   318
    {
hgs
parents:
diff changeset
   319
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   320
    TInt retVal = CreatePartOfReply( aNextReply );
hgs
parents:
diff changeset
   321
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   322
    return retVal;
hgs
parents:
diff changeset
   323
    }
hgs
parents:
diff changeset
   324
hgs
parents:
diff changeset
   325
/**
hgs
parents:
diff changeset
   326
 * @see CATExtPluginBase::ReceiveUnsolicitedResult
hgs
parents:
diff changeset
   327
 */
hgs
parents:
diff changeset
   328
void CATMiscCmdPlugin::ReceiveUnsolicitedResult()
hgs
parents:
diff changeset
   329
    {
hgs
parents:
diff changeset
   330
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   331
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   332
    }
hgs
parents:
diff changeset
   333
hgs
parents:
diff changeset
   334
/**
hgs
parents:
diff changeset
   335
 * @see CATExtPluginBase::ReceiveUnsolicitedResultCancel
hgs
parents:
diff changeset
   336
 */
hgs
parents:
diff changeset
   337
void CATMiscCmdPlugin::ReceiveUnsolicitedResultCancel()
hgs
parents:
diff changeset
   338
    {
hgs
parents:
diff changeset
   339
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   340
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   341
    }
hgs
parents:
diff changeset
   342
hgs
parents:
diff changeset
   343
/**
hgs
parents:
diff changeset
   344
 * @see CATExtPluginBase::ReportNvramStatusChange
hgs
parents:
diff changeset
   345
 */
hgs
parents:
diff changeset
   346
void CATMiscCmdPlugin::ReportNvramStatusChange( const TDesC8& /*aNvram*/ )
hgs
parents:
diff changeset
   347
    {
hgs
parents:
diff changeset
   348
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   349
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   350
    }
hgs
parents:
diff changeset
   351
hgs
parents:
diff changeset
   352
/**
hgs
parents:
diff changeset
   353
 * @see CATExtPluginBase::ReportExternalHandleCommandError
hgs
parents:
diff changeset
   354
 */
hgs
parents:
diff changeset
   355
void CATMiscCmdPlugin::ReportExternalHandleCommandError()
hgs
parents:
diff changeset
   356
    {
hgs
parents:
diff changeset
   357
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   358
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   359
    }
hgs
parents:
diff changeset
   360
hgs
parents:
diff changeset
   361
/**
hgs
parents:
diff changeset
   362
 * Creates part of reply from the global reply buffer to the destination
hgs
parents:
diff changeset
   363
 * buffer. Used with APIs which need the next part of reply in multipart
hgs
parents:
diff changeset
   364
 * reply requests.
hgs
parents:
diff changeset
   365
 *
hgs
parents:
diff changeset
   366
 * @param aBuffer Destination buffer; the next part of reply is stored to
hgs
parents:
diff changeset
   367
 *                   this buffer.
hgs
parents:
diff changeset
   368
 * @return None
hgs
parents:
diff changeset
   369
 */
hgs
parents:
diff changeset
   370
TInt CATMiscCmdPlugin::CreatePartOfReply( RBuf8& aBuffer )
hgs
parents:
diff changeset
   371
    {
hgs
parents:
diff changeset
   372
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   373
    TInt ret = KErrNone;
hgs
parents:
diff changeset
   374
    if ( iReplyBuffer.Length() <= 0 )
hgs
parents:
diff changeset
   375
        {
hgs
parents:
diff changeset
   376
        ret = KErrGeneral;
hgs
parents:
diff changeset
   377
        }
hgs
parents:
diff changeset
   378
    else
hgs
parents:
diff changeset
   379
        {
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   380
    	TInt partLength = NextReplyPartLength();
26
hgs
parents:
diff changeset
   381
        if ( iReplyBuffer.Length() < partLength )
hgs
parents:
diff changeset
   382
            {
hgs
parents:
diff changeset
   383
            ret =  KErrNotFound;
hgs
parents:
diff changeset
   384
            }
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   385
        else if (ret == KErrNone)
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   386
			{
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   387
			aBuffer.Create( iReplyBuffer, partLength );
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   388
			iReplyBuffer.Delete( 0, partLength );
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   389
			if ( iReplyBuffer.Length() == 0 )
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   390
				{
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   391
				iReplyBuffer.Close();
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   392
				}
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   393
			}
26
hgs
parents:
diff changeset
   394
        }
hgs
parents:
diff changeset
   395
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   396
    Trace(KDebugPrintD, "ret: ", ret);
26
hgs
parents:
diff changeset
   397
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   398
    return ret;
hgs
parents:
diff changeset
   399
    }
hgs
parents:
diff changeset
   400
hgs
parents:
diff changeset
   401
/**
hgs
parents:
diff changeset
   402
 * @see MATMiscCmdPlugin::CreateReplyAndComplete
hgs
parents:
diff changeset
   403
 */
hgs
parents:
diff changeset
   404
TInt CATMiscCmdPlugin::CreateReplyAndComplete( TATExtensionReplyType aReplyType,
hgs
parents:
diff changeset
   405
                                              const TDesC8& aSrcBuffer,
hgs
parents:
diff changeset
   406
											  TInt aError )
hgs
parents:
diff changeset
   407
    {
hgs
parents:
diff changeset
   408
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   409
    iReplyBuffer.Close();
hgs
parents:
diff changeset
   410
    Trace(KDebugPrintD, "aError: ", aError);
hgs
parents:
diff changeset
   411
    if ( aError != KErrNone )
hgs
parents:
diff changeset
   412
        {
hgs
parents:
diff changeset
   413
        HandleCommandCompleted( aError, EReplyTypeUndefined );
hgs
parents:
diff changeset
   414
        iHcCmd = NULL;
hgs
parents:
diff changeset
   415
        iHcReply = NULL;
hgs
parents:
diff changeset
   416
        iCurrentHandler = NULL;
hgs
parents:
diff changeset
   417
        TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   418
        return KErrNone;
hgs
parents:
diff changeset
   419
        }
hgs
parents:
diff changeset
   420
    
hgs
parents:
diff changeset
   421
    Trace(KDebugPrintS, "iHcReply: ", &iHcReply);
hgs
parents:
diff changeset
   422
    if (iHcReply == NULL)
hgs
parents:
diff changeset
   423
        {
hgs
parents:
diff changeset
   424
        TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   425
        return KErrGeneral;
hgs
parents:
diff changeset
   426
        }
hgs
parents:
diff changeset
   427
    
hgs
parents:
diff changeset
   428
    Trace(KDebugPrintD, "iQuietMode: ", iQuietMode);
hgs
parents:
diff changeset
   429
    if ( iQuietMode )
hgs
parents:
diff changeset
   430
        {
hgs
parents:
diff changeset
   431
        iReplyBuffer.Create( KNullDesC8 );
hgs
parents:
diff changeset
   432
        }
hgs
parents:
diff changeset
   433
    else
hgs
parents:
diff changeset
   434
        {
hgs
parents:
diff changeset
   435
        iReplyBuffer.Create( aSrcBuffer );
hgs
parents:
diff changeset
   436
        }
hgs
parents:
diff changeset
   437
    
hgs
parents:
diff changeset
   438
    Trace(KDebugPrintD, "aReplyType: ", aReplyType);
hgs
parents:
diff changeset
   439
    switch ( aReplyType )
hgs
parents:
diff changeset
   440
        {
hgs
parents:
diff changeset
   441
        case EReplyTypeOther:
hgs
parents:
diff changeset
   442
            break;
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   443
#ifdef PROTOCOL_TDSCDMA
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   444
        case EReplyTypeEditor:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   445
            CreateEditModeBuffer( iReplyBuffer );
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   446
            break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   447
#endif
26
hgs
parents:
diff changeset
   448
        case EReplyTypeOk:
hgs
parents:
diff changeset
   449
            CreateOkOrErrorReply( iReplyBuffer, ETrue );
hgs
parents:
diff changeset
   450
            break;
hgs
parents:
diff changeset
   451
        case EReplyTypeError:
hgs
parents:
diff changeset
   452
            CreateOkOrErrorReply( iReplyBuffer, EFalse );
hgs
parents:
diff changeset
   453
            break;
hgs
parents:
diff changeset
   454
        default:
hgs
parents:
diff changeset
   455
            TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   456
            return KErrGeneral;
hgs
parents:
diff changeset
   457
        }
hgs
parents:
diff changeset
   458
    CreatePartOfReply( *iHcReply );
hgs
parents:
diff changeset
   459
    HandleCommandCompleted( KErrNone, aReplyType );
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   460
    if ( EReplyTypeEditor != aReplyType )
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   461
        {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   462
        iHcCmd = NULL;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   463
        iHcReply = NULL;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   464
        iCurrentHandler = NULL;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   465
        }
26
hgs
parents:
diff changeset
   466
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   467
    return KErrNone;
hgs
parents:
diff changeset
   468
    }
hgs
parents:
diff changeset
   469
hgs
parents:
diff changeset
   470
/**
hgs
parents:
diff changeset
   471
 * @see MATMiscCmdPlugin::CreateOkOrErrorReply
hgs
parents:
diff changeset
   472
 */
hgs
parents:
diff changeset
   473
TInt CATMiscCmdPlugin::CreateOkOrErrorReply( RBuf8& aReplyBuffer,
hgs
parents:
diff changeset
   474
                                            TBool aOkReply )
hgs
parents:
diff changeset
   475
    {
hgs
parents:
diff changeset
   476
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   477
    _LIT8( KErrorReplyVerbose, "ERROR" );
hgs
parents:
diff changeset
   478
    _LIT8( KOkReplyVerbose,    "OK" );
hgs
parents:
diff changeset
   479
    _LIT8( KErrorReplyNumeric, "4" );
hgs
parents:
diff changeset
   480
    _LIT8( KOkReplyNumeric,    "0" );
hgs
parents:
diff changeset
   481
    TBuf8<KErrorReplyLength> replyBuffer;
hgs
parents:
diff changeset
   482
    if ( iVerboseMode )
hgs
parents:
diff changeset
   483
        {
hgs
parents:
diff changeset
   484
        replyBuffer.Append( iCarriageReturn );
hgs
parents:
diff changeset
   485
        replyBuffer.Append( iLineFeed );
hgs
parents:
diff changeset
   486
        if ( aOkReply )
hgs
parents:
diff changeset
   487
            {
hgs
parents:
diff changeset
   488
            replyBuffer.Append( KOkReplyVerbose );
hgs
parents:
diff changeset
   489
            }
hgs
parents:
diff changeset
   490
        else
hgs
parents:
diff changeset
   491
            {
hgs
parents:
diff changeset
   492
            replyBuffer.Append( KErrorReplyVerbose );
hgs
parents:
diff changeset
   493
            }
hgs
parents:
diff changeset
   494
        replyBuffer.Append( iCarriageReturn );
hgs
parents:
diff changeset
   495
        replyBuffer.Append( iLineFeed );
hgs
parents:
diff changeset
   496
        }
hgs
parents:
diff changeset
   497
    else
hgs
parents:
diff changeset
   498
        {
hgs
parents:
diff changeset
   499
        if ( aOkReply )
hgs
parents:
diff changeset
   500
            {
hgs
parents:
diff changeset
   501
            replyBuffer.Append( KOkReplyNumeric );
hgs
parents:
diff changeset
   502
            }
hgs
parents:
diff changeset
   503
        else
hgs
parents:
diff changeset
   504
            {
hgs
parents:
diff changeset
   505
            replyBuffer.Append( KErrorReplyNumeric );
hgs
parents:
diff changeset
   506
            }
hgs
parents:
diff changeset
   507
        replyBuffer.Append( iCarriageReturn );
hgs
parents:
diff changeset
   508
        }
hgs
parents:
diff changeset
   509
hgs
parents:
diff changeset
   510
    aReplyBuffer.ReAlloc(aReplyBuffer.Length() + replyBuffer.Length());
hgs
parents:
diff changeset
   511
    aReplyBuffer.Append( replyBuffer );
hgs
parents:
diff changeset
   512
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   513
    return KErrNone;
hgs
parents:
diff changeset
   514
    }
hgs
parents:
diff changeset
   515
hgs
parents:
diff changeset
   516
/**
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   517
 * @see MATMiscCmdPlugin::CreateEditModeBuffer
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   518
 */
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   519
TInt CATMiscCmdPlugin::CreateEditModeBuffer( RBuf8& aReplyBuffer )
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   520
    {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   521
    TRACE_FUNC_ENTRY
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   522
    _LIT8( KReplyPromptAndSpace, "> " );
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   523
    TBuf8<KEditorReplyLength> replyBuffer;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   524
    replyBuffer.Append( iCarriageReturn );
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   525
    replyBuffer.Append( iLineFeed );
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   526
    replyBuffer.Append( KReplyPromptAndSpace );
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   527
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   528
    TInt err = aReplyBuffer.ReAlloc( aReplyBuffer.Length() + replyBuffer.Length() );
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   529
    if (KErrNone != err)
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   530
        {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   531
        return err;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   532
        }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   533
    aReplyBuffer.Append( replyBuffer );
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   534
    TRACE_FUNC_EXIT
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   535
    return KErrNone;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   536
    }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   537
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   538
/**
26
hgs
parents:
diff changeset
   539
 * @see MATMiscCmdPlugin::GetCharacterValue
hgs
parents:
diff changeset
   540
 */
hgs
parents:
diff changeset
   541
TInt CATMiscCmdPlugin::GetCharacterValue( TCharacterTypes aCharType,
hgs
parents:
diff changeset
   542
                                         TChar& aChar )
hgs
parents:
diff changeset
   543
    {
hgs
parents:
diff changeset
   544
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   545
    TInt retVal = KErrNone;
hgs
parents:
diff changeset
   546
    switch ( aCharType )
hgs
parents:
diff changeset
   547
        {
hgs
parents:
diff changeset
   548
        case ECharTypeCR:
hgs
parents:
diff changeset
   549
            aChar = iCarriageReturn;
hgs
parents:
diff changeset
   550
            break;
hgs
parents:
diff changeset
   551
        case ECharTypeLF:
hgs
parents:
diff changeset
   552
            aChar = iLineFeed;
hgs
parents:
diff changeset
   553
            break;
hgs
parents:
diff changeset
   554
        case ECharTypeBS:
hgs
parents:
diff changeset
   555
            aChar = iBackspace;
hgs
parents:
diff changeset
   556
            break;
hgs
parents:
diff changeset
   557
        default:
hgs
parents:
diff changeset
   558
            retVal = KErrNotFound;
hgs
parents:
diff changeset
   559
            break;
hgs
parents:
diff changeset
   560
        }
hgs
parents:
diff changeset
   561
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   562
    return retVal;
hgs
parents:
diff changeset
   563
    }
hgs
parents:
diff changeset
   564
hgs
parents:
diff changeset
   565
/**
hgs
parents:
diff changeset
   566
 * @see MATMiscCmdPlugin::GetModeValue
hgs
parents:
diff changeset
   567
 */
hgs
parents:
diff changeset
   568
TInt CATMiscCmdPlugin::GetModeValue( TModeTypes aModeType, TBool& aMode )
hgs
parents:
diff changeset
   569
    {
hgs
parents:
diff changeset
   570
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   571
    TInt retVal = KErrNone;
hgs
parents:
diff changeset
   572
    switch ( aModeType )
hgs
parents:
diff changeset
   573
        {
hgs
parents:
diff changeset
   574
        case EModeTypeQuiet:
hgs
parents:
diff changeset
   575
            aMode = iQuietMode;
hgs
parents:
diff changeset
   576
            break;
hgs
parents:
diff changeset
   577
        case EModeTypeVerbose:
hgs
parents:
diff changeset
   578
            aMode = iVerboseMode;
hgs
parents:
diff changeset
   579
            break;
hgs
parents:
diff changeset
   580
        default:
hgs
parents:
diff changeset
   581
            retVal = KErrNotFound;
hgs
parents:
diff changeset
   582
            break;
hgs
parents:
diff changeset
   583
        }
hgs
parents:
diff changeset
   584
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   585
    return retVal;
hgs
parents:
diff changeset
   586
    }
hgs
parents:
diff changeset
   587
hgs
parents:
diff changeset
   588
void CATMiscCmdPlugin::CreateCMEReplyAndComplete(TInt aError)
hgs
parents:
diff changeset
   589
    {
hgs
parents:
diff changeset
   590
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   591
    
32
hgs
parents: 31
diff changeset
   592
    // currently only support +CME error level 0 and 1
hgs
parents: 31
diff changeset
   593
    ASSERT(iErrorLevel == 0 || iErrorLevel == 1 );
26
hgs
parents:
diff changeset
   594
    
32
hgs
parents: 31
diff changeset
   595
    // Log error code
hgs
parents: 31
diff changeset
   596
    Trace(KDebugPrintD, "complete with error ", aError);
26
hgs
parents:
diff changeset
   597
    
32
hgs
parents: 31
diff changeset
   598
    if(iErrorLevel == 1 && !iQuietMode)
26
hgs
parents:
diff changeset
   599
        {
32
hgs
parents: 31
diff changeset
   600
        // return error code to AT client
hgs
parents: 31
diff changeset
   601
        RBuf8 response;
hgs
parents: 31
diff changeset
   602
        response.Create(KDefaultCmdBufLength);
hgs
parents: 31
diff changeset
   603
        response.Append(KCRLF);
hgs
parents: 31
diff changeset
   604
        switch(aError)
26
hgs
parents:
diff changeset
   605
            {
32
hgs
parents: 31
diff changeset
   606
            case KErrGsm0707IncorrectPassword:
hgs
parents: 31
diff changeset
   607
            case KErrAccessDenied:
hgs
parents: 31
diff changeset
   608
                {    
hgs
parents: 31
diff changeset
   609
                // code was entered erroneously
hgs
parents: 31
diff changeset
   610
                response.Append(KCMEIncorrectPassword);
hgs
parents: 31
diff changeset
   611
                break;
hgs
parents: 31
diff changeset
   612
                }
hgs
parents: 31
diff changeset
   613
            case KErrGsmSSPasswordAttemptsViolation:
hgs
parents: 31
diff changeset
   614
            case KErrLocked:
hgs
parents: 31
diff changeset
   615
                {
hgs
parents: 31
diff changeset
   616
                // Pin blocked 
hgs
parents: 31
diff changeset
   617
                response.Append(KCMEPUKRequired);
hgs
parents: 31
diff changeset
   618
                break;
hgs
parents: 31
diff changeset
   619
                }
hgs
parents: 31
diff changeset
   620
            case KErrGsm0707OperationNotAllowed:
hgs
parents: 31
diff changeset
   621
                {
hgs
parents: 31
diff changeset
   622
                // not allowed with this sim
hgs
parents: 31
diff changeset
   623
                response.Append(KCMENotAllowed);
hgs
parents: 31
diff changeset
   624
                break;
hgs
parents: 31
diff changeset
   625
                }
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   626
			case KErrGsmMMImeiNotAccepted:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   627
	            {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   628
	            // Memory failure
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   629
	            response.Append(KCMEMemoryFailure);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   630
	            break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   631
	            }
32
hgs
parents: 31
diff changeset
   632
            case KErrUnknown:
hgs
parents: 31
diff changeset
   633
                {
hgs
parents: 31
diff changeset
   634
                // unknown error
hgs
parents: 31
diff changeset
   635
                response.Append(KCMEPhoneUnknown);
hgs
parents: 31
diff changeset
   636
                break;
hgs
parents: 31
diff changeset
   637
                }
hgs
parents: 31
diff changeset
   638
            default:
hgs
parents: 31
diff changeset
   639
                {
hgs
parents: 31
diff changeset
   640
                response.Append(KCMEPhoneError);
hgs
parents: 31
diff changeset
   641
                break;
hgs
parents: 31
diff changeset
   642
                }
26
hgs
parents:
diff changeset
   643
            }
32
hgs
parents: 31
diff changeset
   644
        CreateReplyAndComplete( EReplyTypeError, response );
hgs
parents: 31
diff changeset
   645
        response.Close();
26
hgs
parents:
diff changeset
   646
        }
32
hgs
parents: 31
diff changeset
   647
    else
hgs
parents: 31
diff changeset
   648
        {
hgs
parents: 31
diff changeset
   649
        CreateReplyAndComplete( EReplyTypeError);
hgs
parents: 31
diff changeset
   650
        }
hgs
parents: 31
diff changeset
   651
26
hgs
parents:
diff changeset
   652
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   653
    }
hgs
parents:
diff changeset
   654
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   655
void CATMiscCmdPlugin::CreateCMSReplyAndComplete(TInt aError)
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   656
    {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   657
    TRACE_FUNC_ENTRY
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   658
    
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   659
    if(iQuietMode)
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   660
        {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   661
        CreateReplyAndComplete(EReplyTypeError);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   662
        }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   663
    else 
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   664
        {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   665
        // return error code to AT client
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   666
        RBuf8 response;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   667
        if (KErrNone != response.Create(KDefaultCmdBufLength))
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   668
            {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   669
            CreateReplyAndComplete(EReplyTypeError);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   670
            return;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   671
            }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   672
       
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   673
        // return error code to AT client
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   674
        response.Append(KCRLF);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   675
        response.Append(KCMSErr);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   676
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   677
        switch(aError)
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   678
            {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   679
            case KErrGsmSMSReserved:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   680
                {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   681
                // Other application cause SMS interface being reserved
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   682
                response.AppendNum(EATCMSErr301);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   683
                break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   684
                }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   685
            case KErrGsmSMSInvalidPDUModeParameter:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   686
                {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   687
                // Under the mode of PDU, PDU parameter error 
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   688
                response.AppendNum(EATCMSErr304);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   689
                break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   690
                }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   691
            case KErrNotReady:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   692
            case KErrNotFound:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   693
            case KErrGsmSMSSimNotInserted:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   694
                {    
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   695
                // SIM card not inserted
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   696
                response.AppendNum(EATCMSErr310);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   697
                break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   698
                }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   699
            case KErrGsmSMSSimPin1Required:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   700
                {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   701
                // PIN request by SIM card
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   702
                response.AppendNum(EATCMSErr311);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   703
                break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   704
                }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   705
            case KErrGsmSMSPhoneToSimLockRequired:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   706
                {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   707
                // PH-(U) SIM PIN request by SIM card
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   708
                response.AppendNum(EATCMSErr312);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   709
                break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   710
                }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   711
            case KErrGsmSMSSimPuk1Required:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   712
                {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   713
                // PUK request by SIM card
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   714
                response.AppendNum(EATCMSErr316);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   715
                break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   716
                }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   717
            case KErrGsmSMSMemoryFailure:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   718
                {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   719
                // Memory error
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   720
                response.AppendNum(EATCMSErr320);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   721
                break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   722
                }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   723
            case KErrPathNotFound:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   724
            case KErrGsmSMSInvalidMemoryIndex:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   725
                {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   726
                // Invalid Memory index number 
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   727
                response.AppendNum(EATCMSErr321);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   728
                break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   729
                }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   730
            case KErrOverflow:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   731
            case KErrGsmSMSMemoryFull:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   732
                {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   733
                // Memory is full
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   734
                response.AppendNum(EATCMSErr322);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   735
                break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   736
                }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   737
            default:
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   738
				{
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   739
                response.AppendNum(EATCmsErrGeneral);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   740
				break;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   741
				}
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   742
            }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   743
        CreateReplyAndComplete( EReplyTypeError, response );
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   744
        response.Close();
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   745
        }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   746
    
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   747
    TRACE_FUNC_EXIT
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   748
    }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   749
26
hgs
parents:
diff changeset
   750
TInt CATMiscCmdPlugin::HandleUnsolicitedRequest(const TDesC8& aAT )
hgs
parents:
diff changeset
   751
    {
32
hgs
parents: 31
diff changeset
   752
    TRACE_FUNC_ENTRY
hgs
parents: 31
diff changeset
   753
    TRACE_FUNC_EXIT
26
hgs
parents:
diff changeset
   754
    return SendUnsolicitedResult(aAT);
hgs
parents:
diff changeset
   755
    }
hgs
parents:
diff changeset
   756
32
hgs
parents: 31
diff changeset
   757
void CATMiscCmdPlugin::HandleCMEECommand()
hgs
parents: 31
diff changeset
   758
    {
hgs
parents: 31
diff changeset
   759
    TRACE_FUNC_ENTRY
hgs
parents: 31
diff changeset
   760
    TAtCommandParser::TCommandHandlerType cmdHandlerType = iCommandParser.CommandHandlerType();
hgs
parents: 31
diff changeset
   761
    
hgs
parents: 31
diff changeset
   762
    if (cmdHandlerType == TAtCommandParser::ECmdHandlerTypeSet)
hgs
parents: 31
diff changeset
   763
        {
hgs
parents: 31
diff changeset
   764
        // +CMEE=n
hgs
parents: 31
diff changeset
   765
        TInt errLevel;
hgs
parents: 31
diff changeset
   766
        TInt ret = iCommandParser.NextIntParam(errLevel);
hgs
parents: 31
diff changeset
   767
        TPtrC8 param = iCommandParser.NextParam();
hgs
parents: 31
diff changeset
   768
        _LIT8(KCMEDbg, "CME : NextIntParam returned %d, NextParam Length is %d, errLevel %d\r\n");
hgs
parents: 31
diff changeset
   769
        Trace(KCMEDbg, ret, param.Length(), errLevel);
hgs
parents: 31
diff changeset
   770
        if (ret == KErrNone && param.Length() == 0 &&
hgs
parents: 31
diff changeset
   771
           (errLevel == 0 || errLevel == 1))
hgs
parents: 31
diff changeset
   772
            {
hgs
parents: 31
diff changeset
   773
            iErrorLevel = errLevel;
hgs
parents: 31
diff changeset
   774
            _LIT8(KCMEErrorLevel, "CME error level: %d\r\n");
hgs
parents: 31
diff changeset
   775
            Trace(KCMEErrorLevel, iErrorLevel);
hgs
parents: 31
diff changeset
   776
            }
hgs
parents: 31
diff changeset
   777
        }
hgs
parents: 31
diff changeset
   778
    TRACE_FUNC_EXIT
hgs
parents: 31
diff changeset
   779
    }
hgs
parents: 31
diff changeset
   780
45
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   781
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   782
void CATMiscCmdPlugin::HandleCMGFCommand()
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   783
    {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   784
    TRACE_FUNC_ENTRY
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   785
    
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   786
#ifdef PROTOCOL_TDSCDMA    
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   787
    TAtCommandParser::TCommandHandlerType cmdHandlerType = iCommandParser.CommandHandlerType();
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   788
    
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   789
    if (cmdHandlerType == TAtCommandParser::ECmdHandlerTypeSet)
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   790
        {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   791
        TInt msgFormat = 0;
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   792
        TInt ret = iCommandParser.NextIntParam(msgFormat);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   793
        if(ret == KErrNone && iCMGWHandler)
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   794
            {
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   795
            static_cast<CCMGWCommandHandler*> (iCMGWHandler)->SetMessageFormat(msgFormat);
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   796
            }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   797
        }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   798
#endif  
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   799
    
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   800
    TRACE_FUNC_EXIT
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   801
    }
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   802
  
b0aebde9b1fb 201027_02
hgs
parents: 32
diff changeset
   803
26
hgs
parents:
diff changeset
   804
void CATMiscCmdPlugin::ConnectToEtelL(RTelServer& aTelServer, RMobilePhone& aPhone)
hgs
parents:
diff changeset
   805
    {
hgs
parents:
diff changeset
   806
    TRACE_FUNC_ENTRY
hgs
parents:
diff changeset
   807
    User::LeaveIfError(aTelServer.Connect());
hgs
parents:
diff changeset
   808
hgs
parents:
diff changeset
   809
    // get the name of the first available phone
hgs
parents:
diff changeset
   810
    TInt phoneCount;
hgs
parents:
diff changeset
   811
    RTelServer::TPhoneInfo info;
hgs
parents:
diff changeset
   812
hgs
parents:
diff changeset
   813
    User::LeaveIfError(aTelServer.EnumeratePhones(phoneCount));  
hgs
parents:
diff changeset
   814
    if (phoneCount < 1)
hgs
parents:
diff changeset
   815
        {
32
hgs
parents: 31
diff changeset
   816
        User::Leave(KErrNotFound);
26
hgs
parents:
diff changeset
   817
        }
hgs
parents:
diff changeset
   818
    User::LeaveIfError(aTelServer.GetPhoneInfo(0, info));
hgs
parents:
diff changeset
   819
    User::LeaveIfError(aPhone.Open(aTelServer, info.iName));
hgs
parents:
diff changeset
   820
    TRACE_FUNC_EXIT
hgs
parents:
diff changeset
   821
    }
32
hgs
parents: 31
diff changeset
   822