🛡 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
EinMByte e90b0dd54f Update TODO. 9 years ago
Win32 Note that Boost 1.58 works 9 years ago
build Merge pull request #169 from guanqun/fix-binary-name 9 years ago
contrib/certificates reseed certificate updates 9 years ago
debian Update copyright 10 years ago
tests Base64/32 tests for #229. 9 years ago
.gitignore Setup unit test environment. 9 years ago
AddressBook.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
AddressBook.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
BOB.cpp Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
BOB.h Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
ClientContext.cpp Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
ClientContext.h Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
CryptoConst.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
CryptoConst.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Daemon.cpp Do not bind HTTPServer to the "any" address (#235). 9 years ago
Daemon.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
DaemonLinux.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
DaemonWin32.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Datagram.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Datagram.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Destination.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Destination.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
ElGamal.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Garlic.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Garlic.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
HTTPProxy.cpp Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
HTTPProxy.h Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
HTTPServer.cpp Do not bind HTTPServer to the "any" address (#235). 9 years ago
HTTPServer.h Do not bind HTTPServer to the "any" address (#235). 9 years ago
I2NPProtocol.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
I2NPProtocol.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
I2PControl.cpp Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
I2PControl.h Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
I2PEndian.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
I2PEndian.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
I2PService.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
I2PService.h Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
I2PTunnel.cpp Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
I2PTunnel.h Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
Identity.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Identity.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
LICENSE Update LICENSE 10 years ago
LeaseSet.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
LeaseSet.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
LittleBigEndian.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Log.cpp Merge remote-tracking branch 'github/master' 9 years ago
Log.h Merge remote-tracking branch 'github/master' 9 years ago
Makefile Do not build unit tests by default with make (#233). 9 years ago
Makefile.bsd Setup unit test environment. 9 years ago
Makefile.linux Setup unit test environment. 9 years ago
Makefile.osx Setup unit test environment. 9 years ago
NTCPSession.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
NTCPSession.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
NetDb.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
NetDb.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
NetDbRequests.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
NetDbRequests.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Profiling.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Profiling.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Queue.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
README.md Do not build unit tests by default with make (#233). 9 years ago
Reseed.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Reseed.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
RouterContext.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
RouterContext.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
RouterInfo.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
RouterInfo.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
SAM.cpp Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
SAM.h Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
SOCKS.cpp Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
SOCKS.h Make address for proxies, BOB, SAM, ... configurable (#235). 9 years ago
SSU.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
SSU.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
SSUData.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
SSUData.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
SSUSession.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
SSUSession.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Signature.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Signature.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Streaming.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Streaming.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TODO Update TODO. 9 years ago
Timestamp.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TransitTunnel.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TransitTunnel.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TransportSession.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Transports.cpp Fix #227: Transports::GetRandomPeer() crashes if m_Peers is empty 9 years ago
Transports.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Tunnel.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
Tunnel.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TunnelBase.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TunnelConfig.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TunnelEndpoint.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TunnelEndpoint.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TunnelGateway.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TunnelGateway.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TunnelPool.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
TunnelPool.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
UPnP.cpp fixup! Fix UPnP for Win32 9 years ago
UPnP.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
aes.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
aes.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
api.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
api.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
base64.cpp Fix #229 by returning zero instead of -1. 9 years ago
base64.h Fix #229 by returning zero instead of -1. 9 years ago
filelist.mk Tests and documentation for base64. 9 years ago
hmac.h Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
i2p.cpp Tabs -> spaces (yes this breaks compatiblity with upstream) 9 years ago
stdafx.cpp Precompiled headers 9 years ago
stdafx.h Precompiled headers 9 years ago
util.cpp Fixes to GetMTUWindows and GetMTUWindowsIpv6 (thanks mlt). 9 years ago
util.h Cleanup util, add documentation. 9 years ago
version.h version 0.10.0 9 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.

Donations

BTC: 1K7Ds6KUeR8ya287UC4rYTjvC96vXyZbDY
LTC: LKQirrYrDeTuAPnpYq5y7LVKtywfkkHi59

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:

$ ./i2pd

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

Building Unit Tests

To build unit tests, you'll need to install the boost unit test framework.

On Ubuntu/Debian based

  • sudo apt-get install libboost-test-dev

To build the tests, run

$ make tests

Cmdline options

  • --host= - The external IP (deprecated).
  • --port= - The port to listen on
  • --httpport= - The http port to listen on
  • --httpaddress= - The ip address for the HTTP server, 127.0.0.1 by default
  • --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)
  • --httpproxyaddress= - The address to listen on (HTTP Proxy)
  • --socksproxyport= - The port to listen on (SOCKS Proxy)
  • --socksproxyaddress= - The address 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
  • --irchost= - The adddress of IRC tunnel to listen on, 127.0.0.1 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
  • --samhost= - Address of SAM bridge, 127.0.0.1 by default (only used if SAM is on)
  • --bobport= - Port of BOB command channel. Usually 2827. BOB is off if not specified
  • --bobaddress= - Address of BOB service, 127.0.0.1 by default (only used if BOB is on)
  • --i2pcontrolport= - Port of I2P control service. Usually 7650. I2PControl is off if not specified
  • --i2pcontroladdress= - Address of I2P control service, 127.0.0.1 by default (only used if I2PControl is on)
  • --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
; * address -- address to listen on, 127.0.0.1 by default
[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 = <b32>[,<b32>]