accesssec_plat/eap_type_api/inc/EapTypePlugin.h
author hgs
Mon, 24 May 2010 20:32:47 +0300
changeset 26 9abfd4f00d37
permissions -rw-r--r--
201021
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
26
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2001-2006 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  EAP and WLAN authentication protocols.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
/*
hgs
parents:
diff changeset
    19
* %version: 8 %
hgs
parents:
diff changeset
    20
*/
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#ifndef _EAP_TYPE_PLUGIN_H_
hgs
parents:
diff changeset
    23
#define _EAP_TYPE_PLUGIN_H_
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
// INCLUDES
hgs
parents:
diff changeset
    26
#include <e32base.h>
hgs
parents:
diff changeset
    27
#include <ecom/ecom.h> 
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
#include <EapSettings.h>
hgs
parents:
diff changeset
    30
#include <EapTypeDefinitions.h>
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
// FORWARD DECLARATIONS
hgs
parents:
diff changeset
    33
class abs_eap_am_tools_c;
hgs
parents:
diff changeset
    34
class eap_base_type_c;
hgs
parents:
diff changeset
    35
class abs_eap_base_type_c;
hgs
parents:
diff changeset
    36
class CEapTypeInfo;
hgs
parents:
diff changeset
    37
class eap_am_network_id_c;
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
#ifndef RD_WLAN_3_1_BACKPORTING
hgs
parents:
diff changeset
    40
class abs_eap_configuration_if_c;
hgs
parents:
diff changeset
    41
#endif
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
hgs
parents:
diff changeset
    44
// CLASS DECLARATION
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
/**
hgs
parents:
diff changeset
    47
* The interface class for direct EAP plug-in access.
hgs
parents:
diff changeset
    48
* Includes methods to create either the configuration interface or the EAP protocol interface.
hgs
parents:
diff changeset
    49
*/
hgs
parents:
diff changeset
    50
class CEapTypePlugin
hgs
parents:
diff changeset
    51
