javi-forge 0.1.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 (500) hide show
  1. package/.gitignore.template +105 -0
  2. package/.releaserc +44 -0
  3. package/README.md +45 -0
  4. package/ai-config/.skillignore +15 -0
  5. package/ai-config/AUTO_INVOKE.md +300 -0
  6. package/ai-config/agents/_TEMPLATE.md +93 -0
  7. package/ai-config/agents/business/api-designer.md +1657 -0
  8. package/ai-config/agents/business/business-analyst.md +1331 -0
  9. package/ai-config/agents/business/product-strategist.md +206 -0
  10. package/ai-config/agents/business/project-manager.md +178 -0
  11. package/ai-config/agents/business/requirements-analyst.md +1277 -0
  12. package/ai-config/agents/business/technical-writer.md +1679 -0
  13. package/ai-config/agents/creative/ux-designer.md +205 -0
  14. package/ai-config/agents/data-ai/ai-engineer.md +487 -0
  15. package/ai-config/agents/data-ai/analytics-engineer.md +953 -0
  16. package/ai-config/agents/data-ai/data-engineer.md +173 -0
  17. package/ai-config/agents/data-ai/data-scientist.md +672 -0
  18. package/ai-config/agents/data-ai/mlops-engineer.md +814 -0
  19. package/ai-config/agents/data-ai/prompt-engineer.md +772 -0
  20. package/ai-config/agents/development/angular-expert.md +620 -0
  21. package/ai-config/agents/development/backend-architect.md +795 -0
  22. package/ai-config/agents/development/database-specialist.md +212 -0
  23. package/ai-config/agents/development/frontend-specialist.md +686 -0
  24. package/ai-config/agents/development/fullstack-engineer.md +668 -0
  25. package/ai-config/agents/development/golang-pro.md +338 -0
  26. package/ai-config/agents/development/java-enterprise.md +400 -0
  27. package/ai-config/agents/development/javascript-pro.md +422 -0
  28. package/ai-config/agents/development/nextjs-pro.md +474 -0
  29. package/ai-config/agents/development/python-pro.md +570 -0
  30. package/ai-config/agents/development/react-pro.md +487 -0
  31. package/ai-config/agents/development/rust-pro.md +246 -0
  32. package/ai-config/agents/development/spring-boot-4-expert.md +326 -0
  33. package/ai-config/agents/development/typescript-pro.md +336 -0
  34. package/ai-config/agents/development/vue-specialist.md +605 -0
  35. package/ai-config/agents/infrastructure/cloud-architect.md +472 -0
  36. package/ai-config/agents/infrastructure/deployment-manager.md +358 -0
  37. package/ai-config/agents/infrastructure/devops-engineer.md +455 -0
  38. package/ai-config/agents/infrastructure/incident-responder.md +519 -0
  39. package/ai-config/agents/infrastructure/kubernetes-expert.md +705 -0
  40. package/ai-config/agents/infrastructure/monitoring-specialist.md +674 -0
  41. package/ai-config/agents/infrastructure/performance-engineer.md +658 -0
  42. package/ai-config/agents/orchestrator.md +241 -0
  43. package/ai-config/agents/quality/accessibility-auditor.md +1204 -0
  44. package/ai-config/agents/quality/code-reviewer-compact.md +123 -0
  45. package/ai-config/agents/quality/code-reviewer.md +363 -0
  46. package/ai-config/agents/quality/dependency-manager.md +743 -0
  47. package/ai-config/agents/quality/e2e-test-specialist.md +1005 -0
  48. package/ai-config/agents/quality/performance-tester.md +1086 -0
  49. package/ai-config/agents/quality/security-auditor.md +133 -0
  50. package/ai-config/agents/quality/test-engineer.md +453 -0
  51. package/ai-config/agents/specialists/api-designer.md +87 -0
  52. package/ai-config/agents/specialists/backend-architect.md +73 -0
  53. package/ai-config/agents/specialists/code-reviewer.md +77 -0
  54. package/ai-config/agents/specialists/db-optimizer.md +75 -0
  55. package/ai-config/agents/specialists/devops-engineer.md +83 -0
  56. package/ai-config/agents/specialists/documentation-writer.md +78 -0
  57. package/ai-config/agents/specialists/frontend-developer.md +75 -0
  58. package/ai-config/agents/specialists/performance-analyst.md +82 -0
  59. package/ai-config/agents/specialists/refactor-specialist.md +74 -0
  60. package/ai-config/agents/specialists/security-auditor.md +74 -0
  61. package/ai-config/agents/specialists/test-engineer.md +81 -0
  62. package/ai-config/agents/specialists/ux-consultant.md +76 -0
  63. package/ai-config/agents/specialized/agent-generator.md +1190 -0
  64. package/ai-config/agents/specialized/blockchain-developer.md +149 -0
  65. package/ai-config/agents/specialized/code-migrator.md +892 -0
  66. package/ai-config/agents/specialized/context-manager.md +978 -0
  67. package/ai-config/agents/specialized/documentation-writer.md +1078 -0
  68. package/ai-config/agents/specialized/ecommerce-expert.md +1756 -0
  69. package/ai-config/agents/specialized/embedded-engineer.md +1714 -0
  70. package/ai-config/agents/specialized/error-detective.md +1034 -0
  71. package/ai-config/agents/specialized/fintech-specialist.md +1659 -0
  72. package/ai-config/agents/specialized/freelance-project-planner-v2.md +1988 -0
  73. package/ai-config/agents/specialized/freelance-project-planner-v3.md +2136 -0
  74. package/ai-config/agents/specialized/freelance-project-planner-v4.md +4503 -0
  75. package/ai-config/agents/specialized/freelance-project-planner.md +722 -0
  76. package/ai-config/agents/specialized/game-developer.md +1963 -0
  77. package/ai-config/agents/specialized/healthcare-dev.md +1620 -0
  78. package/ai-config/agents/specialized/mobile-developer.md +188 -0
  79. package/ai-config/agents/specialized/parallel-plan-executor.md +506 -0
  80. package/ai-config/agents/specialized/plan-executor.md +485 -0
  81. package/ai-config/agents/specialized/solo-dev-planner-modular/00-INDEX.md +485 -0
  82. package/ai-config/agents/specialized/solo-dev-planner-modular/01-CORE.md +3493 -0
  83. package/ai-config/agents/specialized/solo-dev-planner-modular/02-SELF-CORRECTION.md +778 -0
  84. package/ai-config/agents/specialized/solo-dev-planner-modular/03-PROGRESSIVE-SETUP.md +918 -0
  85. package/ai-config/agents/specialized/solo-dev-planner-modular/04-DEPLOYMENT.md +1537 -0
  86. package/ai-config/agents/specialized/solo-dev-planner-modular/05-TESTING.md +2633 -0
  87. package/ai-config/agents/specialized/solo-dev-planner-modular/06-OPERATIONS.md +5610 -0
  88. package/ai-config/agents/specialized/solo-dev-planner-modular/INSTALL.md +335 -0
  89. package/ai-config/agents/specialized/solo-dev-planner-modular/QUICK-REFERENCE.txt +215 -0
  90. package/ai-config/agents/specialized/solo-dev-planner-modular/README.md +260 -0
  91. package/ai-config/agents/specialized/solo-dev-planner-modular/START-HERE.md +379 -0
  92. package/ai-config/agents/specialized/solo-dev-planner-modular/WORKFLOW-DIAGRAM.md +355 -0
  93. package/ai-config/agents/specialized/solo-dev-planner-modular/solo-dev-planner.md +279 -0
  94. package/ai-config/agents/specialized/template-writer.md +347 -0
  95. package/ai-config/agents/specialized/test-runner.md +99 -0
  96. package/ai-config/agents/specialized/vibekanban-smart-worker.md +244 -0
  97. package/ai-config/agents/specialized/wave-executor.md +138 -0
  98. package/ai-config/agents/specialized/workflow-optimizer.md +1114 -0
  99. package/ai-config/commands/git/changelog.md +32 -0
  100. package/ai-config/commands/git/ci-local.md +70 -0
  101. package/ai-config/commands/git/commit.md +35 -0
  102. package/ai-config/commands/git/fix-issue.md +23 -0
  103. package/ai-config/commands/git/pr-create.md +42 -0
  104. package/ai-config/commands/git/pr-review.md +50 -0
  105. package/ai-config/commands/git/worktree.md +39 -0
  106. package/ai-config/commands/refactoring/cleanup.md +24 -0
  107. package/ai-config/commands/refactoring/dead-code.md +40 -0
  108. package/ai-config/commands/refactoring/extract.md +31 -0
  109. package/ai-config/commands/testing/e2e.md +30 -0
  110. package/ai-config/commands/testing/tdd.md +36 -0
  111. package/ai-config/commands/testing/test-coverage.md +30 -0
  112. package/ai-config/commands/testing/test-fix.md +24 -0
  113. package/ai-config/commands/workflow/generate-agents-md.md +85 -0
  114. package/ai-config/commands/workflow/planning.md +47 -0
  115. package/ai-config/commands/workflows/compound.md +89 -0
  116. package/ai-config/commands/workflows/plan.md +77 -0
  117. package/ai-config/commands/workflows/review.md +78 -0
  118. package/ai-config/commands/workflows/work.md +75 -0
  119. package/ai-config/config.yaml +18 -0
  120. package/ai-config/hooks/_TEMPLATE.md +96 -0
  121. package/ai-config/hooks/block-dangerous-commands.md +75 -0
  122. package/ai-config/hooks/commit-guard.md +90 -0
  123. package/ai-config/hooks/context-loader.md +73 -0
  124. package/ai-config/hooks/improve-prompt.md +91 -0
  125. package/ai-config/hooks/learning-log.md +72 -0
  126. package/ai-config/hooks/model-router.md +86 -0
  127. package/ai-config/hooks/secret-scanner.md +64 -0
  128. package/ai-config/hooks/skill-validator.md +102 -0
  129. package/ai-config/hooks/task-artifact.md +114 -0
  130. package/ai-config/hooks/validate-workflow.md +100 -0
  131. package/ai-config/prompts/base.md +71 -0
  132. package/ai-config/prompts/modes/debug.md +34 -0
  133. package/ai-config/prompts/modes/deploy.md +40 -0
  134. package/ai-config/prompts/modes/research.md +32 -0
  135. package/ai-config/prompts/modes/review.md +33 -0
  136. package/ai-config/prompts/review-policy.md +79 -0
  137. package/ai-config/skills/_TEMPLATE.md +157 -0
  138. package/ai-config/skills/backend/api-gateway/SKILL.md +254 -0
  139. package/ai-config/skills/backend/bff-concepts/SKILL.md +239 -0
  140. package/ai-config/skills/backend/bff-spring/SKILL.md +364 -0
  141. package/ai-config/skills/backend/chi-router/SKILL.md +396 -0
  142. package/ai-config/skills/backend/error-handling/SKILL.md +255 -0
  143. package/ai-config/skills/backend/exceptions-spring/SKILL.md +323 -0
  144. package/ai-config/skills/backend/fastapi/SKILL.md +302 -0
  145. package/ai-config/skills/backend/gateway-spring/SKILL.md +390 -0
  146. package/ai-config/skills/backend/go-backend/SKILL.md +457 -0
  147. package/ai-config/skills/backend/gradle-multimodule/SKILL.md +274 -0
  148. package/ai-config/skills/backend/graphql-concepts/SKILL.md +352 -0
  149. package/ai-config/skills/backend/graphql-spring/SKILL.md +398 -0
  150. package/ai-config/skills/backend/grpc-concepts/SKILL.md +283 -0
  151. package/ai-config/skills/backend/grpc-spring/SKILL.md +445 -0
  152. package/ai-config/skills/backend/jwt-auth/SKILL.md +412 -0
  153. package/ai-config/skills/backend/notifications-concepts/SKILL.md +259 -0
  154. package/ai-config/skills/backend/recommendations-concepts/SKILL.md +261 -0
  155. package/ai-config/skills/backend/search-concepts/SKILL.md +263 -0
  156. package/ai-config/skills/backend/search-spring/SKILL.md +375 -0
  157. package/ai-config/skills/backend/spring-boot-4/SKILL.md +172 -0
  158. package/ai-config/skills/backend/websockets/SKILL.md +532 -0
  159. package/ai-config/skills/data-ai/ai-ml/SKILL.md +423 -0
  160. package/ai-config/skills/data-ai/analytics-concepts/SKILL.md +195 -0
  161. package/ai-config/skills/data-ai/analytics-spring/SKILL.md +340 -0
  162. package/ai-config/skills/data-ai/duckdb-analytics/SKILL.md +440 -0
  163. package/ai-config/skills/data-ai/langchain/SKILL.md +238 -0
  164. package/ai-config/skills/data-ai/mlflow/SKILL.md +302 -0
  165. package/ai-config/skills/data-ai/onnx-inference/SKILL.md +290 -0
  166. package/ai-config/skills/data-ai/powerbi/SKILL.md +352 -0
  167. package/ai-config/skills/data-ai/pytorch/SKILL.md +274 -0
  168. package/ai-config/skills/data-ai/scikit-learn/SKILL.md +321 -0
  169. package/ai-config/skills/data-ai/vector-db/SKILL.md +301 -0
  170. package/ai-config/skills/database/graph-databases/SKILL.md +218 -0
  171. package/ai-config/skills/database/graph-spring/SKILL.md +361 -0
  172. package/ai-config/skills/database/pgx-postgres/SKILL.md +512 -0
  173. package/ai-config/skills/database/redis-cache/SKILL.md +343 -0
  174. package/ai-config/skills/database/sqlite-embedded/SKILL.md +388 -0
  175. package/ai-config/skills/database/timescaledb/SKILL.md +320 -0
  176. package/ai-config/skills/docs/api-documentation/SKILL.md +293 -0
  177. package/ai-config/skills/docs/docs-spring/SKILL.md +377 -0
  178. package/ai-config/skills/docs/mustache-templates/SKILL.md +190 -0
  179. package/ai-config/skills/docs/technical-docs/SKILL.md +447 -0
  180. package/ai-config/skills/frontend/astro-ssr/SKILL.md +441 -0
  181. package/ai-config/skills/frontend/frontend-design/SKILL.md +54 -0
  182. package/ai-config/skills/frontend/frontend-web/SKILL.md +368 -0
  183. package/ai-config/skills/frontend/mantine-ui/SKILL.md +396 -0
  184. package/ai-config/skills/frontend/tanstack-query/SKILL.md +439 -0
  185. package/ai-config/skills/frontend/zod-validation/SKILL.md +417 -0
  186. package/ai-config/skills/frontend/zustand-state/SKILL.md +350 -0
  187. package/ai-config/skills/infrastructure/chaos-engineering/SKILL.md +244 -0
  188. package/ai-config/skills/infrastructure/chaos-spring/SKILL.md +378 -0
  189. package/ai-config/skills/infrastructure/devops-infra/SKILL.md +435 -0
  190. package/ai-config/skills/infrastructure/docker-containers/SKILL.md +420 -0
  191. package/ai-config/skills/infrastructure/kubernetes/SKILL.md +456 -0
  192. package/ai-config/skills/infrastructure/opentelemetry/SKILL.md +546 -0
  193. package/ai-config/skills/infrastructure/traefik-proxy/SKILL.md +474 -0
  194. package/ai-config/skills/infrastructure/woodpecker-ci/SKILL.md +315 -0
  195. package/ai-config/skills/mobile/ionic-capacitor/SKILL.md +504 -0
  196. package/ai-config/skills/mobile/mobile-ionic/SKILL.md +448 -0
  197. package/ai-config/skills/prompt-improver/SKILL.md +125 -0
  198. package/ai-config/skills/quality/ghagga-review/SKILL.md +216 -0
  199. package/ai-config/skills/references/hooks-patterns/SKILL.md +238 -0
  200. package/ai-config/skills/references/mcp-servers/SKILL.md +275 -0
  201. package/ai-config/skills/references/plugins-reference/SKILL.md +110 -0
  202. package/ai-config/skills/references/skills-reference/SKILL.md +420 -0
  203. package/ai-config/skills/references/subagent-templates/SKILL.md +193 -0
  204. package/ai-config/skills/systems-iot/modbus-protocol/SKILL.md +410 -0
  205. package/ai-config/skills/systems-iot/mqtt-rumqttc/SKILL.md +408 -0
  206. package/ai-config/skills/systems-iot/rust-systems/SKILL.md +386 -0
  207. package/ai-config/skills/systems-iot/tokio-async/SKILL.md +324 -0
  208. package/ai-config/skills/testing/playwright-e2e/SKILL.md +289 -0
  209. package/ai-config/skills/testing/testcontainers/SKILL.md +299 -0
  210. package/ai-config/skills/testing/vitest-testing/SKILL.md +381 -0
  211. package/ai-config/skills/workflow/ci-local-guide/SKILL.md +118 -0
  212. package/ai-config/skills/workflow/claude-automation-recommender/SKILL.md +299 -0
  213. package/ai-config/skills/workflow/claude-md-improver/SKILL.md +158 -0
  214. package/ai-config/skills/workflow/finishing-a-development-branch/SKILL.md +117 -0
  215. package/ai-config/skills/workflow/git-github/SKILL.md +334 -0
  216. package/ai-config/skills/workflow/git-github/references/examples.md +160 -0
  217. package/ai-config/skills/workflow/git-workflow/SKILL.md +214 -0
  218. package/ai-config/skills/workflow/ide-plugins/SKILL.md +277 -0
  219. package/ai-config/skills/workflow/ide-plugins-intellij/SKILL.md +401 -0
  220. package/ai-config/skills/workflow/obsidian-brain-workflow/SKILL.md +199 -0
  221. package/ai-config/skills/workflow/using-git-worktrees/SKILL.md +100 -0
  222. package/ai-config/skills/workflow/verification-before-completion/SKILL.md +73 -0
  223. package/ai-config/skills/workflow/wave-workflow/SKILL.md +178 -0
  224. package/ci-local/README.md +170 -0
  225. package/ci-local/ci-local.sh +297 -0
  226. package/ci-local/hooks/commit-msg +74 -0
  227. package/ci-local/hooks/pre-commit +162 -0
  228. package/ci-local/hooks/pre-push +41 -0
  229. package/ci-local/install.sh +49 -0
  230. package/ci-local/semgrep.yml +214 -0
  231. package/dist/commands/analyze.d.ts +9 -0
  232. package/dist/commands/analyze.d.ts.map +1 -0
  233. package/dist/commands/analyze.js +55 -0
  234. package/dist/commands/analyze.js.map +1 -0
  235. package/dist/commands/analyze.test.d.ts +2 -0
  236. package/dist/commands/analyze.test.d.ts.map +1 -0
  237. package/dist/commands/analyze.test.js +145 -0
  238. package/dist/commands/analyze.test.js.map +1 -0
  239. package/dist/commands/doctor.d.ts +7 -0
  240. package/dist/commands/doctor.d.ts.map +1 -0
  241. package/dist/commands/doctor.js +158 -0
  242. package/dist/commands/doctor.js.map +1 -0
  243. package/dist/commands/doctor.test.d.ts +2 -0
  244. package/dist/commands/doctor.test.d.ts.map +1 -0
  245. package/dist/commands/doctor.test.js +200 -0
  246. package/dist/commands/doctor.test.js.map +1 -0
  247. package/dist/commands/init.d.ts +9 -0
  248. package/dist/commands/init.d.ts.map +1 -0
  249. package/dist/commands/init.js +283 -0
  250. package/dist/commands/init.js.map +1 -0
  251. package/dist/commands/init.test.d.ts +2 -0
  252. package/dist/commands/init.test.d.ts.map +1 -0
  253. package/dist/commands/init.test.js +271 -0
  254. package/dist/commands/init.test.js.map +1 -0
  255. package/dist/commands/sync.d.ts +8 -0
  256. package/dist/commands/sync.d.ts.map +1 -0
  257. package/dist/commands/sync.js +201 -0
  258. package/dist/commands/sync.js.map +1 -0
  259. package/dist/constants.d.ts +21 -0
  260. package/dist/constants.d.ts.map +1 -0
  261. package/dist/constants.js +57 -0
  262. package/dist/constants.js.map +1 -0
  263. package/dist/e2e/aggressive.e2e.test.d.ts +2 -0
  264. package/dist/e2e/aggressive.e2e.test.d.ts.map +1 -0
  265. package/dist/e2e/aggressive.e2e.test.js +350 -0
  266. package/dist/e2e/aggressive.e2e.test.js.map +1 -0
  267. package/dist/e2e/commands.e2e.test.d.ts +2 -0
  268. package/dist/e2e/commands.e2e.test.d.ts.map +1 -0
  269. package/dist/e2e/commands.e2e.test.js +213 -0
  270. package/dist/e2e/commands.e2e.test.js.map +1 -0
  271. package/dist/index.d.ts +3 -0
  272. package/dist/index.d.ts.map +1 -0
  273. package/dist/index.js +82 -0
  274. package/dist/index.js.map +1 -0
  275. package/dist/lib/common.d.ts +17 -0
  276. package/dist/lib/common.d.ts.map +1 -0
  277. package/dist/lib/common.js +111 -0
  278. package/dist/lib/common.js.map +1 -0
  279. package/dist/lib/common.test.d.ts +2 -0
  280. package/dist/lib/common.test.d.ts.map +1 -0
  281. package/dist/lib/common.test.js +316 -0
  282. package/dist/lib/common.test.js.map +1 -0
  283. package/dist/lib/frontmatter.d.ts +18 -0
  284. package/dist/lib/frontmatter.d.ts.map +1 -0
  285. package/dist/lib/frontmatter.js +61 -0
  286. package/dist/lib/frontmatter.js.map +1 -0
  287. package/dist/lib/frontmatter.test.d.ts +2 -0
  288. package/dist/lib/frontmatter.test.d.ts.map +1 -0
  289. package/dist/lib/frontmatter.test.js +257 -0
  290. package/dist/lib/frontmatter.test.js.map +1 -0
  291. package/dist/lib/template.d.ts +24 -0
  292. package/dist/lib/template.d.ts.map +1 -0
  293. package/dist/lib/template.js +78 -0
  294. package/dist/lib/template.js.map +1 -0
  295. package/dist/lib/template.test.d.ts +2 -0
  296. package/dist/lib/template.test.d.ts.map +1 -0
  297. package/dist/lib/template.test.js +201 -0
  298. package/dist/lib/template.test.js.map +1 -0
  299. package/dist/types/index.d.ts +48 -0
  300. package/dist/types/index.d.ts.map +1 -0
  301. package/dist/types/index.js +2 -0
  302. package/dist/types/index.js.map +1 -0
  303. package/dist/ui/AnalyzeUI.d.ts +7 -0
  304. package/dist/ui/AnalyzeUI.d.ts.map +1 -0
  305. package/dist/ui/AnalyzeUI.js +100 -0
  306. package/dist/ui/AnalyzeUI.js.map +1 -0
  307. package/dist/ui/App.d.ts +13 -0
  308. package/dist/ui/App.d.ts.map +1 -0
  309. package/dist/ui/App.js +100 -0
  310. package/dist/ui/App.js.map +1 -0
  311. package/dist/ui/CIContext.d.ts +9 -0
  312. package/dist/ui/CIContext.d.ts.map +1 -0
  313. package/dist/ui/CIContext.js +9 -0
  314. package/dist/ui/CIContext.js.map +1 -0
  315. package/dist/ui/CISelector.d.ts +8 -0
  316. package/dist/ui/CISelector.d.ts.map +1 -0
  317. package/dist/ui/CISelector.js +45 -0
  318. package/dist/ui/CISelector.js.map +1 -0
  319. package/dist/ui/Doctor.d.ts +3 -0
  320. package/dist/ui/Doctor.d.ts.map +1 -0
  321. package/dist/ui/Doctor.js +89 -0
  322. package/dist/ui/Doctor.js.map +1 -0
  323. package/dist/ui/Header.d.ts +8 -0
  324. package/dist/ui/Header.d.ts.map +1 -0
  325. package/dist/ui/Header.js +30 -0
  326. package/dist/ui/Header.js.map +1 -0
  327. package/dist/ui/MemorySelector.d.ts +8 -0
  328. package/dist/ui/MemorySelector.d.ts.map +1 -0
  329. package/dist/ui/MemorySelector.js +46 -0
  330. package/dist/ui/MemorySelector.js.map +1 -0
  331. package/dist/ui/NameInput.d.ts +8 -0
  332. package/dist/ui/NameInput.d.ts.map +1 -0
  333. package/dist/ui/NameInput.js +69 -0
  334. package/dist/ui/NameInput.js.map +1 -0
  335. package/dist/ui/OptionSelector.d.ts +12 -0
  336. package/dist/ui/OptionSelector.d.ts.map +1 -0
  337. package/dist/ui/OptionSelector.js +69 -0
  338. package/dist/ui/OptionSelector.js.map +1 -0
  339. package/dist/ui/Progress.d.ts +11 -0
  340. package/dist/ui/Progress.d.ts.map +1 -0
  341. package/dist/ui/Progress.js +58 -0
  342. package/dist/ui/Progress.js.map +1 -0
  343. package/dist/ui/StackSelector.d.ts +9 -0
  344. package/dist/ui/StackSelector.d.ts.map +1 -0
  345. package/dist/ui/StackSelector.js +65 -0
  346. package/dist/ui/StackSelector.js.map +1 -0
  347. package/dist/ui/Summary.d.ts +12 -0
  348. package/dist/ui/Summary.d.ts.map +1 -0
  349. package/dist/ui/Summary.js +114 -0
  350. package/dist/ui/Summary.js.map +1 -0
  351. package/dist/ui/SyncUI.d.ts +10 -0
  352. package/dist/ui/SyncUI.d.ts.map +1 -0
  353. package/dist/ui/SyncUI.js +64 -0
  354. package/dist/ui/SyncUI.js.map +1 -0
  355. package/dist/ui/Welcome.d.ts +7 -0
  356. package/dist/ui/Welcome.d.ts.map +1 -0
  357. package/dist/ui/Welcome.js +45 -0
  358. package/dist/ui/Welcome.js.map +1 -0
  359. package/dist/ui/theme.d.ts +10 -0
  360. package/dist/ui/theme.d.ts.map +1 -0
  361. package/dist/ui/theme.js +9 -0
  362. package/dist/ui/theme.js.map +1 -0
  363. package/modules/engram/.gitignore-snippet.txt +6 -0
  364. package/modules/engram/.mcp-config-snippet.json +11 -0
  365. package/modules/engram/README.md +146 -0
  366. package/modules/engram/install-engram.sh +216 -0
  367. package/modules/ghagga/.env.example +43 -0
  368. package/modules/ghagga/README.md +153 -0
  369. package/modules/ghagga/docker-compose.yml +80 -0
  370. package/modules/ghagga/setup-ghagga.sh +139 -0
  371. package/modules/memory-simple/.project/NOTES.md +22 -0
  372. package/modules/memory-simple/README.md +23 -0
  373. package/modules/obsidian-brain/.obsidian/app.json +23 -0
  374. package/modules/obsidian-brain/.obsidian/appearance.json +5 -0
  375. package/modules/obsidian-brain/.obsidian/bookmarks.json +34 -0
  376. package/modules/obsidian-brain/.obsidian/community-plugins.json +1 -0
  377. package/modules/obsidian-brain/.obsidian/core-plugins-migration.json +21 -0
  378. package/modules/obsidian-brain/.obsidian/core-plugins.json +18 -0
  379. package/modules/obsidian-brain/.obsidian/daily-notes.json +5 -0
  380. package/modules/obsidian-brain/.obsidian/graph.json +37 -0
  381. package/modules/obsidian-brain/.obsidian/hotkeys.json +14 -0
  382. package/modules/obsidian-brain/.obsidian/plugins/dataview/data.json +25 -0
  383. package/modules/obsidian-brain/.obsidian/plugins/obsidian-kanban/data.json +29 -0
  384. package/modules/obsidian-brain/.obsidian/plugins/templater-obsidian/data.json +18 -0
  385. package/modules/obsidian-brain/.obsidian/snippets/project-memory.css +71 -0
  386. package/modules/obsidian-brain/.obsidian-gitignore-snippet.txt +8 -0
  387. package/modules/obsidian-brain/.project/Attachments/.gitkeep +0 -0
  388. package/modules/obsidian-brain/.project/Memory/BLOCKERS.md +78 -0
  389. package/modules/obsidian-brain/.project/Memory/CONTEXT.md +102 -0
  390. package/modules/obsidian-brain/.project/Memory/DASHBOARD.md +73 -0
  391. package/modules/obsidian-brain/.project/Memory/DECISIONS.md +87 -0
  392. package/modules/obsidian-brain/.project/Memory/KANBAN.md +15 -0
  393. package/modules/obsidian-brain/.project/Memory/README.md +61 -0
  394. package/modules/obsidian-brain/.project/Memory/WAVES.md +78 -0
  395. package/modules/obsidian-brain/.project/Sessions/TEMPLATE.md +99 -0
  396. package/modules/obsidian-brain/.project/Templates/ADR.md +33 -0
  397. package/modules/obsidian-brain/.project/Templates/Blocker.md +21 -0
  398. package/modules/obsidian-brain/.project/Templates/Session.md +88 -0
  399. package/modules/obsidian-brain/README.md +268 -0
  400. package/modules/obsidian-brain/new-wave.sh +182 -0
  401. package/package.json +51 -0
  402. package/schemas/agent.schema.json +34 -0
  403. package/schemas/ai-config.schema.json +28 -0
  404. package/schemas/skill.schema.json +44 -0
  405. package/src/commands/analyze.test.ts +145 -0
  406. package/src/commands/analyze.ts +69 -0
  407. package/src/commands/doctor.test.ts +208 -0
  408. package/src/commands/doctor.ts +163 -0
  409. package/src/commands/init.test.ts +298 -0
  410. package/src/commands/init.ts +285 -0
  411. package/src/constants.ts +69 -0
  412. package/src/e2e/aggressive.e2e.test.ts +557 -0
  413. package/src/e2e/commands.e2e.test.ts +298 -0
  414. package/src/index.tsx +106 -0
  415. package/src/lib/common.test.ts +318 -0
  416. package/src/lib/common.ts +127 -0
  417. package/src/lib/frontmatter.test.ts +291 -0
  418. package/src/lib/frontmatter.ts +77 -0
  419. package/src/lib/template.test.ts +226 -0
  420. package/src/lib/template.ts +99 -0
  421. package/src/types/index.ts +53 -0
  422. package/src/ui/AnalyzeUI.tsx +133 -0
  423. package/src/ui/App.tsx +175 -0
  424. package/src/ui/CIContext.tsx +25 -0
  425. package/src/ui/CISelector.tsx +72 -0
  426. package/src/ui/Doctor.tsx +122 -0
  427. package/src/ui/Header.tsx +48 -0
  428. package/src/ui/MemorySelector.tsx +73 -0
  429. package/src/ui/NameInput.tsx +82 -0
  430. package/src/ui/OptionSelector.tsx +100 -0
  431. package/src/ui/Progress.tsx +88 -0
  432. package/src/ui/StackSelector.tsx +101 -0
  433. package/src/ui/Summary.tsx +134 -0
  434. package/src/ui/Welcome.tsx +54 -0
  435. package/src/ui/theme.ts +10 -0
  436. package/stryker.config.json +19 -0
  437. package/tasks/_TEMPLATE/files-edited.md +3 -0
  438. package/tasks/_TEMPLATE/plan.md +3 -0
  439. package/tasks/_TEMPLATE/research.md +3 -0
  440. package/tasks/_TEMPLATE/verification.md +5 -0
  441. package/templates/common/dependabot/cargo.yml +11 -0
  442. package/templates/common/dependabot/github-actions.yml +16 -0
  443. package/templates/common/dependabot/gomod.yml +15 -0
  444. package/templates/common/dependabot/gradle.yml +15 -0
  445. package/templates/common/dependabot/header.yml +3 -0
  446. package/templates/common/dependabot/maven.yml +15 -0
  447. package/templates/common/dependabot/npm.yml +20 -0
  448. package/templates/common/dependabot/pip.yml +11 -0
  449. package/templates/dependabot.yml +162 -0
  450. package/templates/github/ci-go.yml +41 -0
  451. package/templates/github/ci-java.yml +45 -0
  452. package/templates/github/ci-monorepo.yml +150 -0
  453. package/templates/github/ci-node.yml +42 -0
  454. package/templates/github/ci-python.yml +42 -0
  455. package/templates/github/ci-rust.yml +42 -0
  456. package/templates/github/dependabot-automerge.yml +40 -0
  457. package/templates/gitlab/gitlab-ci-go.yml +88 -0
  458. package/templates/gitlab/gitlab-ci-java.yml +79 -0
  459. package/templates/gitlab/gitlab-ci-monorepo.yml +126 -0
  460. package/templates/gitlab/gitlab-ci-node.yml +63 -0
  461. package/templates/gitlab/gitlab-ci-python.yml +147 -0
  462. package/templates/gitlab/gitlab-ci-rust.yml +67 -0
  463. package/templates/global/claude-settings.json +98 -0
  464. package/templates/global/codex-config.toml +8 -0
  465. package/templates/global/copilot-instructions/base-rules.instructions.md +13 -0
  466. package/templates/global/copilot-instructions/sdd-orchestrator.instructions.md +37 -0
  467. package/templates/global/gemini-commands/cleanup.toml +20 -0
  468. package/templates/global/gemini-commands/commit.toml +15 -0
  469. package/templates/global/gemini-commands/dead-code.toml +22 -0
  470. package/templates/global/gemini-commands/plan.toml +30 -0
  471. package/templates/global/gemini-commands/review.toml +17 -0
  472. package/templates/global/gemini-commands/sdd-apply.toml +22 -0
  473. package/templates/global/gemini-commands/sdd-ff.toml +14 -0
  474. package/templates/global/gemini-commands/sdd-new.toml +21 -0
  475. package/templates/global/gemini-commands/sdd-verify.toml +21 -0
  476. package/templates/global/gemini-commands/tdd.toml +26 -0
  477. package/templates/global/gemini-settings.json +8 -0
  478. package/templates/global/opencode-config.json +44 -0
  479. package/templates/global/sdd-instructions.md +47 -0
  480. package/templates/global/sdd-orchestrator-claude.md +46 -0
  481. package/templates/global/sdd-orchestrator-copilot.md +34 -0
  482. package/templates/renovate.json +69 -0
  483. package/templates/woodpecker/monorepo/backend.yml +34 -0
  484. package/templates/woodpecker/monorepo/frontend.yml +34 -0
  485. package/templates/woodpecker/monorepo/summary.yml +25 -0
  486. package/templates/woodpecker/woodpecker-go.yml +51 -0
  487. package/templates/woodpecker/woodpecker-java.yml +67 -0
  488. package/templates/woodpecker/woodpecker-node.yml +47 -0
  489. package/templates/woodpecker/woodpecker-python.yml +108 -0
  490. package/templates/woodpecker/woodpecker-rust.yml +57 -0
  491. package/tsconfig.json +19 -0
  492. package/vitest.config.ts +16 -0
  493. package/workflows/reusable-build-go.yml +111 -0
  494. package/workflows/reusable-build-java.yml +120 -0
  495. package/workflows/reusable-build-node.yml +145 -0
  496. package/workflows/reusable-build-python.yml +159 -0
  497. package/workflows/reusable-build-rust.yml +135 -0
  498. package/workflows/reusable-docker.yml +120 -0
  499. package/workflows/reusable-ghagga-review.yml +165 -0
  500. package/workflows/reusable-release.yml +91 -0
