eapol/eapol_framework/eapol_symbian/eap_if/src/EapFastPacStoreImpl.cpp
author hgs
Mon, 24 May 2010 20:32:47 +0300
changeset 26 9abfd4f00d37
child 34 ad1f037f1ac2
permissions -rw-r--r--
201021
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
26
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2001-2006 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:  EAP and WLAN authentication protocols.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
/*
hgs
parents:
diff changeset
    19
* %version: 21 %
hgs
parents:
diff changeset
    20
*/
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include <e32base.h>
hgs
parents:
diff changeset
    23
#include <ecom/implementationproxy.h>
hgs
parents:
diff changeset
    24
#include "EapolUID.h"
hgs
parents:
diff changeset
    25
#include "EapTraceSymbian.h"
hgs
parents:
diff changeset
    26
#include "EapFastPacStoreImpl.h"
hgs
parents:
diff changeset
    27
#include "eap_automatic_variable.h"
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
// ----------------------------------------------------------
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
const TImplementationProxy ImplementationTable[] = 
hgs
parents:
diff changeset
    32
{
hgs
parents:
diff changeset
    33
	{{0x2002BC93}, reinterpret_cast<TProxyNewLPtr> (CEapFastPacStoreImpl::NewL)}
hgs
parents:
diff changeset
    34
};
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
// ----------------------------------------------------------
hgs
parents:
diff changeset
    37
hgs
parents:
diff changeset
    38
EXPORT_C const TImplementationProxy* ImplementationGroupProxy(TInt& aTableCount)
hgs
parents:
diff changeset
    39
{
hgs
parents:
diff changeset
    40
	aTableCount = sizeof(ImplementationTable) / sizeof(TImplementationProxy);
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
	return ImplementationTable;
hgs
parents:
diff changeset
    43
}
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
// ----------------------------------------------------------
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
CEapFastPacStore* CEapFastPacStoreImpl::NewL()
hgs
parents:
diff changeset
    48
{
hgs
parents:
diff changeset
    49
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
    50
     (_L("CEapFastPacStoreImpl::NewL")));  
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
    CEapFastPacStoreImpl* self = new (ELeave) CEapFastPacStoreImpl();
hgs
parents:
diff changeset
    53
		
hgs
parents:
diff changeset
    54
		self->ConstructL();
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
    57
     (_L("CEapFastPacStoreImpl::NewL end")));  
hgs
parents:
diff changeset
    58
	return self;
hgs
parents:
diff changeset
    59
 	
hgs
parents:
diff changeset
    60
}
hgs
parents:
diff changeset
    61
hgs
parents:
diff changeset
    62
// ----------------------------------------------------------
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
CEapFastPacStoreImpl::CEapFastPacStoreImpl():
hgs
parents:
diff changeset
    65
   	iTools(abs_eap_am_tools_c::new_abs_eap_am_tools_c())
hgs
parents:
diff changeset
    66
	  ,iPartner(eap_pac_store_message_base_c::new_eap_pac_store_client_message_if_c(
hgs
parents:
diff changeset
    67
			iTools,
hgs
parents:
diff changeset
    68
			this))
hgs
parents:
diff changeset
    69
    ,iIsValid (EFalse)
hgs
parents:
diff changeset
    70
   	,iWaitState(eap_fast_pac_store_impl_wait_state_none)
hgs
parents:
diff changeset
    71
    ,iPacStorePassword (new eap_variable_data_c(iTools))
hgs
parents:
diff changeset
    72
    ,iIsPresent(EFalse)
hgs
parents:
diff changeset
    73
		,iIsMatching(EFalse)
hgs
parents:
diff changeset
    74
	{
hgs
parents:
diff changeset
    75
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
    76
     (_L("CEapFastPacStoreImpl::CEapFastPacStoreImpl")));
hgs
parents:
diff changeset
    77
		
hgs
parents:
diff changeset
    78
		
hgs
parents:
diff changeset
    79
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
    80
     (_L("CEapFastPacStoreImpl::CEapFastPacStoreImpl end")));  
hgs
parents:
diff changeset
    81
	}
hgs
parents:
diff changeset
    82
	
hgs
parents:
diff changeset
    83
// ----------------------------------------------------------
hgs
parents:
diff changeset
    84
hgs
parents:
diff changeset
    85
void CEapFastPacStoreImpl::ConstructL()
hgs
parents:
diff changeset
    86
	{
hgs
parents:
diff changeset
    87
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
    88
     (_L("CEapFastPacStoreImpl::ConstructL")));
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
	eap_status_e status = iPartner->configure();
hgs
parents:
diff changeset
    91
	if (status != eap_status_ok)
hgs
parents:
diff changeset
    92
		{
hgs
parents:
diff changeset
    93
			TInt aError = iTools->convert_eapol_error_to_am_error(status);
hgs
parents:
diff changeset
    94
			
hgs
parents:
diff changeset
    95
		abs_eap_am_tools_c::delete_abs_eap_am_tools_c(iTools);
hgs
parents:
diff changeset
    96
		delete iPartner;
hgs
parents:
diff changeset
    97
		iPartner = NULL;
hgs
parents:
diff changeset
    98
		User::Leave(aError);
hgs
parents:
diff changeset
    99
		}
hgs
parents:
diff changeset
   100
			
hgs
parents:
diff changeset
   101
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   102
     (_L("CEapFastPacStoreImpl::ConstructL end")));  
hgs
parents:
diff changeset
   103
		
hgs
parents:
diff changeset
   104
	}
hgs
parents:
diff changeset
   105
	
hgs
parents:
diff changeset
   106
// ----------------------------------------------------------
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
CEapFastPacStoreImpl::~CEapFastPacStoreImpl()
hgs
parents:
diff changeset
   109
	{
hgs
parents:
diff changeset
   110
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   111
     (_L("CEapFastPacStoreImpl::~CEapFastPacStoreImpl")));
hgs
parents:
diff changeset
   112
 
hgs
parents:
diff changeset
   113
     if ( iPacStorePassword != NULL )
hgs
parents:
diff changeset
   114
        {
hgs
parents:
diff changeset
   115
        delete iPacStorePassword;
hgs
parents:
diff changeset
   116
        }
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
		if (iPartner != 0)
hgs
parents:
diff changeset
   119
			{
hgs
parents:
diff changeset
   120
			iPartner->shutdown();
hgs
parents:
diff changeset
   121
			}
hgs
parents:
diff changeset
   122
		delete iPartner;
hgs
parents:
diff changeset
   123
hgs
parents:
diff changeset
   124
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   125
     (_L("CEapFastPacStoreImpl::~CEapFastPacStoreImpl end")));  
hgs
parents:
diff changeset
   126
		
