summaryrefslogtreecommitdiff
path: root/cpp/src/IcePack/ApplicationRegistryI.cpp
diff options
context:
space:
mode:
authorBenoit Foucher <benoit@zeroc.com>2004-06-02 21:17:40 +0000
committerBenoit Foucher <benoit@zeroc.com>2004-06-02 21:17:40 +0000
commitc209ff436f4268b8db689a2dd17615456eea78ce (patch)
tree5feb8607988706851bfdfdd5ba2d3924ba5b8f6c /cpp/src/IcePack/ApplicationRegistryI.cpp
parentFixed to AMD code generation. (diff)
downloadice-c209ff436f4268b8db689a2dd17615456eea78ce.tar.bz2
ice-c209ff436f4268b8db689a2dd17615456eea78ce.tar.xz
ice-c209ff436f4268b8db689a2dd17615456eea78ce.zip
Merged icepack_refactoring2_branch, many IcePack changes.
Diffstat (limited to 'cpp/src/IcePack/ApplicationRegistryI.cpp')
-rw-r--r--cpp/src/IcePack/ApplicationRegistryI.cpp157
1 files changed, 157 insertions, 0 deletions
diff --git a/cpp/src/IcePack/ApplicationRegistryI.cpp b/cpp/src/IcePack/ApplicationRegistryI.cpp
new file mode 100644
index 00000000000..3a7fa001038
--- /dev/null
+++ b/cpp/src/IcePack/ApplicationRegistryI.cpp
@@ -0,0 +1,157 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2004 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 <IcePack/ApplicationRegistryI.h>
+#include <IcePack/TraceLevels.h>
+#include <Freeze/Initialize.h>
+
+using namespace std;
+using namespace IcePack;
+
+IcePack::ApplicationRegistryI::ApplicationRegistryI(const Ice::CommunicatorPtr& communicator,
+ const ServerRegistryPtr& serverRegistry,
+ const string& envName,
+ const string& dbName,
+ const TraceLevelsPtr& traceLevels) :
+ _serverRegistry(serverRegistry),
+ _connectionCache(Freeze::createConnection(communicator, envName)),
+ _dictCache(_connectionCache, dbName),
+ _traceLevels(traceLevels),
+ _envName(envName),
+ _communicator(communicator),
+ _dbName(dbName)
+{
+}
+
+void
+IcePack::ApplicationRegistryI::add(const string& name, const Ice::Current&)
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringStringSeqDict dict(connection, _dbName);
+
+ StringStringSeqDict::iterator p = dict.find(name);
+ if(p != dict.end())
+ {
+ throw ApplicationExistsException();
+ }
+
+ dict.put(pair<const string, const Ice::StringSeq>(name, Ice::StringSeq()));
+
+ if(_traceLevels->applicationRegistry > 0)
+ {
+ Ice::Trace out(_traceLevels->logger, _traceLevels->applicationRegistryCat);
+ out << "added application `" << name << "'";
+ }
+}
+
+void
+IcePack::ApplicationRegistryI::remove(const string& name, const Ice::Current&)
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringStringSeqDict dict(connection, _dbName);
+
+ StringStringSeqDict::iterator p = dict.find(name);
+ if(p == dict.end())
+ {
+ throw ApplicationNotExistException();
+ }
+
+ dict.erase(p);
+
+ if(_traceLevels->applicationRegistry > 0)
+ {
+ Ice::Trace out(_traceLevels->logger, _traceLevels->applicationRegistryCat);
+ out << "removed application `" << name << "'";
+ }
+}
+
+void
+ApplicationRegistryI::registerServer(const string& application, const string& name, const Ice::Current&)
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringStringSeqDict dict(connection, _dbName);
+
+ StringStringSeqDict::iterator p = dict.find(application);
+ if(p == dict.end())
+ {
+ throw ApplicationNotExistException();
+ }
+
+ Ice::StringSeq servers = p->second;
+ servers.push_back(name);
+ p.set(servers);
+}
+
+void
+ApplicationRegistryI::unregisterServer(const string& application, const string& name, const Ice::Current&)
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringStringSeqDict dict(connection, _dbName);
+
+ StringStringSeqDict::iterator p = dict.find(application);
+ if(p == dict.end())
+ {
+ throw ApplicationNotExistException();
+ }
+
+ Ice::StringSeq servers = p->second;
+ for(Ice::StringSeq::iterator q = servers.begin(); q != servers.end(); ++q)
+ {
+ if(*q == name)
+ {
+ servers.erase(q);
+ break;
+ }
+ }
+ p.set(servers);
+}
+
+ApplicationDescriptorPtr
+ApplicationRegistryI::getDescriptor(const string& name, const Ice::Current&)
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringStringSeqDict dict(connection, _dbName);
+
+ StringStringSeqDict::iterator p = dict.find(name);
+ if(p == dict.end())
+ {
+ throw ApplicationNotExistException();
+ }
+
+ ApplicationDescriptorPtr descriptor = new ApplicationDescriptor();
+ descriptor->name = name;
+ for(Ice::StringSeq::const_iterator q = p->second.begin(); q != p->second.end(); ++q)
+ {
+ try
+ {
+ descriptor->servers.push_back(_serverRegistry->getDescriptor(*q));
+ }
+ catch(ServerNotExistException&)
+ {
+ }
+ }
+ return descriptor;
+}
+
+Ice::StringSeq
+IcePack::ApplicationRegistryI::getAll(const Ice::Current&) const
+{
+ Freeze::ConnectionPtr connection = Freeze::createConnection(_communicator, _envName);
+ StringStringSeqDict dict(connection, _dbName);
+
+ Ice::StringSeq names;
+ names.reserve(dict.size());
+
+ for(StringStringSeqDict::const_iterator p = dict.begin(); p != dict.end(); ++p)
+ {
+ names.push_back(p->first);
+ }
+
+ return names;
+}