eapol/eapol_framework/eapol_symbian/eap_server/src/EapServer.cpp
author hgs
Thu, 16 Sep 2010 13:07:04 +0300
changeset 49 43351a4f2da3
parent 34 ad1f037f1ac2
permissions -rw-r--r--
201037
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
26
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2001-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 the License "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:  scheduler of EAP-server.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
/*
49
hgs
parents: 34
diff changeset
    19
* %version: 41 %
26
hgs
parents:
diff changeset
    20
*/
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include "EapServer.h"
hgs
parents:
diff changeset
    23
#include "EapTraceSymbian.h"
hgs
parents:
diff changeset
    24
#include <ecom.h>
hgs
parents:
diff changeset
    25
#include "eap_automatic_variable.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
/*
hgs
parents:
diff changeset
    28
    class CEapServer
hgs
parents:
diff changeset
    29
*/
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
CEapServer::CEapServer()
hgs
parents:
diff changeset
    34
    : CServer2(0, EGlobalSharableSessions) // //ESharableSessions
hgs
parents:
diff changeset
    35
    {
hgs
parents:
diff changeset
    36
    EAP_TRACE_DEBUG_SYMBIAN((_L("CEapServer::CEapServer(): this=0x%08x"),
hgs
parents:
diff changeset
    37
		this));
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
	EAP_TRACE_RETURN_STRING_SYMBIAN(_L("returns: CEapServer::CEapServer()"));
hgs
parents:
diff changeset
    40
    }
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
    43
hgs
parents:
diff changeset
    44
void CEapServer::ConstructL()
hgs
parents:
diff changeset
    45
    {
hgs
parents:
diff changeset
    46
    EAP_TRACE_DEBUG_SYMBIAN((_L("CEapServer::ConstructL(): start")));
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
    iIsValid = EFalse;
hgs
parents:
diff changeset
    51
    iTools = abs_eap_am_tools_c::new_abs_eap_am_tools_c();
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
    // Check if creation went ok and the the iIsValid variable
hgs
parents:
diff changeset
    54
    if (iTools == 0
hgs
parents:
diff changeset
    55
		|| iTools->get_is_valid() == false)
hgs
parents:
diff changeset
    56
	{
hgs
parents:
diff changeset
    57
		if (iTools != 0)
hgs
parents:
diff changeset
    58
		{
hgs
parents:
diff changeset
    59
			iTools->am_cancel_all_timers();
hgs
parents:
diff changeset
    60
		}
hgs
parents:
diff changeset
    61
		abs_eap_am_tools_c::delete_abs_eap_am_tools_c(iTools);
hgs
parents:
diff changeset
    62
		User::Leave(KErrNoMemory);
hgs
parents:
diff changeset
    63
	}
hgs
parents:
diff changeset
    64
	else
hgs
parents:
diff changeset
    65
	{
hgs
parents:
diff changeset
    66
		iIsValid = iTools->get_is_valid();
hgs
parents:
diff changeset
    67
	}
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::ConstructL()");
hgs
parents:
diff changeset
    70
hgs
parents:
diff changeset
    71
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
    72
49
hgs
parents: 34
diff changeset
    73
	eap_status_e status(eap_status_ok);
hgs
parents: 34
diff changeset
    74
26
hgs
parents:
diff changeset
    75
	{
hgs
parents:
diff changeset
    76
		const u8_t DEFAULT_PREFIX[] = "EAP-SERVER";
hgs
parents:
diff changeset
    77
		eap_variable_data_c tmp_prefix(iTools);
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
		if (tmp_prefix.get_is_valid() == false)
hgs
parents:
diff changeset
    80
		{
49
hgs
parents: 34
diff changeset
    81
			status = eap_status_allocation_error;
hgs
parents: 34
diff changeset
    82
			(void) EAP_STATUS_RETURN(iTools, status);
26
hgs
parents:
diff changeset
    83
		}
hgs
parents:
diff changeset
    84
49
hgs
parents: 34
diff changeset
    85
		if (status == eap_status_ok)
26
hgs
parents:
diff changeset
    86
		{
49
hgs
parents: 34
diff changeset
    87
			status = tmp_prefix.set_copy_of_buffer(DEFAULT_PREFIX, sizeof(DEFAULT_PREFIX)-1ul);;
hgs
parents: 34
diff changeset
    88
			if (status != eap_status_ok)
hgs
parents: 34
diff changeset
    89
			{
hgs
parents: 34
diff changeset
    90
				(void) EAP_STATUS_RETURN(iTools, status);
hgs
parents: 34
diff changeset
    91
			}
26
hgs
parents:
diff changeset
    92
		}
hgs
parents:
diff changeset
    93
49
hgs
parents: 34
diff changeset
    94
		if (status == eap_status_ok)
26
hgs
parents:
diff changeset
    95
		{
49
hgs
parents: 34
diff changeset
    96
			status = tmp_prefix.add_end_null();
hgs
parents: 34
diff changeset
    97
			if (status != eap_status_ok)
hgs
parents: 34
diff changeset
    98
			{
hgs
parents: 34
diff changeset
    99
				(void) EAP_STATUS_RETURN(iTools, status);
hgs
parents: 34
diff changeset
   100
			}
26
hgs
parents:
diff changeset
   101
		}
hgs
parents:
diff changeset
   102
49
hgs
parents: 34
diff changeset
   103
		if (status == eap_status_ok)
26
hgs
parents:
diff changeset
   104
		{
49
hgs
parents: 34
diff changeset
   105
			status = iTools->set_trace_prefix(&tmp_prefix);
hgs
parents: 34
diff changeset
   106
			if (status != eap_status_ok)
hgs
parents: 34
diff changeset
   107
			{
hgs
parents: 34
diff changeset
   108
				(void) EAP_STATUS_RETURN(iTools, status);
hgs
parents: 34
diff changeset
   109
			}
26
hgs
parents:
diff changeset
   110
		}
hgs
parents:
diff changeset
   111
	}
hgs
parents:
diff changeset
   112
49
hgs
parents: 34
diff changeset
   113
	if (status != eap_status_ok)
hgs
parents: 34
diff changeset
   114
	{
hgs
parents: 34
diff changeset
   115
		iTools->am_cancel_all_timers();
hgs
parents: 34
diff changeset
   116
		abs_eap_am_tools_c::delete_abs_eap_am_tools_c(iTools);
hgs
parents: 34
diff changeset
   117
		User::Leave(KErrGeneral);
hgs
parents: 34
diff changeset
   118
	}
hgs
parents: 34
diff changeset
   119
26
hgs
parents:
diff changeset
   120
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
	{
hgs
parents:
diff changeset
   123
		TInt error;
hgs
parents:
diff changeset
   124
		RFs aFileServerSession;
hgs
parents:
diff changeset
   125
hgs
parents:
diff changeset
   126
		// Open file server session
hgs
parents:
diff changeset
   127
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   128
			iTools, 
hgs
parents:
diff changeset
   129
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   130
			(EAPL("CEapServer::ConstructL(): - calls aFileServerSession.Connect()\n")));
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
		error = aFileServerSession.Connect();
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   135
			iTools, 
hgs
parents:
diff changeset
   136
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   137
			(EAPL("CEapServer::ConstructL(): - aFileServerSession.Connect(), error=%d\n"),
hgs
parents:
diff changeset
   138
			error));
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
		User::LeaveIfError(error);
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
		// Create the private path - it is not automatically created by Symbian OS.
