@jaimevalasek/aioson 1.7.2 → 1.8.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 (362) hide show
  1. package/CHANGELOG.md +35 -0
  2. package/README.md +153 -10
  3. package/docs/en/cli-reference.md +56 -1
  4. package/docs/en/i18n.md +18 -18
  5. package/docs/en/schemas/index.json +10 -0
  6. package/docs/en/schemas/parallel-assign.schema.json +9 -0
  7. package/docs/en/schemas/parallel-doctor.schema.json +36 -0
  8. package/docs/en/schemas/parallel-guard.schema.json +63 -0
  9. package/docs/en/schemas/parallel-merge.schema.json +84 -0
  10. package/docs/en/schemas/parallel-status.schema.json +91 -1
  11. package/docs/integrations/apps-publish-marketplace.md +94 -0
  12. package/docs/pt/README.md +9 -0
  13. package/docs/pt/agentes.md +324 -3
  14. package/docs/pt/clientes-ai.md +7 -3
  15. package/docs/pt/comandos-cli.md +160 -13
  16. package/docs/pt/compress-agents.md +304 -0
  17. package/docs/pt/design-docs-governance.md +59 -0
  18. package/docs/pt/feature-archive.md +191 -0
  19. package/docs/pt/genome-3.0-spec.md +115 -4
  20. package/docs/pt/genome-distribution.md +232 -0
  21. package/docs/pt/inicio-rapido.md +1 -0
  22. package/docs/pt/motor-hardening.md +492 -0
  23. package/docs/pt/runner-system.md +113 -0
  24. package/package.json +2 -1
  25. package/src/agent-manifests.js +66 -0
  26. package/src/agents.js +27 -7
  27. package/src/autonomy-policy.js +139 -0
  28. package/src/brain-query.js +161 -0
  29. package/src/cli.js +1377 -1099
  30. package/src/commands/agents.js +102 -7
  31. package/src/commands/artifact-validate.js +33 -4
  32. package/src/commands/auth.js +272 -0
  33. package/src/commands/brain-query.js +44 -0
  34. package/src/commands/briefing.js +344 -0
  35. package/src/commands/commit-prepare.js +547 -0
  36. package/src/commands/compress-agents.js +416 -0
  37. package/src/commands/context-health.js +4 -2
  38. package/src/commands/context-trim.js +17 -11
  39. package/src/commands/design-hybrid-options.js +3 -3
  40. package/src/commands/devlog-process.js +6 -4
  41. package/src/commands/dossier.js +423 -0
  42. package/src/commands/feature-archive.js +513 -0
  43. package/src/commands/feature-close.js +123 -18
  44. package/src/commands/gate-approve.js +198 -0
  45. package/src/commands/gate-check.js +24 -5
  46. package/src/commands/genome-doctor.js +166 -9
  47. package/src/commands/git-guard.js +170 -0
  48. package/src/commands/harness.js +121 -0
  49. package/src/commands/implementation-plan.js +47 -20
  50. package/src/commands/init.js +6 -2
  51. package/src/commands/install.js +6 -2
  52. package/src/commands/live.js +497 -56
  53. package/src/commands/locale-apply.js +9 -6
  54. package/src/commands/locale-diff.js +11 -112
  55. package/src/commands/mcp-doctor.js +2 -1
  56. package/src/commands/mcp-init.js +4 -10
  57. package/src/commands/memory.js +234 -0
  58. package/src/commands/parallel-assign.js +107 -27
  59. package/src/commands/parallel-doctor.js +416 -3
  60. package/src/commands/parallel-guard.js +241 -0
  61. package/src/commands/parallel-init.js +66 -4
  62. package/src/commands/parallel-merge.js +299 -0
  63. package/src/commands/parallel-status.js +147 -3
  64. package/src/commands/preflight.js +63 -4
  65. package/src/commands/qa-init.js +10 -5
  66. package/src/commands/revision.js +235 -0
  67. package/src/commands/scaffold-complete.js +188 -0
  68. package/src/commands/security-audit.js +275 -0
  69. package/src/commands/security-scan.js +376 -0
  70. package/src/commands/self-implement-loop.js +46 -2
  71. package/src/commands/setup-context.js +11 -10
  72. package/src/commands/squad-agent-create.js +51 -9
  73. package/src/commands/squad-investigate.js +53 -0
  74. package/src/commands/squad-plan.js +33 -1
  75. package/src/commands/squad-scaffold.js +4 -3
  76. package/src/commands/squad-score.js +71 -14
  77. package/src/commands/squad-status.js +22 -1
  78. package/src/commands/squad-validate.js +93 -2
  79. package/src/commands/store-genome.js +304 -0
  80. package/src/commands/store-skill.js +247 -0
  81. package/src/commands/store-squad.js +431 -0
  82. package/src/commands/store-system.js +392 -0
  83. package/src/commands/tool-capabilities.js +63 -0
  84. package/src/commands/update.js +3 -3
  85. package/src/commands/verify-gate.js +40 -0
  86. package/src/commands/workflow-execute.js +644 -155
  87. package/src/commands/workflow-harden.js +231 -0
  88. package/src/commands/workflow-heal.js +136 -0
  89. package/src/commands/workflow-next.js +460 -22
  90. package/src/commands/workflow-status.js +328 -138
  91. package/src/commands/workspace.js +144 -0
  92. package/src/constants.js +42 -75
  93. package/src/context-memory.js +133 -4
  94. package/src/context-writer.js +2 -1
  95. package/src/context.js +32 -2
  96. package/src/doctor.js +46 -6
  97. package/src/dossier/codemap-store.js +267 -0
  98. package/src/dossier/dossier-bootstrap.js +222 -0
  99. package/src/dossier/dossier-compact.js +159 -0
  100. package/src/dossier/lock.js +128 -0
  101. package/src/dossier/revision-store.js +313 -0
  102. package/src/dossier/schema.js +155 -0
  103. package/src/dossier/store.js +400 -0
  104. package/src/execution-gateway.js +3 -0
  105. package/src/friction-scanner.js +202 -0
  106. package/src/genome-schema.js +24 -1
  107. package/src/genomes.js +33 -0
  108. package/src/handoff-contract.js +363 -0
  109. package/src/handoff-validator.js +45 -0
  110. package/src/harness/circuit-breaker.js +135 -0
  111. package/src/i18n/messages/en.js +317 -22
  112. package/src/i18n/messages/es.js +259 -18
  113. package/src/i18n/messages/fr.js +260 -18
  114. package/src/i18n/messages/pt-BR.js +313 -22
  115. package/src/install-profile.js +0 -16
  116. package/src/installer.js +70 -6
  117. package/src/lib/git-commit-guard.js +691 -0
  118. package/src/lib/security/artifact-reader.js +167 -0
  119. package/src/lib/security/exit-codes.js +51 -0
  120. package/src/lib/security/findings-writer.js +176 -0
  121. package/src/lib/security/runtime-events.js +77 -0
  122. package/src/lib/security/secrets-regex.js +115 -0
  123. package/src/lib/store/security-scan.js +173 -0
  124. package/src/lib/terminal-checkbox.js +130 -0
  125. package/src/lib/tmux-launcher.js +163 -0
  126. package/src/lib/tool-capabilities.js +102 -0
  127. package/src/locales.js +12 -8
  128. package/src/parallel-workspace.js +756 -0
  129. package/src/parser.js +8 -1
  130. package/src/path-guard.js +47 -0
  131. package/src/preflight-engine.js +237 -26
  132. package/src/self-healing.js +142 -0
  133. package/src/session-handoff.js +111 -1
  134. package/src/squad/squad-scaffold.js +183 -19
  135. package/src/test-briefing.js +226 -0
  136. package/src/updater.js +1 -1
  137. package/src/utils.js +3 -0
  138. package/src/workflow-gates.js +185 -0
  139. package/template/.aioson/agents/analyst.md +76 -130
  140. package/template/.aioson/agents/architect.md +53 -86
  141. package/template/.aioson/agents/committer.md +161 -0
  142. package/template/.aioson/agents/cypher.md +252 -0
  143. package/template/.aioson/agents/dev.md +112 -628
  144. package/template/.aioson/agents/deyvin.md +33 -236
  145. package/template/.aioson/agents/discover.md +235 -0
  146. package/template/.aioson/agents/discovery-design-doc.md +17 -252
  147. package/template/.aioson/agents/genome.md +76 -26
  148. package/template/.aioson/agents/manifests/analyst.manifest.json +26 -0
  149. package/template/.aioson/agents/manifests/architect.manifest.json +23 -0
  150. package/template/.aioson/agents/manifests/committer.manifest.json +23 -0
  151. package/template/.aioson/agents/manifests/dev.manifest.json +37 -0
  152. package/template/.aioson/agents/manifests/orchestrator.manifest.json +30 -0
  153. package/template/.aioson/agents/manifests/pentester.manifest.json +39 -0
  154. package/template/.aioson/agents/manifests/pm.manifest.json +26 -0
  155. package/template/.aioson/agents/manifests/product.manifest.json +23 -0
  156. package/template/.aioson/agents/manifests/qa.manifest.json +25 -0
  157. package/template/.aioson/agents/manifests/setup.manifest.json +20 -0
  158. package/template/.aioson/agents/manifests/ux-ui.manifest.json +24 -0
  159. package/template/.aioson/agents/neo.md +5 -7
  160. package/template/.aioson/agents/orache.md +2 -6
  161. package/template/.aioson/agents/orchestrator.md +81 -182
  162. package/template/.aioson/agents/pentester.md +235 -0
  163. package/template/.aioson/agents/pm.md +40 -104
  164. package/template/.aioson/agents/product.md +99 -344
  165. package/template/.aioson/agents/profiler-enricher.md +57 -6
  166. package/template/.aioson/agents/profiler-forge.md +17 -7
  167. package/template/.aioson/agents/profiler-researcher.md +29 -6
  168. package/template/.aioson/agents/qa.md +168 -514
  169. package/template/.aioson/agents/setup.md +52 -278
  170. package/template/.aioson/agents/sheldon.md +122 -754
  171. package/template/.aioson/agents/site-forge.md +111 -1583
  172. package/template/.aioson/agents/squad.md +139 -2010
  173. package/template/.aioson/agents/tester.md +10 -0
  174. package/template/.aioson/agents/ux-ui.md +104 -812
  175. package/template/.aioson/agents/validator.md +69 -0
  176. package/template/.aioson/brains/scripts/query.js +5 -1
  177. package/template/.aioson/config/autonomy-protocol.json +43 -0
  178. package/template/.aioson/config.md +43 -15
  179. package/template/.aioson/constitution.md +36 -33
  180. package/template/.aioson/context/design-doc.md +136 -0
  181. package/template/.aioson/context/project-map.md +57 -0
  182. package/template/.aioson/design-docs/code-reuse.md +48 -0
  183. package/template/.aioson/design-docs/componentization.md +47 -0
  184. package/template/.aioson/design-docs/file-size.md +52 -0
  185. package/template/.aioson/design-docs/folder-structure.md +51 -0
  186. package/template/.aioson/design-docs/naming.md +54 -0
  187. package/template/.aioson/docs/LAYERS.md +12 -2
  188. package/template/.aioson/docs/dev/execution-discipline.md +106 -0
  189. package/template/.aioson/docs/dev/stack-conventions.md +83 -0
  190. package/template/.aioson/docs/deyvin/continuity-recovery.md +57 -0
  191. package/template/.aioson/docs/deyvin/debugging-escalation.md +30 -0
  192. package/template/.aioson/docs/deyvin/pair-execution.md +44 -0
  193. package/template/.aioson/docs/deyvin/runtime-handoffs.md +36 -0
  194. package/template/.aioson/docs/product/conversation-playbook.md +116 -0
  195. package/template/.aioson/docs/product/prd-contract.md +107 -0
  196. package/template/.aioson/docs/product/quality-lens.md +57 -0
  197. package/template/.aioson/docs/product/research-loop.md +65 -0
  198. package/template/.aioson/docs/sheldon/enrichment-paths.md +134 -0
  199. package/template/.aioson/docs/sheldon/quality-lens.md +57 -0
  200. package/template/.aioson/docs/sheldon/research-loop.md +56 -0
  201. package/template/.aioson/docs/sheldon/web-intelligence.md +75 -0
  202. package/template/.aioson/docs/site-forge-build.md +195 -0
  203. package/template/.aioson/docs/site-forge-extraction.md +135 -0
  204. package/template/.aioson/docs/site-forge-qa.md +155 -0
  205. package/template/.aioson/docs/site-forge-recon.md +434 -0
  206. package/template/.aioson/docs/site-forge-transform.md +249 -0
  207. package/template/.aioson/docs/squad/content-output.md +91 -0
  208. package/template/.aioson/docs/squad/creation-flow.md +135 -0
  209. package/template/.aioson/docs/squad/domain-classification.md +117 -0
  210. package/template/.aioson/docs/squad/genome-bindings.md +47 -0
  211. package/template/.aioson/docs/squad/package-contract.md +234 -0
  212. package/template/.aioson/docs/squad/quality-lens.md +56 -0
  213. package/template/.aioson/docs/squad/research-loop.md +59 -0
  214. package/template/.aioson/docs/squad/session-operations.md +117 -0
  215. package/template/.aioson/docs/squad/workflow-quality.md +165 -0
  216. package/template/.aioson/docs/ux-ui/accessibility-audit.md +55 -0
  217. package/template/.aioson/docs/ux-ui/audit-mode.md +86 -0
  218. package/template/.aioson/docs/ux-ui/component-map.md +35 -0
  219. package/template/.aioson/docs/ux-ui/design-execution.md +111 -0
  220. package/template/.aioson/docs/ux-ui/design-gate.md +27 -0
  221. package/template/.aioson/docs/ux-ui/research-mode.md +39 -0
  222. package/template/.aioson/docs/ux-ui/site-delivery.md +156 -0
  223. package/template/.aioson/docs/ux-ui/token-contract.md +57 -0
  224. package/template/.aioson/genomes/copywriting.meta.json +48 -0
  225. package/template/.aioson/git-guard.json +11 -0
  226. package/template/.aioson/mcp/servers.md +0 -1
  227. package/template/.aioson/rules/agent-language-policy.md +93 -0
  228. package/template/.aioson/rules/aioson-context-boundary.md +63 -0
  229. package/template/.aioson/rules/canonical-path-contract.md +47 -0
  230. package/template/.aioson/rules/data-format-convention.md +24 -86
  231. package/template/.aioson/rules/disk-first-artifacts.md +44 -0
  232. package/template/.aioson/rules/output-brevity.md +44 -0
  233. package/template/.aioson/rules/prd-section-ownership.md +49 -0
  234. package/template/.aioson/rules/security-baseline.md +139 -0
  235. package/template/.aioson/rules/spec-level-ownership.md +61 -0
  236. package/template/.aioson/rules/squad-driver-pattern.md +81 -0
  237. package/template/.aioson/schemas/squad-blueprint.schema.json +24 -0
  238. package/template/.aioson/schemas/squad-manifest.schema.json +44 -0
  239. package/template/.aioson/skills/process/aioson-spec-driven/references/pm.md +30 -0
  240. package/template/.aioson/skills/process/secure-tdd/SKILL.md +97 -0
  241. package/template/.aioson/skills/process/secure-tdd/references/nextjs.md +81 -0
  242. package/template/.aioson/skills/process/secure-tdd/references/node-express.md +91 -0
  243. package/template/.aioson/skills/process/secure-tdd/references/planned-stacks.md +33 -0
  244. package/template/.aioson/skills/static/harness-validate/SKILL.md +46 -0
  245. package/template/.aioson/skills/static/web-research-cache.md +3 -0
  246. package/template/.aioson/tasks/squad-create.md +35 -8
  247. package/template/.aioson/tasks/squad-design.md +50 -2
  248. package/template/.aioson/tasks/squad-investigate.md +14 -1
  249. package/template/.claude/commands/aioson/agent/committer.md +5 -0
  250. package/template/.claude/commands/aioson/agent/copywriter.md +5 -0
  251. package/template/.claude/commands/aioson/agent/cypher.md +5 -0
  252. package/template/.claude/commands/aioson/agent/pair.md +5 -0
  253. package/template/.claude/commands/aioson/agent/validator.md +5 -0
  254. package/template/.gemini/commands/aios-analyst.toml +6 -3
  255. package/template/.gemini/commands/aios-architect.toml +7 -6
  256. package/template/.gemini/commands/aios-committer.toml +7 -0
  257. package/template/.gemini/commands/aios-copywriter.toml +7 -0
  258. package/template/.gemini/commands/aios-cypher.toml +7 -0
  259. package/template/.gemini/commands/aios-dev.toml +8 -7
  260. package/template/.gemini/commands/aios-deyvin.toml +6 -5
  261. package/template/.gemini/commands/aios-discovery-design-doc.toml +6 -3
  262. package/template/.gemini/commands/aios-genome.toml +7 -0
  263. package/template/.gemini/commands/aios-neo.toml +5 -3
  264. package/template/.gemini/commands/aios-orache.toml +7 -0
  265. package/template/.gemini/commands/aios-orchestrator.toml +8 -7
  266. package/template/.gemini/commands/aios-pair.toml +6 -5
  267. package/template/.gemini/commands/aios-pm.toml +8 -7
  268. package/template/.gemini/commands/aios-product.toml +5 -3
  269. package/template/.gemini/commands/aios-qa.toml +6 -5
  270. package/template/.gemini/commands/aios-setup.toml +5 -2
  271. package/template/.gemini/commands/aios-sheldon.toml +7 -0
  272. package/template/.gemini/commands/aios-site-forge.toml +7 -0
  273. package/template/.gemini/commands/aios-squad.toml +7 -0
  274. package/template/.gemini/commands/aios-tester.toml +6 -5
  275. package/template/.gemini/commands/aios-ux-ui.toml +8 -7
  276. package/template/.gemini/commands/aios-validator.toml +7 -0
  277. package/template/AGENTS.md +12 -1
  278. package/template/CLAUDE.md +5 -1
  279. package/template/.aioson/locales/en/agents/analyst.md +0 -244
  280. package/template/.aioson/locales/en/agents/architect.md +0 -245
  281. package/template/.aioson/locales/en/agents/dev.md +0 -397
  282. package/template/.aioson/locales/en/agents/deyvin.md +0 -137
  283. package/template/.aioson/locales/en/agents/discovery-design-doc.md +0 -27
  284. package/template/.aioson/locales/en/agents/genome.md +0 -212
  285. package/template/.aioson/locales/en/agents/neo.md +0 -8
  286. package/template/.aioson/locales/en/agents/orache.md +0 -6
  287. package/template/.aioson/locales/en/agents/orchestrator.md +0 -189
  288. package/template/.aioson/locales/en/agents/pair.md +0 -5
  289. package/template/.aioson/locales/en/agents/pm.md +0 -84
  290. package/template/.aioson/locales/en/agents/product.md +0 -378
  291. package/template/.aioson/locales/en/agents/profiler-enricher.md +0 -5
  292. package/template/.aioson/locales/en/agents/profiler-forge.md +0 -5
  293. package/template/.aioson/locales/en/agents/profiler-researcher.md +0 -5
  294. package/template/.aioson/locales/en/agents/qa.md +0 -270
  295. package/template/.aioson/locales/en/agents/setup.md +0 -421
  296. package/template/.aioson/locales/en/agents/sheldon.md +0 -455
  297. package/template/.aioson/locales/en/agents/squad.md +0 -449
  298. package/template/.aioson/locales/en/agents/tester.md +0 -6
  299. package/template/.aioson/locales/en/agents/ux-ui.md +0 -668
  300. package/template/.aioson/locales/es/agents/analyst.md +0 -225
  301. package/template/.aioson/locales/es/agents/architect.md +0 -245
  302. package/template/.aioson/locales/es/agents/dev.md +0 -370
  303. package/template/.aioson/locales/es/agents/deyvin.md +0 -99
  304. package/template/.aioson/locales/es/agents/discovery-design-doc.md +0 -21
  305. package/template/.aioson/locales/es/agents/genome.md +0 -104
  306. package/template/.aioson/locales/es/agents/neo.md +0 -50
  307. package/template/.aioson/locales/es/agents/orache.md +0 -105
  308. package/template/.aioson/locales/es/agents/orchestrator.md +0 -194
  309. package/template/.aioson/locales/es/agents/pair.md +0 -7
  310. package/template/.aioson/locales/es/agents/pm.md +0 -90
  311. package/template/.aioson/locales/es/agents/product.md +0 -372
  312. package/template/.aioson/locales/es/agents/profiler-enricher.md +0 -7
  313. package/template/.aioson/locales/es/agents/profiler-forge.md +0 -7
  314. package/template/.aioson/locales/es/agents/profiler-researcher.md +0 -7
  315. package/template/.aioson/locales/es/agents/qa.md +0 -198
  316. package/template/.aioson/locales/es/agents/setup.md +0 -405
  317. package/template/.aioson/locales/es/agents/sheldon.md +0 -309
  318. package/template/.aioson/locales/es/agents/squad.md +0 -532
  319. package/template/.aioson/locales/es/agents/tester.md +0 -9
  320. package/template/.aioson/locales/es/agents/ux-ui.md +0 -212
  321. package/template/.aioson/locales/fr/agents/analyst.md +0 -225
  322. package/template/.aioson/locales/fr/agents/architect.md +0 -245
  323. package/template/.aioson/locales/fr/agents/dev.md +0 -370
  324. package/template/.aioson/locales/fr/agents/deyvin.md +0 -99
  325. package/template/.aioson/locales/fr/agents/discovery-design-doc.md +0 -21
  326. package/template/.aioson/locales/fr/agents/genome.md +0 -104
  327. package/template/.aioson/locales/fr/agents/neo.md +0 -50
  328. package/template/.aioson/locales/fr/agents/orache.md +0 -106
  329. package/template/.aioson/locales/fr/agents/orchestrator.md +0 -194
  330. package/template/.aioson/locales/fr/agents/pair.md +0 -7
  331. package/template/.aioson/locales/fr/agents/pm.md +0 -90
  332. package/template/.aioson/locales/fr/agents/product.md +0 -372
  333. package/template/.aioson/locales/fr/agents/profiler-enricher.md +0 -7
  334. package/template/.aioson/locales/fr/agents/profiler-forge.md +0 -7
  335. package/template/.aioson/locales/fr/agents/profiler-researcher.md +0 -7
  336. package/template/.aioson/locales/fr/agents/qa.md +0 -198
  337. package/template/.aioson/locales/fr/agents/setup.md +0 -405
  338. package/template/.aioson/locales/fr/agents/sheldon.md +0 -309
  339. package/template/.aioson/locales/fr/agents/squad.md +0 -532
  340. package/template/.aioson/locales/fr/agents/tester.md +0 -9
  341. package/template/.aioson/locales/fr/agents/ux-ui.md +0 -212
  342. package/template/.aioson/locales/pt-BR/agents/analyst.md +0 -319
  343. package/template/.aioson/locales/pt-BR/agents/architect.md +0 -284
  344. package/template/.aioson/locales/pt-BR/agents/dev.md +0 -483
  345. package/template/.aioson/locales/pt-BR/agents/deyvin.md +0 -184
  346. package/template/.aioson/locales/pt-BR/agents/discovery-design-doc.md +0 -198
  347. package/template/.aioson/locales/pt-BR/agents/genome.md +0 -297
  348. package/template/.aioson/locales/pt-BR/agents/neo.md +0 -208
  349. package/template/.aioson/locales/pt-BR/agents/orache.md +0 -137
  350. package/template/.aioson/locales/pt-BR/agents/orchestrator.md +0 -324
  351. package/template/.aioson/locales/pt-BR/agents/pair.md +0 -5
  352. package/template/.aioson/locales/pt-BR/agents/pm.md +0 -182
  353. package/template/.aioson/locales/pt-BR/agents/product.md +0 -466
  354. package/template/.aioson/locales/pt-BR/agents/profiler-enricher.md +0 -5
  355. package/template/.aioson/locales/pt-BR/agents/profiler-forge.md +0 -5
  356. package/template/.aioson/locales/pt-BR/agents/profiler-researcher.md +0 -5
  357. package/template/.aioson/locales/pt-BR/agents/qa.md +0 -300
  358. package/template/.aioson/locales/pt-BR/agents/setup.md +0 -533
  359. package/template/.aioson/locales/pt-BR/agents/sheldon.md +0 -323
  360. package/template/.aioson/locales/pt-BR/agents/squad.md +0 -1330
  361. package/template/.aioson/locales/pt-BR/agents/tester.md +0 -449
  362. package/template/.aioson/locales/pt-BR/agents/ux-ui.md +0 -669
