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,149 @@
|
|
|
1
|
+
import { execFile } from 'node:child_process';
|
|
2
|
+
import { buildLabelBootstrapDefinitions } from '../labels/bootstrap.js';
|
|
3
|
+
const GH_LABEL_COMMAND_TIMEOUT_MS = 20_000;
|
|
4
|
+
export class LabelsInitEngine {
|
|
5
|
+
config;
|
|
6
|
+
runGhLabelCreate;
|
|
7
|
+
constructor(config, runGhLabelCreate = defaultGhLabelCreateExecutor) {
|
|
8
|
+
this.config = config;
|
|
9
|
+
this.runGhLabelCreate = runGhLabelCreate;
|
|
10
|
+
}
|
|
11
|
+
async run(options = {}) {
|
|
12
|
+
const dryRun = options.dryRun ?? false;
|
|
13
|
+
const repos = selectRepos(this.config.repos, options.targetRepo);
|
|
14
|
+
if (options.targetRepo && repos.length === 0) {
|
|
15
|
+
throw new Error(`Repository not found in config: ${options.targetRepo}`);
|
|
16
|
+
}
|
|
17
|
+
const result = {
|
|
18
|
+
targetRepo: options.targetRepo ?? null,
|
|
19
|
+
dryRun,
|
|
20
|
+
selectedRepos: repos.length,
|
|
21
|
+
githubRepos: 0,
|
|
22
|
+
skippedRepos: 0,
|
|
23
|
+
labelsProcessed: 0,
|
|
24
|
+
failures: 0,
|
|
25
|
+
repos: [],
|
|
26
|
+
};
|
|
27
|
+
for (const repoConfig of repos) {
|
|
28
|
+
if (repoConfig.forge !== 'github') {
|
|
29
|
+
result.skippedRepos += 1;
|
|
30
|
+
result.repos.push({
|
|
31
|
+
repo: repoConfig.repo,
|
|
32
|
+
forge: repoConfig.forge,
|
|
33
|
+
skipped: true,
|
|
34
|
+
skipReason: `forge=${repoConfig.forge} (gh label create is GitHub-only)`,
|
|
35
|
+
ghRepo: null,
|
|
36
|
+
labelsTotal: 0,
|
|
37
|
+
labelsProcessed: 0,
|
|
38
|
+
failures: 0,
|
|
39
|
+
errors: [],
|
|
40
|
+
dryRunCommands: [],
|
|
41
|
+
});
|
|
42
|
+
continue;
|
|
43
|
+
}
|
|
44
|
+
result.githubRepos += 1;
|
|
45
|
+
const repoResult = await this.processGithubRepo(repoConfig, this.config.github.apiBaseUrl, dryRun, options.timeoutMs ?? GH_LABEL_COMMAND_TIMEOUT_MS);
|
|
46
|
+
result.labelsProcessed += repoResult.labelsProcessed;
|
|
47
|
+
result.failures += repoResult.failures;
|
|
48
|
+
result.repos.push(repoResult);
|
|
49
|
+
}
|
|
50
|
+
if (result.githubRepos === 0) {
|
|
51
|
+
throw new Error('No GitHub repositories selected from config');
|
|
52
|
+
}
|
|
53
|
+
return result;
|
|
54
|
+
}
|
|
55
|
+
async processGithubRepo(repoConfig, defaultApiBaseUrl, dryRun, timeoutMs) {
|
|
56
|
+
const ghRepo = toGhRepoSelector(repoConfig, defaultApiBaseUrl);
|
|
57
|
+
const definitions = buildLabelBootstrapDefinitions({
|
|
58
|
+
labels: repoConfig.labels,
|
|
59
|
+
labelConfig: repoConfig.labelConfig ?? {},
|
|
60
|
+
kanban: repoConfig.kanban,
|
|
61
|
+
});
|
|
62
|
+
const repoResult = {
|
|
63
|
+
repo: repoConfig.repo,
|
|
64
|
+
forge: repoConfig.forge,
|
|
65
|
+
skipped: false,
|
|
66
|
+
skipReason: null,
|
|
67
|
+
ghRepo,
|
|
68
|
+
labelsTotal: definitions.length,
|
|
69
|
+
labelsProcessed: 0,
|
|
70
|
+
failures: 0,
|
|
71
|
+
errors: [],
|
|
72
|
+
dryRunCommands: [],
|
|
73
|
+
};
|
|
74
|
+
for (const label of definitions) {
|
|
75
|
+
const args = [
|
|
76
|
+
'label',
|
|
77
|
+
'create',
|
|
78
|
+
label.name,
|
|
79
|
+
'--repo',
|
|
80
|
+
ghRepo,
|
|
81
|
+
'--color',
|
|
82
|
+
label.color,
|
|
83
|
+
'--description',
|
|
84
|
+
label.description,
|
|
85
|
+
'--force',
|
|
86
|
+
];
|
|
87
|
+
if (dryRun) {
|
|
88
|
+
repoResult.labelsProcessed += 1;
|
|
89
|
+
repoResult.dryRunCommands.push(`gh ${args.map(shellQuote).join(' ')}`);
|
|
90
|
+
continue;
|
|
91
|
+
}
|
|
92
|
+
try {
|
|
93
|
+
await this.runGhLabelCreate(args, timeoutMs);
|
|
94
|
+
repoResult.labelsProcessed += 1;
|
|
95
|
+
}
|
|
96
|
+
catch (err) {
|
|
97
|
+
repoResult.failures += 1;
|
|
98
|
+
repoResult.errors.push({
|
|
99
|
+
label: label.name,
|
|
100
|
+
message: execErrorMessage(err),
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return repoResult;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
export function formatLabelsInitSummary(result) {
|
|
108
|
+
return `labels-init complete: ${result.labelsProcessed} labels processed, ${result.failures} failures, ${result.skippedRepos} repos skipped`;
|
|
109
|
+
}
|
|
110
|
+
function selectRepos(repos, targetRepo) {
|
|
111
|
+
if (!targetRepo)
|
|
112
|
+
return repos;
|
|
113
|
+
return repos.filter((repo) => repo.repo === targetRepo);
|
|
114
|
+
}
|
|
115
|
+
function toGhRepoSelector(repoConfig, defaultApiBaseUrl) {
|
|
116
|
+
const apiBaseUrl = repoConfig.apiBaseUrl ?? defaultApiBaseUrl;
|
|
117
|
+
const host = new URL(apiBaseUrl).host;
|
|
118
|
+
if (host === 'api.github.com' || host === 'github.com') {
|
|
119
|
+
return repoConfig.repo;
|
|
120
|
+
}
|
|
121
|
+
return `${host}/${repoConfig.repo}`;
|
|
122
|
+
}
|
|
123
|
+
function shellQuote(value) {
|
|
124
|
+
if (/^[A-Za-z0-9_./:@+=,-]+$/.test(value))
|
|
125
|
+
return value;
|
|
126
|
+
return `'${value.replace(/'/g, `'\\''`)}'`;
|
|
127
|
+
}
|
|
128
|
+
function execErrorMessage(err) {
|
|
129
|
+
if (typeof err === 'object' && err !== null) {
|
|
130
|
+
const stderr = 'stderr' in err && typeof err.stderr === 'string' ? err.stderr.trim() : '';
|
|
131
|
+
const message = 'message' in err && typeof err.message === 'string' ? err.message : 'Unknown error';
|
|
132
|
+
if (stderr.length > 0)
|
|
133
|
+
return stderr;
|
|
134
|
+
return message;
|
|
135
|
+
}
|
|
136
|
+
return String(err);
|
|
137
|
+
}
|
|
138
|
+
async function defaultGhLabelCreateExecutor(args, timeoutMs) {
|
|
139
|
+
await new Promise((resolve, reject) => {
|
|
140
|
+
execFile('gh', args, { timeout: timeoutMs }, (err) => {
|
|
141
|
+
if (err) {
|
|
142
|
+
reject(err instanceof Error ? err : new Error('Unknown execFile error'));
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
resolve();
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
//# sourceMappingURL=labels-init.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"labels-init.js","sourceRoot":"","sources":["../../src/ops/labels-init.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type Database from 'better-sqlite3';
|
|
2
|
+
import type { ForgeAdapter } from '../forge/types.js';
|
|
3
|
+
import type { RepoConfig } from '../config/schema.js';
|
|
4
|
+
/**
|
|
5
|
+
* Queue an issue for rebase-and-re-evaluate.
|
|
6
|
+
*
|
|
7
|
+
* This does NOT perform the rebase inline. It transitions the run
|
|
8
|
+
* to 'queued' with runMode='rebase' so the poller picks it up on
|
|
9
|
+
* the next cycle. The poller will:
|
|
10
|
+
* 1. Rebase the branch onto latest base
|
|
11
|
+
* 2. Run verify commands
|
|
12
|
+
* 3. If verify fails, run a full code→verify→review cycle to fix
|
|
13
|
+
*
|
|
14
|
+
* This is the right approach when PRs conceptually conflict —
|
|
15
|
+
* a git rebase might succeed but the code could be semantically broken.
|
|
16
|
+
*/
|
|
17
|
+
export declare function queueRebase(db: Database.Database, forge: ForgeAdapter, repoConfig: RepoConfig, issueNumber: number, botUser: string): Promise<{
|
|
18
|
+
queued: boolean;
|
|
19
|
+
reason: string;
|
|
20
|
+
}>;
|
|
21
|
+
/**
|
|
22
|
+
* Execute the rebase portion of a rebase run.
|
|
23
|
+
* Called by the poller when processing a queued run with rebase context.
|
|
24
|
+
*
|
|
25
|
+
* Returns true if the branch is clean after rebase (verify passes).
|
|
26
|
+
* Returns false if verify fails — the caller should continue with
|
|
27
|
+
* a code→verify→review cycle to fix the issues.
|
|
28
|
+
*/
|
|
29
|
+
export declare function executeRebase(repoLocalPath: string, worktreePath: string, branchName: string, baseBranch: string, repo: string, issueNumber: number, verifyCommands: Array<string | string[]>): Promise<{
|
|
30
|
+
rebased: boolean;
|
|
31
|
+
verifyPassed: boolean;
|
|
32
|
+
conflict: boolean;
|
|
33
|
+
}>;
|
|
34
|
+
//# sourceMappingURL=rebase-and-check.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rebase-and-check.d.ts","sourceRoot":"","sources":["../../src/ops/rebase-and-check.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAA;AAC1C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AACrD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAarD;;;;;;;;;;;;GAYG;AACH,wBAAsB,WAAW,CAC/B,EAAE,EAAE,QAAQ,CAAC,QAAQ,EACrB,KAAK,EAAE,YAAY,EACnB,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,MAAM,EACnB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC;IAAE,MAAM,EAAE,OAAO,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,CAgD9C;AAED;;;;;;;GAOG;AACH,wBAAsB,aAAa,CACjC,aAAa,EAAE,MAAM,EACrB,YAAY,EAAE,MAAM,EACpB,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,MAAM,EAClB,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,EACnB,cAAc,EAAE,KAAK,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC,GACvC,OAAO,CAAC;IAAE,OAAO,EAAE,OAAO,CAAC;IAAC,YAAY,EAAE,OAAO,CAAC;IAAC,QAAQ,EAAE,OAAO,CAAA;CAAE,CAAC,CA+BzE"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { autoRebase } from './rebase.js';
|
|
2
|
+
import { runVerifyCommands, allVerifyPassed } from '../loop/verifier.js';
|
|
3
|
+
import { buildVerifierEnv } from '../workers/env.js';
|
|
4
|
+
import { RunManager } from '../state/runs.js';
|
|
5
|
+
import { transitionLabels } from '../labels/manager.js';
|
|
6
|
+
import { buildLabelConfig } from '../labels/config.js';
|
|
7
|
+
import { upsertBotComment, markerTag } from '../forge/bot-comment.js';
|
|
8
|
+
import { resolveIssueRepo } from '../utils/issue-repo.js';
|
|
9
|
+
import { logger } from '../utils/logger.js';
|
|
10
|
+
const STATUS_MARKER = markerTag('status');
|
|
11
|
+
/**
|
|
12
|
+
* Queue an issue for rebase-and-re-evaluate.
|
|
13
|
+
*
|
|
14
|
+
* This does NOT perform the rebase inline. It transitions the run
|
|
15
|
+
* to 'queued' with runMode='rebase' so the poller picks it up on
|
|
16
|
+
* the next cycle. The poller will:
|
|
17
|
+
* 1. Rebase the branch onto latest base
|
|
18
|
+
* 2. Run verify commands
|
|
19
|
+
* 3. If verify fails, run a full code→verify→review cycle to fix
|
|
20
|
+
*
|
|
21
|
+
* This is the right approach when PRs conceptually conflict —
|
|
22
|
+
* a git rebase might succeed but the code could be semantically broken.
|
|
23
|
+
*/
|
|
24
|
+
export async function queueRebase(db, forge, repoConfig, issueNumber, botUser) {
|
|
25
|
+
const runManager = new RunManager(db);
|
|
26
|
+
// Find the latest run with a branch for this issue
|
|
27
|
+
const run = runManager.getByRepoAndIssue(repoConfig.repo, issueNumber);
|
|
28
|
+
if (!run || !run.branchName) {
|
|
29
|
+
return { queued: false, reason: 'No run with branch found for this issue' };
|
|
30
|
+
}
|
|
31
|
+
if (run.status === 'running' || run.status === 'queued') {
|
|
32
|
+
return { queued: false, reason: `Run is already ${run.status}` };
|
|
33
|
+
}
|
|
34
|
+
const issueRepo = resolveIssueRepo(run.phaseData, repoConfig.repo);
|
|
35
|
+
// Store rebase context and transition to queued
|
|
36
|
+
const existingPhaseData = run.phaseData ?? {};
|
|
37
|
+
runManager.update(run.id, {
|
|
38
|
+
status: 'queued',
|
|
39
|
+
lastError: null,
|
|
40
|
+
endedAt: null,
|
|
41
|
+
phaseData: {
|
|
42
|
+
...existingPhaseData,
|
|
43
|
+
issueRepo,
|
|
44
|
+
reactionContext: 'Rebase requested. Rebase onto latest base branch, run verify, and fix any issues introduced by upstream changes.',
|
|
45
|
+
reactionType: 'rebase',
|
|
46
|
+
reactionSummary: 'Rebase and re-evaluate',
|
|
47
|
+
},
|
|
48
|
+
});
|
|
49
|
+
// Transition labels
|
|
50
|
+
try {
|
|
51
|
+
const issue = await forge.getIssue(issueRepo, issueNumber);
|
|
52
|
+
const fromState = run.status === 'review_ready' ? 'review_ready' : run.status === 'blocked' ? 'blocked' : 'error';
|
|
53
|
+
await transitionLabels(forge, issueRepo, issueNumber, issue.labels, fromState, 'queued', buildLabelConfig(repoConfig, issue.labels));
|
|
54
|
+
}
|
|
55
|
+
catch (err) {
|
|
56
|
+
logger.warn({ repo: issueRepo, issueNumber, err }, 'Failed to transition labels for rebase queue');
|
|
57
|
+
}
|
|
58
|
+
// Post status comment
|
|
59
|
+
await commentStatus(forge, issueRepo, issueNumber, botUser, 'Queued for rebase and re-evaluation. The branch will be rebased onto the latest base, verified, and if anything breaks the coder will fix it.');
|
|
60
|
+
logger.info({ repo: issueRepo, issueNumber, runId: run.id }, 'Queued issue for rebase-and-re-evaluate');
|
|
61
|
+
return { queued: true, reason: 'Queued for rebase and re-evaluation on next poll cycle' };
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Execute the rebase portion of a rebase run.
|
|
65
|
+
* Called by the poller when processing a queued run with rebase context.
|
|
66
|
+
*
|
|
67
|
+
* Returns true if the branch is clean after rebase (verify passes).
|
|
68
|
+
* Returns false if verify fails — the caller should continue with
|
|
69
|
+
* a code→verify→review cycle to fix the issues.
|
|
70
|
+
*/
|
|
71
|
+
export async function executeRebase(repoLocalPath, worktreePath, branchName, baseBranch, repo, issueNumber, verifyCommands) {
|
|
72
|
+
const target = {
|
|
73
|
+
repo,
|
|
74
|
+
issueNumber,
|
|
75
|
+
prNumber: 0,
|
|
76
|
+
branchName,
|
|
77
|
+
baseBranch,
|
|
78
|
+
worktreePath,
|
|
79
|
+
};
|
|
80
|
+
const rebaseResult = await autoRebase(target, repoLocalPath);
|
|
81
|
+
if (rebaseResult === 'up_to_date') {
|
|
82
|
+
return { rebased: false, verifyPassed: true, conflict: false };
|
|
83
|
+
}
|
|
84
|
+
if (rebaseResult === 'conflict') {
|
|
85
|
+
return { rebased: false, verifyPassed: false, conflict: true };
|
|
86
|
+
}
|
|
87
|
+
if (rebaseResult === 'error') {
|
|
88
|
+
return { rebased: false, verifyPassed: false, conflict: false };
|
|
89
|
+
}
|
|
90
|
+
// Rebased successfully — run verify
|
|
91
|
+
if (verifyCommands.length === 0) {
|
|
92
|
+
return { rebased: true, verifyPassed: true, conflict: false };
|
|
93
|
+
}
|
|
94
|
+
const verifyResults = await runVerifyCommands(worktreePath, verifyCommands, buildVerifierEnv());
|
|
95
|
+
return { rebased: true, verifyPassed: allVerifyPassed(verifyResults), conflict: false };
|
|
96
|
+
}
|
|
97
|
+
async function commentStatus(forge, repo, issueNumber, botUser, message) {
|
|
98
|
+
try {
|
|
99
|
+
if (botUser) {
|
|
100
|
+
await upsertBotComment(forge, repo, issueNumber, STATUS_MARKER, `**night-orch**: ${message}`, botUser);
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
await forge.commentOnIssue(repo, issueNumber, `**night-orch**: ${message}`);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
catch (err) {
|
|
107
|
+
logger.warn({ repo, issueNumber, err }, 'Failed to post rebase status comment');
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=rebase-and-check.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rebase-and-check.js","sourceRoot":"","sources":["../../src/ops/rebase-and-check.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export interface RebaseTarget {
|
|
2
|
+
repo: string;
|
|
3
|
+
issueNumber: number;
|
|
4
|
+
prNumber: number;
|
|
5
|
+
branchName: string;
|
|
6
|
+
baseBranch: string;
|
|
7
|
+
worktreePath: string;
|
|
8
|
+
}
|
|
9
|
+
export type RebaseResult = 'up_to_date' | 'rebased' | 'conflict' | 'error';
|
|
10
|
+
/**
|
|
11
|
+
* Check if a branch needs rebase and perform it automatically.
|
|
12
|
+
* Uses --force-with-lease for push to protect against overwriting others' work.
|
|
13
|
+
*
|
|
14
|
+
* @returns 'up_to_date' if no rebase needed, 'rebased' on success,
|
|
15
|
+
* 'conflict' if rebase had conflicts (aborted), 'error' on other failures.
|
|
16
|
+
*/
|
|
17
|
+
export declare function autoRebase(target: RebaseTarget, repoLocalPath: string): Promise<RebaseResult>;
|
|
18
|
+
//# sourceMappingURL=rebase.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rebase.d.ts","sourceRoot":"","sources":["../../src/ops/rebase.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAA;IACZ,WAAW,EAAE,MAAM,CAAA;IACnB,QAAQ,EAAE,MAAM,CAAA;IAChB,UAAU,EAAE,MAAM,CAAA;IAClB,UAAU,EAAE,MAAM,CAAA;IAClB,YAAY,EAAE,MAAM,CAAA;CACrB;AAED,MAAM,MAAM,YAAY,GAAG,YAAY,GAAG,SAAS,GAAG,UAAU,GAAG,OAAO,CAAA;AAE1E;;;;;;GAMG;AACH,wBAAsB,UAAU,CAC9B,MAAM,EAAE,YAAY,EACpB,aAAa,EAAE,MAAM,GACpB,OAAO,CAAC,YAAY,CAAC,CA0DvB"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { runGit } from '../git/process.js';
|
|
2
|
+
import { logger } from '../utils/logger.js';
|
|
3
|
+
/**
|
|
4
|
+
* Check if a branch needs rebase and perform it automatically.
|
|
5
|
+
* Uses --force-with-lease for push to protect against overwriting others' work.
|
|
6
|
+
*
|
|
7
|
+
* @returns 'up_to_date' if no rebase needed, 'rebased' on success,
|
|
8
|
+
* 'conflict' if rebase had conflicts (aborted), 'error' on other failures.
|
|
9
|
+
*/
|
|
10
|
+
export async function autoRebase(target, repoLocalPath) {
|
|
11
|
+
const { branchName, baseBranch, worktreePath } = target;
|
|
12
|
+
const log = logger.child({ repo: target.repo, issue: target.issueNumber, branch: branchName });
|
|
13
|
+
try {
|
|
14
|
+
// Fetch latest remote state
|
|
15
|
+
await runGit(['fetch', 'origin'], {
|
|
16
|
+
cwd: repoLocalPath,
|
|
17
|
+
timeout: 60_000,
|
|
18
|
+
});
|
|
19
|
+
// Check if base branch is already an ancestor of HEAD (i.e., no rebase needed)
|
|
20
|
+
try {
|
|
21
|
+
await runGit(['merge-base', '--is-ancestor', `origin/${baseBranch}`, 'HEAD'], {
|
|
22
|
+
cwd: worktreePath,
|
|
23
|
+
timeout: 30_000,
|
|
24
|
+
});
|
|
25
|
+
// Exit code 0 means base is ancestor → already up to date
|
|
26
|
+
return 'up_to_date';
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
// Non-zero exit = base is NOT an ancestor → rebase needed
|
|
30
|
+
}
|
|
31
|
+
log.info({ baseBranch }, 'Base branch has moved ahead — rebasing');
|
|
32
|
+
// Attempt rebase
|
|
33
|
+
try {
|
|
34
|
+
await runGit(['rebase', `origin/${baseBranch}`], {
|
|
35
|
+
cwd: worktreePath,
|
|
36
|
+
timeout: 120_000,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
catch (rebaseErr) {
|
|
40
|
+
const stderr = rebaseErr.stderr ?? '';
|
|
41
|
+
if (stderr.includes('CONFLICT') || stderr.includes('could not apply')) {
|
|
42
|
+
log.warn({ baseBranch }, 'Rebase conflict — aborting');
|
|
43
|
+
try {
|
|
44
|
+
await runGit(['rebase', '--abort'], { cwd: worktreePath, timeout: 30_000 });
|
|
45
|
+
}
|
|
46
|
+
catch {
|
|
47
|
+
// Abort itself failed — worktree may be in bad state
|
|
48
|
+
log.error('Failed to abort rebase');
|
|
49
|
+
}
|
|
50
|
+
return 'conflict';
|
|
51
|
+
}
|
|
52
|
+
throw rebaseErr;
|
|
53
|
+
}
|
|
54
|
+
// Push with --force-with-lease
|
|
55
|
+
await runGit(['push', '--force-with-lease', 'origin', branchName], {
|
|
56
|
+
cwd: worktreePath,
|
|
57
|
+
timeout: 60_000,
|
|
58
|
+
});
|
|
59
|
+
log.info({ baseBranch }, 'Rebased and pushed successfully');
|
|
60
|
+
return 'rebased';
|
|
61
|
+
}
|
|
62
|
+
catch (err) {
|
|
63
|
+
log.error({ err }, 'Auto-rebase failed');
|
|
64
|
+
return 'error';
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=rebase.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rebase.js","sourceRoot":"","sources":["../../src/ops/rebase.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAC1C,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAa3C;;;;;;GAMG;AACH,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,MAAoB,EACpB,aAAqB;IAErB,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,YAAY,EAAE,GAAG,MAAM,CAAA;IACvD,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,KAAK,EAAE,MAAM,CAAC,WAAW,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAA;IAE9F,IAAI,CAAC;QACH,4BAA4B;QAC5B,MAAM,MAAM,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE;YAChC,GAAG,EAAE,aAAa;YAClB,OAAO,EAAE,MAAM;SAChB,CAAC,CAAA;QAEF,+EAA+E;QAC/E,IAAI,CAAC;YACH,MAAM,MAAM,CAAC,CAAC,YAAY,EAAE,eAAe,EAAE,UAAU,UAAU,EAAE,EAAE,MAAM,CAAC,EAAE;gBAC5E,GAAG,EAAE,YAAY;gBACjB,OAAO,EAAE,MAAM;aAChB,CAAC,CAAA;YACF,0DAA0D;YAC1D,OAAO,YAAY,CAAA;QACrB,CAAC;QAAC,MAAM,CAAC;YACP,0DAA0D;QAC5D,CAAC;QAED,GAAG,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,EAAE,wCAAwC,CAAC,CAAA;QAElE,iBAAiB;QACjB,IAAI,CAAC;YACH,MAAM,MAAM,CAAC,CAAC,QAAQ,EAAE,UAAU,UAAU,EAAE,CAAC,EAAE;gBAC/C,GAAG,EAAE,YAAY;gBACjB,OAAO,EAAE,OAAO;aACjB,CAAC,CAAA;QACJ,CAAC;QAAC,OAAO,SAAS,EAAE,CAAC;YACnB,MAAM,MAAM,GAAI,SAAiC,CAAC,MAAM,IAAI,EAAE,CAAA;YAC9D,IAAI,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,MAAM,CAAC,QAAQ,CAAC,iBAAiB,CAAC,EAAE,CAAC;gBACtE,GAAG,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,EAAE,4BAA4B,CAAC,CAAA;gBACtD,IAAI,CAAC;oBACH,MAAM,MAAM,CAAC,CAAC,QAAQ,EAAE,SAAS,CAAC,EAAE,EAAE,GAAG,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAA;gBAC7E,CAAC;gBAAC,MAAM,CAAC;oBACP,qDAAqD;oBACrD,GAAG,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAA;gBACrC,CAAC;gBACD,OAAO,UAAU,CAAA;YACnB,CAAC;YACD,MAAM,SAAS,CAAA;QACjB,CAAC;QAED,+BAA+B;QAC/B,MAAM,MAAM,CAAC,CAAC,MAAM,EAAE,oBAAoB,EAAE,QAAQ,EAAE,UAAU,CAAC,EAAE;YACjE,GAAG,EAAE,YAAY;YACjB,OAAO,EAAE,MAAM;SAChB,CAAC,CAAA;QAEF,GAAG,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,EAAE,iCAAiC,CAAC,CAAA;QAC3D,OAAO,SAAS,CAAA;IAClB,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,GAAG,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,EAAE,oBAAoB,CAAC,CAAA;QACxC,OAAO,OAAO,CAAA;IAChB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type Database from 'better-sqlite3';
|
|
2
|
+
export interface RetentionOptions {
|
|
3
|
+
/** Compact phase_data and delete events after this many days. */
|
|
4
|
+
detailDays: number;
|
|
5
|
+
/** Delete entire run records after this many days. */
|
|
6
|
+
archiveDays: number;
|
|
7
|
+
/** Run incremental vacuum after pruning. */
|
|
8
|
+
vacuum: boolean;
|
|
9
|
+
dryRun: boolean;
|
|
10
|
+
}
|
|
11
|
+
export interface RetentionResult {
|
|
12
|
+
compactedRuns: number;
|
|
13
|
+
deletedRuns: number;
|
|
14
|
+
deletedEvents: number;
|
|
15
|
+
deletedMentions: number;
|
|
16
|
+
vacuumed: boolean;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Prunes old DB data using a compact-then-delete strategy.
|
|
20
|
+
* - Compact: runs > detailDays have phase_data summarized and events deleted.
|
|
21
|
+
* - Delete: runs > archiveDays are fully deleted along with associated data.
|
|
22
|
+
* - Uses incremental_vacuum instead of full VACUUM to avoid locking.
|
|
23
|
+
*/
|
|
24
|
+
export declare class RetentionEngine {
|
|
25
|
+
private db;
|
|
26
|
+
constructor(db: Database.Database);
|
|
27
|
+
prune(options: RetentionOptions): RetentionResult;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=retention.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retention.d.ts","sourceRoot":"","sources":["../../src/ops/retention.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAA;AAK1C,MAAM,WAAW,gBAAgB;IAC/B,iEAAiE;IACjE,UAAU,EAAE,MAAM,CAAA;IAClB,sDAAsD;IACtD,WAAW,EAAE,MAAM,CAAA;IACnB,4CAA4C;IAC5C,MAAM,EAAE,OAAO,CAAA;IACf,MAAM,EAAE,OAAO,CAAA;CAChB;AAED,MAAM,WAAW,eAAe;IAC9B,aAAa,EAAE,MAAM,CAAA;IACrB,WAAW,EAAE,MAAM,CAAA;IACnB,aAAa,EAAE,MAAM,CAAA;IACrB,eAAe,EAAE,MAAM,CAAA;IACvB,QAAQ,EAAE,OAAO,CAAA;CAClB;AAED;;;;;GAKG;AACH,qBAAa,eAAe;IACd,OAAO,CAAC,EAAE;gBAAF,EAAE,EAAE,QAAQ,CAAC,QAAQ;IAEzC,KAAK,CAAC,OAAO,EAAE,gBAAgB,GAAG,eAAe;CAuGlD"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { RunManager } from '../state/runs.js';
|
|
2
|
+
import { logger } from '../utils/logger.js';
|
|
3
|
+
import { utcIsoFromMs } from '../utils/time.js';
|
|
4
|
+
/**
|
|
5
|
+
* Prunes old DB data using a compact-then-delete strategy.
|
|
6
|
+
* - Compact: runs > detailDays have phase_data summarized and events deleted.
|
|
7
|
+
* - Delete: runs > archiveDays are fully deleted along with associated data.
|
|
8
|
+
* - Uses incremental_vacuum instead of full VACUUM to avoid locking.
|
|
9
|
+
*/
|
|
10
|
+
export class RetentionEngine {
|
|
11
|
+
db;
|
|
12
|
+
constructor(db) {
|
|
13
|
+
this.db = db;
|
|
14
|
+
}
|
|
15
|
+
prune(options) {
|
|
16
|
+
const result = {
|
|
17
|
+
compactedRuns: 0,
|
|
18
|
+
deletedRuns: 0,
|
|
19
|
+
deletedEvents: 0,
|
|
20
|
+
deletedMentions: 0,
|
|
21
|
+
vacuumed: false,
|
|
22
|
+
};
|
|
23
|
+
const detailCutoff = utcIsoFromMs(Date.now() - options.detailDays * 24 * 60 * 60 * 1000);
|
|
24
|
+
const archiveCutoff = utcIsoFromMs(Date.now() - options.archiveDays * 24 * 60 * 60 * 1000);
|
|
25
|
+
if (options.dryRun) {
|
|
26
|
+
const compactCount = this.db
|
|
27
|
+
.prepare("SELECT COUNT(*) as c FROM runs WHERE ended_at < ? AND ended_at >= ? AND phase_data IS NOT NULL AND status IN ('completed', 'error')")
|
|
28
|
+
.get(detailCutoff, archiveCutoff);
|
|
29
|
+
result.compactedRuns = compactCount.c;
|
|
30
|
+
const deleteCount = this.db
|
|
31
|
+
.prepare("SELECT COUNT(*) as c FROM runs WHERE ended_at < ? AND status IN ('completed', 'error')")
|
|
32
|
+
.get(archiveCutoff);
|
|
33
|
+
result.deletedRuns = deleteCount.c;
|
|
34
|
+
return result;
|
|
35
|
+
}
|
|
36
|
+
const runPrune = this.db.transaction(() => {
|
|
37
|
+
// Step 1: Compact — summarize phase_data for old completed/error runs.
|
|
38
|
+
// We must preserve routing metadata (`issueRepo`) so post-compaction
|
|
39
|
+
// continue/retry/rebase/delete flows on linked projects still reach
|
|
40
|
+
// the correct upstream repo via `resolveIssueRepo(phaseData, ...)`.
|
|
41
|
+
const compactRows = this.db
|
|
42
|
+
.prepare("SELECT id, estimated_cost_usd, status, phase_data FROM runs WHERE ended_at < ? AND ended_at >= ? AND phase_data IS NOT NULL AND status IN ('completed', 'error')")
|
|
43
|
+
.all(detailCutoff, archiveCutoff);
|
|
44
|
+
for (const row of compactRows) {
|
|
45
|
+
const preservedIssueRepo = extractIssueRepo(row.phase_data);
|
|
46
|
+
const summary = {
|
|
47
|
+
compacted: true,
|
|
48
|
+
costUsd: row.estimated_cost_usd,
|
|
49
|
+
status: row.status,
|
|
50
|
+
};
|
|
51
|
+
if (preservedIssueRepo) {
|
|
52
|
+
summary['issueRepo'] = preservedIssueRepo;
|
|
53
|
+
}
|
|
54
|
+
new RunManager(this.db).compactPhaseData(row.id, JSON.stringify(summary));
|
|
55
|
+
}
|
|
56
|
+
result.compactedRuns = compactRows.length;
|
|
57
|
+
// Delete events for compacted runs
|
|
58
|
+
if (compactRows.length > 0) {
|
|
59
|
+
const ids = compactRows.map((r) => r.id);
|
|
60
|
+
const placeholders = ids.map(() => '?').join(',');
|
|
61
|
+
const eventInfo = this.db.prepare(`DELETE FROM events WHERE run_id IN (${placeholders})`).run(...ids);
|
|
62
|
+
const agentEventInfo = this.db.prepare(`DELETE FROM agent_events WHERE run_id IN (${placeholders})`).run(...ids);
|
|
63
|
+
result.deletedEvents += eventInfo.changes + agentEventInfo.changes;
|
|
64
|
+
}
|
|
65
|
+
// Step 2: Delete — remove entire runs older than archiveDays
|
|
66
|
+
const archiveRows = this.db
|
|
67
|
+
.prepare("SELECT id FROM runs WHERE ended_at < ? AND status IN ('completed', 'error')")
|
|
68
|
+
.all(archiveCutoff);
|
|
69
|
+
if (archiveRows.length > 0) {
|
|
70
|
+
const ids = archiveRows.map((r) => r.id);
|
|
71
|
+
const placeholders = ids.map(() => '?').join(',');
|
|
72
|
+
// Delete associated events
|
|
73
|
+
const eventInfo = this.db.prepare(`DELETE FROM events WHERE run_id IN (${placeholders})`).run(...ids);
|
|
74
|
+
const agentEventInfo = this.db.prepare(`DELETE FROM agent_events WHERE run_id IN (${placeholders})`).run(...ids);
|
|
75
|
+
result.deletedEvents += eventInfo.changes + agentEventInfo.changes;
|
|
76
|
+
// Delete runs
|
|
77
|
+
const runInfo = this.db.prepare(`DELETE FROM runs WHERE id IN (${placeholders})`).run(...ids);
|
|
78
|
+
result.deletedRuns = runInfo.changes;
|
|
79
|
+
}
|
|
80
|
+
// Delete old mention_tracking entries
|
|
81
|
+
const mentionInfo = this.db
|
|
82
|
+
.prepare('DELETE FROM mention_tracking WHERE posted_at < ?')
|
|
83
|
+
.run(archiveCutoff);
|
|
84
|
+
result.deletedMentions = mentionInfo.changes;
|
|
85
|
+
});
|
|
86
|
+
runPrune();
|
|
87
|
+
// Step 3: Incremental vacuum (outside transaction)
|
|
88
|
+
if (options.vacuum && (result.deletedRuns > 0 || result.compactedRuns > 0)) {
|
|
89
|
+
try {
|
|
90
|
+
this.db.pragma('incremental_vacuum(100)');
|
|
91
|
+
result.vacuumed = true;
|
|
92
|
+
}
|
|
93
|
+
catch (err) {
|
|
94
|
+
logger.warn({ err }, 'Incremental vacuum failed');
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
return result;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Pull the `issueRepo` routing key out of a phase_data JSON blob, if
|
|
102
|
+
* present. Used by retention compaction to preserve cross-repo routing
|
|
103
|
+
* when a run's detailed phase_data is summarized. Degrades to null on
|
|
104
|
+
* any parse error or missing field.
|
|
105
|
+
*/
|
|
106
|
+
function extractIssueRepo(phaseDataJson) {
|
|
107
|
+
if (!phaseDataJson)
|
|
108
|
+
return null;
|
|
109
|
+
try {
|
|
110
|
+
const parsed = JSON.parse(phaseDataJson);
|
|
111
|
+
if (typeof parsed !== 'object' || parsed === null || Array.isArray(parsed))
|
|
112
|
+
return null;
|
|
113
|
+
const value = parsed['issueRepo'];
|
|
114
|
+
return typeof value === 'string' && value.length > 0 ? value : null;
|
|
115
|
+
}
|
|
116
|
+
catch {
|
|
117
|
+
return null;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
//# sourceMappingURL=retention.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retention.js","sourceRoot":"","sources":["../../src/ops/retention.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type Database from 'better-sqlite3';
|
|
2
|
+
import type { Config } from '../config/schema.js';
|
|
3
|
+
import type { ForgeAdapter } from '../forge/types.js';
|
|
4
|
+
export interface RetryOptions {
|
|
5
|
+
immediate: boolean;
|
|
6
|
+
resetPlan: boolean;
|
|
7
|
+
resetBranch: boolean;
|
|
8
|
+
dryRun: boolean;
|
|
9
|
+
}
|
|
10
|
+
export declare class RetryEngine {
|
|
11
|
+
private db;
|
|
12
|
+
private config;
|
|
13
|
+
private forgeFactory;
|
|
14
|
+
private leaseManager;
|
|
15
|
+
constructor(db: Database.Database, config: Config, forgeFactory?: (repo: string) => ForgeAdapter);
|
|
16
|
+
retry(repo: string, issueNumber: number, options?: Partial<RetryOptions>): Promise<void>;
|
|
17
|
+
private updateLabels;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=retry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.d.ts","sourceRoot":"","sources":["../../src/ops/retry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAA;AAC1C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AACjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAUrD,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,OAAO,CAAA;IAClB,SAAS,EAAE,OAAO,CAAA;IAClB,WAAW,EAAE,OAAO,CAAA;IACpB,MAAM,EAAE,OAAO,CAAA;CAChB;AAID,qBAAa,WAAW;IAIpB,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,YAAY;IALtB,OAAO,CAAC,YAAY,CAAc;gBAGxB,EAAE,EAAE,QAAQ,CAAC,QAAQ,EACrB,MAAM,EAAE,MAAM,EACd,YAAY,GAAE,CAAC,IAAI,EAAE,MAAM,KAAK,YAIvC;IAKG,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,OAAO,GAAE,OAAO,CAAC,YAAY,CAAM,GAAG,OAAO,CAAC,IAAI,CAAC;YAwEpF,YAAY;CAoB3B"}
|