diff src/com/trilead/ssh2/packets/PacketUserauthRequestPublicKey.java @ 0:0ce5cc452d02

initial version
author Carl Byington <carl@five-ten-sg.com>
date Thu, 22 May 2014 10:41:19 -0700
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/com/trilead/ssh2/packets/PacketUserauthRequestPublicKey.java	Thu May 22 10:41:19 2014 -0700
@@ -0,0 +1,59 @@
+package com.trilead.ssh2.packets;
+
+import java.io.IOException;
+
+/**
+ * PacketUserauthRequestPublicKey.
+ *
+ * @author Christian Plattner, plattner@trilead.com
+ * @version $Id: PacketUserauthRequestPublicKey.java,v 1.1 2007/10/15 12:49:55 cplattne Exp $
+ */
+public class PacketUserauthRequestPublicKey {
+    byte[] payload;
+
+    String userName;
+    String serviceName;
+    String password;
+    String pkAlgoName;
+    byte[] pk;
+    byte[] sig;
+
+    public PacketUserauthRequestPublicKey(String serviceName, String user,
+                                          String pkAlgorithmName, byte[] pk, byte[] sig) {
+        this.serviceName = serviceName;
+        this.userName = user;
+        this.pkAlgoName = pkAlgorithmName;
+        this.pk = pk;
+        this.sig = sig;
+    }
+
+    public PacketUserauthRequestPublicKey(byte payload[], int off, int len) throws IOException {
+        this.payload = new byte[len];
+        System.arraycopy(payload, off, this.payload, 0, len);
+        TypesReader tr = new TypesReader(payload, off, len);
+        int packet_type = tr.readByte();
+
+        if (packet_type != Packets.SSH_MSG_USERAUTH_REQUEST)
+            throw new IOException("This is not a SSH_MSG_USERAUTH_REQUEST! ("
+                                  + packet_type + ")");
+
+        throw new IOException("Not implemented!");
+    }
+
+    public byte[] getPayload() {
+        if (payload == null) {
+            TypesWriter tw = new TypesWriter();
+            tw.writeByte(Packets.SSH_MSG_USERAUTH_REQUEST);
+            tw.writeString(userName);
+            tw.writeString(serviceName);
+            tw.writeString("publickey");
+            tw.writeBoolean(true);
+            tw.writeString(pkAlgoName);
+            tw.writeString(pk, 0, pk.length);
+            tw.writeString(sig, 0, sig.length);
+            payload = tw.getBytes();
+        }
+
+        return payload;
+    }
+}