@@ -0,0 +1,91 @@
1
+ ---
2
+ name: improve-prompt
3
+ description: Intercepts vague user prompts and asks clarifying questions before execution. Bypass with *, /, #, or ! prefix.
4
+ event: UserPromptSubmit
5
+ action: execute
6
+ metadata:
7
+ author: project-starter-framework
8
+ version: "1.0"
9
+ updated: "2026-02"
10
+ ---
11
+
12
+ # Improve Prompt Hook
13
+
14
+ > Intercepts short or vague prompts and asks targeted clarifying questions to improve output quality.
15
+
16
+ ## Purpose
17
+
18
+ Prevent low-quality AI responses caused by under-specified prompts. When a prompt is vague (< 15 words, no clear action verb), the hook pauses and asks up to 3 clarifying questions before proceeding.
19
+
20
+ ## Bypass Prefixes
21
+
22
+ Prefix your prompt with any of the following to skip interception and pass through immediately:
23
+
24
+ | Prefix | Meaning |
25
+ |--------|---------|
26
+ | `*` | Force execute as-is |
27
+ | `/` | Slash command — pass through |
28
+ | `#` | Comment / meta instruction |
29
+ | `!` | Override / urgent |
30
+
31
+ **Example**: `* just do it` → skips all checks.
32
+
33
+ ## Vagueness Detection
34
+
35
+ A prompt is considered vague when **both** conditions are true:
36
+ 1. Word count < 15
37
+ 2. No clear action verb detected (e.g., `create`, `fix`, `refactor`, `add`, `remove`, `update`, `write`, `build`, `test`, `explain`, `analyze`, `generate`)
38
+
39
+ ## Clarifying Questions (up to 3)
40
+
41
+ Based on what's missing, the hook asks from:
42
+
43
+ 1. **Output**: What is the expected output or deliverable?
44
+ 2. **Constraints**: What constraints or requirements apply (language, framework, style)?
45
+ 3. **Context**: What already exists that I should be aware of?
46
+
47
+ ## Companion Skill
48
+
49
+ See `.ai-config/skills/prompt-improver/SKILL.md` for the full 4-phase logic used to enrich prompts before execution.
50
+
51
+ ## Implementation (Claude Code JSON)
52
+
53
+ ```json
54
+ {
55
+ "hooks": {
56
+ "UserPromptSubmit": [
57
+ {
58
+ "hooks": [
59
+ {
60
+ "type": "command",
61
+ "command": "python3 -c \"\nimport sys, os\nprompt = os.environ.get('CLAUDE_USER_PROMPT', '')\nbypass = ['*', '/', '#', '!']\nif any(prompt.strip().startswith(p) for p in bypass):\n sys.exit(0)\nwords = prompt.strip().split()\naction_verbs = ['create','fix','refactor','add','remove','update','write','build','test','explain','analyze','generate','implement','debug','review','migrate','deploy','configure','setup','delete','rename','move','convert','optimize','document']\nhas_verb = any(v in prompt.lower() for v in action_verbs)\nif len(words) < 15 and not has_verb:\n print('PROMPT IMPROVEMENT NEEDED')\n print('Your prompt appears vague. Please answer up to 3 questions:')\n print(' 1. What is the expected output or deliverable?')\n print(' 2. What constraints apply (language, framework, style)?')\n print(' 3. What already exists that I should be aware of?')\n print('Tip: Prefix with * to skip this check (e.g. \\\"* just do it\\\")')\n sys.exit(1)\nsys.exit(0)\n\""
62
+ }
63
+ ]
64
+ }
65
+ ]
66
+ }
67
+ }
68
+ ```
69
+
70
+ ## Examples
71
+
72
+ ### ✅ Passes Through
73
+ ```
74
+ * fix it quickly
75
+ /commit
76
+ # note: use typescript
77
+ ! urgent: rollback last change
78
+ create a REST endpoint for user authentication using FastAPI with JWT
79
+ ```
80
+
81
+ ### 🛑 Intercepted (vague)
82
+ ```
83
+ fix the bug
84
+ make it better
85
+ add feature
86
+ help
87
+ ```
88
+
89
+ ## Notes
90
+
91
+ This hook complements the `prompt-improver` skill. For prompts that pass through but still need enrichment, the skill applies the full 4-phase Analyze → Research → Question → Execute flow.
@@ -0,0 +1,72 @@
1
+ ---
2
+ name: learning-log
3
+ description: Al finalizar sesión, guarda un resumen de lo aprendido y los commits realizados. Trigger: SessionEnd
4
+ event: SessionEnd
5
+ action: execute
6
+ metadata:
7
+ author: project-starter-framework
8
+ version: "1.0"
9
+ ---
10
+
11
+ # Learning Log Hook
12
+
13
+ > Registra automáticamente los aprendizajes y cambios de cada sesión AI.
14
+
15
+ ## Propósito
16
+
17
+ Crear un historial de sesiones que documente decisiones técnicas, problemas encontrados y soluciones aplicadas — útil para onboarding, debugging futuro y mejora continua.
18
+
19
+ ## Información Registrada
20
+
21
+ ### Por Sesión
22
+ - Fecha y hora de la sesión
23
+ - Branch y commits realizados durante la sesión
24
+ - Archivos modificados (lista compacta)
25
+ - Resumen de cambios (del último commit message)
26
+
27
+ ### Formato de Log
28
+
29
+ ```markdown
30
+ ## 2026-02-25 — feat(auth): add refresh tokens
31
+
32
+ **Branch:** feature/t-42-refresh-tokens
33
+ **Commits:** 3
34
+ **Files changed:** src/auth/token.go, src/auth/refresh.go, tests/auth_test.go
35
+
36
+ **Notes:** Implemented JWT refresh token flow with Redis-backed token rotation.
37
+ Issues: Had to handle concurrent refresh requests with mutex.
38
+ ```
39
+
40
+ ## Comportamiento
41
+
42
+ 1. **Ejecuta** al cerrar cada sesión Claude Code
43
+ 2. **Recopila** commits realizados desde inicio de sesión
44
+ 3. **Escribe** entrada al log `.ai-session-log.md` (gitignored)
45
+ 4. **Rota** el log cuando supera 1000 líneas
46
+
47
+ ## Implementación Claude Code
48
+
49
+ ```json
50
+ {
51
+ "hooks": {
52
+ "SessionEnd": [
53
+ {
54
+ "hooks": [{ "type": "command", "command": "LOG='.ai-session-log.md'; DATE=$(date '+%Y-%m-%d %H:%M'); BRANCH=$(git branch --show-current 2>/dev/null); COMMITS=$(git log --oneline --since='8 hours ago' 2>/dev/null | head -5); echo \"\\n## $DATE — $BRANCH\\n\\n$COMMITS\" >> $LOG 2>/dev/null || true" }]
55
+ }
56
+ ]
57
+ }
58
+ }
59
+ ```
60
+
61
+ ## Configuración del .gitignore
62
+
63
+ Agregar al `.gitignore` del proyecto:
64
+ ```
65
+ .ai-session-log.md
66
+ ```
67
+
68
+ O committear el log si se quiere historial compartido con el equipo.
69
+
70
+ ## Notas
71
+
72
+ El log es local por defecto. Para compartir con el equipo, quitar de `.gitignore` y commitear periódicamente con `chore: update AI session log`.
@@ -0,0 +1,86 @@
1
+ ---
2
+ name: model-router
3
+ description: Detects task complexity from prompt keywords and recommends the appropriate Claude model. Logs a recommendation comment without blocking execution.
4
+ event: UserPromptSubmit
5
+ action: log
6
+
7
+ metadata:
8
+ author: project-starter-framework
9
+ version: "1.0"
10
+ updated: "2026-02"
11
+ ---
12
+
13
+ # Model Router Hook
14
+
15
+ > Recommends the optimal Claude model based on task complexity keywords. Non-blocking — documents the recommendation as a comment.
16
+
17
+ ## Purpose
18
+
19
+ Help developers choose the right model for cost and quality efficiency. Complex reasoning
20
+ tasks benefit from Opus; routine edits benefit from Haiku; most work is Sonnet territory.
21
+
22
+ ## Evento
23
+
24
+ - **Trigger:** UserPromptSubmit (or SessionStart)
25
+ - **Action:** log (recommendation only — does not force model selection)
26
+ - **Condition:** Every prompt is evaluated; only logs when a non-default model is recommended
27
+
28
+ ## Model Routing Table
29
+
30
+ | Keywords in Prompt | Recommended Model | Reason |
31
+ |-------------------|-------------------|--------|
32
+ | `architect`, `system design`, `design pattern`, `scalability`, `microservice`, `distributed`, `trade-off`, `ADR` | `claude-opus-4-5` | Complex multi-step reasoning required |
33
+ | `security audit`, `threat model`, `CVE`, `OWASP`, `pentest`, `cryptography` | `claude-opus-4-5` | Security analysis needs deep reasoning |
34
+ | `performance profile`, `memory leak`, `flame graph`, `bottleneck analysis` | `claude-opus-4-5` | Diagnostic reasoning over complex systems |
35
+ | `quick fix`, `typo`, `rename`, `lint`, `format`, `simple`, `one-liner`, `obvious` | `claude-haiku-4-5` | Fast and cost-effective for trivial tasks |
36
+ | `add comment`, `update README`, `fix spacing`, `bump version` | `claude-haiku-4-5` | Lightweight documentation/formatting tasks |
37
+ | *(default — everything else)* | `claude-sonnet-4-5` | Balanced capability and cost |
38
+
39
+ ## Lógica
40
+
41
+ ```
42
+ SI prompt matches opus keywords
43
+ ENTONCES log "💡 Model recommendation: claude-opus-4-5 (complex reasoning detected)"
44
+ SINO SI prompt matches haiku keywords
45
+ ENTONCES log "💡 Model recommendation: claude-haiku-4-5 (simple task detected)"
46
+ SINO log nothing (sonnet is default, no recommendation needed)
47
+ ```
48
+
49
+ ## Implementación
50
+
51
+ ### Para Claude Code
52
+
53
+ ```json
54
+ {
55
+ "hooks": {
56
+ "UserPromptSubmit": [
57
+ {
58
+ "matcher": ".*",
59
+ "command": "bash .ai-config/scripts/model-router.sh \"$CLAUDE_USER_PROMPT\""
60
+ }
61
+ ]
62
+ }
63
+ }
64
+ ```
65
+
66
+ ### Script: .ai-config/scripts/model-router.sh
67
+
68
+ ```bash
69
+ #!/bin/bash
70
+ PROMPT="$1"
71
+ OPUS_PATTERN="architect|system design|design pattern|scalability|microservice|distributed|trade.off|ADR|security audit|threat model|CVE|OWASP|pentest|cryptography|performance profile|memory leak|flame graph|bottleneck analysis"
72
+ HAIKU_PATTERN="quick fix|typo|rename|lint|format|simple|one.liner|obvious|add comment|update README|fix spacing|bump version"
73
+
74
+ if echo "$PROMPT" | grep -qiE "$OPUS_PATTERN"; then
75
+ echo "💡 Model recommendation: claude-opus-4-5 — complex reasoning detected in prompt"
76
+ elif echo "$PROMPT" | grep -qiE "$HAIKU_PATTERN"; then
77
+ echo "💡 Model recommendation: claude-haiku-4-5 — simple task detected, consider switching for cost savings"
78
+ fi
79
+ # Default (sonnet): no output needed
80
+ ```
81
+
82
+ ## Notes
83
+
84
+ - This hook is **advisory only** — it does not change the active model
85
+ - To actually switch models, use the `/model` command or configure in `CLAUDE.md`
86
+ - Tune the keyword patterns for your team's vocabulary
@@ -0,0 +1,64 @@
1
+ ---
2
+ name: secret-scanner
3
+ description: Escanea archivos antes de escribir/editar para detectar secrets y credenciales. Trigger: PreToolUse Write/Edit
4
+ event: PreToolUse
5
+ tools:
6
+ - Write
7
+ - Edit
8
+ action: warn
9
+ metadata:
10
+ author: project-starter-framework
11
+ version: "1.0"
12
+ ---
13
+
14
+ # Secret Scanner Hook
15
+
16
+ > Detecta secrets, tokens y credenciales antes de escribir archivos.
17
+
18
+ ## Propósito
19
+
20
+ Prevenir que API keys, tokens, passwords y otras credenciales sean escritas en archivos del proyecto o commits.
21
+
22
+ ## Patrones Detectados
23
+
24
+ | Patrón | Ejemplo |
25
+ |--------|---------|
26
+ | AWS keys | `AKIA[0-9A-Z]{16}` |
27
+ | Private keys | `-----BEGIN (RSA\|EC\|DSA) PRIVATE KEY-----` |
28
+ | Tokens Bearer | `Bearer [a-zA-Z0-9_-]{20,}` |
29
+ | GitHub PAT | `ghp_[a-zA-Z0-9]{36}` |
30
+ | Generic secret | `(secret\|password\|passwd\|pwd)\s*=\s*[^\s]{8,}` |
31
+ | API Key pattern | `api[_-]?key\s*=\s*[^\s]{8,}` |
32
+ | .env secrets | Variables en archivos `.env` con valores reales |
33
+
34
+ ## Comportamiento
35
+
36
+ 1. **Analiza** el contenido antes de escribir
37
+ 2. **Detecta** patrones de secrets conocidos
38
+ 3. **Alerta** al usuario con la línea problemática
39
+ 4. **Sugiere** usar variables de entorno o `.env.example` en su lugar
40
+
41
+ ## Implementación Claude Code
42
+
43
+ ```json
44
+ {
45
+ "hooks": {
46
+ "PreToolUse": [
47
+ {
48
+ "matcher": "Write",
49
+ "hooks": [{ "type": "command", "command": "echo \"$TOOL_INPUT\" | python3 -c \"import sys,re; content=sys.stdin.read(); patterns=[r'AKIA[0-9A-Z]{16}', r'-----BEGIN.*(RSA|EC).PRIVATE', r'ghp_[a-zA-Z0-9]{36}', r'(?i)(password|secret|api_?key)\\s*=\\s*[\\S]{8,}']; found=[p for p in patterns if re.search(p,content)]; print('SECRET DETECTED: '+str(found)) if found else None; sys.exit(1 if found else 0)\"" }]
50
+ }
51
+ ]
52
+ }
53
+ }
54
+ ```
55
+
56
+ ## Excepciones Legítimas
57
+
58
+ - Archivos `.env.example` con valores placeholder (`YOUR_KEY_HERE`)
59
+ - Archivos de test con datos ficticios (`fake-secret-for-testing`)
60
+ - Documentación que explica el formato (sin valores reales)
61
+
62
+ ## Notas
63
+
64
+ Complementa al hook `block-dangerous-commands`. Para secrets reales usar siempre variables de entorno.
@@ -0,0 +1,102 @@
1
+ ---
2
+ name: skill-validator
3
+ description: Validates new SKILL.md files being written to ensure they follow the required format and conventions.
4
+ event: PreToolUse
5
+ tools:
6
+ - Write
7
+ - Edit
8
+ match_pattern: ".ai-config/skills/.*/SKILL\\.md"
9
+ action: warn
10
+ metadata:
11
+ author: project-starter-framework
12
+ version: "1.0"
13
+ updated: "2026-02"
14
+ ---
15
+
16
+ # Skill Validator Hook
17
+
18
+ > Validates SKILL.md files before they are written to ensure they meet required format standards.
19
+
20
+ ## Purpose
21
+
22
+ Prevent malformed or incomplete skill files from being saved. Catches common issues like missing required fields, absolute paths, wildcard tool usage, and missing trigger keywords.
23
+
24
+ ## Checks Performed
25
+
26
+ | Check | Rule |
27
+ |-------|------|
28
+ | `name` field | Must be present in frontmatter |
29
+ | `description` field | Must contain trigger keywords (e.g., `Trigger:`) |
30
+ | `tags` field | Must be present and non-empty |
31
+ | Absolute paths | No `/Users/` or `/home/` paths in content |
32
+ | Wildcard tools | Tools list must not contain `"*"` |
33
+
34
+ ## Behavior
35
+
36
+ 1. **Intercepts** Write/Edit operations targeting `SKILL.md` files under `.ai-config/skills/`
37
+ 2. **Reads** the content being written
38
+ 3. **Validates** each rule above
39
+ 4. **Warns** with specific failure reasons if any check fails
40
+ 5. **Allows** the write to proceed (action: warn, not block)
41
+
42
+ ## Implementation (Claude Code JSON)
43
+
44
+ ```json
45
+ {
46
+ "hooks": {
47
+ "PreToolUse": [
48
+ {
49
+ "matcher": "Write",
50
+ "hooks": [
51
+ {
52
+ "type": "command",
53
+ "command": "python3 -c \"\nimport sys, os, json, re\ntool_input = os.environ.get('TOOL_INPUT', '{}')\ntry:\n data = json.loads(tool_input)\nexcept Exception:\n sys.exit(0)\nfile_path = data.get('file_path', data.get('path', ''))\nif not re.search(r'\\.ai-config/skills/.+/SKILL\\.md', file_path):\n sys.exit(0)\ncontent = data.get('content', '')\nwarnings = []\nif not re.search(r'^name:\\s*.+', content, re.MULTILINE):\n warnings.append('MISSING: name field in frontmatter')\nif not re.search(r'Trigger:', content):\n warnings.append('MISSING: Trigger keywords in description field')\nif not re.search(r'^tags:', content, re.MULTILINE):\n warnings.append('MISSING: tags field in frontmatter')\nif re.search(r'/Users/|/home/', content):\n warnings.append('INVALID: Absolute path detected (/Users/ or /home/). Use relative paths.')\nif re.search(r'tools:\\s*\\[\\s*\\\"\\*\\\"', content) or re.search(r\"tools:\\s*\\[\\s*'\\*'\", content):\n warnings.append('INVALID: Wildcard tool [\\\"*\\\"] is not allowed. List specific tools.')\nif warnings:\n print('SKILL VALIDATION WARNINGS:')\n for w in warnings:\n print(' - ' + w)\n print('Fix these issues to ensure the skill works correctly.')\nsys.exit(0)\n\""
54
+ }
55
+ ]
56
+ },
57
+ {
58
+ "matcher": "Edit",
59
+ "hooks": [
60
+ {
61
+ "type": "command",
62
+ "command": "python3 -c \"\nimport sys, os, json, re\ntool_input = os.environ.get('TOOL_INPUT', '{}')\ntry:\n data = json.loads(tool_input)\nexcept Exception:\n sys.exit(0)\nfile_path = data.get('file_path', data.get('path', ''))\nif not re.search(r'\\.ai-config/skills/.+/SKILL\\.md', file_path):\n sys.exit(0)\nnew_content = data.get('new_str', data.get('new_content', ''))\nif not new_content:\n sys.exit(0)\nwarnings = []\nif re.search(r'/Users/|/home/', new_content):\n warnings.append('INVALID: Absolute path detected (/Users/ or /home/). Use relative paths.')\nif re.search(r'tools:\\s*\\[\\s*\\\"\\*\\\"', new_content) or re.search(r\"tools:\\s*\\[\\s*'\\*'\", new_content):\n warnings.append('INVALID: Wildcard tool [\\\"*\\\"] is not allowed. List specific tools.')\nif warnings:\n print('SKILL VALIDATION WARNINGS (Edit):')\n for w in warnings:\n print(' - ' + w)\nsys.exit(0)\n\""
63
+ }
64
+ ]
65
+ }
66
+ ]
67
+ }
68
+ }
69
+ ```
70
+
71
+ ## Examples
72
+
73
+ ### ✅ Valid SKILL.md
74
+ ```yaml
75
+ ---
76
+ name: my-skill
77
+ description: >
78
+ Does something useful.
79
+ Trigger: keyword1, keyword2
80
+ tools:
81
+ - Read
82
+ - Bash
83
+ metadata:
84
+ tags: [tag1, tag2]
85
+ ---
86
+ ```
87
+
88
+ ### ❌ Will Warn
89
+ ```yaml
90
+ ---
91
+ # Missing name field
92
+ description: Does something. # Missing Trigger:
93
+ tools:
94
+ - "*" # Wildcard not allowed
95
+ ---
96
+
97
+ # Content with /Users/john/project/file.ts ← absolute path
98
+ ```
99
+
100
+ ## Notes
101
+
102
+ This hook validates Write and Edit operations. For a full skill authoring guide, see `.ai-config/skills/_TEMPLATE.md`.
@@ -0,0 +1,114 @@
1
+ ---
2
+ name: task-artifact
3
+ description: Creates a structured task directory with blank artifact files at session start. Directory is organized by domain, date, and task slug.
4
+ event: SessionStart
5
+ action: execute
6
+
7
+ metadata:
8
+ author: project-starter-framework
9
+ version: "1.0"
10
+ updated: "2026-02"
11
+ ---
12
+
13
+ # Task Artifact Hook
14
+
15
+ > Scaffolds a task workspace directory at the start of each session.
16
+
17
+ ## Purpose
18
+
19
+ Automatically creates a `tasks/<domain>/<YYYY-MM-DD>/<task-slug>/` directory structure
20
+ with blank artifact files, so every session has a consistent place to capture research,
21
+ plans, file changes, and verification steps.
22
+
23
+ ## Evento
24
+
25
+ - **Trigger:** SessionStart
26
+ - **Action:** execute
27
+ - **Condition:** When a session begins with a clear task or feature in mind
28
+
29
+ ## Domain Detection
30
+
31
+ The `<domain>` is inferred from keywords in the first user message:
32
+
33
+ | Keywords | Domain |
34
+ |----------|--------|
35
+ | `git`, `commit`, `branch`, `merge`, `rebase` | `git` |
36
+ | `test`, `spec`, `coverage`, `mock`, `TDD` | `testing` |
37
+ | `feature`, `implement`, `build`, `create`, `add` | `development` |
38
+ | `bug`, `fix`, `error`, `broken`, `debug` | `bugfix` |
39
+ | `refactor`, `clean`, `extract`, `simplify` | `refactoring` |
40
+ | `deploy`, `CI`, `pipeline`, `docker`, `k8s` | `devops` |
41
+ | `security`, `vulnerability`, `auth`, `CVE` | `security` |
42
+ | `docs`, `README`, `documentation`, `guide` | `docs` |
43
+ | *(default)* | `general` |
44
+
45
+ ## Directory Structure Created
46
+
47
+ ```
48
+ tasks/
49
+ └── <domain>/
50
+ └── <YYYY-MM-DD>/
51
+ └── <task-slug>/
52
+ ├── research.md
53
+ ├── plan.md
54
+ ├── files-edited.md
55
+ └── verification.md
56
+ ```
57
+
58
+ ## Lógica
59
+
60
+ ```
61
+ SI first message contains task keywords
62
+ ENTONCES infer domain and task-slug from message
63
+ CREATE tasks/<domain>/<YYYY-MM-DD>/<task-slug>/
64
+ CREATE research.md with ## Research header
65
+ CREATE plan.md with ## Plan header
66
+ CREATE files-edited.md with ## Files Changed header
67
+ CREATE verification.md with checklist
68
+ SINO skip (no task directory needed for questions/exploration)
69
+ ```
70
+
71
+ ## Implementación
72
+
73
+ ### Para Claude Code
74
+
75
+ ```json
76
+ {
77
+ "hooks": {
78
+ "SessionStart": [
79
+ {
80
+ "matcher": ".*",
81
+ "command": "bash .ai-config/scripts/task-artifact.sh \"$CLAUDE_SESSION_FIRST_MESSAGE\""
82
+ }
83
+ ]
84
+ }
85
+ }
86
+ ```
87
+
88
+ ### Script: .ai-config/scripts/task-artifact.sh
89
+
90
+ ```bash
91
+ #!/bin/bash
92
+ # Usage: task-artifact.sh "<first message>"
93
+ DOMAIN=$(echo "$1" | grep -qiE "git|commit|branch|merge" && echo "git" || \
94
+ echo "$1" | grep -qiE "test|spec|coverage|mock|TDD" && echo "testing" || \
95
+ echo "$1" | grep -qiE "bug|fix|error|broken|debug" && echo "bugfix" || \
96
+ echo "$1" | grep -qiE "refactor|clean|extract" && echo "refactoring" || \
97
+ echo "$1" | grep -qiE "deploy|CI|pipeline|docker" && echo "devops" || \
98
+ echo "development")
99
+
100
+ DATE=$(date +%Y-%m-%d)
101
+ SLUG=$(echo "$1" | tr '[:upper:]' '[:lower:]' | sed 's/[^a-z0-9]/-/g' | cut -c1-40)
102
+ DIR="tasks/$DOMAIN/$DATE/$SLUG"
103
+
104
+ mkdir -p "$DIR"
105
+ echo -e "## Research\n\n_Add findings here_" > "$DIR/research.md"
106
+ echo -e "## Plan\n\n_Add steps here_" > "$DIR/plan.md"
107
+ echo -e "## Files Changed\n\n_Auto-populated_" > "$DIR/files-edited.md"
108
+ echo -e "## Verification Checklist\n\n- [ ] Tests pass\n- [ ] No regressions\n- [ ] Docs updated" > "$DIR/verification.md"
109
+ echo "📁 Task workspace: $DIR"
110
+ ```
111
+
112
+ ## Template Files
113
+
114
+ See `tasks/_TEMPLATE/` for the canonical blank file templates.
@@ -0,0 +1,100 @@
1
+ ---
2
+ name: validate-workflow
3
+ description: Validates GitHub Actions workflow YAML files after writing or editing. Checks syntax and required keys.
4
+ event: PostToolUse
5
+ tools:
6
+ - Write
7
+ - Edit
8
+ match_pattern: "\\.github/workflows/.*\\.yml"
9
+ action: execute
10
+ metadata:
11
+ author: project-starter-framework
12
+ version: "1.0"
13
+ updated: "2026-02"
14
+ ---
15
+
16
+ # Validate Workflow Hook
17
+
18
+ > Automatically validates GitHub Actions workflow files after every write or edit.
19
+
20
+ ## Purpose
21
+
22
+ Catch YAML syntax errors and missing required keys in workflow files immediately after saving, before a broken workflow gets pushed to the repository.
23
+
24
+ ## Checks Performed
25
+
26
+ | Check | Rule |
27
+ |-------|------|
28
+ | YAML syntax | Valid YAML parseable by Python's `yaml.safe_load` |
29
+ | `on:` trigger | Workflow must define at least one trigger |
30
+ | `jobs:` key | Workflow must define at least one job |
31
+
32
+ ## Behavior
33
+
34
+ 1. **Triggers** after Write or Edit on any `.github/workflows/*.yml` file
35
+ 2. **Validates** YAML syntax using `python3 -c "import yaml,sys; yaml.safe_load(open('$FILE'))"`
36
+ 3. **Checks** for `on:` and `jobs:` keys
37
+ 4. **Reports** any issues with line number if available
38
+ 5. **Suggests** local testing tools if validation passes
39
+
40
+ ## Local Testing Suggestion
41
+
42
+ If validation passes, the hook suggests running the workflow locally:
43
+
44
+ - **act** — [github.com/nektos/act](https://github.com/nektos/act): `act push --container-architecture linux/amd64`
45
+ - **wrkflw** — lightweight alternative: `wrkflw run`
46
+
47
+ ## Implementation (Claude Code JSON)
48
+
49
+ ```json
50
+ {
51
+ "hooks": {
52
+ "PostToolUse": [
53
+ {
54
+ "matcher": "Write",
55
+ "hooks": [
56
+ {
57
+ "type": "command",
58
+ "command": "python3 -c \"\nimport sys, os, json\ntool_input = os.environ.get('TOOL_INPUT', '{}')\ntry:\n data = json.loads(tool_input)\nexcept Exception:\n sys.exit(0)\nfile_path = data.get('file_path', data.get('path', ''))\nimport re\nif not re.search(r'\\.github/workflows/.*\\.yml$', file_path):\n sys.exit(0)\nimport yaml\ntry:\n with open(file_path) as f:\n content = yaml.safe_load(f)\nexcept yaml.YAMLError as e:\n print('WORKFLOW SYNTAX ERROR: ' + str(e))\n sys.exit(1)\nexcept FileNotFoundError:\n sys.exit(0)\nwarnings = []\nif not content:\n warnings.append('Workflow file is empty')\nelse:\n if 'on' not in content and True not in content:\n warnings.append('Missing required key: on (trigger definition)')\n if 'jobs' not in content:\n warnings.append('Missing required key: jobs')\nif warnings:\n print('WORKFLOW VALIDATION WARNINGS for ' + file_path + ':')\n for w in warnings:\n print(' - ' + w)\nelse:\n print('Workflow YAML valid: ' + file_path)\n print('Tip: Test locally with:')\n print(' act push --container-architecture linux/amd64')\n print(' # or: wrkflw run')\nsys.exit(0)\n\""
59
+ }
60
+ ]
61
+ },
62
+ {
63
+ "matcher": "Edit",
64
+ "hooks": [
65
+ {
66
+ "type": "command",
67
+ "command": "python3 -c \"\nimport sys, os, json\ntool_input = os.environ.get('TOOL_INPUT', '{}')\ntry:\n data = json.loads(tool_input)\nexcept Exception:\n sys.exit(0)\nfile_path = data.get('file_path', data.get('path', ''))\nimport re\nif not re.search(r'\\.github/workflows/.*\\.yml$', file_path):\n sys.exit(0)\nimport yaml\ntry:\n with open(file_path) as f:\n content = yaml.safe_load(f)\nexcept yaml.YAMLError as e:\n print('WORKFLOW SYNTAX ERROR: ' + str(e))\n sys.exit(1)\nexcept FileNotFoundError:\n sys.exit(0)\nwarnings = []\nif not content:\n warnings.append('Workflow file is empty')\nelse:\n if 'on' not in content and True not in content:\n warnings.append('Missing required key: on (trigger definition)')\n if 'jobs' not in content:\n warnings.append('Missing required key: jobs')\nif warnings:\n print('WORKFLOW VALIDATION WARNINGS for ' + file_path + ':')\n for w in warnings:\n print(' - ' + w)\nelse:\n print('Workflow YAML valid: ' + file_path)\n print('Tip: Test locally with: act push --container-architecture linux/amd64')\nsys.exit(0)\n\""
68
+ }
69
+ ]
70
+ }
71
+ ]
72
+ }
73
+ }
74
+ ```
75
+
76
+ ## Examples
77
+
78
+ ### ✅ Valid Workflow
79
+ ```yaml
80
+ name: CI
81
+ on: [push, pull_request]
82
+ jobs:
83
+ test:
84
+ runs-on: ubuntu-latest
85
+ steps:
86
+ - uses: actions/checkout@v4
87
+ ```
88
+ → Output: `Workflow YAML valid: .github/workflows/ci.yml`
89
+
90
+ ### ❌ Invalid — Missing `jobs:`
91
+ ```yaml
92
+ name: CI
93
+ on: [push]
94
+ # jobs: missing!
95
+ ```
96
+ → Output: `WORKFLOW VALIDATION WARNINGS: Missing required key: jobs`
97
+
98
+ ## Notes
99
+
100
+ For local testing, install `act`: `brew install act` (macOS) or `apt install act` (Ubuntu via snap). See [nektos/act](https://github.com/nektos/act) for full docs.