🛡 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 74c89ce06e proper cleanup of pending tunnels 10 years ago
Win32 added I2PService to VS project 10 years ago
build
contrib/certificates
debian Update copyright 10 years ago
.gitignore
AddressBook.cpp
AddressBook.h changed addressbook subscription update interval to 12 hours 10 years ago
BOB.cpp
BOB.h
ClientContext.cpp added I2PControl to ClientContext 10 years ago
ClientContext.h added I2PControl to ClientContext 10 years ago
CryptoConst.cpp
CryptoConst.h
Daemon.cpp
Daemon.h
DaemonLinux.cpp
DaemonWin32.cpp
Datagram.cpp
Datagram.h
Destination.cpp don't try to re-request expired LeaseSet 10 years ago
Destination.h use shared_ptr for TunnelPool 10 years ago
ElGamal.h
Garlic.cpp
Garlic.h
HTTPProxy.cpp use shared local destination for proxies 10 years ago
HTTPProxy.h use shared local destination for proxies 10 years ago
HTTPServer.cpp moved NTCP to separate thread 10 years ago
HTTPServer.h
I2NPProtocol.cpp
I2NPProtocol.h
I2PControl.cpp Reseed through I2PControl 10 years ago
I2PControl.h Reseed through I2PControl 10 years ago
I2PEndian.cpp
I2PEndian.h
I2PService.cpp
I2PService.h
I2PTunnel.cpp
I2PTunnel.h
Identity.cpp
Identity.h
LICENSE license -> BSD 3-clause 10 years ago
LeaseSet.cpp
LeaseSet.h
LittleBigEndian.h
Log.cpp
Log.h
Makefile Fix: mkdir exist in multi thread building 10 years ago
Makefile.bsd
Makefile.linux Not overwrite -fPIC with CXXFLAGS 10 years ago
Makefile.osx
NTCPSession.cpp make sure DatabaseStore message is first 10 years ago
NTCPSession.h moved delayed queue to Peer 10 years ago
NetDb.cpp Reseed through I2PControl 10 years ago
NetDb.h Reseed through I2PControl 10 years ago
Queue.h
README.md Adding download link 10 years ago
Reseed.cpp correct CRC32 verification at big endian CPU 10 years ago
Reseed.h
RouterContext.cpp
RouterContext.h
RouterInfo.cpp resolve address for NTCP 10 years ago
RouterInfo.h resolve address for NTCP 10 years ago
SAM.cpp
SAM.h
SOCKS.cpp use shared local destination for proxies 10 years ago
SOCKS.h use shared local destination for proxies 10 years ago
SSU.cpp
SSU.h fixed race condition 10 years ago
SSUData.cpp
SSUData.h
SSUSession.cpp moved delayed queue to Peer 10 years ago
SSUSession.h moved delayed queue to Peer 10 years ago
Signature.h
Streaming.cpp
Streaming.h
Timestamp.h
TransitTunnel.cpp
TransitTunnel.h
TransportSession.h use TransportSession for sending messages 10 years ago
Transports.cpp fixed resolve bug 10 years ago
Transports.h resolve address for NTCP 10 years ago
Tunnel.cpp proper cleanup of pending tunnels 10 years ago
Tunnel.h use shared_ptr for TunnelPool 10 years ago
TunnelBase.h
TunnelConfig.h
TunnelEndpoint.cpp
TunnelEndpoint.h
TunnelGateway.cpp
TunnelGateway.h
TunnelPool.cpp use shared_ptr for TunnelPool 10 years ago
TunnelPool.h use shared_ptr for TunnelPool 10 years ago
UPnP.cpp
UPnP.h
aes.cpp
aes.h
api.cpp
api.h
base64.cpp
base64.h
filelist.mk For some reason, the daemon src don't include I2PControl.cpp for OSX 10 years ago
hmac.h
i2p.cpp
util.cpp
util.h
version.h

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

Next, find out your public ip. (find it for example at http://www.whatismyip.com/)

Then, run it with:

$ ./i2p --host=YOUR_PUBLIC_IP

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
  • --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).
  • --unreachable= - 1 if router is declared as unreachable and works through introducers.
  • --v6= - 1 if supports communication through ipv6, off by default
  • --httpproxyport= - The port to listen on (HTTP Proxy)
  • --socksproxyport= - The port to listen on (SOCKS Proxy)
  • --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 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 file

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

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