@heytherevibin/skillforge 0.2.1

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 (402) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/CODE_OF_CONDUCT.md +34 -0
  3. package/CONTRIBUTING.md +38 -0
  4. package/LICENSE +21 -0
  5. package/README.md +337 -0
  6. package/RELEASING.md +93 -0
  7. package/SECURITY.md +31 -0
  8. package/STRATEGY.md +26 -0
  9. package/bin/cli.js +547 -0
  10. package/lib/packs.js +184 -0
  11. package/package.json +38 -0
  12. package/python/app/__init__.py +0 -0
  13. package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
  14. package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
  15. package/python/app/__pycache__/main.cpython-312.pyc +0 -0
  16. package/python/app/auth.py +63 -0
  17. package/python/app/cli.py +78 -0
  18. package/python/app/db_paths.py +26 -0
  19. package/python/app/events_cli.py +175 -0
  20. package/python/app/main.py +647 -0
  21. package/python/app/materialize.py +138 -0
  22. package/python/app/mcp_server.py +610 -0
  23. package/python/app/route_cli.py +117 -0
  24. package/python/requirements-dev.txt +1 -0
  25. package/python/requirements.txt +7 -0
  26. package/python/tests/test_db_paths.py +41 -0
  27. package/skills/accessibility/SKILL.md +145 -0
  28. package/skills/agent-architecture-audit/SKILL.md +256 -0
  29. package/skills/agent-eval/SKILL.md +144 -0
  30. package/skills/agent-harness-construction/SKILL.md +72 -0
  31. package/skills/agent-introspection-debugging/SKILL.md +152 -0
  32. package/skills/agent-payment-x402/SKILL.md +224 -0
  33. package/skills/agent-sort/SKILL.md +214 -0
  34. package/skills/agentic-engineering/SKILL.md +62 -0
  35. package/skills/agentic-os/SKILL.md +386 -0
  36. package/skills/ai-first-engineering/SKILL.md +50 -0
  37. package/skills/ai-regression-testing/SKILL.md +384 -0
  38. package/skills/android-clean-architecture/SKILL.md +338 -0
  39. package/skills/angular-developer/SKILL.md +153 -0
  40. package/skills/angular-developer/references/angular-animations.md +160 -0
  41. package/skills/angular-developer/references/angular-aria.md +410 -0
  42. package/skills/angular-developer/references/cli.md +86 -0
  43. package/skills/angular-developer/references/component-harnesses.md +59 -0
  44. package/skills/angular-developer/references/component-styling.md +91 -0
  45. package/skills/angular-developer/references/components.md +117 -0
  46. package/skills/angular-developer/references/creating-services.md +97 -0
  47. package/skills/angular-developer/references/data-resolvers.md +69 -0
  48. package/skills/angular-developer/references/define-routes.md +67 -0
  49. package/skills/angular-developer/references/defining-providers.md +72 -0
  50. package/skills/angular-developer/references/di-fundamentals.md +120 -0
  51. package/skills/angular-developer/references/e2e-testing.md +56 -0
  52. package/skills/angular-developer/references/effects.md +83 -0
  53. package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  54. package/skills/angular-developer/references/host-elements.md +80 -0
  55. package/skills/angular-developer/references/injection-context.md +63 -0
  56. package/skills/angular-developer/references/inputs.md +101 -0
  57. package/skills/angular-developer/references/linked-signal.md +59 -0
  58. package/skills/angular-developer/references/loading-strategies.md +61 -0
  59. package/skills/angular-developer/references/mcp.md +108 -0
  60. package/skills/angular-developer/references/navigate-to-routes.md +69 -0
  61. package/skills/angular-developer/references/outputs.md +86 -0
  62. package/skills/angular-developer/references/reactive-forms.md +122 -0
  63. package/skills/angular-developer/references/rendering-strategies.md +44 -0
  64. package/skills/angular-developer/references/resource.md +77 -0
  65. package/skills/angular-developer/references/route-animations.md +56 -0
  66. package/skills/angular-developer/references/route-guards.md +52 -0
  67. package/skills/angular-developer/references/router-lifecycle.md +45 -0
  68. package/skills/angular-developer/references/router-testing.md +87 -0
  69. package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  70. package/skills/angular-developer/references/signal-forms.md +795 -0
  71. package/skills/angular-developer/references/signals-overview.md +94 -0
  72. package/skills/angular-developer/references/tailwind-css.md +69 -0
  73. package/skills/angular-developer/references/template-driven-forms.md +114 -0
  74. package/skills/angular-developer/references/testing-fundamentals.md +65 -0
  75. package/skills/api-connector-builder/SKILL.md +120 -0
  76. package/skills/api-design/SKILL.md +522 -0
  77. package/skills/architecture-decision-records/SKILL.md +178 -0
  78. package/skills/article-writing/SKILL.md +78 -0
  79. package/skills/automation-audit-ops/SKILL.md +141 -0
  80. package/skills/autonomous-agent-harness/SKILL.md +272 -0
  81. package/skills/autonomous-loops/SKILL.md +609 -0
  82. package/skills/backend-patterns/SKILL.md +560 -0
  83. package/skills/benchmark/SKILL.md +92 -0
  84. package/skills/blueprint/SKILL.md +104 -0
  85. package/skills/browser-qa/SKILL.md +86 -0
  86. package/skills/bun-runtime/SKILL.md +83 -0
  87. package/skills/canary-watch/SKILL.md +98 -0
  88. package/skills/carrier-relationship-management/SKILL.md +211 -0
  89. package/skills/cisco-ios-patterns/SKILL.md +163 -0
  90. package/skills/ck/SKILL.md +147 -0
  91. package/skills/ck/commands/forget.mjs +44 -0
  92. package/skills/ck/commands/info.mjs +24 -0
  93. package/skills/ck/commands/init.mjs +143 -0
  94. package/skills/ck/commands/list.mjs +40 -0
  95. package/skills/ck/commands/migrate.mjs +202 -0
  96. package/skills/ck/commands/resume.mjs +36 -0
  97. package/skills/ck/commands/save.mjs +210 -0
  98. package/skills/ck/commands/shared.mjs +387 -0
  99. package/skills/ck/hooks/session-start.mjs +224 -0
  100. package/skills/claude-devfleet/SKILL.md +103 -0
  101. package/skills/click-path-audit/SKILL.md +244 -0
  102. package/skills/clickhouse-io/SKILL.md +438 -0
  103. package/skills/code-tour/SKILL.md +235 -0
  104. package/skills/codebase-onboarding/SKILL.md +232 -0
  105. package/skills/coding-standards/SKILL.md +548 -0
  106. package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
  107. package/skills/connections-optimizer/SKILL.md +188 -0
  108. package/skills/content-engine/SKILL.md +126 -0
  109. package/skills/content-hash-cache-pattern/SKILL.md +160 -0
  110. package/skills/context-budget/SKILL.md +134 -0
  111. package/skills/continuous-agent-loop/SKILL.md +44 -0
  112. package/skills/continuous-learning/SKILL.md +129 -0
  113. package/skills/continuous-learning/config.json +18 -0
  114. package/skills/continuous-learning/evaluate-session.sh +69 -0
  115. package/skills/continuous-learning-v2/SKILL.md +358 -0
  116. package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
  117. package/skills/continuous-learning-v2/agents/observer.md +198 -0
  118. package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  119. package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  120. package/skills/continuous-learning-v2/config.json +8 -0
  121. package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
  122. package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
  123. package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
  124. package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  125. package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  126. package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
  127. package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
  128. package/skills/cost-tracking/SKILL.md +147 -0
  129. package/skills/council/SKILL.md +202 -0
  130. package/skills/cpp-coding-standards/SKILL.md +722 -0
  131. package/skills/cpp-testing/SKILL.md +323 -0
  132. package/skills/crosspost/SKILL.md +110 -0
  133. package/skills/csharp-testing/SKILL.md +320 -0
  134. package/skills/customer-billing-ops/SKILL.md +139 -0
  135. package/skills/customs-trade-compliance/SKILL.md +262 -0
  136. package/skills/dart-flutter-patterns/SKILL.md +562 -0
  137. package/skills/dashboard-builder/SKILL.md +108 -0
  138. package/skills/data-scraper-agent/SKILL.md +764 -0
  139. package/skills/database-migrations/SKILL.md +428 -0
  140. package/skills/deep-research/SKILL.md +158 -0
  141. package/skills/defi-amm-security/SKILL.md +166 -0
  142. package/skills/deployment-patterns/SKILL.md +426 -0
  143. package/skills/design-system/SKILL.md +81 -0
  144. package/skills/django-celery/SKILL.md +456 -0
  145. package/skills/django-patterns/SKILL.md +733 -0
  146. package/skills/django-security/SKILL.md +592 -0
  147. package/skills/django-tdd/SKILL.md +728 -0
  148. package/skills/django-verification/SKILL.md +468 -0
  149. package/skills/dmux-workflows/SKILL.md +190 -0
  150. package/skills/docker-patterns/SKILL.md +363 -0
  151. package/skills/documentation-lookup/SKILL.md +89 -0
  152. package/skills/dotnet-patterns/SKILL.md +320 -0
  153. package/skills/e2e-testing/SKILL.md +325 -0
  154. package/skills/email-ops/SKILL.md +120 -0
  155. package/skills/energy-procurement/SKILL.md +227 -0
  156. package/skills/enterprise-agent-ops/SKILL.md +49 -0
  157. package/skills/error-handling/SKILL.md +375 -0
  158. package/skills/eval-harness/SKILL.md +269 -0
  159. package/skills/evm-token-decimals/SKILL.md +130 -0
  160. package/skills/exa-search/SKILL.md +106 -0
  161. package/skills/fal-ai-media/SKILL.md +287 -0
  162. package/skills/fastapi-patterns/SKILL.md +327 -0
  163. package/skills/finance-billing-ops/SKILL.md +126 -0
  164. package/skills/flox-environments/SKILL.md +496 -0
  165. package/skills/flutter-dart-code-review/SKILL.md +434 -0
  166. package/skills/foundation-models-on-device/SKILL.md +243 -0
  167. package/skills/frontend-design-direction/SKILL.md +92 -0
  168. package/skills/frontend-patterns/SKILL.md +641 -0
  169. package/skills/frontend-slides/SKILL.md +183 -0
  170. package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  171. package/skills/frontend-slides/animation-patterns.md +122 -0
  172. package/skills/frontend-slides/html-template.md +419 -0
  173. package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  174. package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  175. package/skills/frontend-slides/viewport-base.css +153 -0
  176. package/skills/fsharp-testing/SKILL.md +279 -0
  177. package/skills/gan-style-harness/SKILL.md +278 -0
  178. package/skills/gateguard/SKILL.md +125 -0
  179. package/skills/git-workflow/SKILL.md +714 -0
  180. package/skills/github-ops/SKILL.md +143 -0
  181. package/skills/golang-patterns/SKILL.md +673 -0
  182. package/skills/golang-testing/SKILL.md +719 -0
  183. package/skills/google-workspace-ops/SKILL.md +94 -0
  184. package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  185. package/skills/healthcare-emr-patterns/SKILL.md +159 -0
  186. package/skills/healthcare-eval-harness/SKILL.md +207 -0
  187. package/skills/healthcare-phi-compliance/SKILL.md +145 -0
  188. package/skills/hermes-imports/SKILL.md +87 -0
  189. package/skills/hexagonal-architecture/SKILL.md +275 -0
  190. package/skills/hipaa-compliance/SKILL.md +78 -0
  191. package/skills/homelab-network-readiness/SKILL.md +169 -0
  192. package/skills/homelab-network-setup/SKILL.md +129 -0
  193. package/skills/homelab-pihole-dns/SKILL.md +274 -0
  194. package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
  195. package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
  196. package/skills/hookify-rules/SKILL.md +128 -0
  197. package/skills/inventory-demand-planning/SKILL.md +246 -0
  198. package/skills/investor-materials/SKILL.md +95 -0
  199. package/skills/investor-outreach/SKILL.md +90 -0
  200. package/skills/ios-icon-gen/SKILL.md +157 -0
  201. package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  202. package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  203. package/skills/iterative-retrieval/SKILL.md +209 -0
  204. package/skills/java-coding-standards/SKILL.md +382 -0
  205. package/skills/jira-integration/SKILL.md +292 -0
  206. package/skills/jpa-patterns/SKILL.md +150 -0
  207. package/skills/knowledge-ops/SKILL.md +153 -0
  208. package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
  209. package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
  210. package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
  211. package/skills/kotlin-patterns/SKILL.md +710 -0
  212. package/skills/kotlin-testing/SKILL.md +823 -0
  213. package/skills/laravel-patterns/SKILL.md +414 -0
  214. package/skills/laravel-plugin-discovery/SKILL.md +228 -0
  215. package/skills/laravel-security/SKILL.md +284 -0
  216. package/skills/laravel-tdd/SKILL.md +282 -0
  217. package/skills/laravel-verification/SKILL.md +178 -0
  218. package/skills/lead-intelligence/SKILL.md +320 -0
  219. package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  220. package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  221. package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  222. package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  223. package/skills/liquid-glass-design/SKILL.md +279 -0
  224. package/skills/llm-trading-agent-security/SKILL.md +146 -0
  225. package/skills/logistics-exception-management/SKILL.md +221 -0
  226. package/skills/make-interfaces-feel-better/SKILL.md +151 -0
  227. package/skills/manim-video/SKILL.md +88 -0
  228. package/skills/manim-video/assets/network_graph_scene.py +52 -0
  229. package/skills/market-research/SKILL.md +74 -0
  230. package/skills/mcp-server-patterns/SKILL.md +68 -0
  231. package/skills/messages-ops/SKILL.md +103 -0
  232. package/skills/mle-workflow/SKILL.md +345 -0
  233. package/skills/motion-advanced/SKILL.md +596 -0
  234. package/skills/motion-foundations/SKILL.md +299 -0
  235. package/skills/motion-patterns/SKILL.md +435 -0
  236. package/skills/motion-ui/SKILL.md +574 -0
  237. package/skills/mysql-patterns/SKILL.md +411 -0
  238. package/skills/nanoclaw-repl/SKILL.md +32 -0
  239. package/skills/nestjs-patterns/SKILL.md +229 -0
  240. package/skills/netmiko-ssh-automation/SKILL.md +173 -0
  241. package/skills/network-bgp-diagnostics/SKILL.md +167 -0
  242. package/skills/network-config-validation/SKILL.md +210 -0
  243. package/skills/network-interface-health/SKILL.md +152 -0
  244. package/skills/nextjs-turbopack/SKILL.md +43 -0
  245. package/skills/nodejs-keccak256/SKILL.md +102 -0
  246. package/skills/nutrient-document-processing/SKILL.md +166 -0
  247. package/skills/nuxt4-patterns/SKILL.md +99 -0
  248. package/skills/openclaw-persona-forge/SKILL.md +288 -0
  249. package/skills/openclaw-persona-forge/gacha.py +224 -0
  250. package/skills/openclaw-persona-forge/gacha.sh +5 -0
  251. package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  252. package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  253. package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  254. package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  255. package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  256. package/skills/openclaw-persona-forge/references/output-template.md +166 -0
  257. package/skills/opensource-pipeline/SKILL.md +254 -0
  258. package/skills/perl-patterns/SKILL.md +503 -0
  259. package/skills/perl-security/SKILL.md +502 -0
  260. package/skills/perl-testing/SKILL.md +474 -0
  261. package/skills/plan-orchestrate/SKILL.md +253 -0
  262. package/skills/plankton-code-quality/SKILL.md +236 -0
  263. package/skills/postgres-patterns/SKILL.md +146 -0
  264. package/skills/product-capability/SKILL.md +140 -0
  265. package/skills/product-lens/SKILL.md +91 -0
  266. package/skills/production-audit/SKILL.md +206 -0
  267. package/skills/production-scheduling/SKILL.md +237 -0
  268. package/skills/project-flow-ops/SKILL.md +110 -0
  269. package/skills/prompt-optimizer/SKILL.md +398 -0
  270. package/skills/python-patterns/SKILL.md +749 -0
  271. package/skills/python-testing/SKILL.md +815 -0
  272. package/skills/pytorch-patterns/SKILL.md +395 -0
  273. package/skills/quality-nonconformance/SKILL.md +259 -0
  274. package/skills/quarkus-patterns/SKILL.md +721 -0
  275. package/skills/quarkus-security/SKILL.md +466 -0
  276. package/skills/quarkus-tdd/SKILL.md +810 -0
  277. package/skills/quarkus-verification/SKILL.md +478 -0
  278. package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
  279. package/skills/redis-patterns/SKILL.md +402 -0
  280. package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
  281. package/skills/remotion-video-creation/SKILL.md +43 -0
  282. package/skills/remotion-video-creation/rules/3d.md +86 -0
  283. package/skills/remotion-video-creation/rules/animations.md +29 -0
  284. package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  285. package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  286. package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  287. package/skills/remotion-video-creation/rules/assets.md +78 -0
  288. package/skills/remotion-video-creation/rules/audio.md +172 -0
  289. package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  290. package/skills/remotion-video-creation/rules/can-decode.md +75 -0
  291. package/skills/remotion-video-creation/rules/charts.md +58 -0
  292. package/skills/remotion-video-creation/rules/compositions.md +146 -0
  293. package/skills/remotion-video-creation/rules/display-captions.md +126 -0
  294. package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  295. package/skills/remotion-video-creation/rules/fonts.md +152 -0
  296. package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  297. package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  298. package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  299. package/skills/remotion-video-creation/rules/gifs.md +138 -0
  300. package/skills/remotion-video-creation/rules/images.md +130 -0
  301. package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  302. package/skills/remotion-video-creation/rules/lottie.md +67 -0
  303. package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  304. package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  305. package/skills/remotion-video-creation/rules/sequencing.md +106 -0
  306. package/skills/remotion-video-creation/rules/tailwind.md +11 -0
  307. package/skills/remotion-video-creation/rules/text-animations.md +20 -0
  308. package/skills/remotion-video-creation/rules/timing.md +179 -0
  309. package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  310. package/skills/remotion-video-creation/rules/transitions.md +122 -0
  311. package/skills/remotion-video-creation/rules/trimming.md +52 -0
  312. package/skills/remotion-video-creation/rules/videos.md +171 -0
  313. package/skills/repo-scan/SKILL.md +78 -0
  314. package/skills/research-ops/SKILL.md +111 -0
  315. package/skills/returns-reverse-logistics/SKILL.md +239 -0
  316. package/skills/rules-distill/SKILL.md +263 -0
  317. package/skills/rules-distill/scripts/scan-rules.sh +58 -0
  318. package/skills/rules-distill/scripts/scan-skills.sh +129 -0
  319. package/skills/rust-patterns/SKILL.md +498 -0
  320. package/skills/rust-testing/SKILL.md +499 -0
  321. package/skills/safety-guard/SKILL.md +74 -0
  322. package/skills/santa-method/SKILL.md +306 -0
  323. package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
  324. package/skills/scientific-db-uspto-database/SKILL.md +177 -0
  325. package/skills/scientific-pkg-gget/SKILL.md +166 -0
  326. package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
  327. package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  328. package/skills/search-first/SKILL.md +181 -0
  329. package/skills/security-bounty-hunter/SKILL.md +99 -0
  330. package/skills/security-review/SKILL.md +502 -0
  331. package/skills/security-review/cloud-infrastructure-security.md +361 -0
  332. package/skills/seo/SKILL.md +153 -0
  333. package/skills/skill-comply/SKILL.md +57 -0
  334. package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  335. package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  336. package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  337. package/skills/skill-comply/prompts/classifier.md +24 -0
  338. package/skills/skill-comply/prompts/scenario_generator.md +62 -0
  339. package/skills/skill-comply/prompts/spec_generator.md +42 -0
  340. package/skills/skill-comply/pyproject.toml +15 -0
  341. package/skills/skill-comply/scripts/__init__.py +0 -0
  342. package/skills/skill-comply/scripts/classifier.py +85 -0
  343. package/skills/skill-comply/scripts/grader.py +124 -0
  344. package/skills/skill-comply/scripts/parser.py +107 -0
  345. package/skills/skill-comply/scripts/report.py +170 -0
  346. package/skills/skill-comply/scripts/run.py +127 -0
  347. package/skills/skill-comply/scripts/runner.py +186 -0
  348. package/skills/skill-comply/scripts/scenario_generator.py +70 -0
  349. package/skills/skill-comply/scripts/spec_generator.py +72 -0
  350. package/skills/skill-comply/scripts/utils.py +13 -0
  351. package/skills/skill-comply/tests/test_grader.py +197 -0
  352. package/skills/skill-comply/tests/test_parser.py +90 -0
  353. package/skills/skill-comply/tests/test_runner.py +172 -0
  354. package/skills/skill-scout/SKILL.md +139 -0
  355. package/skills/skill-stocktake/SKILL.md +193 -0
  356. package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  357. package/skills/skill-stocktake/scripts/save-results.sh +56 -0
  358. package/skills/skill-stocktake/scripts/scan.sh +170 -0
  359. package/skills/social-graph-ranker/SKILL.md +153 -0
  360. package/skills/springboot-patterns/SKILL.md +313 -0
  361. package/skills/springboot-security/SKILL.md +271 -0
  362. package/skills/springboot-tdd/SKILL.md +157 -0
  363. package/skills/springboot-verification/SKILL.md +230 -0
  364. package/skills/strategic-compact/SKILL.md +129 -0
  365. package/skills/strategic-compact/suggest-compact.sh +54 -0
  366. package/skills/swift-actor-persistence/SKILL.md +142 -0
  367. package/skills/swift-concurrency-6-2/SKILL.md +216 -0
  368. package/skills/swift-protocol-di-testing/SKILL.md +189 -0
  369. package/skills/swiftui-patterns/SKILL.md +259 -0
  370. package/skills/tdd-workflow/SKILL.md +462 -0
  371. package/skills/team-builder/SKILL.md +166 -0
  372. package/skills/terminal-ops/SKILL.md +108 -0
  373. package/skills/tinystruct-patterns/SKILL.md +130 -0
  374. package/skills/tinystruct-patterns/references/architecture.md +77 -0
  375. package/skills/tinystruct-patterns/references/data-handling.md +35 -0
  376. package/skills/tinystruct-patterns/references/routing.md +57 -0
  377. package/skills/tinystruct-patterns/references/system-usage.md +74 -0
  378. package/skills/tinystruct-patterns/references/testing.md +59 -0
  379. package/skills/token-budget-advisor/SKILL.md +133 -0
  380. package/skills/ui-demo/SKILL.md +464 -0
  381. package/skills/ui-to-vue/SKILL.md +134 -0
  382. package/skills/unified-notifications-ops/SKILL.md +186 -0
  383. package/skills/verification-loop/SKILL.md +125 -0
  384. package/skills/video-editing/SKILL.md +309 -0
  385. package/skills/videodb/SKILL.md +373 -0
  386. package/skills/videodb/reference/api-reference.md +550 -0
  387. package/skills/videodb/reference/capture-reference.md +407 -0
  388. package/skills/videodb/reference/capture.md +101 -0
  389. package/skills/videodb/reference/editor.md +443 -0
  390. package/skills/videodb/reference/generative.md +331 -0
  391. package/skills/videodb/reference/rtstream-reference.md +564 -0
  392. package/skills/videodb/reference/rtstream.md +65 -0
  393. package/skills/videodb/reference/search.md +230 -0
  394. package/skills/videodb/reference/streaming.md +406 -0
  395. package/skills/videodb/reference/use-cases.md +118 -0
  396. package/skills/videodb/scripts/ws_listener.py +282 -0
  397. package/skills/visa-doc-translate/README.md +86 -0
  398. package/skills/visa-doc-translate/SKILL.md +117 -0
  399. package/skills/vite-patterns/SKILL.md +448 -0
  400. package/skills/windows-desktop-e2e/SKILL.md +787 -0
  401. package/skills/workspace-surface-audit/SKILL.md +124 -0
  402. package/skills/x-api/SKILL.md +233 -0