hgs
parents:
diff changeset
   127
		abs_eap_am_tools_c::delete_abs_eap_am_tools_c(iTools);
hgs
parents:
diff changeset
   128
		iTools = NULL;
hgs
parents:
diff changeset
   129
	}
hgs
parents:
diff changeset
   130
	
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
// ----------------------------------------------------------
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
void CEapFastPacStoreImpl::Activate()
hgs
parents:
diff changeset
   135
{
hgs
parents:
diff changeset
   136
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   137
		iTools,
hgs
parents:
diff changeset
   138
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   139
		(EAPL("CEapFastPacStoreImpl::Activate(): iAsyncronousStatus=%u\n"),
hgs
parents:
diff changeset
   140
			iAsyncronousStatus.Int()));
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapFastPacStoreImpl::Activate()");
hgs
parents:
diff changeset
   143
hgs
parents:
diff changeset
   144
	iAsyncronousStatus = KRequestPending;
hgs
parents:
diff changeset
   145
}
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
//----------------------------------------------------------------
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
void CEapFastPacStoreImpl::Complete()
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("CEapFastPacStoreImpl::Complete(): iAsyncronousStatus=%u\n"),
hgs
parents:
diff changeset
   155
		iAsyncronousStatus.Int()));
hgs
parents:
diff changeset
   156
hgs
parents:
diff changeset
   157
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapFastPacStoreImpl::Complete()");
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
	iAsyncronousStatus = KErrNone;
hgs
parents:
diff changeset
   160
hgs
parents:
diff changeset
   161
	// This is needed to continue the execution after Wait.Start(); 
hgs
parents:
diff changeset
   162
	iWait.AsyncStop();
hgs
parents:
diff changeset
   163
}
hgs
parents:
diff changeset
   164
hgs
parents:
diff changeset
   165
//----------------------------------------------------------------
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
void CEapFastPacStoreImpl::WaitCompletion()
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("CEapFastPacStoreImpl::WaitCompletion(): iAsyncronousStatus=%u\n"),
hgs
parents:
diff changeset
   173
		iAsyncronousStatus.Int()));
hgs
parents:
diff changeset
   174
hgs
parents:
diff changeset
   175
	EAP_TRACE_RETURN_STRING(iTools, "returns: CEapFastPacStoreImpl::WaitCompletion()");
hgs
parents:
diff changeset
   176
hgs
parents:
diff changeset
   177
	while (iAsyncronousStatus == KRequestPending)
hgs
parents:
diff changeset
   178
	{
hgs
parents:
diff changeset
   179
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   180
			iTools,
hgs
parents:
diff changeset
   181
			TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   182
			(EAPL("CEapFastPacStoreImpl::WaitCompletion(): calls iWait.Start()\n")));
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
		iWait.Start();
hgs
parents:
diff changeset
   185
hgs
parents:
diff changeset
   186
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   187
			iTools,
hgs
parents:
diff changeset
   188
			TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   189
			(EAPL("CEapFastPacStoreImpl::WaitCompletion(): iWait.Start() returns, iAsyncronousStatus=%u\n"),
hgs
parents:
diff changeset
   190
			iAsyncronousStatus.Int()));
hgs
parents:
diff changeset
   191
	}
hgs
parents:
diff changeset
   192
}
hgs
parents:
diff changeset
   193
hgs
parents:
diff changeset
   194
// ----------------------------------------------------------
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
void CEapFastPacStoreImpl::OpenPacStoreL()
hgs
parents:
diff changeset
   197
	{
hgs
parents:
diff changeset
   198
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   199
     (_L("CEapFastPacStoreImpl::OpenPacStoreL")));  
hgs
parents:
diff changeset
   200
hgs
parents:
diff changeset
   201
		eap_status_e status = iPartner->open_pac_store(
hgs
parents:
diff changeset
   202
		iCompletionStatus);
hgs
parents:
diff changeset
   203
		
hgs
parents:
diff changeset
   204
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   205
	{
hgs
parents:
diff changeset
   206
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   207
			EAP_STATUS_RETURN(iTools, status)));
hgs
parents:
diff changeset
   208
	}
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
	iWaitState = eap_fast_pac_store_impl_wait_state_complete_open_pac_store;
hgs
parents:
diff changeset
   211
    Activate();
hgs
parents:
diff changeset
   212
    WaitCompletion();
hgs
parents:
diff changeset
   213
hgs
parents:
diff changeset
   214
	if (iCompletionStatus != eap_status_ok)
hgs
parents:
diff changeset
   215
	{
hgs
parents:
diff changeset
   216
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   217
			EAP_STATUS_RETURN(iTools, iCompletionStatus)));
hgs
parents:
diff changeset
   218
	}
hgs
parents:
diff changeset
   219
hgs
parents:
diff changeset
   220
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   221
     (_L("CEapFastPacStoreImpl::OpenPacStoreL end")));  
hgs
parents:
diff changeset
   222
hgs
parents:
diff changeset
   223
}
hgs
parents:
diff changeset
   224
    
hgs
parents:
diff changeset
   225
// ----------------------------------------------------------
hgs
parents:
diff changeset
   226
hgs
parents:
diff changeset
   227
void CEapFastPacStoreImpl::CreateDeviceSeedL()
hgs
parents:
diff changeset
   228
{
hgs
parents:
diff changeset
   229
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   230
     (_L("CEapFastPacStoreImpl::CreateDeviceSeedL")));  
hgs
parents:
diff changeset
   231
hgs
parents:
diff changeset
   232
	eap_status_e status = iPartner->create_device_seed(
hgs
parents:
diff changeset
   233
		iCompletionStatus);
hgs
parents:
diff changeset
   234
hgs
parents:
diff changeset
   235
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   236
	{
hgs
parents:
diff changeset
   237
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   238
			EAP_STATUS_RETURN(iTools, status)));
hgs
parents:
diff changeset
   239
	}
hgs
parents:
diff changeset
   240
hgs
parents:
diff changeset
   241
	iWaitState = eap_fast_pac_store_impl_wait_state_complete_create_device_seed;
hgs
parents:
diff changeset
   242
    Activate();
hgs
parents:
diff changeset
   243
    WaitCompletion();
hgs
parents:
diff changeset
   244
hgs
parents:
diff changeset
   245
	if (iCompletionStatus != eap_status_ok)
hgs
parents:
diff changeset
   246
	{
hgs
parents:
diff changeset
   247
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   248
			EAP_STATUS_RETURN(iTools, iCompletionStatus)));
hgs
parents:
diff changeset
   249
	}
hgs
parents:
diff changeset
   250
hgs
parents:
diff changeset
   251
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   252
     (_L("CEapFastPacStoreImpl::CreateDeviceSeedL end")));  
hgs
parents:
diff changeset
   253
