diff options
Diffstat (limited to 'x11vnc/connections.c')
-rw-r--r-- | x11vnc/connections.c | 47 |
1 files changed, 42 insertions, 5 deletions
diff --git a/x11vnc/connections.c b/x11vnc/connections.c index 2b7d2df..52b3f2a 100644 --- a/x11vnc/connections.c +++ b/x11vnc/connections.c @@ -2338,6 +2338,7 @@ static int do_reverse_connect(char *str_in) { write(vncsock, prestring, prestring_len); free(prestring); } +/* XXX use header */ #define OPENSSL_REVERSE 4 openssl_init(1); accept_openssl(OPENSSL_REVERSE, vncsock); @@ -2345,6 +2346,7 @@ static int do_reverse_connect(char *str_in) { free(host); return 1; } + if (use_stunnel) { if(strcmp(host, "localhost") && strcmp(host, "127.0.0.1")) { if (!getenv("STUNNEL_DISABLE_LOCALHOST")) { @@ -2427,20 +2429,31 @@ void reverse_connect(char *str) { int sleep_min = 1500, sleep_max = 4500, n_max = 5; int n, tot, t, dt = 100, cnt = 0; int nclients0 = client_count; + int lcnt, j; + char **list; if (unixpw_in_progress) return; tmp = strdup(str); + list = (char **) calloc( (strlen(tmp)+2) * sizeof (char *), 1); + lcnt = 0; + p = strtok(tmp, ", \t\r\n"); while (p) { + list[lcnt++] = strdup(p); + p = strtok(NULL, ", \t\r\n"); + } + free(tmp); + + for (j = 0; j < lcnt; j++) { + p = list[j]; + if ((n = do_reverse_connect(p)) != 0) { rfbPE(-1); } cnt += n; - - p = strtok(NULL, ", \t\r\n"); - if (p) { + if (list[j+1] != NULL) { t = 0; while (t < sleep_between_host) { usleep(dt * 1000); @@ -2449,7 +2462,12 @@ void reverse_connect(char *str) { } } } - free(tmp); + + for (j = 0; j < lcnt; j++) { + p = list[j]; + if (p) free(p); + } + free(list); if (cnt == 0) { if (connect_or_exit) { @@ -2739,6 +2757,9 @@ void check_gui_inputs(void) { for (i=0; i<n; i++) { int k, fd = icon_mode_socks[socks[i]]; char *p; + char **list; + int lind; + if (! FD_ISSET(fd, &fds)) { continue; } @@ -2752,8 +2773,18 @@ void check_gui_inputs(void) { continue; } + list = (char **) calloc((strlen(buf)+2) * sizeof(char *), 1); + + lind = 0; p = strtok(buf, "\r\n"); while (p) { + list[lind++] = strdup(p); + p = strtok(NULL, "\r\n"); + } + + lind = 0; + while (list[lind] != NULL) { + p = list[lind++]; if (strstr(p, "cmd=") == p || strstr(p, "qry=") == p) { char *str = process_remote_cmd(p, 1); @@ -2769,8 +2800,14 @@ void check_gui_inputs(void) { break; } } - p = strtok(NULL, "\r\n"); } + + lind = 0; + while (list[lind] != NULL) { + p = list[lind++]; + if (p) free(p); + } + free(list); } } |