Merge docml changeset with recent Nokia delivery.
authorPat Downey <patd@symbian.org>
Tue, 18 May 2010 13:51:10 +0100
changeset 27 6480c77e38d0
parent 25 001d4d78e350 (diff)
parent 23 1d8ec95a8be3 (current diff)
child 34 30a5f517c615
child 40 76c14942b137
Merge docml changeset with recent Nokia delivery.
--- a/hotspotfw/hsclient/inc/hssiaphandler.h	Tue May 11 12:32:08 2010 +0100
+++ b/hotspotfw/hsclient/inc/hssiaphandler.h	Tue May 18 13:51:10 2010 +0100
@@ -100,14 +100,7 @@
         void PackWepKeyCommsDatL( const SHssWep& aInputKey, 
                                   const  EHssWEPKeyFormat&  aFormat, 
                                     CMDBField<TDesC8>* aPackedKey );
-
-         /**
-        * Converts Hotspot EAP settings to EAPOL EAP settings
-        * @param aHssEap, Hotspot EAP settings
-        * @param aEap, EAPOL EAP settings
-        */
-        void ConvertEApSettings( THssEapSettings& aHssEap, EAPSettings& aEap );
-        
+ 
         /**
         * Converts ascii to hecxadecimal 
         * @param aSource, ascii 
@@ -116,14 +109,6 @@
         void ConvertAsciiToHex( const TDes8& aSource, 
                                                 HBufC8*& aDest );   
                                                                          
-        /**
-        * Writes eap type to descriptor
-        * @param aEapType, Eap type
-        * @param aEapString, Eap type descrpitor
-        * @param aEapCode, Eap id code
-        */                 
-        void GetEapTypeDesC( TUint aEapType, TDes8& aEapString, TChar& aEapCode );
-       
     private: // Data
         
         /**
--- a/hotspotfw/hsclient/src/hssiaphandler.cpp	Tue May 11 12:32:08 2010 +0100
+++ b/hotspotfw/hsclient/src/hssiaphandler.cpp	Tue May 18 13:51:10 2010 +0100
@@ -18,7 +18,6 @@
 
 
 // INCLUDE FILES
-#include <EapType.h>
 #include <cdbpreftable.h>
 #include "hssiaphandler.h"
 #include "hotspotclientserver.h"
@@ -40,9 +39,9 @@
 // -----------------------------------------------------------------------------
 //
 CHssIapHandler::CHssIapHandler( )
-	{
+    {
     DEBUG("CHssIapHandler::CHssIapHandler");
-	}
+    }
 
 // -----------------------------------------------------------------------------
 // ConstructL
@@ -71,15 +70,15 @@
 // -----------------------------------------------------------------------------
 //
 CHssIapHandler::~CHssIapHandler()
-	{
-	DEBUG("CHssIapHandler::~CHssIapHandler()");
+    {
+    DEBUG("CHssIapHandler::~CHssIapHandler()");
     
-	if ( iWLANRecord != NULL )
-		{
-		delete iWLANRecord;
-		}
-	iWLANRecord = NULL;
-	}
+    if ( iWLANRecord != NULL )
+        {
+        delete iWLANRecord;
+        }
+    iWLANRecord = NULL;
+    }
 
 // -----------------------------------------------------------------------------
 // ChangeSettingsL
@@ -108,8 +107,8 @@
     
     // Read WLAN table service id
     TUint32 serviceId(0);
-	RCmConnectionMethodExt plugin = cmManager.ConnectionMethodL( aIapID );
-	CleanupClosePushL( plugin );
+    RCmConnectionMethodExt plugin = cmManager.ConnectionMethodL( aIapID );
+    CleanupClosePushL( plugin );
     serviceId = plugin.GetIntAttributeL( EWlanServiceId );
     DEBUG1("CHssIapHandler::ChangeSettingsL WLAN serviceId: %d", serviceId);
     
@@ -125,7 +124,7 @@
     CMDBSession* dbSession = CMDBSession::NewL(CMDBSession::LatestVersion());
     CleanupStack::PushL( dbSession );
     iWLANRecord = static_cast<CMDBGenericRecord*>
-    	( CCDRecordBase::RecordFactoryL( 0));
+        ( CCDRecordBase::RecordFactoryL( 0 ) );
             
     iWLANRecord->InitializeL( KGenericTable(),NULL );
     iWLANRecord->SetRecordId( serviceId );
@@ -156,9 +155,9 @@
     // -> Destination can become unusable.
     TInt secMode = aSettings.iSecurityMode;
     if ( secMode > EHssWpa2Only )
-    	{
-    	secMode = EHssAllowUnsecure;
-    	}
+        {
+        secMode = EHssAllowUnsecure;
+        }
     
     if( secMode == EHssWep )
         {
@@ -194,88 +193,12 @@
             *((CMDBField<TUint32>*)iWLANRecord->GetFieldByIdL(KCDTIdWlanWpaKeyLength)) = aSettings.iWPAKeyLength;
             *((CMDBField<TUint32>*)iWLANRecord->GetFieldByIdL(KCDTIdWlanEnableWpaPsk)) = aSettings.iEnableWpaPsk;
             }
-        else // Use EAP
+        else // Use EAP. EAP settings can be set with EAP API.
             {
             DEBUG("CHssIapHandler::ChangeSettingsL -> SecurityMode > EHssWep -> EAP");
             *((CMDBField<TUint32>*)iWLANRecord->GetFieldByIdL(KCDTIdWlanEnableWpaPsk)) = aSettings.iEnableWpaPsk;
             }
         }
-      
-    // access point updated EAP data can be now set if needed
-    if ( ( !aSettings.iEnableWpaPsk ) && secMode > EHssWep )
-        {
-        DEBUG("CHssIapHandler::ChangeSettingsL -> Set EAP data");
-        TBuf8<KEapListMaxLength> enabledEapList;
-        for (TInt i=0;i<aSettings.iEapDataArray.Count();i++)
-            {
-            TBuf8< KEapExpandedIdLength > eapTypeCue;
-            TChar eapCode;
-            GetEapTypeDesC(aSettings.iEapDataArray[i]->iEAPType, eapTypeCue, eapCode );
-        
-            CEapType* eapType = NULL;
-            TRAPD( error, ( eapType = CEapType::NewL( eapTypeCue, ELan, serviceId ) ) );
-            DEBUG1(" CEapType::NewL error: %d", error);
-            if ( ( error == KErrNone ) && eapType )
-                {
-                CleanupStack::PushL( eapType );
-                EAPSettings* eapSettings = new (ELeave) EAPSettings;
-                
-                ConvertEApSettings( *aSettings.iEapDataArray[i], *eapSettings );
-                
-                // Set EAP tunneling
-                if ( aSettings.iEapDataArray[i]->iEncapsulatedInside != EAPSettings::EEapNone )
-                	{
-                	DEBUG("iEncapsulatedInside != EAPSettings::EEapNone");
-                	eapType->SetTunnelingType( 
-                			static_cast<TInt> ( aSettings.iEapDataArray[i]->iEncapsulatedInside ) );
-                	}
-                else // Write to EAP list
-                	{
-                	DEBUG("CHssIapHandler::ChangeSettingsL -> Add to EAP list");
-                	TBuf8<8> expandedForm;
-    	            expandedForm.AppendFill( 0xFE, 1 );
-    	            if ( THssEapSettings::EEapPlainMschapv2 == aSettings.iEapDataArray[i]->iEAPType )
-    	            	{
-    	            	expandedForm.AppendFill( 0xFF, 3 );
-    	            	}
-    	            else{
-    	            	expandedForm.AppendFill( 0x00, 6 );
-    	            	}
-    	       
-    	            expandedForm.AppendFill( eapCode, 1 );
-    	               	           
-    	            enabledEapList.Append( expandedForm );      
-    	        	}
-                
-                DEBUG("CHssIapHandler::ChangeSettingsL -> eapType->SetConfigurationL");
-                TRAPD( eapErr, eapType->SetConfigurationL( *eapSettings ) );
-                DEBUG1(" eapType->SetConfigurationL error: %d", eapErr);
-                if( eapErr != KErrNone )
-                	{
-                	CleanupStack::PopAndDestroy( eapType );
-                	CleanupStack::PopAndDestroy( dbSession );
-                    DEBUG("CHssIapHandler::ChangeSettingsL EapError DONE");
-                    return eapErr;
-                	}
-                CleanupStack::PopAndDestroy( eapType );
-                }
-            if ( error != KErrNone )
-                {
-                DEBUG("CHssIapHandler::ChangeSettingsL Eap error");
-                CleanupStack::PopAndDestroy( dbSession );
-                return error;
-                }
-            }
-       
-            // Set enabled EAP list
-            if ( enabledEapList.Length() > 0 )
-        		{
-        		DEBUG("CHssIapHandler::ChangeSettingsL -> Set EAP list");
-	            CMDBField<TDesC8>* eaps = (CMDBField<TDesC8>*)iWLANRecord->GetFieldByIdL( KCDTIdWlanEnabledEaps );
-	            //eaps->SetMaxLengthL( eapList16.Length() )
-	            eaps->SetL( enabledEapList );
-            	}
-        }
     // now update the access point
     iWLANRecord->ModifyL( *dbSession );
     
@@ -375,65 +298,6 @@
     
     aPackedKey->SetL( wepBuf);
     }
-
-// -----------------------------------------------------------------------------
-// ConvertEApSettings
-// -----------------------------------------------------------------------------
-//
-void CHssIapHandler::ConvertEApSettings( THssEapSettings& aHssEap, EAPSettings& aEap )
-    {
-    DEBUG("CHssIapHandler::ConvertEApSettings");
-    aEap.iEAPType = static_cast<EAPSettings::TEapType>(aHssEap.iEAPType);
-    aEap.iUsernamePresent = aHssEap.iUsernamePresent;
-    aEap.iUsername = aHssEap.iUsername;
-    aEap.iPasswordPresent = aHssEap.iPasswordPresent;
-    aEap.iPassword = aHssEap.iPassword;
-    aEap.iRealmPresent = aHssEap.iRealmPresent;
-    aEap.iRealm = aHssEap.iRealm;
-    aEap.iUsePseudonymsPresent = aHssEap.iUsePseudonymsPresent;
-    aEap.iUsePseudonyms = aHssEap.iUsePseudonyms;
-    aEap.iVerifyServerRealmPresent = aHssEap.iVerifyServerRealmPresent;
-    aEap.iVerifyServerRealm = aHssEap.iVerifyServerRealm;
-    aEap.iRequireClientAuthenticationPresent = aHssEap.iRequireClientAuthenticationPresent;
-    aEap.iRequireClientAuthentication = aHssEap.iRequireClientAuthentication;
-    aEap.iSessionValidityTimePresent = aHssEap.iSessionValidityTimePresent;
-    aEap.iSessionValidityTime = aHssEap.iSessionValidityTime;
-    aEap.iCipherSuitesPresent = aHssEap.iCipherSuitesPresent;
-    
-    for( TInt i = 0; i < aHssEap.iCipherSuitesCount; i++ )
-        {
-        aEap.iCipherSuites.Append( aHssEap.iCipherSuites[i] );
-        }
-    aEap.iPEAPVersionsPresent = aHssEap.iPEAPVersionsPresent;
-    aEap.iPEAPv0Allowed = aHssEap.iPEAPv0Allowed;
-    aEap.iPEAPv1Allowed = aHssEap.iPEAPv1Allowed;
-    aEap.iPEAPv2Allowed = aHssEap.iPEAPv2Allowed;
-    aEap.iCertificatesPresent = aHssEap.iCertificatesPresent;
-    for( TInt i = 0; i < aHssEap.iCertificatesCount; i++ )
-        {
-        DEBUG("CHssIapHandler::ConvertEApSettings Certificates present");
-        CertificateEntry entry;
-        
-        entry.iCertType = static_cast<CertificateEntry::TCertType>( aHssEap.iCertificates[i]->iCertType );
-        entry.iSubjectNamePresent = aHssEap.iCertificates[i]->iSubjectNamePresent;
-        entry.iSubjectName = aHssEap.iCertificates[i]->iSubjectName;
-        entry.iIssuerNamePresent = aHssEap.iCertificates[i]->iIssuerNamePresent;
-        entry.iIssuerName = aHssEap.iCertificates[i]->iIssuerName;
-        entry.iSerialNumberPresent= aHssEap.iCertificates[i]->iSerialNumberPresent;
-        entry.iSerialNumber = aHssEap.iCertificates[i]->iSerialNumber;
-        entry.iSubjectKeyIDPresent = aHssEap.iCertificates[i]->iSubjectKeyIDPresent;
-        entry.iSubjectKeyID = aHssEap.iCertificates[i]->iSubjectKeyID;
-        
-        entry.iThumbprintPresent = aHssEap.iCertificates[i]->iThumbprintPresent;
-        entry.iThumbprint = aHssEap.iCertificates[i]->iThumbprint;
-        TRAP_IGNORE( aEap.iCertificates.AppendL( entry ) ); // Memory problem, ignored...
-        }
-    aEap.iEncapsulatedEAPTypesPresent = aHssEap.iEncapsulatedEAPTypesPresent;
-    for( TInt i = 0; i < aHssEap.iEncapsulatedEAPTypesCount; i++ )
-        {
-        aEap.iEncapsulatedEAPTypes.Append( aHssEap.iEncapsulatedEAPTypes[i] );
-        }
-    }
     
 // -----------------------------------------------------------------------------
 // ConvertAsciiToHex
@@ -455,78 +319,6 @@
     }
 
 // -----------------------------------------------------------------------------
-// GetEapTypeDesC
-// -----------------------------------------------------------------------------
-//
-void CHssIapHandler::GetEapTypeDesC( TUint aEapType, TDes8& aEapString, TChar& aEapCode )
-    {
-    DEBUG1( "CHssIapHandler::GetEapTypeDesC aEapType: %d", aEapType );
-    switch ( aEapType )
-        {
-            // EapNone
-            case 0:
-                aEapString.Copy( KEapNoneId, KEapExpandedIdLength );
-                aEapCode = KEapNoneId[7];
-                break;
-            // KEapGtc
-            case 6:
-            	aEapString.Copy( KEapGtcId, KEapExpandedIdLength );
-            	aEapCode = KEapGtcId[7];
-                break;
-            // KEapTls
-            case 13:
-            	aEapString.Copy( KEapTlsId, KEapExpandedIdLength );
-            	aEapCode = KEapTlsId[7];
-                break;
-            // KEapLeap
-            case 17:
-            	aEapString.Copy( KEapLeapId, KEapExpandedIdLength );
-            	aEapCode = KEapLeapId[7];
-                break;
-            // KEapSim
-            case 18:
-            	aEapString.Copy( KEapSimId, KEapExpandedIdLength );
-            	aEapCode = KEapSimId[7];
-                break;
-            // KEapTtls
-            case 21:
-            	aEapString.Copy( KEapTtlsId, KEapExpandedIdLength );
-            	aEapCode = KEapTtlsId[7];
-                break;
-            // KEapAka
-            case 23:
-            	aEapString.Copy( KEapAkaId, KEapExpandedIdLength );
-            	aEapCode = KEapAkaId[7];
-                break;
-            // KEapPeap
-            case 25:
-            	aEapString.Copy( KEapPeapId, KEapExpandedIdLength );
-            	aEapCode = KEapPeapId[7];
-                break;
-            // KEapMschapv2
-            case 26:
-            	aEapString.Copy( KEapMschapv2Id, KEapExpandedIdLength );
-            	aEapCode = KEapMschapv2Id[7];
-                break;
-            // KEapSecurid
-            case 32:
-            	aEapString.Copy( KEapSecuridId, KEapExpandedIdLength );
-            	aEapCode = KEapSecuridId[7];
-                break;
-            // KEapPlainMschapv2
-            case 99:
-            	aEapString.Copy( KEapPlainMschapv2Id, KEapExpandedIdLength );
-            	aEapCode = KEapPlainMschapv2Id[7];
-            	break;
-            default:
-            	aEapString.Copy( KEapNoneId, KEapExpandedIdLength );
-            	aEapCode = KEapNoneId[7];
-                break;
-        }
-    DEBUG( "CHssIapHandler::GetEapTypeDesC DONE" );
-    }
-
-// -----------------------------------------------------------------------------
 // GetNetworkIdL
 // -----------------------------------------------------------------------------
 //
--- a/hsfw_plat/hotspot_framework_client_api/group/bld.inf	Tue May 11 12:32:08 2010 +0100
+++ b/hsfw_plat/hotspot_framework_client_api/group/bld.inf	Tue May 18 13:51:10 2010 +0100
@@ -32,4 +32,4 @@
 ../inc/hssmgmtscaninfo.h     MW_LAYER_PLATFORM_EXPORT_PATH(hssmgmtscaninfo.h)
 ../inc/hssmgmtclient.inl     MW_LAYER_PLATFORM_EXPORT_PATH(hssmgmtclient.inl)
 ../inc/hssmgmtscaninfo.inl     MW_LAYER_PLATFORM_EXPORT_PATH(hssmgmtscaninfo.inl)
-../inc/hssiapsettings.inl     MW_LAYER_PLATFORM_EXPORT_PATH(hssiapsettings.inl)
+
--- a/hsfw_plat/hotspot_framework_client_api/inc/hssiapsettings.h	Tue May 11 12:32:08 2010 +0100
+++ b/hsfw_plat/hotspot_framework_client_api/inc/hssiapsettings.h	Tue May 18 13:51:10 2010 +0100
@@ -30,9 +30,6 @@
 const TInt KHssMaxMedTextLength	= 255;
 const TUint8 KHssMaxSSIDLength = 32;
 const TUint32 KHssMaxWEPKeyLength = 29;
-const TUint KHssGeneralStringMaxLength = 255;
-const TUint KHssKeyIdentifierLength = 20;
-const TUint KHssThumbprintMaxLength = 64;
 const TInt KHssMaxNumberOfKeys = 4;
 
 //  DATA TYPES
@@ -76,138 +73,6 @@
     /** Array that stores the WEP key. */
     TUint8 KeyMaterial[KHssMaxWEPKeyLength];
     };
