diff options
author | David Goulet <dgoulet@torproject.org> | 2018-08-30 09:16:48 -0400 |
---|---|---|
committer | David Goulet <dgoulet@torproject.org> | 2018-09-07 14:03:55 -0400 |
commit | 8e57986e7d826141727fc3d538b33882dc4aca91 (patch) | |
tree | 64a58fac87434eb68348440d8331eae75ce7ae73 | |
parent | 5b2871d2f2a541ad15541eebf9830b1e448dbfc2 (diff) | |
download | tor-8e57986e7d826141727fc3d538b33882dc4aca91.tar.gz tor-8e57986e7d826141727fc3d538b33882dc4aca91.zip |
hs-v3: Improve v3 client authorization logging
Part of #20700.
Signed-off-by: David Goulet <dgoulet@torproject.org>
-rw-r--r-- | src/feature/hs/hs_client.c | 14 | ||||
-rw-r--r-- | src/feature/hs/hs_service.c | 18 |
2 files changed, 20 insertions, 12 deletions
diff --git a/src/feature/hs/hs_client.c b/src/feature/hs/hs_client.c index 23ab10e210..af657c7c9c 100644 --- a/src/feature/hs/hs_client.c +++ b/src/feature/hs/hs_client.c @@ -1571,7 +1571,9 @@ hs_config_client_authorization(const or_options_t *options, filename); if (!auth_key_filename_is_valid(filename)) { - log_warn(LD_REND, "The filename is invalid."); + log_notice(LD_REND, "Client authorization unrecognized filename %s. " + "File must end in .auth_private. Ignoring.", + filename); continue; } @@ -1583,7 +1585,7 @@ hs_config_client_authorization(const or_options_t *options, /* If we cannot read the file, continue with the next file. */ if (!client_key_str) { - log_warn(LD_REND, "The file cannot be read."); + log_warn(LD_REND, "The file %s cannot be read.", filename); continue; } @@ -1597,15 +1599,16 @@ hs_config_client_authorization(const or_options_t *options, if (hs_parse_address(auth->onion_address, &identity_pk, NULL, NULL) < 0) { client_service_authorization_free(auth); - log_warn(LD_REND, "The onion address is invalid."); + log_warn(LD_REND, "The onion address \"%s\" is invalid in " + "file %s", filename, auth->onion_address); continue; } if (digest256map_get(auths, identity_pk.pubkey)) { client_service_authorization_free(auth); - log_warn(LD_REND, "Duplicate authorization for the same hidden " - "service."); + "service address %s.", + safe_str_client(auth->onion_address)); goto end; } @@ -1613,7 +1616,6 @@ hs_config_client_authorization(const or_options_t *options, log_info(LD_REND, "Loaded a client authorization key file %s.", filename); } - } SMARTLIST_FOREACH_END(filename); /* Success. */ diff --git a/src/feature/hs/hs_service.c b/src/feature/hs/hs_service.c index 8d5d693020..09329340c1 100644 --- a/src/feature/hs/hs_service.c +++ b/src/feature/hs/hs_service.c @@ -1141,7 +1141,7 @@ parse_authorized_client(const char *client_key_str) SPLIT_SKIP_SPACE, 0); /* Wrong number of fields. */ if (smartlist_len(fields) != 3) { - log_warn(LD_REND, "The file is in a wrong format."); + log_warn(LD_REND, "Unknown format of client authorization file."); goto err; } @@ -1151,13 +1151,15 @@ parse_authorized_client(const char *client_key_str) /* Currently, the only supported auth type is "descriptor". */ if (strcmp(auth_type, "descriptor")) { - log_warn(LD_REND, "The auth type '%s' is not supported.", auth_type); + log_warn(LD_REND, "Client authorization auth type '%s' not supported.", + auth_type); goto err; } /* Currently, the only supported key type is "x25519". */ if (strcmp(key_type, "x25519")) { - log_warn(LD_REND, "The key type '%s' is not supported.", key_type); + log_warn(LD_REND, "Client authorization key type '%s' not supported.", + key_type); goto err; } @@ -1175,7 +1177,8 @@ parse_authorized_client(const char *client_key_str) if (base32_decode((char *) client->client_pk.public_key, sizeof(client->client_pk.public_key), pubkey_b32, strlen(pubkey_b32)) < 0) { - log_warn(LD_REND, "The public key cannot be decoded."); + log_warn(LD_REND, "Client authorization public key cannot be decoded: %s", + pubkey_b32); goto err; } @@ -1245,7 +1248,8 @@ load_client_keys(hs_service_t *service) filename); if (!client_filename_is_valid(filename)) { - log_warn(LD_REND, "The filename is invalid."); + log_warn(LD_REND, "Client authorization unrecognized filename %s. " + "File must end in .auth. Ignoring.", filename); continue; } @@ -1258,7 +1262,9 @@ load_client_keys(hs_service_t *service) /* If we cannot read the file, continue with the next file. */ if (!client_key_str) { - log_warn(LD_REND, "The file cannot be read."); + log_warn(LD_REND, "Client authorization file %s can't be read. " + "Corrupted or verify permission? Ignoring.", + client_key_file_path); continue; } |