hgs
parents:
diff changeset
   143
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   144
			iTools, 
hgs
parents:
diff changeset
   145
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   146
			(EAPL("CEapServer::ConstructL(): - calls aFileServerSession.CreatePrivatePath(%d)\n"),
hgs
parents:
diff changeset
   147
			RFs::GetSystemDrive()));
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
		error = aFileServerSession.CreatePrivatePath(RFs::GetSystemDrive());
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   152
			iTools, 
hgs
parents:
diff changeset
   153
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   154
			(EAPL("CEapServer::ConstructL(): - aFileServerSession.CreatePrivatePath(%d), error=%d\n"),
hgs
parents:
diff changeset
   155
			RFs::GetSystemDrive(),
hgs
parents:
diff changeset
   156
			error));
hgs
parents:
diff changeset
   157
hgs
parents:
diff changeset
   158
		User::LeaveIfError(error);
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
		// Set the session path to the private directory
hgs
parents:
diff changeset
   161
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   162
			iTools, 
hgs
parents:
diff changeset
   163
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   164
			(EAPL("CEapServer::ConstructL(): - calls aFileServerSession.SetSessionToPrivate(%d)\n"),
hgs
parents:
diff changeset
   165
			RFs::GetSystemDrive()));
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
		error = aFileServerSession.SetSessionToPrivate(RFs::GetSystemDrive());
hgs
parents:
diff changeset
   168
hgs
parents:
diff changeset
   169
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   170
			iTools, 
hgs
parents:
diff changeset
   171
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   172
			(EAPL("CEapServer::ConstructL(): - aFileServerSession.SetSessionToPrivate(%d), error=%d\n"),
hgs
parents:
diff changeset
   173
			RFs::GetSystemDrive(),
hgs
parents:
diff changeset
   174
			error));
hgs
parents:
diff changeset
   175
hgs
parents:
diff changeset
   176
		User::LeaveIfError(error);
hgs
parents:
diff changeset
   177
hgs
parents:
diff changeset
   178
		// Close the session with the file server.
hgs
parents:
diff changeset
   179
		aFileServerSession.Close();
hgs
parents:
diff changeset
   180
	}
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
    {
hgs
parents:
diff changeset
   185
		// construct shutdown timer
hgs
parents:
diff changeset
   186
		iShutdown = new(ELeave) CEapDelayedShutdown(iTools, this);
hgs
parents:
diff changeset
   187
		iShutdown->ConstructL();
hgs
parents:
diff changeset
   188
		// identify ourselves and open for service
hgs
parents:
diff changeset
   189
		TBuf<KMaxServerExe> ServerName;
hgs
parents:
diff changeset
   190
		TBuf<KMaxServerExe> ServerExe;
hgs
parents:
diff changeset
   191
    
hgs
parents:
diff changeset
   192
		GetServerNameAndExe(&ServerName, &ServerExe);
hgs
parents:
diff changeset
   193
hgs
parents:
diff changeset
   194
		StartL(ServerName);
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
		// Initiates shut down timer. Timer will close server unless we get client connections.
hgs
parents:
diff changeset
   197
		iShutdown->Start();
hgs
parents:
diff changeset
   198
	}