-
-
-
-	
-/**
-* class containing Certificate info for EAP settings
-*/
-class THssCertificateEntry 
-{
-public:
-
-    enum THssCertType 
-	{
-		EUser,
-		ECA
-	};
-	
-	THssCertificateEntry();
-
-	// Specifies whether this entry describes user or CA certificate (mandatory)
-	THssCertType iCertType;
-	
-	// Subject name in distinguished name ASCII form.
-	// For example "/C=US/O=Some organization/CN=Some common name".	
-	TBool iSubjectNamePresent;
-	TBuf<KHssGeneralStringMaxLength> iSubjectName;
-		
-	// Issuer name in distinguished name ASCII form.
-	// For example "/C=US/O=Some organization/CN=Some common name".
-	TBool iIssuerNamePresent;
-	TBuf<KHssGeneralStringMaxLength> iIssuerName;
-	
-	// Serial number in ASCII form.
-	TBool iSerialNumberPresent;
-	TBuf<KHssGeneralStringMaxLength> iSerialNumber;
-	
-	// Subject key in binary form
-	TBool iSubjectKeyIDPresent;
-	TBuf8<KHssKeyIdentifierLength> iSubjectKeyID;
-	
-	// Thumbprint in binary form
-	TBool iThumbprintPresent;
-	TBuf<KHssThumbprintMaxLength> iThumbprint;
-};
-
-
-/**
-* class containing EAP settings
-*/
-class THssEapSettings 
-{
-public:	
-
-    enum THssEapType
-	{
-		EEapNone		= 0,
-		EEapGtc			= 6,
-		EEapTls			= 13,
-		EEapLeap		= 17,
-		EEapSim			= 18,
-		EEapTtls		= 21,
-		EEapAka			= 23,
-		EEapPeap		= 25,
-		EEapMschapv2	= 26,
-		EEapSecurid		    = 32,
-		EEapPlainMschapv2   = 99
-	};
-	
-	THssEapSettings();
-		
-    void ExternalizeL( RWriteStream& aStream ) const;
-    
-    void InternalizeL( RReadStream& aStream );
-
-	// Specifies the EAP type these settings are for. 
-	// Is not really needed but is here so just some sanity checks can be made
-	THssEapType iEAPType; 
-	
-	// Username in ASCII format
-	TBool iUsernamePresent;
-	TBuf<KHssGeneralStringMaxLength> iUsername; 
-		
-	// Password in ASCII format
-	TBool iPasswordPresent;
-	TBuf<KHssGeneralStringMaxLength> iPassword;
-		
-	// Realm in ASCII format
-	TBool iRealmPresent;
-	TBuf<KHssGeneralStringMaxLength> iRealm; 
-	
-	// Use pseudonym identities in EAP-SIM/AKA
-	TBool iUsePseudonymsPresent;
-	TBool iUsePseudonyms;		
-	
-	// Whether EAP-TLS/TTLS/PEAP should verify server realm
-	TBool iVerifyServerRealmPresent;
-	TBool iVerifyServerRealm;
-	
-	// Whether EAP-TLS/TTLS/PEAP should require client authentication
-	TBool iRequireClientAuthenticationPresent;
-	TBool iRequireClientAuthentication;
-	
-	// General session validity time (in minutes)
-	TBool iSessionValidityTimePresent;
-	TUint iSessionValidityTime;
-	
-	// An array of allowed cipher suites for EAP-TLS/TTLS/PEAP. 
-	// Refer to RFC2246 chapter A.5 for the values.
-	TBool iCipherSuitesPresent;
-	TUint iCipherSuitesCount;
-	RArray<TUint> iCipherSuites;
-
-	// In EAP-PEAP is version 0 allowed
-	TBool iPEAPVersionsPresent;
-	TBool iPEAPv0Allowed;
-	TBool iPEAPv1Allowed;
-	TBool iPEAPv2Allowed;
-  	  
-  	// Array listing the allowed certificates for EAP-TLS/TTLS/PEAP
-  	TBool iCertificatesPresent;
-  	TUint iCertificatesCount;
-	RPointerArray<THssCertificateEntry> iCertificates;
-	
-	// Array listing the encapsulated EAP types (in priority order)
-	TBool iEncapsulatedEAPTypesPresent;
-	TUint iEncapsulatedEAPTypesCount;
-	RArray<TUint> iEncapsulatedEAPTypes;
-	
-	// EAP type that this THssEapSettings type is encapsulated to
-	// Example: For EEapMschapv2 type this value could be EEapPeap
-	THssEapType iEncapsulatedInside;
-};
     
 /**
 * struct containing all wlan settings data
@@ -237,13 +102,8 @@
     TBuf8<KHssWlanWpaPskLength>     iWPAPreSharedKey;
     TUint32                         iWPAKeyLength;
     TBool                           iEnableWpaPsk;
-        
-    RPointerArray<THssEapSettings>  iEapDataArray;
     };
 
-
-#include "hssiapsettings.inl"
-
 #endif // HSSIAPSETTINGS_H
 
 // end of file
--- a/hsfw_plat/hotspot_framework_client_api/inc/hssiapsettings.inl	Tue May 11 12:32:08 2010 +0100
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,161 +0,0 @@
-/*
-* Copyright (c) 2006-2007 Nokia Corporation and/or its subsidiary(-ies).
-* All rights reserved.
-* This component and the accompanying materials are made available
-* under the terms of "Eclipse Public License v1.0"
-* which accompanies this distribution, and is available
-* at the URL "http://www.eclipse.org/legal/epl-v10.html".
-*
-* Initial Contributors:
-* Nokia Corporation - initial contribution.
-*
-* Contributors:
-*
-* Description:   EAP and WLAN authentication protocols.
-*
-*/
-
-
-
-inline THssCertificateEntry::THssCertificateEntry()
-: iSubjectNamePresent(EFalse)
-, iIssuerNamePresent(EFalse)
-, iSerialNumberPresent(EFalse)
-, iSubjectKeyIDPresent(EFalse)
-, iThumbprintPresent(EFalse)
-    {
-    }
-
-inline THssEapSettings::THssEapSettings()
-: iUsernamePresent(EFalse)
-, iPasswordPresent(EFalse)
-, iRealmPresent(EFalse)
-, iVerifyServerRealmPresent(EFalse)
-, iRequireClientAuthenticationPresent(EFalse)
-, iSessionValidityTimePresent(EFalse)
-, iCipherSuitesPresent(EFalse)
-, iCipherSuites(1)
-, iPEAPVersionsPresent(EFalse)
-, iCertificatesPresent(EFalse)
-, iCertificates(1)
-, iEncapsulatedEAPTypesPresent(EFalse)
-, iEncapsulatedEAPTypes(1)
-, iEncapsulatedInside( EEapNone )
-    {
-    }
-
-inline void THssEapSettings::ExternalizeL( RWriteStream& aStream ) const
-    {
-    aStream.WriteInt32L( iEAPType );
-    aStream.WriteUint32L( iUsernamePresent );
-    aStream << iUsername;
-    aStream.WriteUint32L( iPasswordPresent );
-    aStream << iPassword;
-    aStream.WriteUint32L( iRealmPresent );
-    aStream << iRealm;
-    aStream.WriteUint32L( iUsePseudonymsPresent );
-    aStream.WriteUint32L( iUsePseudonyms );
-    aStream.WriteUint32L( iVerifyServerRealmPresent );
-    aStream.WriteUint32L( iVerifyServerRealm );
-    aStream.WriteUint32L( iRequireClientAuthenticationPresent );
-    aStream.WriteUint32L( iRequireClientAuthentication );
-    aStream.WriteUint32L( iSessionValidityTimePresent );
-    aStream.WriteUint32L( iSessionValidityTime );
-    aStream.WriteUint32L( iCipherSuitesPresent );
-    aStream.WriteUint32L( iCipherSuitesCount);
-    for( TInt i = 0; i < iCipherSuitesCount; i++ )
-        {
-        aStream.WriteUint32L(iCipherSuites[i]); 
-        }
-    aStream.WriteUint32L( iPEAPVersionsPresent );
-    aStream.WriteUint32L( iPEAPv0Allowed );
-    aStream.WriteUint32L( iPEAPv1Allowed );
-    aStream.WriteUint32L( iPEAPv2Allowed );
-    aStream.WriteUint32L( iCertificatesPresent );
-    aStream.WriteUint32L( iCertificatesCount);
-    for( TInt i = 0; i < iCertificatesCount; i++ )
-        {
-        aStream.WriteInt32L( iCertificates[i]->iCertType );
-        aStream.WriteUint32L( iCertificates[i]->iSubjectNamePresent ); 
-        aStream << iCertificates[i]->iSubjectName;   
-        aStream.WriteUint32L( iCertificates[i]->iIssuerNamePresent );
-        aStream << iCertificates[i]->iIssuerName;   
-        aStream.WriteUint32L( iCertificates[i]->iSerialNumberPresent );
-        aStream << iCertificates[i]->iSerialNumber;   
-        aStream.WriteUint32L( iCertificates[i]->iSubjectKeyIDPresent );
-        aStream << iCertificates[i]->iSubjectKeyID;   
-        aStream.WriteUint32L( iCertificates[i]->iThumbprintPresent );
-        aStream << iCertificates[i]->iThumbprint;   
-        }
-    aStream.WriteUint32L( iEncapsulatedEAPTypesPresent );     
-    aStream.WriteUint32L( iEncapsulatedEAPTypesCount );
-    for( TInt i = 0; i < iEncapsulatedEAPTypesCount; i++ )
-        {
-        aStream.WriteUint32L( iEncapsulatedEAPTypes[i] ); 
-        }
-    }
-
-inline void THssEapSettings::InternalizeL( RReadStream& aStream )
-    {   
-    iEAPType = static_cast<THssEapSettings::THssEapType>(aStream.ReadInt32L());
-    iUsernamePresent = aStream.ReadUint32L();
-    aStream >>iUsername;
-    iPasswordPresent = aStream.ReadUint32L();
-    aStream >>iPassword;
-    iRealmPresent = aStream.ReadUint32L();
-    aStream >>iRealm;
-    iUsePseudonymsPresent = aStream.ReadUint32L();
-    iUsePseudonyms = aStream.ReadUint32L();
-    iVerifyServerRealmPresent = aStream.ReadUint32L();
-    iVerifyServerRealm = aStream.ReadUint32L();
-    iRequireClientAuthenticationPresent = aStream.ReadUint32L();
-    iRequireClientAuthentication = aStream.ReadUint32L();
-    iSessionValidityTimePresent = aStream.ReadUint32L();
-    iSessionValidityTime = aStream.ReadUint32L();
-    iCipherSuitesPresent = aStream.ReadUint32L();
-    iCipherSuitesCount = aStream.ReadUint32L();
-    for( TInt i = 0; i < iCipherSuitesCount; i++ )
-        {
-        iCipherSuites.Append(aStream.ReadUint32L());
-        }
-    iPEAPVersionsPresent = aStream.ReadUint32L();
-    iPEAPv0Allowed = aStream.ReadUint32L();
-    iPEAPv1Allowed = aStream.ReadUint32L();
-    iPEAPv2Allowed = aStream.ReadUint32L();
-    iCertificatesPresent = aStream.ReadUint32L();
-    iCertificatesCount = aStream.ReadUint32L();
-    for( TInt i = 0; i < iCertificatesCount; i++ )
-        {
-        THssCertificateEntry* entry = new (ELeave) THssCertificateEntry();
-        
-        entry->iCertType = static_cast<THssCertificateEntry::THssCertType>(aStream.ReadInt32L());
-        entry->iSubjectNamePresent = aStream.ReadUint32L();
-        aStream >> entry->iSubjectName;
-        entry->iIssuerNamePresent = aStream.ReadUint32L();
-        aStream >> entry->iIssuerName;
-        entry->iSerialNumberPresent= aStream.ReadUint32L();
-        aStream >> entry->iSerialNumber;
-        entry->iSubjectKeyIDPresent = aStream.ReadUint32L();
-        aStream >> entry->iSubjectKeyID;
-        entry->iThumbprintPresent = aStream.ReadUint32L();
-        aStream >> entry->iThumbprint;
-        iCertificates.Insert(entry, i);
-        }
-    iEncapsulatedEAPTypesPresent = aStream.ReadUint32L();
-    iEncapsulatedEAPTypesCount = aStream.ReadUint32L();
-    for( TInt i = 0; i < iEncapsulatedEAPTypesCount; i++ )
-        {
-        iEncapsulatedEAPTypes.Append(aStream.ReadUint32L());
-        }
-    
-}
-
-inline THssIapSettings::THssIapSettings()
-: iConnectionMode(EHssInfrastructure)
-, iSecurityMode( EHssAllowUnsecure )
-, iAuthenticationMode(EHssOpen)
-, iEapDataArray(1)  
-{
-}
-
-// end of file
--- a/wlanutilities/wlanentryplugin/inc/cpwlanentryplugin.h	Tue May 11 12:32:08 2010 +0100
+++ b/wlanutilities/wlanentryplugin/inc/cpwlanentryplugin.h	Tue May 18 13:51:10 2010 +0100
@@ -1,34 +1,34 @@
 /*
- * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
- * All rights reserved.
- * This component and the accompanying materials are made available
- * under the terms of "Eclipse Public License v1.0""
- * which accompanies this distribution, and is available
- * at the URL "http://www.eclipse.org/legal/epl-v10.html".
- *
- * Initial Contributors:
- * Nokia Corporation - initial contribution.
- *
- * Contributors:
- *
- * Description:  
- *   
- */
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description: 
+* WLAN Entry plugin implementation.
+*/
  
 #ifndef	CPWLANENTRYPLUGIN_H
 #define	CPWLANENTRYPLUGIN_H
 
