This tool provides a secure and efficient reseed server for the I2P network. There are several utility commands to create, sign, and validate SU3 files. Please note that this requires at least Go version 1.13, and uses Go Modules.
go
, git
, and optionally make
are required to build the project. Precompiled binaries for most platforms are available at my github mirror https://github.com/eyedeekay/i2p-tools-1.
In order to install the build-dependencies on Ubuntu or Debian, you may use:
sudo apt-get install golang-go git make
Reseed-tools can be run as a user, as a freestanding service, or be installed as an I2P Plugin. It will attempt to configure itself automatically. You should make sure to set the --signer
flag or the RESEED_EMAIL
environment variable to configure your signing keys/contact info.
Plugin releases are available inside of i2p at http://idk.i2p/reseed-tools/ and via the github mirror at https://github.com/eyedeekay/reseed-tools/releases. These can be installed by adding them on the http://127.0.0.1:7657/configplugins.
git clone https://i2pgit.org/idk/reseed-tools
cd reseed-tools
make build
# Optionally, if you want to install to /usr/bin/reseed-tools
sudo make install
Debian users who are running I2P as a system service must also run the reseed-tools
as the same user. This is so that the reseed-tools can access the I2P service’s netDb directory. On Debian and Ubuntu, that user is i2psvc
and the netDb directory is: /var/lib/i2p/i2p-config/netDb
.
A systemd service is provided which should work with the I2P Debian package when reseed-tools is installed in /usr/bin/reseed-tools
. If you install with make install
this service is also installed. This service will cause the bundles to regenerate every 12 hours.
The contact email for your reseed should be added in: /etc/systemd/system/reseed.d/reseed.conf
.
Self-signed certificates will be auto-generated for these services. To change this you should edit the /etc/systemd/system/reseed.d/reseed.service
.
sudo systemctl enable reseed.service
sudo sysctl start reseed.service
sudo systemctl daemon-reload
sudo journalctl -u reseed.service
An initscript is also provided. The initscript, unlike the systemd service, cannot schedule itself to restart. You should restart the service roughly once a day to ensure that the information does not expire.
The contact email for your reseed should be added in: /etc/init.d/reseed
.
Self-signed certificates will be auto-generated for these services. To change this you should edit the /etc/init.d/reseed
.
If this is your first time running a reseed server (ie. you don’t have any existing keys), you can simply run the command and follow the prompts to create the appropriate keys, crl and certificates. Afterwards an HTTPS reseed server will start on the default port and generate 6 files in your current directory (a TLS key, certificate and crl, and a su3-file signing key, certificate and crl).
reseed-tools reseed --signer=you@mail.i2p --netdb=/home/i2p/.i2p/netDb --tlsHost=your-domain.tld
If you are using a reverse proxy server it may provide the TLS certificate instead.
reseed-tools reseed --signer=you@mail.i2p --netdb=/home/i2p/.i2p/netDb --port=8443 --ip=127.0.0.1 --trustProxy