hgs
parents:
diff changeset
   254
}
hgs
parents:
diff changeset
   255
hgs
parents:
diff changeset
   256
// ----------------------------------------------------------
hgs
parents:
diff changeset
   257
hgs
parents:
diff changeset
   258
TBool CEapFastPacStoreImpl::IsMasterKeyPresentL()
hgs
parents:
diff changeset
   259
{
hgs
parents:
diff changeset
   260
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   261
     (_L("CEapFastPacStoreImpl::IsMasterKeyPresentL")));  
hgs
parents:
diff changeset
   262
hgs
parents:
diff changeset
   263
	eap_status_e status = iPartner->is_master_key_present(
hgs
parents:
diff changeset
   264
		iCompletionStatus);
hgs
parents:
diff changeset
   265
hgs
parents:
diff changeset
   266
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   267
	{
hgs
parents:
diff changeset
   268
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   269
			EAP_STATUS_RETURN(iTools, status)));
hgs
parents:
diff changeset
   270
	}
hgs
parents:
diff changeset
   271
hgs
parents:
diff changeset
   272
	iWaitState = eap_fast_pac_store_impl_wait_state_complete_is_master_key_present;
hgs
parents:
diff changeset
   273
    Activate();
hgs
parents:
diff changeset
   274
    WaitCompletion();
hgs
parents:
diff changeset
   275
hgs
parents:
diff changeset
   276
	if (iCompletionStatus != eap_status_ok)
hgs
parents:
diff changeset
   277
	{
hgs
parents:
diff changeset
   278
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   279
			EAP_STATUS_RETURN(iTools, iCompletionStatus)));
hgs
parents:
diff changeset
   280
	}
hgs
parents:
diff changeset
   281
hgs
parents:
diff changeset
   282
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   283
     (_L("CEapFastPacStoreImpl::IsMasterKeyPresentL end")));  
hgs
parents:
diff changeset
   284
hgs
parents:
diff changeset
   285
	return iIsPresent;
hgs
parents:
diff changeset
   286
hgs
parents:
diff changeset
   287
}
hgs
parents:
diff changeset
   288
hgs
parents:
diff changeset
   289
// ----------------------------------------------------------
hgs
parents:
diff changeset
   290
hgs
parents:
diff changeset
   291
TBool CEapFastPacStoreImpl::IsMasterKeyAndPasswordMatchingL(
hgs
parents:
diff changeset
   292
		const TDesC8 & aPassword8)
hgs
parents:
diff changeset
   293
{
hgs
parents:
diff changeset
   294
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   295
     (_L("CEapFastPacStoreImpl::IsMasterKeyAndPasswordMatchingL")));  
hgs
parents:
diff changeset
   296
hgs
parents:
diff changeset
   297
	iPacStorePassword->set_copy_of_buffer(aPassword8.Ptr(), aPassword8.Size());
hgs
parents:
diff changeset
   298
hgs
parents:
diff changeset
   299
	eap_status_e status = iPartner->is_master_key_and_password_matching(
hgs
parents:
diff changeset
   300
		iPacStorePassword
hgs
parents:
diff changeset
   301
		,iCompletionStatus);
hgs
parents:
diff changeset
   302
hgs
parents:
diff changeset
   303
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   304
	{
hgs
parents:
diff changeset
   305
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   306
			EAP_STATUS_RETURN(iTools, status)));
hgs
parents:
diff changeset
   307
	}
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
	iWaitState = eap_fast_pac_store_impl_wait_state_complete_is_master_key_and_password_matching;
hgs
parents:
diff changeset
   310
    Activate();
hgs
parents:
diff changeset
   311
    WaitCompletion();
hgs
parents:
diff changeset
   312
hgs
parents:
diff changeset
   313
	if (iCompletionStatus != eap_status_ok)
hgs
parents:
diff changeset
   314
	{
hgs
parents:
diff changeset
   315
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   316
			EAP_STATUS_RETURN(iTools, iCompletionStatus)));
hgs
parents:
diff changeset
   317
	}
hgs
parents:
diff changeset
   318
hgs
parents:
diff changeset
   319
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   320
     (_L("CEapFastPacStoreImpl::IsMasterKeyAndPasswordMatchingL end")));  
hgs
parents:
diff changeset
   321
hgs
parents:
diff changeset
   322
	return iIsMatching;
hgs
parents:
diff changeset
   323
hgs
parents:
diff changeset
   324
}
hgs
parents:
diff changeset
   325
hgs
parents:
diff changeset
   326
// ----------------------------------------------------------
hgs
parents:
diff changeset
   327
hgs
parents:
diff changeset
   328
TInt CEapFastPacStoreImpl::CreateAndSaveMasterKeyL(
hgs
parents:
diff changeset
   329
		const TDesC8 & aPassword8)
hgs
parents:
diff changeset
   330
{
hgs
parents:
diff changeset
   331
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   332
     (_L("CEapFastPacStoreImpl::CreateAndSaveMasterKeyL")));  
hgs
parents:
diff changeset
   333
hgs
parents:
diff changeset
   334
	
hgs
parents:
diff changeset
   335
	iPacStorePassword->set_copy_of_buffer(aPassword8.Ptr(), aPassword8.Size());
hgs
parents:
diff changeset
   336
hgs
parents:
diff changeset
   337
	eap_status_e status = iPartner->create_and_save_master_key(
hgs
parents:
diff changeset
   338
		iPacStorePassword
hgs
parents:
diff changeset
   339
		,iCompletionStatus);
hgs
parents:
diff changeset
   340
hgs
parents:
diff changeset
   341
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   342
	{
hgs
parents:
diff changeset
   343
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   344
			EAP_STATUS_RETURN(iTools, status)));
hgs
parents:
diff changeset
   345
	}
hgs
parents:
diff changeset
   346
hgs
parents:
diff changeset
   347
	iWaitState = eap_fast_pac_store_impl_wait_state_complete_create_and_save_master_key;
hgs
parents:
diff changeset
   348
    Activate();
hgs
parents:
diff changeset
   349
    WaitCompletion();
hgs
parents:
diff changeset
   350
hgs
parents:
diff changeset
   351
	if (iCompletionStatus != eap_status_ok)
hgs
parents:
diff changeset
   352
	{
hgs
parents:
diff changeset
   353
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   354
			EAP_STATUS_RETURN(iTools, iCompletionStatus)));
hgs
parents:
diff changeset
   355
	}
hgs
parents:
diff changeset
   356
hgs
parents:
diff changeset
   357
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   358
     (_L("CEapFastPacStoreImpl::CreateAndSaveMasterKeyL end")));  
hgs
parents:
diff changeset
   359
hgs
parents:
diff changeset
   360
  return iCompletionStatus;
