linklayercontrol/networkinterfacemgr/netcfgext/inc/nifconfigurationcontrol.h
changeset 0 af10295192d8
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/linklayercontrol/networkinterfacemgr/netcfgext/inc/nifconfigurationcontrol.h	Tue Jan 26 15:23:49 2010 +0200
@@ -0,0 +1,157 @@
+/**
+* Copyright (c) 2003-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:
+* Declares network layer configuration classes supported by NIFMAN 
+* 
+*
+*/
+
+
+
+/**
+ @file NIFConfigurationControl.h
+ @internalComponent
+*/
+
+#if !defined (__NIFCONFIGURATIONCONTROL_H__)
+#define __NIFCONFIGURATIONCONTROL_H__
+
+#include <e32base.h>
+#include <ecom/ecom.h>
+#include <comms-infras/nifprvar.h>
+
+#include <comms-infras/rconfigdaemonmess.h>
+#include <comms-infras/ss_api_ext.h>
+
+class MNifIfNotify;
+/**
+An abstract base for NIFMAN configuration controls covering the concrete implementation as to
+how to configure network layer
+@internalComponent
+@version 0.03
+@date	26/05/2004
+**/
+class CNifConfigurationControl : public CActive
+	{
+protected:
+	CNifConfigurationControl(MNifIfNotify& aNifIfNotify);
+		
+public:
+	IMPORT_C static CNifConfigurationControl* NewL(MNifIfNotify& aNifIfNotify);
+		
+	/**
+	ConfigureNetworkL - called when NIFMAN wants to start network configuration process
+	@internalComponent
+	@version 0.01
+	**/
+	virtual void ConfigureNetworkL() = 0;
+		
+	/**
+	LinkLayerDown - used to inform the daemon that link layer renegotiation has started.
+	@internalComponent
+	@version 0.01
+	**/
+	virtual void LinkLayerDown() = 0;
+	
+	/**
+	LinkLayerUp - used to inform the daemon that link layer renegotiation has completed.
+	@internalComponent
+	@version 0.01
+	**/
+	virtual void LinkLayerUp() = 0;
+	
+	/**
+	Deregister - called when NIFMAN needs to deregister/unconfigure the network
+	@internalComponent
+	**/
+	virtual void Deregister(TInt aCause) = 0;
+   		
+	virtual void SendIoctlMessageL(const ESock::RLegacyResponseMsg& aMessage) = 0;
+
+   	virtual void CancelControl() = 0;
+   	
+   	virtual void AsyncDelete() = 0;
+
+	/**
+	Notification - used to inform the daemon of notification events.
+	@internalComponent
+	@version 0.01
+	**/
+	virtual void EventNotification(TNetworkAdaptorEventType aEventType, TUint aEvent, const TDesC8& aEventData, TAny* aSource) = 0;
+
+protected:
+	/**
+    iNifIfNotify - to access comm database and notify NIFMAN.
+    Note that this is a pointer to allow it to be zeroed when detaching from
+    NIFMAN (during asynchronous destruction) to avoid a dangling pointer.
+    @internalComponent
+    @version 0.01
+	**/
+	MNifIfNotify* iNifIfNotify;
+	};
+
+inline CNifConfigurationControl::CNifConfigurationControl(MNifIfNotify& aNifIfNotify) :
+CActive(EPriorityStandard),
+iNifIfNotify(&aNifIfNotify)
+/**
+CNifConfigurationControl - constructor
+@param aNifIfNotify - client of the control
+@internalComponent
+@version 0.01
+**/
+	{
+	}
+
+/**
+ NIF configuration interface to be able create plug-ins using ECOM
+ @internalComponent
+ @version 0.01
+ @date	12/08/2003
+**/
+class CNifConfigurationIf : public CNifConfigurationControl
+	{
+  	friend class CNifConfigurationControl; //to access iDtor_ID_Key from ::NewL
+
+public:
+   	CNifConfigurationIf(MNifIfNotify& aNifIfNotify);
+   	
+protected:
+	virtual ~CNifConfigurationIf();
+
+private:
+   	// Instance identifier key
+   	TUid iDtor_ID_Key;
+	};
+
+inline CNifConfigurationIf::CNifConfigurationIf(MNifIfNotify& aNifIfNotify) :
+   CNifConfigurationControl(aNifIfNotify)
+/**
+ CNifConfigurationIf - constructor
+ @param aNifIfNotify - client of the control
+ @internalComponent
+ @version 0.01
+**/
+	{
+	}
+
+//keep the destructor inline even though it's virtual so that 
+//the plug-in doesn't have to link against us
+inline CNifConfigurationIf::~CNifConfigurationIf()
+    {
+    REComSession::DestroyedImplementation(iDtor_ID_Key);
+    }
+
+#endif
+
+