diff options
author | David Goulet <dgoulet@torproject.org> | 2019-05-28 14:43:28 -0400 |
---|---|---|
committer | George Kadianakis <desnacked@riseup.net> | 2019-11-18 19:06:43 +0200 |
commit | fbc18c8989bae0e2acb5d903f2bd5b0648bad828 (patch) | |
tree | 39e107b736314a74a2ebe97ba789cecebbba751f /src/feature/dirclient/dirclient.c | |
parent | 80f241907c1b3d69784de98e9ff3f96d5c37f51b (diff) | |
download | tor-fbc18c8989bae0e2acb5d903f2bd5b0648bad828.tar.gz tor-fbc18c8989bae0e2acb5d903f2bd5b0648bad828.zip |
hs-v3: Refactor descriptor dir fetch done code
This commit extract most of the code that dirclient.c had to handle the end of
a descriptor directory requests (fetch). It is moved into hs_client.c in order
to have one single point of entry and the rest is fully handled by the HS
subsystem.
As part of #30382, depending on how the descriptor ended up stored (decoded or
not), different SOCKS error code can be returned.
Signed-off-by: David Goulet <dgoulet@torproject.org>
Diffstat (limited to 'src/feature/dirclient/dirclient.c')
-rw-r--r-- | src/feature/dirclient/dirclient.c | 80 |
1 files changed, 1 insertions, 79 deletions
diff --git a/src/feature/dirclient/dirclient.c b/src/feature/dirclient/dirclient.c index abece62dd4..6155a09a58 100644 --- a/src/feature/dirclient/dirclient.c +++ b/src/feature/dirclient/dirclient.c @@ -2722,91 +2722,13 @@ handle_response_fetch_hsdesc_v3(dir_connection_t *conn, const char *reason = args->reason; const char *body = args->body; const size_t body_len = args->body_len; - hs_desc_decode_status_t decode_status; tor_assert(conn->hs_ident); log_info(LD_REND,"Received v3 hsdesc (body size %d, status %d (%s))", (int)body_len, status_code, escaped(reason)); - switch (status_code) { - case 200: - /* We got something: Try storing it in the cache. */ - decode_status = hs_cache_store_as_client(body, - &conn->hs_ident->identity_pk); - switch (decode_status) { - case HS_DESC_DECODE_OK: - case HS_DESC_DECODE_NEED_CLIENT_AUTH: - case HS_DESC_DECODE_BAD_CLIENT_AUTH: - log_info(LD_REND, "Stored hidden service descriptor successfully."); - TO_CONN(conn)->purpose = DIR_PURPOSE_HAS_FETCHED_HSDESC; - if (decode_status == HS_DESC_DECODE_OK) { - hs_client_desc_has_arrived(conn->hs_ident); - } else { - /* This handles both client auth decode status. */ - hs_client_desc_missing_bad_client_auth(conn->hs_ident, decode_status); - log_info(LD_REND, "Stored hidden service descriptor requires " - "%s client authorization.", - decode_status == HS_DESC_DECODE_NEED_CLIENT_AUTH ? "missing" - : "new"); - } - /* Fire control port RECEIVED event. */ - hs_control_desc_event_received(conn->hs_ident, conn->identity_digest); - hs_control_desc_event_content(conn->hs_ident, conn->identity_digest, - body); - break; - case HS_DESC_DECODE_ENCRYPTED_ERROR: - case HS_DESC_DECODE_SUPERENC_ERROR: - case HS_DESC_DECODE_PLAINTEXT_ERROR: - case HS_DESC_DECODE_GENERIC_ERROR: - default: - log_info(LD_REND, "Failed to store hidden service descriptor. " - "Descriptor decoding status: %d", decode_status); - /* Fire control port FAILED event. */ - hs_control_desc_event_failed(conn->hs_ident, conn->identity_digest, - "BAD_DESC"); - hs_control_desc_event_content(conn->hs_ident, conn->identity_digest, - NULL); - break; - } - break; - case 404: - /* Not there. We'll retry when connection_about_to_close_connection() - * tries to clean this conn up. */ - log_info(LD_REND, "Fetching hidden service v3 descriptor not found: " - "Retrying at another directory."); - /* Fire control port FAILED event. */ - hs_control_desc_event_failed(conn->hs_ident, conn->identity_digest, - "NOT_FOUND"); - hs_control_desc_event_content(conn->hs_ident, conn->identity_digest, - NULL); - hs_client_desc_not_found(conn->hs_ident); - break; - case 400: - log_warn(LD_REND, "Fetching v3 hidden service descriptor failed: " - "http status 400 (%s). Dirserver didn't like our " - "query? Retrying at another directory.", - escaped(reason)); - /* Fire control port FAILED event. */ - hs_control_desc_event_failed(conn->hs_ident, conn->identity_digest, - "QUERY_REJECTED"); - hs_control_desc_event_content(conn->hs_ident, conn->identity_digest, - NULL); - break; - default: - log_warn(LD_REND, "Fetching v3 hidden service descriptor failed: " - "http status %d (%s) response unexpected from HSDir server " - "'%s:%d'. Retrying at another directory.", - status_code, escaped(reason), TO_CONN(conn)->address, - TO_CONN(conn)->port); - /* Fire control port FAILED event. */ - hs_control_desc_event_failed(conn->hs_ident, conn->identity_digest, - "UNEXPECTED"); - hs_control_desc_event_content(conn->hs_ident, conn->identity_digest, - NULL); - break; - } - + hs_client_dir_fetch_done(conn, reason, body, status_code); return 0; } |