-
 // System includes
 
 #include <QObject>
-#include <cppluginplatinterface.h>
+#include <QSharedPointer>
+#include <cpplugininterface.h>
 
 // User includes
 
 // Forward declarations
 
-class QTranslator;
+class HbTranslator;
 
 // External data types
 
@@ -36,10 +36,10 @@
 
 // Class declaration
 
-class CpWlanEntryPlugin : public QObject, public CpPluginPlatInterface
+class CpWlanEntryPlugin : public QObject, public CpPluginInterface
 {
     Q_OBJECT
-    Q_INTERFACES(CpPluginPlatInterface)
+    Q_INTERFACES(CpPluginInterface)
     
 public:
 
@@ -49,7 +49,8 @@
     
     virtual ~CpWlanEntryPlugin();
     
-    virtual CpSettingFormItemData *createSettingFormItemData(CpItemDataHelper &itemDataHelper) const;
+    virtual QList<CpSettingFormItemData *> createSettingFormItemData(
+        CpItemDataHelper &itemDataHelper) const;
 
 signals:
 
@@ -67,11 +68,12 @@
 
 private: // data
 
-    bool mWlanSupported;            // WLAN dynamic ON/OFF configuration
-    QTranslator *mTranslator;       // Translator for text ID's used in this plugin
+    //! WLAN dynamic ON/OFF configuration
+    bool mWlanSupported;
+    //! Translator for text ID's used in this plugin
+    QSharedPointer<HbTranslator> mTranslator;
 
     // Friend classes
-
 };
 
 #endif	// CPWLANENTRYPLUGIN_H
