1
0
mirror of https://github.com/PurpleI2P/pyseeder synced 2025-01-14 17:08:26 +00:00
Reseed data managment tools for I2P
Go to file
2016-10-15 11:30:06 +03:00
data initialize repository 2016-08-30 20:25:23 +03:00
output initialize repository 2016-08-30 20:25:23 +03:00
pyseeder Added reseed https server action + fixed some issues + refactored code 2016-10-07 12:25:51 -04:00
.gitignore initialize repository 2016-08-30 20:25:23 +03:00
INSTALL.md Instructions updated + requirements fix 2016-10-07 13:20:08 -04:00
pyseeder.py Added reseed https server action + fixed some issues + refactored code 2016-10-07 12:25:51 -04:00
README.md Update README.md 2016-10-15 11:30:06 +03:00
requirements.txt Instructions updated + requirements fix 2016-10-07 13:20:08 -04:00
transports.ini.example initialize repository 2016-08-30 20:25:23 +03:00

pyseeder

Reseed data managment tools for I2P

  • Generate reseed signing keypair
  • Make reseed data files (su3)
  • Download su3 files from official servers for mirroring
  • Upload reseed data to different places (with plugins)
  • Run HTTPS reseed server

Reseed transports are implemented so that users can bootstrap their I2P nodes without needing to connect to "official" I2P reseeds. This makes I2P more invisible for firewalls.

Installation instructions

Usage

$ python3 pyseeder.py --help
$ python3 pyseeder.py keygen --help

Generating keypair

$ python3 pyseeder.py keygen --cert data/user_at_mail.i2p.crt --private-key data/priv_key.pem --signer-id user@mail.i2p

This will generate certificate (user_at_mail.i2p.crt) and private RSA key (priv_key.pem) in data folder. E-mail is used as certificate identifier.

Script will prompt for private key password.

Generating reseed data

$ YOUR_PASSWORD="Pa55w0rd"
$ echo $YOUR_PASSWORD | python3 pyseeder.py reseed --netdb /path/to/netDb --private-key data/priv_key.pem --outfile output/i2pseeds.su3 --signer-id user@mail.i2p

This will generate file i2pseeds.su3 in output folder, using user@mail.i2p as certificate identifier.

Note: you'll have to enter your private key password to stdin, the above is one of the ways to do it (for cron and scripts).

Download su3 file from official servers

$ python3 pyseeder.py transport.pull --urls https://reseed.i2p-projekt.de/ https://reseed.i2p.vzaws.com:8443/ --outfile output/i2pseeds.su3

Note: --urls parameter is optional, defaults are "official" I2P reseeds.

Upload su3 file with pluggable transports

$ python3 pyseeder.py transport.push --config transports.ini --file output/i2pseeds.su3

All parameters are optional. Copy file transports.ini.example to transports.ini. Edit your settings in this new file.

Run HTTPS reseed server

$ python3 pyseeder.py serve --port 8443 --host 127.0.0.1 --private-key data/priv_key.pem --cert data/user_at_mail.i2p.crt --file output/i2pseeds.su3

Note: this server is fine for testing, but for "production" environments please use nginx webserver.