Cosmosh Project Map
1. Monorepo Layout
flowchart TB ROOT[Cosmosh Root] ROOT --> MAIN[packages/main] ROOT --> RENDERER[packages/renderer] ROOT --> BACKEND[packages/backend] ROOT --> API[packages/api-contract] ROOT --> I18N[packages/i18n] ROOT --> DOCS[docs] ROOT --> SCRIPTS[scripts]
2. Directory Responsibilities
packages/main
- Role: Electron host process.
- Key files:
src/index.ts: app bootstrap, BrowserWindow config, IPC handlers, backend subprocess management.src/preload.ts: secure renderer bridge.src/security/database-encryption.ts: DB path/key handling helpers.
packages/renderer
- Role: React UI layer.
- Key folders:
src/pages: feature pages (Home,SSH,SSHEditor,Settings,SettingsEditor, etc.).src/components/ui: Radix-based primitive wrappers and styling contracts.src/components/home: home/SSH shared entity modules (card/icon rendering, visual picker, reusable folder-creation dialog).src/components/terminal: terminal interaction composites (context menu, selection bar, autocomplete menu).src/lib: backend transport, i18n, settings bootstrap (app-settings.ts), utility abstractions (including shared entity visual helpers and folder-dialog hook).theme: token source used to generate CSS variable system.
packages/backend
- Role: Internal API + session orchestration runtime.
- Key folders:
src/http/routes: REST endpoints for settings, SSH entities, and local terminal actions.src/ssh: SSH auth/session logic (ssh2, known-host trust, telemetry, keychain-backed credential resolution).src/settings: settings payload defaults and validation parsers.src/local-terminal: local PTY session logic (node-pty).src/terminal: shared terminal session primitives (WebSocket message normalization, history parsing, size clamping, history sync timing helpers).src/terminal/completion: shared terminal auto-complete domain (spec dataset, ranking engine, completion payload shaping) used by both SSH and local-terminal session services.src/db: Prisma initialization and DB lifecycle.
packages/api-contract
Shared protocol constants, request/response types, OpenAPI source, generated contracts.
src/settings-registry.ts: single source of truth for all settings definitions — types, defaults, constraints, enum sets, UI control metadata, categories, and helper functions. Adding/removing a setting only requires editing this file.src/settings.ts: generic, registry-driven validation and normalization helpers (normalizeSettingsValuesStrict,normalizeSettingsValuesWithDefaults) shared by backend and renderer.
packages/i18n
Locale JSON source files and i18n runtime package for main/backend/renderer scopes.
- Runtime core is payload-agnostic. Consumers import only required locale JSON files and register them through
createMessages(...)+createI18n(...). - Backend scope can merge generated completion locale data (for example
backend-inshellisense.json) viamergeTranslationTrees(...)before registration.
3. Feature Placement Rules
flowchart TD
A[New Feature Request] --> B{UI only?}
B -- Yes --> C[packages/renderer/src/pages + components]
B -- No --> D{Needs privileged access?}
D -- Yes --> E[Add preload bridge API + main IPC]
E --> F[Main proxies to backend or executes OS action]
D -- No --> G[Add backend route/service]
G --> H[Expose through transport in renderer]
F --> I[Update docs + ipc-protocol]
H --> I
4. Naming & Structure Guidelines
- Keep cross-process contracts in
api-contractfirst, then consume in backend/main/renderer. - Keep renderer side effects in
src/lib(transport/services), not directly in presentational components. - Add new IPC channels only via preload and mirror declaration in
renderer/src/vite-env.d.ts. - For backend features:
- route in
http/routes/* - business/session logic in dedicated service module
- input validation in
ssh/validation.ts-style parser modules.
- route in
5. Not Implemented Yet (Planned)
- Full SFTP feature module (backend service, WebSocket/file transfer protocol, renderer explorer page).
- Dedicated shared
commonpackage is not present yet; current sharing is done throughapi-contract+i18n.
6. Common Change Scenarios
Add New IPC Action
- Define or reuse contract types in
packages/api-contractwhen needed. - Expose the bridge API in
packages/main/src/preload.ts. - Add
ipcMainhandler and backend proxy inpackages/main/src/index.ts. - Wire renderer transport wrapper in
packages/renderer/src/lib. - Update
docs/developer/core/ipc-protocol.mdin the same change set.
Add New Backend Capability
- Add route under
packages/backend/src/http/routes. - Add service logic in domain module (
ssh,local-terminal, or new module). - Add validation/parser layer for input boundaries.
- Expose consumption path to renderer via main bridge.
- Sync architecture/runtime docs.
7. SSH Keychain Ownership Map (2026-03)
- Data model owner:
packages/backend/prisma/schema.prismaforSshKeychainandSshServer.keychainIdrelation.- Keychain folder/tag metadata reuses
SshFolderandSshTag(plusSshKeychainTagLink) instead of dedicated keychain-only folder/tag tables.
- Runtime owner:
packages/backend/src/http/routes/ssh.tsfor keychain CRUD + credential fetch routes.packages/backend/src/ssh/session-service.tsfor server→keychain credential hydration during connect.
- Bridge owner:
packages/main/src/ipc/register-backend-ipc.tsandpackages/main/src/preload.tsfor keychain IPC proxy channels.
- Renderer owner:
packages/renderer/src/pages/SSHEditor.tsxfor per-server keychain selection + inline fallback editing flow.packages/renderer/src/pages/SSHKeychains.tsxfor dedicated keychain CRUD management workflow.
Add New Application Setting
- In
packages/api-contract/src/settings-registry.ts:- Add the key and its type to the
SettingsValuesinterface. - Add a
SettingDefinitionentry to theSETTINGS_REGISTRYarray (default value, constraints, UI control, category, i18n keys, etc.).
- Add the key and its type to the
- Add i18n keys in
packages/i18n/locales/en/*.jsonandzh-CN/*.json. - No other files need changes — validation, defaults, and UI rendering are derived from the registry automatically.