--- a/wlanutilities/wlanentryplugin/src/cpwlanentryplugin.cpp	Tue May 11 12:32:08 2010 +0100
+++ b/wlanutilities/wlanentryplugin/src/cpwlanentryplugin.cpp	Tue May 18 13:51:10 2010 +0100
@@ -1,25 +1,24 @@
 /*
- * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
- * All rights reserved.
- * This component and the accompanying materials are made available
- * under the terms of "Eclipse Public License v1.0""
- * which accompanies this distribution, and is available
- * at the URL "http://www.eclipse.org/legal/epl-v10.html".
- *
- * Initial Contributors:
- * Nokia Corporation - initial contribution.
- *
- * Contributors:
- *
- * Description:  
- *
- */
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description: 
+* WLAN Entry plugin implementation.
+*/
 
 // System includes
 
 #include <QApplication>
-#include <QTranslator>
-#include <QLocale>
+#include <HbTranslator>
 #include "qsysteminfo.h"
 
 // User includes
@@ -52,9 +51,12 @@
     Constructor.
 */
 
-CpWlanEntryPlugin::CpWlanEntryPlugin() : QObject()
+CpWlanEntryPlugin::CpWlanEntryPlugin() :
+    QObject(),
+    mWlanSupported(false),
+    mTranslator()
 {
-    OstTraceFunctionEntry1(CPWLANENTRYPLUGIN_CPWLANENTRYPLUGIN_ENTRY, this);
+    OstTraceFunctionEntry0(CPWLANENTRYPLUGIN_CPWLANENTRYPLUGIN_ENTRY);
     
     // Check & store WLAN dynamic configuration
     QtMobility::QSystemInfo sysinfo;
@@ -62,14 +64,11 @@
     
     if (mWlanSupported) {
         // Install localization
-        mTranslator = new QTranslator(this);
-        QString lang = QLocale::system().name(); 
-        QString path = "Z:/resource/qt/translations/"; 
-        mTranslator->load("wlanentryplugin_" + lang, path); 
-        qApp->installTranslator(mTranslator);
+        mTranslator = QSharedPointer<HbTranslator>(
+            new HbTranslator("wlanentryplugin"));
     }
     
-    OstTraceFunctionExit1(CPWLANENTRYPLUGIN_CPWLANENTRYPLUGIN_EXIT, this);
+    OstTraceFunctionExit0(CPWLANENTRYPLUGIN_CPWLANENTRYPLUGIN_EXIT);
 }
 
 /*!
@@ -78,27 +77,30 @@
 
 CpWlanEntryPlugin::~CpWlanEntryPlugin()
 {
-    OstTraceFunctionEntry1(DUP1_CPWLANENTRYPLUGIN_CPWLANENTRYPLUGIN_ENTRY, this);
-    OstTraceFunctionExit1(DUP1_CPWLANENTRYPLUGIN_CPWLANENTRYPLUGIN_EXIT, this);
+    OstTraceFunctionEntry0(DUP1_CPWLANENTRYPLUGIN_CPWLANENTRYPLUGIN_ENTRY);
+    OstTraceFunctionExit0(DUP1_CPWLANENTRYPLUGIN_CPWLANENTRYPLUGIN_EXIT);
 }
 
 /*!
     Plugin function for creating the entry plugin form item data.
+    
+    @param [in,out] itemDataHelper Control Panel item data helper.
 */
 