hgs
parents:
diff changeset
   199
hgs
parents:
diff changeset
   200
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   201
hgs
parents:
diff changeset
   202
    {
hgs
parents:
diff changeset
   203
		// construct backup and restore observer
hgs
parents:
diff changeset
   204
		iBackupRestore = new(ELeave) CEapserverBackup(this);
hgs
parents:
diff changeset
   205
		iBackupRestore->ConstructL();
hgs
parents:
diff changeset
   206
	}
hgs
parents:
diff changeset
   207
hgs
parents:
diff changeset
   208
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
   }
hgs
parents:
diff changeset
   211
hgs
parents:
diff changeset
   212
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   213
hgs
parents:
diff changeset
   214
CEapServer* CEapServer::NewL()
hgs
parents:
diff changeset
   215
    {
hgs
parents:
diff changeset
   216
    EAP_TRACE_DEBUG_SYMBIAN((_L("CEapServer::NewL(): starts")));
hgs
parents:
diff changeset
   217
hgs
parents:
diff changeset
   218
	EAP_TRACE_RETURN_STRING_SYMBIAN(_L("returns: CEapServer::NewL()"));
hgs
parents:
diff changeset
   219
hgs
parents:
diff changeset
   220
    CEapServer* self = new(ELeave)CEapServer();
hgs
parents:
diff changeset
   221
    CleanupStack::PushL(self);
hgs
parents:
diff changeset
   222
hgs
parents:
diff changeset
   223
    self->ConstructL();
hgs
parents:
diff changeset
   224
hgs
parents:
diff changeset
   225
    CleanupStack::Pop(self);
hgs
parents:
diff changeset
   226
hgs
parents:
diff changeset
   227
    return self;
hgs
parents:
diff changeset
   228
    }
hgs
parents:
diff changeset
   229
hgs
parents:
diff changeset
   230
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   231
hgs
parents:
diff changeset
   232
CEapServer::~CEapServer()
hgs
parents:
diff changeset
   233
	{
hgs
parents:
diff changeset
   234
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   235
		iTools, 
hgs
parents:
diff changeset
   236
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   237
		(EAPL("CEapServer::~CEapServer(): this=0x%08x\n"),
hgs
parents:
diff changeset
   238
		this));
hgs
parents:
diff changeset
   239
hgs
parents:
diff changeset
   240
	// Do not use iTools, because it will be destroyed before return.
hgs
parents:
diff changeset
   241
	EAP_TRACE_RETURN_STRING_SYMBIAN(_L("returns: CEapServer::~CEapServer()"));
hgs
parents:
diff changeset
   242
49
hgs
parents: 34
diff changeset
   243
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents: 34
diff changeset
   244
hgs
parents: 34
diff changeset
   245
	TInt aCount = iReadyHandlers.Count();
hgs
parents: 34
diff changeset
   246
hgs
parents: 34
diff changeset
   247
	while (aCount > 0)
hgs
parents: 34
diff changeset
   248
	{
hgs
parents: 34
diff changeset
   249
		EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   250
			iTools,
hgs
parents: 34
diff changeset
   251
			TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   252
			(EAPL("CEapServer::~CEapServer(): Removes iReadyHandlers[0]=0x%08x\n"),
hgs
parents: 34
diff changeset
   253
			iReadyHandlers[0]));
hgs
parents: 34
diff changeset
   254
hgs
parents: 34
diff changeset
   255
		iReadyHandlers.Remove(0);
hgs
parents: 34
diff changeset
   256
hgs
parents: 34
diff changeset
   257
		aCount = iReadyHandlers.Count();
hgs
parents: 34
diff changeset
   258
	}
hgs
parents: 34
diff changeset
   259
hgs
parents: 34
diff changeset
   260
	iReadyHandlers.Close();
hgs
parents: 34
diff changeset
   261
hgs
parents: 34
diff changeset
   262
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents: 34
diff changeset
   263
26
hgs
parents:
diff changeset
   264
	delete iShutdown;
hgs
parents:
diff changeset
   265
	delete iBackupRestore;
hgs
parents:
diff changeset
   266
	
hgs
parents:
diff changeset
   267
	if (iTools) 
hgs
parents:
diff changeset
   268
	{
hgs
parents:
diff changeset
   269
		iTools->am_cancel_all_timers();
hgs
parents:
diff changeset
   270
		abs_eap_am_tools_c::delete_abs_eap_am_tools_c(iTools);
hgs
parents:
diff changeset
   271
	}
hgs
parents:
diff changeset
   272
34
hgs
parents: 27
diff changeset
   273
    EAP_TRACE_DEBUG_SYMBIAN((_L("REComSession::FinalClose(): start")));
hgs
parents: 27
diff changeset
   274
26
hgs
parents:
diff changeset
   275
	REComSession::FinalClose();
34
hgs
parents: 27
diff changeset
   276
hgs
parents: 27
diff changeset
   277
    EAP_TRACE_DEBUG_SYMBIAN((_L("REComSession::FinalClose(): ready")));
hgs
parents: 27
diff changeset
   278
26
hgs
parents:
diff changeset
   279
	}
hgs
parents:
diff changeset
   280
hgs
parents:
diff changeset
   281
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   282
hgs
parents:
diff changeset
   283
