skill-library-mcp 1.0.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 (989) hide show
  1. package/.claude/settings.local.json +10 -0
  2. package/.github/workflows/ci.yml +85 -0
  3. package/.github/workflows/release.yml +57 -0
  4. package/.release-please-manifest.json +3 -0
  5. package/CLAUDE.md +60 -0
  6. package/LICENSE +21 -0
  7. package/Makefile +18 -0
  8. package/README.md +222 -0
  9. package/dist/index.js +312 -0
  10. package/docs/architecture.md +61 -0
  11. package/docs/development.md +83 -0
  12. package/package.json +29 -0
  13. package/release-please-config.json +17 -0
  14. package/scripts/import-skills.ts +103 -0
  15. package/skills/3d-web-experience/SKILL.md +254 -0
  16. package/skills/ab-test-setup/SKILL.md +232 -0
  17. package/skills/accessibility-compliance-accessibility-audit/SKILL.md +42 -0
  18. package/skills/accessibility-compliance-accessibility-audit/resources/implementation-playbook.md +502 -0
  19. package/skills/active-directory-attacks/SKILL.md +383 -0
  20. package/skills/activecampaign-automation/SKILL.md +209 -0
  21. package/skills/address-github-comments/SKILL.md +55 -0
  22. package/skills/agent-evaluation/SKILL.md +64 -0
  23. package/skills/agent-manager-skill/SKILL.md +40 -0
  24. package/skills/agent-memory-mcp/SKILL.md +82 -0
  25. package/skills/agent-memory-systems/SKILL.md +67 -0
  26. package/skills/agent-orchestration-improve-agent/SKILL.md +349 -0
  27. package/skills/agent-orchestration-multi-agent-optimize/SKILL.md +239 -0
  28. package/skills/agent-tool-builder/SKILL.md +53 -0
  29. package/skills/ai-agents-architect/SKILL.md +90 -0
  30. package/skills/ai-engineer/SKILL.md +171 -0
  31. package/skills/ai-product/SKILL.md +54 -0
  32. package/skills/ai-wrapper-product/SKILL.md +273 -0
  33. package/skills/airflow-dag-patterns/SKILL.md +41 -0
  34. package/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
  35. package/skills/airtable-automation/SKILL.md +170 -0
  36. package/skills/algolia-search/SKILL.md +66 -0
  37. package/skills/algorithmic-art/LICENSE.txt +202 -0
  38. package/skills/algorithmic-art/SKILL.md +405 -0
  39. package/skills/algorithmic-art/templates/generator_template.js +223 -0
  40. package/skills/algorithmic-art/templates/viewer.html +599 -0
  41. package/skills/amplitude-automation/SKILL.md +216 -0
  42. package/skills/analytics-tracking/SKILL.md +404 -0
  43. package/skills/angular/SKILL.md +821 -0
  44. package/skills/angular-best-practices/SKILL.md +559 -0
  45. package/skills/angular-migration/SKILL.md +428 -0
  46. package/skills/angular-state-management/SKILL.md +634 -0
  47. package/skills/angular-ui-patterns/SKILL.md +508 -0
  48. package/skills/anti-reversing-techniques/SKILL.md +42 -0
  49. package/skills/anti-reversing-techniques/resources/implementation-playbook.md +539 -0
  50. package/skills/antigravity-workflows/SKILL.md +80 -0
  51. package/skills/antigravity-workflows/resources/implementation-playbook.md +36 -0
  52. package/skills/api-design-principles/SKILL.md +37 -0
  53. package/skills/api-design-principles/resources/implementation-playbook.md +513 -0
  54. package/skills/api-documentation-generator/SKILL.md +484 -0
  55. package/skills/api-documenter/SKILL.md +184 -0
  56. package/skills/api-fuzzing-bug-bounty/SKILL.md +433 -0
  57. package/skills/api-patterns/SKILL.md +81 -0
  58. package/skills/api-security-best-practices/SKILL.md +907 -0
  59. package/skills/api-testing-observability-api-mock/SKILL.md +46 -0
  60. package/skills/api-testing-observability-api-mock/resources/implementation-playbook.md +1327 -0
  61. package/skills/app-builder/SKILL.md +75 -0
  62. package/skills/app-store-optimization/SKILL.md +403 -0
  63. package/skills/application-performance-performance-optimization/SKILL.md +154 -0
  64. package/skills/architect-review/SKILL.md +174 -0
  65. package/skills/architecture/SKILL.md +55 -0
  66. package/skills/architecture-decision-records/SKILL.md +441 -0
  67. package/skills/architecture-patterns/SKILL.md +37 -0
  68. package/skills/architecture-patterns/resources/implementation-playbook.md +479 -0
  69. package/skills/arm-cortex-expert/SKILL.md +306 -0
  70. package/skills/asana-automation/SKILL.md +171 -0
  71. package/skills/async-python-patterns/SKILL.md +39 -0
  72. package/skills/async-python-patterns/resources/implementation-playbook.md +678 -0
  73. package/skills/attack-tree-construction/SKILL.md +38 -0
  74. package/skills/attack-tree-construction/resources/implementation-playbook.md +671 -0
  75. package/skills/audio-transcriber/SKILL.md +558 -0
  76. package/skills/auth-implementation-patterns/SKILL.md +39 -0
  77. package/skills/auth-implementation-patterns/resources/implementation-playbook.md +618 -0
  78. package/skills/automate-whatsapp/SKILL.md +257 -0
  79. package/skills/autonomous-agent-patterns/SKILL.md +761 -0
  80. package/skills/autonomous-agents/SKILL.md +68 -0
  81. package/skills/avalonia-layout-zafiro/SKILL.md +59 -0
  82. package/skills/avalonia-viewmodels-zafiro/SKILL.md +29 -0
  83. package/skills/avalonia-zafiro-development/SKILL.md +29 -0
  84. package/skills/aws-penetration-testing/SKILL.md +405 -0
  85. package/skills/aws-serverless/SKILL.md +323 -0
  86. package/skills/aws-skills/SKILL.md +22 -0
  87. package/skills/azure-functions/SKILL.md +42 -0
  88. package/skills/backend-architect/SKILL.md +333 -0
  89. package/skills/backend-dev-guidelines/SKILL.md +342 -0
  90. package/skills/backend-dev-guidelines/resources/architecture-overview.md +451 -0
  91. package/skills/backend-dev-guidelines/resources/async-and-errors.md +307 -0
  92. package/skills/backend-dev-guidelines/resources/complete-examples.md +638 -0
  93. package/skills/backend-dev-guidelines/resources/configuration.md +275 -0
  94. package/skills/backend-dev-guidelines/resources/database-patterns.md +224 -0
  95. package/skills/backend-dev-guidelines/resources/middleware-guide.md +213 -0
  96. package/skills/backend-dev-guidelines/resources/routing-and-controllers.md +756 -0
  97. package/skills/backend-dev-guidelines/resources/sentry-and-monitoring.md +336 -0
  98. package/skills/backend-dev-guidelines/resources/services-and-repositories.md +789 -0
  99. package/skills/backend-dev-guidelines/resources/testing-guide.md +235 -0
  100. package/skills/backend-dev-guidelines/resources/validation-patterns.md +754 -0
  101. package/skills/backend-development-feature-development/SKILL.md +180 -0
  102. package/skills/backend-security-coder/SKILL.md +156 -0
  103. package/skills/backtesting-frameworks/SKILL.md +39 -0
  104. package/skills/backtesting-frameworks/resources/implementation-playbook.md +647 -0
  105. package/skills/bamboohr-automation/SKILL.md +220 -0
  106. package/skills/basecamp-automation/SKILL.md +234 -0
  107. package/skills/bash-defensive-patterns/SKILL.md +43 -0
  108. package/skills/bash-defensive-patterns/resources/implementation-playbook.md +517 -0
  109. package/skills/bash-linux/SKILL.md +199 -0
  110. package/skills/bash-pro/SKILL.md +310 -0
  111. package/skills/bats-testing-patterns/SKILL.md +34 -0
  112. package/skills/bats-testing-patterns/resources/implementation-playbook.md +614 -0
  113. package/skills/bazel-build-optimization/SKILL.md +397 -0
  114. package/skills/beautiful-prose/SKILL.md +22 -0
  115. package/skills/behavioral-modes/SKILL.md +242 -0
  116. package/skills/billing-automation/SKILL.md +42 -0
  117. package/skills/billing-automation/resources/implementation-playbook.md +544 -0
  118. package/skills/binary-analysis-patterns/SKILL.md +450 -0
  119. package/skills/bitbucket-automation/SKILL.md +224 -0
  120. package/skills/blockchain-developer/SKILL.md +208 -0
  121. package/skills/blockrun/SKILL.md +292 -0
  122. package/skills/box-automation/SKILL.md +233 -0
  123. package/skills/brainstorming/SKILL.md +230 -0
  124. package/skills/brand-guidelines-anthropic/SKILL.md +73 -0
  125. package/skills/brevo-automation/SKILL.md +197 -0
  126. package/skills/broken-authentication/SKILL.md +476 -0
  127. package/skills/browser-automation/SKILL.md +70 -0
  128. package/skills/browser-extension-builder/SKILL.md +261 -0
  129. package/skills/bullmq-specialist/SKILL.md +57 -0
  130. package/skills/bun-development/SKILL.md +691 -0
  131. package/skills/burp-suite-testing/SKILL.md +380 -0
  132. package/skills/business-analyst/SKILL.md +182 -0
  133. package/skills/busybox-on-windows/SKILL.md +30 -0
  134. package/skills/c-pro/SKILL.md +56 -0
  135. package/skills/c4-architecture-c4-architecture/SKILL.md +389 -0
  136. package/skills/c4-code/SKILL.md +244 -0
  137. package/skills/c4-component/SKILL.md +153 -0
  138. package/skills/c4-container/SKILL.md +171 -0
  139. package/skills/c4-context/SKILL.md +150 -0
  140. package/skills/cal-com-automation/SKILL.md +203 -0
  141. package/skills/calendly-automation/SKILL.md +211 -0
  142. package/skills/canva-automation/SKILL.md +217 -0
  143. package/skills/canvas-design/LICENSE.txt +202 -0
  144. package/skills/canvas-design/SKILL.md +130 -0
  145. package/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -0
  146. package/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  147. package/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  148. package/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -0
  149. package/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  150. package/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -0
  151. package/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
  152. package/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  153. package/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
  154. package/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  155. package/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  156. package/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  157. package/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -0
  158. package/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  159. package/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -0
  160. package/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
  161. package/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -0
  162. package/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
  163. package/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
  164. package/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -0
  165. package/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
  166. package/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -0
  167. package/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
  168. package/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  169. package/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
  170. package/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  171. package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  172. package/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  173. package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  174. package/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  175. package/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  176. package/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  177. package/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  178. package/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -0
  179. package/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  180. package/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  181. package/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  182. package/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +93 -0
  183. package/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
  184. package/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  185. package/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
  186. package/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  187. package/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
  188. package/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
  189. package/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -0
  190. package/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
  191. package/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  192. package/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
  193. package/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  194. package/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
  195. package/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -0
  196. package/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
  197. package/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
  198. package/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -0
  199. package/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
  200. package/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
  201. package/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  202. package/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
  203. package/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -0
  204. package/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
  205. package/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  206. package/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -0
  207. package/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +93 -0
  208. package/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  209. package/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  210. package/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -0
  211. package/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  212. package/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -0
  213. package/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  214. package/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  215. package/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -0
  216. package/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
  217. package/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -0
  218. package/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
  219. package/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
  220. package/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  221. package/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
  222. package/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -0
  223. package/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
  224. package/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -0
  225. package/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  226. package/skills/cc-skill-backend-patterns/SKILL.md +584 -0
  227. package/skills/cc-skill-clickhouse-io/SKILL.md +431 -0
  228. package/skills/cc-skill-coding-standards/SKILL.md +522 -0
  229. package/skills/cc-skill-continuous-learning/SKILL.md +10 -0
  230. package/skills/cc-skill-frontend-patterns/SKILL.md +633 -0
  231. package/skills/cc-skill-project-guidelines-example/SKILL.md +352 -0
  232. package/skills/cc-skill-security-review/SKILL.md +496 -0
  233. package/skills/cc-skill-strategic-compact/SKILL.md +10 -0
  234. package/skills/changelog-automation/SKILL.md +38 -0
  235. package/skills/changelog-automation/resources/implementation-playbook.md +538 -0
  236. package/skills/cicd-automation-workflow-automate/SKILL.md +51 -0
  237. package/skills/cicd-automation-workflow-automate/resources/implementation-playbook.md +1333 -0
  238. package/skills/circleci-automation/SKILL.md +177 -0
  239. package/skills/clarity-gate/SKILL.md +22 -0
  240. package/skills/claude-ally-health/SKILL.md +22 -0
  241. package/skills/claude-code-guide/SKILL.md +68 -0
  242. package/skills/claude-d3js-skill/SKILL.md +820 -0
  243. package/skills/claude-scientific-skills/SKILL.md +22 -0
  244. package/skills/claude-speed-reader/SKILL.md +22 -0
  245. package/skills/claude-win11-speckit-update-skill/SKILL.md +22 -0
  246. package/skills/clean-code/SKILL.md +94 -0
  247. package/skills/clerk-auth/SKILL.md +56 -0
  248. package/skills/clickup-automation/SKILL.md +234 -0
  249. package/skills/close-automation/SKILL.md +212 -0
  250. package/skills/cloud-architect/SKILL.md +135 -0
  251. package/skills/cloud-penetration-testing/SKILL.md +501 -0
  252. package/skills/coda-automation/SKILL.md +241 -0
  253. package/skills/code-documentation-code-explain/SKILL.md +46 -0
  254. package/skills/code-documentation-code-explain/resources/implementation-playbook.md +802 -0
  255. package/skills/code-documentation-doc-generate/SKILL.md +48 -0
  256. package/skills/code-documentation-doc-generate/resources/implementation-playbook.md +640 -0
  257. package/skills/code-refactoring-context-restore/SKILL.md +179 -0
  258. package/skills/code-refactoring-refactor-clean/SKILL.md +51 -0
  259. package/skills/code-refactoring-refactor-clean/resources/implementation-playbook.md +879 -0
  260. package/skills/code-refactoring-tech-debt/SKILL.md +386 -0
  261. package/skills/code-review-ai-ai-review/SKILL.md +450 -0
  262. package/skills/code-review-checklist/SKILL.md +444 -0
  263. package/skills/code-review-excellence/SKILL.md +40 -0
  264. package/skills/code-review-excellence/resources/implementation-playbook.md +515 -0
  265. package/skills/code-reviewer/SKILL.md +178 -0
  266. package/skills/codebase-cleanup-deps-audit/SKILL.md +51 -0
  267. package/skills/codebase-cleanup-deps-audit/resources/implementation-playbook.md +766 -0
  268. package/skills/codebase-cleanup-refactor-clean/SKILL.md +51 -0
  269. package/skills/codebase-cleanup-refactor-clean/resources/implementation-playbook.md +879 -0
  270. package/skills/codebase-cleanup-tech-debt/SKILL.md +386 -0
  271. package/skills/codex-review/SKILL.md +37 -0
  272. package/skills/commit/SKILL.md +171 -0
  273. package/skills/competitive-landscape/SKILL.md +34 -0
  274. package/skills/competitive-landscape/resources/implementation-playbook.md +494 -0
  275. package/skills/competitor-alternatives/SKILL.md +750 -0
  276. package/skills/comprehensive-review-full-review/SKILL.md +146 -0
  277. package/skills/comprehensive-review-pr-enhance/SKILL.md +46 -0
  278. package/skills/comprehensive-review-pr-enhance/resources/implementation-playbook.md +691 -0
  279. package/skills/computer-use-agents/SKILL.md +315 -0
  280. package/skills/computer-vision-expert/SKILL.md +70 -0
  281. package/skills/concise-planning/SKILL.md +62 -0
  282. package/skills/conductor-implement/SKILL.md +388 -0
  283. package/skills/conductor-manage/SKILL.md +39 -0
  284. package/skills/conductor-manage/resources/implementation-playbook.md +1120 -0
  285. package/skills/conductor-new-track/SKILL.md +433 -0
  286. package/skills/conductor-revert/SKILL.md +372 -0
  287. package/skills/conductor-setup/SKILL.md +426 -0
  288. package/skills/conductor-status/SKILL.md +338 -0
  289. package/skills/conductor-validator/SKILL.md +62 -0
  290. package/skills/confluence-automation/SKILL.md +208 -0
  291. package/skills/content-creator/SKILL.md +248 -0
  292. package/skills/content-marketer/SKILL.md +170 -0
  293. package/skills/context-compression/SKILL.md +266 -0
  294. package/skills/context-degradation/SKILL.md +238 -0
  295. package/skills/context-driven-development/SKILL.md +400 -0
  296. package/skills/context-fundamentals/SKILL.md +192 -0
  297. package/skills/context-management-context-restore/SKILL.md +179 -0
  298. package/skills/context-management-context-save/SKILL.md +177 -0
  299. package/skills/context-manager/SKILL.md +185 -0
  300. package/skills/context-optimization/SKILL.md +186 -0
  301. package/skills/context-window-management/SKILL.md +53 -0
  302. package/skills/context7-auto-research/SKILL.md +36 -0
  303. package/skills/conversation-memory/SKILL.md +61 -0
  304. package/skills/convertkit-automation/SKILL.md +195 -0
  305. package/skills/copy-editing/SKILL.md +439 -0
  306. package/skills/copywriting/SKILL.md +225 -0
  307. package/skills/core-components/SKILL.md +264 -0
  308. package/skills/cost-optimization/SKILL.md +286 -0
  309. package/skills/cpp-pro/SKILL.md +59 -0
  310. package/skills/cqrs-implementation/SKILL.md +35 -0
  311. package/skills/cqrs-implementation/resources/implementation-playbook.md +540 -0
  312. package/skills/create-pr/SKILL.md +192 -0
  313. package/skills/crewai/SKILL.md +243 -0
  314. package/skills/csharp-pro/SKILL.md +59 -0
  315. package/skills/culture-index/SKILL.md +43 -0
  316. package/skills/customer-support/SKILL.md +170 -0
  317. package/skills/daily-news-report/SKILL.md +356 -0
  318. package/skills/data-engineer/SKILL.md +224 -0
  319. package/skills/data-engineering-data-driven-feature/SKILL.md +182 -0
  320. package/skills/data-engineering-data-pipeline/SKILL.md +201 -0
  321. package/skills/data-quality-frameworks/SKILL.md +40 -0
  322. package/skills/data-quality-frameworks/resources/implementation-playbook.md +573 -0
  323. package/skills/data-scientist/SKILL.md +199 -0
  324. package/skills/data-storytelling/SKILL.md +465 -0
  325. package/skills/database-admin/SKILL.md +165 -0
  326. package/skills/database-architect/SKILL.md +268 -0
  327. package/skills/database-cloud-optimization-cost-optimize/SKILL.md +44 -0
  328. package/skills/database-cloud-optimization-cost-optimize/resources/implementation-playbook.md +1441 -0
  329. package/skills/database-design/SKILL.md +52 -0
  330. package/skills/database-migration/SKILL.md +436 -0
  331. package/skills/database-migrations-migration-observability/SKILL.md +420 -0
  332. package/skills/database-migrations-sql-migrations/SKILL.md +53 -0
  333. package/skills/database-migrations-sql-migrations/resources/implementation-playbook.md +499 -0
  334. package/skills/database-optimizer/SKILL.md +167 -0
  335. package/skills/datadog-automation/SKILL.md +235 -0
  336. package/skills/dbt-transformation-patterns/SKILL.md +34 -0
  337. package/skills/dbt-transformation-patterns/resources/implementation-playbook.md +547 -0
  338. package/skills/debugger/SKILL.md +49 -0
  339. package/skills/debugging-strategies/SKILL.md +34 -0
  340. package/skills/debugging-strategies/resources/implementation-playbook.md +511 -0
  341. package/skills/debugging-toolkit-smart-debug/SKILL.md +197 -0
  342. package/skills/deep-research/SKILL.md +114 -0
  343. package/skills/defi-protocol-templates/SKILL.md +466 -0
  344. package/skills/dependency-management-deps-audit/SKILL.md +44 -0
  345. package/skills/dependency-management-deps-audit/resources/implementation-playbook.md +766 -0
  346. package/skills/dependency-upgrade/SKILL.md +421 -0
  347. package/skills/deployment-engineer/SKILL.md +170 -0
  348. package/skills/deployment-pipeline-design/SKILL.md +371 -0
  349. package/skills/deployment-procedures/SKILL.md +241 -0
  350. package/skills/deployment-validation-config-validate/SKILL.md +496 -0
  351. package/skills/design-md/SKILL.md +178 -0
  352. package/skills/design-orchestration/SKILL.md +167 -0
  353. package/skills/devops-troubleshooter/SKILL.md +161 -0
  354. package/skills/discord-automation/SKILL.md +187 -0
  355. package/skills/discord-bot-architect/SKILL.md +277 -0
  356. package/skills/dispatching-parallel-agents/SKILL.md +180 -0
  357. package/skills/distributed-debugging-debug-trace/SKILL.md +44 -0
  358. package/skills/distributed-debugging-debug-trace/resources/implementation-playbook.md +1307 -0
  359. package/skills/distributed-tracing/SKILL.md +450 -0
  360. package/skills/django-pro/SKILL.md +180 -0
  361. package/skills/doc-coauthoring/SKILL.md +375 -0
  362. package/skills/docker-expert/SKILL.md +409 -0
  363. package/skills/docs-architect/SKILL.md +98 -0
  364. package/skills/documentation-generation-doc-generate/SKILL.md +48 -0
  365. package/skills/documentation-generation-doc-generate/resources/implementation-playbook.md +640 -0
  366. package/skills/documentation-templates/SKILL.md +194 -0
  367. package/skills/docusign-automation/SKILL.md +208 -0
  368. package/skills/dotnet-architect/SKILL.md +197 -0
  369. package/skills/dotnet-backend/SKILL.md +266 -0
  370. package/skills/dotnet-backend-patterns/SKILL.md +37 -0
  371. package/skills/dotnet-backend-patterns/resources/implementation-playbook.md +799 -0
  372. package/skills/dropbox-automation/SKILL.md +230 -0
  373. package/skills/dx-optimizer/SKILL.md +83 -0
  374. package/skills/e2e-testing-patterns/SKILL.md +41 -0
  375. package/skills/e2e-testing-patterns/resources/implementation-playbook.md +531 -0
  376. package/skills/elixir-pro/SKILL.md +59 -0
  377. package/skills/email-sequence/SKILL.md +925 -0
  378. package/skills/email-systems/SKILL.md +54 -0
  379. package/skills/embedding-strategies/SKILL.md +491 -0
  380. package/skills/employment-contract-templates/SKILL.md +39 -0
  381. package/skills/employment-contract-templates/resources/implementation-playbook.md +493 -0
  382. package/skills/environment-setup-guide/SKILL.md +479 -0
  383. package/skills/error-debugging-error-analysis/SKILL.md +47 -0
  384. package/skills/error-debugging-error-analysis/resources/implementation-playbook.md +1143 -0
  385. package/skills/error-debugging-error-trace/SKILL.md +43 -0
  386. package/skills/error-debugging-error-trace/resources/implementation-playbook.md +1361 -0
  387. package/skills/error-debugging-multi-agent-review/SKILL.md +216 -0
  388. package/skills/error-detective/SKILL.md +53 -0
  389. package/skills/error-diagnostics-error-analysis/SKILL.md +47 -0
  390. package/skills/error-diagnostics-error-analysis/resources/implementation-playbook.md +1143 -0
  391. package/skills/error-diagnostics-error-trace/SKILL.md +48 -0
  392. package/skills/error-diagnostics-error-trace/resources/implementation-playbook.md +1371 -0
  393. package/skills/error-diagnostics-smart-debug/SKILL.md +197 -0
  394. package/skills/error-handling-patterns/SKILL.md +35 -0
  395. package/skills/error-handling-patterns/resources/implementation-playbook.md +635 -0
  396. package/skills/ethical-hacking-methodology/SKILL.md +466 -0
  397. package/skills/evaluation/SKILL.md +238 -0
  398. package/skills/event-sourcing-architect/SKILL.md +58 -0
  399. package/skills/event-store-design/SKILL.md +449 -0
  400. package/skills/exa-search/SKILL.md +36 -0
  401. package/skills/executing-plans/SKILL.md +76 -0
  402. package/skills/expo-deployment/SKILL.md +72 -0
  403. package/skills/fal-audio/SKILL.md +22 -0
  404. package/skills/fal-generate/SKILL.md +22 -0
  405. package/skills/fal-image-edit/SKILL.md +22 -0
  406. package/skills/fal-platform/SKILL.md +22 -0
  407. package/skills/fal-upscale/SKILL.md +22 -0
  408. package/skills/fal-workflow/SKILL.md +22 -0
  409. package/skills/fastapi-pro/SKILL.md +192 -0
  410. package/skills/fastapi-templates/SKILL.md +32 -0
  411. package/skills/fastapi-templates/resources/implementation-playbook.md +566 -0
  412. package/skills/ffuf-claude-skill/SKILL.md +22 -0
  413. package/skills/figma-automation/SKILL.md +181 -0
  414. package/skills/file-organizer/SKILL.md +250 -0
  415. package/skills/file-path-traversal/SKILL.md +486 -0
  416. package/skills/file-uploads/SKILL.md +22 -0
  417. package/skills/find-bugs/SKILL.md +86 -0
  418. package/skills/finishing-a-development-branch/SKILL.md +200 -0
  419. package/skills/firebase/SKILL.md +56 -0
  420. package/skills/firecrawl-scraper/SKILL.md +37 -0
  421. package/skills/firmware-analyst/SKILL.md +320 -0
  422. package/skills/fix-review/SKILL.md +53 -0
  423. package/skills/flutter-expert/SKILL.md +200 -0
  424. package/skills/form-cro/SKILL.md +441 -0
  425. package/skills/fp-ts-errors/SKILL.md +856 -0
  426. package/skills/fp-ts-pragmatic/SKILL.md +598 -0
  427. package/skills/fp-ts-react/SKILL.md +796 -0
  428. package/skills/framework-migration-code-migrate/SKILL.md +48 -0
  429. package/skills/framework-migration-code-migrate/resources/implementation-playbook.md +1052 -0
  430. package/skills/framework-migration-deps-upgrade/SKILL.md +48 -0
  431. package/skills/framework-migration-deps-upgrade/resources/implementation-playbook.md +755 -0
  432. package/skills/framework-migration-legacy-modernize/SKILL.md +132 -0
  433. package/skills/free-tool-strategy/SKILL.md +576 -0
  434. package/skills/freshdesk-automation/SKILL.md +219 -0
  435. package/skills/freshservice-automation/SKILL.md +213 -0
  436. package/skills/frontend-design/LICENSE.txt +177 -0
  437. package/skills/frontend-design/SKILL.md +42 -0
  438. package/skills/frontend-dev-guidelines/SKILL.md +359 -0
  439. package/skills/frontend-dev-guidelines/resources/common-patterns.md +331 -0
  440. package/skills/frontend-dev-guidelines/resources/complete-examples.md +872 -0
  441. package/skills/frontend-dev-guidelines/resources/component-patterns.md +502 -0
  442. package/skills/frontend-dev-guidelines/resources/data-fetching.md +767 -0
  443. package/skills/frontend-dev-guidelines/resources/file-organization.md +502 -0
  444. package/skills/frontend-dev-guidelines/resources/loading-and-error-states.md +501 -0
  445. package/skills/frontend-dev-guidelines/resources/performance.md +406 -0
  446. package/skills/frontend-dev-guidelines/resources/routing-guide.md +364 -0
  447. package/skills/frontend-dev-guidelines/resources/styling-guide.md +428 -0
  448. package/skills/frontend-dev-guidelines/resources/typescript-standards.md +418 -0
  449. package/skills/frontend-developer/SKILL.md +171 -0
  450. package/skills/frontend-mobile-development-component-scaffold/SKILL.md +403 -0
  451. package/skills/frontend-mobile-security-xss-scan/SKILL.md +322 -0
  452. package/skills/frontend-security-coder/SKILL.md +170 -0
  453. package/skills/frontend-slides/SKILL.md +770 -0
  454. package/skills/full-stack-orchestration-full-stack-feature/SKILL.md +135 -0
  455. package/skills/game-development/SKILL.md +167 -0
  456. package/skills/gcp-cloud-run/SKILL.md +288 -0
  457. package/skills/gdpr-data-handling/SKILL.md +33 -0
  458. package/skills/gdpr-data-handling/resources/implementation-playbook.md +615 -0
  459. package/skills/geo-fundamentals/SKILL.md +156 -0
  460. package/skills/git-advanced-workflows/SKILL.md +412 -0
  461. package/skills/git-pr-workflows-git-workflow/SKILL.md +140 -0
  462. package/skills/git-pr-workflows-onboard/SKILL.md +416 -0
  463. package/skills/git-pr-workflows-pr-enhance/SKILL.md +48 -0
  464. package/skills/git-pr-workflows-pr-enhance/resources/implementation-playbook.md +701 -0
  465. package/skills/git-pushing/SKILL.md +33 -0
  466. package/skills/github-actions-templates/SKILL.md +345 -0
  467. package/skills/github-automation/SKILL.md +227 -0
  468. package/skills/github-workflow-automation/SKILL.md +846 -0
  469. package/skills/gitlab-automation/SKILL.md +254 -0
  470. package/skills/gitlab-ci-patterns/SKILL.md +283 -0
  471. package/skills/gitops-workflow/SKILL.md +303 -0
  472. package/skills/gmail-automation/SKILL.md +270 -0
  473. package/skills/go-concurrency-patterns/SKILL.md +33 -0
  474. package/skills/go-concurrency-patterns/resources/implementation-playbook.md +654 -0
  475. package/skills/go-playwright/SKILL.md +76 -0
  476. package/skills/go-playwright/resources/implementation-playbook.md +110 -0
  477. package/skills/godot-gdscript-patterns/SKILL.md +33 -0
  478. package/skills/godot-gdscript-patterns/resources/implementation-playbook.md +804 -0
  479. package/skills/golang-pro/SKILL.md +179 -0
  480. package/skills/google-analytics-automation/SKILL.md +227 -0
  481. package/skills/google-calendar-automation/SKILL.md +176 -0
  482. package/skills/google-drive-automation/SKILL.md +193 -0
  483. package/skills/googlesheets-automation/SKILL.md +197 -0
  484. package/skills/grafana-dashboards/SKILL.md +381 -0
  485. package/skills/graphql/SKILL.md +68 -0
  486. package/skills/graphql-architect/SKILL.md +182 -0
  487. package/skills/haskell-pro/SKILL.md +56 -0
  488. package/skills/helm-chart-scaffolding/SKILL.md +34 -0
  489. package/skills/helm-chart-scaffolding/resources/implementation-playbook.md +543 -0
  490. package/skills/helpdesk-automation/SKILL.md +166 -0
  491. package/skills/hr-pro/SKILL.md +126 -0
  492. package/skills/html-injection-testing/SKILL.md +498 -0
  493. package/skills/hubspot-automation/SKILL.md +178 -0
  494. package/skills/hubspot-integration/SKILL.md +42 -0
  495. package/skills/hugging-face-cli/SKILL.md +198 -0
  496. package/skills/hugging-face-jobs/SKILL.md +1038 -0
  497. package/skills/hybrid-cloud-architect/SKILL.md +168 -0
  498. package/skills/hybrid-cloud-networking/SKILL.md +238 -0
  499. package/skills/hybrid-search-implementation/SKILL.md +32 -0
  500. package/skills/hybrid-search-implementation/resources/implementation-playbook.md +567 -0
  501. package/skills/i18n-localization/SKILL.md +154 -0
  502. package/skills/idor-testing/SKILL.md +442 -0
  503. package/skills/imagen/SKILL.md +77 -0
  504. package/skills/incident-responder/SKILL.md +213 -0
  505. package/skills/incident-response-incident-response/SKILL.md +168 -0
  506. package/skills/incident-response-smart-fix/SKILL.md +29 -0
  507. package/skills/incident-response-smart-fix/resources/implementation-playbook.md +838 -0
  508. package/skills/incident-runbook-templates/SKILL.md +395 -0
  509. package/skills/infinite-gratitude/SKILL.md +26 -0
  510. package/skills/inngest/SKILL.md +55 -0
  511. package/skills/instagram-automation/SKILL.md +192 -0
  512. package/skills/interactive-portfolio/SKILL.md +223 -0
  513. package/skills/intercom-automation/SKILL.md +248 -0
  514. package/skills/internal-comms-anthropic/SKILL.md +32 -0
  515. package/skills/ios-developer/SKILL.md +219 -0
  516. package/skills/istio-traffic-management/SKILL.md +337 -0
  517. package/skills/iterate-pr/SKILL.md +150 -0
  518. package/skills/java-pro/SKILL.md +177 -0
  519. package/skills/javascript-mastery/SKILL.md +645 -0
  520. package/skills/javascript-pro/SKILL.md +57 -0
  521. package/skills/javascript-testing-patterns/SKILL.md +35 -0
  522. package/skills/javascript-testing-patterns/resources/implementation-playbook.md +1024 -0
  523. package/skills/javascript-typescript-typescript-scaffold/SKILL.md +361 -0
  524. package/skills/jira-automation/SKILL.md +185 -0
  525. package/skills/julia-pro/SKILL.md +209 -0
  526. package/skills/k8s-manifest-generator/SKILL.md +35 -0
  527. package/skills/k8s-manifest-generator/resources/implementation-playbook.md +510 -0
  528. package/skills/k8s-security-policies/SKILL.md +346 -0
  529. package/skills/kaizen/SKILL.md +730 -0
  530. package/skills/klaviyo-automation/SKILL.md +190 -0
  531. package/skills/kpi-dashboard-design/SKILL.md +440 -0
  532. package/skills/kubernetes-architect/SKILL.md +170 -0
  533. package/skills/langchain-architecture/SKILL.md +350 -0
  534. package/skills/langfuse/SKILL.md +238 -0
  535. package/skills/langgraph/SKILL.md +287 -0
  536. package/skills/last30days/SKILL.md +421 -0
  537. package/skills/launch-strategy/SKILL.md +344 -0
  538. package/skills/legacy-modernizer/SKILL.md +53 -0
  539. package/skills/legal-advisor/SKILL.md +70 -0
  540. package/skills/linear-automation/SKILL.md +178 -0
  541. package/skills/linear-claude-skill/SKILL.md +543 -0
  542. package/skills/linkedin-automation/SKILL.md +175 -0
  543. package/skills/linkerd-patterns/SKILL.md +321 -0
  544. package/skills/lint-and-validate/SKILL.md +45 -0
  545. package/skills/linux-privilege-escalation/SKILL.md +504 -0
  546. package/skills/linux-shell-scripting/SKILL.md +504 -0
  547. package/skills/llm-app-patterns/SKILL.md +760 -0
  548. package/skills/llm-application-dev-ai-assistant/SKILL.md +35 -0
  549. package/skills/llm-application-dev-ai-assistant/resources/implementation-playbook.md +1236 -0
  550. package/skills/llm-application-dev-langchain-agent/SKILL.md +246 -0
  551. package/skills/llm-application-dev-prompt-optimize/SKILL.md +37 -0
  552. package/skills/llm-application-dev-prompt-optimize/resources/implementation-playbook.md +591 -0
  553. package/skills/llm-evaluation/SKILL.md +483 -0
  554. package/skills/loki-mode/SKILL.md +721 -0
  555. package/skills/machine-learning-ops-ml-pipeline/SKILL.md +314 -0
  556. package/skills/mailchimp-automation/SKILL.md +231 -0
  557. package/skills/make-automation/SKILL.md +201 -0
  558. package/skills/makepad-skills/SKILL.md +22 -0
  559. package/skills/malware-analyst/SKILL.md +247 -0
  560. package/skills/market-sizing-analysis/SKILL.md +425 -0
  561. package/skills/marketing-ideas/SKILL.md +221 -0
  562. package/skills/marketing-psychology/SKILL.md +255 -0
  563. package/skills/mcp-builder/LICENSE.txt +202 -0
  564. package/skills/mcp-builder/SKILL.md +236 -0
  565. package/skills/mcp-builder/resources/evaluation.md +602 -0
  566. package/skills/mcp-builder/resources/mcp_best_practices.md +249 -0
  567. package/skills/mcp-builder/resources/node_mcp_server.md +970 -0
  568. package/skills/mcp-builder/resources/python_mcp_server.md +719 -0
  569. package/skills/mcp-builder/scripts/connections.py +151 -0
  570. package/skills/mcp-builder/scripts/evaluation.py +373 -0
  571. package/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  572. package/skills/mcp-builder/scripts/requirements.txt +2 -0
  573. package/skills/memory-forensics/SKILL.md +491 -0
  574. package/skills/memory-safety-patterns/SKILL.md +33 -0
  575. package/skills/memory-safety-patterns/resources/implementation-playbook.md +603 -0
  576. package/skills/memory-systems/SKILL.md +228 -0
  577. package/skills/mermaid-expert/SKILL.md +59 -0
  578. package/skills/metasploit-framework/SKILL.md +478 -0
  579. package/skills/micro-saas-launcher/SKILL.md +212 -0
  580. package/skills/microservices-patterns/SKILL.md +35 -0
  581. package/skills/microservices-patterns/resources/implementation-playbook.md +607 -0
  582. package/skills/microsoft-teams-automation/SKILL.md +211 -0
  583. package/skills/minecraft-bukkit-pro/SKILL.md +126 -0
  584. package/skills/miro-automation/SKILL.md +205 -0
  585. package/skills/mixpanel-automation/SKILL.md +224 -0
  586. package/skills/ml-engineer/SKILL.md +168 -0
  587. package/skills/ml-pipeline-workflow/SKILL.md +257 -0
  588. package/skills/mlops-engineer/SKILL.md +219 -0
  589. package/skills/mobile-design/SKILL.md +284 -0
  590. package/skills/mobile-developer/SKILL.md +205 -0
  591. package/skills/mobile-security-coder/SKILL.md +184 -0
  592. package/skills/modern-javascript-patterns/SKILL.md +35 -0
  593. package/skills/modern-javascript-patterns/resources/implementation-playbook.md +910 -0
  594. package/skills/monday-automation/SKILL.md +233 -0
  595. package/skills/monorepo-architect/SKILL.md +61 -0
  596. package/skills/monorepo-management/SKILL.md +35 -0
  597. package/skills/monorepo-management/resources/implementation-playbook.md +621 -0
  598. package/skills/moodle-external-api-development/SKILL.md +597 -0
  599. package/skills/mtls-configuration/SKILL.md +359 -0
  600. package/skills/multi-agent-brainstorming/SKILL.md +256 -0
  601. package/skills/multi-agent-patterns/SKILL.md +262 -0
  602. package/skills/multi-cloud-architecture/SKILL.md +189 -0
  603. package/skills/multi-platform-apps-multi-platform/SKILL.md +203 -0
  604. package/skills/n8n-code-python/SKILL.md +750 -0
  605. package/skills/n8n-mcp-tools-expert/SKILL.md +654 -0
  606. package/skills/n8n-node-configuration/SKILL.md +796 -0
  607. package/skills/nanobanana-ppt-skills/SKILL.md +22 -0
  608. package/skills/neon-postgres/SKILL.md +56 -0
  609. package/skills/nestjs-expert/SKILL.md +552 -0
  610. package/skills/network-101/SKILL.md +342 -0
  611. package/skills/network-engineer/SKILL.md +169 -0
  612. package/skills/nextjs-app-router-patterns/SKILL.md +33 -0
  613. package/skills/nextjs-app-router-patterns/resources/implementation-playbook.md +543 -0
  614. package/skills/nextjs-best-practices/SKILL.md +203 -0
  615. package/skills/nextjs-supabase-auth/SKILL.md +56 -0
  616. package/skills/nft-standards/SKILL.md +395 -0
  617. package/skills/nodejs-backend-patterns/SKILL.md +35 -0
  618. package/skills/nodejs-backend-patterns/resources/implementation-playbook.md +1019 -0
  619. package/skills/nodejs-best-practices/SKILL.md +333 -0
  620. package/skills/nosql-expert/SKILL.md +111 -0
  621. package/skills/notebooklm/SKILL.md +269 -0
  622. package/skills/notion-automation/SKILL.md +215 -0
  623. package/skills/notion-template-business/SKILL.md +216 -0
  624. package/skills/nx-workspace-patterns/SKILL.md +464 -0
  625. package/skills/observability-engineer/SKILL.md +237 -0
  626. package/skills/observability-monitoring-monitor-setup/SKILL.md +48 -0
  627. package/skills/observability-monitoring-monitor-setup/resources/implementation-playbook.md +505 -0
  628. package/skills/observability-monitoring-slo-implement/SKILL.md +43 -0
  629. package/skills/observability-monitoring-slo-implement/resources/implementation-playbook.md +1077 -0
  630. package/skills/observe-whatsapp/SKILL.md +109 -0
  631. package/skills/obsidian-clipper-template-creator/SKILL.md +64 -0
  632. package/skills/on-call-handoff-patterns/SKILL.md +453 -0
  633. package/skills/onboarding-cro/SKILL.md +433 -0
  634. package/skills/one-drive-automation/SKILL.md +238 -0
  635. package/skills/openapi-spec-generation/SKILL.md +33 -0
  636. package/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
  637. package/skills/oss-hunter/SKILL.md +75 -0
  638. package/skills/outlook-automation/SKILL.md +191 -0
  639. package/skills/outlook-calendar-automation/SKILL.md +236 -0
  640. package/skills/page-cro/SKILL.md +343 -0
  641. package/skills/pagerduty-automation/SKILL.md +245 -0
  642. package/skills/paid-ads/SKILL.md +551 -0
  643. package/skills/parallel-agents/SKILL.md +175 -0
  644. package/skills/payment-integration/SKILL.md +77 -0
  645. package/skills/paypal-integration/SKILL.md +479 -0
  646. package/skills/paywall-upgrade-cro/SKILL.md +570 -0
  647. package/skills/pci-compliance/SKILL.md +478 -0
  648. package/skills/pentest-checklist/SKILL.md +334 -0
  649. package/skills/pentest-commands/SKILL.md +438 -0
  650. package/skills/performance-engineer/SKILL.md +180 -0
  651. package/skills/performance-profiling/SKILL.md +143 -0
  652. package/skills/performance-testing-review-ai-review/SKILL.md +450 -0
  653. package/skills/performance-testing-review-multi-agent-review/SKILL.md +216 -0
  654. package/skills/personal-tool-builder/SKILL.md +289 -0
  655. package/skills/php-pro/SKILL.md +63 -0
  656. package/skills/pipedrive-automation/SKILL.md +224 -0
  657. package/skills/plaid-fintech/SKILL.md +50 -0
  658. package/skills/plan-writing/SKILL.md +152 -0
  659. package/skills/planning-with-files/SKILL.md +211 -0
  660. package/skills/playwright-skill/SKILL.md +453 -0
  661. package/skills/popup-cro/SKILL.md +346 -0
  662. package/skills/posix-shell-pro/SKILL.md +304 -0
  663. package/skills/postgres-best-practices/SKILL.md +57 -0
  664. package/skills/postgresql/SKILL.md +230 -0
  665. package/skills/posthog-automation/SKILL.md +224 -0
  666. package/skills/postmark-automation/SKILL.md +187 -0
  667. package/skills/postmortem-writing/SKILL.md +386 -0
  668. package/skills/powershell-windows/SKILL.md +167 -0
  669. package/skills/pricing-strategy/SKILL.md +356 -0
  670. package/skills/prisma-expert/SKILL.md +355 -0
  671. package/skills/privilege-escalation-methods/SKILL.md +333 -0
  672. package/skills/product-manager-toolkit/SKILL.md +351 -0
  673. package/skills/production-code-audit/SKILL.md +540 -0
  674. package/skills/programmatic-seo/SKILL.md +351 -0
  675. package/skills/projection-patterns/SKILL.md +33 -0
  676. package/skills/projection-patterns/resources/implementation-playbook.md +501 -0
  677. package/skills/prometheus-configuration/SKILL.md +404 -0
  678. package/skills/prompt-caching/SKILL.md +61 -0
  679. package/skills/prompt-engineer/SKILL.md +252 -0
  680. package/skills/prompt-engineering/SKILL.md +171 -0
  681. package/skills/prompt-engineering-patterns/SKILL.md +213 -0
  682. package/skills/prompt-library/SKILL.md +322 -0
  683. package/skills/protocol-reverse-engineering/SKILL.md +29 -0
  684. package/skills/protocol-reverse-engineering/resources/implementation-playbook.md +509 -0
  685. package/skills/pypict-skill/SKILL.md +22 -0
  686. package/skills/python-development-python-scaffold/SKILL.md +331 -0
  687. package/skills/python-packaging/SKILL.md +36 -0
  688. package/skills/python-packaging/resources/implementation-playbook.md +869 -0
  689. package/skills/python-patterns/SKILL.md +441 -0
  690. package/skills/python-performance-optimization/SKILL.md +36 -0
  691. package/skills/python-performance-optimization/resources/implementation-playbook.md +868 -0
  692. package/skills/python-pro/SKILL.md +158 -0
  693. package/skills/python-testing-patterns/SKILL.md +37 -0
  694. package/skills/python-testing-patterns/resources/implementation-playbook.md +906 -0
  695. package/skills/quant-analyst/SKILL.md +53 -0
  696. package/skills/radix-ui-design-system/SKILL.md +847 -0
  697. package/skills/rag-engineer/SKILL.md +90 -0
  698. package/skills/rag-implementation/SKILL.md +421 -0
  699. package/skills/react-best-practices/SKILL.md +121 -0
  700. package/skills/react-modernization/SKILL.md +34 -0
  701. package/skills/react-modernization/resources/implementation-playbook.md +512 -0
  702. package/skills/react-native-architecture/SKILL.md +33 -0
  703. package/skills/react-native-architecture/resources/implementation-playbook.md +670 -0
  704. package/skills/react-patterns/SKILL.md +198 -0
  705. package/skills/react-state-management/SKILL.md +441 -0
  706. package/skills/react-ui-patterns/SKILL.md +289 -0
  707. package/skills/readme/SKILL.md +842 -0
  708. package/skills/receiving-code-review/SKILL.md +213 -0
  709. package/skills/red-team-tactics/SKILL.md +199 -0
  710. package/skills/red-team-tools/SKILL.md +310 -0
  711. package/skills/reddit-automation/SKILL.md +212 -0
  712. package/skills/reference-builder/SKILL.md +188 -0
  713. package/skills/referral-program/SKILL.md +602 -0
  714. package/skills/remotion-best-practices/SKILL.md +45 -0
  715. package/skills/render-automation/SKILL.md +181 -0
  716. package/skills/requesting-code-review/SKILL.md +105 -0
  717. package/skills/research-engineer/SKILL.md +135 -0
  718. package/skills/reverse-engineer/SKILL.md +173 -0
  719. package/skills/risk-manager/SKILL.md +61 -0
  720. package/skills/risk-metrics-calculation/SKILL.md +33 -0
  721. package/skills/risk-metrics-calculation/resources/implementation-playbook.md +554 -0
  722. package/skills/ruby-pro/SKILL.md +56 -0
  723. package/skills/rust-async-patterns/SKILL.md +33 -0
  724. package/skills/rust-async-patterns/resources/implementation-playbook.md +516 -0
  725. package/skills/rust-pro/SKILL.md +178 -0
  726. package/skills/saga-orchestration/SKILL.md +496 -0
  727. package/skills/sales-automator/SKILL.md +55 -0
  728. package/skills/salesforce-automation/SKILL.md +190 -0
  729. package/skills/salesforce-development/SKILL.md +51 -0
  730. package/skills/sast-configuration/SKILL.md +212 -0
  731. package/skills/scala-pro/SKILL.md +82 -0
  732. package/skills/scanning-tools/SKILL.md +589 -0
  733. package/skills/schema-markup/SKILL.md +360 -0
  734. package/skills/screen-reader-testing/SKILL.md +33 -0
  735. package/skills/screen-reader-testing/resources/implementation-playbook.md +544 -0
  736. package/skills/screenshots/SKILL.md +401 -0
  737. package/skills/scroll-experience/SKILL.md +263 -0
  738. package/skills/search-specialist/SKILL.md +80 -0
  739. package/skills/secrets-management/SKILL.md +364 -0
  740. package/skills/security-auditor/SKILL.md +169 -0
  741. package/skills/security-bluebook-builder/SKILL.md +22 -0
  742. package/skills/security-compliance-compliance-check/SKILL.md +55 -0
  743. package/skills/security-compliance-compliance-check/resources/implementation-playbook.md +963 -0
  744. package/skills/security-requirement-extraction/SKILL.md +33 -0
  745. package/skills/security-requirement-extraction/resources/implementation-playbook.md +676 -0
  746. package/skills/security-scanning-security-dependencies/SKILL.md +43 -0
  747. package/skills/security-scanning-security-dependencies/resources/implementation-playbook.md +544 -0
  748. package/skills/security-scanning-security-hardening/SKILL.md +147 -0
  749. package/skills/security-scanning-security-sast/SKILL.md +495 -0
  750. package/skills/segment-automation/SKILL.md +225 -0
  751. package/skills/segment-cdp/SKILL.md +50 -0
  752. package/skills/sendgrid-automation/SKILL.md +228 -0
  753. package/skills/senior-architect/SKILL.md +209 -0
  754. package/skills/senior-fullstack/SKILL.md +209 -0
  755. package/skills/sentry-automation/SKILL.md +232 -0
  756. package/skills/seo-audit/SKILL.md +487 -0
  757. package/skills/seo-authority-builder/SKILL.md +136 -0
  758. package/skills/seo-cannibalization-detector/SKILL.md +123 -0
  759. package/skills/seo-content-auditor/SKILL.md +83 -0
  760. package/skills/seo-content-planner/SKILL.md +108 -0
  761. package/skills/seo-content-refresher/SKILL.md +118 -0
  762. package/skills/seo-content-writer/SKILL.md +96 -0
  763. package/skills/seo-fundamentals/SKILL.md +173 -0
  764. package/skills/seo-keyword-strategist/SKILL.md +95 -0
  765. package/skills/seo-meta-optimizer/SKILL.md +92 -0
  766. package/skills/seo-snippet-hunter/SKILL.md +114 -0
  767. package/skills/seo-structure-architect/SKILL.md +108 -0
  768. package/skills/server-management/SKILL.md +161 -0
  769. package/skills/service-mesh-expert/SKILL.md +58 -0
  770. package/skills/service-mesh-observability/SKILL.md +395 -0
  771. package/skills/sharp-edges/SKILL.md +70 -0
  772. package/skills/shellcheck-configuration/SKILL.md +466 -0
  773. package/skills/shodan-reconnaissance/SKILL.md +503 -0
  774. package/skills/shopify-apps/SKILL.md +42 -0
  775. package/skills/shopify-automation/SKILL.md +168 -0
  776. package/skills/shopify-development/SKILL.md +366 -0
  777. package/skills/signup-flow-cro/SKILL.md +355 -0
  778. package/skills/similarity-search-patterns/SKILL.md +33 -0
  779. package/skills/similarity-search-patterns/resources/implementation-playbook.md +557 -0
  780. package/skills/skill-creator/LICENSE.txt +202 -0
  781. package/skills/skill-creator/SKILL.md +357 -0
  782. package/skills/skill-creator/resources/output-patterns.md +82 -0
  783. package/skills/skill-creator/resources/workflows.md +28 -0
  784. package/skills/skill-creator/scripts/init_skill.py +303 -0
  785. package/skills/skill-creator/scripts/package_skill.py +110 -0
  786. package/skills/skill-creator/scripts/quick_validate.py +103 -0
  787. package/skills/skill-developer/SKILL.md +426 -0
  788. package/skills/skill-rails-upgrade/SKILL.md +408 -0
  789. package/skills/skill-seekers/SKILL.md +22 -0
  790. package/skills/slack-automation/SKILL.md +189 -0
  791. package/skills/slack-bot-builder/SKILL.md +264 -0
  792. package/skills/slack-gif-creator/LICENSE.txt +202 -0
  793. package/skills/slack-gif-creator/SKILL.md +254 -0
  794. package/skills/slack-gif-creator/core/easing.py +234 -0
  795. package/skills/slack-gif-creator/core/frame_composer.py +176 -0
  796. package/skills/slack-gif-creator/core/gif_builder.py +269 -0
  797. package/skills/slack-gif-creator/core/validators.py +136 -0
  798. package/skills/slack-gif-creator/requirements.txt +4 -0
  799. package/skills/slo-implementation/SKILL.md +341 -0
  800. package/skills/smtp-penetration-testing/SKILL.md +500 -0
  801. package/skills/social-content/SKILL.md +807 -0
  802. package/skills/software-architecture/SKILL.md +75 -0
  803. package/skills/solidity-security/SKILL.md +34 -0
  804. package/skills/solidity-security/resources/implementation-playbook.md +524 -0
  805. package/skills/spark-optimization/SKILL.md +427 -0
  806. package/skills/sql-injection-testing/SKILL.md +448 -0
  807. package/skills/sql-optimization-patterns/SKILL.md +35 -0
  808. package/skills/sql-optimization-patterns/resources/implementation-playbook.md +504 -0
  809. package/skills/sql-pro/SKILL.md +173 -0
  810. package/skills/sqlmap-database-pentesting/SKILL.md +400 -0
  811. package/skills/square-automation/SKILL.md +176 -0
  812. package/skills/ssh-penetration-testing/SKILL.md +488 -0
  813. package/skills/startup-analyst/SKILL.md +328 -0
  814. package/skills/startup-business-analyst-business-case/SKILL.md +487 -0
  815. package/skills/startup-business-analyst-financial-projections/SKILL.md +353 -0
  816. package/skills/startup-business-analyst-market-opportunity/SKILL.md +240 -0
  817. package/skills/startup-financial-modeling/SKILL.md +467 -0
  818. package/skills/startup-metrics-framework/SKILL.md +34 -0
  819. package/skills/startup-metrics-framework/resources/implementation-playbook.md +500 -0
  820. package/skills/stitch-ui-design/SKILL.md +378 -0
  821. package/skills/stride-analysis-patterns/SKILL.md +33 -0
  822. package/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
  823. package/skills/stripe-automation/SKILL.md +198 -0
  824. package/skills/stripe-integration/SKILL.md +454 -0
  825. package/skills/subagent-driven-development/SKILL.md +240 -0
  826. package/skills/supabase-automation/SKILL.md +236 -0
  827. package/skills/superpowers-lab/SKILL.md +22 -0
  828. package/skills/swiftui-expert-skill/SKILL.md +275 -0
  829. package/skills/systematic-debugging/SKILL.md +296 -0
  830. package/skills/systems-programming-rust-project/SKILL.md +440 -0
  831. package/skills/tailwind-design-system/SKILL.md +33 -0
  832. package/skills/tailwind-design-system/resources/implementation-playbook.md +665 -0
  833. package/skills/tailwind-patterns/SKILL.md +269 -0
  834. package/skills/tavily-web/SKILL.md +36 -0
  835. package/skills/tdd-orchestrator/SKILL.md +205 -0
  836. package/skills/tdd-workflow/SKILL.md +149 -0
  837. package/skills/tdd-workflows-tdd-cycle/SKILL.md +221 -0
  838. package/skills/tdd-workflows-tdd-green/SKILL.md +73 -0
  839. package/skills/tdd-workflows-tdd-green/resources/implementation-playbook.md +870 -0
  840. package/skills/tdd-workflows-tdd-red/SKILL.md +164 -0
  841. package/skills/tdd-workflows-tdd-refactor/SKILL.md +187 -0
  842. package/skills/team-collaboration-issue/SKILL.md +37 -0
  843. package/skills/team-collaboration-issue/resources/implementation-playbook.md +640 -0
  844. package/skills/team-collaboration-standup-notes/SKILL.md +44 -0
  845. package/skills/team-collaboration-standup-notes/resources/implementation-playbook.md +768 -0
  846. package/skills/team-composition-analysis/SKILL.md +413 -0
  847. package/skills/telegram-automation/SKILL.md +219 -0
  848. package/skills/telegram-bot-builder/SKILL.md +254 -0
  849. package/skills/telegram-mini-app/SKILL.md +279 -0
  850. package/skills/temporal-python-pro/SKILL.md +370 -0
  851. package/skills/temporal-python-testing/SKILL.md +170 -0
  852. package/skills/temporal-python-testing/resources/integration-testing.md +455 -0
  853. package/skills/temporal-python-testing/resources/local-setup.md +553 -0
  854. package/skills/temporal-python-testing/resources/replay-testing.md +462 -0
  855. package/skills/temporal-python-testing/resources/unit-testing.md +328 -0
  856. package/skills/terraform-module-library/SKILL.md +261 -0
  857. package/skills/terraform-skill/SKILL.md +517 -0
  858. package/skills/terraform-specialist/SKILL.md +166 -0
  859. package/skills/test-automator/SKILL.md +224 -0
  860. package/skills/test-driven-development/SKILL.md +371 -0
  861. package/skills/test-fixing/SKILL.md +119 -0
  862. package/skills/testing-patterns/SKILL.md +259 -0
  863. package/skills/theme-factory/LICENSE.txt +202 -0
  864. package/skills/theme-factory/SKILL.md +59 -0
  865. package/skills/theme-factory/theme-showcase.pdf +0 -0
  866. package/skills/theme-factory/themes/arctic-frost.md +19 -0
  867. package/skills/theme-factory/themes/botanical-garden.md +19 -0
  868. package/skills/theme-factory/themes/desert-rose.md +19 -0
  869. package/skills/theme-factory/themes/forest-canopy.md +19 -0
  870. package/skills/theme-factory/themes/golden-hour.md +19 -0
  871. package/skills/theme-factory/themes/midnight-galaxy.md +19 -0
  872. package/skills/theme-factory/themes/modern-minimalist.md +19 -0
  873. package/skills/theme-factory/themes/ocean-depths.md +19 -0
  874. package/skills/theme-factory/themes/sunset-boulevard.md +19 -0
  875. package/skills/theme-factory/themes/tech-innovation.md +19 -0
  876. package/skills/threat-mitigation-mapping/SKILL.md +33 -0
  877. package/skills/threat-mitigation-mapping/resources/implementation-playbook.md +744 -0
  878. package/skills/threat-modeling-expert/SKILL.md +60 -0
  879. package/skills/threejs-skills/SKILL.md +22 -0
  880. package/skills/tiktok-automation/SKILL.md +178 -0
  881. package/skills/todoist-automation/SKILL.md +231 -0
  882. package/skills/tool-design/SKILL.md +318 -0
  883. package/skills/top-web-vulnerabilities/SKILL.md +543 -0
  884. package/skills/track-management/SKILL.md +38 -0
  885. package/skills/track-management/resources/implementation-playbook.md +591 -0
  886. package/skills/trello-automation/SKILL.md +181 -0
  887. package/skills/trigger-dev/SKILL.md +67 -0
  888. package/skills/turborepo-caching/SKILL.md +419 -0
  889. package/skills/tutorial-engineer/SKILL.md +139 -0
  890. package/skills/twilio-communications/SKILL.md +295 -0
  891. package/skills/twitter-automation/SKILL.md +231 -0
  892. package/skills/typescript-advanced-types/SKILL.md +35 -0
  893. package/skills/typescript-advanced-types/resources/implementation-playbook.md +716 -0
  894. package/skills/typescript-expert/SKILL.md +429 -0
  895. package/skills/typescript-pro/SKILL.md +55 -0
  896. package/skills/ui-skills/SKILL.md +22 -0
  897. package/skills/ui-ux-designer/SKILL.md +209 -0
  898. package/skills/ui-ux-pro-max/SKILL.md +351 -0
  899. package/skills/ui-visual-validator/SKILL.md +214 -0
  900. package/skills/unit-testing-test-generate/SKILL.md +319 -0
  901. package/skills/unity-developer/SKILL.md +230 -0
  902. package/skills/unity-ecs-patterns/SKILL.md +33 -0
  903. package/skills/unity-ecs-patterns/resources/implementation-playbook.md +625 -0
  904. package/skills/unreal-engine-cpp-pro/SKILL.md +114 -0
  905. package/skills/upgrading-expo/SKILL.md +118 -0
  906. package/skills/upstash-qstash/SKILL.md +68 -0
  907. package/skills/using-git-worktrees/SKILL.md +217 -0
  908. package/skills/using-neon/SKILL.md +84 -0
  909. package/skills/using-superpowers/SKILL.md +87 -0
  910. package/skills/uv-package-manager/SKILL.md +37 -0
  911. package/skills/uv-package-manager/resources/implementation-playbook.md +830 -0
  912. package/skills/varlock-claude-skill/SKILL.md +22 -0
  913. package/skills/vector-database-engineer/SKILL.md +60 -0
  914. package/skills/vector-index-tuning/SKILL.md +42 -0
  915. package/skills/vector-index-tuning/resources/implementation-playbook.md +507 -0
  916. package/skills/vercel-automation/SKILL.md +226 -0
  917. package/skills/vercel-deploy-claimable/SKILL.md +123 -0
  918. package/skills/vercel-deployment/SKILL.md +79 -0
  919. package/skills/verification-before-completion/SKILL.md +139 -0
  920. package/skills/vexor/SKILL.md +22 -0
  921. package/skills/viral-generator-builder/SKILL.md +199 -0
  922. package/skills/voice-agents/SKILL.md +68 -0
  923. package/skills/voice-ai-development/SKILL.md +302 -0
  924. package/skills/voice-ai-engine-development/SKILL.md +721 -0
  925. package/skills/vulnerability-scanner/SKILL.md +276 -0
  926. package/skills/wcag-audit-patterns/SKILL.md +41 -0
  927. package/skills/wcag-audit-patterns/resources/implementation-playbook.md +541 -0
  928. package/skills/web-artifacts-builder/LICENSE.txt +202 -0
  929. package/skills/web-artifacts-builder/SKILL.md +74 -0
  930. package/skills/web-artifacts-builder/scripts/bundle-artifact.sh +54 -0
  931. package/skills/web-artifacts-builder/scripts/init-artifact.sh +322 -0
  932. package/skills/web-artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  933. package/skills/web-design-guidelines/SKILL.md +36 -0
  934. package/skills/web-performance-optimization/SKILL.md +646 -0
  935. package/skills/web3-testing/SKILL.md +427 -0
  936. package/skills/webapp-testing/LICENSE.txt +202 -0
  937. package/skills/webapp-testing/SKILL.md +96 -0
  938. package/skills/webapp-testing/examples/console_logging.py +35 -0
  939. package/skills/webapp-testing/examples/element_discovery.py +40 -0
  940. package/skills/webapp-testing/examples/static_html_automation.py +33 -0
  941. package/skills/webapp-testing/scripts/with_server.py +106 -0
  942. package/skills/webflow-automation/SKILL.md +236 -0
  943. package/skills/whatsapp-automation/SKILL.md +214 -0
  944. package/skills/windows-privilege-escalation/SKILL.md +496 -0
  945. package/skills/wireshark-analysis/SKILL.md +497 -0
  946. package/skills/wordpress-penetration-testing/SKILL.md +485 -0
  947. package/skills/workflow-automation/SKILL.md +68 -0
  948. package/skills/workflow-orchestration-patterns/SKILL.md +333 -0
  949. package/skills/workflow-patterns/SKILL.md +38 -0
  950. package/skills/workflow-patterns/resources/implementation-playbook.md +621 -0
  951. package/skills/wrike-automation/SKILL.md +233 -0
  952. package/skills/writing-plans/SKILL.md +116 -0
  953. package/skills/writing-skills/SKILL.md +125 -0
  954. package/skills/x-article-publisher-skill/SKILL.md +22 -0
  955. package/skills/xss-html-injection/SKILL.md +499 -0
  956. package/skills/youtube-automation/SKILL.md +218 -0
  957. package/skills/youtube-summarizer/SKILL.md +411 -0
  958. package/skills/zapier-make-patterns/SKILL.md +67 -0
  959. package/skills/zendesk-automation/SKILL.md +215 -0
  960. package/skills/zoho-crm-automation/SKILL.md +206 -0
  961. package/skills/zoom-automation/SKILL.md +217 -0
  962. package/src/dedup.ts +132 -0
  963. package/src/index.ts +26 -0
  964. package/src/loader.ts +33 -0
  965. package/src/search.ts +83 -0
  966. package/src/server.ts +83 -0
  967. package/src/skill-index.ts +105 -0
  968. package/src/types.ts +28 -0
  969. package/test/dedup.test.ts +33 -0
  970. package/test/fixtures/allowed-tools/SKILL.md +9 -0
  971. package/test/fixtures/basic-skill/SKILL.md +11 -0
  972. package/test/fixtures/empty-description/SKILL.md +7 -0
  973. package/test/fixtures/invalid-frontmatter/SKILL.md +7 -0
  974. package/test/fixtures/multiline-description/SKILL.md +11 -0
  975. package/test/fixtures/no-frontmatter/SKILL.md +3 -0
  976. package/test/fixtures/skill-with-hyphenated-resources/SKILL.md +8 -0
  977. package/test/fixtures/skill-with-hyphenated-resources/resources/implementation-playbook.md +3 -0
  978. package/test/fixtures/skill-with-hyphenated-resources/resources/quick-start-guide.md +3 -0
  979. package/test/fixtures/skill-with-resources/SKILL.md +8 -0
  980. package/test/fixtures/skill-with-resources/resources/examples.md +3 -0
  981. package/test/fixtures/skill-with-resources/resources/guide.md +3 -0
  982. package/test/integration.test.ts +148 -0
  983. package/test/loader.test.ts +78 -0
  984. package/test/search.test.ts +135 -0
  985. package/test/server.test.ts +94 -0
  986. package/test/skill-index.test.ts +144 -0
  987. package/tsconfig.json +15 -0
  988. package/tsup.config.ts +12 -0
  989. package/vitest.config.ts +5 -0
