]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
Revert "hs: Implement a helper to repurpose a circuit"
authorMike Perry <mikeperry-git@torproject.org>
Wed, 5 Jun 2019 18:38:01 +0000 (11:38 -0700)
committerMike Perry <mikeperry-git@torproject.org>
Wed, 5 Jun 2019 18:38:01 +0000 (11:38 -0700)
This reverts commit 3789f22bcbfbc6de415a838e4c4bfb2555c7d6c3.

src/core/or/circuituse.c
src/feature/hs/hs_circuit.c
src/feature/hs/hs_circuit.h
src/feature/rend/rendcommon.c
src/feature/rend/rendcommon.h

index b3d5c6bb81520f2eec43d2e8d10d22270e00bbdc..485c3890542a554f179489b4ac2bee4abe91ffd7 100644 (file)
@@ -3068,12 +3068,6 @@ circuit_change_purpose(circuit_t *circ, uint8_t new_purpose)
 
   if (circ->purpose == new_purpose) return;
 
-  /* Take specific actions if we are repurposing a hidden service circuit. */
-  if (circuit_purpose_is_hidden_service(circ->purpose) &&
-      !circuit_purpose_is_hidden_service(new_purpose)) {
-    hs_circ_repurpose(circ);
-  }
-
   if (CIRCUIT_IS_ORIGIN(circ)) {
     char old_purpose_desc[80] = "";
 
index 79377eb731426e50cb1edce38fa1075c6ca694ea..a6e86c5ab3b184c08a5a98b667d919dbdad45246 100644 (file)
@@ -25,7 +25,6 @@
 #include "feature/nodelist/describe.h"
 #include "feature/nodelist/nodelist.h"
 #include "feature/rend/rendservice.h"
-#include "feature/rend/rendcommon.h"
 #include "feature/stats/rephist.h"
 #include "lib/crypt_ops/crypto_dh.h"
 #include "lib/crypt_ops/crypto_rand.h"
@@ -1193,33 +1192,3 @@ hs_circ_cleanup(circuit_t *circ)
     hs_circuitmap_remove_circuit(circ);
   }
 }
-
-/* The given circuit will be repurposed so take the appropriate actions. A
- * cleanup from the HS maps and of all HS related structures is done.
- *
- * Once this function returns, the circuit can be safely repurposed. */
-void
-hs_circ_repurpose(circuit_t *circ)
-{
-  origin_circuit_t *origin_circ;
-
-  tor_assert(circ);
-
-  /* Only repurposing an origin circuit is possible for HS. */
-  if (!CIRCUIT_IS_ORIGIN(circ)) {
-    return;
-  }
-  origin_circ = TO_ORIGIN_CIRCUIT(circ);
-
-  /* First, cleanup the circuit from the HS maps. */
-  hs_circ_cleanup(circ);
-
-  /* Depending on the version, different cleanup is done. */
-  if (origin_circ->rend_data) {
-    /* v2. */
-    rend_circ_cleanup(origin_circ);
-  } else if (origin_circ->hs_ident) {
-    /* v3. */
-    hs_ident_circuit_free(origin_circ->hs_ident);
-  }
-}
index 0786f3ee45af3a2450ef18433c784588f627a2e3..b8d8b25add07a074b18a9400ffbfb1de0b841ff5 100644 (file)
@@ -16,7 +16,6 @@
 
 /* Cleanup function when the circuit is closed or/and freed. */
 void hs_circ_cleanup(circuit_t *circ);
-void hs_circ_repurpose(circuit_t *circ);
 
 /* Circuit API. */
 int hs_circ_service_intro_has_opened(hs_service_t *service,
index 265ee368f10dfa02dfbc1b5fbb9557c6cb01268c..777de2984c7fb1e9078b254625c0dcb67492242e 100644 (file)
@@ -1046,14 +1046,3 @@ rend_circuit_pk_digest_eq(const origin_circuit_t *ocirc,
  match:
   return 1;
 }
-
-/* Cleanup the given circuit of all HS v2 data structure. */
-void
-rend_circ_cleanup(origin_circuit_t *circ)
-{
-  tor_assert(circ);
-
-  /* Both fields are set to NULL with these. */
-  crypto_pk_free(circ->intro_key);
-  rend_data_free(circ->rend_data);
-}
index c9a04846d7cf805e9efb5b5933c8cfda3dc79910..f136863c7aba793bb33adb19b3df6d504367dc09 100644 (file)
@@ -71,8 +71,6 @@ int rend_non_anonymous_mode_enabled(const or_options_t *options);
 void assert_circ_anonymity_ok(const origin_circuit_t *circ,
                               const or_options_t *options);
 
-void rend_circ_cleanup(origin_circuit_t *circ);
-
 #ifdef RENDCOMMON_PRIVATE
 
 STATIC int