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
b8b96689
Commit
b8b96689
authored
Mar 05, 2005
by
runge
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add '-listen ipaddr' option
parent
3c4522e6
Changes
13
Show whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
1008 additions
and
658 deletions
+1008
-658
ChangeLog
ChangeLog
+6
-0
sockets.c
libvncclient/sockets.c
+2
-2
cargs.c
libvncserver/cargs.c
+12
-0
httpd.c
libvncserver/httpd.c
+2
-1
main.c
libvncserver/main.c
+2
-0
sockets.c
libvncserver/sockets.c
+31
-11
rfb.h
rfb/rfb.h
+4
-2
ChangeLog
x11vnc/ChangeLog
+5
-0
README
x11vnc/README
+685
-602
tkx11vnc
x11vnc/tkx11vnc
+4
-2
tkx11vnc.h
x11vnc/tkx11vnc.h
+4
-2
x11vnc.1
x11vnc/x11vnc.1
+24
-5
x11vnc.c
x11vnc/x11vnc.c
+227
-31
No files found.
ChangeLog
View file @
b8b96689
2005-03-04 Karl Runge <runge@karlrunge.com>
* libvncserver/{cargs.c,sockets.c}: add -listen option and
rfbScreen member listenInterface.
* rfb/rfb.h: rfbListenOnTCPPort() and rfbListenOnUDPPort()
function prototypes changed to include network interface.
2005-02-14 Karl Runge <runge@karlrunge.com>
* x11vnc: -users lurk=, -solid for cde, -gui ez,.. beginner mode.
...
...
libvncclient/sockets.c
View file @
b8b96689
...
...
@@ -305,7 +305,7 @@ FindFreeTcpPort(void)
struct
sockaddr_in
addr
;
addr
.
sin_family
=
AF_INET
;
addr
.
sin_addr
.
s_addr
=
INADDR_ANY
;
addr
.
sin_addr
.
s_addr
=
htonl
(
INADDR_ANY
)
;
sock
=
socket
(
AF_INET
,
SOCK_STREAM
,
0
);
if
(
sock
<
0
)
{
...
...
@@ -339,7 +339,7 @@ ListenAtTcpPort(int port)
addr
.
sin_family
=
AF_INET
;
addr
.
sin_port
=
htons
(
port
);
addr
.
sin_addr
.
s_addr
=
INADDR_ANY
;
addr
.
sin_addr
.
s_addr
=
htonl
(
INADDR_ANY
)
;
sock
=
socket
(
AF_INET
,
SOCK_STREAM
,
0
);
if
(
sock
<
0
)
{
...
...
libvncserver/cargs.c
View file @
b8b96689
...
...
@@ -14,6 +14,8 @@
#include <rfb/rfb.h>
extern
rfbStringToAddr
(
char
*
str
,
in_addr_t
*
iface
);
void
rfbUsage
(
void
)
{
...
...
@@ -36,6 +38,8 @@ rfbUsage(void)
fprintf
(
stderr
,
"-httpport portnum use portnum for http connection
\n
"
);
fprintf
(
stderr
,
"-enablehttpproxy enable http proxy support
\n
"
);
fprintf
(
stderr
,
"-progressive height enable progressive updating for slow links
\n
"
);
fprintf
(
stderr
,
"-listen ipaddr listen for connections only on network interface with
\n
"
);
fprintf
(
stderr
,
" addr ipaddr. '-listen localhost' and hostname work too.
\n
"
);
}
/* purges COUNT arguments from ARGV at POSITION and decrements ARGC.
...
...
@@ -125,6 +129,14 @@ rfbProcessArguments(rfbScreenInfoPtr rfbScreen,int* argc, char *argv[])
return
FALSE
;
}
rfbScreen
->
progressiveSliceHeight
=
atoi
(
argv
[
++
i
]);
}
else
if
(
strcmp
(
argv
[
i
],
"-listen"
)
==
0
)
{
/* -listen ipaddr */
if
(
i
+
1
>=
*
argc
)
{
rfbUsage
();
return
FALSE
;
}
if
(
!
rfbStringToAddr
(
argv
[
++
i
],
&
(
rfbScreen
->
listenInterface
)))
{
return
FALSE
;
}
}
else
{
i
++
;
i1
=
i
;
...
...
libvncserver/httpd.c
View file @
b8b96689
...
...
@@ -102,7 +102,8 @@ rfbHttpInitSockets(rfbScreenInfoPtr rfbScreen)
rfbLog
(
" URL http://%s:%d
\n
"
,
rfbScreen
->
thisHost
,
rfbScreen
->
httpPort
);
if
((
rfbScreen
->
httpListenSock
=
rfbListenOnTCPPort
(
rfbScreen
->
httpPort
))
<
0
)
{
if
((
rfbScreen
->
httpListenSock
=
rfbListenOnTCPPort
(
rfbScreen
->
httpPort
,
rfbScreen
->
listenInterface
))
<
0
)
{
rfbLogPerror
(
"ListenOnTCPPort"
);
return
;
}
...
...
libvncserver/main.c
View file @
b8b96689
...
...
@@ -579,6 +579,8 @@ rfbScreenInfoPtr rfbGetScreen(int* argc,char** argv,
/* disable progressive updating per default */
screen
->
progressiveSliceHeight
=
0
;
screen
->
listenInterface
=
htonl
(
INADDR_ANY
);
if
(
!
rfbProcessArguments
(
screen
,
argc
,
argv
))
{
free
(
screen
);
return
0
;
...
...
libvncserver/sockets.c
View file @
b8b96689
...
...
@@ -102,6 +102,8 @@ int rfbMaxClientWait = 20000; /* time (ms) after which we decide client has
void
rfbInitSockets
(
rfbScreenInfoPtr
rfbScreen
)
{
in_addr_t
iface
=
rfbScreen
->
listenInterface
;
if
(
rfbScreen
->
socketInitDone
)
return
;
...
...
@@ -132,9 +134,8 @@ rfbInitSockets(rfbScreenInfoPtr rfbScreen)
if
(
rfbScreen
->
autoPort
)
{
int
i
;
rfbLog
(
"Autoprobing TCP port
\n
"
);
for
(
i
=
5900
;
i
<
6000
;
i
++
)
{
if
((
rfbScreen
->
listenSock
=
rfbListenOnTCPPort
(
i
))
>=
0
)
{
if
((
rfbScreen
->
listenSock
=
rfbListenOnTCPPort
(
i
,
iface
))
>=
0
)
{
rfbScreen
->
port
=
i
;
break
;
}
...
...
@@ -153,7 +154,7 @@ rfbInitSockets(rfbScreenInfoPtr rfbScreen)
else
if
(
rfbScreen
->
port
>
0
)
{
rfbLog
(
"Listening for VNC connections on TCP port %d
\n
"
,
rfbScreen
->
port
);
if
((
rfbScreen
->
listenSock
=
rfbListenOnTCPPort
(
rfbScreen
->
port
))
<
0
)
{
if
((
rfbScreen
->
listenSock
=
rfbListenOnTCPPort
(
rfbScreen
->
port
,
iface
))
<
0
)
{
rfbLogPerror
(
"ListenOnTCPPort"
);
return
;
}
...
...
@@ -166,7 +167,7 @@ rfbInitSockets(rfbScreenInfoPtr rfbScreen)
if
(
rfbScreen
->
udpPort
!=
0
)
{
rfbLog
(
"rfbInitSockets: listening for input on UDP port %d
\n
"
,
rfbScreen
->
udpPort
);
if
((
rfbScreen
->
udpSock
=
rfbListenOnUDPPort
(
rfbScreen
->
udpPort
))
<
0
)
{
if
((
rfbScreen
->
udpSock
=
rfbListenOnUDPPort
(
rfbScreen
->
udpPort
,
iface
))
<
0
)
{
rfbLogPerror
(
"ListenOnUDPPort"
);
return
;
}
...
...
@@ -527,9 +528,29 @@ rfbWriteExact(cl, buf, len)
return
1
;
}
/* currently private, called by rfbProcessArguments() */
int
rfbStringToAddr
(
char
*
str
,
in_addr_t
*
addr
)
{
if
(
str
==
NULL
||
*
str
==
'\0'
||
strcmp
(
str
,
"any"
)
==
0
)
{
*
addr
=
htonl
(
INADDR_ANY
);
}
else
if
(
strcmp
(
str
,
"localhost"
)
==
0
)
{
*
addr
=
htonl
(
INADDR_LOOPBACK
);
}
else
{
struct
hostent
*
hp
;
if
((
*
addr
=
inet_addr
(
str
))
==
htonl
(
INADDR_NONE
))
{
if
(
!
(
hp
=
gethostbyname
(
str
)))
{
return
0
;
}
*
addr
=
*
(
unsigned
long
*
)
hp
->
h_addr
;
}
}
return
1
;
}
int
rfbListenOnTCPPort
(
port
)
rfbListenOnTCPPort
(
port
,
iface
)
int
port
;
in_addr_t
iface
;
{
struct
sockaddr_in
addr
;
int
sock
;
...
...
@@ -538,8 +559,7 @@ rfbListenOnTCPPort(port)
memset
(
&
addr
,
0
,
sizeof
(
addr
));
addr
.
sin_family
=
AF_INET
;
addr
.
sin_port
=
htons
(
port
);
/* addr.sin_addr.s_addr = interface.s_addr; */
addr
.
sin_addr
.
s_addr
=
INADDR_ANY
;
addr
.
sin_addr
.
s_addr
=
iface
;
if
((
sock
=
socket
(
AF_INET
,
SOCK_STREAM
,
0
))
<
0
)
{
return
-
1
;
...
...
@@ -574,7 +594,7 @@ rfbConnectToTcpAddr(host, port)
addr
.
sin_family
=
AF_INET
;
addr
.
sin_port
=
htons
(
port
);
if
((
addr
.
sin_addr
.
s_addr
=
inet_addr
(
host
))
==
INADDR_NONE
)
if
((
addr
.
sin_addr
.
s_addr
=
inet_addr
(
host
))
==
htonl
(
INADDR_NONE
)
)
{
if
(
!
(
hp
=
gethostbyname
(
host
)))
{
errno
=
EINVAL
;
...
...
@@ -596,8 +616,9 @@ rfbConnectToTcpAddr(host, port)
}
int
rfbListenOnUDPPort
(
port
)
rfbListenOnUDPPort
(
port
,
iface
)
int
port
;
in_addr_t
iface
;
{
struct
sockaddr_in
addr
;
int
sock
;
...
...
@@ -606,8 +627,7 @@ rfbListenOnUDPPort(port)
memset
(
&
addr
,
0
,
sizeof
(
addr
));
addr
.
sin_family
=
AF_INET
;
addr
.
sin_port
=
htons
(
port
);
/* addr.sin_addr.s_addr = interface.s_addr; */
addr
.
sin_addr
.
s_addr
=
INADDR_ANY
;
addr
.
sin_addr
.
s_addr
=
iface
;
if
((
sock
=
socket
(
AF_INET
,
SOCK_DGRAM
,
0
))
<
0
)
{
return
-
1
;
...
...
rfb/rfb.h
View file @
b8b96689
...
...
@@ -257,6 +257,8 @@ typedef struct _rfbScreenInfo
/* if LibVNCServer doesn't know the normal message, it calls this
* hook. If the hook handles the message, it returns TRUE. */
rfbProcessCustomClientMessageProcPtr
processCustomClientMessage
;
in_addr_t
listenInterface
;
}
rfbScreenInfo
,
*
rfbScreenInfoPtr
;
...
...
@@ -506,8 +508,8 @@ extern int rfbWriteExact(rfbClientPtr cl, const char *buf, int len);
extern
void
rfbCheckFds
(
rfbScreenInfoPtr
rfbScreen
,
long
usec
);
extern
int
rfbConnect
(
rfbScreenInfoPtr
rfbScreen
,
char
*
host
,
int
port
);
extern
int
rfbConnectToTcpAddr
(
char
*
host
,
int
port
);
extern
int
rfbListenOnTCPPort
(
int
port
);
extern
int
rfbListenOnUDPPort
(
int
port
);
extern
int
rfbListenOnTCPPort
(
int
port
,
in_addr_t
iface
);
extern
int
rfbListenOnUDPPort
(
int
port
,
in_addr_t
iface
);
/* rfbserver.c */
...
...
x11vnc/ChangeLog
View file @
b8b96689
2005-03-04 Karl Runge <runge@karlrunge.com>
* add changes to couple with -listen option, in particular
the behavior of -localhost and remote control cmds.
* workarounds for old trees.
2005-02-23 Karl Runge <runge@karlrunge.com>
* final changes for 0.7.1 release.
...
...
x11vnc/README
View file @
b8b96689
This source diff could not be displayed because it is too large. You can
view the blob
instead.
x11vnc/tkx11vnc
View file @
b8b96689
...
...
@@ -49,6 +49,7 @@ catch {rename send {}}
# be the same after the remote command)
# G means gui internal item
# F means can be set via file browse
# D means for simple gui
# -C:val1,... means it will be a checkbox (radio button)
# the "-" means no other options follow
# 0 means to skip the item.
...
...
@@ -87,7 +88,7 @@ Clients
vncconnect
-- D
=D http
=F
httpdir:
httpdir:
httpport:
enablehttpproxy
...
...
@@ -185,8 +186,9 @@ Permissions
=SQA deny_all
--
=DFP allow:
localhost
=D
localhost
=RA allowonce:
listen:
-- D
=RA noremote
--
...
...
x11vnc/tkx11vnc.h
View file @
b8b96689
...
...
@@ -55,6 +55,7 @@
"# be the same after the remote command)
\n
"
"# G means gui internal item
\n
"
"# F means can be set via file browse
\n
"
"# D means for simple gui
\n
"
"# -C:val1,... means it will be a checkbox (radio button)
\n
"
"# the
\"
-
\"
means no other options follow
\n
"
"# 0 means to skip the item.
\n
"
...
...
@@ -93,7 +94,7 @@
" vncconnect
\n
"
" -- D
\n
"
" =D http
\n
"
"
=F
httpdir:
\n
"
" httpdir:
\n
"
" httpport:
\n
"
" enablehttpproxy
\n
"
"
\n
"
...
...
@@ -191,8 +192,9 @@
" =SQA deny_all
\n
"
" --
\n
"
" =DFP allow:
\n
"
" localhost
\n
"
"
=D
localhost
\n
"
" =RA allowonce:
\n
"
" listen:
\n
"
" -- D
\n
"
" =RA noremote
\n
"
" --
\n
"
...
...
x11vnc/x11vnc.1
View file @
b8b96689
.\" This file was automatically generated from x11vnc -help output.
.TH X11VNC "1" "
February
2005" "x11vnc " "User Commands"
.TH X11VNC "1" "
March
2005" "x11vnc " "User Commands"
.SH NAME
x11vnc - allow VNC connections to real X11 displays
version: 0.7.
1, lastmod: 2005-02-23
version: 0.7.
2pre, lastmod: 2005-03-04
.SH SYNOPSIS
.B x11vnc
[OPTION]...
...
...
@@ -248,7 +248,19 @@ out with the "#" character in the usual way.
.PP
\fB-localhost\fR
.IP
Same as \fB-allow\fR 127.0.0.1
Same as "\fB-allow\fR \fI127.0.0.1\fR".
.IP
Note: if you want to restrict which network interface
x11vnc listens on, see the \fB-listen\fR option below.
E.g. "\fB-listen\fR \fIlocalhost\fR" or "\fB-listen\fR \fI192.168.3.21\fR".
As a special case, the option "\fB-localhost\fR" implies
"\fB-listen\fR \fIlocalhost\fR".
.IP
For non-localhost \fB-listen\fR usage, if you use the remote
control mechanism (-R) to change the \fB-listen\fR interface
you may need to manually adjust the \fB-allow\fR list (and
vice versa) to avoid situations where no connections
(or too many) are allowed.
.PP
\fB-input\fR \fIstring\fR
.IP
...
...
@@ -438,7 +450,7 @@ means to try to guess the DISPLAY from the utmpx login
database as well. So it "lurks" waiting for anyone
to log into an X session and then connects to it.
Specify a list of users after the = to limit which
users will be tried. To enable a differen
ce
searching
users will be tried. To enable a differen
t
searching
mode, if the first user in the list is something like
":0" or ":0-2" that indicates a range of DISPLAY
numbers that will be tried (regardless of whether
...
...
@@ -1202,6 +1214,8 @@ localhost enable \fB-localhost\fR mode
.IP
nolocalhost disable \fB-localhost\fR mode
.IP
listen:str set \fB-listen\fR to str, empty to disable.
.IP
input:str set \fB-input\fR to "str", empty to disable.
.IP
client_input:str set the K, M, B \fB-input\fR on a per-client
...
...
@@ -1484,7 +1498,7 @@ nooverlay_nocursor nooverlay_cursor nooverlay_yescursor
overlay_nocursor visual scale viewonly noviewonly
shared noshared forever noforever once timeout deny
lock nodeny unlock connect allowonce allow localhost
nolocalhost accept gone shm noshm flipbyteorder
nolocalhost
listen
accept gone shm noshm flipbyteorder
noflipbyteorder onetile noonetile solid_color solid
nosolid blackout xinerama noxinerama xrandr noxrandr
xrandr_mode padgeom quiet q noquiet modtweak nomodtweak
...
...
@@ -1634,6 +1648,11 @@ enable http proxy support
\fB-progressive\fR \fIheight\fR
.IP
enable progressive updating for slow links
.PP
\fB-listen\fR \fIipaddr\fR
.IP
listen for connections only on network interface with
addr ipaddr. '-listen localhost' and hostname work too.
.SH "FILES"
.IR $HOME/.x11vncrc ,
.IR $HOME/.Xauthority
...
...
x11vnc/x11vnc.c
View file @
b8b96689
/*
* x11vnc.c: a VNC server for X displays.
*
* Copyright (c) 2002-200
4
Karl J. Runge <runge@karlrunge.com>
* Copyright (c) 2002-200
5
Karl J. Runge <runge@karlrunge.com>
* All rights reserved.
*
* This is free software; you can redistribute it and/or modify
...
...
@@ -27,17 +27,22 @@
* krfb, the KDE desktopsharing project (Tim Jansen)
*
* The primary goal of this program is to create a portable and simple
* command-line server utility that allows a VNC viewer to connect to an
* actual X display (as the above do). The only non-standard dependency
* of this program is the static library libvncserver.a (although in
* some environments libjpeg.so may not be readily available and needs
* to be installed, it may be found at ftp://ftp.uu.net/graphics/jpeg/).
* To increase portability it is written in plain C.
* command-line server utility that allows a VNC viewer to connect
* to an actual X display (as the above do). The only non-standard
* dependency of this program is the static library libvncserver.a.
* Although in some environments libjpeg.so or libz.so may not be
* readily available and needs to be installed, they may be found
* at ftp://ftp.uu.net/graphics/jpeg/ and http://www.gzip.org/zlib/,
* respectively. To increase portability it is written in plain C.
*
*
The next
goal is to improve performance and interactive response.
*
Another
goal is to improve performance and interactive response.
* The algorithm of x0rfbserver was used as a base. Additional heuristics
* are also applied (currently there are a bit too many of these...)
*
* Another goal is to add many features that enable and incourage creative
* Ausage and application of the tool. pologies for the large number
* Aof options!
*
* To build:
*
* Obtain the libvncserver package (http://libvncserver.sourceforge.net).
...
...
@@ -53,12 +58,13 @@
* Known shortcomings:
*
* The screen updates are good, but of course not perfect since the X
* display must be continuously polled and read for changes (as opposed to
* receiving a change callback from the X server, if that were generally
* possible... (Update: this seems to be handled now with the X DAMAGE
* extension, but unfortunately that doesn't seem to address the slow
* read from the video h/w). So, e.g., opaque moves and similar window
* activity can be very painful; one has to modify one's behavior a bit.
* display must be continuously polled and read for changes and this is
* slow for most hardware. This can be contrasted with receiving a change
* callback from the X server, if that were generally possible... (Update:
* this seems to be handled now with the X DAMAGE extension, but
* unfortunately that doesn't seem to address the slow read from the
* video h/w. So, e.g., opaque moves and similar window activity can
* be very painful; one has to modify one's behavior a bit.
*
* General audio at the remote display is lost unless one separately
* sets up some audio side-channel such as esd.
...
...
@@ -73,7 +79,10 @@
* the -cursor option. Further, if -cursorX or -X is used, a trick
* is done to at least show the root window cursor vs non-root cursor.
* (perhaps some heuristic can be done to further distinguish cases...,
* currently -cursor some is a first hack at this)
* currently "-cursor some" is a first hack at this)
*
* Under XFIXES mode for showing the cursor shape, the cursor may be
* poorly approximated if it has transparency.
*
* Windows using visuals other than the default X visual may have
* their colors messed up. When using 8bpp indexed color, the colormap
...
...
@@ -83,9 +92,16 @@
* 24 visuals will incorrectly display windows using the non-default one.
* On Sun and Sgi hardware we can to work around this with -overlay.
*
* Feature -id <windowid> can be picky: it can crash for things like the
* window not sufficiently mapped into server memory, etc. SaveUnders
* menus, popups, etc will not be seen.
* Feature -id <windowid> can be picky: it can crash for things like
* the window not sufficiently mapped into server memory, etc (Update:
* we now use the -xrandr mechanisms to trap errors for this mode).
* SaveUnders menus, popups, etc will not be seen.
*
* Under some situations the keysym unmapping is not correct, especially
* if the two keyboards correspond to different languages. The -modtweak
* option is the default and corrects most problems. One can use the
* -xkb option to try to use the XKEYBOARD extension to clear up any
* remaining problems.
*
* Occasionally, a few tile updates can be missed leaving a patch of
* color that needs to be refreshed. This may only be when threaded,
...
...
@@ -113,15 +129,23 @@
/*
* if you are inserting this file, x11vnc.c into an old CVS tree you
* may need to set OLD_TREE to 1.
* may need to set OLD_TREE to 1.
See below for LibVNCServer 0.7 tips.
*/
#define OLD_TREE 0
#if OLD_TREE
/*
* if have a very old tree and get errors these may be needed as well:
* if you have a very old tree (LibVNCServer 0.6) and get errors these may
* be need to be uncommented. LibVNCServer <= 0.5 is no longer supported.
* note the maxRectsPerUpdate below is a hack that may break some usage.
#define oldCursorX cursorX
#define oldCursorY cursorY
#define thisHost rfbThisHost
#define framebufferUpdateMessagesSent rfbFramebufferUpdateMessagesSent
#define bytesSent rfbBytesSent
#define rawBytesEquivalent rfbRawBytesEquivalent
#define progressiveSliceHeight maxRectsPerUpdate
*/
/*
...
...
@@ -189,8 +213,29 @@
#else
#define RFBUNDRAWCURSOR(s)
#endif
/*
* To get a clean build in a LibVNCServer 0.7 source tree no need for
* OLD_TREE, you just need to either download the forgotten tkx11vnc.h
* file or run:
*
* echo 'char gui_code[] = "";' > tkx11vnc.h
*
* (this disables the gui) and uncomment this line:
#define rfbSetCursor(a, b) rfbSetCursor((a), (b), FALSE)
*/
/*
* To get a clean build on LibVNCServer 0.7.1 no need for OLD_TREE,
* just uncomment this line (note the maxRectsPerUpdate below is a hack
* that may break some usage):
*
#define listenInterface maxRectsPerUpdate
*/
#if LIBVNCSERVER_HAVE_XSHM
# if defined(__hpux) && defined(__ia64)
/* something weird on hp/itanic */
# undef _INCLUDE_HPUX_SOURCE
# endif
#include <sys/ipc.h>
#include <sys/shm.h>
#include <X11/extensions/XShm.h>
...
...
@@ -290,7 +335,7 @@ static int xdamage_base_event_type;
#endif
/* date +'lastmod: %Y-%m-%d' */
char
lastmod
[]
=
"0.7.
1 lastmod: 2005-02-23
"
;
char
lastmod
[]
=
"0.7.
2pre lastmod: 2005-03-04
"
;
/* X display info */
...
...
@@ -579,6 +624,7 @@ int safe_remote_only = 0; /* -safer, -unsafe */
int
started_as_root
=
0
;
char
*
users_list
=
NULL
;
/* -users */
char
*
allow_list
=
NULL
;
/* for -allow and -localhost */
char
*
listen_str
=
NULL
;
char
*
allow_once
=
NULL
;
/* one time -allow */
char
*
accept_cmd
=
NULL
;
/* for -accept */
char
*
gone_cmd
=
NULL
;
/* for -gone */
...
...
@@ -1688,7 +1734,7 @@ typedef unsigned int in_addr_t;
in_addr_t
iaddr
;
iaddr
=
inet_addr
(
ip
);
if
(
iaddr
==
INADDR_NONE
)
{
if
(
iaddr
==
htonl
(
INADDR_NONE
)
)
{
return
strdup
(
"unknown"
);
}
...
...
@@ -7140,7 +7186,7 @@ void reset_httpport(int old, int new) {
close
(
screen
->
httpListenSock
);
}
rfbLog
(
"reset_httpport: setting httpport %d -> %d.
\n
"
,
old
,
hp
);
old
==
-
1
?
hp
:
old
,
hp
);
rfbHttpInitSockets
(
screen
);
}
}
...
...
@@ -7171,7 +7217,7 @@ void reset_rfbport(int old, int new) {
}
rfbLog
(
"reset_rfbport: setting rfbport %d -> %d.
\n
"
,
old
,
rp
);
old
==
-
1
?
rp
:
old
,
rp
);
rfbInitSockets
(
screen
);
maxfd
=
screen
->
maxFd
;
...
...
@@ -7731,7 +7777,9 @@ char *process_remote_cmd(char *cmd, int stringonly) {
char
*
before
,
*
old
;
if
(
query
)
{
int
state
=
0
;
if
(
allow_list
&&
!
strcmp
(
allow_list
,
"127.0.0.1"
))
{
char
*
s
=
allow_list
;
if
(
s
&&
(
!
strcmp
(
s
,
"127.0.0.1"
)
||
!
strcmp
(
s
,
"localhost"
)))
{
state
=
1
;
}
snprintf
(
buf
,
bufn
,
"ans=%s:%d"
,
p
,
state
);
...
...
@@ -7753,11 +7801,26 @@ char *process_remote_cmd(char *cmd, int stringonly) {
}
if
(
old
)
free
(
old
);
free
(
before
);
if
(
listen_str
)
{
free
(
listen_str
);
}
listen_str
=
strdup
(
"localhost"
);
screen
->
listenInterface
=
htonl
(
INADDR_LOOPBACK
);
rfbLog
(
"listening on loopback network only.
\n
"
);
rfbLog
(
"allow list is: '%s'
\n
"
,
NONUL
(
allow_list
));
reset_rfbport
(
-
1
,
screen
->
port
);
if
(
screen
->
httpListenSock
>
-
1
)
{
reset_httpport
(
-
1
,
screen
->
httpPort
);
}
}
else
if
(
!
strcmp
(
p
,
"nolocalhost"
))
{
char
*
before
,
*
old
;
if
(
query
)
{
int
state
=
0
;
if
(
allow_list
&&
!
strcmp
(
allow_list
,
"127.0.0.1"
))
{
char
*
s
=
allow_list
;
if
(
s
&&
(
!
strcmp
(
s
,
"127.0.0.1"
)
||
!
strcmp
(
s
,
"localhost"
)))
{
state
=
1
;
}
snprintf
(
buf
,
bufn
,
"ans=%s:%d"
,
p
,
!
state
);
...
...
@@ -7780,6 +7843,106 @@ char *process_remote_cmd(char *cmd, int stringonly) {
if
(
old
)
free
(
old
);
free
(
before
);
if
(
listen_str
)
{
free
(
listen_str
);
}
listen_str
=
NULL
;
screen
->
listenInterface
=
htonl
(
INADDR_ANY
);
rfbLog
(
"listening on ALL network interfaces.
\n
"
);
rfbLog
(
"allow list is: '%s'
\n
"
,
NONUL
(
allow_list
));
reset_rfbport
(
-
1
,
screen
->
port
);
if
(
screen
->
httpListenSock
>
-
1
)
{
reset_httpport
(
-
1
,
screen
->
httpPort
);
}
}
else
if
(
strstr
(
p
,
"listen"
)
==
p
)
{
char
*
before
;
int
ok
,
mod
=
0
;
COLON_CHECK
(
"listen:"
)
if
(
query
)
{
snprintf
(
buf
,
bufn
,
"ans=%s%s%s"
,
p
,
co
,
NONUL
(
listen_str
));
goto
qry
;
}
if
(
listen_str
)
{
before
=
strdup
(
listen_str
);
}
else
{
before
=
strdup
(
""
);
}
p
+=
strlen
(
"listen:"
);
listen_str
=
strdup
(
p
);
if
(
strcmp
(
before
,
listen_str
))
{
rfbLog
(
"process_remote_cmd: modified listen_str:
\n
"
);
rfbLog
(
" from:
\"
%s
\"\n
"
,
before
);
rfbLog
(
" to:
\"
%s
\"\n
"
,
listen_str
);
mod
=
1
;
}
ok
=
1
;
if
(
listen_str
==
NULL
||
*
listen_str
==
'\0'
||
!
strcmp
(
listen_str
,
"any"
))
{
screen
->
listenInterface
=
htonl
(
INADDR_ANY
);
}
else
if
(
!
strcmp
(
listen_str
,
"localhost"
))
{
screen
->
listenInterface
=
htonl
(
INADDR_LOOPBACK
);
}
else
{
struct
hostent
*
hp
;
in_addr_t
iface
=
inet_addr
(
listen_str
);
if
(
iface
==
htonl
(
INADDR_NONE
))
{
if
(
!
(
hp
=
gethostbyname
(
listen_str
)))
{
ok
=
0
;
}
else
{
iface
=
*
(
unsigned
long
*
)
hp
->
h_addr
;
}
}
if
(
ok
)
{
screen
->
listenInterface
=
iface
;
}
}
if
(
ok
&&
mod
)
{
int
is_loopback
=
0
;
in_addr_t
iface
=
screen
->
listenInterface
;
if
(
allow_list
)
{
if
(
!
strcmp
(
allow_list
,
"127.0.0.1"
)
||
!
strcmp
(
allow_list
,
"localhost"
))
{
is_loopback
=
1
;
}
}
if
(
iface
!=
htonl
(
INADDR_LOOPBACK
))
{
if
(
is_loopback
)
{
rfbLog
(
"re-setting -allow list to all "
"hosts for non-loopback listening.
\n
"
);
free
(
allow_list
);
allow_list
=
NULL
;
}
}
else
{
if
(
!
is_loopback
)
{
if
(
allow_list
)
{
free
(
allow_list
);
}
rfbLog
(
"setting -allow list to 127.0.0.1
\n
"
);
allow_list
=
strdup
(
"127.0.0.1"
);
}
}
}
if
(
ok
)
{
rfbLog
(
"allow list is: '%s'
\n
"
,
NONUL
(
allow_list
));
reset_rfbport
(
-
1
,
screen
->
port
);
if
(
screen
->
httpListenSock
>
-
1
)
{
reset_httpport
(
-
1
,
screen
->
httpPort
);
}
free
(
before
);
}
else
{
rfbLog
(
"bad listen string: %s
\n
"
,
listen_str
);
free
(
listen_str
);
listen_str
=
before
;
}
}
else
if
(
strstr
(
p
,
"accept"
)
==
p
)
{
COLON_CHECK
(
"accept:"
)
if
(
query
)
{
...
...
@@ -16079,7 +16242,7 @@ void initialize_speeds(void) {
s
=
strdup
(
"6,4,200"
);
}
else
if
(
!
strcmp
(
speeds_str
,
"dsl"
))
{
s
=
strdup
(
"6,100,50"
);
}
else
if
(
!
strcmp
(
speeds_str
,
"
modem
"
))
{
}
else
if
(
!
strcmp
(
speeds_str
,
"
lan
"
))
{
s
=
strdup
(
"6,5000,1"
);
}
else
{
s
=
strdup
(
speeds_str
);
...
...
@@ -16556,7 +16719,19 @@ static void print_help(int mode) {
" file containing addresses or prefixes that is re-read
\n
"
" each time a new client connects. Lines can be commented
\n
"
" out with the
\"
#
\"
character in the usual way.
\n
"
"-localhost Same as -allow 127.0.0.1
\n
"
"-localhost Same as
\"
-allow 127.0.0.1
\"
.
\n
"
"
\n
"
" Note: if you want to restrict which network interface
\n
"
" x11vnc listens on, see the -listen option below.
\n
"
" E.g.
\"
-listen localhost
\"
or
\"
-listen 192.168.3.21
\"
.
\n
"
" As a special case, the option
\"
-localhost
\"
implies
\n
"
"
\"
-listen localhost
\"
.
\n
"
"
\n
"
" For non-localhost -listen usage, if you use the remote
\n
"
" control mechanism (-R) to change the -listen interface
\n
"
" you may need to manually adjust the -allow list (and
\n
"
" vice versa) to avoid situations where no connections
\n
"
" (or too many) are allowed.
\n
"
"
\n
"
"-input string Fine tuning of allowed user input. If
\"
string
\"
does
\n
"
" not contain a comma
\"
,
\"
the tuning applies only to
\n
"
...
...
@@ -16708,7 +16883,7 @@ static void print_help(int mode) {
" database as well. So it
\"
lurks
\"
waiting for anyone
\n
"
" to log into an X session and then connects to it.
\n
"
" Specify a list of users after the = to limit which
\n
"
" users will be tried. To enable a differen
ce
searching
\n
"
" users will be tried. To enable a differen
t
searching
\n
"
" mode, if the first user in the list is something like
\n
"
"
\"
:0
\"
or
\"
:0-2
\"
that indicates a range of DISPLAY
\n
"
" numbers that will be tried (regardless of whether
\n
"
...
...
@@ -17286,6 +17461,7 @@ static void print_help(int mode) {
" use
\"
-host
\"
to delete a single host
\n
"
" localhost enable -localhost mode
\n
"
" nolocalhost disable -localhost mode
\n
"
" listen:str set -listen to str, empty to disable.
\n
"
" input:str set -input to
\"
str
\"
, empty to disable.
\n
"
" client_input:str set the K, M, B -input on a per-client
\n
"
" basis. select which client as for
\n
"
...
...
@@ -17456,7 +17632,7 @@ static void print_help(int mode) {
" overlay_nocursor visual scale viewonly noviewonly
\n
"
" shared noshared forever noforever once timeout deny
\n
"
" lock nodeny unlock connect allowonce allow localhost
\n
"
" nolocalhost accept gone shm noshm flipbyteorder
\n
"
" nolocalhost
listen
accept gone shm noshm flipbyteorder
\n
"
" noflipbyteorder onetile noonetile solid_color solid
\n
"
" nosolid blackout xinerama noxinerama xrandr noxrandr
\n
"
" xrandr_mode padgeom quiet q noquiet modtweak nomodtweak
\n
"
...
...
@@ -17606,6 +17782,11 @@ void set_vnc_desktop_name(void) {
if
(
screen
->
port
)
{
char
*
host
=
this_host
();
int
lport
=
screen
->
port
;
char
*
iface
=
listen_str
;
if
(
iface
!=
NULL
&&
*
iface
!=
'\0'
&&
strcmp
(
iface
,
"any"
))
{
host
=
iface
;
}
if
(
host
!=
NULL
)
{
/* note that vncviewer special cases 5900-5999 */
if
(
inetd
)
{
...
...
@@ -18159,7 +18340,7 @@ int main(int argc, char* argv[]) {
}
else
if
(
!
strcmp
(
arg
,
"-?"
)
||
!
strcmp
(
arg
,
"-opts"
))
{
print_help
(
1
);
}
else
if
(
!
strcmp
(
arg
,
"-V"
)
||
!
strcmp
(
arg
,
"-version"
))
{
fprintf
(
std
err
,
"x11vnc: %s
\n
"
,
lastmod
);
fprintf
(
std
out
,
"x11vnc: %s
\n
"
,
lastmod
);
exit
(
0
);
}
else
if
(
!
strcmp
(
arg
,
"-q"
)
||
!
strcmp
(
arg
,
"-quiet"
))
{
quiet
=
1
;
...
...
@@ -18377,6 +18558,9 @@ int main(int argc, char* argv[]) {
if
(
!
strcmp
(
arg
,
"-nevershared"
))
{
got_nevershared
=
1
;
}
if
(
!
strcmp
(
arg
,
"-listen"
)
&&
i
<
argc
-
1
)
{
listen_str
=
strdup
(
argv
[
i
+
1
]);
}
/* otherwise copy it for libvncserver use below. */
if
(
argc_vnc
<
100
)
{
argv_vnc
[
argc_vnc
++
]
=
strdup
(
arg
);
...
...
@@ -18615,6 +18799,18 @@ int main(int argc, char* argv[]) {
}
}
/* tie together cases of -localhost vs. -listen localhost */
if
(
!
listen_str
)
{
if
(
allow_list
&&
!
strcmp
(
allow_list
,
"127.0.0.1"
))
{
listen_str
=
strdup
(
"localhost"
);
argv_vnc
[
argc_vnc
++
]
=
strdup
(
"-listen"
);
argv_vnc
[
argc_vnc
++
]
=
strdup
(
listen_str
);
}
}
else
if
(
!
strcmp
(
listen_str
,
"localhost"
)
||
!
strcmp
(
listen_str
,
"127.0.0.1"
))
{
allow_list
=
strdup
(
"127.0.0.1"
);
}
if
(
!
quiet
)
{
fprintf
(
stderr
,
"
\n
"
);
fprintf
(
stderr
,
"Settings:
\n
"
);
...
...
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