raptor-aios 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +26 -0
- package/LICENSE +21 -0
- package/README.md +315 -0
- package/bin/raptor.js +5 -0
- package/dist/_core/dist/agents/adapters/antigravity.d.ts +9 -0
- package/dist/_core/dist/agents/adapters/antigravity.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/antigravity.js +72 -0
- package/dist/_core/dist/agents/adapters/antigravity.js.map +1 -0
- package/dist/_core/dist/agents/adapters/claude-code.d.ts +9 -0
- package/dist/_core/dist/agents/adapters/claude-code.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/claude-code.js +71 -0
- package/dist/_core/dist/agents/adapters/claude-code.js.map +1 -0
- package/dist/_core/dist/agents/adapters/codex.d.ts +12 -0
- package/dist/_core/dist/agents/adapters/codex.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/codex.js +69 -0
- package/dist/_core/dist/agents/adapters/codex.js.map +1 -0
- package/dist/_core/dist/agents/adapters/copilot.d.ts +12 -0
- package/dist/_core/dist/agents/adapters/copilot.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/copilot.js +71 -0
- package/dist/_core/dist/agents/adapters/copilot.js.map +1 -0
- package/dist/_core/dist/agents/adapters/cursor.d.ts +9 -0
- package/dist/_core/dist/agents/adapters/cursor.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/cursor.js +62 -0
- package/dist/_core/dist/agents/adapters/cursor.js.map +1 -0
- package/dist/_core/dist/agents/adapters/gemini.d.ts +11 -0
- package/dist/_core/dist/agents/adapters/gemini.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/gemini.js +68 -0
- package/dist/_core/dist/agents/adapters/gemini.js.map +1 -0
- package/dist/_core/dist/agents/adapters/human.d.ts +10 -0
- package/dist/_core/dist/agents/adapters/human.d.ts.map +1 -0
- package/dist/_core/dist/agents/adapters/human.js +48 -0
- package/dist/_core/dist/agents/adapters/human.js.map +1 -0
- package/dist/_core/dist/agents/artifact-watcher.d.ts +86 -0
- package/dist/_core/dist/agents/artifact-watcher.d.ts.map +1 -0
- package/dist/_core/dist/agents/artifact-watcher.js +214 -0
- package/dist/_core/dist/agents/artifact-watcher.js.map +1 -0
- package/dist/_core/dist/agents/backup.d.ts +69 -0
- package/dist/_core/dist/agents/backup.d.ts.map +1 -0
- package/dist/_core/dist/agents/backup.js +107 -0
- package/dist/_core/dist/agents/backup.js.map +1 -0
- package/dist/_core/dist/agents/config.d.ts +36 -0
- package/dist/_core/dist/agents/config.d.ts.map +1 -0
- package/dist/_core/dist/agents/config.js +270 -0
- package/dist/_core/dist/agents/config.js.map +1 -0
- package/dist/_core/dist/agents/context-file.d.ts +35 -0
- package/dist/_core/dist/agents/context-file.d.ts.map +1 -0
- package/dist/_core/dist/agents/context-file.js +106 -0
- package/dist/_core/dist/agents/context-file.js.map +1 -0
- package/dist/_core/dist/agents/handoff.d.ts +57 -0
- package/dist/_core/dist/agents/handoff.d.ts.map +1 -0
- package/dist/_core/dist/agents/handoff.js +71 -0
- package/dist/_core/dist/agents/handoff.js.map +1 -0
- package/dist/_core/dist/agents/index.d.ts +32 -0
- package/dist/_core/dist/agents/index.d.ts.map +1 -0
- package/dist/_core/dist/agents/index.js +37 -0
- package/dist/_core/dist/agents/index.js.map +1 -0
- package/dist/_core/dist/agents/keys.d.ts +50 -0
- package/dist/_core/dist/agents/keys.d.ts.map +1 -0
- package/dist/_core/dist/agents/keys.js +91 -0
- package/dist/_core/dist/agents/keys.js.map +1 -0
- package/dist/_core/dist/agents/materialize.d.ts +37 -0
- package/dist/_core/dist/agents/materialize.d.ts.map +1 -0
- package/dist/_core/dist/agents/materialize.js +157 -0
- package/dist/_core/dist/agents/materialize.js.map +1 -0
- package/dist/_core/dist/agents/prompt-builder.d.ts +35 -0
- package/dist/_core/dist/agents/prompt-builder.d.ts.map +1 -0
- package/dist/_core/dist/agents/prompt-builder.js +261 -0
- package/dist/_core/dist/agents/prompt-builder.js.map +1 -0
- package/dist/_core/dist/agents/prompt-markers.d.ts +69 -0
- package/dist/_core/dist/agents/prompt-markers.d.ts.map +1 -0
- package/dist/_core/dist/agents/prompt-markers.js +111 -0
- package/dist/_core/dist/agents/prompt-markers.js.map +1 -0
- package/dist/_core/dist/agents/registry.d.ts +35 -0
- package/dist/_core/dist/agents/registry.d.ts.map +1 -0
- package/dist/_core/dist/agents/registry.js +102 -0
- package/dist/_core/dist/agents/registry.js.map +1 -0
- package/dist/_core/dist/agents/selector.d.ts +33 -0
- package/dist/_core/dist/agents/selector.d.ts.map +1 -0
- package/dist/_core/dist/agents/selector.js +120 -0
- package/dist/_core/dist/agents/selector.js.map +1 -0
- package/dist/_core/dist/agents/slash-materializer.d.ts +63 -0
- package/dist/_core/dist/agents/slash-materializer.d.ts.map +1 -0
- package/dist/_core/dist/agents/slash-materializer.js +131 -0
- package/dist/_core/dist/agents/slash-materializer.js.map +1 -0
- package/dist/_core/dist/agents/types.d.ts +121 -0
- package/dist/_core/dist/agents/types.d.ts.map +1 -0
- package/dist/_core/dist/agents/types.js +10 -0
- package/dist/_core/dist/agents/types.js.map +1 -0
- package/dist/_core/dist/audit/hash.d.ts +4 -0
- package/dist/_core/dist/audit/hash.d.ts.map +1 -0
- package/dist/_core/dist/audit/hash.js +12 -0
- package/dist/_core/dist/audit/hash.js.map +1 -0
- package/dist/_core/dist/audit/index.d.ts +6 -0
- package/dist/_core/dist/audit/index.d.ts.map +1 -0
- package/dist/_core/dist/audit/index.js +6 -0
- package/dist/_core/dist/audit/index.js.map +1 -0
- package/dist/_core/dist/audit/logger.d.ts +77 -0
- package/dist/_core/dist/audit/logger.d.ts.map +1 -0
- package/dist/_core/dist/audit/logger.js +93 -0
- package/dist/_core/dist/audit/logger.js.map +1 -0
- package/dist/_core/dist/audit/query.d.ts +13 -0
- package/dist/_core/dist/audit/query.d.ts.map +1 -0
- package/dist/_core/dist/audit/query.js +57 -0
- package/dist/_core/dist/audit/query.js.map +1 -0
- package/dist/_core/dist/audit/schema.d.ts +455 -0
- package/dist/_core/dist/audit/schema.d.ts.map +1 -0
- package/dist/_core/dist/audit/schema.js +341 -0
- package/dist/_core/dist/audit/schema.js.map +1 -0
- package/dist/_core/dist/audit/validate.d.ts +21 -0
- package/dist/_core/dist/audit/validate.d.ts.map +1 -0
- package/dist/_core/dist/audit/validate.js +139 -0
- package/dist/_core/dist/audit/validate.js.map +1 -0
- package/dist/_core/dist/constitution/core.d.ts +22 -0
- package/dist/_core/dist/constitution/core.d.ts.map +1 -0
- package/dist/_core/dist/constitution/core.js +102 -0
- package/dist/_core/dist/constitution/core.js.map +1 -0
- package/dist/_core/dist/constitution/index.d.ts +2 -0
- package/dist/_core/dist/constitution/index.d.ts.map +1 -0
- package/dist/_core/dist/constitution/index.js +2 -0
- package/dist/_core/dist/constitution/index.js.map +1 -0
- package/dist/_core/dist/extensions/index.d.ts +12 -0
- package/dist/_core/dist/extensions/index.d.ts.map +1 -0
- package/dist/_core/dist/extensions/index.js +12 -0
- package/dist/_core/dist/extensions/index.js.map +1 -0
- package/dist/_core/dist/extensions/integrate.d.ts +69 -0
- package/dist/_core/dist/extensions/integrate.d.ts.map +1 -0
- package/dist/_core/dist/extensions/integrate.js +181 -0
- package/dist/_core/dist/extensions/integrate.js.map +1 -0
- package/dist/_core/dist/extensions/loader.d.ts +24 -0
- package/dist/_core/dist/extensions/loader.d.ts.map +1 -0
- package/dist/_core/dist/extensions/loader.js +73 -0
- package/dist/_core/dist/extensions/loader.js.map +1 -0
- package/dist/_core/dist/extensions/manifest.d.ts +23 -0
- package/dist/_core/dist/extensions/manifest.d.ts.map +1 -0
- package/dist/_core/dist/extensions/manifest.js +176 -0
- package/dist/_core/dist/extensions/manifest.js.map +1 -0
- package/dist/_core/dist/extensions/registry.d.ts +32 -0
- package/dist/_core/dist/extensions/registry.d.ts.map +1 -0
- package/dist/_core/dist/extensions/registry.js +57 -0
- package/dist/_core/dist/extensions/registry.js.map +1 -0
- package/dist/_core/dist/extensions/resolver.d.ts +55 -0
- package/dist/_core/dist/extensions/resolver.d.ts.map +1 -0
- package/dist/_core/dist/extensions/resolver.js +143 -0
- package/dist/_core/dist/extensions/resolver.js.map +1 -0
- package/dist/_core/dist/extensions/types.d.ts +173 -0
- package/dist/_core/dist/extensions/types.d.ts.map +1 -0
- package/dist/_core/dist/extensions/types.js +83 -0
- package/dist/_core/dist/extensions/types.js.map +1 -0
- package/dist/_core/dist/frontmatter/index.d.ts +10 -0
- package/dist/_core/dist/frontmatter/index.d.ts.map +1 -0
- package/dist/_core/dist/frontmatter/index.js +24 -0
- package/dist/_core/dist/frontmatter/index.js.map +1 -0
- package/dist/_core/dist/gates/agent-gates.d.ts +16 -0
- package/dist/_core/dist/gates/agent-gates.d.ts.map +1 -0
- package/dist/_core/dist/gates/agent-gates.js +205 -0
- package/dist/_core/dist/gates/agent-gates.js.map +1 -0
- package/dist/_core/dist/gates/builtin.d.ts +18 -0
- package/dist/_core/dist/gates/builtin.d.ts.map +1 -0
- package/dist/_core/dist/gates/builtin.js +860 -0
- package/dist/_core/dist/gates/builtin.js.map +1 -0
- package/dist/_core/dist/gates/index.d.ts +7 -0
- package/dist/_core/dist/gates/index.d.ts.map +1 -0
- package/dist/_core/dist/gates/index.js +7 -0
- package/dist/_core/dist/gates/index.js.map +1 -0
- package/dist/_core/dist/gates/m7-gates.d.ts +17 -0
- package/dist/_core/dist/gates/m7-gates.d.ts.map +1 -0
- package/dist/_core/dist/gates/m7-gates.js +309 -0
- package/dist/_core/dist/gates/m7-gates.js.map +1 -0
- package/dist/_core/dist/gates/phase-gates.d.ts +18 -0
- package/dist/_core/dist/gates/phase-gates.d.ts.map +1 -0
- package/dist/_core/dist/gates/phase-gates.js +275 -0
- package/dist/_core/dist/gates/phase-gates.js.map +1 -0
- package/dist/_core/dist/gates/runner.d.ts +4 -0
- package/dist/_core/dist/gates/runner.d.ts.map +1 -0
- package/dist/_core/dist/gates/runner.js +64 -0
- package/dist/_core/dist/gates/runner.js.map +1 -0
- package/dist/_core/dist/gates/types.d.ts +36 -0
- package/dist/_core/dist/gates/types.d.ts.map +1 -0
- package/dist/_core/dist/gates/types.js +2 -0
- package/dist/_core/dist/gates/types.js.map +1 -0
- package/dist/_core/dist/hooks/index.d.ts +4 -0
- package/dist/_core/dist/hooks/index.d.ts.map +1 -0
- package/dist/_core/dist/hooks/index.js +4 -0
- package/dist/_core/dist/hooks/index.js.map +1 -0
- package/dist/_core/dist/hooks/runner.d.ts +28 -0
- package/dist/_core/dist/hooks/runner.d.ts.map +1 -0
- package/dist/_core/dist/hooks/runner.js +294 -0
- package/dist/_core/dist/hooks/runner.js.map +1 -0
- package/dist/_core/dist/hooks/runtime.d.ts +65 -0
- package/dist/_core/dist/hooks/runtime.d.ts.map +1 -0
- package/dist/_core/dist/hooks/runtime.js +212 -0
- package/dist/_core/dist/hooks/runtime.js.map +1 -0
- package/dist/_core/dist/hooks/types.d.ts +36 -0
- package/dist/_core/dist/hooks/types.d.ts.map +1 -0
- package/dist/_core/dist/hooks/types.js +23 -0
- package/dist/_core/dist/hooks/types.js.map +1 -0
- package/dist/_core/dist/index.d.ts +21 -0
- package/dist/_core/dist/index.d.ts.map +1 -0
- package/dist/_core/dist/index.js +20 -0
- package/dist/_core/dist/index.js.map +1 -0
- package/dist/_core/dist/manifest/index.d.ts +119 -0
- package/dist/_core/dist/manifest/index.d.ts.map +1 -0
- package/dist/_core/dist/manifest/index.js +125 -0
- package/dist/_core/dist/manifest/index.js.map +1 -0
- package/dist/_core/dist/markers/index.d.ts +47 -0
- package/dist/_core/dist/markers/index.d.ts.map +1 -0
- package/dist/_core/dist/markers/index.js +97 -0
- package/dist/_core/dist/markers/index.js.map +1 -0
- package/dist/_core/dist/mcp/config.d.ts +19 -0
- package/dist/_core/dist/mcp/config.d.ts.map +1 -0
- package/dist/_core/dist/mcp/config.js +114 -0
- package/dist/_core/dist/mcp/config.js.map +1 -0
- package/dist/_core/dist/mcp/index.d.ts +9 -0
- package/dist/_core/dist/mcp/index.d.ts.map +1 -0
- package/dist/_core/dist/mcp/index.js +8 -0
- package/dist/_core/dist/mcp/index.js.map +1 -0
- package/dist/_core/dist/mcp/materializer.d.ts +40 -0
- package/dist/_core/dist/mcp/materializer.d.ts.map +1 -0
- package/dist/_core/dist/mcp/materializer.js +161 -0
- package/dist/_core/dist/mcp/materializer.js.map +1 -0
- package/dist/_core/dist/mcp/targets.d.ts +37 -0
- package/dist/_core/dist/mcp/targets.d.ts.map +1 -0
- package/dist/_core/dist/mcp/targets.js +56 -0
- package/dist/_core/dist/mcp/targets.js.map +1 -0
- package/dist/_core/dist/mcp/types.d.ts +34 -0
- package/dist/_core/dist/mcp/types.d.ts.map +1 -0
- package/dist/_core/dist/mcp/types.js +8 -0
- package/dist/_core/dist/mcp/types.js.map +1 -0
- package/dist/_core/dist/models/analyze.d.ts +131 -0
- package/dist/_core/dist/models/analyze.d.ts.map +1 -0
- package/dist/_core/dist/models/analyze.js +301 -0
- package/dist/_core/dist/models/analyze.js.map +1 -0
- package/dist/_core/dist/models/checklist.d.ts +113 -0
- package/dist/_core/dist/models/checklist.d.ts.map +1 -0
- package/dist/_core/dist/models/checklist.js +159 -0
- package/dist/_core/dist/models/checklist.js.map +1 -0
- package/dist/_core/dist/models/clarify.d.ts +116 -0
- package/dist/_core/dist/models/clarify.d.ts.map +1 -0
- package/dist/_core/dist/models/clarify.js +166 -0
- package/dist/_core/dist/models/clarify.js.map +1 -0
- package/dist/_core/dist/models/impl-log.d.ts +64 -0
- package/dist/_core/dist/models/impl-log.d.ts.map +1 -0
- package/dist/_core/dist/models/impl-log.js +137 -0
- package/dist/_core/dist/models/impl-log.js.map +1 -0
- package/dist/_core/dist/models/index.d.ts +8 -0
- package/dist/_core/dist/models/index.d.ts.map +1 -0
- package/dist/_core/dist/models/index.js +8 -0
- package/dist/_core/dist/models/index.js.map +1 -0
- package/dist/_core/dist/models/plan.d.ts +24 -0
- package/dist/_core/dist/models/plan.d.ts.map +1 -0
- package/dist/_core/dist/models/plan.js +15 -0
- package/dist/_core/dist/models/plan.js.map +1 -0
- package/dist/_core/dist/models/spec.d.ts +23 -0
- package/dist/_core/dist/models/spec.d.ts.map +1 -0
- package/dist/_core/dist/models/spec.js +22 -0
- package/dist/_core/dist/models/spec.js.map +1 -0
- package/dist/_core/dist/models/tasks.d.ts +33 -0
- package/dist/_core/dist/models/tasks.d.ts.map +1 -0
- package/dist/_core/dist/models/tasks.js +78 -0
- package/dist/_core/dist/models/tasks.js.map +1 -0
- package/dist/_core/dist/presets/gates.d.ts +9 -0
- package/dist/_core/dist/presets/gates.d.ts.map +1 -0
- package/dist/_core/dist/presets/gates.js +173 -0
- package/dist/_core/dist/presets/gates.js.map +1 -0
- package/dist/_core/dist/presets/index.d.ts +10 -0
- package/dist/_core/dist/presets/index.d.ts.map +1 -0
- package/dist/_core/dist/presets/index.js +7 -0
- package/dist/_core/dist/presets/index.js.map +1 -0
- package/dist/_core/dist/presets/loader.d.ts +56 -0
- package/dist/_core/dist/presets/loader.d.ts.map +1 -0
- package/dist/_core/dist/presets/loader.js +216 -0
- package/dist/_core/dist/presets/loader.js.map +1 -0
- package/dist/_core/dist/presets/mobile-opinionated.d.ts +3 -0
- package/dist/_core/dist/presets/mobile-opinionated.d.ts.map +1 -0
- package/dist/_core/dist/presets/mobile-opinionated.js +78 -0
- package/dist/_core/dist/presets/mobile-opinionated.js.map +1 -0
- package/dist/_core/dist/presets/registry.d.ts +5 -0
- package/dist/_core/dist/presets/registry.d.ts.map +1 -0
- package/dist/_core/dist/presets/registry.js +14 -0
- package/dist/_core/dist/presets/registry.js.map +1 -0
- package/dist/_core/dist/presets/renderer.d.ts +5 -0
- package/dist/_core/dist/presets/renderer.d.ts.map +1 -0
- package/dist/_core/dist/presets/renderer.js +37 -0
- package/dist/_core/dist/presets/renderer.js.map +1 -0
- package/dist/_core/dist/presets/stacking.d.ts +29 -0
- package/dist/_core/dist/presets/stacking.d.ts.map +1 -0
- package/dist/_core/dist/presets/stacking.js +91 -0
- package/dist/_core/dist/presets/stacking.js.map +1 -0
- package/dist/_core/dist/presets/types.d.ts +22 -0
- package/dist/_core/dist/presets/types.d.ts.map +1 -0
- package/dist/_core/dist/presets/types.js +2 -0
- package/dist/_core/dist/presets/types.js.map +1 -0
- package/dist/_core/dist/prompts/audit-log.d.ts +73 -0
- package/dist/_core/dist/prompts/audit-log.d.ts.map +1 -0
- package/dist/_core/dist/prompts/audit-log.js +73 -0
- package/dist/_core/dist/prompts/audit-log.js.map +1 -0
- package/dist/_core/dist/prompts/index.d.ts +9 -0
- package/dist/_core/dist/prompts/index.d.ts.map +1 -0
- package/dist/_core/dist/prompts/index.js +7 -0
- package/dist/_core/dist/prompts/index.js.map +1 -0
- package/dist/_core/dist/prompts/renderer.d.ts +73 -0
- package/dist/_core/dist/prompts/renderer.d.ts.map +1 -0
- package/dist/_core/dist/prompts/renderer.js +179 -0
- package/dist/_core/dist/prompts/renderer.js.map +1 -0
- package/dist/_core/dist/prompts/resumption.d.ts +59 -0
- package/dist/_core/dist/prompts/resumption.d.ts.map +1 -0
- package/dist/_core/dist/prompts/resumption.js +149 -0
- package/dist/_core/dist/prompts/resumption.js.map +1 -0
- package/dist/_core/dist/skills/config.d.ts +27 -0
- package/dist/_core/dist/skills/config.d.ts.map +1 -0
- package/dist/_core/dist/skills/config.js +102 -0
- package/dist/_core/dist/skills/config.js.map +1 -0
- package/dist/_core/dist/skills/index.d.ts +9 -0
- package/dist/_core/dist/skills/index.d.ts.map +1 -0
- package/dist/_core/dist/skills/index.js +8 -0
- package/dist/_core/dist/skills/index.js.map +1 -0
- package/dist/_core/dist/skills/materializer.d.ts +45 -0
- package/dist/_core/dist/skills/materializer.d.ts.map +1 -0
- package/dist/_core/dist/skills/materializer.js +97 -0
- package/dist/_core/dist/skills/materializer.js.map +1 -0
- package/dist/_core/dist/skills/registry.d.ts +18 -0
- package/dist/_core/dist/skills/registry.d.ts.map +1 -0
- package/dist/_core/dist/skills/registry.js +36 -0
- package/dist/_core/dist/skills/registry.js.map +1 -0
- package/dist/_core/dist/skills/types.d.ts +39 -0
- package/dist/_core/dist/skills/types.d.ts.map +1 -0
- package/dist/_core/dist/skills/types.js +13 -0
- package/dist/_core/dist/skills/types.js.map +1 -0
- package/dist/_core/dist/state/feature.d.ts +58 -0
- package/dist/_core/dist/state/feature.d.ts.map +1 -0
- package/dist/_core/dist/state/feature.js +81 -0
- package/dist/_core/dist/state/feature.js.map +1 -0
- package/dist/_core/dist/state/index.d.ts +8 -0
- package/dist/_core/dist/state/index.d.ts.map +1 -0
- package/dist/_core/dist/state/index.js +6 -0
- package/dist/_core/dist/state/index.js.map +1 -0
- package/dist/_core/dist/state/init-options.d.ts +60 -0
- package/dist/_core/dist/state/init-options.d.ts.map +1 -0
- package/dist/_core/dist/state/init-options.js +74 -0
- package/dist/_core/dist/state/init-options.js.map +1 -0
- package/dist/_core/dist/template/engine.d.ts +7 -0
- package/dist/_core/dist/template/engine.d.ts.map +1 -0
- package/dist/_core/dist/template/engine.js +86 -0
- package/dist/_core/dist/template/engine.js.map +1 -0
- package/dist/_core/dist/template/helpers.d.ts +5 -0
- package/dist/_core/dist/template/helpers.d.ts.map +1 -0
- package/dist/_core/dist/template/helpers.js +59 -0
- package/dist/_core/dist/template/helpers.js.map +1 -0
- package/dist/_core/dist/template/index.d.ts +6 -0
- package/dist/_core/dist/template/index.d.ts.map +1 -0
- package/dist/_core/dist/template/index.js +6 -0
- package/dist/_core/dist/template/index.js.map +1 -0
- package/dist/_core/dist/template/loader.d.ts +36 -0
- package/dist/_core/dist/template/loader.d.ts.map +1 -0
- package/dist/_core/dist/template/loader.js +62 -0
- package/dist/_core/dist/template/loader.js.map +1 -0
- package/dist/_core/dist/template/parser.d.ts +3 -0
- package/dist/_core/dist/template/parser.d.ts.map +1 -0
- package/dist/_core/dist/template/parser.js +234 -0
- package/dist/_core/dist/template/parser.js.map +1 -0
- package/dist/_core/dist/template/types.d.ts +40 -0
- package/dist/_core/dist/template/types.d.ts.map +1 -0
- package/dist/_core/dist/template/types.js +14 -0
- package/dist/_core/dist/template/types.js.map +1 -0
- package/dist/_core/dist/verify/a11y.d.ts +36 -0
- package/dist/_core/dist/verify/a11y.d.ts.map +1 -0
- package/dist/_core/dist/verify/a11y.js +153 -0
- package/dist/_core/dist/verify/a11y.js.map +1 -0
- package/dist/_core/dist/verify/architecture.d.ts +37 -0
- package/dist/_core/dist/verify/architecture.d.ts.map +1 -0
- package/dist/_core/dist/verify/architecture.js +113 -0
- package/dist/_core/dist/verify/architecture.js.map +1 -0
- package/dist/_core/dist/verify/index.d.ts +10 -0
- package/dist/_core/dist/verify/index.d.ts.map +1 -0
- package/dist/_core/dist/verify/index.js +10 -0
- package/dist/_core/dist/verify/index.js.map +1 -0
- package/dist/_core/dist/verify/os-matrix.d.ts +35 -0
- package/dist/_core/dist/verify/os-matrix.d.ts.map +1 -0
- package/dist/_core/dist/verify/os-matrix.js +104 -0
- package/dist/_core/dist/verify/os-matrix.js.map +1 -0
- package/dist/_core/dist/verify/perf.d.ts +43 -0
- package/dist/_core/dist/verify/perf.d.ts.map +1 -0
- package/dist/_core/dist/verify/perf.js +69 -0
- package/dist/_core/dist/verify/perf.js.map +1 -0
- package/dist/_core/dist/verify/stores.d.ts +38 -0
- package/dist/_core/dist/verify/stores.d.ts.map +1 -0
- package/dist/_core/dist/verify/stores.js +57 -0
- package/dist/_core/dist/verify/stores.js.map +1 -0
- package/dist/_core/dist/version.d.ts +8 -0
- package/dist/_core/dist/version.d.ts.map +1 -0
- package/dist/_core/dist/version.js +11 -0
- package/dist/_core/dist/version.js.map +1 -0
- package/dist/_core/dist/workflows/bundled.d.ts +32 -0
- package/dist/_core/dist/workflows/bundled.d.ts.map +1 -0
- package/dist/_core/dist/workflows/bundled.js +254 -0
- package/dist/_core/dist/workflows/bundled.js.map +1 -0
- package/dist/_core/dist/workflows/engine.d.ts +74 -0
- package/dist/_core/dist/workflows/engine.d.ts.map +1 -0
- package/dist/_core/dist/workflows/engine.js +574 -0
- package/dist/_core/dist/workflows/engine.js.map +1 -0
- package/dist/_core/dist/workflows/expressions.d.ts +48 -0
- package/dist/_core/dist/workflows/expressions.d.ts.map +1 -0
- package/dist/_core/dist/workflows/expressions.js +336 -0
- package/dist/_core/dist/workflows/expressions.js.map +1 -0
- package/dist/_core/dist/workflows/index.d.ts +16 -0
- package/dist/_core/dist/workflows/index.d.ts.map +1 -0
- package/dist/_core/dist/workflows/index.js +15 -0
- package/dist/_core/dist/workflows/index.js.map +1 -0
- package/dist/_core/dist/workflows/parser.d.ts +38 -0
- package/dist/_core/dist/workflows/parser.d.ts.map +1 -0
- package/dist/_core/dist/workflows/parser.js +386 -0
- package/dist/_core/dist/workflows/parser.js.map +1 -0
- package/dist/_core/dist/workflows/sdd-flow.d.ts +85 -0
- package/dist/_core/dist/workflows/sdd-flow.d.ts.map +1 -0
- package/dist/_core/dist/workflows/sdd-flow.js +269 -0
- package/dist/_core/dist/workflows/sdd-flow.js.map +1 -0
- package/dist/_core/dist/workflows/types.d.ts +285 -0
- package/dist/_core/dist/workflows/types.d.ts.map +1 -0
- package/dist/_core/dist/workflows/types.js +13 -0
- package/dist/_core/dist/workflows/types.js.map +1 -0
- package/dist/_core/package.json +6 -0
- package/dist/_core/templates/constitution.md.hbs +46 -0
- package/dist/_core/templates/ghaWorkflow.yml.hbs +58 -0
- package/dist/_core/templates/hotfix.md.hbs +39 -0
- package/dist/_core/templates/plan.md.hbs +212 -0
- package/dist/_core/templates/preCommitHook.sh.hbs +30 -0
- package/dist/_core/templates/prePushHook.sh.hbs +45 -0
- package/dist/_core/templates/raptor.yml.hbs +24 -0
- package/dist/_core/templates/spec.md.hbs +127 -0
- package/dist/_core/templates/tasks.md.hbs +71 -0
- package/dist/commands/add-agent.d.ts +22 -0
- package/dist/commands/add-agent.d.ts.map +1 -0
- package/dist/commands/add-agent.js +121 -0
- package/dist/commands/add-agent.js.map +1 -0
- package/dist/commands/add-extension.d.ts +18 -0
- package/dist/commands/add-extension.d.ts.map +1 -0
- package/dist/commands/add-extension.js +83 -0
- package/dist/commands/add-extension.js.map +1 -0
- package/dist/commands/analyze.d.ts +18 -0
- package/dist/commands/analyze.d.ts.map +1 -0
- package/dist/commands/analyze.js +323 -0
- package/dist/commands/analyze.js.map +1 -0
- package/dist/commands/approve.d.ts +14 -0
- package/dist/commands/approve.d.ts.map +1 -0
- package/dist/commands/approve.js +116 -0
- package/dist/commands/approve.js.map +1 -0
- package/dist/commands/audit/query.d.ts +23 -0
- package/dist/commands/audit/query.d.ts.map +1 -0
- package/dist/commands/audit/query.js +118 -0
- package/dist/commands/audit/query.js.map +1 -0
- package/dist/commands/audit/show.d.ts +17 -0
- package/dist/commands/audit/show.d.ts.map +1 -0
- package/dist/commands/audit/show.js +53 -0
- package/dist/commands/audit/show.js.map +1 -0
- package/dist/commands/checklist.d.ts +17 -0
- package/dist/commands/checklist.d.ts.map +1 -0
- package/dist/commands/checklist.js +255 -0
- package/dist/commands/checklist.js.map +1 -0
- package/dist/commands/clarify.d.ts +17 -0
- package/dist/commands/clarify.d.ts.map +1 -0
- package/dist/commands/clarify.js +254 -0
- package/dist/commands/clarify.js.map +1 -0
- package/dist/commands/doctor.d.ts +8 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +435 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/extension/add.d.ts +15 -0
- package/dist/commands/extension/add.d.ts.map +1 -0
- package/dist/commands/extension/add.js +93 -0
- package/dist/commands/extension/add.js.map +1 -0
- package/dist/commands/extension/info.d.ts +13 -0
- package/dist/commands/extension/info.d.ts.map +1 -0
- package/dist/commands/extension/info.js +75 -0
- package/dist/commands/extension/info.js.map +1 -0
- package/dist/commands/extension/list.d.ts +10 -0
- package/dist/commands/extension/list.d.ts.map +1 -0
- package/dist/commands/extension/list.js +71 -0
- package/dist/commands/extension/list.js.map +1 -0
- package/dist/commands/extension/remove.d.ts +14 -0
- package/dist/commands/extension/remove.d.ts.map +1 -0
- package/dist/commands/extension/remove.js +49 -0
- package/dist/commands/extension/remove.js.map +1 -0
- package/dist/commands/gate/approve.d.ts +15 -0
- package/dist/commands/gate/approve.d.ts.map +1 -0
- package/dist/commands/gate/approve.js +106 -0
- package/dist/commands/gate/approve.js.map +1 -0
- package/dist/commands/gate/list.d.ts +6 -0
- package/dist/commands/gate/list.d.ts.map +1 -0
- package/dist/commands/gate/list.js +38 -0
- package/dist/commands/gate/list.js.map +1 -0
- package/dist/commands/gate/skip.d.ts +14 -0
- package/dist/commands/gate/skip.d.ts.map +1 -0
- package/dist/commands/gate/skip.js +95 -0
- package/dist/commands/gate/skip.js.map +1 -0
- package/dist/commands/hook/list.d.ts +11 -0
- package/dist/commands/hook/list.d.ts.map +1 -0
- package/dist/commands/hook/list.js +152 -0
- package/dist/commands/hook/list.js.map +1 -0
- package/dist/commands/hook/run.d.ts +16 -0
- package/dist/commands/hook/run.d.ts.map +1 -0
- package/dist/commands/hook/run.js +74 -0
- package/dist/commands/hook/run.js.map +1 -0
- package/dist/commands/hotfix.d.ts +21 -0
- package/dist/commands/hotfix.d.ts.map +1 -0
- package/dist/commands/hotfix.js +216 -0
- package/dist/commands/hotfix.js.map +1 -0
- package/dist/commands/implement.d.ts +19 -0
- package/dist/commands/implement.d.ts.map +1 -0
- package/dist/commands/implement.js +282 -0
- package/dist/commands/implement.js.map +1 -0
- package/dist/commands/init.d.ts +43 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +465 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/list-agents.d.ts +12 -0
- package/dist/commands/list-agents.d.ts.map +1 -0
- package/dist/commands/list-agents.js +55 -0
- package/dist/commands/list-agents.js.map +1 -0
- package/dist/commands/mcp/add.d.ts +21 -0
- package/dist/commands/mcp/add.d.ts.map +1 -0
- package/dist/commands/mcp/add.js +119 -0
- package/dist/commands/mcp/add.js.map +1 -0
- package/dist/commands/mcp/list.d.ts +10 -0
- package/dist/commands/mcp/list.d.ts.map +1 -0
- package/dist/commands/mcp/list.js +54 -0
- package/dist/commands/mcp/list.js.map +1 -0
- package/dist/commands/mcp/remove.d.ts +10 -0
- package/dist/commands/mcp/remove.d.ts.map +1 -0
- package/dist/commands/mcp/remove.js +53 -0
- package/dist/commands/mcp/remove.js.map +1 -0
- package/dist/commands/mcp/sync.d.ts +7 -0
- package/dist/commands/mcp/sync.d.ts.map +1 -0
- package/dist/commands/mcp/sync.js +31 -0
- package/dist/commands/mcp/sync.js.map +1 -0
- package/dist/commands/new.d.ts +19 -0
- package/dist/commands/new.d.ts.map +1 -0
- package/dist/commands/new.js +306 -0
- package/dist/commands/new.js.map +1 -0
- package/dist/commands/plan.d.ts +17 -0
- package/dist/commands/plan.d.ts.map +1 -0
- package/dist/commands/plan.js +200 -0
- package/dist/commands/plan.js.map +1 -0
- package/dist/commands/preset/add.d.ts +13 -0
- package/dist/commands/preset/add.d.ts.map +1 -0
- package/dist/commands/preset/add.js +66 -0
- package/dist/commands/preset/add.js.map +1 -0
- package/dist/commands/preset/info.d.ts +13 -0
- package/dist/commands/preset/info.d.ts.map +1 -0
- package/dist/commands/preset/info.js +80 -0
- package/dist/commands/preset/info.js.map +1 -0
- package/dist/commands/preset/list.d.ts +10 -0
- package/dist/commands/preset/list.d.ts.map +1 -0
- package/dist/commands/preset/list.js +63 -0
- package/dist/commands/preset/list.js.map +1 -0
- package/dist/commands/preset/remove.d.ts +14 -0
- package/dist/commands/preset/remove.d.ts.map +1 -0
- package/dist/commands/preset/remove.js +60 -0
- package/dist/commands/preset/remove.js.map +1 -0
- package/dist/commands/repair/constitution.d.ts +11 -0
- package/dist/commands/repair/constitution.d.ts.map +1 -0
- package/dist/commands/repair/constitution.js +117 -0
- package/dist/commands/repair/constitution.js.map +1 -0
- package/dist/commands/resync.d.ts +22 -0
- package/dist/commands/resync.d.ts.map +1 -0
- package/dist/commands/resync.js +103 -0
- package/dist/commands/resync.js.map +1 -0
- package/dist/commands/skill/add.d.ts +19 -0
- package/dist/commands/skill/add.d.ts.map +1 -0
- package/dist/commands/skill/add.js +107 -0
- package/dist/commands/skill/add.js.map +1 -0
- package/dist/commands/skill/list.d.ts +10 -0
- package/dist/commands/skill/list.d.ts.map +1 -0
- package/dist/commands/skill/list.js +56 -0
- package/dist/commands/skill/list.js.map +1 -0
- package/dist/commands/skill/remove.d.ts +10 -0
- package/dist/commands/skill/remove.d.ts.map +1 -0
- package/dist/commands/skill/remove.js +47 -0
- package/dist/commands/skill/remove.js.map +1 -0
- package/dist/commands/skill/sync.d.ts +7 -0
- package/dist/commands/skill/sync.d.ts.map +1 -0
- package/dist/commands/skill/sync.js +30 -0
- package/dist/commands/skill/sync.js.map +1 -0
- package/dist/commands/status.d.ts +17 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +265 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/tasks.d.ts +16 -0
- package/dist/commands/tasks.d.ts.map +1 -0
- package/dist/commands/tasks.js +176 -0
- package/dist/commands/tasks.js.map +1 -0
- package/dist/commands/trace.d.ts +16 -0
- package/dist/commands/trace.d.ts.map +1 -0
- package/dist/commands/trace.js +113 -0
- package/dist/commands/trace.js.map +1 -0
- package/dist/commands/upgrade.d.ts +20 -0
- package/dist/commands/upgrade.d.ts.map +1 -0
- package/dist/commands/upgrade.js +178 -0
- package/dist/commands/upgrade.js.map +1 -0
- package/dist/commands/verify/a11y.d.ts +15 -0
- package/dist/commands/verify/a11y.d.ts.map +1 -0
- package/dist/commands/verify/a11y.js +121 -0
- package/dist/commands/verify/a11y.js.map +1 -0
- package/dist/commands/verify/architecture.d.ts +11 -0
- package/dist/commands/verify/architecture.d.ts.map +1 -0
- package/dist/commands/verify/architecture.js +71 -0
- package/dist/commands/verify/architecture.js.map +1 -0
- package/dist/commands/verify/audit.d.ts +18 -0
- package/dist/commands/verify/audit.d.ts.map +1 -0
- package/dist/commands/verify/audit.js +108 -0
- package/dist/commands/verify/audit.js.map +1 -0
- package/dist/commands/verify/constitution.d.ts +10 -0
- package/dist/commands/verify/constitution.d.ts.map +1 -0
- package/dist/commands/verify/constitution.js +91 -0
- package/dist/commands/verify/constitution.js.map +1 -0
- package/dist/commands/verify/os-matrix.d.ts +14 -0
- package/dist/commands/verify/os-matrix.d.ts.map +1 -0
- package/dist/commands/verify/os-matrix.js +108 -0
- package/dist/commands/verify/os-matrix.js.map +1 -0
- package/dist/commands/verify/perf.d.ts +17 -0
- package/dist/commands/verify/perf.d.ts.map +1 -0
- package/dist/commands/verify/perf.js +106 -0
- package/dist/commands/verify/perf.js.map +1 -0
- package/dist/commands/verify/stores.d.ts +14 -0
- package/dist/commands/verify/stores.d.ts.map +1 -0
- package/dist/commands/verify/stores.js +98 -0
- package/dist/commands/verify/stores.js.map +1 -0
- package/dist/commands/verify.d.ts +14 -0
- package/dist/commands/verify.d.ts.map +1 -0
- package/dist/commands/verify.js +97 -0
- package/dist/commands/verify.js.map +1 -0
- package/dist/commands/workflow/catalog.d.ts +11 -0
- package/dist/commands/workflow/catalog.d.ts.map +1 -0
- package/dist/commands/workflow/catalog.js +164 -0
- package/dist/commands/workflow/catalog.js.map +1 -0
- package/dist/commands/workflow/list.d.ts +7 -0
- package/dist/commands/workflow/list.d.ts.map +1 -0
- package/dist/commands/workflow/list.js +50 -0
- package/dist/commands/workflow/list.js.map +1 -0
- package/dist/commands/workflow/resume.d.ts +13 -0
- package/dist/commands/workflow/resume.d.ts.map +1 -0
- package/dist/commands/workflow/resume.js +126 -0
- package/dist/commands/workflow/resume.js.map +1 -0
- package/dist/commands/workflow/run.d.ts +14 -0
- package/dist/commands/workflow/run.d.ts.map +1 -0
- package/dist/commands/workflow/run.js +139 -0
- package/dist/commands/workflow/run.js.map +1 -0
- package/dist/commands/workflow/status.d.ts +10 -0
- package/dist/commands/workflow/status.d.ts.map +1 -0
- package/dist/commands/workflow/status.js +86 -0
- package/dist/commands/workflow/status.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/shared/agents.d.ts +12 -0
- package/dist/shared/agents.d.ts.map +1 -0
- package/dist/shared/agents.js +31 -0
- package/dist/shared/agents.js.map +1 -0
- package/dist/shared/artifact-io.d.ts +54 -0
- package/dist/shared/artifact-io.d.ts.map +1 -0
- package/dist/shared/artifact-io.js +71 -0
- package/dist/shared/artifact-io.js.map +1 -0
- package/dist/shared/feature-prompt.d.ts +18 -0
- package/dist/shared/feature-prompt.d.ts.map +1 -0
- package/dist/shared/feature-prompt.js +21 -0
- package/dist/shared/feature-prompt.js.map +1 -0
- package/dist/shared/hooks.d.ts +7 -0
- package/dist/shared/hooks.d.ts.map +1 -0
- package/dist/shared/hooks.js +52 -0
- package/dist/shared/hooks.js.map +1 -0
- package/dist/shared/mcp.d.ts +9 -0
- package/dist/shared/mcp.d.ts.map +1 -0
- package/dist/shared/mcp.js +15 -0
- package/dist/shared/mcp.js.map +1 -0
- package/dist/shared/project.d.ts +42 -0
- package/dist/shared/project.d.ts.map +1 -0
- package/dist/shared/project.js +98 -0
- package/dist/shared/project.js.map +1 -0
- package/dist/shared/workflow-resolver.d.ts +19 -0
- package/dist/shared/workflow-resolver.d.ts.map +1 -0
- package/dist/shared/workflow-resolver.js +71 -0
- package/dist/shared/workflow-resolver.js.map +1 -0
- package/dist/workflow/args-builder.d.ts +31 -0
- package/dist/workflow/args-builder.d.ts.map +1 -0
- package/dist/workflow/args-builder.js +110 -0
- package/dist/workflow/args-builder.js.map +1 -0
- package/dist/workflow/executor.d.ts +18 -0
- package/dist/workflow/executor.d.ts.map +1 -0
- package/dist/workflow/executor.js +112 -0
- package/dist/workflow/executor.js.map +1 -0
- package/extensions/git/commands/rpt.git.feature.md +85 -0
- package/extensions/git/extension.yml +47 -0
- package/package.json +58 -0
- package/scripts/bash/check-prerequisites.sh +149 -0
- package/scripts/bash/common.sh +389 -0
- package/scripts/bash/create-new-feature.sh +164 -0
- package/scripts/bash/setup-plan.sh +113 -0
- package/scripts/check-naming.sh +138 -0
- package/scripts/check-prompts.sh +165 -0
- package/scripts/check-tasks.sh +166 -0
- package/scripts/powershell/check-prerequisites.ps1 +117 -0
- package/scripts/powershell/common.ps1 +328 -0
- package/scripts/powershell/create-new-feature.ps1 +138 -0
- package/scripts/powershell/setup-plan.ps1 +96 -0
- package/scripts/prepare-npm.mjs +157 -0
- package/templates/checklist-template.md +103 -0
- package/templates/commands/analyze.md +103 -0
- package/templates/commands/checklist.md +87 -0
- package/templates/commands/clarify.md +85 -0
- package/templates/commands/constitution.md +126 -0
- package/templates/commands/implement.md +117 -0
- package/templates/commands/plan.md +125 -0
- package/templates/commands/specify.md +127 -0
- package/templates/commands/tasks.md +98 -0
- package/templates/commands/taskstoissues.md +81 -0
- package/templates/constitution-template.md +48 -0
- package/templates/plan-template.md +150 -0
- package/templates/spec-template.md +116 -0
- package/templates/tasks-template.md +77 -0
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { Args, Command, Flags } from '@oclif/core';
|
|
2
|
+
import { existsSync, readFileSync, writeFileSync } from 'node:fs';
|
|
3
|
+
import { basename, join } from 'node:path';
|
|
4
|
+
import { appendAuditEvent, hashString, updateFrontmatter } from '../_core/dist/index.js';
|
|
5
|
+
import { currentActor, featureDir, requireProjectRoot } from '../shared/project.js';
|
|
6
|
+
import { runAfterHook, runBeforeHook } from '../shared/hooks.js';
|
|
7
|
+
const ARTIFACTS = ['spec', 'plan', 'tasks'];
|
|
8
|
+
export default class Approve extends Command {
|
|
9
|
+
static description = 'Mark a feature artifact as approved (spec, plan, or tasks). Required by C3 before tasks/implement.';
|
|
10
|
+
static examples = [
|
|
11
|
+
'<%= config.bin %> approve login-biometrico --artifact=spec',
|
|
12
|
+
'<%= config.bin %> approve login-biometrico --artifact=plan --phase-minus-one=passed',
|
|
13
|
+
'<%= config.bin %> approve login-biometrico --artifact=tasks',
|
|
14
|
+
];
|
|
15
|
+
static args = {
|
|
16
|
+
feature: Args.string({
|
|
17
|
+
description: 'Feature slug or NNN-slug',
|
|
18
|
+
required: true,
|
|
19
|
+
}),
|
|
20
|
+
};
|
|
21
|
+
static flags = {
|
|
22
|
+
artifact: Flags.string({
|
|
23
|
+
description: 'Which artifact to approve',
|
|
24
|
+
options: [...ARTIFACTS],
|
|
25
|
+
required: true,
|
|
26
|
+
}),
|
|
27
|
+
'phase-minus-one': Flags.string({
|
|
28
|
+
description: '(plan only) Phase -1 outcome: passed | justified | violated',
|
|
29
|
+
options: ['passed', 'justified', 'violated'],
|
|
30
|
+
}),
|
|
31
|
+
};
|
|
32
|
+
async run() {
|
|
33
|
+
const { args, flags } = await this.parse(Approve);
|
|
34
|
+
const root = requireProjectRoot();
|
|
35
|
+
const dir = featureDir(root, args.feature);
|
|
36
|
+
const featureName = basename(dir);
|
|
37
|
+
const artifact = flags.artifact;
|
|
38
|
+
const path = join(dir, `${artifact}.md`);
|
|
39
|
+
if (!existsSync(path))
|
|
40
|
+
this.error(`${artifact}.md missing at ${path}`);
|
|
41
|
+
const actor = currentActor('human');
|
|
42
|
+
runBeforeHook(this, {
|
|
43
|
+
event: 'before_approve',
|
|
44
|
+
command: `raptor approve ${args.feature} --artifact=${artifact}`,
|
|
45
|
+
projectRoot: root,
|
|
46
|
+
feature: featureName,
|
|
47
|
+
featureDir: dir,
|
|
48
|
+
actor: { user: actor.email ?? actor.user, via: actor.via },
|
|
49
|
+
extra: { artifact, ...(flags['phase-minus-one'] ? { phase_minus_one: flags['phase-minus-one'] } : {}) },
|
|
50
|
+
});
|
|
51
|
+
if (artifact === 'plan' && !actor.email) {
|
|
52
|
+
this.error('C5 violation: plan approval is a critical gate and requires an identifiable human approver. ' +
|
|
53
|
+
'No git user.email detected — set `git config user.email` before approving plans.');
|
|
54
|
+
}
|
|
55
|
+
if ((artifact === 'spec' || artifact === 'tasks') && !actor.email) {
|
|
56
|
+
this.warn(`No git user.email detected. ${artifact} approval is non-critical but identifiable approvers are recommended.`);
|
|
57
|
+
}
|
|
58
|
+
const raw = readFileSync(path, 'utf8');
|
|
59
|
+
const now = new Date().toISOString();
|
|
60
|
+
let patch = { status: 'approved' };
|
|
61
|
+
if (artifact === 'plan') {
|
|
62
|
+
const pmone = flags['phase-minus-one'];
|
|
63
|
+
if (!pmone) {
|
|
64
|
+
this.error(`--phase-minus-one is required when approving a plan (passed | justified | violated)`);
|
|
65
|
+
}
|
|
66
|
+
if (pmone === 'violated') {
|
|
67
|
+
this.error(`Refusing to approve plan with phase_minus_one=violated. A critical gate violation requires a framework amendment (C4), not an approval.`);
|
|
68
|
+
}
|
|
69
|
+
patch = {
|
|
70
|
+
...patch,
|
|
71
|
+
phase_minus_one: pmone,
|
|
72
|
+
approved_by: actor.email ?? actor.user,
|
|
73
|
+
approved_at: now,
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
const updated = updateFrontmatter(raw, patch);
|
|
77
|
+
writeFileSync(path, updated);
|
|
78
|
+
const auditPath = join(dir, 'audit.jsonl');
|
|
79
|
+
const event = artifact === 'plan'
|
|
80
|
+
? 'plan.approved'
|
|
81
|
+
: artifact === 'tasks'
|
|
82
|
+
? 'tasks.approved'
|
|
83
|
+
: 'spec.updated';
|
|
84
|
+
appendAuditEvent(auditPath, {
|
|
85
|
+
event,
|
|
86
|
+
feature: featureName,
|
|
87
|
+
command: `raptor approve --artifact=${artifact}`,
|
|
88
|
+
actor: { user: actor.email ?? actor.user, via: 'human' },
|
|
89
|
+
inputs: [{ path: `specs/${featureName}/${artifact}.md`, hash: hashString(raw) }],
|
|
90
|
+
outputs: [{ path: `specs/${featureName}/${artifact}.md`, hash: hashString(updated) }],
|
|
91
|
+
meta: artifact === 'plan'
|
|
92
|
+
? { phase_minus_one: flags['phase-minus-one'] }
|
|
93
|
+
: { status: 'approved' },
|
|
94
|
+
});
|
|
95
|
+
this.log(`✓ Approved ${artifact}.md for ${featureName}`);
|
|
96
|
+
this.log(` Approver: ${actor.email ?? actor.user}`);
|
|
97
|
+
if (artifact === 'plan') {
|
|
98
|
+
this.log(` Phase -1: ${flags['phase-minus-one']}`);
|
|
99
|
+
}
|
|
100
|
+
runAfterHook(this, {
|
|
101
|
+
event: 'after_approve',
|
|
102
|
+
command: `raptor approve ${args.feature} --artifact=${artifact}`,
|
|
103
|
+
projectRoot: root,
|
|
104
|
+
feature: featureName,
|
|
105
|
+
featureDir: dir,
|
|
106
|
+
actor: { user: actor.email ?? actor.user, via: actor.via },
|
|
107
|
+
extra: { artifact, ...(flags['phase-minus-one'] ? { phase_minus_one: flags['phase-minus-one'] } : {}) },
|
|
108
|
+
});
|
|
109
|
+
if (artifact === 'plan') {
|
|
110
|
+
this.log('');
|
|
111
|
+
this.log('Next steps:');
|
|
112
|
+
this.log(` 1. Run 'raptor tasks ${args.feature}' to generate tasks.md`);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
//# sourceMappingURL=approve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"approve.js","sourceRoot":"","sources":["../../src/commands/approve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAClE,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAC/E,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AACpF,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAEjE,MAAM,SAAS,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAU,CAAC;AAGrD,MAAM,CAAC,OAAO,OAAO,OAAQ,SAAQ,OAAO;IAC1C,MAAM,CAAU,WAAW,GACzB,oGAAoG,CAAC;IAEvG,MAAM,CAAU,QAAQ,GAAG;QACzB,4DAA4D;QAC5D,qFAAqF;QACrF,6DAA6D;KAC9D,CAAC;IAEF,MAAM,CAAU,IAAI,GAAG;QACrB,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC;YACnB,WAAW,EAAE,0BAA0B;YACvC,QAAQ,EAAE,IAAI;SACf,CAAC;KACH,CAAC;IAEF,MAAM,CAAU,KAAK,GAAG;QACtB,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC;YACrB,WAAW,EAAE,2BAA2B;YACxC,OAAO,EAAE,CAAC,GAAG,SAAS,CAAC;YACvB,QAAQ,EAAE,IAAI;SACf,CAAC;QACF,iBAAiB,EAAE,KAAK,CAAC,MAAM,CAAC;YAC9B,WAAW,EAAE,6DAA6D;YAC1E,OAAO,EAAE,CAAC,QAAQ,EAAE,WAAW,EAAE,UAAU,CAAC;SAC7C,CAAC;KACH,CAAC;IAEF,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAClD,MAAM,IAAI,GAAG,kBAAkB,EAAE,CAAC;QAClC,MAAM,GAAG,GAAG,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAC3C,MAAM,WAAW,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC;QAClC,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAoB,CAAC;QAC5C,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,QAAQ,KAAK,CAAC,CAAC;QAEzC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;YAAE,IAAI,CAAC,KAAK,CAAC,GAAG,QAAQ,kBAAkB,IAAI,EAAE,CAAC,CAAC;QAEvE,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC;QAEpC,aAAa,CAAC,IAAI,EAAE;YAClB,KAAK,EAAE,gBAAgB;YACvB,OAAO,EAAE,kBAAkB,IAAI,CAAC,OAAO,eAAe,QAAQ,EAAE;YAChE,WAAW,EAAE,IAAI;YACjB,OAAO,EAAE,WAAW;YACpB,UAAU,EAAE,GAAG;YACf,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE;YAC1D,KAAK,EAAE,EAAE,QAAQ,EAAE,GAAG,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,EAAE,eAAe,EAAE,KAAK,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE;SACxG,CAAC,CAAC;QACH,IAAI,QAAQ,KAAK,MAAM,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YACxC,IAAI,CAAC,KAAK,CACR,8FAA8F;gBAC5F,kFAAkF,CACrF,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,QAAQ,KAAK,MAAM,IAAI,QAAQ,KAAK,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;YAClE,IAAI,CAAC,IAAI,CACP,+BAA+B,QAAQ,uEAAuE,CAC/G,CAAC;QACJ,CAAC;QAED,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACvC,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QAErC,IAAI,KAAK,GAA4B,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC;QAC5D,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;YACxB,MAAM,KAAK,GAAG,KAAK,CAAC,iBAAiB,CAAC,CAAC;YACvC,IAAI,CAAC,KAAK,EAAE,CAAC;gBACX,IAAI,CAAC,KAAK,CAAC,qFAAqF,CAAC,CAAC;YACpG,CAAC;YACD,IAAI,KAAK,KAAK,UAAU,EAAE,CAAC;gBACzB,IAAI,CAAC,KAAK,CACR,yIAAyI,CAC1I,CAAC;YACJ,CAAC;YACD,KAAK,GAAG;gBACN,GAAG,KAAK;gBACR,eAAe,EAAE,KAAK;gBACtB,WAAW,EAAE,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI;gBACtC,WAAW,EAAE,GAAG;aACjB,CAAC;QACJ,CAAC;QAED,MAAM,OAAO,GAAG,iBAAiB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;QAC9C,aAAa,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAE7B,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC;QAC3C,MAAM,KAAK,GACT,QAAQ,KAAK,MAAM;YACjB,CAAC,CAAC,eAAe;YACjB,CAAC,CAAC,QAAQ,KAAK,OAAO;gBACpB,CAAC,CAAC,gBAAgB;gBAClB,CAAC,CAAC,cAAc,CAAC;QACvB,gBAAgB,CAAC,SAAS,EAAE;YAC1B,KAAK;YACL,OAAO,EAAE,WAAW;YACpB,OAAO,EAAE,6BAA6B,QAAQ,EAAE;YAChD,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,OAAO,EAAE;YACxD,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,WAAW,IAAI,QAAQ,KAAK,EAAE,IAAI,EAAE,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YAChF,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,WAAW,IAAI,QAAQ,KAAK,EAAE,IAAI,EAAE,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;YACrF,IAAI,EACF,QAAQ,KAAK,MAAM;gBACjB,CAAC,CAAC,EAAE,eAAe,EAAE,KAAK,CAAC,iBAAiB,CAAC,EAAE;gBAC/C,CAAC,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE;SAC7B,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,CAAC,cAAc,QAAQ,WAAW,WAAW,EAAE,CAAC,CAAC;QACzD,IAAI,CAAC,GAAG,CAAC,eAAe,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QACrD,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;YACxB,IAAI,CAAC,GAAG,CAAC,eAAe,KAAK,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;QACtD,CAAC;QAED,YAAY,CAAC,IAAI,EAAE;YACjB,KAAK,EAAE,eAAe;YACtB,OAAO,EAAE,kBAAkB,IAAI,CAAC,OAAO,eAAe,QAAQ,EAAE;YAChE,WAAW,EAAE,IAAI;YACjB,OAAO,EAAE,WAAW;YACpB,UAAU,EAAE,GAAG;YACf,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,GAAG,EAAE;YAC1D,KAAK,EAAE,EAAE,QAAQ,EAAE,GAAG,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,EAAE,eAAe,EAAE,KAAK,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE;SACxG,CAAC,CAAC;QAEH,IAAI,QAAQ,KAAK,MAAM,EAAE,CAAC;YACxB,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACb,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;YACxB,IAAI,CAAC,GAAG,CAAC,0BAA0B,IAAI,CAAC,OAAO,wBAAwB,CAAC,CAAC;QAC3E,CAAC;IACH,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Command } from "@oclif/core";
|
|
2
|
+
export default class AuditQueryCmd extends Command {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
feature: import("@oclif/core/interfaces").Arg<string | undefined, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
all: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
10
|
+
event: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
11
|
+
article: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
12
|
+
"gate-level": import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
13
|
+
"gate-id": import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
14
|
+
task: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
15
|
+
"actor-via": import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
16
|
+
since: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
17
|
+
json: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
18
|
+
};
|
|
19
|
+
run(): Promise<void>;
|
|
20
|
+
private allFeatureDirs;
|
|
21
|
+
private format;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=query.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../../../src/commands/audit/query.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,OAAO,EAAS,MAAM,aAAa,CAAC;AAWnD,MAAM,CAAC,OAAO,OAAO,aAAc,SAAQ,OAAO;IAChD,OAAgB,WAAW,SAEiB;IAE5C,OAAgB,QAAQ,WAKtB;IAEF,OAAgB,IAAI;;MAKlB;IAEF,OAAgB,KAAK;;;;;;;;;;MA2BnB;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;IA0C1B,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,MAAM;CAef"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { Args, Command, Flags } from "@oclif/core";
|
|
2
|
+
import { existsSync, readdirSync } from "node:fs";
|
|
3
|
+
import { basename, join } from "node:path";
|
|
4
|
+
import { queryAudit, readAuditEvents, } from "../../_core/dist/index.js";
|
|
5
|
+
import { featureDir, requireProjectRoot } from "../../shared/project.js";
|
|
6
|
+
export default class AuditQueryCmd extends Command {
|
|
7
|
+
static description = "Query audit.jsonl entries with filters (event/article/gate-level/task/since). " +
|
|
8
|
+
"Use --all to query across all features.";
|
|
9
|
+
static examples = [
|
|
10
|
+
"<%= config.bin %> audit query 001-foo --event plan.approved",
|
|
11
|
+
"<%= config.bin %> audit query 001-foo --event gate.evaluated --gate-level critical",
|
|
12
|
+
"<%= config.bin %> audit query 001-foo --event code.generated --task T003",
|
|
13
|
+
"<%= config.bin %> audit query --all --event violation --article C2 --since 30d",
|
|
14
|
+
];
|
|
15
|
+
static args = {
|
|
16
|
+
feature: Args.string({
|
|
17
|
+
description: "Feature slug or NNN-slug (omit and use --all for cross-feature)",
|
|
18
|
+
required: false,
|
|
19
|
+
}),
|
|
20
|
+
};
|
|
21
|
+
static flags = {
|
|
22
|
+
all: Flags.boolean({
|
|
23
|
+
description: "Query across all features (requires no feature arg)",
|
|
24
|
+
}),
|
|
25
|
+
event: Flags.string({
|
|
26
|
+
description: "Filter by event type (comma-separated for multiple)",
|
|
27
|
+
multiple: false,
|
|
28
|
+
}),
|
|
29
|
+
article: Flags.string({
|
|
30
|
+
description: "Filter by constitutional article (e.g. C2, P1, M3)",
|
|
31
|
+
}),
|
|
32
|
+
"gate-level": Flags.string({
|
|
33
|
+
description: "Filter by gate.level",
|
|
34
|
+
options: ["critical", "required", "advisory"],
|
|
35
|
+
}),
|
|
36
|
+
"gate-id": Flags.string({ description: "Filter by gate.id" }),
|
|
37
|
+
task: Flags.string({ description: "Filter by task.id (e.g. T003)" }),
|
|
38
|
+
"actor-via": Flags.string({
|
|
39
|
+
description: "Filter by actor.via",
|
|
40
|
+
options: ["human", "agent", "ci", "system"],
|
|
41
|
+
}),
|
|
42
|
+
since: Flags.string({
|
|
43
|
+
description: "Only entries since (e.g. 30d, 12h, 2026-04-01)",
|
|
44
|
+
}),
|
|
45
|
+
json: Flags.boolean({
|
|
46
|
+
description: "Output raw JSON lines instead of pretty format",
|
|
47
|
+
}),
|
|
48
|
+
};
|
|
49
|
+
async run() {
|
|
50
|
+
const { args, flags } = await this.parse(AuditQueryCmd);
|
|
51
|
+
const root = requireProjectRoot();
|
|
52
|
+
if (flags.all && args.feature) {
|
|
53
|
+
this.error("--all is incompatible with a feature argument");
|
|
54
|
+
}
|
|
55
|
+
if (!flags.all && !args.feature) {
|
|
56
|
+
this.error("provide a feature slug or use --all");
|
|
57
|
+
}
|
|
58
|
+
const dirs = flags.all
|
|
59
|
+
? this.allFeatureDirs(root)
|
|
60
|
+
: [featureDir(root, args.feature)];
|
|
61
|
+
const q = {
|
|
62
|
+
event: flags.event
|
|
63
|
+
? flags.event.split(",").map((s) => s.trim())
|
|
64
|
+
: undefined,
|
|
65
|
+
article: flags.article,
|
|
66
|
+
gateLevel: flags["gate-level"],
|
|
67
|
+
gateId: flags["gate-id"],
|
|
68
|
+
taskId: flags.task,
|
|
69
|
+
actorVia: flags["actor-via"],
|
|
70
|
+
since: flags.since,
|
|
71
|
+
};
|
|
72
|
+
let total = 0;
|
|
73
|
+
for (const dir of dirs) {
|
|
74
|
+
const events = readAuditEvents(join(dir, "audit.jsonl"));
|
|
75
|
+
const matches = queryAudit(events, q);
|
|
76
|
+
if (matches.length === 0)
|
|
77
|
+
continue;
|
|
78
|
+
if (!flags.json)
|
|
79
|
+
this.log(`# ${basename(dir)} — ${matches.length} match(es)`);
|
|
80
|
+
for (const e of matches) {
|
|
81
|
+
if (flags.json)
|
|
82
|
+
this.log(JSON.stringify(e));
|
|
83
|
+
else
|
|
84
|
+
this.log(this.format(e));
|
|
85
|
+
}
|
|
86
|
+
total += matches.length;
|
|
87
|
+
}
|
|
88
|
+
if (total === 0)
|
|
89
|
+
this.log("(no matches)");
|
|
90
|
+
}
|
|
91
|
+
allFeatureDirs(root) {
|
|
92
|
+
const specsDir = join(root, ".raptor", "specs");
|
|
93
|
+
if (!existsSync(specsDir))
|
|
94
|
+
return [];
|
|
95
|
+
return readdirSync(specsDir)
|
|
96
|
+
.filter((d) => /^\d{3,}-/.test(d))
|
|
97
|
+
.map((d) => join(specsDir, d));
|
|
98
|
+
}
|
|
99
|
+
format(e) {
|
|
100
|
+
const parts = [
|
|
101
|
+
`[${e.sequence}]`,
|
|
102
|
+
e.ts,
|
|
103
|
+
e.event.padEnd(22),
|
|
104
|
+
`${e.actor.via}:${e.actor.user}`,
|
|
105
|
+
];
|
|
106
|
+
const gate = e.gate;
|
|
107
|
+
if (gate?.id)
|
|
108
|
+
parts.push(`gate=${gate.id}/${gate.level}`);
|
|
109
|
+
const task = e.task;
|
|
110
|
+
if (task?.id)
|
|
111
|
+
parts.push(`task=${task.id}`);
|
|
112
|
+
const article = e.article;
|
|
113
|
+
if (article)
|
|
114
|
+
parts.push(`article=${article}`);
|
|
115
|
+
return " " + parts.join(" ");
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=query.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/commands/audit/query.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,EACL,UAAU,EACV,eAAe,GAGhB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAEzE,MAAM,CAAC,OAAO,OAAO,aAAc,SAAQ,OAAO;IAChD,MAAM,CAAU,WAAW,GACzB,gFAAgF;QAChF,yCAAyC,CAAC;IAE5C,MAAM,CAAU,QAAQ,GAAG;QACzB,6DAA6D;QAC7D,oFAAoF;QACpF,0EAA0E;QAC1E,gFAAgF;KACjF,CAAC;IAEF,MAAM,CAAU,IAAI,GAAG;QACrB,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC;YACnB,WAAW,EAAE,iEAAiE;YAC9E,QAAQ,EAAE,KAAK;SAChB,CAAC;KACH,CAAC;IAEF,MAAM,CAAU,KAAK,GAAG;QACtB,GAAG,EAAE,KAAK,CAAC,OAAO,CAAC;YACjB,WAAW,EAAE,qDAAqD;SACnE,CAAC;QACF,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC;YAClB,WAAW,EAAE,qDAAqD;YAClE,QAAQ,EAAE,KAAK;SAChB,CAAC;QACF,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC;YACpB,WAAW,EAAE,oDAAoD;SAClE,CAAC;QACF,YAAY,EAAE,KAAK,CAAC,MAAM,CAAC;YACzB,WAAW,EAAE,sBAAsB;YACnC,OAAO,EAAE,CAAC,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC;SAC9C,CAAC;QACF,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,mBAAmB,EAAE,CAAC;QAC7D,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,+BAA+B,EAAE,CAAC;QACpE,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC;YACxB,WAAW,EAAE,qBAAqB;YAClC,OAAO,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC;SAC5C,CAAC;QACF,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC;YAClB,WAAW,EAAE,gDAAgD;SAC9D,CAAC;QACF,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC;YAClB,WAAW,EAAE,gDAAgD;SAC9D,CAAC;KACH,CAAC;IAEF,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QACxD,MAAM,IAAI,GAAG,kBAAkB,EAAE,CAAC;QAElC,IAAI,KAAK,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YAC9B,IAAI,CAAC,KAAK,CAAC,+CAA+C,CAAC,CAAC;QAC9D,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAChC,IAAI,CAAC,KAAK,CAAC,qCAAqC,CAAC,CAAC;QACpD,CAAC;QAED,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG;YACpB,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC;YAC3B,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,OAAQ,CAAC,CAAC,CAAC;QAEtC,MAAM,CAAC,GAAe;YACpB,KAAK,EAAE,KAAK,CAAC,KAAK;gBAChB,CAAC,CAAE,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAyB;gBACtE,CAAC,CAAC,SAAS;YACb,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,SAAS,EAAE,KAAK,CAAC,YAAY,CAA4B;YACzD,MAAM,EAAE,KAAK,CAAC,SAAS,CAAC;YACxB,MAAM,EAAE,KAAK,CAAC,IAAI;YAClB,QAAQ,EAAE,KAAK,CAAC,WAAW,CAA2B;YACtD,KAAK,EAAE,KAAK,CAAC,KAAK;SACnB,CAAC;QAEF,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,MAAM,GAAG,eAAe,CAAC,IAAI,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC,CAAC;YACzD,MAAM,OAAO,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YACtC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;gBAAE,SAAS;YACnC,IAAI,CAAC,KAAK,CAAC,IAAI;gBAAE,IAAI,CAAC,GAAG,CAAC,KAAK,QAAQ,CAAC,GAAG,CAAC,MAAM,OAAO,CAAC,MAAM,YAAY,CAAC,CAAC;YAC9E,KAAK,MAAM,CAAC,IAAI,OAAO,EAAE,CAAC;gBACxB,IAAI,KAAK,CAAC,IAAI;oBAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;;oBACvC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YAChC,CAAC;YACD,KAAK,IAAI,OAAO,CAAC,MAAM,CAAC;QAC1B,CAAC;QACD,IAAI,KAAK,KAAK,CAAC;YAAE,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IAC5C,CAAC;IAEO,cAAc,CAAC,IAAY;QACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAChD,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;YAAE,OAAO,EAAE,CAAC;QACrC,OAAO,WAAW,CAAC,QAAQ,CAAC;aACzB,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACjC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC;IAEO,MAAM,CAAC,CAAa;QAC1B,MAAM,KAAK,GAAG;YACZ,IAAI,CAAC,CAAC,QAAQ,GAAG;YACjB,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC;YAClB,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE;SACjC,CAAC;QACF,MAAM,IAAI,GAAI,CAAgD,CAAC,IAAI,CAAC;QACpE,IAAI,IAAI,EAAE,EAAE;YAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAC1D,MAAM,IAAI,GAAI,CAAgC,CAAC,IAAI,CAAC;QACpD,IAAI,IAAI,EAAE,EAAE;YAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;QAC5C,MAAM,OAAO,GAAI,CAA0B,CAAC,OAAO,CAAC;QACpD,IAAI,OAAO;YAAE,KAAK,CAAC,IAAI,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;QAC9C,OAAO,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Command } from "@oclif/core";
|
|
2
|
+
export default class AuditShow extends Command {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
feature: import("@oclif/core/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
id: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
10
|
+
sequence: import("@oclif/core/interfaces").OptionFlag<number | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
11
|
+
event: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
12
|
+
latest: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
"include-prompt": import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
14
|
+
};
|
|
15
|
+
run(): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=show.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"show.d.ts","sourceRoot":"","sources":["../../../src/commands/audit/show.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,OAAO,EAAS,MAAM,aAAa,CAAC;AAUnD,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,OAAO;IAC5C,OAAgB,WAAW,SACmE;IAE9F,OAAgB,QAAQ,WAItB;IAEF,OAAgB,IAAI;;MAElB;IAEF,OAAgB,KAAK;;;;;;MAQnB;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CA8B3B"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { Args, Command, Flags } from "@oclif/core";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
import { queryAudit, readAuditEvents, } from "../../_core/dist/index.js";
|
|
4
|
+
import { featureDir, requireProjectRoot } from "../../shared/project.js";
|
|
5
|
+
export default class AuditShow extends Command {
|
|
6
|
+
static description = "Show a single audit entry — by --id, by --sequence, or --latest matching --event/filters.";
|
|
7
|
+
static examples = [
|
|
8
|
+
"<%= config.bin %> audit show 001-foo --id 0190abc-...",
|
|
9
|
+
"<%= config.bin %> audit show 001-foo --sequence 5",
|
|
10
|
+
"<%= config.bin %> audit show 001-foo --event plan.generated --latest",
|
|
11
|
+
];
|
|
12
|
+
static args = {
|
|
13
|
+
feature: Args.string({ description: "Feature slug or NNN-slug", required: true }),
|
|
14
|
+
};
|
|
15
|
+
static flags = {
|
|
16
|
+
id: Flags.string({ description: "Match by event id (UUIDv7)" }),
|
|
17
|
+
sequence: Flags.integer({ description: "Match by sequence number" }),
|
|
18
|
+
event: Flags.string({ description: "Filter by event type (used with --latest)" }),
|
|
19
|
+
latest: Flags.boolean({ description: "Pick the most recent matching entry" }),
|
|
20
|
+
"include-prompt": Flags.boolean({
|
|
21
|
+
description: "Include full prompt text (currently warns: prompt storage is P13.1 pending)",
|
|
22
|
+
}),
|
|
23
|
+
};
|
|
24
|
+
async run() {
|
|
25
|
+
const { args, flags } = await this.parse(AuditShow);
|
|
26
|
+
const root = requireProjectRoot();
|
|
27
|
+
const dir = featureDir(root, args.feature);
|
|
28
|
+
const events = readAuditEvents(join(dir, "audit.jsonl"));
|
|
29
|
+
let match;
|
|
30
|
+
if (flags.id)
|
|
31
|
+
match = events.find((e) => e.id === flags.id);
|
|
32
|
+
else if (flags.sequence != null)
|
|
33
|
+
match = events.find((e) => e.sequence === flags.sequence);
|
|
34
|
+
else if (flags.latest) {
|
|
35
|
+
const q = flags.event
|
|
36
|
+
? { event: flags.event }
|
|
37
|
+
: {};
|
|
38
|
+
const matches = queryAudit(events, q);
|
|
39
|
+
match = matches[matches.length - 1];
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
this.error("provide --id, --sequence, or --latest (optionally with --event)");
|
|
43
|
+
}
|
|
44
|
+
if (!match) {
|
|
45
|
+
this.error("no matching entry found");
|
|
46
|
+
}
|
|
47
|
+
if (flags["include-prompt"]) {
|
|
48
|
+
this.warn("--include-prompt is partial: full prompt text storage is P13.1 (pending). Showing prompt hash only.");
|
|
49
|
+
}
|
|
50
|
+
this.log(JSON.stringify(match, null, 2));
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=show.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"show.js","sourceRoot":"","sources":["../../../src/commands/audit/show.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Command } from "@oclif/core";
|
|
2
|
+
export default class Checklist extends Command {
|
|
3
|
+
static description: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
feature: import("@oclif/core/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
init: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
10
|
+
validate: import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
agent: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
|
|
12
|
+
"wait-artifact": import("@oclif/core/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
"wait-timeout": import("@oclif/core/interfaces").OptionFlag<number, import("@oclif/core/interfaces").CustomOptions>;
|
|
14
|
+
};
|
|
15
|
+
run(): Promise<void>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=checklist.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checklist.d.ts","sourceRoot":"","sources":["../../src/commands/checklist.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,OAAO,EAAS,MAAM,aAAa,CAAC;AAyCnD,MAAM,CAAC,OAAO,OAAO,SAAU,SAAQ,OAAO;IAC5C,OAAgB,WAAW,SAC6C;IAExE,OAAgB,QAAQ,WAItB;IAEF,OAAgB,IAAI;;MAKlB;IAEF,OAAgB,KAAK;;;;;;MAoBnB;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CA0P3B"}
|
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
import { Args, Command, Flags } from "@oclif/core";
|
|
2
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync } from "node:fs";
|
|
3
|
+
import { basename, join } from "node:path";
|
|
4
|
+
import { appendAuditEvent, buildCanonicalPrompt, discoverChecklists, formatReport, gateChecklistFrontmatter, gateChecklistLinksToDecisions, gateChecklistNonEmpty, generateChecklistFrontmatter, hashString, loadAgentsConfig, parseChecklistItems, parsePlan, runGates, selectAgent, summarizeChecklist, } from "../_core/dist/index.js";
|
|
5
|
+
import { parseFrontmatter } from "../_core/dist/index.js";
|
|
6
|
+
import { currentActor, featureDir, requireProjectRoot, } from "../shared/project.js";
|
|
7
|
+
import { writeFeaturePrompt } from "../shared/feature-prompt.js";
|
|
8
|
+
import { runAfterHook, runBeforeHook } from "../shared/hooks.js";
|
|
9
|
+
import { backupPhaseFile, waitForPhaseArtifact, } from "../shared/artifact-io.js";
|
|
10
|
+
const KNOWN_KINDS = [
|
|
11
|
+
"security",
|
|
12
|
+
"performance",
|
|
13
|
+
"accessibility",
|
|
14
|
+
"reliability",
|
|
15
|
+
"privacy",
|
|
16
|
+
];
|
|
17
|
+
export default class Checklist extends Command {
|
|
18
|
+
static description = "Generate, validate, and summarize thematic checklists for a feature";
|
|
19
|
+
static examples = [
|
|
20
|
+
"<%= config.bin %> checklist login-biometrico",
|
|
21
|
+
"<%= config.bin %> checklist login-biometrico --init security",
|
|
22
|
+
"<%= config.bin %> checklist login-biometrico --validate",
|
|
23
|
+
];
|
|
24
|
+
static args = {
|
|
25
|
+
feature: Args.string({
|
|
26
|
+
description: "Feature slug or NNN-slug",
|
|
27
|
+
required: true,
|
|
28
|
+
}),
|
|
29
|
+
};
|
|
30
|
+
static flags = {
|
|
31
|
+
init: Flags.string({
|
|
32
|
+
description: `Initialize a new checklist (${KNOWN_KINDS.join(", ")}, or custom name)`,
|
|
33
|
+
}),
|
|
34
|
+
validate: Flags.boolean({
|
|
35
|
+
description: "Run checklist gates (frontmatter, links, non-empty)",
|
|
36
|
+
default: false,
|
|
37
|
+
}),
|
|
38
|
+
agent: Flags.string({
|
|
39
|
+
description: "Agent to use for checklist (overrides agents.yml policy)",
|
|
40
|
+
}),
|
|
41
|
+
"wait-artifact": Flags.boolean({
|
|
42
|
+
description: "After writing the agent command file, block until a checklist file is produced",
|
|
43
|
+
default: false,
|
|
44
|
+
}),
|
|
45
|
+
"wait-timeout": Flags.integer({
|
|
46
|
+
description: "Timeout (seconds) for --wait-artifact",
|
|
47
|
+
default: 300,
|
|
48
|
+
}),
|
|
49
|
+
};
|
|
50
|
+
async run() {
|
|
51
|
+
const { args, flags } = await this.parse(Checklist);
|
|
52
|
+
const root = requireProjectRoot();
|
|
53
|
+
const dir = featureDir(root, args.feature);
|
|
54
|
+
const featureName = basename(dir);
|
|
55
|
+
const auditPath = join(dir, "audit.jsonl");
|
|
56
|
+
const actor = currentActor("human");
|
|
57
|
+
runBeforeHook(this, {
|
|
58
|
+
event: "before_checklist",
|
|
59
|
+
command: `raptor checklist ${args.feature}`,
|
|
60
|
+
projectRoot: root,
|
|
61
|
+
feature: featureName,
|
|
62
|
+
featureDir: dir,
|
|
63
|
+
actor: { user: actor.email ?? actor.user, via: actor.via },
|
|
64
|
+
});
|
|
65
|
+
// -----------------------------------------------------------------------
|
|
66
|
+
// Agent prompt generation
|
|
67
|
+
// -----------------------------------------------------------------------
|
|
68
|
+
let agentInfo = {
|
|
69
|
+
id: "human",
|
|
70
|
+
reason: "manual_check",
|
|
71
|
+
};
|
|
72
|
+
const agentsConfig = loadAgentsConfig(root);
|
|
73
|
+
if (agentsConfig) {
|
|
74
|
+
try {
|
|
75
|
+
const selection = selectAgent(agentsConfig, "checklist", flags.agent);
|
|
76
|
+
agentInfo = {
|
|
77
|
+
id: selection.agentEntryId,
|
|
78
|
+
reason: selection.reason,
|
|
79
|
+
};
|
|
80
|
+
// Build canonical prompt for checklist
|
|
81
|
+
const canonical = buildCanonicalPrompt({
|
|
82
|
+
command: "checklist",
|
|
83
|
+
feature: featureName,
|
|
84
|
+
projectRoot: root,
|
|
85
|
+
constitutionArticles: [],
|
|
86
|
+
invariants: ["I-04", "I-06"],
|
|
87
|
+
});
|
|
88
|
+
const packedContent = selection.agent.packPrompt(canonical);
|
|
89
|
+
// Feature-scoped prompt — must NOT clobber the rich slash commands (F1).
|
|
90
|
+
agentInfo.commandFile = writeFeaturePrompt({
|
|
91
|
+
root,
|
|
92
|
+
featureDir: dir,
|
|
93
|
+
command: "checklist",
|
|
94
|
+
content: packedContent,
|
|
95
|
+
cmd: this,
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
catch (err) {
|
|
99
|
+
this.warn(`Agent selection failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
// --- Mode: init ---
|
|
103
|
+
if (flags.init) {
|
|
104
|
+
const kind = flags.init;
|
|
105
|
+
const clDir = join(dir, "checklists");
|
|
106
|
+
mkdirSync(clDir, { recursive: true });
|
|
107
|
+
const clPath = join(clDir, `${kind}.md`);
|
|
108
|
+
if (existsSync(clPath)) {
|
|
109
|
+
this.error(`${kind}.md already exists at ${clPath}`);
|
|
110
|
+
}
|
|
111
|
+
// Try to get plan hash for traceability
|
|
112
|
+
const planPath = join(dir, "plan.md");
|
|
113
|
+
const specPath = join(dir, "spec.md");
|
|
114
|
+
let planHash = "";
|
|
115
|
+
let specHash = "";
|
|
116
|
+
if (existsSync(planPath)) {
|
|
117
|
+
const plan = parsePlan(planPath);
|
|
118
|
+
planHash = plan.hash;
|
|
119
|
+
}
|
|
120
|
+
if (existsSync(specPath)) {
|
|
121
|
+
specHash = hashString(readFileSync(specPath, "utf8"));
|
|
122
|
+
}
|
|
123
|
+
const fmMatch = featureName.match(/^(\d{3})-(.+)/);
|
|
124
|
+
const featureId = fmMatch?.[1] ?? "000";
|
|
125
|
+
const slug = fmMatch?.[2] ?? featureName;
|
|
126
|
+
const fm = generateChecklistFrontmatter({
|
|
127
|
+
featureId,
|
|
128
|
+
slug,
|
|
129
|
+
kind,
|
|
130
|
+
planHash,
|
|
131
|
+
specHash,
|
|
132
|
+
});
|
|
133
|
+
const body = `\n## ${kind.charAt(0).toUpperCase() + kind.slice(1)} Checklist\n\n<!-- Add checklist items below. Format:\n- [ ] **CK-1** — Description [D1] [A1]\n Status markers: [ ] pending, [x] passed, [!] failed, [-] N/A, [~] deferred\n [D1] = decision ref from plan.md, [A1] = acceptance ref from spec.md\n-->\n\n- [ ] **CK-1** — [NEEDS CLARIFICATION: first check item] [D1]\n`;
|
|
134
|
+
backupPhaseFile({ root, command: this }, clPath);
|
|
135
|
+
writeFileSync(clPath, fm + body);
|
|
136
|
+
appendAuditEvent(auditPath, {
|
|
137
|
+
event: "checklist.generated",
|
|
138
|
+
feature: featureName,
|
|
139
|
+
command: `raptor checklist --init ${kind}`,
|
|
140
|
+
actor: { user: actor.email ?? actor.user, via: actor.via },
|
|
141
|
+
agent: { key: agentInfo.id },
|
|
142
|
+
prompt: { hash: hashString(`checklist@${kind}@${featureName}`) },
|
|
143
|
+
outputs: [
|
|
144
|
+
{
|
|
145
|
+
path: `specs/${featureName}/checklists/${kind}.md`,
|
|
146
|
+
hash: hashString(fm + body),
|
|
147
|
+
},
|
|
148
|
+
],
|
|
149
|
+
meta: {
|
|
150
|
+
kind,
|
|
151
|
+
plan_hash: planHash || undefined,
|
|
152
|
+
agent_reason: agentInfo.reason,
|
|
153
|
+
},
|
|
154
|
+
});
|
|
155
|
+
this.log(`✓ Created ${kind} checklist at ${clPath}`);
|
|
156
|
+
this.log("");
|
|
157
|
+
this.log("Next steps:");
|
|
158
|
+
this.log(` 1. Edit ${kind}.md — add checklist items with [Dk] and [Ak] refs`);
|
|
159
|
+
this.log(` 2. Run 'raptor checklist ${args.feature}' to see summary`);
|
|
160
|
+
this.log(` 3. Run 'raptor checklist ${args.feature} --validate' to check gates`);
|
|
161
|
+
runAfterHook(this, {
|
|
162
|
+
event: "after_checklist",
|
|
163
|
+
command: `raptor checklist ${args.feature} --init ${kind}`,
|
|
164
|
+
projectRoot: root,
|
|
165
|
+
feature: featureName,
|
|
166
|
+
featureDir: dir,
|
|
167
|
+
actor: { user: actor.email ?? actor.user, via: actor.via },
|
|
168
|
+
});
|
|
169
|
+
return;
|
|
170
|
+
}
|
|
171
|
+
// --- Mode: validate ---
|
|
172
|
+
if (flags.validate) {
|
|
173
|
+
const gates = [
|
|
174
|
+
gateChecklistFrontmatter,
|
|
175
|
+
gateChecklistLinksToDecisions,
|
|
176
|
+
gateChecklistNonEmpty,
|
|
177
|
+
];
|
|
178
|
+
const report = await runGates(gates, {
|
|
179
|
+
projectRoot: root,
|
|
180
|
+
featureDir: dir,
|
|
181
|
+
});
|
|
182
|
+
this.log(`=== Checklist Gates for ${featureName} ===`);
|
|
183
|
+
this.log(formatReport(report));
|
|
184
|
+
if (report.blocked)
|
|
185
|
+
this.exit(1);
|
|
186
|
+
runAfterHook(this, {
|
|
187
|
+
event: "after_checklist",
|
|
188
|
+
command: `raptor checklist ${args.feature} --validate`,
|
|
189
|
+
projectRoot: root,
|
|
190
|
+
feature: featureName,
|
|
191
|
+
featureDir: dir,
|
|
192
|
+
actor: { user: actor.email ?? actor.user, via: actor.via },
|
|
193
|
+
});
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
// --- Mode: summary (default) ---
|
|
197
|
+
const checklists = discoverChecklists(dir);
|
|
198
|
+
if (checklists.length === 0) {
|
|
199
|
+
this.log(`No checklists found for ${featureName}.`);
|
|
200
|
+
this.log("");
|
|
201
|
+
this.log(` Run 'raptor checklist ${args.feature} --init <kind>' to create one.`);
|
|
202
|
+
this.log(` Available kinds: ${KNOWN_KINDS.join(", ")}`);
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
this.log(`=== Checklists for ${featureName} ===\n`);
|
|
206
|
+
let totalAll = 0;
|
|
207
|
+
let passedAll = 0;
|
|
208
|
+
let failedAll = 0;
|
|
209
|
+
for (const { kind, path } of checklists) {
|
|
210
|
+
const raw = readFileSync(path, "utf8");
|
|
211
|
+
const { body } = parseFrontmatter(raw);
|
|
212
|
+
const items = parseChecklistItems(body);
|
|
213
|
+
const summary = summarizeChecklist(items);
|
|
214
|
+
totalAll += summary.total;
|
|
215
|
+
passedAll += summary.passed;
|
|
216
|
+
failedAll += summary.failed;
|
|
217
|
+
const rate = summary.passRate > 0 ? `${(summary.passRate * 100).toFixed(0)}%` : "—";
|
|
218
|
+
const icon = summary.failed > 0 ? "🔴" : summary.pending > 0 ? "🟡" : "🟢";
|
|
219
|
+
this.log(` ${icon} ${kind}`);
|
|
220
|
+
this.log(` Total: ${summary.total} ✅ ${summary.passed} ❌ ${summary.failed} ⏳ ${summary.pending} ⊘ ${summary.notApplicable} ⏸ ${summary.deferred}`);
|
|
221
|
+
this.log(` Pass rate: ${rate} | Linked to decisions: ${summary.linkedToDecision}/${summary.total}`);
|
|
222
|
+
this.log("");
|
|
223
|
+
}
|
|
224
|
+
this.log(` ── Summary ──`);
|
|
225
|
+
this.log(` ${checklists.length} checklist(s) | ${totalAll} items | ✅ ${passedAll} ❌ ${failedAll} ⏳ ${totalAll - passedAll - failedAll}`);
|
|
226
|
+
if (flags["wait-artifact"] && agentInfo.commandFile) {
|
|
227
|
+
const clDir = join(dir, "checklists");
|
|
228
|
+
await waitForPhaseArtifact({
|
|
229
|
+
root,
|
|
230
|
+
command: this,
|
|
231
|
+
expectedPath: `${clDir}/**`,
|
|
232
|
+
agentId: agentInfo.id,
|
|
233
|
+
timeoutMs: flags["wait-timeout"] * 1000,
|
|
234
|
+
label: clDir,
|
|
235
|
+
});
|
|
236
|
+
}
|
|
237
|
+
runAfterHook(this, {
|
|
238
|
+
event: "after_checklist",
|
|
239
|
+
command: `raptor checklist ${args.feature}`,
|
|
240
|
+
projectRoot: root,
|
|
241
|
+
feature: featureName,
|
|
242
|
+
featureDir: dir,
|
|
243
|
+
actor: { user: actor.email ?? actor.user, via: actor.via },
|
|
244
|
+
extra: {
|
|
245
|
+
agent: agentInfo.id,
|
|
246
|
+
agent_reason: agentInfo.reason,
|
|
247
|
+
},
|
|
248
|
+
});
|
|
249
|
+
if (agentInfo.commandFile) {
|
|
250
|
+
this.log(` Agent: ${agentInfo.id} (${agentInfo.reason})`);
|
|
251
|
+
this.log(` Command: ${agentInfo.commandFile}`);
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
//# sourceMappingURL=checklist.js.map
|