specweave 0.4.1 ā 0.6.3
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/.claude-plugin/README.md +312 -0
- package/.claude-plugin/marketplace.json +210 -0
- package/CLAUDE.md +952 -609
- package/README.md +179 -761
- package/bin/install-agents.sh +1 -1
- package/bin/install-commands.sh +66 -14
- package/bin/install-hooks.sh +1 -1
- package/bin/install-skills.sh +1 -1
- package/bin/specweave.js +2 -0
- package/dist/adapters/claude/adapter.d.ts +49 -11
- package/dist/adapters/claude/adapter.d.ts.map +1 -1
- package/dist/adapters/claude/adapter.js +175 -42
- package/dist/adapters/claude/adapter.js.map +1 -1
- package/dist/adapters/copilot/adapter.d.ts +20 -2
- package/dist/adapters/copilot/adapter.d.ts.map +1 -1
- package/dist/adapters/copilot/adapter.js +117 -7
- package/dist/adapters/copilot/adapter.js.map +1 -1
- package/dist/adapters/cursor/adapter.d.ts +18 -0
- package/dist/adapters/cursor/adapter.d.ts.map +1 -1
- package/dist/adapters/cursor/adapter.js +55 -3
- package/dist/adapters/cursor/adapter.js.map +1 -1
- package/dist/adapters/generic/adapter.d.ts +18 -0
- package/dist/adapters/generic/adapter.d.ts.map +1 -1
- package/dist/adapters/generic/adapter.js +55 -3
- package/dist/adapters/generic/adapter.js.map +1 -1
- package/dist/cli/commands/init.d.ts +1 -0
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +521 -185
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/install.d.ts +2 -0
- package/dist/cli/commands/install.d.ts.map +1 -1
- package/dist/cli/commands/install.js +28 -25
- package/dist/cli/commands/install.js.map +1 -1
- package/dist/cli/commands/list.d.ts +2 -0
- package/dist/cli/commands/list.d.ts.map +1 -1
- package/dist/cli/commands/list.js +26 -24
- package/dist/cli/commands/list.js.map +1 -1
- package/dist/cli/commands/plugin.d.ts +23 -6
- package/dist/cli/commands/plugin.d.ts.map +1 -1
- package/dist/cli/commands/plugin.js +92 -66
- package/dist/cli/commands/plugin.js.map +1 -1
- package/dist/core/i18n/language-detector.d.ts +29 -0
- package/dist/core/i18n/language-detector.d.ts.map +1 -0
- package/dist/core/i18n/language-detector.js +143 -0
- package/dist/core/i18n/language-detector.js.map +1 -0
- package/dist/core/i18n/language-manager.d.ts +101 -0
- package/dist/core/i18n/language-manager.d.ts.map +1 -0
- package/dist/core/i18n/language-manager.js +232 -0
- package/dist/core/i18n/language-manager.js.map +1 -0
- package/dist/core/i18n/language-registry.d.ts +44 -0
- package/dist/core/i18n/language-registry.d.ts.map +1 -0
- package/dist/core/i18n/language-registry.js +234 -0
- package/dist/core/i18n/language-registry.js.map +1 -0
- package/dist/core/i18n/locale-manager.d.ts +62 -0
- package/dist/core/i18n/locale-manager.d.ts.map +1 -0
- package/dist/core/i18n/locale-manager.js +137 -0
- package/dist/core/i18n/locale-manager.js.map +1 -0
- package/dist/core/i18n/system-prompt-injector.d.ts +33 -0
- package/dist/core/i18n/system-prompt-injector.d.ts.map +1 -0
- package/dist/core/i18n/system-prompt-injector.js +131 -0
- package/dist/core/i18n/system-prompt-injector.js.map +1 -0
- package/dist/core/i18n/types.d.ts +151 -0
- package/dist/core/i18n/types.d.ts.map +1 -0
- package/dist/core/i18n/types.js +11 -0
- package/dist/core/i18n/types.js.map +1 -0
- package/dist/core/increment-status.d.ts +72 -0
- package/dist/core/increment-status.d.ts.map +1 -0
- package/dist/core/increment-status.js +227 -0
- package/dist/core/increment-status.js.map +1 -0
- package/dist/core/plugin-loader.d.ts +33 -13
- package/dist/core/plugin-loader.d.ts.map +1 -1
- package/dist/core/plugin-loader.js +145 -43
- package/dist/core/plugin-loader.js.map +1 -1
- package/dist/core/types/config.d.ts +51 -0
- package/dist/core/types/config.d.ts.map +1 -0
- package/dist/core/types/config.js +21 -0
- package/dist/core/types/config.js.map +1 -0
- package/dist/core/types/plugin.d.ts +73 -42
- package/dist/core/types/plugin.d.ts.map +1 -1
- package/dist/core/types/plugin.js +4 -3
- package/dist/core/types/plugin.js.map +1 -1
- package/dist/hooks/lib/sync-living-docs.d.ts +27 -0
- package/dist/hooks/lib/sync-living-docs.d.ts.map +1 -0
- package/dist/hooks/lib/sync-living-docs.js +116 -0
- package/dist/hooks/lib/sync-living-docs.js.map +1 -0
- package/dist/hooks/lib/translate-living-docs.d.ts +13 -0
- package/dist/hooks/lib/translate-living-docs.d.ts.map +1 -0
- package/dist/hooks/lib/translate-living-docs.js +166 -0
- package/dist/hooks/lib/translate-living-docs.js.map +1 -0
- package/dist/hooks/lib/update-tasks-md.d.ts +29 -0
- package/dist/hooks/lib/update-tasks-md.d.ts.map +1 -0
- package/dist/hooks/lib/update-tasks-md.js +203 -0
- package/dist/hooks/lib/update-tasks-md.js.map +1 -0
- package/dist/integrations/jira/jira-incremental-mapper.js.map +1 -1
- package/dist/integrations/jira/jira-mapper.js.map +1 -1
- package/dist/locales/de/.gitkeep +0 -0
- package/dist/locales/de/cli.json +108 -0
- package/dist/locales/en/cli.json +285 -0
- package/dist/locales/en/errors.json +7 -0
- package/dist/locales/en/templates.json +6 -0
- package/dist/locales/es/.gitkeep +0 -0
- package/dist/locales/es/cli.json +41 -0
- package/dist/locales/fr/.gitkeep +0 -0
- package/dist/locales/fr/cli.json +108 -0
- package/dist/locales/ja/.gitkeep +0 -0
- package/dist/locales/ja/cli.json +108 -0
- package/dist/locales/ko/.gitkeep +0 -0
- package/dist/locales/ko/cli.json +108 -0
- package/dist/locales/pt/.gitkeep +0 -0
- package/dist/locales/pt/cli.json +108 -0
- package/dist/locales/ru/.gitkeep +0 -0
- package/dist/locales/ru/cli.json +269 -0
- package/dist/locales/zh/.gitkeep +0 -0
- package/dist/locales/zh/cli.json +108 -0
- package/dist/plugins/specweave-github/lib/github-client.d.ts +86 -0
- package/dist/plugins/specweave-github/lib/github-client.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/github-client.js +275 -0
- package/dist/plugins/specweave-github/lib/github-client.js.map +1 -0
- package/dist/plugins/specweave-github/lib/index.d.ts +10 -0
- package/dist/plugins/specweave-github/lib/index.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/index.js +10 -0
- package/dist/plugins/specweave-github/lib/index.js.map +1 -0
- package/dist/plugins/specweave-github/lib/subtask-sync.d.ts +51 -0
- package/dist/plugins/specweave-github/lib/subtask-sync.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/subtask-sync.js +147 -0
- package/dist/plugins/specweave-github/lib/subtask-sync.js.map +1 -0
- package/dist/plugins/specweave-github/lib/task-parser.d.ts +37 -0
- package/dist/plugins/specweave-github/lib/task-parser.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/task-parser.js +211 -0
- package/dist/plugins/specweave-github/lib/task-parser.js.map +1 -0
- package/dist/plugins/specweave-github/lib/task-sync.d.ts +51 -0
- package/dist/plugins/specweave-github/lib/task-sync.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/task-sync.js +332 -0
- package/dist/plugins/specweave-github/lib/task-sync.js.map +1 -0
- package/dist/plugins/specweave-github/lib/types.d.ts +80 -0
- package/dist/plugins/specweave-github/lib/types.d.ts.map +1 -0
- package/dist/plugins/specweave-github/lib/types.js +5 -0
- package/dist/plugins/specweave-github/lib/types.js.map +1 -0
- package/dist/utils/agents-md-compiler.d.ts +68 -0
- package/dist/utils/agents-md-compiler.d.ts.map +1 -0
- package/dist/utils/agents-md-compiler.js +420 -0
- package/dist/utils/agents-md-compiler.js.map +1 -0
- package/dist/utils/execFileNoThrow.d.ts +97 -0
- package/dist/utils/execFileNoThrow.d.ts.map +1 -0
- package/dist/utils/execFileNoThrow.js +130 -0
- package/dist/utils/execFileNoThrow.js.map +1 -0
- package/dist/utils/generate-skills-index.js +4 -4
- package/dist/utils/generate-skills-index.js.map +1 -1
- package/package.json +13 -14
- package/plugins/.specweave/logs/hooks-debug.log +24 -0
- package/plugins/.specweave/logs/last-hook-fire +1 -0
- package/plugins/.specweave/logs/last-todowrite-time +1 -0
- package/plugins/.specweave/logs/tasks.log +6 -0
- package/plugins/specweave/.claude-plugin/plugin.json +22 -0
- package/{src ā plugins/specweave}/agents/pm/AGENT.md +80 -0
- package/plugins/specweave/agents/translator/AGENT.md +282 -0
- package/{src ā plugins/specweave}/commands/README.md +11 -11
- package/{src/commands/specweave.costs.md ā plugins/specweave/commands/costs.md} +8 -8
- package/{src/commands/specweave.do.md ā plugins/specweave/commands/do.md} +35 -8
- package/{src/commands/specweave.done.md ā plugins/specweave/commands/done.md} +1 -1
- package/{src/commands/specweave.inc.md ā plugins/specweave/commands/inc.md} +1 -1
- package/{src/commands/specweave.increment.md ā plugins/specweave/commands/increment.md} +84 -19
- package/{src/commands/specweave.next.md ā plugins/specweave/commands/next.md} +1 -1
- package/{src/commands/specweave.progress.md ā plugins/specweave/commands/progress.md} +1 -1
- package/{src ā plugins/specweave}/commands/specweave.md +57 -25
- package/{src/commands/specweave.sync-docs.md ā plugins/specweave/commands/sync-docs.md} +6 -6
- package/plugins/specweave/commands/translate.md +425 -0
- package/{src/commands/specweave.validate.md ā plugins/specweave/commands/validate.md} +2 -2
- package/plugins/specweave/hooks/hooks.json +15 -0
- package/plugins/specweave/hooks/post-task-completion.sh +265 -0
- package/plugins/specweave/skills/SKILLS-INDEX.md +229 -0
- package/{src ā plugins/specweave}/skills/brownfield-analyzer/SKILL.md +66 -24
- package/{src ā plugins/specweave}/skills/context-loader/SKILL.md +1 -1
- package/plugins/specweave/skills/context-optimizer/SKILL.md +588 -0
- package/plugins/specweave/skills/docs-updater/SKILL.md +0 -0
- package/{src ā plugins/specweave}/skills/increment-planner/SKILL.md +81 -4
- package/plugins/specweave/skills/plugin-detector/SKILL.md +211 -0
- package/{src ā plugins/specweave}/skills/project-kickstarter/SKILL.md +7 -7
- package/plugins/specweave/skills/rfc-generator/SKILL.md +369 -0
- package/{src ā plugins/specweave}/skills/specweave-detector/SKILL.md +2 -2
- package/plugins/specweave/skills/specweave-framework/SKILL.md +498 -0
- package/plugins/specweave/skills/specweave-framework/test-cases/test-1-increment-naming.yaml +11 -0
- package/plugins/specweave/skills/specweave-framework/test-cases/test-2-source-of-truth.yaml +11 -0
- package/plugins/specweave/skills/specweave-framework/test-cases/test-3-increment-discipline.yaml +12 -0
- package/plugins/specweave/skills/specweave-framework/test-cases/test-4-file-placement.yaml +11 -0
- package/{src ā plugins/specweave}/skills/tdd-workflow/SKILL.md +21 -21
- package/plugins/specweave/skills/translator/SKILL.md +172 -0
- package/plugins/specweave-ado/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-alternatives/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-alternatives/skills/bmad-method-expert/SKILL.md +626 -0
- package/plugins/specweave-alternatives/skills/bmad-method-expert/scripts/analyze-project.js +318 -0
- package/plugins/specweave-alternatives/skills/bmad-method-expert/scripts/check-setup.js +208 -0
- package/plugins/specweave-alternatives/skills/bmad-method-expert/scripts/generate-template.js +1149 -0
- package/plugins/specweave-alternatives/skills/bmad-method-expert/scripts/validate-documents.js +340 -0
- package/plugins/specweave-alternatives/skills/spec-kit-expert/SKILL.md +1010 -0
- package/plugins/specweave-backend/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-cost-optimizer/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-diagrams/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-docs/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-docs/skills/docusaurus/SKILL.md +526 -0
- package/plugins/specweave-figma/.claude-plugin/.mcp.json +12 -0
- package/plugins/specweave-figma/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-figma/ARCHITECTURE.md +453 -0
- package/plugins/specweave-figma/README.md +728 -0
- package/plugins/specweave-figma/skills/figma-to-code/SKILL.md +632 -0
- package/plugins/specweave-figma/skills/figma-to-code/test-1-token-generation.yaml +29 -0
- package/plugins/specweave-figma/skills/figma-to-code/test-2-component-generation.yaml +27 -0
- package/plugins/specweave-figma/skills/figma-to-code/test-3-typescript-generation.yaml +28 -0
- package/plugins/specweave-frontend/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-github/.claude-plugin/plugin.json +19 -0
- package/plugins/specweave-github/agents/github-manager/AGENT.md +651 -0
- package/plugins/specweave-github/commands/github-close-issue.md +418 -0
- package/plugins/specweave-github/commands/github-create-issue.md +307 -0
- package/plugins/specweave-github/commands/github-status.md +533 -0
- package/plugins/specweave-github/commands/github-sync-tasks.md +530 -0
- package/plugins/specweave-github/commands/github-sync.md +443 -0
- package/plugins/specweave-github/lib/github-client.ts +330 -0
- package/plugins/specweave-github/lib/index.ts +10 -0
- package/plugins/specweave-github/lib/subtask-sync.ts +225 -0
- package/plugins/specweave-github/lib/task-parser.ts +246 -0
- package/plugins/specweave-github/lib/task-sync.ts +402 -0
- package/plugins/specweave-github/lib/types.ts +86 -0
- package/plugins/specweave-github/skills/github-issue-tracker/SKILL.md +497 -0
- package/plugins/specweave-github/skills/github-sync/SKILL.md +461 -0
- package/plugins/specweave-infrastructure/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-jira/.claude-plugin/plugin.json +8 -0
- package/{src ā plugins/specweave-jira}/commands/specweave.sync-jira.md +18 -18
- package/plugins/specweave-kubernetes/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-ml/.claude-plugin/plugin.json +38 -0
- package/plugins/specweave-ml/README.md +885 -0
- package/plugins/specweave-ml/agents/ml-engineer/AGENT.md +402 -0
- package/plugins/specweave-ml/commands/ml-deploy.md +116 -0
- package/plugins/specweave-ml/commands/ml-evaluate.md +87 -0
- package/plugins/specweave-ml/commands/ml-explain.md +83 -0
- package/plugins/specweave-ml/skills/anomaly-detector/SKILL.md +559 -0
- package/plugins/specweave-ml/skills/automl-optimizer/SKILL.md +485 -0
- package/plugins/specweave-ml/skills/cv-pipeline-builder/SKILL.md +157 -0
- package/plugins/specweave-ml/skills/data-visualizer/SKILL.md +521 -0
- package/plugins/specweave-ml/skills/experiment-tracker/SKILL.md +535 -0
- package/plugins/specweave-ml/skills/feature-engineer/SKILL.md +566 -0
- package/plugins/specweave-ml/skills/ml-deployment-helper/SKILL.md +345 -0
- package/plugins/specweave-ml/skills/ml-pipeline-orchestrator/SKILL.md +518 -0
- package/plugins/specweave-ml/skills/model-evaluator/SKILL.md +155 -0
- package/plugins/specweave-ml/skills/model-explainer/SKILL.md +227 -0
- package/plugins/specweave-ml/skills/model-registry/SKILL.md +541 -0
- package/plugins/specweave-ml/skills/nlp-pipeline-builder/SKILL.md +180 -0
- package/plugins/specweave-ml/skills/time-series-forecaster/SKILL.md +569 -0
- package/plugins/specweave-payments/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-testing/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-tooling/.claude-plugin/plugin.json +8 -0
- package/plugins/specweave-ui/.claude-plugin/plugin.json +26 -0
- package/plugins/specweave-ui/.mcp.json +14 -0
- package/plugins/specweave-ui/README.md +386 -0
- package/src/adapters/claude/adapter.ts +193 -46
- package/src/adapters/copilot/adapter.ts +132 -7
- package/src/adapters/cursor/adapter.ts +62 -3
- package/src/adapters/generic/adapter.ts +62 -3
- package/src/templates/AGENTS.md.template +170 -1
- package/src/templates/CLAUDE.md.template +122 -24
- package/src/templates/tasks.md.template +261 -0
- package/src/agents/ml-engineer/AGENT.md +0 -150
- package/src/commands/specweave.sync-github.md +0 -269
- package/src/hooks/post-task-completion.sh +0 -121
- package/src/skills/SKILLS-INDEX.md +0 -444
- package/src/skills/github-sync/SKILL.md +0 -234
- /package/{src ā plugins/specweave}/agents/architect/AGENT.md +0 -0
- /package/{src ā plugins/specweave}/agents/code-reviewer.md +0 -0
- /package/{src ā plugins/specweave}/agents/docs-writer/AGENT.md +0 -0
- /package/{src ā plugins/specweave}/agents/performance/AGENT.md +0 -0
- /package/{src ā plugins/specweave}/agents/qa-lead/AGENT.md +0 -0
- /package/{src ā plugins/specweave}/agents/security/AGENT.md +0 -0
- /package/{src ā plugins/specweave}/agents/tdd-orchestrator/AGENT.md +0 -0
- /package/{src ā plugins/specweave}/agents/tech-lead/AGENT.md +0 -0
- /package/{src/commands/specweave.list-increments.md ā plugins/specweave/commands/list-increments.md} +0 -0
- /package/{src/commands/specweave.tdd-cycle.md ā plugins/specweave/commands/tdd-cycle.md} +0 -0
- /package/{src/commands/specweave.tdd-green.md ā plugins/specweave/commands/tdd-green.md} +0 -0
- /package/{src/commands/specweave.tdd-red.md ā plugins/specweave/commands/tdd-red.md} +0 -0
- /package/{src/commands/specweave.tdd-refactor.md ā plugins/specweave/commands/tdd-refactor.md} +0 -0
- /package/{src ā plugins/specweave}/hooks/README.md +0 -0
- /package/{src ā plugins/specweave}/hooks/docs-changed.sh +0 -0
- /package/{src ā plugins/specweave}/hooks/human-input-required.sh +0 -0
- /package/{src ā plugins/specweave}/hooks/post-increment-plugin-detect.sh +0 -0
- /package/{src ā plugins/specweave}/hooks/pre-implementation.sh +0 -0
- /package/{src ā plugins/specweave}/hooks/pre-task-plugin-detect.sh +0 -0
- /package/{src ā plugins/specweave}/skills/brownfield-onboarder/SKILL.md +0 -0
- /package/{src ā plugins/specweave}/skills/docs-updater/README.md +0 -0
- /package/{src ā plugins/specweave}/skills/increment-planner/scripts/feature-utils.js +0 -0
- /package/{src ā plugins/specweave}/skills/increment-quality-judge/SKILL.md +0 -0
- /package/{src ā plugins/specweave}/skills/project-kickstarter/test-cases/test-1-high-confidence-full-product.yaml +0 -0
- /package/{src ā plugins/specweave}/skills/project-kickstarter/test-cases/test-2-medium-confidence-partial.yaml +0 -0
- /package/{src ā plugins/specweave}/skills/project-kickstarter/test-cases/test-3-low-confidence-technical-question.yaml +0 -0
- /package/{src ā plugins/specweave}/skills/project-kickstarter/test-cases/test-4-opt-out-explicit.yaml +0 -0
- /package/{src ā plugins/specweave}/skills/role-orchestrator/README.md +0 -0
- /package/{src ā plugins/specweave}/skills/role-orchestrator/SKILL.md +0 -0
- /package/{src ā plugins/specweave}/skills/task-builder/README.md +0 -0
- /package/{src ā plugins/specweave-ado}/skills/ado-sync/README.md +0 -0
- /package/{src ā plugins/specweave-ado}/skills/ado-sync/SKILL.md +0 -0
- /package/{src ā plugins/specweave-ado}/skills/specweave-ado-mapper/SKILL.md +0 -0
- /package/{src ā plugins/specweave-backend}/agents/database-optimizer/AGENT.md +0 -0
- /package/{src ā plugins/specweave-backend}/skills/dotnet-backend/SKILL.md +0 -0
- /package/{src ā plugins/specweave-backend}/skills/nodejs-backend/SKILL.md +0 -0
- /package/{src ā plugins/specweave-backend}/skills/python-backend/SKILL.md +0 -0
- /package/{src ā plugins/specweave-cost-optimizer}/skills/cost-optimizer/SKILL.md +0 -0
- /package/{src ā plugins/specweave-diagrams}/agents/diagrams-architect/AGENT.md +0 -0
- /package/{src ā plugins/specweave-diagrams}/agents/diagrams-architect/templates/c4-component-template.mmd +0 -0
- /package/{src ā plugins/specweave-diagrams}/agents/diagrams-architect/templates/c4-container-template.mmd +0 -0
- /package/{src ā plugins/specweave-diagrams}/agents/diagrams-architect/templates/c4-context-template.mmd +0 -0
- /package/{src ā plugins/specweave-diagrams}/agents/diagrams-architect/templates/deployment-template.mmd +0 -0
- /package/{src ā plugins/specweave-diagrams}/agents/diagrams-architect/templates/er-diagram-template.mmd +0 -0
- /package/{src ā plugins/specweave-diagrams}/agents/diagrams-architect/templates/sequence-template.mmd +0 -0
- /package/{src ā plugins/specweave-diagrams}/agents/diagrams-architect/test-cases/test-1-c4-context.yaml +0 -0
- /package/{src ā plugins/specweave-diagrams}/agents/diagrams-architect/test-cases/test-2-sequence.yaml +0 -0
- /package/{src ā plugins/specweave-diagrams}/agents/diagrams-architect/test-cases/test-3-er-diagram.yaml +0 -0
- /package/{src ā plugins/specweave-diagrams}/skills/diagrams-architect/SKILL.md +0 -0
- /package/{src ā plugins/specweave-diagrams}/skills/diagrams-generator/SKILL.md +0 -0
- /package/{src ā plugins/specweave-docs}/skills/spec-driven-brainstorming/README.md +0 -0
- /package/{src ā plugins/specweave-docs}/skills/spec-driven-brainstorming/SKILL.md +0 -0
- /package/{src ā plugins/specweave-docs}/skills/spec-driven-debugging/README.md +0 -0
- /package/{src ā plugins/specweave-docs}/skills/spec-driven-debugging/SKILL.md +0 -0
- /package/{src ā plugins/specweave-frontend}/skills/design-system-architect/SKILL.md +0 -0
- /package/{src ā plugins/specweave-frontend}/skills/frontend/SKILL.md +0 -0
- /package/{src ā plugins/specweave-frontend}/skills/nextjs/SKILL.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/devops/AGENT.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/network-engineer/AGENT.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/observability-engineer/AGENT.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/performance-engineer/AGENT.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/AGENT.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/modules/backend-diagnostics.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/modules/database-diagnostics.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/modules/infrastructure.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/modules/monitoring.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/modules/security-incidents.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/modules/ui-diagnostics.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/playbooks/01-high-cpu-usage.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/playbooks/02-database-deadlock.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/playbooks/03-memory-leak.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/playbooks/04-slow-api-response.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/playbooks/05-ddos-attack.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/playbooks/06-disk-full.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/playbooks/07-service-down.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/playbooks/08-data-corruption.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/playbooks/09-cascade-failure.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/playbooks/10-rate-limit-exceeded.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/scripts/health-check.sh +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/scripts/log-analyzer.py +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/scripts/metrics-collector.sh +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/scripts/trace-analyzer.js +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/templates/incident-report.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/templates/mitigation-plan.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/templates/post-mortem.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/agents/sre/templates/runbook-template.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/commands/specweave.monitor-setup.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/commands/specweave.slo-implement.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/skills/distributed-tracing/SKILL.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/skills/grafana-dashboards/SKILL.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/skills/hetzner-provisioner/README.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/skills/hetzner-provisioner/SKILL.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/skills/prometheus-configuration/SKILL.md +0 -0
- /package/{src ā plugins/specweave-infrastructure}/skills/slo-implementation/SKILL.md +0 -0
- /package/{src ā plugins/specweave-jira}/skills/jira-sync/README.md +0 -0
- /package/{src ā plugins/specweave-jira}/skills/jira-sync/SKILL.md +0 -0
- /package/{src ā plugins/specweave-jira}/skills/specweave-jira-mapper/SKILL.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/agents/kubernetes-architect/AGENT.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/gitops-workflow/SKILL.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/gitops-workflow/references/argocd-setup.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/gitops-workflow/references/sync-policies.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/helm-chart-scaffolding/SKILL.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/helm-chart-scaffolding/assets/Chart.yaml.template +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/helm-chart-scaffolding/assets/values.yaml.template +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/helm-chart-scaffolding/references/chart-structure.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/helm-chart-scaffolding/scripts/validate-chart.sh +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/k8s-manifest-generator/SKILL.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/k8s-manifest-generator/assets/configmap-template.yaml +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/k8s-manifest-generator/assets/deployment-template.yaml +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/k8s-manifest-generator/assets/service-template.yaml +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/k8s-manifest-generator/references/deployment-spec.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/k8s-manifest-generator/references/service-spec.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/k8s-security-policies/SKILL.md +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/k8s-security-policies/assets/network-policy-template.yaml +0 -0
- /package/{src ā plugins/specweave-kubernetes}/skills/k8s-security-policies/references/rbac-patterns.md +0 -0
- /package/{src ā plugins/specweave-ml}/agents/data-scientist/AGENT.md +0 -0
- /package/{src ā plugins/specweave-ml}/agents/mlops-engineer/AGENT.md +0 -0
- /package/{src ā plugins/specweave-ml}/commands/specweave.ml-pipeline.md +0 -0
- /package/{src ā plugins/specweave-ml}/skills/ml-pipeline-workflow/SKILL.md +0 -0
- /package/{src ā plugins/specweave-payments}/agents/payment-integration/AGENT.md +0 -0
- /package/{src ā plugins/specweave-payments}/skills/billing-automation/SKILL.md +0 -0
- /package/{src ā plugins/specweave-payments}/skills/paypal-integration/SKILL.md +0 -0
- /package/{src ā plugins/specweave-payments}/skills/pci-compliance/SKILL.md +0 -0
- /package/{src ā plugins/specweave-payments}/skills/stripe-integration/SKILL.md +0 -0
- /package/{src ā plugins/specweave-testing}/skills/e2e-playwright/README.md +0 -0
- /package/{src ā plugins/specweave-testing}/skills/e2e-playwright/SKILL.md +0 -0
- /package/{src ā plugins/specweave-testing}/skills/e2e-playwright/execute.js +0 -0
- /package/{src ā plugins/specweave-testing}/skills/e2e-playwright/lib/utils.js +0 -0
- /package/{src ā plugins/specweave-testing}/skills/e2e-playwright/package.json +0 -0
- /package/{src ā plugins/specweave-tooling}/skills/skill-creator/LICENSE.txt +0 -0
- /package/{src ā plugins/specweave-tooling}/skills/skill-creator/SKILL.md +0 -0
- /package/{src ā plugins/specweave-tooling}/skills/skill-creator/scripts/init_skill.py +0 -0
- /package/{src ā plugins/specweave-tooling}/skills/skill-creator/scripts/package_skill.py +0 -0
- /package/{src ā plugins/specweave-tooling}/skills/skill-creator/scripts/quick_validate.py +0 -0
- /package/{src ā plugins/specweave-tooling}/skills/skill-router/SKILL.md +0 -0
package/plugins/specweave-alternatives/skills/bmad-method-expert/scripts/validate-documents.js
ADDED
|
@@ -0,0 +1,340 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* BMAD Document Validator
|
|
5
|
+
*
|
|
6
|
+
* Validates alignment between PRD and Architecture documents
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
const fs = require('fs');
|
|
10
|
+
const path = require('path');
|
|
11
|
+
|
|
12
|
+
class DocumentValidator {
|
|
13
|
+
constructor(projectPath = process.cwd()) {
|
|
14
|
+
this.projectPath = projectPath;
|
|
15
|
+
this.issues = [];
|
|
16
|
+
this.warnings = [];
|
|
17
|
+
this.successes = [];
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
readDocument(relativePath) {
|
|
21
|
+
try {
|
|
22
|
+
const fullPath = path.join(this.projectPath, relativePath);
|
|
23
|
+
return fs.readFileSync(fullPath, 'utf-8');
|
|
24
|
+
} catch (error) {
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
extractSections(markdown) {
|
|
30
|
+
const sections = [];
|
|
31
|
+
const lines = markdown.split('\n');
|
|
32
|
+
let currentSection = null;
|
|
33
|
+
let currentContent = [];
|
|
34
|
+
|
|
35
|
+
for (const line of lines) {
|
|
36
|
+
const headerMatch = line.match(/^(#+)\s+(.+)$/);
|
|
37
|
+
|
|
38
|
+
if (headerMatch) {
|
|
39
|
+
if (currentSection) {
|
|
40
|
+
sections.push({
|
|
41
|
+
level: currentSection.level,
|
|
42
|
+
title: currentSection.title,
|
|
43
|
+
content: currentContent.join('\n')
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
currentSection = {
|
|
48
|
+
level: headerMatch[1].length,
|
|
49
|
+
title: headerMatch[2].trim()
|
|
50
|
+
};
|
|
51
|
+
currentContent = [];
|
|
52
|
+
} else if (currentSection) {
|
|
53
|
+
currentContent.push(line);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
if (currentSection) {
|
|
58
|
+
sections.push({
|
|
59
|
+
level: currentSection.level,
|
|
60
|
+
title: currentSection.title,
|
|
61
|
+
content: currentContent.join('\n')
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
return sections;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
extractFeatures(content) {
|
|
69
|
+
const features = [];
|
|
70
|
+
const lines = content.split('\n');
|
|
71
|
+
|
|
72
|
+
for (const line of lines) {
|
|
73
|
+
// Look for feature headings
|
|
74
|
+
if (/^#{3,4}\s+(Feature|Epic|Story).*:/i.test(line)) {
|
|
75
|
+
features.push(line.replace(/^#+\s+/, '').trim());
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return features;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
extractTechnologies(content) {
|
|
83
|
+
const technologies = new Set();
|
|
84
|
+
const techPatterns = [
|
|
85
|
+
/React/gi, /Vue/gi, /Angular/gi, /Node\.js/gi, /Python/gi,
|
|
86
|
+
/PostgreSQL/gi, /MongoDB/gi, /MySQL/gi, /Redis/gi,
|
|
87
|
+
/Express/gi, /FastAPI/gi, /Django/gi, /Flask/gi,
|
|
88
|
+
/TypeScript/gi, /JavaScript/gi, /Go/gi, /Java/gi,
|
|
89
|
+
/Docker/gi, /Kubernetes/gi, /AWS/gi, /Azure/gi, /GCP/gi,
|
|
90
|
+
/REST/gi, /GraphQL/gi, /gRPC/gi
|
|
91
|
+
];
|
|
92
|
+
|
|
93
|
+
techPatterns.forEach(pattern => {
|
|
94
|
+
const matches = content.match(pattern);
|
|
95
|
+
if (matches) {
|
|
96
|
+
matches.forEach(match => technologies.add(match));
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
return Array.from(technologies);
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
validatePRD(prdContent) {
|
|
104
|
+
console.log('\nš Validating PRD Structure...\n');
|
|
105
|
+
|
|
106
|
+
const sections = this.extractSections(prdContent);
|
|
107
|
+
const sectionTitles = sections.map(s => s.title.toLowerCase());
|
|
108
|
+
|
|
109
|
+
// Required PRD sections
|
|
110
|
+
const requiredSections = [
|
|
111
|
+
{ name: 'project overview', aliases: ['overview', 'executive summary'] },
|
|
112
|
+
{ name: 'functional requirements', aliases: ['requirements', 'features'] },
|
|
113
|
+
{ name: 'non-functional requirements', aliases: ['nfr', 'quality attributes'] },
|
|
114
|
+
{ name: 'user stories', aliases: ['stories'] }
|
|
115
|
+
];
|
|
116
|
+
|
|
117
|
+
requiredSections.forEach(req => {
|
|
118
|
+
const found = sectionTitles.some(title =>
|
|
119
|
+
title.includes(req.name) || req.aliases.some(alias => title.includes(alias))
|
|
120
|
+
);
|
|
121
|
+
|
|
122
|
+
if (found) {
|
|
123
|
+
this.successes.push(`ā PRD has '${req.name}' section`);
|
|
124
|
+
} else {
|
|
125
|
+
this.warnings.push(`ā PRD missing '${req.name}' section`);
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
// Check for epics
|
|
130
|
+
const hasEpics = /##\s*Epics?/i.test(prdContent);
|
|
131
|
+
if (hasEpics) {
|
|
132
|
+
this.successes.push('ā PRD contains Epics section');
|
|
133
|
+
} else {
|
|
134
|
+
this.warnings.push('ā PRD should include Epics section');
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// Check document length
|
|
138
|
+
if (prdContent.length < 2000) {
|
|
139
|
+
this.warnings.push('ā PRD seems short (<2KB) - ensure comprehensive coverage');
|
|
140
|
+
} else {
|
|
141
|
+
this.successes.push(`ā PRD has substantial content (${(prdContent.length / 1024).toFixed(1)}KB)`);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
// Extract features
|
|
145
|
+
const features = this.extractFeatures(prdContent);
|
|
146
|
+
if (features.length > 0) {
|
|
147
|
+
this.successes.push(`ā PRD defines ${features.length} feature(s)/epic(s)`);
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
return features;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
validateArchitecture(archContent) {
|
|
154
|
+
console.log('\nšļø Validating Architecture Document...\n');
|
|
155
|
+
|
|
156
|
+
const sections = this.extractSections(archContent);
|
|
157
|
+
const sectionTitles = sections.map(s => s.title.toLowerCase());
|
|
158
|
+
|
|
159
|
+
// Required Architecture sections
|
|
160
|
+
const requiredSections = [
|
|
161
|
+
{ name: 'architecture overview', aliases: ['overview', 'system overview'] },
|
|
162
|
+
{ name: 'technology stack', aliases: ['tech stack', 'technologies'] },
|
|
163
|
+
{ name: 'system components', aliases: ['components', 'modules'] },
|
|
164
|
+
{ name: 'data architecture', aliases: ['data model', 'database schema', 'data design'] },
|
|
165
|
+
{ name: 'api design', aliases: ['api', 'endpoints', 'api specification'] },
|
|
166
|
+
{ name: 'security', aliases: ['security architecture', 'authentication'] }
|
|
167
|
+
];
|
|
168
|
+
|
|
169
|
+
requiredSections.forEach(req => {
|
|
170
|
+
const found = sectionTitles.some(title =>
|
|
171
|
+
title.includes(req.name) || req.aliases.some(alias => title.includes(alias))
|
|
172
|
+
);
|
|
173
|
+
|
|
174
|
+
if (found) {
|
|
175
|
+
this.successes.push(`ā Architecture has '${req.name}' section`);
|
|
176
|
+
} else {
|
|
177
|
+
this.warnings.push(`ā Architecture missing '${req.name}' section`);
|
|
178
|
+
}
|
|
179
|
+
});
|
|
180
|
+
|
|
181
|
+
// Check document length
|
|
182
|
+
if (archContent.length < 1500) {
|
|
183
|
+
this.warnings.push('ā Architecture seems short (<1.5KB) - ensure detailed design');
|
|
184
|
+
} else {
|
|
185
|
+
this.successes.push(`ā Architecture has substantial content (${(archContent.length / 1024).toFixed(1)}KB)`);
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
// Extract technologies
|
|
189
|
+
const technologies = this.extractTechnologies(archContent);
|
|
190
|
+
if (technologies.length > 0) {
|
|
191
|
+
this.successes.push(`ā Architecture specifies ${technologies.length} technology(ies): ${technologies.slice(0, 5).join(', ')}${technologies.length > 5 ? '...' : ''}`);
|
|
192
|
+
} else {
|
|
193
|
+
this.warnings.push('ā Architecture should explicitly list technologies used');
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
return technologies;
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
validateAlignment(prdContent, archContent, prdFeatures, archTechnologies) {
|
|
200
|
+
console.log('\nš Validating PRD-Architecture Alignment...\n');
|
|
201
|
+
|
|
202
|
+
// Check if PRD features are mentioned in Architecture
|
|
203
|
+
if (prdFeatures.length > 0) {
|
|
204
|
+
const featuresMentioned = prdFeatures.filter(feature => {
|
|
205
|
+
// Extract key terms from feature name
|
|
206
|
+
const terms = feature.toLowerCase().split(/\s+/).filter(t => t.length > 3);
|
|
207
|
+
return terms.some(term => archContent.toLowerCase().includes(term));
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
if (featuresMentioned.length > 0) {
|
|
211
|
+
this.successes.push(`ā ${featuresMentioned.length}/${prdFeatures.length} PRD features referenced in Architecture`);
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
if (featuresMentioned.length < prdFeatures.length) {
|
|
215
|
+
const unreferenced = prdFeatures.filter(f => !featuresMentioned.includes(f));
|
|
216
|
+
this.warnings.push(`ā ${unreferenced.length} PRD feature(s) not clearly referenced in Architecture`);
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
// Check if Architecture technologies align with PRD constraints
|
|
221
|
+
const prdMentionsTech = /technology|tech stack|framework|language|database/i.test(prdContent);
|
|
222
|
+
const archDefinesTech = archTechnologies.length > 0;
|
|
223
|
+
|
|
224
|
+
if (prdMentionsTech && !archDefinesTech) {
|
|
225
|
+
this.warnings.push('ā PRD mentions technology but Architecture doesn\'t specify tech stack');
|
|
226
|
+
} else if (archDefinesTech) {
|
|
227
|
+
this.successes.push('ā Architecture defines technology stack');
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
// Check for API definitions
|
|
231
|
+
const prdHasAPI = /api|endpoint|rest|graphql/i.test(prdContent);
|
|
232
|
+
const archHasAPI = /api|endpoint|rest|graphql/i.test(archContent);
|
|
233
|
+
|
|
234
|
+
if (prdHasAPI && !archHasAPI) {
|
|
235
|
+
this.warnings.push('ā PRD mentions APIs but Architecture lacks API design section');
|
|
236
|
+
} else if (prdHasAPI && archHasAPI) {
|
|
237
|
+
this.successes.push('ā Both PRD and Architecture address API design');
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
// Check for data/database mentions
|
|
241
|
+
const prdHasData = /database|data model|schema|entity|table/i.test(prdContent);
|
|
242
|
+
const archHasData = /database|data model|schema|entity|table/i.test(archContent);
|
|
243
|
+
|
|
244
|
+
if (prdHasData && !archHasData) {
|
|
245
|
+
this.warnings.push('ā PRD mentions data but Architecture lacks data model section');
|
|
246
|
+
} else if (prdHasData && archHasData) {
|
|
247
|
+
this.successes.push('ā Both PRD and Architecture address data design');
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
// Check for security mentions
|
|
251
|
+
const prdHasSecurity = /security|authentication|authorization|auth/i.test(prdContent);
|
|
252
|
+
const archHasSecurity = /security|authentication|authorization|auth/i.test(archContent);
|
|
253
|
+
|
|
254
|
+
if (prdHasSecurity && !archHasSecurity) {
|
|
255
|
+
this.warnings.push('ā PRD has security requirements but Architecture lacks security design');
|
|
256
|
+
} else if (prdHasSecurity && archHasSecurity) {
|
|
257
|
+
this.successes.push('ā Both PRD and Architecture address security');
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
|
|
261
|
+
generateReport() {
|
|
262
|
+
console.log('\nāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā');
|
|
263
|
+
console.log(' BMAD DOCUMENT VALIDATION REPORT');
|
|
264
|
+
console.log('āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā');
|
|
265
|
+
console.log(`\nProject Path: ${this.projectPath}\n`);
|
|
266
|
+
|
|
267
|
+
const prdPath = 'docs/prd.md';
|
|
268
|
+
const archPath = 'docs/architecture.md';
|
|
269
|
+
|
|
270
|
+
const prdContent = this.readDocument(prdPath);
|
|
271
|
+
const archContent = this.readDocument(archPath);
|
|
272
|
+
|
|
273
|
+
if (!prdContent) {
|
|
274
|
+
this.issues.push('ā PRD not found at docs/prd.md');
|
|
275
|
+
console.log('ā Cannot proceed - PRD not found\n');
|
|
276
|
+
console.log('Create a PRD using: node generate-template.js prd\n');
|
|
277
|
+
return;
|
|
278
|
+
}
|
|
279
|
+
|
|
280
|
+
if (!archContent) {
|
|
281
|
+
this.issues.push('ā Architecture document not found at docs/architecture.md');
|
|
282
|
+
console.log('ā Cannot proceed - Architecture document not found\n');
|
|
283
|
+
console.log('Create an Architecture document using: node generate-template.js architecture\n');
|
|
284
|
+
return;
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
const prdFeatures = this.validatePRD(prdContent);
|
|
288
|
+
const archTechnologies = this.validateArchitecture(archContent);
|
|
289
|
+
this.validateAlignment(prdContent, archContent, prdFeatures, archTechnologies);
|
|
290
|
+
|
|
291
|
+
// Print results
|
|
292
|
+
if (this.issues.length > 0) {
|
|
293
|
+
console.log('\nšØ CRITICAL ISSUES:\n');
|
|
294
|
+
this.issues.forEach(issue => console.log(` ${issue}`));
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
if (this.warnings.length > 0) {
|
|
298
|
+
console.log('\nā ļø WARNINGS:\n');
|
|
299
|
+
this.warnings.forEach(warning => console.log(` ${warning}`));
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
if (this.successes.length > 0) {
|
|
303
|
+
console.log('\nā
VALIDATIONS PASSED:\n');
|
|
304
|
+
this.successes.forEach(success => console.log(` ${success}`));
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
console.log('\nāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā');
|
|
308
|
+
|
|
309
|
+
const totalChecks = this.issues.length + this.warnings.length + this.successes.length;
|
|
310
|
+
const passRate = totalChecks > 0 ? ((this.successes.length / totalChecks) * 100).toFixed(1) : 0;
|
|
311
|
+
|
|
312
|
+
if (this.issues.length === 0 && this.warnings.length === 0) {
|
|
313
|
+
console.log(' ā ALL VALIDATIONS PASSED');
|
|
314
|
+
} else if (this.issues.length === 0) {
|
|
315
|
+
console.log(` VALIDATION SCORE: ${passRate}%`);
|
|
316
|
+
} else {
|
|
317
|
+
console.log(' ā CRITICAL ISSUES DETECTED');
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
console.log('āāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāāā\n');
|
|
321
|
+
|
|
322
|
+
if (this.issues.length === 0 && this.warnings.length === 0) {
|
|
323
|
+
console.log('š Documents are well-aligned and ready for development!\n');
|
|
324
|
+
console.log('Next steps:');
|
|
325
|
+
console.log(' 1. Use @po to shard documents into epics/stories');
|
|
326
|
+
console.log(' 2. Move to IDE for development phase');
|
|
327
|
+
console.log(' 3. Use @scrum to draft first story\n');
|
|
328
|
+
} else if (this.warnings.length > 0 && this.issues.length === 0) {
|
|
329
|
+
console.log('š Documents need minor improvements. Consider:');
|
|
330
|
+
console.log(' 1. Addressing warnings above');
|
|
331
|
+
console.log(' 2. Using @po to validate alignment');
|
|
332
|
+
console.log(' 3. Refining PRD or Architecture as needed\n');
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
// Main execution
|
|
338
|
+
const projectPath = process.argv[2] || process.cwd();
|
|
339
|
+
const validator = new DocumentValidator(projectPath);
|
|
340
|
+
validator.generateReport();
|