This document describes how to build the Electron desktop app from source.
- Electron desktop shell (
desktop/main.js) - Bundled WebUI static files (
desktop/resources/webui) - App assets (
desktop/assets)
Current behavior:
- Backend executable is bundled in the installer/package.
- App startup checks backend availability and auto-starts bundled backend when needed.
- Runtime data is stored under
~/.astrbotby default, not as a full AstrBot source project.
- Python environment ready in repository root (
uvavailable) - Node.js available
pnpmavailable
Desktop dependency management uses pnpm with a lockfile:
desktop/pnpm-lock.yamlpnpm --dir desktop install --frozen-lockfile
Run commands from repository root:
uv sync
pnpm --dir dashboard install
pnpm --dir dashboard build
pnpm --dir desktop install --frozen-lockfile
pnpm --dir desktop run dist:fullOutput files are generated under:
desktop/dist/
Start backend first:
uv run main.pyStart Electron shell:
pnpm --dir desktop run devdist:fullruns WebUI build + backend build + Electron packaging.- In packaged app mode, backend data root defaults to
~/.astrbot(can be overridden byASTRBOT_ROOT). - Backend build uses
uv run --with pyinstaller ..., so no manualPyInstallerinstall is required.
By default (ASTRBOT_ROOT not set), packaged desktop app uses this layout:
~/.astrbot/
data/
config/ # Main configuration
plugins/ # Installed plugins
plugin_data/ # Plugin persistent data
site-packages/ # Plugin dependency installation target in packaged mode
temp/ # Runtime temp files
skills/ # Skill-related runtime data
knowledge_base/ # Knowledge base files
backups/ # Backup data
The app does not store a full AstrBot source tree in home directory.
Startup behavior:
- Packaged app shows a local startup page first, then switches to dashboard after backend is reachable.
- If startup page never switches, check logs and timeout settings below.
Runtime logs:
- Electron shell log:
~/.astrbot/logs/electron.log - Backend stdout/stderr log:
~/.astrbot/logs/backend.log - On backend startup failure, the app dialog also shows the backend reason and backend log path.
Timeout and loading controls:
ASTRBOT_BACKEND_TIMEOUT_MScontrols how long Electron waits for backend reachability.- In packaged mode, default is
0(auto mode with a 5-minute safety cap). - In development mode, default is
20000. - If backend startup times out, app shows startup failure dialog and exits.
ASTRBOT_DASHBOARD_TIMEOUT_MScontrols dashboard page load wait time after backend is ready (default20000).- If you see
Unable to load the AstrBot dashboard., increaseASTRBOT_DASHBOARD_TIMEOUT_MS.
Startup page locale:
- Startup page language follows cached dashboard locale in
~/.astrbot/data/desktop_state.json. - Supported startup locales are
zh-CNanden-US. - Remove that file to reset locale fallback behavior.
Backend auto-start:
ASTRBOT_BACKEND_AUTO_START=0disables Electron-managed backend startup.- When disabled, backend must already be running at
ASTRBOT_BACKEND_URLbefore launching app.
If Electron download times out on restricted networks, configure mirrors before install:
export ELECTRON_MIRROR="https://npmmirror.com/mirrors/electron/"
export ELECTRON_BUILDER_BINARIES_MIRROR="https://npmmirror.com/mirrors/electron-builder-binaries/"
pnpm --dir desktop install --frozen-lockfile