@ruaruababa/vibe-kit 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 (462) hide show
  1. package/CATALOG.md +317 -0
  2. package/README.md +121 -0
  3. package/aliases.json +65 -0
  4. package/bin/vibe.js +2 -0
  5. package/bundles.json +265 -0
  6. package/catalog.json +1560 -0
  7. package/dist/antigravity-skills/bin/cli.js +438 -0
  8. package/dist/antigravity-skills/lib/skill-utils.js +158 -0
  9. package/dist/antigravity-skills/scripts/build-catalog.js +305 -0
  10. package/dist/antigravity-skills/scripts/normalize-frontmatter.js +144 -0
  11. package/dist/antigravity-skills/scripts/validate-skills.js +230 -0
  12. package/dist/bin/vibe.js +2 -0
  13. package/dist/dist/src/cli/index.js +26 -0
  14. package/dist/lib/skill-utils.js +158 -0
  15. package/dist/scripts/build-catalog.js +50 -0
  16. package/dist/scripts/normalize-frontmatter.js +144 -0
  17. package/dist/scripts/validate-skills.js +56 -0
  18. package/dist/src/cli/index.js +146 -0
  19. package/dist/src/types/index.js +13 -0
  20. package/dist/src/utils/fs.js +1 -0
  21. package/package.json +43 -0
  22. package/skills/accessibility-compliance-accessibility-audit/SKILL.md +42 -0
  23. package/skills/accessibility-compliance-accessibility-audit/resources/implementation-playbook.md +502 -0
  24. package/skills/agent-orchestration-improve-agent/SKILL.md +349 -0
  25. package/skills/agent-orchestration-multi-agent-optimize/SKILL.md +239 -0
  26. package/skills/agent-orchestrator/SKILL.md +24 -0
  27. package/skills/ai-engineer/SKILL.md +171 -0
  28. package/skills/airflow-dag-patterns/SKILL.md +41 -0
  29. package/skills/airflow-dag-patterns/resources/implementation-playbook.md +509 -0
  30. package/skills/angular-migration/SKILL.md +428 -0
  31. package/skills/anti-reversing-techniques/SKILL.md +42 -0
  32. package/skills/anti-reversing-techniques/resources/implementation-playbook.md +539 -0
  33. package/skills/api-design-principles/SKILL.md +37 -0
  34. package/skills/api-design-principles/assets/api-design-checklist.md +155 -0
  35. package/skills/api-design-principles/assets/rest-api-template.py +182 -0
  36. package/skills/api-design-principles/references/graphql-schema-design.md +583 -0
  37. package/skills/api-design-principles/references/rest-best-practices.md +408 -0
  38. package/skills/api-design-principles/resources/implementation-playbook.md +513 -0
  39. package/skills/api-documenter/SKILL.md +184 -0
  40. package/skills/api-testing-observability-api-mock/SKILL.md +46 -0
  41. package/skills/api-testing-observability-api-mock/resources/implementation-playbook.md +1327 -0
  42. package/skills/application-performance-performance-optimization/SKILL.md +154 -0
  43. package/skills/architect-review/SKILL.md +174 -0
  44. package/skills/architecture-decision-records/SKILL.md +441 -0
  45. package/skills/architecture-patterns/SKILL.md +37 -0
  46. package/skills/architecture-patterns/resources/implementation-playbook.md +479 -0
  47. package/skills/arm-cortex-expert/SKILL.md +306 -0
  48. package/skills/async-python-patterns/SKILL.md +39 -0
  49. package/skills/async-python-patterns/resources/implementation-playbook.md +678 -0
  50. package/skills/attack-tree-construction/SKILL.md +38 -0
  51. package/skills/attack-tree-construction/resources/implementation-playbook.md +671 -0
  52. package/skills/auth-implementation-patterns/SKILL.md +39 -0
  53. package/skills/auth-implementation-patterns/resources/implementation-playbook.md +618 -0
  54. package/skills/backend-architect/SKILL.md +333 -0
  55. package/skills/backend-development-feature-development/SKILL.md +180 -0
  56. package/skills/backend-security-coder/SKILL.md +156 -0
  57. package/skills/backtesting-frameworks/SKILL.md +39 -0
  58. package/skills/backtesting-frameworks/resources/implementation-playbook.md +647 -0
  59. package/skills/bash-defensive-patterns/SKILL.md +43 -0
  60. package/skills/bash-defensive-patterns/resources/implementation-playbook.md +517 -0
  61. package/skills/bash-pro/SKILL.md +310 -0
  62. package/skills/bats-testing-patterns/SKILL.md +34 -0
  63. package/skills/bats-testing-patterns/resources/implementation-playbook.md +614 -0
  64. package/skills/bazel-build-optimization/SKILL.md +397 -0
  65. package/skills/billing-automation/SKILL.md +42 -0
  66. package/skills/billing-automation/resources/implementation-playbook.md +544 -0
  67. package/skills/binary-analysis-patterns/SKILL.md +450 -0
  68. package/skills/blockchain-developer/SKILL.md +208 -0
  69. package/skills/business-analyst/SKILL.md +182 -0
  70. package/skills/c-pro/SKILL.md +56 -0
  71. package/skills/c4-architecture-c4-architecture/SKILL.md +389 -0
  72. package/skills/c4-code/SKILL.md +244 -0
  73. package/skills/c4-component/SKILL.md +153 -0
  74. package/skills/c4-container/SKILL.md +171 -0
  75. package/skills/c4-context/SKILL.md +150 -0
  76. package/skills/changelog-automation/SKILL.md +38 -0
  77. package/skills/changelog-automation/resources/implementation-playbook.md +538 -0
  78. package/skills/cicd-automation-workflow-automate/SKILL.md +51 -0
  79. package/skills/cicd-automation-workflow-automate/resources/implementation-playbook.md +1333 -0
  80. package/skills/clean-markdown/SKILL.md +23 -0
  81. package/skills/cloud-architect/SKILL.md +135 -0
  82. package/skills/code-documentation-code-explain/SKILL.md +46 -0
  83. package/skills/code-documentation-code-explain/resources/implementation-playbook.md +802 -0
  84. package/skills/code-documentation-doc-generate/SKILL.md +48 -0
  85. package/skills/code-documentation-doc-generate/resources/implementation-playbook.md +640 -0
  86. package/skills/code-refactoring-context-restore/SKILL.md +179 -0
  87. package/skills/code-refactoring-refactor-clean/SKILL.md +51 -0
  88. package/skills/code-refactoring-refactor-clean/resources/implementation-playbook.md +879 -0
  89. package/skills/code-refactoring-tech-debt/SKILL.md +386 -0
  90. package/skills/code-review-ai-ai-review/SKILL.md +450 -0
  91. package/skills/code-review-excellence/SKILL.md +40 -0
  92. package/skills/code-review-excellence/resources/implementation-playbook.md +515 -0
  93. package/skills/code-reviewer/SKILL.md +178 -0
  94. package/skills/codebase-cleanup-deps-audit/SKILL.md +51 -0
  95. package/skills/codebase-cleanup-deps-audit/resources/implementation-playbook.md +766 -0
  96. package/skills/codebase-cleanup-refactor-clean/SKILL.md +51 -0
  97. package/skills/codebase-cleanup-refactor-clean/resources/implementation-playbook.md +879 -0
  98. package/skills/codebase-cleanup-tech-debt/SKILL.md +386 -0
  99. package/skills/competitive-landscape/SKILL.md +34 -0
  100. package/skills/competitive-landscape/resources/implementation-playbook.md +494 -0
  101. package/skills/comprehensive-review-full-review/SKILL.md +146 -0
  102. package/skills/comprehensive-review-pr-enhance/SKILL.md +46 -0
  103. package/skills/comprehensive-review-pr-enhance/resources/implementation-playbook.md +691 -0
  104. package/skills/conductor-implement/SKILL.md +388 -0
  105. package/skills/conductor-manage/SKILL.md +39 -0
  106. package/skills/conductor-manage/resources/implementation-playbook.md +1120 -0
  107. package/skills/conductor-new-track/SKILL.md +433 -0
  108. package/skills/conductor-revert/SKILL.md +372 -0
  109. package/skills/conductor-setup/SKILL.md +426 -0
  110. package/skills/conductor-status/SKILL.md +338 -0
  111. package/skills/conductor-validator/SKILL.md +62 -0
  112. package/skills/content-marketer/SKILL.md +170 -0
  113. package/skills/context-driven-development/SKILL.md +400 -0
  114. package/skills/context-management-context-restore/SKILL.md +179 -0
  115. package/skills/context-management-context-save/SKILL.md +177 -0
  116. package/skills/context-manager/SKILL.md +185 -0
  117. package/skills/cost-optimization/SKILL.md +286 -0
  118. package/skills/cpp-pro/SKILL.md +59 -0
  119. package/skills/cqrs-implementation/SKILL.md +35 -0
  120. package/skills/cqrs-implementation/resources/implementation-playbook.md +540 -0
  121. package/skills/csharp-pro/SKILL.md +59 -0
  122. package/skills/customer-support/SKILL.md +170 -0
  123. package/skills/data-engineer/SKILL.md +224 -0
  124. package/skills/data-engineering-data-driven-feature/SKILL.md +182 -0
  125. package/skills/data-engineering-data-pipeline/SKILL.md +201 -0
  126. package/skills/data-quality-frameworks/SKILL.md +40 -0
  127. package/skills/data-quality-frameworks/resources/implementation-playbook.md +573 -0
  128. package/skills/data-scientist/SKILL.md +199 -0
  129. package/skills/data-storytelling/SKILL.md +465 -0
  130. package/skills/database-admin/SKILL.md +165 -0
  131. package/skills/database-architect/SKILL.md +268 -0
  132. package/skills/database-cloud-optimization-cost-optimize/SKILL.md +44 -0
  133. package/skills/database-cloud-optimization-cost-optimize/resources/implementation-playbook.md +1441 -0
  134. package/skills/database-migration/SKILL.md +436 -0
  135. package/skills/database-migrations-migration-observability/SKILL.md +420 -0
  136. package/skills/database-migrations-sql-migrations/SKILL.md +53 -0
  137. package/skills/database-migrations-sql-migrations/resources/implementation-playbook.md +499 -0
  138. package/skills/database-optimizer/SKILL.md +167 -0
  139. package/skills/dbt-transformation-patterns/SKILL.md +34 -0
  140. package/skills/dbt-transformation-patterns/resources/implementation-playbook.md +547 -0
  141. package/skills/debugger/SKILL.md +49 -0
  142. package/skills/debugging-strategies/SKILL.md +34 -0
  143. package/skills/debugging-strategies/resources/implementation-playbook.md +511 -0
  144. package/skills/debugging-toolkit-smart-debug/SKILL.md +197 -0
  145. package/skills/defi-protocol-templates/SKILL.md +466 -0
  146. package/skills/dependency-management-deps-audit/SKILL.md +44 -0
  147. package/skills/dependency-management-deps-audit/resources/implementation-playbook.md +766 -0
  148. package/skills/dependency-upgrade/SKILL.md +421 -0
  149. package/skills/deployment-engineer/SKILL.md +170 -0
  150. package/skills/deployment-pipeline-design/SKILL.md +371 -0
  151. package/skills/deployment-validation-config-validate/SKILL.md +496 -0
  152. package/skills/devops-troubleshooter/SKILL.md +161 -0
  153. package/skills/distributed-debugging-debug-trace/SKILL.md +44 -0
  154. package/skills/distributed-debugging-debug-trace/resources/implementation-playbook.md +1307 -0
  155. package/skills/distributed-tracing/SKILL.md +450 -0
  156. package/skills/django-pro/SKILL.md +180 -0
  157. package/skills/docs-architect/SKILL.md +98 -0
  158. package/skills/documentation-generation-doc-generate/SKILL.md +48 -0
  159. package/skills/documentation-generation-doc-generate/resources/implementation-playbook.md +640 -0
  160. package/skills/dotnet-architect/SKILL.md +197 -0
  161. package/skills/dotnet-backend-patterns/SKILL.md +37 -0
  162. package/skills/dotnet-backend-patterns/assets/repository-template.cs +523 -0
  163. package/skills/dotnet-backend-patterns/assets/service-template.cs +336 -0
  164. package/skills/dotnet-backend-patterns/references/dapper-patterns.md +544 -0
  165. package/skills/dotnet-backend-patterns/references/ef-core-best-practices.md +355 -0
  166. package/skills/dotnet-backend-patterns/resources/implementation-playbook.md +799 -0
  167. package/skills/dummy-skill/SKILL.md +5 -0
  168. package/skills/dx-optimizer/SKILL.md +83 -0
  169. package/skills/e2e-testing-patterns/SKILL.md +41 -0
  170. package/skills/e2e-testing-patterns/resources/implementation-playbook.md +531 -0
  171. package/skills/elixir-pro/SKILL.md +59 -0
  172. package/skills/embedding-strategies/SKILL.md +491 -0
  173. package/skills/employment-contract-templates/SKILL.md +39 -0
  174. package/skills/employment-contract-templates/resources/implementation-playbook.md +493 -0
  175. package/skills/error-debugging-error-analysis/SKILL.md +47 -0
  176. package/skills/error-debugging-error-analysis/resources/implementation-playbook.md +1143 -0
  177. package/skills/error-debugging-error-trace/SKILL.md +43 -0
  178. package/skills/error-debugging-error-trace/resources/implementation-playbook.md +1361 -0
  179. package/skills/error-debugging-multi-agent-review/SKILL.md +216 -0
  180. package/skills/error-detective/SKILL.md +53 -0
  181. package/skills/error-diagnostics-error-analysis/SKILL.md +47 -0
  182. package/skills/error-diagnostics-error-analysis/resources/implementation-playbook.md +1143 -0
  183. package/skills/error-diagnostics-error-trace/SKILL.md +48 -0
  184. package/skills/error-diagnostics-error-trace/resources/implementation-playbook.md +1371 -0
  185. package/skills/error-diagnostics-smart-debug/SKILL.md +197 -0
  186. package/skills/error-handling-patterns/SKILL.md +35 -0
  187. package/skills/error-handling-patterns/resources/implementation-playbook.md +635 -0
  188. package/skills/event-sourcing-architect/SKILL.md +58 -0
  189. package/skills/event-store-design/SKILL.md +449 -0
  190. package/skills/fastapi-pro/SKILL.md +192 -0
  191. package/skills/fastapi-templates/SKILL.md +32 -0
  192. package/skills/fastapi-templates/resources/implementation-playbook.md +566 -0
  193. package/skills/final-test/SKILL.md +5 -0
  194. package/skills/firmware-analyst/SKILL.md +320 -0
  195. package/skills/flutter-expert/SKILL.md +200 -0
  196. package/skills/framework-migration-code-migrate/SKILL.md +48 -0
  197. package/skills/framework-migration-code-migrate/resources/implementation-playbook.md +1052 -0
  198. package/skills/framework-migration-deps-upgrade/SKILL.md +48 -0
  199. package/skills/framework-migration-deps-upgrade/resources/implementation-playbook.md +755 -0
  200. package/skills/framework-migration-legacy-modernize/SKILL.md +132 -0
  201. package/skills/frontend-developer/SKILL.md +171 -0
  202. package/skills/frontend-mobile-development-component-scaffold/SKILL.md +403 -0
  203. package/skills/frontend-mobile-security-xss-scan/SKILL.md +322 -0
  204. package/skills/frontend-security-coder/SKILL.md +170 -0
  205. package/skills/full-stack-orchestration-full-stack-feature/SKILL.md +135 -0
  206. package/skills/gdpr-data-handling/SKILL.md +33 -0
  207. package/skills/gdpr-data-handling/resources/implementation-playbook.md +615 -0
  208. package/skills/git-advanced-workflows/SKILL.md +412 -0
  209. package/skills/git-pr-workflows-git-workflow/SKILL.md +140 -0
  210. package/skills/git-pr-workflows-onboard/SKILL.md +416 -0
  211. package/skills/git-pr-workflows-pr-enhance/SKILL.md +48 -0
  212. package/skills/git-pr-workflows-pr-enhance/resources/implementation-playbook.md +701 -0
  213. package/skills/github-actions-templates/SKILL.md +345 -0
  214. package/skills/gitlab-ci-patterns/SKILL.md +283 -0
  215. package/skills/gitops-workflow/SKILL.md +303 -0
  216. package/skills/gitops-workflow/references/argocd-setup.md +134 -0
  217. package/skills/gitops-workflow/references/sync-policies.md +131 -0
  218. package/skills/go-concurrency-patterns/SKILL.md +33 -0
  219. package/skills/go-concurrency-patterns/resources/implementation-playbook.md +654 -0
  220. package/skills/godot-gdscript-patterns/SKILL.md +33 -0
  221. package/skills/godot-gdscript-patterns/resources/implementation-playbook.md +804 -0
  222. package/skills/golang-pro/SKILL.md +179 -0
  223. package/skills/grafana-dashboards/SKILL.md +381 -0
  224. package/skills/graphql-architect/SKILL.md +182 -0
  225. package/skills/haskell-pro/SKILL.md +56 -0
  226. package/skills/helm-chart-scaffolding/SKILL.md +34 -0
  227. package/skills/helm-chart-scaffolding/assets/Chart.yaml.template +42 -0
  228. package/skills/helm-chart-scaffolding/assets/values.yaml.template +185 -0
  229. package/skills/helm-chart-scaffolding/references/chart-structure.md +500 -0
  230. package/skills/helm-chart-scaffolding/resources/implementation-playbook.md +543 -0
  231. package/skills/helm-chart-scaffolding/scripts/validate-chart.sh +244 -0
  232. package/skills/hr-pro/SKILL.md +126 -0
  233. package/skills/hybrid-cloud-architect/SKILL.md +168 -0
  234. package/skills/hybrid-cloud-networking/SKILL.md +238 -0
  235. package/skills/hybrid-search-implementation/SKILL.md +32 -0
  236. package/skills/hybrid-search-implementation/resources/implementation-playbook.md +567 -0
  237. package/skills/incident-responder/SKILL.md +213 -0
  238. package/skills/incident-response-incident-response/SKILL.md +168 -0
  239. package/skills/incident-response-smart-fix/SKILL.md +29 -0
  240. package/skills/incident-response-smart-fix/resources/implementation-playbook.md +838 -0
  241. package/skills/incident-runbook-templates/SKILL.md +395 -0
  242. package/skills/ios-developer/SKILL.md +219 -0
  243. package/skills/istio-traffic-management/SKILL.md +337 -0
  244. package/skills/java-pro/SKILL.md +177 -0
  245. package/skills/javascript-pro/SKILL.md +57 -0
  246. package/skills/javascript-testing-patterns/SKILL.md +35 -0
  247. package/skills/javascript-testing-patterns/resources/implementation-playbook.md +1024 -0
  248. package/skills/javascript-typescript-typescript-scaffold/SKILL.md +361 -0
  249. package/skills/julia-pro/SKILL.md +209 -0
  250. package/skills/k8s-manifest-generator/SKILL.md +35 -0
  251. package/skills/k8s-manifest-generator/assets/configmap-template.yaml +296 -0
  252. package/skills/k8s-manifest-generator/assets/deployment-template.yaml +203 -0
  253. package/skills/k8s-manifest-generator/assets/service-template.yaml +171 -0
  254. package/skills/k8s-manifest-generator/references/deployment-spec.md +753 -0
  255. package/skills/k8s-manifest-generator/references/service-spec.md +724 -0
  256. package/skills/k8s-manifest-generator/resources/implementation-playbook.md +510 -0
  257. package/skills/k8s-security-policies/SKILL.md +346 -0
  258. package/skills/k8s-security-policies/assets/network-policy-template.yaml +177 -0
  259. package/skills/k8s-security-policies/references/rbac-patterns.md +187 -0
  260. package/skills/kpi-dashboard-design/SKILL.md +440 -0
  261. package/skills/kubernetes-architect/SKILL.md +170 -0
  262. package/skills/langchain-architecture/SKILL.md +350 -0
  263. package/skills/legacy-modernizer/SKILL.md +53 -0
  264. package/skills/legal-advisor/SKILL.md +70 -0
  265. package/skills/linkerd-patterns/SKILL.md +321 -0
  266. package/skills/llm-application-dev-ai-assistant/SKILL.md +35 -0
  267. package/skills/llm-application-dev-ai-assistant/resources/implementation-playbook.md +1236 -0
  268. package/skills/llm-application-dev-langchain-agent/SKILL.md +246 -0
  269. package/skills/llm-application-dev-prompt-optimize/SKILL.md +37 -0
  270. package/skills/llm-application-dev-prompt-optimize/resources/implementation-playbook.md +591 -0
  271. package/skills/llm-evaluation/SKILL.md +483 -0
  272. package/skills/machine-learning-ops-ml-pipeline/SKILL.md +314 -0
  273. package/skills/malware-analyst/SKILL.md +247 -0
  274. package/skills/market-sizing-analysis/SKILL.md +425 -0
  275. package/skills/market-sizing-analysis/examples/saas-market-sizing.md +349 -0
  276. package/skills/market-sizing-analysis/references/data-sources.md +360 -0
  277. package/skills/memory-forensics/SKILL.md +491 -0
  278. package/skills/memory-safety-patterns/SKILL.md +33 -0
  279. package/skills/memory-safety-patterns/resources/implementation-playbook.md +603 -0
  280. package/skills/mermaid-expert/SKILL.md +59 -0
  281. package/skills/microservices-patterns/SKILL.md +35 -0
  282. package/skills/microservices-patterns/resources/implementation-playbook.md +607 -0
  283. package/skills/minecraft-bukkit-pro/SKILL.md +126 -0
  284. package/skills/ml-engineer/SKILL.md +168 -0
  285. package/skills/ml-pipeline-workflow/SKILL.md +257 -0
  286. package/skills/mlops-engineer/SKILL.md +219 -0
  287. package/skills/mobile-developer/SKILL.md +205 -0
  288. package/skills/mobile-security-coder/SKILL.md +184 -0
  289. package/skills/modern-javascript-patterns/SKILL.md +35 -0
  290. package/skills/modern-javascript-patterns/resources/implementation-playbook.md +910 -0
  291. package/skills/monorepo-architect/SKILL.md +61 -0
  292. package/skills/monorepo-management/SKILL.md +35 -0
  293. package/skills/monorepo-management/resources/implementation-playbook.md +621 -0
  294. package/skills/mtls-configuration/SKILL.md +359 -0
  295. package/skills/multi-cloud-architecture/SKILL.md +189 -0
  296. package/skills/multi-platform-apps-multi-platform/SKILL.md +203 -0
  297. package/skills/network-engineer/SKILL.md +169 -0
  298. package/skills/nextjs-app-router-patterns/SKILL.md +33 -0
  299. package/skills/nextjs-app-router-patterns/resources/implementation-playbook.md +543 -0
  300. package/skills/nft-standards/SKILL.md +395 -0
  301. package/skills/node-expert/SKILL.md +23 -0
  302. package/skills/nodejs-backend-patterns/SKILL.md +35 -0
  303. package/skills/nodejs-backend-patterns/resources/implementation-playbook.md +1019 -0
  304. package/skills/nx-workspace-patterns/SKILL.md +464 -0
  305. package/skills/observability-engineer/SKILL.md +237 -0
  306. package/skills/observability-monitoring-monitor-setup/SKILL.md +48 -0
  307. package/skills/observability-monitoring-monitor-setup/resources/implementation-playbook.md +505 -0
  308. package/skills/observability-monitoring-slo-implement/SKILL.md +43 -0
  309. package/skills/observability-monitoring-slo-implement/resources/implementation-playbook.md +1077 -0
  310. package/skills/on-call-handoff-patterns/SKILL.md +453 -0
  311. package/skills/openapi-spec-generation/SKILL.md +33 -0
  312. package/skills/openapi-spec-generation/resources/implementation-playbook.md +1027 -0
  313. package/skills/payment-integration/SKILL.md +77 -0
  314. package/skills/paypal-integration/SKILL.md +479 -0
  315. package/skills/pci-compliance/SKILL.md +478 -0
  316. package/skills/performance-engineer/SKILL.md +180 -0
  317. package/skills/performance-testing-review-ai-review/SKILL.md +450 -0
  318. package/skills/performance-testing-review-multi-agent-review/SKILL.md +216 -0
  319. package/skills/php-pro/SKILL.md +63 -0
  320. package/skills/posix-shell-pro/SKILL.md +304 -0
  321. package/skills/postgresql/SKILL.md +230 -0
  322. package/skills/postmortem-writing/SKILL.md +386 -0
  323. package/skills/projection-patterns/SKILL.md +33 -0
  324. package/skills/projection-patterns/resources/implementation-playbook.md +501 -0
  325. package/skills/prometheus-configuration/SKILL.md +404 -0
  326. package/skills/prompt-engineer/SKILL.md +272 -0
  327. package/skills/prompt-engineering-patterns/SKILL.md +213 -0
  328. package/skills/prompt-engineering-patterns/assets/few-shot-examples.json +106 -0
  329. package/skills/prompt-engineering-patterns/assets/prompt-template-library.md +246 -0
  330. package/skills/prompt-engineering-patterns/references/chain-of-thought.md +399 -0
  331. package/skills/prompt-engineering-patterns/references/few-shot-learning.md +369 -0
  332. package/skills/prompt-engineering-patterns/references/prompt-optimization.md +414 -0
  333. package/skills/prompt-engineering-patterns/references/prompt-templates.md +470 -0
  334. package/skills/prompt-engineering-patterns/references/system-prompts.md +189 -0
  335. package/skills/prompt-engineering-patterns/scripts/optimize-prompt.py +279 -0
  336. package/skills/protocol-reverse-engineering/SKILL.md +29 -0
  337. package/skills/protocol-reverse-engineering/resources/implementation-playbook.md +509 -0
  338. package/skills/python-development-python-scaffold/SKILL.md +331 -0
  339. package/skills/python-packaging/SKILL.md +36 -0
  340. package/skills/python-packaging/resources/implementation-playbook.md +869 -0
  341. package/skills/python-performance-optimization/SKILL.md +36 -0
  342. package/skills/python-performance-optimization/resources/implementation-playbook.md +868 -0
  343. package/skills/python-pro/SKILL.md +158 -0
  344. package/skills/python-testing-patterns/SKILL.md +37 -0
  345. package/skills/python-testing-patterns/resources/implementation-playbook.md +906 -0
  346. package/skills/quant-analyst/SKILL.md +53 -0
  347. package/skills/rag-implementation/SKILL.md +421 -0
  348. package/skills/react-modernization/SKILL.md +34 -0
  349. package/skills/react-modernization/resources/implementation-playbook.md +512 -0
  350. package/skills/react-native-architecture/SKILL.md +33 -0
  351. package/skills/react-native-architecture/resources/implementation-playbook.md +670 -0
  352. package/skills/react-state-management/SKILL.md +441 -0
  353. package/skills/reference-builder/SKILL.md +188 -0
  354. package/skills/reverse-engineer/SKILL.md +173 -0
  355. package/skills/risk-manager/SKILL.md +61 -0
  356. package/skills/risk-metrics-calculation/SKILL.md +33 -0
  357. package/skills/risk-metrics-calculation/resources/implementation-playbook.md +554 -0
  358. package/skills/ruby-pro/SKILL.md +56 -0
  359. package/skills/rust-async-patterns/SKILL.md +33 -0
  360. package/skills/rust-async-patterns/resources/implementation-playbook.md +516 -0
  361. package/skills/rust-pro/SKILL.md +178 -0
  362. package/skills/saga-orchestration/SKILL.md +496 -0
  363. package/skills/sales-automator/SKILL.md +55 -0
  364. package/skills/sast-configuration/SKILL.md +212 -0
  365. package/skills/scala-pro/SKILL.md +82 -0
  366. package/skills/screen-reader-testing/SKILL.md +33 -0
  367. package/skills/screen-reader-testing/resources/implementation-playbook.md +544 -0
  368. package/skills/search-specialist/SKILL.md +80 -0
  369. package/skills/secrets-management/SKILL.md +364 -0
  370. package/skills/security-auditor/SKILL.md +169 -0
  371. package/skills/security-compliance-compliance-check/SKILL.md +55 -0
  372. package/skills/security-compliance-compliance-check/resources/implementation-playbook.md +963 -0
  373. package/skills/security-requirement-extraction/SKILL.md +33 -0
  374. package/skills/security-requirement-extraction/resources/implementation-playbook.md +676 -0
  375. package/skills/security-scanning-security-dependencies/SKILL.md +43 -0
  376. package/skills/security-scanning-security-dependencies/resources/implementation-playbook.md +544 -0
  377. package/skills/security-scanning-security-hardening/SKILL.md +147 -0
  378. package/skills/security-scanning-security-sast/SKILL.md +495 -0
  379. package/skills/seo-authority-builder/SKILL.md +136 -0
  380. package/skills/seo-cannibalization-detector/SKILL.md +123 -0
  381. package/skills/seo-content-auditor/SKILL.md +83 -0
  382. package/skills/seo-content-planner/SKILL.md +108 -0
  383. package/skills/seo-content-refresher/SKILL.md +118 -0
  384. package/skills/seo-content-writer/SKILL.md +96 -0
  385. package/skills/seo-keyword-strategist/SKILL.md +95 -0
  386. package/skills/seo-meta-optimizer/SKILL.md +92 -0
  387. package/skills/seo-snippet-hunter/SKILL.md +114 -0
  388. package/skills/seo-structure-architect/SKILL.md +108 -0
  389. package/skills/service-mesh-expert/SKILL.md +58 -0
  390. package/skills/service-mesh-observability/SKILL.md +395 -0
  391. package/skills/shellcheck-configuration/SKILL.md +466 -0
  392. package/skills/similarity-search-patterns/SKILL.md +33 -0
  393. package/skills/similarity-search-patterns/resources/implementation-playbook.md +557 -0
  394. package/skills/slo-implementation/SKILL.md +341 -0
  395. package/skills/solidity-security/SKILL.md +34 -0
  396. package/skills/solidity-security/resources/implementation-playbook.md +524 -0
  397. package/skills/spark-optimization/SKILL.md +427 -0
  398. package/skills/sql-optimization-patterns/SKILL.md +35 -0
  399. package/skills/sql-optimization-patterns/resources/implementation-playbook.md +504 -0
  400. package/skills/sql-pro/SKILL.md +173 -0
  401. package/skills/startup-analyst/SKILL.md +328 -0
  402. package/skills/startup-business-analyst-business-case/SKILL.md +487 -0
  403. package/skills/startup-business-analyst-financial-projections/SKILL.md +353 -0
  404. package/skills/startup-business-analyst-market-opportunity/SKILL.md +240 -0
  405. package/skills/startup-financial-modeling/SKILL.md +467 -0
  406. package/skills/startup-metrics-framework/SKILL.md +34 -0
  407. package/skills/startup-metrics-framework/resources/implementation-playbook.md +500 -0
  408. package/skills/stride-analysis-patterns/SKILL.md +33 -0
  409. package/skills/stride-analysis-patterns/resources/implementation-playbook.md +655 -0
  410. package/skills/stripe-integration/SKILL.md +454 -0
  411. package/skills/systems-programming-rust-project/SKILL.md +440 -0
  412. package/skills/tailwind-design-system/SKILL.md +33 -0
  413. package/skills/tailwind-design-system/resources/implementation-playbook.md +665 -0
  414. package/skills/tdd-orchestrator/SKILL.md +205 -0
  415. package/skills/tdd-workflows-tdd-cycle/SKILL.md +221 -0
  416. package/skills/tdd-workflows-tdd-green/SKILL.md +73 -0
  417. package/skills/tdd-workflows-tdd-green/resources/implementation-playbook.md +870 -0
  418. package/skills/tdd-workflows-tdd-red/SKILL.md +164 -0
  419. package/skills/tdd-workflows-tdd-refactor/SKILL.md +187 -0
  420. package/skills/team-collaboration-issue/SKILL.md +37 -0
  421. package/skills/team-collaboration-issue/resources/implementation-playbook.md +640 -0
  422. package/skills/team-collaboration-standup-notes/SKILL.md +44 -0
  423. package/skills/team-collaboration-standup-notes/resources/implementation-playbook.md +768 -0
  424. package/skills/team-composition-analysis/SKILL.md +413 -0
  425. package/skills/temporal-python-pro/SKILL.md +370 -0
  426. package/skills/temporal-python-testing/SKILL.md +170 -0
  427. package/skills/temporal-python-testing/resources/integration-testing.md +455 -0
  428. package/skills/temporal-python-testing/resources/local-setup.md +553 -0
  429. package/skills/temporal-python-testing/resources/replay-testing.md +462 -0
  430. package/skills/temporal-python-testing/resources/unit-testing.md +328 -0
  431. package/skills/terraform-module-library/SKILL.md +261 -0
  432. package/skills/terraform-module-library/references/aws-modules.md +63 -0
  433. package/skills/terraform-specialist/SKILL.md +166 -0
  434. package/skills/test-automator/SKILL.md +224 -0
  435. package/skills/threat-mitigation-mapping/SKILL.md +33 -0
  436. package/skills/threat-mitigation-mapping/resources/implementation-playbook.md +744 -0
  437. package/skills/threat-modeling-expert/SKILL.md +60 -0
  438. package/skills/track-management/SKILL.md +38 -0
  439. package/skills/track-management/resources/implementation-playbook.md +591 -0
  440. package/skills/turborepo-caching/SKILL.md +419 -0
  441. package/skills/tutorial-engineer/SKILL.md +139 -0
  442. package/skills/typescript-advanced-types/SKILL.md +35 -0
  443. package/skills/typescript-advanced-types/resources/implementation-playbook.md +716 -0
  444. package/skills/typescript-pro/SKILL.md +55 -0
  445. package/skills/ui-minimal/SKILL.md +23 -0
  446. package/skills/ui-ux-designer/SKILL.md +209 -0
  447. package/skills/ui-visual-validator/SKILL.md +214 -0
  448. package/skills/unit-testing-test-generate/SKILL.md +319 -0
  449. package/skills/unity-developer/SKILL.md +230 -0
  450. package/skills/unity-ecs-patterns/SKILL.md +33 -0
  451. package/skills/unity-ecs-patterns/resources/implementation-playbook.md +625 -0
  452. package/skills/uv-package-manager/SKILL.md +37 -0
  453. package/skills/uv-package-manager/resources/implementation-playbook.md +830 -0
  454. package/skills/vector-database-engineer/SKILL.md +60 -0
  455. package/skills/vector-index-tuning/SKILL.md +42 -0
  456. package/skills/vector-index-tuning/resources/implementation-playbook.md +507 -0
  457. package/skills/wcag-audit-patterns/SKILL.md +41 -0
  458. package/skills/wcag-audit-patterns/resources/implementation-playbook.md +541 -0
  459. package/skills/web3-testing/SKILL.md +427 -0
  460. package/skills/workflow-orchestration-patterns/SKILL.md +333 -0
  461. package/skills/workflow-patterns/SKILL.md +38 -0
  462. package/skills/workflow-patterns/resources/implementation-playbook.md +621 -0
