mirror of
https://github.com/EKKOLearnAI/hermes-web-ui.git
synced 2026-06-06 19:10:17 +00:00
6da5cd605a
Co-authored-by: xingzhi <chuzihao.czh@alibaba-inc.com>
2.0 KiB
2.0 KiB
Agent Map
This file is a short map for coding agents. Keep detailed guidance in docs/
and keep this file small enough to fit into every task context.
First Reads
DEVELOPMENT.md- project commands, coding rules, test rules, and PR shape.ARCHITECTURE.md- package boundaries, data ownership, and runtime flow.docs/harness/README.md- how this repository is prepared for agent work.docs/harness/validation.md- which checks to run for each change type.docs/harness/worktree-runbook.md- isolated local dev and test setup.docs/harness/pr-review.md- self-review checklist before pushing.
Common Commands
npm ci --ignore-scripts
npm run harness:check
npm run test
npm run test:e2e
npm run build
Use the smallest relevant check while iterating. Before a broad PR, run
npm run harness:check, npm run test:coverage, npm run test:e2e, and
npm run build.
Code Ownership Map
packages/client/src- Vue 3 client, stores, routes, i18n, API helpers.packages/server/src- Koa API, Socket.IO, persistence, Hermes integration.packages/desktop- Electron wrapper, bundled Python/Hermes runtime, release artifacts.tests/client,tests/server,tests/shared- Vitest coverage.tests/e2e- Playwright browser coverage with mocked backend services..github/workflows- CI, release, Docker, and desktop packaging automation.
Hard Rules
- Keep routes thin: put request handling in controllers and reusable behavior in services.
- Keep Web UI state under
HERMES_WEB_UI_HOMEorHERMES_WEBUI_STATE_DIR. - Keep Hermes Agent state separate from Web UI state.
- Register local API routes before proxy catch-all routes.
- Use structured APIs and argument arrays instead of shell string construction.
- Add user-facing strings to every locale file.
- Do not mix unrelated refactors into a bug fix.
When The Agent Gets Stuck
Improve the harness instead of repeating the same prompt. Add missing docs, tests, logs, scripts, or CI checks so the next agent can see and verify the constraint directly.