eapol/eapol_framework/eapol_symbian/eap_server/src/EapServer.cpp
author hgs
Thu, 27 May 2010 10:23:43 +0300
changeset 27 9660a5eb236f
parent 26 9abfd4f00d37
child 34 ad1f037f1ac2
permissions -rw-r--r--
201021_1
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
/*
27
9660a5eb236f 201021_1
hgs
parents: 26
diff changeset
    19
* %version: 31 %
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
hgs
parents:
diff changeset
    73
	{
hgs
parents:
diff changeset
    74
		const u8_t DEFAULT_PREFIX[] = "EAP-SERVER";
hgs
parents:
diff changeset
    75
		eap_variable_data_c tmp_prefix(iTools);
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
		if (tmp_prefix.get_is_valid() == false)
hgs
parents:
diff changeset
    78
		{
hgs
parents:
diff changeset
    79
			iTools->am_cancel_all_timers();
hgs
parents:
diff changeset
    80
			abs_eap_am_tools_c::delete_abs_eap_am_tools_c(iTools);
hgs
parents:
diff changeset
    81
			User::Leave(KErrNoMemory);
hgs
parents:
diff changeset
    82
		}
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
		eap_status_e status = tmp_prefix.set_copy_of_buffer(DEFAULT_PREFIX, sizeof(DEFAULT_PREFIX)-1ul);;
hgs
parents:
diff changeset
    85
		if (status != eap_status_ok)
hgs
parents:
diff changeset
    86
		{
hgs
parents:
diff changeset
    87
			iTools->am_cancel_all_timers();
hgs
parents:
diff changeset
    88
			abs_eap_am_tools_c::delete_abs_eap_am_tools_c(iTools);
hgs
parents:
diff changeset
    89
			User::Leave(KErrNoMemory);
hgs
parents:
diff changeset
    90
		}
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
		status = tmp_prefix.add_end_null();
hgs
parents:
diff changeset
    93
		if (status != eap_status_ok)
hgs
parents:
diff changeset
    94
		{
hgs
parents:
diff changeset
    95
			iTools->am_cancel_all_timers();
hgs
parents:
diff changeset
    96
			abs_eap_am_tools_c::delete_abs_eap_am_tools_c(iTools);
hgs
parents:
diff changeset
    97
			User::Leave(KErrNoMemory);
hgs
parents:
diff changeset
    98
		}
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
		status = iTools->set_trace_prefix(&tmp_prefix);
hgs
parents:
diff changeset
   101
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   102
		{
hgs
parents:
diff changeset
   103
			iTools->am_cancel_all_timers();
hgs
parents:
diff changeset
   104
			abs_eap_am_tools_c::delete_abs_eap_am_tools_c(iTools);
hgs
parents:
diff changeset
   105
			User::Leave(KErrNoMemory);
hgs
parents:
diff changeset
   106
		}
hgs
parents:
diff changeset
   107
	}
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
	{
hgs
parents:
diff changeset
   112
		TInt error;
hgs
parents:
diff changeset
   113
		RFs aFileServerSession;
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
		// Open file server session
hgs
parents:
diff changeset
   116
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   117
			iTools, 
hgs
parents:
diff changeset
   118
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   119
			(EAPL("CEapServer::ConstructL(): - calls aFileServerSession.Connect()\n")));
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
		error = aFileServerSession.Connect();
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   124
			iTools, 
hgs
parents:
diff changeset
   125
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   126
			(EAPL("CEapServer::ConstructL(): - aFileServerSession.Connect(), error=%d\n"),
hgs
parents:
diff changeset
   127
			error));
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
		User::LeaveIfError(error);
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
		// Create the private path - it is not automatically created by Symbian OS.
hgs
parents:
diff changeset
   132
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   133
			iTools, 
hgs
parents:
diff changeset
   134
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   135
			(EAPL("CEapServer::ConstructL(): - calls aFileServerSession.CreatePrivatePath(%d)\n"),
hgs
parents:
diff changeset
   136
			RFs::GetSystemDrive()));
hgs
parents:
diff changeset
   137
hgs
parents:
diff changeset
   138
		error = aFileServerSession.CreatePrivatePath(RFs::GetSystemDrive());
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   141
			iTools, 
hgs
parents:
diff changeset
   142
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   143
			(EAPL("CEapServer::ConstructL(): - aFileServerSession.CreatePrivatePath(%d), error=%d\n"),
hgs
parents:
diff changeset
   144
			RFs::GetSystemDrive(),
hgs
parents:
diff changeset
   145
			error));
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
		User::LeaveIfError(error);
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
		// Set the session path to the private directory
hgs
parents:
diff changeset
   150
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   151
			iTools, 
hgs
parents:
diff changeset
   152
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   153
			(EAPL("CEapServer::ConstructL(): - calls aFileServerSession.SetSessionToPrivate(%d)\n"),
hgs
parents:
diff changeset
   154
			RFs::GetSystemDrive()));
hgs
parents:
diff changeset
   155
hgs
parents:
diff changeset
   156
		error = aFileServerSession.SetSessionToPrivate(RFs::GetSystemDrive());
hgs
parents:
diff changeset
   157
hgs
parents:
diff changeset
   158
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   159
			iTools, 
hgs
parents:
diff changeset
   160
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   161
			(EAPL("CEapServer::ConstructL(): - aFileServerSession.SetSessionToPrivate(%d), error=%d\n"),
hgs
parents:
diff changeset
   162
			RFs::GetSystemDrive(),
hgs
parents:
diff changeset
   163
			error));
hgs
parents:
diff changeset
   164
hgs
parents:
diff changeset
   165
		User::LeaveIfError(error);
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
		// Close the session with the file server.
hgs
parents:
diff changeset
   168
		aFileServerSession.Close();
hgs
parents:
diff changeset
   169
	}
hgs
parents:
diff changeset
   170
hgs
parents:
diff changeset
   171
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   172
hgs
parents:
diff changeset
   173
    {
hgs
parents:
diff changeset
   174
		// construct shutdown timer
hgs
parents:
diff changeset
   175
		iShutdown = new(ELeave) CEapDelayedShutdown(iTools, this);
hgs
parents:
diff changeset
   176
		iShutdown->ConstructL();
hgs
parents:
diff changeset
   177
		// identify ourselves and open for service
hgs
parents:
diff changeset
   178
		TBuf<KMaxServerExe> ServerName;
hgs
parents:
diff changeset
   179
		TBuf<KMaxServerExe> ServerExe;
hgs
parents:
diff changeset
   180
    
hgs
parents:
diff changeset
   181
		GetServerNameAndExe(&ServerName, &ServerExe);
hgs
parents:
diff changeset
   182
hgs
parents:
diff changeset
   183
		StartL(ServerName);
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
		// Initiates shut down timer. Timer will close server unless we get client connections.
hgs
parents:
diff changeset
   186
		iShutdown->Start();
hgs
parents:
diff changeset
   187
	}
hgs
parents:
diff changeset
   188
hgs
parents:
diff changeset
   189
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
    {
hgs
parents:
diff changeset
   192
		// construct backup and restore observer
hgs
parents:
diff changeset
   193
		iBackupRestore = new(ELeave) CEapserverBackup(this);
hgs
parents:
diff changeset
   194
		iBackupRestore->ConstructL();
hgs
parents:
diff changeset
   195
	}
hgs
parents:
diff changeset
   196
hgs
parents:
diff changeset
   197
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - -
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
CEapServer* CEapServer::NewL()
hgs
parents:
diff changeset
   204
    {
hgs
parents:
diff changeset
   205
    EAP_TRACE_DEBUG_SYMBIAN((_L("CEapServer::NewL(): starts")));
hgs
parents:
diff changeset
   206
hgs
parents:
diff changeset
   207
	EAP_TRACE_RETURN_STRING_SYMBIAN(_L("returns: CEapServer::NewL()"));
hgs
parents:
diff changeset
   208
hgs
parents:
diff changeset
   209
    CEapServer* self = new(ELeave)CEapServer();
hgs
parents:
diff changeset
   210
    CleanupStack::PushL(self);
hgs
parents:
diff changeset
   211
hgs
parents:
diff changeset
   212
    self->ConstructL();
hgs
parents:
diff changeset
   213
hgs
parents:
diff changeset
   214
    CleanupStack::Pop(self);
hgs
parents:
diff changeset
   215
hgs
parents:
diff changeset
   216
    return self;
hgs
parents:
diff changeset
   217
    }
hgs
parents:
diff changeset
   218
hgs
parents:
diff changeset
   219
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   220
hgs
parents:
diff changeset
   221
CEapServer::~CEapServer()
hgs
parents:
diff changeset
   222
	{
hgs
parents:
diff changeset
   223
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   224
		iTools, 
hgs
parents:
diff changeset
   225
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   226
		(EAPL("CEapServer::~CEapServer(): this=0x%08x\n"),
hgs
parents:
diff changeset
   227
		this));
hgs
parents:
diff changeset
   228
hgs
parents:
diff changeset
   229
	// Do not use iTools, because it will be destroyed before return.
hgs
parents:
diff changeset
   230
	EAP_TRACE_RETURN_STRING_SYMBIAN(_L("returns: CEapServer::~CEapServer()"));
hgs
parents:
diff changeset
   231
hgs
parents:
diff changeset
   232
	delete iShutdown;
hgs
parents:
diff changeset
   233
	delete iBackupRestore;
hgs
parents:
diff changeset
   234
	
hgs
parents:
diff changeset
   235
	if (iTools) 
hgs
parents:
diff changeset
   236
	{
hgs
parents:
diff changeset
   237
		iTools->am_cancel_all_timers();
hgs
parents:
diff changeset
   238
		abs_eap_am_tools_c::delete_abs_eap_am_tools_c(iTools);
hgs
parents:
diff changeset
   239
	}
hgs
parents:
diff changeset
   240
hgs
parents:
diff changeset
   241
	REComSession::FinalClose();
hgs
parents:
diff changeset
   242
	}
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   245
hgs
parents:
diff changeset
   246
// from CServer
hgs
parents:
diff changeset
   247
hgs
parents:
diff changeset
   248
CSession2* CEapServer::NewSessionL(const TVersion& /* aVersion */, const RMessage2 &aMessage) const
hgs
parents:
diff changeset
   249
    {
hgs
parents:
diff changeset
   250
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   251
		iTools, 
hgs
parents:
diff changeset
   252
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   253
		(EAPL("CEapServer::NewSessionL(): starts\n")));
