--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/XDMEngine/XdmProvisioning/src/xdmprovadapter.cpp Tue Feb 02 01:05:17 2010 +0200
@@ -0,0 +1,375 @@
+/*
+* Copyright (c) 2006 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: XDM Provisioning Adapter implementation.
+*
+*/
+
+
+
+
+
+// INCLUDE FILES
+#include <CWPCharacteristic.h>
+#include <WPAdapterUtil.h>
+#include <xdmprovisioningtexts.rsg>
+#include <XdmSettingsApi.h>
+
+#include "xdmprovitem.h"
+#include "xdmprovadapter.h"
+
+
+#ifdef _DEBUG
+ #include <flogger.h>
+#endif
+
+
+// ============================ MEMBER FUNCTIONS ===============================
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::CXdmProvAdapter
+//
+// -----------------------------------------------------------------------------
+//
+CXdmProvAdapter::CXdmProvAdapter():
+iDefaultName( NULL ),
+iTitle( NULL ),
+iProvItems( 1 )
+ {
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::ConstructL
+// Symbian 2nd phase constructor can leave.
+// -----------------------------------------------------------------------------
+//
+void CXdmProvAdapter::ConstructL()
+ {
+ // AdapterUtil needs the name of the resource file without the prefix and
+ // the path returned by Dll::FileName. Note that Dll::FileName is an
+ // undocumented method.
+ //
+ _LIT( KXdmAdapterName, "xdmprovisioningtexts"); // xdmprovisioningtexts.rss
+ TFileName fileName;
+ Dll::FileName(fileName);
+
+ iTitle = WPAdapterUtil::ReadHBufCL( fileName,
+ KXdmAdapterName,
+ R_QTN_SM_HEAD_CONNECTION);
+ iDefaultName = WPAdapterUtil::ReadHBufCL( fileName,
+ KXdmAdapterName,
+ R_QTN_XDM_PROVISIONING_NAME);
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::NewL
+// Two-phased constructor.
+// -----------------------------------------------------------------------------
+//
+CXdmProvAdapter* CXdmProvAdapter::NewL()
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::NewL" ) );
+#endif
+ CXdmProvAdapter* self = new(ELeave) CXdmProvAdapter;
+ CleanupStack::PushL(self);
+ self->ConstructL();
+ CleanupStack::Pop();
+ return self;
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::~CXdmProvAdapter
+// Destructor
+// -----------------------------------------------------------------------------
+//
+CXdmProvAdapter::~CXdmProvAdapter()
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::~CXdmProvAdapter" ) );
+#endif
+ delete iTitle;
+ delete iDefaultName;
+ iProvItems.ResetAndDestroy();
+ iProvItems.Close();
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::ItemCount
+// -----------------------------------------------------------------------------
+//
+TInt CXdmProvAdapter::ItemCount() const
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::ItemCount returns %d" ), iProvItems.Count());
+#endif
+ return iProvItems.Count();
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::SummaryTitle
+// -----------------------------------------------------------------------------
+//
+const TDesC16& CXdmProvAdapter::SummaryTitle(TInt /*aIndex*/) const
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::SummaryTitle" ) );
+#endif
+ return *iTitle;
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::SummaryText
+// -----------------------------------------------------------------------------
+//
+const TDesC16& CXdmProvAdapter::SummaryText( TInt aIndex ) const
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::SummaryText" ) );
+#endif
+ TInt count = iProvItems.Count();
+ if( aIndex < count )
+ {
+ if( 0 < iProvItems[aIndex]->Name().Length() )
+ {
+ return iProvItems[aIndex]->Name();
+ }
+ }
+ return *iDefaultName;
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::SaveL
+// -----------------------------------------------------------------------------
+//
+void CXdmProvAdapter::SaveL( TInt aItem )
+ {
+ if ( aItem < iProvItems.Count() - 1 )
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::SaveL leaves with KErrArgument" ) );
+#endif
+ User::Leave ( KErrArgument );
+ }
+ iProvItems[aItem]->SaveL();
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::SaveL done" ) );
+#endif
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::CanSetAsDefault
+// -----------------------------------------------------------------------------
+//
+TBool CXdmProvAdapter::CanSetAsDefault( TInt /*aItem*/ ) const
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::CanSetAsDefault" ) );
+#endif
+ return EFalse;
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::SetAsDefaultL
+// -----------------------------------------------------------------------------
+//
+void CXdmProvAdapter::SetAsDefaultL( TInt /*aItem*/ )
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::SetAsDefaultL" ) );
+#endif
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::DetailsL
+//
+// -----------------------------------------------------------------------------
+//
+TInt CXdmProvAdapter::DetailsL( TInt /*aItem*/, MWPPairVisitor& /*aVisitor*/ )
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::DetailsL" ) );
+#endif
+ return KErrNotSupported;
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::VisitL
+// -----------------------------------------------------------------------------
+//
+void CXdmProvAdapter::VisitL( CWPCharacteristic& aCharacteristic )
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::VisitL( CWPCharacteristic& aCharacteristic)" ) );
+#endif
+ if( KWPApplication == aCharacteristic.Type() )
+ {
+ CXdmProvItem* item = CXdmProvItem::NewL();
+ CleanupStack::PushL( item ); // << item
+ aCharacteristic.AcceptL( *item );
+
+ if( item->Validate() )
+ {
+ iProvItems.AppendL( item );
+ CleanupStack::Pop( item ); // >> item
+ }
+ else
+ {
+ CleanupStack::PopAndDestroy( item ); // >>> item
+ }
+ }
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::VisitL
+// -----------------------------------------------------------------------------
+//
+void CXdmProvAdapter::VisitL( CWPParameter& /*aParameter*/ )
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::VisitL( CWPParameter& /*aParameter*/" ) );
+#endif
+ // Not used.
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::VisitLinkL
+// -----------------------------------------------------------------------------
+//
+void CXdmProvAdapter::VisitLinkL( CWPCharacteristic& /*aLink*/ )
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::VisitLinkL( CWPCharacteristic& aLink" ) );
+#endif
+ // Not used.
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::SettingsSavedL
+//
+// -----------------------------------------------------------------------------
+void CXdmProvAdapter::SettingsSavedL( const TDesC8& aAppIdOfSavingItem,
+ const TDesC8& aAppRef,
+ const TDesC8& aStorageIdValue )
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::SettingsSavedL" ) );
+#endif
+ // Convert aAppRef
+ HBufC* appRef16 = HBufC::NewLC( aAppRef.Length() ); // << aAppRef16
+ appRef16->Des().Copy( aAppRef );
+
+ // Offer application references to all provisioned XDM settings
+ TInt provItemsCount( iProvItems.Count() );
+ for( TInt i(0); i < provItemsCount; i++ )
+ {
+ CXdmProvItem* item = iProvItems[i];
+ const RArray<TPtrC>& toAppRefs = item->ToAppReferences();
+
+ // Find application reference that is being offered
+ TInt toAppRefsCount( toAppRefs.Count() );
+ for( TInt j(0); j < toAppRefsCount; j++ )
+ {
+ const TDesC& toAppRef = toAppRefs[j];
+ if( !toAppRef.Compare( *appRef16 ) )
+ {
+ // Set correct application reference
+ if( !aAppIdOfSavingItem.Compare( KXdmProvSipIdentifier ) )
+ {
+ item->SetSipSettingsIdL( aStorageIdValue );
+ break;
+ }
+ }
+ }
+ }
+ CleanupStack::PopAndDestroy( appRef16 ); // >>> appRef16
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::GetSavingInfoL
+//
+// -----------------------------------------------------------------------------
+void CXdmProvAdapter::GetSavingInfoL( TInt aIndex,
+ RPointerArray<HBufC8>& aSavingInfo )
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::GetSavingInfoL" ) );
+#endif
+ if ( aIndex < iProvItems.Count() - 1 )
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::GetSavingInfoL leaves with KErrArgument" ) );
+#endif
+ User::Leave ( KErrArgument );
+ }
+ TInt length ( iProvItems[aIndex]->AppReference().Length() );
+ // if the APPREF exists
+ if ( 0 < length )
+ {
+ // APPID into place [0].
+ TPtrC8 appId ( KXdmProvAppId8 );
+ HBufC8* appIdBuf = appId.AllocLC(); // << appIdBuf
+ aSavingInfo.AppendL( appIdBuf );
+ CleanupStack::Pop( appIdBuf ); // >> appIdBuf
+ appIdBuf = NULL;
+
+ // APPREF into place [1].
+ HBufC8* appRefBuf = HBufC8::NewLC( length ); // << appRefBuf
+ TPtr8 appRef = appRefBuf->Des();
+ appRef.Copy( iProvItems[aIndex]->AppReference() );
+ aSavingInfo.AppendL( appRefBuf );
+ CleanupStack::Pop( appRefBuf ); // >> appRefBuf
+ appRefBuf = NULL;
+
+ // Xdm settings id into place [2].
+ HBufC8* idBuf = HBufC8::NewLC( KXdmProvIntMaxLength ); // << idBuf
+ TPtr8 id = idBuf->Des();
+ id.Num( iProvItems[aIndex]->XdmSettingsId() );
+ aSavingInfo.AppendL( idBuf );
+ CleanupStack::Pop( idBuf ); // >> idBuf
+ idBuf = NULL;
+ }
+
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::GetSavingInfoL done" ) );
+#endif
+ }
+
+// -----------------------------------------------------------------------------
+// CXdmProvAdapter::SavingFinalizedL()
+//
+// -----------------------------------------------------------------------------
+void CXdmProvAdapter::SavingFinalizedL()
+ {
+#ifdef _DEBUG
+ WriteToLog( _L8( "CXdmProvAdapter::SavingFinalizedL" ) );
+#endif
+ }
+
+
+// ----------------------------------------------------
+// CXdmProvAdapter::WriteToLog
+// _DEBUG only
+// ----------------------------------------------------
+//
+#ifdef _DEBUG
+void CXdmProvAdapter::WriteToLog( TRefByValue<const TDesC8> aFmt,... )
+ {
+ VA_LIST list;
+ VA_START( list, aFmt );
+ TBuf8<KXdmProvAdapterBufferMaxSize> buf;
+ buf.FormatList( aFmt, list );
+ RFileLogger::Write( KXdmProvAdapterLogDir, KXdmProvAdapterLogFile, EFileLoggingModeAppend, buf );
+ }
+#endif
+// End of File