// from CServer
hgs
parents:
diff changeset
   284
34
hgs
parents: 27
diff changeset
   285
CSession2* CEapServer::NewSessionL(const TVersion& /* aVersion */, const RMessage2& /* aMessage */) const
26
hgs
parents:
diff changeset
   286
    {
hgs
parents:
diff changeset
   287
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   288
		iTools, 
hgs
parents:
diff changeset
   289
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   290
		(EAPL("CEapServer::NewSessionL(): starts\n")));
hgs
parents:
diff changeset
   291
hgs
parents:
diff changeset
   292
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::NewSessionL()");
hgs
parents:
diff changeset
   293
hgs
parents:
diff changeset
   294
    CEapSession* session = new(ELeave) CEapSession();
hgs
parents:
diff changeset
   295
    CleanupStack::PushL(session);
hgs
parents:
diff changeset
   296
hgs
parents:
diff changeset
   297
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   298
		iTools, 
hgs
parents:
diff changeset
   299
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   300
		(EAPL("CEapServer::NewSessionL(): session=0x%08x\n"),
hgs
parents:
diff changeset
   301
		session));
hgs
parents:
diff changeset
   302
hgs
parents:
diff changeset
   303
    EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   304
		iTools, 
hgs
parents:
diff changeset
   305
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   306
		(EAPL("CEapServer::NewSessionL(): session->ConstructL() starts")));
hgs
parents:
diff changeset
   307
hgs
parents:
diff changeset
   308
    session->ConstructL(*const_cast<CEapServer*>(this), iTools);
hgs
parents:
diff changeset
   309
hgs
parents:
diff changeset
   310
    EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   311
		iTools, 
hgs
parents:
diff changeset
   312
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   313
		(EAPL("CEapServer::NewSessionL(): session->ConstructL() ends")));
hgs
parents:
diff changeset
   314
hgs
parents:
diff changeset
   315
    CleanupStack::Pop(session);
hgs
parents:
diff changeset
   316
hgs
parents:
diff changeset
   317
    const_cast<CEapServer*>(this)->IncrementSessions();
hgs
parents:
diff changeset
   318
hgs
parents:
diff changeset
   319
	return session;
hgs
parents:
diff changeset
   320
    }
hgs
parents:
diff changeset
   321
hgs
parents:
diff changeset
   322
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   323
hgs
parents:
diff changeset
   324
TInt CEapServer::RunError(TInt aErr)
hgs
parents:
diff changeset
   325
    /**
hgs
parents:
diff changeset
   326
       Handle leaves from ServiceL.
hgs
parents:
diff changeset
   327
hgs
parents:
diff changeset
   328
       Any leave from a ServiceL() will land up here.
hgs
parents:
diff changeset
   329
    */
hgs
parents:
diff changeset
   330
    {
hgs
parents:
diff changeset
   331
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   332
		iTools, 
hgs
parents:
diff changeset
   333
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   334
		(EAPL("CEapServer::RunError(), aErr=%d\n"),
hgs
parents:
diff changeset
   335
		aErr));
hgs
parents:
diff changeset
   336
hgs
parents:
diff changeset
   337
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::RunError()");
hgs
parents:
diff changeset
   338
hgs
parents:
diff changeset
   339
    // if it's a bad descriptor, panic the client
hgs
parents:
diff changeset
   340
    if (aErr==KErrBadDescriptor)    // client had a bad descriptor
hgs
parents:
diff changeset
   341
        {
hgs
parents:
diff changeset
   342
        PanicClient(EBadDescriptor);
hgs
parents:
diff changeset
   343
        }
hgs
parents:
diff changeset
   344
hgs
parents:
diff changeset
   345
    // anyway, complete the outstanding message
hgs
parents:
diff changeset
   346
    Message().Complete(aErr);
hgs
parents:
diff changeset
   347
    ReStart(); // really means just continue reading client requests
hgs
parents:
diff changeset
   348
    return KErrNone;
hgs
parents:
diff changeset
   349
    }
hgs
parents:
diff changeset
   350
hgs
parents:
diff changeset
   351
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   352
hgs
parents:
diff changeset
   353
/**
hgs
parents:
diff changeset
   354
   session count support
hgs
parents:
diff changeset
   355
*/
hgs
parents:
diff changeset
   356
void CEapServer::IncrementSessions()
hgs
parents:
diff changeset
   357
{   
hgs
parents:
diff changeset
   358
	iSessionCount++;
hgs
parents:
diff changeset
   359
hgs
parents:
diff changeset
   360
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   361
		iTools, 
hgs
parents:
diff changeset
   362
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   363
		(EAPL("CEapServer::IncrementSessions(): iSessionCount=%d\n"),
hgs
parents:
diff changeset
   364
		iSessionCount));
hgs
parents:
diff changeset
   365
hgs
parents:
diff changeset
   366
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::IncrementSessions()");
hgs
parents:
diff changeset
   367
hgs
parents:
diff changeset
   368
	iShutdown->Cancel();
hgs
parents:
diff changeset
   369
}
hgs
parents:
diff changeset
   370
hgs
parents:
diff changeset
   371
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   372
hgs
parents:
diff changeset
   373
