summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorteor <teor@torproject.org>2019-03-30 12:09:47 +1000
committerNick Mathewson <nickm@torproject.org>2019-04-04 20:26:09 -0400
commit8e961b2174f6714fdff295f032abe993f864b81b (patch)
treefd9747522cfde77f6213954b0050292df0c44701
parent6d188fb4cc026668502c0fb28e9bffaa098f84dc (diff)
downloadtor-8e961b2174f6714fdff295f032abe993f864b81b.tar.gz
tor-8e961b2174f6714fdff295f032abe993f864b81b.zip
bwauth: Actually include the bandwidth-file-digest in authority votes
Fixes bug 29959; bugfix on 0.4.0.2-alpha.
-rw-r--r--changes/bug29959-0403
-rw-r--r--src/feature/dirauth/dirvote.c21
2 files changed, 13 insertions, 11 deletions
diff --git a/changes/bug29959-040 b/changes/bug29959-040
new file mode 100644
index 0000000000..3740e0169a
--- /dev/null
+++ b/changes/bug29959-040
@@ -0,0 +1,3 @@
+ o Minor bugfixes (directory authorities):
+ - Actually include the bandwidth-file-digest line in directory authority
+ votes. Fixes bug 29959; bugfix on 0.4.0.2-alpha.
diff --git a/src/feature/dirauth/dirvote.c b/src/feature/dirauth/dirvote.c
index ba7b2f1de6..29f5d04509 100644
--- a/src/feature/dirauth/dirvote.c
+++ b/src/feature/dirauth/dirvote.c
@@ -320,18 +320,17 @@ format_networkstatus_vote(crypto_pk_t *private_signing_key,
if (!tor_digest256_is_zero((const char *)v3_ns->bw_file_digest256)) {
/* Encode the digest. */
char b64_digest_bw_file[BASE64_DIGEST256_LEN+1] = {0};
- if (digest256_to_base64(b64_digest_bw_file,
- (const char *)v3_ns->bw_file_digest256)>0) {
- /* "bandwidth-file-digest" 1*(SP algorithm "=" digest) NL */
- char *digest_algo_b64_digest_bw_file = NULL;
- tor_asprintf(&digest_algo_b64_digest_bw_file, "%s=%s",
- crypto_digest_algorithm_get_name(DIGEST_ALG_BW_FILE),
- b64_digest_bw_file);
- /* No need for tor_strdup(""), format_line_if_present does it. */
- bw_file_digest = format_line_if_present(
+ digest256_to_base64(b64_digest_bw_file,
+ (const char *)v3_ns->bw_file_digest256);
+ /* "bandwidth-file-digest" 1*(SP algorithm "=" digest) NL */
+ char *digest_algo_b64_digest_bw_file = NULL;
+ tor_asprintf(&digest_algo_b64_digest_bw_file, "%s=%s",
+ crypto_digest_algorithm_get_name(DIGEST_ALG_BW_FILE),
+ b64_digest_bw_file);
+ /* No need for tor_strdup(""), format_line_if_present does it. */
+ bw_file_digest = format_line_if_present(
"bandwidth-file-digest", digest_algo_b64_digest_bw_file);
- tor_free(digest_algo_b64_digest_bw_file);
- }
+ tor_free(digest_algo_b64_digest_bw_file);
}
smartlist_add_asprintf(chunks,