hgs
parents:
diff changeset
   254
hgs
parents:
diff changeset
   255
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::NewSessionL()");
hgs
parents:
diff changeset
   256
hgs
parents:
diff changeset
   257
    CEapSession* session = new(ELeave) CEapSession();
hgs
parents:
diff changeset
   258
    CleanupStack::PushL(session);
hgs
parents:
diff changeset
   259
hgs
parents:
diff changeset
   260
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   261
		iTools, 
hgs
parents:
diff changeset
   262
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   263
		(EAPL("CEapServer::NewSessionL(): session=0x%08x\n"),
hgs
parents:
diff changeset
   264
		session));
hgs
parents:
diff changeset
   265
hgs
parents:
diff changeset
   266
    EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   267
		iTools, 
hgs
parents:
diff changeset
   268
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   269
		(EAPL("CEapServer::NewSessionL(): session->ConstructL() starts")));
hgs
parents:
diff changeset
   270
hgs
parents:
diff changeset
   271
    session->ConstructL(*const_cast<CEapServer*>(this), iTools);
hgs
parents:
diff changeset
   272
hgs
parents:
diff changeset
   273
    EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   274
		iTools, 
hgs
parents:
diff changeset
   275
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   276
		(EAPL("CEapServer::NewSessionL(): session->ConstructL() ends")));