hgs
parents:
diff changeset
   361
hgs
parents:
diff changeset
   362
}
hgs
parents:
diff changeset
   363
hgs
parents:
diff changeset
   364
// ----------------------------------------------------------
hgs
parents:
diff changeset
   365
hgs
parents:
diff changeset
   366
TBool CEapFastPacStoreImpl::ComparePacStorePasswordL(
hgs
parents:
diff changeset
   367
		TDes8 & aPassword8)
hgs
parents:
diff changeset
   368
{
hgs
parents:
diff changeset
   369
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   370
     (_L("CEapFastPacStoreImpl::ComparePacStorePasswordL")));  
hgs
parents:
diff changeset
   371
hgs
parents:
diff changeset
   372
	iPacStorePassword->set_copy_of_buffer(aPassword8.Ptr(), aPassword8.Size());
hgs
parents:
diff changeset
   373
hgs
parents:
diff changeset
   374
	eap_status_e status = iPartner->compare_pac_store_password(
hgs
parents:
diff changeset
   375
		iPacStorePassword);
hgs
parents:
diff changeset
   376
		
hgs
parents:
diff changeset
   377
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   378
	{
hgs
parents:
diff changeset
   379
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   380
			EAP_STATUS_RETURN(iTools, status)));
hgs
parents:
diff changeset
   381
	}
hgs
parents:
diff changeset
   382
hgs
parents:
diff changeset
   383
	iWaitState = eap_fast_pac_store_impl_wait_state_complete_compare_pac_store_password;
hgs
parents:
diff changeset
   384
    Activate();
hgs
parents:
diff changeset
   385
    WaitCompletion();
hgs
parents:
diff changeset
   386
hgs
parents:
diff changeset
   387
	if (iCompletionStatus != eap_status_ok)
hgs
parents:
diff changeset
   388
	{
hgs
parents:
diff changeset
   389
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   390
			EAP_STATUS_RETURN(iTools, iCompletionStatus)));
hgs
parents:
diff changeset
   391
	}
hgs
parents:
diff changeset
   392
hgs
parents:
diff changeset
   393
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   394
     (_L("CEapFastPacStoreImpl::ComparePacStorePasswordL end")));  
hgs
parents:
diff changeset
   395
     
hgs
parents:
diff changeset
   396
  return iIsPwMatching;
hgs
parents:
diff changeset
   397
hgs
parents:
diff changeset
   398
}
hgs
parents:
diff changeset
   399
hgs
parents:
diff changeset
   400
 TBool CEapFastPacStoreImpl::IsPacStorePasswordPresentL()
hgs
parents:
diff changeset
   401
 	{
hgs
parents:
diff changeset
   402
     EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   403
     (_L("CEapFastPacStoreImpl::IsPacStorePasswordPresentL")));  
hgs
parents:
diff changeset
   404
hgs
parents:
diff changeset
   405
	eap_status_e status = iPartner->is_pacstore_password_present();
hgs
parents:
diff changeset
   406
hgs
parents:
diff changeset
   407
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   408
	{
hgs
parents:
diff changeset
   409
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   410
			EAP_STATUS_RETURN(iTools, status)));
hgs
parents:
diff changeset
   411
	}
hgs
parents:
diff changeset
   412
hgs
parents:
diff changeset
   413
	iWaitState = eap_fast_pac_store_impl_wait_state_complete_is_pacstore_password_present;
hgs
parents:
diff changeset
   414
    Activate();
hgs
parents:
diff changeset
   415
    WaitCompletion();
hgs
parents:
diff changeset
   416
hgs
parents:
diff changeset
   417
	if (iCompletionStatus != eap_status_ok)
hgs
parents:
diff changeset
   418
	{
hgs
parents:
diff changeset
   419
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   420
			EAP_STATUS_RETURN(iTools, iCompletionStatus)));
hgs
parents:
diff changeset
   421
	}
hgs
parents:
diff changeset
   422
hgs
parents:
diff changeset
   423
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   424
     (_L("CEapFastPacStoreImpl::IsPacStorePasswordPresentL end")));  
hgs
parents:
diff changeset
   425
hgs
parents:
diff changeset
   426
	return iIsPwPresent;
hgs
parents:
diff changeset
   427
		
hgs
parents:
diff changeset
   428
 	}
hgs
parents:
diff changeset
   429
hgs
parents:
diff changeset
   430
// ----------------------------------------------------------
hgs
parents:
diff changeset
   431
hgs
parents:
diff changeset
   432
TInt CEapFastPacStoreImpl::SetPacStorePasswordL(
hgs
parents:
diff changeset
   433
		const TDesC8 & aPassword8)
hgs
parents:
diff changeset
   434
{
hgs
parents:
diff changeset
   435
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   436
     (_L("CEapFastPacStoreImpl::SetPacStorePasswordL")));  
hgs
parents:
diff changeset
   437
hgs
parents:
diff changeset
   438
	iPacStorePassword->set_copy_of_buffer(aPassword8.Ptr(), aPassword8.Size());
hgs
parents:
diff changeset
   439
	
hgs
parents:
diff changeset
   440
	eap_status_e status = iPartner->set_pac_store_password(
hgs
parents:
diff changeset
   441
		iPacStorePassword
hgs
parents:
diff changeset
   442
		,iCompletionStatus);
hgs
parents:
diff changeset
   443
hgs
parents:
diff changeset
   444
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   445
	{
hgs
parents:
diff changeset
   446
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   447
			EAP_STATUS_RETURN(iTools, status)));
hgs
parents:
diff changeset
   448
	}
hgs
parents:
diff changeset
   449
hgs
parents:
diff changeset
   450
	iWaitState = eap_fast_pac_store_impl_wait_state_complete_set_pac_store_password;
hgs
parents:
diff changeset
   451
    Activate();
hgs
parents:
diff changeset
   452
    WaitCompletion();
hgs
parents:
diff changeset
   453
hgs
parents:
diff changeset
   454
	if (iCompletionStatus != eap_status_ok)
hgs
parents:
diff changeset
   455
	{
hgs
parents:
diff changeset
   456
		User::Leave(iTools->convert_eapol_error_to_am_error(
hgs
parents:
diff changeset
   457
			EAP_STATUS_RETURN(iTools, iCompletionStatus)));
hgs
parents:
diff changeset
   458
	}
hgs
parents:
diff changeset
   459
hgs
parents:
diff changeset
   460
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   461
     (_L("CEapFastPacStoreImpl::SetPacStorePasswordL end")));  
hgs
parents:
diff changeset
   462
hgs
parents:
diff changeset
   463
	return iCompletionStatus;
hgs
parents:
diff changeset
   464
hgs
parents:
diff changeset
   465
hgs
parents:
diff changeset
   466
}
hgs
parents:
diff changeset
   467