void CEapServer::DecrementSessions()
hgs
parents:
diff changeset
   374
{
hgs
parents:
diff changeset
   375
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   376
		iTools, 
hgs
parents:
diff changeset
   377
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   378
		(EAPL("CEapServer::DecrementSessions(): iSessionCount=%d\n"),
hgs
parents:
diff changeset
   379
		iSessionCount));
hgs
parents:
diff changeset
   380
hgs
parents:
diff changeset
   381
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::DecrementSessions()");
hgs
parents:
diff changeset
   382
hgs
parents:
diff changeset
   383
	iSessionCount--;
hgs
parents:
diff changeset
   384
	if (iSessionCount>0)
hgs
parents:
diff changeset
   385
		return;
hgs
parents:
diff changeset
   386
hgs
parents:
diff changeset
   387
	iShutdown->Start();
hgs
parents:
diff changeset
   388
}
hgs
parents:
diff changeset
   389
hgs
parents:
diff changeset
   390
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   391
hgs
parents:
diff changeset
   392
void CEapServer::PanicClient(TInt aPanic) const
hgs
parents:
diff changeset
   393
{
34
hgs
parents: 27
diff changeset
   394
	EAP_UNREFERENCED_PARAMETER(aPanic);
26
hgs
parents:
diff changeset
   395
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   396
		iTools, 
hgs
parents:
diff changeset
   397
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   398
		(EAPL("CEapServer::PanicClient(): aPanic=%d\n"),
hgs
parents:
diff changeset
   399
		aPanic));
hgs
parents:
diff changeset
   400
hgs
parents:
diff changeset
   401
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::PanicClient()");
hgs
parents:
diff changeset
   402
hgs
parents:
diff changeset
   403
	// let's have a look before we panic the client
hgs
parents:
diff changeset
   404
	__DEBUGGER()
hgs
parents:
diff changeset
   405
	// ok, go for it
hgs
parents:
diff changeset
   406
hgs
parents:
diff changeset
   407
	const TBufC<KMaxCategoryLength> aCategory; 
hgs
parents:
diff changeset
   408
	Message().Panic(aCategory, EBadRequest);
hgs
parents:
diff changeset
   409
}
hgs
parents:
diff changeset
   410
hgs
parents:
diff changeset
   411
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   412
hgs
parents:
diff changeset
   413
void CEapServer::StopL()
hgs
parents:
diff changeset
   414
{
hgs
parents:
diff changeset
   415
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   416
		iTools, 
hgs
parents:
diff changeset
   417
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   418
		(EAPL("CEapServer::StopL()\n")));
hgs
parents:
diff changeset
   419
hgs
parents:
diff changeset
   420
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::StopL()");
hgs
parents:
diff changeset
   421
hgs
parents:
diff changeset
   422
	for (iSessionIter.SetToFirst(); iSessionIter; iSessionIter++)
hgs
parents:
diff changeset
   423
	{
hgs
parents:
diff changeset
   424
		CSession2 * aSession = iSessionIter;
hgs
parents:
diff changeset
   425
hgs
parents:
diff changeset
   426
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   427
			iTools, 
hgs
parents:
diff changeset
   428
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   429
			(EAPL("CEapServer::StopL(): aSession=0x%08x calls CancelReceive()\n"),
hgs
parents:
diff changeset
   430
			aSession));
hgs
parents:
diff changeset
   431
27
9660a5eb236f 201021_1
hgs
parents: 26
diff changeset
   432
		if (static_cast<CEapSession *>(aSession) != NULL)
26
hgs
parents:
diff changeset
   433
			{
27
9660a5eb236f 201021_1
hgs
parents: 26
diff changeset
   434
			static_cast<CEapSession *>(aSession)->CancelReceive();
26
hgs
parents:
diff changeset
   435
			}
hgs
parents:
diff changeset
   436
	}
hgs
parents:
diff changeset
   437
}
hgs
parents:
diff changeset
   438
hgs
parents:
diff changeset
   439
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   440
hgs
parents:
diff changeset
   441
void CEapServer::BackupOrRestoreCompleteL()
hgs
parents:
diff changeset
   442
{
hgs
parents:
diff changeset
   443
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   444
		iTools, 
hgs
parents:
diff changeset
   445
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   446
		(EAPL("ERROR: CEapServer::BackupOrRestoreCompleteL(): Do something\n")));
hgs
parents:
diff changeset
   447
hgs
parents:
diff changeset
   448
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::BackupOrRestoreCompleteL()");
hgs
parents:
diff changeset
   449
}
hgs
parents:
diff changeset
   450
hgs
parents:
diff changeset
   451
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   452
hgs
parents:
diff changeset
   453
void CEapServer::BackupOrRestoreStartingL()
hgs
parents:
diff changeset
   454
{
hgs
parents:
diff changeset
   455
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   456
		iTools, 
hgs
parents:
diff changeset
   457
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   458
		(EAPL("WARNING: CEapServer::BackupOrRestoreStartingL(): Terminates EAP-SERVER. All sessions are also closed. All files are unlocked for backup or restore.\n")));
hgs
parents:
diff changeset
   459
hgs
parents:
diff changeset
   460
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::BackupOrRestoreStartingL()");
hgs
parents:
diff changeset
   461
hgs
parents:
diff changeset
   462
    StopL();
hgs
parents:
diff changeset
   463
}
hgs
parents:
diff changeset
   464
49
hgs
parents: 34
diff changeset
   465
