night-orch 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/README.md +138 -0
- package/dist/cli/commands/cleanup.d.ts +14 -0
- package/dist/cli/commands/cleanup.d.ts.map +1 -0
- package/dist/cli/commands/cleanup.js +62 -0
- package/dist/cli/commands/cleanup.js.map +1 -0
- package/dist/cli/commands/continue.d.ts +9 -0
- package/dist/cli/commands/continue.d.ts.map +1 -0
- package/dist/cli/commands/continue.js +70 -0
- package/dist/cli/commands/continue.js.map +1 -0
- package/dist/cli/commands/cost-override.d.ts +11 -0
- package/dist/cli/commands/cost-override.d.ts.map +1 -0
- package/dist/cli/commands/cost-override.js +76 -0
- package/dist/cli/commands/cost-override.js.map +1 -0
- package/dist/cli/commands/daily-cost-override.d.ts +11 -0
- package/dist/cli/commands/daily-cost-override.d.ts.map +1 -0
- package/dist/cli/commands/daily-cost-override.js +71 -0
- package/dist/cli/commands/daily-cost-override.js.map +1 -0
- package/dist/cli/commands/delete-entry.d.ts +12 -0
- package/dist/cli/commands/delete-entry.d.ts.map +1 -0
- package/dist/cli/commands/delete-entry.js +68 -0
- package/dist/cli/commands/delete-entry.js.map +1 -0
- package/dist/cli/commands/doctor.d.ts +9 -0
- package/dist/cli/commands/doctor.d.ts.map +1 -0
- package/dist/cli/commands/doctor.js +227 -0
- package/dist/cli/commands/doctor.js.map +1 -0
- package/dist/cli/commands/init.d.ts +2 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +73 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/labels-init.d.ts +9 -0
- package/dist/cli/commands/labels-init.d.ts.map +1 -0
- package/dist/cli/commands/labels-init.js +52 -0
- package/dist/cli/commands/labels-init.js.map +1 -0
- package/dist/cli/commands/mcp.d.ts +9 -0
- package/dist/cli/commands/mcp.d.ts.map +1 -0
- package/dist/cli/commands/mcp.js +52 -0
- package/dist/cli/commands/mcp.js.map +1 -0
- package/dist/cli/commands/monitoring-init.d.ts +2 -0
- package/dist/cli/commands/monitoring-init.d.ts.map +1 -0
- package/dist/cli/commands/monitoring-init.js +43 -0
- package/dist/cli/commands/monitoring-init.js.map +1 -0
- package/dist/cli/commands/notify-test.d.ts +9 -0
- package/dist/cli/commands/notify-test.d.ts.map +1 -0
- package/dist/cli/commands/notify-test.js +41 -0
- package/dist/cli/commands/notify-test.js.map +1 -0
- package/dist/cli/commands/rebase.d.ts +9 -0
- package/dist/cli/commands/rebase.d.ts.map +1 -0
- package/dist/cli/commands/rebase.js +63 -0
- package/dist/cli/commands/rebase.js.map +1 -0
- package/dist/cli/commands/retry.d.ts +14 -0
- package/dist/cli/commands/retry.d.ts.map +1 -0
- package/dist/cli/commands/retry.js +52 -0
- package/dist/cli/commands/retry.js.map +1 -0
- package/dist/cli/commands/run-once.d.ts +9 -0
- package/dist/cli/commands/run-once.d.ts.map +1 -0
- package/dist/cli/commands/run-once.js +62 -0
- package/dist/cli/commands/run-once.js.map +1 -0
- package/dist/cli/commands/run.d.ts +9 -0
- package/dist/cli/commands/run.d.ts.map +1 -0
- package/dist/cli/commands/run.js +142 -0
- package/dist/cli/commands/run.js.map +1 -0
- package/dist/cli/commands/serve.d.ts +14 -0
- package/dist/cli/commands/serve.d.ts.map +1 -0
- package/dist/cli/commands/serve.js +51 -0
- package/dist/cli/commands/serve.js.map +1 -0
- package/dist/cli/commands/settings.d.ts +10 -0
- package/dist/cli/commands/settings.d.ts.map +1 -0
- package/dist/cli/commands/settings.js +100 -0
- package/dist/cli/commands/settings.js.map +1 -0
- package/dist/cli/commands/status.d.ts +8 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/status.js +153 -0
- package/dist/cli/commands/status.js.map +1 -0
- package/dist/cli/commands/sync.d.ts +9 -0
- package/dist/cli/commands/sync.d.ts.map +1 -0
- package/dist/cli/commands/sync.js +60 -0
- package/dist/cli/commands/sync.js.map +1 -0
- package/dist/cli/commands/update.d.ts +4 -0
- package/dist/cli/commands/update.d.ts.map +1 -0
- package/dist/cli/commands/update.js +29 -0
- package/dist/cli/commands/update.js.map +1 -0
- package/dist/cli/commands/watch.d.ts +9 -0
- package/dist/cli/commands/watch.d.ts.map +1 -0
- package/dist/cli/commands/watch.js +56 -0
- package/dist/cli/commands/watch.js.map +1 -0
- package/dist/cli/commands/web.d.ts +16 -0
- package/dist/cli/commands/web.d.ts.map +1 -0
- package/dist/cli/commands/web.js +206 -0
- package/dist/cli/commands/web.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +213 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/init/detector.d.ts +7 -0
- package/dist/cli/init/detector.d.ts.map +1 -0
- package/dist/cli/init/detector.js +40 -0
- package/dist/cli/init/detector.js.map +1 -0
- package/dist/cli/init/templates.d.ts +10 -0
- package/dist/cli/init/templates.d.ts.map +1 -0
- package/dist/cli/init/templates.js +30 -0
- package/dist/cli/init/templates.js.map +1 -0
- package/dist/cli/tui/actions-bar.d.ts +21 -0
- package/dist/cli/tui/actions-bar.d.ts.map +1 -0
- package/dist/cli/tui/actions-bar.js +91 -0
- package/dist/cli/tui/actions-bar.js.map +1 -0
- package/dist/cli/tui/active-runs.d.ts +9 -0
- package/dist/cli/tui/active-runs.d.ts.map +1 -0
- package/dist/cli/tui/active-runs.js +23 -0
- package/dist/cli/tui/active-runs.js.map +1 -0
- package/dist/cli/tui/agent-stream.d.ts +10 -0
- package/dist/cli/tui/agent-stream.d.ts.map +1 -0
- package/dist/cli/tui/agent-stream.js +83 -0
- package/dist/cli/tui/agent-stream.js.map +1 -0
- package/dist/cli/tui/app.d.ts +40 -0
- package/dist/cli/tui/app.d.ts.map +1 -0
- package/dist/cli/tui/app.js +995 -0
- package/dist/cli/tui/app.js.map +1 -0
- package/dist/cli/tui/constants.d.ts +15 -0
- package/dist/cli/tui/constants.d.ts.map +1 -0
- package/dist/cli/tui/constants.js +102 -0
- package/dist/cli/tui/constants.js.map +1 -0
- package/dist/cli/tui/cost-bar.d.ts +10 -0
- package/dist/cli/tui/cost-bar.d.ts.map +1 -0
- package/dist/cli/tui/cost-bar.js +17 -0
- package/dist/cli/tui/cost-bar.js.map +1 -0
- package/dist/cli/tui/data.d.ts +56 -0
- package/dist/cli/tui/data.d.ts.map +1 -0
- package/dist/cli/tui/data.js +296 -0
- package/dist/cli/tui/data.js.map +1 -0
- package/dist/cli/tui/format.d.ts +11 -0
- package/dist/cli/tui/format.d.ts.map +1 -0
- package/dist/cli/tui/format.js +83 -0
- package/dist/cli/tui/format.js.map +1 -0
- package/dist/cli/tui/header.d.ts +16 -0
- package/dist/cli/tui/header.d.ts.map +1 -0
- package/dist/cli/tui/header.js +22 -0
- package/dist/cli/tui/header.js.map +1 -0
- package/dist/cli/tui/logs-view.d.ts +19 -0
- package/dist/cli/tui/logs-view.d.ts.map +1 -0
- package/dist/cli/tui/logs-view.js +63 -0
- package/dist/cli/tui/logs-view.js.map +1 -0
- package/dist/cli/tui/merge-queue-panel.d.ts +9 -0
- package/dist/cli/tui/merge-queue-panel.d.ts.map +1 -0
- package/dist/cli/tui/merge-queue-panel.js +14 -0
- package/dist/cli/tui/merge-queue-panel.js.map +1 -0
- package/dist/cli/tui/projects-view.d.ts +25 -0
- package/dist/cli/tui/projects-view.d.ts.map +1 -0
- package/dist/cli/tui/projects-view.js +145 -0
- package/dist/cli/tui/projects-view.js.map +1 -0
- package/dist/cli/tui/recent-runs.d.ts +9 -0
- package/dist/cli/tui/recent-runs.d.ts.map +1 -0
- package/dist/cli/tui/recent-runs.js +20 -0
- package/dist/cli/tui/recent-runs.js.map +1 -0
- package/dist/cli/tui/runs-view.d.ts +22 -0
- package/dist/cli/tui/runs-view.d.ts.map +1 -0
- package/dist/cli/tui/runs-view.js +48 -0
- package/dist/cli/tui/runs-view.js.map +1 -0
- package/dist/cli/tui/settings-view.d.ts +9 -0
- package/dist/cli/tui/settings-view.d.ts.map +1 -0
- package/dist/cli/tui/settings-view.js +21 -0
- package/dist/cli/tui/settings-view.js.map +1 -0
- package/dist/cli/tui/stats-view.d.ts +11 -0
- package/dist/cli/tui/stats-view.d.ts.map +1 -0
- package/dist/cli/tui/stats-view.js +48 -0
- package/dist/cli/tui/stats-view.js.map +1 -0
- package/dist/cli/tui/titles.d.ts +36 -0
- package/dist/cli/tui/titles.d.ts.map +1 -0
- package/dist/cli/tui/titles.js +50 -0
- package/dist/cli/tui/titles.js.map +1 -0
- package/dist/cli/tui/types.d.ts +10 -0
- package/dist/cli/tui/types.d.ts.map +1 -0
- package/dist/cli/tui/types.js +2 -0
- package/dist/cli/tui/types.js.map +1 -0
- package/dist/cli/tui/view-model.d.ts +20 -0
- package/dist/cli/tui/view-model.d.ts.map +1 -0
- package/dist/cli/tui/view-model.js +80 -0
- package/dist/cli/tui/view-model.js.map +1 -0
- package/dist/components/button/button.tui.d.ts +4 -0
- package/dist/components/button/button.tui.d.ts.map +1 -0
- package/dist/components/button/button.tui.js +16 -0
- package/dist/components/button/button.tui.js.map +1 -0
- package/dist/components/button/button.web.d.ts +4 -0
- package/dist/components/button/button.web.d.ts.map +1 -0
- package/dist/components/button/button.web.js +7 -0
- package/dist/components/button/button.web.js.map +1 -0
- package/dist/components/button/index.d.ts +5 -0
- package/dist/components/button/index.d.ts.map +1 -0
- package/dist/components/button/index.js +4 -0
- package/dist/components/button/index.js.map +1 -0
- package/dist/components/button/types.d.ts +28 -0
- package/dist/components/button/types.d.ts.map +1 -0
- package/dist/components/button/types.js +2 -0
- package/dist/components/button/types.js.map +1 -0
- package/dist/components/button/view-model.d.ts +3 -0
- package/dist/components/button/view-model.d.ts.map +1 -0
- package/dist/components/button/view-model.js +53 -0
- package/dist/components/button/view-model.js.map +1 -0
- package/dist/components/card/card.tui.d.ts +4 -0
- package/dist/components/card/card.tui.d.ts.map +1 -0
- package/dist/components/card/card.tui.js +41 -0
- package/dist/components/card/card.tui.js.map +1 -0
- package/dist/components/card/card.web.d.ts +4 -0
- package/dist/components/card/card.web.d.ts.map +1 -0
- package/dist/components/card/card.web.js +12 -0
- package/dist/components/card/card.web.js.map +1 -0
- package/dist/components/card/index.d.ts +5 -0
- package/dist/components/card/index.d.ts.map +1 -0
- package/dist/components/card/index.js +4 -0
- package/dist/components/card/index.js.map +1 -0
- package/dist/components/card/types.d.ts +22 -0
- package/dist/components/card/types.d.ts.map +1 -0
- package/dist/components/card/types.js +2 -0
- package/dist/components/card/types.js.map +1 -0
- package/dist/components/card/view-model.d.ts +3 -0
- package/dist/components/card/view-model.d.ts.map +1 -0
- package/dist/components/card/view-model.js +35 -0
- package/dist/components/card/view-model.js.map +1 -0
- package/dist/components/index.d.ts +5 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +5 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/issue-row/index.d.ts +5 -0
- package/dist/components/issue-row/index.d.ts.map +1 -0
- package/dist/components/issue-row/index.js +4 -0
- package/dist/components/issue-row/index.js.map +1 -0
- package/dist/components/issue-row/issue-row.tui.d.ts +4 -0
- package/dist/components/issue-row/issue-row.tui.d.ts.map +1 -0
- package/dist/components/issue-row/issue-row.tui.js +15 -0
- package/dist/components/issue-row/issue-row.tui.js.map +1 -0
- package/dist/components/issue-row/issue-row.web.d.ts +4 -0
- package/dist/components/issue-row/issue-row.web.d.ts.map +1 -0
- package/dist/components/issue-row/issue-row.web.js +14 -0
- package/dist/components/issue-row/issue-row.web.js.map +1 -0
- package/dist/components/issue-row/types.d.ts +18 -0
- package/dist/components/issue-row/types.d.ts.map +1 -0
- package/dist/components/issue-row/types.js +2 -0
- package/dist/components/issue-row/types.js.map +1 -0
- package/dist/components/issue-row/view-model.d.ts +3 -0
- package/dist/components/issue-row/view-model.d.ts.map +1 -0
- package/dist/components/issue-row/view-model.js +31 -0
- package/dist/components/issue-row/view-model.js.map +1 -0
- package/dist/components/modal/index.d.ts +3 -0
- package/dist/components/modal/index.d.ts.map +1 -0
- package/dist/components/modal/index.js +2 -0
- package/dist/components/modal/index.js.map +1 -0
- package/dist/components/modal/modal.web.d.ts +16 -0
- package/dist/components/modal/modal.web.d.ts.map +1 -0
- package/dist/components/modal/modal.web.js +92 -0
- package/dist/components/modal/modal.web.js.map +1 -0
- package/dist/components/modal/types.d.ts +15 -0
- package/dist/components/modal/types.d.ts.map +1 -0
- package/dist/components/modal/types.js +2 -0
- package/dist/components/modal/types.js.map +1 -0
- package/dist/config/loader.d.ts +23 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +136 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/paths.d.ts +6 -0
- package/dist/config/paths.d.ts.map +1 -0
- package/dist/config/paths.js +24 -0
- package/dist/config/paths.js.map +1 -0
- package/dist/config/schema.d.ts +3088 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +328 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/discovery/commands.d.ts +33 -0
- package/dist/discovery/commands.d.ts.map +1 -0
- package/dist/discovery/commands.js +82 -0
- package/dist/discovery/commands.js.map +1 -0
- package/dist/discovery/decomposer.d.ts +6 -0
- package/dist/discovery/decomposer.d.ts.map +1 -0
- package/dist/discovery/decomposer.js +102 -0
- package/dist/discovery/decomposer.js.map +1 -0
- package/dist/discovery/discover.d.ts +21 -0
- package/dist/discovery/discover.d.ts.map +1 -0
- package/dist/discovery/discover.js +98 -0
- package/dist/discovery/discover.js.map +1 -0
- package/dist/discovery/followup.d.ts +14 -0
- package/dist/discovery/followup.d.ts.map +1 -0
- package/dist/discovery/followup.js +27 -0
- package/dist/discovery/followup.js.map +1 -0
- package/dist/discovery/roles.d.ts +15 -0
- package/dist/discovery/roles.d.ts.map +1 -0
- package/dist/discovery/roles.js +36 -0
- package/dist/discovery/roles.js.map +1 -0
- package/dist/discovery/selector.d.ts +13 -0
- package/dist/discovery/selector.d.ts.map +1 -0
- package/dist/discovery/selector.js +27 -0
- package/dist/discovery/selector.js.map +1 -0
- package/dist/discovery/triage.d.ts +29 -0
- package/dist/discovery/triage.d.ts.map +1 -0
- package/dist/discovery/triage.js +61 -0
- package/dist/discovery/triage.js.map +1 -0
- package/dist/environment/bootstrap.d.ts +19 -0
- package/dist/environment/bootstrap.d.ts.map +1 -0
- package/dist/environment/bootstrap.js +89 -0
- package/dist/environment/bootstrap.js.map +1 -0
- package/dist/environment/dedicated.d.ts +17 -0
- package/dist/environment/dedicated.d.ts.map +1 -0
- package/dist/environment/dedicated.js +68 -0
- package/dist/environment/dedicated.js.map +1 -0
- package/dist/environment/env-file.d.ts +16 -0
- package/dist/environment/env-file.d.ts.map +1 -0
- package/dist/environment/env-file.js +74 -0
- package/dist/environment/env-file.js.map +1 -0
- package/dist/environment/manager.d.ts +33 -0
- package/dist/environment/manager.d.ts.map +1 -0
- package/dist/environment/manager.js +113 -0
- package/dist/environment/manager.js.map +1 -0
- package/dist/environment/port.d.ts +15 -0
- package/dist/environment/port.d.ts.map +1 -0
- package/dist/environment/port.js +21 -0
- package/dist/environment/port.js.map +1 -0
- package/dist/environment/shared.d.ts +6 -0
- package/dist/environment/shared.d.ts.map +1 -0
- package/dist/environment/shared.js +30 -0
- package/dist/environment/shared.js.map +1 -0
- package/dist/events/bus.d.ts +18 -0
- package/dist/events/bus.d.ts.map +1 -0
- package/dist/events/bus.js +70 -0
- package/dist/events/bus.js.map +1 -0
- package/dist/events/observability.d.ts +32 -0
- package/dist/events/observability.d.ts.map +1 -0
- package/dist/events/observability.js +155 -0
- package/dist/events/observability.js.map +1 -0
- package/dist/events/types.d.ts +18 -0
- package/dist/events/types.d.ts.map +1 -0
- package/dist/events/types.js +2 -0
- package/dist/events/types.js.map +1 -0
- package/dist/forge/bot-comment.d.ts +17 -0
- package/dist/forge/bot-comment.d.ts.map +1 -0
- package/dist/forge/bot-comment.js +30 -0
- package/dist/forge/bot-comment.js.map +1 -0
- package/dist/forge/factory.d.ts +4 -0
- package/dist/forge/factory.d.ts.map +1 -0
- package/dist/forge/factory.js +31 -0
- package/dist/forge/factory.js.map +1 -0
- package/dist/forge/forgejo-client.d.ts +20 -0
- package/dist/forge/forgejo-client.d.ts.map +1 -0
- package/dist/forge/forgejo-client.js +114 -0
- package/dist/forge/forgejo-client.js.map +1 -0
- package/dist/forge/forgejo-labels.d.ts +13 -0
- package/dist/forge/forgejo-labels.d.ts.map +1 -0
- package/dist/forge/forgejo-labels.js +51 -0
- package/dist/forge/forgejo-labels.js.map +1 -0
- package/dist/forge/forgejo.d.ts +31 -0
- package/dist/forge/forgejo.d.ts.map +1 -0
- package/dist/forge/forgejo.js +264 -0
- package/dist/forge/forgejo.js.map +1 -0
- package/dist/forge/github.d.ts +31 -0
- package/dist/forge/github.d.ts.map +1 -0
- package/dist/forge/github.js +438 -0
- package/dist/forge/github.js.map +1 -0
- package/dist/forge/status-comment.d.ts +19 -0
- package/dist/forge/status-comment.d.ts.map +1 -0
- package/dist/forge/status-comment.js +44 -0
- package/dist/forge/status-comment.js.map +1 -0
- package/dist/forge/types.d.ts +118 -0
- package/dist/forge/types.d.ts.map +1 -0
- package/dist/forge/types.js +2 -0
- package/dist/forge/types.js.map +1 -0
- package/dist/git/process.d.ts +15 -0
- package/dist/git/process.d.ts.map +1 -0
- package/dist/git/process.js +38 -0
- package/dist/git/process.js.map +1 -0
- package/dist/git/repo.d.ts +64 -0
- package/dist/git/repo.d.ts.map +1 -0
- package/dist/git/repo.js +158 -0
- package/dist/git/repo.js.map +1 -0
- package/dist/git/slug.d.ts +13 -0
- package/dist/git/slug.d.ts.map +1 -0
- package/dist/git/slug.js +28 -0
- package/dist/git/slug.js.map +1 -0
- package/dist/git/worktree.d.ts +23 -0
- package/dist/git/worktree.d.ts.map +1 -0
- package/dist/git/worktree.js +200 -0
- package/dist/git/worktree.js.map +1 -0
- package/dist/labels/bootstrap.d.ts +12 -0
- package/dist/labels/bootstrap.d.ts.map +1 -0
- package/dist/labels/bootstrap.js +101 -0
- package/dist/labels/bootstrap.js.map +1 -0
- package/dist/labels/config.d.ts +6 -0
- package/dist/labels/config.d.ts.map +1 -0
- package/dist/labels/config.js +56 -0
- package/dist/labels/config.js.map +1 -0
- package/dist/labels/manager.d.ts +10 -0
- package/dist/labels/manager.d.ts.map +1 -0
- package/dist/labels/manager.js +30 -0
- package/dist/labels/manager.js.map +1 -0
- package/dist/labels/transitions.d.ts +33 -0
- package/dist/labels/transitions.d.ts.map +1 -0
- package/dist/labels/transitions.js +81 -0
- package/dist/labels/transitions.js.map +1 -0
- package/dist/loop/checkpoint.d.ts +60 -0
- package/dist/loop/checkpoint.d.ts.map +1 -0
- package/dist/loop/checkpoint.js +226 -0
- package/dist/loop/checkpoint.js.map +1 -0
- package/dist/loop/commit.d.ts +17 -0
- package/dist/loop/commit.d.ts.map +1 -0
- package/dist/loop/commit.js +65 -0
- package/dist/loop/commit.js.map +1 -0
- package/dist/loop/context.d.ts +11 -0
- package/dist/loop/context.d.ts.map +1 -0
- package/dist/loop/context.js +26 -0
- package/dist/loop/context.js.map +1 -0
- package/dist/loop/cost.d.ts +79 -0
- package/dist/loop/cost.d.ts.map +1 -0
- package/dist/loop/cost.js +223 -0
- package/dist/loop/cost.js.map +1 -0
- package/dist/loop/decision.d.ts +22 -0
- package/dist/loop/decision.d.ts.map +1 -0
- package/dist/loop/decision.js +118 -0
- package/dist/loop/decision.js.map +1 -0
- package/dist/loop/diff-guard.d.ts +21 -0
- package/dist/loop/diff-guard.d.ts.map +1 -0
- package/dist/loop/diff-guard.js +52 -0
- package/dist/loop/diff-guard.js.map +1 -0
- package/dist/loop/engine.d.ts +32 -0
- package/dist/loop/engine.d.ts.map +1 -0
- package/dist/loop/engine.js +376 -0
- package/dist/loop/engine.js.map +1 -0
- package/dist/loop/parallel.d.ts +20 -0
- package/dist/loop/parallel.d.ts.map +1 -0
- package/dist/loop/parallel.js +144 -0
- package/dist/loop/parallel.js.map +1 -0
- package/dist/loop/plan-summary-comment.d.ts +5 -0
- package/dist/loop/plan-summary-comment.d.ts.map +1 -0
- package/dist/loop/plan-summary-comment.js +89 -0
- package/dist/loop/plan-summary-comment.js.map +1 -0
- package/dist/loop/pricing.d.ts +23 -0
- package/dist/loop/pricing.d.ts.map +1 -0
- package/dist/loop/pricing.js +64 -0
- package/dist/loop/pricing.js.map +1 -0
- package/dist/loop/review-feedback.d.ts +12 -0
- package/dist/loop/review-feedback.d.ts.map +1 -0
- package/dist/loop/review-feedback.js +55 -0
- package/dist/loop/review-feedback.js.map +1 -0
- package/dist/loop/step-executor.d.ts +70 -0
- package/dist/loop/step-executor.d.ts.map +1 -0
- package/dist/loop/step-executor.js +328 -0
- package/dist/loop/step-executor.js.map +1 -0
- package/dist/loop/supervisor.d.ts +9 -0
- package/dist/loop/supervisor.d.ts.map +1 -0
- package/dist/loop/supervisor.js +22 -0
- package/dist/loop/supervisor.js.map +1 -0
- package/dist/loop/types.d.ts +66 -0
- package/dist/loop/types.d.ts.map +1 -0
- package/dist/loop/types.js +2 -0
- package/dist/loop/types.js.map +1 -0
- package/dist/loop/verifier.d.ts +9 -0
- package/dist/loop/verifier.d.ts.map +1 -0
- package/dist/loop/verifier.js +59 -0
- package/dist/loop/verifier.js.map +1 -0
- package/dist/loop/workflow.d.ts +38 -0
- package/dist/loop/workflow.d.ts.map +1 -0
- package/dist/loop/workflow.js +64 -0
- package/dist/loop/workflow.js.map +1 -0
- package/dist/mcp/http.d.ts +8 -0
- package/dist/mcp/http.d.ts.map +1 -0
- package/dist/mcp/http.js +76 -0
- package/dist/mcp/http.js.map +1 -0
- package/dist/mcp/resources/index.d.ts +11 -0
- package/dist/mcp/resources/index.d.ts.map +1 -0
- package/dist/mcp/resources/index.js +137 -0
- package/dist/mcp/resources/index.js.map +1 -0
- package/dist/mcp/server.d.ts +16 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +54 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/index.d.ts +19 -0
- package/dist/mcp/tools/index.d.ts.map +1 -0
- package/dist/mcp/tools/index.js +847 -0
- package/dist/mcp/tools/index.js.map +1 -0
- package/dist/mentions/manager.d.ts +12 -0
- package/dist/mentions/manager.d.ts.map +1 -0
- package/dist/mentions/manager.js +50 -0
- package/dist/mentions/manager.js.map +1 -0
- package/dist/mentions/resolver.d.ts +12 -0
- package/dist/mentions/resolver.d.ts.map +1 -0
- package/dist/mentions/resolver.js +26 -0
- package/dist/mentions/resolver.js.map +1 -0
- package/dist/mentions/tracker.d.ts +8 -0
- package/dist/mentions/tracker.d.ts.map +1 -0
- package/dist/mentions/tracker.js +18 -0
- package/dist/mentions/tracker.js.map +1 -0
- package/dist/merge-queue/batch.d.ts +19 -0
- package/dist/merge-queue/batch.d.ts.map +1 -0
- package/dist/merge-queue/batch.js +100 -0
- package/dist/merge-queue/batch.js.map +1 -0
- package/dist/merge-queue/bisect.d.ts +10 -0
- package/dist/merge-queue/bisect.d.ts.map +1 -0
- package/dist/merge-queue/bisect.js +18 -0
- package/dist/merge-queue/bisect.js.map +1 -0
- package/dist/merge-queue/eligibility.d.ts +25 -0
- package/dist/merge-queue/eligibility.d.ts.map +1 -0
- package/dist/merge-queue/eligibility.js +125 -0
- package/dist/merge-queue/eligibility.js.map +1 -0
- package/dist/merge-queue/finalize.d.ts +7 -0
- package/dist/merge-queue/finalize.d.ts.map +1 -0
- package/dist/merge-queue/finalize.js +36 -0
- package/dist/merge-queue/finalize.js.map +1 -0
- package/dist/merge-queue/runner.d.ts +13 -0
- package/dist/merge-queue/runner.d.ts.map +1 -0
- package/dist/merge-queue/runner.js +246 -0
- package/dist/merge-queue/runner.js.map +1 -0
- package/dist/merge-queue/staging.d.ts +13 -0
- package/dist/merge-queue/staging.d.ts.map +1 -0
- package/dist/merge-queue/staging.js +88 -0
- package/dist/merge-queue/staging.js.map +1 -0
- package/dist/merge-queue/types.d.ts +23 -0
- package/dist/merge-queue/types.d.ts.map +1 -0
- package/dist/merge-queue/types.js +2 -0
- package/dist/merge-queue/types.js.map +1 -0
- package/dist/metrics/collectors.d.ts +24 -0
- package/dist/metrics/collectors.d.ts.map +1 -0
- package/dist/metrics/collectors.js +132 -0
- package/dist/metrics/collectors.js.map +1 -0
- package/dist/metrics/server.d.ts +8 -0
- package/dist/metrics/server.d.ts.map +1 -0
- package/dist/metrics/server.js +41 -0
- package/dist/metrics/server.js.map +1 -0
- package/dist/metrics/service.d.ts +26 -0
- package/dist/metrics/service.d.ts.map +1 -0
- package/dist/metrics/service.js +161 -0
- package/dist/metrics/service.js.map +1 -0
- package/dist/notify/channels/console.d.ts +10 -0
- package/dist/notify/channels/console.d.ts.map +1 -0
- package/dist/notify/channels/console.js +17 -0
- package/dist/notify/channels/console.js.map +1 -0
- package/dist/notify/channels/discord.d.ts +13 -0
- package/dist/notify/channels/discord.d.ts.map +1 -0
- package/dist/notify/channels/discord.js +183 -0
- package/dist/notify/channels/discord.js.map +1 -0
- package/dist/notify/channels/github-comment.d.ts +13 -0
- package/dist/notify/channels/github-comment.d.ts.map +1 -0
- package/dist/notify/channels/github-comment.js +52 -0
- package/dist/notify/channels/github-comment.js.map +1 -0
- package/dist/notify/channels/smtp.d.ts +17 -0
- package/dist/notify/channels/smtp.d.ts.map +1 -0
- package/dist/notify/channels/smtp.js +65 -0
- package/dist/notify/channels/smtp.js.map +1 -0
- package/dist/notify/channels/webhook-common.d.ts +19 -0
- package/dist/notify/channels/webhook-common.d.ts.map +1 -0
- package/dist/notify/channels/webhook-common.js +111 -0
- package/dist/notify/channels/webhook-common.js.map +1 -0
- package/dist/notify/channels/webhook.d.ts +13 -0
- package/dist/notify/channels/webhook.d.ts.map +1 -0
- package/dist/notify/channels/webhook.js +72 -0
- package/dist/notify/channels/webhook.js.map +1 -0
- package/dist/notify/dispatcher.d.ts +11 -0
- package/dist/notify/dispatcher.d.ts.map +1 -0
- package/dist/notify/dispatcher.js +66 -0
- package/dist/notify/dispatcher.js.map +1 -0
- package/dist/notify/factory.d.ts +5 -0
- package/dist/notify/factory.d.ts.map +1 -0
- package/dist/notify/factory.js +46 -0
- package/dist/notify/factory.js.map +1 -0
- package/dist/notify/payload.d.ts +8 -0
- package/dist/notify/payload.d.ts.map +1 -0
- package/dist/notify/payload.js +37 -0
- package/dist/notify/payload.js.map +1 -0
- package/dist/notify/types.d.ts +34 -0
- package/dist/notify/types.d.ts.map +1 -0
- package/dist/notify/types.js +2 -0
- package/dist/notify/types.js.map +1 -0
- package/dist/ops/auto-cleanup.d.ts +14 -0
- package/dist/ops/auto-cleanup.d.ts.map +1 -0
- package/dist/ops/auto-cleanup.js +58 -0
- package/dist/ops/auto-cleanup.js.map +1 -0
- package/dist/ops/cleanup.d.ts +32 -0
- package/dist/ops/cleanup.d.ts.map +1 -0
- package/dist/ops/cleanup.js +208 -0
- package/dist/ops/cleanup.js.map +1 -0
- package/dist/ops/continue.d.ts +12 -0
- package/dist/ops/continue.d.ts.map +1 -0
- package/dist/ops/continue.js +240 -0
- package/dist/ops/continue.js.map +1 -0
- package/dist/ops/cost-override.d.ts +16 -0
- package/dist/ops/cost-override.d.ts.map +1 -0
- package/dist/ops/cost-override.js +28 -0
- package/dist/ops/cost-override.js.map +1 -0
- package/dist/ops/daily-cost-override.d.ts +15 -0
- package/dist/ops/daily-cost-override.d.ts.map +1 -0
- package/dist/ops/daily-cost-override.js +23 -0
- package/dist/ops/daily-cost-override.js.map +1 -0
- package/dist/ops/delete-entry.d.ts +44 -0
- package/dist/ops/delete-entry.d.ts.map +1 -0
- package/dist/ops/delete-entry.js +381 -0
- package/dist/ops/delete-entry.js.map +1 -0
- package/dist/ops/labels-init.d.ts +43 -0
- package/dist/ops/labels-init.d.ts.map +1 -0
- package/dist/ops/labels-init.js +149 -0
- package/dist/ops/labels-init.js.map +1 -0
- package/dist/ops/rebase-and-check.d.ts +34 -0
- package/dist/ops/rebase-and-check.d.ts.map +1 -0
- package/dist/ops/rebase-and-check.js +110 -0
- package/dist/ops/rebase-and-check.js.map +1 -0
- package/dist/ops/rebase.d.ts +18 -0
- package/dist/ops/rebase.d.ts.map +1 -0
- package/dist/ops/rebase.js +67 -0
- package/dist/ops/rebase.js.map +1 -0
- package/dist/ops/retention.d.ts +29 -0
- package/dist/ops/retention.d.ts.map +1 -0
- package/dist/ops/retention.js +120 -0
- package/dist/ops/retention.js.map +1 -0
- package/dist/ops/retry.d.ts +19 -0
- package/dist/ops/retry.d.ts.map +1 -0
- package/dist/ops/retry.js +106 -0
- package/dist/ops/retry.js.map +1 -0
- package/dist/ops/summary.d.ts +42 -0
- package/dist/ops/summary.d.ts.map +1 -0
- package/dist/ops/summary.js +86 -0
- package/dist/ops/summary.js.map +1 -0
- package/dist/ops/sync.d.ts +47 -0
- package/dist/ops/sync.d.ts.map +1 -0
- package/dist/ops/sync.js +445 -0
- package/dist/ops/sync.js.map +1 -0
- package/dist/planning/mode.d.ts +14 -0
- package/dist/planning/mode.d.ts.map +1 -0
- package/dist/planning/mode.js +33 -0
- package/dist/planning/mode.js.map +1 -0
- package/dist/poller/control.d.ts +21 -0
- package/dist/poller/control.d.ts.map +1 -0
- package/dist/poller/control.js +42 -0
- package/dist/poller/control.js.map +1 -0
- package/dist/poller/shutdown.d.ts +20 -0
- package/dist/poller/shutdown.d.ts.map +1 -0
- package/dist/poller/shutdown.js +94 -0
- package/dist/poller/shutdown.js.map +1 -0
- package/dist/publishing/pr-body.d.ts +25 -0
- package/dist/publishing/pr-body.d.ts.map +1 -0
- package/dist/publishing/pr-body.js +119 -0
- package/dist/publishing/pr-body.js.map +1 -0
- package/dist/publishing/publisher.d.ts +19 -0
- package/dist/publishing/publisher.d.ts.map +1 -0
- package/dist/publishing/publisher.js +116 -0
- package/dist/publishing/publisher.js.map +1 -0
- package/dist/publishing/push.d.ts +13 -0
- package/dist/publishing/push.d.ts.map +1 -0
- package/dist/publishing/push.js +56 -0
- package/dist/publishing/push.js.map +1 -0
- package/dist/reactions/handler.d.ts +20 -0
- package/dist/reactions/handler.d.ts.map +1 -0
- package/dist/reactions/handler.js +50 -0
- package/dist/reactions/handler.js.map +1 -0
- package/dist/reactions/scanner.d.ts +13 -0
- package/dist/reactions/scanner.d.ts.map +1 -0
- package/dist/reactions/scanner.js +141 -0
- package/dist/reactions/scanner.js.map +1 -0
- package/dist/reactions/types.d.ts +41 -0
- package/dist/reactions/types.d.ts.map +1 -0
- package/dist/reactions/types.js +2 -0
- package/dist/reactions/types.js.map +1 -0
- package/dist/runner/poller.d.ts +19 -0
- package/dist/runner/poller.d.ts.map +1 -0
- package/dist/runner/poller.js +1358 -0
- package/dist/runner/poller.js.map +1 -0
- package/dist/settings/registry.d.ts +37 -0
- package/dist/settings/registry.d.ts.map +1 -0
- package/dist/settings/registry.js +299 -0
- package/dist/settings/registry.js.map +1 -0
- package/dist/settings/runtime.d.ts +33 -0
- package/dist/settings/runtime.d.ts.map +1 -0
- package/dist/settings/runtime.js +148 -0
- package/dist/settings/runtime.js.map +1 -0
- package/dist/state/db.d.ts +3 -0
- package/dist/state/db.d.ts.map +1 -0
- package/dist/state/db.js +80 -0
- package/dist/state/db.js.map +1 -0
- package/dist/state/issues.d.ts +47 -0
- package/dist/state/issues.d.ts.map +1 -0
- package/dist/state/issues.js +188 -0
- package/dist/state/issues.js.map +1 -0
- package/dist/state/leases.d.ts +27 -0
- package/dist/state/leases.d.ts.map +1 -0
- package/dist/state/leases.js +75 -0
- package/dist/state/leases.js.map +1 -0
- package/dist/state/migrations/001-initial.d.ts +3 -0
- package/dist/state/migrations/001-initial.d.ts.map +1 -0
- package/dist/state/migrations/001-initial.js +70 -0
- package/dist/state/migrations/001-initial.js.map +1 -0
- package/dist/state/migrations/002-placeholder.d.ts +7 -0
- package/dist/state/migrations/002-placeholder.d.ts.map +1 -0
- package/dist/state/migrations/002-placeholder.js +8 -0
- package/dist/state/migrations/002-placeholder.js.map +1 -0
- package/dist/state/migrations/003-mention-tracking.d.ts +3 -0
- package/dist/state/migrations/003-mention-tracking.d.ts.map +1 -0
- package/dist/state/migrations/003-mention-tracking.js +13 -0
- package/dist/state/migrations/003-mention-tracking.js.map +1 -0
- package/dist/state/migrations/004-command-tracking.d.ts +3 -0
- package/dist/state/migrations/004-command-tracking.d.ts.map +1 -0
- package/dist/state/migrations/004-command-tracking.js +13 -0
- package/dist/state/migrations/004-command-tracking.js.map +1 -0
- package/dist/state/migrations/005-block-reason.d.ts +3 -0
- package/dist/state/migrations/005-block-reason.d.ts.map +1 -0
- package/dist/state/migrations/005-block-reason.js +4 -0
- package/dist/state/migrations/005-block-reason.js.map +1 -0
- package/dist/state/migrations/006-parent-run.d.ts +3 -0
- package/dist/state/migrations/006-parent-run.d.ts.map +1 -0
- package/dist/state/migrations/006-parent-run.js +4 -0
- package/dist/state/migrations/006-parent-run.js.map +1 -0
- package/dist/state/migrations/007-merge-queue.d.ts +3 -0
- package/dist/state/migrations/007-merge-queue.d.ts.map +1 -0
- package/dist/state/migrations/007-merge-queue.js +21 -0
- package/dist/state/migrations/007-merge-queue.js.map +1 -0
- package/dist/state/migrations/008-agent-events.d.ts +3 -0
- package/dist/state/migrations/008-agent-events.d.ts.map +1 -0
- package/dist/state/migrations/008-agent-events.js +15 -0
- package/dist/state/migrations/008-agent-events.js.map +1 -0
- package/dist/state/migrations/009-run-titles.d.ts +3 -0
- package/dist/state/migrations/009-run-titles.d.ts.map +1 -0
- package/dist/state/migrations/009-run-titles.js +11 -0
- package/dist/state/migrations/009-run-titles.js.map +1 -0
- package/dist/state/migrations/010-issues.d.ts +9 -0
- package/dist/state/migrations/010-issues.d.ts.map +1 -0
- package/dist/state/migrations/010-issues.js +193 -0
- package/dist/state/migrations/010-issues.js.map +1 -0
- package/dist/state/migrations/011-rebuild-issues-from-latest-run.d.ts +8 -0
- package/dist/state/migrations/011-rebuild-issues-from-latest-run.d.ts.map +1 -0
- package/dist/state/migrations/011-rebuild-issues-from-latest-run.js +125 -0
- package/dist/state/migrations/011-rebuild-issues-from-latest-run.js.map +1 -0
- package/dist/state/migrations/012-settings-overrides.d.ts +3 -0
- package/dist/state/migrations/012-settings-overrides.d.ts.map +1 -0
- package/dist/state/migrations/012-settings-overrides.js +14 -0
- package/dist/state/migrations/012-settings-overrides.js.map +1 -0
- package/dist/state/migrations/013-token-usage.d.ts +3 -0
- package/dist/state/migrations/013-token-usage.d.ts.map +1 -0
- package/dist/state/migrations/013-token-usage.js +21 -0
- package/dist/state/migrations/013-token-usage.js.map +1 -0
- package/dist/state/migrations/014-daily-run-usage.d.ts +3 -0
- package/dist/state/migrations/014-daily-run-usage.d.ts.map +1 -0
- package/dist/state/migrations/014-daily-run-usage.js +14 -0
- package/dist/state/migrations/014-daily-run-usage.js.map +1 -0
- package/dist/state/migrations/015-run-cost-override.d.ts +11 -0
- package/dist/state/migrations/015-run-cost-override.d.ts.map +1 -0
- package/dist/state/migrations/015-run-cost-override.js +20 -0
- package/dist/state/migrations/015-run-cost-override.js.map +1 -0
- package/dist/state/migrations/016-daily-cost-cap-override.d.ts +15 -0
- package/dist/state/migrations/016-daily-cost-cap-override.d.ts.map +1 -0
- package/dist/state/migrations/016-daily-cost-cap-override.js +24 -0
- package/dist/state/migrations/016-daily-cost-cap-override.js.map +1 -0
- package/dist/state/migrations/017-merge-batch-merged-prs.d.ts +13 -0
- package/dist/state/migrations/017-merge-batch-merged-prs.d.ts.map +1 -0
- package/dist/state/migrations/017-merge-batch-merged-prs.js +22 -0
- package/dist/state/migrations/017-merge-batch-merged-prs.js.map +1 -0
- package/dist/state/migrations/018-run-retry-count.d.ts +13 -0
- package/dist/state/migrations/018-run-retry-count.d.ts.map +1 -0
- package/dist/state/migrations/018-run-retry-count.js +22 -0
- package/dist/state/migrations/018-run-retry-count.js.map +1 -0
- package/dist/state/migrations/019-runs-active-index-top-level.d.ts +16 -0
- package/dist/state/migrations/019-runs-active-index-top-level.d.ts.map +1 -0
- package/dist/state/migrations/019-runs-active-index-top-level.js +23 -0
- package/dist/state/migrations/019-runs-active-index-top-level.js.map +1 -0
- package/dist/state/runs.d.ts +100 -0
- package/dist/state/runs.d.ts.map +1 -0
- package/dist/state/runs.js +321 -0
- package/dist/state/runs.js.map +1 -0
- package/dist/state/settings.d.ts +16 -0
- package/dist/state/settings.d.ts.map +1 -0
- package/dist/state/settings.js +55 -0
- package/dist/state/settings.js.map +1 -0
- package/dist/state/stats.d.ts +133 -0
- package/dist/state/stats.d.ts.map +1 -0
- package/dist/state/stats.js +419 -0
- package/dist/state/stats.js.map +1 -0
- package/dist/supervisor/health.d.ts +24 -0
- package/dist/supervisor/health.d.ts.map +1 -0
- package/dist/supervisor/health.js +186 -0
- package/dist/supervisor/health.js.map +1 -0
- package/dist/supervisor/index.d.ts +31 -0
- package/dist/supervisor/index.d.ts.map +1 -0
- package/dist/supervisor/index.js +387 -0
- package/dist/supervisor/index.js.map +1 -0
- package/dist/supervisor/status.d.ts +18 -0
- package/dist/supervisor/status.d.ts.map +1 -0
- package/dist/supervisor/status.js +30 -0
- package/dist/supervisor/status.js.map +1 -0
- package/dist/supervisor/updater.d.ts +18 -0
- package/dist/supervisor/updater.d.ts.map +1 -0
- package/dist/supervisor/updater.js +108 -0
- package/dist/supervisor/updater.js.map +1 -0
- package/dist/utils/build-info.d.ts +6 -0
- package/dist/utils/build-info.d.ts.map +1 -0
- package/dist/utils/build-info.js +56 -0
- package/dist/utils/build-info.js.map +1 -0
- package/dist/utils/command.d.ts +8 -0
- package/dist/utils/command.d.ts.map +1 -0
- package/dist/utils/command.js +71 -0
- package/dist/utils/command.js.map +1 -0
- package/dist/utils/ids.d.ts +4 -0
- package/dist/utils/ids.d.ts.map +1 -0
- package/dist/utils/ids.js +17 -0
- package/dist/utils/ids.js.map +1 -0
- package/dist/utils/install-method.d.ts +4 -0
- package/dist/utils/install-method.d.ts.map +1 -0
- package/dist/utils/install-method.js +13 -0
- package/dist/utils/install-method.js.map +1 -0
- package/dist/utils/issue-repo.d.ts +2 -0
- package/dist/utils/issue-repo.d.ts.map +1 -0
- package/dist/utils/issue-repo.js +7 -0
- package/dist/utils/issue-repo.js.map +1 -0
- package/dist/utils/logger.d.ts +7 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +63 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/project-root.d.ts +8 -0
- package/dist/utils/project-root.d.ts.map +1 -0
- package/dist/utils/project-root.js +22 -0
- package/dist/utils/project-root.js.map +1 -0
- package/dist/utils/sanitize-error.d.ts +36 -0
- package/dist/utils/sanitize-error.d.ts.map +1 -0
- package/dist/utils/sanitize-error.js +89 -0
- package/dist/utils/sanitize-error.js.map +1 -0
- package/dist/utils/time.d.ts +7 -0
- package/dist/utils/time.d.ts.map +1 -0
- package/dist/utils/time.js +47 -0
- package/dist/utils/time.js.map +1 -0
- package/dist/web/server.d.ts +14 -0
- package/dist/web/server.d.ts.map +1 -0
- package/dist/web/server.js +1185 -0
- package/dist/web/server.js.map +1 -0
- package/dist/workers/acp.d.ts +9 -0
- package/dist/workers/acp.d.ts.map +1 -0
- package/dist/workers/acp.js +190 -0
- package/dist/workers/acp.js.map +1 -0
- package/dist/workers/acpx-imports.d.ts +18 -0
- package/dist/workers/acpx-imports.d.ts.map +1 -0
- package/dist/workers/acpx-imports.js +43 -0
- package/dist/workers/acpx-imports.js.map +1 -0
- package/dist/workers/claude.d.ts +9 -0
- package/dist/workers/claude.d.ts.map +1 -0
- package/dist/workers/claude.js +341 -0
- package/dist/workers/claude.js.map +1 -0
- package/dist/workers/codex.d.ts +21 -0
- package/dist/workers/codex.d.ts.map +1 -0
- package/dist/workers/codex.js +337 -0
- package/dist/workers/codex.js.map +1 -0
- package/dist/workers/command.d.ts +6 -0
- package/dist/workers/command.d.ts.map +1 -0
- package/dist/workers/command.js +15 -0
- package/dist/workers/command.js.map +1 -0
- package/dist/workers/env.d.ts +18 -0
- package/dist/workers/env.d.ts.map +1 -0
- package/dist/workers/env.js +172 -0
- package/dist/workers/env.js.map +1 -0
- package/dist/workers/events.d.ts +7 -0
- package/dist/workers/events.d.ts.map +1 -0
- package/dist/workers/events.js +30 -0
- package/dist/workers/events.js.map +1 -0
- package/dist/workers/factory.d.ts +6 -0
- package/dist/workers/factory.d.ts.map +1 -0
- package/dist/workers/factory.js +13 -0
- package/dist/workers/factory.js.map +1 -0
- package/dist/workers/parsers/coder.d.ts +6 -0
- package/dist/workers/parsers/coder.d.ts.map +1 -0
- package/dist/workers/parsers/coder.js +59 -0
- package/dist/workers/parsers/coder.js.map +1 -0
- package/dist/workers/parsers/decomposer.d.ts +16 -0
- package/dist/workers/parsers/decomposer.d.ts.map +1 -0
- package/dist/workers/parsers/decomposer.js +35 -0
- package/dist/workers/parsers/decomposer.js.map +1 -0
- package/dist/workers/parsers/extract.d.ts +41 -0
- package/dist/workers/parsers/extract.d.ts.map +1 -0
- package/dist/workers/parsers/extract.js +231 -0
- package/dist/workers/parsers/extract.js.map +1 -0
- package/dist/workers/parsers/planner.d.ts +6 -0
- package/dist/workers/parsers/planner.d.ts.map +1 -0
- package/dist/workers/parsers/planner.js +77 -0
- package/dist/workers/parsers/planner.js.map +1 -0
- package/dist/workers/parsers/reviewer.d.ts +6 -0
- package/dist/workers/parsers/reviewer.d.ts.map +1 -0
- package/dist/workers/parsers/reviewer.js +105 -0
- package/dist/workers/parsers/reviewer.js.map +1 -0
- package/dist/workers/prompt/compiler.d.ts +11 -0
- package/dist/workers/prompt/compiler.d.ts.map +1 -0
- package/dist/workers/prompt/compiler.js +199 -0
- package/dist/workers/prompt/compiler.js.map +1 -0
- package/dist/workers/prompt/templates.d.ts +13 -0
- package/dist/workers/prompt/templates.d.ts.map +1 -0
- package/dist/workers/prompt/templates.js +110 -0
- package/dist/workers/prompt/templates.js.map +1 -0
- package/dist/workers/registry.d.ts +9 -0
- package/dist/workers/registry.d.ts.map +1 -0
- package/dist/workers/registry.js +21 -0
- package/dist/workers/registry.js.map +1 -0
- package/dist/workers/streaming-exec.d.ts +26 -0
- package/dist/workers/streaming-exec.d.ts.map +1 -0
- package/dist/workers/streaming-exec.js +166 -0
- package/dist/workers/streaming-exec.js.map +1 -0
- package/dist/workers/timeout.d.ts +17 -0
- package/dist/workers/timeout.d.ts.map +1 -0
- package/dist/workers/timeout.js +37 -0
- package/dist/workers/timeout.js.map +1 -0
- package/dist/workers/types.d.ts +120 -0
- package/dist/workers/types.d.ts.map +1 -0
- package/dist/workers/types.js +2 -0
- package/dist/workers/types.js.map +1 -0
- package/docker-compose.example.yaml +29 -0
- package/examples/config.example.yaml +256 -0
- package/examples/night-orch.service +40 -0
- package/monitoring/grafana/dashboards/night-orch.json +140 -0
- package/monitoring/grafana/provisioning/dashboards/dashboards.yml +10 -0
- package/monitoring/grafana/provisioning/datasources/prometheus.yml +9 -0
- package/monitoring/prometheus.yml +8 -0
- package/package.json +104 -0
- package/web/dist/assets/index-CBFNqVuV.js +9 -0
- package/web/dist/assets/index-RCNGmuI2.css +1 -0
- package/web/dist/icon.svg +10 -0
- package/web/dist/index.html +22 -0
- package/web/dist/manifest.webmanifest +16 -0
- package/web/dist/sw.js +58 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkpoint.js","sourceRoot":"","sources":["../../src/loop/checkpoint.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { Config } from '../config/schema.js';
|
|
2
|
+
export interface CommitChangesOptions {
|
|
3
|
+
planningOnlyPrdPath?: string;
|
|
4
|
+
issueLabels?: string[];
|
|
5
|
+
}
|
|
6
|
+
export interface CommitChangesResult {
|
|
7
|
+
committed: boolean;
|
|
8
|
+
reason: string | null;
|
|
9
|
+
/** If true, caller should end the run as blocked instead of publishing. */
|
|
10
|
+
blockRun: boolean;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Stage all changes and commit with a standard message.
|
|
14
|
+
* Runs diff-guard before committing.
|
|
15
|
+
*/
|
|
16
|
+
export declare function commitChanges(worktreePath: string, issueNumber: number, issueTitle: string, securityConfig: Config['security'], opts?: CommitChangesOptions): Promise<CommitChangesResult>;
|
|
17
|
+
//# sourceMappingURL=commit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commit.d.ts","sourceRoot":"","sources":["../../src/loop/commit.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAMjD,MAAM,WAAW,oBAAoB;IACnC,mBAAmB,CAAC,EAAE,MAAM,CAAA;IAC5B,WAAW,CAAC,EAAE,MAAM,EAAE,CAAA;CACvB;AAED,MAAM,WAAW,mBAAmB;IAClC,SAAS,EAAE,OAAO,CAAA;IAClB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,2EAA2E;IAC3E,QAAQ,EAAE,OAAO,CAAA;CAClB;AAED;;;GAGG;AACH,wBAAsB,aAAa,CACjC,YAAY,EAAE,MAAM,EACpB,WAAW,EAAE,MAAM,EACnB,UAAU,EAAE,MAAM,EAClB,cAAc,EAAE,MAAM,CAAC,UAAU,CAAC,EAClC,IAAI,GAAE,oBAAyB,GAC9B,OAAO,CAAC,mBAAmB,CAAC,CA0D9B"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { checkDiffSize } from './diff-guard.js';
|
|
2
|
+
import { logger } from '../utils/logger.js';
|
|
3
|
+
import { normalizeRepoRelativePath } from '../planning/mode.js';
|
|
4
|
+
import { runGit } from '../git/process.js';
|
|
5
|
+
import { compilePRTitle } from '../publishing/pr-body.js';
|
|
6
|
+
/**
|
|
7
|
+
* Stage all changes and commit with a standard message.
|
|
8
|
+
* Runs diff-guard before committing.
|
|
9
|
+
*/
|
|
10
|
+
export async function commitChanges(worktreePath, issueNumber, issueTitle, securityConfig, opts = {}) {
|
|
11
|
+
const expectedPlanningPath = opts.planningOnlyPrdPath
|
|
12
|
+
? normalizeGitPath(opts.planningOnlyPrdPath)
|
|
13
|
+
: null;
|
|
14
|
+
// Check if there are any changes to commit
|
|
15
|
+
const { stdout: statusOutput } = await runGit(['status', '--porcelain'], {
|
|
16
|
+
cwd: worktreePath,
|
|
17
|
+
});
|
|
18
|
+
if (statusOutput.trim() === '') {
|
|
19
|
+
if (expectedPlanningPath) {
|
|
20
|
+
return {
|
|
21
|
+
committed: false,
|
|
22
|
+
reason: `Planning-only guard: expected "${expectedPlanningPath}" but no changes were found`,
|
|
23
|
+
blockRun: true,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
return { committed: false, reason: 'No changes to commit', blockRun: false };
|
|
27
|
+
}
|
|
28
|
+
// Stage before diff-size guard so new files are included in checks.
|
|
29
|
+
await runGit(['add', '-A'], { cwd: worktreePath });
|
|
30
|
+
// Diff-size guard on staged changes.
|
|
31
|
+
const diffCheck = await checkDiffSize(worktreePath, securityConfig, { staged: true });
|
|
32
|
+
if (!diffCheck.ok) {
|
|
33
|
+
await runGit(['reset', 'HEAD', '--', '.'], { cwd: worktreePath, reject: false });
|
|
34
|
+
logger.warn({ stats: diffCheck.stats, reason: diffCheck.reason }, 'Diff-size guard triggered — skipping commit');
|
|
35
|
+
return { committed: false, reason: `Diff-size guard: ${diffCheck.reason}`, blockRun: true };
|
|
36
|
+
}
|
|
37
|
+
if (expectedPlanningPath) {
|
|
38
|
+
const changedFiles = await getStagedChangedFiles(worktreePath);
|
|
39
|
+
const normalizedFiles = changedFiles.map(normalizeGitPath);
|
|
40
|
+
const isOnlyExpected = normalizedFiles.length === 1 && normalizedFiles[0] === expectedPlanningPath;
|
|
41
|
+
if (!isOnlyExpected) {
|
|
42
|
+
await runGit(['reset', 'HEAD', '--', '.'], { cwd: worktreePath, reject: false });
|
|
43
|
+
return {
|
|
44
|
+
committed: false,
|
|
45
|
+
reason: `Planning-only guard: expected only "${expectedPlanningPath}" but found [${normalizedFiles.join(', ') || '(none)'}]`,
|
|
46
|
+
blockRun: true,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
const message = compilePRTitle(issueNumber, issueTitle, opts.issueLabels ?? []);
|
|
51
|
+
await runGit(['commit', '-m', message], { cwd: worktreePath });
|
|
52
|
+
logger.info({ issueNumber, files: diffCheck.stats.changedFiles, lines: diffCheck.stats.totalChangedLines }, 'Changes committed');
|
|
53
|
+
return { committed: true, reason: null, blockRun: false };
|
|
54
|
+
}
|
|
55
|
+
function normalizeGitPath(path) {
|
|
56
|
+
return normalizeRepoRelativePath(path).replace(/^\/+/, '');
|
|
57
|
+
}
|
|
58
|
+
async function getStagedChangedFiles(worktreePath) {
|
|
59
|
+
const { stdout } = await runGit(['diff', '--cached', '--name-only'], { cwd: worktreePath });
|
|
60
|
+
return stdout
|
|
61
|
+
.split('\n')
|
|
62
|
+
.map((line) => line.trim())
|
|
63
|
+
.filter(Boolean);
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=commit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commit.js","sourceRoot":"","sources":["../../src/loop/commit.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { RunContext, LoopPhase } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Create an updated RunContext with new fields.
|
|
4
|
+
* Returns a new object — original is not mutated.
|
|
5
|
+
*/
|
|
6
|
+
export declare function updateContext(ctx: RunContext, patch: Partial<RunContext>): RunContext;
|
|
7
|
+
/**
|
|
8
|
+
* Record a phase completion in the context's phase history.
|
|
9
|
+
*/
|
|
10
|
+
export declare function recordPhase(ctx: RunContext, phase: LoopPhase, result: 'success' | 'failure' | 'skipped', artifacts?: Record<string, unknown>, startedAt?: string): RunContext;
|
|
11
|
+
//# sourceMappingURL=context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../src/loop/context.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAe,MAAM,YAAY,CAAA;AAGpE;;;GAGG;AACH,wBAAgB,aAAa,CAAC,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,GAAG,UAAU,CAErF;AAED;;GAEG;AACH,wBAAgB,WAAW,CACzB,GAAG,EAAE,UAAU,EACf,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,SAAS,EACzC,SAAS,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM,EACvC,SAAS,CAAC,EAAE,MAAM,GACjB,UAAU,CAaZ"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { nowUtcIso } from '../utils/time.js';
|
|
2
|
+
/**
|
|
3
|
+
* Create an updated RunContext with new fields.
|
|
4
|
+
* Returns a new object — original is not mutated.
|
|
5
|
+
*/
|
|
6
|
+
export function updateContext(ctx, patch) {
|
|
7
|
+
return { ...ctx, ...patch };
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* Record a phase completion in the context's phase history.
|
|
11
|
+
*/
|
|
12
|
+
export function recordPhase(ctx, phase, result, artifacts = {}, startedAt) {
|
|
13
|
+
const completedAt = nowUtcIso();
|
|
14
|
+
const record = {
|
|
15
|
+
phase,
|
|
16
|
+
startedAt: startedAt ?? completedAt,
|
|
17
|
+
completedAt,
|
|
18
|
+
result,
|
|
19
|
+
artifacts,
|
|
20
|
+
};
|
|
21
|
+
return updateContext(ctx, {
|
|
22
|
+
phaseHistory: [...ctx.phaseHistory, record],
|
|
23
|
+
currentPhase: phase,
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/loop/context.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAE5C;;;GAGG;AACH,MAAM,UAAU,aAAa,CAAC,GAAe,EAAE,KAA0B;IACvE,OAAO,EAAE,GAAG,GAAG,EAAE,GAAG,KAAK,EAAE,CAAA;AAC7B,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,WAAW,CACzB,GAAe,EACf,KAAgB,EAChB,MAAyC,EACzC,YAAqC,EAAE,EACvC,SAAkB;IAElB,MAAM,WAAW,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,MAAM,GAAgB;QAC1B,KAAK;QACL,SAAS,EAAE,SAAS,IAAI,WAAW;QACnC,WAAW;QACX,MAAM;QACN,SAAS;KACV,CAAA;IACD,OAAO,aAAa,CAAC,GAAG,EAAE;QACxB,YAAY,EAAE,CAAC,GAAG,GAAG,CAAC,YAAY,EAAE,MAAM,CAAC;QAC3C,YAAY,EAAE,KAAK;KACpB,CAAC,CAAA;AACJ,CAAC"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import type Database from 'better-sqlite3';
|
|
2
|
+
import type { Config } from '../config/schema.js';
|
|
3
|
+
interface TokenUsageInput {
|
|
4
|
+
promptTokens: number;
|
|
5
|
+
completionTokens: number;
|
|
6
|
+
}
|
|
7
|
+
export interface TokenUsageTotals {
|
|
8
|
+
promptTokens: number;
|
|
9
|
+
completionTokens: number;
|
|
10
|
+
totalTokens: number;
|
|
11
|
+
}
|
|
12
|
+
export declare class CostTracker {
|
|
13
|
+
private db;
|
|
14
|
+
private issueManager;
|
|
15
|
+
constructor(db: Database.Database);
|
|
16
|
+
recordCost(runId: string, costUsd: number, tokenUsage?: TokenUsageInput): void;
|
|
17
|
+
getDailyCost(): number;
|
|
18
|
+
getRunCost(runId: string): number;
|
|
19
|
+
getDailyTokenUsage(): TokenUsageTotals;
|
|
20
|
+
getRunTokenUsage(runId: string): TokenUsageTotals;
|
|
21
|
+
/**
|
|
22
|
+
* Evaluate whether a run has crossed any spend limit.
|
|
23
|
+
* Returns a discriminated status so callers can build messages that name
|
|
24
|
+
* the specific limit that tripped (daily vs per-run) instead of guessing.
|
|
25
|
+
*
|
|
26
|
+
* When `costModel === 'subscription'` (Claude Pro/Max, Codex Pro, etc.) the
|
|
27
|
+
* USD estimate is advisory only — the operator pays a flat subscription fee,
|
|
28
|
+
* not per-token — so enforcement is skipped entirely. Tokens and the
|
|
29
|
+
* advisory USD estimate continue to be written to the DB for analytics.
|
|
30
|
+
*
|
|
31
|
+
* A non-null `cost_budget_override_usd` on the run row overrides the
|
|
32
|
+
* per-run cap with the stored value AND exempts the run from the daily
|
|
33
|
+
* cap. Operators grant this override to push a specific run through when
|
|
34
|
+
* they accept the extra spend.
|
|
35
|
+
*
|
|
36
|
+
* A non-null `daily_cost_cap_override_usd` on today's `daily_costs` row
|
|
37
|
+
* replaces `limits.maxDailyCostUsd` for today only. It auto-expires when
|
|
38
|
+
* the UTC day rolls over (next day's row starts NULL).
|
|
39
|
+
*/
|
|
40
|
+
checkBudget(runId: string, limits: Config['security'], costModel?: Config['cost']['model']): BudgetStatus;
|
|
41
|
+
/**
|
|
42
|
+
* Read the cost budget override for a run, or null if no override is set.
|
|
43
|
+
*/
|
|
44
|
+
getRunBudgetOverride(runId: string): number | null;
|
|
45
|
+
/**
|
|
46
|
+
* Grant a per-run cost override. Pass null to clear it.
|
|
47
|
+
* When set, the value becomes the run's per-run cap and the daily cap
|
|
48
|
+
* is bypassed for this run.
|
|
49
|
+
*/
|
|
50
|
+
setRunBudgetOverride(runId: string, overrideUsd: number | null): void;
|
|
51
|
+
/**
|
|
52
|
+
* Read the daily cost cap override for a UTC day (defaults to today).
|
|
53
|
+
* Returns null when no override is set.
|
|
54
|
+
*/
|
|
55
|
+
getDailyCapOverride(date?: string): number | null;
|
|
56
|
+
/**
|
|
57
|
+
* Set or clear the daily cost cap override for a UTC day (defaults to
|
|
58
|
+
* today). Upserts the `daily_costs` row so the override works even on a
|
|
59
|
+
* day with no recorded spend yet. The override auto-expires when the UTC
|
|
60
|
+
* day rolls over — operators do not need to clear it manually.
|
|
61
|
+
*/
|
|
62
|
+
setDailyCapOverride(overrideUsd: number | null, date?: string): void;
|
|
63
|
+
}
|
|
64
|
+
export type BudgetStatus = {
|
|
65
|
+
overBudget: false;
|
|
66
|
+
} | {
|
|
67
|
+
overBudget: true;
|
|
68
|
+
limit: 'daily' | 'per-run';
|
|
69
|
+
actualUsd: number;
|
|
70
|
+
limitUsd: number;
|
|
71
|
+
};
|
|
72
|
+
/** Human-readable message naming the specific limit that tripped. */
|
|
73
|
+
export declare function describeBudgetBlock(status: Extract<BudgetStatus, {
|
|
74
|
+
overBudget: true;
|
|
75
|
+
}>): string;
|
|
76
|
+
/** Actionable recovery hint shown alongside the block reason. */
|
|
77
|
+
export declare function costLimitRecoveryHint(limit: 'daily' | 'per-run'): string;
|
|
78
|
+
export {};
|
|
79
|
+
//# sourceMappingURL=cost.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cost.d.ts","sourceRoot":"","sources":["../../src/loop/cost.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAA;AAC1C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAKjD,UAAU,eAAe;IACvB,YAAY,EAAE,MAAM,CAAA;IACpB,gBAAgB,EAAE,MAAM,CAAA;CACzB;AAED,MAAM,WAAW,gBAAgB;IAC/B,YAAY,EAAE,MAAM,CAAA;IACpB,gBAAgB,EAAE,MAAM,CAAA;IACxB,WAAW,EAAE,MAAM,CAAA;CACpB;AAED,qBAAa,WAAW;IAGV,OAAO,CAAC,EAAE;IAFtB,OAAO,CAAC,YAAY,CAAc;gBAEd,EAAE,EAAE,QAAQ,CAAC,QAAQ;IAIzC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,eAAe,GAAG,IAAI;IA4C9E,YAAY,IAAI,MAAM;IAQtB,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAOjC,kBAAkB,IAAI,gBAAgB;IAetC,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,gBAAgB;IAcjD;;;;;;;;;;;;;;;;;;OAkBG;IACH,WAAW,CACT,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,CAAC,UAAU,CAAC,EAC1B,SAAS,GAAE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAiB,GACjD,YAAY;IA0Cf;;OAEG;IACH,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAQlD;;;;OAIG;IACH,oBAAoB,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI;IASrE;;;OAGG;IACH,mBAAmB,CAAC,IAAI,GAAE,MAAoB,GAAG,MAAM,GAAG,IAAI;IAQ9D;;;;;OAKG;IACH,mBAAmB,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI,EAAE,IAAI,GAAE,MAAoB,GAAG,IAAI;CAclF;AAED,MAAM,MAAM,YAAY,GACpB;IAAE,UAAU,EAAE,KAAK,CAAA;CAAE,GACrB;IACE,UAAU,EAAE,IAAI,CAAA;IAChB,KAAK,EAAE,OAAO,GAAG,SAAS,CAAA;IAC1B,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,EAAE,MAAM,CAAA;CACjB,CAAA;AAEL,qEAAqE;AACrE,wBAAgB,mBAAmB,CACjC,MAAM,EAAE,OAAO,CAAC,YAAY,EAAE;IAAE,UAAU,EAAE,IAAI,CAAA;CAAE,CAAC,GAClD,MAAM,CAGR;AAED,iEAAiE;AACjE,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,OAAO,GAAG,SAAS,GAAG,MAAM,CAaxE"}
|
|
@@ -0,0 +1,223 @@
|
|
|
1
|
+
import { IssueManager } from '../state/issues.js';
|
|
2
|
+
import { RunManager } from '../state/runs.js';
|
|
3
|
+
import { utcDayKey } from '../utils/time.js';
|
|
4
|
+
export class CostTracker {
|
|
5
|
+
db;
|
|
6
|
+
issueManager;
|
|
7
|
+
constructor(db) {
|
|
8
|
+
this.db = db;
|
|
9
|
+
this.issueManager = new IssueManager(db);
|
|
10
|
+
}
|
|
11
|
+
recordCost(runId, costUsd, tokenUsage) {
|
|
12
|
+
const amountUsd = Number(Math.max(0, costUsd).toFixed(6));
|
|
13
|
+
const normalizedTokens = normalizeTokenUsage(tokenUsage);
|
|
14
|
+
if (amountUsd <= 0 && normalizedTokens.totalTokens <= 0)
|
|
15
|
+
return;
|
|
16
|
+
const today = utcDayKey();
|
|
17
|
+
const tx = this.db.transaction((id, date, usage, usdAmount) => {
|
|
18
|
+
const runUsageInsert = this.db
|
|
19
|
+
.prepare(`INSERT INTO daily_run_usage (date, run_id)
|
|
20
|
+
VALUES (?, ?)
|
|
21
|
+
ON CONFLICT(date, run_id) DO NOTHING`)
|
|
22
|
+
.run(date, id);
|
|
23
|
+
const dailyRunCountIncrement = runUsageInsert.changes > 0 ? 1 : 0;
|
|
24
|
+
this.db
|
|
25
|
+
.prepare(`INSERT INTO daily_costs (date, total_cost_usd, run_count, total_prompt_tokens, total_completion_tokens)
|
|
26
|
+
VALUES (?, ?, ?, ?, ?)
|
|
27
|
+
ON CONFLICT(date) DO UPDATE SET
|
|
28
|
+
total_cost_usd = total_cost_usd + excluded.total_cost_usd,
|
|
29
|
+
run_count = run_count + excluded.run_count,
|
|
30
|
+
total_prompt_tokens = total_prompt_tokens + excluded.total_prompt_tokens,
|
|
31
|
+
total_completion_tokens = total_completion_tokens + excluded.total_completion_tokens`)
|
|
32
|
+
.run(date, usdAmount, dailyRunCountIncrement, usage.promptTokens, usage.completionTokens);
|
|
33
|
+
this.db
|
|
34
|
+
.prepare(`UPDATE runs
|
|
35
|
+
SET estimated_cost_usd = estimated_cost_usd + ?,
|
|
36
|
+
prompt_tokens = prompt_tokens + ?,
|
|
37
|
+
completion_tokens = completion_tokens + ?
|
|
38
|
+
WHERE id = ?`)
|
|
39
|
+
.run(usdAmount, usage.promptTokens, usage.completionTokens, id);
|
|
40
|
+
this.issueManager.syncFromRunId(id);
|
|
41
|
+
});
|
|
42
|
+
tx(runId, today, normalizedTokens, amountUsd);
|
|
43
|
+
}
|
|
44
|
+
getDailyCost() {
|
|
45
|
+
const today = utcDayKey();
|
|
46
|
+
const row = this.db
|
|
47
|
+
.prepare('SELECT total_cost_usd FROM daily_costs WHERE date = ?')
|
|
48
|
+
.get(today);
|
|
49
|
+
return row?.total_cost_usd ?? 0;
|
|
50
|
+
}
|
|
51
|
+
getRunCost(runId) {
|
|
52
|
+
const row = this.db
|
|
53
|
+
.prepare('SELECT estimated_cost_usd FROM runs WHERE id = ?')
|
|
54
|
+
.get(runId);
|
|
55
|
+
return row?.estimated_cost_usd ?? 0;
|
|
56
|
+
}
|
|
57
|
+
getDailyTokenUsage() {
|
|
58
|
+
const today = utcDayKey();
|
|
59
|
+
const row = this.db
|
|
60
|
+
.prepare('SELECT total_prompt_tokens, total_completion_tokens FROM daily_costs WHERE date = ?')
|
|
61
|
+
.get(today);
|
|
62
|
+
const promptTokens = row?.total_prompt_tokens ?? 0;
|
|
63
|
+
const completionTokens = row?.total_completion_tokens ?? 0;
|
|
64
|
+
return {
|
|
65
|
+
promptTokens,
|
|
66
|
+
completionTokens,
|
|
67
|
+
totalTokens: promptTokens + completionTokens,
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
getRunTokenUsage(runId) {
|
|
71
|
+
const row = this.db
|
|
72
|
+
.prepare('SELECT prompt_tokens, completion_tokens FROM runs WHERE id = ?')
|
|
73
|
+
.get(runId);
|
|
74
|
+
const promptTokens = row?.prompt_tokens ?? 0;
|
|
75
|
+
const completionTokens = row?.completion_tokens ?? 0;
|
|
76
|
+
return {
|
|
77
|
+
promptTokens,
|
|
78
|
+
completionTokens,
|
|
79
|
+
totalTokens: promptTokens + completionTokens,
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Evaluate whether a run has crossed any spend limit.
|
|
84
|
+
* Returns a discriminated status so callers can build messages that name
|
|
85
|
+
* the specific limit that tripped (daily vs per-run) instead of guessing.
|
|
86
|
+
*
|
|
87
|
+
* When `costModel === 'subscription'` (Claude Pro/Max, Codex Pro, etc.) the
|
|
88
|
+
* USD estimate is advisory only — the operator pays a flat subscription fee,
|
|
89
|
+
* not per-token — so enforcement is skipped entirely. Tokens and the
|
|
90
|
+
* advisory USD estimate continue to be written to the DB for analytics.
|
|
91
|
+
*
|
|
92
|
+
* A non-null `cost_budget_override_usd` on the run row overrides the
|
|
93
|
+
* per-run cap with the stored value AND exempts the run from the daily
|
|
94
|
+
* cap. Operators grant this override to push a specific run through when
|
|
95
|
+
* they accept the extra spend.
|
|
96
|
+
*
|
|
97
|
+
* A non-null `daily_cost_cap_override_usd` on today's `daily_costs` row
|
|
98
|
+
* replaces `limits.maxDailyCostUsd` for today only. It auto-expires when
|
|
99
|
+
* the UTC day rolls over (next day's row starts NULL).
|
|
100
|
+
*/
|
|
101
|
+
checkBudget(runId, limits, costModel = 'pay-per-use') {
|
|
102
|
+
// Subscription plans are flat-rate. The per-token USD numbers the worker
|
|
103
|
+
// adapters report are "what this would have cost on the API" estimates and
|
|
104
|
+
// have no relationship to what the operator actually pays, so enforcing
|
|
105
|
+
// them would block every run the moment tokens add up.
|
|
106
|
+
if (costModel === 'subscription') {
|
|
107
|
+
return { overBudget: false };
|
|
108
|
+
}
|
|
109
|
+
const override = this.getRunBudgetOverride(runId);
|
|
110
|
+
const runCost = this.getRunCost(runId);
|
|
111
|
+
const effectivePerRunLimit = override ?? limits.maxCostPerRunUsd;
|
|
112
|
+
if (runCost >= effectivePerRunLimit) {
|
|
113
|
+
return {
|
|
114
|
+
overBudget: true,
|
|
115
|
+
limit: 'per-run',
|
|
116
|
+
actualUsd: runCost,
|
|
117
|
+
limitUsd: effectivePerRunLimit,
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
// Override grants a one-time bypass of the daily cap so a stuck run can
|
|
121
|
+
// make forward progress even if the day has already blown past the limit.
|
|
122
|
+
if (override !== null) {
|
|
123
|
+
return { overBudget: false };
|
|
124
|
+
}
|
|
125
|
+
const dailyCost = this.getDailyCost();
|
|
126
|
+
const dailyCapOverride = this.getDailyCapOverride();
|
|
127
|
+
const effectiveDailyLimit = dailyCapOverride ?? limits.maxDailyCostUsd;
|
|
128
|
+
if (dailyCost >= effectiveDailyLimit) {
|
|
129
|
+
return {
|
|
130
|
+
overBudget: true,
|
|
131
|
+
limit: 'daily',
|
|
132
|
+
actualUsd: dailyCost,
|
|
133
|
+
limitUsd: effectiveDailyLimit,
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
return { overBudget: false };
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Read the cost budget override for a run, or null if no override is set.
|
|
140
|
+
*/
|
|
141
|
+
getRunBudgetOverride(runId) {
|
|
142
|
+
const row = this.db
|
|
143
|
+
.prepare('SELECT cost_budget_override_usd FROM runs WHERE id = ?')
|
|
144
|
+
.get(runId);
|
|
145
|
+
if (!row)
|
|
146
|
+
return null;
|
|
147
|
+
return row.cost_budget_override_usd ?? null;
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* Grant a per-run cost override. Pass null to clear it.
|
|
151
|
+
* When set, the value becomes the run's per-run cap and the daily cap
|
|
152
|
+
* is bypassed for this run.
|
|
153
|
+
*/
|
|
154
|
+
setRunBudgetOverride(runId, overrideUsd) {
|
|
155
|
+
if (overrideUsd !== null) {
|
|
156
|
+
if (!Number.isFinite(overrideUsd) || overrideUsd <= 0) {
|
|
157
|
+
throw new Error(`cost budget override must be a positive finite number, got ${overrideUsd}`);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
new RunManager(this.db).setCostBudgetOverride(runId, overrideUsd);
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Read the daily cost cap override for a UTC day (defaults to today).
|
|
164
|
+
* Returns null when no override is set.
|
|
165
|
+
*/
|
|
166
|
+
getDailyCapOverride(date = utcDayKey()) {
|
|
167
|
+
const row = this.db
|
|
168
|
+
.prepare('SELECT daily_cost_cap_override_usd FROM daily_costs WHERE date = ?')
|
|
169
|
+
.get(date);
|
|
170
|
+
if (!row)
|
|
171
|
+
return null;
|
|
172
|
+
return row.daily_cost_cap_override_usd ?? null;
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Set or clear the daily cost cap override for a UTC day (defaults to
|
|
176
|
+
* today). Upserts the `daily_costs` row so the override works even on a
|
|
177
|
+
* day with no recorded spend yet. The override auto-expires when the UTC
|
|
178
|
+
* day rolls over — operators do not need to clear it manually.
|
|
179
|
+
*/
|
|
180
|
+
setDailyCapOverride(overrideUsd, date = utcDayKey()) {
|
|
181
|
+
if (overrideUsd !== null) {
|
|
182
|
+
if (!Number.isFinite(overrideUsd) || overrideUsd <= 0) {
|
|
183
|
+
throw new Error(`daily cap override must be a positive finite number, got ${overrideUsd}`);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
this.db
|
|
187
|
+
.prepare(`INSERT INTO daily_costs (date, total_cost_usd, run_count, total_prompt_tokens, total_completion_tokens, daily_cost_cap_override_usd)
|
|
188
|
+
VALUES (?, 0, 0, 0, 0, ?)
|
|
189
|
+
ON CONFLICT(date) DO UPDATE SET daily_cost_cap_override_usd = excluded.daily_cost_cap_override_usd`)
|
|
190
|
+
.run(date, overrideUsd);
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
/** Human-readable message naming the specific limit that tripped. */
|
|
194
|
+
export function describeBudgetBlock(status) {
|
|
195
|
+
const label = status.limit === 'daily' ? 'Daily cost limit' : 'Per-run cost limit';
|
|
196
|
+
return `${label} exceeded: $${status.actualUsd.toFixed(2)} >= $${status.limitUsd.toFixed(2)}`;
|
|
197
|
+
}
|
|
198
|
+
/** Actionable recovery hint shown alongside the block reason. */
|
|
199
|
+
export function costLimitRecoveryHint(limit) {
|
|
200
|
+
if (limit === 'daily') {
|
|
201
|
+
return ('Run `night-orch daily-cost-override <amount>` to raise today\'s cap (auto-expires at 00:00 UTC), ' +
|
|
202
|
+
'grant this specific run a budget override via `night-orch cost-override <repo> <issue> <amount>`, ' +
|
|
203
|
+
'permanently raise `security.maxDailyCostUsd` via `night-orch settings set`, ' +
|
|
204
|
+
'or wait until 00:00 UTC for the daily counter to reset.');
|
|
205
|
+
}
|
|
206
|
+
return ('Raise `security.maxCostPerRunUsd` in Settings (TUI/web/CLI `night-orch settings set`) ' +
|
|
207
|
+
'or grant this run a budget override to continue.');
|
|
208
|
+
}
|
|
209
|
+
function normalizeTokenUsage(tokenUsage) {
|
|
210
|
+
const promptTokens = normalizeTokenCount(tokenUsage?.promptTokens);
|
|
211
|
+
const completionTokens = normalizeTokenCount(tokenUsage?.completionTokens);
|
|
212
|
+
return {
|
|
213
|
+
promptTokens,
|
|
214
|
+
completionTokens,
|
|
215
|
+
totalTokens: promptTokens + completionTokens,
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
function normalizeTokenCount(value) {
|
|
219
|
+
if (typeof value !== 'number' || !Number.isFinite(value))
|
|
220
|
+
return 0;
|
|
221
|
+
return Math.max(0, Math.floor(value));
|
|
222
|
+
}
|
|
223
|
+
//# sourceMappingURL=cost.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cost.js","sourceRoot":"","sources":["../../src/loop/cost.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { RunContext, LoopDecision } from './types.js';
|
|
2
|
+
import type { Config } from '../config/schema.js';
|
|
3
|
+
/**
|
|
4
|
+
* Determine next action based on review verdict, verify results,
|
|
5
|
+
* iteration counts, and cost limits.
|
|
6
|
+
*
|
|
7
|
+
* Rules:
|
|
8
|
+
* 1. Cost limit exceeded → block
|
|
9
|
+
* 2. Max total agent passes reached → block
|
|
10
|
+
* 3. APPROVED + verify pass → publish
|
|
11
|
+
* 4. APPROVED + verify fail → iterate (fix verify failures)
|
|
12
|
+
* 5. CHANGES_REQUIRED + under limit → iterate
|
|
13
|
+
* 6. CHANGES_REQUIRED + at max review iterations → block
|
|
14
|
+
* 7. BLOCKED verdict → block
|
|
15
|
+
* 8. Parse failure + blockOnAmbiguousReview → block
|
|
16
|
+
* 9. Parse failure + !blockOnAmbiguousReview → iterate (one more try)
|
|
17
|
+
*/
|
|
18
|
+
export declare function decide(ctx: RunContext, loopConfig: Config['loop'], securityConfig: Config['security'], options?: {
|
|
19
|
+
requireReview?: boolean;
|
|
20
|
+
costModel?: Config['cost']['model'];
|
|
21
|
+
}): LoopDecision;
|
|
22
|
+
//# sourceMappingURL=decision.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"decision.d.ts","sourceRoot":"","sources":["../../src/loop/decision.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAC1D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAIjD;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,MAAM,CACpB,GAAG,EAAE,UAAU,EACf,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,EAC1B,cAAc,EAAE,MAAM,CAAC,UAAU,CAAC,EAClC,OAAO,GAAE;IAAE,aAAa,CAAC,EAAE,OAAO,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAA;CAAO,GAC7E,YAAY,CA8Gd"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { isPlanningIssue } from '../planning/mode.js';
|
|
2
|
+
import { costLimitRecoveryHint } from './cost.js';
|
|
3
|
+
/**
|
|
4
|
+
* Determine next action based on review verdict, verify results,
|
|
5
|
+
* iteration counts, and cost limits.
|
|
6
|
+
*
|
|
7
|
+
* Rules:
|
|
8
|
+
* 1. Cost limit exceeded → block
|
|
9
|
+
* 2. Max total agent passes reached → block
|
|
10
|
+
* 3. APPROVED + verify pass → publish
|
|
11
|
+
* 4. APPROVED + verify fail → iterate (fix verify failures)
|
|
12
|
+
* 5. CHANGES_REQUIRED + under limit → iterate
|
|
13
|
+
* 6. CHANGES_REQUIRED + at max review iterations → block
|
|
14
|
+
* 7. BLOCKED verdict → block
|
|
15
|
+
* 8. Parse failure + blockOnAmbiguousReview → block
|
|
16
|
+
* 9. Parse failure + !blockOnAmbiguousReview → iterate (one more try)
|
|
17
|
+
*/
|
|
18
|
+
export function decide(ctx, loopConfig, securityConfig, options = {}) {
|
|
19
|
+
const maxReviewIter = ctx.adjustedLimits.maxReviewIterations;
|
|
20
|
+
const maxTotalPasses = ctx.adjustedLimits.maxTotalAgentPasses;
|
|
21
|
+
const requireReview = options.requireReview ?? true;
|
|
22
|
+
const costModel = options.costModel ?? 'pay-per-use';
|
|
23
|
+
// Rule 1: Per-run cost limit
|
|
24
|
+
// (Primary check lives in the engine via CostTracker.checkBudget which also
|
|
25
|
+
// covers the daily cap; this is a pure-function fallback that only sees the
|
|
26
|
+
// run-local estimate, so it can only catch the per-run overrun here.)
|
|
27
|
+
// Skipped in subscription mode — the USD numbers are advisory-only estimates
|
|
28
|
+
// and don't correspond to what the operator actually pays.
|
|
29
|
+
if (costModel !== 'subscription' && ctx.estimatedCostUsd > securityConfig.maxCostPerRunUsd) {
|
|
30
|
+
const reason = `Per-run cost limit exceeded: $${ctx.estimatedCostUsd.toFixed(2)} >= ` +
|
|
31
|
+
`$${securityConfig.maxCostPerRunUsd.toFixed(2)}. ${costLimitRecoveryHint('per-run')}`;
|
|
32
|
+
return { action: 'block', reason, blockReason: 'cost_limit' };
|
|
33
|
+
}
|
|
34
|
+
// Rule 2: Max total passes
|
|
35
|
+
if (ctx.totalAgentPasses >= maxTotalPasses) {
|
|
36
|
+
return { action: 'block', reason: `Max total agent passes reached: ${ctx.totalAgentPasses}/${maxTotalPasses}`, blockReason: 'agent_pass_limit' };
|
|
37
|
+
}
|
|
38
|
+
// Planning-only mode bypasses verify/review gates. The commit guard enforces
|
|
39
|
+
// that only the configured PRD markdown file is committed.
|
|
40
|
+
if (isPlanningIssue(ctx.issue.labels, ctx.repoConfig)) {
|
|
41
|
+
if (!ctx.codeResult) {
|
|
42
|
+
return { action: 'block', reason: 'Planning-only mode requires a PRD output from the coder', blockReason: 'ambiguous_review' };
|
|
43
|
+
}
|
|
44
|
+
return { action: 'publish', reason: 'Planning-only mode: PRD ready for publishing' };
|
|
45
|
+
}
|
|
46
|
+
const review = ctx.reviewResult;
|
|
47
|
+
const verifyCommandsConfigured = (ctx.repoConfig.verify?.length ?? 0) > 0;
|
|
48
|
+
const verifyResultsAvailable = ctx.verifyResults.length > 0;
|
|
49
|
+
const allVerifyPassed = verifyResultsAvailable && ctx.verifyResults.every((r) => r.passed);
|
|
50
|
+
const verificationSatisfied = loopConfig.requireVerificationPass
|
|
51
|
+
? verifyCommandsConfigured && verifyResultsAvailable && allVerifyPassed
|
|
52
|
+
: ctx.verifyResults.length === 0 || allVerifyPassed;
|
|
53
|
+
// No review result = parse failure
|
|
54
|
+
if (!review) {
|
|
55
|
+
// Lightweight workflows may intentionally omit reviewer phases.
|
|
56
|
+
if (!requireReview) {
|
|
57
|
+
if (loopConfig.requireVerificationPass && !verifyCommandsConfigured) {
|
|
58
|
+
return { action: 'block', reason: 'Verification required but no verify commands are configured', blockReason: 'verify_config' };
|
|
59
|
+
}
|
|
60
|
+
if (loopConfig.requireVerificationPass && !verifyResultsAvailable) {
|
|
61
|
+
return { action: 'block', reason: 'Verification required but no verify results are available', blockReason: 'verify_config' };
|
|
62
|
+
}
|
|
63
|
+
if (verificationSatisfied) {
|
|
64
|
+
return { action: 'publish', reason: 'Verification passed in no-review workflow' };
|
|
65
|
+
}
|
|
66
|
+
if (ctx.iteration >= maxReviewIter) {
|
|
67
|
+
return { action: 'block', reason: `Max review iterations reached: ${ctx.iteration}/${maxReviewIter}`, blockReason: 'iteration_limit' };
|
|
68
|
+
}
|
|
69
|
+
return {
|
|
70
|
+
action: 'iterate',
|
|
71
|
+
reason: 'Verification failed in no-review workflow — retrying',
|
|
72
|
+
findings: [],
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
// Rules 8, 9
|
|
76
|
+
if (loopConfig.blockOnAmbiguousReview) {
|
|
77
|
+
return { action: 'block', reason: 'Review output not parseable and blockOnAmbiguousReview is true', blockReason: 'ambiguous_review' };
|
|
78
|
+
}
|
|
79
|
+
if (ctx.iteration >= maxReviewIter) {
|
|
80
|
+
return { action: 'block', reason: 'Review parse failure at max iterations', blockReason: 'iteration_limit' };
|
|
81
|
+
}
|
|
82
|
+
return { action: 'iterate', reason: 'Review output not parseable — retrying', findings: [] };
|
|
83
|
+
}
|
|
84
|
+
switch (review.verdict) {
|
|
85
|
+
case 'APPROVED':
|
|
86
|
+
// Rules 3, 4
|
|
87
|
+
if (loopConfig.requireVerificationPass && !verifyCommandsConfigured) {
|
|
88
|
+
return { action: 'block', reason: 'Verification required but no verify commands are configured', blockReason: 'verify_config' };
|
|
89
|
+
}
|
|
90
|
+
if (loopConfig.requireVerificationPass && !verifyResultsAvailable) {
|
|
91
|
+
return { action: 'block', reason: 'Verification required but no verify results are available', blockReason: 'verify_config' };
|
|
92
|
+
}
|
|
93
|
+
if (verificationSatisfied) {
|
|
94
|
+
return { action: 'publish', reason: 'Review approved, all verification passed' };
|
|
95
|
+
}
|
|
96
|
+
return {
|
|
97
|
+
action: 'iterate',
|
|
98
|
+
reason: 'Review approved but verification failed — fixing',
|
|
99
|
+
findings: [],
|
|
100
|
+
};
|
|
101
|
+
case 'CHANGES_REQUIRED':
|
|
102
|
+
// Rules 5, 6
|
|
103
|
+
if (ctx.iteration >= maxReviewIter) {
|
|
104
|
+
return { action: 'block', reason: `Max review iterations reached: ${ctx.iteration}/${maxReviewIter}`, blockReason: 'iteration_limit' };
|
|
105
|
+
}
|
|
106
|
+
return {
|
|
107
|
+
action: 'iterate',
|
|
108
|
+
reason: `Review requested changes (iteration ${ctx.iteration}/${maxReviewIter})`,
|
|
109
|
+
findings: review.findings,
|
|
110
|
+
};
|
|
111
|
+
case 'BLOCKED':
|
|
112
|
+
// Rule 7
|
|
113
|
+
return { action: 'block', reason: `Reviewer blocked: ${review.summary}`, blockReason: 'reviewer_blocked' };
|
|
114
|
+
default:
|
|
115
|
+
return { action: 'error', reason: `Unknown review verdict: ${review.verdict}` };
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
//# sourceMappingURL=decision.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"decision.js","sourceRoot":"","sources":["../../src/loop/decision.ts"],"names":[],"mappings":"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"}
|