hgs
parents:
diff changeset
   468
// ----------------------------------------------------------
hgs
parents:
diff changeset
   469
hgs
parents:
diff changeset
   470
TInt CEapFastPacStoreImpl::DestroyPacStore()
hgs
parents:
diff changeset
   471
{
hgs
parents:
diff changeset
   472
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   473
     (_L("CEapFastPacStoreImpl::DestroyPacStore")));  
hgs
parents:
diff changeset
   474
hgs
parents:
diff changeset
   475
	eap_status_e status = iPartner->destroy_pac_store(
hgs
parents:
diff changeset
   476
		iCompletionStatus);
hgs
parents:
diff changeset
   477
hgs
parents:
diff changeset
   478
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   479
	{
hgs
parents:
diff changeset
   480
		return iTools->convert_eapol_error_to_am_error(status);
hgs
parents:
diff changeset
   481
	}
hgs
parents:
diff changeset
   482
hgs
parents:
diff changeset
   483
	iWaitState = eap_fast_pac_store_impl_wait_state_complete_destroy_pac_store;
hgs
parents:
diff changeset
   484
    Activate();
hgs
parents:
diff changeset
   485
    WaitCompletion();
hgs
parents:
diff changeset
   486
hgs
parents:
diff changeset
   487
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   488
     (_L("CEapFastPacStoreImpl::DestroyPacStore end")));  
hgs
parents:
diff changeset
   489
hgs
parents:
diff changeset
   490
	return iCompletionStatus;
hgs
parents:
diff changeset
   491
hgs
parents:
diff changeset
   492
hgs
parents:
diff changeset
   493
}
hgs
parents:
diff changeset
   494
hgs
parents:
diff changeset
   495
// ----------------------------------------------------------
hgs
parents:
diff changeset
   496
hgs
parents:
diff changeset
   497
eap_status_e CEapFastPacStoreImpl::complete_open_pac_store(
hgs
parents:
diff changeset
   498
		const eap_status_e completion_status)
hgs
parents:
diff changeset
   499
{
hgs
parents:
diff changeset
   500
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   501
		iTools,
hgs
parents:
diff changeset
   502
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   503
		(EAPL("CEapFastPacStoreImpl::complete_open_pac_store(): this=0x%08x, iWaitState=%d\n"),
hgs
parents:
diff changeset
   504
		this,
hgs
parents:
diff changeset
   505
		iWaitState));
hgs
parents:
diff changeset
   506
hgs
parents:
diff changeset
   507
	iCompletionStatus = completion_status;
hgs
parents:
diff changeset
   508
hgs
parents:
diff changeset
   509
	if (iWaitState != eap_fast_pac_store_impl_wait_state_complete_open_pac_store
hgs
parents:
diff changeset
   510
		&& iCompletionStatus == eap_status_ok)
hgs
parents:
diff changeset
   511
	{
hgs
parents:
diff changeset
   512
		// ERROR wrong state.
hgs
parents:
diff changeset
   513
		iCompletionStatus = eap_status_wrong_eap_type_state;
hgs
parents:
diff changeset
   514
	}
hgs
parents:
diff changeset
   515
hgs
parents:
diff changeset
   516
	Complete();
hgs
parents:
diff changeset
   517
hgs
parents:
diff changeset
   518
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   519
     (_L("CEapFastPacStoreImpl::complete_open_pac_store end")));  
hgs
parents:
diff changeset
   520
hgs
parents:
diff changeset
   521
	return iCompletionStatus;
hgs
parents:
diff changeset
   522
hgs
parents:
diff changeset
   523
}
hgs
parents:
diff changeset
   524
hgs
parents:
diff changeset
   525
// ----------------------------------------------------------
hgs
parents:
diff changeset
   526
hgs
parents:
diff changeset
   527
eap_status_e CEapFastPacStoreImpl::complete_create_device_seed(
hgs
parents:
diff changeset
   528
		const eap_status_e completion_status)
hgs
parents:
diff changeset
   529
{
hgs
parents:
diff changeset
   530
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   531
		iTools,
hgs
parents:
diff changeset
   532
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   533
		(EAPL("CEapFastPacStoreImpl::complete_create_device_seed(): this=0x%08x, iWaitState=%d\n"),
hgs
parents:
diff changeset
   534
		this,
hgs
parents:
diff changeset
   535
		iWaitState));
hgs
parents:
diff changeset
   536
hgs
parents:
diff changeset
   537
	iCompletionStatus = completion_status;
hgs
parents:
diff changeset
   538
hgs
parents:
diff changeset
   539
	if (iWaitState != eap_fast_pac_store_impl_wait_state_complete_create_device_seed
hgs
parents:
diff changeset
   540
		&& iCompletionStatus == eap_status_ok)
hgs
parents:
diff changeset
   541
	{
hgs
parents:
diff changeset
   542
		// ERROR wrong state.
hgs
parents:
diff changeset
   543
		iCompletionStatus = eap_status_wrong_eap_type_state;
hgs
parents:
diff changeset
   544
	}
hgs
parents:
diff changeset
   545
hgs
parents:
diff changeset
   546
	Complete();
hgs
parents:
diff changeset
   547
hgs
parents:
diff changeset
   548
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   549
     (_L("CEapFastPacStoreImpl::complete_create_device_seed end")));  
hgs
parents:
diff changeset
   550
hgs
parents:
diff changeset
   551
	return iCompletionStatus;
hgs
parents:
diff changeset
   552
hgs
parents:
diff changeset
   553
}
hgs
parents:
diff changeset
   554
hgs
parents:
diff changeset
   555
// ----------------------------------------------------------
hgs
parents:
diff changeset
   556
hgs
parents:
diff changeset
   557
eap_status_e CEapFastPacStoreImpl::complete_is_master_key_present(
hgs
parents:
diff changeset
   558
		bool is_present
hgs
parents:
diff changeset
   559
		,const eap_status_e completion_status)
hgs
parents:
diff changeset
   560
{
hgs
parents:
diff changeset
   561
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   562
		iTools,
hgs
parents:
diff changeset
   563
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   564
		(EAPL("CEapFastPacStoreImpl::complete_is_master_key_present(): this=0x%08x, iWaitState=%d\n"),
hgs
parents:
diff changeset
   565
		this,
hgs
parents:
diff changeset
   566
		iWaitState));
hgs
parents:
diff changeset
   567
hgs
parents:
diff changeset
   568
	iIsPresent = is_present;
hgs
parents:
diff changeset
   569
	iCompletionStatus = completion_status;
hgs
parents:
diff changeset
   570
hgs
parents:
diff changeset
   571
	if (iWaitState != eap_fast_pac_store_impl_wait_state_complete_is_master_key_present
hgs
parents:
diff changeset
   572
		&& iCompletionStatus == eap_status_ok)