hgs
parents:
diff changeset
   277
hgs
parents:
diff changeset
   278
    CleanupStack::Pop(session);
hgs
parents:
diff changeset
   279
hgs
parents:
diff changeset
   280
    const_cast<CEapServer*>(this)->IncrementSessions();
hgs
parents:
diff changeset
   281
hgs
parents:
diff changeset
   282
	return session;
hgs
parents:
diff changeset
   283
    }
hgs
parents:
diff changeset
   284
hgs
parents:
diff changeset
   285
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   286
hgs
parents:
diff changeset
   287
TInt CEapServer::RunError(TInt aErr)
hgs
parents:
diff changeset
   288
    /**
hgs
parents:
diff changeset
   289
       Handle leaves from ServiceL.
hgs
parents:
diff changeset
   290
hgs
parents:
diff changeset
   291
       Any leave from a ServiceL() will land up here.
hgs
parents:
diff changeset
   292
    */
hgs
parents:
diff changeset
   293
    {
hgs
parents:
diff changeset
   294
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   295
		iTools, 
hgs
parents:
diff changeset
   296
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   297
		(EAPL("CEapServer::RunError(), aErr=%d\n"),
hgs
parents:
diff changeset
   298
		aErr));
hgs
parents:
diff changeset
   299
hgs
parents:
diff changeset
   300
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::RunError()");
hgs
parents:
diff changeset
   301
