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,856 @@
1
+ ---
2
+ name: fp-ts-errors
3
+ description: Handle errors as values using fp-ts Either and TaskEither for cleaner, more predictable TypeScript code. Use when implementing error handling patterns with fp-ts.
4
+ risk: safe
5
+ source: https://github.com/whatiskadudoing/fp-ts-skills
6
+ ---
7
+
8
+ # Practical Error Handling with fp-ts
9
+
10
+ This skill teaches you how to handle errors without try/catch spaghetti. No academic jargon - just practical patterns for real problems.
11
+
12
+ ## When to Use This Skill
13
+
14
+ - When you want type-safe error handling in TypeScript
15
+ - When replacing try/catch with Either and TaskEither patterns
16
+ - When building APIs or services that need explicit error types
17
+ - When accumulating multiple validation errors
18
+
19
+ The core idea: **Errors are just data**. Instead of throwing them into the void and hoping someone catches them, return them as values that TypeScript can track.
20
+
21
+ ---
22
+
23
+ ## 1. Stop Throwing Everywhere
24
+
25
+ ### The Problem with Exceptions
26
+
27
+ Exceptions are invisible in your types. They break the contract between functions.
28
+
29
+ ```typescript
30
+ // What this function signature promises:
31
+ function getUser(id: string): User
32
+
33
+ // What it actually does:
34
+ function getUser(id: string): User {
35
+ if (!id) throw new Error('ID required')
36
+ const user = db.find(id)
37
+ if (!user) throw new Error('User not found')
38
+ return user
39
+ }
40
+
41
+ // The caller has no idea this can fail
42
+ const user = getUser(id) // Might explode!
43
+ ```
44
+
45
+ You end up with code like this:
46
+
47
+ ```typescript
48
+ // MESSY: try/catch everywhere
49
+ function processOrder(orderId: string) {
50
+ let order
51
+ try {
52
+ order = getOrder(orderId)
53
+ } catch (e) {
54
+ console.error('Failed to get order')
55
+ return null
56
+ }
57
+
58
+ let user
59
+ try {
60
+ user = getUser(order.userId)
61
+ } catch (e) {
62
+ console.error('Failed to get user')
63
+ return null
64
+ }
65
+
66
+ let payment
67
+ try {
68
+ payment = chargeCard(user.cardId, order.total)
69
+ } catch (e) {
70
+ console.error('Payment failed')
71
+ return null
72
+ }
73
+
74
+ return { order, user, payment }
75
+ }
76
+ ```
77
+
78
+ ### The Solution: Return Errors as Values
79
+
80
+ ```typescript
81
+ import * as E from 'fp-ts/Either'
82
+ import { pipe } from 'fp-ts/function'
83
+
84
+ // Now TypeScript KNOWS this can fail
85
+ function getUser(id: string): E.Either<string, User> {
86
+ if (!id) return E.left('ID required')
87
+ const user = db.find(id)
88
+ if (!user) return E.left('User not found')
89
+ return E.right(user)
90
+ }
91
+
92
+ // The caller is forced to handle both cases
93
+ const result = getUser(id)
94
+ // result is Either<string, User> - error OR success, never both
95
+ ```
96
+
97
+ ---
98
+
99
+ ## 2. The Result Pattern (Either)
100
+
101
+ `Either<E, A>` is simple: it holds either an error (`E`) or a value (`A`).
102
+
103
+ - `Left` = error case
104
+ - `Right` = success case (think "right" as in "correct")
105
+
106
+ ```typescript
107
+ import * as E from 'fp-ts/Either'
108
+
109
+ // Creating values
110
+ const success = E.right(42) // Right(42)
111
+ const failure = E.left('Oops') // Left('Oops')
112
+
113
+ // Checking what you have
114
+ if (E.isRight(result)) {
115
+ console.log(result.right) // The success value
116
+ } else {
117
+ console.log(result.left) // The error
118
+ }
119
+
120
+ // Better: pattern match with fold
121
+ const message = pipe(
122
+ result,
123
+ E.fold(
124
+ (error) => `Failed: ${error}`,
125
+ (value) => `Got: ${value}`
126
+ )
127
+ )
128
+ ```
129
+
130
+ ### Converting Throwing Code to Either
131
+
132
+ ```typescript
133
+ // Wrap any throwing function with tryCatch
134
+ const parseJSON = (json: string): E.Either<Error, unknown> =>
135
+ E.tryCatch(
136
+ () => JSON.parse(json),
137
+ (e) => (e instanceof Error ? e : new Error(String(e)))
138
+ )
139
+
140
+ parseJSON('{"valid": true}') // Right({ valid: true })
141
+ parseJSON('not json') // Left(SyntaxError: ...)
142
+
143
+ // For functions you'll reuse, use tryCatchK
144
+ const safeParseJSON = E.tryCatchK(
145
+ JSON.parse,
146
+ (e) => (e instanceof Error ? e : new Error(String(e)))
147
+ )
148
+ ```
149
+
150
+ ### Common Either Operations
151
+
152
+ ```typescript
153
+ import * as E from 'fp-ts/Either'
154
+ import { pipe } from 'fp-ts/function'
155
+
156
+ // Transform the success value
157
+ const doubled = pipe(
158
+ E.right(21),
159
+ E.map(n => n * 2)
160
+ ) // Right(42)
161
+
162
+ // Transform the error
163
+ const betterError = pipe(
164
+ E.left('bad'),
165
+ E.mapLeft(e => `Error: ${e}`)
166
+ ) // Left('Error: bad')
167
+
168
+ // Provide a default for errors
169
+ const value = pipe(
170
+ E.left('failed'),
171
+ E.getOrElse(() => 0)
172
+ ) // 0
173
+
174
+ // Convert nullable to Either
175
+ const fromNullable = E.fromNullable('not found')
176
+ fromNullable(user) // Right(user) if exists, Left('not found') if null/undefined
177
+ ```
178
+
179
+ ---
180
+
181
+ ## 3. Chaining Operations That Might Fail
182
+
183
+ The real power comes from chaining. Each step can fail, but you write it as a clean pipeline.
184
+
185
+ ### Before: Nested Try/Catch Hell
186
+
187
+ ```typescript
188
+ // MESSY: Each step can fail, nested try/catch everywhere
189
+ function processUserOrder(userId: string, productId: string): Result | null {
190
+ let user
191
+ try {
192
+ user = getUser(userId)
193
+ } catch (e) {
194
+ logError('User fetch failed', e)
195
+ return null
196
+ }
197
+
198
+ if (!user.isActive) {
199
+ logError('User not active')
200
+ return null
201
+ }
202
+
203
+ let product
204
+ try {
205
+ product = getProduct(productId)
206
+ } catch (e) {
207
+ logError('Product fetch failed', e)
208
+ return null
209
+ }
210
+
211
+ if (product.stock < 1) {
212
+ logError('Out of stock')
213
+ return null
214
+ }
215
+
216
+ let order
217
+ try {
218
+ order = createOrder(user, product)
219
+ } catch (e) {
220
+ logError('Order creation failed', e)
221
+ return null
222
+ }
223
+
224
+ return order
225
+ }
226
+ ```
227
+
228
+ ### After: Clean Chain with Either
229
+
230
+ ```typescript
231
+ import * as E from 'fp-ts/Either'
232
+ import { pipe } from 'fp-ts/function'
233
+
234
+ // Each function returns Either<Error, T>
235
+ const getUser = (id: string): E.Either<string, User> => { ... }
236
+ const getProduct = (id: string): E.Either<string, Product> => { ... }
237
+ const createOrder = (user: User, product: Product): E.Either<string, Order> => { ... }
238
+
239
+ // Chain them together - first error stops the chain
240
+ const processUserOrder = (userId: string, productId: string): E.Either<string, Order> =>
241
+ pipe(
242
+ getUser(userId),
243
+ E.filterOrElse(
244
+ user => user.isActive,
245
+ () => 'User not active'
246
+ ),
247
+ E.chain(user =>
248
+ pipe(
249
+ getProduct(productId),
250
+ E.filterOrElse(
251
+ product => product.stock >= 1,
252
+ () => 'Out of stock'
253
+ ),
254
+ E.chain(product => createOrder(user, product))
255
+ )
256
+ )
257
+ )
258
+
259
+ // Or use Do notation for cleaner access to intermediate values
260
+ const processUserOrder = (userId: string, productId: string): E.Either<string, Order> =>
261
+ pipe(
262
+ E.Do,
263
+ E.bind('user', () => getUser(userId)),
264
+ E.filterOrElse(
265
+ ({ user }) => user.isActive,
266
+ () => 'User not active'
267
+ ),
268
+ E.bind('product', () => getProduct(productId)),
269
+ E.filterOrElse(
270
+ ({ product }) => product.stock >= 1,
271
+ () => 'Out of stock'
272
+ ),
273
+ E.chain(({ user, product }) => createOrder(user, product))
274
+ )
275
+ ```
276
+
277
+ ### Different Error Types? Use chainW
278
+
279
+ ```typescript
280
+ type ValidationError = { type: 'validation'; message: string }
281
+ type DbError = { type: 'db'; message: string }
282
+
283
+ const validateInput = (id: string): E.Either<ValidationError, string> => { ... }
284
+ const fetchFromDb = (id: string): E.Either<DbError, User> => { ... }
285
+
286
+ // chainW (W = "wider") automatically unions the error types
287
+ const process = (id: string): E.Either<ValidationError | DbError, User> =>
288
+ pipe(
289
+ validateInput(id),
290
+ E.chainW(validId => fetchFromDb(validId))
291
+ )
292
+ ```
293
+
294
+ ---
295
+
296
+ ## 4. Collecting Multiple Errors
297
+
298
+ Sometimes you want ALL errors, not just the first one. Form validation is the classic example.
299
+
300
+ ### Before: Collecting Errors Manually
301
+
302
+ ```typescript
303
+ // MESSY: Manual error accumulation
304
+ function validateForm(form: FormData): { valid: boolean; errors: string[] } {
305
+ const errors: string[] = []
306
+
307
+ if (!form.email) {
308
+ errors.push('Email required')
309
+ } else if (!form.email.includes('@')) {
310
+ errors.push('Invalid email')
311
+ }
312
+
313
+ if (!form.password) {
314
+ errors.push('Password required')
315
+ } else if (form.password.length < 8) {
316
+ errors.push('Password too short')
317
+ }
318
+
319
+ if (!form.age) {
320
+ errors.push('Age required')
321
+ } else if (form.age < 18) {
322
+ errors.push('Must be 18+')
323
+ }
324
+
325
+ return { valid: errors.length === 0, errors }
326
+ }
327
+ ```
328
+
329
+ ### After: Validation with Error Accumulation
330
+
331
+ ```typescript
332
+ import * as E from 'fp-ts/Either'
333
+ import * as NEA from 'fp-ts/NonEmptyArray'
334
+ import { sequenceS } from 'fp-ts/Apply'
335
+ import { pipe } from 'fp-ts/function'
336
+
337
+ // Errors as a NonEmptyArray (always at least one)
338
+ type Errors = NEA.NonEmptyArray<string>
339
+
340
+ // Create the applicative that accumulates errors
341
+ const validation = E.getApplicativeValidation(NEA.getSemigroup<string>())
342
+
343
+ // Validators that return Either<Errors, T>
344
+ const validateEmail = (email: string): E.Either<Errors, string> =>
345
+ !email ? E.left(NEA.of('Email required'))
346
+ : !email.includes('@') ? E.left(NEA.of('Invalid email'))
347
+ : E.right(email)
348
+
349
+ const validatePassword = (password: string): E.Either<Errors, string> =>
350
+ !password ? E.left(NEA.of('Password required'))
351
+ : password.length < 8 ? E.left(NEA.of('Password too short'))
352
+ : E.right(password)
353
+
354
+ const validateAge = (age: number | undefined): E.Either<Errors, number> =>
355
+ age === undefined ? E.left(NEA.of('Age required'))
356
+ : age < 18 ? E.left(NEA.of('Must be 18+'))
357
+ : E.right(age)
358
+
359
+ // Combine all validations - collects ALL errors
360
+ const validateForm = (form: FormData) =>
361
+ sequenceS(validation)({
362
+ email: validateEmail(form.email),
363
+ password: validatePassword(form.password),
364
+ age: validateAge(form.age)
365
+ })
366
+
367
+ // Usage
368
+ validateForm({ email: '', password: '123', age: 15 })
369
+ // Left(['Email required', 'Password too short', 'Must be 18+'])
370
+
371
+ validateForm({ email: 'a@b.com', password: 'longpassword', age: 25 })
372
+ // Right({ email: 'a@b.com', password: 'longpassword', age: 25 })
373
+ ```
374
+
375
+ ### Field-Level Errors for Forms
376
+
377
+ ```typescript
378
+ interface FieldError {
379
+ field: string
380
+ message: string
381
+ }
382
+
383
+ type FormErrors = NEA.NonEmptyArray<FieldError>
384
+
385
+ const fieldError = (field: string, message: string): FormErrors =>
386
+ NEA.of({ field, message })
387
+
388
+ const formValidation = E.getApplicativeValidation(NEA.getSemigroup<FieldError>())
389
+
390
+ // Now errors know which field they belong to
391
+ const validateEmail = (email: string): E.Either<FormErrors, string> =>
392
+ !email ? E.left(fieldError('email', 'Required'))
393
+ : !email.includes('@') ? E.left(fieldError('email', 'Invalid format'))
394
+ : E.right(email)
395
+
396
+ // Easy to display in UI
397
+ const getFieldError = (errors: FormErrors, field: string): string | undefined =>
398
+ errors.find(e => e.field === field)?.message
399
+ ```
400
+
401
+ ---
402
+
403
+ ## 5. Async Operations (TaskEither)
404
+
405
+ For async operations that can fail, use `TaskEither`. It's like `Either` but for promises.
406
+
407
+ - `TaskEither<E, A>` = a function that returns `Promise<Either<E, A>>`
408
+ - Lazy: nothing runs until you execute it
409
+
410
+ ```typescript
411
+ import * as TE from 'fp-ts/TaskEither'
412
+ import { pipe } from 'fp-ts/function'
413
+
414
+ // Wrap any async operation
415
+ const fetchUser = (id: string): TE.TaskEither<Error, User> =>
416
+ TE.tryCatch(
417
+ () => fetch(`/api/users/${id}`).then(r => r.json()),
418
+ (e) => (e instanceof Error ? e : new Error(String(e)))
419
+ )
420
+
421
+ // Chain async operations - just like Either
422
+ const getUserPosts = (userId: string): TE.TaskEither<Error, Post[]> =>
423
+ pipe(
424
+ fetchUser(userId),
425
+ TE.chain(user => fetchPosts(user.id))
426
+ )
427
+
428
+ // Execute when ready
429
+ const result = await getUserPosts('123')() // Returns Either<Error, Post[]>
430
+ ```
431
+
432
+ ### Before: Promise Chain with Error Handling
433
+
434
+ ```typescript
435
+ // MESSY: try/catch mixed with promise chains
436
+ async function loadDashboard(userId: string) {
437
+ try {
438
+ const user = await fetchUser(userId)
439
+ if (!user) throw new Error('User not found')
440
+
441
+ let posts, notifications, settings
442
+ try {
443
+ [posts, notifications, settings] = await Promise.all([
444
+ fetchPosts(user.id),
445
+ fetchNotifications(user.id),
446
+ fetchSettings(user.id)
447
+ ])
448
+ } catch (e) {
449
+ // Which one failed? Who knows!
450
+ console.error('Failed to load data', e)
451
+ return null
452
+ }
453
+
454
+ return { user, posts, notifications, settings }
455
+ } catch (e) {
456
+ console.error('Failed to load user', e)
457
+ return null
458
+ }
459
+ }
460
+ ```
461
+
462
+ ### After: Clean TaskEither Pipeline
463
+
464
+ ```typescript
465
+ import * as TE from 'fp-ts/TaskEither'
466
+ import { sequenceS } from 'fp-ts/Apply'
467
+ import { pipe } from 'fp-ts/function'
468
+
469
+ const loadDashboard = (userId: string) =>
470
+ pipe(
471
+ fetchUser(userId),
472
+ TE.chain(user =>
473
+ pipe(
474
+ // Parallel fetch with sequenceS
475
+ sequenceS(TE.ApplyPar)({
476
+ posts: fetchPosts(user.id),
477
+ notifications: fetchNotifications(user.id),
478
+ settings: fetchSettings(user.id)
479
+ }),
480
+ TE.map(data => ({ user, ...data }))
481
+ )
482
+ )
483
+ )
484
+
485
+ // Execute and handle both cases
486
+ pipe(
487
+ loadDashboard('123'),
488
+ TE.fold(
489
+ (error) => T.of(renderError(error)),
490
+ (data) => T.of(renderDashboard(data))
491
+ )
492
+ )()
493
+ ```
494
+
495
+ ### Retry Failed Operations
496
+
497
+ ```typescript
498
+ import * as T from 'fp-ts/Task'
499
+ import * as TE from 'fp-ts/TaskEither'
500
+ import { pipe } from 'fp-ts/function'
501
+
502
+ const retry = <E, A>(
503
+ task: TE.TaskEither<E, A>,
504
+ attempts: number,
505
+ delayMs: number
506
+ ): TE.TaskEither<E, A> =>
507
+ pipe(
508
+ task,
509
+ TE.orElse((error) =>
510
+ attempts > 1
511
+ ? pipe(
512
+ T.delay(delayMs)(T.of(undefined)),
513
+ T.chain(() => retry(task, attempts - 1, delayMs * 2))
514
+ )
515
+ : TE.left(error)
516
+ )
517
+ )
518
+
519
+ // Retry up to 3 times with exponential backoff
520
+ const fetchWithRetry = retry(fetchUser('123'), 3, 1000)
521
+ ```
522
+
523
+ ### Fallback to Alternative
524
+
525
+ ```typescript
526
+ // Try cache first, fall back to API
527
+ const getUserData = (id: string) =>
528
+ pipe(
529
+ fetchFromCache(id),
530
+ TE.orElse(() => fetchFromApi(id)),
531
+ TE.orElse(() => TE.right(defaultUser)) // Last resort default
532
+ )
533
+ ```
534
+
535
+ ---
536
+
537
+ ## 6. Converting Between Patterns
538
+
539
+ Real codebases have throwing functions, nullable values, and promises. Here's how to work with them.
540
+
541
+ ### From Nullable to Either
542
+
543
+ ```typescript
544
+ import * as E from 'fp-ts/Either'
545
+ import * as O from 'fp-ts/Option'
546
+
547
+ // Direct conversion
548
+ const user = users.find(u => u.id === id) // User | undefined
549
+ const result = E.fromNullable('User not found')(user)
550
+
551
+ // From Option
552
+ const maybeUser: O.Option<User> = O.fromNullable(user)
553
+ const eitherUser = pipe(
554
+ maybeUser,
555
+ E.fromOption(() => 'User not found')
556
+ )
557
+ ```
558
+
559
+ ### From Throwing Function to Either
560
+
561
+ ```typescript
562
+ // Wrap at the boundary
563
+ const safeParse = <T>(schema: ZodSchema<T>) => (data: unknown): E.Either<ZodError, T> =>
564
+ E.tryCatch(
565
+ () => schema.parse(data),
566
+ (e) => e as ZodError
567
+ )
568
+
569
+ // Use throughout your code
570
+ const parseUser = safeParse(UserSchema)
571
+ const result = parseUser(rawData) // Either<ZodError, User>
572
+ ```
573
+
574
+ ### From Promise to TaskEither
575
+
576
+ ```typescript
577
+ import * as TE from 'fp-ts/TaskEither'
578
+
579
+ // Wrap external async functions
580
+ const fetchJson = <T>(url: string): TE.TaskEither<Error, T> =>
581
+ TE.tryCatch(
582
+ () => fetch(url).then(r => r.json()),
583
+ (e) => new Error(`Fetch failed: ${e}`)
584
+ )
585
+
586
+ // Wrap axios, prisma, any async library
587
+ const getUserFromDb = (id: string): TE.TaskEither<DbError, User> =>
588
+ TE.tryCatch(
589
+ () => prisma.user.findUniqueOrThrow({ where: { id } }),
590
+ (e) => ({ code: 'DB_ERROR', cause: e })
591
+ )
592
+ ```
593
+
594
+ ### Back to Promise (Escape Hatch)
595
+
596
+ Sometimes you need a plain Promise for external APIs.
597
+
598
+ ```typescript
599
+ import * as TE from 'fp-ts/TaskEither'
600
+ import * as E from 'fp-ts/Either'
601
+
602
+ const myTaskEither: TE.TaskEither<Error, User> = fetchUser('123')
603
+
604
+ // Option 1: Get the Either (preserves both cases)
605
+ const either: E.Either<Error, User> = await myTaskEither()
606
+
607
+ // Option 2: Throw on error (for legacy code)
608
+ const toThrowingPromise = <E, A>(te: TE.TaskEither<E, A>): Promise<A> =>
609
+ te().then(E.fold(
610
+ (error) => Promise.reject(error),
611
+ (value) => Promise.resolve(value)
612
+ ))
613
+
614
+ const user = await toThrowingPromise(fetchUser('123')) // Throws if Left
615
+
616
+ // Option 3: Default on error
617
+ const user = await pipe(
618
+ fetchUser('123'),
619
+ TE.getOrElse(() => T.of(defaultUser))
620
+ )()
621
+ ```
622
+
623
+ ---
624
+
625
+ ## Real Scenarios
626
+
627
+ ### Parse User Input Safely
628
+
629
+ ```typescript
630
+ interface ParsedInput {
631
+ id: number
632
+ name: string
633
+ tags: string[]
634
+ }
635
+
636
+ const parseInput = (raw: unknown): E.Either<string, ParsedInput> =>
637
+ pipe(
638
+ E.Do,
639
+ E.bind('obj', () =>
640
+ typeof raw === 'object' && raw !== null
641
+ ? E.right(raw as Record<string, unknown>)
642
+ : E.left('Input must be an object')
643
+ ),
644
+ E.bind('id', ({ obj }) =>
645
+ typeof obj.id === 'number'
646
+ ? E.right(obj.id)
647
+ : E.left('id must be a number')
648
+ ),
649
+ E.bind('name', ({ obj }) =>
650
+ typeof obj.name === 'string' && obj.name.length > 0
651
+ ? E.right(obj.name)
652
+ : E.left('name must be a non-empty string')
653
+ ),
654
+ E.bind('tags', ({ obj }) =>
655
+ Array.isArray(obj.tags) && obj.tags.every(t => typeof t === 'string')
656
+ ? E.right(obj.tags as string[])
657
+ : E.left('tags must be an array of strings')
658
+ ),
659
+ E.map(({ id, name, tags }) => ({ id, name, tags }))
660
+ )
661
+
662
+ // Usage
663
+ parseInput({ id: 1, name: 'test', tags: ['a', 'b'] })
664
+ // Right({ id: 1, name: 'test', tags: ['a', 'b'] })
665
+
666
+ parseInput({ id: 'wrong', name: '', tags: null })
667
+ // Left('id must be a number')
668
+ ```
669
+
670
+ ### API Call with Full Error Handling
671
+
672
+ ```typescript
673
+ interface ApiError {
674
+ code: string
675
+ message: string
676
+ status?: number
677
+ }
678
+
679
+ const createApiError = (message: string, code = 'UNKNOWN', status?: number): ApiError =>
680
+ ({ code, message, status })
681
+
682
+ const fetchWithErrorHandling = <T>(url: string): TE.TaskEither<ApiError, T> =>
683
+ pipe(
684
+ TE.tryCatch(
685
+ () => fetch(url),
686
+ () => createApiError('Network error', 'NETWORK')
687
+ ),
688
+ TE.chain(response =>
689
+ response.ok
690
+ ? TE.tryCatch(
691
+ () => response.json() as Promise<T>,
692
+ () => createApiError('Invalid JSON', 'PARSE')
693
+ )
694
+ : TE.left(createApiError(
695
+ `HTTP ${response.status}`,
696
+ response.status === 404 ? 'NOT_FOUND' : 'HTTP_ERROR',
697
+ response.status
698
+ ))
699
+ )
700
+ )
701
+
702
+ // Usage with pattern matching on error codes
703
+ const handleUserFetch = (userId: string) =>
704
+ pipe(
705
+ fetchWithErrorHandling<User>(`/api/users/${userId}`),
706
+ TE.fold(
707
+ (error) => {
708
+ switch (error.code) {
709
+ case 'NOT_FOUND': return T.of(showNotFoundPage())
710
+ case 'NETWORK': return T.of(showOfflineMessage())
711
+ default: return T.of(showGenericError(error.message))
712
+ }
713
+ },
714
+ (user) => T.of(showUserProfile(user))
715
+ )
716
+ )
717
+ ```
718
+
719
+ ### Process List Where Some Items Might Fail
720
+
721
+ ```typescript
722
+ import * as A from 'fp-ts/Array'
723
+ import * as E from 'fp-ts/Either'
724
+ import { pipe } from 'fp-ts/function'
725
+
726
+ interface ProcessResult<T> {
727
+ successes: T[]
728
+ failures: Array<{ item: unknown; error: string }>
729
+ }
730
+
731
+ // Process all, collect successes and failures separately
732
+ const processAllCollectErrors = <T, R>(
733
+ items: T[],
734
+ process: (item: T) => E.Either<string, R>
735
+ ): ProcessResult<R> => {
736
+ const results = items.map((item, index) =>
737
+ pipe(
738
+ process(item),
739
+ E.mapLeft(error => ({ item, error, index }))
740
+ )
741
+ )
742
+
743
+ return {
744
+ successes: pipe(results, A.filterMap(E.toOption)),
745
+ failures: pipe(
746
+ results,
747
+ A.filterMap(r => E.isLeft(r) ? O.some(r.left) : O.none)
748
+ )
749
+ }
750
+ }
751
+
752
+ // Usage
753
+ const parseNumbers = (inputs: string[]) =>
754
+ processAllCollectErrors(inputs, input => {
755
+ const n = parseInt(input, 10)
756
+ return isNaN(n) ? E.left(`Invalid number: ${input}`) : E.right(n)
757
+ })
758
+
759
+ parseNumbers(['1', 'abc', '3', 'def'])
760
+ // {
761
+ // successes: [1, 3],
762
+ // failures: [
763
+ // { item: 'abc', error: 'Invalid number: abc', index: 1 },
764
+ // { item: 'def', error: 'Invalid number: def', index: 3 }
765
+ // ]
766
+ // }
767
+ ```
768
+
769
+ ### Bulk Operations with Partial Success
770
+
771
+ ```typescript
772
+ import * as TE from 'fp-ts/TaskEither'
773
+ import * as T from 'fp-ts/Task'
774
+ import { pipe } from 'fp-ts/function'
775
+
776
+ interface BulkResult<T> {
777
+ succeeded: T[]
778
+ failed: Array<{ id: string; error: string }>
779
+ }
780
+
781
+ const bulkProcess = <T>(
782
+ ids: string[],
783
+ process: (id: string) => TE.TaskEither<string, T>
784
+ ): T.Task<BulkResult<T>> =>
785
+ pipe(
786
+ ids,
787
+ A.map(id =>
788
+ pipe(
789
+ process(id),
790
+ TE.fold(
791
+ (error) => T.of({ type: 'failed' as const, id, error }),
792
+ (result) => T.of({ type: 'succeeded' as const, result })
793
+ )
794
+ )
795
+ ),
796
+ T.sequenceArray,
797
+ T.map(results => ({
798
+ succeeded: results
799
+ .filter((r): r is { type: 'succeeded'; result: T } => r.type === 'succeeded')
800
+ .map(r => r.result),
801
+ failed: results
802
+ .filter((r): r is { type: 'failed'; id: string; error: string } => r.type === 'failed')
803
+ .map(({ id, error }) => ({ id, error }))
804
+ }))
805
+ )
806
+
807
+ // Usage
808
+ const deleteUsers = (userIds: string[]) =>
809
+ bulkProcess(userIds, id =>
810
+ pipe(
811
+ deleteUser(id),
812
+ TE.mapLeft(e => e.message)
813
+ )
814
+ )
815
+
816
+ // All operations run, you get a report of what worked and what didn't
817
+ ```
818
+
819
+ ---
820
+
821
+ ## Quick Reference
822
+
823
+ | Pattern | Use When | Example |
824
+ |---------|----------|---------|
825
+ | `E.right(value)` | Creating a success | `E.right(42)` |
826
+ | `E.left(error)` | Creating a failure | `E.left('not found')` |
827
+ | `E.tryCatch(fn, onError)` | Wrapping throwing code | `E.tryCatch(() => JSON.parse(s), toError)` |
828
+ | `E.fromNullable(error)` | Converting nullable | `E.fromNullable('missing')(maybeValue)` |
829
+ | `E.map(fn)` | Transform success | `pipe(result, E.map(x => x * 2))` |
830
+ | `E.mapLeft(fn)` | Transform error | `pipe(result, E.mapLeft(addContext))` |
831
+ | `E.chain(fn)` | Chain operations | `pipe(getA(), E.chain(a => getB(a.id)))` |
832
+ | `E.chainW(fn)` | Chain with different error type | `pipe(validate(), E.chainW(save))` |
833
+ | `E.fold(onError, onSuccess)` | Handle both cases | `E.fold(showError, showData)` |
834
+ | `E.getOrElse(onError)` | Extract with default | `E.getOrElse(() => 0)` |
835
+ | `E.filterOrElse(pred, onFalse)` | Validate with error | `E.filterOrElse(x => x > 0, () => 'must be positive')` |
836
+ | `sequenceS(validation)({...})` | Collect all errors | Form validation |
837
+
838
+ ### TaskEither Equivalents
839
+
840
+ All Either operations have TaskEither equivalents:
841
+ - `TE.right`, `TE.left`, `TE.tryCatch`
842
+ - `TE.map`, `TE.mapLeft`, `TE.chain`, `TE.chainW`
843
+ - `TE.fold`, `TE.getOrElse`, `TE.filterOrElse`
844
+ - `TE.orElse` for fallbacks
845
+
846
+ ---
847
+
848
+ ## Summary
849
+
850
+ 1. **Return errors as values** - Use Either/TaskEither instead of throwing
851
+ 2. **Chain with confidence** - `chain` stops at first error automatically
852
+ 3. **Collect all errors when needed** - Use validation applicative for forms
853
+ 4. **Wrap at boundaries** - Convert throwing/Promise code at the edges
854
+ 5. **Match at the end** - Use `fold` to handle both cases when you're ready to act
855
+
856
+ The payoff: TypeScript tracks your errors, no more forgotten try/catch, clear control flow, and composable error handling.