summaryrefslogtreecommitdiff
path: root/cpp/src/IceGrid/ServerRegistryI.cpp
diff options
context:
space:
mode:
authorBenoit Foucher <benoit@zeroc.com>2005-04-01 15:42:10 +0000
committerBenoit Foucher <benoit@zeroc.com>2005-04-01 15:42:10 +0000
commitf496752b90c2d5c9099b7dbca383bd30820a6ebd (patch)
treedaba3e307aea127eccb2b1c50fe9353f18f1ca05 /cpp/src/IceGrid/ServerRegistryI.cpp
parentObjectNotExistException is now retried. (diff)
downloadice-f496752b90c2d5c9099b7dbca383bd30820a6ebd.tar.bz2
ice-f496752b90c2d5c9099b7dbca383bd30820a6ebd.tar.xz
ice-f496752b90c2d5c9099b7dbca383bd30820a6ebd.zip
Copied IcePack code to IceGrid.
Diffstat (limited to 'cpp/src/IceGrid/ServerRegistryI.cpp')
-rw-r--r--cpp/src/IceGrid/ServerRegistryI.cpp182
1 files changed, 182 insertions, 0 deletions
diff --git a/cpp/src/IceGrid/ServerRegistryI.cpp b/cpp/src/IceGrid/ServerRegistryI.cpp
new file mode 100644
index 00000000000..fdb87302485
--- /dev/null
+++ b/cpp/src/IceGrid/ServerRegistryI.cpp
@@ -0,0 +1,182 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2005 ZeroC, Inc. All rights reserved.
+//
+// This copy of Ice is licensed to you under the terms described in the
+// ICE_LICENSE file included in this distribution.
+//
+// **********************************************************************
+
+#include <IceGrid/ServerRegistryI.h>
+#include <IceGrid/TraceLevels.h>
+#include <Freeze/Initialize.h>
+
+using namespace std;
+using namespace IceGrid;
+
+const string ServerRegistryI::_dbName = "serverregistry";
+const string ServerRegistryI::_dbDescriptorName = "serverdescriptors";
+
+ServerRegistryI::ServerRegistryI(const Ice::CommunicatorPtr& communicator, const string& envName,
+ const TraceLevelsPtr& traceLevels) :
+ _connectionCache(Freeze::createConnection(communicator, envName)),
+ _dictCache(_connectionCache, _dbName),
+ _dictDescriptorCache(_connectionCache, _dbDescriptorName),
+ _traceLevels(traceLevels),
+ _envName(envName),
+ _communicator(communicator)
+{
+}
+
+void
+ServerRegistryI::add(const string& name,
+ const ServerPrx& server,
+ const ServerDescriptorPtr& descriptor,
+ const Ice::Current& current)
+{
+ while(true)
+ {
+ ServerPrx oldServer;
+ try
+ {
+ oldServer = findByName(name, current);
+ oldServer->ice_ping();
+ throw ServerExistsException();
+ }
+ catch(const ServerNotExistException&)
+ {
+ }
+ catch(const Ice::ObjectNotExistException&)
+ {
+ }
+ catch(const Ice::LocalException&)
+ {
+ throw ServerExistsException();
+ }
+
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringObjectProxyDict dict(connection, _dbName);
+ StringServerDescriptorDict dictDescriptor(connection, _dbDescriptorName);
+
+ StringObjectProxyDict::iterator p = dict.find(name);
+ if(p != dict.end())
+ {
+ if(oldServer && oldServer != p->second)
+ {
+ continue;
+ }
+ }
+
+ dict.put(pair<const string, const Ice::ObjectPrx>(name, server));
+ dictDescriptor.put(pair<const string, const ServerDescriptorPtr>(name, descriptor));
+
+ if(_traceLevels->serverRegistry > 0)
+ {
+ Ice::Trace out(_traceLevels->logger, _traceLevels->serverRegistryCat);
+ out << "added server `" << name << "'";
+ }
+
+ break;
+ }
+}
+
+ServerPrx
+ServerRegistryI::remove(const string& name, const Ice::Current&)
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringObjectProxyDict dict(connection, _dbName);
+ StringServerDescriptorDict dictDescriptor(connection, _dbDescriptorName);
+
+ StringObjectProxyDict::iterator p = dict.find(name);
+ if(p == dict.end())
+ {
+ throw ServerNotExistException();
+ }
+
+ ServerPrx server = ServerPrx::uncheckedCast(p->second);
+ dict.erase(p);
+ dictDescriptor.erase(name);
+
+ if(_traceLevels->serverRegistry > 0)
+ {
+ Ice::Trace out(_traceLevels->logger, _traceLevels->serverRegistryCat);
+ out << "removed server `" << name << "'";
+ }
+
+ return server;
+}
+
+ServerPrx
+ServerRegistryI::findByName(const string& name, const Ice::Current&)
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringObjectProxyDict dict(connection, _dbName);
+
+ StringObjectProxyDict::iterator p = dict.find(name);
+ if(p != dict.end())
+ {
+ try
+ {
+ return ServerPrx::checkedCast(p->second);
+ }
+ catch(const Ice::ObjectNotExistException&)
+ {
+ dict.erase(p);
+ }
+ catch(const Ice::LocalException&)
+ {
+ return ServerPrx::uncheckedCast(p->second);
+ }
+ }
+ throw ServerNotExistException();
+}
+
+ServerDescriptorPtr
+ServerRegistryI::getDescriptor(const string& name, const Ice::Current&)
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringServerDescriptorDict dictDescriptor(connection, _dbDescriptorName);
+
+ StringServerDescriptorDict::iterator p = dictDescriptor.find(name);
+ if(p == dictDescriptor.end())
+ {
+ throw ServerNotExistException();
+ }
+ return p->second;
+}
+
+Ice::StringSeq
+ServerRegistryI::getAll(const Ice::Current&) const
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringObjectProxyDict dict(connection, _dbName);
+
+ Ice::StringSeq names;
+ names.reserve(dict.size());
+
+ for(StringObjectProxyDict::iterator p = dict.begin(); p != dict.end(); ++p)
+ {
+ names.push_back(p->first);
+ }
+
+ return names;
+}
+
+ServerDescriptorSeq
+ServerRegistryI::getAllDescriptorsOnNode(const string& node, const Ice::Current&) const
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringServerDescriptorDict dict(connection, _dbDescriptorName);
+
+ ServerDescriptorSeq descriptors;
+
+ for(StringServerDescriptorDict::iterator p = dict.begin(); p != dict.end(); ++p)
+ {
+ if(p->second->node == node)
+ {
+ descriptors.push_back(p->second);
+ }
+ }
+
+ return descriptors;
+}