summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2006-12-07 17:04:44 +0000
committerNick Mathewson <nickm@torproject.org>2006-12-07 17:04:44 +0000
commit26392fc75de5923787a74f405398295bc14073fb (patch)
tree91d9ef243f1e6ae29880f560e7f4abe98d0953c9 /src
parent8249f5d676ee6b1e4e0774ade10f8052f4772108 (diff)
downloadtor-26392fc75de5923787a74f405398295bc14073fb.tar.gz
tor-26392fc75de5923787a74f405398295bc14073fb.zip
r11458@Kushana: nickm | 2006-12-07 12:04:22 -0500
Fix bug 338: log verbose nicknames, not just keys, for intro points. Also, suppress intro point name logging when SafeLogging is 1. (The security part is a possible backport candidate.) svn:r9041
Diffstat (limited to 'src')
-rw-r--r--src/or/rendservice.c30
1 files changed, 19 insertions, 11 deletions
diff --git a/src/or/rendservice.c b/src/or/rendservice.c
index d53fd45f23..4afb911650 100644
--- a/src/or/rendservice.c
+++ b/src/or/rendservice.c
@@ -305,8 +305,8 @@ rend_service_update_descriptor(rend_service_t *service)
for (i=0; i < n; ++i) {
router = router_get_by_nickname(smartlist_get(service->intro_nodes, i),1);
if (!router) {
- log_info(LD_REND,"Router '%s' not found. Skipping.",
- (char*)smartlist_get(service->intro_nodes, i));
+ log_info(LD_REND,"Router '%s' not found for intro point %d. Skipping.",
+ safe_str((char*)smartlist_get(service->intro_nodes, i)), i);
continue;
}
circ = find_intro_circuit(router, service->pk_digest);
@@ -540,7 +540,7 @@ rend_service_introduce(origin_circuit_t *circuit, const char *request,
router = router_get_by_nickname(rp_nickname, 0);
if (!router) {
log_info(LD_REND, "Couldn't find router %s named in rendezvous cell.",
- escaped(rp_nickname));
+ escaped_safe_str(rp_nickname));
/* XXXX Add a no-such-router reason? */
reason = END_CIRC_REASON_TORPROTOCOL;
goto err;
@@ -591,7 +591,7 @@ rend_service_introduce(origin_circuit_t *circuit, const char *request,
if (!launched) { /* give up */
log_warn(LD_REND, "Giving up launching first hop of circuit to rendezvous "
"point '%s' for service %s.",
- extend_info->nickname, serviceid);
+ escaped_safe_str(extend_info->nickname), serviceid);
reason = END_CIRC_REASON_CONNECTFAILED;
goto err;
}
@@ -1110,7 +1110,8 @@ rend_service_dump_stats(int severity)
int i,j;
routerinfo_t *router;
rend_service_t *service;
- char *nickname;
+ const char *nickname, *safe_name;
+ char nn_buf[MAX_VERBOSE_NICKNAME_LEN];
origin_circuit_t *circ;
for (i=0; i < smartlist_len(rend_service_list); ++i) {
@@ -1119,19 +1120,26 @@ rend_service_dump_stats(int severity)
service->directory);
for (j=0; j < smartlist_len(service->intro_nodes); ++j) {
nickname = smartlist_get(service->intro_nodes, j);
- router = router_get_by_nickname(smartlist_get(service->intro_nodes,j),1);
+ router = router_get_by_nickname(nickname,1);
+ if (router) {
+ router_get_verbose_nickname(nn_buf, router);
+ nickname = nn_buf;
+ }
+ safe_name = safe_str(nickname);
+
if (!router) {
- log(severity, LD_GENERAL, " Intro point at %s: unrecognized router",
- nickname);
+ log(severity, LD_GENERAL, " Intro point %d at %s: unrecognized router",
+ j, safe_name);
continue;
}
circ = find_intro_circuit(router, service->pk_digest);
if (!circ) {
- log(severity, LD_GENERAL, " Intro point at %s: no circuit",nickname);
+ log(severity, LD_GENERAL, " Intro point %d at %s: no circuit",
+ j, safe_name);
continue;
}
- log(severity, LD_GENERAL, " Intro point at %s: circuit is %s",nickname,
- circuit_state_to_string(circ->_base.state));
+ log(severity, LD_GENERAL, " Intro point %d at %s: circuit is %s",
+ j, safe_name, circuit_state_to_string(circ->_base.state));
}
}
}