wapstack/wapmessageapi/client/wapmessage.cpp
branchRCL_3
changeset 63 f1e62dc8c3f9
parent 18 50bae5c5c85f
child 53 12b52b1a573e
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/wapstack/wapmessageapi/client/wapmessage.cpp	Mon Aug 23 13:09:49 2010 +0100
@@ -0,0 +1,508 @@
+// Copyright (c) 2001-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:
+//
+
+
+#include <wapmessage.h>
+#include <ecom/ecom.h>
+
+/** The WAP Messaging API.  Four interfaces are defined that provide bound and fully-specified versions of WDP and Connectionless Push.
+	An instantiation of each may be obtained using the CreateImplementationL() function, and must be released using Release() when no
+	longer required.  Release() causes the instantiation to be deleted.
+*/
+
+// Use SWS as default WAP stack
+//  If undefined th3em NWSS stack will be used as default
+#define WAPUSE_SWS // since 8.0
+
+#ifndef WAPUSE_SWS
+// Symbian OS 7.0
+_LIT8(KDefBoundWdpCue, "wdp/bound");
+_LIT8(KDefFullSpecWdpCue, "wdp/fullyspec");
+_LIT8(KDefBoundCLPushCue, "clpush/bound");
+_LIT8(KDefFullSpecCLPushCue, "clpush/fullyspec");
+
+_LIT8(KAltBoundWdpCue, "swswdp/bound");
+_LIT8(KAltFullSpecWdpCue, "swswdp/fullyspec");
+_LIT8(KAltBoundCLPushCue, "swsclpush/bound");
+_LIT8(KAltFullSpecCLPushCue, "swsclpush/fullyspec");
+
+#else
+// Symbian OS 8.0
+_LIT8(KAltBoundWdpCue, "wdp/bound");
+_LIT8(KAltFullSpecWdpCue, "wdp/fullyspec");
+_LIT8(KAltBoundCLPushCue, "clpush/bound");
+_LIT8(KAltFullSpecCLPushCue, "clpush/fullyspec");
+
+_LIT8(KDefBoundWdpCue, "swswdp/bound");
+_LIT8(KDefFullSpecWdpCue, "swswdp/fullyspec");
+_LIT8(KDefBoundCLPushCue, "swsclpush/bound");
+_LIT8(KDefFullSpecCLPushCue, "swsclpush/fullyspec");
+#endif
+
+_LIT8(KBoundCLWSPCue, "swsclwsp/bound");
+_LIT8(KFullSpecCLWSPCue, "swsclwsp/fullyspec");
+
+/** Bound WDP
+*/
+
+EXPORT_C 
+CWapBoundDatagramService* CWapBoundDatagramService::NewL()
+	/** Allocates and creates a new CWapBoundDatagramService object. 
+	* 
+	* @return	A new CWapBoundDatagramService object.
+	* @leave	System wide error codes
+	*/
+	{
+	// CWapBoundDatagramService ECOM Interface UID = 101F4471
+	const TUid KUidBoundWDPInterface = {0x101F4471};
+
+	// Set resolving parameters
+	TEComResolverParams resolverParams;
+	resolverParams.SetDataType(KDefBoundWdpCue);
+	resolverParams.SetWildcardMatch(ETrue);
+
+	// Get the instantiation
+	TInt trapValue(0); 
+	TAny* ptr = NULL;
+	TRAP(trapValue, ptr = REComSession::CreateImplementationL(KUidBoundWDPInterface,
+								 _FOFF(CWapBoundDatagramService, iDtor_ID_Key),
+								 resolverParams));
+	if(trapValue)
+	{
+		resolverParams.SetDataType(KAltBoundWdpCue);
+		// Trying to load old wapmessage plug-in
+		ptr = REComSession::CreateImplementationL(KUidBoundWDPInterface,
+								 _FOFF(CWapBoundDatagramService, iDtor_ID_Key),
+								 resolverParams);
+	}
+
+	return REINTERPRET_CAST(CWapBoundDatagramService*, ptr);
+	}
+
+EXPORT_C 
+CWapBoundDatagramService* CWapBoundDatagramService::NewL(const TUid& aImplementation)
+	/** Allocates and creates a new CWapBoundDatagramService object. 
+	* 
+	* @param aImplementation
+	* @return					A new CWapBoundDatagramService object.
+	* @leave					System wide error codes
+	*/
+	{
+		TAny* ptr = REComSession::CreateImplementationL(aImplementation,
+								 _FOFF(CWapBoundDatagramService, iDtor_ID_Key));
+
+	return	REINTERPRET_CAST(CWapBoundDatagramService*, ptr);
+	}
+
+EXPORT_C 
+CWapBoundDatagramService::~CWapBoundDatagramService()
+	/** Destructor */
+	{
+	REComSession::DestroyedImplementation(iDtor_ID_Key);
+	}
+
+EXPORT_C 
+CWapBoundDatagramService::CWapBoundDatagramService()
+	{
+	}
+
+EXPORT_C 
+void CWapBoundDatagramService::ConstructL()
+	{
+	}
+	
+/** Fully-specified WDP
+*/
+
+EXPORT_C 
+CWapFullySpecDatagramService* CWapFullySpecDatagramService::NewL()
+	/** Allocates and creates a new CWapFullySpecDatagramService object. 
+	* 
+	* @return	A new CWapFullySpecDatagramService object.
+	* @leave	System wide error codes.
+	*/
+	{
+	// MWapFullySpecDatagramService ECOM Interface UID = 101F4473
+	const TUid KUidFullySpecDatagramInterface = {0x101F4473};
+
+	// Set resolving parameters
+	TEComResolverParams resolverParams;
+	resolverParams.SetDataType(KDefFullSpecWdpCue);
+	resolverParams.SetWildcardMatch(ETrue);
+
+	// Get the instantiation
+	TInt trapValue(0); 
+	TAny* ptr = NULL;
+	TRAP(trapValue, ptr = REComSession::CreateImplementationL(KUidFullySpecDatagramInterface,
+								 _FOFF(CWapFullySpecDatagramService, iDtor_ID_Key),
+								 resolverParams));
+	if(trapValue)
+	{
+		// Trying to load old wapmessage plug-in
+		resolverParams.SetDataType(KAltFullSpecWdpCue);
+		ptr = REComSession::CreateImplementationL(KUidFullySpecDatagramInterface,
+								 _FOFF(CWapFullySpecDatagramService, iDtor_ID_Key),
+								 resolverParams);
+	}
+
+	return REINTERPRET_CAST(CWapFullySpecDatagramService*, ptr);
+	}
+
+EXPORT_C 
+CWapFullySpecDatagramService* CWapFullySpecDatagramService::NewL(const TUid& aImplementation)
+	/** Allocates and creates a new CWapFullySpecDatagramService object. 
+	* 
+	* @param aImplementation	
+	* @return					A new CWapFullySpecDatagramService object.
+	* @leave					System wide error codes.
+	*/
+	{
+		TAny* ptr = REComSession::CreateImplementationL(aImplementation,
+								 _FOFF(CWapFullySpecDatagramService, iDtor_ID_Key));
+
+	return	REINTERPRET_CAST(CWapFullySpecDatagramService*, ptr);
+	}
+
+EXPORT_C 
+CWapFullySpecDatagramService::~CWapFullySpecDatagramService()
+	/** Destructor */
+	{
+	REComSession::DestroyedImplementation(iDtor_ID_Key);
+	}
+
+EXPORT_C 
+CWapFullySpecDatagramService::CWapFullySpecDatagramService()
+	{
+	}
+
+EXPORT_C 
+void CWapFullySpecDatagramService::ConstructL()
+	{
+	}
+
+/** Bound Connection-less Push
+*/
+
+EXPORT_C 
+CWapBoundCLPushService* CWapBoundCLPushService::NewL()
+	/** Allocates and creates a new CWapBoundCLPushService object. 
+	*
+	* @return	A new <code>CWapBoundCLPushService</code> object.
+	* @leave	System wide error codes.
+	*/
+	{
+	// MWapBoundCLPushService ECOM Interface UID = 101F4475
+	const TUid KUidBoundCLPushInterface = {0x101F4475};
+
+	// Set resolving parameters
+	TEComResolverParams resolverParams;
+	resolverParams.SetDataType(KDefBoundCLPushCue);
+	resolverParams.SetWildcardMatch(ETrue);
+
+	// Get the instantiation
+	TInt trapValue(0); 
+	TAny* ptr = NULL;
+	TRAP(trapValue, ptr = REComSession::CreateImplementationL(KUidBoundCLPushInterface,
+								 _FOFF(CWapBoundCLPushService, iDtor_ID_Key),
+								 resolverParams));
+	if(trapValue)
+	{
+		// Trying to load old wapmessage plug-in
+		resolverParams.SetDataType(KAltBoundCLPushCue);
+		ptr = REComSession::CreateImplementationL(KUidBoundCLPushInterface,
+								 _FOFF(CWapBoundCLPushService, iDtor_ID_Key),
+								 resolverParams);
+	}
+	return REINTERPRET_CAST(CWapBoundCLPushService*, ptr);
+	}
+
+EXPORT_C 
+CWapBoundCLPushService* CWapBoundCLPushService::NewL(const TUid& aImplementation)
+	/** Allocates and creates a new CWapBoundCLPushService object. 
+	*
+	* @param aImplementation	
+	* @return					A new CWapBoundCLPushService object.
+	* @leave					System wide error codes.
+	*/
+	{
+		TAny* ptr = REComSession::CreateImplementationL(aImplementation,
+								 _FOFF(CWapBoundCLPushService, iDtor_ID_Key));
+
+	return	REINTERPRET_CAST(CWapBoundCLPushService*, ptr);
+	}
+
+EXPORT_C 
+CWapBoundCLPushService::~CWapBoundCLPushService()
+	/** Destructor */
+	{
+	REComSession::DestroyedImplementation(iDtor_ID_Key);
+	}
+
+EXPORT_C 
+CWapBoundCLPushService::CWapBoundCLPushService()
+	{
+	}
+
+EXPORT_C 
+void CWapBoundCLPushService::ConstructL()
+	{
+	}
+
+/** Fully-specified Connection-less Push
+*/
+
+EXPORT_C 
+CWapFullySpecCLPushService* CWapFullySpecCLPushService::NewL()
+	/** Allocates and creates a new CWapFullySpecCLPushService object. 
+	*
+	* @return	A new CWapFullySpecCLPushService object.
+	* @leave	System wide error codes.
+	*/
+	{
+	// MWapFullySpecCLPushService ECOM Interface UID = 101F4477
+	const TUid KUidFullySpecCLPushInterface = {0x101F4477};
+
+	// Set resolving parameters
+	TEComResolverParams resolverParams;
+	resolverParams.SetDataType(KDefFullSpecCLPushCue);
+	resolverParams.SetWildcardMatch(ETrue);
+
+	// Get the instantiation
+	TInt trapValue(0); 
+	TAny* ptr = NULL;
+	TRAP(trapValue, ptr = REComSession::CreateImplementationL(KUidFullySpecCLPushInterface,
+								 _FOFF(CWapFullySpecCLPushService, iDtor_ID_Key),
+								 resolverParams));
+	if(trapValue)
+	{
+		// Trying to load old wapmessage plug-in
+		resolverParams.SetDataType(KAltFullSpecCLPushCue);
+		ptr = REComSession::CreateImplementationL(KUidFullySpecCLPushInterface,
+								 _FOFF(CWapFullySpecCLPushService, iDtor_ID_Key),
+								 resolverParams);
+	}
+
+	return REINTERPRET_CAST(CWapFullySpecCLPushService*, ptr);
+	}
+
+EXPORT_C 
+CWapFullySpecCLPushService* CWapFullySpecCLPushService::NewL(const TUid& aImplementation)
+	/** Allocates and creates a new CWapFullySpecCLPushService object. 
+	*
+	* @param aImplementation
+	* @return					A new CWapFullySpecCLPushService object.
+	* @leave					System wide error codes.
+	*/
+	{
+		TAny* ptr = REComSession::CreateImplementationL(aImplementation,
+								 _FOFF(CWapFullySpecCLPushService, iDtor_ID_Key));
+
+	return	REINTERPRET_CAST(CWapFullySpecCLPushService*, ptr);
+	}
+
+EXPORT_C 
+CWapFullySpecCLPushService::~CWapFullySpecCLPushService()
+	/** Destructor */
+	{
+	REComSession::DestroyedImplementation(iDtor_ID_Key);
+	}
+
+EXPORT_C 
+CWapFullySpecCLPushService::CWapFullySpecCLPushService()
+	{
+	}
+
+EXPORT_C 
+void CWapFullySpecCLPushService::ConstructL()
+	{
+	}
+
+/** Bound WSP
+	New interface and implementation
+*/
+
+EXPORT_C 
+CWapBoundCLWSPService* CWapBoundCLWSPService::NewL()
+	/** Allocates and creates a new CWapBoundCLWSPService object. 
+	*
+	* @return					A new CWapBoundCLWSPService object.
+	* @leave					System wide error codes.
+	*/
+	{
+	// CWapBoundWSPService ECOM Interface UID = 101FBB3B
+	const TUid KUidBoundCLWSPInterface = {0x101FBB3B};
+
+	// Set resolving parameters
+	TEComResolverParams resolverParams;
+	resolverParams.SetDataType(KBoundCLWSPCue);
+	resolverParams.SetWildcardMatch(ETrue);
+
+	// Get the instantiation
+	TAny* ptr = REComSession::CreateImplementationL(KUidBoundCLWSPInterface,
+								 _FOFF(CWapBoundCLWSPService, iDtor_ID_Key),
+								 resolverParams);
+
+	return REINTERPRET_CAST(CWapBoundCLWSPService*, ptr);
+	}
+
+EXPORT_C 
+CWapBoundCLWSPService* CWapBoundCLWSPService::NewL(const TUid& aImplementation)
+	/** Allocates and creates a new CWapBoundCLWSPService object. 
+	*
+	* @param aImplementation
+	* @return					A new CWapBoundCLWSPService object.
+	* @leave					System wide error codes.
+	*/
+	{
+		TAny* ptr = REComSession::CreateImplementationL(aImplementation,
+								 _FOFF(CWapBoundCLWSPService, iDtor_ID_Key));
+
+	return	REINTERPRET_CAST(CWapBoundCLWSPService*, ptr);
+	}
+
+EXPORT_C 
+CWapBoundCLWSPService::~CWapBoundCLWSPService()
+	/** Destructor */
+	{
+	REComSession::DestroyedImplementation(iDtor_ID_Key);
+	}
+
+EXPORT_C 
+CWapBoundCLWSPService::CWapBoundCLWSPService()
+	{
+	}
+
+EXPORT_C 
+void CWapBoundCLWSPService::ConstructL()
+	{
+	}
+
+/** Fully-specified Connection-less WSP
+	New interface and implementation
+*/
+
+EXPORT_C 
+CWapFullySpecCLWSPService* CWapFullySpecCLWSPService::NewL()
+	/** Allocates and creates a new CWapFullySpecCLWSPService object. 
+	*
+	* @return					A new CWapFullySpecCLWSPService object.
+	* @leave					System wide error codes.
+	*/
+	{
+	// CWapFullySpecCLWSPService ECOM Interface UID = 101FBB3D
+	const TUid KUidFullySpecCLWSPInterface = {0x101FBB3D};
+
+	// Set resolving parameters
+	TEComResolverParams resolverParams;
+	resolverParams.SetDataType(KFullSpecCLWSPCue);
+	resolverParams.SetWildcardMatch(ETrue);
+
+	// Get the instantiation
+	TAny* ptr = REComSession::CreateImplementationL(KUidFullySpecCLWSPInterface,
+								 _FOFF(CWapFullySpecCLWSPService, iDtor_ID_Key),
+								 resolverParams);
+
+	return REINTERPRET_CAST(CWapFullySpecCLWSPService*, ptr);
+	}
+
+EXPORT_C 
+CWapFullySpecCLWSPService* CWapFullySpecCLWSPService::NewL(const TUid& aImplementation)
+	/** Allocates and creates a new CWapFullySpecCLWSPService object. 
+	*
+	* @param aImplementation
+	* @return					A new CWapFullySpecCLWSPService object.
+	* @leave					System wide error codes.
+	*/
+	{
+		TAny* ptr = REComSession::CreateImplementationL(aImplementation,
+								 _FOFF(CWapFullySpecCLWSPService, iDtor_ID_Key));
+
+	return	REINTERPRET_CAST(CWapFullySpecCLWSPService*, ptr);
+	}
+
+EXPORT_C 
+CWapFullySpecCLWSPService::~CWapFullySpecCLWSPService()
+	/** Destructor */
+	{
+	REComSession::DestroyedImplementation(iDtor_ID_Key);
+	}
+
+EXPORT_C 
+CWapFullySpecCLWSPService::CWapFullySpecCLWSPService()
+	{
+	}
+
+EXPORT_C 
+void CWapFullySpecCLWSPService::ConstructL()
+	{
+	}
+
+   
+EXPORT_C TInt CWapMessageUtils::GetLocalAddressesL(RArray<Wap::TAddressInfo>& aAddressInfo)
+	/** Gets a list of all the available network interface addresses.
+	*
+	* @param aAddressInfo	On return, an array of the available network interface addresses.
+	* @return				KErrNone if successful, KErrNotFound if there are no addresses available. */
+	{
+	Wap::TAddressInfo addrInfo;
+
+	// Check if the esock ini file has been parsed
+//	User::LeaveIfError(Nifman::CheckIniConfig());
+
+	// The list of interfaces is available from a RSocket.GetOpt
+	TAutoClose<RSocketServ> sockServer;
+	User::LeaveIfError(sockServer.iObj.Connect());
+	sockServer.PushL();
+
+	TAutoClose<RSocket> sock;
+	User::LeaveIfError(sock.iObj.Open(sockServer.iObj, _L("udp")));
+	sock.PushL();
+
+	User::LeaveIfError(sock.iObj.SetOpt(KSoInetEnumInterfaces, KSolInetIfCtrl));
+
+	TPckgBuf<TSoInetInterfaceInfo> info, next;
+
+	TInt res=sock.iObj.GetOpt(KSoInetNextInterface, KSolInetIfCtrl, info);
+	if(res!=KErrNone)
+		User::Leave(res);
+
+	TInt validAddr = KErrNotFound;
+
+	while(res==KErrNone)
+		{
+		res=sock.iObj.GetOpt(KSoInetNextInterface, KSolInetIfCtrl, next);
+
+		// Only consider the address is its up, and is point to point.
+		// (TODO-would it be right to include pending state addresses too????)
+		if ( (info().iState == EIfUp) &&
+			 (info().iFeatures & KIfIsPointToPoint) )
+			{
+			// Just want the interface name
+			// = info().iName;
+			// and the address
+			// = info().iAddress;
+			validAddr = KErrNone;	   
+			
+			addrInfo.iAddress = info().iAddress;
+			addrInfo.iName = info().iName;
+			aAddressInfo.Append(addrInfo);
+			}
+		}
+
+	sock.Pop();
+	sockServer.Pop();
+
+	return validAddr;
+	}