hgs
parents:
diff changeset
   302
    // if it's a bad descriptor, panic the client
hgs
parents:
diff changeset
   303
    if (aErr==KErrBadDescriptor)    // client had a bad descriptor
hgs
parents:
diff changeset
   304
        {
hgs
parents:
diff changeset
   305
        PanicClient(EBadDescriptor);
hgs
parents:
diff changeset
   306
        }
hgs
parents:
diff changeset
   307
hgs
parents:
diff changeset
   308
    // anyway, complete the outstanding message
hgs
parents:
diff changeset
   309
    Message().Complete(aErr);
hgs
parents:
diff changeset
   310
    ReStart(); // really means just continue reading client requests
hgs
parents:
diff changeset
   311
    return KErrNone;
hgs
parents:
diff changeset
   312
    }
hgs
parents:
diff changeset
   313
hgs
parents:
diff changeset
   314
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   315
hgs
parents:
diff changeset
   316
/**
hgs
parents:
diff changeset
   317
   session count support
hgs
parents:
diff changeset
   318
*/
hgs
parents:
diff changeset
   319
void CEapServer::IncrementSessions()
hgs
parents:
diff changeset
   320
{   
hgs
parents:
diff changeset
   321
	iSessionCount++;
hgs
parents:
diff changeset
   322
hgs
parents:
diff changeset
   323
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   324
		iTools, 
hgs
parents:
diff changeset
   325
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   326
		(EAPL("CEapServer::IncrementSessions(): iSessionCount=%d\n"),
hgs
parents:
diff changeset
   327
		iSessionCount));
hgs
parents:
diff changeset
   328
hgs
parents:
diff changeset
   329
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::IncrementSessions()");
hgs
parents:
diff changeset
   330
hgs
parents:
diff changeset
   331
	iShutdown->Cancel();
hgs
parents:
diff changeset
   332
}
hgs
parents:
diff changeset
   333
hgs
parents:
diff changeset
   334
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   335
hgs
parents:
diff changeset
   336
void CEapServer::DecrementSessions()
hgs
parents:
diff changeset
   337
{
hgs
parents:
diff changeset
   338
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   339
		iTools, 
hgs
parents:
diff changeset
   340
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   341
		(EAPL("CEapServer::DecrementSessions(): iSessionCount=%d\n"),
hgs
parents:
diff changeset
   342
		iSessionCount));
hgs
parents:
diff changeset
   343
hgs
parents:
diff changeset
   344
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::DecrementSessions()");
hgs
parents:
diff changeset
   345
hgs
parents:
diff changeset
   346
	iSessionCount--;
hgs
parents:
diff changeset
   347
	if (iSessionCount>0)
hgs
parents:
diff changeset
   348
		return;
hgs
parents:
diff changeset
   349
hgs
parents:
diff changeset
   350
	iShutdown->Start();
hgs
parents:
diff changeset
   351
}
hgs
parents:
diff changeset
   352
hgs
parents:
diff changeset
   353
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   354
hgs
parents:
diff changeset
   355
void CEapServer::PanicClient(TInt aPanic) const
hgs
parents:
diff changeset
   356
{
hgs
parents:
diff changeset
   357
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   358
		iTools, 
hgs
parents:
diff changeset
   359
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   360
		(EAPL("CEapServer::PanicClient(): aPanic=%d\n"),
hgs
parents:
diff changeset
   361
		aPanic));
hgs
parents:
diff changeset
   362
hgs
parents:
diff changeset
   363
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::PanicClient()");
hgs
parents:
diff changeset
   364
hgs
parents:
diff changeset
   365
	// let's have a look before we panic the client
hgs
parents:
diff changeset
   366
	__DEBUGGER()
hgs
parents:
diff changeset
   367
	// ok, go for it
hgs
parents:
diff changeset
   368
hgs
parents:
diff changeset
   369
	const TBufC<KMaxCategoryLength> aCategory; 
hgs
parents:
diff changeset
   370
	Message().Panic(aCategory, EBadRequest);
