Skip to content

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/ipc/register-app-utility-ipc.ts: privileged app utility IPC such as native dialogs, file manager integration, SFTP temp-file creation, and validated OS-open/Open With flows.
    • src/preload.ts: secure renderer bridge.
    • src/security/database-encryption.ts: DB path/key handling helpers.
    • resources/helpers: packaged OS helpers, including the macOS NSWorkspace SFTP Open With helper source/binary.
    • scripts/compile-macos-open-with-helper.mjs: macOS-only build hook that compiles the SFTP Open With helper before packaging.

packages/renderer

  • Role: React UI layer.
  • Key folders:
    • src/pages: feature pages (Home, SSH, SSHEditor, Settings, SettingsEditor, etc.). Home owns the SSH, keychain, and port-forwarding landing surfaces.
    • src/pages/sftp: SFTP page submodules for browser UI composition, action menus, directory/tree/detail panels, and shared SFTP helpers.
    • 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), shared date-time display formatting (date-time-format.ts), and 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, port-forwarding rules, and local terminal actions.
    • src/audit: local-first audit domain (sanitization, retention policy, query model, write service).
    • src/ssh: SSH auth/session logic (ssh2, known-host trust, telemetry, keychain-backed credential resolution) plus shared non-shell connection helpers.
    • src/port-forward: SSH port-forwarding rule validation, SOCKS5 parsing, and active runtime session service.
    • src/sftp: SFTP browser, download, and file-operation session logic (ssh2.sftp, path normalization, entry mapping, session cleanup).
    • src/settings: settings payload defaults and validation parsers.
    • src/validation-utils.ts: shared backend HTTP-boundary validation primitives used by route and domain payload 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/http.ts: API path-token and query-string resolution helpers shared by main IPC proxying and renderer browser transport.
  • src/ipc.ts: shared IPC-only payload enums and structs that are not generated from OpenAPI, such as app menu actions and SFTP Open With application descriptors.
  • 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.
  • src/sftp.ts: shared SFTP entry/name ordering helpers consumed by backend session listings and renderer browser/tree views.

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) via mergeTranslationTrees(...) 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-contract first, 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.

5. Not Implemented Yet (Planned)

  • Full SFTP transfer queue module (upload streams, directory download, progress/cancellation, conflict handling, and editor write-back integration).
  • Dedicated shared common package is not present yet; current sharing is done through api-contract + i18n.

6. Common Change Scenarios