-CpSettingFormItemData *CpWlanEntryPlugin::createSettingFormItemData(CpItemDataHelper &itemDataHelper) const
+QList<CpSettingFormItemData *> CpWlanEntryPlugin::createSettingFormItemData(
+    CpItemDataHelper &itemDataHelper) const
 {
-    OstTraceFunctionEntry1(CPWLANENTRYPLUGIN_CREATESETTINGFORMITEMDATA_ENTRY, this);
+    OstTraceFunctionEntry0(CPWLANENTRYPLUGIN_CREATESETTINGFORMITEMDATA_ENTRY);
     
-    CpWlanEntryItemData *entryItemData = 0;
+    QList<CpSettingFormItemData *> settingFormData;
     
     // The plugin is disabled if WLAN is not supported by the product.
     if (mWlanSupported) {
-        entryItemData = new CpWlanEntryItemData(itemDataHelper);
+        settingFormData.append(new CpWlanEntryItemData(itemDataHelper));
     }
 
-    OstTraceFunctionExit1(CPWLANENTRYPLUGIN_CREATESETTINGFORMITEMDATA_EXIT, this);
-    return entryItemData;
+    OstTraceFunctionExit0(CPWLANENTRYPLUGIN_CREATESETTINGFORMITEMDATA_EXIT);
+    return settingFormData;
 }
 
 Q_EXPORT_PLUGIN2(cpwlanentryplugin, CpWlanEntryPlugin);
