eapol/eapol_framework/eapol_common/core/eap_plugin_server_message_if.cpp
author hgs
Mon, 24 May 2010 20:32:47 +0300
changeset 26 9abfd4f00d37
child 34 ad1f037f1ac2
permissions -rw-r--r--
201021
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
26
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2001-2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  EAP-plugin message interface in the server.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
/*
hgs
parents:
diff changeset
    19
* %version: 11 %
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_plugin_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
hgs
parents:
diff changeset
    41
//--------------------------------------------------
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
// 
hgs
parents:
diff changeset
    44
EAP_FUNC_EXPORT eap_plugin_server_message_if_c::~eap_plugin_server_message_if_c()
hgs
parents:
diff changeset
    45
{
hgs
parents:
diff changeset
    46
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
    49
		m_am_tools, 
hgs
parents:
diff changeset
    50
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
    51
		(EAPL("eap_plugin_server_message_if_c::~eap_plugin_server_message_if_c(): this = 0x%08x\n"),
hgs
parents:
diff changeset
    52
		this));
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
	EAP_ASSERT(m_shutdown_was_called == true);
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
	delete m_am_plugin;
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
    59
}
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
//--------------------------------------------------
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
#if defined(_WIN32) && !defined(__GNUC__)
hgs
parents:
diff changeset
    64
	#pragma warning( disable : 4355 ) // 'this' : used in base member initializer list
hgs
parents:
diff changeset
    65
#endif
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
// 
hgs
parents:
diff changeset
    68
EAP_FUNC_EXPORT eap_plugin_server_message_if_c::eap_plugin_server_message_if_c(
hgs
parents:
diff changeset
    69
	abs_eap_am_tools_c * const tools)
hgs
parents:
diff changeset
    70
	: m_partner(0)
hgs
parents:
diff changeset
    71
	, m_am_plugin(new_eap_am_plugin_c(tools, this))
hgs
parents:
diff changeset
    72
	, m_am_tools(tools)
hgs
parents:
diff changeset
    73
	, m_error_code(eap_status_ok)
hgs
parents:
diff changeset
    74
	, m_error_function(eap_tlv_message_type_function_none)
hgs
parents:
diff changeset
    75
	, m_is_client(false)
hgs
parents:
diff changeset
    76
	, m_is_valid(false)
hgs
parents:
diff changeset
    77
	, m_shutdown_was_called(false)
hgs
parents:
diff changeset
    78
{
hgs
parents:
diff changeset
    79
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
    80
hgs
parents:
diff changeset
    81
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
    82
		m_am_tools, 
hgs
parents:
diff changeset
    83
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
    84
		(EAPL("eap_plugin_server_message_if_c::eap_plugin_server_message_if_c(): %s, this = 0x%08x => 0x%08x, compiled %s %s.\n"),
hgs
parents:
diff changeset
    85
		(m_is_client == true) ? "client": "server",
hgs
parents:
diff changeset
    86
		this,
hgs
parents:
diff changeset
    87
		dynamic_cast<abs_eap_base_timer_c *>(this),
hgs
parents:
diff changeset
    88
		__DATE__,
hgs
parents:
diff changeset
    89
		__TIME__));
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
	if (m_am_plugin != 0
hgs
parents:
diff changeset
    92
		&& m_am_plugin->get_is_valid() == true)
hgs
parents:
diff changeset
    93
	{
hgs
parents:
diff changeset
    94
		set_is_valid();
hgs
parents:
diff changeset
    95
	}
hgs
parents:
diff changeset
    96
hgs
parents:
diff changeset
    97
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
    98
}
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
//--------------------------------------------------
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
//
hgs
parents:
diff changeset
   103
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::configure(
hgs
parents:
diff changeset
   104
	const eap_variable_data_c * const client_configuration)
hgs
parents:
diff changeset
   105
{
hgs
parents:
diff changeset
   106
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   109
		m_am_tools,
hgs
parents:
diff changeset
   110
		EAP_TRACE_FLAGS_MESSAGE_DATA,
hgs
parents:
diff changeset
   111
		(EAPL("%s: eap_plugin_server_message_if_c::configure()\n"),
hgs
parents:
diff changeset
   112
		(m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::configure()");
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
	if (m_am_plugin != 0)
hgs
parents:
diff changeset
   119
	{
hgs
parents:
diff changeset
   120
		status = m_am_plugin->configure();
hgs
parents:
diff changeset
   121
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   122
		{
hgs
parents:
diff changeset
   123
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   124
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   125
		}
hgs
parents:
diff changeset
   126
	}
hgs
parents:
diff changeset
   127
hgs
parents:
diff changeset
   128
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   129
}
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
//--------------------------------------------------
hgs
parents:
diff changeset
   132
hgs
parents:
diff changeset
   133
//
hgs
parents:
diff changeset
   134
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::shutdown()
hgs
parents:
diff changeset
   135
{
hgs
parents:
diff changeset
   136
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   137
		m_am_tools,
hgs
parents:
diff changeset
   138
		EAP_TRACE_FLAGS_MESSAGE_DATA,
hgs
parents:
diff changeset
   139
		(EAPL("%s: eap_plugin_server_message_if_c::shutdown(), m_shutdown_was_called=%d\n"),
hgs
parents:
diff changeset
   140
		(m_is_client == true) ? "client": "server",
hgs
parents:
diff changeset
   141
		m_shutdown_was_called));
hgs
parents:
diff changeset
   142
hgs
parents:
diff changeset
   143
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::shutdown()");
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
	EAP_ASSERT(m_am_tools->get_global_mutex()->get_is_reserved() == true);
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
	if (m_shutdown_was_called == true)
hgs
parents:
diff changeset
   148
	{
hgs
parents:
diff changeset
   149
		// Shutdown function was called already.
hgs
parents:
diff changeset
   150
		return EAP_STATUS_RETURN(m_am_tools, eap_status_ok);
hgs
parents:
diff changeset
   151
	}
hgs
parents:
diff changeset
   152
	m_shutdown_was_called = true;
hgs
parents:
diff changeset
   153
hgs
parents:
diff changeset
   154
	if (m_am_plugin != 0)
hgs
parents:
diff changeset
   155
	{
hgs
parents:
diff changeset
   156
		(void) m_am_plugin->shutdown();
hgs
parents:
diff changeset
   157
	}
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
	return EAP_STATUS_RETURN(m_am_tools, eap_status_ok);
hgs
parents:
diff changeset
   160
}
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
//--------------------------------------------------
hgs
parents:
diff changeset
   163
hgs
parents:
diff changeset
   164
//
hgs
parents:
diff changeset
   165
EAP_FUNC_EXPORT void eap_plugin_server_message_if_c::set_partner(abs_eap_am_message_if_c * const partner)
hgs
parents:
diff changeset
   166
{
hgs
parents:
diff changeset
   167
	m_partner = partner;
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_plugin_server_message_if_c::send_error_message(
hgs
parents:
diff changeset
   173
	const eap_status_e error_code,
hgs
parents:
diff changeset
   174
	const eap_tlv_message_type_function_e function)
hgs
parents:
diff changeset
   175
{
hgs
parents:
diff changeset
   176
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   177
hgs
parents:
diff changeset
   178
	{
hgs
parents:
diff changeset
   179
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   180
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
   183
		{
hgs
parents:
diff changeset
   184
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   185
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   186
		}
hgs
parents:
diff changeset
   187
hgs
parents:
diff changeset
   188
		status = message.add_parameter_data(
hgs
parents:
diff changeset
   189
			eap_tlv_message_type_error,
hgs
parents:
diff changeset
   190
			static_cast<u32_t>(error_code));
hgs
parents:
diff changeset
   191
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   192
		{
hgs
parents:
diff changeset
   193
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   194
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   195
		}
hgs
parents:
diff changeset
   196
hgs
parents:
diff changeset
   197
		status = message.add_parameter_data(function);
hgs
parents:
diff changeset
   198
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   199
		{
hgs
parents:
diff changeset
   200
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   201
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   202
		}
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
		status = send_message(&message);
hgs
parents:
diff changeset
   205
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   206
		{
hgs
parents:
diff changeset
   207
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   208
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   209
		}
hgs
parents:
diff changeset
   210
	}
hgs
parents:
diff changeset
   211
hgs
parents:
diff changeset
   212
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   213
	return EAP_STATUS_RETURN(m_am_tools, eap_status_ok);
hgs
parents:
diff changeset
   214
}
hgs
parents:
diff changeset
   215
hgs
parents:
diff changeset
   216
//--------------------------------------------------
hgs
parents:
diff changeset
   217
hgs
parents:
diff changeset
   218
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::send_message(eap_process_tlv_message_data_c * const message)
hgs
parents:
diff changeset
   219
{
hgs
parents:
diff changeset
   220
	// Sends message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   221
hgs
parents:
diff changeset
   222
	EAP_TRACE_DATA_DEBUG(
hgs
parents:
diff changeset
   223
		m_am_tools,
hgs
parents:
diff changeset
   224
		EAP_TRACE_FLAGS_MESSAGE_DATA,
hgs
parents:
diff changeset
   225
		(EAPL("eap_core_client_message_if_c::send_message()"),
hgs
parents:
diff changeset
   226
		message->get_message_data(),
hgs
parents:
diff changeset
   227
		message->get_message_data_length()));
hgs
parents:
diff changeset
   228
hgs
parents:
diff changeset
   229
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_core_client_message_if_c::send_message()");
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231
	eap_status_e send_status = m_partner->send_data(
hgs
parents:
diff changeset
   232
		message->get_message_data(),
hgs
parents:
diff changeset
   233
		message->get_message_data_length());
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, send_status);
hgs
parents:
diff changeset
   237
}
hgs
parents:
diff changeset
   238
hgs
parents:
diff changeset
   239
//--------------------------------------------------
hgs
parents:
diff changeset
   240
hgs
parents:
diff changeset
   241
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::process_message_type_error(
hgs
parents:
diff changeset
   242
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
   243
{
hgs
parents:
diff changeset
   244
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   245
hgs
parents:
diff changeset
   246
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
   247
hgs
parents:
diff changeset
   248
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
   249
	{
hgs
parents:
diff changeset
   250
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   251
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   252
	}
hgs
parents:
diff changeset
   253
hgs
parents:
diff changeset
   254
	// Error payload is the first in this case.
hgs
parents:
diff changeset
   255
	status = message_data.read_parameter_data(parameters, eap_message_payload_index_function, eap_tlv_message_type_error, &m_error_code);
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
	// Fuction payload is the second in this case.
hgs
parents:
diff changeset
   263
	status = message_data.read_parameter_data(parameters, eap_message_payload_index_first_parameter, &m_error_function);
hgs
parents:
diff changeset
   264
hgs
parents:
diff changeset
   265
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   266
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   267
}
hgs
parents:
diff changeset
   268
hgs
parents:
diff changeset
   269
//--------------------------------------------------
hgs
parents:
diff changeset
   270
hgs
parents:
diff changeset
   271
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::process_message(eap_process_tlv_message_data_c * const message)
hgs
parents:
diff changeset
   272
{
hgs
parents:
diff changeset
   273
	// Parses message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   274
hgs
parents:
diff changeset
   275
	EAP_TRACE_DATA_DEBUG(
hgs
parents:
diff changeset
   276
		m_am_tools,
hgs
parents:
diff changeset
   277
		EAP_TRACE_FLAGS_MESSAGE_DATA,
hgs
parents:
diff changeset
   278
		(EAPL("eap_plugin_server_message_if_c::process_message()"),
hgs
parents:
diff changeset
   279
		message->get_message_data(),
hgs
parents:
diff changeset
   280
		message->get_message_data_length()));
hgs
parents:
diff changeset
   281
hgs
parents:
diff changeset
   282
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::process_message()");
hgs
parents:
diff changeset
   283
hgs
parents:
diff changeset
   284
	eap_array_c<eap_tlv_header_c> parameters(m_am_tools);
hgs
parents:
diff changeset
   285
hgs
parents:
diff changeset
   286
	eap_status_e status = message->parse_message_data(&parameters);
hgs
parents:
diff changeset
   287
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   288
	{
hgs
parents:
diff changeset
   289
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   290
hgs
parents:
diff changeset
   291
		(void) send_error_message(
hgs
parents:
diff changeset
   292
			status,
hgs
parents:
diff changeset
   293
			eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   294
hgs
parents:
diff changeset
   295
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   296
	}
hgs
parents:
diff changeset
   297
hgs
parents:
diff changeset
   298
	if (parameters.get_object_count() == 0)
hgs
parents:
diff changeset
   299
	{
hgs
parents:
diff changeset
   300
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   301
hgs
parents:
diff changeset
   302
		status = eap_status_illegal_parameter;
hgs
parents:
diff changeset
   303
hgs
parents:
diff changeset
   304
		(void) send_error_message(
hgs
parents:
diff changeset
   305
			status,
hgs
parents:
diff changeset
   306
			eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   307
hgs
parents:
diff changeset
   308
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   309
	}
hgs
parents:
diff changeset
   310
hgs
parents:
diff changeset
   311
	const eap_tlv_header_c * const function_header = parameters.get_object(eap_message_payload_index_function);
hgs
parents:
diff changeset
   312
	if (function_header == 0
hgs
parents:
diff changeset
   313
		|| (function_header->get_type() != eap_tlv_message_type_error
hgs
parents:
diff changeset
   314
			&& function_header->get_type() != eap_tlv_message_type_function))
hgs
parents:
diff changeset
   315
	{
hgs
parents:
diff changeset
   316
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   317
hgs
parents:
diff changeset
   318
		status = eap_status_illegal_parameter;
hgs
parents:
diff changeset
   319
hgs
parents:
diff changeset
   320
		(void) send_error_message(
hgs
parents:
diff changeset
   321
			status,
hgs
parents:
diff changeset
   322
			eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   323
hgs
parents:
diff changeset
   324
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   325
	}
hgs
parents:
diff changeset
   326
hgs
parents:
diff changeset
   327
	if (function_header->get_type() == eap_tlv_message_type_error)
hgs
parents:
diff changeset
   328
	{
hgs
parents:
diff changeset
   329
		status = process_message_type_error(&parameters);
hgs
parents:
diff changeset
   330
	}
hgs
parents:
diff changeset
   331
	else // function_header->get_type() == eap_tlv_message_type_function
hgs
parents:
diff changeset
   332
	{
hgs
parents:
diff changeset
   333
		eap_tlv_message_type_function_e function(eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   334
hgs
parents:
diff changeset
   335
		status = message->get_parameter_data(function_header, &function);
hgs
parents:
diff changeset
   336
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   337
		{
hgs
parents:
diff changeset
   338
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   339
hgs
parents:
diff changeset
   340
			(void) send_error_message(
hgs
parents:
diff changeset
   341
				status,
hgs
parents:
diff changeset
   342
				eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   343
hgs
parents:
diff changeset
   344
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   345
		}
hgs
parents:
diff changeset
   346
hgs
parents:
diff changeset
   347
		switch(function)
hgs
parents:
diff changeset
   348
		{
hgs
parents:
diff changeset
   349
		case eap_tlv_message_type_function_plugin_get_configuration:
hgs
parents:
diff changeset
   350
			status = get_configuration(&parameters);
hgs
parents:
diff changeset
   351
			break;
hgs
parents:
diff changeset
   352
		case eap_tlv_message_type_function_plugin_set_configuration:
hgs
parents:
diff changeset
   353
			status = set_configuration(&parameters);
hgs
parents:
diff changeset
   354
			break;
hgs
parents:
diff changeset
   355
		case eap_tlv_message_type_function_plugin_copy_configuration:
hgs
parents:
diff changeset
   356
			status = copy_configuration(&parameters);
hgs
parents:
diff changeset
   357
			break;
hgs
parents:
diff changeset
   358
		case eap_tlv_message_type_function_plugin_delete_configuration:
hgs
parents:
diff changeset
   359
			status = delete_configuration(&parameters);
hgs
parents:
diff changeset
   360
			break;
hgs
parents:
diff changeset
   361
		case eap_tlv_message_type_function_plugin_set_index:
hgs
parents:
diff changeset
   362
			status = set_index(&parameters);
hgs
parents:
diff changeset
   363
			break;
hgs
parents:
diff changeset
   364
		case eap_tlv_message_type_function_plugin_get_type_info:
hgs
parents:
diff changeset
   365
			status = get_type_info(&parameters);
hgs
parents:
diff changeset
   366
			break;
hgs
parents:
diff changeset
   367
		case eap_tlv_message_type_function_plugin_invoke_ui:
hgs
parents:
diff changeset
   368
			status = invoke_ui(&parameters);
hgs
parents:
diff changeset
   369
			break;
hgs
parents:
diff changeset
   370
		default:
hgs
parents:
diff changeset
   371
			EAP_TRACE_ERROR(
hgs
parents:
diff changeset
   372
				m_am_tools,
hgs
parents:
diff changeset
   373
				TRACE_FLAGS_DEFAULT,
hgs
parents:
diff changeset
   374
				(EAPL("ERROR: process_data(): unknown function %d.\n"),
hgs
parents:
diff changeset
   375
				 function));
hgs
parents:
diff changeset
   376
hgs
parents:
diff changeset
   377
			status = eap_status_illegal_parameter;
hgs
parents:
diff changeset
   378
hgs
parents:
diff changeset
   379
			EAP_ASSERT_ANYWAY_TOOLS(m_am_tools);
hgs
parents:
diff changeset
   380
		};
hgs
parents:
diff changeset
   381
hgs
parents:
diff changeset
   382
		if (status != eap_status_ok
hgs
parents:
diff changeset
   383
			&& status != eap_status_success
hgs
parents:
diff changeset
   384
			&& status != eap_status_pending_request
hgs
parents:
diff changeset
   385
			&& status != eap_status_completed_request
hgs
parents:
diff changeset
   386
			&& status != eap_status_drop_packet_quietly)
hgs
parents:
diff changeset
   387
		{
hgs
parents:
diff changeset
   388
			(void) send_error_message(
hgs
parents:
diff changeset
   389
				status,
hgs
parents:
diff changeset
   390
				function);
hgs
parents:
diff changeset
   391
		}
hgs
parents:
diff changeset
   392
	}
hgs
parents:
diff changeset
   393
hgs
parents:
diff changeset
   394
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
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
//--------------------------------------------------
hgs
parents:
diff changeset
   399
hgs
parents:
diff changeset
   400
/// Function receives the data message from lower layer.
hgs
parents:
diff changeset
   401
/// Data is formatted to Attribute-Value Pairs.
hgs
parents:
diff changeset
   402
/// Look at eap_tlv_header_c and eap_tlv_message_data_c.
hgs
parents:
diff changeset
   403
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::process_data(const void * const data, const u32_t length)
hgs
parents:
diff changeset
   404
{
hgs
parents:
diff changeset
   405
	EAP_TRACE_DATA_DEBUG(
hgs
parents:
diff changeset
   406
		m_am_tools,
hgs
parents:
diff changeset
   407
		EAP_TRACE_FLAGS_MESSAGE_DATA,
hgs
parents:
diff changeset
   408
		(EAPL("eap_plugin_server_message_if_c::process_data()"),
hgs
parents:
diff changeset
   409
		data,
hgs
parents:
diff changeset
   410
		length));
hgs
parents:
diff changeset
   411
hgs
parents:
diff changeset
   412
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::process_message()");
hgs
parents:
diff changeset
   413
hgs
parents:
diff changeset
   414
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   415
hgs
parents:
diff changeset
   416
	{
hgs
parents:
diff changeset
   417
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
   418
hgs
parents:
diff changeset
   419
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
   420
		{
hgs
parents:
diff changeset
   421
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   422
hgs
parents:
diff changeset
   423
			status = eap_status_allocation_error;
hgs
parents:
diff changeset
   424
hgs
parents:
diff changeset
   425
			(void) send_error_message(
hgs
parents:
diff changeset
   426
				status,
hgs
parents:
diff changeset
   427
				eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   428
hgs
parents:
diff changeset
   429
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   430
		}
hgs
parents:
diff changeset
   431
hgs
parents:
diff changeset
   432
		status = message.set_message_data(length, data);
hgs
parents:
diff changeset
   433
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   434
		{
hgs
parents:
diff changeset
   435
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   436
hgs
parents:
diff changeset
   437
			(void) send_error_message(
hgs
parents:
diff changeset
   438
				status,
hgs
parents:
diff changeset
   439
				eap_tlv_message_type_function_none);
hgs
parents:
diff changeset
   440
hgs
parents:
diff changeset
   441
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   442
		}
hgs
parents:
diff changeset
   443
hgs
parents:
diff changeset
   444
		status = process_message(&message);
hgs
parents:
diff changeset
   445
	}
hgs
parents:
diff changeset
   446
hgs
parents:
diff changeset
   447
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   448
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   449
}
hgs
parents:
diff changeset
   450
hgs
parents:
diff changeset
   451
//--------------------------------------------------
hgs
parents:
diff changeset
   452
hgs
parents:
diff changeset
   453
//
hgs
parents:
diff changeset
   454
EAP_FUNC_EXPORT void eap_plugin_server_message_if_c::set_is_valid()
hgs
parents:
diff changeset
   455
{
hgs
parents:
diff changeset
   456
	m_is_valid = true;
hgs
parents:
diff changeset
   457
}
hgs
parents:
diff changeset
   458
hgs
parents:
diff changeset
   459
//--------------------------------------------------
hgs
parents:
diff changeset
   460
hgs
parents:
diff changeset
   461
//
hgs
parents:
diff changeset
   462
EAP_FUNC_EXPORT bool eap_plugin_server_message_if_c::get_is_valid()
hgs
parents:
diff changeset
   463
{
hgs
parents:
diff changeset
   464
	return m_is_valid;
hgs
parents:
diff changeset
   465
}
hgs
parents:
diff changeset
   466
hgs
parents:
diff changeset
   467
//--------------------------------------------------
hgs
parents:
diff changeset
   468
hgs
parents:
diff changeset
   469
//
hgs
parents:
diff changeset
   470
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::timer_expired(
hgs
parents:
diff changeset
   471
	const u32_t id, void *data)
hgs
parents:
diff changeset
   472
{
hgs
parents:
diff changeset
   473
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   474
hgs
parents:
diff changeset
   475
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   476
		m_am_tools,
hgs
parents:
diff changeset
   477
		EAP_TRACE_FLAGS_MESSAGE_DATA,
hgs
parents:
diff changeset
   478
		(EAPL("TIMER: %s: [0x%08x]->eap_plugin_server_message_if_c::timer_expired(id 0x%02x, data 0x%08x).\n"),
hgs
parents:
diff changeset
   479
		 (m_is_client == true) ? "client": "server",
hgs
parents:
diff changeset
   480
		 this,
hgs
parents:
diff changeset
   481
		 id,
hgs
parents:
diff changeset
   482
		 data));
hgs
parents:
diff changeset
   483
hgs
parents:
diff changeset
   484
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::timer_expired()");
hgs
parents:
diff changeset
   485
hgs
parents:
diff changeset
   486
hgs
parents:
diff changeset
   487
	return EAP_STATUS_RETURN(m_am_tools, eap_status_ok);
hgs
parents:
diff changeset
   488
}
hgs
parents:
diff changeset
   489
hgs
parents:
diff changeset
   490
//--------------------------------------------------
hgs
parents:
diff changeset
   491
hgs
parents:
diff changeset
   492
//
hgs
parents:
diff changeset
   493
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::timer_delete_data(
hgs
parents:
diff changeset
   494
	const u32_t id, void *data)
hgs
parents:
diff changeset
   495
{
hgs
parents:
diff changeset
   496
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   497
hgs
parents:
diff changeset
   498
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   499
		m_am_tools,
hgs
parents:
diff changeset
   500
		EAP_TRACE_FLAGS_MESSAGE_DATA,
hgs
parents:
diff changeset
   501
		(EAPL("TIMER: %s: [0x%08x]->eap_plugin_server_message_if_c::timer_delete_data(id 0x%02x, data 0x%08x).\n"),
hgs
parents:
diff changeset
   502
		(m_is_client == true) ? "client": "server",
hgs
parents:
diff changeset
   503
		this, id, data));
hgs
parents:
diff changeset
   504
hgs
parents:
diff changeset
   505
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::timer_delete_data()");
hgs
parents:
diff changeset
   506
hgs
parents:
diff changeset
   507
	return EAP_STATUS_RETURN(m_am_tools, eap_status_ok);
hgs
parents:
diff changeset
   508
}
hgs
parents:
diff changeset
   509
hgs
parents:
diff changeset
   510
//--------------------------------------------------
hgs
parents:
diff changeset
   511
hgs
parents:
diff changeset
   512
eap_status_e eap_plugin_server_message_if_c::get_configuration(
hgs
parents:
diff changeset
   513
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
   514
{
hgs
parents:
diff changeset
   515
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   516
hgs
parents:
diff changeset
   517
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   518
		m_am_tools, 
hgs
parents:
diff changeset
   519
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
   520
		(EAPL("%s: eap_plugin_server_message_if_c::get_configuration(): parameters=0x%08x, count=%d\n"),
hgs
parents:
diff changeset
   521
		 (m_is_client == true) ? "client": "server",
hgs
parents:
diff changeset
   522
		 parameters,
hgs
parents:
diff changeset
   523
		 (parameters != 0) ? parameters->get_object_count(): 0));
hgs
parents:
diff changeset
   524
hgs
parents:
diff changeset
   525
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::get_configuration()");
hgs
parents:
diff changeset
   526
hgs
parents:
diff changeset
   527
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   528
hgs
parents:
diff changeset
   529
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   530
hgs
parents:
diff changeset
   531
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
   532
hgs
parents:
diff changeset
   533
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
   534
hgs
parents:
diff changeset
   535
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
   536
	{
hgs
parents:
diff changeset
   537
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   538
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   539
	}
hgs
parents:
diff changeset
   540
hgs
parents:
diff changeset
   541
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   542
hgs
parents:
diff changeset
   543
	eap_method_settings_c * const internal_settings = new eap_method_settings_c(m_am_tools);
hgs
parents:
diff changeset
   544
hgs
parents:
diff changeset
   545
	eap_automatic_variable_c<eap_method_settings_c> automatic_internal_settings(m_am_tools, internal_settings);
hgs
parents:
diff changeset
   546
hgs
parents:
diff changeset
   547
	if (internal_settings == 0)
hgs
parents:
diff changeset
   548
	{
hgs
parents:
diff changeset
   549
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   550
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   551
	}
hgs
parents:
diff changeset
   552
hgs
parents:
diff changeset
   553
	status = message_data.read_parameter_data(parameters, parameter_index, internal_settings);
hgs
parents:
diff changeset
   554
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   555
	{
hgs
parents:
diff changeset
   556
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   557
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   558
	}
hgs
parents:
diff changeset
   559
hgs
parents:
diff changeset
   560
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   561
hgs
parents:
diff changeset
   562
	status = m_am_plugin->get_configuration(
hgs
parents:
diff changeset
   563
		internal_settings
hgs
parents:
diff changeset
   564
		);
hgs
parents:
diff changeset
   565
hgs
parents:
diff changeset
   566
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   567
hgs
parents:
diff changeset
   568
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   569
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   570
}
hgs
parents:
diff changeset
   571
hgs
parents:
diff changeset
   572
//--------------------------------------------------
hgs
parents:
diff changeset
   573
hgs
parents:
diff changeset
   574
eap_status_e eap_plugin_server_message_if_c::set_configuration(
hgs
parents:
diff changeset
   575
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
   576
{
hgs
parents:
diff changeset
   577
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   578
hgs
parents:
diff changeset
   579
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   580
		m_am_tools, 
hgs
parents:
diff changeset
   581
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
   582
		(EAPL("%s: eap_plugin_server_message_if_c::set_configuration()\n"),
hgs
parents:
diff changeset
   583
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   584
hgs
parents:
diff changeset
   585
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::set_configuration()");
hgs
parents:
diff changeset
   586
hgs
parents:
diff changeset
   587
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   588
hgs
parents:
diff changeset
   589
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   590
hgs
parents:
diff changeset
   591
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
   592
hgs
parents:
diff changeset
   593
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
   594
hgs
parents:
diff changeset
   595
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
   596
	{
hgs
parents:
diff changeset
   597
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   598
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   599
	}
hgs
parents:
diff changeset
   600
hgs
parents:
diff changeset
   601
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   602
hgs
parents:
diff changeset
   603
	eap_method_settings_c * const internal_settings = new eap_method_settings_c(m_am_tools);
hgs
parents:
diff changeset
   604
hgs
parents:
diff changeset
   605
	eap_automatic_variable_c<eap_method_settings_c> automatic_internal_settings(m_am_tools, internal_settings);
hgs
parents:
diff changeset
   606
hgs
parents:
diff changeset
   607
	if (internal_settings == 0)
hgs
parents:
diff changeset
   608
	{
hgs
parents:
diff changeset
   609
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   610
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   611
	}
hgs
parents:
diff changeset
   612
hgs
parents:
diff changeset
   613
	status = message_data.read_parameter_data(parameters, parameter_index, internal_settings);
hgs
parents:
diff changeset
   614
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   615
	{
hgs
parents:
diff changeset
   616
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   617
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   618
	}
hgs
parents:
diff changeset
   619
hgs
parents:
diff changeset
   620
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   621
hgs
parents:
diff changeset
   622
	status = m_am_plugin->set_configuration(
hgs
parents:
diff changeset
   623
		internal_settings
hgs
parents:
diff changeset
   624
		);
hgs
parents:
diff changeset
   625
hgs
parents:
diff changeset
   626
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   627
hgs
parents:
diff changeset
   628
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   629
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   630
}
hgs
parents:
diff changeset
   631
hgs
parents:
diff changeset
   632
//--------------------------------------------------
hgs
parents:
diff changeset
   633
hgs
parents:
diff changeset
   634
eap_status_e eap_plugin_server_message_if_c::copy_configuration(
hgs
parents:
diff changeset
   635
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
   636
{
hgs
parents:
diff changeset
   637
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   638
hgs
parents:
diff changeset
   639
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   640
		m_am_tools, 
hgs
parents:
diff changeset
   641
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
   642
		(EAPL("%s: eap_plugin_server_message_if_c::copy_configuration()\n"),
hgs
parents:
diff changeset
   643
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   644
hgs
parents:
diff changeset
   645
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::copy_configuration()");
hgs
parents:
diff changeset
   646
hgs
parents:
diff changeset
   647
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   648
hgs
parents:
diff changeset
   649
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   650
hgs
parents:
diff changeset
   651
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
   652
hgs
parents:
diff changeset
   653
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
   654
hgs
parents:
diff changeset
   655
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
   656
	{
hgs
parents:
diff changeset
   657
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   658
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   659
	}
hgs
parents:
diff changeset
   660
hgs
parents:
diff changeset
   661
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   662
hgs
parents:
diff changeset
   663
	eap_method_settings_c * const internal_settings = new eap_method_settings_c(m_am_tools);
hgs
parents:
diff changeset
   664
hgs
parents:
diff changeset
   665
	eap_automatic_variable_c<eap_method_settings_c> automatic_internal_settings(m_am_tools, internal_settings);
hgs
parents:
diff changeset
   666
hgs
parents:
diff changeset
   667
	if (internal_settings == 0)
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, eap_status_allocation_error);
hgs
parents:
diff changeset
   671
	}
hgs
parents:
diff changeset
   672
hgs
parents:
diff changeset
   673
	status = message_data.read_parameter_data(parameters, parameter_index, internal_settings);
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
hgs
parents:
diff changeset
   682
	status = m_am_plugin->copy_configuration(
hgs
parents:
diff changeset
   683
		internal_settings
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_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   689
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   690
}
hgs
parents:
diff changeset
   691
hgs
parents:
diff changeset
   692
//--------------------------------------------------
hgs
parents:
diff changeset
   693
hgs
parents:
diff changeset
   694
eap_status_e eap_plugin_server_message_if_c::delete_configuration(
hgs
parents:
diff changeset
   695
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
   696
{
hgs
parents:
diff changeset
   697
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   698
hgs
parents:
diff changeset
   699
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   700
		m_am_tools, 
hgs
parents:
diff changeset
   701
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
   702
		(EAPL("%s: eap_plugin_server_message_if_c::delete_configuration()\n"),
hgs
parents:
diff changeset
   703
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   704
hgs
parents:
diff changeset
   705
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::delete_configuration()");
hgs
parents:
diff changeset
   706
hgs
parents:
diff changeset
   707
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   708
hgs
parents:
diff changeset
   709
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   710
hgs
parents:
diff changeset
   711
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
   712
hgs
parents:
diff changeset
   713
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
   714
hgs
parents:
diff changeset
   715
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
   716
	{
hgs
parents:
diff changeset
   717
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   718
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   719
	}
hgs
parents:
diff changeset
   720
hgs
parents:
diff changeset
   721
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   722
hgs
parents:
diff changeset
   723
	eap_method_settings_c * const internal_settings = new eap_method_settings_c(m_am_tools);
hgs
parents:
diff changeset
   724
hgs
parents:
diff changeset
   725
	eap_automatic_variable_c<eap_method_settings_c> automatic_internal_settings(m_am_tools, internal_settings);
hgs
parents:
diff changeset
   726
hgs
parents:
diff changeset
   727
	if (internal_settings == 0)
hgs
parents:
diff changeset
   728
	{
hgs
parents:
diff changeset
   729
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   730
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   731
	}
hgs
parents:
diff changeset
   732
hgs
parents:
diff changeset
   733
	status = message_data.read_parameter_data(parameters, parameter_index, internal_settings);
hgs
parents:
diff changeset
   734
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   735
	{
hgs
parents:
diff changeset
   736
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   737
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   738
	}
hgs
parents:
diff changeset
   739
hgs
parents:
diff changeset
   740
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   741
hgs
parents:
diff changeset
   742
	status = m_am_plugin->delete_configuration(
hgs
parents:
diff changeset
   743
		internal_settings
hgs
parents:
diff changeset
   744
		);
hgs
parents:
diff changeset
   745
hgs
parents:
diff changeset
   746
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   747
hgs
parents:
diff changeset
   748
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   749
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   750
}
hgs
parents:
diff changeset
   751
hgs
parents:
diff changeset
   752
//--------------------------------------------------
hgs
parents:
diff changeset
   753
hgs
parents:
diff changeset
   754
eap_status_e eap_plugin_server_message_if_c::set_index(
hgs
parents:
diff changeset
   755
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
   756
{
hgs
parents:
diff changeset
   757
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   758
hgs
parents:
diff changeset
   759
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   760
		m_am_tools, 
hgs
parents:
diff changeset
   761
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
   762
		(EAPL("%s: eap_plugin_server_message_if_c::set_index()\n"),
hgs
parents:
diff changeset
   763
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   764
hgs
parents:
diff changeset
   765
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::set_index()");
hgs
parents:
diff changeset
   766
hgs
parents:
diff changeset
   767
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   768
hgs
parents:
diff changeset
   769
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   770
hgs
parents:
diff changeset
   771
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
   772
hgs
parents:
diff changeset
   773
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
   774
hgs
parents:
diff changeset
   775
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
   776
	{
hgs
parents:
diff changeset
   777
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   778
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   779
	}
hgs
parents:
diff changeset
   780
hgs
parents:
diff changeset
   781
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   782
hgs
parents:
diff changeset
   783
	eap_method_settings_c * const internal_settings = new eap_method_settings_c(m_am_tools);
hgs
parents:
diff changeset
   784
hgs
parents:
diff changeset
   785
	eap_automatic_variable_c<eap_method_settings_c> automatic_internal_settings(m_am_tools, internal_settings);
hgs
parents:
diff changeset
   786
hgs
parents:
diff changeset
   787
	if (internal_settings == 0)
hgs
parents:
diff changeset
   788
	{
hgs
parents:
diff changeset
   789
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   790
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   791
	}
hgs
parents:
diff changeset
   792
hgs
parents:
diff changeset
   793
	status = message_data.read_parameter_data(parameters, parameter_index, internal_settings);
hgs
parents:
diff changeset
   794
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   795
	{
hgs
parents:
diff changeset
   796
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   797
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   798
	}
hgs
parents:
diff changeset
   799
hgs
parents:
diff changeset
   800
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   801
hgs
parents:
diff changeset
   802
	status = m_am_plugin->set_index(
hgs
parents:
diff changeset
   803
		internal_settings
hgs
parents:
diff changeset
   804
		);
hgs
parents:
diff changeset
   805
hgs
parents:
diff changeset
   806
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   807
hgs
parents:
diff changeset
   808
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   809
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   810
}
hgs
parents:
diff changeset
   811
hgs
parents:
diff changeset
   812
//--------------------------------------------------
hgs
parents:
diff changeset
   813
hgs
parents:
diff changeset
   814
eap_status_e eap_plugin_server_message_if_c::get_type_info(
hgs
parents:
diff changeset
   815
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
   816
{
hgs
parents:
diff changeset
   817
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   818
hgs
parents:
diff changeset
   819
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   820
		m_am_tools, 
hgs
parents:
diff changeset
   821
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
   822
		(EAPL("%s: eap_plugin_server_message_if_c::get_type_info()\n"),
hgs
parents:
diff changeset
   823
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   824
hgs
parents:
diff changeset
   825
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::get_type_info()");
hgs
parents:
diff changeset
   826
hgs
parents:
diff changeset
   827
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   828
hgs
parents:
diff changeset
   829
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   830
hgs
parents:
diff changeset
   831
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
   832
hgs
parents:
diff changeset
   833
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
   834
hgs
parents:
diff changeset
   835
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
   836
	{
hgs
parents:
diff changeset
   837
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   838
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   839
	}
hgs
parents:
diff changeset
   840
hgs
parents:
diff changeset
   841
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   842
hgs
parents:
diff changeset
   843
	eap_method_settings_c * const internal_settings = new eap_method_settings_c(m_am_tools);
hgs
parents:
diff changeset
   844
hgs
parents:
diff changeset
   845
	eap_automatic_variable_c<eap_method_settings_c> automatic_internal_settings(m_am_tools, internal_settings);
hgs
parents:
diff changeset
   846
hgs
parents:
diff changeset
   847
	if (internal_settings == 0)
hgs
parents:
diff changeset
   848
	{
hgs
parents:
diff changeset
   849
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   850
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   851
	}
hgs
parents:
diff changeset
   852
hgs
parents:
diff changeset
   853
	status = message_data.read_parameter_data(parameters, parameter_index, internal_settings);
hgs
parents:
diff changeset
   854
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   855
	{
hgs
parents:
diff changeset
   856
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   857
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   858
	}
hgs
parents:
diff changeset
   859
hgs
parents:
diff changeset
   860
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   861
hgs
parents:
diff changeset
   862
	status = m_am_plugin->get_type_info(
hgs
parents:
diff changeset
   863
		internal_settings
hgs
parents:
diff changeset
   864
		);
hgs
parents:
diff changeset
   865
hgs
parents:
diff changeset
   866
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   867
hgs
parents:
diff changeset
   868
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   869
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   870
}
hgs
parents:
diff changeset
   871
hgs
parents:
diff changeset
   872
//--------------------------------------------------
hgs
parents:
diff changeset
   873
hgs
parents:
diff changeset
   874
eap_status_e eap_plugin_server_message_if_c::invoke_ui(
hgs
parents:
diff changeset
   875
	EAP_TEMPLATE_CONST eap_array_c<eap_tlv_header_c> * const parameters)
hgs
parents:
diff changeset
   876
{
hgs
parents:
diff changeset
   877
	EAP_TRACE_BEGIN(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   878
hgs
parents:
diff changeset
   879
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   880
		m_am_tools, 
hgs
parents:
diff changeset
   881
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
   882
		(EAPL("%s: eap_plugin_server_message_if_c::invoke_ui()\n"),
hgs
parents:
diff changeset
   883
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   884
hgs
parents:
diff changeset
   885
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_plugin_server_message_if_c::invoke_ui()");
hgs
parents:
diff changeset
   886
hgs
parents:
diff changeset
   887
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   888
hgs
parents:
diff changeset
   889
	eap_status_e status(eap_status_ok);
hgs
parents:
diff changeset
   890
hgs
parents:
diff changeset
   891
	u32_t parameter_index(eap_message_payload_index_first_parameter);
hgs
parents:
diff changeset
   892
hgs
parents:
diff changeset
   893
	eap_process_tlv_message_data_c message_data(m_am_tools);
hgs
parents:
diff changeset
   894
hgs
parents:
diff changeset
   895
	if (message_data.get_is_valid() == false)
hgs
parents:
diff changeset
   896
	{
hgs
parents:
diff changeset
   897
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   898
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   899
	}
hgs
parents:
diff changeset
   900
hgs
parents:
diff changeset
   901
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   902
hgs
parents:
diff changeset
   903
	eap_method_settings_c * const internal_settings = new eap_method_settings_c(m_am_tools);
hgs
parents:
diff changeset
   904
hgs
parents:
diff changeset
   905
	eap_automatic_variable_c<eap_method_settings_c> automatic_internal_settings(m_am_tools, internal_settings);
hgs
parents:
diff changeset
   906
hgs
parents:
diff changeset
   907
	if (internal_settings == 0)
hgs
parents:
diff changeset
   908
	{
hgs
parents:
diff changeset
   909
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   910
		return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   911
	}
hgs
parents:
diff changeset
   912
hgs
parents:
diff changeset
   913
	status = message_data.read_parameter_data(parameters, parameter_index, internal_settings);
hgs
parents:
diff changeset
   914
	if (status != eap_status_ok)
hgs
parents:
diff changeset
   915
	{
hgs
parents:
diff changeset
   916
		EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   917
		return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   918
	}
hgs
parents:
diff changeset
   919
hgs
parents:
diff changeset
   920
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   921
hgs
parents:
diff changeset
   922
hgs
parents:
diff changeset
   923
hgs
parents:
diff changeset
   924
	// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
hgs
parents:
diff changeset
   925
hgs
parents:
diff changeset
   926
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   927
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   928
}
hgs
parents:
diff changeset
   929
hgs
parents:
diff changeset
   930
//--------------------------------------------------
hgs
parents:
diff changeset
   931
hgs
parents:
diff changeset
   932
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::complete_get_configuration(const eap_method_settings_c * const internal_settings)
hgs
parents:
diff changeset
   933
{
hgs
parents:
diff changeset
   934
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   935
hgs
parents:
diff changeset
   936
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   937
		m_am_tools, 
hgs
parents:
diff changeset
   938
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
   939
		(EAPL("%s: eap_core_server_message_if_c::complete_get_configuration()\n"),
hgs
parents:
diff changeset
   940
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   941
hgs
parents:
diff changeset
   942
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_core_server_message_if_c::complete_get_configuration()");
hgs
parents:
diff changeset
   943
hgs
parents:
diff changeset
   944
	{
hgs
parents:
diff changeset
   945
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   946
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
   947
hgs
parents:
diff changeset
   948
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
   949
		{
hgs
parents:
diff changeset
   950
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   951
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
   952
		}
hgs
parents:
diff changeset
   953
hgs
parents:
diff changeset
   954
		status = message.add_parameter_data(eap_tlv_message_type_function_plugin_complete_get_configuration);
hgs
parents:
diff changeset
   955
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   956
		{
hgs
parents:
diff changeset
   957
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   958
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   959
		}
hgs
parents:
diff changeset
   960
hgs
parents:
diff changeset
   961
		status = message.add_parameter_data(internal_settings);
hgs
parents:
diff changeset
   962
		if (status != eap_status_ok)
hgs
parents:
diff changeset
   963
		{
hgs
parents:
diff changeset
   964
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   965
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   966
		}
hgs
parents:
diff changeset
   967
hgs
parents:
diff changeset
   968
		status = send_message(&message);
hgs
parents:
diff changeset
   969
		if (status != eap_status_ok)
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
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
   977
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
   978
}
hgs
parents:
diff changeset
   979
hgs
parents:
diff changeset
   980
//--------------------------------------------------
hgs
parents:
diff changeset
   981
hgs
parents:
diff changeset
   982
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::complete_set_configuration(const eap_method_settings_c * const internal_settings)
hgs
parents:
diff changeset
   983
{
hgs
parents:
diff changeset
   984
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
   985
hgs
parents:
diff changeset
   986
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
   987
		m_am_tools, 
hgs
parents:
diff changeset
   988
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
   989
		(EAPL("%s: eap_core_server_message_if_c::complete_set_configuration()\n"),
hgs
parents:
diff changeset
   990
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
   991
hgs
parents:
diff changeset
   992
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_core_server_message_if_c::complete_set_configuration()");
hgs
parents:
diff changeset
   993
hgs
parents:
diff changeset
   994
	{
hgs
parents:
diff changeset
   995
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
   996
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
   997
hgs
parents:
diff changeset
   998
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
   999
		{
hgs
parents:
diff changeset
  1000
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1001
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1002
		}
hgs
parents:
diff changeset
  1003
hgs
parents:
diff changeset
  1004
		status = message.add_parameter_data(eap_tlv_message_type_function_plugin_complete_set_configuration);
hgs
parents:
diff changeset
  1005
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1006
		{
hgs
parents:
diff changeset
  1007
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1008
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1009
		}
hgs
parents:
diff changeset
  1010
hgs
parents:
diff changeset
  1011
		status = message.add_parameter_data(internal_settings);
hgs
parents:
diff changeset
  1012
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1013
		{
hgs
parents:
diff changeset
  1014
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1015
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1016
		}
hgs
parents:
diff changeset
  1017
hgs
parents:
diff changeset
  1018
		status = send_message(&message);
hgs
parents:
diff changeset
  1019
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1020
		{
hgs
parents:
diff changeset
  1021
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1022
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1023
		}
hgs
parents:
diff changeset
  1024
	}
hgs
parents:
diff changeset
  1025
hgs
parents:
diff changeset
  1026
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1027
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1028
}
hgs
parents:
diff changeset
  1029
hgs
parents:
diff changeset
  1030
//--------------------------------------------------
hgs
parents:
diff changeset
  1031
hgs
parents:
diff changeset
  1032
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::complete_delete_configuration(const eap_method_settings_c * const internal_settings)
hgs
parents:
diff changeset
  1033
{
hgs
parents:
diff changeset
  1034
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
  1035
hgs
parents:
diff changeset
  1036
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1037
		m_am_tools, 
hgs
parents:
diff changeset
  1038
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
  1039
		(EAPL("%s: eap_core_server_message_if_c::complete_delete_configuration()\n"),
hgs
parents:
diff changeset
  1040
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1041
hgs
parents:
diff changeset
  1042
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_core_server_message_if_c::complete_delete_configuration()");
hgs
parents:
diff changeset
  1043
hgs
parents:
diff changeset
  1044
	{
hgs
parents:
diff changeset
  1045
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
  1046
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
  1047
hgs
parents:
diff changeset
  1048
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
  1049
		{
hgs
parents:
diff changeset
  1050
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1051
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1052
		}
hgs
parents:
diff changeset
  1053
hgs
parents:
diff changeset
  1054
		status = message.add_parameter_data(eap_tlv_message_type_function_plugin_complete_delete_configuration);
hgs
parents:
diff changeset
  1055
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1056
		{
hgs
parents:
diff changeset
  1057
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1058
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1059
		}
hgs
parents:
diff changeset
  1060
hgs
parents:
diff changeset
  1061
		status = message.add_parameter_data(internal_settings);
hgs
parents:
diff changeset
  1062
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1063
		{
hgs
parents:
diff changeset
  1064
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1065
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1066
		}
hgs
parents:
diff changeset
  1067
hgs
parents:
diff changeset
  1068
		status = send_message(&message);
hgs
parents:
diff changeset
  1069
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1070
		{
hgs
parents:
diff changeset
  1071
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1072
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1073
		}
hgs
parents:
diff changeset
  1074
	}
hgs
parents:
diff changeset
  1075
hgs
parents:
diff changeset
  1076
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1077
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1078
}
hgs
parents:
diff changeset
  1079
hgs
parents:
diff changeset
  1080
//--------------------------------------------------
hgs
parents:
diff changeset
  1081
hgs
parents:
diff changeset
  1082
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::complete_copy_configuration(const eap_method_settings_c * const internal_settings)
hgs
parents:
diff changeset
  1083
{
hgs
parents:
diff changeset
  1084
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
  1085
hgs
parents:
diff changeset
  1086
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1087
		m_am_tools, 
hgs
parents:
diff changeset
  1088
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
  1089
		(EAPL("%s: eap_core_server_message_if_c::complete_copy_configuration()\n"),
hgs
parents:
diff changeset
  1090
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1091
hgs
parents:
diff changeset
  1092
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_core_server_message_if_c::complete_copy_configuration()");
hgs
parents:
diff changeset
  1093
hgs
parents:
diff changeset
  1094
	{
hgs
parents:
diff changeset
  1095
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
  1096
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
  1097
hgs
parents:
diff changeset
  1098
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
  1099
		{
hgs
parents:
diff changeset
  1100
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1101
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1102
		}
hgs
parents:
diff changeset
  1103
hgs
parents:
diff changeset
  1104
		status = message.add_parameter_data(eap_tlv_message_type_function_plugin_complete_copy_configuration);
hgs
parents:
diff changeset
  1105
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1106
		{
hgs
parents:
diff changeset
  1107
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1108
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1109
		}
hgs
parents:
diff changeset
  1110
hgs
parents:
diff changeset
  1111
		status = message.add_parameter_data(internal_settings);
hgs
parents:
diff changeset
  1112
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1113
		{
hgs
parents:
diff changeset
  1114
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1115
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1116
		}
hgs
parents:
diff changeset
  1117
hgs
parents:
diff changeset
  1118
		status = send_message(&message);
hgs
parents:
diff changeset
  1119
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1120
		{
hgs
parents:
diff changeset
  1121
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1122
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1123
		}
hgs
parents:
diff changeset
  1124
	}
hgs
parents:
diff changeset
  1125
hgs
parents:
diff changeset
  1126
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1127
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1128
}
hgs
parents:
diff changeset
  1129
hgs
parents:
diff changeset
  1130
//--------------------------------------------------
hgs
parents:
diff changeset
  1131
hgs
parents:
diff changeset
  1132
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::complete_set_index(const eap_method_settings_c * const internal_settings)
hgs
parents:
diff changeset
  1133
{
hgs
parents:
diff changeset
  1134
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
  1135
hgs
parents:
diff changeset
  1136
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1137
		m_am_tools, 
hgs
parents:
diff changeset
  1138
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
  1139
		(EAPL("%s: eap_core_server_message_if_c::complete_set_index()\n"),
hgs
parents:
diff changeset
  1140
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1141
hgs
parents:
diff changeset
  1142
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_core_server_message_if_c::complete_set_index()");
hgs
parents:
diff changeset
  1143
hgs
parents:
diff changeset
  1144
	{
hgs
parents:
diff changeset
  1145
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
  1146
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
  1147
hgs
parents:
diff changeset
  1148
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
  1149
		{
hgs
parents:
diff changeset
  1150
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1151
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1152
		}
hgs
parents:
diff changeset
  1153
hgs
parents:
diff changeset
  1154
		status = message.add_parameter_data(eap_tlv_message_type_function_plugin_complete_set_index);
hgs
parents:
diff changeset
  1155
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1156
		{
hgs
parents:
diff changeset
  1157
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1158
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1159
		}
hgs
parents:
diff changeset
  1160
hgs
parents:
diff changeset
  1161
		status = message.add_parameter_data(internal_settings);
hgs
parents:
diff changeset
  1162
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1163
		{
hgs
parents:
diff changeset
  1164
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1165
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1166
		}
hgs
parents:
diff changeset
  1167
hgs
parents:
diff changeset
  1168
		status = send_message(&message);
hgs
parents:
diff changeset
  1169
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1170
		{
hgs
parents:
diff changeset
  1171
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1172
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1173
		}
hgs
parents:
diff changeset
  1174
	}
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, status);
hgs
parents:
diff changeset
  1178
}
hgs
parents:
diff changeset
  1179
hgs
parents:
diff changeset
  1180
//--------------------------------------------------
hgs
parents:
diff changeset
  1181
hgs
parents:
diff changeset
  1182
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::complete_get_type_info(const eap_method_settings_c * const internal_settings)
hgs
parents:
diff changeset
  1183
{
hgs
parents:
diff changeset
  1184
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
  1185
hgs
parents:
diff changeset
  1186
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1187
		m_am_tools, 
hgs
parents:
diff changeset
  1188
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
  1189
		(EAPL("%s: eap_core_server_message_if_c::complete_get_type_info()\n"),
hgs
parents:
diff changeset
  1190
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1191
hgs
parents:
diff changeset
  1192
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_core_server_message_if_c::complete_get_type_info()");
hgs
parents:
diff changeset
  1193
hgs
parents:
diff changeset
  1194
	{
hgs
parents:
diff changeset
  1195
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
  1196
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
  1197
hgs
parents:
diff changeset
  1198
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
  1199
		{
hgs
parents:
diff changeset
  1200
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1201
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1202
		}
hgs
parents:
diff changeset
  1203
hgs
parents:
diff changeset
  1204
		status = message.add_parameter_data(eap_tlv_message_type_function_plugin_complete_get_type_info);
hgs
parents:
diff changeset
  1205
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1206
		{
hgs
parents:
diff changeset
  1207
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1208
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1209
		}
hgs
parents:
diff changeset
  1210
hgs
parents:
diff changeset
  1211
		status = message.add_parameter_data(internal_settings);
hgs
parents:
diff changeset
  1212
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1213
		{
hgs
parents:
diff changeset
  1214
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1215
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1216
		}
hgs
parents:
diff changeset
  1217
hgs
parents:
diff changeset
  1218
		status = send_message(&message);
hgs
parents:
diff changeset
  1219
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1220
		{
hgs
parents:
diff changeset
  1221
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1222
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1223
		}
hgs
parents:
diff changeset
  1224
	}
hgs
parents:
diff changeset
  1225
hgs
parents:
diff changeset
  1226
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1227
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1228
}
hgs
parents:
diff changeset
  1229
hgs
parents:
diff changeset
  1230
//--------------------------------------------------
hgs
parents:
diff changeset
  1231
hgs
parents:
diff changeset
  1232
EAP_FUNC_EXPORT eap_status_e eap_plugin_server_message_if_c::complete_invoke_ui(const eap_method_settings_c * const internal_settings)
hgs
parents:
diff changeset
  1233
{
hgs
parents:
diff changeset
  1234
	eap_status_e status(eap_status_process_general_error);
hgs
parents:
diff changeset
  1235
hgs
parents:
diff changeset
  1236
	EAP_TRACE_DEBUG(
hgs
parents:
diff changeset
  1237
		m_am_tools, 
hgs
parents:
diff changeset
  1238
		EAP_TRACE_FLAGS_MESSAGE_DATA, 
hgs
parents:
diff changeset
  1239
		(EAPL("%s: eap_core_server_message_if_c::complete_invoke_ui()\n"),
hgs
parents:
diff changeset
  1240
		 (m_is_client == true) ? "client": "server"));
hgs
parents:
diff changeset
  1241
hgs
parents:
diff changeset
  1242
	EAP_TRACE_RETURN_STRING_FLAGS(m_am_tools, EAP_TRACE_FLAGS_MESSAGE_DATA, "returns: eap_core_server_message_if_c::complete_invoke_ui()");
hgs
parents:
diff changeset
  1243
hgs
parents:
diff changeset
  1244
	{
hgs
parents:
diff changeset
  1245
		// Creates message data composed of Attribute-Value Pairs.
hgs
parents:
diff changeset
  1246
		eap_process_tlv_message_data_c message(m_am_tools);
hgs
parents:
diff changeset
  1247
hgs
parents:
diff changeset
  1248
		if (message.get_is_valid() == false)
hgs
parents:
diff changeset
  1249
		{
hgs
parents:
diff changeset
  1250
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1251
			return EAP_STATUS_RETURN(m_am_tools, eap_status_allocation_error);
hgs
parents:
diff changeset
  1252
		}
hgs
parents:
diff changeset
  1253
hgs
parents:
diff changeset
  1254
		status = message.add_parameter_data(eap_tlv_message_type_function_plugin_complete_invoke_ui);
hgs
parents:
diff changeset
  1255
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1256
		{
hgs
parents:
diff changeset
  1257
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1258
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1259
		}
hgs
parents:
diff changeset
  1260
hgs
parents:
diff changeset
  1261
		status = message.add_parameter_data(internal_settings);
hgs
parents:
diff changeset
  1262
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1263
		{
hgs
parents:
diff changeset
  1264
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1265
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1266
		}
hgs
parents:
diff changeset
  1267
hgs
parents:
diff changeset
  1268
		status = send_message(&message);
hgs
parents:
diff changeset
  1269
		if (status != eap_status_ok)
hgs
parents:
diff changeset
  1270
		{
hgs
parents:
diff changeset
  1271
			EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1272
			return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1273
		}
hgs
parents:
diff changeset
  1274
	}
hgs
parents:
diff changeset
  1275
hgs
parents:
diff changeset
  1276
	EAP_TRACE_END(m_am_tools, TRACE_FLAGS_DEFAULT);
hgs
parents:
diff changeset
  1277
	return EAP_STATUS_RETURN(m_am_tools, status);
hgs
parents:
diff changeset
  1278
}
hgs
parents:
diff changeset
  1279
hgs
parents:
diff changeset
  1280
//--------------------------------------------------
hgs
parents:
diff changeset
  1281
// End.