@@ -0,0 +1,305 @@
1
+ "use strict";
2
+ const fs = require('fs');
3
+ const path = require('path');
4
+ const { listSkillIds, readSkill, tokenize, unique, } = require('../lib/skill-utils');
5
+ const ROOT = path.resolve(__dirname, '..');
6
+ const SKILLS_DIR = path.join(ROOT, 'skills');
7
+ const STOPWORDS = new Set([
8
+ 'a', 'an', 'and', 'are', 'as', 'at', 'be', 'but', 'by', 'for', 'from', 'has', 'have', 'in', 'into',
9
+ 'is', 'it', 'its', 'of', 'on', 'or', 'our', 'out', 'over', 'that', 'the', 'their', 'they', 'this',
10
+ 'to', 'use', 'when', 'with', 'you', 'your', 'will', 'can', 'if', 'not', 'only', 'also', 'more',
11
+ 'best', 'practice', 'practices', 'expert', 'specialist', 'focused', 'focus', 'master', 'modern',
12
+ 'advanced', 'comprehensive', 'production', 'production-ready', 'ready', 'build', 'create', 'deliver',
13
+ 'design', 'implement', 'implementation', 'strategy', 'strategies', 'patterns', 'pattern', 'workflow',
14
+ 'workflows', 'guide', 'template', 'templates', 'tool', 'tools', 'project', 'projects', 'support',
15
+ 'manage', 'management', 'system', 'systems', 'services', 'service', 'across', 'end', 'end-to-end',
16
+ 'using', 'based', 'ensure', 'ensure', 'help', 'needs', 'need', 'focuses', 'handles', 'builds', 'make',
17
+ ]);
18
+ const TAG_STOPWORDS = new Set([
19
+ 'pro', 'expert', 'patterns', 'pattern', 'workflow', 'workflows', 'templates', 'template', 'toolkit',
20
+ 'tools', 'tool', 'project', 'projects', 'guide', 'management', 'engineer', 'architect', 'developer',
21
+ 'specialist', 'assistant', 'analysis', 'review', 'reviewer', 'automation', 'orchestration', 'scaffold',
22
+ 'scaffolding', 'implementation', 'strategy', 'context', 'management', 'feature', 'features', 'smart',
23
+ 'system', 'systems', 'design', 'development', 'development', 'test', 'testing', 'workflow',
24
+ ]);
25
+ const CATEGORY_RULES = [
26
+ {
27
+ name: 'security',
28
+ keywords: [
29
+ 'security', 'sast', 'compliance', 'privacy', 'threat', 'vulnerability', 'owasp', 'pci', 'gdpr',
30
+ 'secrets', 'risk', 'malware', 'forensics', 'attack', 'incident', 'auth', 'mtls', 'zero', 'trust',
31
+ ],
32
+ },
33
+ {
34
+ name: 'infrastructure',
35
+ keywords: [
36
+ 'kubernetes', 'k8s', 'helm', 'terraform', 'cloud', 'network', 'devops', 'gitops', 'prometheus',
37
+ 'grafana', 'observability', 'monitoring', 'logging', 'tracing', 'deployment', 'istio', 'linkerd',
38
+ 'service', 'mesh', 'slo', 'sre', 'oncall', 'incident', 'pipeline', 'cicd', 'ci', 'cd', 'kafka',
39
+ ],
40
+ },
41
+ {
42
+ name: 'data-ai',
43
+ keywords: [
44
+ 'data', 'database', 'db', 'sql', 'postgres', 'mysql', 'analytics', 'etl', 'warehouse', 'dbt',
45
+ 'ml', 'ai', 'llm', 'rag', 'vector', 'embedding', 'spark', 'airflow', 'cdc', 'pipeline',
46
+ ],
47
+ },
48
+ {
49
+ name: 'development',
50
+ keywords: [
51
+ 'python', 'javascript', 'typescript', 'java', 'golang', 'go', 'rust', 'csharp', 'dotnet', 'php',
52
+ 'ruby', 'node', 'react', 'frontend', 'backend', 'mobile', 'ios', 'android', 'flutter', 'fastapi',
53
+ 'django', 'nextjs', 'vue', 'api',
54
+ ],
55
+ },
56
+ {
57
+ name: 'architecture',
58
+ keywords: [
59
+ 'architecture', 'c4', 'microservices', 'event', 'cqrs', 'saga', 'domain', 'ddd', 'patterns',
60
+ 'decision', 'adr',
61
+ ],
62
+ },
63
+ {
64
+ name: 'testing',
65
+ keywords: ['testing', 'tdd', 'unit', 'e2e', 'qa', 'test'],
66
+ },
67
+ {
68
+ name: 'business',
69
+ keywords: [
70
+ 'business', 'market', 'sales', 'finance', 'startup', 'legal', 'hr', 'product', 'customer', 'seo',
71
+ 'marketing', 'kpi', 'contract', 'employment',
72
+ ],
73
+ },
74
+ {
75
+ name: 'workflow',
76
+ keywords: ['workflow', 'orchestration', 'conductor', 'automation', 'process', 'collaboration'],
77
+ },
78
+ ];
79
+ const BUNDLE_RULES = {
80
+ 'core-dev': {
81
+ description: 'Core development skills across languages, frameworks, and backend/frontend fundamentals.',
82
+ keywords: [
83
+ 'python', 'javascript', 'typescript', 'go', 'golang', 'rust', 'java', 'node', 'frontend', 'backend',
84
+ 'react', 'fastapi', 'django', 'nextjs', 'api', 'mobile', 'ios', 'android', 'flutter', 'php', 'ruby',
85
+ ],
86
+ },
87
+ 'security-core': {
88
+ description: 'Security, privacy, and compliance essentials.',
89
+ keywords: [
90
+ 'security', 'sast', 'compliance', 'threat', 'risk', 'privacy', 'secrets', 'owasp', 'gdpr', 'pci',
91
+ 'vulnerability', 'auth',
92
+ ],
93
+ },
94
+ 'k8s-core': {
95
+ description: 'Kubernetes and service mesh essentials.',
96
+ keywords: ['kubernetes', 'k8s', 'helm', 'istio', 'linkerd', 'service', 'mesh'],
97
+ },
98
+ 'data-core': {
99
+ description: 'Data engineering and analytics foundations.',
100
+ keywords: [
101
+ 'data', 'database', 'sql', 'dbt', 'airflow', 'spark', 'analytics', 'etl', 'warehouse', 'postgres',
102
+ 'mysql', 'kafka',
103
+ ],
104
+ },
105
+ 'ops-core': {
106
+ description: 'Operations, observability, and delivery pipelines.',
107
+ keywords: [
108
+ 'observability', 'monitoring', 'logging', 'tracing', 'prometheus', 'grafana', 'devops', 'gitops',
109
+ 'deployment', 'cicd', 'pipeline', 'slo', 'sre', 'incident',
110
+ ],
111
+ },
112
+ };
113
+ const CURATED_COMMON = [
114
+ 'bash-pro',
115
+ 'python-pro',
116
+ 'javascript-pro',
117
+ 'typescript-pro',
118
+ 'golang-pro',
119
+ 'rust-pro',
120
+ 'java-pro',
121
+ 'frontend-developer',
122
+ 'backend-architect',
123
+ 'nodejs-backend-patterns',
124
+ 'fastapi-pro',
125
+ 'api-design-principles',
126
+ 'sql-pro',
127
+ 'database-architect',
128
+ 'kubernetes-architect',
129
+ 'terraform-specialist',
130
+ 'observability-engineer',
131
+ 'security-auditor',
132
+ 'sast-configuration',
133
+ 'gitops-workflow',
134
+ ];
135
+ function normalizeTokens(tokens) {
136
+ return unique(tokens.map(token => token.toLowerCase())).filter(Boolean);
137
+ }
138
+ function deriveTags(skill) {
139
+ let tags = Array.isArray(skill.tags) ? skill.tags : [];
140
+ tags = tags.map(tag => tag.toLowerCase()).filter(Boolean);
141
+ if (!tags.length) {
142
+ tags = skill.id
143
+ .split('-')
144
+ .map(tag => tag.toLowerCase())
145
+ .filter(tag => tag && !TAG_STOPWORDS.has(tag));
146
+ }
147
+ return normalizeTokens(tags);
148
+ }
149
+ function detectCategory(skill, tags) {
150
+ const haystack = normalizeTokens([
151
+ ...tags,
152
+ ...tokenize(skill.name),
153
+ ...tokenize(skill.description),
154
+ ]);
155
+ const haystackSet = new Set(haystack);
156
+ for (const rule of CATEGORY_RULES) {
157
+ for (const keyword of rule.keywords) {
158
+ if (haystackSet.has(keyword)) {
159
+ return rule.name;
160
+ }
161
+ }
162
+ }
163
+ return 'general';
164
+ }
165
+ function buildTriggers(skill, tags) {
166
+ const tokens = tokenize(`${skill.name} ${skill.description}`)
167
+ .filter(token => token.length >= 2 && !STOPWORDS.has(token));
168
+ return unique([...tags, ...tokens]).slice(0, 12);
169
+ }
170
+ function buildAliases(skills) {
171
+ const existingIds = new Set(skills.map(skill => skill.id));
172
+ const aliases = {};
173
+ const used = new Set();
174
+ for (const skill of skills) {
175
+ if (skill.name && skill.name !== skill.id) {
176
+ const alias = skill.name.toLowerCase();
177
+ if (!existingIds.has(alias) && !used.has(alias)) {
178
+ aliases[alias] = skill.id;
179
+ used.add(alias);
180
+ }
181
+ }
182
+ const tokens = skill.id.split('-').filter(Boolean);
183
+ if (skill.id.length < 28 || tokens.length < 4)
184
+ continue;
185
+ const deduped = [];
186
+ const tokenSeen = new Set();
187
+ for (const token of tokens) {
188
+ if (tokenSeen.has(token))
189
+ continue;
190
+ tokenSeen.add(token);
191
+ deduped.push(token);
192
+ }
193
+ const aliasTokens = deduped.length > 3
194
+ ? [deduped[0], deduped[1], deduped[deduped.length - 1]]
195
+ : deduped;
196
+ const alias = unique(aliasTokens).join('-');
197
+ if (!alias || alias === skill.id)
198
+ continue;
199
+ if (existingIds.has(alias) || used.has(alias))
200
+ continue;
201
+ aliases[alias] = skill.id;
202
+ used.add(alias);
203
+ }
204
+ return aliases;
205
+ }
206
+ function buildBundles(skills) {
207
+ const bundles = {};
208
+ const skillTokens = new Map();
209
+ for (const skill of skills) {
210
+ const tokens = normalizeTokens([
211
+ ...skill.tags,
212
+ ...tokenize(skill.name),
213
+ ...tokenize(skill.description),
214
+ ]);
215
+ skillTokens.set(skill.id, new Set(tokens));
216
+ }
217
+ for (const [bundleName, rule] of Object.entries(BUNDLE_RULES)) {
218
+ const bundleSkills = [];
219
+ const keywords = rule.keywords.map(keyword => keyword.toLowerCase());
220
+ for (const skill of skills) {
221
+ const tokenSet = skillTokens.get(skill.id) || new Set();
222
+ if (keywords.some(keyword => tokenSet.has(keyword))) {
223
+ bundleSkills.push(skill.id);
224
+ }
225
+ }
226
+ bundles[bundleName] = {
227
+ description: rule.description,
228
+ skills: bundleSkills.sort(),
229
+ };
230
+ }
231
+ const common = CURATED_COMMON.filter(skillId => skillTokens.has(skillId));
232
+ return { bundles, common };
233
+ }
234
+ function truncate(value, limit) {
235
+ if (!value || value.length <= limit)
236
+ return value || '';
237
+ return `${value.slice(0, limit - 3)}...`;
238
+ }
239
+ function renderCatalogMarkdown(catalog) {
240
+ const lines = [];
241
+ lines.push('# Skill Catalog');
242
+ lines.push('');
243
+ lines.push(`Generated at: ${catalog.generatedAt}`);
244
+ lines.push('');
245
+ lines.push(`Total skills: ${catalog.total}`);
246
+ lines.push('');
247
+ const categories = Array.from(new Set(catalog.skills.map(skill => skill.category))).sort();
248
+ for (const category of categories) {
249
+ const grouped = catalog.skills.filter(skill => skill.category === category);
250
+ lines.push(`## ${category} (${grouped.length})`);
251
+ lines.push('');
252
+ lines.push('| Skill | Description | Tags | Triggers |');
253
+ lines.push('| --- | --- | --- | --- |');
254
+ for (const skill of grouped) {
255
+ const description = truncate(skill.description, 160).replace(/\|/g, '\\|');
256
+ const tags = skill.tags.join(', ');
257
+ const triggers = skill.triggers.join(', ');
258
+ lines.push(`| \`${skill.id}\` | ${description} | ${tags} | ${triggers} |`);
259
+ }
260
+ lines.push('');
261
+ }
262
+ return lines.join('\n');
263
+ }
264
+ function buildCatalog() {
265
+ const skillIds = listSkillIds(SKILLS_DIR);
266
+ const skills = skillIds.map(skillId => readSkill(SKILLS_DIR, skillId));
267
+ const catalogSkills = [];
268
+ for (const skill of skills) {
269
+ const tags = deriveTags(skill);
270
+ const category = detectCategory(skill, tags);
271
+ const triggers = buildTriggers(skill, tags);
272
+ catalogSkills.push({
273
+ id: skill.id,
274
+ name: skill.name,
275
+ description: skill.description,
276
+ category,
277
+ tags,
278
+ triggers,
279
+ path: path.relative(ROOT, skill.path),
280
+ });
281
+ }
282
+ const catalog = {
283
+ generatedAt: new Date().toISOString(),
284
+ total: catalogSkills.length,
285
+ skills: catalogSkills.sort((a, b) => a.id.localeCompare(b.id)),
286
+ };
287
+ const aliases = buildAliases(catalog.skills);
288
+ const bundleData = buildBundles(catalog.skills);
289
+ const catalogPath = path.join(ROOT, 'catalog.json');
290
+ const catalogMarkdownPath = path.join(ROOT, 'CATALOG.md');
291
+ const bundlesPath = path.join(ROOT, 'bundles.json');
292
+ const aliasesPath = path.join(ROOT, 'aliases.json');
293
+ fs.writeFileSync(catalogPath, JSON.stringify(catalog, null, 2));
294
+ fs.writeFileSync(catalogMarkdownPath, renderCatalogMarkdown(catalog));
295
+ fs.writeFileSync(bundlesPath, JSON.stringify({ generatedAt: catalog.generatedAt, ...bundleData }, null, 2));
296
+ fs.writeFileSync(aliasesPath, JSON.stringify({ generatedAt: catalog.generatedAt, aliases }, null, 2));
297
+ return catalog;
298
+ }
299
+ if (require.main === module) {
300
+ const catalog = buildCatalog();
301
+ console.log(`Generated catalog for ${catalog.total} skills.`);
302
+ }
303
+ module.exports = {
304
+ buildCatalog,
305
+ };
@@ -0,0 +1,144 @@
1
+ "use strict";
2
+ const fs = require('fs');
3
+ const path = require('path');
4
+ const yaml = require('yaml');
5
+ const { listSkillIds, parseFrontmatter } = require('../lib/skill-utils');
6
+ const ROOT = path.resolve(__dirname, '..');
7
+ const SKILLS_DIR = path.join(ROOT, 'skills');
8
+ const ALLOWED_FIELDS = new Set([
9
+ 'name',
10
+ 'description',
11
+ 'license',
12
+ 'compatibility',
13
+ 'metadata',
14
+ 'allowed-tools',
15
+ ]);
16
+ function isPlainObject(value) {
17
+ return value && typeof value === 'object' && !Array.isArray(value);
18
+ }
19
+ function coerceToString(value) {
20
+ if (value === null || value === undefined)
21
+ return '';
22
+ if (typeof value === 'string')
23
+ return value.trim();
24
+ if (typeof value === 'number' || typeof value === 'boolean')
25
+ return String(value);
26
+ if (Array.isArray(value)) {
27
+ const simple = value.every(item => ['string', 'number', 'boolean'].includes(typeof item));
28
+ return simple ? value.map(item => String(item).trim()).filter(Boolean).join(', ') : JSON.stringify(value);
29
+ }
30
+ if (isPlainObject(value)) {
31
+ return JSON.stringify(value);
32
+ }
33
+ return String(value).trim();
34
+ }
35
+ function appendMetadata(metadata, key, value) {
36
+ const nextValue = coerceToString(value);
37
+ if (!nextValue)
38
+ return;
39
+ if (!metadata[key]) {
40
+ metadata[key] = nextValue;
41
+ return;
42
+ }
43
+ if (metadata[key].includes(nextValue))
44
+ return;
45
+ metadata[key] = `${metadata[key]}, ${nextValue}`;
46
+ }
47
+ function collectAllowedTools(value, toolSet) {
48
+ if (!value)
49
+ return;
50
+ if (typeof value === 'string') {
51
+ value
52
+ .split(/[\s,]+/)
53
+ .map(token => token.trim())
54
+ .filter(Boolean)
55
+ .forEach(token => toolSet.add(token));
56
+ return;
57
+ }
58
+ if (Array.isArray(value)) {
59
+ value
60
+ .map(token => String(token).trim())
61
+ .filter(Boolean)
62
+ .forEach(token => toolSet.add(token));
63
+ }
64
+ }
65
+ function normalizeSkill(skillId) {
66
+ const skillPath = path.join(SKILLS_DIR, skillId, 'SKILL.md');
67
+ const content = fs.readFileSync(skillPath, 'utf8');
68
+ const { data, body, hasFrontmatter } = parseFrontmatter(content);
69
+ if (!hasFrontmatter)
70
+ return false;
71
+ let modified = false;
72
+ const updated = { ...data };
73
+ const metadata = isPlainObject(updated.metadata) ? { ...updated.metadata } : {};
74
+ if (updated.metadata !== undefined && !isPlainObject(updated.metadata)) {
75
+ appendMetadata(metadata, 'legacy_metadata', updated.metadata);
76
+ modified = true;
77
+ }
78
+ const allowedTools = new Set();
79
+ collectAllowedTools(updated['allowed-tools'], allowedTools);
80
+ collectAllowedTools(updated.tools, allowedTools);
81
+ collectAllowedTools(updated.tool_access, allowedTools);
82
+ if (updated.tools !== undefined) {
83
+ delete updated.tools;
84
+ modified = true;
85
+ }
86
+ if (updated.tool_access !== undefined) {
87
+ delete updated.tool_access;
88
+ modified = true;
89
+ }
90
+ for (const key of Object.keys(updated)) {
91
+ if (ALLOWED_FIELDS.has(key))
92
+ continue;
93
+ if (key === 'tags') {
94
+ appendMetadata(metadata, 'tags', updated[key]);
95
+ }
96
+ else {
97
+ appendMetadata(metadata, key, updated[key]);
98
+ }
99
+ delete updated[key];
100
+ modified = true;
101
+ }
102
+ if (allowedTools.size) {
103
+ updated['allowed-tools'] = Array.from(allowedTools).join(' ');
104
+ modified = true;
105
+ }
106
+ else if (updated['allowed-tools'] !== undefined) {
107
+ delete updated['allowed-tools'];
108
+ modified = true;
109
+ }
110
+ if (Object.keys(metadata).length) {
111
+ updated.metadata = metadata;
112
+ modified = true;
113
+ }
114
+ else if (updated.metadata !== undefined) {
115
+ delete updated.metadata;
116
+ modified = true;
117
+ }
118
+ if (!modified)
119
+ return false;
120
+ const ordered = {};
121
+ for (const key of ['name', 'description', 'license', 'compatibility', 'allowed-tools', 'metadata']) {
122
+ if (updated[key] !== undefined) {
123
+ ordered[key] = updated[key];
124
+ }
125
+ }
126
+ const fm = yaml.stringify(ordered).trimEnd();
127
+ const bodyPrefix = body.length && (body.startsWith('\n') || body.startsWith('\r\n')) ? '' : '\n';
128
+ const next = `---\n${fm}\n---${bodyPrefix}${body}`;
129
+ fs.writeFileSync(skillPath, next);
130
+ return true;
131
+ }
132
+ function run() {
133
+ const skillIds = listSkillIds(SKILLS_DIR);
134
+ let updatedCount = 0;
135
+ for (const skillId of skillIds) {
136
+ if (normalizeSkill(skillId))
137
+ updatedCount += 1;
138
+ }
139
+ console.log(`Normalized frontmatter for ${updatedCount} skills.`);
140
+ }
141
+ if (require.main === module) {
142
+ run();
143
+ }
144
+ module.exports = { run };
@@ -0,0 +1,230 @@
1
+ "use strict";
2
+ const fs = require('fs');
3
+ const path = require('path');
4
+ const { listSkillIds, parseFrontmatter } = require('../lib/skill-utils');
5
+ const ROOT = path.resolve(__dirname, '..');
6
+ const SKILLS_DIR = path.join(ROOT, 'skills');
7
+ const BASELINE_PATH = path.join(ROOT, 'validation-baseline.json');
8
+ const errors = [];
9
+ const warnings = [];
10
+ const missingUseSection = [];
11
+ const missingDoNotUseSection = [];
12
+ const missingInstructionsSection = [];
13
+ const longFiles = [];
14
+ const unknownFieldSkills = [];
15
+ const isStrict = process.argv.includes('--strict')
16
+ || process.env.STRICT === '1'
17
+ || process.env.STRICT === 'true';
18
+ const writeBaseline = process.argv.includes('--write-baseline')
19
+ || process.env.WRITE_BASELINE === '1'
20
+ || process.env.WRITE_BASELINE === 'true';
21
+ const NAME_PATTERN = /^[a-z0-9]+(?:-[a-z0-9]+)*$/;
22
+ const MAX_NAME_LENGTH = 64;
23
+ const MAX_DESCRIPTION_LENGTH = 1024;
24
+ const MAX_COMPATIBILITY_LENGTH = 500;
25
+ const MAX_SKILL_LINES = 500;
26
+ const ALLOWED_FIELDS = new Set([
27
+ 'name',
28
+ 'description',
29
+ 'license',
30
+ 'compatibility',
31
+ 'metadata',
32
+ 'allowed-tools',
33
+ ]);
34
+ function isPlainObject(value) {
35
+ return value && typeof value === 'object' && !Array.isArray(value);
36
+ }
37
+ function validateStringField(fieldName, value, { min = 1, max = Infinity } = {}) {
38
+ if (typeof value !== 'string') {
39
+ return `${fieldName} must be a string.`;
40
+ }
41
+ const trimmed = value.trim();
42
+ if (!trimmed) {
43
+ return `${fieldName} cannot be empty.`;
44
+ }
45
+ if (trimmed.length < min) {
46
+ return `${fieldName} must be at least ${min} characters.`;
47
+ }
48
+ if (trimmed.length > max) {
49
+ return `${fieldName} must be <= ${max} characters.`;
50
+ }
51
+ return null;
52
+ }
53
+ function addError(message) {
54
+ errors.push(message);
55
+ }
56
+ function addWarning(message) {
57
+ warnings.push(message);
58
+ }
59
+ function loadBaseline() {
60
+ if (!fs.existsSync(BASELINE_PATH)) {
61
+ return {
62
+ useSection: [],
63
+ doNotUseSection: [],
64
+ instructionsSection: [],
65
+ longFile: [],
66
+ };
67
+ }
68
+ try {
69
+ const parsed = JSON.parse(fs.readFileSync(BASELINE_PATH, 'utf8'));
70
+ return {
71
+ useSection: Array.isArray(parsed.useSection) ? parsed.useSection : [],
72
+ doNotUseSection: Array.isArray(parsed.doNotUseSection) ? parsed.doNotUseSection : [],
73
+ instructionsSection: Array.isArray(parsed.instructionsSection) ? parsed.instructionsSection : [],
74
+ longFile: Array.isArray(parsed.longFile) ? parsed.longFile : [],
75
+ };
76
+ }
77
+ catch (err) {
78
+ addWarning('Failed to parse validation-baseline.json; strict mode may fail.');
79
+ return { useSection: [], doNotUseSection: [], instructionsSection: [], longFile: [] };
80
+ }
81
+ }
82
+ function addStrictSectionErrors(label, missing, baselineSet) {
83
+ if (!isStrict)
84
+ return;
85
+ const strictMissing = missing.filter(skillId => !baselineSet.has(skillId));
86
+ if (strictMissing.length) {
87
+ addError(`Missing "${label}" section (strict): ${strictMissing.length} skills (examples: ${strictMissing.slice(0, 5).join(', ')})`);
88
+ }
89
+ }
90
+ const skillIds = listSkillIds(SKILLS_DIR);
91
+ const baseline = loadBaseline();
92
+ const baselineUse = new Set(baseline.useSection || []);
93
+ const baselineDoNotUse = new Set(baseline.doNotUseSection || []);
94
+ const baselineInstructions = new Set(baseline.instructionsSection || []);
95
+ const baselineLongFile = new Set(baseline.longFile || []);
96
+ for (const skillId of skillIds) {
97
+ const skillPath = path.join(SKILLS_DIR, skillId, 'SKILL.md');
98
+ if (!fs.existsSync(skillPath)) {
99
+ addError(`Missing SKILL.md: ${skillId}`);
100
+ continue;
101
+ }
102
+ const content = fs.readFileSync(skillPath, 'utf8');
103
+ const { data, errors: fmErrors, hasFrontmatter } = parseFrontmatter(content);
104
+ const lineCount = content.split(/\r?\n/).length;
105
+ if (!hasFrontmatter) {
106
+ addError(`Missing frontmatter: ${skillId}`);
107
+ }
108
+ if (fmErrors && fmErrors.length) {
109
+ fmErrors.forEach(error => addError(`Frontmatter parse error (${skillId}): ${error}`));
110
+ }
111
+ if (!NAME_PATTERN.test(skillId)) {
112
+ addError(`Folder name must match ${NAME_PATTERN}: ${skillId}`);
113
+ }
114
+ if (data.name !== undefined) {
115
+ const nameError = validateStringField('name', data.name, { min: 1, max: MAX_NAME_LENGTH });
116
+ if (nameError) {
117
+ addError(`${nameError} (${skillId})`);
118
+ }
119
+ else {
120
+ const nameValue = String(data.name).trim();
121
+ if (!NAME_PATTERN.test(nameValue)) {
122
+ addError(`name must match ${NAME_PATTERN}: ${skillId}`);
123
+ }
124
+ if (nameValue !== skillId) {
125
+ addError(`name must match folder name: ${skillId} -> ${nameValue}`);
126
+ }
127
+ }
128
+ }
129
+ const descError = data.description === undefined
130
+ ? 'description is required.'
131
+ : validateStringField('description', data.description, { min: 1, max: MAX_DESCRIPTION_LENGTH });
132
+ if (descError) {
133
+ addError(`${descError} (${skillId})`);
134
+ }
135
+ if (data.license !== undefined) {
136
+ const licenseError = validateStringField('license', data.license, { min: 1, max: 128 });
137
+ if (licenseError) {
138
+ addError(`${licenseError} (${skillId})`);
139
+ }
140
+ }
141
+ if (data.compatibility !== undefined) {
142
+ const compatibilityError = validateStringField('compatibility', data.compatibility, { min: 1, max: MAX_COMPATIBILITY_LENGTH });
143
+ if (compatibilityError) {
144
+ addError(`${compatibilityError} (${skillId})`);
145
+ }
146
+ }
147
+ if (data['allowed-tools'] !== undefined) {
148
+ if (typeof data['allowed-tools'] !== 'string') {
149
+ addError(`allowed-tools must be a space-delimited string. (${skillId})`);
150
+ }
151
+ else if (!data['allowed-tools'].trim()) {
152
+ addError(`allowed-tools cannot be empty. (${skillId})`);
153
+ }
154
+ }
155
+ if (data.metadata !== undefined) {
156
+ if (!isPlainObject(data.metadata)) {
157
+ addError(`metadata must be a string map/object. (${skillId})`);
158
+ }
159
+ else {
160
+ for (const [key, value] of Object.entries(data.metadata)) {
161
+ if (typeof value !== 'string') {
162
+ addError(`metadata.${key} must be a string. (${skillId})`);
163
+ }
164
+ }
165
+ }
166
+ }
167
+ if (data && Object.keys(data).length) {
168
+ const unknownFields = Object.keys(data).filter(key => !ALLOWED_FIELDS.has(key));
169
+ if (unknownFields.length) {
170
+ unknownFieldSkills.push(skillId);
171
+ addError(`Unknown frontmatter fields (${skillId}): ${unknownFields.join(', ')}`);
172
+ }
173
+ }
174
+ if (lineCount > MAX_SKILL_LINES) {
175
+ longFiles.push(skillId);
176
+ }
177
+ if (!content.includes('## Use this skill when')) {
178
+ missingUseSection.push(skillId);
179
+ }
180
+ if (!content.includes('## Do not use')) {
181
+ missingDoNotUseSection.push(skillId);
182
+ }
183
+ if (!content.includes('## Instructions')) {
184
+ missingInstructionsSection.push(skillId);
185
+ }
186
+ }
187
+ if (missingUseSection.length) {
188
+ addWarning(`Missing "Use this skill when" section: ${missingUseSection.length} skills (examples: ${missingUseSection.slice(0, 5).join(', ')})`);
189
+ }
190
+ if (missingDoNotUseSection.length) {
191
+ addWarning(`Missing "Do not use" section: ${missingDoNotUseSection.length} skills (examples: ${missingDoNotUseSection.slice(0, 5).join(', ')})`);
192
+ }
193
+ if (missingInstructionsSection.length) {
194
+ addWarning(`Missing "Instructions" section: ${missingInstructionsSection.length} skills (examples: ${missingInstructionsSection.slice(0, 5).join(', ')})`);
195
+ }
196
+ if (longFiles.length) {
197
+ addWarning(`SKILL.md over ${MAX_SKILL_LINES} lines: ${longFiles.length} skills (examples: ${longFiles.slice(0, 5).join(', ')})`);
198
+ }
199
+ if (unknownFieldSkills.length) {
200
+ addWarning(`Unknown frontmatter fields detected: ${unknownFieldSkills.length} skills (examples: ${unknownFieldSkills.slice(0, 5).join(', ')})`);
201
+ }
202
+ addStrictSectionErrors('Use this skill when', missingUseSection, baselineUse);
203
+ addStrictSectionErrors('Do not use', missingDoNotUseSection, baselineDoNotUse);
204
+ addStrictSectionErrors('Instructions', missingInstructionsSection, baselineInstructions);
205
+ addStrictSectionErrors(`SKILL.md line count <= ${MAX_SKILL_LINES}`, longFiles, baselineLongFile);
206
+ if (writeBaseline) {
207
+ const baselineData = {
208
+ generatedAt: new Date().toISOString(),
209
+ useSection: [...missingUseSection].sort(),
210
+ doNotUseSection: [...missingDoNotUseSection].sort(),
211
+ instructionsSection: [...missingInstructionsSection].sort(),
212
+ longFile: [...longFiles].sort(),
213
+ };
214
+ fs.writeFileSync(BASELINE_PATH, JSON.stringify(baselineData, null, 2));
215
+ console.log(`Baseline written to ${BASELINE_PATH}`);
216
+ }
217
+ if (warnings.length) {
218
+ console.warn('Warnings:');
219
+ for (const warning of warnings) {
220
+ console.warn(`- ${warning}`);
221
+ }
222
+ }
223
+ if (errors.length) {
224
+ console.error('\nErrors:');
225
+ for (const error of errors) {
226
+ console.error(`- ${error}`);
227
+ }
228
+ process.exit(1);
229
+ }
230
+ console.log(`Validation passed for ${skillIds.length} skills.`);
@@ -0,0 +1,2 @@
1
+ #!/usr/bin/env node
2
+ import '../dist/src/cli/index.js';