@@ -0,0 +1,1019 @@
1
+ # Node.js Backend Patterns Implementation Playbook
2
+
3
+ This file contains detailed patterns, checklists, and code samples referenced by the skill.
4
+
5
+ # Node.js Backend Patterns
6
+
7
+ Comprehensive guidance for building scalable, maintainable, and production-ready Node.js backend applications with modern frameworks, architectural patterns, and best practices.
8
+
9
+ ## When to Use This Skill
10
+
11
+ - Building REST APIs or GraphQL servers
12
+ - Creating microservices with Node.js
13
+ - Implementing authentication and authorization
14
+ - Designing scalable backend architectures
15
+ - Setting up middleware and error handling
16
+ - Integrating databases (SQL and NoSQL)
17
+ - Building real-time applications with WebSockets
18
+ - Implementing background job processing
19
+
20
+ ## Core Frameworks
21
+
22
+ ### Express.js - Minimalist Framework
23
+
24
+ **Basic Setup:**
25
+ ```typescript
26
+ import express, { Request, Response, NextFunction } from 'express';
27
+ import helmet from 'helmet';
28
+ import cors from 'cors';
29
+ import compression from 'compression';
30
+
31
+ const app = express();
32
+
33
+ // Security middleware
34
+ app.use(helmet());
35
+ app.use(cors({ origin: process.env.ALLOWED_ORIGINS?.split(',') }));
36
+ app.use(compression());
37
+
38
+ // Body parsing
39
+ app.use(express.json({ limit: '10mb' }));
40
+ app.use(express.urlencoded({ extended: true, limit: '10mb' }));
41
+
42
+ // Request logging
43
+ app.use((req: Request, res: Response, next: NextFunction) => {
44
+ console.log(`${req.method} ${req.path}`);
45
+ next();
46
+ });
47
+
48
+ const PORT = process.env.PORT || 3000;
49
+ app.listen(PORT, () => {
50
+ console.log(`Server running on port ${PORT}`);
51
+ });
52
+ ```
53
+
54
+ ### Fastify - High Performance Framework
55
+
56
+ **Basic Setup:**
57
+ ```typescript
58
+ import Fastify from 'fastify';
59
+ import helmet from '@fastify/helmet';
60
+ import cors from '@fastify/cors';
61
+ import compress from '@fastify/compress';
62
+
63
+ const fastify = Fastify({
64
+ logger: {
65
+ level: process.env.LOG_LEVEL || 'info',
66
+ transport: {
67
+ target: 'pino-pretty',
68
+ options: { colorize: true }
69
+ }
70
+ }
71
+ });
72
+
73
+ // Plugins
74
+ await fastify.register(helmet);
75
+ await fastify.register(cors, { origin: true });
76
+ await fastify.register(compress);
77
+
78
+ // Type-safe routes with schema validation
79
+ fastify.post<{
80
+ Body: { name: string; email: string };
81
+ Reply: { id: string; name: string };
82
+ }>('/users', {
83
+ schema: {
84
+ body: {
85
+ type: 'object',
86
+ required: ['name', 'email'],
87
+ properties: {
88
+ name: { type: 'string', minLength: 1 },
89
+ email: { type: 'string', format: 'email' }
90
+ }
91
+ }
92
+ }
93
+ }, async (request, reply) => {
94
+ const { name, email } = request.body;
95
+ return { id: '123', name };
96
+ });
97
+
98
+ await fastify.listen({ port: 3000, host: '0.0.0.0' });
99
+ ```
100
+
101
+ ## Architectural Patterns
102
+
103
+ ### Pattern 1: Layered Architecture
104
+
105
+ **Structure:**
106
+ ```
107
+ src/
108
+ ├── controllers/ # Handle HTTP requests/responses
109
+ ├── services/ # Business logic
110
+ ├── repositories/ # Data access layer
111
+ ├── models/ # Data models
112
+ ├── middleware/ # Express/Fastify middleware
113
+ ├── routes/ # Route definitions
114
+ ├── utils/ # Helper functions
115
+ ├── config/ # Configuration
116
+ └── types/ # TypeScript types
117
+ ```
118
+
119
+ **Controller Layer:**
120
+ ```typescript
121
+ // controllers/user.controller.ts
122
+ import { Request, Response, NextFunction } from 'express';
123
+ import { UserService } from '../services/user.service';
124
+ import { CreateUserDTO, UpdateUserDTO } from '../types/user.types';
125
+
126
+ export class UserController {
127
+ constructor(private userService: UserService) {}
128
+
129
+ async createUser(req: Request, res: Response, next: NextFunction) {
130
+ try {
131
+ const userData: CreateUserDTO = req.body;
132
+ const user = await this.userService.createUser(userData);
133
+ res.status(201).json(user);
134
+ } catch (error) {
135
+ next(error);
136
+ }
137
+ }
138
+
139
+ async getUser(req: Request, res: Response, next: NextFunction) {
140
+ try {
141
+ const { id } = req.params;
142
+ const user = await this.userService.getUserById(id);
143
+ res.json(user);
144
+ } catch (error) {
145
+ next(error);
146
+ }
147
+ }
148
+
149
+ async updateUser(req: Request, res: Response, next: NextFunction) {
150
+ try {
151
+ const { id } = req.params;
152
+ const updates: UpdateUserDTO = req.body;
153
+ const user = await this.userService.updateUser(id, updates);
154
+ res.json(user);
155
+ } catch (error) {
156
+ next(error);
157
+ }
158
+ }
159
+
160
+ async deleteUser(req: Request, res: Response, next: NextFunction) {
161
+ try {
162
+ const { id } = req.params;
163
+ await this.userService.deleteUser(id);
164
+ res.status(204).send();
165
+ } catch (error) {
166
+ next(error);
167
+ }
168
+ }
169
+ }
170
+ ```
171
+
172
+ **Service Layer:**
173
+ ```typescript
174
+ // services/user.service.ts
175
+ import { UserRepository } from '../repositories/user.repository';
176
+ import { CreateUserDTO, UpdateUserDTO, User } from '../types/user.types';
177
+ import { NotFoundError, ValidationError } from '../utils/errors';
178
+ import bcrypt from 'bcrypt';
179
+
180
+ export class UserService {
181
+ constructor(private userRepository: UserRepository) {}
182
+
183
+ async createUser(userData: CreateUserDTO): Promise<User> {
184
+ // Validation
185
+ const existingUser = await this.userRepository.findByEmail(userData.email);
186
+ if (existingUser) {
187
+ throw new ValidationError('Email already exists');
188
+ }
189
+
190
+ // Hash password
191
+ const hashedPassword = await bcrypt.hash(userData.password, 10);
192
+
193
+ // Create user
194
+ const user = await this.userRepository.create({
195
+ ...userData,
196
+ password: hashedPassword
197
+ });
198
+
199
+ // Remove password from response
200
+ const { password, ...userWithoutPassword } = user;
201
+ return userWithoutPassword as User;
202
+ }
203
+
204
+ async getUserById(id: string): Promise<User> {
205
+ const user = await this.userRepository.findById(id);
206
+ if (!user) {
207
+ throw new NotFoundError('User not found');
208
+ }
209
+ const { password, ...userWithoutPassword } = user;
210
+ return userWithoutPassword as User;
211
+ }
212
+
213
+ async updateUser(id: string, updates: UpdateUserDTO): Promise<User> {
214
+ const user = await this.userRepository.update(id, updates);
215
+ if (!user) {
216
+ throw new NotFoundError('User not found');
217
+ }
218
+ const { password, ...userWithoutPassword } = user;
219
+ return userWithoutPassword as User;
220
+ }
221
+
222
+ async deleteUser(id: string): Promise<void> {
223
+ const deleted = await this.userRepository.delete(id);
224
+ if (!deleted) {
225
+ throw new NotFoundError('User not found');
226
+ }
227
+ }
228
+ }
229
+ ```
230
+
231
+ **Repository Layer:**
232
+ ```typescript
233
+ // repositories/user.repository.ts
234
+ import { Pool } from 'pg';
235
+ import { CreateUserDTO, UpdateUserDTO, UserEntity } from '../types/user.types';
236
+
237
+ export class UserRepository {
238
+ constructor(private db: Pool) {}
239
+
240
+ async create(userData: CreateUserDTO & { password: string }): Promise<UserEntity> {
241
+ const query = `
242
+ INSERT INTO users (name, email, password)
243
+ VALUES ($1, $2, $3)
244
+ RETURNING id, name, email, password, created_at, updated_at
245
+ `;
246
+ const { rows } = await this.db.query(query, [
247
+ userData.name,
248
+ userData.email,
249
+ userData.password
250
+ ]);
251
+ return rows[0];
252
+ }
253
+
254
+ async findById(id: string): Promise<UserEntity | null> {
255
+ const query = 'SELECT * FROM users WHERE id = $1';
256
+ const { rows } = await this.db.query(query, [id]);
257
+ return rows[0] || null;
258
+ }
259
+
260
+ async findByEmail(email: string): Promise<UserEntity | null> {
261
+ const query = 'SELECT * FROM users WHERE email = $1';
262
+ const { rows } = await this.db.query(query, [email]);
263
+ return rows[0] || null;
264
+ }
265
+
266
+ async update(id: string, updates: UpdateUserDTO): Promise<UserEntity | null> {
267
+ const fields = Object.keys(updates);
268
+ const values = Object.values(updates);
269
+
270
+ const setClause = fields
271
+ .map((field, idx) => `${field} = $${idx + 2}`)
272
+ .join(', ');
273
+
274
+ const query = `
275
+ UPDATE users
276
+ SET ${setClause}, updated_at = CURRENT_TIMESTAMP
277
+ WHERE id = $1
278
+ RETURNING *
279
+ `;
280
+
281
+ const { rows } = await this.db.query(query, [id, ...values]);
282
+ return rows[0] || null;
283
+ }
284
+
285
+ async delete(id: string): Promise<boolean> {
286
+ const query = 'DELETE FROM users WHERE id = $1';
287
+ const { rowCount } = await this.db.query(query, [id]);
288
+ return rowCount > 0;
289
+ }
290
+ }
291
+ ```
292
+
293
+ ### Pattern 2: Dependency Injection
294
+
295
+ **DI Container:**
296
+ ```typescript
297
+ // di-container.ts
298
+ import { Pool } from 'pg';
299
+ import { UserRepository } from './repositories/user.repository';
300
+ import { UserService } from './services/user.service';
301
+ import { UserController } from './controllers/user.controller';
302
+ import { AuthService } from './services/auth.service';
303
+
304
+ class Container {
305
+ private instances = new Map<string, any>();
306
+
307
+ register<T>(key: string, factory: () => T): void {
308
+ this.instances.set(key, factory);
309
+ }
310
+
311
+ resolve<T>(key: string): T {
312
+ const factory = this.instances.get(key);
313
+ if (!factory) {
314
+ throw new Error(`No factory registered for ${key}`);
315
+ }
316
+ return factory();
317
+ }
318
+
319
+ singleton<T>(key: string, factory: () => T): void {
320
+ let instance: T;
321
+ this.instances.set(key, () => {
322
+ if (!instance) {
323
+ instance = factory();
324
+ }
325
+ return instance;
326
+ });
327
+ }
328
+ }
329
+
330
+ export const container = new Container();
331
+
332
+ // Register dependencies
333
+ container.singleton('db', () => new Pool({
334
+ host: process.env.DB_HOST,
335
+ port: parseInt(process.env.DB_PORT || '5432'),
336
+ database: process.env.DB_NAME,
337
+ user: process.env.DB_USER,
338
+ password: process.env.DB_PASSWORD,
339
+ max: 20,
340
+ idleTimeoutMillis: 30000,
341
+ connectionTimeoutMillis: 2000,
342
+ }));
343
+
344
+ container.singleton('userRepository', () =>
345
+ new UserRepository(container.resolve('db'))
346
+ );
347
+
348
+ container.singleton('userService', () =>
349
+ new UserService(container.resolve('userRepository'))
350
+ );
351
+
352
+ container.register('userController', () =>
353
+ new UserController(container.resolve('userService'))
354
+ );
355
+
356
+ container.singleton('authService', () =>
357
+ new AuthService(container.resolve('userRepository'))
358
+ );
359
+ ```
360
+
361
+ ## Middleware Patterns
362
+
363
+ ### Authentication Middleware
364
+
365
+ ```typescript
366
+ // middleware/auth.middleware.ts
367
+ import { Request, Response, NextFunction } from 'express';
368
+ import jwt from 'jsonwebtoken';
369
+ import { UnauthorizedError } from '../utils/errors';
370
+
371
+ interface JWTPayload {
372
+ userId: string;
373
+ email: string;
374
+ }
375
+
376
+ declare global {
377
+ namespace Express {
378
+ interface Request {
379
+ user?: JWTPayload;
380
+ }
381
+ }
382
+ }
383
+
384
+ export const authenticate = async (
385
+ req: Request,
386
+ res: Response,
387
+ next: NextFunction
388
+ ) => {
389
+ try {
390
+ const token = req.headers.authorization?.replace('Bearer ', '');
391
+
392
+ if (!token) {
393
+ throw new UnauthorizedError('No token provided');
394
+ }
395
+
396
+ const payload = jwt.verify(
397
+ token,
398
+ process.env.JWT_SECRET!
399
+ ) as JWTPayload;
400
+
401
+ req.user = payload;
402
+ next();
403
+ } catch (error) {
404
+ next(new UnauthorizedError('Invalid token'));
405
+ }
406
+ };
407
+
408
+ export const authorize = (...roles: string[]) => {
409
+ return async (req: Request, res: Response, next: NextFunction) => {
410
+ if (!req.user) {
411
+ return next(new UnauthorizedError('Not authenticated'));
412
+ }
413
+
414
+ // Check if user has required role
415
+ const hasRole = roles.some(role =>
416
+ req.user?.roles?.includes(role)
417
+ );
418
+
419
+ if (!hasRole) {
420
+ return next(new UnauthorizedError('Insufficient permissions'));
421
+ }
422
+
423
+ next();
424
+ };
425
+ };
426
+ ```
427
+
428
+ ### Validation Middleware
429
+
430
+ ```typescript
431
+ // middleware/validation.middleware.ts
432
+ import { Request, Response, NextFunction } from 'express';
433
+ import { AnyZodObject, ZodError } from 'zod';
434
+ import { ValidationError } from '../utils/errors';
435
+
436
+ export const validate = (schema: AnyZodObject) => {
437
+ return async (req: Request, res: Response, next: NextFunction) => {
438
+ try {
439
+ await schema.parseAsync({
440
+ body: req.body,
441
+ query: req.query,
442
+ params: req.params
443
+ });
444
+ next();
445
+ } catch (error) {
446
+ if (error instanceof ZodError) {
447
+ const errors = error.errors.map(err => ({
448
+ field: err.path.join('.'),
449
+ message: err.message
450
+ }));
451
+ next(new ValidationError('Validation failed', errors));
452
+ } else {
453
+ next(error);
454
+ }
455
+ }
456
+ };
457
+ };
458
+
459
+ // Usage with Zod
460
+ import { z } from 'zod';
461
+
462
+ const createUserSchema = z.object({
463
+ body: z.object({
464
+ name: z.string().min(1),
465
+ email: z.string().email(),
466
+ password: z.string().min(8)
467
+ })
468
+ });
469
+
470
+ router.post('/users', validate(createUserSchema), userController.createUser);
471
+ ```
472
+
473
+ ### Rate Limiting Middleware
474
+
475
+ ```typescript
476
+ // middleware/rate-limit.middleware.ts
477
+ import rateLimit from 'express-rate-limit';
478
+ import RedisStore from 'rate-limit-redis';
479
+ import Redis from 'ioredis';
480
+
481
+ const redis = new Redis({
482
+ host: process.env.REDIS_HOST,
483
+ port: parseInt(process.env.REDIS_PORT || '6379')
484
+ });
485
+
486
+ export const apiLimiter = rateLimit({
487
+ store: new RedisStore({
488
+ client: redis,
489
+ prefix: 'rl:',
490
+ }),
491
+ windowMs: 15 * 60 * 1000, // 15 minutes
492
+ max: 100, // Limit each IP to 100 requests per windowMs
493
+ message: 'Too many requests from this IP, please try again later',
494
+ standardHeaders: true,
495
+ legacyHeaders: false,
496
+ });
497
+
498
+ export const authLimiter = rateLimit({
499
+ store: new RedisStore({
500
+ client: redis,
501
+ prefix: 'rl:auth:',
502
+ }),
503
+ windowMs: 15 * 60 * 1000,
504
+ max: 5, // Stricter limit for auth endpoints
505
+ skipSuccessfulRequests: true,
506
+ });
507
+ ```
508
+
509
+ ### Request Logging Middleware
510
+
511
+ ```typescript
512
+ // middleware/logger.middleware.ts
513
+ import { Request, Response, NextFunction } from 'express';
514
+ import pino from 'pino';
515
+
516
+ const logger = pino({
517
+ level: process.env.LOG_LEVEL || 'info',
518
+ transport: {
519
+ target: 'pino-pretty',
520
+ options: { colorize: true }
521
+ }
522
+ });
523
+
524
+ export const requestLogger = (
525
+ req: Request,
526
+ res: Response,
527
+ next: NextFunction
528
+ ) => {
529
+ const start = Date.now();
530
+
531
+ // Log response when finished
532
+ res.on('finish', () => {
533
+ const duration = Date.now() - start;
534
+ logger.info({
535
+ method: req.method,
536
+ url: req.url,
537
+ status: res.statusCode,
538
+ duration: `${duration}ms`,
539
+ userAgent: req.headers['user-agent'],
540
+ ip: req.ip
541
+ });
542
+ });
543
+
544
+ next();
545
+ };
546
+
547
+ export { logger };
548
+ ```
549
+
550
+ ## Error Handling
551
+
552
+ ### Custom Error Classes
553
+
554
+ ```typescript
555
+ // utils/errors.ts
556
+ export class AppError extends Error {
557
+ constructor(
558
+ public message: string,
559
+ public statusCode: number = 500,
560
+ public isOperational: boolean = true
561
+ ) {
562
+ super(message);
563
+ Object.setPrototypeOf(this, AppError.prototype);
564
+ Error.captureStackTrace(this, this.constructor);
565
+ }
566
+ }
567
+
568
+ export class ValidationError extends AppError {
569
+ constructor(message: string, public errors?: any[]) {
570
+ super(message, 400);
571
+ }
572
+ }
573
+
574
+ export class NotFoundError extends AppError {
575
+ constructor(message: string = 'Resource not found') {
576
+ super(message, 404);
577
+ }
578
+ }
579
+
580
+ export class UnauthorizedError extends AppError {
581
+ constructor(message: string = 'Unauthorized') {
582
+ super(message, 401);
583
+ }
584
+ }
585
+
586
+ export class ForbiddenError extends AppError {
587
+ constructor(message: string = 'Forbidden') {
588
+ super(message, 403);
589
+ }
590
+ }
591
+
592
+ export class ConflictError extends AppError {
593
+ constructor(message: string) {
594
+ super(message, 409);
595
+ }
596
+ }
597
+ ```
598
+
599
+ ### Global Error Handler
600
+
601
+ ```typescript
602
+ // middleware/error-handler.ts
603
+ import { Request, Response, NextFunction } from 'express';
604
+ import { AppError } from '../utils/errors';
605
+ import { logger } from './logger.middleware';
606
+
607
+ export const errorHandler = (
608
+ err: Error,
609
+ req: Request,
610
+ res: Response,
611
+ next: NextFunction
612
+ ) => {
613
+ if (err instanceof AppError) {
614
+ return res.status(err.statusCode).json({
615
+ status: 'error',
616
+ message: err.message,
617
+ ...(err instanceof ValidationError && { errors: err.errors })
618
+ });
619
+ }
620
+
621
+ // Log unexpected errors
622
+ logger.error({
623
+ error: err.message,
624
+ stack: err.stack,
625
+ url: req.url,
626
+ method: req.method
627
+ });
628
+
629
+ // Don't leak error details in production
630
+ const message = process.env.NODE_ENV === 'production'
631
+ ? 'Internal server error'
632
+ : err.message;
633
+
634
+ res.status(500).json({
635
+ status: 'error',
636
+ message
637
+ });
638
+ };
639
+
640
+ // Async error wrapper
641
+ export const asyncHandler = (
642
+ fn: (req: Request, res: Response, next: NextFunction) => Promise<any>
643
+ ) => {
644
+ return (req: Request, res: Response, next: NextFunction) => {
645
+ Promise.resolve(fn(req, res, next)).catch(next);
646
+ };
647
+ };
648
+ ```
649
+
650
+ ## Database Patterns
651
+
652
+ ### PostgreSQL with Connection Pool
653
+
654
+ ```typescript
655
+ // config/database.ts
656
+ import { Pool, PoolConfig } from 'pg';
657
+
658
+ const poolConfig: PoolConfig = {
659
+ host: process.env.DB_HOST,
660
+ port: parseInt(process.env.DB_PORT || '5432'),
661
+ database: process.env.DB_NAME,
662
+ user: process.env.DB_USER,
663
+ password: process.env.DB_PASSWORD,
664
+ max: 20,
665
+ idleTimeoutMillis: 30000,
666
+ connectionTimeoutMillis: 2000,
667
+ };
668
+
669
+ export const pool = new Pool(poolConfig);
670
+
671
+ // Test connection
672
+ pool.on('connect', () => {
673
+ console.log('Database connected');
674
+ });
675
+
676
+ pool.on('error', (err) => {
677
+ console.error('Unexpected database error', err);
678
+ process.exit(-1);
679
+ });
680
+
681
+ // Graceful shutdown
682
+ export const closeDatabase = async () => {
683
+ await pool.end();
684
+ console.log('Database connection closed');
685
+ };
686
+ ```
687
+
688
+ ### MongoDB with Mongoose
689
+
690
+ ```typescript
691
+ // config/mongoose.ts
692
+ import mongoose from 'mongoose';
693
+
694
+ const connectDB = async () => {
695
+ try {
696
+ await mongoose.connect(process.env.MONGODB_URI!, {
697
+ maxPoolSize: 10,
698
+ serverSelectionTimeoutMS: 5000,
699
+ socketTimeoutMS: 45000,
700
+ });
701
+
702
+ console.log('MongoDB connected');
703
+ } catch (error) {
704
+ console.error('MongoDB connection error:', error);
705
+ process.exit(1);
706
+ }
707
+ };
708
+
709
+ mongoose.connection.on('disconnected', () => {
710
+ console.log('MongoDB disconnected');
711
+ });
712
+
713
+ mongoose.connection.on('error', (err) => {
714
+ console.error('MongoDB error:', err);
715
+ });
716
+
717
+ export { connectDB };
718
+
719
+ // Model example
720
+ import { Schema, model, Document } from 'mongoose';
721
+
722
+ interface IUser extends Document {
723
+ name: string;
724
+ email: string;
725
+ password: string;
726
+ createdAt: Date;
727
+ updatedAt: Date;
728
+ }
729
+
730
+ const userSchema = new Schema<IUser>({
731
+ name: { type: String, required: true },
732
+ email: { type: String, required: true, unique: true },
733
+ password: { type: String, required: true },
734
+ }, {
735
+ timestamps: true
736
+ });
737
+
738
+ // Indexes
739
+ userSchema.index({ email: 1 });
740
+
741
+ export const User = model<IUser>('User', userSchema);
742
+ ```
743
+
744
+ ### Transaction Pattern
745
+
746
+ ```typescript
747
+ // services/order.service.ts
748
+ import { Pool } from 'pg';
749
+
750
+ export class OrderService {
751
+ constructor(private db: Pool) {}
752
+
753
+ async createOrder(userId: string, items: any[]) {
754
+ const client = await this.db.connect();
755
+
756
+ try {
757
+ await client.query('BEGIN');
758
+
759
+ // Create order
760
+ const orderResult = await client.query(
761
+ 'INSERT INTO orders (user_id, total) VALUES ($1, $2) RETURNING id',
762
+ [userId, calculateTotal(items)]
763
+ );
764
+ const orderId = orderResult.rows[0].id;
765
+
766
+ // Create order items
767
+ for (const item of items) {
768
+ await client.query(
769
+ 'INSERT INTO order_items (order_id, product_id, quantity, price) VALUES ($1, $2, $3, $4)',
770
+ [orderId, item.productId, item.quantity, item.price]
771
+ );
772
+
773
+ // Update inventory
774
+ await client.query(
775
+ 'UPDATE products SET stock = stock - $1 WHERE id = $2',
776
+ [item.quantity, item.productId]
777
+ );
778
+ }
779
+
780
+ await client.query('COMMIT');
781
+ return orderId;
782
+ } catch (error) {
783
+ await client.query('ROLLBACK');
784
+ throw error;
785
+ } finally {
786
+ client.release();
787
+ }
788
+ }
789
+ }
790
+ ```
791
+
792
+ ## Authentication & Authorization
793
+
794
+ ### JWT Authentication
795
+
796
+ ```typescript
797
+ // services/auth.service.ts
798
+ import jwt from 'jsonwebtoken';
799
+ import bcrypt from 'bcrypt';
800
+ import { UserRepository } from '../repositories/user.repository';
801
+ import { UnauthorizedError } from '../utils/errors';
802
+
803
+ export class AuthService {
804
+ constructor(private userRepository: UserRepository) {}
805
+
806
+ async login(email: string, password: string) {
807
+ const user = await this.userRepository.findByEmail(email);
808
+
809
+ if (!user) {
810
+ throw new UnauthorizedError('Invalid credentials');
811
+ }
812
+
813
+ const isValid = await bcrypt.compare(password, user.password);
814
+
815
+ if (!isValid) {
816
+ throw new UnauthorizedError('Invalid credentials');
817
+ }
818
+
819
+ const token = this.generateToken({
820
+ userId: user.id,
821
+ email: user.email
822
+ });
823
+
824
+ const refreshToken = this.generateRefreshToken({
825
+ userId: user.id
826
+ });
827
+
828
+ return {
829
+ token,
830
+ refreshToken,
831
+ user: {
832
+ id: user.id,
833
+ name: user.name,
834
+ email: user.email
835
+ }
836
+ };
837
+ }
838
+
839
+ async refreshToken(refreshToken: string) {
840
+ try {
841
+ const payload = jwt.verify(
842
+ refreshToken,
843
+ process.env.REFRESH_TOKEN_SECRET!
844
+ ) as { userId: string };
845
+
846
+ const user = await this.userRepository.findById(payload.userId);
847
+
848
+ if (!user) {
849
+ throw new UnauthorizedError('User not found');
850
+ }
851
+
852
+ const token = this.generateToken({
853
+ userId: user.id,
854
+ email: user.email
855
+ });
856
+
857
+ return { token };
858
+ } catch (error) {
859
+ throw new UnauthorizedError('Invalid refresh token');
860
+ }
861
+ }
862
+
863
+ private generateToken(payload: any): string {
864
+ return jwt.sign(payload, process.env.JWT_SECRET!, {
865
+ expiresIn: '15m'
866
+ });
867
+ }
868
+
869
+ private generateRefreshToken(payload: any): string {
870
+ return jwt.sign(payload, process.env.REFRESH_TOKEN_SECRET!, {
871
+ expiresIn: '7d'
872
+ });
873
+ }
874
+ }
875
+ ```
876
+
877
+ ## Caching Strategies
878
+
879
+ ```typescript
880
+ // utils/cache.ts
881
+ import Redis from 'ioredis';
882
+
883
+ const redis = new Redis({
884
+ host: process.env.REDIS_HOST,
885
+ port: parseInt(process.env.REDIS_PORT || '6379'),
886
+ retryStrategy: (times) => {
887
+ const delay = Math.min(times * 50, 2000);
888
+ return delay;
889
+ }
890
+ });
891
+
892
+ export class CacheService {
893
+ async get<T>(key: string): Promise<T | null> {
894
+ const data = await redis.get(key);
895
+ return data ? JSON.parse(data) : null;
896
+ }
897
+
898
+ async set(key: string, value: any, ttl?: number): Promise<void> {
899
+ const serialized = JSON.stringify(value);
900
+ if (ttl) {
901
+ await redis.setex(key, ttl, serialized);
902
+ } else {
903
+ await redis.set(key, serialized);
904
+ }
905
+ }
906
+
907
+ async delete(key: string): Promise<void> {
908
+ await redis.del(key);
909
+ }
910
+
911
+ async invalidatePattern(pattern: string): Promise<void> {
912
+ const keys = await redis.keys(pattern);
913
+ if (keys.length > 0) {
914
+ await redis.del(...keys);
915
+ }
916
+ }
917
+ }
918
+
919
+ // Cache decorator
920
+ export function Cacheable(ttl: number = 300) {
921
+ return function (
922
+ target: any,
923
+ propertyKey: string,
924
+ descriptor: PropertyDescriptor
925
+ ) {
926
+ const originalMethod = descriptor.value;
927
+
928
+ descriptor.value = async function (...args: any[]) {
929
+ const cache = new CacheService();
930
+ const cacheKey = `${propertyKey}:${JSON.stringify(args)}`;
931
+
932
+ const cached = await cache.get(cacheKey);
933
+ if (cached) {
934
+ return cached;
935
+ }
936
+
937
+ const result = await originalMethod.apply(this, args);
938
+ await cache.set(cacheKey, result, ttl);
939
+
940
+ return result;
941
+ };
942
+
943
+ return descriptor;
944
+ };
945
+ }
946
+ ```
947
+
948
+ ## API Response Format
949
+
950
+ ```typescript
951
+ // utils/response.ts
952
+ import { Response } from 'express';
953
+
954
+ export class ApiResponse {
955
+ static success<T>(res: Response, data: T, message?: string, statusCode = 200) {
956
+ return res.status(statusCode).json({
957
+ status: 'success',
958
+ message,
959
+ data
960
+ });
961
+ }
962
+
963
+ static error(res: Response, message: string, statusCode = 500, errors?: any) {
964
+ return res.status(statusCode).json({
965
+ status: 'error',
966
+ message,
967
+ ...(errors && { errors })
968
+ });
969
+ }
970
+
971
+ static paginated<T>(
972
+ res: Response,
973
+ data: T[],
974
+ page: number,
975
+ limit: number,
976
+ total: number
977
+ ) {
978
+ return res.json({
979
+ status: 'success',
980
+ data,
981
+ pagination: {
982
+ page,
983
+ limit,
984
+ total,
985
+ pages: Math.ceil(total / limit)
986
+ }
987
+ });
988
+ }
989
+ }
990
+ ```
991
+
992
+ ## Best Practices
993
+
994
+ 1. **Use TypeScript**: Type safety prevents runtime errors
995
+ 2. **Implement proper error handling**: Use custom error classes
996
+ 3. **Validate input**: Use libraries like Zod or Joi
997
+ 4. **Use environment variables**: Never hardcode secrets
998
+ 5. **Implement logging**: Use structured logging (Pino, Winston)
999
+ 6. **Add rate limiting**: Prevent abuse
1000
+ 7. **Use HTTPS**: Always in production
1001
+ 8. **Implement CORS properly**: Don't use `*` in production
1002
+ 9. **Use dependency injection**: Easier testing and maintenance
1003
+ 10. **Write tests**: Unit, integration, and E2E tests
1004
+ 11. **Handle graceful shutdown**: Clean up resources
1005
+ 12. **Use connection pooling**: For databases
1006
+ 13. **Implement health checks**: For monitoring
1007
+ 14. **Use compression**: Reduce response size
1008
+ 15. **Monitor performance**: Use APM tools
1009
+
1010
+ ## Testing Patterns
1011
+
1012
+ See `javascript-testing-patterns` skill for comprehensive testing guidance.
1013
+
1014
+ ## Resources
1015
+
1016
+ - **Node.js Best Practices**: https://github.com/goldbergyoni/nodebestpractices
1017
+ - **Express.js Guide**: https://expressjs.com/en/guide/
1018
+ - **Fastify Documentation**: https://www.fastify.io/docs/
1019
+ - **TypeScript Node Starter**: https://github.com/microsoft/TypeScript-Node-Starter