From 5bf61633e3c44ad65a91d90c4002475ddd5ef8e4 Mon Sep 17 00:00:00 2001 From: Roger Dingledine Date: Sun, 4 Nov 2007 02:06:09 +0000 Subject: [PATCH] avoid sending a request for "keys/fp" (for which we'll get a 400 bad request) if we need more v3 certs but we've already got pending requests for all of them. svn:r12370 --- src/or/routerlist.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/or/routerlist.c b/src/or/routerlist.c index 95e048cb77..93369e157e 100644 --- a/src/or/routerlist.c +++ b/src/or/routerlist.c @@ -367,6 +367,12 @@ authority_certs_fetch_missing(networkstatus_vote_t *status, time_t now) fp[HEX_DIGEST_LEN+1] = '\0'; smartlist_add(fps, fp); }); + if (smartlist_len(fps) == 1) { + /* we didn't add any: they were all pending */ + SMARTLIST_FOREACH(fps, char *, cp, tor_free(cp)); + smartlist_free(fps); + goto done; + } resource = smartlist_join_strings(fps, "", 0, NULL); resource[strlen(resource)-1] = '\0'; SMARTLIST_FOREACH(fps, char *, cp, tor_free(cp));