hgs
parents:
diff changeset
   573
	{
hgs
parents:
diff changeset
   574
		// ERROR wrong state.
hgs
parents:
diff changeset
   575
		iCompletionStatus = eap_status_wrong_eap_type_state;
hgs
parents:
diff changeset
   576
	}
hgs
parents:
diff changeset
   577
	
hgs
parents:
diff changeset
   578
	iIsPresent = is_present;
hgs
parents:
diff changeset
   579
	Complete();
hgs
parents:
diff changeset
   580
hgs
parents:
diff changeset
   581
    EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   582
     (_L("CEapFastPacStoreImpl::complete_is_master_key_present end")));  
hgs
parents:
diff changeset
   583
hgs
parents:
diff changeset
   584
	return iCompletionStatus;
hgs
parents:
diff changeset
   585
hgs
parents:
diff changeset
   586
}
hgs
parents:
diff changeset
   587
hgs
parents:
diff changeset
   588
// ----------------------------------------------------------
hgs
parents:
diff changeset
   589
hgs
parents:
diff changeset
   590
eap_status_e CEapFastPacStoreImpl::complete_is_master_key_and_password_matching(
hgs
parents:
diff changeset
   591
		bool is_matching
hgs
parents:
diff changeset
   592
		,const eap_status_e completion_status)
hgs
parents:
diff changeset
   593
{
hgs
parents:
diff changeset
   594
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   595
		iTools,
hgs
parents:
diff changeset
   596
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   597
		(EAPL("CEapFastPacStoreImpl::complete_is_master_key_and_password_matching(): this=0x%08x, iWaitState=%d\n"),
hgs
parents:
diff changeset
   598
		this,
hgs
parents:
diff changeset
   599
		iWaitState));
hgs
parents:
diff changeset
   600
hgs
parents:
diff changeset
   601
	iCompletionStatus = completion_status;
hgs
parents:
diff changeset
   602
hgs
parents:
diff changeset
   603
	iIsMatching = is_matching;
hgs
parents:
diff changeset
   604
	if (iWaitState != eap_fast_pac_store_impl_wait_state_complete_is_master_key_and_password_matching
hgs
parents:
diff changeset
   605
		&& iCompletionStatus == eap_status_ok)
hgs
parents:
diff changeset
   606
	{
hgs
parents:
diff changeset
   607
		// ERROR wrong state.
hgs
parents:
diff changeset
   608
		iCompletionStatus = eap_status_wrong_eap_type_state;
hgs
parents:
diff changeset
   609
	}
hgs
parents:
diff changeset
   610
	iIsMatching = is_matching;
hgs
parents:
diff changeset
   611
	
hgs
parents:
diff changeset
   612
	Complete();
hgs
parents:
diff changeset
   613
hgs
parents:
diff changeset
   614
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   615
     (_L("CEapFastPacStoreImpl::complete_is_master_key_and_password_matching end")));  
hgs
parents:
diff changeset
   616
hgs
parents:
diff changeset
   617
	return iCompletionStatus;
hgs
parents:
diff changeset
   618
hgs
parents:
diff changeset
   619
}
hgs
parents:
diff changeset
   620
hgs
parents:
diff changeset
   621
// ----------------------------------------------------------
hgs
parents:
diff changeset
   622
hgs
parents:
diff changeset
   623
eap_status_e CEapFastPacStoreImpl::complete_create_and_save_master_key(
hgs
parents:
diff changeset
   624
		const eap_status_e completion_status)
hgs
parents:
diff changeset
   625
{
hgs
parents:
diff changeset
   626
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   627
		iTools,
hgs
parents:
diff changeset
   628
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   629
		(EAPL("CEapFastPacStoreImpl::complete_create_and_save_master_key(): this=0x%08x, iWaitState=%d\n"),
hgs
parents:
diff changeset
   630
		this,
hgs
parents:
diff changeset
   631
		iWaitState));
hgs
parents:
diff changeset
   632
hgs
parents:
diff changeset
   633
	iCompletionStatus = completion_status;
hgs
parents:
diff changeset
   634
hgs
parents:
diff changeset
   635
	if (iWaitState != eap_fast_pac_store_impl_wait_state_complete_create_and_save_master_key
hgs
parents:
diff changeset
   636
		&& iCompletionStatus == eap_status_ok)
hgs
parents:
diff changeset
   637
	{
hgs
parents:
diff changeset
   638
		// ERROR wrong state.
hgs
parents:
diff changeset
   639
		iCompletionStatus = eap_status_wrong_eap_type_state;
hgs
parents:
diff changeset
   640
	}
hgs
parents:
diff changeset
   641
hgs
parents:
diff changeset
   642
	Complete();
hgs
parents:
diff changeset
   643
hgs
parents:
diff changeset
   644
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   645
     (_L("CEapFastPacStoreImpl::complete_create_and_save_master_key end")));  
hgs
parents:
diff changeset
   646
hgs
parents:
diff changeset
   647
	return iCompletionStatus;
hgs
parents:
diff changeset
   648
hgs
parents:
diff changeset
   649
}
hgs
parents:
diff changeset
   650
hgs
parents:
diff changeset
   651
// ----------------------------------------------------------
hgs
parents:
diff changeset
   652
hgs
parents:
diff changeset
   653
eap_status_e CEapFastPacStoreImpl::complete_compare_pac_store_password(
hgs
parents:
diff changeset
   654
		bool is_matching)
hgs
parents:
diff changeset
   655
{
hgs
parents:
diff changeset
   656
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   657
		iTools,
hgs
parents:
diff changeset
   658
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   659
		(EAPL("CEapFastPacStoreImpl::complete_compare_pac_store_password(): this=0x%08x, iWaitState=%d\n"),
hgs
parents:
diff changeset
   660
		this,
hgs
parents:
diff changeset
   661
		iWaitState));
hgs
parents:
diff changeset
   662
hgs
parents:
diff changeset
   663
	iCompletionStatus = eap_status_ok;
hgs
parents:
diff changeset
   664
hgs
parents:
diff changeset
   665
	if (iWaitState != eap_fast_pac_store_impl_wait_state_complete_compare_pac_store_password)
hgs
parents:
diff changeset
   666
	{
hgs
parents:
diff changeset
   667
		// ERROR wrong state.
hgs
parents:
diff changeset
   668
		iCompletionStatus = eap_status_wrong_eap_type_state;
hgs
parents:
diff changeset
   669
	}
hgs
parents:
diff changeset
   670
hgs
parents:
diff changeset
   671
	iIsPwMatching = is_matching;
hgs
parents:
diff changeset
   672
	Complete();
hgs
parents:
diff changeset
   673
