# HG changeset patch
# User Shinji KONO <kono@ie.u-ryukyu.ac.jp>
# Date 1402611172 -32400
# Node ID 703db66138b5f54ec5e2a6ae702fde55488a06aa
# Parent  5be1d92e783505dba7c8e97ee7d2ffc13b398274
WhereToConnect

diff -r 5be1d92e7835 -r 703db66138b5 src/main/java/jp/ac/u_ryukyu/treevnc/MyRfbProto.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/MyRfbProto.java	Fri Jun 13 01:19:08 2014 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/MyRfbProto.java	Fri Jun 13 07:12:52 2014 +0900
@@ -12,12 +12,9 @@
 import java.util.zip.DataFormatException;
 import java.util.zip.Deflater;
 import java.util.zip.Inflater;
-
-import sun.rmi.runtime.Log;
 import jp.ac.u_ryukyu.treevnc.client.TreeVncProtocol;
 import jp.ac.u_ryukyu.treevnc.server.RequestScreenThread;
 import jp.ac.u_ryukyu.treevnc.server.VncProxyService;
-
 import com.glavsoft.exceptions.TransportException;
 import com.glavsoft.rfb.client.ClientToServerMessage;
 import com.glavsoft.rfb.encoding.EncodingType;
@@ -105,7 +102,7 @@
             }
         } catch (Exception e) {
             try {
-                System.out.println("new client faild");
+                System.out.println("new client faild :" + e.getMessage());
                 newCli.close();
                 return;
             } catch (IOException e1) {
diff -r 5be1d92e7835 -r 703db66138b5 src/main/java/jp/ac/u_ryukyu/treevnc/TreeVncCommand.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/TreeVncCommand.java	Fri Jun 13 01:19:08 2014 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/TreeVncCommand.java	Fri Jun 13 07:12:52 2014 +0900
@@ -26,12 +26,18 @@
 
     /**
      * handle TreeVNC Command
-     * @param b   12byte header ( command 4byte, length 4byte, port 4byte, option String )
+     * @param b   byte [] command
      * @param is
      * @param os
      * @param myHostName 
      * @throws TransportException 
      * @throws IOException 
+     * 
+     * TreeVNC Command is sent as a possible replied version message. 12 bytes is already read.
+     *       Command 4 byte (including padding)
+     *       lenght      4 byte 
+     *       port         4 byte 
+     *       rest of data ( add padding if it is shorter than 12 byte)
      */
     void treeVncCommand(byte[] b, Reader is, Writer os, String myHostName) throws TransportException, IOException {
     	ByteBuffer buf = ByteBuffer.wrap(b);
@@ -41,6 +47,10 @@
         int port = buf.getInt();
         String hostname = null;
         if (length>4) {
+            if (length>1024) {
+                System.out.println("Too long TreeVncCommand ");
+                return;
+            }
              byte namebuf[] = new byte[length-4];
              try {
                 is.readBytes(namebuf);
@@ -60,10 +70,10 @@
             handleConnectTo( port,hostname,false);
             break;
     	case ProtocolContext.FIND_ROOT :
-    	    // this is a multicast message, cannot happen
+    	    // this is a multicast message, it is handled in FindRootListener
     	    break;
         case ProtocolContext.WHERE_TO_CONNECT : 
-            handleWhereToConnect(port,hostname);
+            handleWhereToConnect(port,hostname, myHostName);
             break;
         case ProtocolContext.LOST_PARENT :
             handleLostParent(port,hostname);
@@ -79,9 +89,10 @@
      * tell him his parent
      * @param port
      * @param hostname
+     * @param myHostName 
      */
-    void handleWhereToConnect(int port, String hostname) {
-        viewer.replyCreateTree(hostname,port);
+    void handleWhereToConnect(int port, String hostname, String myHostName) {
+        viewer.replyCreateTree(hostname,port,myHostName);
     }
 
     /**
diff -r 5be1d92e7835 -r 703db66138b5 src/main/java/jp/ac/u_ryukyu/treevnc/client/TreeVncProtocol.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/client/TreeVncProtocol.java	Fri Jun 13 01:19:08 2014 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/client/TreeVncProtocol.java	Fri Jun 13 07:12:52 2014 +0900
@@ -63,7 +63,9 @@
 	public void sendWithHostAndPort(int command, String hostname, int port)
 			throws IOException {
 		openport();
-		ByteBuffer buf = ByteBuffer.allocate(4+4+4+hostname.length());
+		int cmdlen = 4+4+4+hostname.length();
+		if (cmdlen < 12) cmdlen=12;
+		ByteBuffer buf = ByteBuffer.allocate(cmdlen);
 		buf.order(ByteOrder.BIG_ENDIAN);
 		buf.put((byte) command);
 		
@@ -73,12 +75,12 @@
 		buf.putInt(4+hostname.length()); // length
 		buf.putInt(port);
 		buf.put(hostname.getBytes(), 0, hostname.length());
+		while (buf.hasRemaining() ) buf.put((byte)0) ;
+        buf.flip();
 		sendCommandToTheRoot(buf);
 	}
 
     public void sendCommandToTheRoot(ByteBuffer buf) throws IOException {
-        buf.flip();
-
         char[] charBuf = new char[12];
         is.read(charBuf , 0, 12);                       // skip root's version header
         os.write(buf.array(), 0, buf.limit());         // send our command
diff -r 5be1d92e7835 -r 703db66138b5 src/main/java/jp/ac/u_ryukyu/treevnc/server/AcceptClient.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/server/AcceptClient.java	Fri Jun 13 01:19:08 2014 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/server/AcceptClient.java	Fri Jun 13 07:12:52 2014 +0900
@@ -5,6 +5,7 @@
 import java.net.*;
 import java.util.*;
 
+import jp.ac.u_ryukyu.treevnc.MyRfbProto;
 import jp.ac.u_ryukyu.treevnc.client.TreeVncProtocol;
 
 public class AcceptClient {
@@ -12,11 +13,13 @@
 	boolean runflag = false;
 	private final int treebranch = 2;
 	//  private final int intv_time = 100;    avoid too frequent reconnection
+    private MyRfbProto rfb;
 
-	public AcceptClient(String hostName, int vncport) {
-		TreeVNCNode me = new TreeVNCNode(hostName, vncport);
+	public AcceptClient(String hostName, int vncport, MyRfbProto myRfb) {
+		TreeVNCNode me = new TreeVNCNode(hostName, vncport,"localhost");
 		me.setTreeNum(0);
 		nodeList.add(me);
+		rfb = myRfb;
 	}
 	
 //
@@ -118,8 +121,8 @@
 	 * @param hostname
 	 * @param port
 	 */
-	public void replyCreateTree(String hostname, int port) {
-        TreeVNCNode node = new TreeVNCNode(hostname,port);
+	public void replyCreateTree(String hostname, int port, String localhostname) {
+        TreeVNCNode node = new TreeVNCNode(hostname,port,localhostname);
         node.setTreeNum(nodeList.size());
         nodeList.add(node);
 	    TreeVncProtocol treeProtocol = new TreeVncProtocol(hostname,port);
@@ -130,7 +133,7 @@
 	            treeProtocol.connectTo(parent.getHostname(),parent.getPort(),isLeader(node));
 	        } else {
 	            // connect to me
-	            treeProtocol.connectTo(nodeList.getFirst().getHostname(),nodeList.getFirst().getPort(),isLeader(node));
+	            treeProtocol.connectTo(localhostname,rfb.getAcceptPort(),isLeader(node));
 	        }
 	    } catch (IOException e) {
 	        // log
diff -r 5be1d92e7835 -r 703db66138b5 src/main/java/jp/ac/u_ryukyu/treevnc/server/TreeVNCNode.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/server/TreeVNCNode.java	Fri Jun 13 01:19:08 2014 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/server/TreeVNCNode.java	Fri Jun 13 07:12:52 2014 +0900
@@ -4,11 +4,12 @@
     String hostname;
     int port;
     int treeNum;
-    // String myAddress;    // Do we need local socket address?  
+    String localhostname;
 
-    public TreeVNCNode(String hostname, int port) {
+    public TreeVNCNode(String hostname, int port, String localhostname) {
         this.hostname = hostname;
         this.port = port;
+        this.localhostname = localhostname;
     }
 
     public int getTreeNum() {
diff -r 5be1d92e7835 -r 703db66138b5 src/main/java/jp/ac/u_ryukyu/treevnc/server/VncProxyService.java
--- a/src/main/java/jp/ac/u_ryukyu/treevnc/server/VncProxyService.java	Fri Jun 13 01:19:08 2014 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/treevnc/server/VncProxyService.java	Fri Jun 13 07:12:52 2014 +0900
@@ -72,7 +72,7 @@
 	private void initProxy1(String hostName) {
 		myRfb = new MyRfbProtoProxy();
 		myRfb.setVncProxy(this);
-		clients = new AcceptClient(hostName, vncport);
+		clients = new AcceptClient(hostName, vncport,myRfb);
 		isApplet = false;
 		setIsTreeVNC(true);
 		setConnectionParam(hostName,vncport);
@@ -192,8 +192,8 @@
 		return clients.getList();
 	}
 
-    public void replyCreateTree(String hostname, int port) {
-        clients.replyCreateTree(hostname,port);
+    public void replyCreateTree(String hostname, int port,String localhostname) {
+        clients.replyCreateTree(hostname,port,localhostname);
     }
 
     public void fixLostParent(String hostname, int port) {