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.
i2p-zero/README.md

165 lines
5.8 KiB

5 years ago
<img src="https://github.com/knaccc/i2p-zero/blob/master/i2p-zero.png" align="left" width="336" height="124">
5 years ago
## Zero dependency, small footprint, cross-platform I2P Java Router with GUI, simple tunnel/socks controller and SAM interface
##
5 years ago
This project will run under Linux, and build native launchers for Linux, MacOS and Windows.
The launchers will include the I2P router, a SAM listener, simple tunnel and socks tunnel functionality and a minimal JVM.
5 years ago
## GUI Screenshots
<img src="https://github.com/knaccc/i2p-zero/blob/master/screenshot1.png" align="center" width="497" height="440">
<br/>
<img src="https://github.com/knaccc/i2p-zero/blob/master/screenshot2.png" align="center" width="892" height="549">
<br/>
<img src="https://github.com/knaccc/i2p-zero/blob/master/screenshot3.png" align="center" width="880" height="540">
5 years ago
## Footprint
The zero-dependency distribution sizes are as follows:
OS | Uncompressed size (MB) | xz Compressed size (MB)
------------ | ------------- | -------------
Linux | 48.1 | 28.8
Mac | 38.0 | 24.5
Windows | 38.9 | 26.9
Linux GUI | 72.4 | 48.0
Mac GUI | 61.1 | 43.1
Windows GUI | 59.6 | 43.2
5 years ago
5 years ago
## Building the launchers
5 years ago
From a freshly installed Ubuntu system, first ensure git is installed:
5 years ago
`sudo apt install git`
Then, retrieve this project from git:
`git clone https://github.com/knaccc/i2p-zero.git`
5 years ago
Note that the current version of this script uses jdk-11.0.2. If this version of Java becomes no longer available for
download, then update the references to jdk-11.0.2 in java-config.sh to the later version. To locate a recent
5 years ago
JDK download URL, see https://jdk.java.net/11/
5 years ago
5 years ago
Also note that JDKs for Linux, MacOS and Windows will be downloaded, which will total several hundred megabytes.
Run the `bin/build-all.sh` script, which will in turn call the following scripts:
5 years ago
1. `bin/import-packages.sh` to retrieve the I2P Java sources, OpenJDK and the Ant build tool
5 years ago
5 years ago
2. `bin/build-original-i2p.sh` to build the I2P project retrieved from the I2P repository
5 years ago
5 years ago
3. `build-launcher.sh` to convert the I2P JARs to modules, compile the Java source code in this project, and then use
5 years ago
the jlink tool to build zero-dependency platform-specific launchers.
5 years ago
5 years ago
## Running the GUI
To run the Linux router, type:
`dist/linux-gui/router/bin/launch-gui.sh`
or double-click the `dist/linux-gui/router/i2p-zero.desktop` file
To run the MacOS router, double-click the app located at `dist/mac-gui/router/i2p-zero.app`
For Windows, double-click on `dist/windows-gui/router/bin/launch-gui.bat`
Note that for the Windows GUI to run, you may need to install the latest <a href="https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads">Microsoft Visual C++ Redistributable</a>
## Running the command line version
5 years ago
5 years ago
To run the Linux router, type:
5 years ago
5 years ago
`dist/linux/router/bin/launch.sh`
5 years ago
5 years ago
To run the MacOS router, type:
`dist/mac/router/bin/launch.sh`
5 years ago
For Windows, run:
5 years ago
5 years ago
`dist/windows/router/bin/launch.bat`
5 years ago
5 years ago
If it launches successfully, you'll see the message:
5 years ago
5 years ago
```
5 years ago
I2P router launched.
5 years ago
Press Ctrl-C to gracefully shut down the router (or send the SIGINT signal to the process).
```
5 years ago
## Tunnel control
5 years ago
Note that it may take a short while for new tunnels to be set up.
Call the `dist/linux/router/bin/tunnel-control.sh` script as follows to create and destroy tunnels:
#### Get the router reachability status. Returns a string such as "Testing", "Firewalled", "Running", "Error"
`tunnel-control.sh router.reachability`
#### Listen for I2P connections and forward them to the specified host and port. Returns the I2P base 32 destination address for the server tunnel created.
Optionally, specify a directory for storing/reading the server key file.
If the directory doesn't exist with a file named *.b32.i2p.keys in it,
returns a newly created destination address and writes the secret key for the
new address to a file called <I2P dest addr>.keys in the specified directory. Otherwise, read the existing
secret key from that directory. The server tunnel will listen for I2P connections and forward them to the
specified host and port. Note that the base 32 I2P destination address deterministically depends on the contents of the .keys file).
`tunnel-control.sh server.create <host> <port> <(optional) directory>`
#### Check the state of a tunnel. Returns "opening" or "open"
`tunnel-control.sh server.state <base 32 I2P address>`
`tunnel-control.sh client.state <local port>`
`tunnel-control.sh http.state <local port>`
`tunnel-control.sh socks.state <local port>`
#### Close the tunnel listening for connections on the specified I2P destination address. Returns "OK".
`tunnel-control.sh server.destroy <base 32 I2P address>`
#### Create a tunnel that listens for connections on localhost on the specified port and forwards connections over I2P to the specified destination public key.
`tunnel-control.sh client.create <local port> <I2P destination public key>`
#### Close the tunnel listening for connections on the specified port. Returns "OK".
`tunnel-control.sh client.destroy <local port>`
#### Create an http proxy (for accessing .i2p web sites), listening on the specified port
`tunnel-control.sh http.create <local port>`
#### Destroy the http proxy listening on the specified port
`tunnel-control.sh http.destroy <local port>`
#### Create a socks tunnel, listening on the specified port
`tunnel-control.sh socks.create <local port>`
#### Destroy the socks tunnel listening on the specified port
`tunnel-control.sh socks.destroy <local port>`
#### Destroy all tunnels. Returns "OK"
`tunnel-control.sh all.destroy`
#### List all tunnels. Returns JSON string containing information about all tunnels currently in existence
`tunnel-control.sh all.list`
#### Start a SAM listener on port 7656. Returns "OK"
`tunnel-control.sh sam.create`
## Watch the I2P log for messages
5 years ago
`tail -f dist/linux/router/i2p.config/wrapper.log`