networkcontrol/ipcprshim/src/shimnifmansconn.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 16:45:15 +0300
branchRCL_3
changeset 21 abbed5a4b42a
permissions -rw-r--r--
Revision: 201035 Kit: 201035

// Copyright (c) 2005-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:
// SHIMSCPR.CPP
// This is part of an ECOM plug-in
// 
//

#include <ss_std.h>
#include <comms-infras/ss_log.h>
#include "shimnifmansconn.h"

START_ATTRIBUTE_TABLE(TShimConnectionInfo, KShimCommsUid, Meta::KNetMetaTypeAny)
END_ATTRIBUTE_TABLE()

TInt CNifManSubConnectionShim::AsyncDestructorCb(TAny* aInstance)
	{
	CNifManSubConnectionShim* nifManSubConnection= reinterpret_cast<CNifManSubConnectionShim*>(aInstance);
	delete nifManSubConnection;
	return KErrNone;
	}

/**
Create a new CNifManSubConnectionShim to act as a mux/demux for subconnections
*/
CNifManSubConnectionShim::CNifManSubConnectionShim (CConnectionProviderShim& aProviderShim)
   :iSubConnectionsUniqueId(0), iConnectionProvider(&aProviderShim),
   iAsyncDestructor(CActive::EPriorityStandard + 1)
	{
	__CFLOG_VAR((KShimScprTag, KShimScprSubTag, _L8("CNifManSubConnectionShim [this=%08x]:\tCNifManSubConnectionShim() [MConnectionDataClient=%08x]"),
	   this, (MConnectionDataClient*)this));
	iAsyncDestructor.Set(TCallBack(AsyncDestructorCb, this));
	}

/**
D'tor
*/
CNifManSubConnectionShim::~CNifManSubConnectionShim()
	{
	__CFLOG_VAR((KShimScprTag, KShimScprSubTag, _L8("CNifManSubConnectionShim::~CNifManSubConnectionShim() %08x"), this));
	iShimClients.ResetAndDestroy();
	delete iConnDataTransferShim;
	}


void CNifManSubConnectionShim::DeleteAsync()
	{
	if ( !iAsyncDestructor.IsActive() )
		{
		iAsyncDestructor.CallBack();
		}
    }

TInt CNifManSubConnectionShim::FindClient(const CConnection& aConnection)
	{
	TInt max = iShimClients.Count();
	for (TInt i = max - 1 ; i >= 0 ; i--)
		{
		CSubConnectionLinkShimClient* client = iShimClients[i];
		if ( client->Match(aConnection) )
			{
			return i;
			}
		}
	return KErrNotFound;
	}
	
void CNifManSubConnectionShim::ConnectionJoiningL(const CConnection& aConnection)
	{//create a new CSubConnectionLinkShimClient for the joining conection
	TInt i = FindClient(aConnection);
	if ( i == KErrNotFound )
		{
		CSubConnectionLinkShimClient* client = new (ELeave)CSubConnectionLinkShimClient(aConnection,*this);
		CleanupStack::PushL(client);
		//create data transfer object if not created yet
		CreateDataTransferL();
		iConnDataTransferShim->RegisterClientL(*client);
		TInt ret = iShimClients.Append(client);
		if (ret != KErrNone)
			{
			iConnDataTransferShim->DeRegisterClient(*client);
			User::Leave(ret);
			}
		CleanupStack::Pop(client);
		}
	}
	
void CNifManSubConnectionShim::ConnectionLeaving(const CConnection& aConnection)
	{//destroy a CSubConnectionLinkShimClient belonging to leaving conection
	TInt i = FindClient(aConnection);
	if ( i >= 0 )
		{
		CSubConnectionLinkShimClient* client = iShimClients[i];
		iShimClients.Remove(i);
		delete client;
		}
	}

void CNifManSubConnectionShim::ConnectionGoingDown(CConnectionProviderBase& /*aConnProvider*/)
	{
	__CFLOG_VAR((KShimScprTag, KShimScprSubTag, _L8("CNifManSubConnectionShim %08x:\tConnectionGoingDown() Id %d"), 
						 this, iSubConnectionsUniqueId));
						 
   // The ConnectionProvider has told us its going down so we delete ourselves, clearing
   // the pointer to it so our d'tor doesn't make any calls on it.
	iConnectionProvider = NULL;
	delete this;
	}
	
void CNifManSubConnectionShim::ConnectionError(TInt /*aStage*/, TInt /*aError*/)
	{
	}
	
void CNifManSubConnectionShim::Notify(TNotify /*aNotifyType*/,  CConnectionProviderBase* /*aConnProvider*/, TInt /*aError*/, const CConNotificationEvent* /*aConNotificationEvent*/)
	{
	}