hgs
parents:
diff changeset
   674
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   675
     (_L("CEapFastPacStoreImpl::complete_compare_pac_store_password end")));  
hgs
parents:
diff changeset
   676
hgs
parents:
diff changeset
   677
	return iCompletionStatus;
hgs
parents:
diff changeset
   678
hgs
parents:
diff changeset
   679
}
hgs
parents:
diff changeset
   680
hgs
parents:
diff changeset
   681
// ----------------------------------------------------------
hgs
parents:
diff changeset
   682
hgs
parents:
diff changeset
   683
eap_status_e CEapFastPacStoreImpl::complete_is_pacstore_password_present(
hgs
parents:
diff changeset
   684
		bool is_present)
hgs
parents:
diff changeset
   685
{
hgs
parents:
diff changeset
   686
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   687
		iTools,
hgs
parents:
diff changeset
   688
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   689
		(EAPL("CEapFastPacStoreImpl::complete_is_pacstore_password_present(): this=0x%08x, iWaitState=%d\n"),
hgs
parents:
diff changeset
   690
		this,
hgs
parents:
diff changeset
   691
		iWaitState));
hgs
parents:
diff changeset
   692
hgs
parents:
diff changeset
   693
	iCompletionStatus = eap_status_ok;
hgs
parents:
diff changeset
   694
hgs
parents:
diff changeset
   695
	if (iWaitState != eap_fast_pac_store_impl_wait_state_complete_is_pacstore_password_present)
hgs
parents:
diff changeset
   696
	{
hgs
parents:
diff changeset
   697
		// ERROR wrong state.
hgs
parents:
diff changeset
   698
		iCompletionStatus = eap_status_wrong_eap_type_state;
hgs
parents:
diff changeset
   699
	}
hgs
parents:
diff changeset
   700
hgs
parents:
diff changeset
   701
	iIsPwPresent = is_present;
hgs
parents:
diff changeset
   702
	Complete();
hgs
parents:
diff changeset
   703
hgs
parents:
diff changeset
   704
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   705
     (_L("CEapFastPacStoreImpl::complete_is_pacstore_password_present end")));  
hgs
parents:
diff changeset
   706
hgs
parents:
diff changeset
   707
	return iCompletionStatus;
hgs
parents:
diff changeset
   708
hgs
parents:
diff changeset
   709
}
hgs
parents:
diff changeset
   710
// ----------------------------------------------------------
hgs
parents:
diff changeset
   711
hgs
parents:
diff changeset
   712
eap_status_e CEapFastPacStoreImpl::complete_set_pac_store_password(
hgs
parents:
diff changeset
   713
		const eap_status_e completion_status)
hgs
parents:
diff changeset
   714
{
hgs
parents:
diff changeset
   715
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   716
		iTools,
hgs
parents:
diff changeset
   717
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   718
		(EAPL("CEapFastPacStoreImpl::complete_set_pac_store_password(): this=0x%08x, iWaitState=%d\n"),
hgs
parents:
diff changeset
   719
		this,
hgs
parents:
diff changeset
   720
		iWaitState));
hgs
parents:
diff changeset
   721
hgs
parents:
diff changeset
   722
	iCompletionStatus = completion_status;
hgs
parents:
diff changeset
   723
hgs
parents:
diff changeset
   724
	if (iWaitState != eap_fast_pac_store_impl_wait_state_complete_set_pac_store_password
hgs
parents:
diff changeset
   725
		&& iCompletionStatus == eap_status_ok)
hgs
parents:
diff changeset
   726
	{
hgs
parents:
diff changeset
   727
		// ERROR wrong state.
hgs
parents:
diff changeset
   728
		iCompletionStatus = eap_status_wrong_eap_type_state;
hgs
parents:
diff changeset
   729
	}
hgs
parents:
diff changeset
   730
hgs
parents:
diff changeset
   731
	Complete();
hgs
parents:
diff changeset
   732
hgs
parents:
diff changeset
   733
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   734
     (_L("CEapFastPacStoreImpl::complete_set_pac_store_password end")));  
hgs
parents:
diff changeset
   735
hgs
parents:
diff changeset
   736
	return iCompletionStatus;
hgs
parents:
diff changeset
   737
hgs
parents:
diff changeset
   738
}
hgs
parents:
diff changeset
   739
hgs
parents:
diff changeset
   740
// ----------------------------------------------------------
hgs
parents:
diff changeset
   741
hgs
parents:
diff changeset
   742
eap_status_e CEapFastPacStoreImpl::complete_destroy_pac_store(
hgs
parents:
diff changeset
   743
		const eap_status_e completion_status)
hgs
parents:
diff changeset
   744
{
hgs
parents:
diff changeset
   745
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   746
		iTools,
hgs
parents:
diff changeset
   747
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   748
		(EAPL("CEapFastPacStoreImpl::complete_destroy_pac_store(): this=0x%08x, iWaitState=%d\n"),
hgs
parents:
diff changeset
   749
		this,
hgs
parents:
diff changeset
   750
		iWaitState));
hgs
parents:
diff changeset
   751
hgs
parents:
diff changeset
   752
	iCompletionStatus = completion_status;
hgs
parents:
diff changeset
   753
hgs
parents:
diff changeset
   754
	if (iWaitState != eap_fast_pac_store_impl_wait_state_complete_destroy_pac_store
hgs
parents:
diff changeset
   755
		&& iCompletionStatus == eap_status_ok)
hgs
parents:
diff changeset
   756
	{
hgs
parents:
diff changeset
   757
		// ERROR wrong state.
hgs
parents:
diff changeset
   758
		iCompletionStatus = eap_status_wrong_eap_type_state;
hgs
parents:
diff changeset
   759
	}
hgs
parents:
diff changeset
   760
hgs
parents:
diff changeset
   761
	Complete();
hgs
parents:
diff changeset
   762
hgs
parents:
diff changeset
   763
  EAP_TRACE_DEBUG_SYMBIAN(
hgs
parents:
diff changeset
   764
     (_L("CEapFastPacStoreImpl::complete_destroy_pac_store end")));  
hgs
parents:
diff changeset
   765
hgs
parents:
diff changeset
   766
	return iCompletionStatus;
hgs
parents:
diff changeset
   767
hgs
parents:
diff changeset
   768
}
hgs
parents:
diff changeset
   769
hgs
parents:
diff changeset
   770
// ----------------------------------------------------------
hgs
parents:
diff changeset
   771
hgs
parents:
diff changeset
   772
eap_am_message_if_c * eap_am_message_if_c::new_eap_am_message_if_c(
hgs
parents:
diff changeset
   773
	abs_eap_am_tools_c * const tools)
