Files
2026-05-25 17:04:34 +03:00

2.2 KiB

Development

Requirements for the development of Qortal-Hub from sources:

  • installation of nodejs from the official site
  • Python 3.9+ and Git on PATH for Reticulum networking during Electron development
  • an IDE like vscode or Intellij, or similar tools
  • some knowledge of React and its ecosystem

Running Qortal-Hub while developing

Browser-only development:

Follow these steps:

  • install dependencies: npm install
  • npm run dev
  • open the browser at page http://localhost:5173/

Electron development with Reticulum networking:

  • install root dependencies: npm install
  • sync Electron after web/native changes: npx cap sync @capacitor-community/electron
  • move into Electron folder: cd electron
  • install Electron dependencies: npm install
  • start the desktop app: npm run electron:start

On first run, Electron installs the Qortal Reticulum runtime from https://github.com/Philreact/Reticulum.git@master plus LXMF into electron/resources/reticulum-runtime/venv. If that runtime gets stale or broken, rebuild it with:

cd electron
rm -rf resources/reticulum-runtime/venv
npm run bundle:reticulum-venv

Build Qortal-Hub from Source

Follow these steps:

  • install dependencies: npm install

  • npm run build

  • npx cap sync @capacitor-community/electron

  • move into electron folder: cd electron

  • npm install

  • npm run build

Alternatively you can start the app:

  • npm run electron:start

Or create an Executable Package for linux:

  • npm run electron:make-local

Reticulum is bundled as a native binary for packaged Electron builds. For Linux release artifacts, prefer the Docker commands so the bundled native binaries are built on Debian 11 with an older glibc compatibility baseline:

  • Linux x64: npm run electron:make-lin-docker or npm run electron:make-lin-docker-appimage
  • Linux arm64: npm run electron:make-arm-docker or npm run electron:make-arm-docker-appimage
  • macOS: npm run electron:make-mac
  • Windows: npm run electron:make-win

Linux arm64 Docker builds from a non-arm64 host require QEMU/binfmt arm64 emulation on the host.

Contribution guide

See some useful instructions about contribution.