mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-06-04 02:02:42 +02:00
Merge bitcoin/bitcoin#25355: I2P: add support for transient addresses for outbound connections
59aa54f731i2p: log "SAM session" instead of "session" (Vasil Dimov)d7ec30b648doc: add release notes about the I2P transient addresses (Vasil Dimov)47c0d02f12doc: document I2P transient addresses usage in doc/i2p.md (Vasil Dimov)3914e472f5test: add a test that -i2pacceptincoming=0 creates a transient session (Vasil Dimov)ae1e97ce86net: use transient I2P session for outbound if -i2pacceptincoming=0 (Vasil Dimov)a1580a04f5net: store an optional I2P session in CNode (Vasil Dimov)2b781ad66ei2p: add support for creating transient sessions (Vasil Dimov) Pull request description: Add support for generating a transient, one-time I2P address for ourselves when making I2P outbound connection and discard it once the connection is closed. Background --- In I2P connections, the host that receives the connection knows the I2P address of the connection initiator. This is unlike the Tor network where the recipient does not know who is connecting to them, not even the initiator's Tor address. Persistent vs transient I2P addresses --- Even if an I2P node is not accepting incoming connections, they are known to other nodes by their outgoing I2P address. This creates an opportunity to white-list given nodes or treat them differently based on their I2P address. However, this also creates an opportunity to fingerprint or analyze a given node because it always uses the same I2P address when it connects to other nodes. If this is undesirable, then a node operator can use the newly introduced `-i2ptransientout` to generate a transient (disposable), one-time I2P address for each new outgoing connection. That address is never going to be reused again, not even if reconnecting to the same peer later. ACKs for top commit: mzumsande: ACK59aa54f731(verified via range-diff that just a typo / `unique_ptr` initialisation were fixed) achow101: re-ACK59aa54f731jonatack: utACK59aa54f731reviewed range diff, rebased to master, debug build + relevant tests + review at each commit Tree-SHA512: 2be9b9dd7502b2d44a75e095aaece61700766bff9af0a2846c29ca4e152b0a92bdfa30f61e8e32b6edb1225f74f1a78d19b7bf069f00b8f8173e69705414a93e
This commit is contained in:
26
doc/i2p.md
26
doc/i2p.md
@@ -47,9 +47,26 @@ In a typical situation, this suffices:
|
||||
bitcoind -i2psam=127.0.0.1:7656
|
||||
```
|
||||
|
||||
The first time Bitcoin Core connects to the I2P router, its I2P address (and
|
||||
corresponding private key) will be automatically generated and saved in a file
|
||||
named `i2p_private_key` in the Bitcoin Core data directory.
|
||||
The first time Bitcoin Core connects to the I2P router, if
|
||||
`-i2pacceptincoming=1`, then it will automatically generate a persistent I2P
|
||||
address and its corresponding private key. The private key will be saved in a
|
||||
file named `i2p_private_key` in the Bitcoin Core data directory. The persistent
|
||||
I2P address is used for accepting incoming connections and for making outgoing
|
||||
connections if `-i2pacceptincoming=1`. If `-i2pacceptincoming=0` then only
|
||||
outbound I2P connections are made and a different transient I2P address is used
|
||||
for each connection to improve privacy.
|
||||
|
||||
## Persistent vs transient I2P addresses
|
||||
|
||||
In I2P connections, the connection receiver sees the I2P address of the
|
||||
connection initiator. This is unlike the Tor network where the recipient does
|
||||
not know who is connecting to them and can't tell if two connections are from
|
||||
the same peer or not.
|
||||
|
||||
If an I2P node is not accepting incoming connections, then Bitcoin Core uses
|
||||
random, one-time, transient I2P addresses for itself for outbound connections
|
||||
to make it harder to discriminate, fingerprint or analyze it based on its I2P
|
||||
address.
|
||||
|
||||
## Additional configuration options related to I2P
|
||||
|
||||
@@ -85,7 +102,8 @@ one of the networks has issues.
|
||||
|
||||
## I2P-related information in Bitcoin Core
|
||||
|
||||
There are several ways to see your I2P address in Bitcoin Core:
|
||||
There are several ways to see your I2P address in Bitcoin Core if accepting
|
||||
incoming I2P connections (`-i2pacceptincoming`):
|
||||
- in the "Local addresses" output of CLI `-netinfo`
|
||||
- in the "localaddresses" output of RPC `getnetworkinfo`
|
||||
- in the debug log (grep for `AddLocal`; the I2P address ends in `.b32.i2p`)
|
||||
|
||||
8
doc/release-notes-25355.md
Normal file
8
doc/release-notes-25355.md
Normal file
@@ -0,0 +1,8 @@
|
||||
Notable changes
|
||||
===============
|
||||
|
||||
P2P and network changes
|
||||
-----------------------
|
||||
|
||||
- With I2P connections, a new, transient address is used for each outbound
|
||||
connection if `-i2pacceptincoming=0`. (#25355)
|
||||
Reference in New Issue
Block a user