hgs
parents:
diff changeset
   371
}
hgs
parents:
diff changeset
   372
hgs
parents:
diff changeset
   373
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   374
hgs
parents:
diff changeset
   375
void CEapServer::StopL()
hgs
parents:
diff changeset
   376
{
hgs
parents:
diff changeset
   377
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   378
		iTools, 
hgs
parents:
diff changeset
   379
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   380
		(EAPL("CEapServer::StopL()\n")));
hgs
parents:
diff changeset
   381
hgs
parents:
diff changeset
   382
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::StopL()");
hgs
parents:
diff changeset
   383
hgs
parents:
diff changeset
   384
	for (iSessionIter.SetToFirst(); iSessionIter; iSessionIter++)
hgs
parents:
diff changeset
   385
	{
hgs
parents:
diff changeset
   386
		CSession2 * aSession = iSessionIter;
hgs
parents:
diff changeset
   387
hgs
parents:
diff changeset
   388
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   389
			iTools, 
hgs
parents:
diff changeset
   390
			TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   391
			(EAPL("CEapServer::StopL(): aSession=0x%08x calls CancelReceive()\n"),
hgs
parents:
diff changeset
   392
			aSession));
hgs
parents:
diff changeset
   393
27
9660a5eb236f 201021_1
hgs
parents: 26
diff changeset
   394
		if (static_cast<CEapSession *>(aSession) != NULL)
26
hgs
parents:
diff changeset
   395
			{
27
9660a5eb236f 201021_1
hgs
parents: 26
diff changeset
   396
			static_cast<CEapSession *>(aSession)->CancelReceive();
26
hgs
parents:
diff changeset
   397
			}
hgs
parents:
diff changeset
   398
	}
hgs
parents:
diff changeset
   399
}
hgs
parents:
diff changeset
   400
hgs
parents:
diff changeset
   401
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   402
hgs
parents:
diff changeset
   403
void CEapServer::BackupOrRestoreCompleteL()
hgs
parents:
diff changeset
   404
{
hgs
parents:
diff changeset
   405
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   406
		iTools, 
hgs
parents:
diff changeset
   407
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   408
		(EAPL("ERROR: CEapServer::BackupOrRestoreCompleteL(): Do something\n")));
hgs
parents:
diff changeset
   409
hgs
parents:
diff changeset
   410
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::BackupOrRestoreCompleteL()");
hgs
parents:
diff changeset
   411
}
hgs
parents:
diff changeset
   412
hgs
parents:
diff changeset
   413
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   414
hgs
parents:
diff changeset
   415
void CEapServer::BackupOrRestoreStartingL()
hgs
parents:
diff changeset
   416
{
hgs
parents:
diff changeset
   417
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   418
		iTools, 
hgs
parents:
diff changeset
   419
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   420
		(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
   421
hgs
parents:
diff changeset
   422
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapServer::BackupOrRestoreStartingL()");
hgs
parents:
diff changeset
   423
hgs
parents:
diff changeset
   424
    StopL();
hgs
parents:
diff changeset
   425
}
hgs
parents:
diff changeset
   426
hgs
parents:
diff changeset
   427
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   428
hgs
parents:
diff changeset
   429
/*
hgs
parents:
diff changeset
   430
    class CEapDelayedShutdown
hgs
parents:
diff changeset
   431
*/
hgs
parents:
diff changeset
   432
hgs
parents:
diff changeset
   433
CEapDelayedShutdown::CEapDelayedShutdown(abs_eap_am_tools_c * const tools, CEapServer * const aServer)
hgs
parents:
diff changeset
   434
    : CActive(0)
hgs
parents:
diff changeset
   435
	, iTools(tools)
hgs
parents:
diff changeset
   436
	, iServer(aServer)
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
hgs
parents:
diff changeset
   442
void CEapDelayedShutdown::ConstructL()
hgs
parents:
diff changeset
   443
    {
hgs
parents:
diff changeset
   444
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   445
		iTools, 
hgs
parents:
diff changeset
   446
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   447
		(EAPL("CEapDelayedShutdown::ConstructL()\n")));
hgs
parents:
diff changeset
   448
hgs
parents:
diff changeset
   449
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::ConstructL()");
hgs
parents:
diff changeset
   450
hgs
parents:
diff changeset
   451
    CActiveScheduler::Add(this);
hgs
parents:
diff changeset
   452
    User::LeaveIfError(iTimer.CreateLocal());
hgs
parents:
diff changeset
   453
    }