// -----------------------------------------------------------------------------------------
hgs
parents: 34
diff changeset
   466
hgs
parents: 34
diff changeset
   467
TInt CEapServer::AddReadyHandler(CEapServerProcessHandler * const handler)
hgs
parents: 34
diff changeset
   468
{
hgs
parents: 34
diff changeset
   469
	EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   470
		iTools,
hgs
parents: 34
diff changeset
   471
		TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   472
		(EAPL("CEapServer::AddReadyHandler(): this=0x%08x: handler=0x%08x\n"),
hgs
parents: 34
diff changeset
   473
		this,
hgs
parents: 34
diff changeset
   474
		handler));
hgs
parents: 34
diff changeset
   475
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::AddReadyHandler()");
hgs
parents: 34
diff changeset
   476
hgs
parents: 34
diff changeset
   477
	TInt aCount = iReadyHandlers.Count();
hgs
parents: 34
diff changeset
   478
hgs
parents: 34
diff changeset
   479
	if (aCount > 0)
hgs
parents: 34
diff changeset
   480
	{
hgs
parents: 34
diff changeset
   481
		EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   482
			iTools,
hgs
parents: 34
diff changeset
   483
			TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   484
			(EAPL("CEapServer::AddReadyHandler(): this=0x%08x: iReadyHandlers[0]=0x%08x\n"),
hgs
parents: 34
diff changeset
   485
			this,
hgs
parents: 34
diff changeset
   486
			iReadyHandlers[0]));
hgs
parents: 34
diff changeset
   487
	}
hgs
parents: 34
diff changeset
   488
hgs
parents: 34
diff changeset
   489
	TInt error = iReadyHandlers.Append(handler);
hgs
parents: 34
diff changeset
   490
	if (error != KErrNone)
hgs
parents: 34
diff changeset
   491
	{
hgs
parents: 34
diff changeset
   492
		EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   493
			iTools,
hgs
parents: 34
diff changeset
   494
			TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   495
			(EAPL("ERROR: CEapServer::AddReadyHandler(): Cannot append handler, error = %d\n"),
hgs
parents: 34
diff changeset
   496
			error));
hgs
parents: 34
diff changeset
   497
	}
hgs
parents: 34
diff changeset
   498
hgs
parents: 34
diff changeset
   499
	if (aCount == 0
hgs
parents: 34
diff changeset
   500
		&& error == KErrNone)
hgs
parents: 34
diff changeset
   501
	{
hgs
parents: 34
diff changeset
   502
			EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   503
				iTools,
hgs
parents: 34
diff changeset
   504
				TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   505
				(EAPL("CEapServer::AddReadyHandler(): this=0x%08x: Activates handler=0x%08x\n"),
hgs
parents: 34
diff changeset
   506
				this,
hgs
parents: 34
diff changeset
   507
				handler));
hgs
parents: 34
diff changeset
   508
hgs
parents: 34
diff changeset
   509
		// Acticate the first handler.
hgs
parents: 34
diff changeset
   510
		handler->Activate(EapServerProcessHandlerState_All);
hgs
parents: 34
diff changeset
   511
	}
hgs
parents: 34
diff changeset
   512
hgs
parents: 34
diff changeset
   513
	return error;
hgs
parents: 34
diff changeset
   514
}
hgs
parents: 34
diff changeset
   515
hgs
parents: 34
diff changeset
   516
// -----------------------------------------------------------------------------------------
hgs
parents: 34
diff changeset
   517
hgs
parents: 34
diff changeset
   518
TInt CEapServer::CompleteReadyHandler(CEapServerProcessHandler * const handler)
hgs
parents: 34
diff changeset
   519
{
hgs
parents: 34
diff changeset
   520
	EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   521
		iTools,
hgs
parents: 34
diff changeset
   522
		TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   523
		(EAPL("CEapServer::CompleteReadyHandler(): this=0x%08x: handler=0x%08x\n"),
hgs
parents: 34
diff changeset
   524
		this,
hgs
parents: 34
diff changeset
   525
		handler));
hgs
parents: 34
diff changeset
   526
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::CompleteReadyHandler()");
hgs
parents: 34
diff changeset
   527
hgs
parents: 34
diff changeset
   528
	TInt aCount = iReadyHandlers.Count();
hgs
parents: 34
diff changeset
   529
hgs
parents: 34
diff changeset
   530
	TInt error(KErrNone);
hgs
parents: 34
diff changeset
   531
hgs
parents: 34
diff changeset
   532
	if (aCount == 0)
hgs
parents: 34
diff changeset
   533
	{
hgs
parents: 34
diff changeset
   534
		EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   535
			iTools,
hgs
parents: 34
diff changeset
   536
			TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   537
			(EAPL("CEapServer::CompleteReadyHandler(): this=0x%08x, no handlers ready.\n"),
hgs
parents: 34
diff changeset
   538
			this,
hgs
parents: 34
diff changeset
   539
			handler));
hgs
parents: 34
diff changeset
   540
	}
hgs
parents: 34
diff changeset
   541
	else if (iReadyHandlers[0] != handler)