--- a/wlanutilities/wlansniffer/inc/wlansnifferlistview.h	Tue May 11 12:32:08 2010 +0100
+++ b/wlanutilities/wlansniffer/inc/wlansnifferlistview.h	Tue May 18 13:51:10 2010 +0100
@@ -44,9 +44,13 @@
     void detailsTriggered(int);
     void completeServiceTriggered();
 
+public slots:
+    void handleContextMenuClosed();
+
 private slots:
     void handleListItemActivated(HbListWidgetItem *item);
     void handleListItemLongPressed(HbListWidgetItem *item, const QPointF &coords);
+    void handleListItemDisconnect();
     void handleDisconnect();
     
 private:
@@ -59,7 +63,12 @@
     HbLabel *mStatusLabel;
     WlanSniffer *mAppRef;
     int mConnectingIapId;
-    bool mIapItemMenuOpen;
+    /*!
+     * Data identifying the network for which the context menu has been
+     * opened: WlanQtUtilsAp class, or int IAP ID
+     */
+    QVariant mContextMenuData;
+    HbMenu *mContextMenu; //!< Context menu reference, if one is open
     };
 
 #endif
--- a/wlanutilities/wlansniffer/src/wlansnifferlistview.cpp	Tue May 11 12:32:08 2010 +0100
+++ b/wlanutilities/wlansniffer/src/wlansnifferlistview.cpp	Tue May 18 13:51:10 2010 +0100
@@ -44,7 +44,7 @@
     mStatusLabel(NULL),
     mAppRef(appRef),
     mConnectingIapId(0),
