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.
- package/CHANGELOG.md +479 -425
- package/LICENSE +21 -21
- package/README.md +557 -447
- 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 +584 -426
- package/readme-international/README.es.md +601 -518
- package/readme-international/README.fr.md +599 -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/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/{agents → packs}/pack-animated/animated-website-agent.md +325 -325
- package/src/bmad-plus/{agents → packs}/pack-animated/templates/animated-website-workflow.md +55 -55
- package/src/bmad-plus/{agents → packs}/pack-backup/backup-agent.md +71 -71
- package/src/bmad-plus/{agents → packs}/pack-backup/templates/backup-workflow.md +51 -51
- 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/{agents → packs}/pack-seo/SKILL.md +171 -171
- package/src/bmad-plus/packs/pack-seo/bmad-skill-manifest.yaml +13 -0
- package/src/bmad-plus/{agents → packs}/pack-seo/checklist.md +140 -140
- package/src/bmad-plus/{agents → packs}/pack-seo/pagespeed-playbook.md +320 -320
- package/src/bmad-plus/{agents → packs}/pack-seo/ref/audit-schema.json +187 -187
- package/src/bmad-plus/{agents → packs}/pack-seo/ref/cwv-thresholds.md +87 -87
- package/src/bmad-plus/{agents → packs}/pack-seo/ref/eeat-criteria.md +123 -123
- package/src/bmad-plus/{agents → packs}/pack-seo/ref/geo-signals.md +167 -167
- package/src/bmad-plus/{agents → packs}/pack-seo/ref/hreflang-rules.md +153 -153
- package/src/bmad-plus/{agents → packs}/pack-seo/ref/quality-gates.md +133 -133
- package/src/bmad-plus/{agents → packs}/pack-seo/ref/schema-catalog.md +91 -91
- package/src/bmad-plus/{agents → packs}/pack-seo/ref/schema-templates.json +356 -356
- package/src/bmad-plus/{agents → packs}/pack-seo/seo-chief.md +294 -294
- package/src/bmad-plus/{agents → packs}/pack-seo/seo-judge.md +241 -241
- package/src/bmad-plus/{agents → packs}/pack-seo/seo-scout.md +171 -171
- package/src/bmad-plus/{agents → packs}/pack-seo/templates/seo-audit-workflow.md +241 -241
- package/src/bmad-plus/packs/pack-shield/README.md +110 -110
- package/src/bmad-plus/packs/pack-shield/SKILL.md +82 -0
- 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/bmad-plus-npx.js +3 -5
- package/tools/cli/commands/autoconfig.js +508 -489
- package/tools/cli/commands/doctor.js +219 -222
- package/tools/cli/commands/install.js +548 -739
- package/tools/cli/commands/memory.js +194 -194
- package/tools/cli/commands/scan.js +362 -350
- package/tools/cli/commands/uninstall.js +96 -96
- package/tools/cli/commands/update.js +116 -174
- package/tools/cli/i18n.js +845 -763
- package/tools/cli/lib/memory-init.js +114 -0
- package/tools/cli/lib/pack-copy.js +84 -0
- 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
|
-
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
clack.
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
let
|
|
174
|
-
|
|
175
|
-
if (options.
|
|
176
|
-
const
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
.
|
|
188
|
-
|
|
189
|
-
label:
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
});
|
|
195
|
-
|
|
196
|
-
if (clack.isCancel(
|
|
197
|
-
clack.cancel(i.cancelled);
|
|
198
|
-
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
if (
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
const
|
|
294
|
-
const
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
fsExtra.ensureDirSync(
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
}
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
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
|
+
}
|