diff options
author | Karsten Loesing <karsten.loesing@gmx.net> | 2008-07-10 21:02:01 +0000 |
---|---|---|
committer | Karsten Loesing <karsten.loesing@gmx.net> | 2008-07-10 21:02:01 +0000 |
commit | 9231858ff54d9c8eda671bf9fe69f019b136f35d (patch) | |
tree | 7ff1c5a3d33fbc2e109748d7337ad721a934a0b7 /src | |
parent | cb7cc9e12d66907343e1522e7128de206c0dc86f (diff) | |
download | tor-9231858ff54d9c8eda671bf9fe69f019b136f35d.tar.gz tor-9231858ff54d9c8eda671bf9fe69f019b136f35d.zip |
Fix bug 763. When a hidden service is giving up on an introduction point candidate that was not included in the last published rendezvous descriptor, don't reschedule publication of the next descriptor.
svn:r15825
Diffstat (limited to 'src')
-rw-r--r-- | src/common/tortls.c | 2 | ||||
-rw-r--r-- | src/or/rendservice.c | 23 |
2 files changed, 21 insertions, 4 deletions
diff --git a/src/common/tortls.c b/src/common/tortls.c index d2751d1653..67c68fe6d4 100644 --- a/src/common/tortls.c +++ b/src/common/tortls.c @@ -564,7 +564,7 @@ tor_tls_context_new(crypto_pk_env_t *identity, unsigned int key_lifetime) SSL_CTX_set_options(result->ctx, SSL_OP_NO_SSLv2); #endif SSL_CTX_set_options(result->ctx, SSL_OP_SINGLE_DH_USE); - + #ifdef SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION SSL_CTX_set_options(result->ctx, SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION); diff --git a/src/or/rendservice.c b/src/or/rendservice.c index b38d73e1c0..1965b12859 100644 --- a/src/or/rendservice.c +++ b/src/or/rendservice.c @@ -1256,14 +1256,31 @@ rend_services_introduce(void) for (j=0; j < smartlist_len(service->intro_nodes); ++j) { intro = smartlist_get(service->intro_nodes, j); router = router_get_by_digest(intro->extend_info->identity_digest); - if (!router || !find_intro_circuit(intro, service->pk_digest, - service->descriptor_version)) { + if (!router) { + log_warn(LD_BUG, "We have picked router %s as introduction point, " + "but we don't have its router descriptor. Skipping.", + intro->extend_info->nickname); + continue; + } + if (!find_intro_circuit(intro, service->pk_digest, + service->descriptor_version)) { log_info(LD_REND,"Giving up on %s as intro point for %s.", intro->extend_info->nickname, service->service_id); + if (service->desc) { + SMARTLIST_FOREACH(service->desc->intro_nodes, rend_intro_point_t *, + dintro, { + if (!memcmp(dintro->extend_info->identity_digest, + intro->extend_info->identity_digest, DIGEST_LEN)) { + log_info(LD_REND, "The intro point we are giving up on was " + "included in the last published descriptor. " + "Marking current descriptor as dirty."); + service->desc_is_dirty = now; + } + }); + } rend_intro_point_free(intro); smartlist_del(service->intro_nodes,j--); changed = 1; - service->desc_is_dirty = now; } smartlist_add(intro_routers, router); } |