Add New IPC Action

  1. Define or reuse contract types in packages/api-contract when needed.
  2. Expose the bridge API in packages/main/src/preload.ts.
  3. Add ipcMain handler in packages/main/src/ipc/* and, when needed, backend proxy wiring.
  4. Wire renderer transport wrapper in packages/renderer/src/lib.
  5. Update docs/developer/core/ipc-protocol.md in the same change set.

Add New Backend Capability

  1. Add route under packages/backend/src/http/routes.
  2. Add service logic in domain module (ssh, local-terminal, or new module).
  3. Add validation/parser layer for input boundaries.
  4. For security-core operations, emit AuditEventService events with redacted metadata.
  5. Expose consumption path to renderer via main bridge.
  6. Sync architecture/runtime docs.

Add New Port Forwarding Behavior

  1. Update packages/api-contract/openapi/cosmosh.openapi.yaml first when route or payload shape changes.
  2. Keep persistence fields in packages/backend/prisma/schema.prisma and matching migrations.
  3. Keep runtime ownership in packages/backend/src/port-forward, using packages/backend/src/ssh/connect.ts for SSH authentication and host trust.
  4. Mirror bridge changes through packages/main/src/preload.ts, packages/main/src/ipc/register-backend-ipc.ts, packages/renderer/src/vite-env.d.ts, and renderer API wrappers.
  5. Update docs/developer/runtime/port-forwarding.md and docs/zh-CN/developer/runtime/port-forwarding.md.

Add New Application Setting

  1. In packages/api-contract/src/settings-registry.ts:
  • Add the key and its type to the SettingsValues interface.
  • Add a SettingDefinition entry to the SETTINGS_REGISTRY array (default value, constraints, UI control, category, i18n keys, etc.).
  1. Add i18n keys in packages/i18n/locales/en/*.json and zh-CN/*.json.
  2. No other files need changes — validation, defaults, and UI rendering are derived from the registry automatically.

7. Local-First Audit Ownership Map (2026-03)

  • Data model owner:
    • packages/backend/prisma/schema.prisma (AuditEvent, AuditSyncCursor).
    • packages/backend/prisma/migrations/* for runtime schema convergence.
  • Runtime owner:
    • packages/backend/src/audit/service.ts for write/query/retention flow.
    • packages/backend/src/audit/sanitizer.ts for metadata redaction and size caps.
    • packages/backend/src/http/routes/audit.ts for list/detail API surface.
  • Bridge owner:
    • packages/main/src/ipc/register-backend-ipc.ts and packages/main/src/preload.ts for audit IPC channels.
  • Renderer owner:
    • packages/renderer/src/pages/AuditLogs.tsx for operator-facing list/detail experience.
    • packages/renderer/src/lib/api/* for typed transport/client mapping.
  • Documentation owner:
    • docs/developer/runtime/audit-events.md and docs/zh-CN/developer/runtime/audit-events.md as runtime source pages.

8. SSH Keychain Ownership Map (2026-03)

  • Data model owner:
    • packages/backend/prisma/schema.prisma for SshKeychain and SshServer.keychainId relation.
    • Keychain folder/tag metadata reuses SshFolder and SshTag (plus SshKeychainTagLink) instead of dedicated keychain-only folder/tag tables.
  • Runtime owner:
    • packages/backend/src/http/routes/ssh.ts for keychain CRUD + credential fetch routes.
    • packages/backend/src/ssh/session-service.ts for server→keychain credential hydration during connect.
  • Bridge owner:
    • packages/main/src/ipc/register-backend-ipc.ts and packages/main/src/preload.ts for keychain IPC proxy channels.
  • Renderer owner:
    • packages/renderer/src/pages/SSHEditor.tsx for per-server keychain selection + inline fallback editing flow.
    • packages/renderer/src/pages/SSHKeychains.tsx for dedicated keychain CRUD management workflow.
    • packages/renderer/src/pages/Home.tsx for the shared Home sidebar and SSH / keychain / port-forwarding mode bodies; the Home keychain mode reuses shared SSH folders/tags and SSHKeychainEditorDialog for create/edit. Each Home mode owns an independent sort/group view preference so mode switches do not rewrite another surface's organization state.

9. SSH Port Forwarding Ownership Map (2026-05)

  • Data model owner:
    • packages/backend/prisma/schema.prisma (PortForwardRule, PortForwardRuleType).
    • packages/backend/prisma/migrations/*port_forward_rules* for runtime schema convergence.
  • Contract owner:
    • packages/api-contract/openapi/cosmosh.openapi.yaml for routes, payloads, API codes, and generated API_PATHS.
    • packages/api-contract/src/index.ts for exported request/response aliases consumed by main/renderer.
  • Runtime owner:
    • packages/backend/src/http/routes/port-forward.ts for CRUD/start/stop routes.
    • packages/backend/src/port-forward/session-service.ts for active local/remote/dynamic runtime state.
    • packages/backend/src/port-forward/validation.ts and socks5.ts for input and SOCKS protocol boundaries.
    • packages/backend/src/ssh/connect.ts for shared SSH authentication and host trust.
  • Bridge owner:
    • packages/main/src/ipc/register-backend-ipc.ts, packages/main/src/preload.ts, and packages/renderer/src/vite-env.d.ts.
  • Renderer owner:
    • packages/renderer/src/pages/Home.tsx for Home -> Port Forwarding table, mode-local sort/group controls, dialog, actions, and host trust retry.
    • packages/renderer/src/lib/api/* and packages/renderer/src/lib/backend.ts for typed transport wrappers.
  • Documentation owner:
    • docs/developer/runtime/port-forwarding.md and docs/zh-CN/developer/runtime/port-forwarding.md.