summaryrefslogtreecommitdiff
path: root/cpp/src/IceGrid/NodeAdminRouter.cpp
diff options
context:
space:
mode:
authorBernard Normier <bernard@zeroc.com>2014-09-10 19:09:53 +0000
committerBernard Normier <bernard@zeroc.com>2014-09-10 19:09:53 +0000
commitac587d9f1a6d34e46956fd17c81f99beb7ed97ad (patch)
treefa09b2b2d5b6037c76976ee293eb0d15b7a93717 /cpp/src/IceGrid/NodeAdminRouter.cpp
parentFix networkProxy test dependencies (diff)
downloadice-ac587d9f1a6d34e46956fd17c81f99beb7ed97ad.tar.bz2
ice-ac587d9f1a6d34e46956fd17c81f99beb7ed97ad.tar.xz
ice-ac587d9f1a6d34e46956fd17c81f99beb7ed97ad.zip
IceGrid::Admin now provides remote access to IceGrid registry and node Admin objects, and icegridadmin uses these
new operations to show the Ice log file for IceGrid registries and IceGrid nodes (ICE-2400)
Diffstat (limited to 'cpp/src/IceGrid/NodeAdminRouter.cpp')
-rw-r--r--cpp/src/IceGrid/NodeAdminRouter.cpp61
1 files changed, 61 insertions, 0 deletions
diff --git a/cpp/src/IceGrid/NodeAdminRouter.cpp b/cpp/src/IceGrid/NodeAdminRouter.cpp
new file mode 100644
index 00000000000..6c4631b1e93
--- /dev/null
+++ b/cpp/src/IceGrid/NodeAdminRouter.cpp
@@ -0,0 +1,61 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2014 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/NodeAdminRouter.h>
+#include <Ice/Ice.h>
+#include <IceGrid/ServerI.h>
+#include <IceGrid/ServerAdapterI.h>
+
+using namespace IceGrid;
+using namespace Ice;
+using namespace std;
+
+
+IceGrid::NodeServerAdminRouter::NodeServerAdminRouter(const NodeIPtr& node) :
+ _node(node)
+{
+}
+
+ObjectPrx
+IceGrid::NodeServerAdminRouter::getTarget(const Current& current)
+{
+ //
+ // First, get the ServerI servant
+ //
+ Identity serverId = _node->createServerIdentity(current.id.name);
+ ServerIPtr server = ServerIPtr::dynamicCast(_node->getAdapter()->find(serverId));
+ if(server == 0)
+ {
+ throw ObjectNotExistException(__FILE__, __LINE__);
+ }
+
+ //
+ // Then get a proxy to the Process facet of the real admin object
+ //
+ ObjectPrx target = server->getProcess();
+
+ if(target == 0)
+ {
+ throw ObjectNotExistException(__FILE__, __LINE__);
+ }
+
+ //
+ // If this is a legacy Process proxy with no facet, we keep target as is
+ //
+ if(current.facet != "Process")
+ {
+ //
+ // Set the facet
+ //
+ target = target->ice_facet(current.facet);
+ }
+
+ return target;
+}
+