diff options
author | David Goulet <dgoulet@torproject.org> | 2021-02-23 09:37:17 -0500 |
---|---|---|
committer | David Goulet <dgoulet@torproject.org> | 2021-02-23 09:49:45 -0500 |
commit | 39d0f69dfee86c4f8703094990d3169fb20614f3 (patch) | |
tree | 5b01dbd2a73e5a0f43586eeaa861f6263c893458 /changes/ticket40300 | |
parent | bc21ed32903459c53599ee03605e8d23bf42ffe9 (diff) | |
download | tor-39d0f69dfee86c4f8703094990d3169fb20614f3.tar.gz tor-39d0f69dfee86c4f8703094990d3169fb20614f3.zip |
relay: Avoid a directory early fetch
The directory_fetches_from_authorities() is used to know if a client or relay
should fetch data from an authority early in the boot process.
We had a condition in that function that made a relay trigger that fetch if it
didn't know its address (so we can learn it). However, when this is called,
the address discovery has not been done yet so it would always return true for
a relay.
Furthermore, it would always trigger a log notice that the IPv4 couldn't be
found which was inevitable because the address discovery process has not been
done yet (done when building our first descriptor).
It is also important to point out that starting in 0.4.5.1-alpha, asking an
authority for an address is done during address discovery time using a one-hop
circuit thus independent from the relay deciding to fetch or not documents
from an authority.
Small fix also is to reverse the "IPv(4|6)Only" flag in the notice so that if
we can't find IPv6 it would output to use IPv4Only.
Fixes #40300
Signed-off-by: David Goulet <dgoulet@torproject.org>
Diffstat (limited to 'changes/ticket40300')
-rw-r--r-- | changes/ticket40300 | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/changes/ticket40300 b/changes/ticket40300 index aef01b4c64..b772ff60a4 100644 --- a/changes/ticket40300 +++ b/changes/ticket40300 @@ -2,4 +2,7 @@ - Remove a spammy log notice that should not have been indicating the operator that its IPv4/v6 was missing but it was not. Fixes bug 40300; bugfix on 0.4.5.1-alpha. - + - Do not query the address cache early in the boot process when deciding + if we a relay needs to fetch early directory information from an + authority. This resulted in a relay falsely believing it didn't have an + address and thus triggering an authority fetch at each boot. |