-    mIapItemMenuOpen(false)
+    mContextMenu(NULL)
 {
     OstTraceFunctionEntry0( WLANSNIFFERLISTVIEW_WLANSNIFFERLISTVIEW_ENTRY );
     
@@ -113,7 +113,8 @@
 {
     OstTraceFunctionEntry0( WLANSNIFFERLISTVIEW_UPDATE_ENTRY );
     
-    if (mIapItemMenuOpen == false) {
+    // Do not update list while the context menu is open
+    if (mContextMenu == NULL) {
         QList<WlanQtUtilsWlanAp*> aps;
         QList<WlanQtUtilsWlanIap*> iaps;
         
@@ -158,6 +159,17 @@
     OstTraceFunctionExit0( WLANSNIFFERLISTVIEW_UPDATECONNECTIONCLOSED_EXIT );
 }
 
+void WlanSnifferListView::handleContextMenuClosed()
+{
+    OstTraceFunctionEntry0( WLANSNIFFERLISTVIEW_HANDLECONTEXTMENUCLOSED_ENTRY );
+
+    // Menu deletes itself, but we need to cleanup the member variable
+    // in order to enable list updating again
+    mContextMenu = NULL;
+    
+    OstTraceFunctionExit0( WLANSNIFFERLISTVIEW_HANDLECONTEXTMENUCLOSED_EXIT );
+}
+
 void WlanSnifferListView::handleListItemActivated(HbListWidgetItem *item)
 {
     OstTraceFunctionEntry0( WLANSNIFFERLISTVIEW_HANDLELISTITEMACTIVATED_ENTRY );
@@ -193,46 +205,49 @@
 {
     OstTraceFunctionEntry0( WLANSNIFFERLISTVIEW_HANDLELISTITEMLONGPRESSED_ENTRY );
     
-    // Disable list refreshing while context menu is shown
-    // Todo: Propably a more elegant way to do this is needed..
-    mIapItemMenuOpen = true;
-    
-    (void)item;
-    HbMenu *contextMenu = new HbMenu();
-    HbAction *actionDetails = contextMenu->addAction(hbTrId("txt_occ_menu_details"));
-    HbAction *actionSettings = contextMenu->addAction(hbTrId("txt_occ_menu_network_settings"));
-    HbAction *actionDisable = contextMenu->addAction(hbTrId("txt_occ_menu_disable_network"));
-    
-    // Add disconnect option if the IAP is connected
-    HbAction *actionDisconnect = 0;
-    WlanQtUtilsIap *iap = 0;
-    QVariant data = item->data();
-    if (data.canConvert<int>()) {
-        // Item was an IAP.
-        iap = mAppRef->wlanQtUtils()->iap(data.toInt());
-        if (iap->connectionStatus() == WlanQtUtilsConnectionStatusConnected) {
-            actionDisconnect = contextMenu->addAction(hbTrId("txt_common_menu_disconnect"));
-        }
+    Q_ASSERT(mContextMenu == NULL);
+
+    if (item->data().canConvert<int>() && item->data().toInt() ==
+        mAppRef->wlanQtUtils()->connectedWlanId()) {
+        // Connected IAP, add "Disconnect" action
+		    mContextMenu = new HbMenu();
+		    // Remember the item that was long pressed
+    		mContextMenuData = item->data();
+        mContextMenu->addAction(
+            hbTrId("txt_common_menu_disconnect"),
+            this,
+            SLOT(handleListItemDisconnect()));
+		    // Show the menu and connect closure signal (to re-enable list refreshing)
+		    bool connectStatus = connect(
+		        mContextMenu,
+		        SIGNAL(aboutToClose()),
+		        this,
+		        SLOT(handleContextMenuClosed()));
+		    Q_ASSERT(connectStatus);
+		    mContextMenu->setAttribute(Qt::WA_DeleteOnClose);
+		    mContextMenu->setTimeout(HbPopup::ContextMenuTimeout);
+		    mContextMenu->setPreferredPos(coords);
+		    mContextMenu->show();
     }
-    
-    // Show the menu
-    HbAction *selectedAction = contextMenu->exec(coords);
-    // Re-enable list refreshing
-    mIapItemMenuOpen = false;
-
-    if (selectedAction) {
-        // Handle the "Disconnect" menu selection
-        if (selectedAction == actionDisconnect) {
-            mStatusLabel->setPlainText(hbTrId("txt_occ_grid_not_connected"));
-            mAppRef->wlanQtUtils()->disconnectIap(iap->id());
-            // Redraw the list so that disconnected network is not shown anymore
-            update();
-        }
-    }        
 
     OstTraceFunctionExit0( WLANSNIFFERLISTVIEW_HANDLELISTITEMLONGPRESSED_EXIT );
 }
 
+/*!
+    Handles a "Disconnect" action selected from the context menu for a list item.
+ */
+void WlanSnifferListView::handleListItemDisconnect()
+{
+    OstTraceFunctionEntry0( WLANSNIFFERLISTVIEW_HANDLELISTITEMDISCONNECT_ENTRY );
+
+    // "Disconnect" was only added, if the item was an IAP and data was
+    // the IAP ID
+    Q_ASSERT(mContextMenuData.canConvert<int>());
+    mAppRef->wlanQtUtils()->disconnectIap(mContextMenuData.toInt());
+    
+    OstTraceFunctionExit0( WLANSNIFFERLISTVIEW_HANDLELISTITEMDISCONNECT_EXIT );
+}
+
 // Todo: This is a temporary solution - real WLAN status indication & listening
 // is implemented later on.
 void WlanSnifferListView::handleDisconnect()