aboutsummaryrefslogtreecommitdiff
path: root/src/or
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2008-12-18 04:27:23 +0000
committerNick Mathewson <nickm@torproject.org>2008-12-18 04:27:23 +0000
commit676175103de747085d02a647fc200f77cb0f4260 (patch)
tree697422330ba1cc19ed32d43e090d1e354e1e802a /src/or
parent5c235cb5ecf83a89ff6c9f514d1d8618043b39e7 (diff)
downloadtor-676175103de747085d02a647fc200f77cb0f4260.tar.gz
tor-676175103de747085d02a647fc200f77cb0f4260.zip
Fix a valgrind-located memory stomp. Bugfix on 0.2.1.6-alpha.
svn:r17667
Diffstat (limited to 'src/or')
-rw-r--r--src/or/rendclient.c19
1 files changed, 12 insertions, 7 deletions
diff --git a/src/or/rendclient.c b/src/or/rendclient.c
index 7964185fce..050397532a 100644
--- a/src/or/rendclient.c
+++ b/src/or/rendclient.c
@@ -402,14 +402,19 @@ directory_get_from_hs_dir(const char *desc_id, const rend_data_t *rend_query)
lookup_last_hid_serv_request(hs_dir, desc_id_base32, now, 1);
/* Encode descriptor cookie for logging purposes. */
- if (rend_query->auth_type != REND_NO_AUTH &&
- base64_encode(descriptor_cookie_base64, 3*REND_DESC_COOKIE_LEN_BASE64,
- rend_query->descriptor_cookie, REND_DESC_COOKIE_LEN) < 0) {
- log_warn(LD_BUG, "Could not base64-encode descriptor cookie.");
- return 0;
+ if (rend_query->auth_type != REND_NO_AUTH) {
+ if (base64_encode(descriptor_cookie_base64,
+ sizeof(descriptor_cookie_base64),
+ rend_query->descriptor_cookie, REND_DESC_COOKIE_LEN)<0) {
+ log_warn(LD_BUG, "Could not base64-encode descriptor cookie.");
+ return 0;
+ }
+ /* Remove == signs and newline. */
+ descriptor_cookie_base64[strlen(descriptor_cookie_base64)-3] = '\0';
+ } else {
+ strlcpy(descriptor_cookie_base64, "(none)",
+ sizeof(descriptor_cookie_base64));
}
- /* Remove == signs and newline. */
- descriptor_cookie_base64[strlen(descriptor_cookie_base64)-3] = '\0';
/* Send fetch request. (Pass query and possibly descriptor cookie so that
* they can be written to the directory connection and be referred to when