javacommons/gcfprotocols/socket/serverconnection/src/socketserverconnectionfactory.cpp
branchRCL_3
changeset 14 04becd199f91
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/javacommons/gcfprotocols/socket/serverconnection/src/socketserverconnectionfactory.cpp	Tue Apr 27 16:30:29 2010 +0300
@@ -0,0 +1,151 @@
+/*
+* Copyright (c) 2007-2007 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 "logger.h"
+#include "socketserverconnection.h"
+#include "socketserverconnectionfactory.h"
+#include "serverconnectionfactorybase.h"
+#include "socketserverconnection.h"
+
+
+#if defined(__SYMBIAN32__) && defined(__WINSCW__)
+#include <pls.h>
+#else
+static SocketServerConnectionFactory* sSocSrvConnFac = 0;
+#endif
+
+
+/*
+* returns a pointer of SocketServerConnectionFactory to the push controller
+* so that it can invoke this class when a incoming push event arrives
+* for this connection
+*/
+
+#ifdef __SYMBIAN32__
+ServerConnectionFactory& getServerConnectionFactory()
+{
+#else
+extern "C" ServerConnectionFactory& getServerConnectionFactory()
+{
+#endif
+    //CONTEXT_REMOVAL
+#if defined(__SYMBIAN32__) && defined(__WINSCW__)
+    TUid uid = TUid::Uid(0xE0000079);
+    SocketServerConnectionFactory* socSrvConnFac = Pls<SocketServerConnectionFactory>(uid);
+    return *socSrvConnFac;
+#else
+    if (sSocSrvConnFac == 0)
+    {
+        sSocSrvConnFac = new SocketServerConnectionFactory();
+    }
+    return *sSocSrvConnFac;
+#endif
+}
+
+OS_EXPORT SocketServerConnectionFactory& SocketServerConnectionFactory::getFactory()
+{
+    JELOG2(ESOCKET);
+    LOG(ESOCKET,EInfo,"+SocketServerConnectionFactory::getFactory() ");
+    ServerConnectionFactory& scf = ::getServerConnectionFactory();
+    return reinterpret_cast<SocketServerConnectionFactory&>(scf);
+}
+
+/**
+ * Construcot
+ */
+OS_EXPORT SocketServerConnectionFactory::SocketServerConnectionFactory()
+{
+    JELOG2(ESOCKET);
+}
+
+/**
+ * Destrucor
+ */
+OS_EXPORT SocketServerConnectionFactory::~SocketServerConnectionFactory()
+{
+    JELOG2(ESOCKET);
+}
+
+/**
+ * This operation creates protocol specific ServerConnection object
+ * @param aUri    ServerConnection URI.
+ * @param aFilter Connection URL indicating which senders are allowed to cause
+ * the MIDlet to be launched.
+ * Value of this argument is empty string in the normal server connection case.
+ */
+OS_EXPORT ServerConnection* SocketServerConnectionFactory::createSrvConnObj(const std::wstring& aUri, const std::wstring& aFilter)
+{
+    return new SocketServerConnection(aUri,aFilter);
+}
+
+/*
+* This method indicates whether multiple Connector.open() operation call is allowed
+* for a connection.
+*/
+OS_EXPORT bool SocketServerConnectionFactory::isMultipleSrvConnAllowed()
+{
+    return false;
+}
+
+/* overriding create() method, to handle special case of allowing more than 1 connection socket://: type of url
+ called from midlet */
+
+OS_EXPORT ServerConnection* SocketServerConnectionFactory::create(const std::wstring& aUri)
+{
+    JELOG2(ESOCKET);
+    LOG(ESOCKET,EInfo,"SocketServerConnectionFactory::create()");
+
+    // ScopedLock lockObj(mMutex);
+    if (aUri.length() == 10) // "socket://:" dynamic port url first time return push object
+    {
+        LOG(ESOCKET,EInfo,"SocketServerConnectionFactory::create() - dynamic url");
+        SrvConnContainerIter_t iter = mServerConnections.find(aUri);
+        if (iter == mServerConnections.end())
+        {
+            //      std::auto_ptr<ServerConnection> newSrvConn(createSrvConnObj(aUri,L""));
+            //      SrvConnContainerData newDataObj(newSrvConn.release(),0,false,SrvConnContainerData::NORMAL);
+            //      mServerConnections.insert(std::pair<std::wstring,SrvConnContainerData>(aUri,newDataObj));
+            //      SocketServerConnection * dsc = (SocketServerConnection*)newDataObj.getConn();
+            //      dsc->setPushEnabled();
+            //      return dsc;
+            LOG(ESOCKET,EInfo,"SocketServerConnectionFactory::create() - dynamic url, normal server connection");
+            SocketServerConnection * socketserver = new SocketServerConnection();
+            return reinterpret_cast<ServerConnection *>(socketserver);
+
+        }
+        else
+        {
+            if (SrvConnContainerData::PUSH == iter->second.connType())
+            {
+                LOG(ESOCKET,EInfo,"SocketServerConnectionFactory::create() - dynamic url, this url is already registered for push");
+                iter->second.setConnType(SrvConnContainerData::PUSH_LISTEN_BY_MIDLET);
+                return reinterpret_cast<ServerConnection *>(iter->second.getConn());
+            }
+            else
+            {
+                LOG(ESOCKET,EInfo,"SocketServerConnectionFactory::create() - dynamic url, not registered with push db, so return normal server connection");
+                SocketServerConnection * socketserver = new SocketServerConnection();
+                return reinterpret_cast<ServerConnection *>(socketserver);
+            }
+        }
+    }
+    else
+    {
+        return ServerConnectionFactoryBase::create(aUri);
+    }
+}