void CNifManSubConnectionShim::AttachToNext(CSubConnectionProviderBase* /*aSubConnProvider*/)
	{
	}

TInt CNifManSubConnectionShim::ProgressNotification(TInt aStage, TInt aError, const TDesC8& aInfo)
/**
Upcall from connection provider via CInterface with notification of new progress stage reached

@param aStage The progress stage that the subconnection has reached
@param aError Any errors that were encountered at this stage
@param aInfo No idea what this is, it's inserted by CInterface and is currently null
@return KErrNone, or one of the system-wide error codes
*/
	{
	__CFLOG_VAR((KShimScprTag, KShimScprSubTag, _L8("CNifManSubConnectionShim %08x:\tProgressNotification(%d, %d) SubConnId: %d"), 
				this, aStage, aError, iSubConnectionsUniqueId));

	TInt max = iShimClients.Count();
	for (TInt i = max - 1 ; i >= 0 ; i--)
		{
		iShimClients[i]->ProgressNotification(aStage, aError, aInfo);
		}

	return KErrNone;
	}

	
TInt CNifManSubConnectionShim::NotifyDataTransferred(TUint aUplinkVolume, TUint aDownlinkVolume)
	{
	return  iConnDataTransferShim ? iConnDataTransferShim->NotifyDataTransferred(aUplinkVolume, aDownlinkVolume) : KErrNone;

	}
	
TInt CNifManSubConnectionShim::NotifyDataSent(TUint aUplinkVolume, TUint /*aCurrentGranularity*/)
	{
	return  iConnDataTransferShim ? iConnDataTransferShim->NotifyDataSent(aUplinkVolume) : KErrNone;

	}
	
TInt CNifManSubConnectionShim::NotifyDataReceived(TUint aDownlinkVolume, TUint /*aCurrentGranularity*/)
	{
	return  iConnDataTransferShim ? iConnDataTransferShim->NotifyDataReceived(aDownlinkVolume) : KErrNone;

	}
	
TSubConnectionUniqueId CNifManSubConnectionShim::Id()
	/**
	Access this subconnections unique id for search purposes
	*/
	{
	return iSubConnectionsUniqueId;
	}
	
void CNifManSubConnectionShim::SetSubConnectionUniqueId( TSubConnectionUniqueId aSubConnectionUniqueId )
	{
	iSubConnectionsUniqueId = aSubConnectionUniqueId;
	}
	
//void CNifManSubConnectionShim::DataClientJoiningL(MSubConnectionDataClient& aDataClient)
//	{
//	aDataClient.JoinComplete(*this);
//	}

//void CNifManSubConnectionShim::DataClientLeaving(MSubConnectionDataClient& aDataClient)
//	{
//	aDataClient.LeaveComplete(*this);
//	}

//void CNifManSubConnectionShim::DoSourceAddressUpdate(MSubConnectionDataClient& /*aDataClient*/, const TSockAddr& /*aSource*/)
//	{//do nothing
//	}

//void CNifManSubConnectionShim::DoDestinationAddressUpdate(MSubConnectionDataClient& /*aDataClient*/, const TSockAddr& /*aDestination*/)
//	{//do nothing
//	}

//void CNifManSubConnectionShim::DoDataClientRouted(MSubConnectionDataClient& /*aDataClient*/, const TSockAddr& /*aSource*/, const TSockAddr& /*aDestination*/, const TDesC8& /*aConnectionInfo*/)
//	{//do nothing
//	}

//void CNifManSubConnectionShim::DoParametersAboutToBeSetL(CSubConParameterBundle& /*aParameterBundle*/)
//	{//do nothing
//	}

//TInt CNifManSubConnectionShim::DoControl(TUint /*aOptionLevel*/, TUint /*aOptionName*/, TDes8& /*aOption*/)
//	{//do nothing
//	return KErrNotSupported;	
//	}
	
//void CNifManSubConnectionShim::DoStartL()
//	{
//	User::Leave(KErrNotSupported);
//	}

//void CNifManSubConnectionShim::DoStop()
//	{
//	}

//CSubConnectionProviderBase* CNifManSubConnectionShim::DoNextLayer()
//	{
//	return NULL;
//	}

CConnDataTransfer& CNifManSubConnectionShim::CreateDataTransferL()
	{
	if (!iConnDataTransferShim)
		{
		iConnDataTransferShim = new (ELeave)CConnDataTransferShim(*this);
		}
	return *iConnDataTransferShim;
	}

//MConnectionDataClient* CNifManSubConnectionShim::DoSelfConnectionDataClient()
//	{
//	return this;
//	}