summaryrefslogtreecommitdiff
path: root/cpp/src/IceGrid/NodeAdminRouter.cpp
diff options
context:
space:
mode:
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;
+}
+