bmad-plus 0.7.5 → 0.9.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 (281) hide show
  1. package/CHANGELOG.md +479 -425
  2. package/LICENSE +21 -21
  3. package/README.md +557 -447
  4. package/osint-agent-package/README.md +88 -88
  5. package/osint-agent-package/SETUP_KEYS.md +108 -108
  6. package/osint-agent-package/agents/osint-investigator.md +80 -80
  7. package/osint-agent-package/install.ps1 +87 -87
  8. package/osint-agent-package/install.sh +76 -76
  9. package/osint-agent-package/skills/bmad-osint-investigate/SKILL.md +147 -147
  10. package/osint-agent-package/skills/bmad-osint-investigate/osint/SKILL.md +452 -452
  11. package/osint-agent-package/skills/bmad-osint-investigate/osint/assets/dossier-template.md +116 -116
  12. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/content-extraction.md +100 -100
  13. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/enrichment-databases-fr.md +148 -148
  14. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/platforms.md +130 -130
  15. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/psychoprofile.md +69 -69
  16. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/tools.md +281 -281
  17. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/_http.py +101 -101
  18. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/apify.py +266 -260
  19. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/brightdata.py +101 -101
  20. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/diagnose.py +141 -141
  21. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/exa.py +79 -79
  22. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/jina.py +71 -71
  23. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/mcp-client.py +136 -136
  24. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/parallel.py +85 -85
  25. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/perplexity.py +102 -102
  26. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/tavily.py +72 -72
  27. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/volley.py +208 -208
  28. package/osint-agent-package/skills/bmad-osint-investigator/SKILL.md +15 -15
  29. package/package.json +62 -57
  30. package/readme-international/README.de.md +584 -426
  31. package/readme-international/README.es.md +601 -518
  32. package/readme-international/README.fr.md +599 -516
  33. package/src/bmad-plus/agents/agent-architect-dev/SKILL.md +96 -96
  34. package/src/bmad-plus/agents/agent-architect-dev/bmad-skill-manifest.yaml +13 -13
  35. package/src/bmad-plus/agents/agent-maker/SKILL.md +201 -201
  36. package/src/bmad-plus/agents/agent-maker/bmad-skill-manifest.yaml +13 -13
  37. package/src/bmad-plus/agents/agent-orchestrator/SKILL.md +137 -137
  38. package/src/bmad-plus/agents/agent-orchestrator/bmad-skill-manifest.yaml +13 -13
  39. package/src/bmad-plus/agents/agent-quality/SKILL.md +83 -83
  40. package/src/bmad-plus/agents/agent-quality/bmad-skill-manifest.yaml +13 -13
  41. package/src/bmad-plus/agents/agent-shadow/SKILL.md +71 -71
  42. package/src/bmad-plus/agents/agent-shadow/bmad-skill-manifest.yaml +13 -13
  43. package/src/bmad-plus/agents/agent-strategist/SKILL.md +80 -80
  44. package/src/bmad-plus/agents/agent-strategist/bmad-skill-manifest.yaml +13 -13
  45. package/src/bmad-plus/data/role-triggers.yaml +209 -209
  46. package/src/bmad-plus/module-help.csv +10 -10
  47. package/src/bmad-plus/module.yaml +283 -280
  48. package/src/bmad-plus/{agents → packs}/pack-animated/animated-website-agent.md +325 -325
  49. package/src/bmad-plus/{agents → packs}/pack-animated/templates/animated-website-workflow.md +55 -55
  50. package/src/bmad-plus/{agents → packs}/pack-backup/backup-agent.md +71 -71
  51. package/src/bmad-plus/{agents → packs}/pack-backup/templates/backup-workflow.md +51 -51
  52. package/src/bmad-plus/packs/pack-dev-studio/README.md +162 -162
  53. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/analyst-agent.md +73 -73
  54. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/document-project.md +61 -61
  55. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/domain-research.md +95 -95
  56. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/market-research.md +95 -95
  57. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/prfaq.md +134 -134
  58. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/product-brief.md +80 -80
  59. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/tech-writer-agent.md +73 -73
  60. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/technical-research.md +95 -95
  61. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/architect-agent.md +73 -73
  62. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/create-architecture.md +73 -73
  63. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/create-epics-stories.md +92 -92
  64. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/generate-project-context.md +80 -80
  65. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/implementation-readiness.md +90 -90
  66. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-01-init.md +153 -153
  67. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-01b-continue.md +173 -173
  68. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-02-context.md +224 -224
  69. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-03-starter.md +329 -329
  70. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-04-decisions.md +318 -318
  71. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-05-patterns.md +359 -359
  72. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-06-structure.md +379 -379
  73. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-07-validation.md +361 -361
  74. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-08-complete.md +81 -81
  75. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/checkpoint-preview.md +67 -67
  76. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-01-gather-context.md +85 -85
  77. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-02-review.md +35 -35
  78. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-03-triage.md +49 -49
  79. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-04-present.md +131 -131
  80. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review.md +89 -89
  81. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/correct-course.md +300 -300
  82. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/create-story.md +428 -428
  83. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-agent.md +73 -73
  84. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-story-checklist.md +80 -80
  85. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-story.md +484 -484
  86. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/investigate.md +193 -193
  87. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/qa-e2e-tests.md +175 -175
  88. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/quick-dev.md +110 -110
  89. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/retrospective.md +1511 -1511
  90. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/sprint-planning.md +298 -298
  91. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/sprint-status.md +296 -296
  92. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/create-prd.md +29 -29
  93. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/create-ux-design.md +74 -74
  94. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/edit-prd.md +29 -29
  95. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/pm-agent.md +73 -73
  96. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/prd.md +89 -89
  97. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/ux-designer-agent.md +73 -73
  98. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/validate-prd.md +29 -29
  99. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/advanced-elicitation.md +141 -141
  100. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/adversarial-review.md +37 -37
  101. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/bmad-help.md +75 -75
  102. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/brainstorming.md +6 -6
  103. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/customize.md +110 -110
  104. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/distillator.md +176 -176
  105. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/edge-case-hunter.md +67 -67
  106. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/editorial-review-prose.md +86 -86
  107. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/editorial-review-structure.md +179 -179
  108. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/index-docs.md +66 -66
  109. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/party-mode.md +127 -127
  110. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/shard-doc.md +105 -105
  111. package/src/bmad-plus/packs/pack-dev-studio/dev-studio-orchestrator.md +120 -120
  112. package/src/bmad-plus/packs/pack-dev-studio/shared/architecture-decision-template.md +12 -12
  113. package/src/bmad-plus/packs/pack-dev-studio/shared/bwml-spec.md +328 -328
  114. package/src/bmad-plus/packs/pack-dev-studio/shared/module-help.csv +32 -32
  115. package/src/bmad-plus/packs/pack-dev-studio/upstream-sync.yaml +81 -81
  116. package/src/bmad-plus/packs/pack-memory/README.md +106 -106
  117. package/src/bmad-plus/packs/pack-memory/memory-orchestrator.md +79 -79
  118. package/src/bmad-plus/packs/pack-memory/shared/karpathy-guardrails.md +86 -86
  119. package/src/bmad-plus/packs/pack-memory/shared/memory-protocol.md +143 -143
  120. package/src/bmad-plus/packs/pack-memory/templates/context.md +39 -39
  121. package/src/bmad-plus/packs/pack-memory/templates/decisions.md +25 -25
  122. package/src/bmad-plus/packs/pack-memory/templates/identity.yaml +39 -39
  123. package/src/bmad-plus/packs/pack-memory/templates/lessons.md +31 -31
  124. package/src/bmad-plus/packs/pack-memory/templates/patterns.md +24 -24
  125. package/src/bmad-plus/packs/pack-memory/templates/session-handoff.md +25 -25
  126. package/src/bmad-plus/packs/pack-memory/zecher-agent.md +157 -157
  127. package/src/bmad-plus/{agents → packs}/pack-seo/SKILL.md +171 -171
  128. package/src/bmad-plus/packs/pack-seo/bmad-skill-manifest.yaml +13 -0
  129. package/src/bmad-plus/{agents → packs}/pack-seo/checklist.md +140 -140
  130. package/src/bmad-plus/{agents → packs}/pack-seo/pagespeed-playbook.md +320 -320
  131. package/src/bmad-plus/{agents → packs}/pack-seo/ref/audit-schema.json +187 -187
  132. package/src/bmad-plus/{agents → packs}/pack-seo/ref/cwv-thresholds.md +87 -87
  133. package/src/bmad-plus/{agents → packs}/pack-seo/ref/eeat-criteria.md +123 -123
  134. package/src/bmad-plus/{agents → packs}/pack-seo/ref/geo-signals.md +167 -167
  135. package/src/bmad-plus/{agents → packs}/pack-seo/ref/hreflang-rules.md +153 -153
  136. package/src/bmad-plus/{agents → packs}/pack-seo/ref/quality-gates.md +133 -133
  137. package/src/bmad-plus/{agents → packs}/pack-seo/ref/schema-catalog.md +91 -91
  138. package/src/bmad-plus/{agents → packs}/pack-seo/ref/schema-templates.json +356 -356
  139. package/src/bmad-plus/{agents → packs}/pack-seo/seo-chief.md +294 -294
  140. package/src/bmad-plus/{agents → packs}/pack-seo/seo-judge.md +241 -241
  141. package/src/bmad-plus/{agents → packs}/pack-seo/seo-scout.md +171 -171
  142. package/src/bmad-plus/{agents → packs}/pack-seo/templates/seo-audit-workflow.md +241 -241
  143. package/src/bmad-plus/packs/pack-shield/README.md +110 -110
  144. package/src/bmad-plus/packs/pack-shield/SKILL.md +82 -0
  145. package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/csrd-agent.md +262 -262
  146. package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/section508-agent.md +179 -179
  147. package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/wcag-agent.md +201 -201
  148. package/src/bmad-plus/packs/pack-shield/categories/ai-governance/eu-ai-act-agent.md +97 -97
  149. package/src/bmad-plus/packs/pack-shield/categories/ai-governance/iso42001-agent.md +251 -251
  150. package/src/bmad-plus/packs/pack-shield/categories/ai-governance/nist-ai-rmf-agent.md +133 -133
  151. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/cis-controls-agent.md +221 -221
  152. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/ism-agent.md +150 -150
  153. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/iso27001-agent.md +167 -167
  154. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nis2-agent.md +83 -83
  155. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nist-800-53-agent.md +250 -250
  156. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nist-csf-agent.md +218 -218
  157. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/ccpa-agent.md +94 -94
  158. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/dpdpa-agent.md +136 -136
  159. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/gdpr-agent.md +296 -296
  160. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/iso27701-agent.md +134 -134
  161. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/lgpd-agent.md +129 -129
  162. package/src/bmad-plus/packs/pack-shield/categories/defense-export/cmmc-agent.md +127 -127
  163. package/src/bmad-plus/packs/pack-shield/categories/defense-export/ear-agent.md +272 -272
  164. package/src/bmad-plus/packs/pack-shield/categories/defense-export/itar-agent.md +202 -202
  165. package/src/bmad-plus/packs/pack-shield/categories/defense-export/tsa-agent.md +367 -367
  166. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/dora-agent.md +510 -510
  167. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/fedramp-agent.md +247 -247
  168. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/hipaa-agent.md +173 -173
  169. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/pci-dss-agent.md +239 -239
  170. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/soc2-agent.md +266 -266
  171. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/swift-csp-agent.md +164 -164
  172. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-classifier.md +131 -131
  173. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-fria.md +155 -155
  174. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-incidents.md +187 -187
  175. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-roles.md +113 -113
  176. package/src/bmad-plus/packs/pack-shield/categories/workflows/breach-sentinel.md +197 -197
  177. package/src/bmad-plus/packs/pack-shield/categories/workflows/cookie-policy-gen.md +180 -180
  178. package/src/bmad-plus/packs/pack-shield/categories/workflows/dpia-sentinel.md +235 -235
  179. package/src/bmad-plus/packs/pack-shield/categories/workflows/legitimate-interest.md +159 -159
  180. package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-advisor.md +133 -133
  181. package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-notice-gen.md +160 -160
  182. package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-policy-gen.md +135 -135
  183. package/src/bmad-plus/packs/pack-shield/references/ccpa/ccpa-gdpr-comparison.md +117 -117
  184. package/src/bmad-plus/packs/pack-shield/references/ccpa/consumer-rights-workflows.md +177 -177
  185. package/src/bmad-plus/packs/pack-shield/references/cis-controls/framework-mappings.md +162 -162
  186. package/src/bmad-plus/packs/pack-shield/references/cis-controls/implementation-guidance.md +235 -235
  187. package/src/bmad-plus/packs/pack-shield/references/cis-controls/safeguards-detail.md +252 -252
  188. package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-assessment.md +170 -170
  189. package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-levels.md +113 -113
  190. package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-practices.md +211 -211
  191. package/src/bmad-plus/packs/pack-shield/references/csrd/compliance-program.md +281 -281
  192. package/src/bmad-plus/packs/pack-shield/references/csrd/double-materiality.md +253 -253
  193. package/src/bmad-plus/packs/pack-shield/references/csrd/esrs-standards.md +401 -401
  194. package/src/bmad-plus/packs/pack-shield/references/dora/article-reference.md +441 -441
  195. package/src/bmad-plus/packs/pack-shield/references/dora/incident-classification.md +297 -297
  196. package/src/bmad-plus/packs/pack-shield/references/dora/rts-its-guide.md +306 -306
  197. package/src/bmad-plus/packs/pack-shield/references/dora/third-party-risk.md +349 -349
  198. package/src/bmad-plus/packs/pack-shield/references/dpdpa/gdpr-comparison.md +173 -173
  199. package/src/bmad-plus/packs/pack-shield/references/dpdpa/rights-and-obligations.md +426 -426
  200. package/src/bmad-plus/packs/pack-shield/references/dpdpa/rules-2025.md +599 -599
  201. package/src/bmad-plus/packs/pack-shield/references/dpdpa/sections-reference.md +319 -319
  202. package/src/bmad-plus/packs/pack-shield/references/ear/ccl-eccn-guide.md +250 -250
  203. package/src/bmad-plus/packs/pack-shield/references/ear/compliance-program.md +280 -280
  204. package/src/bmad-plus/packs/pack-shield/references/ear/license-exceptions.md +207 -207
  205. package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/gpai-governance.md +267 -267
  206. package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/obligations-high-risk.md +287 -287
  207. package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/risk-classification.md +182 -182
  208. package/src/bmad-plus/packs/pack-shield/references/fedramp/appendices-guide.md +209 -209
  209. package/src/bmad-plus/packs/pack-shield/references/fedramp/control-families.md +281 -281
  210. package/src/bmad-plus/packs/pack-shield/references/fedramp/poam-guide.md +93 -93
  211. package/src/bmad-plus/packs/pack-shield/references/fedramp/readiness-checklist.md +134 -134
  212. package/src/bmad-plus/packs/pack-shield/references/fedramp/sap-sar-guide.md +86 -86
  213. package/src/bmad-plus/packs/pack-shield/references/fedramp/ssp-guide.md +129 -129
  214. package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/documents.md +192 -192
  215. package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/dpa-template.md +121 -121
  216. package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/privacy-notice.md +87 -87
  217. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/breach-notification.md +293 -293
  218. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/privacy-rule.md +276 -276
  219. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/security-rule.md +299 -299
  220. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/templates.md +568 -568
  221. package/src/bmad-plus/packs/pack-shield/references/ism/control-applicability.md +181 -181
  222. package/src/bmad-plus/packs/pack-shield/references/ism/guidelines-overview.md +183 -183
  223. package/src/bmad-plus/packs/pack-shield/references/iso27001/annex-a-2013.md +203 -203
  224. package/src/bmad-plus/packs/pack-shield/references/iso27001/annex-a-2022.md +132 -132
  225. package/src/bmad-plus/packs/pack-shield/references/iso27001/control-mapping.md +153 -153
  226. package/src/bmad-plus/packs/pack-shield/references/iso27701/annex-a-controls.md +195 -195
  227. package/src/bmad-plus/packs/pack-shield/references/iso27701/regulatory-mapping.md +229 -229
  228. package/src/bmad-plus/packs/pack-shield/references/iso27701/transition-guide.md +219 -219
  229. package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-ai-risk-assessment.md +258 -258
  230. package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-clauses-requirements.md +279 -279
  231. package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-controls-annex-a.md +155 -155
  232. package/src/bmad-plus/packs/pack-shield/references/itar/compliance-program.md +174 -174
  233. package/src/bmad-plus/packs/pack-shield/references/itar/licensing-guide.md +146 -146
  234. package/src/bmad-plus/packs/pack-shield/references/itar/usml-categories.md +93 -93
  235. package/src/bmad-plus/packs/pack-shield/references/lgpd/anpd-enforcement.md +147 -147
  236. package/src/bmad-plus/packs/pack-shield/references/lgpd/compliance-program.md +272 -272
  237. package/src/bmad-plus/packs/pack-shield/references/lgpd/lgpd-articles.md +271 -271
  238. package/src/bmad-plus/packs/pack-shield/references/nis2/article-21-measures.md +153 -153
  239. package/src/bmad-plus/packs/pack-shield/references/nis2/iso27001-nis2-mapping.md +68 -68
  240. package/src/bmad-plus/packs/pack-shield/references/nist-800-53/assessment-rmf.md +349 -349
  241. package/src/bmad-plus/packs/pack-shield/references/nist-800-53/baselines-tailoring.md +277 -277
  242. package/src/bmad-plus/packs/pack-shield/references/nist-800-53/control-families.md +450 -450
  243. package/src/bmad-plus/packs/pack-shield/references/nist-ai-rmf/rmf-core.md +361 -361
  244. package/src/bmad-plus/packs/pack-shield/references/nist-ai-rmf/rmf-profiles.md +192 -192
  245. package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-10-to-20-mapping.md +143 -143
  246. package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-20-functions-categories.md +278 -278
  247. package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-implementation-tiers.md +135 -135
  248. package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-requirements.md +366 -366
  249. package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-saq-guide.md +217 -217
  250. package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-v4-changes.md +190 -190
  251. package/src/bmad-plus/packs/pack-shield/references/section-508/wcag-mapping.md +160 -160
  252. package/src/bmad-plus/packs/pack-shield/references/soc2/controls.md +241 -241
  253. package/src/bmad-plus/packs/pack-shield/references/soc2/evidence.md +236 -236
  254. package/src/bmad-plus/packs/pack-shield/references/soc2/policies.md +254 -254
  255. package/src/bmad-plus/packs/pack-shield/references/soc2/vendor.md +276 -276
  256. package/src/bmad-plus/packs/pack-shield/references/swift-csp/swift-assessment.md +202 -202
  257. package/src/bmad-plus/packs/pack-shield/references/swift-csp/swift-controls.md +545 -545
  258. package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-crmp-requirements.md +359 -359
  259. package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-directives-overview.md +187 -187
  260. package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-incident-reporting.md +187 -187
  261. package/src/bmad-plus/packs/pack-shield/references/wcag/criteria-detail.md +510 -510
  262. package/src/bmad-plus/packs/pack-shield/shared/audit-report-template.md +103 -103
  263. package/src/bmad-plus/packs/pack-shield/shared/cross-framework-mapper.md +103 -103
  264. package/src/bmad-plus/packs/pack-shield/shared/gap-analysis-template.md +83 -83
  265. package/src/bmad-plus/packs/pack-shield/shield-orchestrator.md +229 -229
  266. package/src/bmad-plus/packs/pack-shield/upstream-sync.yaml +68 -68
  267. package/src/bmad-plus/skills/bmad-plus-autopilot/SKILL.md +99 -99
  268. package/src/bmad-plus/skills/bmad-plus-parallel/SKILL.md +93 -93
  269. package/src/bmad-plus/skills/bmad-plus-sync/SKILL.md +69 -69
  270. package/tools/bmad-plus-npx.js +3 -5
  271. package/tools/cli/commands/autoconfig.js +508 -489
  272. package/tools/cli/commands/doctor.js +219 -222
  273. package/tools/cli/commands/install.js +548 -739
  274. package/tools/cli/commands/memory.js +194 -194
  275. package/tools/cli/commands/scan.js +362 -350
  276. package/tools/cli/commands/uninstall.js +96 -96
  277. package/tools/cli/commands/update.js +116 -174
  278. package/tools/cli/i18n.js +845 -763
  279. package/tools/cli/lib/memory-init.js +114 -0
  280. package/tools/cli/lib/pack-copy.js +84 -0
  281. package/tools/cli/lib/packs.js +114 -0
