summaryrefslogtreecommitdiffstats
path: root/x11vnc/x11vnc.1
diff options
context:
space:
mode:
Diffstat (limited to 'x11vnc/x11vnc.1')
-rw-r--r--x11vnc/x11vnc.1270
1 files changed, 214 insertions, 56 deletions
diff --git a/x11vnc/x11vnc.1 b/x11vnc/x11vnc.1
index 0d822ed..7053ef9 100644
--- a/x11vnc/x11vnc.1
+++ b/x11vnc/x11vnc.1
@@ -2,7 +2,7 @@
.TH X11VNC "1" "November 2008" "x11vnc " "User Commands"
.SH NAME
x11vnc - allow VNC connections to real X11 displays
- version: 0.9.6, lastmod: 2008-11-04
+ version: 0.9.6, lastmod: 2008-11-22
.SH SYNOPSIS
.B x11vnc
[OPTION]...
@@ -90,6 +90,22 @@ Automatically probe for a free VNC port starting at n.
The default is to start probing at 5900. Use this to
stay away from other VNC servers near 5900.
.PP
+\fB-rfbport\fR \fIstr\fR
+.IP
+The VNC port to listen on (a libvncserver option), e.g.
+5900, 5901, etc. If specified as "\fB-rfbport\fR \fIPROMPT\fR"
+then the x11vnc \fB-gui\fR is used to prompt the user to
+enter the port number.
+.PP
+\fB-reopen\fR
+.IP
+If the X server connection is disconnected, try to
+reopen the X display (up to one time.) This is of use
+for display managers like GDM (KillInitClients option)
+that kill x11vnc just after the user logs into the
+X session. Note: the reopened state may be unstable.
+Set X11VNC_REOPEN_DISPLAY=n to reopen n times.
+.PP
\fB-reflect\fR \fIhost:N\fR
.IP
Instead of connecting to and polling an X display,
@@ -1408,6 +1424,89 @@ module for the h/w display however it will work only
for finding the display and the user must already be
logged into the X console.
.PP
+\fB-vencrypt\fR \fImode\fR
+.IP
+The VeNCrypt extension to the VNC protocol allows
+encrypted SSL/TLS connections. If the \fB-ssl\fR mode is
+enabled, then VeNCrypt is enabled as well BY DEFAULT
+(they both use the SSL/TLS tunnel, only the protocol
+handshake is a little different.)
+.IP
+To control when and how VeNCrypt is used, specify the
+mode string. If mode is "never", then VeNCrypt is
+not used. If mode is "support" (the default) then
+VeNCrypt is supported. If mode is "only", then the
+similar and older TLSVNC protocol is not simultaneously
+supported. x11vnc's normal SSL mode (vncs://) will be
+supported under \fB-ssl\fR unless you set mode to "force".
+.IP
+If mode is prefixed with "nodh:", then Diffie Hellman
+anonymous key exchange is disabled. If mode is prefixed
+with "nox509:", then X509 key exchange is disabled.
+.IP
+To disable all Anonymous Diffie-Hellman access
+(susceptible to Man-In-The-Middle attack) you will need
+to supply "\fB-vencrypt\fR \fInodh:support \fB-tlsvnc\fR never\fR"
+.IP
+If mode is prefixed with "newdh:", then new Diffie
+Hellman parameters are generated for each connection
+(this can be time consuming: 1-60 secs) rather than
+using the fixed values in the program. Using fixed,
+publicly known values is not known to be a security
+problem. This setting applies to TLSVNC as well.
+.IP
+Long example: \fB-vencrypt\fR newdh:nox509:support
+.IP
+Also, if mode is prefixed with "plain:", then
+if \fB-unixpw\fR mode is active the VeNCrypt "*Plain"
+username+passwd method is enabled for Unix logins.
+Otherwise in \fB-unixpw\fR mode the normal login panel is
+provided.
+.IP
+You *MUST* supply the \fB-ssl\fR option for VeNCrypt to be
+active. This option only fine-tunes its operation.
+.PP
+\fB-tlsvnc\fR \fImode\fR
+.IP
+The TLSVNC extension to the VNC protocol allows
+encrypted SSL/TLS connections. If the \fB-ssl\fR mode is
+enabled, then TLSVNC is enabled as well BY DEFAULT
+(they both use the SSL/TLS tunnel, only the protocol
+handshake is a little different.)
+.IP
+To control when and how TLSVNC is used, specify the
+mode string. If mode is "never", then TLSVNC is not
+used. If mode is "support" (the default) then TLSVNC
+is supported. If mode is "only", then the similar
+VeNCrypt protocol is not simultaneously supported.
+x11vnc's normal SSL mode (vncs://) will be supported
+under \fB-ssl\fR unless you set mode to "force".
+.IP
+If mode is prefixed with "newdh:", then new Diffie
+Hellman parameters are generated for each connection
+(this can be time consuming: 1-60 secs) rather than
+using the fixed values in the program. Using fixed,
+publicly known values is not known to be a security
+problem. This setting applies to VeNCrypt as well.
+See the description of "plain:" under \fB-vencrypt.\fR
+.IP
+Long example: \fB-tlsvnc\fR newdh:plain:support
+.IP
+You *MUST* supply the \fB-ssl\fR option for TLSVNC to be
+active. This option only fine-tunes its operation.
+.PP
+\fB-dhparams\fR \fIfile\fR
+.IP
+For some operations a set of Diffie Hellman parameters
+(prime and generator) is needed. If so, use the
+parameters in \fIfile\fR. In particular, the VeNCrypt and
+TLSVNC anonymous DH mode need them. By default a
+fixed set is used. If you do not want to do that you
+can specify "newdh:" to the \fB-vencrypt\fR and \fB-tlsvnc\fR
+options to generate a new set each session. If that
+is too slow for you, use \fB-dhparams\fR file to a set you
+created manually via "openssl dhparam \fB-out\fR file 1024"
+.PP
\fB-nossl\fR
.IP
Disable the \fB-ssl\fR option (see below). Since \fB-ssl\fR is off
@@ -1417,44 +1516,49 @@ to unset any *earlier* \fB-ssl\fR option (or \fB-svc...)\fR
\fB-ssl\fR \fI[pem]\fR
.IP
Use the openssl library (www.openssl.org) to provide a
-built-in encrypted SSL tunnel between VNC viewers and
-x11vnc. This requires libssl support to be compiled
+built-in encrypted SSL/TLS tunnel between VNC viewers
+and x11vnc. This requires libssl support to be compiled
into x11vnc at build time. If x11vnc is not built
with libssl support it will exit immediately when \fB-ssl\fR
is prescribed.
.IP
-The VNC Viewer-side needs support SSL as well.
-See this URL and also the discussion below for ideas
-on how to enable SSL support for the viewer:
+The VNC Viewer-side needs to support SSL/TLS as well.
+See this URL and also the discussion below for
+ideas on how to enable SSL support for the viewer:
http://www.karlrunge.com/x11vnc/#faq-ssl-tunnel-viewers
+x11vnc provides an SSL enabled Java viewer applet in
+the classes/ssl directory (-http or \fB-httpdir\fR options.)
+The SSVNC viewer package supports SSL too.
.IP
-[pem] is optional, use "\fB-ssl\fR \fI/path/to/mycert.pem\fR"
-to specify a PEM certificate file to use to identify
-and provide a key for this server. See
+[pem] is optional, use "\fB-ssl\fR \fI/path/to/mycert.pem\fR" to
+specify a PEM certificate file to use to identify and
+provide a key for this server. See
.IR openssl (1)
-for
-more info about PEMs and the \fB-sslGenCert\fR option below.
-.IP
-The connecting VNC viewer SSL tunnel can optionally
-authenticate this server if they have the public
-key part of the certificate (or a common certificate
-authority, CA, is a more sophisticated way to verify
-this server's cert, see \fB-sslGenCA\fR below). This is
-used to prevent man-in-the-middle attacks. Otherwise,
-if the VNC viewer accepts this server's key without
-verification, at least the traffic is protected
-from passive sniffing on the network (but *NOT* from
-man-in-the-middle attacks).
+for more
+info about PEMs and the \fB-sslGenCert\fR and "\fB-ssl\fR \fISAVE\fR"
+options below for how to create them.
+.IP
+The connecting VNC viewer SSL tunnel can (optionally)
+authenticate this server if they have the public key
+part of the certificate (or a common certificate
+authority, CA, is a more sophisticated way to
+verify this server's cert, see \fB-sslGenCA\fR below).
+This is used to prevent Man-In-The-Middle attacks.
+Otherwise, if the VNC viewer accepts this server's
+key WITHOUT verification, the traffic is protected
+from passive sniffing on the network, but *NOT* from
+Man-In-The-Middle attacks.
.IP
If [pem] is not supplied and the
.IR openssl (1)
utility
command exists in PATH, then a temporary, self-signed
-certificate will be generated for this session (this
-may take 5-30 seconds on slow machines). If
+certificate will be generated for this session
+(this may take 5-30 seconds on very slow machines).
+If
.IR openssl (1)
-cannot be used to generate a temporary certificate
-x11vnc exits immediately.
+cannot be used to generate a temporary
+certificate x11vnc exits immediately.
.IP
If successful in using
.IR openssl (1)
@@ -1462,17 +1566,27 @@ to generate a
temporary certificate, the public part of it will be
displayed to stderr (e.g. one could copy it to the
client-side to provide authentication of the server to
-VNC viewers.) See following paragraphs for how to save
-keys to reuse when x11vnc is restarted.
-.IP
-Set the env. var. X11VNC_SHOW_TMP_PEM=1 to have x11vnc
-print out the entire certificate, including the PRIVATE
-KEY part, to stderr. One could reuse this cert if saved
-in a [pem] file. Similarly, set X11VNC_KEEP_TMP_PEM=1
-to not delete the temporary PEM file: the file name
-will be printed to stderr (so one could move it to
-a safe place for reuse). You will be prompted for a
-passphrase for the private key.
+VNC viewers.)
+.IP
+NOTE: Unless you safely copy the public part of the
+temporary Cert to the viewer for authenticate *every
+time* (unlikely...), then only passive sniffing
+attacks are prevented and you are still open to
+Man-In-The-Middle attacks. See the following
+paragraphs for how to save keys to reuse them when
+x11vnc is restarted. With saved keys AND the VNC viewer
+authenticating them by using the public certificate,
+then Man-In-The-Middle attacks are prevented.
+.IP
+If [pem] is "ANON" then the Diffie-Hellman anonymous
+key exchange method is used. In this mode there
+are *no* SSL certificates and so it is not possible
+to authenticate either the VNC server or VNC client.
+Thus only passive network sniffing attacks are avoided:
+the "ANON" method is susceptible to Man-In-The-Middle
+attacks. "ANON" is not recommended; instead use
+a SSL PEM you created or the "SAVE" method in the
+next paragraph.
.IP
If [pem] is "SAVE" then the certificate will be saved
to the file ~/.vnc/certs/server.pem, or if that file
@@ -1488,19 +1602,17 @@ to refer to the file ~/.vnc/certs/server-<string>.pem
instead. E.g. "SAVE-charlie" will store to the file
~/.vnc/certs/server-charlie.pem
.IP
+Examples: x11vnc \fB-ssl\fR SAVE \fB-display\fR :0 ...
+x11vnc \fB-ssl\fR SAVE-other \fB-display\fR :0 ...
+.IP
See \fB-ssldir\fR below to use a directory besides the
default ~/.vnc/certs
.IP
-Example: x11vnc \fB-ssl\fR SAVE \fB-display\fR :0 ...
-.IP
-Your VNC viewer will need to be able to connect
-via SSL. See the discussion below under \fB-stunnel\fR and
-http://www.karlrunge.com/x11vnc/#faq-ssl-tunnel-viewers
-for how this might be achieved. E.g. on Unix it is
-easy to write a shell script that starts up stunnel
-and then vncviewer. Also in the x11vnc source a SSL
-enabled Java VNC Viewer applet is provided in the
-classes/ssl directory.
+Misc Info: In temporary cert creation mode, set the
+env. var. X11VNC_SHOW_TMP_PEM=1 to have x11vnc print out
+the entire certificate, including the PRIVATE KEY part,
+to stderr. There are better ways to get/save this info.
+See "SAVE" above and "\fB-sslGenCert\fR" below.
.PP
\fB-ssltimeout\fR \fIn\fR
.IP
@@ -1656,6 +1768,39 @@ Certificates" actions as does the Java applet plugin
Control Panel. stunnel can also use these files (see
the ss_vncviewer example script in the FAQ.)
.PP
+\fB-sslCRL\fR \fIpath\fR
+.IP
+Set the Certificate Revocation Lists (CRL) to \fIpath\fR.
+.IP
+If path is a file, the file contains one more more CRLs
+in PEM format. If path is a directory, it contains
+hash named files of CRLs in the usual OpenSSL manner.
+See the OpenSSL and
+.IR stunnel (8)
+documentation for
+more info.
+.IP
+This option only applies if \fB-sslverify\fR has been
+supplied: it checks for revocation along the
+certificate chain used to verify the VNC client.
+The \fB-sslCRL\fR setting will be ignored when \fB-sslverify\fR is
+not specified.
+.IP
+Only rarely will one's x11vnc \fB-ssl\fR infrastructure be so
+large that this option would be useful (since normally
+maintaining the contents of the \fB-sslverify\fR file or
+directory should be enough.) However, when using
+x11vnc with a Certificate Authority (see \fB-sslGenCA)\fR
+to authenticate Clients via SSL/TLS, the \fB-sslCRL\fR option
+can be useful to revoke users' certs whose private SSL
+keys were lost or stolen (e.g. laptop.) This way a new
+CA cert+key does not need to be created and new signed
+client keys generated and distributed to all users.
+.IP
+To create a CRL file with revoked certificates the
+commands 'openssl ca \fB-revoke\fR ...' and 'openssl ca
+\fB-gencrl\fR ...' are useful. (Run them in ~/.vnc/certs)
+.PP
\fB-sslGenCA\fR \fI[dir]\fR
.IP
Generate your own Certificate Authority private key,
@@ -2606,9 +2751,12 @@ to handle all subsequent resizes (e.g. under \fB-xrandr,\fR
.PP
\fB-o\fR \fIlogfile\fR
.IP
-Write stderr messages to file \fIlogfile\fR instead of
-to the terminal. Same as "\fB-logfile\fR \fIfile\fR". To append
+Write stderr messages to file \fIlogfile\fR instead of to
+the terminal. Same as "\fB-logfile\fR \fIfile\fR". To append
to the file use "\fB-oa\fR \fIfile\fR" or "\fB-logappend\fR \fIfile\fR".
+If \fIlogfile\fR contains the string "%VNCDISPLAY"
+it is expanded to the vnc display (the name may need
+to be guessed at.) "%HOME" works too.
.PP
\fB-flag\fR \fIfile\fR
.IP
@@ -3745,6 +3893,12 @@ has been recent user input (pointer or keyboard).
Improves response, but increases the load whenever you
are moving the mouse or typing. Default: 2.00
.PP
+\fB-setdefer\fR \fIn\fR
+.IP
+When the \fB-wait_ui\fR mechanism cuts down the wait time ms,
+set the defer time to the same ms value. n=1 to enable,
+0 to disable, and -1 to set defer to 0 (no delay).
+.PP
\fB-nowait_bog\fR
.IP
Do not detect if the screen polling is "bogging down"
@@ -4715,6 +4869,10 @@ mdns enable avahi service advertising.
.IP
nomdns disable avahi service advertising.
.IP
+zeroconf enable avahi service advertising.
+.IP
+nozeroconf disable avahi service advertising.
+.IP
connect:host do reverse connection to host, "host"
may be a comma separated list of hosts
or host:ports. See \fB-connect.\fR Passwords
@@ -5287,13 +5445,13 @@ nooverlay_yescursor overlay_nocursor 8to24 no8to24
viewonly noviewonly shared noshared forever noforever
once timeout tightfilexfer notightfilexfer ultrafilexfer
noultrafilexfer rfbversion deny lock nodeny unlock
-avahi mdns noavahi nomdns connect proxy allowonce
-allow localhost nolocalhost listen lookup nolookup
-accept afteraccept gone shm noshm flipbyteorder
-noflipbyteorder onetile noonetile solid_color solid
-nosolid blackout xinerama noxinerama xtrap noxtrap
-xrandr noxrandr xrandr_mode rotate padgeom quiet
-q noquiet modtweak nomodtweak xkb noxkb capslock
+avahi mdns zeroconf noavahi nomdns nozeroconf connect
+proxy allowonce allow localhost nolocalhost listen
+lookup nolookup accept afteraccept gone shm noshm
+flipbyteorder noflipbyteorder onetile noonetile
+solid_color solid nosolid blackout xinerama noxinerama
+xtrap noxtrap xrandr noxrandr xrandr_mode rotate padgeom
+quiet q noquiet modtweak nomodtweak xkb noxkb capslock
nocapslock skip_lockkeys noskip_lockkeys skip_keycodes
sloppy_keys nosloppy_keys skip_dups noskip_dups
add_keysyms noadd_keysyms clear_mods noclear_mods