/libp2p-relay

Setup a websocket libp2p relay with letsencrypt and nginx

Primary LanguageJavaScript

Websocket libp2p-relay

Description

This is a docker image and docker compose file which runs a

  • NodeJS websocket relay for libp2p with
  • nginx and
  • letsencrypt

Usage

via nodejs

  1. Copy .env.example to .env and change according to your environment
    • RELAY_DEV_MODE=true in order to disable gossip-sub tresholds
    • SERVER_NAME=your-server-name.domain.xyz
    • RELAY_PUBSUB_PEER_DISCOVERY_TOPICS=your-topic._peer-discovery._p2p._pubsub
    • RELAY_PRIVATE_KEY=how to generate a good private key for your node?
  2. Run node relay/src/relay.js
  3. Run DEBUG=libp2p:* node relay/src/relay.js (for debug mode) or

Docker

  1. Copy .env.example to .env and change to your environment
  2. Modify init-letsencrypt.sh (domains=(ipfs.le-space.de) around line 8) to setup your letsencrypt domain
  3. Run ./init-letsencrypt.sh (letsencrypt is creating ssl certificates for nginx)
  4. Run docker-compose up -d (nginx, letsencrypt, relay-service starting)
  5. Run docker-compose logs and find the libp2p address to connect your peers

Todo

  • move private key from relay.js into .env
  • SERVER_NAME inside docker-compose.yml should go into .env
  • init-letsencrypt.sh should take SERVER_NAME as an argument or environment variable
  • make listen addresses of relay service configurable via .env / docker-compose
  • make announce: ['/dns4/ipfs.le-space.de//tcp/443/wss'] configurable via .env / docker-compose
  • make bootstrap seed nodes configurable via .env / docker-compose
  • make pubsubPeerDiscovery topics configurable via .env / docker-compose