🛡 I2P: End-to-End encrypted and anonymous Internet
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Go to file
orignal 2741e94a72 fixed infinite loop 10 years ago
Win32 NetDb/NetDbRequests split 10 years ago
build Fix -lboost_date_time missing from CMakeLists.txt 10 years ago
contrib/certificates
debian
.gitignore
AddressBook.cpp pass LeaseSet to callback of RequestDestination 10 years ago
AddressBook.h fixed addressbook crash at shutdown 10 years ago
BOB.cpp fixed crash 10 years ago
BOB.h pass LeaseSet to callback of RequestDestination 10 years ago
ClientContext.cpp fixed addressbook crash at shutdown 10 years ago
ClientContext.h
CryptoConst.cpp
CryptoConst.h
Daemon.cpp
Daemon.h
DaemonLinux.cpp
DaemonWin32.cpp
Datagram.cpp pass LeaseSet to callback of RequestDestination 10 years ago
Datagram.h pass LeaseSet to callback of RequestDestination 10 years ago
Destination.cpp validate leaseset for zero leases 10 years ago
Destination.h use shared_ptr for local LeaseSet 10 years ago
ElGamal.h made Encrypt const 10 years ago
Garlic.cpp 4 tags for LeaseSet request 10 years ago
Garlic.h use shared_ptr for local LeaseSet 10 years ago
HTTPProxy.cpp use shared_ptr for socket in I2PTunnelConnection 10 years ago
HTTPProxy.h use shared_ptr for socket in I2PTunnelConnection 10 years ago
HTTPServer.cpp show local destination for SAM sessions 10 years ago
HTTPServer.h fixed memory leak 10 years ago
I2NPProtocol.cpp use shared_ptr for CreateDatabaseStore 10 years ago
I2NPProtocol.h use shared_ptr for CreateDatabaseStore 10 years ago
I2PControl.cpp
I2PControl.h
I2PEndian.cpp
I2PEndian.h
I2PService.cpp use shared_ptr for socket in I2PTunnelConnection 10 years ago
I2PService.h use shared_ptr for socket in I2PTunnelConnection 10 years ago
I2PTunnel.cpp use AsyncSend 10 years ago
I2PTunnel.h use shared_ptr for socket in I2PTunnelConnection 10 years ago
Identity.cpp EdDSA signer added 10 years ago
Identity.h EdDSA signature type added 10 years ago
LICENSE
LeaseSet.cpp fixed crash 10 years ago
LeaseSet.h validate leaseset for zero leases 10 years ago
LittleBigEndian.h
Log.cpp
Log.h
Makefile
Makefile.bsd
Makefile.linux
Makefile.osx
NTCPSession.cpp
NTCPSession.h
NetDb.cpp NetDb/NetDbRequests split 10 years ago
NetDb.h NetDb/NetDbRequests split 10 years ago
NetDbRequests.cpp NetDb/NetDbRequests split 10 years ago
NetDbRequests.h NetDb/NetDbRequests split 10 years ago
Profiling.cpp count tunnel acceptance ratio for peer selection 10 years ago
Profiling.h count tunnel acceptance ratio for peer selection 10 years ago
Queue.h
README.md Update README.md 10 years ago
Reseed.cpp fixed crash if can't connect to a reseed 10 years ago
Reseed.h fixed crash if can't connect to a reseed 10 years ago
RouterContext.cpp select tunnel from TunnelPool rather than from LeaseSet for DeliveryStatus 10 years ago
RouterContext.h use shared_ptr for local LeaseSet 10 years ago
RouterInfo.cpp Fixed memory leak: delete -> delete[] 10 years ago
RouterInfo.h Fixed memory leak: delete -> delete[] 10 years ago
SAM.cpp use AsyncSend 10 years ago
SAM.h pass LeaseSet to callback of RequestDestination 10 years ago
SOCKS.cpp use shared_ptr for socket in I2PTunnelConnection 10 years ago
SOCKS.h use shared_ptr for socket in I2PTunnelConnection 10 years ago
SSU.cpp fixed typo 10 years ago
SSU.h store session with Alice with PeerTest 10 years ago
SSUData.cpp
SSUData.h
SSUSession.cpp delete trailing paddings of SSU packtes 10 years ago
SSUSession.h
Signature.cpp EdDSA signer added 10 years ago
Signature.h EdDSA signer added 10 years ago
Streaming.cpp fixed infinite loop 10 years ago
Streaming.h show windows size and connection status 10 years ago
Timestamp.h
TransitTunnel.cpp
TransitTunnel.h
TransportSession.h
Transports.cpp repeat peer test if previous was not successive 10 years ago
Transports.h
Tunnel.cpp fixed crash if no routers available 10 years ago
Tunnel.h
TunnelBase.h
TunnelConfig.h
TunnelEndpoint.cpp
TunnelEndpoint.h
TunnelGateway.cpp
TunnelGateway.h
TunnelPool.cpp fixed crash if no routers available 10 years ago
TunnelPool.h
UPnP.cpp
UPnP.h
aes.cpp check # of block to encrypt/decrypt for zero 10 years ago
aes.h
api.cpp
api.h
base64.cpp
base64.h
filelist.mk NetDb/NetDbRequests split 10 years ago
hmac.h
i2p.cpp
util.cpp
util.h
version.h 0.9.0 10 years ago

