🛡 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 4c8d85870b check identity buffer size 10 years ago
Win32 BOB added 10 years ago
api delete stream from inside 10 years ago
build BOB added 10 years ago
contrib/certificates
debian
.gitignore
AddressBook.cpp check identity buffer size 10 years ago
AddressBook.h load from addressbook first 10 years ago
BOB.cpp handle .i2p address for BOB inbound connections 10 years ago
BOB.h BOB setkeys/getkeys 10 years ago
ClientContext.cpp BOB command parser 10 years ago
ClientContext.h BOB added 10 years ago
CryptoConst.cpp
CryptoConst.h
Daemon.cpp
Daemon.h
DaemonLinux.cpp
DaemonWin32.cpp
Datagram.cpp remember last outgoing tunnel per stream rather than per client destination 10 years ago
Datagram.h
Destination.cpp delete stream from inside 10 years ago
Destination.h pass I2CP options to local destination. Process tunnel length 10 years ago
ElGamal.h
Garlic.cpp 16 bytes alignmen of AES block 10 years ago
Garlic.h
HTTPProxy.cpp
HTTPProxy.h
HTTPServer.cpp delete stream from inside 10 years ago
HTTPServer.h shared pointers for streams 10 years ago
I2NPProtocol.cpp
I2NPProtocol.h adjust message length after alignment 10 years ago
I2PEndian.cpp
I2PEndian.h
I2PTunnel.cpp send recived data after address from BOB inbound connection 10 years ago
I2PTunnel.h send recived data after address from BOB inbound connection 10 years ago
Identity.cpp check identity buffer size 10 years ago
Identity.h from/to base64 10 years ago
LICENSE
LeaseSet.cpp
LeaseSet.h
LittleBigEndian.h
Log.cpp
Log.h
Makefile
Makefile.bsd
Makefile.linux
Makefile.osx
NTCPSession.cpp use shared pointer for NTCPSession 10 years ago
NTCPSession.h use shared pointer for NTCPSession 10 years ago
NetDb.cpp wait for confirmantion of publishing 10 years ago
NetDb.h wait for confirmantion of publishing 10 years ago
Queue.h
README.md
Reseed.cpp
Reseed.h
RouterContext.cpp
RouterContext.h
RouterInfo.cpp drop verifier not used anymore 10 years ago
RouterInfo.h
SAM.cpp delete stream from inside 10 years ago
SAM.h fixed crash on termination 10 years ago
SOCKS.cpp shared pointers for streams 10 years ago
SOCKS.h shared pointers for streams 10 years ago
SSU.cpp handle ipv6 sessions in separate thread 10 years ago
SSU.h handle ipv6 sessions in separate thread 10 years ago
SSUData.cpp shared pointer for SSU 10 years ago
SSUData.h
SSUSession.cpp shared pointer for SSU 10 years ago
SSUSession.h shared pointer for SSU 10 years ago
Signature.h ECDSA P384 and ECDSA P521 support 10 years ago
Streaming.cpp delete non-responding streams 10 years ago
Streaming.h delete stream from inside 10 years ago
Timestamp.h
TransitTunnel.cpp
TransitTunnel.h
TransportSession.h
Transports.cpp use shared pointer for NTCPSession 10 years ago
Transports.h use shared pointer for NTCPSession 10 years ago
Tunnel.cpp different tunnel length for IB and OB 10 years ago
Tunnel.h different tunnel length for IB and OB 10 years ago
TunnelBase.h
TunnelConfig.h
TunnelEndpoint.cpp
TunnelEndpoint.h
TunnelGateway.cpp alignment 10 years ago
TunnelGateway.h
TunnelPool.cpp temporary disabled tunnel test encryption due instability 10 years ago
TunnelPool.h different tunnel length for IB and OB 10 years ago
UPnP.cpp
UPnP.h
aes.cpp
aes.h 16 bytes alignmen of AES block 10 years ago
base64.cpp check identity buffer size 10 years ago
base64.h
filelist.mk BOB added 10 years ago
hmac.h
i2p.cpp
util.cpp
util.h
version.h Update version.h 10 years ago

README.md

i2pd

I2P router written in C++

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.

Build Statuses

  • Linux x64 - Build Status
  • Linux ARM - To be added
  • Mac OS X - To be added
  • Microsoft VC13 - To be added

Testing

First, build it.

  • $ 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

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
  • --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