hgs
parents:
diff changeset
   774
{
hgs
parents:
diff changeset
   775
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   776
		tools,
hgs
parents:
diff changeset
   777
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   778
		(EAPL("eap_am_message_if_c::new_eap_am_server_pac_store_message_c()\n")));
hgs
parents:
diff changeset
   779
hgs
parents:
diff changeset
   780
    eap_am_message_if_c *client_if = new eap_am_message_if_symbian_c(tools, EEapPacStoreNew);
hgs
parents:
diff changeset
   781
hgs
parents:
diff changeset
   782
	eap_automatic_variable_c<eap_am_message_if_c> automatic_client_if(
hgs
parents:
diff changeset
   783
		tools,
hgs
parents:
diff changeset
   784
		client_if);
hgs
parents:
diff changeset
   785
hgs
parents:
diff changeset
   786
	if (client_if == 0
hgs
parents:
diff changeset
   787
		|| client_if->get_is_valid() == false)
hgs
parents:
diff changeset
   788
	{
hgs
parents:
diff changeset
   789
		// ERROR.
hgs
parents:
diff changeset
   790
		if (client_if != 0)
hgs
parents:
diff changeset
   791
		{
hgs
parents:
diff changeset
   792
			EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   793
				tools,
hgs
parents:
diff changeset
   794
				TRACE_FLAGS_ALWAYS|TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   795
				(EAPL("ERROR: calls: eap_am_message_if_c::new_eap_am_server_general_settings_c(): client_if->shutdown()\n")));
hgs
parents:
diff changeset
   796
hgs
parents:
diff changeset
   797
			client_if->shutdown();
hgs
parents:
diff changeset
   798
		}
hgs
parents:
diff changeset
   799
		return 0;
hgs
parents:
diff changeset
   800
	}
hgs
parents:
diff changeset
   801
hgs
parents:
diff changeset
   802
	automatic_client_if.do_not_free_variable();
hgs
parents:
diff changeset
   803
hgs
parents:
diff changeset
   804
	return client_if;
hgs
parents:
diff changeset
   805
hgs
parents:
diff changeset
   806
}
hgs
parents:
diff changeset
   807
hgs
parents:
diff changeset
   808
// ----------------------------------------------------------
hgs
parents:
diff changeset
   809
hgs
parents:
diff changeset
   810
EAP_FUNC_EXPORT eap_pac_store_message_base_c * eap_pac_store_message_base_c::new_eap_pac_store_client_message_if_c(
hgs
parents:
diff changeset
   811
	abs_eap_am_tools_c * const tools,
hgs
parents:
diff changeset
   812
	abs_eap_pac_store_message_c * const partner)
hgs
parents:
diff changeset
   813
{
hgs
parents:
diff changeset
   814
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   815
		tools,
hgs
parents:
diff changeset
   816
		TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   817
		(EAPL("eap_pac_store_message_base_c::new_eap_pac_store_client_message_if_c()\n")));
hgs
parents:
diff changeset
   818
hgs
parents:
diff changeset
   819
	eap_am_message_if_c *client_if = eap_am_message_if_c::new_eap_am_message_if_c(
hgs
parents:
diff changeset
   820
		tools);
hgs
parents:
diff changeset
   821
hgs
parents:
diff changeset
   822
	eap_automatic_variable_c<eap_am_message_if_c> automatic_client_if(
hgs
parents:
diff changeset
   823
		tools,
hgs
parents:
diff changeset
   824
		client_if);
hgs
parents:
diff changeset
   825
hgs
parents:
diff changeset
   826
	if (client_if == 0
hgs
parents:
diff changeset
   827
		|| client_if->get_is_valid() == false)
hgs
parents:
diff changeset
   828
	{
hgs
parents:
diff changeset
   829
		// ERROR.
hgs
parents:
diff changeset
   830
		if (client_if != 0)
hgs
parents:
diff changeset
   831
		{
hgs
parents:
diff changeset
   832
			EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   833
				tools,
hgs
parents:
diff changeset
   834
				TRACE_FLAGS_ALWAYS|TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   835
				(EAPL("ERROR: calls: eap_pac_store_message_base_c::new_eap_pac_store_client_message_if_c(): client_if->shutdown()\n")));
hgs
parents:
diff changeset
   836
hgs
parents:
diff changeset
   837
			(void) client_if->shutdown();
hgs
parents:
diff changeset
   838
		}
hgs
parents:
diff changeset
   839
		return 0;
hgs
parents:
diff changeset
   840
	}
hgs
parents:
diff changeset
   841
hgs
parents:
diff changeset
   842
	eap_pac_store_client_message_if_c * new_session_core = new eap_pac_store_client_message_if_c(tools, client_if, partner);
hgs
parents:
diff changeset
   843
hgs
parents:
diff changeset
   844
	eap_automatic_variable_c<eap_pac_store_client_message_if_c> automatic_new_session_core(
hgs
parents:
diff changeset
   845
		tools,
hgs
parents:
diff changeset
   846
		new_session_core);
hgs
parents:
diff changeset
   847
hgs
parents:
diff changeset
   848
	if (new_session_core == 0
hgs
parents:
diff changeset
   849
		|| new_session_core->get_is_valid() == false)
hgs
parents:
diff changeset
   850
	{
hgs
parents:
diff changeset
   851
		// ERROR.
hgs
parents:
diff changeset
   852
		if (new_session_core != 0)
hgs
parents:
diff changeset
   853
		{
hgs
parents:
diff changeset
   854
			EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   855
				tools,
hgs
parents:
diff changeset
   856
				TRACE_FLAGS_ALWAYS|TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
   857
				(EAPL("ERROR: calls: eap_pac_store_message_base_c::new_eap_pac_store_client_message_if_c(): new_session_core->shutdown()\n")));
hgs
parents:
diff changeset
   858
hgs
parents:
diff changeset
   859
			new_session_core->shutdown();
hgs
parents:
diff changeset
   860
		}
hgs
parents:
diff changeset
   861
		return 0;
hgs
parents:
diff changeset
   862
	}
hgs
parents:
diff changeset
   863
hgs
parents:
diff changeset
   864
	client_if->set_partner(new_session_core);
hgs
parents:
diff changeset
   865
hgs
parents:
diff changeset
   866
	automatic_client_if.do_not_free_variable();
hgs
parents:
diff changeset
   867
	automatic_new_session_core.do_not_free_variable();
hgs
parents:
diff changeset
   868
hgs
parents:
diff changeset
   869
	return new_session_core;
hgs
parents:
diff changeset
   870
}
hgs
parents:
diff changeset
   871
hgs
parents:
diff changeset
   872
hgs
parents:
diff changeset
   873
// ----------------------------------------------------------
hgs
parents:
diff changeset
   874
hgs
parents:
diff changeset
   875