: public CBase
hgs
parents:
diff changeset
    52
{
hgs
parents:
diff changeset
    53
public:
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
	/**
hgs
parents:
diff changeset
    56
	* Factory function that loads the EAP type implementation DLL (plug-in).
hgs
parents:
diff changeset
    57
	* Uses ECom architecture to load the correct EAP type DLL. Calls the initialization
hgs
parents:
diff changeset
    58
	* function of the EAP type
hgs
parents:
diff changeset
    59
	* @param aCue EAP type id that specifies which plugin is loaded.
hgs
parents:
diff changeset
    60
	* @param aIndexType Indicates the bearer used for this connection.
hgs
parents:
diff changeset
    61
	* @param aIndex Index for the connection. aIndexType and aIndex uniquely specify the connection.
hgs
parents:
diff changeset
    62
	* @return Pointer to the implementation.
hgs
parents:
diff changeset
    63
	*/
hgs
parents:
diff changeset
    64
	inline static CEapTypePlugin* NewL(const TDesC8& aCue, TIndexType aIndexType, TInt aIndex);	
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
	/**
hgs
parents:
diff changeset
    67
	* Unloads the implementation DLL.
hgs
parents:
diff changeset
    68
	*/
hgs
parents:
diff changeset
    69
	inline virtual ~CEapTypePlugin();
hgs
parents:
diff changeset
    70
hgs
parents:
diff changeset
    71
	/**
hgs
parents:
diff changeset
    72
	* Creates EAP protocol interface implementation. Instances an object that
hgs
parents:
diff changeset
    73
	* has been derived from eap_base_type_c that handles the communication 
hgs
parents:
diff changeset
    74
	* with EAP stack. 
hgs
parents:
diff changeset
    75
	* @param aTools Pointer to tools class.
hgs
parents:
diff changeset
    76
	* @param aPartner Used for callbacks to the stack.
hgs
parents:
diff changeset
    77
	* @param is_client_when_true Specifies whether the EAP type acts as a client or server.
hgs
parents:
diff changeset
    78
	* @param receive_network_id Network addresses
hgs
parents:
diff changeset
    79
	* @param eap_config_if Pointer used for call back to creater of stack (eapol_am_wlan_authentication_symbian_c class).
hgs
parents:
diff changeset
    80
	* @return Pointer to the implementation.
hgs
parents:
diff changeset
    81
	*/		
hgs
parents:
diff changeset
    82
	virtual eap_base_type_c* GetStackInterfaceL(abs_eap_am_tools_c* const aTools, 
hgs
parents:
diff changeset
    83
											   abs_eap_base_type_c* const aPartner,
hgs
parents:
diff changeset
    84
											   const bool is_client_when_true,
hgs
parents:
diff changeset
    85
											   const eap_am_network_id_c * const receive_network_id,
hgs
parents:
diff changeset
    86
											   abs_eap_configuration_if_c * const configuration_if) = 0;
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
#if 0
hgs
parents:
diff changeset
    89
#ifndef RD_WLAN_3_1_BACKPORTING
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
#else
hgs
parents:
diff changeset
    92
hgs
parents:
diff changeset
    93
	/**
hgs
parents:
diff changeset
    94
	* Creates EAP protocol interface implementation. Instances an object that
hgs
parents:
diff changeset
    95
	* has been derived from eap_base_type_c that handles the communication 
hgs
parents:
diff changeset
    96
	* with EAP stack. 
hgs
parents:
diff changeset
    97
	* @param aTools Pointer to tools class.
hgs
parents:
diff changeset
    98
	* @param aPartner Used for callbacks to the stack.
hgs
parents:
diff changeset
    99
	* @param is_client_when_true Specifies whether the EAP type acts as a client or server.
hgs
parents:
diff changeset
   100
	* @param receive_network_id Network addresses
hgs
parents:
diff changeset
   101
	* @return Pointer to the implementation.
hgs
parents:
diff changeset
   102
	*/		
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
	virtual eap_base_type_c* GetStackInterfaceL(abs_eap_am_tools_c* const aTools, 
hgs
parents:
diff changeset
   105
											   abs_eap_base_type_c* const aPartner,
hgs
parents:
diff changeset
   106
											   const bool is_client_when_true,
hgs
parents:
diff changeset
   107
											   const eap_am_network_id_c * const receive_network_id) = 0;
hgs
parents:
diff changeset
   108
	
hgs
parents:
diff changeset
   109
#endif // #ifndef RD_WLAN_3_1_BACKPORTING
hgs
parents:
diff changeset
   110
#endif
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
	* Gets information about EAP type. 
hgs
parents:
diff changeset
   116
	* @return Pointer to a class that contains the EAP type information. Also pushed to cleanup stack.
hgs
parents:
diff changeset
   117
	*/
hgs
parents:
diff changeset
   118
	virtual CEapTypeInfo* GetInfoL() = 0;
hgs
parents:
diff changeset
   119
	
hgs
parents:
diff changeset
   120
	/**
hgs
parents:
diff changeset
   121
	* Deletes EAP type configuration
hgs
parents:
diff changeset
   122
	*/	
hgs
parents:
diff changeset
   123
	virtual void DeleteConfigurationL() = 0;
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
	/**
hgs
parents:
diff changeset
   126
	* Returns the version of the interface that the EAP type implements.
hgs
parents:
diff changeset
   127
	* The client-side of the interface must always check the version with this function 
hgs
parents:
diff changeset
   128
	* and not call the functions that are not implemented. New functions must be
hgs
parents:
diff changeset
   129
	* added to the end of the interface so that the order of the old functions
hgs
parents:
diff changeset
   130
	* does not change.
hgs
parents:
diff changeset
   131
	* @return Integer indicating the version.
hgs
parents:
diff changeset
   132
	*/
hgs
parents:
diff changeset
   133
	virtual TUint GetInterfaceVersion() = 0;
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
	/**
hgs
parents:
diff changeset
   136
	* Parses the opaque_data field in CImplementationInformation and returns true if
hgs
parents:
diff changeset
   137
	* string NOT_OUTSIDE_PEAP is found.
hgs
parents:
diff changeset
   138
	* @param aImplInfo Implementation info returned by ListImplementations call
hgs
parents:
diff changeset
   139
	* @return Boolean
hgs
parents:
diff changeset
   140
	*/
hgs
parents:
diff changeset
   141
	inline static TBool IsDisallowedOutsidePEAP(const CImplementationInformation& aImplInfo);
hgs
parents:
diff changeset
   142
hgs
parents:
diff changeset
   143
	/**
hgs
parents:
diff changeset
   144
	* Parses the opaque_data field in CImplementationInformation and returns true if
hgs
parents:
diff changeset
   145
	* string NOT_INSIDE_PEAP is found.
hgs
parents:
diff changeset
   146
	* @param aImplInfo Implementation info returned by ListImplementations call
hgs
parents:
diff changeset
   147
	* @return Boolean
hgs
parents:
diff changeset
   148
	*/	
hgs
parents:
diff changeset
   149
	inline static TBool IsDisallowedInsidePEAP(const CImplementationInformation& aImplInfo);
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
	/**
hgs
parents:
diff changeset
   152
	* Parses the opaque_data field in CImplementationInformation and returns true if
hgs
parents:
diff changeset
   153
	* string NOT_INSIDE_TTLS is found.
hgs
parents:
diff changeset
   154
	* @param aImplInfo Implementation info returned by ListImplementations call
hgs
parents:
diff changeset
   155
	* @return Boolean
hgs
parents:
diff changeset
   156
	*/	
hgs
parents:
diff changeset
   157
	inline static TBool IsDisallowedInsideTTLS(const CImplementationInformation& aImplInfo);
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
	/**
hgs
parents:
diff changeset
   160
	* Sets the tunneling type. This is used to indicate that this type is run inside another 
hgs
parents:
diff changeset
   161
	* EAP type. 
hgs
parents:
diff changeset
   162
	* @param aTunnelingType Type number for the tunneling type
hgs
parents:
diff changeset
   163
	*/	
hgs
parents:
diff changeset
   164
	virtual void SetTunnelingType(const TEapExpandedType aTunnelingType) = 0;
hgs
parents:
diff changeset
   165
	
hgs
parents:
diff changeset
   166
	/**
hgs
parents:
diff changeset
   167
	* Changes the index of the saved parameters.
hgs
parents:
diff changeset
   168
	* @param aIndexType Indicates the bearer used for this connection.
hgs
parents:
diff changeset
   169
	* @param aIndex Index for the connection. aIndexType and aIndex uniquely specify the connection.
hgs
parents:
diff changeset
   170
	*/
hgs
parents:
diff changeset
   171
	virtual void SetIndexL(
hgs
parents:
diff changeset
   172
		const TIndexType aIndexType, 
hgs
parents:
diff changeset
   173
		const TInt aIndex) = 0;
hgs
parents:
diff changeset
   174
hgs
parents:
diff changeset
   175
	/**
hgs
parents:
diff changeset
   176
	* Sets the EAP types configuration
hgs
parents:
diff changeset
   177
	* @param aSettings Structure containing the settings
hgs
parents:
diff changeset
   178
	*/
hgs
parents:
diff changeset
   179
	virtual void SetConfigurationL(const EAPSettings& aSettings) = 0;
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
	/**
hgs
parents:
diff changeset
   182
	* Gets the EAP types configuration
hgs
parents:
diff changeset
   183
	* @param aSettings Structure containing the settings
hgs
parents:
diff changeset
   184
	*/
hgs
parents:
diff changeset
   185
	virtual void GetConfigurationL(EAPSettings& aSettings) = 0;
hgs
parents:
diff changeset
   186
	
hgs
parents:
diff changeset
   187
	/**
hgs
parents:
diff changeset
   188
	* Copies the EAP types configuration
hgs
parents:
diff changeset
   189
	* @param aDestinationIndexType index type of the destination, ELan for WLAN.
hgs
parents:
diff changeset
   190
	* @param aDestinationIndex ID to where copy the settings.
hgs
parents:
diff changeset
   191
	*/
hgs
parents:
diff changeset
   192
	virtual void CopySettingsL(
hgs
parents:
diff changeset
   193
		const TIndexType aDestinationIndexType, 
hgs
parents:
diff changeset
   194
		const TInt aDestinationIndex) = 0;
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
hgs
parents:
diff changeset
   197
private:
hgs
parents:
diff changeset
   198
hgs
parents:
diff changeset
   199
	/// ECom uses this key to keep track of DLL usage.
hgs
parents:
diff changeset
   200
	TUid iDtor_ID_Key;
hgs
parents:
diff changeset
   201
};
hgs
parents:
diff changeset
   202
hgs
parents:
diff changeset
   203
#include "EapTypePlugin.inl"
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
#endif // _EAP_TYPE_PLUGIN_H_
hgs
parents:
diff changeset
   206
hgs
parents:
diff changeset
   207
// End of file