I2P: End-to-End encrypted and anonymous Internet https://i2pd.website/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Kill Your TV 21e3778e69 Revert the 'clean-up' commits so that custom build-time flags can be set 10 years ago
Win32
build * update build/CMakeLists.txt 10 years ago
contrib/certificates sync certificates with the java router 10 years ago
debian
.gitignore
AddressBook.cpp process addressbook request response 10 years ago
AddressBook.h process addressbook request response 10 years ago
BOB.cpp terminate acceptor and sessions on stop 10 years ago
BOB.h
ClientContext.cpp
ClientContext.h
CryptoConst.cpp
CryptoConst.h
Daemon.cpp
Daemon.h
DaemonLinux.cpp
DaemonWin32.cpp
Datagram.cpp create io_service together with destination 10 years ago
Datagram.h
Destination.cpp fixed crash at shutdown 10 years ago
Destination.h create io_service together with destination 10 years ago
ElGamal.h
Garlic.cpp
Garlic.h
HTTPProxy.cpp
HTTPProxy.h
HTTPServer.cpp some cleanup 10 years ago
HTTPServer.h
I2NPProtocol.cpp drop incoming garlic messages if local destination doesn't exist anymore 10 years ago
I2NPProtocol.h
I2PEndian.cpp
I2PEndian.h
I2PTunnel.cpp
I2PTunnel.h
Identity.cpp
Identity.h
LICENSE
LeaseSet.cpp pass local destination by pointer 10 years ago
LeaseSet.h extend LeaseSet buffer to fir RSA-4096 key and signature 10 years ago
LittleBigEndian.h
Log.cpp
Log.h
Makefile Revert the 'clean-up' commits so that custom build-time flags can be set 10 years ago
Makefile.bsd Revert the 'clean-up' commits so that custom build-time flags can be set 10 years ago
Makefile.linux Revert the 'clean-up' commits so that custom build-time flags can be set 10 years ago
Makefile.osx * move USE_* to main Makefile 10 years ago
NTCPSession.cpp
NTCPSession.h
NetDb.cpp pass local destination by pointer 10 years ago
NetDb.h
Queue.h
README.md
Reseed.cpp fixed typo 10 years ago
Reseed.h load certificates and verify signatures 10 years ago
RouterContext.cpp
RouterContext.h
RouterInfo.cpp
RouterInfo.h
SAM.cpp delete local destination on session close 10 years ago
SAM.h store SAMSession by pointer 10 years ago
SOCKS.cpp
SOCKS.h
SSU.cpp
SSU.h
SSUData.cpp
SSUData.h
SSUSession.cpp
SSUSession.h
Signature.h fixed compilation warning 10 years ago
Streaming.cpp create io_service together with destination 10 years ago
Streaming.h Cancel added 10 years ago
Timestamp.h
TransitTunnel.cpp
TransitTunnel.h
TransportSession.h
Transports.cpp
Transports.h
Tunnel.cpp pass local destination by pointer 10 years ago
Tunnel.h pass local destination by pointer 10 years ago
TunnelBase.h
TunnelConfig.h
TunnelEndpoint.cpp
TunnelEndpoint.h
TunnelGateway.cpp
TunnelGateway.h
TunnelPool.cpp pass local destination by pointer 10 years ago
TunnelPool.h pass local destination by pointer 10 years ago
UPnP.cpp
UPnP.h
aes.cpp fixed crash 10 years ago
aes.h
api.cpp
api.h
base64.cpp
base64.h
filelist.mk * (1/3) update filelist.mk : 3 lists of sources: common, daemon-specific and library-specific 10 years ago
hmac.h
i2p.cpp
util.cpp load certificates and verify signatures 10 years ago
util.h load certificates and verify signatures 10 years ago
version.h version updated 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

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