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