bmad-plus 0.7.4 → 0.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.
- package/CHANGELOG.md +450 -407
- package/LICENSE +21 -0
- package/README.md +555 -446
- package/osint-agent-package/README.md +88 -88
- package/osint-agent-package/SETUP_KEYS.md +108 -108
- package/osint-agent-package/agents/osint-investigator.md +80 -80
- package/osint-agent-package/install.ps1 +87 -87
- package/osint-agent-package/install.sh +76 -76
- package/osint-agent-package/skills/bmad-osint-investigate/SKILL.md +147 -147
- package/osint-agent-package/skills/bmad-osint-investigate/osint/SKILL.md +452 -452
- package/osint-agent-package/skills/bmad-osint-investigate/osint/assets/dossier-template.md +116 -116
- package/osint-agent-package/skills/bmad-osint-investigate/osint/references/content-extraction.md +100 -100
- package/osint-agent-package/skills/bmad-osint-investigate/osint/references/enrichment-databases-fr.md +148 -148
- package/osint-agent-package/skills/bmad-osint-investigate/osint/references/platforms.md +130 -130
- package/osint-agent-package/skills/bmad-osint-investigate/osint/references/psychoprofile.md +69 -69
- package/osint-agent-package/skills/bmad-osint-investigate/osint/references/tools.md +281 -281
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/_http.py +101 -101
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/apify.py +266 -260
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/brightdata.py +101 -101
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/diagnose.py +141 -141
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/exa.py +79 -79
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/jina.py +71 -71
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/mcp-client.py +136 -136
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/parallel.py +85 -85
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/perplexity.py +102 -102
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/tavily.py +72 -72
- package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/volley.py +208 -208
- package/osint-agent-package/skills/bmad-osint-investigator/SKILL.md +15 -15
- package/package.json +62 -57
- package/readme-international/README.de.md +576 -426
- package/readme-international/README.es.md +578 -518
- package/readme-international/README.fr.md +576 -516
- package/src/bmad-plus/agents/agent-architect-dev/SKILL.md +96 -96
- package/src/bmad-plus/agents/agent-architect-dev/bmad-skill-manifest.yaml +13 -13
- package/src/bmad-plus/agents/agent-maker/SKILL.md +201 -201
- package/src/bmad-plus/agents/agent-maker/bmad-skill-manifest.yaml +13 -13
- package/src/bmad-plus/agents/agent-orchestrator/SKILL.md +137 -137
- package/src/bmad-plus/agents/agent-orchestrator/bmad-skill-manifest.yaml +13 -13
- package/src/bmad-plus/agents/agent-quality/SKILL.md +83 -83
- package/src/bmad-plus/agents/agent-quality/bmad-skill-manifest.yaml +13 -13
- package/src/bmad-plus/agents/agent-shadow/SKILL.md +71 -71
- package/src/bmad-plus/agents/agent-shadow/bmad-skill-manifest.yaml +13 -13
- package/src/bmad-plus/agents/agent-strategist/SKILL.md +80 -80
- package/src/bmad-plus/agents/agent-strategist/bmad-skill-manifest.yaml +13 -13
- package/src/bmad-plus/agents/pack-animated/animated-website-agent.md +325 -325
- package/src/bmad-plus/agents/pack-animated/templates/animated-website-workflow.md +55 -55
- package/src/bmad-plus/agents/pack-backup/backup-agent.md +71 -71
- package/src/bmad-plus/agents/pack-backup/templates/backup-workflow.md +51 -51
- package/src/bmad-plus/agents/pack-seo/SKILL.md +171 -171
- package/src/bmad-plus/agents/pack-seo/checklist.md +140 -140
- package/src/bmad-plus/agents/pack-seo/pagespeed-playbook.md +320 -320
- package/src/bmad-plus/agents/pack-seo/ref/audit-schema.json +187 -187
- package/src/bmad-plus/agents/pack-seo/ref/cwv-thresholds.md +87 -87
- package/src/bmad-plus/agents/pack-seo/ref/eeat-criteria.md +123 -123
- package/src/bmad-plus/agents/pack-seo/ref/geo-signals.md +167 -167
- package/src/bmad-plus/agents/pack-seo/ref/hreflang-rules.md +153 -153
- package/src/bmad-plus/agents/pack-seo/ref/quality-gates.md +133 -133
- package/src/bmad-plus/agents/pack-seo/ref/schema-catalog.md +91 -91
- package/src/bmad-plus/agents/pack-seo/ref/schema-templates.json +356 -356
- package/src/bmad-plus/agents/pack-seo/seo-chief.md +294 -294
- package/src/bmad-plus/agents/pack-seo/seo-judge.md +241 -241
- package/src/bmad-plus/agents/pack-seo/seo-scout.md +171 -171
- package/src/bmad-plus/agents/pack-seo/templates/seo-audit-workflow.md +241 -241
- package/src/bmad-plus/data/role-triggers.yaml +209 -209
- package/src/bmad-plus/module-help.csv +10 -10
- package/src/bmad-plus/module.yaml +283 -280
- package/src/bmad-plus/packs/pack-animated/animated-website-agent.md +325 -0
- package/src/bmad-plus/packs/pack-animated/templates/animated-website-workflow.md +55 -0
- package/src/bmad-plus/packs/pack-backup/backup-agent.md +71 -0
- package/src/bmad-plus/packs/pack-backup/templates/backup-workflow.md +51 -0
- package/src/bmad-plus/packs/pack-dev-studio/README.md +162 -162
- package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/analyst-agent.md +73 -73
- package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/document-project.md +61 -61
- package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/domain-research.md +95 -95
- package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/market-research.md +95 -95
- package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/prfaq.md +134 -134
- package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/product-brief.md +80 -80
- package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/tech-writer-agent.md +73 -73
- package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/technical-research.md +95 -95
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/architect-agent.md +73 -73
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/create-architecture.md +73 -73
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/create-epics-stories.md +92 -92
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/generate-project-context.md +80 -80
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/implementation-readiness.md +90 -90
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-01-init.md +153 -153
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-01b-continue.md +173 -173
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-02-context.md +224 -224
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-03-starter.md +329 -329
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-04-decisions.md +318 -318
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-05-patterns.md +359 -359
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-06-structure.md +379 -379
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-07-validation.md +361 -361
- package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-08-complete.md +81 -81
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/checkpoint-preview.md +67 -67
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-01-gather-context.md +85 -85
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-02-review.md +35 -35
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-03-triage.md +49 -49
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-04-present.md +131 -131
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review.md +89 -89
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/correct-course.md +300 -300
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/create-story.md +428 -428
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-agent.md +73 -73
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-story-checklist.md +80 -80
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-story.md +484 -484
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/investigate.md +193 -193
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/qa-e2e-tests.md +175 -175
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/quick-dev.md +110 -110
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/retrospective.md +1511 -1511
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/sprint-planning.md +298 -298
- package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/sprint-status.md +296 -296
- package/src/bmad-plus/packs/pack-dev-studio/categories/planning/create-prd.md +29 -29
- package/src/bmad-plus/packs/pack-dev-studio/categories/planning/create-ux-design.md +74 -74
- package/src/bmad-plus/packs/pack-dev-studio/categories/planning/edit-prd.md +29 -29
- package/src/bmad-plus/packs/pack-dev-studio/categories/planning/pm-agent.md +73 -73
- package/src/bmad-plus/packs/pack-dev-studio/categories/planning/prd.md +89 -89
- package/src/bmad-plus/packs/pack-dev-studio/categories/planning/ux-designer-agent.md +73 -73
- package/src/bmad-plus/packs/pack-dev-studio/categories/planning/validate-prd.md +29 -29
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/advanced-elicitation.md +141 -141
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/adversarial-review.md +37 -37
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/bmad-help.md +75 -75
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/brainstorming.md +6 -6
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/customize.md +110 -110
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/distillator.md +176 -176
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/edge-case-hunter.md +67 -67
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/editorial-review-prose.md +86 -86
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/editorial-review-structure.md +179 -179
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/index-docs.md +66 -66
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/party-mode.md +127 -127
- package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/shard-doc.md +105 -105
- package/src/bmad-plus/packs/pack-dev-studio/dev-studio-orchestrator.md +120 -120
- package/src/bmad-plus/packs/pack-dev-studio/shared/architecture-decision-template.md +12 -12
- package/src/bmad-plus/packs/pack-dev-studio/shared/bwml-spec.md +328 -328
- package/src/bmad-plus/packs/pack-dev-studio/shared/module-help.csv +32 -32
- package/src/bmad-plus/packs/pack-dev-studio/upstream-sync.yaml +81 -81
- package/src/bmad-plus/packs/pack-memory/README.md +106 -106
- package/src/bmad-plus/packs/pack-memory/memory-orchestrator.md +79 -79
- package/src/bmad-plus/packs/pack-memory/shared/karpathy-guardrails.md +86 -86
- package/src/bmad-plus/packs/pack-memory/shared/memory-protocol.md +143 -143
- package/src/bmad-plus/packs/pack-memory/templates/context.md +39 -39
- package/src/bmad-plus/packs/pack-memory/templates/decisions.md +25 -25
- package/src/bmad-plus/packs/pack-memory/templates/identity.yaml +39 -39
- package/src/bmad-plus/packs/pack-memory/templates/lessons.md +31 -31
- package/src/bmad-plus/packs/pack-memory/templates/patterns.md +24 -24
- package/src/bmad-plus/packs/pack-memory/templates/session-handoff.md +25 -25
- package/src/bmad-plus/packs/pack-memory/zecher-agent.md +157 -157
- package/src/bmad-plus/packs/pack-seo/SKILL.md +171 -0
- package/src/bmad-plus/packs/pack-seo/checklist.md +140 -0
- package/src/bmad-plus/packs/pack-seo/pagespeed-playbook.md +320 -0
- package/src/bmad-plus/packs/pack-seo/ref/audit-schema.json +187 -0
- package/src/bmad-plus/packs/pack-seo/ref/cwv-thresholds.md +87 -0
- package/src/bmad-plus/packs/pack-seo/ref/eeat-criteria.md +123 -0
- package/src/bmad-plus/packs/pack-seo/ref/geo-signals.md +167 -0
- package/src/bmad-plus/packs/pack-seo/ref/hreflang-rules.md +153 -0
- package/src/bmad-plus/packs/pack-seo/ref/quality-gates.md +133 -0
- package/src/bmad-plus/packs/pack-seo/ref/schema-catalog.md +91 -0
- package/src/bmad-plus/packs/pack-seo/ref/schema-templates.json +356 -0
- package/src/bmad-plus/packs/pack-seo/seo-chief.md +294 -0
- package/src/bmad-plus/packs/pack-seo/seo-judge.md +241 -0
- package/src/bmad-plus/packs/pack-seo/seo-scout.md +171 -0
- package/src/bmad-plus/packs/pack-seo/templates/seo-audit-workflow.md +241 -0
- package/src/bmad-plus/packs/pack-shield/README.md +110 -110
- package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/csrd-agent.md +262 -262
- package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/section508-agent.md +179 -179
- package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/wcag-agent.md +201 -201
- package/src/bmad-plus/packs/pack-shield/categories/ai-governance/eu-ai-act-agent.md +97 -97
- package/src/bmad-plus/packs/pack-shield/categories/ai-governance/iso42001-agent.md +251 -251
- package/src/bmad-plus/packs/pack-shield/categories/ai-governance/nist-ai-rmf-agent.md +133 -133
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/cis-controls-agent.md +221 -221
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/ism-agent.md +150 -150
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/iso27001-agent.md +167 -167
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nis2-agent.md +83 -83
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nist-800-53-agent.md +250 -250
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nist-csf-agent.md +218 -218
- package/src/bmad-plus/packs/pack-shield/categories/data-privacy/ccpa-agent.md +94 -94
- package/src/bmad-plus/packs/pack-shield/categories/data-privacy/dpdpa-agent.md +136 -136
- package/src/bmad-plus/packs/pack-shield/categories/data-privacy/gdpr-agent.md +296 -296
- package/src/bmad-plus/packs/pack-shield/categories/data-privacy/iso27701-agent.md +134 -134
- package/src/bmad-plus/packs/pack-shield/categories/data-privacy/lgpd-agent.md +129 -129
- package/src/bmad-plus/packs/pack-shield/categories/defense-export/cmmc-agent.md +127 -127
- package/src/bmad-plus/packs/pack-shield/categories/defense-export/ear-agent.md +272 -272
- package/src/bmad-plus/packs/pack-shield/categories/defense-export/itar-agent.md +202 -202
- package/src/bmad-plus/packs/pack-shield/categories/defense-export/tsa-agent.md +367 -367
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/dora-agent.md +510 -510
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/fedramp-agent.md +247 -247
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/hipaa-agent.md +173 -173
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/pci-dss-agent.md +239 -239
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/soc2-agent.md +266 -266
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/swift-csp-agent.md +164 -164
- package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-classifier.md +131 -131
- package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-fria.md +155 -155
- package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-incidents.md +187 -187
- package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-roles.md +113 -113
- package/src/bmad-plus/packs/pack-shield/categories/workflows/breach-sentinel.md +197 -197
- package/src/bmad-plus/packs/pack-shield/categories/workflows/cookie-policy-gen.md +180 -180
- package/src/bmad-plus/packs/pack-shield/categories/workflows/dpia-sentinel.md +235 -235
- package/src/bmad-plus/packs/pack-shield/categories/workflows/legitimate-interest.md +159 -159
- package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-advisor.md +133 -133
- package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-notice-gen.md +160 -160
- package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-policy-gen.md +135 -135
- package/src/bmad-plus/packs/pack-shield/references/ccpa/ccpa-gdpr-comparison.md +117 -117
- package/src/bmad-plus/packs/pack-shield/references/ccpa/consumer-rights-workflows.md +177 -177
- package/src/bmad-plus/packs/pack-shield/references/cis-controls/framework-mappings.md +162 -162
- package/src/bmad-plus/packs/pack-shield/references/cis-controls/implementation-guidance.md +235 -235
- package/src/bmad-plus/packs/pack-shield/references/cis-controls/safeguards-detail.md +252 -252
- package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-assessment.md +170 -170
- package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-levels.md +113 -113
- package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-practices.md +211 -211
- package/src/bmad-plus/packs/pack-shield/references/csrd/compliance-program.md +281 -281
- package/src/bmad-plus/packs/pack-shield/references/csrd/double-materiality.md +253 -253
- package/src/bmad-plus/packs/pack-shield/references/csrd/esrs-standards.md +401 -401
- package/src/bmad-plus/packs/pack-shield/references/dora/article-reference.md +441 -441
- package/src/bmad-plus/packs/pack-shield/references/dora/incident-classification.md +297 -297
- package/src/bmad-plus/packs/pack-shield/references/dora/rts-its-guide.md +306 -306
- package/src/bmad-plus/packs/pack-shield/references/dora/third-party-risk.md +349 -349
- package/src/bmad-plus/packs/pack-shield/references/dpdpa/gdpr-comparison.md +173 -173
- package/src/bmad-plus/packs/pack-shield/references/dpdpa/rights-and-obligations.md +426 -426
- package/src/bmad-plus/packs/pack-shield/references/dpdpa/rules-2025.md +599 -599
- package/src/bmad-plus/packs/pack-shield/references/dpdpa/sections-reference.md +319 -319
- package/src/bmad-plus/packs/pack-shield/references/ear/ccl-eccn-guide.md +250 -250
- package/src/bmad-plus/packs/pack-shield/references/ear/compliance-program.md +280 -280
- package/src/bmad-plus/packs/pack-shield/references/ear/license-exceptions.md +207 -207
- package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/gpai-governance.md +267 -267
- package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/obligations-high-risk.md +287 -287
- package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/risk-classification.md +182 -182
- package/src/bmad-plus/packs/pack-shield/references/fedramp/appendices-guide.md +209 -209
- package/src/bmad-plus/packs/pack-shield/references/fedramp/control-families.md +281 -281
- package/src/bmad-plus/packs/pack-shield/references/fedramp/poam-guide.md +93 -93
- package/src/bmad-plus/packs/pack-shield/references/fedramp/readiness-checklist.md +134 -134
- package/src/bmad-plus/packs/pack-shield/references/fedramp/sap-sar-guide.md +86 -86
- package/src/bmad-plus/packs/pack-shield/references/fedramp/ssp-guide.md +129 -129
- package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/documents.md +192 -192
- package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/dpa-template.md +121 -121
- package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/privacy-notice.md +87 -87
- package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/breach-notification.md +293 -293
- package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/privacy-rule.md +276 -276
- package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/security-rule.md +299 -299
- package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/templates.md +568 -568
- package/src/bmad-plus/packs/pack-shield/references/ism/control-applicability.md +181 -181
- package/src/bmad-plus/packs/pack-shield/references/ism/guidelines-overview.md +183 -183
- package/src/bmad-plus/packs/pack-shield/references/iso27001/annex-a-2013.md +203 -203
- package/src/bmad-plus/packs/pack-shield/references/iso27001/annex-a-2022.md +132 -132
- package/src/bmad-plus/packs/pack-shield/references/iso27001/control-mapping.md +153 -153
- package/src/bmad-plus/packs/pack-shield/references/iso27701/annex-a-controls.md +195 -195
- package/src/bmad-plus/packs/pack-shield/references/iso27701/regulatory-mapping.md +229 -229
- package/src/bmad-plus/packs/pack-shield/references/iso27701/transition-guide.md +219 -219
- package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-ai-risk-assessment.md +258 -258
- package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-clauses-requirements.md +279 -279
- package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-controls-annex-a.md +155 -155
- package/src/bmad-plus/packs/pack-shield/references/itar/compliance-program.md +174 -174
- package/src/bmad-plus/packs/pack-shield/references/itar/licensing-guide.md +146 -146
- package/src/bmad-plus/packs/pack-shield/references/itar/usml-categories.md +93 -93
- package/src/bmad-plus/packs/pack-shield/references/lgpd/anpd-enforcement.md +147 -147
- package/src/bmad-plus/packs/pack-shield/references/lgpd/compliance-program.md +272 -272
- package/src/bmad-plus/packs/pack-shield/references/lgpd/lgpd-articles.md +271 -271
- package/src/bmad-plus/packs/pack-shield/references/nis2/article-21-measures.md +153 -153
- package/src/bmad-plus/packs/pack-shield/references/nis2/iso27001-nis2-mapping.md +68 -68
- package/src/bmad-plus/packs/pack-shield/references/nist-800-53/assessment-rmf.md +349 -349
- package/src/bmad-plus/packs/pack-shield/references/nist-800-53/baselines-tailoring.md +277 -277
- package/src/bmad-plus/packs/pack-shield/references/nist-800-53/control-families.md +450 -450
- package/src/bmad-plus/packs/pack-shield/references/nist-ai-rmf/rmf-core.md +361 -361
- package/src/bmad-plus/packs/pack-shield/references/nist-ai-rmf/rmf-profiles.md +192 -192
- package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-10-to-20-mapping.md +143 -143
- package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-20-functions-categories.md +278 -278
- package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-implementation-tiers.md +135 -135
- package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-requirements.md +366 -366
- package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-saq-guide.md +217 -217
- package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-v4-changes.md +190 -190
- package/src/bmad-plus/packs/pack-shield/references/section-508/wcag-mapping.md +160 -160
- package/src/bmad-plus/packs/pack-shield/references/soc2/controls.md +241 -241
- package/src/bmad-plus/packs/pack-shield/references/soc2/evidence.md +236 -236
- package/src/bmad-plus/packs/pack-shield/references/soc2/policies.md +254 -254
- package/src/bmad-plus/packs/pack-shield/references/soc2/vendor.md +276 -276
- package/src/bmad-plus/packs/pack-shield/references/swift-csp/swift-assessment.md +202 -202
- package/src/bmad-plus/packs/pack-shield/references/swift-csp/swift-controls.md +545 -545
- package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-crmp-requirements.md +359 -359
- package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-directives-overview.md +187 -187
- package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-incident-reporting.md +187 -187
- package/src/bmad-plus/packs/pack-shield/references/wcag/criteria-detail.md +510 -510
- package/src/bmad-plus/packs/pack-shield/shared/audit-report-template.md +103 -103
- package/src/bmad-plus/packs/pack-shield/shared/cross-framework-mapper.md +103 -103
- package/src/bmad-plus/packs/pack-shield/shared/gap-analysis-template.md +83 -83
- package/src/bmad-plus/packs/pack-shield/shield-orchestrator.md +229 -229
- package/src/bmad-plus/packs/pack-shield/upstream-sync.yaml +68 -68
- package/src/bmad-plus/skills/bmad-plus-autopilot/SKILL.md +99 -99
- package/src/bmad-plus/skills/bmad-plus-parallel/SKILL.md +93 -93
- package/src/bmad-plus/skills/bmad-plus-sync/SKILL.md +69 -69
- package/tools/cli/commands/autoconfig.js +498 -489
- package/tools/cli/commands/doctor.js +222 -175
- package/tools/cli/commands/install.js +739 -739
- package/tools/cli/commands/memory.js +194 -194
- package/tools/cli/commands/scan.js +360 -350
- package/tools/cli/commands/uninstall.js +96 -96
- package/tools/cli/commands/update.js +174 -174
- package/tools/cli/i18n.js +763 -763
|
@@ -1,739 +1,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
|
-
|
|
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: '
|
|
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
|
+
|
|
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: '38 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
|
+
}
|