hgs
parents: 34
diff changeset
   542
	{
hgs
parents: 34
diff changeset
   543
		EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   544
			iTools,
hgs
parents: 34
diff changeset
   545
			TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   546
			(EAPL("ERROR: CEapServer::CompleteReadyHandler(): this=0x%08x, handler=0x%08x is not the first one 0x%08x\n"),
hgs
parents: 34
diff changeset
   547
			this,
hgs
parents: 34
diff changeset
   548
			handler,
hgs
parents: 34
diff changeset
   549
			iReadyHandlers[0]));
hgs
parents: 34
diff changeset
   550
hgs
parents: 34
diff changeset
   551
		error = KErrGeneral;
hgs
parents: 34
diff changeset
   552
	}
hgs
parents: 34
diff changeset
   553
	else
hgs
parents: 34
diff changeset
   554
	{
hgs
parents: 34
diff changeset
   555
		iReadyHandlers.Remove(0);
hgs
parents: 34
diff changeset
   556
hgs
parents: 34
diff changeset
   557
		aCount = iReadyHandlers.Count();
hgs
parents: 34
diff changeset
   558
hgs
parents: 34
diff changeset
   559
		if (aCount > 0)
hgs
parents: 34
diff changeset
   560
		{
hgs
parents: 34
diff changeset
   561
			EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   562
				iTools,
hgs
parents: 34
diff changeset
   563
				TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   564
				(EAPL("CEapServer::CompleteReadyHandler(): this=0x%08x, Activates handler=0x%08x\n"),
hgs
parents: 34
diff changeset
   565
				this,
hgs
parents: 34
diff changeset
   566
				iReadyHandlers[0]));
hgs
parents: 34
diff changeset
   567
hgs
parents: 34
diff changeset
   568
			// Activate the next handler.
hgs
parents: 34
diff changeset
   569
			iReadyHandlers[0]->Activate(EapServerProcessHandlerState_All);
hgs
parents: 34
diff changeset
   570
		}
hgs
parents: 34
diff changeset
   571
	}
hgs
parents: 34
diff changeset
   572
hgs
parents: 34
diff changeset
   573
	return error;
hgs
parents: 34
diff changeset
   574
}
hgs
parents: 34
diff changeset
   575
hgs
parents: 34
diff changeset
   576
// -----------------------------------------------------------------------------------------
hgs
parents: 34
diff changeset
   577
hgs
parents: 34
diff changeset
   578
TInt CEapServer::CancelReadyHandler(CEapServerProcessHandler * const handler)
hgs
parents: 34
diff changeset
   579
{
hgs
parents: 34
diff changeset
   580
	EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   581
		iTools,
hgs
parents: 34
diff changeset
   582
		TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   583
		(EAPL("CEapServer::CancelReadyHandler(): this=0x%08x: handler=0x%08x\n"),
hgs
parents: 34
diff changeset
   584
		this,
hgs
parents: 34
diff changeset
   585
		handler));
hgs
parents: 34
diff changeset
   586
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::CancelReadyHandler()");
hgs
parents: 34
diff changeset
   587
hgs
parents: 34
diff changeset
   588
	TInt index(0);
hgs
parents: 34
diff changeset
   589
	TInt aCount = iReadyHandlers.Count();
hgs
parents: 34
diff changeset
   590
hgs
parents: 34
diff changeset
   591
	while (index < aCount)
hgs
parents: 34
diff changeset
   592
	{
hgs
parents: 34
diff changeset
   593
		if (iReadyHandlers[index] != handler)
hgs
parents: 34
diff changeset
   594
		{
hgs
parents: 34
diff changeset
   595
			EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   596
				iTools,
hgs
parents: 34
diff changeset
   597
				TRACE_FLAGS_DEFAULT,
hgs
parents: 34
diff changeset
   598
				(EAPL("CEapServer::CancelReadyHandler(): Removes iReadyHandlers[%d]=0x%08x\n"),
hgs
parents: 34
diff changeset
   599
				index,
hgs
parents: 34
diff changeset
   600
				iReadyHandlers[index]));
hgs
parents: 34
diff changeset
   601
hgs
parents: 34
diff changeset
   602
			iReadyHandlers.Remove(index);
hgs
parents: 34
diff changeset
   603
hgs
parents: 34
diff changeset
   604
			aCount = iReadyHandlers.Count();
hgs
parents: 34
diff changeset
   605
		}
hgs
parents: 34
diff changeset
   606
		else
hgs
parents: 34
diff changeset
   607
		{
hgs
parents: 34
diff changeset
   608
			++index;
hgs
parents: 34
diff changeset
   609
		}
hgs
parents: 34
diff changeset
   610
	} // while()
hgs
parents: 34
diff changeset
   611
hgs
parents: 34
diff changeset
   612
	return KErrNone;
hgs
parents: 34
diff changeset
   613
}
hgs
parents: 34
diff changeset
   614
hgs
parents: 34
diff changeset
   615
//----------------------------------------------------------------------------
hgs
parents: 34
diff changeset
   616
//----------------------------------------------------------------------------
26
hgs
parents:
diff changeset
   617
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   618
hgs
parents:
diff changeset
   619
/*
hgs
parents:
diff changeset
   620
    class CEapDelayedShutdown
hgs
parents:
diff changeset
   621
*/
hgs
parents:
diff changeset
   622
hgs
parents:
diff changeset
   623
CEapDelayedShutdown::CEapDelayedShutdown(abs_eap_am_tools_c * const tools, CEapServer * const aServer)
hgs
parents:
diff changeset
   624
    : CActive(0)
