multimediacommsengine/tsrc/testdriver/siptester/src/CTcSIPProfileContainer.cpp
changeset 0 1bce908db942
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/multimediacommsengine/tsrc/testdriver/siptester/src/CTcSIPProfileContainer.cpp	Tue Feb 02 01:04:58 2010 +0200
@@ -0,0 +1,358 @@
+/*
+* Copyright (c) 2004 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:  Implementation.
+*
+*/
+
+
+#include "CTcSIPProfileContainer.h"
+#include "TTcSIPReceived.h"
+#include "CTcSIPContext.h"
+#include "SipConstants.h"
+#include "sipprofile.h"
+#include "sipmanagedprofile.h"
+
+#include "tclog.h"
+#include "TesterConstants.h"
+#include "ErrorHandling.h"
+
+CTcSIPProfileContainer* CTcSIPProfileContainer::NewL(
+													CTcSIPContext& aContext,
+													CSIP& aSip )
+	{
+	CTcSIPProfileContainer* self =
+						new( ELeave ) CTcSIPProfileContainer( aContext,
+															  aSip );
+
+	CleanupStack::PushL( self );
+	self->ConstructL();
+	CleanupStack::Pop( self );
+
+	return self;
+	}
+
+CTcSIPProfileContainer::~CTcSIPProfileContainer()
+	{
+	TcLog::Write( _L8("CTcSIPContext::~CTcSIPContext() start\n") );
+
+    iProfiles.ResetAndDestroy();
+    iManagedProfiles.ResetAndDestroy();
+    
+	delete iProfileRegistry;
+	delete iManagedProfileRegistry;
+	delete iTimer;
+	iReceiveQueue.Reset();
+
+    TcLog::Write( _L8("CTcSIPContext::~CTcSIPContext() end\n") );
+	}
+
+CTcSIPProfileContainer::CTcSIPProfileContainer( CTcSIPContext& aContext, CSIP& aSip )
+	: iContext( aContext ), iSip( aSip ), iReceiveQueue( 1 ), iProfiles( 2 ), iManagedProfiles( 2 )
+	{
+	}
+
+void CTcSIPProfileContainer::ConstructL()
+	{
+	iTimer = CDeltaTimer::NewL( CActive::EPriorityStandard );
+	TCallBack cb( ReceiveTimeout, this );
+	iReceiveTimeout.Set( cb );
+
+    TcLog::Write( _L8("CTcSIPProfileContainer::ConstructL() initializing SIP Profiles client\n") );
+	// Could be used only MangedProfile or UserProfile..
+    iManagedProfileRegistry = CSIPManagedProfileRegistry::NewL( *this );
+	iProfileRegistry = CSIPProfileRegistry::NewL( iSip, *this ); 
+
+    TcLog::Write( _L8("CTcSIPProfileContainer::ConstructL() end\n") );
+	}
+
+
+//
+// -- MSIPProfileRegistryObserver functions -----------------------------------
+//
+
+void CTcSIPProfileContainer::ProfileRegistryEventOccurred(TUint32 aProfileId, TEvent aEvent)
+    {	
+	TTcProfileReceived received;
+	received.iProfileId = aProfileId;
+	
+	switch (aEvent)
+	    {
+	    case MSIPProfileRegistryObserver::EProfileCreated:
+	        {
+	        received.iEvent = ETcProfileCreated;
+	        break;
+	        }
+	    case MSIPProfileRegistryObserver::EProfileUpdated:
+	        {
+	        received.iEvent = ETcProfileUpdated;
+	        break;
+	        }
+	    case MSIPProfileRegistryObserver::EProfileRegistered:
+	        {
+	        received.iEvent = ETcProfileRegistrationStatusChanged;
+	        received.iRegStatus = ETcStatusRegistered;
+	        break;
+	        }
+	    case MSIPProfileRegistryObserver::EProfileDeregistered:
+	        {
+	        received.iEvent = ETcProfileRegistrationStatusChanged;
+	        received.iRegStatus = ETcStatusUnregistered;
+	        break;
+	        }
+	    case MSIPProfileRegistryObserver::EProfileDestroyed:
+	        {
+	        received.iEvent = ETcProfileDestroyed;
+	        break;
+	        }
+	    default:
+	        {
+	        received.iEvent = ETcUnknown;
+	        break;
+	        }
+	    }
+	QueueProfileReceived( received );
+    }
+
+void CTcSIPProfileContainer::ProfileRegistryErrorOccurred(TUint32 aProfileId, TInt aError )
+	{
+	TTcProfileReceived received;
+	received.iProfileId = aProfileId;
+	received.iEvent = ETcProfileRegistryErrorOccurred;
+	received.iError = aError;
+	QueueProfileReceived( received );
+	}
+
+//
+// -- Public functions --------------------------------------------------------
+//
+
+TTcProfileReceived CTcSIPProfileContainer::ReceivedProfileItemL( TInt aTimeout )
+	{
+	if( iReceiveQueue.Count() == 0 )
+		{
+		// wait for items to arrive
+		iTimer->Queue( aTimeout * KSecondAsMicros, iReceiveTimeout );
+		iActiveWait.Start();
+		}
+
+	// Is the queue still empty ? (i.e. timeout occurred)
+	if( iReceiveQueue.Count() == 0 )
+		{
+		User::Leave( KErrTimedOut );
+		}
+
+	// Get the first (oldest) item from the array
+    TTcProfileReceived item = iReceiveQueue[ 0 ];
+
+	// ..and remove it from the array
+	iReceiveQueue.Delete( 0 );
+	iReceiveQueue.Compress();
+	return item;
+	}
+	
+void CTcSIPProfileContainer::AddManagedProfileL( CSIPManagedProfile* aManagedProfile )
+    {
+    CleanupStack::PushL( aManagedProfile );
+    
+    TUint32 id( 0 );
+	User::LeaveIfError( aManagedProfile->GetParameter( KSIPProfileId, id ) );
+	
+	// Array may contain multiple instances with same profileId
+    CTcSIPManagedProfile* tcprofile = new ( ELeave ) CTcSIPManagedProfile( aManagedProfile, (TInt)id );
+    CleanupStack::Pop( aManagedProfile );
+    CleanupStack::PushL( tcprofile );
+    User::LeaveIfError( iManagedProfiles.Append( tcprofile ) );
+    CleanupStack::Pop();
+    }
+
+
+CSIPProfile& CTcSIPProfileContainer::GetProfileByIdL( TInt aProfileId )
+    {
+    CSIPProfile* profile = 0;
+    
+    // Check whether profile is already stored into our internal array
+    TInt count = iProfiles.Count();
+    for( TInt i=0; i < count; i++ )
+        {
+        if( iProfiles[ i ]->ProfileId() == aProfileId )
+            {
+            return iProfiles[ i ]->Profile();
+            }
+        
+        }
+    // Profile wasn't found from internal array, create new instance through registry 
+    // and store it 
+    profile = ProfileRegistry().ProfileL( aProfileId );
+    
+    CleanupStack::PushL( profile );
+    CTcSIPProfile* item = new ( ELeave ) CTcSIPProfile( profile, aProfileId );
+    CleanupStack::Pop( profile );
+    
+    CleanupStack::PushL( item );
+    User::LeaveIfError( iProfiles.Append( item ) );
+    CleanupStack::Pop( item );
+    
+    return *profile;
+    }
+    
+    
+CSIPManagedProfile& CTcSIPProfileContainer::GetManagedProfileByIdL( TInt aManagedProfileId )
+    {
+    CSIPManagedProfile* profile = 0;
+    
+    // Check whether profile is already stored into our internal array
+    for( TInt i = 0; i < iManagedProfiles.Count(); i++ )
+        {
+        if( iManagedProfiles[ i ]->ProfileId() == aManagedProfileId )
+            {
+            return iManagedProfiles[ i ]->Profile();
+            }
+        
+        }
+    // Profile wasn't found from internal array, create new instance through registry 
+    // and store it 
+    profile = static_cast< CSIPManagedProfile* >( ManagedProfileRegistry().ProfileL( aManagedProfileId ) );
+    
+    CleanupStack::PushL( profile );
+    CTcSIPManagedProfile* item = new ( ELeave ) CTcSIPManagedProfile( profile, aManagedProfileId );
+    CleanupStack::Pop( profile );
+    
+    CleanupStack::PushL( item );
+    User::LeaveIfError( iManagedProfiles.Append( item ) );
+    CleanupStack::Pop( item );
+    
+    return *profile;
+    }
+ 
+CSIPManagedProfile& CTcSIPProfileContainer::GetDefaultProfileL()
+    {
+	CSIPManagedProfile* profile = static_cast< CSIPManagedProfile* >( ManagedProfileRegistry().DefaultProfileL() );
+				
+    AddManagedProfileL( profile );
+        
+    return *profile;			
+    }
+
+void CTcSIPProfileContainer::DeleteProfileById( TInt aProfileId )
+    {
+    CTcSIPProfile* tcprofile = 0;
+    for( TInt i = 0; i < iProfiles.Count(); i++ )
+        {
+        tcprofile = iProfiles[ i ];
+        
+        if( tcprofile->ProfileId() == aProfileId )
+            {
+            iProfiles.Remove( i );
+            delete tcprofile;
+            return;
+            }
+        }
+    }
+    
+void CTcSIPProfileContainer::DeleteManagedProfileById( TInt aManagedProfileId )
+    {
+    CTcSIPManagedProfile* tcprofile = 0;
+    for( TInt i = 0; i < iManagedProfiles.Count(); i++ )
+        {
+        tcprofile = iManagedProfiles[ i ];
+        if( tcprofile->ProfileId() == aManagedProfileId )
+            {
+            iManagedProfiles.Remove( i );
+            delete tcprofile;
+            return;
+            }
+        }
+    }
+//
+// -- Internal utility functions ----------------------------------------------
+//
+
+void CTcSIPProfileContainer::QueueProfileReceived( TTcProfileReceived& aItem )
+	{
+	TcLog::WriteFormat( _L8("CTcSIPProfileContainer::QueueProfileReceived( ProfileId = %d, Event = %d, Error = %d )"), aItem.iProfileId, aItem.iEvent, aItem.iError );
+
+	TRAPD( err, iReceiveQueue.AppendL( aItem ) );
+	__ASSERT_ALWAYS( !err, Panic( KSIPErrOOMInNotifier ) );
+
+	if( iActiveWait.IsStarted() )
+		{
+		iTimer->Remove( iReceiveTimeout );
+		iActiveWait.AsyncStop();
+		}
+	}
+
+
+TInt CTcSIPProfileContainer::ReceiveTimeout( TAny* aSelf )
+	{
+	CTcSIPProfileContainer& self =
+				*reinterpret_cast< CTcSIPProfileContainer* >( aSelf );
+	if( self.iActiveWait.IsStarted() )
+		{
+		self.iActiveWait.AsyncStop();
+		}
+
+	return KErrNone;
+	}
+
+
+//
+// -- Helper classes ------------------------------------------------------------
+//
+
+
+CTcSIPProfile::CTcSIPProfile( CSIPProfile* aProfile, TInt aProfileId )
+    {
+	iProfile = aProfile;
+	iProfileId = aProfileId;
+    }
+
+CTcSIPProfile::~CTcSIPProfile()
+    {
+    delete iProfile;
+    }
+            
+
+CSIPProfile& CTcSIPProfile::Profile()
+    {
+    return *iProfile;
+    }
+            
+TInt CTcSIPProfile::ProfileId()
+     {
+     return iProfileId;
+     }
+            
+	    
+CTcSIPManagedProfile::CTcSIPManagedProfile( CSIPManagedProfile* aManagedProfile, TInt aManagedProfileId )
+    {
+    iManagedProfile = aManagedProfile;
+    iManagedProfileId = aManagedProfileId;
+    }
+    
+ CTcSIPManagedProfile::~CTcSIPManagedProfile()
+    {
+    delete iManagedProfile;
+    }
+    
+CSIPManagedProfile& CTcSIPManagedProfile::Profile()
+    {
+    return *iManagedProfile;
+    }
+    
+TInt CTcSIPManagedProfile::ProfileId()
+    {
+    return iManagedProfileId;
+    }
+
+