diff options
author | David Goulet <dgoulet@ev0ke.net> | 2015-01-28 18:01:53 -0500 |
---|---|---|
committer | David Goulet <dgoulet@ev0ke.net> | 2015-01-28 18:01:53 -0500 |
commit | ebc59092bc6badaa55743d85e6095c3e2d4993ff (patch) | |
tree | 92be607c19dbb6b89f8ad957ed1cd246770c0c0d /src/or/rendservice.c | |
parent | bf3fb55c4721cf9228c24060a15397d2b8a62ee7 (diff) | |
download | tor-ebc59092bc6badaa55743d85e6095c3e2d4993ff.tar.gz tor-ebc59092bc6badaa55743d85e6095c3e2d4993ff.zip |
Make hidden service use the config unix prefix
Signed-off-by: David Goulet <dgoulet@ev0ke.net>
Diffstat (limited to 'src/or/rendservice.c')
-rw-r--r-- | src/or/rendservice.c | 25 |
1 files changed, 9 insertions, 16 deletions
diff --git a/src/or/rendservice.c b/src/or/rendservice.c index 8d3f041759..69ea6a9857 100644 --- a/src/or/rendservice.c +++ b/src/or/rendservice.c @@ -341,7 +341,6 @@ parse_port_config(const char *string) tor_addr_t addr; const char *addrport; rend_service_port_config_t *result = NULL; - const char *socket_prefix = "socket:"; unsigned int is_unix_addr = 0; char *socket_path = NULL; @@ -365,25 +364,19 @@ parse_port_config(const char *string) realport = virtport; tor_addr_from_ipv4h(&addr, 0x7F000001u); /* 127.0.0.1 */ } else { + int ret; + addrport = smartlist_get(sl,1); - /* If it starts with socket:, try to parse it as a socket path */ - if (!strcmpstart(addrport, socket_prefix)) { - if (strlen(addrport + strlen(socket_prefix)) > 0) { -#ifdef HAVE_SYS_UN_H - is_unix_addr = 1; - socket_path = tor_strdup(addrport + strlen(socket_prefix)); -#else - log_warn(LD_CONFIG, - "Hidden service port configuration %s is for an AF_UNIX " - "socket, but we have no support available on this platform", - escaped(addrport)); - goto err; -#endif /* defined(HAVE_SYS_UN_H) */ - } else { + ret = config_parse_unix_port(addrport, &socket_path); + if (ret < 0 && ret != ENOENT) { + if (ret == -EINVAL) { log_warn(LD_CONFIG, "Empty socket path in hidden service port configuration."); - goto err; } + goto err; + } + if (socket_path) { + is_unix_addr = 1; } else if (strchr(addrport, ':') || strchr(addrport, '.')) { /* else try it as an IP:port pair if it has a : or . in it */ if (tor_addr_port_lookup(addrport, &addr, &p)<0) { |