bmad-plus 0.7.5 → 0.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (281) hide show
  1. package/CHANGELOG.md +479 -425
  2. package/LICENSE +21 -21
  3. package/README.md +557 -447
  4. package/osint-agent-package/README.md +88 -88
  5. package/osint-agent-package/SETUP_KEYS.md +108 -108
  6. package/osint-agent-package/agents/osint-investigator.md +80 -80
  7. package/osint-agent-package/install.ps1 +87 -87
  8. package/osint-agent-package/install.sh +76 -76
  9. package/osint-agent-package/skills/bmad-osint-investigate/SKILL.md +147 -147
  10. package/osint-agent-package/skills/bmad-osint-investigate/osint/SKILL.md +452 -452
  11. package/osint-agent-package/skills/bmad-osint-investigate/osint/assets/dossier-template.md +116 -116
  12. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/content-extraction.md +100 -100
  13. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/enrichment-databases-fr.md +148 -148
  14. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/platforms.md +130 -130
  15. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/psychoprofile.md +69 -69
  16. package/osint-agent-package/skills/bmad-osint-investigate/osint/references/tools.md +281 -281
  17. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/_http.py +101 -101
  18. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/apify.py +266 -260
  19. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/brightdata.py +101 -101
  20. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/diagnose.py +141 -141
  21. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/exa.py +79 -79
  22. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/jina.py +71 -71
  23. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/mcp-client.py +136 -136
  24. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/parallel.py +85 -85
  25. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/perplexity.py +102 -102
  26. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/tavily.py +72 -72
  27. package/osint-agent-package/skills/bmad-osint-investigate/osint/scripts/volley.py +208 -208
  28. package/osint-agent-package/skills/bmad-osint-investigator/SKILL.md +15 -15
  29. package/package.json +62 -57
  30. package/readme-international/README.de.md +584 -426
  31. package/readme-international/README.es.md +601 -518
  32. package/readme-international/README.fr.md +599 -516
  33. package/src/bmad-plus/agents/agent-architect-dev/SKILL.md +96 -96
  34. package/src/bmad-plus/agents/agent-architect-dev/bmad-skill-manifest.yaml +13 -13
  35. package/src/bmad-plus/agents/agent-maker/SKILL.md +201 -201
  36. package/src/bmad-plus/agents/agent-maker/bmad-skill-manifest.yaml +13 -13
  37. package/src/bmad-plus/agents/agent-orchestrator/SKILL.md +137 -137
  38. package/src/bmad-plus/agents/agent-orchestrator/bmad-skill-manifest.yaml +13 -13
  39. package/src/bmad-plus/agents/agent-quality/SKILL.md +83 -83
  40. package/src/bmad-plus/agents/agent-quality/bmad-skill-manifest.yaml +13 -13
  41. package/src/bmad-plus/agents/agent-shadow/SKILL.md +71 -71
  42. package/src/bmad-plus/agents/agent-shadow/bmad-skill-manifest.yaml +13 -13
  43. package/src/bmad-plus/agents/agent-strategist/SKILL.md +80 -80
  44. package/src/bmad-plus/agents/agent-strategist/bmad-skill-manifest.yaml +13 -13
  45. package/src/bmad-plus/data/role-triggers.yaml +209 -209
  46. package/src/bmad-plus/module-help.csv +10 -10
  47. package/src/bmad-plus/module.yaml +283 -280
  48. package/src/bmad-plus/{agents → packs}/pack-animated/animated-website-agent.md +325 -325
  49. package/src/bmad-plus/{agents → packs}/pack-animated/templates/animated-website-workflow.md +55 -55
  50. package/src/bmad-plus/{agents → packs}/pack-backup/backup-agent.md +71 -71
  51. package/src/bmad-plus/{agents → packs}/pack-backup/templates/backup-workflow.md +51 -51
  52. package/src/bmad-plus/packs/pack-dev-studio/README.md +162 -162
  53. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/analyst-agent.md +73 -73
  54. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/document-project.md +61 -61
  55. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/domain-research.md +95 -95
  56. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/market-research.md +95 -95
  57. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/prfaq.md +134 -134
  58. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/product-brief.md +80 -80
  59. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/tech-writer-agent.md +73 -73
  60. package/src/bmad-plus/packs/pack-dev-studio/categories/analysis/technical-research.md +95 -95
  61. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/architect-agent.md +73 -73
  62. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/create-architecture.md +73 -73
  63. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/create-epics-stories.md +92 -92
  64. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/generate-project-context.md +80 -80
  65. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/implementation-readiness.md +90 -90
  66. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-01-init.md +153 -153
  67. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-01b-continue.md +173 -173
  68. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-02-context.md +224 -224
  69. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-03-starter.md +329 -329
  70. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-04-decisions.md +318 -318
  71. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-05-patterns.md +359 -359
  72. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-06-structure.md +379 -379
  73. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-07-validation.md +361 -361
  74. package/src/bmad-plus/packs/pack-dev-studio/categories/architecture/steps/step-08-complete.md +81 -81
  75. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/checkpoint-preview.md +67 -67
  76. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-01-gather-context.md +85 -85
  77. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-02-review.md +35 -35
  78. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-03-triage.md +49 -49
  79. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review-steps/step-04-present.md +131 -131
  80. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/code-review.md +89 -89
  81. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/correct-course.md +300 -300
  82. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/create-story.md +428 -428
  83. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-agent.md +73 -73
  84. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-story-checklist.md +80 -80
  85. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/dev-story.md +484 -484
  86. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/investigate.md +193 -193
  87. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/qa-e2e-tests.md +175 -175
  88. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/quick-dev.md +110 -110
  89. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/retrospective.md +1511 -1511
  90. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/sprint-planning.md +298 -298
  91. package/src/bmad-plus/packs/pack-dev-studio/categories/implementation/sprint-status.md +296 -296
  92. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/create-prd.md +29 -29
  93. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/create-ux-design.md +74 -74
  94. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/edit-prd.md +29 -29
  95. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/pm-agent.md +73 -73
  96. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/prd.md +89 -89
  97. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/ux-designer-agent.md +73 -73
  98. package/src/bmad-plus/packs/pack-dev-studio/categories/planning/validate-prd.md +29 -29
  99. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/advanced-elicitation.md +141 -141
  100. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/adversarial-review.md +37 -37
  101. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/bmad-help.md +75 -75
  102. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/brainstorming.md +6 -6
  103. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/customize.md +110 -110
  104. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/distillator.md +176 -176
  105. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/edge-case-hunter.md +67 -67
  106. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/editorial-review-prose.md +86 -86
  107. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/editorial-review-structure.md +179 -179
  108. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/index-docs.md +66 -66
  109. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/party-mode.md +127 -127
  110. package/src/bmad-plus/packs/pack-dev-studio/categories/utilities/shard-doc.md +105 -105
  111. package/src/bmad-plus/packs/pack-dev-studio/dev-studio-orchestrator.md +120 -120
  112. package/src/bmad-plus/packs/pack-dev-studio/shared/architecture-decision-template.md +12 -12
  113. package/src/bmad-plus/packs/pack-dev-studio/shared/bwml-spec.md +328 -328
  114. package/src/bmad-plus/packs/pack-dev-studio/shared/module-help.csv +32 -32
  115. package/src/bmad-plus/packs/pack-dev-studio/upstream-sync.yaml +81 -81
  116. package/src/bmad-plus/packs/pack-memory/README.md +106 -106
  117. package/src/bmad-plus/packs/pack-memory/memory-orchestrator.md +79 -79
  118. package/src/bmad-plus/packs/pack-memory/shared/karpathy-guardrails.md +86 -86
  119. package/src/bmad-plus/packs/pack-memory/shared/memory-protocol.md +143 -143
  120. package/src/bmad-plus/packs/pack-memory/templates/context.md +39 -39
  121. package/src/bmad-plus/packs/pack-memory/templates/decisions.md +25 -25
  122. package/src/bmad-plus/packs/pack-memory/templates/identity.yaml +39 -39
  123. package/src/bmad-plus/packs/pack-memory/templates/lessons.md +31 -31
  124. package/src/bmad-plus/packs/pack-memory/templates/patterns.md +24 -24
  125. package/src/bmad-plus/packs/pack-memory/templates/session-handoff.md +25 -25
  126. package/src/bmad-plus/packs/pack-memory/zecher-agent.md +157 -157
  127. package/src/bmad-plus/{agents → packs}/pack-seo/SKILL.md +171 -171
  128. package/src/bmad-plus/packs/pack-seo/bmad-skill-manifest.yaml +13 -0
  129. package/src/bmad-plus/{agents → packs}/pack-seo/checklist.md +140 -140
  130. package/src/bmad-plus/{agents → packs}/pack-seo/pagespeed-playbook.md +320 -320
  131. package/src/bmad-plus/{agents → packs}/pack-seo/ref/audit-schema.json +187 -187
  132. package/src/bmad-plus/{agents → packs}/pack-seo/ref/cwv-thresholds.md +87 -87
  133. package/src/bmad-plus/{agents → packs}/pack-seo/ref/eeat-criteria.md +123 -123
  134. package/src/bmad-plus/{agents → packs}/pack-seo/ref/geo-signals.md +167 -167
  135. package/src/bmad-plus/{agents → packs}/pack-seo/ref/hreflang-rules.md +153 -153
  136. package/src/bmad-plus/{agents → packs}/pack-seo/ref/quality-gates.md +133 -133
  137. package/src/bmad-plus/{agents → packs}/pack-seo/ref/schema-catalog.md +91 -91
  138. package/src/bmad-plus/{agents → packs}/pack-seo/ref/schema-templates.json +356 -356
  139. package/src/bmad-plus/{agents → packs}/pack-seo/seo-chief.md +294 -294
  140. package/src/bmad-plus/{agents → packs}/pack-seo/seo-judge.md +241 -241
  141. package/src/bmad-plus/{agents → packs}/pack-seo/seo-scout.md +171 -171
  142. package/src/bmad-plus/{agents → packs}/pack-seo/templates/seo-audit-workflow.md +241 -241
  143. package/src/bmad-plus/packs/pack-shield/README.md +110 -110
  144. package/src/bmad-plus/packs/pack-shield/SKILL.md +82 -0
  145. package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/csrd-agent.md +262 -262
  146. package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/section508-agent.md +179 -179
  147. package/src/bmad-plus/packs/pack-shield/categories/accessibility-esg/wcag-agent.md +201 -201
  148. package/src/bmad-plus/packs/pack-shield/categories/ai-governance/eu-ai-act-agent.md +97 -97
  149. package/src/bmad-plus/packs/pack-shield/categories/ai-governance/iso42001-agent.md +251 -251
  150. package/src/bmad-plus/packs/pack-shield/categories/ai-governance/nist-ai-rmf-agent.md +133 -133
  151. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/cis-controls-agent.md +221 -221
  152. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/ism-agent.md +150 -150
  153. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/iso27001-agent.md +167 -167
  154. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nis2-agent.md +83 -83
  155. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nist-800-53-agent.md +250 -250
  156. package/src/bmad-plus/packs/pack-shield/categories/cybersecurity/nist-csf-agent.md +218 -218
  157. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/ccpa-agent.md +94 -94
  158. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/dpdpa-agent.md +136 -136
  159. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/gdpr-agent.md +296 -296
  160. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/iso27701-agent.md +134 -134
  161. package/src/bmad-plus/packs/pack-shield/categories/data-privacy/lgpd-agent.md +129 -129
  162. package/src/bmad-plus/packs/pack-shield/categories/defense-export/cmmc-agent.md +127 -127
  163. package/src/bmad-plus/packs/pack-shield/categories/defense-export/ear-agent.md +272 -272
  164. package/src/bmad-plus/packs/pack-shield/categories/defense-export/itar-agent.md +202 -202
  165. package/src/bmad-plus/packs/pack-shield/categories/defense-export/tsa-agent.md +367 -367
  166. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/dora-agent.md +510 -510
  167. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/fedramp-agent.md +247 -247
  168. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/hipaa-agent.md +173 -173
  169. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/pci-dss-agent.md +239 -239
  170. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/soc2-agent.md +266 -266
  171. package/src/bmad-plus/packs/pack-shield/categories/industry-compliance/swift-csp-agent.md +164 -164
  172. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-classifier.md +131 -131
  173. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-fria.md +155 -155
  174. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-incidents.md +187 -187
  175. package/src/bmad-plus/packs/pack-shield/categories/workflows/ai-act-roles.md +113 -113
  176. package/src/bmad-plus/packs/pack-shield/categories/workflows/breach-sentinel.md +197 -197
  177. package/src/bmad-plus/packs/pack-shield/categories/workflows/cookie-policy-gen.md +180 -180
  178. package/src/bmad-plus/packs/pack-shield/categories/workflows/dpia-sentinel.md +235 -235
  179. package/src/bmad-plus/packs/pack-shield/categories/workflows/legitimate-interest.md +159 -159
  180. package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-advisor.md +133 -133
  181. package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-notice-gen.md +160 -160
  182. package/src/bmad-plus/packs/pack-shield/categories/workflows/privacy-policy-gen.md +135 -135
  183. package/src/bmad-plus/packs/pack-shield/references/ccpa/ccpa-gdpr-comparison.md +117 -117
  184. package/src/bmad-plus/packs/pack-shield/references/ccpa/consumer-rights-workflows.md +177 -177
  185. package/src/bmad-plus/packs/pack-shield/references/cis-controls/framework-mappings.md +162 -162
  186. package/src/bmad-plus/packs/pack-shield/references/cis-controls/implementation-guidance.md +235 -235
  187. package/src/bmad-plus/packs/pack-shield/references/cis-controls/safeguards-detail.md +252 -252
  188. package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-assessment.md +170 -170
  189. package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-levels.md +113 -113
  190. package/src/bmad-plus/packs/pack-shield/references/cmmc/cmmc-practices.md +211 -211
  191. package/src/bmad-plus/packs/pack-shield/references/csrd/compliance-program.md +281 -281
  192. package/src/bmad-plus/packs/pack-shield/references/csrd/double-materiality.md +253 -253
  193. package/src/bmad-plus/packs/pack-shield/references/csrd/esrs-standards.md +401 -401
  194. package/src/bmad-plus/packs/pack-shield/references/dora/article-reference.md +441 -441
  195. package/src/bmad-plus/packs/pack-shield/references/dora/incident-classification.md +297 -297
  196. package/src/bmad-plus/packs/pack-shield/references/dora/rts-its-guide.md +306 -306
  197. package/src/bmad-plus/packs/pack-shield/references/dora/third-party-risk.md +349 -349
  198. package/src/bmad-plus/packs/pack-shield/references/dpdpa/gdpr-comparison.md +173 -173
  199. package/src/bmad-plus/packs/pack-shield/references/dpdpa/rights-and-obligations.md +426 -426
  200. package/src/bmad-plus/packs/pack-shield/references/dpdpa/rules-2025.md +599 -599
  201. package/src/bmad-plus/packs/pack-shield/references/dpdpa/sections-reference.md +319 -319
  202. package/src/bmad-plus/packs/pack-shield/references/ear/ccl-eccn-guide.md +250 -250
  203. package/src/bmad-plus/packs/pack-shield/references/ear/compliance-program.md +280 -280
  204. package/src/bmad-plus/packs/pack-shield/references/ear/license-exceptions.md +207 -207
  205. package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/gpai-governance.md +267 -267
  206. package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/obligations-high-risk.md +287 -287
  207. package/src/bmad-plus/packs/pack-shield/references/eu-ai-act/risk-classification.md +182 -182
  208. package/src/bmad-plus/packs/pack-shield/references/fedramp/appendices-guide.md +209 -209
  209. package/src/bmad-plus/packs/pack-shield/references/fedramp/control-families.md +281 -281
  210. package/src/bmad-plus/packs/pack-shield/references/fedramp/poam-guide.md +93 -93
  211. package/src/bmad-plus/packs/pack-shield/references/fedramp/readiness-checklist.md +134 -134
  212. package/src/bmad-plus/packs/pack-shield/references/fedramp/sap-sar-guide.md +86 -86
  213. package/src/bmad-plus/packs/pack-shield/references/fedramp/ssp-guide.md +129 -129
  214. package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/documents.md +192 -192
  215. package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/dpa-template.md +121 -121
  216. package/src/bmad-plus/packs/pack-shield/references/gdpr-compliance/privacy-notice.md +87 -87
  217. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/breach-notification.md +293 -293
  218. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/privacy-rule.md +276 -276
  219. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/security-rule.md +299 -299
  220. package/src/bmad-plus/packs/pack-shield/references/hipaa-compliance/templates.md +568 -568
  221. package/src/bmad-plus/packs/pack-shield/references/ism/control-applicability.md +181 -181
  222. package/src/bmad-plus/packs/pack-shield/references/ism/guidelines-overview.md +183 -183
  223. package/src/bmad-plus/packs/pack-shield/references/iso27001/annex-a-2013.md +203 -203
  224. package/src/bmad-plus/packs/pack-shield/references/iso27001/annex-a-2022.md +132 -132
  225. package/src/bmad-plus/packs/pack-shield/references/iso27001/control-mapping.md +153 -153
  226. package/src/bmad-plus/packs/pack-shield/references/iso27701/annex-a-controls.md +195 -195
  227. package/src/bmad-plus/packs/pack-shield/references/iso27701/regulatory-mapping.md +229 -229
  228. package/src/bmad-plus/packs/pack-shield/references/iso27701/transition-guide.md +219 -219
  229. package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-ai-risk-assessment.md +258 -258
  230. package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-clauses-requirements.md +279 -279
  231. package/src/bmad-plus/packs/pack-shield/references/iso42001/iso42001-controls-annex-a.md +155 -155
  232. package/src/bmad-plus/packs/pack-shield/references/itar/compliance-program.md +174 -174
  233. package/src/bmad-plus/packs/pack-shield/references/itar/licensing-guide.md +146 -146
  234. package/src/bmad-plus/packs/pack-shield/references/itar/usml-categories.md +93 -93
  235. package/src/bmad-plus/packs/pack-shield/references/lgpd/anpd-enforcement.md +147 -147
  236. package/src/bmad-plus/packs/pack-shield/references/lgpd/compliance-program.md +272 -272
  237. package/src/bmad-plus/packs/pack-shield/references/lgpd/lgpd-articles.md +271 -271
  238. package/src/bmad-plus/packs/pack-shield/references/nis2/article-21-measures.md +153 -153
  239. package/src/bmad-plus/packs/pack-shield/references/nis2/iso27001-nis2-mapping.md +68 -68
  240. package/src/bmad-plus/packs/pack-shield/references/nist-800-53/assessment-rmf.md +349 -349
  241. package/src/bmad-plus/packs/pack-shield/references/nist-800-53/baselines-tailoring.md +277 -277
  242. package/src/bmad-plus/packs/pack-shield/references/nist-800-53/control-families.md +450 -450
  243. package/src/bmad-plus/packs/pack-shield/references/nist-ai-rmf/rmf-core.md +361 -361
  244. package/src/bmad-plus/packs/pack-shield/references/nist-ai-rmf/rmf-profiles.md +192 -192
  245. package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-10-to-20-mapping.md +143 -143
  246. package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-20-functions-categories.md +278 -278
  247. package/src/bmad-plus/packs/pack-shield/references/nist-csf/csf-implementation-tiers.md +135 -135
  248. package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-requirements.md +366 -366
  249. package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-saq-guide.md +217 -217
  250. package/src/bmad-plus/packs/pack-shield/references/pci-compliance/pci-dss-v4-changes.md +190 -190
  251. package/src/bmad-plus/packs/pack-shield/references/section-508/wcag-mapping.md +160 -160
  252. package/src/bmad-plus/packs/pack-shield/references/soc2/controls.md +241 -241
  253. package/src/bmad-plus/packs/pack-shield/references/soc2/evidence.md +236 -236
  254. package/src/bmad-plus/packs/pack-shield/references/soc2/policies.md +254 -254
  255. package/src/bmad-plus/packs/pack-shield/references/soc2/vendor.md +276 -276
  256. package/src/bmad-plus/packs/pack-shield/references/swift-csp/swift-assessment.md +202 -202
  257. package/src/bmad-plus/packs/pack-shield/references/swift-csp/swift-controls.md +545 -545
  258. package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-crmp-requirements.md +359 -359
  259. package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-directives-overview.md +187 -187
  260. package/src/bmad-plus/packs/pack-shield/references/tsa-compliance/tsa-incident-reporting.md +187 -187
  261. package/src/bmad-plus/packs/pack-shield/references/wcag/criteria-detail.md +510 -510
  262. package/src/bmad-plus/packs/pack-shield/shared/audit-report-template.md +103 -103
  263. package/src/bmad-plus/packs/pack-shield/shared/cross-framework-mapper.md +103 -103
  264. package/src/bmad-plus/packs/pack-shield/shared/gap-analysis-template.md +83 -83
  265. package/src/bmad-plus/packs/pack-shield/shield-orchestrator.md +229 -229
  266. package/src/bmad-plus/packs/pack-shield/upstream-sync.yaml +68 -68
  267. package/src/bmad-plus/skills/bmad-plus-autopilot/SKILL.md +99 -99
  268. package/src/bmad-plus/skills/bmad-plus-parallel/SKILL.md +93 -93
  269. package/src/bmad-plus/skills/bmad-plus-sync/SKILL.md +69 -69
  270. package/tools/bmad-plus-npx.js +3 -5
  271. package/tools/cli/commands/autoconfig.js +508 -489
  272. package/tools/cli/commands/doctor.js +219 -222
  273. package/tools/cli/commands/install.js +548 -739
  274. package/tools/cli/commands/memory.js +194 -194
  275. package/tools/cli/commands/scan.js +362 -350
  276. package/tools/cli/commands/uninstall.js +96 -96
  277. package/tools/cli/commands/update.js +116 -174
  278. package/tools/cli/i18n.js +845 -763
  279. package/tools/cli/lib/memory-init.js +114 -0
  280. package/tools/cli/lib/pack-copy.js +84 -0
  281. package/tools/cli/lib/packs.js +114 -0