hgs
parents:
diff changeset
   625
	, iTools(tools)
hgs
parents:
diff changeset
   626
	, iServer(aServer)
hgs
parents:
diff changeset
   627
    {
hgs
parents:
diff changeset
   628
    }
hgs
parents:
diff changeset
   629
hgs
parents:
diff changeset
   630
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   631
hgs
parents:
diff changeset
   632
void CEapDelayedShutdown::ConstructL()
hgs
parents:
diff changeset
   633
    {
hgs
parents:
diff changeset
   634
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   635
		iTools, 
hgs
parents:
diff changeset
   636
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   637
		(EAPL("CEapDelayedShutdown::ConstructL()\n")));
hgs
parents:
diff changeset
   638
hgs
parents:
diff changeset
   639
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::ConstructL()");
hgs
parents:
diff changeset
   640
hgs
parents:
diff changeset
   641
    CActiveScheduler::Add(this);
hgs
parents:
diff changeset
   642
    User::LeaveIfError(iTimer.CreateLocal());
hgs
parents:
diff changeset
   643
    }
hgs
parents:
diff changeset
   644
hgs
parents:
diff changeset
   645
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   646
hgs
parents:
diff changeset
   647
CEapDelayedShutdown::~CEapDelayedShutdown()
hgs
parents:
diff changeset
   648
    {
hgs
parents:
diff changeset
   649
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   650
		iTools, 
hgs
parents:
diff changeset
   651
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   652
		(EAPL("CEapDelayedShutdown::~CEapDelayedShutdown()\n")));
hgs
parents:
diff changeset
   653
hgs
parents:
diff changeset
   654
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::~CEapDelayedShutdown()");
hgs
parents:
diff changeset
   655
hgs
parents:
diff changeset
   656
    Cancel();
hgs
parents:
diff changeset
   657
    iTimer.Close();
hgs
parents:
diff changeset
   658
    }
hgs
parents:
diff changeset
   659
hgs
parents:
diff changeset
   660
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   661
hgs
parents:
diff changeset
   662
void CEapDelayedShutdown::Start()
hgs
parents:
diff changeset
   663
    {
hgs
parents:
diff changeset
   664
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   665
		iTools, 
hgs
parents:
diff changeset
   666
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   667
		(EAPL("CEapDelayedShutdown::Start()\n")));
hgs
parents:
diff changeset
   668
hgs
parents:
diff changeset
   669
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::Start()");
hgs
parents:
diff changeset
   670
hgs
parents:
diff changeset
   671
    iTimer.After(iStatus, KEapShutdownInterval);
hgs
parents:
diff changeset
   672
    SetActive();
hgs
parents:
diff changeset
   673
    }
hgs
parents:
diff changeset
   674
hgs
parents:
diff changeset
   675
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   676
hgs
parents:
diff changeset
   677
void CEapDelayedShutdown::DoCancel()
hgs
parents:
diff changeset
   678
{
hgs
parents:
diff changeset
   679
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   680
		iTools, 
hgs
parents:
diff changeset
   681
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   682
		(EAPL("CEapDelayedShutdown::DoCancel()\n")));
hgs
parents:
diff changeset
   683
hgs
parents:
diff changeset
   684
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::DoCancel()");
hgs
parents:
diff changeset
   685
hgs
parents:
diff changeset
   686
	iTimer.Cancel();
hgs
parents:
diff changeset
   687
}
hgs
parents:
diff changeset
   688
hgs
parents:
diff changeset
   689
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   690
hgs
parents:
diff changeset
   691
TInt CEapDelayedShutdown::RunError(TInt aError)
hgs
parents:
diff changeset
   692
{
hgs
parents:
diff changeset
   693
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   694
		iTools,
hgs
parents:
diff changeset
   695
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   696
		(EAPL("CEapDelayedShutdown::RunError(): aError=%d, this=0x%08x\n"),
hgs
parents:
diff changeset
   697
		aError,
hgs
parents:
diff changeset
   698
		this));
hgs
parents:
diff changeset
   699
hgs
parents:
diff changeset
   700
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::RunError()");
hgs
parents:
diff changeset
   701
hgs
parents:
diff changeset
   702
	iTimer.Cancel();
hgs
parents:
diff changeset
   703
hgs
parents:
diff changeset
   704
	return aError;
hgs
parents:
diff changeset
   705
}
hgs
parents:
diff changeset
   706
hgs
parents:
diff changeset
   707
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   708
hgs
parents:
diff changeset
   709
void CEapDelayedShutdown::RunL()
hgs
parents:
diff changeset
   710
{
hgs
parents:
diff changeset
   711
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   712
		iTools, 
hgs
parents:
diff changeset
   713
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   714
		(EAPL("CEapDelayedShutdown::RunL(), calls CActiveScheduler::Stop()\n")));
hgs
parents:
diff changeset
   715
hgs
parents:
diff changeset
   716
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::RunL()");
hgs
parents:
diff changeset
   717
hgs
parents:
diff changeset
   718
	CActiveScheduler::Stop();
hgs
parents:
diff changeset
   719
}
hgs
parents:
diff changeset
   720
hgs
parents:
diff changeset
   721
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   722
hgs
parents:
diff changeset
   723
// end