2.5 KiB
2.5 KiB
apps/AGENTS.md
Follow the root AGENTS.md first. This file only records module-level boundaries for apps/.
Active apps
apps/web: Next.js 16 App Router + React 18 web runtime. Entrypoints live inapps/web/app/; the main client shell isapps/web/src/App.tsx. During localtools-devweb runs,apps/web/next.config.tsrewrites/api/*,/artifacts/*, and/frames/*toOD_PORT.apps/daemon: Express + SQLite local daemon andodbin. It owns REST/SSE APIs, agent CLI spawning, skills, design systems, artifact persistence, static serving, and local data under.od/.apps/desktop: Electron shell. Desktop does not guess the web port; it reads runtime status through sidecar IPC and opens the reported web URL.apps/packaged: Thin packaged Electron runtime entry. It starts packaged daemon/web sidecars, registers theod://entry protocol, and delegates desktop host behavior toapps/desktop.
Daemon layout
apps/daemon/src/contains only daemon app source.apps/daemon/tests/contains daemon tests.apps/daemon/sidecar/contains the daemon sidecar entry.- CLI/agent argument changes or stdout parser changes belong in
apps/daemon/src/agents.tsand the matching parser tests.
Sidecar awareness
- App business layers must not import sidecar packages or branch on
runtime.mode,namespace,ipc, orsource. - Keep sidecar awareness in
apps/<app>/sidecaror the desktop sidecar entry wrapper.
Packaged runtime
apps/nextjshas been removed; do not restore it.- Packaged web uses Next.js SSR through the web sidecar; do not put Next output under daemon
OD_RESOURCE_ROOT. - Packaged
OD_RESOURCE_ROOTis only for daemon non-Next read-only resources:skills/,design-systems/, andframes/. - Packaged data/log/runtime/cache paths must be namespace-scoped and must not depend on daemon or web ports.
- Daemon↔web packaged traffic still uses an HTTP origin/port because Next.js dev server and SSR proxy paths assume HTTP origins; switching to Unix sockets would require patching Next internals. The invariant is that data/log/runtime/cache paths never embed ports.
Common app commands
pnpm --filter @open-design/web typecheck
pnpm --filter @open-design/web test
pnpm --filter @open-design/daemon typecheck
pnpm --filter @open-design/daemon test
pnpm --filter @open-design/daemon build
pnpm --filter @open-design/desktop typecheck
pnpm --filter @open-design/desktop build
pnpm --filter @open-design/packaged typecheck
pnpm --filter @open-design/packaged build