i2pd/README.md

127 lines
4.9 KiB
Markdown
Raw Normal View History

2013-09-01 17:09:28 +02:00
i2pd
====
I2P router written in C++
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.
Requirements for Linux/FreeBSD/OSX
----------------------------------
2014-01-09 20:59:35 +01:00
GCC 4.6 or newer, Boost 1.46 or newer, crypto++. Clang can be used instead of
GCC.
2014-01-09 20:59:35 +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.
2015-01-16 02:44:18 +01:00
Downloads
------------
Official binary releases could be found at:
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/)
- 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
2014-04-03 18:18:56 +02:00
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
2014-01-31 01:42:27 +01:00
* $ 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
2014-01-31 07:35:21 +01:00
The client should now reseed by itself.
To visit an I2P page, you need to find the b32 address of your destination.
2014-10-21 13:44:48 +02:00
After that, go to the webconsole and add it behind the url. (Remove http:// from the address)
This should resulting in for example:
2014-10-21 13:44:48 +02:00
http://localhost:7070/4oes3rlgrpbkmzv4lqcfili23h3cvpwslqcfjlk6vvguxyggspwa.b32.i2p
2014-12-11 05:59:22 +01:00
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.
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).
* --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.
2014-03-17 23:31:29 +01:00
* --httpproxyport= - The port to listen on (HTTP Proxy)
2014-08-14 16:20:22 +02:00
* --socksproxyport= - The port 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
* --ircdest= - I2P destination address of IRC server. For example irc.postman.i2p
* --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).
* --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
2014-12-07 23:29:09 +01:00
* --bobport= - Port of BOB command channel. Usually 2827. BOB is off if not specified
2015-01-08 19:28:51 +01:00
* --i2pcontrolport= - Port of I2P control service. Usually 7650. I2PControl is off if not specified
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
Config files
------------
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:
i2p.conf:
2014-12-11 19:05:21 +01:00
log = 1
v6 = 0
ircdest = irc.postman.i2p
tunnels.cfg (filename of this config is subject of change):
2015-03-21 23:35:17 +01:00
; outgoing tunnel, to remote service
[tunnel1]
type = client ; mandatory
port = <integer> ; mandatory, bind our side of tunnel to this local port
keys = <filename> ; optional
destination = <ident> ; mandatory
destinationport = <integer> ; optional, port of remote i2p service
; incoming tunnel, for local service(s)
[tunnel2]
type = server ; mandatory
host = <ident> ; mandatory, hostname of our i2p service
keys = <filename> ; mandatory, hostname keys
port = <integer> ; mandatory, forward incoming connections from i2p to this port
inport = <integer> ; optional, i2p service port
accesslist = <ident>[,<ident>] ; optional, comma-separated list of i2p idents, allowed to connect to service
Note: '<ident>' type is a string like <hostname.i2p> or <abracadabra.b32.i2p>