🛡 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 fcd3680547 delete expired incoming tags 10 years ago
Win32
build
contrib/certificates
debian
.gitignore
AddressBook.cpp
AddressBook.h
ClientContext.cpp
ClientContext.h
CryptoConst.cpp
CryptoConst.h
Daemon.cpp
Daemon.h
DaemonLinux.cpp
DaemonWin32.cpp
Destination.cpp
Destination.h
ElGamal.h
Garlic.cpp
Garlic.h
HTTPProxy.cpp
HTTPProxy.h
HTTPServer.cpp
HTTPServer.h
I2NPProtocol.cpp
I2NPProtocol.h
I2PEndian.cpp
I2PEndian.h
I2PTunnel.cpp
I2PTunnel.h
Identity.cpp
Identity.h
LICENSE
LeaseSet.cpp
LeaseSet.h
LittleBigEndian.h
Log.cpp
Log.h
Makefile
Makefile.bsd
Makefile.linux
Makefile.osx
NTCPSession.cpp
NTCPSession.h
NetDb.cpp
NetDb.h
Queue.h
README.md
Reseed.cpp
Reseed.h
RouterContext.cpp
RouterContext.h
RouterInfo.cpp
RouterInfo.h
SAM.cpp
SAM.h
SOCKS.cpp
SOCKS.h
SSU.cpp
SSU.h
SSUData.cpp
SSUData.h
Signature.h
Streaming.cpp
Streaming.h
Timestamp.h
TransitTunnel.cpp
TransitTunnel.h
Transports.cpp
Transports.h
Tunnel.cpp
Tunnel.h
TunnelBase.h
TunnelConfig.h
TunnelEndpoint.cpp
TunnelEndpoint.h
TunnelGateway.cpp
TunnelGateway.h
TunnelPool.cpp
TunnelPool.h
UPnP.cpp
UPnP.h
aes.cpp
aes.h
base64.cpp
base64.h
filelist.mk
hmac.h
i2p.cpp
util.cpp
util.h
version.h

README.md

i2pd

i2p router for Linux written on C++

Requires gcc 4.6 and higher, boost 1.46 and higher, crypto++

on Windows

Requires msvs2013 (require Visual C++ Compiler November 2013 CTP update), boost 1.46 and higher, crypto++

Build Statuses

  • Linux x64 - Build Status
  • Linux ARM - Too be added
  • Mac OS X - Too be added
  • Microsoft VC13 - Too 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:// and b32.i2p from the address)

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

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