summaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorGeorge Kadianakis <desnacked@gmail.com>2011-07-18 16:42:31 +0200
committerGeorge Kadianakis <desnacked@gmail.com>2011-07-18 16:42:31 +0200
commit51cdd30c01c47e3522bd49a23a83a566cf4de5a7 (patch)
treecf4c4b3f3f3016044480a06a0cab58e067194b70 /src/or
parent14c5a24fe74f7ebaf94c69721025f142d42ef1e0 (diff)
downloadtor-51cdd30c01c47e3522bd49a23a83a566cf4de5a7.tar.gz
tor-51cdd30c01c47e3522bd49a23a83a566cf4de5a7.zip
Let's be smarter while parsing {Client,Server}TransportPlugin lines.
Diffstat (limited to 'src/or')
-rw-r--r--src/or/config.c64
-rw-r--r--src/or/transports.c1
2 files changed, 29 insertions, 36 deletions
diff --git a/src/or/config.c b/src/or/config.c
index da35270b4b..02925f39b8 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -4702,22 +4702,25 @@ parse_client_transport_line(const char *line, int validate_only)
/* managed proxy options */
int is_managed=0;
char **proxy_argv=NULL;
+ char **tmp=NULL;
+ int proxy_argc,i;
+
+ int line_length;
items = smartlist_create();
smartlist_split_string(items, line, NULL,
SPLIT_SKIP_SPACE|SPLIT_IGNORE_BLANK, -1);
- if (smartlist_len(items) < 3) {
+ line_length = smartlist_len(items);
+ if (line_length < 3) {
log_warn(LD_CONFIG, "Too few arguments on ClientTransportPlugin line.");
goto err;
}
name = smartlist_get(items, 0);
- smartlist_del_keeporder(items, 0);
/* field2 is either a SOCKS version or "exec" */
- field2 = smartlist_get(items, 0);
- smartlist_del_keeporder(items, 0);
+ field2 = smartlist_get(items, 1);
if (!strcmp(field2,"socks4")) {
socks_ver = PROXY_SOCKS4;
@@ -4735,16 +4738,12 @@ parse_client_transport_line(const char *line, int validate_only)
if (!validate_only) { /* if we are not just validating, use the
rest of the line as the argv of the proxy
to be launched */
- char **tmp;
- char *tmp_arg;
- proxy_argv = tor_malloc_zero(sizeof(char*)*(smartlist_len(items)+1));
+ proxy_argc = line_length-2;
+ tor_assert(proxy_argc > 0);
+ proxy_argv = tor_malloc_zero(sizeof(char*)*(proxy_argc+1));
tmp = proxy_argv;
- while (smartlist_len(items)) {
- tmp_arg = smartlist_get(items, 0);
- smartlist_del_keeporder(items, 0);
- *tmp++ = tor_strdup(tmp_arg);
- tor_free(tmp_arg);
- }
+ for (i=0;i<proxy_argc;i++) /* store arguments */
+ *tmp++ = smartlist_get(items, 2+i);
*tmp = NULL; /*terminated with NUL pointer, just like execve() likes it*/
if (pt_managed_launch_client_proxy(name, proxy_argv) < 0) {
@@ -4754,8 +4753,7 @@ parse_client_transport_line(const char *line, int validate_only)
}
}
} else { /* external */
- addrport = smartlist_get(items, 0);
- smartlist_del_keeporder(items, 0);
+ addrport = smartlist_get(items, 2);
if (tor_addr_port_parse(addrport, &addr, &port)<0) {
log_warn(LD_CONFIG, "Error parsing transport "
@@ -4788,9 +4786,7 @@ parse_client_transport_line(const char *line, int validate_only)
done:
SMARTLIST_FOREACH(items, char*, s, tor_free(s));
smartlist_free(items);
- tor_free(name);
- tor_free(field2);
- tor_free(addrport);
+ tor_free(proxy_argv);
return r;
}
@@ -4813,21 +4809,24 @@ parse_server_transport_line(const char *line, int validate_only)
/* managed proxy options */
int is_managed=0;
char **proxy_argv=NULL;
+ char **tmp=NULL;
+ int proxy_argc,i;
+
+ int line_length;
items = smartlist_create();
smartlist_split_string(items, line, NULL,
SPLIT_SKIP_SPACE|SPLIT_IGNORE_BLANK, -1);
- if (smartlist_len(items) < 3) {
+ line_length = smartlist_len(items);
+ if (line_length < 3) {
log_warn(LD_CONFIG, "Too few arguments on ServerTransportPlugin line.");
goto err;
}
name = smartlist_get(items, 0);
- smartlist_del_keeporder(items, 0);
- type = smartlist_get(items, 0);
- smartlist_del_keeporder(items, 0);
+ type = smartlist_get(items, 1);
if (!strcmp(type, "exec")) {
is_managed=1;
@@ -4840,16 +4839,13 @@ parse_server_transport_line(const char *line, int validate_only)
if (is_managed) { /* managed */
if (!validate_only) {
- char **tmp;
- char *tmp_arg;
- proxy_argv = tor_malloc_zero(sizeof(char*)*(smartlist_len(items)+1));
+ proxy_argc = line_length-2;
+ tor_assert(proxy_argc > 0);
+ proxy_argv = tor_malloc_zero(sizeof(char*)*(proxy_argc+1));
tmp = proxy_argv;
- while (smartlist_len(items)) {
- tmp_arg = smartlist_get(items, 0);
- smartlist_del_keeporder(items, 0);
- *tmp++ = tor_strdup(tmp_arg);
- tor_free(tmp_arg);
- }
+
+ for (i=0;i<proxy_argc;i++) /* store arguments */
+ *tmp++ = smartlist_get(items, 2+i);
*tmp = NULL; /*terminated with NUL pointer, just like execve() likes it*/
if (pt_managed_launch_server_proxy(name, proxy_argv) < 0) { /* launch it! */
@@ -4859,8 +4855,7 @@ parse_server_transport_line(const char *line, int validate_only)
}
}
} else { /* external */
- addrport = smartlist_get(items, 0);
- smartlist_del_keeporder(items, 0);
+ addrport = smartlist_get(items, 2);
if (tor_addr_port_parse(addrport, &addr, &port)<0) {
log_warn(LD_CONFIG, "Error parsing transport "
@@ -4888,8 +4883,7 @@ parse_server_transport_line(const char *line, int validate_only)
done:
SMARTLIST_FOREACH(items, char*, s, tor_free(s));
smartlist_free(items);
- tor_free(name);
- tor_free(type);
+ tor_free(proxy_argv);
return r;
}
diff --git a/src/or/transports.c b/src/or/transports.c
index 6589a8cd97..930cb8c0ce 100644
--- a/src/or/transports.c
+++ b/src/or/transports.c
@@ -106,7 +106,6 @@ pt_managed_launch_proxy(const char *method,
/* free the memory allocated for the execve() */
free_execve_args(envp);
- free_execve_args(proxy_argv);
/* Set stdout/stderr pipes to be non-blocking */
fcntl(stdout_pipe, F_SETFL, O_NONBLOCK);