hgs
parents:
diff changeset
   454
hgs
parents:
diff changeset
   455
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   456
hgs
parents:
diff changeset
   457
CEapDelayedShutdown::~CEapDelayedShutdown()
hgs
parents:
diff changeset
   458
    {
hgs
parents:
diff changeset
   459
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   460
		iTools, 
hgs
parents:
diff changeset
   461
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   462
		(EAPL("CEapDelayedShutdown::~CEapDelayedShutdown()\n")));
hgs
parents:
diff changeset
   463
hgs
parents:
diff changeset
   464
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::~CEapDelayedShutdown()");
hgs
parents:
diff changeset
   465
hgs
parents:
diff changeset
   466
    Cancel();
hgs
parents:
diff changeset
   467
    iTimer.Close();
hgs
parents:
diff changeset
   468
    }
hgs
parents:
diff changeset
   469
hgs
parents:
diff changeset
   470
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   471
hgs
parents:
diff changeset
   472
void CEapDelayedShutdown::Start()
hgs
parents:
diff changeset
   473
    {
hgs
parents:
diff changeset
   474
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   475
		iTools, 
hgs
parents:
diff changeset
   476
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   477
		(EAPL("CEapDelayedShutdown::Start()\n")));
hgs
parents:
diff changeset
   478
hgs
parents:
diff changeset
   479
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::Start()");
hgs
parents:
diff changeset
   480
hgs
parents:
diff changeset
   481
    iTimer.After(iStatus, KEapShutdownInterval);
hgs
parents:
diff changeset
   482
    SetActive();
hgs
parents:
diff changeset
   483
    }
hgs
parents:
diff changeset
   484
hgs
parents:
diff changeset
   485
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   486
hgs
parents:
diff changeset
   487
void CEapDelayedShutdown::DoCancel()
hgs
parents:
diff changeset
   488
{
hgs
parents:
diff changeset
   489
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   490
		iTools, 
hgs
parents:
diff changeset
   491
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   492
		(EAPL("CEapDelayedShutdown::DoCancel()\n")));
hgs
parents:
diff changeset
   493
hgs
parents:
diff changeset
   494
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::DoCancel()");
hgs
parents:
diff changeset
   495
hgs
parents:
diff changeset
   496
	iTimer.Cancel();
hgs
parents:
diff changeset
   497
}
hgs
parents:
diff changeset
   498
hgs
parents:
diff changeset
   499
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   500
hgs
parents:
diff changeset
   501
TInt CEapDelayedShutdown::RunError(TInt aError)
hgs
parents:
diff changeset
   502
{
hgs
parents:
diff changeset
   503
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   504
		iTools,
hgs
parents:
diff changeset
   505
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   506
		(EAPL("CEapDelayedShutdown::RunError(): aError=%d, this=0x%08x\n"),
hgs
parents:
diff changeset
   507
		aError,
hgs
parents:
diff changeset
   508
		this));
hgs
parents:
diff changeset
   509
hgs
parents:
diff changeset
   510
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::RunError()");
hgs
parents:
diff changeset
   511
hgs
parents:
diff changeset
   512
	iTimer.Cancel();
hgs
parents:
diff changeset
   513
hgs
parents:
diff changeset
   514
	return aError;
hgs
parents:
diff changeset
   515
}
hgs
parents:
diff changeset
   516
hgs
parents:
diff changeset
   517
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   518
hgs
parents:
diff changeset
   519
void CEapDelayedShutdown::RunL()
hgs
parents:
diff changeset
   520
{
hgs
parents:
diff changeset
   521
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   522
		iTools, 
hgs
parents:
diff changeset
   523
		TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   524
		(EAPL("CEapDelayedShutdown::RunL(), calls CActiveScheduler::Stop()\n")));
hgs
parents:
diff changeset
   525
hgs
parents:
diff changeset
   526
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapDelayedShutdown::RunL()");
hgs
parents:
diff changeset
   527
hgs
parents:
diff changeset
   528
	CActiveScheduler::Stop();
hgs
parents:
diff changeset
   529
}
hgs
parents:
diff changeset
   530
hgs
parents:
diff changeset
   531
//----------------------------------------------------------------------------
hgs
parents:
diff changeset
   532
hgs
parents:
diff changeset
   533
// end