summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--java/com/tigervnc/vncviewer/CConn.java26
-rw-r--r--java/com/tigervnc/vncviewer/VncViewer.java8
2 files changed, 33 insertions, 1 deletions
diff --git a/java/com/tigervnc/vncviewer/CConn.java b/java/com/tigervnc/vncviewer/CConn.java
index b20b82ea..965bcb27 100644
--- a/java/com/tigervnc/vncviewer/CConn.java
+++ b/java/com/tigervnc/vncviewer/CConn.java
@@ -49,7 +49,8 @@ import javax.swing.ImageIcon;
import java.net.InetSocketAddress;
import java.net.URL;
import java.net.SocketException;
-import java.util.*;
+import java.util.ArrayList;
+import java.util.Iterator;
import com.tigervnc.rdr.*;
import com.tigervnc.rfb.*;
@@ -227,6 +228,18 @@ public class CConn extends CConnection
setServerName(serverHost);
setStreams(sock.inStream(), sock.outStream());
initialiseProtocol();
+ int delay = viewer.keepAliveTimeout.getValue();
+ if (delay > 0) {
+ ActionListener keepAliveListener = new ActionListener() {
+ public void actionPerformed(ActionEvent evt) {
+ synchronized (writer()) {
+ writer().writeFramebufferUpdateRequest(new Rect(0,0,0,0), true);
+ }
+ }
+ };
+ keepAliveTimer = new Timer(1000*delay, keepAliveListener);
+ keepAliveTimer.start();
+ }
}
public void refreshFramebuffer()
@@ -249,6 +262,8 @@ public class CConn extends CConnection
// deleteWindow() is called when the user closes the desktop or menu windows.
void deleteWindow() {
+ if (keepAliveTimer != null)
+ keepAliveTimer.stop();
if (viewport != null)
viewport.dispose();
viewport = null;
@@ -465,6 +480,8 @@ public class CConn extends CConnection
}
firstUpdate = false;
+ if (keepAliveTimer != null)
+ keepAliveTimer.restart();
}
// A format change has been scheduled and we are now past the update
@@ -779,6 +796,8 @@ public class CConn extends CConnection
}
forceNonincremental = false;
+ if (keepAliveTimer != null)
+ keepAliveTimer.restart();
}
@@ -1217,6 +1236,8 @@ public class CConn extends CConnection
synchronized public void writeClientCutText(String str, int len) {
if (state() != RFBSTATE_NORMAL) return;
writer().writeClientCutText(str,len);
+ if (keepAliveTimer != null)
+ keepAliveTimer.restart();
}
synchronized public void writeKeyEvent(int keysym, boolean down) {
@@ -1388,6 +1409,8 @@ public class CConn extends CConnection
if ((m & Event.META_MASK) != (pressedModifiers & Event.META_MASK))
writeKeyEvent(Keysyms.Meta_L, (m & Event.META_MASK) != 0);
pressedModifiers = m;
+ if (keepAliveTimer != null)
+ keepAliveTimer.restart();
}
@@ -1421,6 +1444,7 @@ public class CConn extends CConnection
ImageIcon logo = new ImageIcon(cl.getResource("com/tigervnc/vncviewer/tigervnc.png"));
public static UserPasswdGetter upg;
public UserMsgBox msg;
+ Timer keepAliveTimer;
// shuttingDown is set by the GUI thread and only ever tested by the RFB
// thread after the window has been destroyed.
diff --git a/java/com/tigervnc/vncviewer/VncViewer.java b/java/com/tigervnc/vncviewer/VncViewer.java
index 91504d2c..6a062840 100644
--- a/java/com/tigervnc/vncviewer/VncViewer.java
+++ b/java/com/tigervnc/vncviewer/VncViewer.java
@@ -331,6 +331,14 @@ public class VncViewer extends java.applet.Applet implements Runnable
"Use specified compression level "+
"0 = Low, 6 = High",
1);
+ IntParameter keepAliveTimeout
+ = new IntParameter("KeepAliveTimeout",
+ "Send dummy framebuffer update requests if no "+
+ "network activity has occurred for more than "+
+ "the specified number of seconds. This is to "+
+ "prevent VPNs or other applications from "+
+ "disconnecting due to inactivity. A value of "+
+ "0 disables this feature.", 0);
BoolParameter noJpeg
= new BoolParameter("NoJPEG",
"Disable lossy JPEG compression in Tight encoding.", false);