@@ -1,429 +1,429 @@
1
- ---
2
- name: bmad-create-story
3
- description: 'Creates a dedicated story file with all the context the agent will need to implement it later. Use when the user says "create the next story" or "create story [story identifier]"'
4
- ---
5
-
6
- # Create Story Workflow
7
-
8
- **Goal:** Create a comprehensive story file that gives the dev agent everything needed for flawless implementation.
9
-
10
- **Your Role:** Story context engine that prevents LLM developer mistakes, omissions, or disasters.
11
- - Communicate all responses in {communication_language} and generate all documents in {document_output_language}
12
- - Your purpose is NOT to copy from epics - it's to create a comprehensive, optimized story file that gives the DEV agent EVERYTHING needed for flawless implementation
13
- - COMMON LLM MISTAKES TO PREVENT: reinventing wheels, wrong libraries, wrong file locations, breaking regressions, ignoring UX, vague implementations, lying about completion, not learning from past work
14
- - EXHAUSTIVE ANALYSIS REQUIRED: You must thoroughly analyze ALL artifacts to extract critical context - do NOT be lazy or skim! This is the most important function in the entire development process!
15
- - UTILIZE SUBPROCESSES AND SUBAGENTS: Use research subagents, subprocesses or parallel processing if available to thoroughly analyze different artifacts simultaneously and thoroughly
16
- - SAVE QUESTIONS: If you think of questions or clarifications during analysis, save them for the end after the complete story is written
17
- - ZERO USER INTERVENTION: Process should be fully automated except for initial epic/story selection or missing documents
18
-
19
- ## Conventions
20
-
21
- - Bare paths (e.g. `discover-inputs.md`) resolve from the skill root.
22
- - `this skill directory` resolves to this skill's installed directory (where `agent configuration` lives).
23
- - `{project-root}`-prefixed paths resolve from the project working directory.
24
- - `{skill-name}` resolves to the skill directory's basename.
25
-
26
- ## On Activation
27
-
28
- ### Step 1: Resolve the Workflow Block
29
-
30
- <!-- Adapted for BMAD+: original script dependency removed -->
31
-
32
- **If the script fails**, resolve the `workflow` block yourself by reading these three files in base → team → user order and applying the same structural merge rules as the resolver:
33
-
34
- 1. `this skill file` — defaults
35
- 2. `{project-root}/custom/{skill-name}.toml` — team overrides
36
- 3. `{project-root}/custom/{skill-name}.user.toml` — personal overrides
37
-
38
- Any missing file is skipped. Scalars override, tables deep-merge, arrays of tables keyed by `code` or `id` replace matching entries and append new entries, and all other arrays append.
39
-
40
- ### Step 2: Execute Prepend Steps
41
-
42
- Execute each entry in `{workflow.activation_steps_prepend}` in order before proceeding.
43
-
44
- ### Step 3: Load Persistent Facts
45
-
46
- Treat every entry in `{workflow.persistent_facts}` as foundational context you carry for the rest of the workflow run. Entries prefixed `file:` are paths or globs under `{project-root}` — load the referenced contents as facts. All other entries are facts verbatim.
47
-
48
- ### Step 4: Load Config
49
-
50
- Load config from `{project-root}/project config` and resolve:
51
-
52
- - `project_name`, `user_name`
53
- - `communication_language`, `document_output_language`
54
- - `user_skill_level`
55
- - `planning_artifacts`, `implementation_artifacts`
56
- - `date` as system-generated current datetime
57
-
58
- ### Step 5: Greet the User
59
-
60
- Greet `{user_name}`, speaking in `{communication_language}`.
61
-
62
- ### Step 6: Execute Append Steps
63
-
64
- Execute each entry in `{workflow.activation_steps_append}` in order.
65
-
66
- Activation is complete. Begin the workflow below.
67
-
68
- ## Paths
69
-
70
- - `sprint_status` = `{implementation_artifacts}/sprint-status.yaml`
71
- - `epics_file` = `{planning_artifacts}/epics.md`
72
- - `prd_file` = `{planning_artifacts}/prd.md`
73
- - `architecture_file` = `{planning_artifacts}/architecture.md`
74
- - `ux_file` = `{planning_artifacts}/*ux*.md`
75
- - `story_title` = "" (will be elicited if not derivable)
76
- - `default_output_file` = `{implementation_artifacts}/{{story_key}}.md`
77
-
78
- ## Input Files
79
-
80
- | Input | Description | Path Pattern(s) | Load Strategy |
81
- |-------|-------------|------------------|---------------|
82
- | prd | PRD (fallback - epics file should have most content) | whole: `{planning_artifacts}/*prd*.md`, sharded: `{planning_artifacts}/*prd*/*.md` | SELECTIVE_LOAD |
83
- | architecture | Architecture (fallback - epics file should have relevant sections) | whole: `{planning_artifacts}/*architecture*.md`, sharded: `{planning_artifacts}/*architecture*/*.md` | SELECTIVE_LOAD |
84
- | ux | UX design (fallback - epics file should have relevant sections) | whole: `{planning_artifacts}/*ux*.md`, sharded: `{planning_artifacts}/*ux*/*.md` | SELECTIVE_LOAD |
85
- | epics | Enhanced epics+stories file with BDD and source hints | whole: `{planning_artifacts}/*epic*.md`, sharded: `{planning_artifacts}/*epic*/*.md` | SELECTIVE_LOAD |
86
-
87
- ## Execution
88
-
89
- <workflow>
90
-
91
- <step n="1" goal="Determine target story">
92
- <check if="{{story_path}} is provided by user or user provided the epic and story number such as 2-4 or 1.6 or epic 1 story 5">
93
- <action>Parse user-provided story path: extract epic_num, story_num, story_title from format like "1-2-user-auth"</action>
94
- <action>Set {{epic_num}}, {{story_num}}, {{story_key}} from user input</action>
95
- <action>GOTO step 2a</action>
96
- </check>
97
-
98
- <action>Check if {{sprint_status}} file exists for auto discover</action>
99
- <check if="sprint status file does NOT exist">
100
- <output>🚫 No sprint status file found and no story specified</output>
101
- <output>
102
- **Required Options:**
103
- 1. Run `sprint-planning` to initialize sprint tracking (recommended)
104
- 2. Provide specific epic-story number to create (e.g., "1-2-user-auth")
105
- 3. Provide path to story documents if sprint status doesn't exist yet
106
- </output>
107
- <ask>Choose option [1], provide epic-story number, path to story docs, or [q] to quit:</ask>
108
-
109
- <check if="user chooses 'q'">
110
- <action>HALT - No work needed</action>
111
- </check>
112
-
113
- <check if="user chooses '1'">
114
- <output>Run sprint-planning workflow first to create sprint-status.yaml</output>
115
- <action>HALT - User needs to run sprint-planning</action>
116
- </check>
117
-
118
- <check if="user provides epic-story number">
119
- <action>Parse user input: extract epic_num, story_num, story_title</action>
120
- <action>Set {{epic_num}}, {{story_num}}, {{story_key}} from user input</action>
121
- <action>GOTO step 2a</action>
122
- </check>
123
-
124
- <check if="user provides story docs path">
125
- <action>Use user-provided path for story documents</action>
126
- <action>GOTO step 2a</action>
127
- </check>
128
- </check>
129
-
130
- <!-- Auto-discover from sprint status only if no user input -->
131
- <check if="no user input provided">
132
- <critical>MUST read COMPLETE {sprint_status} file from start to end to preserve order</critical>
133
- <action>Load the FULL file: {{sprint_status}}</action>
134
- <action>Read ALL lines from beginning to end - do not skip any content</action>
135
- <action>Parse the development_status section completely</action>
136
-
137
- <action>Find the FIRST story (by reading in order from top to bottom) where:
138
- - Key matches pattern: number-number-name (e.g., "1-2-user-auth")
139
- - NOT an epic key (epic-X) or retrospective (epic-X-retrospective)
140
- - Status value equals "backlog"
141
- </action>
142
-
143
- <check if="no backlog story found">
144
- <output>📋 No backlog stories found in sprint-status.yaml
145
-
146
- All stories are either already created, in progress, or done.
147
-
148
- **Options:**
149
- 1. Run sprint-planning to refresh story tracking
150
- 2. Load PM agent and run correct-course to add more stories
151
- 3. Check if current sprint is complete and run retrospective
152
- </output>
153
- <action>HALT</action>
154
- </check>
155
-
156
- <action>Extract from found story key (e.g., "1-2-user-authentication"):
157
- - epic_num: first number before dash (e.g., "1")
158
- - story_num: second number after first dash (e.g., "2")
159
- - story_title: remainder after second dash (e.g., "user-authentication")
160
- </action>
161
- <action>Set {{story_id}} = "{{epic_num}}.{{story_num}}"</action>
162
- <action>Store story_key for later use (e.g., "1-2-user-authentication")</action>
163
-
164
- <!-- Mark epic as in-progress if this is first story -->
165
- <action>Check if this is the first story in epic {{epic_num}} by looking for {{epic_num}}-1-* pattern</action>
166
- <check if="this is first story in epic {{epic_num}}">
167
- <action>Load {{sprint_status}} and check epic-{{epic_num}} status</action>
168
- <action>If epic status is "backlog" → update to "in-progress"</action>
169
- <action>If epic status is "contexted" (legacy status) → update to "in-progress" (backward compatibility)</action>
170
- <action>If epic status is "in-progress" → no change needed</action>
171
- <check if="epic status is 'done'">
172
- <output>🚫 ERROR: Cannot create story in completed epic</output>
173
- <output>Epic {{epic_num}} is marked as 'done'. All stories are complete.</output>
174
- <output>If you need to add more work, either:</output>
175
- <output>1. Manually change epic status back to 'in-progress' in sprint-status.yaml</output>
176
- <output>2. Create a new epic for additional work</output>
177
- <action>HALT - Cannot proceed</action>
178
- </check>
179
- <check if="epic status is not one of: backlog, contexted, in-progress, done">
180
- <output>🚫 ERROR: Invalid epic status '{{epic_status}}'</output>
181
- <output>Epic {{epic_num}} has invalid status. Expected: backlog, in-progress, or done</output>
182
- <output>Please fix sprint-status.yaml manually or run sprint-planning to regenerate</output>
183
- <action>HALT - Cannot proceed</action>
184
- </check>
185
- <output>📊 Epic {{epic_num}} status updated to in-progress</output>
186
- </check>
187
-
188
- <action>GOTO step 2a</action>
189
- </check>
190
- <action>Load the FULL file: {{sprint_status}}</action>
191
- <action>Read ALL lines from beginning to end - do not skip any content</action>
192
- <action>Parse the development_status section completely</action>
193
-
194
- <action>Find the FIRST story (by reading in order from top to bottom) where:
195
- - Key matches pattern: number-number-name (e.g., "1-2-user-auth")
196
- - NOT an epic key (epic-X) or retrospective (epic-X-retrospective)
197
- - Status value equals "backlog"
198
- </action>
199
-
200
- <check if="no backlog story found">
201
- <output>No backlog stories found in sprint-status.yaml
202
-
203
- All stories are either already created, in progress, or done.
204
-
205
- **Options:**
206
- 1. Run sprint-planning to refresh story tracking
207
- 2. Load PM agent and run correct-course to add more stories
208
- 3. Check if current sprint is complete and run retrospective
209
- </output>
210
- <action>HALT</action>
211
- </check>
212
-
213
- <action>Extract from found story key (e.g., "1-2-user-authentication"):
214
- - epic_num: first number before dash (e.g., "1")
215
- - story_num: second number after first dash (e.g., "2")
216
- - story_title: remainder after second dash (e.g., "user-authentication")
217
- </action>
218
- <action>Set {{story_id}} = "{{epic_num}}.{{story_num}}"</action>
219
- <action>Store story_key for later use (e.g., "1-2-user-authentication")</action>
220
-
221
- <!-- Mark epic as in-progress if this is first story -->
222
- <action>Check if this is the first story in epic {{epic_num}} by looking for {{epic_num}}-1-* pattern</action>
223
- <check if="this is first story in epic {{epic_num}}">
224
- <action>Load {{sprint_status}} and check epic-{{epic_num}} status</action>
225
- <action>If epic status is "backlog" → update to "in-progress"</action>
226
- <action>If epic status is "contexted" (legacy status) → update to "in-progress" (backward compatibility)</action>
227
- <action>If epic status is "in-progress" → no change needed</action>
228
- <check if="epic status is 'done'">
229
- <output>ERROR: Cannot create story in completed epic</output>
230
- <output>Epic {{epic_num}} is marked as 'done'. All stories are complete.</output>
231
- <output>If you need to add more work, either:</output>
232
- <output>1. Manually change epic status back to 'in-progress' in sprint-status.yaml</output>
233
- <output>2. Create a new epic for additional work</output>
234
- <action>HALT - Cannot proceed</action>
235
- </check>
236
- <check if="epic status is not one of: backlog, contexted, in-progress, done">
237
- <output>ERROR: Invalid epic status '{{epic_status}}'</output>
238
- <output>Epic {{epic_num}} has invalid status. Expected: backlog, in-progress, or done</output>
239
- <output>Please fix sprint-status.yaml manually or run sprint-planning to regenerate</output>
240
- <action>HALT - Cannot proceed</action>
241
- </check>
242
- <output>Epic {{epic_num}} status updated to in-progress</output>
243
- </check>
244
-
245
- <action>GOTO step 2a</action>
246
- </step>
247
-
248
- <step n="2" goal="Load and analyze core artifacts">
249
- <critical>🔬 EXHAUSTIVE ARTIFACT ANALYSIS - This is where you prevent future developer mistakes!</critical>
250
-
251
- <!-- Load all available content through discovery protocol -->
252
- <action>Read fully and follow `./discover-inputs.md` to load all input files</action>
253
- <note>Available content: {epics_content}, {prd_content}, {architecture_content}, {ux_content}, plus the project-context facts loaded during activation via `persistent_facts`.</note>
254
-
255
- <!-- Analyze epics file for story foundation -->
256
- <action>From {epics_content}, extract Epic {{epic_num}} complete context:</action> **EPIC ANALYSIS:** - Epic
257
- objectives and business value - ALL stories in this epic for cross-story context - Our specific story's requirements, user story
258
- statement, acceptance criteria - Technical requirements and constraints - Dependencies on other stories/epics - Source hints pointing to
259
- original documents <!-- Extract specific story requirements -->
260
- <action>Extract our story ({{epic_num}}-{{story_num}}) details:</action> **STORY FOUNDATION:** - User story statement
261
- (As a, I want, so that) - Detailed acceptance criteria (already BDD formatted) - Technical requirements specific to this story -
262
- Business context and value - Success criteria <!-- Previous story analysis for context continuity -->
263
- <check if="story_num > 1">
264
- <action>Find {{previous_story_num}}: scan {implementation_artifacts} for the story file in epic {{epic_num}} with the highest story number less than {{story_num}}</action>
265
- <action>Load previous story file: {implementation_artifacts}/{{epic_num}}-{{previous_story_num}}-*.md</action> **PREVIOUS STORY INTELLIGENCE:** -
266
- Dev notes and learnings from previous story - Review feedback and corrections needed - Files that were created/modified and their
267
- patterns - Testing approaches that worked/didn't work - Problems encountered and solutions found - Code patterns established <action>Extract
268
- all learnings that could impact current story implementation</action>
269
- </check>
270
-
271
- <!-- Git intelligence for previous work patterns -->
272
- <check
273
- if="previous story exists AND git repository detected">
274
- <action>Get last 5 commit titles to understand recent work patterns</action>
275
- <action>Analyze 1-5 most recent commits for relevance to current story:
276
- - Files created/modified
277
- - Code patterns and conventions used
278
- - Library dependencies added/changed
279
- - Architecture decisions implemented
280
- - Testing approaches used
281
- </action>
282
- <action>Extract actionable insights for current story implementation</action>
283
- </check>
284
- </step>
285
-
286
- <step n="3" goal="Architecture analysis for developer guardrails">
287
- <critical>🏗️ ARCHITECTURE INTELLIGENCE - Extract everything the developer MUST follow!</critical> **ARCHITECTURE DOCUMENT ANALYSIS:** <action>Systematically
288
- analyze architecture content for story-relevant requirements:</action>
289
-
290
- <!-- Load architecture - single file or sharded -->
291
- <check if="architecture file is single file">
292
- <action>Load complete {architecture_content}</action>
293
- </check>
294
- <check if="architecture is sharded to folder">
295
- <action>Load architecture index and scan all architecture files</action>
296
- </check> **CRITICAL ARCHITECTURE EXTRACTION:** <action>For
297
- each architecture section, determine if relevant to this story:</action> - **Technical Stack:** Languages, frameworks, libraries with
298
- versions - **Code Structure:** Folder organization, naming conventions, file patterns - **API Patterns:** Service structure, endpoint
299
- patterns, data contracts - **Database Schemas:** Tables, relationships, constraints relevant to story - **Security Requirements:**
300
- Authentication patterns, authorization rules - **Performance Requirements:** Caching strategies, optimization patterns - **Testing
301
- Standards:** Testing frameworks, coverage expectations, test patterns - **Deployment Patterns:** Environment configurations, build
302
- processes - **Integration Patterns:** External service integrations, data flows <action>Extract any story-specific requirements that the
303
- developer MUST follow</action>
304
- <action>Identify any architectural decisions that override previous patterns</action>
305
-
306
- <!-- Read existing code being modified — non-negotiable -->
307
- <critical>📂 READ FILES BEING MODIFIED — skipping this is the primary cause of implementation failures and review cycles</critical>
308
- <action>From the architecture directory structure, identify every file marked UPDATE (not NEW) that this story will touch</action>
309
- <action>Read each relevant UPDATE file completely. For each one, document in dev notes:
310
- - Current state: what it does today (state machine, API calls, data shapes, existing behaviors)
311
- - What this story changes: the specific sections or behaviors being modified
312
- - What must be preserved: existing interactions and behaviors the story must not break
313
- </action>
314
- <critical>A story implementation must leave the system working end-to-end — not just satisfy its stated ACs.
315
- If a behavior is required for the feature to work correctly in the existing system, it is a requirement
316
- whether or not it is explicitly written in the story. The dev agent owns this.</critical>
317
- </step>
318
-
319
- <step n="4" goal="Web research for latest technical specifics">
320
- <critical>🌐 ENSURE LATEST TECH KNOWLEDGE - Prevent outdated implementations!</critical> **WEB INTELLIGENCE:** <action>Identify specific
321
- technical areas that require latest version knowledge:</action>
322
-
323
- <!-- Check for libraries/frameworks mentioned in architecture -->
324
- <action>From architecture analysis, identify specific libraries, APIs, or
325
- frameworks</action>
326
- <action>For each critical technology, research latest stable version and key changes:
327
- - Latest API documentation and breaking changes
328
- - Security vulnerabilities or updates
329
- - Performance improvements or deprecations
330
- - Best practices for current version
331
- </action>
332
- **EXTERNAL CONTEXT INCLUSION:** <action>Include in story any critical latest information the developer needs:
333
- - Specific library versions and why chosen
334
- - API endpoints with parameters and authentication
335
- - Recent security patches or considerations
336
- - Performance optimization techniques
337
- - Migration considerations if upgrading
338
- </action>
339
- </step>
340
-
341
- <step n="5" goal="Create comprehensive story file">
342
- <critical>📝 CREATE ULTIMATE STORY FILE - The developer's master implementation guide!</critical>
343
-
344
- <action>Initialize from template.md:
345
- {default_output_file}</action>
346
- <template-output file="{default_output_file}">story_header</template-output>
347
-
348
- <!-- Story foundation from epics analysis -->
349
- <template-output
350
- file="{default_output_file}">story_requirements</template-output>
351
-
352
- <!-- Developer context section - MOST IMPORTANT PART -->
353
- <template-output file="{default_output_file}">
354
- developer_context_section</template-output> **DEV AGENT GUARDRAILS:** <template-output file="{default_output_file}">
355
- technical_requirements</template-output>
356
- <template-output file="{default_output_file}">architecture_compliance</template-output>
357
- <template-output
358
- file="{default_output_file}">library_framework_requirements</template-output>
359
- <template-output file="{default_output_file}">
360
- file_structure_requirements</template-output>
361
- <template-output file="{default_output_file}">testing_requirements</template-output>
362
-
363
- <!-- Previous story intelligence -->
364
- <check
365
- if="previous story learnings available">
366
- <template-output file="{default_output_file}">previous_story_intelligence</template-output>
367
- </check>
368
-
369
- <!-- Git intelligence -->
370
- <check
371
- if="git analysis completed">
372
- <template-output file="{default_output_file}">git_intelligence_summary</template-output>
373
- </check>
374
-
375
- <!-- Latest technical specifics -->
376
- <check if="web research completed">
377
- <template-output file="{default_output_file}">latest_tech_information</template-output>
378
- </check>
379
-
380
- <!-- Project context reference -->
381
- <template-output
382
- file="{default_output_file}">project_context_reference</template-output>
383
-
384
- <!-- Final status update -->
385
- <template-output file="{default_output_file}">
386
- story_completion_status</template-output>
387
-
388
- <!-- CRITICAL: Set status to ready-for-dev -->
389
- <action>Set story Status to: "ready-for-dev"</action>
390
- <action>Add completion note: "Ultimate
391
- context engine analysis completed - comprehensive developer guide created"</action>
392
- </step>
393
-
394
- <step n="6" goal="Update sprint status and finalize">
395
- <action>Validate the newly created story file {default_output_file} against `./checklist.md` and apply any required fixes before finalizing</action>
396
- <action>Save story document unconditionally</action>
397
-
398
- <!-- Update sprint status -->
399
- <check if="sprint status file exists">
400
- <action>Update {{sprint_status}}</action>
401
- <action>Load the FULL file and read all development_status entries</action>
402
- <action>Find development_status key matching {{story_key}}</action>
403
- <action>Verify current status is "backlog" (expected previous state)</action>
404
- <action>Update development_status[{{story_key}}] = "ready-for-dev"</action>
405
- <action>Update last_updated field to current date</action>
406
- <action>Save file, preserving ALL comments and structure including STATUS DEFINITIONS</action>
407
- </check>
408
-
409
- <action>Report completion</action>
410
- <output>**🎯 ULTIMATE BMad Method STORY CONTEXT CREATED, {user_name}!**
411
-
412
- **Story Details:**
413
- - Story ID: {{story_id}}
414
- - Story Key: {{story_key}}
415
- - File: {{story_file}}
416
- - Status: ready-for-dev
417
-
418
- **Next Steps:**
419
- 1. Review the comprehensive story in {{story_file}}
420
- 2. Run dev agents `dev-story` for optimized implementation
421
- 3. Run `code-review` when complete (auto-marks done)
422
- 4. Optional: If Test Architect module installed, run `/bmad:tea:automate` after `dev-story` to generate guardrail tests
423
-
424
- **The developer now has everything needed for flawless implementation!**
425
- </output>
426
- <!-- Adapted for BMAD+: original script dependency removed -->
427
- </step>
428
-
1
+ ---
2
+ name: bmad-create-story
3
+ description: 'Creates a dedicated story file with all the context the agent will need to implement it later. Use when the user says "create the next story" or "create story [story identifier]"'
4
+ ---
5
+
6
+ # Create Story Workflow
7
+
8
+ **Goal:** Create a comprehensive story file that gives the dev agent everything needed for flawless implementation.
9
+
10
+ **Your Role:** Story context engine that prevents LLM developer mistakes, omissions, or disasters.
11
+ - Communicate all responses in {communication_language} and generate all documents in {document_output_language}
12
+ - Your purpose is NOT to copy from epics - it's to create a comprehensive, optimized story file that gives the DEV agent EVERYTHING needed for flawless implementation
13
+ - COMMON LLM MISTAKES TO PREVENT: reinventing wheels, wrong libraries, wrong file locations, breaking regressions, ignoring UX, vague implementations, lying about completion, not learning from past work
14
+ - EXHAUSTIVE ANALYSIS REQUIRED: You must thoroughly analyze ALL artifacts to extract critical context - do NOT be lazy or skim! This is the most important function in the entire development process!
15
+ - UTILIZE SUBPROCESSES AND SUBAGENTS: Use research subagents, subprocesses or parallel processing if available to thoroughly analyze different artifacts simultaneously and thoroughly
16
+ - SAVE QUESTIONS: If you think of questions or clarifications during analysis, save them for the end after the complete story is written
17
+ - ZERO USER INTERVENTION: Process should be fully automated except for initial epic/story selection or missing documents
18
+
19
+ ## Conventions
20
+
21
+ - Bare paths (e.g. `discover-inputs.md`) resolve from the skill root.
22
+ - `this skill directory` resolves to this skill's installed directory (where `agent configuration` lives).
23
+ - `{project-root}`-prefixed paths resolve from the project working directory.
24
+ - `{skill-name}` resolves to the skill directory's basename.
25
+
26
+ ## On Activation
27
+
28
+ ### Step 1: Resolve the Workflow Block
29
+
30
+ <!-- Adapted for BMAD+: original script dependency removed -->
31
+
32
+ **If the script fails**, resolve the `workflow` block yourself by reading these three files in base → team → user order and applying the same structural merge rules as the resolver:
33
+
34
+ 1. `this skill file` — defaults
35
+ 2. `{project-root}/custom/{skill-name}.toml` — team overrides
36
+ 3. `{project-root}/custom/{skill-name}.user.toml` — personal overrides
37
+
38
+ Any missing file is skipped. Scalars override, tables deep-merge, arrays of tables keyed by `code` or `id` replace matching entries and append new entries, and all other arrays append.
39
+
40
+ ### Step 2: Execute Prepend Steps
41
+
42
+ Execute each entry in `{workflow.activation_steps_prepend}` in order before proceeding.
43
+
44
+ ### Step 3: Load Persistent Facts
45
+
46
+ Treat every entry in `{workflow.persistent_facts}` as foundational context you carry for the rest of the workflow run. Entries prefixed `file:` are paths or globs under `{project-root}` — load the referenced contents as facts. All other entries are facts verbatim.
47
+
48
+ ### Step 4: Load Config
49
+
50
+ Load config from `{project-root}/project config` and resolve:
51
+
52
+ - `project_name`, `user_name`
53
+ - `communication_language`, `document_output_language`
54
+ - `user_skill_level`
55
+ - `planning_artifacts`, `implementation_artifacts`
56
+ - `date` as system-generated current datetime
57
+
58
+ ### Step 5: Greet the User
59
+
60
+ Greet `{user_name}`, speaking in `{communication_language}`.
61
+
62
+ ### Step 6: Execute Append Steps
63
+
64
+ Execute each entry in `{workflow.activation_steps_append}` in order.
65
+
66
+ Activation is complete. Begin the workflow below.
67
+
68
+ ## Paths
69
+
70
+ - `sprint_status` = `{implementation_artifacts}/sprint-status.yaml`
71
+ - `epics_file` = `{planning_artifacts}/epics.md`
72
+ - `prd_file` = `{planning_artifacts}/prd.md`
73
+ - `architecture_file` = `{planning_artifacts}/architecture.md`
74
+ - `ux_file` = `{planning_artifacts}/*ux*.md`
75
+ - `story_title` = "" (will be elicited if not derivable)
76
+ - `default_output_file` = `{implementation_artifacts}/{{story_key}}.md`
77
+
78
+ ## Input Files
79
+
80
+ | Input | Description | Path Pattern(s) | Load Strategy |
81
+ |-------|-------------|------------------|---------------|
82
+ | prd | PRD (fallback - epics file should have most content) | whole: `{planning_artifacts}/*prd*.md`, sharded: `{planning_artifacts}/*prd*/*.md` | SELECTIVE_LOAD |
83
+ | architecture | Architecture (fallback - epics file should have relevant sections) | whole: `{planning_artifacts}/*architecture*.md`, sharded: `{planning_artifacts}/*architecture*/*.md` | SELECTIVE_LOAD |
84
+ | ux | UX design (fallback - epics file should have relevant sections) | whole: `{planning_artifacts}/*ux*.md`, sharded: `{planning_artifacts}/*ux*/*.md` | SELECTIVE_LOAD |
85
+ | epics | Enhanced epics+stories file with BDD and source hints | whole: `{planning_artifacts}/*epic*.md`, sharded: `{planning_artifacts}/*epic*/*.md` | SELECTIVE_LOAD |
86
+
87
+ ## Execution
88
+
89
+ <workflow>
90
+
91
+ <step n="1" goal="Determine target story">
92
+ <check if="{{story_path}} is provided by user or user provided the epic and story number such as 2-4 or 1.6 or epic 1 story 5">
93
+ <action>Parse user-provided story path: extract epic_num, story_num, story_title from format like "1-2-user-auth"</action>
94
+ <action>Set {{epic_num}}, {{story_num}}, {{story_key}} from user input</action>
95
+ <action>GOTO step 2a</action>
96
+ </check>
97
+
98
+ <action>Check if {{sprint_status}} file exists for auto discover</action>
99
+ <check if="sprint status file does NOT exist">
100
+ <output>🚫 No sprint status file found and no story specified</output>
101
+ <output>
102
+ **Required Options:**
103
+ 1. Run `sprint-planning` to initialize sprint tracking (recommended)
104
+ 2. Provide specific epic-story number to create (e.g., "1-2-user-auth")
105
+ 3. Provide path to story documents if sprint status doesn't exist yet
106
+ </output>
107
+ <ask>Choose option [1], provide epic-story number, path to story docs, or [q] to quit:</ask>
108
+
109
+ <check if="user chooses 'q'">
110
+ <action>HALT - No work needed</action>
111
+ </check>
112
+
113
+ <check if="user chooses '1'">
114
+ <output>Run sprint-planning workflow first to create sprint-status.yaml</output>
115
+ <action>HALT - User needs to run sprint-planning</action>
116
+ </check>
117
+
118
+ <check if="user provides epic-story number">
119
+ <action>Parse user input: extract epic_num, story_num, story_title</action>
120
+ <action>Set {{epic_num}}, {{story_num}}, {{story_key}} from user input</action>
121
+ <action>GOTO step 2a</action>
122
+ </check>
123
+
124
+ <check if="user provides story docs path">
125
+ <action>Use user-provided path for story documents</action>
126
+ <action>GOTO step 2a</action>
127
+ </check>
128
+ </check>
129
+
130
+ <!-- Auto-discover from sprint status only if no user input -->
131
+ <check if="no user input provided">
132
+ <critical>MUST read COMPLETE {sprint_status} file from start to end to preserve order</critical>
133
+ <action>Load the FULL file: {{sprint_status}}</action>
134
+ <action>Read ALL lines from beginning to end - do not skip any content</action>
135
+ <action>Parse the development_status section completely</action>
136
+
137
+ <action>Find the FIRST story (by reading in order from top to bottom) where:
138
+ - Key matches pattern: number-number-name (e.g., "1-2-user-auth")
139
+ - NOT an epic key (epic-X) or retrospective (epic-X-retrospective)
140
+ - Status value equals "backlog"
141
+ </action>
142
+
143
+ <check if="no backlog story found">
144
+ <output>📋 No backlog stories found in sprint-status.yaml
145
+
146
+ All stories are either already created, in progress, or done.
147
+
148
+ **Options:**
149
+ 1. Run sprint-planning to refresh story tracking
150
+ 2. Load PM agent and run correct-course to add more stories
151
+ 3. Check if current sprint is complete and run retrospective
152
+ </output>
153
+ <action>HALT</action>
154
+ </check>
155
+
156
+ <action>Extract from found story key (e.g., "1-2-user-authentication"):
157
+ - epic_num: first number before dash (e.g., "1")
158
+ - story_num: second number after first dash (e.g., "2")
159
+ - story_title: remainder after second dash (e.g., "user-authentication")
160
+ </action>
161
+ <action>Set {{story_id}} = "{{epic_num}}.{{story_num}}"</action>
162
+ <action>Store story_key for later use (e.g., "1-2-user-authentication")</action>
163
+
164
+ <!-- Mark epic as in-progress if this is first story -->
165
+ <action>Check if this is the first story in epic {{epic_num}} by looking for {{epic_num}}-1-* pattern</action>
166
+ <check if="this is first story in epic {{epic_num}}">
167
+ <action>Load {{sprint_status}} and check epic-{{epic_num}} status</action>
168
+ <action>If epic status is "backlog" → update to "in-progress"</action>
169
+ <action>If epic status is "contexted" (legacy status) → update to "in-progress" (backward compatibility)</action>
170
+ <action>If epic status is "in-progress" → no change needed</action>
171
+ <check if="epic status is 'done'">
172
+ <output>🚫 ERROR: Cannot create story in completed epic</output>
173
+ <output>Epic {{epic_num}} is marked as 'done'. All stories are complete.</output>
174
+ <output>If you need to add more work, either:</output>
175
+ <output>1. Manually change epic status back to 'in-progress' in sprint-status.yaml</output>
176
+ <output>2. Create a new epic for additional work</output>
177
+ <action>HALT - Cannot proceed</action>
178
+ </check>
179
+ <check if="epic status is not one of: backlog, contexted, in-progress, done">
180
+ <output>🚫 ERROR: Invalid epic status '{{epic_status}}'</output>
181
+ <output>Epic {{epic_num}} has invalid status. Expected: backlog, in-progress, or done</output>
182
+ <output>Please fix sprint-status.yaml manually or run sprint-planning to regenerate</output>
183
+ <action>HALT - Cannot proceed</action>
184
+ </check>
185
+ <output>📊 Epic {{epic_num}} status updated to in-progress</output>
186
+ </check>
187
+
188
+ <action>GOTO step 2a</action>
189
+ </check>
190
+ <action>Load the FULL file: {{sprint_status}}</action>
191
+ <action>Read ALL lines from beginning to end - do not skip any content</action>
192
+ <action>Parse the development_status section completely</action>
193
+
194
+ <action>Find the FIRST story (by reading in order from top to bottom) where:
195
+ - Key matches pattern: number-number-name (e.g., "1-2-user-auth")
196
+ - NOT an epic key (epic-X) or retrospective (epic-X-retrospective)
197
+ - Status value equals "backlog"
198
+ </action>
199
+
200
+ <check if="no backlog story found">
201
+ <output>No backlog stories found in sprint-status.yaml
202
+
203
+ All stories are either already created, in progress, or done.
204
+
205
+ **Options:**
206
+ 1. Run sprint-planning to refresh story tracking
207
+ 2. Load PM agent and run correct-course to add more stories
208
+ 3. Check if current sprint is complete and run retrospective
209
+ </output>
210
+ <action>HALT</action>
211
+ </check>
212
+
213
+ <action>Extract from found story key (e.g., "1-2-user-authentication"):
214
+ - epic_num: first number before dash (e.g., "1")
215
+ - story_num: second number after first dash (e.g., "2")
216
+ - story_title: remainder after second dash (e.g., "user-authentication")
217
+ </action>
218
+ <action>Set {{story_id}} = "{{epic_num}}.{{story_num}}"</action>
219
+ <action>Store story_key for later use (e.g., "1-2-user-authentication")</action>
220
+
221
+ <!-- Mark epic as in-progress if this is first story -->
222
+ <action>Check if this is the first story in epic {{epic_num}} by looking for {{epic_num}}-1-* pattern</action>
223
+ <check if="this is first story in epic {{epic_num}}">
224
+ <action>Load {{sprint_status}} and check epic-{{epic_num}} status</action>
225
+ <action>If epic status is "backlog" → update to "in-progress"</action>
226
+ <action>If epic status is "contexted" (legacy status) → update to "in-progress" (backward compatibility)</action>
227
+ <action>If epic status is "in-progress" → no change needed</action>
228
+ <check if="epic status is 'done'">
229
+ <output>ERROR: Cannot create story in completed epic</output>
230
+ <output>Epic {{epic_num}} is marked as 'done'. All stories are complete.</output>
231
+ <output>If you need to add more work, either:</output>
232
+ <output>1. Manually change epic status back to 'in-progress' in sprint-status.yaml</output>
233
+ <output>2. Create a new epic for additional work</output>
234
+ <action>HALT - Cannot proceed</action>
235
+ </check>
236
+ <check if="epic status is not one of: backlog, contexted, in-progress, done">
237
+ <output>ERROR: Invalid epic status '{{epic_status}}'</output>
238
+ <output>Epic {{epic_num}} has invalid status. Expected: backlog, in-progress, or done</output>
239
+ <output>Please fix sprint-status.yaml manually or run sprint-planning to regenerate</output>
240
+ <action>HALT - Cannot proceed</action>
241
+ </check>
242
+ <output>Epic {{epic_num}} status updated to in-progress</output>
243
+ </check>
244
+
245
+ <action>GOTO step 2a</action>
246
+ </step>
247
+
248
+ <step n="2" goal="Load and analyze core artifacts">
249
+ <critical>🔬 EXHAUSTIVE ARTIFACT ANALYSIS - This is where you prevent future developer mistakes!</critical>
250
+
251
+ <!-- Load all available content through discovery protocol -->
252
+ <action>Read fully and follow `./discover-inputs.md` to load all input files</action>
253
+ <note>Available content: {epics_content}, {prd_content}, {architecture_content}, {ux_content}, plus the project-context facts loaded during activation via `persistent_facts`.</note>
254
+
255
+ <!-- Analyze epics file for story foundation -->
256
+ <action>From {epics_content}, extract Epic {{epic_num}} complete context:</action> **EPIC ANALYSIS:** - Epic
257
+ objectives and business value - ALL stories in this epic for cross-story context - Our specific story's requirements, user story
258
+ statement, acceptance criteria - Technical requirements and constraints - Dependencies on other stories/epics - Source hints pointing to
259
+ original documents <!-- Extract specific story requirements -->
260
+ <action>Extract our story ({{epic_num}}-{{story_num}}) details:</action> **STORY FOUNDATION:** - User story statement
261
+ (As a, I want, so that) - Detailed acceptance criteria (already BDD formatted) - Technical requirements specific to this story -
262
+ Business context and value - Success criteria <!-- Previous story analysis for context continuity -->
263
+ <check if="story_num > 1">
264
+ <action>Find {{previous_story_num}}: scan {implementation_artifacts} for the story file in epic {{epic_num}} with the highest story number less than {{story_num}}</action>
265
+ <action>Load previous story file: {implementation_artifacts}/{{epic_num}}-{{previous_story_num}}-*.md</action> **PREVIOUS STORY INTELLIGENCE:** -
266
+ Dev notes and learnings from previous story - Review feedback and corrections needed - Files that were created/modified and their
267
+ patterns - Testing approaches that worked/didn't work - Problems encountered and solutions found - Code patterns established <action>Extract
268
+ all learnings that could impact current story implementation</action>
269
+ </check>
270
+
271
+ <!-- Git intelligence for previous work patterns -->
272
+ <check
273
+ if="previous story exists AND git repository detected">
274
+ <action>Get last 5 commit titles to understand recent work patterns</action>
275
+ <action>Analyze 1-5 most recent commits for relevance to current story:
276
+ - Files created/modified
277
+ - Code patterns and conventions used
278
+ - Library dependencies added/changed
279
+ - Architecture decisions implemented
280
+ - Testing approaches used
281
+ </action>
282
+ <action>Extract actionable insights for current story implementation</action>
283
+ </check>
284
+ </step>
285
+
286
+ <step n="3" goal="Architecture analysis for developer guardrails">
287
+ <critical>🏗️ ARCHITECTURE INTELLIGENCE - Extract everything the developer MUST follow!</critical> **ARCHITECTURE DOCUMENT ANALYSIS:** <action>Systematically
288
+ analyze architecture content for story-relevant requirements:</action>
289
+
290
+ <!-- Load architecture - single file or sharded -->
291
+ <check if="architecture file is single file">
292
+ <action>Load complete {architecture_content}</action>
293
+ </check>
294
+ <check if="architecture is sharded to folder">
295
+ <action>Load architecture index and scan all architecture files</action>
296
+ </check> **CRITICAL ARCHITECTURE EXTRACTION:** <action>For
297
+ each architecture section, determine if relevant to this story:</action> - **Technical Stack:** Languages, frameworks, libraries with
298
+ versions - **Code Structure:** Folder organization, naming conventions, file patterns - **API Patterns:** Service structure, endpoint
299
+ patterns, data contracts - **Database Schemas:** Tables, relationships, constraints relevant to story - **Security Requirements:**
300
+ Authentication patterns, authorization rules - **Performance Requirements:** Caching strategies, optimization patterns - **Testing
301
+ Standards:** Testing frameworks, coverage expectations, test patterns - **Deployment Patterns:** Environment configurations, build
302
+ processes - **Integration Patterns:** External service integrations, data flows <action>Extract any story-specific requirements that the
303
+ developer MUST follow</action>
304
+ <action>Identify any architectural decisions that override previous patterns</action>
305
+
306
+ <!-- Read existing code being modified — non-negotiable -->
307
+ <critical>📂 READ FILES BEING MODIFIED — skipping this is the primary cause of implementation failures and review cycles</critical>
308
+ <action>From the architecture directory structure, identify every file marked UPDATE (not NEW) that this story will touch</action>
309
+ <action>Read each relevant UPDATE file completely. For each one, document in dev notes:
310
+ - Current state: what it does today (state machine, API calls, data shapes, existing behaviors)
311
+ - What this story changes: the specific sections or behaviors being modified
312
+ - What must be preserved: existing interactions and behaviors the story must not break
313
+ </action>
314
+ <critical>A story implementation must leave the system working end-to-end — not just satisfy its stated ACs.
315
+ If a behavior is required for the feature to work correctly in the existing system, it is a requirement
316
+ whether or not it is explicitly written in the story. The dev agent owns this.</critical>
317
+ </step>
318
+
319
+ <step n="4" goal="Web research for latest technical specifics">
320
+ <critical>🌐 ENSURE LATEST TECH KNOWLEDGE - Prevent outdated implementations!</critical> **WEB INTELLIGENCE:** <action>Identify specific
321
+ technical areas that require latest version knowledge:</action>
322
+
323
+ <!-- Check for libraries/frameworks mentioned in architecture -->
324
+ <action>From architecture analysis, identify specific libraries, APIs, or
325
+ frameworks</action>
326
+ <action>For each critical technology, research latest stable version and key changes:
327
+ - Latest API documentation and breaking changes
328
+ - Security vulnerabilities or updates
329
+ - Performance improvements or deprecations
330
+ - Best practices for current version
331
+ </action>
332
+ **EXTERNAL CONTEXT INCLUSION:** <action>Include in story any critical latest information the developer needs:
333
+ - Specific library versions and why chosen
334
+ - API endpoints with parameters and authentication
335
+ - Recent security patches or considerations
336
+ - Performance optimization techniques
337
+ - Migration considerations if upgrading
338
+ </action>
339
+ </step>
340
+
341
+ <step n="5" goal="Create comprehensive story file">
342
+ <critical>📝 CREATE ULTIMATE STORY FILE - The developer's master implementation guide!</critical>
343
+
344
+ <action>Initialize from template.md:
345
+ {default_output_file}</action>
346
+ <template-output file="{default_output_file}">story_header</template-output>
347
+
348
+ <!-- Story foundation from epics analysis -->
349
+ <template-output
350
+ file="{default_output_file}">story_requirements</template-output>
351
+
352
+ <!-- Developer context section - MOST IMPORTANT PART -->
353
+ <template-output file="{default_output_file}">
354
+ developer_context_section</template-output> **DEV AGENT GUARDRAILS:** <template-output file="{default_output_file}">
355
+ technical_requirements</template-output>
356
+ <template-output file="{default_output_file}">architecture_compliance</template-output>
357
+ <template-output
358
+ file="{default_output_file}">library_framework_requirements</template-output>
359
+ <template-output file="{default_output_file}">
360
+ file_structure_requirements</template-output>
361
+ <template-output file="{default_output_file}">testing_requirements</template-output>
362
+
363
+ <!-- Previous story intelligence -->
364
+ <check
365
+ if="previous story learnings available">
366
+ <template-output file="{default_output_file}">previous_story_intelligence</template-output>
367
+ </check>
368
+
369
+ <!-- Git intelligence -->
370
+ <check
371
+ if="git analysis completed">
372
+ <template-output file="{default_output_file}">git_intelligence_summary</template-output>
373
+ </check>
374
+
375
+ <!-- Latest technical specifics -->
376
+ <check if="web research completed">
377
+ <template-output file="{default_output_file}">latest_tech_information</template-output>
378
+ </check>
379
+
380
+ <!-- Project context reference -->
381
+ <template-output
382
+ file="{default_output_file}">project_context_reference</template-output>
383
+
384
+ <!-- Final status update -->
385
+ <template-output file="{default_output_file}">
386
+ story_completion_status</template-output>
387
+
388
+ <!-- CRITICAL: Set status to ready-for-dev -->
389
+ <action>Set story Status to: "ready-for-dev"</action>
390
+ <action>Add completion note: "Ultimate
391
+ context engine analysis completed - comprehensive developer guide created"</action>
392
+ </step>
393
+
394
+ <step n="6" goal="Update sprint status and finalize">
395
+ <action>Validate the newly created story file {default_output_file} against `./checklist.md` and apply any required fixes before finalizing</action>
396
+ <action>Save story document unconditionally</action>
397
+
398
+ <!-- Update sprint status -->
399
+ <check if="sprint status file exists">
400
+ <action>Update {{sprint_status}}</action>
401
+ <action>Load the FULL file and read all development_status entries</action>
402
+ <action>Find development_status key matching {{story_key}}</action>
403
+ <action>Verify current status is "backlog" (expected previous state)</action>
404
+ <action>Update development_status[{{story_key}}] = "ready-for-dev"</action>
405
+ <action>Update last_updated field to current date</action>
406
+ <action>Save file, preserving ALL comments and structure including STATUS DEFINITIONS</action>
407
+ </check>
408
+
409
+ <action>Report completion</action>
410
+ <output>**🎯 ULTIMATE BMad Method STORY CONTEXT CREATED, {user_name}!**
411
+
412
+ **Story Details:**
413
+ - Story ID: {{story_id}}
414
+ - Story Key: {{story_key}}
415
+ - File: {{story_file}}
416
+ - Status: ready-for-dev
417
+
418
+ **Next Steps:**
419
+ 1. Review the comprehensive story in {{story_file}}
420
+ 2. Run dev agents `dev-story` for optimized implementation
421
+ 3. Run `code-review` when complete (auto-marks done)
422
+ 4. Optional: If Test Architect module installed, run `/bmad:tea:automate` after `dev-story` to generate guardrail tests
423
+
424
+ **The developer now has everything needed for flawless implementation!**
425
+ </output>
426
+ <!-- Adapted for BMAD+: original script dependency removed -->
427
+ </step>
428
+
429
429
  </workflow>