summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/or/rendcommon.c2
-rw-r--r--src/or/rendservice.c7
2 files changed, 5 insertions, 4 deletions
diff --git a/src/or/rendcommon.c b/src/or/rendcommon.c
index 287d089459..a90f6a6116 100644
--- a/src/or/rendcommon.c
+++ b/src/or/rendcommon.c
@@ -146,7 +146,7 @@ rend_parse_service_descriptor(const char *str, size_t len)
result->protocols = ntohs(get_uint16(cp));
cp += 2;
} else {
- result->protocols = 1;
+ result->protocols = 1<<2; /* always use intro format 2 */
}
if (end-cp < 2) goto truncated;
result->n_intro_points = ntohs(get_uint16(cp));
diff --git a/src/or/rendservice.c b/src/or/rendservice.c
index 3b509a0e4b..0e05dc23f7 100644
--- a/src/or/rendservice.c
+++ b/src/or/rendservice.c
@@ -303,16 +303,17 @@ rend_service_update_descriptor(rend_service_t *service)
d->intro_point_extend_info = tor_malloc_zero(sizeof(extend_info_t*)*n);
d->protocols = (1<<2) | (1<<0); /* We support protocol 2 and protocol 0. */
for (i=0; i < n; ++i) {
- router = router_get_by_nickname(smartlist_get(service->intro_nodes, i),1);
+ const char *name = smartlist_get(service->intro_nodes, i);
+ router = router_get_by_nickname(name, 1);
if (!router) {
log_info(LD_REND,"Router '%s' not found for intro point %d. Skipping.",
- safe_str((char*)smartlist_get(service->intro_nodes, i)), i);
+ safe_str(name), i);
continue;
}
circ = find_intro_circuit(router, service->pk_digest);
if (circ && circ->_base.purpose == CIRCUIT_PURPOSE_S_INTRO) {
/* We have an entirely established intro circuit. */
- d->intro_points[d->n_intro_points] = tor_strdup(router->nickname);
+ d->intro_points[d->n_intro_points] = tor_strdup(name);
d->intro_point_extend_info[d->n_intro_points] =
extend_info_from_router(router);
d->n_intro_points++;