- Update default backup path from /a0/tmp/self-update-backups to /root/update-backups in self_update_manager.py, helpers/self_update.py, and documentation - Move aiogram from global requirements.txt to plugin-local requirements for _telegram_integration - Add ensure_dependencies() helper that installs aiogram on-demand via uv pip install - Add has_aiogram() check to avoid
2.6 KiB
Self Update
Agent Zero includes a Docker-oriented self-update flow for switching to a specific repository version tag on main, testing, or development.
How it works
- The WebUI writes a YAML request file outside
/a0so the request survives upgrades and downgrades. - Agent Zero restarts.
- The durable updater in
/exereads the YAML request before starting the UI. - If requested, it creates a zip backup of
/a0/usr. - It fetches the requested branch and version tag from the official Agent Zero repository.
- It updates
/a0while preserving gitignored paths such as/a0/usr. - It starts Agent Zero again and waits for
/api/healthto become healthy. - If the UI does not become healthy within the allowed time, it restores the previous checkout and starts that version again.
Durable files
The self-update flow stores its runtime files outside /a0:
- Trigger file:
/exe/a0-self-update.yaml - Status file:
/exe/a0-self-update-status.yaml - Last attempt log:
/exe/a0-self-update.log
Because these files live in /exe, you can recover from an older downgraded /a0 by creating a new update YAML manually.
Backup behavior
The updater can create a zip backup of /a0/usr before replacing repository files.
- The default backup directory is
/root/update-backups - The default file name format is
usr-YYYYMMDD-HHMMSS.zip - Conflict handling supports rename, overwrite, or fail-before-restart
Version selection
The WebUI preloads repository version tags for the selected branch into a standard selector.
Only tags from the current major release line are listed in the selector. If newer major lines are available on the selected branch, the UI shows an attention banner that links to the Docker update guide.
Agent Zero version tags follow this format:
v{major}.{minor}
Examples:
v1.0v1.1
Tags below v1.0 are ignored by the selector and rejected by the self-update request validator.
Major version limitation
Self-update is intentionally limited to changes within the same major line.
If a newer major line exists, the UI points you to the Docker setup guide because those upgrades require downloading a new Docker image. They can include operating system level changes or other breaking changes outside the repository checkout.
Safety notes
- Gitignored paths are preserved during update
- Obsolete tracked files are removed as part of the checkout replacement
- Rollback is automatic when the updated UI fails its health check
- The updater itself lives outside
/a0, so it is not lost by downgrading to an older repository state