eapol/eapol_framework/eapol_symbian/eap_server/include/EapTypePlugin.h
author hgs
Thu, 16 Sep 2010 13:07:04 +0300
changeset 49 43351a4f2da3
permissions -rw-r--r--
201037
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
49
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: 13 %
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
class AbsPacStoreInitializer;
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
struct SPluginInfo
hgs
parents:
diff changeset
    46
{
hgs
parents:
diff changeset
    47
	TIndexType indexType;
hgs
parents:
diff changeset
    48
	TInt index;
hgs
parents:
diff changeset
    49
	TEapExpandedType aEapType;
hgs
parents:
diff changeset
    50
	abs_eap_am_tools_c * aTools;
hgs
parents:
diff changeset
    51
}; 
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
// CLASS DECLARATION
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
/**
hgs
parents:
diff changeset
    56
* The interface class for direct EAP plug-in access.
hgs
parents:
diff changeset
    57
* Includes methods to create either the configuration interface or the EAP protocol interface.
hgs
parents:
diff changeset
    58
*/
hgs
parents:
diff changeset
    59
class CEapTypePlugin
hgs
parents:
diff changeset
    60
: public CBase
hgs
parents:
diff changeset
    61
{
hgs
parents:
diff changeset
    62
public:
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
	/**
hgs
parents:
diff changeset
    65
	* Factory function that loads the EAP type implementation DLL (plug-in).
hgs
parents:
diff changeset
    66
	* Uses ECom architecture to load the correct EAP type DLL. Calls the initialization
hgs
parents:
diff changeset
    67
	* function of the EAP type
hgs
parents:
diff changeset
    68
	* @param aCue EAP type id that specifies which plugin is loaded.
hgs
parents:
diff changeset
    69
	* @param aIndexType Indicates the bearer used for this connection.
hgs
parents:
diff changeset
    70
	* @param aIndex Index for the connection. aIndexType and aIndex uniquely specify the connection.
hgs
parents:
diff changeset
    71
	* @return Pointer to the implementation.
hgs
parents:
diff changeset
    72
	*/
hgs
parents:
diff changeset
    73
	inline static CEapTypePlugin* NewL(const TDesC8& aCue, TIndexType aIndexType, TInt aIndex, abs_eap_am_tools_c * const aTools);	
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
	/**
hgs
parents:
diff changeset
    76
	* Unloads the implementation DLL.
hgs
parents:
diff changeset
    77
	*/
hgs
parents:
diff changeset
    78
	inline virtual ~CEapTypePlugin();
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
	/**
hgs
parents:
diff changeset
    81
	* Creates EAP protocol interface implementation. Instances an object that
hgs
parents:
diff changeset
    82
	* has been derived from eap_base_type_c that handles the communication 
hgs
parents:
diff changeset
    83
	* with EAP stack. 
hgs
parents:
diff changeset
    84
	* @param aTools Pointer to tools class.
hgs
parents:
diff changeset
    85
	* @param aPartner Used for callbacks to the stack.
hgs
parents:
diff changeset
    86
	* @param is_client_when_true Specifies whether the EAP type acts as a client or server.
hgs
parents:
diff changeset
    87
	* @param receive_network_id Network addresses
hgs
parents:
diff changeset
    88
	* @param eap_config_if Pointer used for call back to creater of stack (eapol_am_wlan_authentication_symbian_c class).
hgs
parents:
diff changeset
    89
	* @return Pointer to the implementation.
hgs
parents:
diff changeset
    90
	*/		
hgs
parents:
diff changeset
    91
	virtual eap_base_type_c* GetStackInterfaceL(abs_eap_am_tools_c * const aTools, 
hgs
parents:
diff changeset
    92
											   abs_eap_base_type_c * const aPartner,
hgs
parents:
diff changeset
    93
											   const bool is_client_when_true,
hgs
parents:
diff changeset
    94
											   const eap_am_network_id_c * const receive_network_id,
hgs
parents:
diff changeset
    95
											   abs_eap_configuration_if_c * const configuration_if) = 0;
hgs
parents:
diff changeset
    96
hgs
parents:
diff changeset
    97
#if 0
hgs
parents:
diff changeset
    98
#ifndef RD_WLAN_3_1_BACKPORTING
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
#else
hgs
parents:
diff changeset
   101
hgs
parents:
diff changeset
   102
	/**
hgs
parents:
diff changeset
   103
	* Creates EAP protocol interface implementation. Instances an object that
hgs
parents:
diff changeset
   104
	* has been derived from eap_base_type_c that handles the communication 
hgs
parents:
diff changeset
   105
	* with EAP stack. 
hgs
parents:
diff changeset
   106
	* @param aTools Pointer to tools class.
hgs
parents:
diff changeset
   107
	* @param aPartner Used for callbacks to the stack.
hgs
parents:
diff changeset
   108
	* @param is_client_when_true Specifies whether the EAP type acts as a client or server.
hgs
parents:
diff changeset
   109
	* @param receive_network_id Network addresses
hgs
parents:
diff changeset
   110
	* @return Pointer to the implementation.
hgs
parents:
diff changeset
   111
	*/		
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
	virtual eap_base_type_c* GetStackInterfaceL(abs_eap_am_tools_c* const aTools, 
hgs
parents:
diff changeset
   114
											   abs_eap_base_type_c* const aPartner,
hgs
parents:
diff changeset
   115
											   const bool is_client_when_true,
hgs
parents:
diff changeset
   116
											   const eap_am_network_id_c * const receive_network_id) = 0;
hgs
parents:
diff changeset
   117
	
hgs
parents:
diff changeset
   118
#endif // #ifndef RD_WLAN_3_1_BACKPORTING
hgs
parents:
diff changeset
   119
#endif
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
	
hgs
parents:
diff changeset
   123
	/**
hgs
parents:
diff changeset
   124
	* Gets information about EAP type. 
hgs
parents:
diff changeset
   125
	* @return Pointer to a class that contains the EAP type information. Also pushed to cleanup stack.
hgs
parents:
diff changeset
   126
	*/
hgs
parents:
diff changeset
   127
	virtual CEapTypeInfo* GetInfoL() = 0;
hgs
parents:
diff changeset
   128
	
hgs
parents:
diff changeset
   129
	/**
hgs
parents:
diff changeset
   130
	* Deletes EAP type configuration
hgs
parents:
diff changeset
   131
	*/	
hgs
parents:
diff changeset
   132
	virtual void DeleteConfigurationL() = 0;
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
	/**
hgs
parents:
diff changeset
   135
	* Returns the version of the interface that the EAP type implements.
hgs
parents:
diff changeset
   136
	* The client-side of the interface must always check the version with this function 
hgs
parents:
diff changeset
   137
	* and not call the functions that are not implemented. New functions must be
hgs
parents:
diff changeset
   138
	* added to the end of the interface so that the order of the old functions
hgs
parents:
diff changeset
   139
	* does not change.
hgs
parents:
diff changeset
   140
	* @return Integer indicating the version.
hgs
parents:
diff changeset
   141
	*/
hgs
parents:
diff changeset
   142
	virtual TUint GetInterfaceVersion() = 0;
hgs
parents:
diff changeset
   143
hgs
parents:
diff changeset
   144
	/**
hgs
parents:
diff changeset
   145
	* Parses the opaque_data field in CImplementationInformation and returns true if
hgs
parents:
diff changeset
   146
	* string NOT_OUTSIDE_PEAP is found.
hgs
parents:
diff changeset
   147
	* @param aImplInfo Implementation info returned by ListImplementations call
hgs
parents:
diff changeset
   148
	* @return Boolean
hgs
parents:
diff changeset
   149
	*/
hgs
parents:
diff changeset
   150
	inline static TBool IsDisallowedOutsidePEAP(const CImplementationInformation& aImplInfo);
hgs
parents:
diff changeset
   151
hgs
parents:
diff changeset
   152
	/**
hgs
parents:
diff changeset
   153
	* Parses the opaque_data field in CImplementationInformation and returns true if
hgs
parents:
diff changeset
   154
	* string NOT_INSIDE_PEAP is found.
hgs
parents:
diff changeset
   155
	* @param aImplInfo Implementation info returned by ListImplementations call
hgs
parents:
diff changeset
   156
	* @return Boolean
hgs
parents:
diff changeset
   157
	*/	
hgs
parents:
diff changeset
   158
	inline static TBool IsDisallowedInsidePEAP(const CImplementationInformation& aImplInfo);
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
	/**
hgs
parents:
diff changeset
   161
	* Parses the opaque_data field in CImplementationInformation and returns true if
hgs
parents:
diff changeset
   162
	* string NOT_INSIDE_TTLS is found.
hgs
parents:
diff changeset
   163
	* @param aImplInfo Implementation info returned by ListImplementations call
hgs
parents:
diff changeset
   164
	* @return Boolean
hgs
parents:
diff changeset
   165
	*/	
hgs
parents:
diff changeset
   166
	inline static TBool IsDisallowedInsideTTLS(const CImplementationInformation& aImplInfo);
hgs
parents:
diff changeset
   167
hgs
parents:
diff changeset
   168
	/**
hgs
parents:
diff changeset
   169
	* Sets the tunneling type. This is used to indicate that this type is run inside another 
hgs
parents:
diff changeset
   170
	* EAP type. 
hgs
parents:
diff changeset
   171
	* @param aTunnelingType Type number for the tunneling type
hgs
parents:
diff changeset
   172
	*/	
hgs
parents:
diff changeset
   173
	virtual void SetTunnelingType(const TEapExpandedType aTunnelingType) = 0;
hgs
parents:
diff changeset
   174
	
hgs
parents:
diff changeset
   175
	/**
hgs
parents:
diff changeset
   176
	* Changes the index of the saved parameters.
hgs
parents:
diff changeset
   177
	* @param aIndexType Indicates the bearer used for this connection.
hgs
parents:
diff changeset
   178
	* @param aIndex Index for the connection. aIndexType and aIndex uniquely specify the connection.
hgs
parents:
diff changeset
   179
	*/
hgs
parents:
diff changeset
   180
	virtual void SetIndexL(
hgs
parents:
diff changeset
   181
		const TIndexType aIndexType, 
hgs
parents:
diff changeset
   182
		const TInt aIndex) = 0;
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
	/**
hgs
parents:
diff changeset
   185
	* Sets the EAP types configuration
hgs
parents:
diff changeset
   186
	* @param aSettings Structure containing the settings
hgs
parents:
diff changeset
   187
	*/
hgs
parents:
diff changeset
   188
	virtual void SetConfigurationL(const EAPSettings& aSettings) = 0;
hgs
parents:
diff changeset
   189
hgs
parents:
diff changeset
   190
	/**
hgs
parents:
diff changeset
   191
	* Gets the EAP types configuration
hgs
parents:
diff changeset
   192
	* @param aSettings Structure containing the settings
hgs
parents:
diff changeset
   193
	*/
hgs
parents:
diff changeset
   194
	virtual void GetConfigurationL(EAPSettings& aSettings) = 0;
hgs
parents:
diff changeset
   195
	
hgs
parents:
diff changeset
   196
	/**
hgs
parents:
diff changeset
   197
	* Copies the EAP types configuration
hgs
parents:
diff changeset
   198
	* @param aDestinationIndexType index type of the destination, ELan for WLAN.
hgs
parents:
diff changeset
   199
	* @param aDestinationIndex ID to where copy the settings.
hgs
parents:
diff changeset
   200
	*/
hgs
parents:
diff changeset
   201
	virtual void CopySettingsL(
hgs
parents:
diff changeset
   202
		const TIndexType aDestinationIndexType, 
hgs
parents:
diff changeset
   203
		const TInt aDestinationIndex) = 0;
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
	virtual TInt InitialisePacStore(AbsPacStoreInitializer * const initializer) = 0;
hgs
parents:
diff changeset
   206
hgs
parents:
diff changeset
   207
private:
hgs
parents:
diff changeset
   208
hgs
parents:
diff changeset
   209
	/// ECom uses this key to keep track of DLL usage.
hgs
parents:
diff changeset
   210
	TUid iDtor_ID_Key;
hgs
parents:
diff changeset
   211
};
hgs
parents:
diff changeset
   212
hgs
parents:
diff changeset
   213
#include "EapTypePlugin.inl"
hgs
parents:
diff changeset
   214
hgs
parents:
diff changeset
   215
#endif // _EAP_TYPE_PLUGIN_H_
hgs
parents:
diff changeset
   216
hgs
parents:
diff changeset
   217
// End of file