@@ -1,739 +1,548 @@
1
- /**
2
- * BMAD+ Install Command
3
- * Installs agents, skills, and IDE configs into the current project
4
- * Supports 10 languages: EN, FR, ES, DE, PT-BR, RU, ZH, HE, JA, IT
5
- *
6
- * Author: Laurent Rochetta
7
- */
8
-
9
- const path = require('node:path');
10
- const fs = require('node:fs');
11
- const os = require('node:os');
12
- const fsExtra = require('fs-extra');
13
- const clack = require('@clack/prompts');
14
- const pc = require('picocolors');
15
- const { t, getLanguageOptions, getCommLanguageOptions } = require('../i18n');
16
-
17
- // Pack definitions
18
- const PACKS = {
19
- core: {
20
- name: 'Core Development',
21
- icon: '⚙️',
22
- description: '4 multi-role agents (Atlas, Forge, Sentinel, Nexus)',
23
- required: true,
24
- agents: ['agent-strategist', 'agent-architect-dev', 'agent-quality', 'agent-orchestrator'],
25
- skills: ['bmad-plus-autopilot', 'bmad-plus-parallel', 'bmad-plus-sync'],
26
- data: ['role-triggers.yaml'],
27
- },
28
- osint: {
29
- name: 'OSINT Intelligence',
30
- icon: '🔍',
31
- description: 'Agent Shadow — investigation, scraping, psychoprofil',
32
- required: false,
33
- agents: ['agent-shadow'],
34
- skills: [],
35
- externalPackage: 'osint-agent-package',
36
- },
37
- maker: {
38
- name: 'Agent Creator',
39
- icon: '🧬',
40
- description: 'Maker — design, build, and package new BMAD+ agents',
41
- required: false,
42
- agents: ['agent-maker'],
43
- skills: [],
44
- data: [],
45
- },
46
- shield: {
47
- name: 'Pack Shield (GRC)',
48
- icon: '🛡️',
49
- description: '27 compliance agents — GDPR, ISO 27001, SOC 2, PCI DSS, EU AI Act...',
50
- required: false,
51
- agents: [],
52
- skills: [],
53
- packDir: 'pack-shield',
54
- packSrcDir: 'packs',
55
- },
56
- 'dev-studio': {
57
- name: 'Dev Studio Full SDLC',
58
- icon: '🏗️',
59
- description: 'Full SDLC pipeline: brainstorm PRD → architecture → TDD → code review → deploy',
60
- required: false,
61
- agents: [],
62
- skills: [],
63
- packDir: 'pack-dev-studio',
64
- packSrcDir: 'packs',
65
- },
66
- seo: {
67
- name: 'SEO Audit 360',
68
- icon: '🔍',
69
- description: '3 agents (Scout, Chief, Judge) + 6-phase audit + PageSpeed loop',
70
- required: false,
71
- agents: [],
72
- skills: [],
73
- packDir: 'pack-seo',
74
- },
75
- backup: {
76
- name: 'Universal Backup',
77
- icon: '🗂️',
78
- description: 'Timestamped ZIP backup with smart exclusions',
79
- required: false,
80
- agents: [],
81
- skills: [],
82
- packDir: 'pack-backup',
83
- },
84
- animated: {
85
- name: 'Animated Website',
86
- icon: '🎬',
87
- description: 'Luxury scroll-driven website from video',
88
- required: false,
89
- agents: [],
90
- skills: [],
91
- packDir: 'pack-animated',
92
- },
93
- memory: {
94
- name: 'Memory — Persistent Brain',
95
- icon: '🧠',
96
- description: 'Cross-session memory + project scanner + Karpathy guardrails. Agents learn.',
97
- required: false,
98
- agents: [],
99
- skills: [],
100
- packDir: 'pack-memory',
101
- packSrcDir: 'packs',
102
- },
103
- };
104
-
105
- // IDE configurations
106
- const IDE_CONFIGS = {
107
- 'claude-code': {
108
- name: 'Claude Code',
109
- detect: ['.claude'],
110
- configFile: 'CLAUDE.md',
111
- },
112
- 'gemini-cli': {
113
- name: 'Gemini CLI',
114
- detect: ['.gemini'],
115
- configFile: 'GEMINI.md',
116
- },
117
- 'codex-cli': {
118
- name: 'Codex CLI / OpenCode',
119
- detect: ['.codex', '.opencode'],
120
- configFile: 'AGENTS.md',
121
- },
122
- 'antigravity': {
123
- name: 'Antigravity',
124
- detect: ['.gemini/antigravity'],
125
- configFile: 'GEMINI.md',
126
- },
127
- };
128
-
129
- module.exports = {
130
- command: 'install',
131
- description: 'Install BMAD+ agents and skills into your project',
132
- options: [
133
- ['-d, --directory <path>', 'Installation directory (default: current directory)'],
134
- ['-p, --packs <packs>', 'Comma-separated pack IDs: core,osint,all (default: interactive)'],
135
- ['-y, --yes', 'Accept all defaults, skip prompts'],
136
- ['--tools <tools>', 'Comma-separated IDE IDs (default: auto-detect)'],
137
- ],
138
- action: async (options) => {
139
- const projectDir = path.resolve(options.directory || process.cwd());
140
- const bmadSrc = path.join(__dirname, '..', '..', '..', 'src', 'bmad-plus');
141
-
142
- // ── Step 0: Language Selection ──
143
- const pkgJson = require('../../../package.json');
144
- clack.intro(pc.bgCyan(pc.black(` BMAD+ Installer v${pkgJson.version} `)));
145
- clack.log.info(pc.dim('✨ Created by Laurent Rochetta — github.com/lrochetta/BMAD-PLUS'));
146
-
147
- let lang = 'en';
148
- if (!options.yes) {
149
- const langChoice = await clack.select({
150
- message: '🌐 Select your language / Choisissez votre langue / 选择语言',
151
- options: getLanguageOptions(),
152
- });
153
-
154
- if (clack.isCancel(langChoice)) {
155
- clack.cancel('Installation cancelled.');
156
- process.exit(0);
157
- }
158
- lang = langChoice;
159
- }
160
-
161
- const i = t(lang); // Get translations for selected language
162
-
163
- // Verify source exists
164
- if (!fs.existsSync(bmadSrc)) {
165
- clack.log.error(`${i.source_not_found}: ${bmadSrc}`);
166
- clack.outro(pc.red(i.failed));
167
- process.exit(1);
168
- }
169
-
170
- clack.log.info(`${i.installing_to}: ${pc.cyan(projectDir)}`);
171
-
172
- // ── Step 1: Pack Selection ──
173
- let selectedPacks = ['core']; // Core always included
174
-
175
- if (options.packs) {
176
- const requested = options.packs.split(',').map(p => p.trim());
177
- if (requested.includes('all')) {
178
- selectedPacks = Object.keys(PACKS).filter(k => !PACKS[k].disabled);
179
- } else {
180
- selectedPacks = [...new Set(['core', ...requested.filter(p => PACKS[p] && !PACKS[p].disabled)])];
181
- }
182
- } else if (!options.yes) {
183
- const packChoice = await clack.multiselect({
184
- message: i.select_packs,
185
- options: Object.entries(PACKS)
186
- .filter(([, p]) => !p.required)
187
- .map(([key, pack]) => ({
188
- value: key,
189
- label: `${pack.icon} ${pack.name}`,
190
- hint: pack.disabled ? i.soon : pack.description,
191
- disabled: pack.disabled,
192
- })),
193
- required: false,
194
- });
195
-
196
- if (clack.isCancel(packChoice)) {
197
- clack.cancel(i.cancelled);
198
- process.exit(0);
199
- }
200
-
201
- selectedPacks = [...new Set(['core', ...packChoice])];
202
- }
203
-
204
- clack.log.success(`${i.selected_packs}: ${selectedPacks.map(p => `${PACKS[p].icon} ${PACKS[p].name}`).join(', ')}`);
205
-
206
- // ── Step 2: IDE Detection ──
207
- let detectedIDEs = [];
208
-
209
- if (options.tools) {
210
- if (options.tools === 'none' || options.tools === 'skip') {
211
- detectedIDEs = [];
212
- } else {
213
- detectedIDEs = options.tools.split(',').map(t => t.trim()).filter(t => IDE_CONFIGS[t]);
214
- }
215
- } else {
216
- // Auto-detect
217
- for (const [id, ide] of Object.entries(IDE_CONFIGS)) {
218
- for (const marker of ide.detect) {
219
- if (fs.existsSync(path.join(projectDir, marker))) {
220
- detectedIDEs.push(id);
221
- break;
222
- }
223
- }
224
- }
225
-
226
- // If nothing detected, ask
227
- if (detectedIDEs.length === 0 && !options.yes) {
228
- const ideChoice = await clack.multiselect({
229
- message: i.select_ide,
230
- options: Object.entries(IDE_CONFIGS).map(([key, ide]) => ({
231
- value: key,
232
- label: ide.name,
233
- })),
234
- required: false,
235
- });
236
-
237
- if (!clack.isCancel(ideChoice)) {
238
- detectedIDEs = ideChoice;
239
- }
240
- }
241
-
242
- // Default to all if --yes
243
- if (detectedIDEs.length === 0 && options.yes) {
244
- detectedIDEs = Object.keys(IDE_CONFIGS);
245
- }
246
- }
247
-
248
- if (detectedIDEs.length > 0) {
249
- clack.log.info(`${i.detected_ides}: ${detectedIDEs.map(id => IDE_CONFIGS[id].name).join(', ')}`);
250
- } else if (options.tools === 'none' || options.tools === 'skip') {
251
- clack.log.info(pc.dim('⏭️ IDE config skipped (--tools none) — existing configs preserved'));
252
- }
253
-
254
- // ── Step 3: User Config ──
255
- let userName = process.env.USER || process.env.USERNAME || 'Developer';
256
- let commLang = 'French';
257
-
258
- if (!options.yes) {
259
- const userConfig = await clack.group({
260
- userName: () => clack.text({
261
- message: i.enter_name,
262
- placeholder: userName,
263
- defaultValue: userName,
264
- }),
265
- commLang: () => clack.select({
266
- message: i.comm_language,
267
- options: getCommLanguageOptions(),
268
- }),
269
- execMode: () => clack.select({
270
- message: i.exec_mode,
271
- options: [
272
- { value: 'manual', label: i.exec_manual },
273
- { value: 'autopilot', label: i.exec_autopilot },
274
- { value: 'hybrid', label: i.exec_hybrid },
275
- ],
276
- }),
277
- });
278
-
279
- if (clack.isCancel(userConfig)) {
280
- clack.cancel(i.cancelled);
281
- process.exit(0);
282
- }
283
-
284
- userName = userConfig.userName;
285
- commLang = userConfig.commLang;
286
- }
287
-
288
- // ── Step 4: Install Files ──
289
- const spinner = clack.spinner();
290
- spinner.start(i.installing_files);
291
-
292
- const targetAgentsDir = path.join(projectDir, '.agents', 'skills');
293
- const targetDataDir = path.join(projectDir, '.agents', 'data');
294
- const targetBmadDir = path.join(projectDir, '_bmad');
295
-
296
- // Create directories
297
- fsExtra.ensureDirSync(targetAgentsDir);
298
- fsExtra.ensureDirSync(targetDataDir);
299
- fsExtra.ensureDirSync(targetBmadDir);
300
-
301
- let copiedAgents = 0;
302
- let copiedSkills = 0;
303
- let copiedFiles = 0;
304
-
305
- for (const packId of selectedPacks) {
306
- const pack = PACKS[packId];
307
- if (!pack || pack.disabled) continue;
308
-
309
- // Copy agents
310
- for (const agent of pack.agents) {
311
- const src = path.join(bmadSrc, 'agents', agent);
312
- const dest = path.join(targetAgentsDir, agent);
313
- if (fs.existsSync(src)) {
314
- fsExtra.copySync(src, dest, { overwrite: true });
315
- copiedAgents++;
316
- }
317
- }
318
-
319
- // Copy skills
320
- for (const skill of pack.skills) {
321
- const src = path.join(bmadSrc, 'skills', skill);
322
- const dest = path.join(targetAgentsDir, skill);
323
- if (fs.existsSync(src)) {
324
- fsExtra.copySync(src, dest, { overwrite: true });
325
- copiedSkills++;
326
- }
327
- }
328
-
329
- // Copy data files
330
- for (const dataFile of (pack.data || [])) {
331
- const src = path.join(bmadSrc, 'data', dataFile);
332
- const dest = path.join(targetDataDir, dataFile);
333
- if (fs.existsSync(src)) {
334
- fsExtra.copySync(src, dest, { overwrite: true });
335
- copiedFiles++;
336
- }
337
- }
338
-
339
- // Copy external package (OSINT)
340
- if (pack.externalPackage) {
341
- const extSrc = path.join(__dirname, '..', '..', '..', pack.externalPackage, 'skills');
342
- const extDest = path.join(targetAgentsDir);
343
- if (fs.existsSync(extSrc)) {
344
- fsExtra.copySync(extSrc, extDest, { overwrite: true });
345
- copiedSkills++;
346
- }
347
- }
348
-
349
- // Copy pack directory (SEO, Backup, Animated Website, Shield)
350
- if (pack.packDir) {
351
- const srcParent = pack.packSrcDir || 'agents';
352
- const packSrc = path.join(bmadSrc, srcParent, pack.packDir);
353
- const packDest = path.join(targetAgentsDir, pack.packDir);
354
- if (fs.existsSync(packSrc)) {
355
- fsExtra.copySync(packSrc, packDest, { overwrite: true });
356
- copiedAgents++;
357
- copiedFiles++;
358
- }
359
- }
360
-
361
- // Memory pack: initialize brain with existing brain detection
362
- if (packId === 'memory' && pack.packDir) {
363
- const memoryDir = path.join(projectDir, '.agents', 'memory');
364
- const sessionsDir = path.join(memoryDir, 'sessions');
365
- const globalBrainDir = path.join(os.homedir(), '.bmad-plus', 'brain', 'projects');
366
- const templateDir = path.join(bmadSrc, 'packs', 'pack-memory', 'templates');
367
-
368
- // Create project memory (never overwrite existing)
369
- fsExtra.ensureDirSync(sessionsDir);
370
- const memoryFiles = ['decisions.md', 'lessons.md', 'patterns.md', 'context.md'];
371
- for (const mf of memoryFiles) {
372
- const dest = path.join(memoryDir, mf);
373
- if (!fs.existsSync(dest)) {
374
- const src = path.join(templateDir, mf);
375
- if (fs.existsSync(src)) {
376
- let content = fs.readFileSync(src, 'utf8');
377
- content = content.replace(/\{\{date\}\}/g, new Date().toISOString().slice(0, 10));
378
- content = content.replace(/\{\{project_name\}\}/g, path.basename(projectDir));
379
- content = content.replace(/\{\{project_path\}\}/g, projectDir);
380
- fs.writeFileSync(dest, content, 'utf8');
381
- }
382
- }
383
- }
384
-
385
- // Detect existing brain directories
386
- const brainCandidates = [
387
- path.join(os.homedir(), '.bmad-plus', 'brain'),
388
- path.join(projectDir, '_brain'),
389
- path.join(os.homedir(), '.claude', 'memory'),
390
- ];
391
- const existingBrain = brainCandidates.find(p => fs.existsSync(p));
392
-
393
- if (existingBrain) {
394
- clack.log.info(`🧠 ${i.brain_detected || 'Existing brain detected'}: ${existingBrain}`);
395
- // Write brain link pointer
396
- fs.writeFileSync(
397
- path.join(memoryDir, '.brain-link'),
398
- JSON.stringify({ linked_brain: existingBrain, linked_at: new Date().toISOString() }, null, 2),
399
- 'utf8'
400
- );
401
- } else {
402
- // Create fresh global brain
403
- fsExtra.ensureDirSync(globalBrainDir);
404
- const identitySrc = path.join(templateDir, 'identity.yaml');
405
- const identityDest = path.join(os.homedir(), '.bmad-plus', 'brain', 'identity.yaml');
406
- if (fs.existsSync(identitySrc) && !fs.existsSync(identityDest)) {
407
- let content = fs.readFileSync(identitySrc, 'utf8');
408
- content = content.replace(/\{\{user_name\}\}/g, userName);
409
- content = content.replace(/\{\{language\}\}/g, commLang);
410
- content = content.replace(/\{\{date\}\}/g, new Date().toISOString().slice(0, 10));
411
- fs.writeFileSync(identityDest, content, 'utf8');
412
- }
413
- // Copy global memory templates
414
- for (const gf of ['decisions.md', 'lessons.md', 'patterns.md']) {
415
- const dest = path.join(os.homedir(), '.bmad-plus', 'brain', gf);
416
- if (!fs.existsSync(dest)) {
417
- const src = path.join(templateDir, gf);
418
- if (fs.existsSync(src)) {
419
- let content = fs.readFileSync(src, 'utf8');
420
- content = content.replace(/\{\{date\}\}/g, new Date().toISOString().slice(0, 10));
421
- content = content.replace(/\{\{project_name\}\}/g, 'Global Brain');
422
- fs.writeFileSync(dest, content, 'utf8');
423
- }
424
- }
425
- }
426
- clack.log.info(`🧠 ${i.brain_created || 'Global brain created'}: ${path.join(os.homedir(), '.bmad-plus', 'brain')}`);
427
- }
428
-
429
- // Index this project in global brain
430
- const crypto = require('node:crypto');
431
- const projHash = crypto.createHash('sha256').update(projectDir).digest('hex').slice(0, 8);
432
- const projMeta = {
433
- path: projectDir,
434
- name: path.basename(projectDir),
435
- hash: projHash,
436
- status: 'active',
437
- bmad_installed: true,
438
- packs_installed: selectedPacks,
439
- last_scanned: new Date().toISOString().slice(0, 10),
440
- };
441
- fsExtra.ensureDirSync(globalBrainDir);
442
- fs.writeFileSync(
443
- path.join(globalBrainDir, `${projHash}.yaml`),
444
- Object.entries(projMeta).map(([k, v]) => `${k}: ${JSON.stringify(v)}`).join('\n'),
445
- 'utf8'
446
- );
447
- }
448
- }
449
-
450
- // Copy module config
451
- const moduleYaml = path.join(bmadSrc, 'module.yaml');
452
- if (fs.existsSync(moduleYaml)) {
453
- fsExtra.copySync(moduleYaml, path.join(targetBmadDir, 'module.yaml'));
454
- copiedFiles++;
455
- }
456
-
457
- const helpCsv = path.join(bmadSrc, 'module-help.csv');
458
- if (fs.existsSync(helpCsv)) {
459
- fsExtra.copySync(helpCsv, path.join(targetBmadDir, 'module-help.csv'));
460
- copiedFiles++;
461
- }
462
-
463
- spinner.stop(i.installed_summary(copiedAgents, copiedSkills, copiedFiles));
464
-
465
- // ── Step 5: Generate IDE Configs ──
466
- if (detectedIDEs.length > 0) {
467
- const ideSpinner = clack.spinner();
468
- ideSpinner.start(i.configuring_ides);
469
-
470
- const configContent = generateIDEConfig(userName, commLang, selectedPacks);
471
-
472
- for (const ideId of detectedIDEs) {
473
- const ide = IDE_CONFIGS[ideId];
474
- if (!ide) continue;
475
-
476
- const configPath = path.join(projectDir, ide.configFile);
477
- fs.writeFileSync(configPath, configContent, 'utf8');
478
- }
479
-
480
- ideSpinner.stop(i.ide_configured(detectedIDEs.length));
481
- }
482
-
483
- // ── Step 6: Create config.yaml ──
484
- const configYaml = generateConfigYaml(userName, commLang, projectDir);
485
- const configPath = path.join(targetBmadDir, 'config.yaml');
486
- fs.writeFileSync(configPath, configYaml, 'utf8');
487
-
488
- // ── Step 7: Create output directories ──
489
- const outputDir = path.join(projectDir, '_bmad-output');
490
- fsExtra.ensureDirSync(path.join(outputDir, 'discovery'));
491
- fsExtra.ensureDirSync(path.join(outputDir, 'build'));
492
- fsExtra.ensureDirSync(path.join(projectDir, 'docs'));
493
-
494
- // ── Step 8: Write install manifest ──
495
- const pkgVersion = require('../../../package.json').version;
496
- const manifest = {
497
- version: pkgVersion,
498
- uiLanguage: lang,
499
- installed: new Date().toISOString(),
500
- packs: selectedPacks,
501
- ides: detectedIDEs,
502
- user: userName,
503
- language: commLang,
504
- };
505
- fs.writeFileSync(
506
- path.join(targetBmadDir, '.bmad-plus-install.json'),
507
- JSON.stringify(manifest, null, 2),
508
- 'utf8'
509
- );
510
-
511
- // ── Summary — Contextual Getting Started ──
512
- const agentGuide = [
513
- i.guide_who,
514
- '',
515
- ` ${i.guide_idea.padEnd(28)} → "Atlas, [...]"`,
516
- ` ${i.guide_prd.padEnd(28)} → "Atlas, create PRD"`,
517
- ` ${i.guide_arch.padEnd(28)} → "Forge, propose architecture"`,
518
- ` ${i.guide_code.padEnd(28)} → "Forge, implement story [X]"`,
519
- ` ${i.guide_test.padEnd(28)} → "Sentinel, review module [X]"`,
520
- ` ${i.guide_sprint.padEnd(28)} → "Nexus, create epics"`,
521
- ` ${i.guide_auto.padEnd(28)} → "autopilot"`,
522
- ];
523
-
524
- if (selectedPacks.includes('osint')) {
525
- agentGuide.push(` ${i.guide_osint.padEnd(28)} → "Shadow, investigate [name]"`);
526
- }
527
-
528
- if (selectedPacks.includes('maker')) {
529
- agentGuide.push(` ${i.guide_maker.padEnd(28)} → "Maker, create agent [desc]"`);
530
- }
531
-
532
- if (selectedPacks.includes('seo')) {
533
- agentGuide.push(` ${i.guide_seo.padEnd(28)} → "/seo audit <url>"`);
534
- }
535
-
536
- if (selectedPacks.includes('backup')) {
537
- agentGuide.push(` ${i.guide_backup.padEnd(28)}"/backup create"`);
538
- }
539
-
540
- if (selectedPacks.includes('animated')) {
541
- agentGuide.push(` ${i.guide_animated.padEnd(28)}"/animated build <video>"`);
542
- }
543
-
544
- if (selectedPacks.includes('shield')) {
545
- agentGuide.push(` ${(i.guide_shield || '🛡️ GRC Compliance').padEnd(28)} → "Shield, audit my SaaS for GDPR"`);
546
- }
547
-
548
- if (selectedPacks.includes('memory')) {
549
- agentGuide.push(` ${(i.guide_memory || '🧠 Memory Brain').padEnd(28)} → "Zecher, scan projects in [path]"`);
550
- }
551
-
552
- if (selectedPacks.includes('dev-studio')) {
553
- agentGuide.push(` ${(i.guide_dev_studio || '🏗️ Dev Studio').padEnd(28)} → "Miriam, brainstorm my app idea"`);
554
- }
555
-
556
- agentGuide.push(
557
- '',
558
- i.guide_workflow,
559
- ' 1. Atlas (idea → brief → PRD)',
560
- ' 2. Forge (architecture → code)',
561
- ' 3. Sentinel (tests → review)',
562
- '',
563
- i.guide_or_auto,
564
- '',
565
- `${i.guide_output}: _bmad-output/discovery/ & _bmad-output/build/`,
566
- '',
567
- '─'.repeat(50),
568
- '',
569
- `📦 ${i.guide_cli_title || 'CLI Commands'}:`,
570
- ` npx bmad-plus install ${i.guide_cli_install || '— Install agents & skills'}`,
571
- ` npx bmad-plus update ${i.guide_cli_update || '— Update agents (keeps config)'}`,
572
- ` npx bmad-plus doctor ${i.guide_cli_doctor || '— Check installation health'}`,
573
- ` npx bmad-plus uninstall ${i.guide_cli_uninstall || '— Remove BMAD+ from project'}`,
574
- );
575
-
576
- // Add pack-specific examples
577
- const examples = [];
578
- if (selectedPacks.includes('seo')) {
579
- examples.push(` ${i.guide_example_seo || '🔍 SEO: "/seo audit https://example.com"'}`);
580
- }
581
- if (selectedPacks.includes('backup')) {
582
- examples.push(` ${i.guide_example_backup || '🗂️ Backup: "/backup create" → ZIP timestamped'}`);
583
- }
584
- if (selectedPacks.includes('animated')) {
585
- examples.push(` ${i.guide_example_animated || '🎬 Animated: "/animated build hero.mp4"'}`);
586
- }
587
- if (selectedPacks.includes('osint')) {
588
- examples.push(` ${i.guide_example_osint || '🔍 OSINT: "Shadow, investigate John Doe"'}`);
589
- }
590
- if (selectedPacks.includes('shield')) {
591
- examples.push(
592
- ` ${i.guide_example_shield_1 || '🛡️ GRC: "Shield, audit my app for GDPR compliance"'}`,
593
- ` ${i.guide_example_shield_2 || '🛡️ GRC: "Shield, gap analysis ISO 27001 vs NIST CSF"'}`,
594
- ` ${i.guide_example_shield_3 || '🛡️ GRC: "Shield, generate SOC 2 evidence checklist"'}`,
595
- );
596
- }
597
- if (selectedPacks.includes('dev-studio')) {
598
- examples.push(
599
- ` ${i.guide_example_dev_studio_1 || '🏗️ Dev Studio: "Miriam, brainstorm a productivity app"'}`,
600
- ` ${i.guide_example_dev_studio_2 || '🏗️ Dev Studio: "Bezalel, design the architecture"'}`,
601
- ` ${i.guide_example_dev_studio_3 || '🏗️ Dev Studio: "Oholiab, implement story S1"'}`,
602
- );
603
- }
604
- if (selectedPacks.includes('memory')) {
605
- examples.push(
606
- ` ${i.guide_example_memory_1 || '🧠 Memory: "Zecher, scan projects in D:\\travail\\DEV"'}`,
607
- ` ${i.guide_example_memory_2 || '🧠 Memory: "Zecher, where were we?"'}`,
608
- ` ${i.guide_example_memory_3 || '🧠 Memory: "Zecher, consolidate memory"'}`,
609
- );
610
- }
611
-
612
- if (examples.length > 0) {
613
- agentGuide.push(
614
- '',
615
- `💡 ${i.guide_examples_title || 'Quick Examples'}:`,
616
- ...examples
617
- );
618
- }
619
-
620
- agentGuide.push(
621
- '',
622
- '---',
623
- i.guide_credits
624
- );
625
-
626
- clack.note(agentGuide.join('\n'), i.guide_title);
627
-
628
- clack.outro(pc.green(i.guide_ready));
629
- },
630
- };
631
-
632
-
633
- // ── Helpers ──
634
-
635
- function generateIDEConfig(userName, language, packs) {
636
- const agents = [
637
- '- **Atlas** (Strategist) — Business analysis + Product management',
638
- '- **Forge** (Architect-Dev) — Architecture + Development + Documentation',
639
- '- **Sentinel** (Quality) — QA + UX review',
640
- '- **Nexus** (Orchestrator) — Sprint management + Autopilot + Parallel execution',
641
- ];
642
-
643
- if (packs.includes('osint')) {
644
- agents.push('- **Shadow** (OSINT) — Investigation + Scraping + Psychoprofiling');
645
- }
646
-
647
- if (packs.includes('shield')) {
648
- agents.push('- **Shield** (GRC) — 38 compliance agents (GDPR, ISO 27001, SOC 2, HIPAA, EU AI Act, DORA, NIS2...)');
649
- }
650
-
651
- if (packs.includes('dev-studio')) {
652
- agents.push('- **Miriam** (מרים) — Business Analyst — Strategic analysis, research, product briefs');
653
- agents.push('- **Huldah** (חולדה) — Technical Writer — Documentation, diagrams, editorial review');
654
- agents.push('- **Yosef** (יוסף) — Product Manager — PRD, requirements, feature prioritization');
655
- agents.push('- **Rachel** (רחל) — UX Designer — User experience, wireframes, empathy mapping');
656
- agents.push('- **Bezalel** (בצלאל) — System Architect — Architecture, ADRs, epics & stories');
657
- agents.push('- **Oholiab** (אהליאב) — Senior Engineer — TDD, sprint, code review, implementation');
658
- }
659
-
660
- if (packs.includes('memory')) {
661
- agents.push('- **Zecher** (זכר) — Memory Archivist — Consolidation, project scanning, context recall');
662
- }
663
-
664
- // Build memory section if memory pack is installed
665
- let memorySection = '';
666
- if (packs.includes('memory')) {
667
- memorySection = [
668
- '',
669
- '## Memory Protocol (Karpathy Guardrails)',
670
- '',
671
- 'Agents MUST follow these behavioral principles:',
672
- '',
673
- '### G1 — Think Before Coding',
674
- '- State assumptions explicitly. If uncertain, ask.',
675
- '- Check `.agents/memory/decisions.md` for prior decisions before re-deciding.',
676
- '',
677
- '### G2 — Simplicity First',
678
- '- Minimum code that solves the problem. Nothing speculative.',
679
- '- Check `.agents/memory/patterns.md` for existing solutions.',
680
- '',
681
- '### G3 — Surgical Changes',
682
- '- Touch only what you must. Match existing style.',
683
- '- Log surprises in `.agents/memory/lessons.md`.',
684
- '',
685
- '### G4 — Goal-Driven Execution',
686
- '- Define success criteria before implementing.',
687
- '- Log non-obvious decisions in `.agents/memory/decisions.md`.',
688
- '',
689
- '### Memory Files',
690
- '- `.agents/memory/decisions.md` — Read at session start, write when making decisions',
691
- '- `.agents/memory/lessons.md` — Write when something unexpected happens',
692
- '- `.agents/memory/patterns.md` — Write when a reusable pattern is validated',
693
- '- `.agents/memory/context.md` — Update at session end with project state',
694
- ].join('\n');
695
- }
696
-
697
- return `# BMAD+ — AI Agent Configuration
698
-
699
- ## Project Context
700
- This project uses BMAD+, an augmented AI-driven development framework.
701
- Based on BMAD-METHOD v6.6.0 with multi-role agents, autopilot mode, and parallel execution.
702
-
703
- ## Agents
704
- To activate an agent, say its name or persona:
705
- ${agents.join('\n')}
706
-
707
- ## Skills
708
- - Load skills from \`.agents/skills/\`
709
- - Each agent has a SKILL.md with capabilities, activation protocol, and role-switching rules
710
- - Auto-activation triggers: \`.agents/data/role-triggers.yaml\`
711
-
712
- ## Key Commands
713
- - \`bmad-help\` — Show all available agents and skills
714
- - \`autopilot\` — Launch Nexus in full pipeline mode
715
- - \`parallel\` — Enable parallel multi-agent execution
716
-
717
- ## Communication
718
- - User name: ${userName}
719
- - Default language: ${language} for user-facing content, English for code and technical docs.
720
- ${memorySection}`;
721
- }
722
-
723
- function generateConfigYaml(userName, language, projectDir) {
724
- const projectName = path.basename(projectDir);
725
- return `# BMAD+ Project Configuration
726
- # Generated by bmad-plus install
727
-
728
- user_name: "${userName}"
729
- communication_language: "${language}"
730
- document_output_language: "${language}"
731
- output_folder: "_bmad-output"
732
- project_name: "${projectName}"
733
-
734
- # Execution settings
735
- execution_mode: "manual"
736
- auto_role_activation: true
737
- parallel_execution: true
738
- `;
739
- }
1
+ /**
2
+ * BMAD+ Install Command
3
+ * Installs agents, skills, and IDE configs into the current project
4
+ * Supports 10 languages: EN, FR, ES, DE, PT-BR, RU, ZH, HE, JA, IT
5
+ *
6
+ * Author: Laurent Rochetta
7
+ */
8
+
9
+ const path = require('node:path');
10
+ const fs = require('node:fs');
11
+ const os = require('node:os');
12
+ const fsExtra = require('fs-extra');
13
+ const clack = require('@clack/prompts');
14
+ const pc = require('picocolors');
15
+ const { t, getLanguageOptions, getCommLanguageOptions } = require('../i18n');
16
+ const { PACKS } = require('../lib/packs');
17
+ const { copyPackFiles } = require('../lib/pack-copy');
18
+ const { initMemory } = require('../lib/memory-init');
19
+
20
+ // Pack definitions are imported from the shared module: require('../lib/packs').PACKS
21
+
22
+ // IDE configurations
23
+ const IDE_CONFIGS = {
24
+ 'claude-code': {
25
+ name: 'Claude Code',
26
+ detect: ['.claude'],
27
+ configFile: 'CLAUDE.md',
28
+ },
29
+ 'gemini-cli': {
30
+ name: 'Gemini CLI',
31
+ detect: ['.gemini'],
32
+ configFile: 'GEMINI.md',
33
+ },
34
+ 'codex-cli': {
35
+ name: 'Codex CLI / OpenCode',
36
+ detect: ['.codex', '.opencode'],
37
+ configFile: 'AGENTS.md',
38
+ },
39
+ 'antigravity': {
40
+ name: 'Antigravity',
41
+ detect: ['.gemini/antigravity'],
42
+ configFile: 'GEMINI.md',
43
+ },
44
+ };
45
+
46
+ module.exports = {
47
+ command: 'install',
48
+ description: 'Install BMAD+ agents and skills into your project',
49
+ options: [
50
+ ['-d, --directory <path>', 'Installation directory (default: current directory)'],
51
+ ['-p, --packs <packs>', 'Comma-separated pack IDs: core,osint,all (default: interactive)'],
52
+ ['-y, --yes', 'Accept all defaults, skip prompts'],
53
+ ['--tools <tools>', 'Comma-separated IDE IDs (default: auto-detect)'],
54
+ ],
55
+ action: async (options) => {
56
+ const projectDir = path.resolve(options.directory || process.cwd());
57
+ const bmadSrc = path.join(__dirname, '..', '..', '..', 'src', 'bmad-plus');
58
+
59
+ // ── Step 0: Language Selection ──
60
+ const pkgJson = require('../../../package.json');
61
+ clack.intro(pc.bgCyan(pc.black(` BMAD+ Installer v${pkgJson.version} `)));
62
+ clack.log.info(pc.dim('✨ Created by Laurent Rochetta — github.com/lrochetta/BMAD-PLUS'));
63
+
64
+ let lang = 'en';
65
+ if (!options.yes) {
66
+ const langChoice = await clack.select({
67
+ message: '🌐 Select your language / Choisissez votre langue / 选择语言',
68
+ options: getLanguageOptions(),
69
+ });
70
+
71
+ if (clack.isCancel(langChoice)) {
72
+ clack.cancel('Installation cancelled.');
73
+ throw new Error('Installation cancelled.');
74
+ }
75
+ lang = langChoice;
76
+ }
77
+
78
+ const i = t(lang); // Get translations for selected language
79
+
80
+ // Verify source exists
81
+ if (!fs.existsSync(bmadSrc)) {
82
+ clack.log.error(`${i.source_not_found}: ${bmadSrc}`);
83
+ clack.outro(pc.red(i.failed));
84
+ throw new Error(`Source not found: ${bmadSrc}`);
85
+ }
86
+
87
+ clack.log.info(`${i.installing_to}: ${pc.cyan(projectDir)}`);
88
+
89
+ // ── Step 1: Pack Selection ──
90
+ let selectedPacks = ['core']; // Core always included
91
+
92
+ if (options.packs) {
93
+ const requested = options.packs.split(',').map(p => p.trim());
94
+ if (requested.includes('all')) {
95
+ selectedPacks = Object.keys(PACKS).filter(k => !PACKS[k].disabled);
96
+ } else {
97
+ selectedPacks = [...new Set(['core', ...requested.filter(p => PACKS[p] && !PACKS[p].disabled)])];
98
+ }
99
+ } else if (!options.yes) {
100
+ const packChoice = await clack.multiselect({
101
+ message: i.select_packs,
102
+ options: Object.entries(PACKS)
103
+ .filter(([, p]) => !p.required)
104
+ .map(([key, pack]) => ({
105
+ value: key,
106
+ label: `${pack.icon} ${pack.name}`,
107
+ hint: pack.disabled ? i.soon : (pack.desc || pack.description || ''),
108
+ disabled: pack.disabled,
109
+ })),
110
+ required: false,
111
+ });
112
+
113
+ if (clack.isCancel(packChoice)) {
114
+ clack.cancel(i.cancelled);
115
+ throw new Error(i.cancelled);
116
+ }
117
+
118
+ selectedPacks = [...new Set(['core', ...packChoice])];
119
+ }
120
+
121
+ clack.log.success(`${i.selected_packs}: ${selectedPacks.map(p => `${PACKS[p].icon} ${PACKS[p].name}`).join(', ')}`);
122
+
123
+ // ── Step 2: IDE Detection ──
124
+ let detectedIDEs = [];
125
+
126
+ if (options.tools) {
127
+ if (options.tools === 'none' || options.tools === 'skip') {
128
+ detectedIDEs = [];
129
+ } else {
130
+ detectedIDEs = options.tools.split(',').map(t => t.trim()).filter(t => IDE_CONFIGS[t]);
131
+ }
132
+ } else {
133
+ // Auto-detect
134
+ for (const [id, ide] of Object.entries(IDE_CONFIGS)) {
135
+ for (const marker of ide.detect) {
136
+ if (fs.existsSync(path.join(projectDir, marker))) {
137
+ detectedIDEs.push(id);
138
+ break;
139
+ }
140
+ }
141
+ }
142
+
143
+ // If nothing detected, ask
144
+ if (detectedIDEs.length === 0 && !options.yes) {
145
+ const ideChoice = await clack.multiselect({
146
+ message: i.select_ide,
147
+ options: Object.entries(IDE_CONFIGS).map(([key, ide]) => ({
148
+ value: key,
149
+ label: ide.name,
150
+ })),
151
+ required: false,
152
+ });
153
+
154
+ if (!clack.isCancel(ideChoice)) {
155
+ detectedIDEs = ideChoice;
156
+ }
157
+ }
158
+
159
+ // Default to all if --yes
160
+ if (detectedIDEs.length === 0 && options.yes) {
161
+ detectedIDEs = Object.keys(IDE_CONFIGS);
162
+ }
163
+ }
164
+
165
+ if (detectedIDEs.length > 0) {
166
+ clack.log.info(`${i.detected_ides}: ${detectedIDEs.map(id => IDE_CONFIGS[id].name).join(', ')}`);
167
+ } else if (options.tools === 'none' || options.tools === 'skip') {
168
+ clack.log.info(pc.dim('⏭️ IDE config skipped (--tools none) — existing configs preserved'));
169
+ }
170
+
171
+ // ── Step 3: User Config ──
172
+ let userName = process.env.USER || process.env.USERNAME || 'Developer';
173
+ let commLang = 'French';
174
+
175
+ if (!options.yes) {
176
+ const userConfig = await clack.group({
177
+ userName: () => clack.text({
178
+ message: i.enter_name,
179
+ placeholder: userName,
180
+ defaultValue: userName,
181
+ }),
182
+ commLang: () => clack.select({
183
+ message: i.comm_language,
184
+ options: getCommLanguageOptions(),
185
+ }),
186
+ execMode: () => clack.select({
187
+ message: i.exec_mode,
188
+ options: [
189
+ { value: 'manual', label: i.exec_manual },
190
+ { value: 'autopilot', label: i.exec_autopilot },
191
+ { value: 'hybrid', label: i.exec_hybrid },
192
+ ],
193
+ }),
194
+ });
195
+
196
+ if (clack.isCancel(userConfig)) {
197
+ clack.cancel(i.cancelled);
198
+ throw new Error(i.cancelled);
199
+ }
200
+
201
+ // Validate user-provided name
202
+ const rawName = userConfig.userName;
203
+ const SHELL_META = /[;&|`$(){}[\]!#~<>*?\\\n\r]/;
204
+ if (!rawName || rawName.trim().length === 0) {
205
+ clack.log.warn('Name cannot be empty. Using default.');
206
+ userName = process.env.USER || process.env.USERNAME || 'Developer';
207
+ } else if (rawName.length > 100) {
208
+ clack.log.warn('Name too long (>100 chars). Truncating.');
209
+ userName = rawName.slice(0, 100);
210
+ } else if (SHELL_META.test(rawName)) {
211
+ clack.log.warn('Name contains shell metacharacters. Using sanitized version.');
212
+ userName = rawName.replace(SHELL_META, '').trim() || 'Developer';
213
+ } else {
214
+ userName = rawName;
215
+ }
216
+ commLang = userConfig.commLang;
217
+ }
218
+
219
+ // ── Step 4: Install Files ──
220
+ const spinner = clack.spinner();
221
+ spinner.start(i.installing_files);
222
+
223
+ const targetAgentsDir = path.join(projectDir, '.agents', 'skills');
224
+ const targetDataDir = path.join(projectDir, '.agents', 'data');
225
+ const targetBmadDir = path.join(projectDir, '_bmad');
226
+
227
+ // Create directories
228
+ fsExtra.ensureDirSync(targetAgentsDir);
229
+ fsExtra.ensureDirSync(targetDataDir);
230
+ fsExtra.ensureDirSync(targetBmadDir);
231
+
232
+ let copiedAgents = 0;
233
+ let copiedSkills = 0;
234
+ let copiedFiles = 0;
235
+
236
+ const projectRoot = path.join(bmadSrc, '..', '..');
237
+
238
+ for (const packId of selectedPacks) {
239
+ const pack = PACKS[packId];
240
+ if (!pack || pack.disabled) continue;
241
+
242
+ const result = copyPackFiles({
243
+ bmadSrc,
244
+ targetAgentsDir,
245
+ targetDataDir,
246
+ projectRoot,
247
+ pack,
248
+ });
249
+ copiedAgents += result.copiedAgents;
250
+ copiedSkills += result.copiedSkills;
251
+ copiedFiles += result.copiedFiles;
252
+
253
+ // Memory pack: initialize brain with existing brain detection
254
+ if (packId === 'memory' && pack.packDir) {
255
+ initMemory({ projectDir, bmadSrc, userName, commLang, selectedPacks });
256
+ }
257
+ }
258
+
259
+ // Copy module config
260
+ const moduleYaml = path.join(bmadSrc, 'module.yaml');
261
+ if (fs.existsSync(moduleYaml)) {
262
+ fsExtra.copySync(moduleYaml, path.join(targetBmadDir, 'module.yaml'));
263
+ copiedFiles++;
264
+ }
265
+
266
+ const helpCsv = path.join(bmadSrc, 'module-help.csv');
267
+ if (fs.existsSync(helpCsv)) {
268
+ fsExtra.copySync(helpCsv, path.join(targetBmadDir, 'module-help.csv'));
269
+ copiedFiles++;
270
+ }
271
+
272
+ spinner.stop(i.installed_summary(copiedAgents, copiedSkills, copiedFiles));
273
+
274
+ // ── Step 5: Generate IDE Configs ──
275
+ if (detectedIDEs.length > 0) {
276
+ const ideSpinner = clack.spinner();
277
+ ideSpinner.start(i.configuring_ides);
278
+
279
+ const configContent = generateIDEConfig(userName, commLang, selectedPacks);
280
+
281
+ for (const ideId of detectedIDEs) {
282
+ const ide = IDE_CONFIGS[ideId];
283
+ if (!ide) continue;
284
+
285
+ const configPath = path.join(projectDir, ide.configFile);
286
+ fs.writeFileSync(configPath, configContent, 'utf8');
287
+ }
288
+
289
+ ideSpinner.stop(i.ide_configured(detectedIDEs.length));
290
+ }
291
+
292
+ // ── Step 6: Create config.yaml ──
293
+ const configYaml = generateConfigYaml(userName, commLang, projectDir);
294
+ const configPath = path.join(targetBmadDir, 'config.yaml');
295
+ fs.writeFileSync(configPath, configYaml, 'utf8');
296
+
297
+ // ── Step 7: Create output directories ──
298
+ const outputDir = path.join(projectDir, '_bmad-output');
299
+ fsExtra.ensureDirSync(path.join(outputDir, 'discovery'));
300
+ fsExtra.ensureDirSync(path.join(outputDir, 'build'));
301
+ fsExtra.ensureDirSync(path.join(projectDir, 'docs'));
302
+
303
+ // ── Step 8: Write install manifest ──
304
+ const pkgVersion = require('../../../package.json').version;
305
+ const manifest = {
306
+ version: pkgVersion,
307
+ uiLanguage: lang,
308
+ installed: new Date().toISOString(),
309
+ packs: selectedPacks,
310
+ ides: detectedIDEs,
311
+ user: userName,
312
+ language: commLang,
313
+ };
314
+ fs.writeFileSync(
315
+ path.join(targetBmadDir, '.bmad-plus-install.json'),
316
+ JSON.stringify(manifest, null, 2),
317
+ 'utf8'
318
+ );
319
+
320
+ // ── Summary Contextual Getting Started ──
321
+ const agentGuide = [
322
+ i.guide_who,
323
+ '',
324
+ ` ${i.guide_idea.padEnd(28)} → "Atlas, [...]"`,
325
+ ` ${i.guide_prd.padEnd(28)} → "Atlas, create PRD"`,
326
+ ` ${i.guide_arch.padEnd(28)} → "Forge, propose architecture"`,
327
+ ` ${i.guide_code.padEnd(28)} → "Forge, implement story [X]"`,
328
+ ` ${i.guide_test.padEnd(28)} → "Sentinel, review module [X]"`,
329
+ ` ${i.guide_sprint.padEnd(28)} → "Nexus, create epics"`,
330
+ ` ${i.guide_auto.padEnd(28)} → "autopilot"`,
331
+ ];
332
+
333
+ if (selectedPacks.includes('osint')) {
334
+ agentGuide.push(` ${i.guide_osint.padEnd(28)} → "Shadow, investigate [name]"`);
335
+ }
336
+
337
+ if (selectedPacks.includes('maker')) {
338
+ agentGuide.push(` ${i.guide_maker.padEnd(28)} → "Maker, create agent [desc]"`);
339
+ }
340
+
341
+ if (selectedPacks.includes('seo')) {
342
+ agentGuide.push(` ${i.guide_seo.padEnd(28)} → "/seo audit <url>"`);
343
+ }
344
+
345
+ if (selectedPacks.includes('backup')) {
346
+ agentGuide.push(` ${i.guide_backup.padEnd(28)} → "/backup create"`);
347
+ }
348
+
349
+ if (selectedPacks.includes('animated')) {
350
+ agentGuide.push(` ${i.guide_animated.padEnd(28)} → "/animated build <video>"`);
351
+ }
352
+
353
+ if (selectedPacks.includes('shield')) {
354
+ agentGuide.push(` ${(i.guide_shield || '🛡️ GRC Compliance').padEnd(28)} → "Shield, audit my SaaS for GDPR"`);
355
+ }
356
+
357
+ if (selectedPacks.includes('memory')) {
358
+ agentGuide.push(` ${(i.guide_memory || '🧠 Memory Brain').padEnd(28)} → "Zecher, scan projects in [path]"`);
359
+ }
360
+
361
+ if (selectedPacks.includes('dev-studio')) {
362
+ agentGuide.push(` ${(i.guide_dev_studio || '🏗️ Dev Studio').padEnd(28)} → "Miriam, brainstorm my app idea"`);
363
+ }
364
+
365
+ agentGuide.push(
366
+ '',
367
+ i.guide_workflow,
368
+ ' 1. Atlas (idea brief PRD)',
369
+ ' 2. Forge (architecture → code)',
370
+ ' 3. Sentinel (tests review)',
371
+ '',
372
+ i.guide_or_auto,
373
+ '',
374
+ `${i.guide_output}: _bmad-output/discovery/ & _bmad-output/build/`,
375
+ '',
376
+ '─'.repeat(50),
377
+ '',
378
+ `📦 ${i.guide_cli_title || 'CLI Commands'}:`,
379
+ ` npx bmad-plus install ${i.guide_cli_install || '— Install agents & skills'}`,
380
+ ` npx bmad-plus update ${i.guide_cli_update || '— Update agents (keeps config)'}`,
381
+ ` npx bmad-plus doctor ${i.guide_cli_doctor || '— Check installation health'}`,
382
+ ` npx bmad-plus uninstall ${i.guide_cli_uninstall || '— Remove BMAD+ from project'}`,
383
+ );
384
+
385
+ // Add pack-specific examples
386
+ const examples = [];
387
+ if (selectedPacks.includes('seo')) {
388
+ examples.push(` ${i.guide_example_seo || '🔍 SEO: "/seo audit https://example.com"'}`);
389
+ }
390
+ if (selectedPacks.includes('backup')) {
391
+ examples.push(` ${i.guide_example_backup || '🗂️ Backup: "/backup create" → ZIP timestamped'}`);
392
+ }
393
+ if (selectedPacks.includes('animated')) {
394
+ examples.push(` ${i.guide_example_animated || '🎬 Animated: "/animated build hero.mp4"'}`);
395
+ }
396
+ if (selectedPacks.includes('osint')) {
397
+ examples.push(` ${i.guide_example_osint || '🔍 OSINT: "Shadow, investigate John Doe"'}`);
398
+ }
399
+ if (selectedPacks.includes('shield')) {
400
+ examples.push(
401
+ ` ${i.guide_example_shield_1 || '🛡️ GRC: "Shield, audit my app for GDPR compliance"'}`,
402
+ ` ${i.guide_example_shield_2 || '🛡️ GRC: "Shield, gap analysis ISO 27001 vs NIST CSF"'}`,
403
+ ` ${i.guide_example_shield_3 || '🛡️ GRC: "Shield, generate SOC 2 evidence checklist"'}`,
404
+ );
405
+ }
406
+ if (selectedPacks.includes('dev-studio')) {
407
+ examples.push(
408
+ ` ${i.guide_example_dev_studio_1 || '🏗️ Dev Studio: "Miriam, brainstorm a productivity app"'}`,
409
+ ` ${i.guide_example_dev_studio_2 || '🏗️ Dev Studio: "Bezalel, design the architecture"'}`,
410
+ ` ${i.guide_example_dev_studio_3 || '🏗️ Dev Studio: "Oholiab, implement story S1"'}`,
411
+ );
412
+ }
413
+ if (selectedPacks.includes('memory')) {
414
+ examples.push(
415
+ ` ${i.guide_example_memory_1 || '🧠 Memory: "Zecher, scan projects in D:\\travail\\DEV"'}`,
416
+ ` ${i.guide_example_memory_2 || '🧠 Memory: "Zecher, where were we?"'}`,
417
+ ` ${i.guide_example_memory_3 || '🧠 Memory: "Zecher, consolidate memory"'}`,
418
+ );
419
+ }
420
+
421
+ if (examples.length > 0) {
422
+ agentGuide.push(
423
+ '',
424
+ `💡 ${i.guide_examples_title || 'Quick Examples'}:`,
425
+ ...examples
426
+ );
427
+ }
428
+
429
+ agentGuide.push(
430
+ '',
431
+ '---',
432
+ i.guide_credits
433
+ );
434
+
435
+ clack.note(agentGuide.join('\n'), i.guide_title);
436
+
437
+ clack.outro(pc.green(i.guide_ready));
438
+ },
439
+ };
440
+
441
+
442
+ // ── Helpers ──
443
+
444
+ function generateIDEConfig(userName, language, packs) {
445
+ const agents = [
446
+ '- **Atlas** (Strategist) — Business analysis + Product management',
447
+ '- **Forge** (Architect-Dev) — Architecture + Development + Documentation',
448
+ '- **Sentinel** (Quality) — QA + UX review',
449
+ '- **Nexus** (Orchestrator) — Sprint management + Autopilot + Parallel execution',
450
+ ];
451
+
452
+ if (packs.includes('osint')) {
453
+ agents.push('- **Shadow** (OSINT) — Investigation + Scraping + Psychoprofiling');
454
+ }
455
+
456
+ if (packs.includes('shield')) {
457
+ agents.push('- **Shield** (GRC) — 38 compliance agents (GDPR, ISO 27001, SOC 2, HIPAA, EU AI Act, DORA, NIS2...)');
458
+ }
459
+
460
+ if (packs.includes('dev-studio')) {
461
+ agents.push('- **Miriam** (מרים) — Business Analyst — Strategic analysis, research, product briefs');
462
+ agents.push('- **Huldah** (חולדה) — Technical Writer — Documentation, diagrams, editorial review');
463
+ agents.push('- **Yosef** (יוסף) — Product Manager — PRD, requirements, feature prioritization');
464
+ agents.push('- **Rachel** (רחל) — UX Designer — User experience, wireframes, empathy mapping');
465
+ agents.push('- **Bezalel** (בצלאל) System Architect Architecture, ADRs, epics & stories');
466
+ agents.push('- **Oholiab** (אהליאב) Senior Engineer — TDD, sprint, code review, implementation');
467
+ }
468
+
469
+ if (packs.includes('memory')) {
470
+ agents.push('- **Zecher** (זכר) — Memory Archivist — Consolidation, project scanning, context recall');
471
+ }
472
+
473
+ // Build memory section if memory pack is installed
474
+ let memorySection = '';
475
+ if (packs.includes('memory')) {
476
+ memorySection = [
477
+ '',
478
+ '## Memory Protocol (Karpathy Guardrails)',
479
+ '',
480
+ 'Agents MUST follow these behavioral principles:',
481
+ '',
482
+ '### G1 — Think Before Coding',
483
+ '- State assumptions explicitly. If uncertain, ask.',
484
+ '- Check `.agents/memory/decisions.md` for prior decisions before re-deciding.',
485
+ '',
486
+ '### G2 — Simplicity First',
487
+ '- Minimum code that solves the problem. Nothing speculative.',
488
+ '- Check `.agents/memory/patterns.md` for existing solutions.',
489
+ '',
490
+ '### G3 — Surgical Changes',
491
+ '- Touch only what you must. Match existing style.',
492
+ '- Log surprises in `.agents/memory/lessons.md`.',
493
+ '',
494
+ '### G4 Goal-Driven Execution',
495
+ '- Define success criteria before implementing.',
496
+ '- Log non-obvious decisions in `.agents/memory/decisions.md`.',
497
+ '',
498
+ '### Memory Files',
499
+ '- `.agents/memory/decisions.md` — Read at session start, write when making decisions',
500
+ '- `.agents/memory/lessons.md` — Write when something unexpected happens',
501
+ '- `.agents/memory/patterns.md` — Write when a reusable pattern is validated',
502
+ '- `.agents/memory/context.md` — Update at session end with project state',
503
+ ].join('\n');
504
+ }
505
+
506
+ return `# BMAD+ — AI Agent Configuration
507
+
508
+ ## Project Context
509
+ This project uses BMAD+, an augmented AI-driven development framework.
510
+ Based on BMAD-METHOD v6.6.0 with multi-role agents, autopilot mode, and parallel execution.
511
+
512
+ ## Agents
513
+ To activate an agent, say its name or persona:
514
+ ${agents.join('\n')}
515
+
516
+ ## Skills
517
+ - Load skills from \`.agents/skills/\`
518
+ - Each agent has a SKILL.md with capabilities, activation protocol, and role-switching rules
519
+ - Auto-activation triggers: \`.agents/data/role-triggers.yaml\`
520
+
521
+ ## Key Commands
522
+ - \`bmad-help\` — Show all available agents and skills
523
+ - \`autopilot\` — Launch Nexus in full pipeline mode
524
+ - \`parallel\` — Enable parallel multi-agent execution
525
+
526
+ ## Communication
527
+ - User name: ${userName}
528
+ - Default language: ${language} for user-facing content, English for code and technical docs.
529
+ ${memorySection}`;
530
+ }
531
+
532
+ function generateConfigYaml(userName, language, projectDir) {
533
+ const projectName = path.basename(projectDir);
534
+ return `# BMAD+ Project Configuration
535
+ # Generated by bmad-plus install
536
+
537
+ user_name: "${userName}"
538
+ communication_language: "${language}"
539
+ document_output_language: "${language}"
540
+ output_folder: "_bmad-output"
541
+ project_name: "${projectName}"
542
+
543
+ # Execution settings
544
+ execution_mode: "manual"
545
+ auto_role_activation: true
546
+ parallel_execution: true
547
+ `;
548
+ }