Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
L
libvncserver
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
rasky
libvncserver
Commits
1cb25ce3
Commit
1cb25ce3
authored
Sep 05, 2006
by
runge
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update ssl_vncviewer. Fix bug in proxy.vnc with multiple PORT= params.
parent
816d7e06
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
86 additions
and
24 deletions
+86
-24
proxy.vnc
classes/ssl/proxy.vnc
+4
-1
ssl_vncviewer
classes/ssl/ssl_vncviewer
+82
-23
No files found.
classes/ssl/proxy.vnc
View file @
1cb25ce3
...
@@ -52,6 +52,9 @@ SignedVncViewer.jar is just a signed version of VncViewer.jar
...
@@ -52,6 +52,9 @@ SignedVncViewer.jar is just a signed version of VncViewer.jar
The URL to use for this file: https://host:port/proxy.vnc
The URL to use for this file: https://host:port/proxy.vnc
Note LIBVNCSERVERPORT, we assume $PARAMS will have the correct PORT setting
(e.g. 563), not the one libvncserver puts in....
-->
-->
...
@@ -61,7 +64,7 @@ $USER's $DESKTOP desktop ($DISPLAY)
...
@@ -61,7 +64,7 @@ $USER's $DESKTOP desktop ($DISPLAY)
</TITLE>
</TITLE>
<APPLET CODE=VncViewer.class ARCHIVE=SignedVncViewer.jar
<APPLET CODE=VncViewer.class ARCHIVE=SignedVncViewer.jar
WIDTH=$APPLETWIDTH HEIGHT=$APPLETHEIGHT>
WIDTH=$APPLETWIDTH HEIGHT=$APPLETHEIGHT>
<param name=PORT value=$PORT>
<param name=
LIBVNCSERVER
PORT value=$PORT>
<param name="Open New Window" value=yes>
<param name="Open New Window" value=yes>
$PARAMS
$PARAMS
</APPLET>
</APPLET>
...
...
classes/ssl/ssl_vncviewer
View file @
1cb25ce3
...
@@ -64,10 +64,20 @@
...
@@ -64,10 +64,20 @@
# ssl_vncviewer -ssh -proxy fred@mygate.com:2022 mymachine:0
# ssl_vncviewer -ssh -proxy fred@mygate.com:2022 mymachine:0
# ssl_vncviewer -ssh -proxy bob@bobs-home.net:2222 localhost:0
# ssl_vncviewer -ssh -proxy bob@bobs-home.net:2222 localhost:0
#
#
#
# -sshcmd cmd Run "cmd" via ssh instead of the default "sleep 15"
# -sshcmd cmd Run "cmd" via ssh instead of the default "sleep 15"
# e.g. -sshcmd 'x11vnc -display :0 -localhost -rfbport 5900'
# e.g. -sshcmd 'x11vnc -display :0 -localhost -rfbport 5900'
#
#
# -sshargs "args" pass "args" to the ssh process, e.g. -L/-R port redirs.
#
# -sshssl Tunnel the SSL connection thru a SSH connection. The tunnel as
# under -ssh is set up and the SSL connection goes thru it. Use
# this if you want to have and end-to-end SSL connection but must
# go thru a SSH gateway host (e.g. not the vnc server). Or use
# this if you need to tunnel additional services via -R and -L
# (see -sshargs above).
#
# ssl_vncviewer -sshssl -proxy fred@mygate.com mymachine:0
#
#
#
# -alpha turn on cursor alphablending hack if you are using the
# -alpha turn on cursor alphablending hack if you are using the
# enhanced tightvnc vncviewer.
# enhanced tightvnc vncviewer.
...
@@ -103,8 +113,13 @@ help() {
...
@@ -103,8 +113,13 @@ help() {
gotalpha
=
""
gotalpha
=
""
use_ssh
=
""
use_ssh
=
""
ssl_sleep
=
15
use_sshssl
=
""
ssh_cmd
=
"sleep
$ssl_sleep
"
ssh_sleep
=
15
ssh_cmd
=
"sleep
$ssh_sleep
"
if
[
"X
$SSL_VNCVIEWER_SSH_CMD
"
!=
"X"
]
;
then
ssh_cmd
=
"
$SSL_VNCVIEWER_SSH_CMD
"
fi
ssh_args
=
""
# grab our cmdline options:
# grab our cmdline options:
while
[
"X
$1
"
!=
"X"
]
while
[
"X
$1
"
!=
"X"
]
...
@@ -118,8 +133,13 @@ do
...
@@ -118,8 +133,13 @@ do
;;
;;
"-ssh"
)
use_ssh
=
1
"-ssh"
)
use_ssh
=
1
;;
;;
"-sshssl"
)
use_ssh
=
1
use_sshssl
=
1
;;
"-sshcmd"
)
shift
;
ssh_cmd
=
"
$1
"
"-sshcmd"
)
shift
;
ssh_cmd
=
"
$1
"
;;
;;
"-sshargs"
)
shift
;
ssh_args
=
"
$1
"
;;
"-alpha"
)
gotalpha
=
1
"-alpha"
)
gotalpha
=
1
;;
;;
"-grab"
)
VNCVIEWER_GRAB_SERVER
=
1
;
export
VNCVIEWER_GRAB_SERVER
"-grab"
)
VNCVIEWER_GRAB_SERVER
=
1
;
export
VNCVIEWER_GRAB_SERVER
...
@@ -142,7 +162,7 @@ fi
...
@@ -142,7 +162,7 @@ fi
orig
=
"
$1
"
orig
=
"
$1
"
shift
shift
if
[
"X
$use_ssh
"
=
"X1"
]
;
then
if
[
"X
$use_ssh
"
=
"X1"
-a
"X
$use_sshssl
"
=
"X"
]
;
then
if
[
"X
$mycert
"
!=
"X"
-o
"X
$verify
"
!=
"X"
]
;
then
if
[
"X
$mycert
"
!=
"X"
-o
"X
$verify
"
!=
"X"
]
;
then
echo
"-mycert and -verify cannot be used in -ssh mode"
echo
"-mycert and -verify cannot be used in -ssh mode"
exit
1
exit
1
...
@@ -168,31 +188,42 @@ else
...
@@ -168,31 +188,42 @@ else
fi
fi
# try to find an open listening port via netstat(1):
# try to find an open listening port via netstat(1):
use
=
""
inuse
=
""
inuse
=
""
if
uname
|
grep
Linux
>
/dev/null
;
then
if
uname
|
grep
Linux
>
/dev/null
;
then
inuse
=
`
netstat
-ant
| egrep
'LISTEN|WAIT|ESTABLISH|CLOSE'
|
awk
'{print $4}'
|
sed
's/^.*://'
`
inuse
=
`
netstat
-ant
| egrep
'LISTEN|WAIT|ESTABLISH|CLOSE'
|
awk
'{print $4}'
|
sed
's/^.*://'
`
elif
uname
|
grep
SunOS
>
/dev/null
;
then
elif
uname
|
grep
SunOS
>
/dev/null
;
then
inuse
=
`
netstat
-an
-f
inet
-P
tcp |
grep
LISTEN |
awk
'{print $1}'
|
sed
's/^.*\.//'
`
inuse
=
`
netstat
-an
-f
inet
-P
tcp |
grep
LISTEN |
awk
'{print $1}'
|
sed
's/^.*\.//'
`
# add others...
fi
fi
if
[
"x
$inuse
"
!=
"x"
]
;
then
try
=
5930
date_sec
=
`
date
+%S
`
findfree
()
{
try0
=
$1
try
=
$try0
use0
=
""
while
[
$try
-lt
6000
]
while
[
$try
-lt
6000
]
do
do
if
[
"X
$inuse
"
=
"X"
]
;
then
break
fi
if
echo
"
$inuse
"
|
grep
-w
$try
>
/dev/null
;
then
if
echo
"
$inuse
"
|
grep
-w
$try
>
/dev/null
;
then
:
:
else
else
use
=
$try
use
0
=
$try
break
break
fi
fi
try
=
`
expr
$try
+ 1
`
try
=
`
expr
$try
+ 1
`
done
done
fi
if
[
"X
$use0
"
=
"X"
]
;
then
if
[
"X
$use
"
=
"X"
]
;
then
use0
=
`
expr
$date_sec
+
$try0
`
# otherwise choose a "random" one:
fi
use
=
`
date
+%S
`
use
=
`
expr
$use
+ 5930
`
echo
$use0
fi
}
use
=
`
findfree 5930
`
if
[
$use
-ge
5900
]
;
then
if
[
$use
-ge
5900
]
;
then
N
=
`
expr
$use
- 5900
`
N
=
`
expr
$use
- 5900
`
...
@@ -219,28 +250,56 @@ if [ "X$use_ssh" = "X1" ]; then
...
@@ -219,28 +250,56 @@ if [ "X$use_ssh" = "X1" ]; then
fi
fi
echo
""
echo
""
echo
"Running ssh:"
echo
"Running ssh:"
echo
"
$ssh
-f -p
$ssh_port
-L
${
use
}
:
${
vnc_host
}
:
${
port
}
$ssh_host
\"
$ssh_cmd
\"
"
sz
=
`
echo
"
$ssh_cmd
"
|
wc
-c
`
echo
""
if
[
"
$sz
"
-gt
200
]
;
then
$ssh
-f
-p
$ssh_port
-L
${
use
}
:
${
vnc_host
}
:
${
port
}
$ssh_host
"
$ssh_cmd
"
info
=
"..."
else
info
=
"
$ssh_cmd
"
fi
if
[
"X
$SSL_VNCVIEWER_SSH_ONLY
"
!=
"X"
]
;
then
echo
"
$ssh
-p
$ssh_port
-t -C
$ssh_args
$ssh_host
\"
$info
\"
"
echo
""
$ssh
-p
$ssh_port
-t
-C
$ssh_args
$ssh_host
"
$ssh_cmd
"
exit
$?
elif
[
"X
$SSL_VNCVIEWER_NO_F
"
!=
"X"
]
;
then
echo
"
$ssh
-p
$ssh_port
-C -L
${
use
}
:
${
vnc_host
}
:
${
port
}
$ssh_args
$ssh_host
\"
$info
\"
"
echo
""
$ssh
-p
$ssh_port
-C
-L
${
use
}
:
${
vnc_host
}
:
${
port
}
$ssh_args
$ssh_host
"
$ssh_cmd
"
else
echo
"
$ssh
-f -p
$ssh_port
-C -L
${
use
}
:
${
vnc_host
}
:
${
port
}
$ssh_args
$ssh_host
\"
$info
\"
"
echo
""
$ssh
-f
-p
$ssh_port
-C
-L
${
use
}
:
${
vnc_host
}
:
${
port
}
$ssh_args
$ssh_host
"
$ssh_cmd
"
fi
if
[
"
$?
"
!=
"0"
]
;
then
if
[
"
$?
"
!=
"0"
]
;
then
echo
""
echo
""
echo
"ssh to
$ssh_host
failed."
echo
"ssh to
$ssh_host
failed."
exit
1
exit
1
fi
fi
echo
""
echo
""
if
[
"X
$ssh_cmd
"
=
"Xsleep
$ss
l
_sleep
"
]
;
then
if
[
"X
$ssh_cmd
"
=
"Xsleep
$ss
h
_sleep
"
]
;
then
sleep
1
sleep
1
else
else
# let any command get started a bit.
# let any command get started a bit.
sleep
5
sleep
5
fi
fi
echo
""
echo
""
echo
"Running viewer:"
if
[
"X
$use_sshssl
"
=
"X"
]
;
then
echo
$VNCVIEWERCMD
"
$@
"
localhost:
$N
echo
"Running viewer:"
echo
""
echo
$VNCVIEWERCMD
"
$@
"
localhost:
$N
$VNCVIEWERCMD
"
$@
"
localhost:
$N
echo
""
$VNCVIEWERCMD
"
$@
"
localhost:
$N
exit
$?
exit
$?
else
use2
=
`
findfree 5960
`
host0
=
$host
port0
=
$port
host
=
localhost
port
=
$use
use
=
$use2
N
=
`
expr
$use
- 5900
`
proxy
=
""
fi
fi
fi
# create the stunnel config file:
# create the stunnel config file:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment