Move insomnia-data models, services, database code, and common utilities into a dedicated workspace package. Update consumers to import from the new package entrypoints and declare workspace dependencies for the extracted package.
5.2 KiB
AGENTS.md
Tech Stack
- UI: React with React Router (loaders/actions pattern)
- Components: React Aria Components
- Desktop Shell: Electron (main + renderer processes)
- Styling: TailwindCSS
- Language: TypeScript
- Database: NeDB (
@seald-io/nedb) — embedded NoSQL - Build/Dev: Vite, npm workspaces monorepo
See package.json for current versions and .nvmrc for the Node version.
Strict Rules
- No unsolicited formatting. Rely on ESLint/Prettier. Do not reformat existing code.
- Strict scoping. Only modify code directly related to the prompt. Do not refactor adjacent code unless asked.
Command Output
Prefer quiet command variants to minimise output volume:
git log --oneline -20notgit loggit diff --statnotgit diffnpm test --silentnotnpm testtsc --noEmit 2>&1 | head -50for type-check failures- Use the
Readtool withlimitrather thancaton large files - Use
Grepwithhead_limitrather than unrestricted searches
Validation Commands
Run from repo root before considering work complete:
npm run lint # ESLint all workspaces
npm run type-check # TypeScript check all workspaces
npm test # Tests all workspaces (or: npm test -w packages/insomnia)
Worktree Setup
- New git worktrees may not have
node_modulesyet. Before installing or validating, switch to the repo's required runtime from the worktree root:
fnm use "$(cat .nvmrc)"
node -v
npm -v
- This repo expects the
.nvmrcNode version and npm 11+. Iffnmis unavailable, manually use an equivalent Node/npm version before running anynpmcommands. - After switching versions in a fresh worktree, install dependencies from repo root with
npm ci. - Do not use
npm ci --ignore-scriptsfor normal worktree setup. It leaves Electron partially installed, which later breaks builds, renderer import checks, and other validation commands.
Repository Structure
packages/
insomnia/ ← Main Electron app
src/
common/ ← Shared utils, settings types
routes/ ← React Router files (clientLoader/clientAction)
ui/ ← React components, hooks, insomnia-fetch.ts
main/ ← Electron IPC handlers, preload.ts
account/ ← Auth, session, encryption
sync/ ← Git/VCS sync
network/ ← Request execution engine
templating/ ← Nunjucks rendering (Web Worker)
insomnia-data/ ← Data models, services, NeDB implementation, shared data utilities
insomnia-api/ ← Cloud API client
insomnia-inso/ ← CLI tool
insomnia-testing/ ← Test framework
Data Model Hierarchy
Organization
→ Project (local | remote/cloud | git-backed)
→ Workspace (scope: 'collection' | 'design')
→ Base Environment (auto-created: use models.environment.getOrCreateForParentId(workspaceId))
→ Sub-Environments
→ Cookie Jar (auto-created)
→ Request Group (folders)
→ Request (HTTP, GraphQL, gRPC, WebSocket, Socket.IO)
→ Request (can be direct child of workspace)
Note: A Workspace with scope: 'collection' IS the collection.
Key Patterns
- Route-Based Actions: Mutations use React Router's
clientAction(src/routes/).- CRITICAL:
clientActionblocks navigation. For long-running UI operations, use plain async functions instead.
- CRITICAL:
- Database Buffering: Always buffer bulk writes (
database.bufferChangesIndefinitely(), thenflushChanges()). Unbuffered writes fire UI revalidation per operation, causing severe lag. - State Management: Use Router loaders/actions and NeDB for persistent state. Use React
useState/context for ephemeral UI state (No Redux/Zustand). - Electron IPC: For main↔renderer communication, define handlers in
src/main/ipc/, expose insrc/main/preload.ts, and updatewindow.maininsrc/global.d.ts. - Templates: Nunjucks runs in a Web Worker (
src/templating/). Use{{ _.variable_name }}. - Models: Follow CRUD via
models.<type>(e.g.,create(),update()). - HTTP Calls: Use
insomniaFetch()for Insomnia backend APIs. Use plainfetch()for external/third-party APIs. - Styling: Tailwind utility classes only. Use
clsx/tailwind-mergefor conditionals. Use React Aria for interactive HTML elements. - Testing: Use Vitest (unit) and Playwright (E2E). Co-locate unit tests as
filename.test.ts. Usevi.mock(). Prefer testing logic via loaders over mounting components. - E2E tests live in
packages/insomnia-smoke-test/. Full docs:packages/insomnia-smoke-test/README.md. - Run E2E from repo root:
npm run test:smoke:dev(filter:npm run test:smoke:dev -- <title-substring>). - New test imports:
import { test } from '../../playwright/test'andimport { expect } from '@playwright/test'.
Sensitive Data
- Vault system (AES-GCM): For environment secrets (
EnvironmentKvPairDataType.SECRET). - Electron safeStorage: Platform-native encryption (
window.main.secretStorage).