Yaniv Bronhaim has uploaded a new change for review.

Change subject: Adding query that get server's ssh pubic key
......................................................................

Adding query that get server's ssh pubic key

Change-Id: Ie508d6f9bdaa482f46a3cf1224b2fd84568299ba
Signed-off-by: Yaniv Bronhaim <[email protected]>
---
A 
backend/manager/modules/bll/src/main/java/org/ovirt/engine/core/bll/GetServerSSHPublicKeyQuery.java
M 
backend/manager/modules/common/src/main/java/org/ovirt/engine/core/common/queries/VdcQueryType.java
2 files changed, 45 insertions(+), 0 deletions(-)


  git pull ssh://gerrit.ovirt.org:29418/ovirt-engine refs/changes/19/16019/1

diff --git 
a/backend/manager/modules/bll/src/main/java/org/ovirt/engine/core/bll/GetServerSSHPublicKeyQuery.java
 
b/backend/manager/modules/bll/src/main/java/org/ovirt/engine/core/bll/GetServerSSHPublicKeyQuery.java
new file mode 100644
index 0000000..b1e7c4a
--- /dev/null
+++ 
b/backend/manager/modules/bll/src/main/java/org/ovirt/engine/core/bll/GetServerSSHPublicKeyQuery.java
@@ -0,0 +1,44 @@
+package org.ovirt.engine.core.bll;
+
+import org.apache.commons.lang.exception.ExceptionUtils;
+
+import org.ovirt.engine.core.common.queries.ServerParameters;
+import org.ovirt.engine.core.utils.ssh.EngineSSHDialog;
+
+/**
+ * Query to fetch fingerprint of the given server name
+ */
+public class GetServerSSHPublicKeyQuery<P extends ServerParameters> extends 
QueriesCommandBase<P> {
+
+    protected EngineSSHDialog getEngineSSHDialog() {
+        return new EngineSSHDialog();
+    }
+
+    public GetServerSSHPublicKeyQuery(P parameters) {
+        super(parameters);
+    }
+
+    public String getServerPublicKey(String serverName) {
+       PublicKey pk = null;
+        EngineSSHDialog dialog = getEngineSSHDialog();
+        try {
+            dialog.setHost(serverName);
+            dialog.connect();
+            dialog.useDefaultKeyPair();
+            PublicKey pk = dialog.getPublicKey
+        } catch (Throwable e) {
+            log.errorFormat("Could not ssh public key of host {0} with 
message: {1}",
+                serverName,
+                ExceptionUtils.getMessage(e)
+            );
+        } finally {
+            dialog.disconnect();
+        }
+        return pk.toString();
+    }
+
+    @Override
+    protected void executeQueryCommand() {
+        
getQueryReturnValue().setReturnValue(getServerPublicKey(getParameters().getServer()));
+    }
+}
diff --git 
a/backend/manager/modules/common/src/main/java/org/ovirt/engine/core/common/queries/VdcQueryType.java
 
b/backend/manager/modules/common/src/main/java/org/ovirt/engine/core/common/queries/VdcQueryType.java
index 51cff0a..6d47d3c 100644
--- 
a/backend/manager/modules/common/src/main/java/org/ovirt/engine/core/common/queries/VdcQueryType.java
+++ 
b/backend/manager/modules/common/src/main/java/org/ovirt/engine/core/common/queries/VdcQueryType.java
@@ -33,6 +33,7 @@
     GetHostListFromExternalProvider(),
     GetProviderCertificateChain(),
     GetHostsForStorageOperation,
+    GetServerSSHPublicKey,
 
     // Vds Networks
     GetVdsInterfacesByVdsId(VdcQueryAuthType.User),


-- 
To view, visit http://gerrit.ovirt.org/16019
To unsubscribe, visit http://gerrit.ovirt.org/settings

Gerrit-MessageType: newchange
Gerrit-Change-Id: Ie508d6f9bdaa482f46a3cf1224b2fd84568299ba
Gerrit-PatchSet: 1
Gerrit-Project: ovirt-engine
Gerrit-Branch: master
Gerrit-Owner: Yaniv Bronhaim <[email protected]>
_______________________________________________
Engine-patches mailing list
[email protected]
http://lists.ovirt.org/mailman/listinfo/engine-patches

Reply via email to