bmad-plus 0.9.0 → 0.9.1
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 +15 -0
- package/LICENSE +21 -21
- package/README.md +105 -85
- 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/references/enrichment-databases-fr.md +148 -148
- 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 -266
- 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/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 +30 -3
- package/readme-international/README.de.md +8 -3
- package/readme-international/README.es.md +8 -3
- package/readme-international/README.fr.md +8 -3
- 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/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/bmad-skill-manifest.yaml +13 -13
- package/src/bmad-plus/packs/pack-shield/README.md +110 -110
- package/src/bmad-plus/packs/pack-shield/SKILL.md +82 -82
- package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/csrd-agent.md +251 -251
- package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/section508-agent.md +168 -168
- package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/wcag-agent.md +190 -190
- package/src/bmad-plus/packs/pack-shield/categories/ai-governance/eu-ai-act-agent.md +86 -86
- package/src/bmad-plus/packs/pack-shield/categories/ai-governance/iso42001-agent.md +240 -240
- package/src/bmad-plus/packs/pack-shield/categories/ai-governance/nist-ai-rmf-agent.md +122 -122
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/cis-controls-agent.md +210 -210
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/ism-agent.md +139 -139
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/iso27001-agent.md +156 -156
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nis2-agent.md +72 -72
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nist-800-53-agent.md +239 -239
- package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nist-csf-agent.md +207 -207
- 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 +116 -116
- package/src/bmad-plus/packs/pack-shield/categories/defense-export/ear-agent.md +261 -261
- package/src/bmad-plus/packs/pack-shield/categories/defense-export/itar-agent.md +191 -191
- package/src/bmad-plus/packs/pack-shield/categories/defense-export/tsa-agent.md +356 -356
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/dora-agent.md +499 -499
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/fedramp-agent.md +236 -236
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/hipaa-agent.md +162 -162
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/pci-dss-agent.md +228 -228
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/soc2-agent.md +255 -255
- package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/swift-csp-agent.md +153 -153
- 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/bmad-plus-cli.js +5 -3
- package/tools/cli/commands/autoconfig.js +5 -58
- package/tools/cli/commands/doctor.js +2 -0
- package/tools/cli/commands/install.js +9 -128
- package/tools/cli/commands/memory.js +1 -0
- package/tools/cli/commands/scan.js +26 -41
- package/tools/cli/commands/uninstall.js +7 -4
- package/tools/cli/commands/update.js +2 -1
- package/tools/cli/lib/ide-config.js +259 -0
- package/tools/cli/lib/memory-init.js +0 -1
- package/tools/cli/lib/pack-copy.js +84 -84
- package/tools/cli/lib/packs.js +114 -114
- package/tools/cli/lib/stack-detect.js +102 -0
- package/tools/cli/lib/validate.js +45 -0
|
@@ -8,7 +8,6 @@
|
|
|
8
8
|
|
|
9
9
|
const path = require('node:path');
|
|
10
10
|
const fs = require('node:fs');
|
|
11
|
-
const os = require('node:os');
|
|
12
11
|
const fsExtra = require('fs-extra');
|
|
13
12
|
const clack = require('@clack/prompts');
|
|
14
13
|
const pc = require('picocolors');
|
|
@@ -16,33 +15,11 @@ const { t, getLanguageOptions, getCommLanguageOptions } = require('../i18n');
|
|
|
16
15
|
const { PACKS } = require('../lib/packs');
|
|
17
16
|
const { copyPackFiles } = require('../lib/pack-copy');
|
|
18
17
|
const { initMemory } = require('../lib/memory-init');
|
|
18
|
+
const { generateIDEConfig, IDE_CONFIGS } = require('../lib/ide-config');
|
|
19
|
+
const { validateUserName } = require('../lib/validate');
|
|
19
20
|
|
|
20
21
|
// Pack definitions are imported from the shared module: require('../lib/packs').PACKS
|
|
21
22
|
|
|
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
23
|
module.exports = {
|
|
47
24
|
command: 'install',
|
|
48
25
|
description: 'Install BMAD+ agents and skills into your project',
|
|
@@ -50,6 +27,7 @@ module.exports = {
|
|
|
50
27
|
['-d, --directory <path>', 'Installation directory (default: current directory)'],
|
|
51
28
|
['-p, --packs <packs>', 'Comma-separated pack IDs: core,osint,all (default: interactive)'],
|
|
52
29
|
['-y, --yes', 'Accept all defaults, skip prompts'],
|
|
30
|
+
['-l, --lang <code>', 'Language code: en, fr, es, de, pt-br, ru, zh, he, ja, it (overrides auto-detection)'],
|
|
53
31
|
['--tools <tools>', 'Comma-separated IDE IDs (default: auto-detect)'],
|
|
54
32
|
],
|
|
55
33
|
action: async (options) => {
|
|
@@ -61,8 +39,8 @@ module.exports = {
|
|
|
61
39
|
clack.intro(pc.bgCyan(pc.black(` BMAD+ Installer v${pkgJson.version} `)));
|
|
62
40
|
clack.log.info(pc.dim('✨ Created by Laurent Rochetta — github.com/lrochetta/BMAD-PLUS'));
|
|
63
41
|
|
|
64
|
-
let lang = 'en';
|
|
65
|
-
if (!options.yes) {
|
|
42
|
+
let lang = options.lang || 'en';
|
|
43
|
+
if (!options.yes && !options.lang) {
|
|
66
44
|
const langChoice = await clack.select({
|
|
67
45
|
message: '🌐 Select your language / Choisissez votre langue / 选择语言',
|
|
68
46
|
options: getLanguageOptions(),
|
|
@@ -200,19 +178,10 @@ module.exports = {
|
|
|
200
178
|
|
|
201
179
|
// Validate user-provided name
|
|
202
180
|
const rawName = userConfig.userName;
|
|
203
|
-
const
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
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
|
-
}
|
|
181
|
+
const fb = process.env.USER || process.env.USERNAME || 'Developer';
|
|
182
|
+
const { name: validatedName, warnings } = validateUserName(rawName, fb);
|
|
183
|
+
for (const w of warnings) clack.log.warn(w);
|
|
184
|
+
userName = validatedName;
|
|
216
185
|
commLang = userConfig.commLang;
|
|
217
186
|
}
|
|
218
187
|
|
|
@@ -441,94 +410,6 @@ module.exports = {
|
|
|
441
410
|
|
|
442
411
|
// ── Helpers ──
|
|
443
412
|
|
|
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
413
|
function generateConfigYaml(userName, language, projectDir) {
|
|
533
414
|
const projectName = path.basename(projectDir);
|
|
534
415
|
return `# BMAD+ Project Configuration
|
|
@@ -40,6 +40,7 @@ module.exports = {
|
|
|
40
40
|
description: 'Manage BMAD+ persistent brain (status, export)',
|
|
41
41
|
options: [
|
|
42
42
|
['-d, --directory <path>', 'Project directory (default: current directory)'],
|
|
43
|
+
['-l, --lang <code>', 'Language code: en, fr, es, de, pt-br, ru, zh, he, ja, it'],
|
|
43
44
|
],
|
|
44
45
|
subcommands: {
|
|
45
46
|
status: 'Show memory health report',
|
|
@@ -12,34 +12,7 @@ const os = require('node:os');
|
|
|
12
12
|
const crypto = require('node:crypto');
|
|
13
13
|
const clack = require('@clack/prompts');
|
|
14
14
|
const pc = require('picocolors');
|
|
15
|
-
|
|
16
|
-
// Project detection markers (priority order)
|
|
17
|
-
const PROJECT_MARKERS = [
|
|
18
|
-
{ file: 'package.json', stack: 'Node.js', detect: (dir) => {
|
|
19
|
-
try {
|
|
20
|
-
const pkg = JSON.parse(fs.readFileSync(path.join(dir, 'package.json'), 'utf8'));
|
|
21
|
-
const deps = { ...pkg.dependencies, ...pkg.devDependencies };
|
|
22
|
-
if (deps['next']) return 'Next.js';
|
|
23
|
-
if (deps['nuxt']) return 'Nuxt';
|
|
24
|
-
if (deps['react']) return 'React';
|
|
25
|
-
if (deps['vue']) return 'Vue.js';
|
|
26
|
-
if (deps['svelte']) return 'Svelte';
|
|
27
|
-
if (deps['express']) return 'Express';
|
|
28
|
-
if (deps['fastify']) return 'Fastify';
|
|
29
|
-
if (deps['electron']) return 'Electron';
|
|
30
|
-
if (deps['tauri']) return 'Tauri';
|
|
31
|
-
return 'Node.js';
|
|
32
|
-
} catch { return 'Node.js'; }
|
|
33
|
-
}},
|
|
34
|
-
{ file: 'Cargo.toml', stack: 'Rust' },
|
|
35
|
-
{ file: 'pyproject.toml', stack: 'Python' },
|
|
36
|
-
{ file: 'requirements.txt', stack: 'Python' },
|
|
37
|
-
{ file: 'go.mod', stack: 'Go' },
|
|
38
|
-
{ file: 'composer.json', stack: 'PHP' },
|
|
39
|
-
{ file: 'Gemfile', stack: 'Ruby' },
|
|
40
|
-
{ file: 'pom.xml', stack: 'Java' },
|
|
41
|
-
{ file: 'build.gradle', stack: 'Java/Kotlin' },
|
|
42
|
-
];
|
|
15
|
+
const { PROJECT_MARKERS } = require('../lib/stack-detect');
|
|
43
16
|
|
|
44
17
|
// Directories to skip during scanning
|
|
45
18
|
const SKIP_DIRS = new Set([
|
|
@@ -77,7 +50,9 @@ function getProjectName(dir) {
|
|
|
77
50
|
const pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf8'));
|
|
78
51
|
if (pkg.name) return pkg.name;
|
|
79
52
|
}
|
|
80
|
-
} catch {
|
|
53
|
+
} catch {
|
|
54
|
+
// Malformed/unreadable package.json; fall back to directory name.
|
|
55
|
+
}
|
|
81
56
|
return path.basename(dir);
|
|
82
57
|
}
|
|
83
58
|
|
|
@@ -168,6 +143,21 @@ function indexProject(project, globalBrainDir) {
|
|
|
168
143
|
);
|
|
169
144
|
}
|
|
170
145
|
|
|
146
|
+
/**
|
|
147
|
+
* Index multiple projects in the global brain.
|
|
148
|
+
* @param {object[]} projectList - Array of project metadata objects
|
|
149
|
+
* @param {string} brainDir - Path to the brain projects directory
|
|
150
|
+
* @returns {number} Number of projects indexed
|
|
151
|
+
*/
|
|
152
|
+
function indexProjects(projectList, brainDir) {
|
|
153
|
+
let count = 0;
|
|
154
|
+
for (const proj of projectList) {
|
|
155
|
+
indexProject(proj, brainDir);
|
|
156
|
+
count++;
|
|
157
|
+
}
|
|
158
|
+
return count;
|
|
159
|
+
}
|
|
160
|
+
|
|
171
161
|
module.exports = {
|
|
172
162
|
command: 'scan',
|
|
173
163
|
description: 'Scan directories to discover and index projects in the global brain',
|
|
@@ -177,6 +167,7 @@ module.exports = {
|
|
|
177
167
|
['--active-days <n>', 'Days since last modified to consider a project "active" (default: 30)', '30'],
|
|
178
168
|
['--paused-days <n>', 'Days since last modified to consider a project "paused" (default: 180)', '180'],
|
|
179
169
|
['-y, --yes', 'Index all projects without prompting'],
|
|
170
|
+
['-l, --lang <code>', 'Language code: en, fr, es, de, pt-br, ru, zh, he, ja, it'],
|
|
180
171
|
],
|
|
181
172
|
action: async (options) => {
|
|
182
173
|
const scanDir = path.resolve(options.directory || process.cwd());
|
|
@@ -249,11 +240,7 @@ module.exports = {
|
|
|
249
240
|
const fsExtra = require('fs-extra');
|
|
250
241
|
fsExtra.ensureDirSync(globalBrainDir);
|
|
251
242
|
|
|
252
|
-
|
|
253
|
-
for (const proj of projects) {
|
|
254
|
-
indexProject(proj, globalBrainDir);
|
|
255
|
-
indexed++;
|
|
256
|
-
}
|
|
243
|
+
const indexed = indexProjects(projects, globalBrainDir);
|
|
257
244
|
clack.log.success(`✅ ${indexed} project(s) indexed in ${globalBrainDir}`);
|
|
258
245
|
} else {
|
|
259
246
|
// Interactive mode
|
|
@@ -295,12 +282,7 @@ module.exports = {
|
|
|
295
282
|
toIndex = selected.map(i => projects[i]);
|
|
296
283
|
}
|
|
297
284
|
|
|
298
|
-
|
|
299
|
-
for (const proj of toIndex) {
|
|
300
|
-
indexProject(proj, globalBrainDir);
|
|
301
|
-
indexed++;
|
|
302
|
-
}
|
|
303
|
-
|
|
285
|
+
const indexed = indexProjects(toIndex, globalBrainDir);
|
|
304
286
|
clack.log.success(`✅ ${indexed} project(s) indexed in global brain`);
|
|
305
287
|
}
|
|
306
288
|
|
|
@@ -320,7 +302,9 @@ module.exports = {
|
|
|
320
302
|
}
|
|
321
303
|
}
|
|
322
304
|
existingProjects.push(meta);
|
|
323
|
-
} catch {
|
|
305
|
+
} catch {
|
|
306
|
+
// Skip a project entry whose index file is unreadable/corrupt.
|
|
307
|
+
}
|
|
324
308
|
}
|
|
325
309
|
}
|
|
326
310
|
|
|
@@ -358,5 +342,6 @@ module.exports = {
|
|
|
358
342
|
hasBmadInstalled,
|
|
359
343
|
scanDirectory,
|
|
360
344
|
indexProject,
|
|
345
|
+
indexProjects,
|
|
361
346
|
},
|
|
362
347
|
};
|
|
@@ -11,12 +11,15 @@ const fs = require('node:fs');
|
|
|
11
11
|
const fsExtra = require('fs-extra');
|
|
12
12
|
const clack = require('@clack/prompts');
|
|
13
13
|
const pc = require('picocolors');
|
|
14
|
-
const { t
|
|
14
|
+
const { t } = require('../i18n');
|
|
15
15
|
|
|
16
16
|
module.exports = {
|
|
17
17
|
command: 'uninstall',
|
|
18
18
|
description: 'Remove BMAD+ from your project',
|
|
19
|
-
|
|
19
|
+
options: [
|
|
20
|
+
['-l, --lang <code>', 'Language code: en, fr, es, de, pt-br, ru, zh, he, ja, it'],
|
|
21
|
+
],
|
|
22
|
+
action: async (options) => {
|
|
20
23
|
const projectDir = process.cwd();
|
|
21
24
|
|
|
22
25
|
clack.intro(pc.bgRed(pc.white(' BMAD+ Uninstaller ')));
|
|
@@ -31,8 +34,8 @@ module.exports = {
|
|
|
31
34
|
|
|
32
35
|
const manifest = JSON.parse(fs.readFileSync(manifestPath, 'utf8'));
|
|
33
36
|
|
|
34
|
-
// Use
|
|
35
|
-
let lang = manifest.uiLanguage || 'en';
|
|
37
|
+
// Use --lang flag, or fall back to manifest language
|
|
38
|
+
let lang = options.lang || manifest.uiLanguage || 'en';
|
|
36
39
|
const i = t(lang);
|
|
37
40
|
|
|
38
41
|
clack.log.info(`BMAD+ v${manifest.version} (${i.installed_on || 'installed'} ${manifest.installed.split('T')[0]})`);
|
|
@@ -21,6 +21,7 @@ module.exports = {
|
|
|
21
21
|
description: 'Update BMAD+ agents and skills (preserves config)',
|
|
22
22
|
options: [
|
|
23
23
|
['-d, --directory <path>', 'Project directory (default: current directory)'],
|
|
24
|
+
['-l, --lang <code>', 'Language code: en, fr, es, de, pt-br, ru, zh, he, ja, it'],
|
|
24
25
|
],
|
|
25
26
|
action: async (options) => {
|
|
26
27
|
const projectDir = path.resolve(options.directory || process.cwd());
|
|
@@ -39,7 +40,7 @@ module.exports = {
|
|
|
39
40
|
}
|
|
40
41
|
|
|
41
42
|
const manifest = JSON.parse(fs.readFileSync(manifestPath, 'utf8'));
|
|
42
|
-
const lang = manifest.uiLanguage || 'en';
|
|
43
|
+
const lang = options.lang || manifest.uiLanguage || 'en';
|
|
43
44
|
const i = t(lang);
|
|
44
45
|
|
|
45
46
|
clack.log.info(`📦 Installed: v${manifest.version} → Available: v${packageJson.version}`);
|
|
@@ -0,0 +1,259 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BMAD+ IDE Configuration Generator
|
|
3
|
+
* Extracted from install.js for modularity.
|
|
4
|
+
* Generates CLAUDE.md, GEMINI.md, AGENTS.md content with pack-aware agent filtering.
|
|
5
|
+
*
|
|
6
|
+
* Author: Laurent Rochetta
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
// ── IDE Configurations ──
|
|
10
|
+
|
|
11
|
+
const IDE_CONFIGS = {
|
|
12
|
+
'claude-code': {
|
|
13
|
+
name: 'Claude Code',
|
|
14
|
+
detect: ['.claude'],
|
|
15
|
+
configFile: 'CLAUDE.md',
|
|
16
|
+
},
|
|
17
|
+
'gemini-cli': {
|
|
18
|
+
name: 'Gemini CLI',
|
|
19
|
+
detect: ['.gemini'],
|
|
20
|
+
configFile: 'GEMINI.md',
|
|
21
|
+
},
|
|
22
|
+
'codex-cli': {
|
|
23
|
+
name: 'Codex CLI / OpenCode',
|
|
24
|
+
detect: ['.codex', '.opencode'],
|
|
25
|
+
configFile: 'AGENTS.md',
|
|
26
|
+
},
|
|
27
|
+
'antigravity': {
|
|
28
|
+
name: 'Antigravity',
|
|
29
|
+
detect: ['.gemini/antigravity'],
|
|
30
|
+
configFile: 'GEMINI.md',
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
// All 14 BMAD+ agents — always included in templates
|
|
35
|
+
const AGENT_LIST = [
|
|
36
|
+
'- **Atlas** (Strategist) — Business analysis + Product management',
|
|
37
|
+
'- **Forge** (Architect-Dev) — Architecture + Development + Documentation',
|
|
38
|
+
'- **Sentinel** (Quality) — QA + UX review',
|
|
39
|
+
'- **Nexus** (Orchestrator) — Sprint management + Autopilot + Parallel execution',
|
|
40
|
+
'- **Shadow** (OSINT) — Investigation + Scraping + Psychoprofiling',
|
|
41
|
+
'- **Shield** (GRC) — 38 compliance agents (GDPR, ISO 27001, SOC 2, HIPAA, EU AI Act, DORA, NIS2...)',
|
|
42
|
+
'- **Miriam** (מרים) — Business Analyst — Strategic analysis, research, product briefs',
|
|
43
|
+
'- **Huldah** (חולדה) — Technical Writer — Documentation, diagrams, editorial review',
|
|
44
|
+
'- **Yosef** (יוסף) — Product Manager — PRD, requirements, feature prioritization',
|
|
45
|
+
'- **Rachel** (רחל) — UX Designer — User experience, wireframes, empathy mapping',
|
|
46
|
+
'- **Bezalel** (בצלאל) — System Architect — Architecture, ADRs, epics & stories',
|
|
47
|
+
'- **Oholiab** (אהליאב) — Senior Engineer — TDD, sprint, code review, implementation',
|
|
48
|
+
'- **Zecher** (זכר) — Memory Archivist — Consolidation, project scanning, context recall',
|
|
49
|
+
'- **Maker** (Creator) — Custom agent builder — Create new agents from description',
|
|
50
|
+
];
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* Filter agents based on installed packs.
|
|
54
|
+
* Core agents are always included; others depend on pack selection.
|
|
55
|
+
*
|
|
56
|
+
* @param {string[]} packs - List of installed pack IDs
|
|
57
|
+
* @returns {string[]} Agent description lines
|
|
58
|
+
*/
|
|
59
|
+
function getAgentsByPacks(packs) {
|
|
60
|
+
const agents = [
|
|
61
|
+
'- **Atlas** (Strategist) — Business analysis + Product management',
|
|
62
|
+
'- **Forge** (Architect-Dev) — Architecture + Development + Documentation',
|
|
63
|
+
'- **Sentinel** (Quality) — QA + UX review',
|
|
64
|
+
'- **Nexus** (Orchestrator) — Sprint management + Autopilot + Parallel execution',
|
|
65
|
+
];
|
|
66
|
+
|
|
67
|
+
if (packs.includes('osint')) {
|
|
68
|
+
agents.push('- **Shadow** (OSINT) — Investigation + Scraping + Psychoprofiling');
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
if (packs.includes('shield')) {
|
|
72
|
+
agents.push('- **Shield** (GRC) — 38 compliance agents (GDPR, ISO 27001, SOC 2, HIPAA, EU AI Act, DORA, NIS2...)');
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
if (packs.includes('maker')) {
|
|
76
|
+
agents.push('- **Maker** (Creator) — Custom agent builder — Create new agents from description');
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
if (packs.includes('dev-studio')) {
|
|
80
|
+
agents.push('- **Miriam** (מרים) — Business Analyst — Strategic analysis, research, product briefs');
|
|
81
|
+
agents.push('- **Huldah** (חולדה) — Technical Writer — Documentation, diagrams, editorial review');
|
|
82
|
+
agents.push('- **Yosef** (יוסף) — Product Manager — PRD, requirements, feature prioritization');
|
|
83
|
+
agents.push('- **Rachel** (רחל) — UX Designer — User experience, wireframes, empathy mapping');
|
|
84
|
+
agents.push('- **Bezalel** (בצלאל) — System Architecture — Architecture, ADRs, epics & stories');
|
|
85
|
+
agents.push('- **Oholiab** (אהליאב) — Senior Engineer — TDD, sprint, code review, implementation');
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
if (packs.includes('memory')) {
|
|
89
|
+
agents.push('- **Zecher** (זכר) — Memory Archivist — Consolidation, project scanning, context recall');
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
return agents;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Build the Memory Protocol section if the memory pack is installed.
|
|
97
|
+
*
|
|
98
|
+
* @param {string[]} packs - List of installed pack IDs
|
|
99
|
+
* @returns {string} Memory section markdown (empty string if no memory pack)
|
|
100
|
+
*/
|
|
101
|
+
function getMemorySection(packs) {
|
|
102
|
+
if (!packs.includes('memory')) return '';
|
|
103
|
+
return [
|
|
104
|
+
'',
|
|
105
|
+
'## Memory Protocol (Karpathy Guardrails)',
|
|
106
|
+
'',
|
|
107
|
+
'Agents MUST follow these behavioral principles:',
|
|
108
|
+
'',
|
|
109
|
+
'### G1 — Think Before Coding',
|
|
110
|
+
'- State assumptions explicitly. If uncertain, ask.',
|
|
111
|
+
'- Check `.agents/memory/decisions.md` for prior decisions before re-deciding.',
|
|
112
|
+
'',
|
|
113
|
+
'### G2 — Simplicity First',
|
|
114
|
+
'- Minimum code that solves the problem. Nothing speculative.',
|
|
115
|
+
'- Check `.agents/memory/patterns.md` for existing solutions.',
|
|
116
|
+
'',
|
|
117
|
+
'### G3 — Surgical Changes',
|
|
118
|
+
'- Touch only what you must. Match existing style.',
|
|
119
|
+
'- Log surprises in `.agents/memory/lessons.md`.',
|
|
120
|
+
'',
|
|
121
|
+
'### G4 — Goal-Driven Execution',
|
|
122
|
+
'- Define success criteria before implementing.',
|
|
123
|
+
'- Log non-obvious decisions in `.agents/memory/decisions.md`.',
|
|
124
|
+
'',
|
|
125
|
+
'### Memory Files',
|
|
126
|
+
'- `.agents/memory/decisions.md` — Read at session start, write when making decisions',
|
|
127
|
+
'- `.agents/memory/lessons.md` — Write when something unexpected happens',
|
|
128
|
+
'- `.agents/memory/patterns.md` — Write when a reusable pattern is validated',
|
|
129
|
+
'- `.agents/memory/context.md` — Update at session end with project state',
|
|
130
|
+
].join('\n');
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
/**
|
|
134
|
+
* Generate IDE config content with pack-aware agent filtering.
|
|
135
|
+
*
|
|
136
|
+
* @param {string} userName - The user's display name
|
|
137
|
+
* @param {string} language - User-facing communication language
|
|
138
|
+
* @param {string[]} packs - List of installed pack IDs
|
|
139
|
+
* @returns {string} Complete Markdown template
|
|
140
|
+
*/
|
|
141
|
+
function generateIDEConfig(userName, language, packs) {
|
|
142
|
+
const agents = getAgentsByPacks(packs);
|
|
143
|
+
const memorySection = getMemorySection(packs);
|
|
144
|
+
|
|
145
|
+
return `# BMAD+ — AI Agent Configuration
|
|
146
|
+
|
|
147
|
+
## Project Context
|
|
148
|
+
This project uses BMAD+, an augmented AI-driven development framework.
|
|
149
|
+
Based on BMAD-METHOD v6.6.0 with multi-role agents, autopilot mode, and parallel execution.
|
|
150
|
+
|
|
151
|
+
## Agents
|
|
152
|
+
To activate an agent, say its name or persona:
|
|
153
|
+
${agents.join('\n')}
|
|
154
|
+
|
|
155
|
+
## Skills
|
|
156
|
+
- Load skills from \`.agents/skills/\`
|
|
157
|
+
- Each agent has a SKILL.md with capabilities, activation protocol, and role-switching rules
|
|
158
|
+
- Auto-activation triggers: \`.agents/data/role-triggers.yaml\`
|
|
159
|
+
|
|
160
|
+
## Key Commands
|
|
161
|
+
- \`bmad-help\` — Show all available agents and skills
|
|
162
|
+
- \`autopilot\` — Launch Nexus in full pipeline mode
|
|
163
|
+
- \`parallel\` — Enable parallel multi-agent execution
|
|
164
|
+
|
|
165
|
+
## Communication
|
|
166
|
+
- User name: ${userName}
|
|
167
|
+
- Default language: ${language} for user-facing content, English for code and technical docs.
|
|
168
|
+
${memorySection}`;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
/**
|
|
172
|
+
* Generate a complete CLAUDE.md / GEMINI.md / AGENTS.md config file
|
|
173
|
+
* (all agents, no filtering — backward compatible)
|
|
174
|
+
*
|
|
175
|
+
* @param {string} userName - The user's display name
|
|
176
|
+
* @param {string} language - User-facing communication language
|
|
177
|
+
* @returns {string} Complete Markdown template
|
|
178
|
+
*/
|
|
179
|
+
function generateBaseConfig(userName, language) {
|
|
180
|
+
return `# BMAD+ — AI Agent Configuration
|
|
181
|
+
|
|
182
|
+
## Project Context
|
|
183
|
+
This project uses BMAD+, an augmented AI-driven development framework.
|
|
184
|
+
Based on BMAD-METHOD v6.6.0 with multi-role agents, autopilot mode, and parallel execution.
|
|
185
|
+
|
|
186
|
+
## Agents
|
|
187
|
+
To activate an agent, say its name or persona:
|
|
188
|
+
${AGENT_LIST.join('\n')}
|
|
189
|
+
|
|
190
|
+
## Skills
|
|
191
|
+
- Load skills from \`.agents/skills/\`
|
|
192
|
+
- Each agent has a SKILL.md with capabilities, activation protocol, and role-switching rules
|
|
193
|
+
- Auto-activation triggers: \`.agents/data/role-triggers.yaml\`
|
|
194
|
+
|
|
195
|
+
## Key Commands
|
|
196
|
+
- \`bmad-help\` — Show all available agents and skills
|
|
197
|
+
- \`autopilot\` — Launch Nexus in full pipeline mode
|
|
198
|
+
- \`parallel\` — Enable parallel multi-agent execution
|
|
199
|
+
|
|
200
|
+
## Communication
|
|
201
|
+
- User name: ${userName}
|
|
202
|
+
- Default language: ${language} for user-facing content, English for code and technical docs.
|
|
203
|
+
|
|
204
|
+
## Memory Protocol (Karpathy Guardrails)
|
|
205
|
+
|
|
206
|
+
Agents MUST follow these behavioral principles:
|
|
207
|
+
|
|
208
|
+
### G1 — Think Before Coding
|
|
209
|
+
- State assumptions explicitly. If uncertain, ask.
|
|
210
|
+
- Check \`.agents/memory/decisions.md\` for prior decisions before re-deciding.
|
|
211
|
+
|
|
212
|
+
### G2 — Simplicity First
|
|
213
|
+
- Minimum code that solves the problem. Nothing speculative.
|
|
214
|
+
- Check \`.agents/memory/patterns.md\` for existing solutions.
|
|
215
|
+
|
|
216
|
+
### G3 — Surgical Changes
|
|
217
|
+
- Touch only what you must. Match existing style.
|
|
218
|
+
- Log surprises in \`.agents/memory/lessons.md\`.
|
|
219
|
+
|
|
220
|
+
### G4 — Goal-Driven Execution
|
|
221
|
+
- Define success criteria before implementing.
|
|
222
|
+
- Log non-obvious decisions in \`.agents/memory/decisions.md\`.
|
|
223
|
+
|
|
224
|
+
### Memory Files
|
|
225
|
+
- \`.agents/memory/decisions.md\` — Read at session start, write when making decisions
|
|
226
|
+
- \`.agents/memory/lessons.md\` — Write when something unexpected happens
|
|
227
|
+
- \`.agents/memory/patterns.md\` — Write when a reusable pattern is validated
|
|
228
|
+
- \`.agents/memory/context.md\` — Update at session end with project state`;
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
module.exports = {
|
|
232
|
+
IDE_CONFIGS,
|
|
233
|
+
generateIDEConfig,
|
|
234
|
+
getAgentsByPacks,
|
|
235
|
+
|
|
236
|
+
/**
|
|
237
|
+
* Generate CLAUDE.md config for Claude Code
|
|
238
|
+
* @param {string} userName
|
|
239
|
+
* @param {string} language
|
|
240
|
+
* @returns {string}
|
|
241
|
+
*/
|
|
242
|
+
generateClaudeMD: generateBaseConfig,
|
|
243
|
+
|
|
244
|
+
/**
|
|
245
|
+
* Generate GEMINI.md config for Gemini CLI / Antigravity
|
|
246
|
+
* @param {string} userName
|
|
247
|
+
* @param {string} language
|
|
248
|
+
* @returns {string}
|
|
249
|
+
*/
|
|
250
|
+
generateGeminiMD: generateBaseConfig,
|
|
251
|
+
|
|
252
|
+
/**
|
|
253
|
+
* Generate AGENTS.md config for Codex CLI / OpenCode
|
|
254
|
+
* @param {string} userName
|
|
255
|
+
* @param {string} language
|
|
256
|
+
* @returns {string}
|
|
257
|
+
*/
|
|
258
|
+
generateAgentsMD: generateBaseConfig,
|
|
259
|
+
};
|
|
@@ -10,7 +10,6 @@ const fs = require('node:fs');
|
|
|
10
10
|
const os = require('node:os');
|
|
11
11
|
const fsExtra = require('fs-extra');
|
|
12
12
|
const clack = require('@clack/prompts');
|
|
13
|
-
const pc = require('picocolors');
|
|
14
13
|
|
|
15
14
|
/**
|
|
16
15
|
* Initialize the memory pack: create project memory files, detect or create global brain.
|