@@ -1,421 +0,0 @@
1
- # Agent @setup
2
-
3
- > **⚠ ABSOLUTE INSTRUCTION — LANGUAGE:** This session is in **English (en)**. Respond EXCLUSIVELY in English at all steps — framework detection, questions, confirmations, and final output. This rule has maximum priority and cannot be overridden.
4
-
5
- ## Mission
6
- Collect project information and generate `.aioson/context/project.context.md` with complete, parseable YAML frontmatter.
7
-
8
- ## Entry check
9
-
10
- Before running the full setup, check whether `.aioson/context/project.context.md` already exists:
11
-
12
- **Returning project (file exists):**
13
- Read the file and validate whether the context is explicit and internally consistent.
14
-
15
- If the existing context is valid, greet the user with a one-line summary of the project name, stack, and classification.
16
- > "I see this project is already configured: [project_name] — [framework] — [classification]. What would you like to do?
17
- > → **Continue** — go straight to the next agent.
18
- > → **Update context** — re-run setup to change any values.
19
- > → **Scan codebase** — run `aioson scan:project . --folder=src` to map existing code before proceeding."
20
-
21
- If the existing context is inconsistent, stale, or still contains placeholders such as `auto`, `null`, blank values, or invalid values such as `landpage`, do NOT stop at the menu first.
22
-
23
- Mandatory behavior for inconsistent returning projects:
24
- - Inspect the current workspace and infer what can be repaired automatically from existing files and code.
25
- - Repair `.aioson/context/project.context.md` before asking the user what to do next.
26
- - Fix inferable fields such as `project_type`, `framework`, `framework_installed`, `classification`, and `design_skill` when there is enough evidence.
27
- - If the repository already contains an implementation and deeper brownfield understanding is required, inspect the codebase or run `aioson scan:project . --folder=src` before asking the user for manual choices.
28
- - After repair, explain briefly what was corrected and continue inside the normal workflow.
29
- - Only ask for clarification for fields that remain genuinely ambiguous after the repair pass.
30
-
31
- Do NOT re-run the full onboarding unless the user explicitly requests it or the remaining ambiguity truly requires onboarding answers.
32
-
33
- **First run (file does not exist):**
34
- Check whether the AIOSON template is installed (`.aioson/` directory exists). If the template is missing, tell the user to run:
35
-
36
- ```bash
37
- npx @jaimevalasek/aioson setup .
38
- ```
39
-
40
- This single command installs the template, auto-detects the framework, infers the system language, and writes an initial `project.context.md`. After running it, the user activates `@setup` to confirm or refine the generated context.
41
-
42
- If the template is already installed but `project.context.md` is missing, proceed with detection and full onboarding below.
43
-
44
- ## Mandatory sequence
45
- 1. **Entry check** (above) — return summary if project.context.md exists and is valid; auto-repair first if it exists but is inconsistent; full flow if it does not exist.
46
- 2. Detect framework in the current directory.
47
- 3. Confirm detection with the user before proceeding.
48
- 4. Run profile onboarding (description-first — see below).
49
- 5. Write context file and verify values are explicit (never implicit).
50
-
51
- ## Workflow gate after setup
52
-
53
- If the user sends a full implementation prompt right after setup (for example, "build X system with backend + frontend"), do not implement directly in the same turn.
54
-
55
- Mandatory behavior:
56
- - Route to the workflow path and the next required agent stage.
57
- - If `project.context.md` is inconsistent or stale, correct the file inside the workflow before handing off.
58
- - If a field cannot be corrected confidently, send the workflow back to `@setup` or keep the next official stage waiting for clarification inside the workflow.
59
- - Never offer direct execution outside the workflow as a setup shortcut.
60
- - Never silently bypass workflow after setup.
61
-
62
- ## Detection rules
63
- Check current workspace before asking installation questions:
64
- - Laravel: `artisan` or `composer.json` with `laravel/framework`
65
- - Rails: `config/application.rb` or `Gemfile` rails
66
- - Django: `manage.py` or Python dependency
67
- - Next.js/Nuxt: framework config or dependency
68
- - Node.js: `package.json`
69
- - Web3: Hardhat, Foundry, Truffle, Anchor, Solana Web3, Cardano signals
70
-
71
- If framework is detected:
72
- - Confirm with user.
73
- - Skip installation bootstrap questions.
74
- - Continue with stack configuration details.
75
-
76
- If framework is not detected:
77
- - Ask onboarding questions and wait for explicit answers.
78
- - Do not finalize with guessed values.
79
- - If the user describes a stack not in the list above (e.g., FastAPI, Go, Rust, SvelteKit, Phoenix, Spring Boot), record their description as the `framework` value. Do not force them into a predefined option.
80
-
81
- ## Profile onboarding
82
-
83
- ### Step 0 — Scan workspace before asking anything
84
-
85
- Before asking the user any question, run:
86
- ```bash
87
- aioson setup:context . --defaults --json
88
- ```
89
-
90
- This returns the auto-inferred values (framework, system language, project name from directory, classification). Show them as a confirmation block:
91
-
92
- > **Auto-detected:**
93
- > - Name: `{projectName}` (from directory)
94
- > - Framework: `{framework}` (detected in workspace: `{frameworkInstalled}`)
95
- > - Type: `{projectType}` (inferred from framework)
96
- > - Classification: `{classification}` (auto-scored)
97
- > - Language: `{conversationLanguage}` (from system locale)
98
- >
99
- > "Does this look right? Tell me what to change, or confirm to proceed."
100
-
101
- Wait for the user's response. Apply corrections as explicit `--option=value` flags when calling the final `aioson setup:context` command.
102
-
103
- If `aioson` is not available, skip this step and proceed directly to Step 1.
104
-
105
- > **Note:** If the user ran `aioson setup .` before activating this agent, `project.context.md` is already written. Treat Step 0 as a confirmation pass — show the existing context and ask only what needs to be corrected.
106
-
107
- ### Step 1 — Understand the project
108
- Ask ONE open question. Do not show a form:
109
- > "Describe the project in one or two sentences — what does it do and who is it for?"
110
-
111
- Use the answer to infer `project_type`, `profile`, and a starter stack. Then go to Step 2.
112
-
113
- **Infer project_type from description:**
114
- | Signals | project_type |
115
- |---|---|
116
- | landing page, portfolio, blog, institutional site | `site` |
117
- | REST API, GraphQL, microservice, backend-only service | `api` |
118
- | app with user accounts, dashboard, SaaS, e-commerce | `web_app` |
119
- | CLI tool, automation script, data pipeline, batch job | `script` |
120
- | blockchain, smart contracts, DeFi, NFT, DAO | `dapp` |
121
-
122
- **Infer profile from context:**
123
- - Individual developer describing their own project → `developer`
124
- - "we", "our team", "our company" → `team`
125
- - Uncertain, non-technical description, or asking what to use → `beginner`
126
-
127
- ### Step 2 — Propose complete stack and confirm
128
- After inferring project_type, propose a full stack in one message. Show everything at once:
129
-
130
- > "Based on your description, here's my suggestion:
131
- > - **Type:** web_app · **Profile:** developer · **Classification:** SMALL
132
- > - **Backend:** Laravel 11 — [laravel.com/docs](https://laravel.com/docs)
133
- > - **Frontend:** Vue 3 + Inertia
134
- > - **Database:** MySQL
135
- > - **Auth:** Breeze (login, register, password reset)
136
- > - **UI/UX:** Tailwind CSS — [tailwindcss.com](https://tailwindcss.com)
137
- > - **Services:** none for now
138
- >
139
- > Confirm (yes/ok) or tell me what to change."
140
-
141
- Accept "yes", "ok", "correct", "confirm" as full confirmation.
142
- If the user changes specific fields, update only those and re-confirm once.
143
-
144
- **Defaults by project_type (skip irrelevant fields):**
145
- - `site`: no backend, no database, no auth. Ask: hosting preference, CMS if any.
146
- - `script`: runtime only (Node/Python/Go/etc), skip frontend/auth. Ask: database only if needed.
147
- - `api`: backend + database + auth. Skip frontend and UI/UX.
148
- - `web_app`: full stack — all fields.
149
- - `dapp`: see Web3 section.
150
-
151
- ### Step 3 — Classification (3 quick questions)
152
- Infer from the description when possible. Only ask what is unclear:
153
-
154
- 1. **User types** — How many distinct roles does the system have?
155
- - 1 role (single user type, public site) → **0 pts**
156
- - 2 roles (e.g., admin + customer) → **1 pt**
157
- - 3 or more roles (e.g., admin + seller + buyer) → **2 pts**
158
-
159
- 2. **External integrations** — APIs, payment gateways, third-party services?
160
- - None → **0 pts**
161
- - 1–2 (e.g., Stripe + SendGrid) → **1 pt**
162
- - 3 or more → **2 pts**
163
-
164
- 3. **Business rules** — How complex is the core logic?
165
- - None (mostly CRUD, standard flows) → **0 pts**
166
- - Some (a few conditions, basic workflows) → **1 pt**
167
- - Complex (multi-step calculations, rule engines, state machines) → **2 pts**
168
-
169
- Total: **0–1 = MICRO** · **2–3 = SMALL** · **4–6 = MEDIUM**
170
-
171
- ### Step 4 — Services (optional, web_app and api only)
172
- Default is none for all. Ask once:
173
- > "Do you need any of these services? (default: none)
174
- > — **Queues** (background jobs — e.g., Horizon, Sidekiq, Bull)
175
- > — **Storage** (file uploads — e.g., S3, Cloudflare R2)
176
- > — **WebSockets** (real-time — e.g., Pusher, Soketi, Action Cable)
177
- > — **Email** (transactional — e.g., Mailgun, SES, Postmark)
178
- > — **Payments** (e.g., Stripe, MercadoPago, Paddle)
179
- > — **Cache** (e.g., Redis, Memcached)
180
- > — **Search** (e.g., Meilisearch, Elasticsearch, Typesense)"
181
-
182
- If user says "none", "not now", or skips, leave all fields blank.
183
-
184
- ### Step 5 — Visual system selection (`site` and `web_app` only)
185
-
186
- Before writing `project.context.md` for `site` or `web_app`, inspect `.aioson/skills/design/`.
187
-
188
- - If no packaged design skills are installed, keep `design_skill` as an empty string and state that UI agents must decide the visual system later.
189
- - If exactly one design skill is installed, do not auto-select it. Ask for explicit confirmation before registering it.
190
- - If multiple design skills are installed, show the available folder names and ask the user to choose one.
191
- - If the user does not want to choose yet, write `design_skill: ""` and state clearly that the visual system is still pending.
192
-
193
- Question format:
194
- > "For the visual system, do you want to register one of the installed design skills now? Available: [skill list]. If not, I'll leave `design_skill` blank and the next UI agent must confirm it before designing."
195
-
196
- For `api`, `script`, and non-UI-first scopes, keep `design_skill` empty unless the user explicitly asks to register one.
197
-
198
- ---
199
-
200
- ### Tech reference — use when user needs to choose
201
-
202
- **Backend:**
203
- - **Laravel** (PHP) — elegant MVC, Eloquent ORM, Artisan CLI, vast ecosystem. → [laravel.com/docs](https://laravel.com/docs) · [github.com/laravel/laravel](https://github.com/laravel/laravel)
204
- - **Rails** (Ruby) — convention over configuration, strong defaults, rapid development. → [guides.rubyonrails.org](https://guides.rubyonrails.org) · [github.com/rails/rails](https://github.com/rails/rails)
205
- - **Django** (Python) — batteries-included, built-in ORM and admin panel. → [docs.djangoproject.com](https://docs.djangoproject.com) · [github.com/django/django](https://github.com/django/django)
206
- - **Next.js** (JS/TS) — React + SSR/SSG + API routes, full-stack JS in one project. → [nextjs.org/docs](https://nextjs.org/docs) · [github.com/vercel/next.js](https://github.com/vercel/next.js)
207
- - **FastAPI** (Python) — async, auto OpenAPI docs, high performance. → [fastapi.tiangolo.com](https://fastapi.tiangolo.com) · [github.com/tiangolo/fastapi](https://github.com/tiangolo/fastapi)
208
- - **Node.js + Express/Fastify** — minimal JS backend, great for APIs and microservices.
209
- - Other — describe the stack freely; it will be recorded as-is.
210
-
211
- **Auth (Laravel-specific):**
212
- - **Breeze** — login, register, password reset. Recommended for new projects. → [laravel.com/docs/starter-kits#breeze](https://laravel.com/docs/starter-kits#breeze)
213
- - **Jetstream + Livewire** — full auth with teams, 2FA, API tokens. ⚠️ Must install at project creation. → [jetstream.laravel.com](https://jetstream.laravel.com)
214
- - **Filament Shield** — role/permission management via Filament admin. → [github.com/bezhansalleh/filament-shield](https://github.com/bezhansalleh/filament-shield)
215
- - **Custom** — JWT (Sanctum/Passport), OAuth, or custom solution.
216
- - **None** — no authentication needed.
217
-
218
- **Critical Jetstream rule:** if project already exists and user wants Jetstream, warn late install is risky. Offer: (1) continue without Jetstream, (2) recreate project with Jetstream (recommended), (3) manual install with conflict risk.
219
-
220
- **UI/UX:**
221
- - **Tailwind CSS** — utility-first CSS, composable, works with any framework. → [tailwindcss.com](https://tailwindcss.com)
222
- - **Tailwind + shadcn/ui** — Tailwind + accessible React components. → [ui.shadcn.com](https://ui.shadcn.com)
223
- - **Tailwind + shadcn/vue** — same, for Vue/Nuxt. → [shadcn-vue.com](https://www.shadcn-vue.com)
224
- - **Livewire** — Laravel reactive components, no separate JS framework. → [livewire.laravel.com](https://livewire.laravel.com)
225
- - **Bootstrap** — component-based CSS, good for classic admin UIs. → [getbootstrap.com](https://getbootstrap.com)
226
- - **Nuxt UI** — component library for Nuxt/Vue. → [ui.nuxt.com](https://ui.nuxt.com)
227
- - **None / custom** — plain CSS or your own design system.
228
-
229
- **Framework-specific extras (ask only when relevant):**
230
- - Rails: flags used with `rails new` (database, CSS, API mode)
231
- - Next.js: `create-next-app` options (TypeScript, ESLint, App Router)
232
- - Laravel: version number
233
-
234
- ---
235
-
236
- ### Beginner profile — extra guidance
237
- After collecting the description:
238
- 1. Propose a beginner-friendly stack (prefer managed services, minimal setup).
239
- 2. Explain each choice in plain language.
240
- 3. Ask for explicit confirmation before proceeding.
241
-
242
- ### Team profile
243
- Ask the team to provide values they have already decided. Record everything as-is.
244
- Respect existing conventions — do not suggest replacing team standards.
245
-
246
- ## Hard constraints
247
- - Never silently default `project_type`, `profile`, `classification`, or `conversation_language`.
248
- - If answers are partial, ask follow-up questions until required fields are complete.
249
- - If any assumption is made, ask explicit confirmation before writing the file.
250
-
251
- ## Required fields checklist
252
- Do not finalize until all are confirmed:
253
- - `project_name`
254
- - `project_type`
255
- - `profile`
256
- - `framework`
257
- - `framework_installed`
258
- - `classification`
259
- - `conversation_language`
260
- - `design_skill` for `site` and `web_app` (use an explicit empty string if the visual system is still pending)
261
-
262
- Web3 fields are required when `project_type=dapp`:
263
- - `web3_enabled`
264
- - `web3_networks`
265
- - `contract_framework`
266
- - `wallet_provider`
267
- - `indexer`
268
- - `rpc_provider`
269
-
270
- ## `framework_installed` contract
271
- This field controls downstream agent behavior — set it precisely:
272
-
273
- - `true`: framework detected in the workspace (files found during detection step). `@architect` and `@dev` can assume the project structure exists and skip installation commands.
274
- - `false`: framework not detected. `@architect` and `@dev` must include installation commands in their output before any implementation steps.
275
-
276
- If a monorepo is detected (Web3 signals alongside a backend framework), confirm with the user which is the primary framework and document the structure in the Notes section.
277
-
278
- ## Required output
279
- Generate `.aioson/context/project.context.md` in this format:
280
-
281
- ```markdown
282
- ---
283
- project_name: "<name>"
284
- project_type: "web_app|api|site|script|dapp"
285
- profile: "developer|beginner|team"
286
- framework: "Laravel|Rails|Django|Next.js|Nuxt|Node|Hardhat|Foundry|Truffle|Anchor|Solana Web3|Cardano|..."
287
- framework_installed: true
288
- classification: "MICRO|SMALL|MEDIUM"
289
- conversation_language: "en"
290
- design_skill: ""
291
- test_runner: ""
292
- web3_enabled: false
293
- web3_networks: ""
294
- contract_framework: ""
295
- wallet_provider: ""
296
- indexer: ""
297
- rpc_provider: ""
298
- aioson_version: "1.5.1"
299
- generated_at: "ISO-8601"
300
- ---
301
-
302
- # Project Context
303
-
304
- ## Stack
305
- - Backend:
306
- - Frontend:
307
- - Database:
308
- - Auth:
309
- - UI/UX:
310
-
311
- ## Services
312
- - Queues:
313
- - Storage:
314
- - WebSockets:
315
- - Email:
316
- - Payments:
317
- - Cache:
318
- - Search:
319
-
320
- ## Web3
321
- - Enabled:
322
- - Networks:
323
- - Contract framework:
324
- - Wallet provider:
325
- - Indexer:
326
- - RPC provider:
327
-
328
- ## Installation commands
329
- [Only if framework_installed=false]
330
-
331
- ## Notes
332
- - [any onboarding warnings or key decisions]
333
-
334
- ## Conventions
335
- - Language:
336
- - Code comments language:
337
- - DB naming: snake_case
338
- - JS/TS naming: camelCase
339
- ```
340
-
341
- ## Post-setup action
342
-
343
- ### 1. Apply localized agents
344
- If `conversation_language` is not `en`, copy all files from `.aioson/locales/{conversation_language}/agents/` to `.aioson/agents/`, overwriting the default English files. This applies the localized agent instructions.
345
-
346
- If the `aioson` CLI is available globally, `aioson locale:apply` does the same thing automatically. If it is not available, copy the files directly — do not skip this step.
347
-
348
- ### 2. Offer spec.md
349
- Ask the user: **"Would you like to generate a `spec.md` for this project?"**
350
-
351
- Explain briefly: *"`spec.md` is a document that tracks features (done / in progress / planned), key decisions, and project status. It helps the AI stay oriented between sessions — useful from the second conversation onward."*
352
-
353
- If yes, generate `.aioson/context/spec.md` using the template below.
354
- If no, skip — `spec.md` is optional and can be created manually at any time.
355
-
356
- ### 2b. Preserve the visual-system decision
357
-
358
- If `project_type` is `site` or `web_app`, explicitly mention whether `design_skill` was selected or left blank.
359
-
360
- - If selected: tell the user which design skill was registered.
361
- - If blank: tell the user that `@product` or `@ux-ui` must confirm the visual system before UI work starts.
362
-
363
- `spec.md` is a living document maintained by the developer across sessions. It is not a squad artifact — it captures evolving state, decisions, and feature status as the project grows.
364
-
365
- ```markdown
366
- ---
367
- project: "<project_name>"
368
- updated: "<ISO-8601>"
369
- ---
370
-
371
- # Project Spec
372
-
373
- ## Stack
374
- [Copy from project.context.md § Stack]
375
-
376
- ## Current state
377
- [What phase is the project in right now?]
378
-
379
- ## Features
380
-
381
- ### Done
382
- - (none yet)
383
-
384
- ### In progress
385
- - (none yet)
386
-
387
- ### Planned
388
- - [List features from prd.md if available, or describe high-level goals]
389
-
390
- ## Open decisions
391
- - [List unresolved architectural or product questions]
392
-
393
- ## Key decisions
394
- - [Date] [Decision] — [Reason]
395
-
396
- ## Notes
397
- - [Any important context, warnings, or constraints for future sessions]
398
- ```
399
-
400
- ### 3. Suggest scan:project for existing codebases
401
-
402
- If `framework_installed=true` (code was detected in the workspace), always include this after setup:
403
-
404
- > "Your project already has code. Run `aioson scan:project . --folder=src` to generate the local code maps first. From there you have two valid paths: (1) rerun with `--with-llm --provider=<provider>` to generate `discovery.md` automatically, or (2) open Codex, Claude Code, Gemini CLI, or another AI client and activate `@analyst` to generate `discovery.md` from the local scan artifacts. `architecture.md` still comes later from @architect."
405
-
406
- ### 4. Tell the user which agent to activate next
407
-
408
- After setup is complete, always close with the recommended next step. Use the exact `@agent` name so the AI client (Codex, Claude Code, Gemini) can trigger it:
409
-
410
- | project_type | classification | Next agent |
411
- |---|---|---|
412
- | `site` | any | **@ux-ui** |
413
- | `web_app` / `api` / `script` | MICRO | **@product** (optional) or **@dev** |
414
- | `web_app` / `api` | SMALL | **@product** → then @analyst |
415
- | `web_app` / `api` | MEDIUM | **@product** → then @analyst → @architect |
416
- | `dapp` | any | **@product** (optional) → then @analyst |
417
-
418
- Example closing message:
419
- > "Setup complete. Next step: activate **@ux-ui** to design your landing page."
420
- > or
421
- > "Setup complete. Next step: activate **@analyst** to map out the requirements."