@@ -0,0 +1,411 @@
1
+ ---
2
+ name: mysql-patterns
3
+ description: MySQL and MariaDB schema, query, indexing, transaction, replication, and connection-pool patterns for production backends.
4
+ ---
5
+
6
+ # MySQL Patterns
7
+
8
+ Use this skill when working on MySQL or MariaDB schema design, migrations,
9
+ slow-query investigation, queue-style transactions, connection pools, or
10
+ production database configuration. Prefer exact version checks before applying a
11
+ feature-specific pattern because MySQL and MariaDB have diverged in several SQL
12
+ details.
13
+
14
+ ## Activation
15
+
16
+ - Designing MySQL or MariaDB tables, indexes, and constraints
17
+ - Reviewing migrations before they run on large production tables
18
+ - Debugging slow queries, lock waits, deadlocks, or connection exhaustion
19
+ - Adding keyset pagination, upserts, full-text search, JSON columns, or queues
20
+ - Configuring application connection pools, read replicas, TLS, or slow logs
21
+
22
+ ## Version Check
23
+
24
+ Start by identifying the engine and version:
25
+
26
+ ```sql
27
+ SELECT VERSION();
28
+ SHOW VARIABLES LIKE 'version_comment';
29
+ ```
30
+
31
+ Keep MySQL and MariaDB guidance separate when syntax differs:
32
+
33
+ - MySQL documents row aliases as the replacement for `VALUES(col)` in
34
+ `ON DUPLICATE KEY UPDATE`; `VALUES(col)` is deprecated there.
35
+ - MariaDB documents `VALUES(col)` as the supported way to reference inserted
36
+ values in `ON DUPLICATE KEY UPDATE`; use it for cross-engine compatibility.
37
+ - `SKIP LOCKED` is appropriate for queue-like work only. It skips locked rows
38
+ and can return an inconsistent view, so do not use it for general accounting
39
+ or integrity-sensitive reads.
40
+
41
+ ## Schema Defaults
42
+
43
+ ```sql
44
+ CREATE TABLE orders (
45
+ id BIGINT UNSIGNED NOT NULL AUTO_INCREMENT,
46
+ account_id BIGINT UNSIGNED NOT NULL,
47
+ status VARCHAR(32) NOT NULL,
48
+ total DECIMAL(15, 2) NOT NULL,
49
+ created_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
50
+ updated_at DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
51
+ deleted_at DATETIME NULL,
52
+ PRIMARY KEY (id),
53
+ KEY idx_orders_account_status_created (account_id, status, created_at),
54
+ KEY idx_orders_active (account_id, deleted_at)
55
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
56
+ ```
57
+
58
+ Default choices:
59
+
60
+ | Use Case | Prefer | Avoid |
61
+ | --- | --- | --- |
62
+ | Surrogate primary keys | `BIGINT UNSIGNED AUTO_INCREMENT` | `INT` for tables that can grow beyond 2B rows |
63
+ | UUID lookup keys | `BINARY(16)` with conversion helpers | `VARCHAR(36)` primary keys on hot tables |
64
+ | Money and exact quantities | `DECIMAL(p, s)` | `FLOAT` or `DOUBLE` |
65
+ | User-facing text | `utf8mb4` tables and indexes | MySQL `utf8` / `utf8mb3` defaults |
66
+ | Application timestamps | `DATETIME` with UTC managed by the app | Assuming `DATETIME` stores time zone metadata |
67
+ | Soft deletes | `deleted_at DATETIME NULL` plus scoped indexes | Filtering soft-deleted rows without an index |
68
+ | Extensible status values | lookup table or constrained `VARCHAR` | `ENUM` when values change often |
69
+
70
+ ## Indexing
71
+
72
+ Composite index order usually follows equality predicates first, then range or
73
+ sort columns:
74
+
75
+ ```sql
76
+ CREATE INDEX idx_orders_account_status_created
77
+ ON orders (account_id, status, created_at);
78
+
79
+ SELECT id, total
80
+ FROM orders
81
+ WHERE account_id = ?
82
+ AND status = 'pending'
83
+ AND created_at >= ?
84
+ ORDER BY created_at DESC
85
+ LIMIT 50;
86
+ ```
87
+
88
+ Use `EXPLAIN` before adding or changing an index:
89
+
90
+ ```sql
91
+ EXPLAIN
92
+ SELECT id, total
93
+ FROM orders
94
+ WHERE account_id = 123 AND status = 'pending'
95
+ ORDER BY created_at DESC
96
+ LIMIT 50;
97
+ ```
98
+
99
+ Signals to investigate:
100
+
101
+ | Field | Risk Signal |
102
+ | --- | --- |
103
+ | `type` | `ALL` on a large table |
104
+ | `key` | `NULL` when a selective predicate exists |
105
+ | `rows` | Very high row estimate for an interactive path |
106
+ | `Extra` | `Using temporary`, `Using filesort`, or broad `Using where` |
107
+
108
+ Avoid adding indexes blindly. Each index increases write cost, migration time,
109
+ backup size, and buffer-pool pressure.
110
+
111
+ ## Query Patterns
112
+
113
+ ### Upsert
114
+
115
+ Cross-engine-compatible form:
116
+
117
+ ```sql
118
+ INSERT INTO user_settings (user_id, setting_key, setting_value)
119
+ VALUES (?, ?, ?)
120
+ ON DUPLICATE KEY UPDATE
121
+ setting_value = VALUES(setting_value),
122
+ updated_at = CURRENT_TIMESTAMP;
123
+ ```
124
+
125
+ MySQL row-alias form:
126
+
127
+ ```sql
128
+ INSERT INTO user_settings (user_id, setting_key, setting_value)
129
+ VALUES (?, ?, ?) AS new
130
+ ON DUPLICATE KEY UPDATE
131
+ setting_value = new.setting_value,
132
+ updated_at = CURRENT_TIMESTAMP;
133
+ ```
134
+
135
+ Use the row-alias form only after confirming the target is MySQL. Use
136
+ `VALUES(col)` for MariaDB or mixed MySQL/MariaDB fleets.
137
+
138
+ ### Keyset Pagination
139
+
140
+ ```sql
141
+ SELECT id, name, created_at
142
+ FROM products
143
+ WHERE (created_at, id) < (?, ?)
144
+ ORDER BY created_at DESC, id DESC
145
+ LIMIT 50;
146
+ ```
147
+
148
+ Back it with an index that matches the cursor:
149
+
150
+ ```sql
151
+ CREATE INDEX idx_products_created_id ON products (created_at, id);
152
+ ```
153
+
154
+ Do not use deep `OFFSET` pagination on large tables; it makes the server scan
155
+ and discard rows before returning the page.
156
+
157
+ ### JSON Fields
158
+
159
+ Use JSON columns for extension data, not for fields that need heavy relational
160
+ filtering or constraints.
161
+
162
+ ```sql
163
+ CREATE TABLE events (
164
+ id BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
165
+ payload JSON NOT NULL,
166
+ event_type VARCHAR(64)
167
+ GENERATED ALWAYS AS (JSON_UNQUOTE(JSON_EXTRACT(payload, '$.type'))) STORED,
168
+ KEY idx_events_type (event_type)
169
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
170
+ ```
171
+
172
+ For frequently queried JSON paths, expose a generated column and index that
173
+ column. Keep foreign keys, ownership, tenancy, and lifecycle fields relational.
174
+
175
+ ### Full-Text Search
176
+
177
+ ```sql
178
+ ALTER TABLE articles ADD FULLTEXT KEY ft_articles_title_body (title, body);
179
+
180
+ SELECT id, title, MATCH(title, body) AGAINST (? IN NATURAL LANGUAGE MODE) AS score
181
+ FROM articles
182
+ WHERE MATCH(title, body) AGAINST (? IN NATURAL LANGUAGE MODE)
183
+ ORDER BY score DESC
184
+ LIMIT 20;
185
+ ```
186
+
187
+ Use external search when you need typo tolerance, complex ranking, cross-table
188
+ facets, or language-specific analysis beyond built-in full-text behavior.
189
+
190
+ ## Transactions
191
+
192
+ Keep transactions short and lock rows in a consistent order:
193
+
194
+ ```sql
195
+ START TRANSACTION;
196
+
197
+ SELECT id, balance
198
+ FROM accounts
199
+ WHERE id IN (?, ?)
200
+ ORDER BY id
201
+ FOR UPDATE;
202
+
203
+ UPDATE accounts SET balance = balance - ? WHERE id = ?;
204
+ UPDATE accounts SET balance = balance + ? WHERE id = ?;
205
+
206
+ COMMIT;
207
+ ```
208
+
209
+ Deadlock and lock-wait checklist:
210
+
211
+ - Lock rows in a deterministic order across code paths.
212
+ - Do external API calls before opening the transaction, not inside it.
213
+ - Add indexes for predicates used in `UPDATE`, `DELETE`, and locking reads.
214
+ - On deadlock, roll back and retry the whole transaction with a bounded retry
215
+ budget.
216
+ - Capture `SHOW ENGINE INNODB STATUS\G` soon after a deadlock; it is overwritten
217
+ by later events.
218
+
219
+ Queue-style worker claim:
220
+
221
+ ```sql
222
+ START TRANSACTION;
223
+
224
+ SELECT id
225
+ FROM jobs
226
+ WHERE status = 'pending'
227
+ ORDER BY created_at
228
+ LIMIT 1
229
+ FOR UPDATE SKIP LOCKED;
230
+
231
+ UPDATE jobs
232
+ SET status = 'processing', started_at = CURRENT_TIMESTAMP
233
+ WHERE id = ?;
234
+
235
+ COMMIT;
236
+ ```
237
+
238
+ Use `SKIP LOCKED` only for queue-like workloads where skipping a locked row is
239
+ acceptable. It is not a replacement for normal transactional consistency.
240
+
241
+ ## Connection Pools
242
+
243
+ SQLAlchemy example:
244
+
245
+ ```python
246
+ from sqlalchemy import create_engine
247
+
248
+ engine = create_engine(
249
+ "mysql+mysqlconnector://app:secret@db.internal/app",
250
+ pool_size=10,
251
+ max_overflow=5,
252
+ pool_timeout=30,
253
+ pool_recycle=240,
254
+ pool_pre_ping=True,
255
+ connect_args={"connect_timeout": 5},
256
+ )
257
+ ```
258
+
259
+ Node.js `mysql2` example:
260
+
261
+ ```javascript
262
+ import mysql from 'mysql2/promise';
263
+
264
+ const pool = mysql.createPool({
265
+ host: process.env.DB_HOST,
266
+ user: process.env.DB_USER,
267
+ password: process.env.DB_PASSWORD,
268
+ database: process.env.DB_NAME,
269
+ waitForConnections: true,
270
+ connectionLimit: 10,
271
+ queueLimit: 0,
272
+ enableKeepAlive: true,
273
+ keepAliveInitialDelay: 30000,
274
+ });
275
+
276
+ const [rows] = await pool.execute(
277
+ 'SELECT id, total FROM orders WHERE account_id = ? LIMIT 50',
278
+ [accountId],
279
+ );
280
+ ```
281
+
282
+ Keep application pool recycling below the server `wait_timeout`. If the server
283
+ uses `wait_timeout = 300`, a `pool_recycle` around 240 seconds is coherent;
284
+ `pool_pre_ping` still helps recover from network and failover events.
285
+
286
+ ## Diagnostics
287
+
288
+ Useful first-pass commands:
289
+
290
+ ```sql
291
+ SHOW FULL PROCESSLIST;
292
+ SHOW ENGINE INNODB STATUS\G;
293
+ SHOW VARIABLES LIKE 'slow_query_log';
294
+ SHOW VARIABLES LIKE 'long_query_time';
295
+ ```
296
+
297
+ Enable the slow log in a controlled environment:
298
+
299
+ ```sql
300
+ SET GLOBAL slow_query_log = 'ON';
301
+ SET GLOBAL long_query_time = 1;
302
+ SET GLOBAL log_queries_not_using_indexes = 'ON';
303
+ ```
304
+
305
+ Use `EXPLAIN ANALYZE` only when it is safe to execute the query. It runs the
306
+ statement and can be expensive on production-sized data.
307
+
308
+ ## Replication
309
+
310
+ Read replicas can lag. Do not route read-your-own-write paths, checkout flows,
311
+ permission checks, or idempotency-key reads to a replica immediately after a
312
+ write.
313
+
314
+ ```sql
315
+ -- MySQL legacy terminology, still common in existing fleets
316
+ SHOW SLAVE STATUS\G;
317
+
318
+ -- Newer terminology where supported
319
+ SHOW REPLICA STATUS\G;
320
+ ```
321
+
322
+ Check the engine/version before standardizing on one command. Monitor replica
323
+ SQL thread health, IO thread health, and lag, not just whether the TCP
324
+ connection is alive.
325
+
326
+ ## Security
327
+
328
+ ```sql
329
+ CREATE USER 'app'@'%' IDENTIFIED BY 'use-a-secret-manager';
330
+ GRANT SELECT, INSERT, UPDATE, DELETE ON appdb.* TO 'app'@'%';
331
+
332
+ ALTER USER 'app'@'%' REQUIRE SSL;
333
+
334
+ SELECT user, host
335
+ FROM mysql.user
336
+ WHERE user = '';
337
+
338
+ DROP USER IF EXISTS ''@'localhost';
339
+ DROP USER IF EXISTS ''@'%';
340
+ ```
341
+
342
+ Security review points:
343
+
344
+ - Do not grant `ALL PRIVILEGES` or `*.*` to application users.
345
+ - Require TLS for application users when traffic crosses hosts or networks.
346
+ - Store credentials in the platform secret manager, not in examples, scripts, or
347
+ repository files.
348
+ - Separate migration/admin users from runtime application users.
349
+ - Audit public network exposure and bind addresses before tuning performance.
350
+
351
+ ## Configuration
352
+
353
+ Example starting point for a dedicated database host:
354
+
355
+ ```ini
356
+ [mysqld]
357
+ innodb_buffer_pool_size = 4G
358
+ innodb_flush_log_at_trx_commit = 1
359
+ sync_binlog = 1
360
+
361
+ max_connections = 300
362
+ thread_cache_size = 50
363
+
364
+ wait_timeout = 300
365
+ interactive_timeout = 300
366
+ innodb_lock_wait_timeout = 10
367
+
368
+ slow_query_log = ON
369
+ long_query_time = 1
370
+ log_queries_not_using_indexes = ON
371
+
372
+ log_bin = mysql-bin
373
+ binlog_format = ROW
374
+ binlog_expire_logs_seconds = 604800
375
+ ```
376
+
377
+ Treat configuration values as a prompt for review, not a universal preset. Size
378
+ memory, connections, log retention, and durability settings from workload,
379
+ hardware, backup policy, and recovery objectives.
380
+
381
+ ## Anti-Patterns
382
+
383
+ | Anti-Pattern | Risk | Better Pattern |
384
+ | --- | --- | --- |
385
+ | `SELECT *` in hot paths | Over-fetching and brittle clients | Select explicit columns |
386
+ | Deep `OFFSET` pagination | Linear scans and slow pages | Keyset pagination |
387
+ | No index on foreign-key joins | Slow joins and lock-heavy deletes | Index FK columns intentionally |
388
+ | Long transactions | Lock waits and large undo history | Commit small units of work |
389
+ | Direct DML against `mysql.user` | Grant-table corruption risk | Use `CREATE USER`, `ALTER USER`, `DROP USER` |
390
+ | Application user with admin grants | High blast radius | Least-privilege runtime user |
391
+ | Pool recycle above `wait_timeout` | Stale pooled connections | Recycle below timeout and pre-ping |
392
+ | Replica reads after writes | Stale user-facing state | Pin read-after-write flows to primary |
393
+
394
+ ## Output Expectations
395
+
396
+ When this skill is used for review, return:
397
+
398
+ 1. Engine/version assumptions.
399
+ 2. Highest-risk correctness, lock, security, and migration issues.
400
+ 3. Exact SQL or code changes for the safe path.
401
+ 4. Validation plan: `EXPLAIN`, migration dry run, lock/deadlock check, and
402
+ rollback criteria.
403
+ 5. Any MySQL/MariaDB syntax differences that affect the recommendation.
404
+
405
+ ## Related
406
+
407
+ - Skill: `postgres-patterns` - PostgreSQL-specific schema and query patterns
408
+ - Skill: `database-migrations` - migration planning and rollout safety
409
+ - Skill: `backend-patterns` - API and service-layer patterns
410
+ - Skill: `security-review` - secret handling, auth, and least privilege
411
+ - Agent: `database-reviewer` - broader database review workflow
@@ -0,0 +1,32 @@
1
+ ---
2
+ name: nanoclaw-repl
3
+ description: Operate and extend NanoClaw v2, the toolset's zero-dependency session-aware REPL built on claude -p.
4
+ ---
5
+
6
+ # NanoClaw REPL
7
+
8
+ Use this skill when running or extending `scripts/claw.js`.
9
+
10
+ ## Capabilities
11
+
12
+ - persistent markdown-backed sessions
13
+ - model switching with `/model`
14
+ - dynamic skill loading with `/load`
15
+ - session branching with `/branch`
16
+ - cross-session search with `/search`
17
+ - history compaction with `/compact`
18
+ - export to md/json/txt with `/export`
19
+ - session metrics with `/metrics`
20
+
21
+ ## Operating Guidance
22
+
23
+ 1. Keep sessions task-focused.
24
+ 2. Branch before high-risk changes.
25
+ 3. Compact after major milestones.
26
+ 4. Export before sharing or archival.
27
+
28
+ ## Extension Rules
29
+
30
+ - keep zero external runtime dependencies
31
+ - preserve markdown-as-database compatibility
32
+ - keep command handlers deterministic and local
@@ -0,0 +1,229 @@
1
+ ---
2
+ name: nestjs-patterns
3
+ description: NestJS architecture patterns for modules, controllers, providers, DTO validation, guards, interceptors, config, and production-grade TypeScript backends.
4
+ ---
5
+
6
+ # NestJS Development Patterns
7
+
8
+ Production-grade NestJS patterns for modular TypeScript backends.
9
+
10
+ ## When to Activate
11
+
12
+ - Building NestJS APIs or services
13
+ - Structuring modules, controllers, and providers
14
+ - Adding DTO validation, guards, interceptors, or exception filters
15
+ - Configuring environment-aware settings and database integrations
16
+ - Testing NestJS units or HTTP endpoints
17
+
18
+ ## Project Structure
19
+
20
+ ```text
21
+ src/
22
+ ├── app.module.ts
23
+ ├── main.ts
24
+ ├── common/
25
+ │ ├── filters/
26
+ │ ├── guards/
27
+ │ ├── interceptors/
28
+ │ └── pipes/
29
+ ├── config/
30
+ │ ├── configuration.ts
31
+ │ └── validation.ts
32
+ ├── modules/
33
+ │ ├── auth/
34
+ │ │ ├── auth.controller.ts
35
+ │ │ ├── auth.module.ts
36
+ │ │ ├── auth.service.ts
37
+ │ │ ├── dto/
38
+ │ │ ├── guards/
39
+ │ │ └── strategies/
40
+ │ └── users/
41
+ │ ├── dto/
42
+ │ ├── entities/
43
+ │ ├── users.controller.ts
44
+ │ ├── users.module.ts
45
+ │ └── users.service.ts
46
+ └── prisma/ or database/
47
+ ```
48
+
49
+ - Keep domain code inside feature modules.
50
+ - Put cross-cutting filters, decorators, guards, and interceptors in `common/`.
51
+ - Keep DTOs close to the module that owns them.
52
+
53
+ ## Bootstrap and Global Validation
54
+
55
+ ```ts
56
+ async function bootstrap() {
57
+ const app = await NestFactory.create(AppModule, { bufferLogs: true });
58
+
59
+ app.useGlobalPipes(
60
+ new ValidationPipe({
61
+ whitelist: true,
62
+ forbidNonWhitelisted: true,
63
+ transform: true,
64
+ transformOptions: { enableImplicitConversion: true },
65
+ }),
66
+ );
67
+
68
+ app.useGlobalInterceptors(new ClassSerializerInterceptor(app.get(Reflector)));
69
+ app.useGlobalFilters(new HttpExceptionFilter());
70
+
71
+ await app.listen(process.env.PORT ?? 3000);
72
+ }
73
+ bootstrap();
74
+ ```
75
+
76
+ - Always enable `whitelist` and `forbidNonWhitelisted` on public APIs.
77
+ - Prefer one global validation pipe instead of repeating validation config per route.
78
+
79
+ ## Modules, Controllers, and Providers
80
+
81
+ ```ts
82
+ @Module({
83
+ controllers: [UsersController],
84
+ providers: [UsersService],
85
+ exports: [UsersService],
86
+ })
87
+ export class UsersModule {}
88
+
89
+ @Controller('users')
90
+ export class UsersController {
91
+ constructor(private readonly usersService: UsersService) {}
92
+
93
+ @Get(':id')
94
+ getById(@Param('id', ParseUUIDPipe) id: string) {
95
+ return this.usersService.getById(id);
96
+ }
97
+
98
+ @Post()
99
+ create(@Body() dto: CreateUserDto) {
100
+ return this.usersService.create(dto);
101
+ }
102
+ }
103
+
104
+ @Injectable()
105
+ export class UsersService {
106
+ constructor(private readonly usersRepo: UsersRepository) {}
107
+
108
+ async create(dto: CreateUserDto) {
109
+ return this.usersRepo.create(dto);
110
+ }
111
+ }
112
+ ```
113
+
114
+ - Controllers should stay thin: parse HTTP input, call a provider, return response DTOs.
115
+ - Put business logic in injectable services, not controllers.
116
+ - Export only the providers other modules genuinely need.
117
+
118
+ ## DTOs and Validation
119
+
120
+ ```ts
121
+ export class CreateUserDto {
122
+ @IsEmail()
123
+ email!: string;
124
+
125
+ @IsString()
126
+ @Length(2, 80)
127
+ name!: string;
128
+
129
+ @IsOptional()
130
+ @IsEnum(UserRole)
131
+ role?: UserRole;
132
+ }
133
+ ```
134
+
135
+ - Validate every request DTO with `class-validator`.
136
+ - Use dedicated response DTOs or serializers instead of returning ORM entities directly.
137
+ - Avoid leaking internal fields such as password hashes, tokens, or audit columns.
138
+
139
+ ## Auth, Guards, and Request Context
140
+
141
+ ```ts
142
+ @UseGuards(JwtAuthGuard, RolesGuard)
143
+ @Roles('admin')
144
+ @Get('admin/report')
145
+ getAdminReport(@Req() req: AuthenticatedRequest) {
146
+ return this.reportService.getForUser(req.user.id);
147
+ }
148
+ ```
149
+
150
+ - Keep auth strategies and guards module-local unless they are truly shared.
151
+ - Encode coarse access rules in guards, then do resource-specific authorization in services.
152
+ - Prefer explicit request types for authenticated request objects.
153
+
154
+ ## Exception Filters and Error Shape
155
+
156
+ ```ts
157
+ @Catch()
158
+ export class HttpExceptionFilter implements ExceptionFilter {
159
+ catch(exception: unknown, host: ArgumentsHost) {
160
+ const response = host.switchToHttp().getResponse<Response>();
161
+ const request = host.switchToHttp().getRequest<Request>();
162
+
163
+ if (exception instanceof HttpException) {
164
+ return response.status(exception.getStatus()).json({
165
+ path: request.url,
166
+ error: exception.getResponse(),
167
+ });
168
+ }
169
+
170
+ return response.status(500).json({
171
+ path: request.url,
172
+ error: 'Internal server error',
173
+ });
174
+ }
175
+ }
176
+ ```
177
+
178
+ - Keep one consistent error envelope across the API.
179
+ - Throw framework exceptions for expected client errors; log and wrap unexpected failures centrally.
180
+
181
+ ## Config and Environment Validation
182
+
183
+ ```ts
184
+ ConfigModule.forRoot({
185
+ isGlobal: true,
186
+ load: [configuration],
187
+ validate: validateEnv,
188
+ });
189
+ ```
190
+
191
+ - Validate env at boot, not lazily at first request.
192
+ - Keep config access behind typed helpers or config services.
193
+ - Split dev/staging/prod concerns in config factories instead of branching throughout feature code.
194
+
195
+ ## Persistence and Transactions
196
+
197
+ - Keep repository / ORM code behind providers that speak domain language.
198
+ - For Prisma or TypeORM, isolate transactional workflows in services that own the unit of work.
199
+ - Do not let controllers coordinate multi-step writes directly.
200
+
201
+ ## Testing
202
+
203
+ ```ts
204
+ describe('UsersController', () => {
205
+ let app: INestApplication;
206
+
207
+ beforeAll(async () => {
208
+ const moduleRef = await Test.createTestingModule({
209
+ imports: [UsersModule],
210
+ }).compile();
211
+
212
+ app = moduleRef.createNestApplication();
213
+ app.useGlobalPipes(new ValidationPipe({ whitelist: true, transform: true }));
214
+ await app.init();
215
+ });
216
+ });
217
+ ```
218
+
219
+ - Unit test providers in isolation with mocked dependencies.
220
+ - Add request-level tests for guards, validation pipes, and exception filters.
221
+ - Reuse the same global pipes/filters in tests that you use in production.
222
+
223
+ ## Production Defaults
224
+
225
+ - Enable structured logging and request correlation ids.
226
+ - Terminate on invalid env/config instead of booting partially.
227
+ - Prefer async provider initialization for DB/cache clients with explicit health checks.
228
+ - Keep background jobs and event consumers in their own modules, not inside HTTP controllers.
229
+ - Make rate limiting, auth, and audit logging explicit for public endpoints.