multimediacommsengine/tsrc/testdriver/siptester/src/CTcSIPProfileContainer.cpp
author hgs
Fri, 11 Jun 2010 11:20:25 +0300
changeset 27 5be06b45e413
parent 0 1bce908db942
permissions -rw-r--r--
201023

/*
* 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;
    }