qualia-framework 2.6.0 → 3.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (321) hide show
  1. package/CLAUDE.md +64 -0
  2. package/README.md +103 -30
  3. package/agents/builder.md +110 -0
  4. package/agents/planner.md +134 -0
  5. package/agents/qa-browser.md +186 -0
  6. package/agents/verifier.md +221 -0
  7. package/bin/cli.js +336 -531
  8. package/bin/install.js +570 -0
  9. package/bin/qualia-ui.js +299 -0
  10. package/bin/state.js +630 -0
  11. package/bin/statusline.js +252 -0
  12. package/guide.md +63 -0
  13. package/hooks/auto-update.js +139 -0
  14. package/hooks/branch-guard.js +47 -0
  15. package/hooks/migration-guard.js +60 -0
  16. package/hooks/pre-compact.js +32 -0
  17. package/hooks/pre-deploy-gate.js +110 -0
  18. package/hooks/pre-push.js +33 -0
  19. package/hooks/session-start.js +170 -0
  20. package/package.json +29 -20
  21. package/rules/design-reference.md +179 -0
  22. package/rules/frontend.md +126 -0
  23. package/skills/qualia/SKILL.md +87 -0
  24. package/skills/qualia-build/SKILL.md +97 -0
  25. package/skills/qualia-debug/SKILL.md +87 -0
  26. package/skills/qualia-design/SKILL.md +93 -0
  27. package/skills/qualia-handoff/SKILL.md +66 -0
  28. package/skills/qualia-idk/SKILL.md +8 -0
  29. package/skills/qualia-learn/SKILL.md +88 -0
  30. package/skills/qualia-new/SKILL.md +323 -0
  31. package/{framework/skills → skills}/qualia-optimize/SKILL.md +1 -1
  32. package/skills/qualia-pause/SKILL.md +63 -0
  33. package/skills/qualia-plan/SKILL.md +101 -0
  34. package/skills/qualia-polish/SKILL.md +157 -0
  35. package/skills/qualia-quick/SKILL.md +37 -0
  36. package/skills/qualia-report/SKILL.md +105 -0
  37. package/skills/qualia-resume/SKILL.md +49 -0
  38. package/skills/qualia-review/SKILL.md +76 -0
  39. package/skills/qualia-ship/SKILL.md +90 -0
  40. package/skills/qualia-skill-new/SKILL.md +167 -0
  41. package/skills/qualia-task/SKILL.md +91 -0
  42. package/skills/qualia-verify/SKILL.md +113 -0
  43. package/templates/DESIGN.md +137 -0
  44. package/templates/plan.md +28 -0
  45. package/templates/project.md +22 -0
  46. package/templates/state.md +27 -0
  47. package/templates/tracking.json +20 -0
  48. package/tests/bin.test.sh +673 -0
  49. package/tests/hooks.test.sh +315 -0
  50. package/tests/state.test.sh +535 -0
  51. package/tests/statusline.test.sh +243 -0
  52. package/bin/collect-metrics.sh +0 -62
  53. package/framework/.claudeignore +0 -51
  54. package/framework/CLAUDE.md +0 -51
  55. package/framework/MCP_SETUP.md +0 -229
  56. package/framework/agents/architecture-strategist.md +0 -53
  57. package/framework/agents/backend-agent.md +0 -150
  58. package/framework/agents/code-simplicity-reviewer.md +0 -86
  59. package/framework/agents/frontend-agent.md +0 -111
  60. package/framework/agents/kieran-typescript-reviewer.md +0 -96
  61. package/framework/agents/performance-oracle.md +0 -111
  62. package/framework/agents/qualia-codebase-mapper.md +0 -761
  63. package/framework/agents/qualia-debugger.md +0 -1204
  64. package/framework/agents/qualia-executor.md +0 -882
  65. package/framework/agents/qualia-integration-checker.md +0 -424
  66. package/framework/agents/qualia-phase-researcher.md +0 -457
  67. package/framework/agents/qualia-plan-checker.md +0 -700
  68. package/framework/agents/qualia-planner.md +0 -1245
  69. package/framework/agents/qualia-project-researcher.md +0 -603
  70. package/framework/agents/qualia-research-synthesizer.md +0 -200
  71. package/framework/agents/qualia-roadmapper.md +0 -606
  72. package/framework/agents/qualia-verifier.md +0 -686
  73. package/framework/agents/red-team-qa.md +0 -130
  74. package/framework/agents/security-auditor.md +0 -72
  75. package/framework/agents/team-orchestrator.md +0 -229
  76. package/framework/agents/teams/framework-audit-team.md +0 -66
  77. package/framework/agents/teams/full-stack-team.md +0 -48
  78. package/framework/agents/teams/optimize-team.md +0 -53
  79. package/framework/agents/teams/review-team.md +0 -70
  80. package/framework/agents/teams/ship-team.md +0 -86
  81. package/framework/agents/test-agent.md +0 -182
  82. package/framework/hooks/auto-format.sh +0 -54
  83. package/framework/hooks/block-env-edit.sh +0 -42
  84. package/framework/hooks/branch-guard.sh +0 -43
  85. package/framework/hooks/confirm-delete.sh +0 -59
  86. package/framework/hooks/migration-validate.sh +0 -77
  87. package/framework/hooks/notification-speak.sh +0 -16
  88. package/framework/hooks/pre-commit.sh +0 -100
  89. package/framework/hooks/pre-compact.sh +0 -56
  90. package/framework/hooks/pre-deploy-gate.sh +0 -160
  91. package/framework/hooks/qualia-colors.sh +0 -32
  92. package/framework/hooks/retention-cleanup.sh +0 -62
  93. package/framework/hooks/save-session-state.sh +0 -185
  94. package/framework/hooks/session-context-loader.sh +0 -96
  95. package/framework/hooks/session-learn.sh +0 -32
  96. package/framework/hooks/skill-announce.sh +0 -123
  97. package/framework/hooks/tool-error-announce.sh +0 -27
  98. package/framework/install.ps1 +0 -323
  99. package/framework/install.sh +0 -313
  100. package/framework/qualia-framework/VERSION +0 -1
  101. package/framework/qualia-framework/assets/qualia-logo.png +0 -0
  102. package/framework/qualia-framework/bin/collect-metrics.sh +0 -67
  103. package/framework/qualia-framework/bin/generate-report-docx.py +0 -429
  104. package/framework/qualia-framework/bin/qualia-tools.js +0 -2201
  105. package/framework/qualia-framework/bin/qualia-tools.test.js +0 -1054
  106. package/framework/qualia-framework/references/checkpoints.md +0 -775
  107. package/framework/qualia-framework/references/completion-checklists.md +0 -359
  108. package/framework/qualia-framework/references/continuation-format.md +0 -249
  109. package/framework/qualia-framework/references/continuation-prompt.md +0 -97
  110. package/framework/qualia-framework/references/decimal-phase-calculation.md +0 -65
  111. package/framework/qualia-framework/references/design-quality.md +0 -56
  112. package/framework/qualia-framework/references/employee-guide.md +0 -167
  113. package/framework/qualia-framework/references/git-integration.md +0 -254
  114. package/framework/qualia-framework/references/git-planning-commit.md +0 -50
  115. package/framework/qualia-framework/references/model-profile-resolution.md +0 -32
  116. package/framework/qualia-framework/references/model-profiles.md +0 -73
  117. package/framework/qualia-framework/references/phase-argument-parsing.md +0 -61
  118. package/framework/qualia-framework/references/planning-config.md +0 -195
  119. package/framework/qualia-framework/references/questioning.md +0 -141
  120. package/framework/qualia-framework/references/tdd.md +0 -263
  121. package/framework/qualia-framework/references/ui-brand.md +0 -160
  122. package/framework/qualia-framework/references/verification-patterns.md +0 -612
  123. package/framework/qualia-framework/templates/DEBUG.md +0 -159
  124. package/framework/qualia-framework/templates/DESIGN.md +0 -81
  125. package/framework/qualia-framework/templates/UAT.md +0 -247
  126. package/framework/qualia-framework/templates/codebase/architecture.md +0 -255
  127. package/framework/qualia-framework/templates/codebase/concerns.md +0 -310
  128. package/framework/qualia-framework/templates/codebase/conventions.md +0 -307
  129. package/framework/qualia-framework/templates/codebase/integrations.md +0 -280
  130. package/framework/qualia-framework/templates/codebase/stack.md +0 -186
  131. package/framework/qualia-framework/templates/codebase/structure.md +0 -285
  132. package/framework/qualia-framework/templates/codebase/testing.md +0 -480
  133. package/framework/qualia-framework/templates/config.json +0 -35
  134. package/framework/qualia-framework/templates/context.md +0 -283
  135. package/framework/qualia-framework/templates/continue-here.md +0 -78
  136. package/framework/qualia-framework/templates/debug-subagent-prompt.md +0 -91
  137. package/framework/qualia-framework/templates/discovery.md +0 -146
  138. package/framework/qualia-framework/templates/lab-notes.md +0 -16
  139. package/framework/qualia-framework/templates/milestone-archive.md +0 -123
  140. package/framework/qualia-framework/templates/milestone.md +0 -115
  141. package/framework/qualia-framework/templates/phase-prompt.md +0 -567
  142. package/framework/qualia-framework/templates/planner-subagent-prompt.md +0 -117
  143. package/framework/qualia-framework/templates/project.md +0 -184
  144. package/framework/qualia-framework/templates/projects/ai-agent.md +0 -156
  145. package/framework/qualia-framework/templates/projects/mobile-app.md +0 -181
  146. package/framework/qualia-framework/templates/projects/voice-agent.md +0 -134
  147. package/framework/qualia-framework/templates/projects/website.md +0 -137
  148. package/framework/qualia-framework/templates/requirements.md +0 -231
  149. package/framework/qualia-framework/templates/research-project/ARCHITECTURE.md +0 -204
  150. package/framework/qualia-framework/templates/research-project/FEATURES.md +0 -147
  151. package/framework/qualia-framework/templates/research-project/PITFALLS.md +0 -200
  152. package/framework/qualia-framework/templates/research-project/STACK.md +0 -120
  153. package/framework/qualia-framework/templates/research-project/SUMMARY.md +0 -170
  154. package/framework/qualia-framework/templates/research.md +0 -552
  155. package/framework/qualia-framework/templates/roadmap.md +0 -206
  156. package/framework/qualia-framework/templates/state.md +0 -179
  157. package/framework/qualia-framework/templates/summary-complex.md +0 -59
  158. package/framework/qualia-framework/templates/summary-minimal.md +0 -41
  159. package/framework/qualia-framework/templates/summary-standard.md +0 -48
  160. package/framework/qualia-framework/templates/summary.md +0 -246
  161. package/framework/qualia-framework/templates/user-setup.md +0 -311
  162. package/framework/qualia-framework/templates/verification-report.md +0 -322
  163. package/framework/qualia-framework/workflows/add-phase.md +0 -179
  164. package/framework/qualia-framework/workflows/add-todo.md +0 -157
  165. package/framework/qualia-framework/workflows/audit-milestone.md +0 -241
  166. package/framework/qualia-framework/workflows/check-todos.md +0 -176
  167. package/framework/qualia-framework/workflows/complete-milestone.md +0 -858
  168. package/framework/qualia-framework/workflows/diagnose-issues.md +0 -219
  169. package/framework/qualia-framework/workflows/discovery-phase.md +0 -289
  170. package/framework/qualia-framework/workflows/discuss-phase.md +0 -534
  171. package/framework/qualia-framework/workflows/execute-phase.md +0 -559
  172. package/framework/qualia-framework/workflows/execute-plan.md +0 -438
  173. package/framework/qualia-framework/workflows/help.md +0 -470
  174. package/framework/qualia-framework/workflows/insert-phase.md +0 -220
  175. package/framework/qualia-framework/workflows/list-phase-assumptions.md +0 -178
  176. package/framework/qualia-framework/workflows/map-codebase.md +0 -327
  177. package/framework/qualia-framework/workflows/new-milestone.md +0 -363
  178. package/framework/qualia-framework/workflows/new-project.md +0 -982
  179. package/framework/qualia-framework/workflows/pause-work.md +0 -122
  180. package/framework/qualia-framework/workflows/plan-milestone-gaps.md +0 -256
  181. package/framework/qualia-framework/workflows/plan-phase.md +0 -422
  182. package/framework/qualia-framework/workflows/progress.md +0 -389
  183. package/framework/qualia-framework/workflows/quick.md +0 -252
  184. package/framework/qualia-framework/workflows/remove-phase.md +0 -326
  185. package/framework/qualia-framework/workflows/research-phase.md +0 -74
  186. package/framework/qualia-framework/workflows/resume-project.md +0 -306
  187. package/framework/qualia-framework/workflows/set-profile.md +0 -80
  188. package/framework/qualia-framework/workflows/settings.md +0 -145
  189. package/framework/qualia-framework/workflows/transition.md +0 -556
  190. package/framework/qualia-framework/workflows/update.md +0 -197
  191. package/framework/qualia-framework/workflows/verify-phase.md +0 -195
  192. package/framework/qualia-framework/workflows/verify-work.md +0 -625
  193. package/framework/rules/context7.md +0 -14
  194. package/framework/rules/frontend.md +0 -33
  195. package/framework/rules/speed.md +0 -23
  196. package/framework/scripts/__pycache__/say.cpython-314.pyc +0 -0
  197. package/framework/scripts/apply-retention.sh +0 -120
  198. package/framework/scripts/bootstrap-pop-os.sh +0 -354
  199. package/framework/scripts/claude-voice +0 -13
  200. package/framework/scripts/cleanup.sh +0 -131
  201. package/framework/scripts/cowork-mode.sh +0 -141
  202. package/framework/scripts/generate-project-claude-md.sh +0 -153
  203. package/framework/scripts/load-test-webhook.js +0 -172
  204. package/framework/scripts/say.py +0 -236
  205. package/framework/scripts/showcase-video-recorder/ffmpeg-builder.js +0 -167
  206. package/framework/scripts/showcase-video-recorder/playwright-helpers.js +0 -216
  207. package/framework/scripts/speak.py +0 -55
  208. package/framework/scripts/speak.sh +0 -18
  209. package/framework/scripts/status.sh +0 -138
  210. package/framework/scripts/sync-to-framework.sh +0 -65
  211. package/framework/scripts/voice-hotkey.py +0 -227
  212. package/framework/scripts/voice-input.sh +0 -51
  213. package/framework/skills/animate/SKILL.md +0 -202
  214. package/framework/skills/bolder/SKILL.md +0 -144
  215. package/framework/skills/browser-qa/SKILL.md +0 -536
  216. package/framework/skills/clarify/SKILL.md +0 -179
  217. package/framework/skills/client-handoff/SKILL.md +0 -135
  218. package/framework/skills/collab-onboard/SKILL.md +0 -111
  219. package/framework/skills/colorize/SKILL.md +0 -170
  220. package/framework/skills/critique/SKILL.md +0 -126
  221. package/framework/skills/deep-research/SKILL.md +0 -240
  222. package/framework/skills/delight/SKILL.md +0 -329
  223. package/framework/skills/deploy/SKILL.md +0 -261
  224. package/framework/skills/deploy-verify/SKILL.md +0 -377
  225. package/framework/skills/deploy-verify/scripts/canary-check.sh +0 -206
  226. package/framework/skills/deploy-verify/scripts/check-console-errors.js +0 -147
  227. package/framework/skills/deploy-verify/scripts/check-cwv.js +0 -139
  228. package/framework/skills/deploy-verify/scripts/project-detect.sh +0 -84
  229. package/framework/skills/deploy-verify/scripts/verify.sh +0 -548
  230. package/framework/skills/design-quieter/SKILL.md +0 -130
  231. package/framework/skills/distill/SKILL.md +0 -149
  232. package/framework/skills/docs-lookup/SKILL.md +0 -79
  233. package/framework/skills/fcm-notifications/SKILL.md +0 -125
  234. package/framework/skills/financial-ledger/SKILL.md +0 -1039
  235. package/framework/skills/frontend-master/NOTICE.md +0 -4
  236. package/framework/skills/frontend-master/SKILL.md +0 -127
  237. package/framework/skills/frontend-master/reference/color-and-contrast.md +0 -132
  238. package/framework/skills/frontend-master/reference/interaction-design.md +0 -123
  239. package/framework/skills/frontend-master/reference/motion-design.md +0 -99
  240. package/framework/skills/frontend-master/reference/responsive-design.md +0 -114
  241. package/framework/skills/frontend-master/reference/spatial-design.md +0 -100
  242. package/framework/skills/frontend-master/reference/typography.md +0 -131
  243. package/framework/skills/frontend-master/reference/ux-writing.md +0 -107
  244. package/framework/skills/harden/SKILL.md +0 -357
  245. package/framework/skills/i18n-rtl/SKILL.md +0 -752
  246. package/framework/skills/learn/SKILL.md +0 -95
  247. package/framework/skills/memory/SKILL.md +0 -50
  248. package/framework/skills/mobile-expo/SKILL.md +0 -977
  249. package/framework/skills/mobile-expo/references/store-checklist.md +0 -550
  250. package/framework/skills/nestjs-backend/README.md +0 -73
  251. package/framework/skills/nestjs-backend/SKILL.md +0 -446
  252. package/framework/skills/nestjs-backend/references/templates.md +0 -1173
  253. package/framework/skills/normalize/SKILL.md +0 -79
  254. package/framework/skills/onboard/SKILL.md +0 -242
  255. package/framework/skills/openrouter-agent/SKILL.md +0 -922
  256. package/framework/skills/polish/SKILL.md +0 -209
  257. package/framework/skills/pr/SKILL.md +0 -66
  258. package/framework/skills/qualia/SKILL.md +0 -199
  259. package/framework/skills/qualia-add-todo/SKILL.md +0 -68
  260. package/framework/skills/qualia-audit-milestone/SKILL.md +0 -95
  261. package/framework/skills/qualia-check-todos/SKILL.md +0 -55
  262. package/framework/skills/qualia-complete-milestone/SKILL.md +0 -134
  263. package/framework/skills/qualia-debug/SKILL.md +0 -149
  264. package/framework/skills/qualia-design/SKILL.md +0 -203
  265. package/framework/skills/qualia-discuss-phase/SKILL.md +0 -72
  266. package/framework/skills/qualia-evolve/SKILL.md +0 -200
  267. package/framework/skills/qualia-execute-phase/SKILL.md +0 -89
  268. package/framework/skills/qualia-framework-audit/SKILL.md +0 -604
  269. package/framework/skills/qualia-guide/SKILL.md +0 -32
  270. package/framework/skills/qualia-help/SKILL.md +0 -114
  271. package/framework/skills/qualia-idk/SKILL.md +0 -352
  272. package/framework/skills/qualia-list-phase-assumptions/SKILL.md +0 -67
  273. package/framework/skills/qualia-new-milestone/SKILL.md +0 -72
  274. package/framework/skills/qualia-new-project/SKILL.md +0 -232
  275. package/framework/skills/qualia-pause-work/SKILL.md +0 -96
  276. package/framework/skills/qualia-plan-milestone-gaps/SKILL.md +0 -57
  277. package/framework/skills/qualia-plan-phase/SKILL.md +0 -104
  278. package/framework/skills/qualia-production-check/SKILL.md +0 -0
  279. package/framework/skills/qualia-progress/SKILL.md +0 -53
  280. package/framework/skills/qualia-quick/SKILL.md +0 -89
  281. package/framework/skills/qualia-report/SKILL.md +0 -166
  282. package/framework/skills/qualia-research-phase/SKILL.md +0 -88
  283. package/framework/skills/qualia-resume-work/SKILL.md +0 -62
  284. package/framework/skills/qualia-review/SKILL.md +0 -263
  285. package/framework/skills/qualia-start/SKILL.md +0 -161
  286. package/framework/skills/qualia-verify-work/SKILL.md +0 -132
  287. package/framework/skills/rag/SKILL.md +0 -750
  288. package/framework/skills/responsive/SKILL.md +0 -231
  289. package/framework/skills/retro/SKILL.md +0 -284
  290. package/framework/skills/sakani-conventions/SKILL.md +0 -136
  291. package/framework/skills/sakani-conventions/evals/evals.json +0 -23
  292. package/framework/skills/sakani-conventions/references/entities.md +0 -365
  293. package/framework/skills/sakani-conventions/references/error-codes.md +0 -95
  294. package/framework/skills/seo-master/SKILL.md +0 -490
  295. package/framework/skills/seo-master/references/checklist.md +0 -199
  296. package/framework/skills/seo-master/references/structured-data.md +0 -609
  297. package/framework/skills/ship/SKILL.md +0 -239
  298. package/framework/skills/stack-researcher/SKILL.md +0 -215
  299. package/framework/skills/status/SKILL.md +0 -154
  300. package/framework/skills/status/scripts/health-check.sh +0 -562
  301. package/framework/skills/subscription-payments/SKILL.md +0 -250
  302. package/framework/skills/supabase/SKILL.md +0 -973
  303. package/framework/skills/supabase/references/templates.md +0 -159
  304. package/framework/skills/team/SKILL.md +0 -67
  305. package/framework/skills/test-runner/SKILL.md +0 -202
  306. package/framework/skills/voice-agent/SKILL.md +0 -1312
  307. package/framework/skills/zoho-workflow/SKILL.md +0 -51
  308. package/framework/statusline-command.sh +0 -117
  309. package/framework/teams/default/inboxes/plan-04.json +0 -9
  310. package/framework/teams/review-team.md +0 -75
  311. package/framework/teams/ship-team.md +0 -86
  312. package/profiles/fawzi.json +0 -16
  313. package/profiles/hasan.json +0 -16
  314. package/profiles/moayad.json +0 -16
  315. package/templates/CLAUDE-owner.md +0 -52
  316. package/templates/CLAUDE.md.hbs +0 -58
  317. package/templates/env.claude.template +0 -12
  318. package/templates/settings.json +0 -172
  319. package/uninstall.sh +0 -90
  320. /package/{framework/rules → rules}/deployment.md +0 -0
  321. /package/{framework/rules → rules}/security.md +0 -0
