eapol/eapol_framework/eapol_common/core/eap_core_server_message_if.cpp
author hgs
Thu, 16 Sep 2010 13:07:04 +0300
changeset 49 43351a4f2da3
parent 36 c98682f98478
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-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
/*
49
hgs
parents: 36
diff changeset
    19
* %version: 36 %
26
hgs
parents:
diff changeset
    20
*/
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
// This is enumeration of EAPOL source code.
hgs
parents:
diff changeset
    23
#if defined(USE_EAP_MINIMUM_RELEASE_TRACES)
hgs
parents:
diff changeset
    24
	#undef EAP_FILE_NUMBER_ENUM
hgs
parents:
diff changeset
    25
	#define EAP_FILE_NUMBER_ENUM 48 
hgs
parents:
diff changeset
    26
	#undef EAP_FILE_NUMBER_DATE 
hgs
parents:
diff changeset
    27
	#define EAP_FILE_NUMBER_DATE 1127594498 
hgs
parents:
diff changeset
    28
#endif //#if defined(USE_EAP_MINIMUM_RELEASE_TRACES)
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
#include "eap_am_memory.h"
hgs
parents:
diff changeset
    33
#include "eap_tools.h"
hgs
parents:
diff changeset
    34
#include "eap_core_server_message_if.h"
hgs
parents:
diff changeset
    35
#include "eap_crypto_api.h"
hgs
parents:
diff changeset
    36
#include "eap_state_notification.h"
hgs
parents:
diff changeset
    37
#include "eap_automatic_variable.h"
hgs
parents:
diff changeset
    38
#include "eap_network_id_selector.h"
hgs
parents:
diff changeset
    39
#include "eap_config.h"
hgs
parents:
diff changeset
    40
#include "eap_buffer.h"
hgs
parents:
diff changeset
    41
#include "eapol_session_key.h"
hgs
parents:
diff changeset
    42
#include "eap_master_session_key.h"
hgs
parents:
diff changeset
    43
#include "eap_am_stack.h"
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
//--------------------------------------------------
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
// 
hgs
parents:
diff changeset
    48
EAP_FUNC_EXPORT eap_core_server_message_if_c::~eap_core_server_message_if_c()
hgs
parents:
diff changeset
    49
{
hgs
parents:
diff changeset
    50
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
    53
		m_am_tools, 
49
hgs
parents: 36
diff changeset
    54
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
    55
		(EAPL("eap_core_server_message_if_c::~eap_core_server_message_if_c(): this = 0x%08x\n"),
hgs
parents:
diff changeset
    56
		this));
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
	EAP_ASSERT(m_shutdown_was_called == true);
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
	delete m_eap_core;
hgs
parents:
diff changeset
    61
	delete m_am_stack;
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
    64
}
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
//--------------------------------------------------
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
#if defined(_WIN32) && !defined(__GNUC__)
hgs
parents:
diff changeset
    69
	#pragma warning( disable : 4355 ) // 'this' : used in base member initializer list
hgs
parents:
diff changeset
    70
#endif
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
// 
hgs
parents:
diff changeset
    73
EAP_FUNC_EXPORT eap_core_server_message_if_c::eap_core_server_message_if_c(
hgs
parents:
diff changeset
    74
	abs_eap_am_tools_c * const tools,
hgs
parents:
diff changeset
    75
	const bool is_client_when_true,
hgs
parents:
diff changeset
    76
	const u32_t MTU)
hgs
parents:
diff changeset
    77
	: m_partner(0)
hgs
parents:
diff changeset
    78
	, m_eap_core(eap_session_core_base_c::new_eap_session_core_c(tools, this, is_client_when_true, MTU))
hgs
parents:
diff changeset
    79
	, m_am_stack(new_eap_am_stack_c(tools, is_client_when_true))
hgs
parents:
diff changeset
    80
	, m_am_tools(tools)
hgs
parents:
diff changeset
    81
	, m_eap_header_offset(0u)
hgs
parents:
diff changeset
    82
	, m_MTU(MTU)
hgs
parents:
diff changeset
    83
	, m_trailer_length(0u)
hgs
parents:
diff changeset
    84
	, m_error_code(eap_status_ok)
hgs
parents:
diff changeset
    85
	, m_error_function(eap_tlv_message_type_function_none)
hgs
parents:
diff changeset
    86
	, m_is_client(is_client_when_true)
hgs
parents:
diff changeset
    87
	, m_is_valid(false)
hgs
parents:
diff changeset
    88
	, m_shutdown_was_called(false)
hgs
parents:
diff changeset
    89
{
hgs
parents:
diff changeset
    90
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
    93
		m_am_tools, 
49
hgs
parents: 36
diff changeset
    94
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
    95
		(EAPL("eap_core_server_message_if_c::eap_core_server_message_if_c(): %s, this = 0x%08x => 0x%08x, compiled %s %s.\n"),
hgs
parents:
diff changeset
    96
		(m_is_client == true) ? "client": "server",
hgs
parents:
diff changeset
    97
		this,
hgs
parents:
diff changeset
    98
		dynamic_cast<abs_eap_base_timer_c *>(this),
hgs
parents:
diff changeset
    99
		__DATE__,
hgs
parents:
diff changeset
   100
		__TIME__));
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
	if (m_eap_core != 0
hgs
parents:
diff changeset
   103
		&& m_eap_core->get_is_valid() == true
hgs
parents:
diff changeset
   104
		&& m_am_stack != 0
hgs
parents:
diff changeset
   105
		&& m_am_stack->get_is_valid() == true)
hgs
parents:
diff changeset
   106
	{
hgs
parents:
diff changeset
   107
		set_is_valid();
hgs
parents:
diff changeset
   108
	}
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   111
}
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
//--------------------------------------------------
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
//
hgs
parents:
diff changeset
   116
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::configure(
hgs
parents:
diff changeset
   117
	const eap_variable_data_c * const client_configuration)
