summaryrefslogtreecommitdiff
path: root/cpp/src/IceGrid/IceGridObserver.cpp
diff options
context:
space:
mode:
authorBenoit Foucher <benoit@zeroc.com>2005-06-09 14:33:56 +0000
committerBenoit Foucher <benoit@zeroc.com>2005-06-09 14:33:56 +0000
commitdd4155ec2f0c543061e3a08d0938c5f8aff227c7 (patch)
tree5feac0309fb01f2da479179ddc23d93a407ceae9 /cpp/src/IceGrid/IceGridObserver.cpp
parentadding support classes for CLDC support (diff)
downloadice-dd4155ec2f0c543061e3a08d0938c5f8aff227c7.tar.bz2
ice-dd4155ec2f0c543061e3a08d0938c5f8aff227c7.tar.xz
ice-dd4155ec2f0c543061e3a08d0938c5f8aff227c7.zip
Added support for sessions and node/registry observers
Diffstat (limited to 'cpp/src/IceGrid/IceGridObserver.cpp')
-rw-r--r--cpp/src/IceGrid/IceGridObserver.cpp245
1 files changed, 245 insertions, 0 deletions
diff --git a/cpp/src/IceGrid/IceGridObserver.cpp b/cpp/src/IceGrid/IceGridObserver.cpp
new file mode 100644
index 00000000000..f1895f3f81d
--- /dev/null
+++ b/cpp/src/IceGrid/IceGridObserver.cpp
@@ -0,0 +1,245 @@
+// **********************************************************************
+//
+// 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 <IceUtil/Options.h>
+#include <IceUtil/Thread.h>
+#include <Ice/Application.h>
+#include <Ice/SliceChecksums.h>
+#include <IceGrid/Observer.h>
+#include <IceGrid/Admin.h>
+#include <fstream>
+
+using namespace std;
+using namespace Ice;
+using namespace IceGrid;
+
+class SessionKeepAliveThread : public IceUtil::Thread, public IceUtil::Monitor<IceUtil::Mutex>
+{
+public:
+
+ SessionKeepAliveThread(const Ice::LoggerPtr& logger, const IceUtil::Time& timeout, const SessionPrx& session) :
+ _logger(logger),
+ _session(session),
+ _timeout(timeout),
+ _terminated(false)
+ {
+ }
+
+ virtual void
+ run()
+ {
+ Lock sync(*this);
+ while(!_terminated)
+ {
+ timedWait(_timeout);
+ if(!_terminated)
+ {
+ try
+ {
+ _session->keepAlive();
+ }
+ catch(const Ice::Exception& ex)
+ {
+ Ice::Warning warn(_logger);
+ warn << "SessionKeepAliveThread: " << ex;
+ _terminated = true;
+ }
+ }
+ }
+ }
+
+ void
+ terminate()
+ {
+ Lock sync(*this);
+ _terminated = true;
+ notify();
+ }
+
+private:
+
+ const Ice::LoggerPtr _logger;
+ const SessionPrx _session;
+ const IceUtil::Time _timeout;
+ bool _terminated;
+};
+typedef IceUtil::Handle<SessionKeepAliveThread> SessionKeepAliveThreadPtr;
+
+class RegistryObserverI : public RegistryObserver
+{
+public:
+
+ virtual void
+ nodeUp(const string& name, const Ice::Current& current)
+ {
+ cout << "node `" << name << "' is up" << endl;
+ }
+
+ virtual void
+ nodeDown(const string& name, const Ice::Current& current)
+ {
+ cout << "node `" << name << "' is down" << endl;
+ }
+};
+
+class NodeObserverI : public NodeObserver
+{
+public:
+
+ virtual void
+ init(const string& node, const ServerDynamicInfoSeq& servers, const AdapterDynamicInfoSeq& adapters,
+ const Ice::Current&)
+ {
+ cout << "node init" << endl;
+ }
+
+ virtual void
+ updateServer(const string& node, const ServerDynamicInfo& info, const Ice::Current&)
+ {
+ cout << "node `" << node << "' server `" << info.name << "' updated: pid = " << info.pid << " state = `";
+ switch(info.state)
+ {
+ case Inactive:
+ cout << "Inactive";
+ break;
+ case Activating:
+ cout << "Activation";
+ break;
+ case Active:
+ cout << "Active";
+ break;
+ case Deactivating:
+ cout << "Deactivation";
+ break;
+ case Destroying:
+ cout << "Destroying";
+ break;
+ case Destroyed:
+ cout << "Destroyed";
+ break;
+ }
+ cout << "'" << endl;
+ }
+
+ virtual void
+ updateAdapter(const string& node, const AdapterDynamicInfo& info, const Ice::Current& current)
+ {
+ cout << "node `" << node << "' adapter `" << info.id << "' updated: ";
+ cout << current.adapter->getCommunicator()->proxyToString(info.proxy);
+ cout << endl;
+ }
+};
+
+class Client : public Application
+{
+public:
+
+ void usage();
+ virtual int run(int, char*[]);
+};
+
+int
+main(int argc, char* argv[])
+{
+ Client app;
+ return app.main(argc, argv);
+}
+
+void
+Client::usage()
+{
+ cerr << "Usage: " << appName() << " [options] [file...]\n";
+ cerr <<
+ "Options:\n"
+ "-h, --help Show this message.\n"
+ "-v, --version Display the Ice version.\n"
+ ;
+}
+
+int
+Client::run(int argc, char* argv[])
+{
+ IceUtil::Options opts;
+ opts.addOpt("h", "help");
+ opts.addOpt("v", "version");
+
+ vector<string> args;
+ try
+ {
+ args = opts.parse(argc, argv);
+ }
+ catch(const IceUtil::Options::BadOpt& e)
+ {
+ cerr << e.reason << endl;
+ usage();
+ return EXIT_FAILURE;
+ }
+
+ if(opts.isSet("h") || opts.isSet("help"))
+ {
+ usage();
+ return EXIT_SUCCESS;
+ }
+ if(opts.isSet("v") || opts.isSet("version"))
+ {
+ cout << ICE_STRING_VERSION << endl;
+ return EXIT_SUCCESS;
+ }
+
+ SessionManagerPrx manager = SessionManagerPrx::checkedCast(communicator()->stringToProxy("IceGrid/SessionManager"));
+ if(!manager)
+ {
+ cerr << appName() << ": no valid session manager interface" << endl;
+ return EXIT_FAILURE;
+ }
+
+
+ AdminPrx admin = AdminPrx::checkedCast(communicator()->stringToProxy("IceGrid/Admin"));
+ if(!admin)
+ {
+ cerr << appName() << ": no valid administrative interface" << endl;
+ return EXIT_FAILURE;
+ }
+
+ Ice::SliceChecksumDict serverChecksums = admin->getSliceChecksums();
+ Ice::SliceChecksumDict localChecksums = Ice::sliceChecksums();
+ for(Ice::SliceChecksumDict::const_iterator q = localChecksums.begin(); q != localChecksums.end(); ++q)
+ {
+ Ice::SliceChecksumDict::const_iterator r = serverChecksums.find(q->first);
+ if(r == serverChecksums.end())
+ {
+ cerr << appName() << ": server is using unknown Slice type `" << q->first << "'" << endl;
+ }
+ else if(q->second != r->second)
+ {
+ cerr << appName() << ": server is using a different Slice definition of `" << q->first << "'" << endl;
+ }
+ }
+
+ SessionPrx session = manager->createLocalSession("IceGrid.Observer");
+
+ Ice::ObjectAdapterPtr adapter = communicator()->createObjectAdapter("IceGrid.Observer");
+ RegistryObserverPrx regObserver = RegistryObserverPrx::uncheckedCast(adapter->addWithUUID(new RegistryObserverI()));
+ NodeObserverPrx nodeObserver = NodeObserverPrx::uncheckedCast(adapter->addWithUUID(new NodeObserverI()));
+ adapter->activate();
+
+ SessionKeepAliveThreadPtr keepAlive;
+ keepAlive = new SessionKeepAliveThread(communicator()->getLogger(), IceUtil::Time::seconds(5), session);
+ keepAlive->start();
+
+ session->setObservers(regObserver, nodeObserver);
+
+ communicator()->waitForShutdown();
+
+ keepAlive->terminate();
+ keepAlive->getThreadControl().join();
+ keepAlive = 0;
+
+ return EXIT_SUCCESS;
+}