diff options
Diffstat (limited to 'src/or/rendclient.c')
-rw-r--r-- | src/or/rendclient.c | 26 |
1 files changed, 17 insertions, 9 deletions
diff --git a/src/or/rendclient.c b/src/or/rendclient.c index 2fd0567b9..0f2dfa15c 100644 --- a/src/or/rendclient.c +++ b/src/or/rendclient.c @@ -8,11 +8,16 @@ void rend_client_introcirc_is_open(circuit_t *circ) { + circuit_t *rendcirc = NULL; assert(circ->purpose == CIRCUIT_PURPOSE_C_INTRODUCING); assert(CIRCUIT_IS_ORIGIN(circ) && circ->cpath); log_fn(LOG_INFO,"introcirc is open"); connection_ap_attach_pending(); + while ((rendcirc = circuit_get_next_by_pk_and_purpose( + rendcirc, circ->rend_pk_digest, CIRCUIT_PURPOSE_C_REND_READY))) { + rend_client_send_introduction(circ, rendcirc); + } } /* send the establish-rendezvous cell. if it fails, mark @@ -69,15 +74,18 @@ rend_client_send_introduction(circuit_t *introcirc, circuit_t *rendcirc) { } /* Initialize the pending_final_cpath and start the DH handshake. */ - cpath = rendcirc->build_state->pending_final_cpath = - tor_malloc_zero(sizeof(crypt_path_t)); - if (!(cpath->handshake_state = crypto_dh_new())) { - log_fn(LOG_WARN, "Couldn't allocate DH"); - goto err; - } - if (crypto_dh_generate_public(cpath->handshake_state)<0) { - log_fn(LOG_WARN, "Couldn't generate g^x"); - goto err; + cpath = rendcirc->build_state->pending_final_cpath; + if (!cpath) { + cpath = rendcirc->build_state->pending_final_cpath = + tor_malloc_zero(sizeof(crypt_path_t)); + if (!(cpath->handshake_state = crypto_dh_new())) { + log_fn(LOG_WARN, "Couldn't allocate DH"); + goto err; + } + if (crypto_dh_generate_public(cpath->handshake_state)<0) { + log_fn(LOG_WARN, "Couldn't generate g^x"); + goto err; + } } /* write the remaining items into tmp */ |