hgs
parents:
diff changeset
   118
{
hgs
parents:
diff changeset
   119
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   122
		m_am_tools,
49
hgs
parents: 36
diff changeset
   123
		TRACE_FLAGS_DEFAULT,
26
hgs
parents:
diff changeset
   124
		(EAPL("%s: eap_core_server_message_if_c::configure()\n"),
hgs
parents:
diff changeset
   125
		(m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   126
49
hgs
parents: 36
diff changeset
   127
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::configure()");
26
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
	m_eap_header_offset = 0ul;
hgs
parents:
diff changeset
   132
	m_trailer_length = 0ul;
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
	if (m_am_stack != 0)
hgs
parents:
diff changeset
   135
	{
hgs
parents:
diff changeset
   136
		status = m_am_stack->set_partner(
hgs
parents:
diff changeset
   137
			this
hgs
parents:
diff changeset
   138
#if defined(USE_EAP_SIMPLE_CONFIG)
hgs
parents:
diff changeset
   139
			, this
hgs
parents:
diff changeset
   140
#endif // #if defined(USE_EAP_SIMPLE_CONFIG)
hgs
parents:
diff changeset
   141
			);
hgs
parents:
diff changeset
   142
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   143
		{
hgs
parents:
diff changeset
   144
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   145
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   146
		}
hgs
parents:
diff changeset
   147
hgs
parents:
diff changeset
   148
		status = m_am_stack->configure(client_configuration);
hgs
parents:
diff changeset
   149
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   150
		{
hgs
parents:
diff changeset
   151
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   152
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   153
		}
hgs
parents:
diff changeset
   154
	}
hgs
parents:
diff changeset
   155
	
hgs
parents:
diff changeset
   156
	if (m_eap_core != 0)
hgs
parents:
diff changeset
   157
	{
hgs
parents:
diff changeset
   158
		status = m_eap_core->configure();
hgs
parents:
diff changeset
   159
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   160
		{
hgs
parents:
diff changeset
   161
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   162
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   163
		}
hgs
parents:
diff changeset
   164
	}
hgs
parents:
diff changeset
   165
hgs
parents:
diff changeset
   166
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   167
}
hgs
parents:
diff changeset
   168
hgs
parents:
diff changeset
   169
//--------------------------------------------------
hgs
parents:
diff changeset
   170
hgs
parents:
diff changeset
   171
//
hgs
parents:
diff changeset
   172
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::shutdown()
hgs
parents:
diff changeset
   173
{
hgs
parents:
diff changeset
   174
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   175
		m_am_tools,
49
hgs
parents: 36
diff changeset
   176
		TRACE_FLAGS_DEFAULT,
26
hgs
parents:
diff changeset
   177
		(EAPL("%s: eap_core_server_message_if_c::shutdown(), m_shutdown_was_called=%d\n"),
hgs
parents:
diff changeset
   178
		(m_is_client == true) ? "client": "server",
hgs
parents:
diff changeset
   179
		m_shutdown_was_called));
hgs
parents:
diff changeset
   180
49
hgs
parents: 36
diff changeset
   181
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::shutdown()");
26
hgs
parents:
diff changeset
   182
hgs
parents:
diff changeset
   183
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
	if (m_shutdown_was_called == true)
hgs
parents:
diff changeset
   186
	{
hgs
parents:
diff changeset
   187
		// Shutdown function was called already.
hgs
parents:
diff changeset
   188
		return EAP_STATUS_RETURN(m_am_tools, eap_status_ok);
hgs
parents:
diff changeset
   189
	}
hgs
parents:
diff changeset
   190
	m_shutdown_was_called = true;
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
	if (m_eap_core != 0)
hgs
parents:
diff changeset
   193
	{
hgs
parents:
diff changeset
   194
		(void) m_eap_core->shutdown();
hgs
parents:
diff changeset
   195
	}
hgs
parents:
diff changeset
   196
hgs
parents:
diff changeset
   197
	if (m_am_stack != 0)
hgs
parents:
diff changeset
   198
	{
hgs
parents:
diff changeset
   199
		(void) m_am_stack->shutdown();
hgs
parents:
diff changeset
   200
	}
hgs
parents:
diff changeset
   201
hgs
parents:
diff changeset
   202
	return EAP_STATUS_RETURN(m_am_tools, eap_status_ok);
hgs
parents:
diff changeset
   203
}
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
//--------------------------------------------------
hgs
parents:
diff changeset
   206
hgs
parents:
diff changeset
   207
//
hgs
parents:
diff changeset
   208
EAP_FUNC_EXPORT void eap_core_server_message_if_c::set_partner(abs_eap_am_message_if_c * const partner)
hgs
parents:
diff changeset
   209
{
hgs
parents:
diff changeset
   210
	m_partner = partner;
hgs
parents:
diff changeset
   211
}
hgs
parents:
diff changeset
   212
hgs
parents:
diff changeset
   213
//--------------------------------------------------
hgs
parents:
diff changeset
   214
hgs
parents:
diff changeset
   215
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::send_error_message(
hgs
parents:
diff changeset
   216
	const eap_status_e error_code,
hgs
parents:
diff changeset
   217
	const eap_tlv_message_type_function_e function)
hgs
parents:
diff changeset
   218
{
49
hgs
parents: 36
diff changeset
   219
	EAP_TRACE_DEBUG(
hgs
parents: 36
diff changeset
   220
		m_am_tools, 
hgs
parents: 36
diff changeset
   221
		TRACE_FLAGS_DEFAULT, 
hgs
parents: 36
diff changeset
   222
		(EAPL("%s: eap_core_server_message_if_c::send_error_message()\n"),
hgs
parents: 36
diff changeset
   223
		 (m_is_client == true) ? "client": "server"));
hgs
parents: 36
diff changeset
   224
hgs
parents: 36
diff changeset
   225
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::send_error_message()");
hgs
parents: 36
diff changeset
   226
26
hgs
parents:
diff changeset
   227
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   228
hgs
parents:
diff changeset
   229
	{
hgs
parents:
diff changeset
   230
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   231
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
   232
hgs
parents:
diff changeset
   233
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
   234
		{
hgs
parents:
diff changeset
   235
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   236
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   237
		}
hgs
parents:
diff changeset
   238
hgs
parents:
diff changeset
   239
		status = message.add_parameter_data(
hgs
parents:
diff changeset
   240
			eap_tlv_message_type_error,
hgs
parents:
diff changeset
   241
			static_cast<u32_t>(error_code));
hgs
parents:
diff changeset
   242
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   243
		{
hgs
parents:
diff changeset
   244
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   245
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   246
		}
hgs
parents:
diff changeset
   247
hgs
parents:
diff changeset
   248
		status = message.add_parameter_data(function);
hgs
parents:
diff changeset
   249
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   250
		{
hgs
parents:
diff changeset
   251
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   252
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   253
		}
hgs
parents:
diff changeset
   254
hgs
parents:
diff changeset
   255
		status = send_message(&message);
hgs
parents:
diff changeset
   256
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   257
		{
hgs
parents:
diff changeset
   258
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   259
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   260
		}
hgs
parents:
diff changeset
   261
	}
hgs
parents:
diff changeset
   262
hgs
parents:
diff changeset
   263
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   264
	return EAP_STATUS_RETURN(m_am_tools, eap_status_ok);
hgs
parents:
diff changeset
   265
}
hgs
parents:
diff changeset
   266
hgs
parents:
diff changeset
   267
//--------------------------------------------------
hgs
parents:
diff changeset
   268
hgs
parents:
diff changeset
   269
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::send_message(eap_process_tlv_message_data_c * const message)
hgs
parents:
diff changeset
   270
{
hgs
parents:
diff changeset
   271
	// Sends message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   272
36
hgs
parents: 34
diff changeset
   273
	EAP_TRACE_DEBUG(
hgs
parents: 34
diff changeset
   274
		m_am_tools, 
49
hgs
parents: 36
diff changeset
   275
		TRACE_FLAGS_DEFAULT, 
36
hgs
parents: 34
diff changeset
   276
		(EAPL("eap_core_server_message_if_c::send_message(): this = 0x%08x => 0x%08x.\n"),
hgs
parents: 34
diff changeset
   277
		this,
hgs
parents: 34
diff changeset
   278
		dynamic_cast<abs_eap_base_timer_c *>(this)));
hgs
parents: 34
diff changeset
   279
26
hgs
parents:
diff changeset
   280
	EAP_TRACE_DATA_DEBUG(
hgs
parents:
diff changeset
   281
		m_am_tools,
36
hgs
parents: 34
diff changeset
   282
		EAP_TRACE_FLAGS_NEVER,
26
hgs
parents:
diff changeset
   283
		(EAPL("eap_core_client_message_if_c::send_message()"),
hgs
parents:
diff changeset
   284
		message->get_message_data(),
hgs
parents:
diff changeset
   285
		message->get_message_data_length()));
hgs
parents:
diff changeset
   286
49
hgs
parents: 36
diff changeset
   287
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_client_message_if_c::send_message()");
26
hgs
parents:
diff changeset
   288
hgs
parents:
diff changeset
   289
hgs
parents:
diff changeset
   290
	{
hgs
parents:
diff changeset
   291
		eap_status_e send_status = m_partner->send_data(
hgs
parents:
diff changeset
   292
			message->get_message_data(),
hgs
parents:
diff changeset
   293
			message->get_message_data_length());
hgs
parents:
diff changeset
   294
		if (send_status != eap_status_ok)
hgs
parents:
diff changeset
   295
		{
hgs
parents:
diff changeset
   296
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   297
			return EAP_STATUS_RETURN(m_am_tools, send_status);
hgs
parents:
diff changeset
   298
		}
hgs
parents:
diff changeset
   299
hgs
parents:
diff changeset
   300
hgs
parents:
diff changeset
   301
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   302
		return EAP_STATUS_RETURN(m_am_tools, send_status);
hgs
parents:
diff changeset
   303
	}
hgs
parents:
diff changeset
   304
hgs
parents:
diff changeset
   305
}
hgs
parents:
diff changeset
   306
hgs
parents:
diff changeset
   307
//--------------------------------------------------
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::process_message_type_error(
hgs
parents:
diff changeset
   310
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
   311
{
49
hgs
parents: 36
diff changeset
   312
	EAP_TRACE_DEBUG(
hgs
parents: 36
diff changeset
   313
		m_am_tools, 
hgs
parents: 36
diff changeset
   314
		TRACE_FLAGS_DEFAULT, 
hgs
parents: 36
diff changeset
   315
		(EAPL("%s: eap_core_server_message_if_c::process_message_type_error()\n"),
hgs
parents: 36
diff changeset
   316
		 (m_is_client == true) ? "client": "server"));
hgs
parents: 36
diff changeset
   317
hgs
parents: 36
diff changeset
   318
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::process_message_type_error()");
hgs
parents: 36
diff changeset
   319
26
hgs
parents:
diff changeset
   320
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   321
hgs
parents:
diff changeset
   322
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
   323
hgs
parents:
diff changeset
   324
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
   325
	{
hgs
parents:
diff changeset
   326
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   327
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   328
	}
hgs
parents:
diff changeset
   329
hgs
parents:
diff changeset
   330
	// Error payload is the first in this case.
hgs
parents:
diff changeset
   331
	status = message_data.read_parameter_data(parameters, eap_message_payload_index_function, eap_tlv_message_type_error, &m_error_code);
hgs
parents:
diff changeset
   332
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   333
	{
hgs
parents:
diff changeset
   334
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   335
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   336
	}
hgs
parents:
diff changeset
   337
hgs
parents:
diff changeset
   338
	// Fuction payload is the second in this case.
hgs
parents:
diff changeset
   339
	status = message_data.read_parameter_data(parameters, eap_message_payload_index_first_parameter, &m_error_function);
hgs
parents:
diff changeset
   340
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   341
	{
hgs
parents:
diff changeset
   342
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   343
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   344
	}
hgs
parents:
diff changeset
   345
hgs
parents:
diff changeset
   346
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   347
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   348
}
hgs
parents:
diff changeset
   349
hgs
parents:
diff changeset
   350
//--------------------------------------------------
hgs
parents:
diff changeset
   351
hgs
parents:
diff changeset
   352
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::process_message(eap_process_tlv_message_data_c * const message)
hgs
parents:
diff changeset
   353
{
hgs
parents:
diff changeset
   354
	// Parses message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   355
49
hgs
parents: 36
diff changeset
   356
	EAP_TRACE_DEBUG(
hgs
parents: 36
diff changeset
   357
		m_am_tools, 
hgs
parents: 36
diff changeset
   358
		TRACE_FLAGS_DEFAULT, 
hgs
parents: 36
diff changeset
   359
		(EAPL("%s: eap_core_server_message_if_c::process_message()\n"),
hgs
parents: 36
diff changeset
   360
		 (m_is_client == true) ? "client": "server"));
hgs
parents: 36
diff changeset
   361
hgs
parents: 36
diff changeset
   362
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::process_message()");
hgs
parents: 36
diff changeset
   363
26
hgs
parents:
diff changeset
   364
	EAP_TRACE_DATA_DEBUG(
hgs
parents:
diff changeset
   365
		m_am_tools,
49
hgs
parents: 36
diff changeset
   366
		EAP_TRACE_FLAGS_NEVER,
26
hgs
parents:
diff changeset
   367
		(EAPL("eap_core_server_message_if_c::process_message()"),
hgs
parents:
diff changeset
   368
		message->get_message_data(),
hgs
parents:
diff changeset
   369
		message->get_message_data_length()));
hgs
parents:
diff changeset
   370
hgs
parents:
diff changeset
   371
	eap_array_c<eap_tlv_header_c> parameters(m_am_tools);
hgs
parents:
diff changeset
   372
hgs
parents:
diff changeset
   373
	eap_status_e status = message->parse_message_data(&parameters);
hgs
parents:
diff changeset
   374
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   375
	{
hgs
parents:
diff changeset
   376
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   377
hgs
parents:
diff changeset
   378
		(void) send_error_message(
hgs
parents:
diff changeset
   379
			status,
hgs
parents:
diff changeset
   380
			eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   381
hgs
parents:
diff changeset
   382
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   383
	}
hgs
parents:
diff changeset
   384
hgs
parents:
diff changeset
   385
	if (parameters.get_object_count() == 0)
hgs
parents:
diff changeset
   386
	{
hgs
parents:
diff changeset
   387
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   388
hgs
parents:
diff changeset
   389
		status = eap_status_illegal_parameter;
hgs
parents:
diff changeset
   390
hgs
parents:
diff changeset
   391
		(void) send_error_message(
hgs
parents:
diff changeset
   392
			status,
hgs
parents:
diff changeset
   393
			eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   394
hgs
parents:
diff changeset
   395
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   396
	}
hgs
parents:
diff changeset
   397
hgs
parents:
diff changeset
   398
	const eap_tlv_header_c * const function_header = parameters.get_object(eap_message_payload_index_function);
hgs
parents:
diff changeset
   399
	if (function_header == 0
hgs
parents:
diff changeset
   400
		|| (function_header->get_type() != eap_tlv_message_type_error
hgs
parents:
diff changeset
   401
			&& function_header->get_type() != eap_tlv_message_type_function))
hgs
parents:
diff changeset
   402
	{
hgs
parents:
diff changeset
   403
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   404
hgs
parents:
diff changeset
   405
		status = eap_status_illegal_parameter;
hgs
parents:
diff changeset
   406
hgs
parents:
diff changeset
   407
		(void) send_error_message(
hgs
parents:
diff changeset
   408
			status,
hgs
parents:
diff changeset
   409
			eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   410
hgs
parents:
diff changeset
   411
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   412
	}
hgs
parents:
diff changeset
   413
hgs
parents:
diff changeset
   414
	if (function_header->get_type() == eap_tlv_message_type_error)
hgs
parents:
diff changeset
   415
	{
hgs
parents:
diff changeset
   416
		status = process_message_type_error(&parameters);
hgs
parents:
diff changeset
   417
	}
hgs
parents:
diff changeset
   418
	else // function_header->get_type() == eap_tlv_message_type_function
hgs
parents:
diff changeset
   419
	{
hgs
parents:
diff changeset
   420
		eap_tlv_message_type_function_e function(eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   421
hgs
parents:
diff changeset
   422
		status = message->get_parameter_data(function_header, &function);
hgs
parents:
diff changeset
   423
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   424
		{
hgs
parents:
diff changeset
   425
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   426
hgs
parents:
diff changeset
   427
			(void) send_error_message(
hgs
parents:
diff changeset
   428
				status,
hgs
parents:
diff changeset
   429
				eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   430
hgs
parents:
diff changeset
   431
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   432
		}
hgs
parents:
diff changeset
   433
49
hgs
parents: 36
diff changeset
   434
		EAP_TRACE_DEBUG(
hgs
parents: 36
diff changeset
   435
			m_am_tools, 
hgs
parents: 36
diff changeset
   436
			TRACE_FLAGS_DEFAULT, 
hgs
parents: 36
diff changeset
   437
			(EAPL("eap_core_server_message_if_c::process_message(): this = 0x%08x, message=%d=%s\n"),
hgs
parents: 36
diff changeset
   438
			this,
hgs
parents: 36
diff changeset
   439
			function,
hgs
parents: 36
diff changeset
   440
			eap_process_tlv_message_data_c::get_function_string(function)));
hgs
parents: 36
diff changeset
   441
26
hgs
parents:
diff changeset
   442
		switch(function)
hgs
parents:
diff changeset
   443
		{
hgs
parents:
diff changeset
   444
		case eap_tlv_message_type_function_create_eap_session:
hgs
parents:
diff changeset
   445
			status = create_eap_session(&parameters);
hgs
parents:
diff changeset
   446
			break;
hgs
parents:
diff changeset
   447
		case eap_tlv_message_type_function_remove_eap_session:
hgs
parents:
diff changeset
   448
			status = remove_eap_session(&parameters);
hgs
parents:
diff changeset
   449
			break;
hgs
parents:
diff changeset
   450
		case eap_tlv_message_type_function_send_eap_identity_request:
hgs
parents:
diff changeset
   451
			status = send_eap_identity_request(&parameters);
hgs
parents:
diff changeset
   452
			break;
hgs
parents:
diff changeset
   453
		case eap_tlv_message_type_function_packet_process:
hgs
parents:
diff changeset
   454
			status = packet_process(&parameters);
hgs
parents:
diff changeset
   455
			break;
hgs
parents:
diff changeset
   456
		case eap_tlv_message_type_function_eap_acknowledge:
hgs
parents:
diff changeset
   457
			status = eap_acknowledge(&parameters);
hgs
parents:
diff changeset
   458
			break;
hgs
parents:
diff changeset
   459
		case eap_tlv_message_type_function_set_eap_database_reference_values:
hgs
parents:
diff changeset
   460
			status = set_eap_database_reference_values(&parameters);
hgs
parents:
diff changeset
   461
			break;
hgs
parents:
diff changeset
   462
		case eap_tlv_message_type_function_eap_mtu:
hgs
parents:
diff changeset
   463
			status = eap_mtu(&parameters);
hgs
parents:
diff changeset
   464
			break;
hgs
parents:
diff changeset
   465
		case eap_tlv_message_type_function_get_802_11_authentication_mode:
hgs
parents:
diff changeset
   466
			status = get_802_11_authentication_mode(&parameters);
hgs
parents:
diff changeset
   467
			break;
hgs
parents:
diff changeset
   468
		default:
hgs
parents:
diff changeset
   469
			EAP_TRACE_ERROR(
hgs
parents:
diff changeset
   470
				m_am_tools,
hgs
parents:
diff changeset
   471
				TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   472
				(EAPL("ERROR: process_data(): unknown function %d.\n"),
hgs
parents:
diff changeset
   473
				 function));
hgs
parents:
diff changeset
   474
hgs
parents:
diff changeset
   475
			status = eap_status_illegal_parameter;
hgs
parents:
diff changeset
   476
hgs
parents:
diff changeset
   477
			EAP_ASSERT_ANYWAY_TOOLS(m_am_tools);
hgs
parents:
diff changeset
   478
		};
hgs
parents:
diff changeset
   479
hgs
parents:
diff changeset
   480
		if (status != eap_status_ok
hgs
parents:
diff changeset
   481
			&& status != eap_status_success
hgs
parents:
diff changeset
   482
			&& status != eap_status_pending_request
hgs
parents:
diff changeset
   483
			&& status != eap_status_completed_request
hgs
parents:
diff changeset
   484
			&& status != eap_status_drop_packet_quietly)
hgs
parents:
diff changeset
   485
		{
hgs
parents:
diff changeset
   486
			(void) send_error_message(
hgs
parents:
diff changeset
   487
				status,
hgs
parents:
diff changeset
   488
				function);
hgs
parents:
diff changeset
   489
		}
hgs
parents:
diff changeset
   490
	}
hgs
parents:
diff changeset
   491
hgs
parents:
diff changeset
   492
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   493
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   494
}
hgs
parents:
diff changeset
   495
hgs
parents:
diff changeset
   496
//--------------------------------------------------
hgs
parents:
diff changeset
   497
hgs
parents:
diff changeset
   498
/// Function receives the data message from lower layer.
hgs
parents:
diff changeset
   499
/// Data is formatted to Attribute-Value Pairs.
hgs
parents:
diff changeset
   500
/// Look at eap_tlv_header_c and eap_tlv_message_data_c.
hgs
parents:
diff changeset
   501
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::process_data(const void * const data, const u32_t length)
hgs
parents:
diff changeset
   502
{
49
hgs
parents: 36
diff changeset
   503
	EAP_TRACE_DEBUG(
hgs
parents: 36
diff changeset
   504
		m_am_tools, 
hgs
parents: 36
diff changeset
   505
		TRACE_FLAGS_DEFAULT, 
hgs
parents: 36
diff changeset
   506
		(EAPL("%s: eap_core_server_message_if_c::process_data()\n"),
hgs
parents: 36
diff changeset
   507
		 (m_is_client == true) ? "client": "server"));
hgs
parents: 36
diff changeset
   508
hgs
parents: 36
diff changeset
   509
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::process_data()");
hgs
parents: 36
diff changeset
   510
26
hgs
parents:
diff changeset
   511
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   512
hgs
parents:
diff changeset
   513
	{
hgs
parents:
diff changeset
   514
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
   515
hgs
parents:
diff changeset
   516
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
   517
		{
hgs
parents:
diff changeset
   518
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   519
hgs
parents:
diff changeset
   520
			status = eap_status_allocation_error;
hgs
parents:
diff changeset
   521
hgs
parents:
diff changeset
   522
			(void) send_error_message(
hgs
parents:
diff changeset
   523
				status,
hgs
parents:
diff changeset
   524
				eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   525
hgs
parents:
diff changeset
   526
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   527
		}
hgs
parents:
diff changeset
   528
hgs
parents:
diff changeset
   529
		status = message.set_message_data(length, data);
hgs
parents:
diff changeset
   530
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   531
		{
hgs
parents:
diff changeset
   532
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   533
hgs
parents:
diff changeset
   534
			(void) send_error_message(
hgs
parents:
diff changeset
   535
				status,
hgs
parents:
diff changeset
   536
				eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   537
hgs
parents:
diff changeset
   538
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   539
		}
hgs
parents:
diff changeset
   540
hgs
parents:
diff changeset
   541
		status = process_message(&message);
hgs
parents:
diff changeset
   542
	}
hgs
parents:
diff changeset
   543
hgs
parents:
diff changeset
   544
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   545
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   546
}
hgs
parents:
diff changeset
   547
hgs
parents:
diff changeset
   548
//--------------------------------------------------
hgs
parents:
diff changeset
   549
hgs
parents:
diff changeset
   550
//
hgs
parents:
diff changeset
   551
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::packet_send(
hgs
parents:
diff changeset
   552
	const eap_am_network_id_c * const send_network_id,
hgs
parents:
diff changeset
   553
	eap_buf_chain_wr_c * const sent_packet,
hgs
parents:
diff changeset
   554
	const u32_t header_offset,
hgs
parents:
diff changeset
   555
	const u32_t data_length,
hgs
parents:
diff changeset
   556
	const u32_t buffer_length)
hgs
parents:
diff changeset
   557
{
49
hgs
parents: 36
diff changeset
   558
	EAP_TRACE_DEBUG(
hgs
parents: 36
diff changeset
   559
		m_am_tools, 
hgs
parents: 36
diff changeset
   560
		TRACE_FLAGS_DEFAULT, 
hgs
parents: 36
diff changeset
   561
		(EAPL("%s: eap_core_server_message_if_c::packet_send()\n"),
hgs
parents: 36
diff changeset
   562
		 (m_is_client == true) ? "client": "server"));
hgs
parents: 36
diff changeset
   563
hgs
parents: 36
diff changeset
   564
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::packet_send()");
hgs
parents: 36
diff changeset
   565
26
hgs
parents:
diff changeset
   566
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   567
hgs
parents:
diff changeset
   568
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   569
	EAP_ASSERT(header_offset < sent_packet->get_data_length());
hgs
parents:
diff changeset
   570
	EAP_ASSERT(data_length <= sent_packet->get_data_length());
hgs
parents:
diff changeset
   571
	EAP_ASSERT(sent_packet->get_data_length() <= buffer_length);
hgs
parents:
diff changeset
   572
hgs
parents:
diff changeset
   573
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   574
hgs
parents:
diff changeset
   575
	if (sent_packet->get_do_length_checks() == true)
hgs
parents:
diff changeset
   576
	{
hgs
parents:
diff changeset
   577
		if (header_offset != 0ul)
hgs
parents:
diff changeset
   578
		{
hgs
parents:
diff changeset
   579
			EAP_TRACE_ERROR(
hgs
parents:
diff changeset
   580
				m_am_tools,
hgs
parents:
diff changeset
   581
				TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   582
				(EAPL("ERROR: packet_send: packet buffer corrupted (header_offset != %d).\n"),
hgs
parents:
diff changeset
   583
				0ul));
hgs
parents:
diff changeset
   584
			EAP_ASSERT_ALWAYS(header_offset == 0ul);
hgs
parents:
diff changeset
   585
			return EAP_STATUS_RETURN(m_am_tools, eap_status_process_general_error);
hgs
parents:
diff changeset
   586
		}
hgs
parents:
diff changeset
   587
		else if (header_offset+data_length != sent_packet->get_data_length())
hgs
parents:
diff changeset
   588
		{
hgs
parents:
diff changeset
   589
			EAP_TRACE_ERROR(
hgs
parents:
diff changeset
   590
				m_am_tools,
hgs
parents:
diff changeset
   591
				TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   592
				(EAPL("ERROR: packet_send: packet buffer corrupted ")
hgs
parents:
diff changeset
   593
				 EAPL("(data_length %d != sent_packet->get_data_length() %d).\n"),
hgs
parents:
diff changeset
   594
				 header_offset+data_length,
hgs
parents:
diff changeset
   595
				 sent_packet->get_data_length()));
hgs
parents:
diff changeset
   596
			EAP_ASSERT_ALWAYS(data_length == sent_packet->get_buffer_length());
hgs
parents:
diff changeset
   597
			return EAP_STATUS_RETURN(m_am_tools, eap_status_process_general_error);
hgs
parents:
diff changeset
   598
		}
hgs
parents:
diff changeset
   599
		else if (header_offset+data_length > buffer_length)
hgs
parents:
diff changeset
   600
		{
hgs
parents:
diff changeset
   601
			EAP_TRACE_ERROR(
hgs
parents:
diff changeset
   602
				m_am_tools,
hgs
parents:
diff changeset
   603
				TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   604
				(EAPL("ERROR: packet_send: packet buffer corrupted ")
hgs
parents:
diff changeset
   605
				 EAPL("(header_offset+data_length %d > buffer_length %d).\n"),
hgs
parents:
diff changeset
   606
				 header_offset+data_length,
hgs
parents:
diff changeset
   607
				 buffer_length));
hgs
parents:
diff changeset
   608
			EAP_ASSERT_ALWAYS(header_offset+data_length <= buffer_length);
hgs
parents:
diff changeset
   609
			return EAP_STATUS_RETURN(m_am_tools, eap_status_process_general_error);
hgs
parents:
diff changeset
   610
		}
hgs
parents:
diff changeset
   611
		else if (header_offset+data_length > m_MTU)
hgs
parents:
diff changeset
   612
		{
hgs
parents:
diff changeset
   613
			EAP_TRACE_ERROR(
hgs
parents:
diff changeset
   614
				m_am_tools,
hgs
parents:
diff changeset
   615
				TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   616
				(EAPL("ERROR: packet_send: packet buffer corrupted ")
hgs
parents:
diff changeset
   617
				 EAPL("(header_offset+data_length %d > m_MTU %d).\n"),
hgs
parents:
diff changeset
   618
				 header_offset+data_length,
hgs
parents:
diff changeset
   619
				 m_MTU));
hgs
parents:
diff changeset
   620
			EAP_ASSERT_ALWAYS(header_offset+data_length <= m_MTU);
hgs
parents:
diff changeset
   621
			return EAP_STATUS_RETURN(m_am_tools, eap_status_process_general_error);
hgs
parents:
diff changeset
   622
		}
hgs
parents:
diff changeset
   623
	}
hgs
parents:
diff changeset
   624
	else
hgs
parents:
diff changeset
   625
	{
hgs
parents:
diff changeset
   626
		// Always we need at least the EAP header.
hgs
parents:
diff changeset
   627
		if (sent_packet->get_data_length()
hgs
parents:
diff changeset
   628
			< eap_header_base_c::get_header_length())
hgs
parents:
diff changeset
   629
		{
hgs
parents:
diff changeset
   630
			EAP_TRACE_ERROR(
hgs
parents:
diff changeset
   631
				m_am_tools,
hgs
parents:
diff changeset
   632
				TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   633
				(EAPL("ERROR: packet_send: packet buffer corrupted ")
hgs
parents:
diff changeset
   634
				 EAPL("(sent_packet->get_data_length() %d < ")
hgs
parents:
diff changeset
   635
				 EAPL("eap_header_base_c::get_header_length() %d).\n"),
hgs
parents:
diff changeset
   636
				 sent_packet->get_data_length(),
hgs
parents:
diff changeset
   637
				 eap_header_base_c::get_header_length()));
hgs
parents:
diff changeset
   638
			return EAP_STATUS_RETURN(m_am_tools, eap_status_process_general_error);
hgs
parents:
diff changeset
   639
		}
hgs
parents:
diff changeset
   640
	}
hgs
parents:
diff changeset
   641
	
hgs
parents:
diff changeset
   642
	{
hgs
parents:
diff changeset
   643
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   644
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
   645
hgs
parents:
diff changeset
   646
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
   647
		{
hgs
parents:
diff changeset
   648
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   649
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   650
		}
hgs
parents:
diff changeset
   651
hgs
parents:
diff changeset
   652
		status = message.add_parameter_data(eap_tlv_message_type_function_packet_send);
hgs
parents:
diff changeset
   653
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   654
		{
hgs
parents:
diff changeset
   655
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   656
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   657
		}
hgs
parents:
diff changeset
   658
hgs
parents:
diff changeset
   659
		status = message.add_parameter_data(send_network_id);
hgs
parents:
diff changeset
   660
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   661
		{
hgs
parents:
diff changeset
   662
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   663
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   664
		}
hgs
parents:
diff changeset
   665
hgs
parents:
diff changeset
   666
		status = message.add_parameter_data(sent_packet);
hgs
parents:
diff changeset
   667
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   668
		{
hgs
parents:
diff changeset
   669
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   670
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   671
		}
hgs
parents:
diff changeset
   672
hgs
parents:
diff changeset
   673
		status = send_message(&message);
hgs
parents:
diff changeset
   674
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   675
		{
hgs
parents:
diff changeset
   676
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   677
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   678
		}
hgs
parents:
diff changeset
   679
	}
hgs
parents:
diff changeset
   680
hgs
parents:
diff changeset
   681
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   682
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   683
}
hgs
parents:
diff changeset
   684
hgs
parents:
diff changeset
   685
//--------------------------------------------------
hgs
parents:
diff changeset
   686
hgs
parents:
diff changeset
   687
//
hgs
parents:
diff changeset
   688
EAP_FUNC_EXPORT u32_t eap_core_server_message_if_c::get_header_offset(
hgs
parents:
diff changeset
   689
	u32_t * const MTU,
hgs
parents:
diff changeset
   690
	u32_t * const trailer_length)
hgs
parents:
diff changeset
   691
{
hgs
parents:
diff changeset
   692
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   693
hgs
parents:
diff changeset
   694
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   695
hgs
parents:
diff changeset
   696
	const u32_t offset = 0ul;
hgs
parents:
diff changeset
   697
hgs
parents:
diff changeset
   698
	*MTU = m_MTU;
hgs
parents:
diff changeset
   699
	*trailer_length = m_trailer_length;
hgs
parents:
diff changeset
   700
hgs
parents:
diff changeset
   701
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   702
	return offset;
hgs
parents:
diff changeset
   703
}
hgs
parents:
diff changeset
   704
hgs
parents:
diff changeset
   705
//--------------------------------------------------
hgs
parents:
diff changeset
   706
hgs
parents:
diff changeset
   707
//
hgs
parents:
diff changeset
   708
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::load_module(
hgs
parents:
diff changeset
   709
	const eap_type_value_e type,
hgs
parents:
diff changeset
   710
	const eap_type_value_e tunneling_type,
hgs
parents:
diff changeset
   711
	abs_eap_base_type_c * const partner,
hgs
parents:
diff changeset
   712
	eap_base_type_c ** const eap_type,
hgs
parents:
diff changeset
   713
	const bool is_client_when_true,
hgs
parents:
diff changeset
   714
	const eap_am_network_id_c * const receive_network_id)
hgs
parents:
diff changeset
   715
{
hgs
parents:
diff changeset
   716
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   717
hgs
parents:
diff changeset
   718
	eap_status_e status = m_am_stack->load_module(
hgs
parents:
diff changeset
   719
		type,
hgs
parents:
diff changeset
   720
		tunneling_type,
hgs
parents:
diff changeset
   721
		partner,
hgs
parents:
diff changeset
   722
		eap_type,
hgs
parents:
diff changeset
   723
		is_client_when_true,
hgs
parents:
diff changeset
   724
		receive_network_id);
hgs
parents:
diff changeset
   725
hgs
parents:
diff changeset
   726
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   727
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   728
}
hgs
parents:
diff changeset
   729
hgs
parents:
diff changeset
   730
//--------------------------------------------------
hgs
parents:
diff changeset
   731
hgs
parents:
diff changeset
   732
//
34
hgs
parents: 26
diff changeset
   733
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::unload_module(const eap_type_value_e /* type*/)
26
hgs
parents:
diff changeset
   734
{
hgs
parents:
diff changeset
   735
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   736
hgs
parents:
diff changeset
   737
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   738
hgs
parents:
diff changeset
   739
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   740
hgs
parents:
diff changeset
   741
	EAP_ASSERT_ANYWAY_TOOLS(m_am_tools);
hgs
parents:
diff changeset
   742
hgs
parents:
diff changeset
   743
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   744
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   745
}
hgs
parents:
diff changeset
   746
hgs
parents:
diff changeset
   747
//--------------------------------------------------
hgs
parents:
diff changeset
   748
hgs
parents:
diff changeset
   749
//
hgs
parents:
diff changeset
   750
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::packet_data_crypto_keys(
hgs
parents:
diff changeset
   751
	const eap_am_network_id_c * const send_network_id,
hgs
parents:
diff changeset
   752
	const eap_master_session_key_c * const master_session_key
hgs
parents:
diff changeset
   753
	)
hgs
parents:
diff changeset
   754
{
hgs
parents:
diff changeset
   755
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   756
hgs
parents:
diff changeset
   757
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   758
		m_am_tools,
49
hgs
parents: 36
diff changeset
   759
		TRACE_FLAGS_DEFAULT,
26
hgs
parents:
diff changeset
   760
		(EAPL("%s: eap_core_server_message_if_c::packet_data_crypto_keys()\n"),
hgs
parents:
diff changeset
   761
		(m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   762
49
hgs
parents: 36
diff changeset
   763
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::packet_data_crypto_keys()");
26
hgs
parents:
diff changeset
   764
hgs
parents:
diff changeset
   765
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   766
hgs
parents:
diff changeset
   767
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   768
hgs
parents:
diff changeset
   769
	if (master_session_key == 0
hgs
parents:
diff changeset
   770
		|| master_session_key->get_is_valid() == false)
hgs
parents:
diff changeset
   771
	{
hgs
parents:
diff changeset
   772
		EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   773
			m_am_tools,
hgs
parents:
diff changeset
   774
			TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   775
			(EAPL("ERROR: eap_core_server_message_if_c::packet_data_crypto_keys(), invalid key.\n")));
hgs
parents:
diff changeset
   776
		return EAP_STATUS_RETURN(m_am_tools, eap_status_key_error);
hgs
parents:
diff changeset
   777
	}
hgs
parents:
diff changeset
   778
	
hgs
parents:
diff changeset
   779
	EAP_TRACE_DATA_DEBUG(
hgs
parents:
diff changeset
   780
		m_am_tools,
hgs
parents:
diff changeset
   781
		EAP_TRACE_FLAGS_MESSAGE_DATA,
hgs
parents:
diff changeset
   782
		(EAPL("eap_core_server_message_if_c::packet_data_crypto_keys(): master_session_key"), 
hgs
parents:
diff changeset
   783
		 master_session_key->get_data(),
hgs
parents:
diff changeset
   784
		 master_session_key->get_data_length()));
hgs
parents:
diff changeset
   785
	
hgs
parents:
diff changeset
   786
	{
hgs
parents:
diff changeset
   787
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   788
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
   789
hgs
parents:
diff changeset
   790
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
   791
		{
hgs
parents:
diff changeset
   792
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   793
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   794
		}
hgs
parents:
diff changeset
   795
hgs
parents:
diff changeset
   796
		status = message.add_parameter_data(eap_tlv_message_type_function_packet_data_crypto_keys);
hgs
parents:
diff changeset
   797
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   798
		{
hgs
parents:
diff changeset
   799
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   800
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   801
		}
hgs
parents:
diff changeset
   802
hgs
parents:
diff changeset
   803
		status = message.add_parameter_data(send_network_id);
hgs
parents:
diff changeset
   804
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   805
		{
hgs
parents:
diff changeset
   806
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   807
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   808
		}
hgs
parents:
diff changeset
   809
hgs
parents:
diff changeset
   810
		// This adds only the EAP-type.
hgs
parents:
diff changeset
   811
		status = message.add_parameter_data(master_session_key->get_eap_type());
hgs
parents:
diff changeset
   812
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   813
		{
hgs
parents:
diff changeset
   814
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   815
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   816
		}
hgs
parents:
diff changeset
   817
hgs
parents:
diff changeset
   818
		// This adds only the eap_variable_data.
hgs
parents:
diff changeset
   819
		status = message.add_parameter_data(master_session_key);
hgs
parents:
diff changeset
   820
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   821
		{
hgs
parents:
diff changeset
   822
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   823
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   824
		}
hgs
parents:
diff changeset
   825
hgs
parents:
diff changeset
   826
		status = send_message(&message);
hgs
parents:
diff changeset
   827
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   828
		{
hgs
parents:
diff changeset
   829
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   830
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   831
		}
hgs
parents:
diff changeset
   832
	}
hgs
parents:
diff changeset
   833
hgs
parents:
diff changeset
   834
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   835
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   836
}
hgs
parents:
diff changeset
   837
hgs
parents:
diff changeset
   838
//--------------------------------------------------
hgs
parents:
diff changeset
   839
hgs
parents:
diff changeset
   840
//
hgs
parents:
diff changeset
   841
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::complete_get_802_11_authentication_mode(
hgs
parents:
diff changeset
   842
	const eap_status_e completion_status,
hgs
parents:
diff changeset
   843
	const eap_am_network_id_c * const receive_network_id,
hgs
parents:
diff changeset
   844
	const eapol_key_802_11_authentication_mode_e mode)
hgs
parents:
diff changeset
   845
{
hgs
parents:
diff changeset
   846
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   847
hgs
parents:
diff changeset
   848
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   849
		m_am_tools,
49
hgs
parents: 36
diff changeset
   850
		TRACE_FLAGS_DEFAULT,
26
hgs
parents:
diff changeset
   851
		(EAPL("%s: eap_core_server_message_if_c::complete_get_802_11_authentication_mode()\n"),
hgs
parents:
diff changeset
   852
		(m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   853
49
hgs
parents: 36
diff changeset
   854
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::complete_get_802_11_authentication_mode()");
26
hgs
parents:
diff changeset
   855
hgs
parents:
diff changeset
   856
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   857
hgs
parents:
diff changeset
   858
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   859
hgs
parents:
diff changeset
   860
	{
hgs
parents:
diff changeset
   861
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   862
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
   863
hgs
parents:
diff changeset
   864
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
   865
		{
hgs
parents:
diff changeset
   866
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   867
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   868
		}
hgs
parents:
diff changeset
   869
hgs
parents:
diff changeset
   870
		status = message.add_parameter_data(eap_tlv_message_type_function_complete_get_802_11_authentication_mode);
hgs
parents:
diff changeset
   871
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   872
		{
hgs
parents:
diff changeset
   873
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   874
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   875
		}
hgs
parents:
diff changeset
   876
hgs
parents:
diff changeset
   877
		status = message.add_parameter_data(completion_status);
hgs
parents:
diff changeset
   878
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   879
		{
hgs
parents:
diff changeset
   880
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   881
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   882
		}
hgs
parents:
diff changeset
   883
hgs
parents:
diff changeset
   884
		status = message.add_parameter_data(receive_network_id);
hgs
parents:
diff changeset
   885
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   886
		{
hgs
parents:
diff changeset
   887
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   888
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   889
		}
hgs
parents:
diff changeset
   890
hgs
parents:
diff changeset
   891
		status = message.add_parameter_data(mode);
hgs
parents:
diff changeset
   892
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   893
		{
hgs
parents:
diff changeset
   894
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   895
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   896
		}
hgs
parents:
diff changeset
   897
hgs
parents:
diff changeset
   898
		status = send_message(&message);
hgs
parents:
diff changeset
   899
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   900
		{
hgs
parents:
diff changeset
   901
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   902
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   903
		}
hgs
parents:
diff changeset
   904
	}
hgs
parents:
diff changeset
   905
hgs
parents:
diff changeset
   906
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   907
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   908
}
hgs
parents:
diff changeset
   909
hgs
parents:
diff changeset
   910
//--------------------------------------------------
hgs
parents:
diff changeset
   911
hgs
parents:
diff changeset
   912
//
hgs
parents:
diff changeset
   913
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::complete_remove_eap_session(
hgs
parents:
diff changeset
   914
	const bool complete_to_lower_layer,
hgs
parents:
diff changeset
   915
	const eap_am_network_id_c * const receive_network_id)
hgs
parents:
diff changeset
   916
{
hgs
parents:
diff changeset
   917
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   918
hgs
parents:
diff changeset
   919
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   920
		m_am_tools,
49
hgs
parents: 36
diff changeset
   921
		TRACE_FLAGS_DEFAULT,
26
hgs
parents:
diff changeset
   922
		(EAPL("%s: eap_core_server_message_if_c::complete_remove_eap_session(): complete_to_lower_layer=%s\n"),
hgs
parents:
diff changeset
   923
		(m_is_client == true) ? "client": "server",
hgs
parents:
diff changeset
   924
		(complete_to_lower_layer == true) ? "true": "false"));
hgs
parents:
diff changeset
   925
49
hgs
parents: 36
diff changeset
   926
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::complete_remove_eap_session()");
26
hgs
parents:
diff changeset
   927
hgs
parents:
diff changeset
   928
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   929
hgs
parents:
diff changeset
   930
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   931
hgs
parents:
diff changeset
   932
	{
hgs
parents:
diff changeset
   933
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   934
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
   935
hgs
parents:
diff changeset
   936
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
   937
		{
hgs
parents:
diff changeset
   938
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   939
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   940
		}
hgs
parents:
diff changeset
   941
hgs
parents:
diff changeset
   942
		status = message.add_parameter_data(eap_tlv_message_type_function_complete_remove_eap_session);
hgs
parents:
diff changeset
   943
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   944
		{
hgs
parents:
diff changeset
   945
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   946
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   947
		}
hgs
parents:
diff changeset
   948
hgs
parents:
diff changeset
   949
		status = message.add_parameter_data(complete_to_lower_layer);
hgs
parents:
diff changeset
   950
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   951
		{
hgs
parents:
diff changeset
   952
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   953
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   954
		}
hgs
parents:
diff changeset
   955
hgs
parents:
diff changeset
   956
		status = message.add_parameter_data(receive_network_id);
hgs
parents:
diff changeset
   957
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   958
		{
hgs
parents:
diff changeset
   959
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   960
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   961
		}
hgs
parents:
diff changeset
   962
hgs
parents:
diff changeset
   963
		status = send_message(&message);
hgs
parents:
diff changeset
   964
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   965
		{
hgs
parents:
diff changeset
   966
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   967
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   968
		}
hgs
parents:
diff changeset
   969
	}
hgs
parents:
diff changeset
   970
hgs
parents:
diff changeset
   971
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   972
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   973
}
hgs
parents:
diff changeset
   974
hgs
parents:
diff changeset
   975
//--------------------------------------------------
hgs
parents:
diff changeset
   976
hgs
parents:
diff changeset
   977
//
hgs
parents:
diff changeset
   978
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::read_configure(
hgs
parents:
diff changeset
   979
	const eap_configuration_field_c * const field,
hgs
parents:
diff changeset
   980
	eap_variable_data_c * const data)
hgs
parents:
diff changeset
   981
{
hgs
parents:
diff changeset
   982
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   983
hgs
parents:
diff changeset
   984
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   985
hgs
parents:
diff changeset
   986
	eap_status_e status = m_am_stack->read_configure(
hgs
parents:
diff changeset
   987
		field,
hgs
parents:
diff changeset
   988
		data);
hgs
parents:
diff changeset
   989
hgs
parents:
diff changeset
   990
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   991
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   992
}
hgs
parents:
diff changeset
   993
hgs
parents:
diff changeset
   994
//--------------------------------------------------
hgs
parents:
diff changeset
   995
hgs
parents:
diff changeset
   996
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::write_configure(
34
hgs
parents: 26
diff changeset
   997
	const eap_configuration_field_c * const /* field */,
hgs
parents: 26
diff changeset
   998
	eap_variable_data_c * const /* data */)
26
hgs
parents:
diff changeset
   999
{
hgs
parents:
diff changeset
  1000
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1001
hgs
parents:
diff changeset
  1002
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
  1003
hgs
parents:
diff changeset
  1004
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
  1005
hgs
parents:
diff changeset
  1006
	EAP_ASSERT_ANYWAY_TOOLS(m_am_tools);
hgs
parents:
diff changeset
  1007
hgs
parents:
diff changeset
  1008
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1009
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1010
}
hgs
parents:
diff changeset
  1011
hgs
parents:
diff changeset
  1012
//--------------------------------------------------
hgs
parents:
diff changeset
  1013
hgs
parents:
diff changeset
  1014
//
hgs
parents:
diff changeset
  1015
EAP_FUNC_EXPORT void eap_core_server_message_if_c::set_is_valid()
hgs
parents:
diff changeset
  1016
{
hgs
parents:
diff changeset
  1017
	m_is_valid = true;
hgs
parents:
diff changeset
  1018
}
hgs
parents:
diff changeset
  1019
hgs
parents:
diff changeset
  1020
//--------------------------------------------------
hgs
parents:
diff changeset
  1021
hgs
parents:
diff changeset
  1022
//
hgs
parents:
diff changeset
  1023
EAP_FUNC_EXPORT bool eap_core_server_message_if_c::get_is_valid()
hgs
parents:
diff changeset
  1024
{
hgs
parents:
diff changeset
  1025
	return m_is_valid;
hgs
parents:
diff changeset
  1026
}
hgs
parents:
diff changeset
  1027
hgs
parents:
diff changeset
  1028
//--------------------------------------------------
hgs
parents:
diff changeset
  1029
hgs
parents:
diff changeset
  1030
//
hgs
parents:
diff changeset
  1031
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::timer_expired(
hgs
parents:
diff changeset
  1032
	const u32_t id, void *data)
hgs
parents:
diff changeset
  1033
{
34
hgs
parents: 26
diff changeset
  1034
	EAP_UNREFERENCED_PARAMETER(id);
hgs
parents: 26
diff changeset
  1035
	EAP_UNREFERENCED_PARAMETER(data);
26
hgs
parents:
diff changeset
  1036
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1037
hgs
parents:
diff changeset
  1038
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1039
		m_am_tools,
49
hgs
parents: 36
diff changeset
  1040
		TRACE_FLAGS_DEFAULT,
26
hgs
parents:
diff changeset
  1041
		(EAPL("TIMER: %s: [0x%08x]->eap_core_server_message_if_c::timer_expired(id 0x%02x, data 0x%08x).\n"),
hgs
parents:
diff changeset
  1042
		 (m_is_client == true) ? "client": "server",
hgs
parents:
diff changeset
  1043
		 this,
hgs
parents:
diff changeset
  1044
		 id,
hgs
parents:
diff changeset
  1045
		 data));
hgs
parents:
diff changeset
  1046
49
hgs
parents: 36
diff changeset
  1047
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::timer_expired()");
26
hgs
parents:
diff changeset
  1048
hgs
parents:
diff changeset
  1049
hgs
parents:
diff changeset
  1050
	return EAP_STATUS_RETURN(m_am_tools, eap_status_ok);
hgs
parents:
diff changeset
  1051
}
hgs
parents:
diff changeset
  1052
hgs
parents:
diff changeset
  1053
//--------------------------------------------------
hgs
parents:
diff changeset
  1054
hgs
parents:
diff changeset
  1055
//
hgs
parents:
diff changeset
  1056
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::timer_delete_data(
hgs
parents:
diff changeset
  1057
	const u32_t id, void *data)
hgs
parents:
diff changeset
  1058
{
34
hgs
parents: 26
diff changeset
  1059
	EAP_UNREFERENCED_PARAMETER(id);
hgs
parents: 26
diff changeset
  1060
	EAP_UNREFERENCED_PARAMETER(data);
26
hgs
parents:
diff changeset
  1061
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1062
hgs
parents:
diff changeset
  1063
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1064
		m_am_tools,
49
hgs
parents: 36
diff changeset
  1065
		TRACE_FLAGS_DEFAULT,
26
hgs
parents:
diff changeset
  1066
		(EAPL("TIMER: %s: [0x%08x]->eap_core_server_message_if_c::timer_delete_data(id 0x%02x, data 0x%08x).\n"),
hgs
parents:
diff changeset
  1067
		(m_is_client == true) ? "client": "server",
hgs
parents:
diff changeset
  1068
		this, id, data));
hgs
parents:
diff changeset
  1069
49
hgs
parents: 36
diff changeset
  1070
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::timer_delete_data()");
26
hgs
parents:
diff changeset
  1071
hgs
parents:
diff changeset
  1072
	return EAP_STATUS_RETURN(m_am_tools, eap_status_ok);
hgs
parents:
diff changeset
  1073
}
hgs
parents:
diff changeset
  1074
hgs
parents:
diff changeset
  1075
//--------------------------------------------------
hgs
parents:
diff changeset
  1076
hgs
parents:
diff changeset
  1077
EAP_FUNC_EXPORT void eap_core_server_message_if_c::state_notification(
hgs
parents:
diff changeset
  1078
	const abs_eap_state_notification_c * const state)
hgs
parents:
diff changeset
  1079
{
hgs
parents:
diff changeset
  1080
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
  1081
hgs
parents:
diff changeset
  1082
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1083
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1084
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1085
		(EAPL("%s: eap_core_server_message_if_c::state_notification()\n"),
hgs
parents:
diff changeset
  1086
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1087
49
hgs
parents: 36
diff changeset
  1088
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::state_notification()");
26
hgs
parents:
diff changeset
  1089
hgs
parents:
diff changeset
  1090
	{
hgs
parents:
diff changeset
  1091
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
  1092
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
  1093
hgs
parents:
diff changeset
  1094
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
  1095
		{
hgs
parents:
diff changeset
  1096
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1097
			(void)EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1098
			return;
hgs
parents:
diff changeset
  1099
		}
hgs
parents:
diff changeset
  1100
hgs
parents:
diff changeset
  1101
		status = message.add_parameter_data(eap_tlv_message_type_function_state_notification);
hgs
parents:
diff changeset
  1102
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1103
		{
hgs
parents:
diff changeset
  1104
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1105
			(void)EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1106
			return;
hgs
parents:
diff changeset
  1107
		}
hgs
parents:
diff changeset
  1108
hgs
parents:
diff changeset
  1109
		status = message.add_parameter_data(state);
hgs
parents:
diff changeset
  1110
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1111
		{
hgs
parents:
diff changeset
  1112
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1113
			(void)EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1114
			return;
hgs
parents:
diff changeset
  1115
		}
hgs
parents:
diff changeset
  1116
hgs
parents:
diff changeset
  1117
		status = send_message(&message);
hgs
parents:
diff changeset
  1118
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1119
		{
hgs
parents:
diff changeset
  1120
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1121
			(void)EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1122
			return;
hgs
parents:
diff changeset
  1123
		}
hgs
parents:
diff changeset
  1124
	}
hgs
parents:
diff changeset
  1125
}
hgs
parents:
diff changeset
  1126
hgs
parents:
diff changeset
  1127
//--------------------------------------------------
hgs
parents:
diff changeset
  1128
hgs
parents:
diff changeset
  1129
//
hgs
parents:
diff changeset
  1130
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::asynchronous_init_remove_eap_session(
hgs
parents:
diff changeset
  1131
	const eap_am_network_id_c * const /* send_network_id */)
hgs
parents:
diff changeset
  1132
{
hgs
parents:
diff changeset
  1133
	// eap_core_server_message_if_c object does not support asynchronous_init_remove_eap_session().
hgs
parents:
diff changeset
  1134
	return EAP_STATUS_RETURN(m_am_tools, eap_status_not_supported);
hgs
parents:
diff changeset
  1135
}
hgs
parents:
diff changeset
  1136
hgs
parents:
diff changeset
  1137
//--------------------------------------------------
hgs
parents:
diff changeset
  1138
hgs
parents:
diff changeset
  1139
//
hgs
parents:
diff changeset
  1140
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::asynchronous_start_authentication(
hgs
parents:
diff changeset
  1141
	const eap_am_network_id_c * const /* receive_network_id */,
hgs
parents:
diff changeset
  1142
	const bool /* is_client_when_true */)
hgs
parents:
diff changeset
  1143
{
hgs
parents:
diff changeset
  1144
	return EAP_STATUS_RETURN(m_am_tools, eap_status_not_supported);
hgs
parents:
diff changeset
  1145
}
hgs
parents:
diff changeset
  1146
hgs
parents:
diff changeset
  1147
//--------------------------------------------------
hgs
parents:
diff changeset
  1148
hgs
parents:
diff changeset
  1149
//
hgs
parents:
diff changeset
  1150
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::restart_authentication(
hgs
parents:
diff changeset
  1151
	const eap_am_network_id_c * const send_network_id,
hgs
parents:
diff changeset
  1152
	const bool is_client_when_true,
hgs
parents:
diff changeset
  1153
	const bool force_clean_restart,
hgs
parents:
diff changeset
  1154
	const bool from_timer)
hgs
parents:
diff changeset
  1155
{
hgs
parents:
diff changeset
  1156
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1157
hgs
parents:
diff changeset
  1158
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1159
		m_am_tools,
49
hgs
parents: 36
diff changeset
  1160
		TRACE_FLAGS_DEFAULT,
26
hgs
parents:
diff changeset
  1161
		(EAPL("%s: eap_core_server_message_if_c::restart_authentication()\n"),
hgs
parents:
diff changeset
  1162
		(m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1163
49
hgs
parents: 36
diff changeset
  1164
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::restart_authentication()");
26
hgs
parents:
diff changeset
  1165
hgs
parents:
diff changeset
  1166
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
  1167
hgs
parents:
diff changeset
  1168
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
  1169
hgs
parents:
diff changeset
  1170
	{
hgs
parents:
diff changeset
  1171
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
  1172
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
  1173
hgs
parents:
diff changeset
  1174
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
  1175
		{
hgs
parents:
diff changeset
  1176
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1177
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1178
		}
hgs
parents:
diff changeset
  1179
hgs
parents:
diff changeset
  1180
		status = message.add_parameter_data(eap_tlv_message_type_function_restart_authentication);
hgs
parents:
diff changeset
  1181
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1182
		{
hgs
parents:
diff changeset
  1183
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1184
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1185
		}
hgs
parents:
diff changeset
  1186
hgs
parents:
diff changeset
  1187
		status = message.add_parameter_data(send_network_id);
hgs
parents:
diff changeset
  1188
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1189
		{
hgs
parents:
diff changeset
  1190
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1191
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1192
		}
hgs
parents:
diff changeset
  1193
hgs
parents:
diff changeset
  1194
		status = message.add_parameter_data(is_client_when_true);
hgs
parents:
diff changeset
  1195
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1196
		{
hgs
parents:
diff changeset
  1197
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1198
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1199
		}
hgs
parents:
diff changeset
  1200
hgs
parents:
diff changeset
  1201
		status = message.add_parameter_data(force_clean_restart);
hgs
parents:
diff changeset
  1202
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1203
		{
hgs
parents:
diff changeset
  1204
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1205
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1206
		}
hgs
parents:
diff changeset
  1207
hgs
parents:
diff changeset
  1208
		status = message.add_parameter_data(from_timer);
hgs
parents:
diff changeset
  1209
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1210
		{
hgs
parents:
diff changeset
  1211
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1212
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1213
		}
hgs
parents:
diff changeset
  1214
hgs
parents:
diff changeset
  1215
		status = send_message(&message);
hgs
parents:
diff changeset
  1216
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1217
		{
hgs
parents:
diff changeset
  1218
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1219
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1220
		}
hgs
parents:
diff changeset
  1221
	}
hgs
parents:
diff changeset
  1222
hgs
parents:
diff changeset
  1223
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1224
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1225
}
hgs
parents:
diff changeset
  1226
hgs
parents:
diff changeset
  1227
//--------------------------------------------------
hgs
parents:
diff changeset
  1228
hgs
parents:
diff changeset
  1229
//
hgs
parents:
diff changeset
  1230
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::set_timer(
hgs
parents:
diff changeset
  1231
	abs_eap_base_timer_c * const p_initializer, 
hgs
parents:
diff changeset
  1232
	const u32_t p_id, 
hgs
parents:
diff changeset
  1233
	void * const p_data,
hgs
parents:
diff changeset
  1234
	const u32_t p_time_ms)
hgs
parents:
diff changeset
  1235
{
hgs
parents:
diff changeset
  1236
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1237
hgs
parents:
diff changeset
  1238
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
  1239
hgs
parents:
diff changeset
  1240
	eap_status_e status = m_am_stack->set_timer(
hgs
parents:
diff changeset
  1241
		p_initializer, 
hgs
parents:
diff changeset
  1242
		p_id, 
hgs
parents:
diff changeset
  1243
		p_data,
hgs
parents:
diff changeset
  1244
		p_time_ms);
hgs
parents:
diff changeset
  1245
hgs
parents:
diff changeset
  1246
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1247
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1248
}
hgs
parents:
diff changeset
  1249
hgs
parents:
diff changeset
  1250
//--------------------------------------------------
hgs
parents:
diff changeset
  1251
hgs
parents:
diff changeset
  1252
//
hgs
parents:
diff changeset
  1253
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::cancel_timer(
hgs
parents:
diff changeset
  1254
	abs_eap_base_timer_c * const p_initializer, 
hgs
parents:
diff changeset
  1255
	const u32_t p_id)
hgs
parents:
diff changeset
  1256
{
hgs
parents:
diff changeset
  1257
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1258
hgs
parents:
diff changeset
  1259
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
  1260
hgs
parents:
diff changeset
  1261
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  1262
hgs
parents:
diff changeset
  1263
	if (m_am_stack != 0)
hgs
parents:
diff changeset
  1264
	{
hgs
parents:
diff changeset
  1265
		status = m_am_stack->cancel_timer(
hgs
parents:
diff changeset
  1266
			p_initializer, 
hgs
parents:
diff changeset
  1267
			p_id);
hgs
parents:
diff changeset
  1268
	}
hgs
parents:
diff changeset
  1269
hgs
parents:
diff changeset
  1270
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1271
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1272
}
hgs
parents:
diff changeset
  1273
hgs
parents:
diff changeset
  1274
//--------------------------------------------------
hgs
parents:
diff changeset
  1275
hgs
parents:
diff changeset
  1276
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::check_is_valid_eap_type(
hgs
parents:
diff changeset
  1277
	const eap_type_value_e eap_type)
hgs
parents:
diff changeset
  1278
{
hgs
parents:
diff changeset
  1279
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1280
hgs
parents:
diff changeset
  1281
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
  1282
hgs
parents:
diff changeset
  1283
	eap_status_e status = m_am_stack->check_is_valid_eap_type(eap_type);
hgs
parents:
diff changeset
  1284
hgs
parents:
diff changeset
  1285
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1286
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1287
}
hgs
parents:
diff changeset
  1288
hgs
parents:
diff changeset
  1289
//--------------------------------------------------
hgs
parents:
diff changeset
  1290
hgs
parents:
diff changeset
  1291
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::get_eap_type_list(
hgs
parents:
diff changeset
  1292
	eap_array_c<eap_type_value_e> * const eap_type_list)
hgs
parents:
diff changeset
  1293
{
hgs
parents:
diff changeset
  1294
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1295
hgs
parents:
diff changeset
  1296
	eap_status_e status = m_am_stack->get_eap_type_list(eap_type_list);
hgs
parents:
diff changeset
  1297
hgs
parents:
diff changeset
  1298
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1299
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1300
}
hgs
parents:
diff changeset
  1301
hgs
parents:
diff changeset
  1302
//--------------------------------------------------
hgs
parents:
diff changeset
  1303
hgs
parents:
diff changeset
  1304
/// @see abs_eap_core_c::add_rogue_ap().
hgs
parents:
diff changeset
  1305
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::add_rogue_ap(
34
hgs
parents: 26
diff changeset
  1306
	eap_array_c<eap_rogue_ap_entry_c> & /* rogue_ap_list */)
26
hgs
parents:
diff changeset
  1307
{
hgs
parents:
diff changeset
  1308
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1309
hgs
parents:
diff changeset
  1310
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1311
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1312
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1313
		(EAPL("%s: eap_core_server_message_if_c::add_rogue_ap(): Does nothing.\n"),
hgs
parents:
diff changeset
  1314
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1315
hgs
parents:
diff changeset
  1316
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  1317
hgs
parents:
diff changeset
  1318
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1319
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1320
}
hgs
parents:
diff changeset
  1321
hgs
parents:
diff changeset
  1322
//--------------------------------------------------
hgs
parents:
diff changeset
  1323
hgs
parents:
diff changeset
  1324
//
hgs
parents:
diff changeset
  1325
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::set_session_timeout(
hgs
parents:
diff changeset
  1326
	const u32_t /* session_timeout_ms */)
hgs
parents:
diff changeset
  1327
{
hgs
parents:
diff changeset
  1328
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1329
hgs
parents:
diff changeset
  1330
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
  1331
hgs
parents:
diff changeset
  1332
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1333
	return EAP_STATUS_RETURN(m_am_tools, eap_status_not_supported);
hgs
parents:
diff changeset
  1334
}
hgs
parents:
diff changeset
  1335
hgs
parents:
diff changeset
  1336
//--------------------------------------------------
hgs
parents:
diff changeset
  1337
hgs
parents:
diff changeset
  1338
eap_status_e eap_core_server_message_if_c::create_eap_session(
hgs
parents:
diff changeset
  1339
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
  1340
{
hgs
parents:
diff changeset
  1341
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1342
hgs
parents:
diff changeset
  1343
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1344
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1345
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1346
		(EAPL("%s: eap_core_server_message_if_c::create_eap_session()\n"),
hgs
parents:
diff changeset
  1347
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1348
49
hgs
parents: 36
diff changeset
  1349
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::create_eap_session()");
26
hgs
parents:
diff changeset
  1350
hgs
parents:
diff changeset
  1351
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1352
hgs
parents:
diff changeset
  1353
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  1354
hgs
parents:
diff changeset
  1355
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
  1356
hgs
parents:
diff changeset
  1357
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
  1358
hgs
parents:
diff changeset
  1359
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
  1360
	{
hgs
parents:
diff changeset
  1361
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1362
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1363
	}
hgs
parents:
diff changeset
  1364
hgs
parents:
diff changeset
  1365
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1366
hgs
parents:
diff changeset
  1367
	eap_am_network_id_c receive_network_id(m_am_tools);
hgs
parents:
diff changeset
  1368
hgs
parents:
diff changeset
  1369
	status = message_data.read_parameter_data(parameters, parameter_index, &receive_network_id);
hgs
parents:
diff changeset
  1370
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1371
	{
hgs
parents:
diff changeset
  1372
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1373
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1374
	}
hgs
parents:
diff changeset
  1375
hgs
parents:
diff changeset
  1376
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1377
hgs
parents:
diff changeset
  1378
	status = m_eap_core->create_eap_session(
hgs
parents:
diff changeset
  1379
		&receive_network_id ///< source includes remote address, destination includes local address.
hgs
parents:
diff changeset
  1380
		);
hgs
parents:
diff changeset
  1381
hgs
parents:
diff changeset
  1382
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1383
hgs
parents:
diff changeset
  1384
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1385
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1386
}
hgs
parents:
diff changeset
  1387
hgs
parents:
diff changeset
  1388
//--------------------------------------------------
hgs
parents:
diff changeset
  1389
hgs
parents:
diff changeset
  1390
eap_status_e eap_core_server_message_if_c::remove_eap_session(
hgs
parents:
diff changeset
  1391
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
  1392
{
hgs
parents:
diff changeset
  1393
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1394
hgs
parents:
diff changeset
  1395
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1396
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1397
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1398
		(EAPL("%s: eap_core_server_message_if_c::remove_eap_session()\n"),
hgs
parents:
diff changeset
  1399
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1400
49
hgs
parents: 36
diff changeset
  1401
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::remove_eap_session()");
26
hgs
parents:
diff changeset
  1402
hgs
parents:
diff changeset
  1403
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1404
hgs
parents:
diff changeset
  1405
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  1406
hgs
parents:
diff changeset
  1407
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
  1408
hgs
parents:
diff changeset
  1409
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
  1410
hgs
parents:
diff changeset
  1411
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
  1412
	{
hgs
parents:
diff changeset
  1413
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1414
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1415
	}
hgs
parents:
diff changeset
  1416
hgs
parents:
diff changeset
  1417
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1418
hgs
parents:
diff changeset
  1419
	bool complete_to_lower_layer(false);
hgs
parents:
diff changeset
  1420
hgs
parents:
diff changeset
  1421
	status = message_data.read_parameter_data(parameters, parameter_index, &complete_to_lower_layer);
hgs
parents:
diff changeset
  1422
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1423
	{
hgs
parents:
diff changeset
  1424
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1425
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1426
	}
hgs
parents:
diff changeset
  1427
hgs
parents:
diff changeset
  1428
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1429
hgs
parents:
diff changeset
  1430
	++parameter_index;
hgs
parents:
diff changeset
  1431
hgs
parents:
diff changeset
  1432
	eap_am_network_id_c receive_network_id(m_am_tools);
hgs
parents:
diff changeset
  1433
hgs
parents:
diff changeset
  1434
	status = message_data.read_parameter_data(parameters, parameter_index, &receive_network_id);
hgs
parents:
diff changeset
  1435
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1436
	{
hgs
parents:
diff changeset
  1437
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1438
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1439
	}
hgs
parents:
diff changeset
  1440
hgs
parents:
diff changeset
  1441
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1442
hgs
parents:
diff changeset
  1443
	status = m_eap_core->remove_eap_session(
hgs
parents:
diff changeset
  1444
		complete_to_lower_layer,
hgs
parents:
diff changeset
  1445
		&receive_network_id ///< source includes remote address, destination includes local address.
hgs
parents:
diff changeset
  1446
		);
hgs
parents:
diff changeset
  1447
hgs
parents:
diff changeset
  1448
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1449
hgs
parents:
diff changeset
  1450
	// This is a new function to synchronize EAP-client and EAP-server.
hgs
parents:
diff changeset
  1451
	eap_status_e completion_status = complete_remove_eap_session(
hgs
parents:
diff changeset
  1452
		complete_to_lower_layer,
hgs
parents:
diff changeset
  1453
		&receive_network_id ///< source includes remote address, destination includes local address.
hgs
parents:
diff changeset
  1454
		);
hgs
parents:
diff changeset
  1455
hgs
parents:
diff changeset
  1456
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1457
hgs
parents:
diff changeset
  1458
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1459
	return EAP_STATUS_RETURN(m_am_tools, completion_status);
hgs
parents:
diff changeset
  1460
}
hgs
parents:
diff changeset
  1461
hgs
parents:
diff changeset
  1462
//--------------------------------------------------
hgs
parents:
diff changeset
  1463
hgs
parents:
diff changeset
  1464
eap_status_e eap_core_server_message_if_c::send_eap_identity_request(
hgs
parents:
diff changeset
  1465
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
  1466
{
hgs
parents:
diff changeset
  1467
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1468
hgs
parents:
diff changeset
  1469
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1470
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1471
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1472
		(EAPL("%s: eap_core_server_message_if_c::send_eap_identity_request()\n"),
hgs
parents:
diff changeset
  1473
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1474
49
hgs
parents: 36
diff changeset
  1475
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::send_eap_identity_request()");
26
hgs
parents:
diff changeset
  1476
hgs
parents:
diff changeset
  1477
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1478
hgs
parents:
diff changeset
  1479
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  1480
hgs
parents:
diff changeset
  1481
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
  1482
hgs
parents:
diff changeset
  1483
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
  1484
hgs
parents:
diff changeset
  1485
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
  1486
	{
hgs
parents:
diff changeset
  1487
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1488
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1489
	}
hgs
parents:
diff changeset
  1490
hgs
parents:
diff changeset
  1491
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1492
hgs
parents:
diff changeset
  1493
	eap_am_network_id_c receive_network_id(m_am_tools);
hgs
parents:
diff changeset
  1494
hgs
parents:
diff changeset
  1495
	status = message_data.read_parameter_data(parameters, parameter_index, &receive_network_id);
hgs
parents:
diff changeset
  1496
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1497
	{
hgs
parents:
diff changeset
  1498
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1499
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1500
	}
hgs
parents:
diff changeset
  1501
hgs
parents:
diff changeset
  1502
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1503
hgs
parents:
diff changeset
  1504
	status = m_eap_core->send_eap_identity_request(
hgs
parents:
diff changeset
  1505
		&receive_network_id ///< source includes remote address, destination includes local address.
hgs
parents:
diff changeset
  1506
		);
hgs
parents:
diff changeset
  1507
hgs
parents:
diff changeset
  1508
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1509
hgs
parents:
diff changeset
  1510
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1511
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1512
}
hgs
parents:
diff changeset
  1513
hgs
parents:
diff changeset
  1514
//--------------------------------------------------
hgs
parents:
diff changeset
  1515
hgs
parents:
diff changeset
  1516
eap_status_e eap_core_server_message_if_c::packet_process(
hgs
parents:
diff changeset
  1517
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
  1518
{
hgs
parents:
diff changeset
  1519
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1520
hgs
parents:
diff changeset
  1521
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1522
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1523
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1524
		(EAPL("%s: eap_core_server_message_if_c::packet_process()\n"),
hgs
parents:
diff changeset
  1525
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1526
49
hgs
parents: 36
diff changeset
  1527
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::packet_process()");
26
hgs
parents:
diff changeset
  1528
hgs
parents:
diff changeset
  1529
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1530
hgs
parents:
diff changeset
  1531
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  1532
hgs
parents:
diff changeset
  1533
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
  1534
hgs
parents:
diff changeset
  1535
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
  1536
hgs
parents:
diff changeset
  1537
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
  1538
	{
hgs
parents:
diff changeset
  1539
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1540
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1541
	}
hgs
parents:
diff changeset
  1542
hgs
parents:
diff changeset
  1543
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1544
hgs
parents:
diff changeset
  1545
	eap_am_network_id_c receive_network_id(m_am_tools);
hgs
parents:
diff changeset
  1546
hgs
parents:
diff changeset
  1547
	status = message_data.read_parameter_data(parameters, parameter_index, &receive_network_id);
hgs
parents:
diff changeset
  1548
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1549
	{
hgs
parents:
diff changeset
  1550
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1551
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1552
	}
hgs
parents:
diff changeset
  1553
hgs
parents:
diff changeset
  1554
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1555
hgs
parents:
diff changeset
  1556
	++parameter_index;
hgs
parents:
diff changeset
  1557
hgs
parents:
diff changeset
  1558
	eap_variable_data_c packet_data_payload(m_am_tools);
hgs
parents:
diff changeset
  1559
hgs
parents:
diff changeset
  1560
	status = message_data.read_parameter_data(parameters, parameter_index, &packet_data_payload);
hgs
parents:
diff changeset
  1561
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1562
	{
hgs
parents:
diff changeset
  1563
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1564
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1565
	}
hgs
parents:
diff changeset
  1566
hgs
parents:
diff changeset
  1567
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1568
hgs
parents:
diff changeset
  1569
	eap_header_wr_c eap(
hgs
parents:
diff changeset
  1570
		m_am_tools,
hgs
parents:
diff changeset
  1571
		packet_data_payload.get_data(),
hgs
parents:
diff changeset
  1572
		packet_data_payload.get_data_length());
hgs
parents:
diff changeset
  1573
	if (eap.get_is_valid() == false)
hgs
parents:
diff changeset
  1574
	{
hgs
parents:
diff changeset
  1575
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1576
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1577
	}
hgs
parents:
diff changeset
  1578
hgs
parents:
diff changeset
  1579
	status = m_eap_core->packet_process(
hgs
parents:
diff changeset
  1580
		&receive_network_id,
hgs
parents:
diff changeset
  1581
		&eap,
hgs
parents:
diff changeset
  1582
		packet_data_payload.get_data_length()
hgs
parents:
diff changeset
  1583
		);
hgs
parents:
diff changeset
  1584
hgs
parents:
diff changeset
  1585
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1586
hgs
parents:
diff changeset
  1587
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1588
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1589
}
hgs
parents:
diff changeset
  1590
hgs
parents:
diff changeset
  1591
//--------------------------------------------------
hgs
parents:
diff changeset
  1592
hgs
parents:
diff changeset
  1593
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::eap_acknowledge(
hgs
parents:
diff changeset
  1594
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
  1595
{
hgs
parents:
diff changeset
  1596
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1597
hgs
parents:
diff changeset
  1598
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1599
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1600
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1601
		(EAPL("%s: eap_core_server_message_if_c::eap_acknowledge()\n"),
hgs
parents:
diff changeset
  1602
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1603
49
hgs
parents: 36
diff changeset
  1604
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::eap_acknowledge()");
26
hgs
parents:
diff changeset
  1605
hgs
parents:
diff changeset
  1606
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1607
hgs
parents:
diff changeset
  1608
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  1609
hgs
parents:
diff changeset
  1610
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
  1611
hgs
parents:
diff changeset
  1612
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
  1613
hgs
parents:
diff changeset
  1614
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
  1615
	{
hgs
parents:
diff changeset
  1616
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1617
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1618
	}
hgs
parents:
diff changeset
  1619
hgs
parents:
diff changeset
  1620
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1621
hgs
parents:
diff changeset
  1622
	eap_am_network_id_c receive_network_id(m_am_tools);
hgs
parents:
diff changeset
  1623
hgs
parents:
diff changeset
  1624
	status = message_data.read_parameter_data(parameters, parameter_index, &receive_network_id);
hgs
parents:
diff changeset
  1625
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1626
	{
hgs
parents:
diff changeset
  1627
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1628
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1629
	}
hgs
parents:
diff changeset
  1630
hgs
parents:
diff changeset
  1631
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1632
hgs
parents:
diff changeset
  1633
	status = m_eap_core->eap_acknowledge(
hgs
parents:
diff changeset
  1634
		&receive_network_id ///< source includes remote address, destination includes local address.
hgs
parents:
diff changeset
  1635
		);
hgs
parents:
diff changeset
  1636
hgs
parents:
diff changeset
  1637
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1638
hgs
parents:
diff changeset
  1639
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1640
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1641
}
hgs
parents:
diff changeset
  1642
hgs
parents:
diff changeset
  1643
//--------------------------------------------------
hgs
parents:
diff changeset
  1644
hgs
parents:
diff changeset
  1645
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::eap_mtu(
hgs
parents:
diff changeset
  1646
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
  1647
{
hgs
parents:
diff changeset
  1648
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1649
hgs
parents:
diff changeset
  1650
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1651
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1652
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1653
		(EAPL("%s: eap_core_server_message_if_c::eap_mtu()\n"),
hgs
parents:
diff changeset
  1654
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1655
49
hgs
parents: 36
diff changeset
  1656
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::eap_mtu()");
26
hgs
parents:
diff changeset
  1657
hgs
parents:
diff changeset
  1658
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1659
hgs
parents:
diff changeset
  1660
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  1661
hgs
parents:
diff changeset
  1662
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
  1663
hgs
parents:
diff changeset
  1664
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
  1665
hgs
parents:
diff changeset
  1666
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
  1667
	{
hgs
parents:
diff changeset
  1668
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1669
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1670
	}
hgs
parents:
diff changeset
  1671
hgs
parents:
diff changeset
  1672
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1673
hgs
parents:
diff changeset
  1674
	status = message_data.read_parameter_data(parameters, parameter_index, &m_MTU);
hgs
parents:
diff changeset
  1675
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1676
	{
hgs
parents:
diff changeset
  1677
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1678
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1679
	}
hgs
parents:
diff changeset
  1680
hgs
parents:
diff changeset
  1681
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1682
hgs
parents:
diff changeset
  1683
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1684
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1685
}
hgs
parents:
diff changeset
  1686
hgs
parents:
diff changeset
  1687
//--------------------------------------------------
hgs
parents:
diff changeset
  1688
hgs
parents:
diff changeset
  1689
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::get_802_11_authentication_mode(
hgs
parents:
diff changeset
  1690
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
  1691
{
hgs
parents:
diff changeset
  1692
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1693
hgs
parents:
diff changeset
  1694
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1695
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1696
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1697
		(EAPL("%s: eap_core_server_message_if_c::get_802_11_authentication_mode()\n"),
hgs
parents:
diff changeset
  1698
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1699
49
hgs
parents: 36
diff changeset
  1700
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::get_802_11_authentication_mode()");
26
hgs
parents:
diff changeset
  1701
hgs
parents:
diff changeset
  1702
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1703
hgs
parents:
diff changeset
  1704
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  1705
hgs
parents:
diff changeset
  1706
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
  1707
hgs
parents:
diff changeset
  1708
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
  1709
hgs
parents:
diff changeset
  1710
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
  1711
	{
hgs
parents:
diff changeset
  1712
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1713
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1714
	}
hgs
parents:
diff changeset
  1715
hgs
parents:
diff changeset
  1716
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1717
hgs
parents:
diff changeset
  1718
	eap_am_network_id_c receive_network_id(m_am_tools);
hgs
parents:
diff changeset
  1719
hgs
parents:
diff changeset
  1720
	status = message_data.read_parameter_data(parameters, parameter_index, &receive_network_id);
hgs
parents:
diff changeset
  1721
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1722
	{
hgs
parents:
diff changeset
  1723
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1724
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1725
	}
hgs
parents:
diff changeset
  1726
hgs
parents:
diff changeset
  1727
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1728
hgs
parents:
diff changeset
  1729
	++parameter_index;
hgs
parents:
diff changeset
  1730
hgs
parents:
diff changeset
  1731
	eapol_key_authentication_type_e authentication_type(eapol_key_authentication_type_none);
hgs
parents:
diff changeset
  1732
hgs
parents:
diff changeset
  1733
	status = message_data.read_parameter_data(parameters, parameter_index, &authentication_type);
hgs
parents:
diff changeset
  1734
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1735
	{
hgs
parents:
diff changeset
  1736
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1737
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1738
	}
hgs
parents:
diff changeset
  1739
hgs
parents:
diff changeset
  1740
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1741
hgs
parents:
diff changeset
  1742
	++parameter_index;
hgs
parents:
diff changeset
  1743
hgs
parents:
diff changeset
  1744
	eap_variable_data_c SSID(m_am_tools);
hgs
parents:
diff changeset
  1745
hgs
parents:
diff changeset
  1746
	status = message_data.read_parameter_data(parameters, parameter_index, &SSID);
hgs
parents:
diff changeset
  1747
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1748
	{
hgs
parents:
diff changeset
  1749
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1750
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1751
	}
hgs
parents:
diff changeset
  1752
49
hgs
parents: 36
diff changeset
  1753
    EAP_TRACE_DATA_DEBUG(
hgs
parents: 36
diff changeset
  1754
        m_am_tools,
hgs
parents: 36
diff changeset
  1755
        TRACE_FLAGS_DEFAULT,
hgs
parents: 36
diff changeset
  1756
        (EAPL("new SSID"),
hgs
parents: 36
diff changeset
  1757
        SSID.get_data(),
hgs
parents: 36
diff changeset
  1758
        SSID.get_data_length()));
hgs
parents: 36
diff changeset
  1759
26
hgs
parents:
diff changeset
  1760
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1761
hgs
parents:
diff changeset
  1762
	++parameter_index;
hgs
parents:
diff changeset
  1763
hgs
parents:
diff changeset
  1764
	eap_variable_data_c preshared_key(m_am_tools);
hgs
parents:
diff changeset
  1765
hgs
parents:
diff changeset
  1766
	status = message_data.read_parameter_data(parameters, parameter_index, &preshared_key);
hgs
parents:
diff changeset
  1767
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1768
	{
hgs
parents:
diff changeset
  1769
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1770
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1771
	}
hgs
parents:
diff changeset
  1772
49
hgs
parents: 36
diff changeset
  1773
    EAP_TRACE_DATA_DEBUG(
hgs
parents: 36
diff changeset
  1774
        m_am_tools,
hgs
parents: 36
diff changeset
  1775
        TRACE_FLAGS_DEFAULT,
hgs
parents: 36
diff changeset
  1776
        (EAPL("new preshared_key"),
hgs
parents: 36
diff changeset
  1777
        preshared_key.get_data(),
hgs
parents: 36
diff changeset
  1778
        preshared_key.get_data_length()));
hgs
parents: 36
diff changeset
  1779
26
hgs
parents:
diff changeset
  1780
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1781
hgs
parents:
diff changeset
  1782
	if (authentication_type == eapol_key_authentication_type_WPS)
hgs
parents:
diff changeset
  1783
	{
49
hgs
parents: 36
diff changeset
  1784
		// Saves SSID and pre-shared key for WPS to memory store.
hgs
parents: 36
diff changeset
  1785
hgs
parents: 36
diff changeset
  1786
		EAP_TRACE_DEBUG(
hgs
parents: 36
diff changeset
  1787
			m_am_tools, 
hgs
parents: 36
diff changeset
  1788
			TRACE_FLAGS_DEFAULT, 
hgs
parents: 36
diff changeset
  1789
			(EAPL("%s: eap_core_server_message_if_c::get_802_11_authentication_mode(): Saves SSID and pre-shared key for WPS to memory store.\n"),
hgs
parents: 36
diff changeset
  1790
			 (m_is_client == true) ? "client": "server"));
hgs
parents: 36
diff changeset
  1791
26
hgs
parents:
diff changeset
  1792
		eap_variable_data_c memory_store_key(m_am_tools);
hgs
parents:
diff changeset
  1793
hgs
parents:
diff changeset
  1794
		eap_status_e status = memory_store_key.set_copy_of_buffer(
hgs
parents:
diff changeset
  1795
			EAP_WPS_CONFIGURATION_MEMORY_STORE_KEY,
hgs
parents:
diff changeset
  1796
			sizeof(EAP_WPS_CONFIGURATION_MEMORY_STORE_KEY));
hgs
parents:
diff changeset
  1797
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1798
		{
hgs
parents:
diff changeset
  1799
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1800
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1801
		}
hgs
parents:
diff changeset
  1802
hgs
parents:
diff changeset
  1803
		status = memory_store_key.add_data(
hgs
parents:
diff changeset
  1804
			&m_is_client,
hgs
parents:
diff changeset
  1805
			sizeof(m_is_client));
hgs
parents:
diff changeset
  1806
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1807
		{
hgs
parents:
diff changeset
  1808
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1809
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1810
		}
hgs
parents:
diff changeset
  1811
hgs
parents:
diff changeset
  1812
		eap_network_id_selector_c state_selector(
hgs
parents:
diff changeset
  1813
			m_am_tools,
hgs
parents:
diff changeset
  1814
			&receive_network_id);
hgs
parents:
diff changeset
  1815
hgs
parents:
diff changeset
  1816
		status = memory_store_key.add_data(
hgs
parents:
diff changeset
  1817
			&state_selector);
hgs
parents:
diff changeset
  1818
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1819
		{
hgs
parents:
diff changeset
  1820
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1821
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1822
		}
hgs
parents:
diff changeset
  1823
hgs
parents:
diff changeset
  1824
		eap_tlv_message_data_c tlv_data(m_am_tools);
hgs
parents:
diff changeset
  1825
hgs
parents:
diff changeset
  1826
		status = tlv_data.add_message_data(
hgs
parents:
diff changeset
  1827
			eap_type_protected_setup_stored_preshared_key,
hgs
parents:
diff changeset
  1828
			preshared_key.get_data_length(),
hgs
parents:
diff changeset
  1829
			preshared_key.get_data());
hgs
parents:
diff changeset
  1830
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1831
		{
hgs
parents:
diff changeset
  1832
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1833
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1834
		}
hgs
parents:
diff changeset
  1835
hgs
parents:
diff changeset
  1836
		status = tlv_data.add_message_data(
hgs
parents:
diff changeset
  1837
			eap_type_protected_setup_stored_ssid,
hgs
parents:
diff changeset
  1838
			SSID.get_data_length(),
hgs
parents:
diff changeset
  1839
			SSID.get_data());
hgs
parents:
diff changeset
  1840
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1841
		{
hgs
parents:
diff changeset
  1842
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1843
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1844
		}
hgs
parents:
diff changeset
  1845
hgs
parents:
diff changeset
  1846
		status = m_am_tools->memory_store_remove_data(&memory_store_key);
hgs
parents:
diff changeset
  1847
		if (status != eap_status_ok
hgs
parents:
diff changeset
  1848
			&& status != eap_status_not_found)
hgs
parents:
diff changeset
  1849
		{
hgs
parents:
diff changeset
  1850
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1851
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1852
		}
hgs
parents:
diff changeset
  1853
hgs
parents:
diff changeset
  1854
		status = m_am_tools->memory_store_add_data(
hgs
parents:
diff changeset
  1855
			&memory_store_key,
hgs
parents:
diff changeset
  1856
			&tlv_data,
hgs
parents:
diff changeset
  1857
			eap_type_default_credential_timeout);
hgs
parents:
diff changeset
  1858
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1859
		{
hgs
parents:
diff changeset
  1860
			EAP_TRACE_ERROR(
hgs
parents:
diff changeset
  1861
				m_am_tools,
hgs
parents:
diff changeset
  1862
				TRACE_FLAGS_ERROR,
hgs
parents:
diff changeset
  1863
				(EAPL("eap_core_server_message_if_c::get_802_11_authentication_mode(): cannot store WPS credentials\n")));
hgs
parents:
diff changeset
  1864
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1865
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1866
		}
hgs
parents:
diff changeset
  1867
	}
hgs
parents:
diff changeset
  1868
hgs
parents:
diff changeset
  1869
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1870
hgs
parents:
diff changeset
  1871
	status = m_am_stack->get_802_11_authentication_mode(
hgs
parents:
diff changeset
  1872
		&receive_network_id, ///< source includes remote address, destination includes local address.
hgs
parents:
diff changeset
  1873
		authentication_type);
hgs
parents:
diff changeset
  1874
hgs
parents:
diff changeset
  1875
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1876
hgs
parents:
diff changeset
  1877
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1878
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1879
}
hgs
parents:
diff changeset
  1880
hgs
parents:
diff changeset
  1881
//--------------------------------------------------
hgs
parents:
diff changeset
  1882
hgs
parents:
diff changeset
  1883
eap_status_e eap_core_server_message_if_c::set_eap_database_reference_values(
hgs
parents:
diff changeset
  1884
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
  1885
{
hgs
parents:
diff changeset
  1886
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1887
hgs
parents:
diff changeset
  1888
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1889
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1890
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1891
		(EAPL("%s: eap_core_server_message_if_c::set_eap_database_reference_values()\n"),
hgs
parents:
diff changeset
  1892
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1893
49
hgs
parents: 36
diff changeset
  1894
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::set_eap_database_reference_values()");
26
hgs
parents:
diff changeset
  1895
hgs
parents:
diff changeset
  1896
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1897
hgs
parents:
diff changeset
  1898
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  1899
hgs
parents:
diff changeset
  1900
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
  1901
hgs
parents:
diff changeset
  1902
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
  1903
hgs
parents:
diff changeset
  1904
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
  1905
	{
hgs
parents:
diff changeset
  1906
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1907
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1908
	}
hgs
parents:
diff changeset
  1909
hgs
parents:
diff changeset
  1910
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1911
hgs
parents:
diff changeset
  1912
	eap_variable_data_c reference(m_am_tools);
hgs
parents:
diff changeset
  1913
hgs
parents:
diff changeset
  1914
	status = message_data.read_parameter_data(parameters, parameter_index, &reference);
hgs
parents:
diff changeset
  1915
	if (status != eap_status_ok)
hgs
parents:
diff changeset
  1916
	{
hgs
parents:
diff changeset
  1917
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1918
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1919
	}
hgs
parents:
diff changeset
  1920
hgs
parents:
diff changeset
  1921
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1922
hgs
parents:
diff changeset
  1923
	status = m_am_stack->set_eap_database_reference_values(
hgs
parents:
diff changeset
  1924
		&reference
hgs
parents:
diff changeset
  1925
		);
hgs
parents:
diff changeset
  1926
hgs
parents:
diff changeset
  1927
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1928
hgs
parents:
diff changeset
  1929
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1930
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1931
}
hgs
parents:
diff changeset
  1932
hgs
parents:
diff changeset
  1933
//--------------------------------------------------
hgs
parents:
diff changeset
  1934
hgs
parents:
diff changeset
  1935
#if defined(USE_EAP_SIMPLE_CONFIG)
hgs
parents:
diff changeset
  1936
hgs
parents:
diff changeset
  1937
EAP_FUNC_EXPORT eap_status_e eap_core_server_message_if_c::save_simple_config_session(
34
hgs
parents: 26
diff changeset
  1938
	const simple_config_state_e /* state */,
26
hgs
parents:
diff changeset
  1939
	EAP_TEMPLATE_CONST eap_array_c<simple_config_credential_c> * const credential_array,
34
hgs
parents: 26
diff changeset
  1940
	const eap_variable_data_c * const /* new_password */,
hgs
parents: 26
diff changeset
  1941
	const simple_config_Device_Password_ID_e /* Device_Password_ID */,
hgs
parents: 26
diff changeset
  1942
	const simple_config_payloads_c * const /* other_configuration */)
26
hgs
parents:
diff changeset
  1943
{
hgs
parents:
diff changeset
  1944
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1945
hgs
parents:
diff changeset
  1946
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1947
		m_am_tools, 
49
hgs
parents: 36
diff changeset
  1948
		TRACE_FLAGS_DEFAULT, 
26
hgs
parents:
diff changeset
  1949
		(EAPL("%s: eap_core_server_message_if_c::save_simple_config_session()\n"),
hgs
parents:
diff changeset
  1950
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1951
49
hgs
parents: 36
diff changeset
  1952
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::save_simple_config_session()");
26
hgs
parents:
diff changeset
  1953
hgs
parents:
diff changeset
  1954
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  1955
hgs
parents:
diff changeset
  1956
	// Message is formatted as:
hgs
parents:
diff changeset
  1957
	// 0                   1                   2                   3   
hgs
parents:
diff changeset
  1958
	//  0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 
hgs
parents:
diff changeset
  1959
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
hgs
parents:
diff changeset
  1960
	// |                    Type = Function                            |
hgs
parents:
diff changeset
  1961
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1962
	// |                    Length = 4                                 |
hgs
parents:
diff changeset
  1963
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1964
	// |                    Value = New_protected_setup_credentials    |
hgs
parents:
diff changeset
  1965
	// +#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+ <= start of Array of Protected setup credential
hgs
parents:
diff changeset
  1966
	// |                    Type = Array                               |
hgs
parents:
diff changeset
  1967
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1968
	// |                    Length = 137                               |
hgs
parents:
diff changeset
  1969
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ <= start of Array of Protected setup credential value
hgs
parents:
diff changeset
  1970
	// |                    Type = Protected setup credential          |
hgs
parents:
diff changeset
  1971
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1972
	// |                    Length = 129                               |
hgs
parents:
diff changeset
  1973
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
hgs
parents:
diff changeset
  1974
	// |                    Type = Unsigned 8 bit integer              |
hgs
parents:
diff changeset
  1975
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1976
	// |                    Length = 1                                 |
hgs
parents:
diff changeset
  1977
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1978
	// |   u8_t value  |
hgs
parents:
diff changeset
  1979
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
hgs
parents:
diff changeset
  1980
	// |                    Type = Variable data                       |
hgs
parents:
diff changeset
  1981
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1982
	// |                    Length = 12                                |
hgs
parents:
diff changeset
  1983
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1984
	// |                    Value = SSID string                        |
hgs
parents:
diff changeset
  1985
	// +-+-+-+-                                                 -+-+-+-+
hgs
parents:
diff changeset
  1986
	// |                                                               |
hgs
parents:
diff changeset
  1987
	// +-+-+-+-                                                 -+-+-+-+
hgs
parents:
diff changeset
  1988
	// |                                                               |
hgs
parents:
diff changeset
  1989
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
hgs
parents:
diff changeset
  1990
	// |                    Type = Unsigned 16 bit integer             |
hgs
parents:
diff changeset
  1991
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1992
	// |                    Length = 2                                 |
hgs
parents:
diff changeset
  1993
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1994
	// |   u16_t Authentication type   |
hgs
parents:
diff changeset
  1995
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
hgs
parents:
diff changeset
  1996
	// |                    Type = Unsigned 16 bit integer             |
hgs
parents:
diff changeset
  1997
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  1998
	// |                    Length = 2                                 |
hgs
parents:
diff changeset
  1999
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2000
	// |   u16_t Encryption type       |
hgs
parents:
diff changeset
  2001
	// +#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+ <= start of Array of Network key
hgs
parents:
diff changeset
  2002
	// |                    Type = Array                               |
hgs
parents:
diff changeset
  2003
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2004
	// |                    Length = 66                                |
hgs
parents:
diff changeset
  2005
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+ <= start of Array of Network key value
hgs
parents:
diff changeset
  2006
	// |                    Type = Network key                         |
hgs
parents:
diff changeset
  2007
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2008
	// |                    Length = 25                                |
hgs
parents:
diff changeset
  2009
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
hgs
parents:
diff changeset
  2010
	// |                    Type = Unsigned 8 bit integer              |
hgs
parents:
diff changeset
  2011
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2012
	// |                    Length = 1                                 |
hgs
parents:
diff changeset
  2013
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2014
	// |   u8_t value  |
hgs
parents:
diff changeset
  2015
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
hgs
parents:
diff changeset
  2016
	// |                    Type = Variable data                       |
hgs
parents:
diff changeset
  2017
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2018
	// |                    Length = 8                                 |
hgs
parents:
diff changeset
  2019
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2020
	// |                    Value = Network key                        |
hgs
parents:
diff changeset
  2021
	// +-+-+-+-                                                 -+-+-+-+
hgs
parents:
diff changeset
  2022
	// |                                                               |
hgs
parents:
diff changeset
  2023
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
hgs
parents:
diff changeset
  2024
	// |                    Type = Network key                         |
hgs
parents:
diff changeset
  2025
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2026
	// |                    Length = 25                                |
hgs
parents:
diff changeset
  2027
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
hgs
parents:
diff changeset
  2028
	// |                    Type = Unsigned 8 bit integer              |
hgs
parents:
diff changeset
  2029
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2030
	// |                    Length = 1                                 |
hgs
parents:
diff changeset
  2031
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2032
	// |   u8_t value  |
hgs
parents:
diff changeset
  2033
	// +=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+=+
hgs
parents:
diff changeset
  2034
	// |                    Type = Variable data                       |
hgs
parents:
diff changeset
  2035
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2036
	// |                    Length = 8                                 |
hgs
parents:
diff changeset
  2037
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2038
	// |                    Value = Network key                        |
hgs
parents:
diff changeset
  2039
	// +-+-+-+-                                                 -+-+-+-+
hgs
parents:
diff changeset
  2040
	// |                                                               |
hgs
parents:
diff changeset
  2041
	// +#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+ <= end of Array of Network key
hgs
parents:
diff changeset
  2042
	// |                    Type = Variable data                       |
hgs
parents:
diff changeset
  2043
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2044
	// |                    Length = 6                                 |
hgs
parents:
diff changeset
  2045
	// +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2046
	// |                    Value = MAC address                        |
hgs
parents:
diff changeset
  2047
	// +-+-+-+-                        +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
hgs
parents:
diff changeset
  2048
	// |                               |
hgs
parents:
diff changeset
  2049
	// +#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+#+                                 <= end of Array of Protected setup credential
hgs
parents:
diff changeset
  2050
hgs
parents:
diff changeset
  2051
hgs
parents:
diff changeset
  2052
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
  2053
hgs
parents:
diff changeset
  2054
	{
hgs
parents:
diff changeset
  2055
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
  2056
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
  2057
hgs
parents:
diff changeset
  2058
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
  2059
		{
hgs
parents:
diff changeset
  2060
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  2061
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  2062
		}
hgs
parents:
diff changeset
  2063
hgs
parents:
diff changeset
  2064
		status = message.add_parameter_data(eap_tlv_message_type_function_new_protected_setup_credentials);
hgs
parents:
diff changeset
  2065
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  2066
		{
hgs
parents:
diff changeset
  2067
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  2068
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  2069
		}
hgs
parents:
diff changeset
  2070
hgs
parents:
diff changeset
  2071
		status = message.add_parameter_data(credential_array);
hgs
parents:
diff changeset
  2072
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  2073
		{
hgs
parents:
diff changeset
  2074
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  2075
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  2076
		}
hgs
parents:
diff changeset
  2077
hgs
parents:
diff changeset
  2078
		status = send_message(&message);
hgs
parents:
diff changeset
  2079
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  2080
		{
hgs
parents:
diff changeset
  2081
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  2082
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  2083
		}
hgs
parents:
diff changeset
  2084
	}
hgs
parents:
diff changeset
  2085
hgs
parents:
diff changeset
  2086
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
  2087
hgs
parents:
diff changeset
  2088
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  2089
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  2090
}
hgs
parents:
diff changeset
  2091
hgs
parents:
diff changeset
  2092
#endif // #if defined(USE_EAP_SIMPLE_CONFIG)
hgs
parents:
diff changeset
  2093
hgs
parents:
diff changeset
  2094
//--------------------------------------------------
hgs
parents:
diff changeset
  2095
hgs
parents:
diff changeset
  2096
eap_am_message_if_c * eap_am_message_if_c::new_eap_am_server_message_if_c(
hgs
parents:
diff changeset
  2097
	abs_eap_am_tools_c * const tools,
hgs
parents:
diff changeset
  2098
	const bool is_client_when_true,
hgs
parents:
diff changeset
  2099
	const u32_t MTU)
hgs
parents:
diff changeset
  2100
{
49
hgs
parents: 36
diff changeset
  2101
	EAP_TRACE_DEBUG(
hgs
parents: 36
diff changeset
  2102
		tools, 
hgs
parents: 36
diff changeset
  2103
		TRACE_FLAGS_DEFAULT, 
hgs
parents: 36
diff changeset
  2104
		(EAPL("eap_core_server_message_if_c::new_eap_am_server_message_if_c()\n")));
hgs
parents: 36
diff changeset
  2105
hgs
parents: 36
diff changeset
  2106
	EAP_TRACE_RETURN_STRING_FLAGS(tools, TRACE_FLAGS_DEFAULT, "returns: eap_core_server_message_if_c::new_eap_am_server_message_if_c()");
hgs
parents: 36
diff changeset
  2107
26
hgs
parents:
diff changeset
  2108
	eap_am_message_if_c * server = new eap_core_server_message_if_c(
hgs
parents:
diff changeset
  2109
		tools,
hgs
parents:
diff changeset
  2110
		is_client_when_true,
hgs
parents:
diff changeset
  2111
		MTU);
hgs
parents:
diff changeset
  2112
hgs
parents:
diff changeset
  2113
	eap_automatic_variable_c<eap_am_message_if_c> automatic_server(
hgs
parents:
diff changeset
  2114
		tools,
hgs
parents:
diff changeset
  2115
		server);
hgs
parents:
diff changeset
  2116
hgs
parents:
diff changeset
  2117
	if (server == 0
hgs
parents:
diff changeset
  2118
		|| server->get_is_valid() == false)
hgs
parents:
diff changeset
  2119
	{
hgs
parents:
diff changeset
  2120
		// ERROR.
hgs
parents:
diff changeset
  2121
		if (server != 0)
hgs
parents:
diff changeset
  2122
		{
hgs
parents:
diff changeset
  2123
			EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  2124
				tools,
hgs
parents:
diff changeset
  2125
				TRACE_FLAGS_ALWAYS|TRACE_FLAGS_DEFAULT, 
hgs
parents:
diff changeset
  2126
				(EAPL("ERROR: calls: eap_am_message_if_c::new_eap_am_server_message_if_c(): server->shutdown(): %s.\n"),
hgs
parents:
diff changeset
  2127
				(is_client_when_true == true) ? "client": "server"));
hgs
parents:
diff changeset
  2128
hgs
parents:
diff changeset
  2129
			server->shutdown();
hgs
parents:
diff changeset
  2130
		}
hgs
parents:
diff changeset
  2131
hgs
parents:
diff changeset
  2132
		return 0;
hgs
parents:
diff changeset
  2133
	}
hgs
parents:
diff changeset
  2134
hgs
parents:
diff changeset
  2135
	automatic_server.do_not_free_variable();
hgs
parents:
diff changeset
  2136
hgs
parents:
diff changeset
  2137
	return server;
hgs
parents:
diff changeset
  2138
}
hgs
parents:
diff changeset
  2139
hgs
parents:
diff changeset
  2140
//--------------------------------------------------
hgs
parents:
diff changeset
  2141
// End.