README.md

i2pd

I2P router written in C++

License

This project is licensed under the BSD 3-clause license, which can be found in the file LICENSE in the root of the project source code.

Requirements for Linux/FreeBSD/OSX

GCC 4.6 or newer, Boost 1.46 or newer, crypto++. Clang can be used instead of GCC.

Requirements for Windows

VS2013 (known to work with 12.0.21005.1 or newer), Boost 1.46 or newer, crypto++ 5.62. See Win32/README-Build.txt for instructions on how to build i2pd and its dependencies.

Downloads

Official binary releases could be found at: http://download.i2p.io/purplei2p/i2pd/releases/

Build Statuses

  • Linux x64 - Build Status
  • Linux ARM - To be added
  • Mac OS X - Got it working, but not well tested. (Only works with clang, not GCC.)
  • Microsoft VC13 - To be added

Testing

First, build it.

On Ubuntu/Debian based

  • sudo apt-get install libboost-dev libboost-filesystem-dev libboost-program-options-dev libboost-regex-dev libcrypto++-dev libboost-date-time-dev
  • $ cd i2pd
  • $ make

Then, run it:

$ ./i2p

The client should now reseed by itself.

To visit an I2P page, you need to find the b32 address of your destination. After that, go to the webconsole and add it behind the url. (Remove http:// from the address)

This should resulting in for example: http://localhost:7070/4oes3rlgrpbkmzv4lqcfili23h3cvpwslqcfjlk6vvguxyggspwa.b32.i2p

Cmdline options

  • --host= - The external IP (deprecated).
  • --port= - The port to listen on
  • --httpport= - The http port to listen on
  • --log= - Enable or disable logging to file. 1 for yes, 0 for no.
  • --daemon= - Enable or disable daemon mode. 1 for yes, 0 for no.
  • --service= - 1 if uses system folders (/var/run/i2pd.pid, /var/log/i2pd.log, /var/lib/i2pd).
  • --v6= - 1 if supports communication through ipv6, off by default
  • --floodfill= - 1 if router is floodfill, off by default
  • --bandwidth= - L if bandwidth is limited to 32Kbs/sec, O if not. Always O if floodfill, otherwise L by default.
  • --httpproxyport= - The port to listen on (HTTP Proxy)
  • --socksproxyport= - The port to listen on (SOCKS Proxy)
  • --proxykeys= - optional keys file for proxy's local destination
  • --ircport= - The local port of IRC tunnel to listen on. 6668 by default
  • --ircdest= - I2P destination address of IRC server. For example irc.postman.i2p
  • --irckeys= - optional keys file for tunnel's local destination
  • --eepkeys= - File name containing destination keys, for example privKeys.dat. The file will be created if it does not already exist (issue #110).
  • --eephost= - Address incoming trafic forward to. 127.0.0.1 by default
  • --eepport= - Port incoming trafic forward to. 80 by default
  • --samport= - Port of SAM bridge. Usually 7656. SAM is off if not specified
  • --bobport= - Port of BOB command channel. Usually 2827. BOB is off if not specified
  • --i2pcontrolport= - Port of I2P control service. Usually 7650. I2PControl is off if not specified
  • --conf= - Config file (default: ~/.i2pd/i2p.conf or /var/lib/i2pd/i2p.conf) This parameter will be silently ignored if the specified config file does not exist. Options specified on the command line take precedence over those in the config file.

Config files

INI-like, syntax is the following : = . All command-line parameters are allowed as keys, for example:

i2p.conf:

log = 1
v6 = 0
ircdest = irc.postman.i2p

tunnels.cfg (filename of this config is subject of change):

; outgoing tunnel sample, to remote service
; mandatory parameters:
; * type -- always "client"
; * port -- local port to listen to
; * destination -- i2p hostname
; optional parameters (may be omitted)
; * keys -- our identity, if unset, will be generated on every startup,
; if set and file missing, keys will be generated and placed to this file
[IRC]
type = client
port = 6668
destination = irc.echelon.i2p
keys = irc-keys.dat

; incoming tunnel sample, for local service
; mandatory parameters:
; * type -- always "server"
; * host -- ip address of our service
; * port -- port of our service
; * keys -- file with LeaseSet of address in i2p
; optional parameters (may be omitted)
; * inport -- optional, i2p service port, if unset - the same as 'port'
; * accesslist -- comma-separated list of i2p addresses, allowed to connect
; every address is b32 without '.b32.i2p' part
[LOCALSITE]
type = server
host = 127.0.0.1
port = 80
keys = site-keys.dat
inport = 81
accesslist = [,]