@@ -1,446 +0,0 @@
1
- ---
2
- name: nestjs-backend
3
- description: "NestJS backend development patterns — module/controller/service architecture, guards, interceptors, DTOs with Zod, error handling, database integration, and API design. Use whenever building or modifying a NestJS API server, creating endpoints, services, guards, middleware, or any backend logic in a NestJS application. Triggers on: NestJS, API endpoint, controller, service, guard, interceptor, DTO, middleware, backend module, REST API server."
4
- tags: [nestjs, backend, api, typescript]
5
- ---
6
-
7
- # NestJS Backend Skill
8
-
9
- ## Project Structure
10
-
11
- Standard NestJS modular structure with feature modules:
12
-
13
- ```
14
- src/
15
- ├── main.ts
16
- ├── app.module.ts
17
- ├── common/
18
- │ ├── decorators/ # Custom decorators (@CurrentUser, @Roles, @IdempotencyKey)
19
- │ ├── filters/ # Exception filters (global error handler)
20
- │ ├── guards/ # Auth guard, Role guard, Subscription guard
21
- │ ├── interceptors/ # Request ID, Logging, Transform response
22
- │ ├── middleware/ # Correlation ID middleware
23
- │ ├── pipes/ # Zod validation pipe
24
- │ └── types/ # Shared interfaces
25
- ├── modules/
26
- │ ├── auth/ # Auth module (OTP, tokens, sessions)
27
- │ ├── building/ # Building CRUD + verification
28
- │ ├── unit/ # Unit CRUD + claims
29
- │ └── [feature]/ # Feature modules
30
- ├── config/ # Configuration module with validation
31
- └── database/ # Supabase client and RLS utilities
32
- ```
33
-
34
- ## Module Pattern
35
-
36
- Every feature module follows a consistent structure:
37
-
38
- - **module.ts**: Registers controllers and providers
39
- - **controller.ts**: HTTP layer — validates input, delegates to service, returns response
40
- - **service.ts**: Business logic — domain operations, database queries, validation
41
- - **dto/**: Data Transfer Objects with Zod schemas
42
- - **entities/**: TypeScript interfaces for database tables
43
- - **spec.ts**: Unit and integration tests
44
-
45
- Controllers are thin (validate + delegate). Services contain all business logic and are testable in isolation.
46
-
47
- ## Controller Pattern
48
-
49
- Controllers handle HTTP concerns only — request validation, response formatting, and delegation.
50
-
51
- **Guidelines:**
52
- - Validate input using Zod validation pipe
53
- - Use decorators for authentication (@UseGuards, @Roles)
54
- - Call service methods and return results
55
- - Let global exception filter handle errors
56
- - Response shape is always: `{ data: T }` for success, errors via exception filter
57
-
58
- **Example structure:**
59
- ```typescript
60
- @Controller('buildings')
61
- export class BuildingController {
62
- constructor(private readonly buildingService: BuildingService) {}
63
-
64
- @Post()
65
- @UseGuards(AuthGuard)
66
- async create(
67
- @Body() dto: CreateBuildingDto,
68
- @CurrentUser() user: JwtPayload,
69
- ) {
70
- return {
71
- data: await this.buildingService.create(dto, user.id),
72
- };
73
- }
74
-
75
- @Get(':id')
76
- @UseGuards(AuthGuard)
77
- async findOne(@Param('id') id: string) {
78
- return {
79
- data: await this.buildingService.findById(id),
80
- };
81
- }
82
- }
83
- ```
84
-
85
- ## Service Pattern
86
-
87
- Services contain all business logic, database operations, and domain-specific validation.
88
-
89
- **Guidelines:**
90
- - Inject dependencies (database client, other services)
91
- - All queries and mutations happen here
92
- - Throw domain exceptions, never HTTP exceptions
93
- - Services are testable in isolation with mocked dependencies
94
- - Use transactions for multi-step operations
95
- - Validate business rules before state changes
96
-
97
- **Example structure:**
98
- ```typescript
99
- @Injectable()
100
- export class BuildingService {
101
- constructor(
102
- private readonly supabase: SupabaseService,
103
- private readonly logger: LoggerService,
104
- ) {}
105
-
106
- async create(dto: CreateBuildingDto, userId: string) {
107
- // Validate business rules
108
- const existingCount = await this.supabase
109
- .from('buildings')
110
- .select('id')
111
- .eq('owner_id', userId)
112
- .count('exact');
113
-
114
- if (existingCount >= 10) {
115
- throw new DomainException('MAX_BUILDINGS_EXCEEDED', {
116
- limit: 10,
117
- current: existingCount,
118
- });
119
- }
120
-
121
- // Create record
122
- const { data, error } = await this.supabase
123
- .from('buildings')
124
- .insert([{ ...dto, owner_id: userId }])
125
- .select()
126
- .single();
127
-
128
- if (error) {
129
- this.logger.error('Failed to create building', { error, dto });
130
- throw new DomainException('BUILDING_CREATE_FAILED');
131
- }
132
-
133
- return data;
134
- }
135
-
136
- async findById(id: string, userId?: string) {
137
- const query = this.supabase
138
- .from('buildings')
139
- .select('*')
140
- .eq('id', id);
141
-
142
- if (userId) {
143
- query.eq('owner_id', userId);
144
- }
145
-
146
- const { data, error } = await query.single();
147
-
148
- if (error || !data) {
149
- throw new DomainException('BUILDING_NOT_FOUND');
150
- }
151
-
152
- return data;
153
- }
154
- }
155
- ```
156
-
157
- ## DTO Pattern with Zod
158
-
159
- DTOs are derived from Zod schemas for type-safe validation across the stack.
160
-
161
- **Guidelines:**
162
- - Define Zod schemas in separate files
163
- - Export both schema and inferred type
164
- - Use shared DTO packages in monorepos (frontend + backend)
165
- - Zod validates at controller layer via ZodValidationPipe
166
- - DTOs are plain objects, not class-validator decorators
167
-
168
- **Example DTO file:**
169
- ```typescript
170
- // dtos/create-building.dto.ts
171
- import { z } from 'zod';
172
-
173
- export const CreateBuildingDtoSchema = z.object({
174
- nameAr: z.string().min(1).max(200),
175
- nameEn: z.string().min(1).max(200),
176
- buildingType: z.enum(['RESIDENTIAL', 'COMMERCIAL', 'MIXED']),
177
- unitCount: z.number().int().positive().max(1000),
178
- address: z.string().optional(),
179
- });
180
-
181
- export type CreateBuildingDto = z.infer<typeof CreateBuildingDtoSchema>;
182
- ```
183
-
184
- **Usage in controller:**
185
- ```typescript
186
- @Post()
187
- async create(
188
- @Body(new ZodValidationPipe(CreateBuildingDtoSchema))
189
- dto: CreateBuildingDto,
190
- ) {
191
- return { data: await this.buildingService.create(dto) };
192
- }
193
- ```
194
-
195
- ## Error Handling
196
-
197
- A global exception filter standardizes all error responses.
198
-
199
- **Guidelines:**
200
- - Services throw DomainException (never HttpException)
201
- - Global filter catches all exceptions and formats them
202
- - Error responses include: HTTP status, error_code, message_key, request_id
203
- - Never expose internal details (stack traces, SQL errors, database column names)
204
- - Log errors server-side for debugging, send safe messages to client
205
-
206
- **Error response shape:**
207
- ```typescript
208
- {
209
- http_status: 400,
210
- error_code: "VALIDATION_FAILED",
211
- message_key: "error.validation_failed",
212
- request_id: "req_abc123",
213
- details: { field: "nameAr", reason: "too_short" }
214
- }
215
- ```
216
-
217
- **Exception mapping:**
218
- ```
219
- DomainException codes:
220
- NOT_FOUND → 404
221
- UNAUTHORIZED → 401
222
- FORBIDDEN → 403
223
- VALIDATION_FAILED → 400
224
- CONFLICT → 409
225
- INTERNAL_ERROR → 500
226
- ```
227
-
228
- ## Guards
229
-
230
- Guards enforce authentication and authorization at the controller method level.
231
-
232
- **AuthGuard:** Validates JWT token and attaches user to request.
233
-
234
- **RolesGuard:** Checks user role against @Roles() decorator on method.
235
-
236
- **SubscriptionGuard:** For gated features, validates subscription status before execution.
237
-
238
- Usage:
239
- ```typescript
240
- @Post()
241
- @UseGuards(AuthGuard, RolesGuard)
242
- @Roles('ADMIN', 'MANAGER')
243
- async create(@Body() dto: CreateDto) {
244
- // Only authenticated admins/managers reach here
245
- }
246
- ```
247
-
248
- ## Interceptors
249
-
250
- Interceptors handle cross-cutting concerns around request/response handling.
251
-
252
- **RequestIdInterceptor:** Generates or propagates a unique request_id UUID for tracing.
253
-
254
- **LoggingInterceptor:** Logs request and response details (timing, status) — no PII.
255
-
256
- **TransformInterceptor:** Wraps all responses in `{ data: T }` envelope and adds metadata.
257
-
258
- Usage:
259
- ```typescript
260
- // In app.module.ts
261
- providers: [
262
- {
263
- provide: APP_INTERCEPTOR,
264
- useClass: RequestIdInterceptor,
265
- },
266
- {
267
- provide: APP_INTERCEPTOR,
268
- useClass: LoggingInterceptor,
269
- },
270
- {
271
- provide: APP_INTERCEPTOR,
272
- useClass: TransformInterceptor,
273
- },
274
- ];
275
- ```
276
-
277
- ## Database Integration
278
-
279
- Supabase is the primary database with RLS (Row-Level Security) policies enforced at the database layer.
280
-
281
- **Guidelines:**
282
- - Inject SupabaseService to access client
283
- - Use `@supabase/supabase-js` for type-safe queries
284
- - RLS enforced at DB level; service layer adds application-level checks
285
- - Transactions via stored procedures or `.rpc()` for atomic operations
286
- - Always handle errors gracefully and log server-side
287
-
288
- **Example service:**
289
- ```typescript
290
- async findByOwner(userId: string) {
291
- const { data, error } = await this.supabase
292
- .from('buildings')
293
- .select('*')
294
- .eq('owner_id', userId);
295
-
296
- if (error) {
297
- this.logger.error('Supabase query failed', { error, userId });
298
- throw new DomainException('INTERNAL_ERROR');
299
- }
300
-
301
- return data ?? [];
302
- }
303
- ```
304
-
305
- ## Testing
306
-
307
- Tests are colocated with source files and follow NestJS testing patterns.
308
-
309
- **Unit tests for services:**
310
- - Mock Supabase client
311
- - Test business logic in isolation
312
- - Mock other service dependencies
313
-
314
- **Integration tests for controllers:**
315
- - Use `supertest` for HTTP testing
316
- - Create test module with real/mocked dependencies
317
- - Test full request/response cycle
318
-
319
- **Test file naming:** `*.spec.ts` next to source file.
320
-
321
- **Example service test:**
322
- ```typescript
323
- describe('BuildingService', () => {
324
- let service: BuildingService;
325
- let mockSupabase: jest.Mocked<SupabaseService>;
326
-
327
- beforeEach(async () => {
328
- mockSupabase = {
329
- from: jest.fn().mockReturnValue({
330
- select: jest.fn().mockReturnThis(),
331
- eq: jest.fn().mockReturnThis(),
332
- single: jest.fn(),
333
- }),
334
- } as any;
335
-
336
- const module = await Test.createTestingModule({
337
- providers: [
338
- BuildingService,
339
- { provide: SupabaseService, useValue: mockSupabase },
340
- ],
341
- }).compile();
342
-
343
- service = module.get(BuildingService);
344
- });
345
-
346
- it('should create a building', async () => {
347
- mockSupabase.from().select().eq().single.mockResolvedValue({
348
- data: { id: '1', nameAr: 'Test' },
349
- error: null,
350
- });
351
-
352
- const result = await service.create({ nameAr: 'Test' });
353
- expect(result.id).toBe('1');
354
- });
355
- });
356
- ```
357
-
358
- ## Idempotency Pattern
359
-
360
- For financial or state-changing operations, idempotency keys prevent duplicate processing.
361
-
362
- **Implementation:**
363
- ```typescript
364
- async createWithIdempotency(
365
- dto: CreateDto,
366
- idempotencyKey: string,
367
- ) {
368
- // Check if request already processed
369
- const existing = await this.findByIdempotencyKey(idempotencyKey);
370
- if (existing) return existing; // Return original result
371
-
372
- // Create new record with idempotency_key
373
- const result = await this.create(dto);
374
- await this.saveIdempotencyKey(idempotencyKey, result.id);
375
- return result;
376
- }
377
- ```
378
-
379
- **Client usage:**
380
- ```typescript
381
- @Post()
382
- async create(
383
- @Body() dto: CreateDto,
384
- @IdempotencyKey() key: string,
385
- ) {
386
- return {
387
- data: await this.service.createWithIdempotency(dto, key),
388
- };
389
- }
390
- ```
391
-
392
- ## Configuration
393
-
394
- Configuration is centralized in a Config module with Zod schema validation.
395
-
396
- **Guidelines:**
397
- - Validate all env vars at startup (fail fast on misconfiguration)
398
- - Use Zod for schema validation
399
- - Typed access via ConfigService
400
- - Store sensitive values in environment only
401
-
402
- **Example:**
403
- ```typescript
404
- const envSchema = z.object({
405
- PORT: z.string().pipe(z.coerce.number()).default('3000'),
406
- DATABASE_URL: z.string(),
407
- JWT_SECRET: z.string(),
408
- SUPABASE_URL: z.string().url(),
409
- SUPABASE_ANON_KEY: z.string(),
410
- NODE_ENV: z.enum(['development', 'production']).default('development'),
411
- });
412
-
413
- export type Environment = z.infer<typeof envSchema>;
414
- ```
415
-
416
- ## Best Practices
417
-
418
- **Code Organization:**
419
- - One class per file
420
- - Controllers handle HTTP only
421
- - Services handle business logic
422
- - DTOs in separate folder with Zod schemas
423
-
424
- **Error Handling:**
425
- - Never expose stack traces or internal errors to client
426
- - Log errors server-side for debugging
427
- - Use domain exceptions for business rule violations
428
- - Map domain exceptions to HTTP status codes in filter
429
-
430
- **Security:**
431
- - Validate all inputs with Zod
432
- - Use guards for authentication and authorization
433
- - RLS policies enforced at database layer
434
- - Never trust client data
435
-
436
- **Performance:**
437
- - Use request ID for tracing
438
- - Log timing for slow queries
439
- - Lazy-load modules with dynamic imports
440
- - Use caching for read-heavy operations
441
-
442
- **Testing:**
443
- - Unit test services with mocked dependencies
444
- - Integration test controllers with test database
445
- - Aim for 70%+ coverage on business logic
446
- - Test error paths, not just happy paths