diff options
Diffstat (limited to 'x11vnc/connections.c')
-rw-r--r-- | x11vnc/connections.c | 42 |
1 files changed, 36 insertions, 6 deletions
diff --git a/x11vnc/connections.c b/x11vnc/connections.c index 3492059..ac9d40c 100644 --- a/x11vnc/connections.c +++ b/x11vnc/connections.c @@ -48,6 +48,7 @@ void start_client_info_sock(char *host_port_cookie); void send_client_info(char *str); void adjust_grabs(int grab, int quiet); void check_new_clients(void); +int accept_client(rfbClientPtr client); static rfbClientPtr *client_match(char *str); @@ -58,7 +59,6 @@ static void ugly_geom(char *p, int *x, int *y); static int ugly_window(char *addr, char *userhost, int X, int Y, int timeout, char *mode, int accept); static int action_match(char *action, int rc); -static int accept_client(rfbClientPtr client); static void check_connect_file(char *file); static void send_client_connect(void); @@ -133,7 +133,11 @@ char *list_clients(void) { char *s = ident_username(cl); if (s) free(s); } - strcat(list, cd->username); + if (strstr(cd->username, "UNIX:") == cd->username) { + strcat(list, cd->username + strlen("UNIX:")); + } else { + strcat(list, cd->username); + } strcat(list, ":"); if (cd->unixname[0] == '\0') { strcat(list, "none"); @@ -996,7 +1000,15 @@ static unsigned char t2x2_bits[] = { XFlush_wr(dpy); if (accept) { - snprintf(strh, 100, "x11vnc: accept connection from %s?", addr); + char *ip = addr; + char *type = "accept"; + if (unixpw && strstr(userhost, "UNIX:") != userhost) { + type = "unixpw"; + if (openssl_last_ip) { + ip = openssl_last_ip; + } + } + snprintf(strh, 100, "x11vnc: %s connection from %s?", type, ip); } else { snprintf(strh, 100, "x11vnc: client disconnected from %s", addr); } @@ -1282,7 +1294,7 @@ static void ugly_geom(char *p, int *x, int *y) { * popup: use internal X widgets for prompting. * */ -static int accept_client(rfbClientPtr client) { +int accept_client(rfbClientPtr client) { char xmessage[200], *cmd = NULL; char *addr = client->host; @@ -1327,6 +1339,14 @@ static int accept_client(rfbClientPtr client) { mode = "both"; } + if (dpy == NULL && use_dpy && strstr(use_dpy, "WAIT:") == + use_dpy) { + rfbLog("accept_client: warning allowing client under conditions:\n"); + rfbLog(" -display WAIT:, dpy == NULL, -accept popup.\n"); + rfbLog(" There will be another popup.\n"); + return 1; + } + rfbLog("accept_client: using builtin popup for: %s\n", addr); if ((ret = ugly_window(addr, userhost, x, y, timeout, mode, 1))) { @@ -1526,6 +1546,7 @@ static int do_reverse_connect(char *str) { rfbLog("reverse connections disabled in -ssl mode.\n"); return 0; } + if (unixpw_in_progress) return 0; /* copy in to host */ host = (char *) malloc(len+1); @@ -1579,11 +1600,15 @@ static int do_reverse_connect(char *str) { * Break up comma separated list of hosts and call do_reverse_connect() */ void reverse_connect(char *str) { - char *p, *tmp = strdup(str); + char *p, *tmp; int sleep_between_host = 300; int sleep_min = 1500, sleep_max = 4500, n_max = 5; int n, tot, t, dt = 100, cnt = 0; + if (unixpw_in_progress) return; + + tmp = strdup(str); + p = strtok(tmp, ", \t\r\n"); while (p) { if ((n = do_reverse_connect(p)) != 0) { @@ -1887,7 +1912,6 @@ enum rfbNewClientAction new_client(rfbClientPtr client) { last_event = last_input = time(NULL); - if (inetd) { /* * Set this so we exit as soon as connection closes, @@ -2010,6 +2034,12 @@ if (0) fprintf(stderr, "SET ssl_helper_pid: %d\n", openssl_last_helper_pid); unixpw_last_try_time = time(NULL); unixpw_screen(1); unixpw_keystroke(0, 0, 1); + if (!unixpw_in_rfbPE) { + rfbLog("new client: %s in non-unixpw_in_rfbPE.\n", + client->host); + } + /* always put client on hold even if unixpw_in_rfbPE is true */ + return(RFB_CLIENT_ON_HOLD); } return(RFB_CLIENT_ACCEPT); |