summaryrefslogtreecommitdiffstats
path: root/x11vnc/tkx11vnc
diff options
context:
space:
mode:
authorrunge <runge>2008-11-22 18:36:33 +0000
committerrunge <runge>2008-11-22 18:36:33 +0000
commit6fbba525a924961083bf2e43bb841bd15671f526 (patch)
tree3ec0cf4b285fb0140294a151b801c91bc78a612e /x11vnc/tkx11vnc
parent63b98dba790fa9835e970b8502d93258862a9373 (diff)
downloadlibtdevnc-6fbba525a924961083bf2e43bb841bd15671f526.tar.gz
libtdevnc-6fbba525a924961083bf2e43bb841bd15671f526.zip
x11vnc: x11vnc.desktop file. -reopen, -dhparams, -sslCRL,
-setdefer options. -rfbport PROMPT VeNCrypt and TLSVNC SSL/TLS encryption support. Tweaks to choose_delay() algorithm. -ssl ANON anonymouse Diffie-Hellman mode. Fix bugs in certs management. Additions to tray=setpass naive user mode.
Diffstat (limited to 'x11vnc/tkx11vnc')
-rwxr-xr-xx11vnc/tkx11vnc592
1 files changed, 517 insertions, 75 deletions
diff --git a/x11vnc/tkx11vnc b/x11vnc/tkx11vnc
index ba90801..85727fd 100755
--- a/x11vnc/tkx11vnc
+++ b/x11vnc/tkx11vnc
@@ -123,7 +123,7 @@ Clients
afteraccept:
gone:
vncconnect
- avahi
+ zeroconf
-- D
tightfilexfer
ultrafilexfer
@@ -708,6 +708,8 @@ of actions:
Stop x11vnc - Directs the x11vnc server to disconnect all vncviewers
and then exit. The tray/icon GUI then exits as well.
+ Logfile - Show the logfile if x11vnc is being run with one.
+
Custom - If you have a \$HOME/.x11vnc.gui file each uncommented
line in it becomes an additional menu item for this
menu. The remote control command is run directly
@@ -755,42 +757,78 @@ The Properties dialog allows you to set some basic parameters of a
running x11vnc server. After modifying them press \"OK\" or \"Apply\"
to apply the changes, or press \"Cancel\" to skip applying them.
- - \"Accept Connections\" toggles whether VNC viewers are allowed
- to connect or not. It corresponds to the \"-R unlock\" and \"-R lock\"
- remote-control commands.
-
- - \"Ask for Confirmation\" toggles whether a popup menu will be presented
- at the X display when a new VNC viewer attempts to connect. The person
- sitting at the X display can choose to accept or reject the connection
- or accept the connection in View-Only mode. It corresponds to the
- \"-R accept:popup\" and \"-R accept:\" remote-control commands.
+ Accept Connections:
+
+ Toggles whether VNC viewers are allowed to connect or not. It corresponds
+ to the \"-R unlock\" and \"-R lock\" remote-control commands.
+
+ Ask for Confirmation:
+
+ Toggles whether a popup menu will be presented at the X display when
+ a new VNC viewer attempts to connect. The person sitting at the X
+ display can choose to accept or reject the connection or accept the
+ connection in ViewOnly mode. It corresponds to the \"-R accept:popup\"
+ and \"-R accept:\" remote-control commands.
- - \"All Clients ViewOnly\" toggles whether the entire VNC desktop is
- view only. All clients will only be able to watch when this is set
- (regardless of how they logged in). It corresponds to the
- \"-R viewonly\" and \"-R noviewonly\" remote-control commands.
+ All Clients ViewOnly:
+
+ Toggles whether the entire VNC desktop is view only. All clients
+ will only be able to watch when this is set (regardless of how they
+ logged in). It corresponds to the \"-R viewonly\" and \"-R noviewonly\"
+ remote-control commands.
- - \"Shared\" toggles whether multiple simultaneous connections are
- allowed or not. It corresponds to the \"-R shared\" and \"-R noshared\"
+ Shared:
+
+ Toggles whether multiple simultaneous viewer connections are allowed
+ or not. It corresponds to the \"-R shared\" and \"-R noshared\"
remote-control commands.
- - \"Password\" lets you set the session password viewers may use to gain full
- access to the display. This will only work if x11vnc was started with
- the -gui icon or -gui tray mode.
+ Advertise Service (Zeroconf):
+
+ Toggles whether this VNC server should advertize itself via Zeroconf
+ (also called Bonjour, mDNS, and avahi). Then VNC viewers can then find
+ this service on the local network. It corresponds to the \"-R zeroconf\"
+ and \"-R nozeroconf\" remote-control commands.
+
+ Serve Java Viewer Applet:
+
+ Toggles whether this VNC server should serve up a Java VNC Viewer
+ applet via HTTP on http://hostname:5800/ (or port 5800+n for VNC
+ port 5900+n). A java enabled Web Browser can then connect to the
+ desktopby VNC. If SSL is active then the HTTPS URL https://hostname:5900/
+ (etc.) will work as well. This requires the x11vnc java viewer jar file
+ (shared/x11vnc/classes) to be installed. It corresponds to the
+ \"-R http\" and \"-R nohttp\" remote commands.
+
+ Solid Background Color:
+
+ To improve VNC performance, if this option is set, then x11vnc will try
+ to make the desktop background a solid color (which compresses extremely
+ well compared to photo images, etc.) It corresponds to the \"-R solid\"
+ and \"-R nosolid\" remote commands.
+
+ Password:
+
+ Lets you set the session password viewers may use to gain full access
+ to the display. This will only work if x11vnc was started with the
+ -gui icon or -gui tray mode.
- - \"ViewOnly Password\" lets you set the session password viewers may
- use to gain view only access to the display. This will only work if
- x11vnc was started with the -gui icon or -gui tray mode.
+ ViewOnly Password:
+
+ Lets you set the session password viewers may use to gain view only
+ access to the display. This will only work if x11vnc was started with
+ the -gui icon or -gui tray mode.
+
-NOTE: These \"session\" passwords only last for the current x11vnc
-session (they are not remembered, see the -storepasswd, -passwdfile,
-and -rfbauth x11vnc options for using stored passwords).
+ NOTE: These \"session\" passwords only last for the current x11vnc
+ session (they are not remembered, see the -storepasswd, -passwdfile,
+ and -rfbauth x11vnc options for using stored passwords).
-If you set \"Password\" to the empty string that makes the \"View-Only
-Password\" empty as well and removes the need for any password to log in.
+ If you set \"Password\" to the empty string that makes the \"ViewOnly
+ Password\" empty as well and removes the need for any password to log in.
-If you set \"ViewOnly Password\" to the empty string that just removes
-the ViewOnly log in aspect: \"Password\" is still required to log in.
+ If you set \"ViewOnly Password\" to the empty string that just removes
+ the ViewOnly log in aspect: \"Password\" is still required to log in.
- The \"Help\" button shows this help text.
@@ -798,7 +836,8 @@ the ViewOnly log in aspect: \"Password\" is still required to log in.
tkx11vnc GUI. All dynamic settings can be modified in the full GUI.
---------------------------------------------------------------------
+==========================================================================
+
Don't Lock Yourself Out:
If you are sitting at the physical X display you cannot get into too
@@ -1648,6 +1687,9 @@ proc parse_help {} {
if {[regexp {^These options} $line]} {
continue;
}
+ # tweak aliases:
+ regsub {^-zeroconf} $line "-zero_conf" line
+ regsub {^-avahi } $line "-zeroconf" line
if {! $sawopts} {
continue;
@@ -2912,6 +2954,8 @@ proc all_query_vars {} {
}
set cache_all_query_vars $qry
+#puts $qry
+
return $qry
}
@@ -2919,6 +2963,7 @@ proc query_all {{quiet 0}} {
global query_ans_list query_aro_list all_settings
global last_query_all_time
+ dtime 1
set qry [all_query_vars]
set qargs [list "-Q" $qry]
@@ -2936,6 +2981,7 @@ proc query_all {{quiet 0}} {
}
}
set last_query_all_time [clock seconds]
+ dtime 2
return $all
}
@@ -4023,9 +4069,11 @@ proc props_widgets {state} {
}
proc props_apply {} {
- global props_accept props_confirm props_viewonly props_shared
+ global props_accept props_confirm props_viewonly props_shared
+ global props_zeroconf props_javaview props_solid
global props_passwd props_viewpasswd
global prop0_accept prop0_confirm prop0_viewonly prop0_shared
+ global prop0_zeroconf prop0_javaview prop0_solid
global prop0_passwd prop0_viewpasswd
global menu_var
global client_sock
@@ -4040,15 +4088,7 @@ proc props_apply {} {
}
set did 0
- if {$props_accept != $prop0_accept} {
- if {$did > 0} {after $aft}; incr did
- if {$props_accept} {
- push_new_value "unlock" "unlock" 1 0
- } else {
- push_new_value "lock" "lock" 1 0
- }
- set prop0_accept $props_accept
- }
+ set fail 0
if {$props_confirm != $prop0_confirm} {
if {$did > 0} {after $aft}; incr did
@@ -4062,6 +4102,7 @@ proc props_apply {} {
} elseif {$menu_var(accept) == ""} {
set props_confirm 0
}
+ if {$props_confirm == $prop0_confirm} {incr fail}
set prop0_confirm $props_confirm
}
@@ -4077,6 +4118,7 @@ proc props_apply {} {
} else {
set props_viewonly 0
}
+ if {$props_viewonly == $prop0_viewonly} {incr fail}
set prop0_viewonly $props_viewonly
}
@@ -4092,9 +4134,58 @@ proc props_apply {} {
} else {
set props_shared 0
}
+ if {$props_shared == $prop0_shared} {incr fail}
set prop0_shared $props_shared
}
+ if {$props_zeroconf != $prop0_zeroconf} {
+ if {$did > 0} {after $aft}; incr did
+ if {$props_zeroconf} {
+ push_new_value "zeroconf" "zeroconf" 1 1
+ } else {
+ push_new_value "zeroconf" "nozeroconf" 1 1
+ }
+ if {$menu_var(zeroconf)} {
+ set props_zeroconf 1
+ } else {
+ set props_zeroconf 0
+ }
+ if {$props_zeroconf == $prop0_zeroconf} {incr fail}
+ set prop0_zeroconf $props_zeroconf
+ }
+
+ if {$props_javaview != $prop0_javaview} {
+ if {$did > 0} {after $aft}; incr did
+ if {$props_javaview} {
+ push_new_value "http" "http" 1 1
+ } else {
+ push_new_value "http" "nohttp" 1 1
+ }
+ if {$menu_var(http)} {
+ set props_javaview 1
+ } else {
+ set props_javaview 0
+ }
+ if {$props_javaview == $prop0_javaview} {incr fail}
+ set prop0_javaview $props_javaview
+ }
+
+ if {$props_solid != $prop0_solid} {
+ if {$did > 0} {after $aft}; incr did
+ if {$props_solid} {
+ push_new_value "solid" "solid" 1 1
+ } else {
+ push_new_value "solid" "nosolid" 1 1
+ }
+ if {$menu_var(solid)} {
+ set props_solid 1
+ } else {
+ set props_solid 0
+ }
+ if {$props_solid == $prop0_solid} {incr fail}
+ set prop0_solid $props_solid
+ }
+
set fpw 0
if {$props_passwd != $prop0_passwd} {
set fpw 1
@@ -4159,16 +4250,34 @@ proc props_apply {} {
if {$case == "fpw"} {
if {$did > 0} {after $aft}; incr did
push_new_value "passwd" "passwd" "$props_passwd" 1
+ if {$props_passwd == $prop0_passwd} {incr fail}
set prop0_passwd $props_passwd
}
if {$case == "vpw"} {
if {$did > 0} {after $aft}; incr did
push_new_value "viewpasswd" "viewpasswd" "$props_viewpasswd" 1
+ if {$props_viewpasswd == $prop0_viewpasswd} {incr fail}
set prop0_viewpasswd $props_viewpasswd
}
}
+ if {$props_accept != $prop0_accept} {
+ if {$did > 0} {after $aft}; incr did
+ if {$props_accept} {
+ push_new_value "unlock" "unlock" 1 0
+ } else {
+ push_new_value "lock" "lock" 1 0
+ }
+ if {$props_accept == $prop0_accept} {incr fail}
+ set prop0_accept $props_accept
+ }
+
props_widgets normal
+ if {$fail > 0} {
+ return 0
+ } else {
+ return 1
+ }
}
proc props_advanced {} {
@@ -4192,20 +4301,29 @@ proc props_advanced {} {
}
}
-proc do_props {{msg ""}} {
+proc do_props {} {
global props_accept props_confirm props_viewonly props_shared
+ global props_zeroconf props_javaview props_solid
global props_passwd props_viewpasswd
global prop0_accept prop0_confirm prop0_viewonly prop0_shared
+ global prop0_zeroconf prop0_javaview prop0_solid
global prop0_passwd prop0_viewpasswd
global menu_var unset_str
global have_labelframes ffont bfont
global props_buttons icon_noadvanced
global icon_mode icon_mode_at_startup
global screen_height screen_width
+ global do_props_msg
+
+ set msg ""
+ if {[info exists do_props_msg]} {
+ set msg $do_props_msg
+ }
check_update_vars
- set pady 1m
+ set pady 0.5m
+ set pady 0.3m
if {$screen_height <= 360} {
set pady 0m
}
@@ -4262,6 +4380,48 @@ proc do_props {{msg ""}} {
}
set prop0_shared $props_shared
+ if [info exists menu_var(zeroconf)] {
+ if {$menu_var(zeroconf) == $unset_str || $menu_var(zeroconf) == ""} {
+ set props_zeroconf 0
+ } elseif ($menu_var(zeroconf)) {
+ set props_zeroconf 1
+ } else {
+ set props_zeroconf 0
+ }
+ } else {
+ set menu_var(zeroconf) 0
+ set props_zeroconf 0
+ }
+ set prop0_zeroconf $props_zeroconf
+
+ if [info exists menu_var(http)] {
+ if {$menu_var(http) == $unset_str || $menu_var(http) == ""} {
+ set props_javaview 0
+ } elseif ($menu_var(http)) {
+ set props_javaview 1
+ } else {
+ set props_javaview 0
+ }
+ } else {
+ set menu_var(http) 0
+ set props_javaview 0
+ }
+ set prop0_javaview $props_javaview
+
+ if [info exists menu_var(solid)] {
+ if {$menu_var(solid) == $unset_str || $menu_var(solid) == ""} {
+ set props_solid 0
+ } elseif ($menu_var(solid)) {
+ set props_solid 1
+ } else {
+ set props_solid 0
+ }
+ } else {
+ set menu_var(solid) 0
+ set props_solid 0
+ }
+ set prop0_solid $props_solid
+
if ![info exists props_passwd] {
set props_passwd ""
}
@@ -4283,7 +4443,7 @@ proc do_props {{msg ""}} {
wm title $w "x11vnc Properties"
set b1 "$w.buttons1"
frame $b1
- button $b1.ok -text OK -command "props_apply; destroy $w" -font $bfont
+ button $b1.ok -text OK -command "if {\[props_apply\]} {destroy $w}" -font $bfont
button $b1.cancel -text Cancel -command "destroy $w" -font $bfont
button $b1.apply -text Apply -command "props_apply" -font $bfont
@@ -4295,17 +4455,29 @@ proc do_props {{msg ""}} {
set b2 "$w.buttons2"
frame $b2
- button $b2.advanced -text "Advanced ..." \
+ button $b2.advanced -text " Advanced ... " \
-command "destroy $w; props_advanced" -font $bfont
if {! $icon_noadvanced} {
lappend props_buttons $b2.advanced
pack $b2.advanced -side left -expand 0
}
- button $b2.help -text "Help" -command "menu_help Properties" -font $bfont
+ button $b2.help -text " Help " -command "menu_help Properties" -font $bfont
lappend props_buttons $b2.help
pack $b2.help -side left -expand 0
+ set pw "$w.passwd"
+ if {$have_labelframes} {
+ labelframe $pw -text "Password" -font $bfont
+ } else {
+ frame $pw
+ set l $pw.l
+ label $l -text "Password:" -justify left -anchor w -font $bfont
+ pack $pw.l -fill x -expand 1 -padx 1m -pady 0m -side top
+ }
+ entry $pw.e -show "*" -textvariable props_passwd -font $bfont
+ pack $pw.e -fill x -expand 1 -padx 1m -pady $pady -side top
+
set vp "$w.viewpw"
if {$have_labelframes} {
labelframe $vp -text "ViewOnly Password" -font $bfont
@@ -4321,18 +4493,6 @@ proc do_props {{msg ""}} {
lappend props_buttons $vp.e
- set pw "$w.passwd"
- if {$have_labelframes} {
- labelframe $pw -text "Password" -font $bfont
- } else {
- frame $pw
- set l $pw.l
- label $l -text "Password:" -justify left -anchor w -font $bfont
- pack $pw.l -fill x -expand 1 -padx 1m -pady 0m -side top
- }
- entry $pw.e -show "*" -textvariable props_passwd -font $bfont
- pack $pw.e -fill x -expand 1 -padx 1m -pady $pady -side top
-
if {! $icon_mode_at_startup} {
$vp.e configure -state disabled
catch {$vp.l configure -state disabled}
@@ -4346,6 +4506,24 @@ proc do_props {{msg ""}} {
lappend props_buttons $pw.e
+ set sb "$w.solid"
+ frame $sb
+ checkbutton $sb.button -text "Solid Background Color" \
+ -variable props_solid -anchor w -font $bfont
+ pack $sb.button -fill x -expand 1 -padx 1m -pady $pady
+
+ set jv "$w.javaview"
+ frame $jv
+ checkbutton $jv.button -text "Serve Java Viewer Applet" \
+ -variable props_javaview -anchor w -font $bfont
+ pack $jv.button -fill x -expand 1 -padx 1m -pady $pady
+
+ set zc "$w.zeroconf"
+ frame $zc
+ checkbutton $zc.button -text "Advertise Service (Zeroconf)" \
+ -variable props_zeroconf -anchor w -font $bfont
+ pack $zc.button -fill x -expand 1 -padx 1m -pady $pady
+
set sh "$w.shared"
frame $sh
checkbutton $sh.button -text "Shared" \
@@ -4375,11 +4553,21 @@ proc do_props {{msg ""}} {
pack $b2 -side bottom -fill x -pady $pady -padx $px
pack $vp -side bottom -fill x -pady $pady -padx $px
pack $pw -side bottom -fill x -pady $pady -padx $px
+ pack $sb -side bottom -fill x -pady 0m -padx $px
+ pack $jv -side bottom -fill x -pady 0m -padx $px
+ pack $zc -side bottom -fill x -pady 0m -padx $px
pack $sh -side bottom -fill x -pady 0m -padx $px
pack $vo -side bottom -fill x -pady 0m -padx $px
pack $cf -side bottom -fill x -pady 0m -padx $px
pack $ac -side bottom -fill x -pady 0m -padx $px
+ global show_props_instructions
+ if {![info exists show_props_instructions]} {
+ set show_props_instructions 1
+ }
+
+ wm withdraw $w
+
if {$msg != ""} {
set tw [textwidth $msg]
set th [textheight $msg]
@@ -4387,18 +4575,46 @@ proc do_props {{msg ""}} {
set ms "$w.msg"
text $ms -font $ffont -relief ridge -width $tw -height $th
$ms insert 1.0 $msg
- pack $ms -side bottom -fill x -pady $pady -padx $px
+
+ set si "$w.instructions"
+ frame $si
+ checkbutton $si.button -text "Show Instructions" \
+ -variable show_props_instructions -anchor w -font $bfont \
+ -command "toggle_instructions $ms $pady $px"
+
+ pack $si.button -fill x -expand 1 -padx 1m -pady $pady
+ pack $si -side bottom -fill x -pady 0m -padx $px
+
+ if {$show_props_instructions} {
+ pack $ms -side bottom -fill x -pady $pady -padx $px
+ }
+
update
}
- lappend props_buttons $ac.button $cf.button $vo.button $sh.button
+ lappend props_buttons $ac.button $cf.button $vo.button $sh.button $zc.button $jv.button $sb.button
+
+ update
wm resizable $w 1 0
center_win $w
update
- wm minsize $w [winfo width $w] [winfo height $w]
+
+ #wm minsize $w [winfo width $w] [winfo height $w]
tkwait window $w
+ set show_props_instructions 0
+}
+
+proc toggle_instructions {ms pady px} {
+ global show_props_instructions
+ if {$show_props_instructions} {
+ pack $ms -side bottom -fill x -pady $pady -padx $px
+ } else {
+ pack forget $ms
+ }
+ catch {pack .props}
+ update
}
proc do_new_client {} {
@@ -4547,8 +4763,11 @@ proc set_client_balloon {str} {
proc read_client_info {channel} {
global x11vnc_client_file client_str client_info_read
global read_client_info_lock
+ global read_clients
set db 0
+ set read_clients 0
+
if {![info exists read_client_info_lock]} {
set read_client_info_lock 0
}
@@ -4580,6 +4799,7 @@ proc read_client_info {channel} {
;
} elseif [regexp {^clients:} $str] {
regsub {^clients:} $str "" str
+ set read_clients 1
if {$str == "none"} {
set str ""
}
@@ -4592,11 +4812,30 @@ proc read_client_info {channel} {
}
}
+proc check_set_vnc_display {} {
+
+ global read_clients check_set_vnc_display_done
+
+ if {[info exists check_set_vnc_display_done]} {
+ return
+ }
+ if {[info exists read_clients]} {
+ if {$read_clients} {
+ after 250
+ query_all
+ global client_str
+ set_client_balloon $client_str
+ set check_set_vnc_display_done 1
+ }
+ }
+}
+
proc read_client_tail {} {
global client_tail
if {$client_tail != ""} {
read_client_info $client_tail
+ check_set_vnc_display
}
}
@@ -4605,6 +4844,7 @@ proc read_client_sock {} {
if {$client_sock != ""} {
read_client_info $client_sock
+ check_set_vnc_display
}
}
@@ -5023,6 +5263,7 @@ proc make_icon {} {
menu $menu -tearoff 0 -postcommand "popup_post $menu"
$menu add command -font $mfont -label "Properties" -command do_props
$menu add command -font $mfont -label "Help" -command "menu_help Tray"
+ $menu add command -font $mfont -label "Logfile" -command show_logfile
$menu add separator
$menu add command -font $mfont -label "New Client" -command do_new_client
@@ -5138,6 +5379,7 @@ proc setup_client_channel {} {
textwin "Warning" "Warning" $m
update
}
+ dtime C
}
proc clean_client_tail {} {
@@ -6179,6 +6421,125 @@ proc get_view_variable {} {
return $menu_var(WindowView)
}
+proc dono {a b c} {
+ exit 1;
+}
+
+proc do_port_prompt {} {
+ global bfont ffont
+ global port_reply port_set
+
+ set guess 5900
+ for {set i 0} {$i < 50} {incr i} {
+ set fh ""
+ set try [expr $guess + $i]
+ catch {set fh [socket -server dono $try]}
+ if {$fh != ""} {
+ catch {close $fh}
+ set guess $try
+ break;
+ }
+ }
+ set hn ""
+ catch {set hn [exec uname -n]}
+ if {$hn == ""} {
+ set hn "hostname"
+ }
+
+ set text " Set the x11vnc Listening Port:
+
+ VNC Display :0 corresponds to TCP port 5900
+ VNC Display :1 corresponds to TCP port 5901
+ etc.
+
+ In the Entry below, indicate a Port for x11vnc to listen on.
+
+ Note that to connect to x11vnc, a VNC Viewer will need to
+ know your selection, for example:
+
+ vncviewer $hn:0
+ vncviewer $hn:1
+ etc.
+
+ You may also set some additional parameters:
+
+ - Enable SSL encryption.
+ (requires an SSL enabled vncviewer, such as SSVNC)
+ - Listen only on localhost. (e.g. for an SSH tunnel)
+ - Enable UltraVNC or TightVNC File transfer.
+"
+ set port_set $guess
+ set port_reply ""
+
+ toplevel .pp
+ wm title .pp "Select x11vnc port"
+
+ wm protocol . WM_DELETE_WINDOW "destroy .; exit"
+ wm protocol .pp WM_DELETE_WINDOW "destroy .pp; exit"
+
+ label .pp.m -text "$text" -justify left -font $ffont
+
+ frame .pp.f -bd 1 -relief ridge -pady 2
+ label .pp.f.l -text "Port: "
+ entry .pp.f.e -width 8 -textvariable port_set
+ global enable_ssl; set enable_ssl 0
+ if [info exists env(X11VNC_SSL_ENABLED)] {
+ set enable_ssl 1
+ }
+ checkbutton .pp.f.ssl -relief raised -pady 3 -padx 3 -text "Enable SSL" -variable enable_ssl
+ global localhost; set localhost 0
+ if [info exists env(X11VNC_LOCALHOST_ENABLED)] {
+ set localhost 1
+ }
+ checkbutton .pp.f.loc -relief raised -pady 3 -padx 3 -text "Listen on localhost" -variable localhost
+ pack .pp.f.l .pp.f.e -side left
+ pack .pp.f.loc .pp.f.ssl -side right
+
+ frame .pp.t -bd 1 -relief ridge -pady 2
+ global file_transfer; set file_transfer "none"
+ if [info exists env(X11VNC_FILETRANSFER_ENABLED)] {
+ set file_transfer $env(X11VNC_FILETRANSFER_ENABLED)
+ }
+ label .pp.t.l -text "File Transfer: "
+ radiobutton .pp.t.none -text "None" -variable file_transfer -value "none"
+ radiobutton .pp.t.ultra -text "UltraVNC" -variable file_transfer -value "ultra"
+ radiobutton .pp.t.tight -text "TightVNC" -variable file_transfer -value "tight"
+ pack .pp.t.l .pp.t.none .pp.t.ultra .pp.t.tight -side left
+
+ frame .pp.o -bd 1 -relief ridge
+ button .pp.o.ok -text "OK" -command "set port_reply 1; destroy .pp"
+ button .pp.o.cancel -text "Cancel" -command "set port_reply 0; destroy .pp"
+ pack .pp.o.ok .pp.o.cancel -side left -fill x -expand 1
+ pack .pp.m -side top -fill x -expand 1
+ pack .pp.f .pp.t .pp.o -side top -fill x
+
+ focus .pp.f.e
+ .pp.f.e icursor end
+
+ wm withdraw .pp
+ update
+ center_win .pp
+
+ wm minsize .pp [winfo width .pp] [winfo height .pp]
+
+ bind .pp.f.e <KeyPress-Return> "set port_reply 1; destroy .pp"
+
+ vwait port_reply
+
+ if {$port_reply} {
+ regsub -all {^:} $port_set "" port_set
+ regsub -all {[ \t]} $port_set "" port_set
+ if {[regexp {^[0-9][0-9]*$} $port_set]} {
+ if {$port_set < 0} {
+ set port_set [expr 0 - $port_set]
+ } elseif {$port_set < 200} {
+ set port_set [expr $port_set + 5900]
+ }
+ puts "$port_set:ssl${enable_ssl}:localhost$localhost:ft_$file_transfer"
+ }
+ }
+}
+
proc change_view_state {} {
global menu_var gui_current_state
@@ -6376,20 +6737,47 @@ set ffont "fixed"
set ls ""
catch {set ls [font metrics $bfont -linespace]}
-if {$ls != ""} {
- if {$ls > 14} {
+if {$ls != "" && $ls > 14} {
# some recent setups have BIG rendering for the above fonts.
# on recent (8/08) debian these are really ragged:
set bfont "-adobe-helvetica-bold-r-*-*-*-90-*-*-*-*-*-*"
set sfont "-adobe-helvetica-bold-r-*-*-*-75-*-*-*-*-*-*"
set snfont "-adobe-helvetica-medium-r-*-*-*-75-*-*-*-*-*-*"
- # these are bigger but look better... but for how long?
- set bfont "-adobe-helvetica-bold-r-*-*-*-100-*-*-*-*-*-*"
- set sfont "-adobe-helvetica-bold-r-*-*-*-80-*-*-*-*-*-*"
- set snfont "-adobe-helvetica-medium-r-*-*-*-80-*-*-*-*-*-*"
- }
+ set ls ""
+ catch {set ls [font metrics $bfont -linespace]}
+ if {$ls != "" && $ls < 14} {
+ # these are bigger but look better... but for how long?
+ set bfont "-adobe-helvetica-bold-r-*-*-*-100-*-*-*-*-*-*"
+ set sfont "-adobe-helvetica-bold-r-*-*-*-80-*-*-*-*-*-*"
+ set snfont "-adobe-helvetica-medium-r-*-*-*-80-*-*-*-*-*-*"
+
+ # maybe consider... {-font font Font {Helvetica -12 bold} {Helvetica -12 bold}}
+ # or stick with system font like ssvnc.
+ }
+}
+
+# need to check if "fixed" font under XFT on tk8.5 is actually fixed width!!
+set ls ""
+catch {set ls [font metrics $ffont -linespace]}
+set fs ""
+catch {set fs [font metrics $ffont -fixed]}
+set redo 0
+if {$fs != "" && $fs != "1"} {
+ set redo 1
+}
+if {$ls != "" && $ls > 14} {
+ set redo 1
+}
+if {$redo} {
+ foreach fn [font names] {
+ if {$fn == "TkFixedFont"} {
+ set ffont $fn
+ break
+ }
+ }
}
+
set help_indent 24;
set reply_xdisplay ""
set all_settings "None so far."
@@ -6467,6 +6855,10 @@ if {"$argv" == "-spit"} {
puts ";"
exit 0
}
+if {"$argv" == "-portprompt"} {
+ do_port_prompt
+ exit 0
+}
set_view_variable "full"
@@ -6665,15 +7057,65 @@ get_default_vars
dtime D
proc check_setpasswd {} {
- global icon_setpasswd
+ global env icon_setpasswd
+ global do_props_msg
+ set do_props_msg ""
if {$icon_setpasswd} {
- set m "You must specify a Session Password\n"
- set m "${m}before VNC clients can connect.\n"
- set m "${m}Enter one in the Password field\n"
- set m "${m}and Press \"OK\". The password(s) is\n"
- set m "${m}only for this x11vnc session.\n"
- do_props $m
- #push_new_value "unlock" "unlock" 1 0
+ set m "\n"
+ set m " Note the x11vnc icon in the system tray \n"
+ set m "${m} This panel is its 'Properties' dialog.\n"
+ set m "${m}\n"
+ set m "${m} To specify a Session Password and to\n"
+ set m "${m} allow VNC clients to connect, follow\n"
+ set m "${m} these steps:\n"
+ set m "${m}\n"
+ set m "${m} Enter a passwd in the Password field\n"
+ set m "${m} (it can be left blank.) You can also\n"
+ set m "${m} supply a ViewOnly passwd if desired.\n"
+ set m "${m}\n"
+ set m "${m} Set 'Accept Connections' and then Press \n"
+ set m "${m} 'Apply' to allow incoming connections.\n"
+ set m "${m}\n"
+ set m "${m} The passwords are only for this x11vnc\n"
+ set m "${m} session and are not saved. Run x11vnc\n"
+ set m "${m} manually for more control.\n"
+ set m "${m}\n"
+ set m "${m} See 'Help' for details on each option.\n"
+
+ global x11vnc_cmdline
+
+ set dossl 0
+ if {[info exists x11vnc_cmdline]} {
+ if [regexp -- {-ssl} $x11vnc_cmdline] {
+ set dossl 1
+ }
+ }
+ if {$dossl || [info exists env(X11VNC_GOT_SSL)]} {
+ set m "${m}\n"
+ set m "${m} SSL encryption mode active. You can\n"
+ set m "${m} find your Public Cert in the Logfile\n"
+ set m "${m} and also the ~/.vnc/certs directory.\n"
+ }
+
+ if {[info exists env(X11VNC_SETPASS_FAIL)]} {
+ set pp 5900
+ if {[info exists env(X11VNC_GOT_RFBPORT_VAL)]} {
+ if {$env(X11VNC_GOT_RFBPORT_VAL) > 0} {
+ set pp $env(X11VNC_GOT_RFBPORT_VAL)
+ }
+ }
+
+ set m " The x11vnc program failed to start! \n"
+ set m "${m}\n"
+ set m "${m} Maybe there is another VNC server\n"
+ set m "${m} already listening on port $pp?\n"
+ set m "${m}\n"
+ set m "${m} You will need to start over after\n"
+ set m "${m} you make sure x11vnc can start.\n"
+ }
+
+ set do_props_msg $m
+ do_props
}
}