2013-09-01 17:09:28 +02:00
|
|
|
i2pd
|
|
|
|
====
|
|
|
|
|
2014-11-04 01:49:40 +01:00
|
|
|
I2P router written in C++
|
2015-11-03 15:34:44 +01:00
|
|
|
Contains all ongoing changes from https://bitbucket.org/orignal/i2pd/src
|
2013-09-01 19:49:06 +02:00
|
|
|
|
2015-01-12 16:54:09 +01:00
|
|
|
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.
|
|
|
|
|
2015-05-05 23:30:14 +02:00
|
|
|
Donations
|
|
|
|
---------
|
|
|
|
|
2015-05-05 23:30:32 +02:00
|
|
|
BTC: 1K7Ds6KUeR8ya287UC4rYTjvC96vXyZbDY
|
|
|
|
LTC: LKQirrYrDeTuAPnpYq5y7LVKtywfkkHi59
|
2015-11-03 15:22:09 +01:00
|
|
|
ANC: AQJYweYYUqM1nVfLqfoSMpUMfzxvS4Xd7z
|
2015-05-05 23:30:14 +02:00
|
|
|
|
2014-11-04 01:49:40 +01:00
|
|
|
Requirements for Linux/FreeBSD/OSX
|
|
|
|
----------------------------------
|
2014-01-09 20:59:35 +01:00
|
|
|
|
2015-11-03 15:22:09 +01:00
|
|
|
GCC 4.6 or newer, Boost 1.46 or newer, openssl, zlib. Clang can be used instead of
|
2014-11-04 01:49:40 +01:00
|
|
|
GCC.
|
2014-01-09 20:59:35 +01:00
|
|
|
|
2014-11-04 01:49:40 +01:00
|
|
|
Requirements for Windows
|
|
|
|
------------------------
|
|
|
|
|
2014-11-08 14:29:15 +01:00
|
|
|
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.
|
2014-01-31 01:39:16 +01:00
|
|
|
|
2015-01-16 02:44:18 +01:00
|
|
|
Downloads
|
|
|
|
------------
|
|
|
|
|
|
|
|
Official binary releases could be found at:
|
2015-11-27 03:04:19 +01:00
|
|
|
http://i2pd.website/releases/
|
2015-11-27 03:03:58 +01:00
|
|
|
older releases
|
2015-01-16 02:44:18 +01:00
|
|
|
http://download.i2p.io/purplei2p/i2pd/releases/
|
|
|
|
|
|
|
|
|
2014-07-26 07:04:19 +02:00
|
|
|
Build Statuses
|
|
|
|
---------------
|
|
|
|
|
2015-01-16 02:44:18 +01:00
|
|
|
- Linux x64 - [![Build Status](https://jenkins.greyhat.no/buildStatus/icon?job=i2pd-linux)](https://jenkins.nordcloud.no/job/i2pd-linux/)
|
2014-11-04 01:49:40 +01:00
|
|
|
- Linux ARM - To be added
|
2014-12-29 17:12:05 +01:00
|
|
|
- Mac OS X - Got it working, but not well tested. (Only works with clang, not GCC.)
|
2014-11-04 01:49:40 +01:00
|
|
|
- Microsoft VC13 - To be added
|
2014-04-03 18:18:56 +02:00
|
|
|
|
2014-01-31 01:39:16 +01:00
|
|
|
|
|
|
|
Testing
|
|
|
|
-------
|
|
|
|
|
|
|
|
First, build it.
|
|
|
|
|
2015-01-06 21:52:13 +01:00
|
|
|
On Ubuntu/Debian based
|
2015-11-03 15:22:09 +01:00
|
|
|
* sudo apt-get install libboost-dev libboost-filesystem-dev libboost-program-options-dev libboost-regex-dev libboost-date-time-dev libssl-dev zlib1g-dev
|
2014-01-31 01:42:27 +01:00
|
|
|
* $ cd i2pd
|
|
|
|
* $ make
|
2014-01-31 01:39:16 +01:00
|
|
|
|
2015-03-22 23:42:18 +01:00
|
|
|
Then, run it:
|
2014-01-31 01:39:16 +01:00
|
|
|
|
2015-03-22 23:42:18 +01:00
|
|
|
$ ./i2p
|
2014-01-31 01:39:16 +01:00
|
|
|
|
2014-01-31 07:35:21 +01:00
|
|
|
The client should now reseed by itself.
|
2015-11-22 22:47:55 +01:00
|
|
|
To visit an eepsite use HTTP proxy port 4446.
|
2015-11-22 22:48:38 +01:00
|
|
|
For tunnels follow [instructions](https://github.com/PurpleI2P/i2pd/wiki/tunnels.cfg)
|
2014-01-31 01:39:16 +01:00
|
|
|
|
2014-02-05 00:43:50 +01:00
|
|
|
|
2014-12-11 05:59:22 +01:00
|
|
|
Cmdline options
|
|
|
|
---------------
|
2014-02-05 00:43:50 +01:00
|
|
|
|
2015-03-24 18:33:29 +01:00
|
|
|
* --host= - The external IP (deprecated).
|
2014-02-05 00:43:50 +01:00
|
|
|
* --port= - The port to listen on
|
2015-11-30 15:44:32 +01:00
|
|
|
* --httpaddress= - The address to listen on (HTTP server)
|
|
|
|
* --httpport= - The port to listen on (HTTP server)
|
2014-02-05 00:43:50 +01:00
|
|
|
* --log= - Enable or disable logging to file. 1 for yes, 0 for no.
|
2014-09-08 22:43:20 +02:00
|
|
|
* --daemon= - Enable or disable daemon mode. 1 for yes, 0 for no.
|
2014-10-17 15:55:41 +02:00
|
|
|
* --service= - 1 if uses system folders (/var/run/i2pd.pid, /var/log/i2pd.log, /var/lib/i2pd).
|
2014-11-04 01:49:40 +01:00
|
|
|
* --v6= - 1 if supports communication through ipv6, off by default
|
2015-02-02 17:15:38 +01:00
|
|
|
* --floodfill= - 1 if router is floodfill, off by default
|
2015-03-19 16:14:21 +01:00
|
|
|
* --bandwidth= - L if bandwidth is limited to 32Kbs/sec, O if not. Always O if floodfill, otherwise L by default.
|
2015-11-30 15:44:32 +01:00
|
|
|
* --httpproxyaddress= - The address to listen on (HTTP Proxy)
|
|
|
|
* --httpproxyport= - The port to listen on (HTTP Proxy) 4446 by default
|
|
|
|
* --socksproxyaddress= - The address to listen on (SOCKS Proxy)
|
|
|
|
* --socksproxyport= - The port to listen on (SOCKS Proxy). 4447 by default
|
2015-03-17 16:44:01 +01:00
|
|
|
* --proxykeys= - optional keys file for proxy's local destination
|
2015-11-30 15:44:32 +01:00
|
|
|
* --ircaddress= - The address to listen on (IRC tunnel)
|
|
|
|
* --ircport= - The port listen on (IRC tunnel). 6668 by default
|
2014-11-04 01:49:40 +01:00
|
|
|
* --ircdest= - I2P destination address of IRC server. For example irc.postman.i2p
|
2015-03-17 16:44:01 +01:00
|
|
|
* --irckeys= - optional keys file for tunnel's local destination
|
2014-12-11 19:05:21 +01:00
|
|
|
* --eepkeys= - File name containing destination keys, for example privKeys.dat.
|
|
|
|
The file will be created if it does not already exist (issue #110).
|
2014-11-04 01:49:40 +01:00
|
|
|
* --eephost= - Address incoming trafic forward to. 127.0.0.1 by default
|
|
|
|
* --eepport= - Port incoming trafic forward to. 80 by default
|
2015-11-30 15:44:32 +01:00
|
|
|
* --samaddress= - The address to listen on (SAM bridge)
|
2014-11-04 01:49:40 +01:00
|
|
|
* --samport= - Port of SAM bridge. Usually 7656. SAM is off if not specified
|
2015-11-30 15:44:32 +01:00
|
|
|
* --bobaddress= - The address to listen on (BOB command channel)
|
2014-12-07 23:29:09 +01:00
|
|
|
* --bobport= - Port of BOB command channel. Usually 2827. BOB is off if not specified
|
2015-11-30 15:44:32 +01:00
|
|
|
* --i2pcontroladdress= - The address to listen on (I2P control service)
|
2015-01-08 19:28:51 +01:00
|
|
|
* --i2pcontrolport= - Port of I2P control service. Usually 7650. I2PControl is off if not specified
|
2015-11-20 13:52:38 +01:00
|
|
|
* --tunnelscfg= - Tunnels Config file (default: ~/.i2pd/tunnels.cfg or /var/lib/i2pd/tunnels.cfg)
|
2014-12-11 05:59:22 +01:00
|
|
|
* --conf= - Config file (default: ~/.i2pd/i2p.conf or /var/lib/i2pd/i2p.conf)
|
2014-12-11 19:05:21 +01:00
|
|
|
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.
|
2014-12-11 05:59:22 +01:00
|
|
|
|
2015-03-21 13:34:20 +01:00
|
|
|
Config files
|
|
|
|
------------
|
2014-02-05 00:43:50 +01:00
|
|
|
|
2014-12-11 05:59:22 +01:00
|
|
|
INI-like, syntax is the following : <key> = <value>.
|
2014-12-11 19:05:21 +01:00
|
|
|
All command-line parameters are allowed as keys, for example:
|
|
|
|
|
2015-03-21 13:34:20 +01:00
|
|
|
i2p.conf:
|
|
|
|
|
2014-12-11 19:05:21 +01:00
|
|
|
log = 1
|
|
|
|
v6 = 0
|
|
|
|
ircdest = irc.postman.i2p
|
2015-03-21 13:34:20 +01:00
|
|
|
|
|
|
|
tunnels.cfg (filename of this config is subject of change):
|
|
|
|
|
2015-04-02 15:01:15 +02:00
|
|
|
; 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
|
|
|
|
[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>]
|