@nervekit/orchestrator 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/LICENSE +201 -0
- package/NOTICE +5 -0
- package/dist/agent-process.d.ts +32 -0
- package/dist/agent-process.d.ts.map +1 -0
- package/dist/agent-process.js +129 -0
- package/dist/agent-process.js.map +1 -0
- package/dist/agent-runner/agent-runner.d.ts +65 -0
- package/dist/agent-runner/agent-runner.d.ts.map +1 -0
- package/dist/agent-runner/agent-runner.js +802 -0
- package/dist/agent-runner/agent-runner.js.map +1 -0
- package/dist/agent-runner/index.d.ts +6 -0
- package/dist/agent-runner/index.d.ts.map +1 -0
- package/dist/agent-runner/index.js +4 -0
- package/dist/agent-runner/index.js.map +1 -0
- package/dist/agent-runner/message-mirror.d.ts +44 -0
- package/dist/agent-runner/message-mirror.d.ts.map +1 -0
- package/dist/agent-runner/message-mirror.js +154 -0
- package/dist/agent-runner/message-mirror.js.map +1 -0
- package/dist/agent-runner/run-state.d.ts +12 -0
- package/dist/agent-runner/run-state.d.ts.map +1 -0
- package/dist/agent-runner/run-state.js +2 -0
- package/dist/agent-runner/run-state.js.map +1 -0
- package/dist/agent-runner/subagent-runner.d.ts +29 -0
- package/dist/agent-runner/subagent-runner.d.ts.map +1 -0
- package/dist/agent-runner/subagent-runner.js +84 -0
- package/dist/agent-runner/subagent-runner.js.map +1 -0
- package/dist/agent-runner/system-prompt-builder.d.ts +19 -0
- package/dist/agent-runner/system-prompt-builder.d.ts.map +1 -0
- package/dist/agent-runner/system-prompt-builder.js +35 -0
- package/dist/agent-runner/system-prompt-builder.js.map +1 -0
- package/dist/agent-runner/tool-draft-streaming.d.ts +2 -0
- package/dist/agent-runner/tool-draft-streaming.d.ts.map +1 -0
- package/dist/agent-runner/tool-draft-streaming.js +5 -0
- package/dist/agent-runner/tool-draft-streaming.js.map +1 -0
- package/dist/agent-suspension-service.d.ts +44 -0
- package/dist/agent-suspension-service.d.ts.map +1 -0
- package/dist/agent-suspension-service.js +96 -0
- package/dist/agent-suspension-service.js.map +1 -0
- package/dist/agent-tool-adapter.d.ts +20 -0
- package/dist/agent-tool-adapter.d.ts.map +1 -0
- package/dist/agent-tool-adapter.js +215 -0
- package/dist/agent-tool-adapter.js.map +1 -0
- package/dist/agents/agent-authority.d.ts +5 -0
- package/dist/agents/agent-authority.d.ts.map +1 -0
- package/dist/agents/agent-authority.js +28 -0
- package/dist/agents/agent-authority.js.map +1 -0
- package/dist/agents/agent-budget.d.ts +3 -0
- package/dist/agents/agent-budget.d.ts.map +1 -0
- package/dist/agents/agent-budget.js +17 -0
- package/dist/agents/agent-budget.js.map +1 -0
- package/dist/agents/agent-status.d.ts +4 -0
- package/dist/agents/agent-status.d.ts.map +1 -0
- package/dist/agents/agent-status.js +10 -0
- package/dist/agents/agent-status.js.map +1 -0
- package/dist/auth.d.ts +30 -0
- package/dist/auth.d.ts.map +1 -0
- package/dist/auth.js +158 -0
- package/dist/auth.js.map +1 -0
- package/dist/conversation-operations/compaction-service.d.ts +37 -0
- package/dist/conversation-operations/compaction-service.d.ts.map +1 -0
- package/dist/conversation-operations/compaction-service.js +102 -0
- package/dist/conversation-operations/compaction-service.js.map +1 -0
- package/dist/conversation-operations/export-service.d.ts +22 -0
- package/dist/conversation-operations/export-service.d.ts.map +1 -0
- package/dist/conversation-operations/export-service.js +79 -0
- package/dist/conversation-operations/export-service.js.map +1 -0
- package/dist/conversation-operations/import-service.d.ts +20 -0
- package/dist/conversation-operations/import-service.d.ts.map +1 -0
- package/dist/conversation-operations/import-service.js +97 -0
- package/dist/conversation-operations/import-service.js.map +1 -0
- package/dist/conversation-operations/index.d.ts +8 -0
- package/dist/conversation-operations/index.d.ts.map +1 -0
- package/dist/conversation-operations/index.js +6 -0
- package/dist/conversation-operations/index.js.map +1 -0
- package/dist/conversation-operations/navigation-service.d.ts +18 -0
- package/dist/conversation-operations/navigation-service.d.ts.map +1 -0
- package/dist/conversation-operations/navigation-service.js +102 -0
- package/dist/conversation-operations/navigation-service.js.map +1 -0
- package/dist/conversation-operations/summary.d.ts +11 -0
- package/dist/conversation-operations/summary.d.ts.map +1 -0
- package/dist/conversation-operations/summary.js +29 -0
- package/dist/conversation-operations/summary.js.map +1 -0
- package/dist/conversation-runtime.d.ts +96 -0
- package/dist/conversation-runtime.d.ts.map +1 -0
- package/dist/conversation-runtime.js +363 -0
- package/dist/conversation-runtime.js.map +1 -0
- package/dist/conversation-service.d.ts +17 -0
- package/dist/conversation-service.d.ts.map +1 -0
- package/dist/conversation-service.js +56 -0
- package/dist/conversation-service.js.map +1 -0
- package/dist/credential-crypto.d.ts +19 -0
- package/dist/credential-crypto.d.ts.map +1 -0
- package/dist/credential-crypto.js +75 -0
- package/dist/credential-crypto.js.map +1 -0
- package/dist/domains/agents/agent-authority.d.ts +5 -0
- package/dist/domains/agents/agent-authority.d.ts.map +1 -0
- package/dist/domains/agents/agent-authority.js +28 -0
- package/dist/domains/agents/agent-authority.js.map +1 -0
- package/dist/domains/agents/agent-budget.d.ts +3 -0
- package/dist/domains/agents/agent-budget.d.ts.map +1 -0
- package/dist/domains/agents/agent-budget.js +17 -0
- package/dist/domains/agents/agent-budget.js.map +1 -0
- package/dist/domains/agents/agent-lifecycle.service.d.ts +37 -0
- package/dist/domains/agents/agent-lifecycle.service.d.ts.map +1 -0
- package/dist/domains/agents/agent-lifecycle.service.js +241 -0
- package/dist/domains/agents/agent-lifecycle.service.js.map +1 -0
- package/dist/domains/agents/agent-status.d.ts +4 -0
- package/dist/domains/agents/agent-status.d.ts.map +1 -0
- package/dist/domains/agents/agent-status.js +10 -0
- package/dist/domains/agents/agent-status.js.map +1 -0
- package/dist/domains/agents/agent-suspension.service.d.ts +44 -0
- package/dist/domains/agents/agent-suspension.service.d.ts.map +1 -0
- package/dist/domains/agents/agent-suspension.service.js +96 -0
- package/dist/domains/agents/agent-suspension.service.js.map +1 -0
- package/dist/domains/agents/agent.repository.d.ts +12 -0
- package/dist/domains/agents/agent.repository.d.ts.map +1 -0
- package/dist/domains/agents/agent.repository.js +33 -0
- package/dist/domains/agents/agent.repository.js.map +1 -0
- package/dist/domains/agents/index.d.ts +6 -0
- package/dist/domains/agents/index.d.ts.map +1 -0
- package/dist/domains/agents/index.js +6 -0
- package/dist/domains/agents/index.js.map +1 -0
- package/dist/domains/agents/prompt-queue.repository.d.ts +28 -0
- package/dist/domains/agents/prompt-queue.repository.d.ts.map +1 -0
- package/dist/domains/agents/prompt-queue.repository.js +88 -0
- package/dist/domains/agents/prompt-queue.repository.js.map +1 -0
- package/dist/domains/agents/queued-prompt.service.d.ts +16 -0
- package/dist/domains/agents/queued-prompt.service.d.ts.map +1 -0
- package/dist/domains/agents/queued-prompt.service.js +30 -0
- package/dist/domains/agents/queued-prompt.service.js.map +1 -0
- package/dist/domains/agents/retry-continuation.service.d.ts +14 -0
- package/dist/domains/agents/retry-continuation.service.d.ts.map +1 -0
- package/dist/domains/agents/retry-continuation.service.js +75 -0
- package/dist/domains/agents/retry-continuation.service.js.map +1 -0
- package/dist/domains/agents/run/agent-run-session.d.ts +6 -0
- package/dist/domains/agents/run/agent-run-session.d.ts.map +1 -0
- package/dist/domains/agents/run/agent-run-session.js +587 -0
- package/dist/domains/agents/run/agent-run-session.js.map +1 -0
- package/dist/domains/agents/run/agent-runner-shared.d.ts +19 -0
- package/dist/domains/agents/run/agent-runner-shared.d.ts.map +1 -0
- package/dist/domains/agents/run/agent-runner-shared.js +58 -0
- package/dist/domains/agents/run/agent-runner-shared.js.map +1 -0
- package/dist/domains/agents/run/agent-runner.d.ts +119 -0
- package/dist/domains/agents/run/agent-runner.d.ts.map +1 -0
- package/dist/domains/agents/run/agent-runner.js +515 -0
- package/dist/domains/agents/run/agent-runner.js.map +1 -0
- package/dist/domains/agents/run/explore-helpers.d.ts +32 -0
- package/dist/domains/agents/run/explore-helpers.d.ts.map +1 -0
- package/dist/domains/agents/run/explore-helpers.js +431 -0
- package/dist/domains/agents/run/explore-helpers.js.map +1 -0
- package/dist/domains/agents/run/index.d.ts +6 -0
- package/dist/domains/agents/run/index.d.ts.map +1 -0
- package/dist/domains/agents/run/index.js +4 -0
- package/dist/domains/agents/run/index.js.map +1 -0
- package/dist/domains/agents/run/interrupted-run-recovery.d.ts +21 -0
- package/dist/domains/agents/run/interrupted-run-recovery.d.ts.map +1 -0
- package/dist/domains/agents/run/interrupted-run-recovery.js +94 -0
- package/dist/domains/agents/run/interrupted-run-recovery.js.map +1 -0
- package/dist/domains/agents/run/live-tool-draft-reconciliation.d.ts +32 -0
- package/dist/domains/agents/run/live-tool-draft-reconciliation.d.ts.map +1 -0
- package/dist/domains/agents/run/live-tool-draft-reconciliation.js +72 -0
- package/dist/domains/agents/run/live-tool-draft-reconciliation.js.map +1 -0
- package/dist/domains/agents/run/message-mirror.d.ts +44 -0
- package/dist/domains/agents/run/message-mirror.d.ts.map +1 -0
- package/dist/domains/agents/run/message-mirror.js +179 -0
- package/dist/domains/agents/run/message-mirror.js.map +1 -0
- package/dist/domains/agents/run/run-state.d.ts +28 -0
- package/dist/domains/agents/run/run-state.d.ts.map +1 -0
- package/dist/domains/agents/run/run-state.js +2 -0
- package/dist/domains/agents/run/run-state.js.map +1 -0
- package/dist/domains/agents/run/subagent-runner.d.ts +104 -0
- package/dist/domains/agents/run/subagent-runner.d.ts.map +1 -0
- package/dist/domains/agents/run/subagent-runner.js +374 -0
- package/dist/domains/agents/run/subagent-runner.js.map +1 -0
- package/dist/domains/agents/run/system-prompt-builder.d.ts +19 -0
- package/dist/domains/agents/run/system-prompt-builder.d.ts.map +1 -0
- package/dist/domains/agents/run/system-prompt-builder.js +39 -0
- package/dist/domains/agents/run/system-prompt-builder.js.map +1 -0
- package/dist/domains/agents/run/tool-draft-progress.d.ts +47 -0
- package/dist/domains/agents/run/tool-draft-progress.d.ts.map +1 -0
- package/dist/domains/agents/run/tool-draft-progress.js +438 -0
- package/dist/domains/agents/run/tool-draft-progress.js.map +1 -0
- package/dist/domains/agents/run/tool-draft-streaming.d.ts +3 -0
- package/dist/domains/agents/run/tool-draft-streaming.d.ts.map +1 -0
- package/dist/domains/agents/run/tool-draft-streaming.js +13 -0
- package/dist/domains/agents/run/tool-draft-streaming.js.map +1 -0
- package/dist/domains/completions/file-completion-candidates.d.ts +13 -0
- package/dist/domains/completions/file-completion-candidates.d.ts.map +1 -0
- package/dist/domains/completions/file-completion-candidates.js +208 -0
- package/dist/domains/completions/file-completion-candidates.js.map +1 -0
- package/dist/domains/completions/file-completion-ranking.d.ts +19 -0
- package/dist/domains/completions/file-completion-ranking.d.ts.map +1 -0
- package/dist/domains/completions/file-completion-ranking.js +350 -0
- package/dist/domains/completions/file-completion-ranking.js.map +1 -0
- package/dist/domains/completions/file-completion-service.d.ts +11 -0
- package/dist/domains/completions/file-completion-service.d.ts.map +1 -0
- package/dist/domains/completions/file-completion-service.js +60 -0
- package/dist/domains/completions/file-completion-service.js.map +1 -0
- package/dist/domains/completions/index.d.ts +4 -0
- package/dist/domains/completions/index.d.ts.map +1 -0
- package/dist/domains/completions/index.js +4 -0
- package/dist/domains/completions/index.js.map +1 -0
- package/dist/domains/conversations/conversation-lifecycle.service.d.ts +32 -0
- package/dist/domains/conversations/conversation-lifecycle.service.d.ts.map +1 -0
- package/dist/domains/conversations/conversation-lifecycle.service.js +139 -0
- package/dist/domains/conversations/conversation-lifecycle.service.js.map +1 -0
- package/dist/domains/conversations/conversation-query.service.d.ts +19 -0
- package/dist/domains/conversations/conversation-query.service.d.ts.map +1 -0
- package/dist/domains/conversations/conversation-query.service.js +76 -0
- package/dist/domains/conversations/conversation-query.service.js.map +1 -0
- package/dist/domains/conversations/conversation-runtime.d.ts +112 -0
- package/dist/domains/conversations/conversation-runtime.d.ts.map +1 -0
- package/dist/domains/conversations/conversation-runtime.js +417 -0
- package/dist/domains/conversations/conversation-runtime.js.map +1 -0
- package/dist/domains/conversations/conversation-service.d.ts +17 -0
- package/dist/domains/conversations/conversation-service.d.ts.map +1 -0
- package/dist/domains/conversations/conversation-service.js +56 -0
- package/dist/domains/conversations/conversation-service.js.map +1 -0
- package/dist/domains/conversations/conversation.repository.d.ts +13 -0
- package/dist/domains/conversations/conversation.repository.d.ts.map +1 -0
- package/dist/domains/conversations/conversation.repository.js +39 -0
- package/dist/domains/conversations/conversation.repository.js.map +1 -0
- package/dist/domains/conversations/entry.repository.d.ts +15 -0
- package/dist/domains/conversations/entry.repository.d.ts.map +1 -0
- package/dist/domains/conversations/entry.repository.js +81 -0
- package/dist/domains/conversations/entry.repository.js.map +1 -0
- package/dist/domains/conversations/harness-manager.d.ts +29 -0
- package/dist/domains/conversations/harness-manager.d.ts.map +1 -0
- package/dist/domains/conversations/harness-manager.js +129 -0
- package/dist/domains/conversations/harness-manager.js.map +1 -0
- package/dist/domains/conversations/index.d.ts +5 -0
- package/dist/domains/conversations/index.d.ts.map +1 -0
- package/dist/domains/conversations/index.js +5 -0
- package/dist/domains/conversations/index.js.map +1 -0
- package/dist/domains/conversations/operations/compaction-service.d.ts +63 -0
- package/dist/domains/conversations/operations/compaction-service.d.ts.map +1 -0
- package/dist/domains/conversations/operations/compaction-service.js +200 -0
- package/dist/domains/conversations/operations/compaction-service.js.map +1 -0
- package/dist/domains/conversations/operations/export-service.d.ts +22 -0
- package/dist/domains/conversations/operations/export-service.d.ts.map +1 -0
- package/dist/domains/conversations/operations/export-service.js +79 -0
- package/dist/domains/conversations/operations/export-service.js.map +1 -0
- package/dist/domains/conversations/operations/import-service.d.ts +20 -0
- package/dist/domains/conversations/operations/import-service.d.ts.map +1 -0
- package/dist/domains/conversations/operations/import-service.js +97 -0
- package/dist/domains/conversations/operations/import-service.js.map +1 -0
- package/dist/domains/conversations/operations/index.d.ts +8 -0
- package/dist/domains/conversations/operations/index.d.ts.map +1 -0
- package/dist/domains/conversations/operations/index.js +6 -0
- package/dist/domains/conversations/operations/index.js.map +1 -0
- package/dist/domains/conversations/operations/navigation-service.d.ts +18 -0
- package/dist/domains/conversations/operations/navigation-service.d.ts.map +1 -0
- package/dist/domains/conversations/operations/navigation-service.js +102 -0
- package/dist/domains/conversations/operations/navigation-service.js.map +1 -0
- package/dist/domains/conversations/operations/summary.d.ts +11 -0
- package/dist/domains/conversations/operations/summary.d.ts.map +1 -0
- package/dist/domains/conversations/operations/summary.js +29 -0
- package/dist/domains/conversations/operations/summary.js.map +1 -0
- package/dist/domains/git/git-branches.d.ts +12 -0
- package/dist/domains/git/git-branches.d.ts.map +1 -0
- package/dist/domains/git/git-branches.js +131 -0
- package/dist/domains/git/git-branches.js.map +1 -0
- package/dist/domains/git/git-command.d.ts +13 -0
- package/dist/domains/git/git-command.d.ts.map +1 -0
- package/dist/domains/git/git-command.js +38 -0
- package/dist/domains/git/git-command.js.map +1 -0
- package/dist/domains/git/git-github-parsers.d.ts +12 -0
- package/dist/domains/git/git-github-parsers.d.ts.map +1 -0
- package/dist/domains/git/git-github-parsers.js +82 -0
- package/dist/domains/git/git-github-parsers.js.map +1 -0
- package/dist/domains/git/git-github-service.d.ts +30 -0
- package/dist/domains/git/git-github-service.d.ts.map +1 -0
- package/dist/domains/git/git-github-service.js +171 -0
- package/dist/domains/git/git-github-service.js.map +1 -0
- package/dist/domains/git/git-service.d.ts +53 -0
- package/dist/domains/git/git-service.d.ts.map +1 -0
- package/dist/domains/git/git-service.js +440 -0
- package/dist/domains/git/git-service.js.map +1 -0
- package/dist/domains/git/git-status.d.ts +24 -0
- package/dist/domains/git/git-status.d.ts.map +1 -0
- package/dist/domains/git/git-status.js +133 -0
- package/dist/domains/git/git-status.js.map +1 -0
- package/dist/domains/human-input/human-input-resolution.service.d.ts +47 -0
- package/dist/domains/human-input/human-input-resolution.service.d.ts.map +1 -0
- package/dist/domains/human-input/human-input-resolution.service.js +305 -0
- package/dist/domains/human-input/human-input-resolution.service.js.map +1 -0
- package/dist/domains/human-input/index.d.ts +3 -0
- package/dist/domains/human-input/index.d.ts.map +1 -0
- package/dist/domains/human-input/index.js +2 -0
- package/dist/domains/human-input/index.js.map +1 -0
- package/dist/domains/pinned-commands/index.d.ts +3 -0
- package/dist/domains/pinned-commands/index.d.ts.map +1 -0
- package/dist/domains/pinned-commands/index.js +3 -0
- package/dist/domains/pinned-commands/index.js.map +1 -0
- package/dist/domains/pinned-commands/pinned-command.repository.d.ts +10 -0
- package/dist/domains/pinned-commands/pinned-command.repository.d.ts.map +1 -0
- package/dist/domains/pinned-commands/pinned-command.repository.js +28 -0
- package/dist/domains/pinned-commands/pinned-command.repository.js.map +1 -0
- package/dist/domains/pinned-commands/pinned-command.service.d.ts +11 -0
- package/dist/domains/pinned-commands/pinned-command.service.d.ts.map +1 -0
- package/dist/domains/pinned-commands/pinned-command.service.js +40 -0
- package/dist/domains/pinned-commands/pinned-command.service.js.map +1 -0
- package/dist/domains/plans/plan-paths.d.ts +6 -0
- package/dist/domains/plans/plan-paths.d.ts.map +1 -0
- package/dist/domains/plans/plan-paths.js +30 -0
- package/dist/domains/plans/plan-paths.js.map +1 -0
- package/dist/domains/plans/plan-service.d.ts +62 -0
- package/dist/domains/plans/plan-service.d.ts.map +1 -0
- package/dist/domains/plans/plan-service.js +266 -0
- package/dist/domains/plans/plan-service.js.map +1 -0
- package/dist/domains/processes/index.d.ts +10 -0
- package/dist/domains/processes/index.d.ts.map +1 -0
- package/dist/domains/processes/index.js +7 -0
- package/dist/domains/processes/index.js.map +1 -0
- package/dist/domains/processes/process-launch-config.store.d.ts +21 -0
- package/dist/domains/processes/process-launch-config.store.d.ts.map +1 -0
- package/dist/domains/processes/process-launch-config.store.js +49 -0
- package/dist/domains/processes/process-launch-config.store.js.map +1 -0
- package/dist/domains/processes/process-log.service.d.ts +25 -0
- package/dist/domains/processes/process-log.service.d.ts.map +1 -0
- package/dist/domains/processes/process-log.service.js +155 -0
- package/dist/domains/processes/process-log.service.js.map +1 -0
- package/dist/domains/processes/process-manager.d.ts +107 -0
- package/dist/domains/processes/process-manager.d.ts.map +1 -0
- package/dist/domains/processes/process-manager.js +814 -0
- package/dist/domains/processes/process-manager.js.map +1 -0
- package/dist/domains/processes/process-readiness.service.d.ts +7 -0
- package/dist/domains/processes/process-readiness.service.d.ts.map +1 -0
- package/dist/domains/processes/process-readiness.service.js +26 -0
- package/dist/domains/processes/process-readiness.service.js.map +1 -0
- package/dist/domains/processes/process-status.d.ts +5 -0
- package/dist/domains/processes/process-status.d.ts.map +1 -0
- package/dist/domains/processes/process-status.js +13 -0
- package/dist/domains/processes/process-status.js.map +1 -0
- package/dist/domains/processes/process-supervisor.d.ts +34 -0
- package/dist/domains/processes/process-supervisor.d.ts.map +1 -0
- package/dist/domains/processes/process-supervisor.js +211 -0
- package/dist/domains/processes/process-supervisor.js.map +1 -0
- package/dist/domains/processes/process.repository.d.ts +11 -0
- package/dist/domains/processes/process.repository.d.ts.map +1 -0
- package/dist/domains/processes/process.repository.js +31 -0
- package/dist/domains/processes/process.repository.js.map +1 -0
- package/dist/domains/projects/index.d.ts +5 -0
- package/dist/domains/projects/index.d.ts.map +1 -0
- package/dist/domains/projects/index.js +5 -0
- package/dist/domains/projects/index.js.map +1 -0
- package/dist/domains/projects/project-editor.service.d.ts +20 -0
- package/dist/domains/projects/project-editor.service.d.ts.map +1 -0
- package/dist/domains/projects/project-editor.service.js +240 -0
- package/dist/domains/projects/project-editor.service.js.map +1 -0
- package/dist/domains/projects/project.repository.d.ts +12 -0
- package/dist/domains/projects/project.repository.d.ts.map +1 -0
- package/dist/domains/projects/project.repository.js +33 -0
- package/dist/domains/projects/project.repository.js.map +1 -0
- package/dist/domains/projects/project.service.d.ts +22 -0
- package/dist/domains/projects/project.service.d.ts.map +1 -0
- package/dist/domains/projects/project.service.js +83 -0
- package/dist/domains/projects/project.service.js.map +1 -0
- package/dist/domains/projects/prune-conversations.service.d.ts +39 -0
- package/dist/domains/projects/prune-conversations.service.d.ts.map +1 -0
- package/dist/domains/projects/prune-conversations.service.js +91 -0
- package/dist/domains/projects/prune-conversations.service.js.map +1 -0
- package/dist/domains/providers/index.d.ts +2 -0
- package/dist/domains/providers/index.d.ts.map +1 -0
- package/dist/domains/providers/index.js +2 -0
- package/dist/domains/providers/index.js.map +1 -0
- package/dist/domains/providers/provider-catalog.store.d.ts +30 -0
- package/dist/domains/providers/provider-catalog.store.d.ts.map +1 -0
- package/dist/domains/providers/provider-catalog.store.js +109 -0
- package/dist/domains/providers/provider-catalog.store.js.map +1 -0
- package/dist/domains/runtime/python-runtime-service.d.ts +15 -0
- package/dist/domains/runtime/python-runtime-service.d.ts.map +1 -0
- package/dist/domains/runtime/python-runtime-service.js +65 -0
- package/dist/domains/runtime/python-runtime-service.js.map +1 -0
- package/dist/domains/storage/index.d.ts +2 -0
- package/dist/domains/storage/index.d.ts.map +1 -0
- package/dist/domains/storage/index.js +2 -0
- package/dist/domains/storage/index.js.map +1 -0
- package/dist/domains/storage/storage-usage.service.d.ts +39 -0
- package/dist/domains/storage/storage-usage.service.d.ts.map +1 -0
- package/dist/domains/storage/storage-usage.service.js +394 -0
- package/dist/domains/storage/storage-usage.service.js.map +1 -0
- package/dist/domains/tasks/index.d.ts +11 -0
- package/dist/domains/tasks/index.d.ts.map +1 -0
- package/dist/domains/tasks/index.js +8 -0
- package/dist/domains/tasks/index.js.map +1 -0
- package/dist/domains/tasks/task-completion.service.d.ts +31 -0
- package/dist/domains/tasks/task-completion.service.d.ts.map +1 -0
- package/dist/domains/tasks/task-completion.service.js +147 -0
- package/dist/domains/tasks/task-completion.service.js.map +1 -0
- package/dist/domains/tasks/task-launch-config.store.d.ts +21 -0
- package/dist/domains/tasks/task-launch-config.store.d.ts.map +1 -0
- package/dist/domains/tasks/task-launch-config.store.js +49 -0
- package/dist/domains/tasks/task-launch-config.store.js.map +1 -0
- package/dist/domains/tasks/task-legacy-migration.d.ts +15 -0
- package/dist/domains/tasks/task-legacy-migration.d.ts.map +1 -0
- package/dist/domains/tasks/task-legacy-migration.js +191 -0
- package/dist/domains/tasks/task-legacy-migration.js.map +1 -0
- package/dist/domains/tasks/task-log.service.d.ts +25 -0
- package/dist/domains/tasks/task-log.service.d.ts.map +1 -0
- package/dist/domains/tasks/task-log.service.js +169 -0
- package/dist/domains/tasks/task-log.service.js.map +1 -0
- package/dist/domains/tasks/task-manager-finalization.d.ts +8 -0
- package/dist/domains/tasks/task-manager-finalization.d.ts.map +1 -0
- package/dist/domains/tasks/task-manager-finalization.js +164 -0
- package/dist/domains/tasks/task-manager-finalization.js.map +1 -0
- package/dist/domains/tasks/task-manager-foreground.d.ts +5 -0
- package/dist/domains/tasks/task-manager-foreground.d.ts.map +1 -0
- package/dist/domains/tasks/task-manager-foreground.js +146 -0
- package/dist/domains/tasks/task-manager-foreground.js.map +1 -0
- package/dist/domains/tasks/task-manager-orphan.d.ts +14 -0
- package/dist/domains/tasks/task-manager-orphan.d.ts.map +1 -0
- package/dist/domains/tasks/task-manager-orphan.js +241 -0
- package/dist/domains/tasks/task-manager-orphan.js.map +1 -0
- package/dist/domains/tasks/task-manager-output-readiness.d.ts +17 -0
- package/dist/domains/tasks/task-manager-output-readiness.d.ts.map +1 -0
- package/dist/domains/tasks/task-manager-output-readiness.js +234 -0
- package/dist/domains/tasks/task-manager-output-readiness.js.map +1 -0
- package/dist/domains/tasks/task-manager-start.d.ts +12 -0
- package/dist/domains/tasks/task-manager-start.d.ts.map +1 -0
- package/dist/domains/tasks/task-manager-start.js +166 -0
- package/dist/domains/tasks/task-manager-start.js.map +1 -0
- package/dist/domains/tasks/task-manager-utils.d.ts +11 -0
- package/dist/domains/tasks/task-manager-utils.d.ts.map +1 -0
- package/dist/domains/tasks/task-manager-utils.js +28 -0
- package/dist/domains/tasks/task-manager-utils.js.map +1 -0
- package/dist/domains/tasks/task-manager.d.ts +213 -0
- package/dist/domains/tasks/task-manager.d.ts.map +1 -0
- package/dist/domains/tasks/task-manager.js +451 -0
- package/dist/domains/tasks/task-manager.js.map +1 -0
- package/dist/domains/tasks/task-notification.service.d.ts +42 -0
- package/dist/domains/tasks/task-notification.service.d.ts.map +1 -0
- package/dist/domains/tasks/task-notification.service.js +373 -0
- package/dist/domains/tasks/task-notification.service.js.map +1 -0
- package/dist/domains/tasks/task-readiness.service.d.ts +7 -0
- package/dist/domains/tasks/task-readiness.service.d.ts.map +1 -0
- package/dist/domains/tasks/task-readiness.service.js +27 -0
- package/dist/domains/tasks/task-readiness.service.js.map +1 -0
- package/dist/domains/tasks/task-status.d.ts +5 -0
- package/dist/domains/tasks/task-status.d.ts.map +1 -0
- package/dist/domains/tasks/task-status.js +13 -0
- package/dist/domains/tasks/task-status.js.map +1 -0
- package/dist/domains/tasks/task-summary-format.d.ts +42 -0
- package/dist/domains/tasks/task-summary-format.d.ts.map +1 -0
- package/dist/domains/tasks/task-summary-format.js +149 -0
- package/dist/domains/tasks/task-summary-format.js.map +1 -0
- package/dist/domains/tasks/task-supervisor.d.ts +34 -0
- package/dist/domains/tasks/task-supervisor.d.ts.map +1 -0
- package/dist/domains/tasks/task-supervisor.js +211 -0
- package/dist/domains/tasks/task-supervisor.js.map +1 -0
- package/dist/domains/tasks/task.repository.d.ts +37 -0
- package/dist/domains/tasks/task.repository.d.ts.map +1 -0
- package/dist/domains/tasks/task.repository.js +58 -0
- package/dist/domains/tasks/task.repository.js.map +1 -0
- package/dist/domains/tools/agent-tool-adapter.d.ts +25 -0
- package/dist/domains/tools/agent-tool-adapter.d.ts.map +1 -0
- package/dist/domains/tools/agent-tool-adapter.js +251 -0
- package/dist/domains/tools/agent-tool-adapter.js.map +1 -0
- package/dist/domains/tools/approval.repository.d.ts +28 -0
- package/dist/domains/tools/approval.repository.d.ts.map +1 -0
- package/dist/domains/tools/approval.repository.js +59 -0
- package/dist/domains/tools/approval.repository.js.map +1 -0
- package/dist/domains/tools/index.d.ts +12 -0
- package/dist/domains/tools/index.d.ts.map +1 -0
- package/dist/domains/tools/index.js +10 -0
- package/dist/domains/tools/index.js.map +1 -0
- package/dist/domains/tools/interaction-session.service.d.ts +23 -0
- package/dist/domains/tools/interaction-session.service.d.ts.map +1 -0
- package/dist/domains/tools/interaction-session.service.js +130 -0
- package/dist/domains/tools/interaction-session.service.js.map +1 -0
- package/dist/domains/tools/orchestration-tool-dispatcher-handlers.d.ts +25 -0
- package/dist/domains/tools/orchestration-tool-dispatcher-handlers.d.ts.map +1 -0
- package/dist/domains/tools/orchestration-tool-dispatcher-handlers.js +379 -0
- package/dist/domains/tools/orchestration-tool-dispatcher-handlers.js.map +1 -0
- package/dist/domains/tools/orchestration-tool-dispatcher.d.ts +58 -0
- package/dist/domains/tools/orchestration-tool-dispatcher.d.ts.map +1 -0
- package/dist/domains/tools/orchestration-tool-dispatcher.js +347 -0
- package/dist/domains/tools/orchestration-tool-dispatcher.js.map +1 -0
- package/dist/domains/tools/policy.d.ts +14 -0
- package/dist/domains/tools/policy.d.ts.map +1 -0
- package/dist/domains/tools/policy.js +330 -0
- package/dist/domains/tools/policy.js.map +1 -0
- package/dist/domains/tools/todo-state.service.d.ts +23 -0
- package/dist/domains/tools/todo-state.service.d.ts.map +1 -0
- package/dist/domains/tools/todo-state.service.js +63 -0
- package/dist/domains/tools/todo-state.service.js.map +1 -0
- package/dist/domains/tools/tool-args.d.ts +12 -0
- package/dist/domains/tools/tool-args.d.ts.map +1 -0
- package/dist/domains/tools/tool-args.js +55 -0
- package/dist/domains/tools/tool-args.js.map +1 -0
- package/dist/domains/tools/tool-call.repository.d.ts +55 -0
- package/dist/domains/tools/tool-call.repository.d.ts.map +1 -0
- package/dist/domains/tools/tool-call.repository.js +74 -0
- package/dist/domains/tools/tool-call.repository.js.map +1 -0
- package/dist/domains/tools/tool-errors.d.ts +9 -0
- package/dist/domains/tools/tool-errors.d.ts.map +1 -0
- package/dist/domains/tools/tool-errors.js +58 -0
- package/dist/domains/tools/tool-errors.js.map +1 -0
- package/dist/domains/tools/tool-execution-suspension.d.ts +5 -0
- package/dist/domains/tools/tool-execution-suspension.d.ts.map +1 -0
- package/dist/domains/tools/tool-execution-suspension.js +9 -0
- package/dist/domains/tools/tool-execution-suspension.js.map +1 -0
- package/dist/domains/tools/tool-executor.service.d.ts +18 -0
- package/dist/domains/tools/tool-executor.service.d.ts.map +1 -0
- package/dist/domains/tools/tool-executor.service.js +82 -0
- package/dist/domains/tools/tool-executor.service.js.map +1 -0
- package/dist/domains/tools/tool-result-bounds.d.ts +5 -0
- package/dist/domains/tools/tool-result-bounds.d.ts.map +1 -0
- package/dist/domains/tools/tool-result-bounds.js +149 -0
- package/dist/domains/tools/tool-result-bounds.js.map +1 -0
- package/dist/domains/tools/tool-service.d.ts +143 -0
- package/dist/domains/tools/tool-service.d.ts.map +1 -0
- package/dist/domains/tools/tool-service.js +459 -0
- package/dist/domains/tools/tool-service.js.map +1 -0
- package/dist/domains/tools/user-question.repository.d.ts +34 -0
- package/dist/domains/tools/user-question.repository.d.ts.map +1 -0
- package/dist/domains/tools/user-question.repository.js +62 -0
- package/dist/domains/tools/user-question.repository.js.map +1 -0
- package/dist/domains/transcription/transcription.service.d.ts +15 -0
- package/dist/domains/transcription/transcription.service.d.ts.map +1 -0
- package/dist/domains/transcription/transcription.service.js +128 -0
- package/dist/domains/transcription/transcription.service.js.map +1 -0
- package/dist/domains/usage/anthropic-client.d.ts +9 -0
- package/dist/domains/usage/anthropic-client.d.ts.map +1 -0
- package/dist/domains/usage/anthropic-client.js +207 -0
- package/dist/domains/usage/anthropic-client.js.map +1 -0
- package/dist/domains/usage/codex-client.d.ts +18 -0
- package/dist/domains/usage/codex-client.d.ts.map +1 -0
- package/dist/domains/usage/codex-client.js +316 -0
- package/dist/domains/usage/codex-client.js.map +1 -0
- package/dist/domains/usage/subscription-usage-service.d.ts +42 -0
- package/dist/domains/usage/subscription-usage-service.d.ts.map +1 -0
- package/dist/domains/usage/subscription-usage-service.js +131 -0
- package/dist/domains/usage/subscription-usage-service.js.map +1 -0
- package/dist/domains/workers/agent-process.d.ts +32 -0
- package/dist/domains/workers/agent-process.d.ts.map +1 -0
- package/dist/domains/workers/agent-process.js +129 -0
- package/dist/domains/workers/agent-process.js.map +1 -0
- package/dist/domains/workers/index.d.ts +3 -0
- package/dist/domains/workers/index.d.ts.map +1 -0
- package/dist/domains/workers/index.js +3 -0
- package/dist/domains/workers/index.js.map +1 -0
- package/dist/domains/workers/worker-manager.d.ts +51 -0
- package/dist/domains/workers/worker-manager.d.ts.map +1 -0
- package/dist/domains/workers/worker-manager.js +116 -0
- package/dist/domains/workers/worker-manager.js.map +1 -0
- package/dist/events.d.ts +2 -0
- package/dist/events.d.ts.map +1 -0
- package/dist/events.js +2 -0
- package/dist/events.js.map +1 -0
- package/dist/git/git-service.d.ts +51 -0
- package/dist/git/git-service.d.ts.map +1 -0
- package/dist/git/git-service.js +716 -0
- package/dist/git/git-service.js.map +1 -0
- package/dist/git/git-status.d.ts +24 -0
- package/dist/git/git-status.d.ts.map +1 -0
- package/dist/git/git-status.js +133 -0
- package/dist/git/git-status.js.map +1 -0
- package/dist/harness-manager.d.ts +21 -0
- package/dist/harness-manager.d.ts.map +1 -0
- package/dist/harness-manager.js +105 -0
- package/dist/harness-manager.js.map +1 -0
- package/dist/http/auth-middleware.d.ts +12 -0
- package/dist/http/auth-middleware.d.ts.map +1 -0
- package/dist/http/auth-middleware.js +64 -0
- package/dist/http/auth-middleware.js.map +1 -0
- package/dist/http/errors.d.ts +7 -0
- package/dist/http/errors.d.ts.map +1 -0
- package/dist/http/errors.js +21 -0
- package/dist/http/errors.js.map +1 -0
- package/dist/http/query.d.ts +2 -0
- package/dist/http/query.d.ts.map +1 -0
- package/dist/http/query.js +7 -0
- package/dist/http/query.js.map +1 -0
- package/dist/http/request-context.d.ts +11 -0
- package/dist/http/request-context.d.ts.map +1 -0
- package/dist/http/request-context.js +11 -0
- package/dist/http/request-context.js.map +1 -0
- package/dist/http/responses.d.ts +3 -0
- package/dist/http/responses.d.ts.map +1 -0
- package/dist/http/responses.js +20 -0
- package/dist/http/responses.js.map +1 -0
- package/dist/http/route-params.d.ts +3 -0
- package/dist/http/route-params.d.ts.map +1 -0
- package/dist/http/route-params.js +9 -0
- package/dist/http/route-params.js.map +1 -0
- package/dist/http/static-files.d.ts +4 -0
- package/dist/http/static-files.d.ts.map +1 -0
- package/dist/http/static-files.js +125 -0
- package/dist/http/static-files.js.map +1 -0
- package/dist/index-store.d.ts +2 -0
- package/dist/index-store.d.ts.map +1 -0
- package/dist/index-store.js +2 -0
- package/dist/index-store.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -0
- package/dist/infrastructure/events/event-bus.d.ts +58 -0
- package/dist/infrastructure/events/event-bus.d.ts.map +1 -0
- package/dist/infrastructure/events/event-bus.js +242 -0
- package/dist/infrastructure/events/event-bus.js.map +1 -0
- package/dist/infrastructure/events/event-ref-extractor.d.ts +3 -0
- package/dist/infrastructure/events/event-ref-extractor.d.ts.map +1 -0
- package/dist/infrastructure/events/event-ref-extractor.js +30 -0
- package/dist/infrastructure/events/event-ref-extractor.js.map +1 -0
- package/dist/infrastructure/events/index.d.ts +3 -0
- package/dist/infrastructure/events/index.d.ts.map +1 -0
- package/dist/infrastructure/events/index.js +3 -0
- package/dist/infrastructure/events/index.js.map +1 -0
- package/dist/infrastructure/index-store/event-refs.d.ts +9 -0
- package/dist/infrastructure/index-store/event-refs.d.ts.map +1 -0
- package/dist/infrastructure/index-store/event-refs.js +40 -0
- package/dist/infrastructure/index-store/event-refs.js.map +1 -0
- package/dist/infrastructure/index-store/index-store.d.ts +83 -0
- package/dist/infrastructure/index-store/index-store.d.ts.map +1 -0
- package/dist/infrastructure/index-store/index-store.js +436 -0
- package/dist/infrastructure/index-store/index-store.js.map +1 -0
- package/dist/infrastructure/index-store/index.d.ts +4 -0
- package/dist/infrastructure/index-store/index.d.ts.map +1 -0
- package/dist/infrastructure/index-store/index.js +4 -0
- package/dist/infrastructure/index-store/index.js.map +1 -0
- package/dist/infrastructure/index-store/schema.d.ts +2 -0
- package/dist/infrastructure/index-store/schema.d.ts.map +1 -0
- package/dist/infrastructure/index-store/schema.js +84 -0
- package/dist/infrastructure/index-store/schema.js.map +1 -0
- package/dist/infrastructure/storage/index.d.ts +4 -0
- package/dist/infrastructure/storage/index.d.ts.map +1 -0
- package/dist/infrastructure/storage/index.js +4 -0
- package/dist/infrastructure/storage/index.js.map +1 -0
- package/dist/infrastructure/storage/initialize.d.ts +12 -0
- package/dist/infrastructure/storage/initialize.d.ts.map +1 -0
- package/dist/infrastructure/storage/initialize.js +118 -0
- package/dist/infrastructure/storage/initialize.js.map +1 -0
- package/dist/infrastructure/storage/json.d.ts +29 -0
- package/dist/infrastructure/storage/json.d.ts.map +1 -0
- package/dist/infrastructure/storage/json.js +222 -0
- package/dist/infrastructure/storage/json.js.map +1 -0
- package/dist/infrastructure/storage/paths.d.ts +11 -0
- package/dist/infrastructure/storage/paths.d.ts.map +1 -0
- package/dist/infrastructure/storage/paths.js +18 -0
- package/dist/infrastructure/storage/paths.js.map +1 -0
- package/dist/infrastructure/tls/lan-certificate.d.ts +11 -0
- package/dist/infrastructure/tls/lan-certificate.d.ts.map +1 -0
- package/dist/infrastructure/tls/lan-certificate.js +209 -0
- package/dist/infrastructure/tls/lan-certificate.js.map +1 -0
- package/dist/logging.d.ts +58 -0
- package/dist/logging.d.ts.map +1 -0
- package/dist/logging.js +348 -0
- package/dist/logging.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +422 -0
- package/dist/main.js.map +1 -0
- package/dist/nerve-system-prompt.d.ts +17 -0
- package/dist/nerve-system-prompt.d.ts.map +1 -0
- package/dist/nerve-system-prompt.js +161 -0
- package/dist/nerve-system-prompt.js.map +1 -0
- package/dist/oauth-flow.d.ts +27 -0
- package/dist/oauth-flow.d.ts.map +1 -0
- package/dist/oauth-flow.js +268 -0
- package/dist/oauth-flow.js.map +1 -0
- package/dist/plan-paths.d.ts +6 -0
- package/dist/plan-paths.d.ts.map +1 -0
- package/dist/plan-paths.js +30 -0
- package/dist/plan-paths.js.map +1 -0
- package/dist/plan-service.d.ts +61 -0
- package/dist/plan-service.d.ts.map +1 -0
- package/dist/plan-service.js +255 -0
- package/dist/plan-service.js.map +1 -0
- package/dist/policy.d.ts +14 -0
- package/dist/policy.d.ts.map +1 -0
- package/dist/policy.js +247 -0
- package/dist/policy.js.map +1 -0
- package/dist/process-manager.d.ts +72 -0
- package/dist/process-manager.d.ts.map +1 -0
- package/dist/process-manager.js +376 -0
- package/dist/process-manager.js.map +1 -0
- package/dist/prompt-text.d.ts +9 -0
- package/dist/prompt-text.d.ts.map +1 -0
- package/dist/prompt-text.js +48 -0
- package/dist/prompt-text.js.map +1 -0
- package/dist/registry/agent-lifecycle-service.d.ts +38 -0
- package/dist/registry/agent-lifecycle-service.d.ts.map +1 -0
- package/dist/registry/agent-lifecycle-service.js +199 -0
- package/dist/registry/agent-lifecycle-service.js.map +1 -0
- package/dist/registry/conversation-lifecycle-service.d.ts +35 -0
- package/dist/registry/conversation-lifecycle-service.d.ts.map +1 -0
- package/dist/registry/conversation-lifecycle-service.js +136 -0
- package/dist/registry/conversation-lifecycle-service.js.map +1 -0
- package/dist/registry/pinned-command-service.d.ts +11 -0
- package/dist/registry/pinned-command-service.d.ts.map +1 -0
- package/dist/registry/pinned-command-service.js +40 -0
- package/dist/registry/pinned-command-service.js.map +1 -0
- package/dist/registry/project-lifecycle-service.d.ts +22 -0
- package/dist/registry/project-lifecycle-service.d.ts.map +1 -0
- package/dist/registry/project-lifecycle-service.js +87 -0
- package/dist/registry/project-lifecycle-service.js.map +1 -0
- package/dist/registry/types.d.ts +25 -0
- package/dist/registry/types.d.ts.map +1 -0
- package/dist/registry/types.js +2 -0
- package/dist/registry/types.js.map +1 -0
- package/dist/registry.d.ts +977 -0
- package/dist/registry.d.ts.map +1 -0
- package/dist/registry.js +356 -0
- package/dist/registry.js.map +1 -0
- package/dist/repositories/agent-repository.d.ts +12 -0
- package/dist/repositories/agent-repository.d.ts.map +1 -0
- package/dist/repositories/agent-repository.js +33 -0
- package/dist/repositories/agent-repository.js.map +1 -0
- package/dist/repositories/conversation-repository.d.ts +13 -0
- package/dist/repositories/conversation-repository.d.ts.map +1 -0
- package/dist/repositories/conversation-repository.js +39 -0
- package/dist/repositories/conversation-repository.js.map +1 -0
- package/dist/repositories/entry-repository.d.ts +15 -0
- package/dist/repositories/entry-repository.d.ts.map +1 -0
- package/dist/repositories/entry-repository.js +81 -0
- package/dist/repositories/entry-repository.js.map +1 -0
- package/dist/repositories/index.d.ts +7 -0
- package/dist/repositories/index.d.ts.map +1 -0
- package/dist/repositories/index.js +7 -0
- package/dist/repositories/index.js.map +1 -0
- package/dist/repositories/pinned-command-repository.d.ts +10 -0
- package/dist/repositories/pinned-command-repository.d.ts.map +1 -0
- package/dist/repositories/pinned-command-repository.js +28 -0
- package/dist/repositories/pinned-command-repository.js.map +1 -0
- package/dist/repositories/project-repository.d.ts +12 -0
- package/dist/repositories/project-repository.d.ts.map +1 -0
- package/dist/repositories/project-repository.js +33 -0
- package/dist/repositories/project-repository.js.map +1 -0
- package/dist/repositories/prompt-queue-repository.d.ts +28 -0
- package/dist/repositories/prompt-queue-repository.d.ts.map +1 -0
- package/dist/repositories/prompt-queue-repository.js +88 -0
- package/dist/repositories/prompt-queue-repository.js.map +1 -0
- package/dist/resource-loader.d.ts +15 -0
- package/dist/resource-loader.d.ts.map +1 -0
- package/dist/resource-loader.js +109 -0
- package/dist/resource-loader.js.map +1 -0
- package/dist/routes/agent-routes.d.ts +4 -0
- package/dist/routes/agent-routes.d.ts.map +1 -0
- package/dist/routes/agent-routes.js +58 -0
- package/dist/routes/agent-routes.js.map +1 -0
- package/dist/routes/auth-routes.d.ts +4 -0
- package/dist/routes/auth-routes.d.ts.map +1 -0
- package/dist/routes/auth-routes.js +70 -0
- package/dist/routes/auth-routes.js.map +1 -0
- package/dist/routes/completion-routes.d.ts +4 -0
- package/dist/routes/completion-routes.d.ts.map +1 -0
- package/dist/routes/completion-routes.js +49 -0
- package/dist/routes/completion-routes.js.map +1 -0
- package/dist/routes/conversation-routes.d.ts +4 -0
- package/dist/routes/conversation-routes.d.ts.map +1 -0
- package/dist/routes/conversation-routes.js +65 -0
- package/dist/routes/conversation-routes.js.map +1 -0
- package/dist/routes/filesystem-routes.d.ts +5 -0
- package/dist/routes/filesystem-routes.d.ts.map +1 -0
- package/dist/routes/filesystem-routes.js +341 -0
- package/dist/routes/filesystem-routes.js.map +1 -0
- package/dist/routes/git-routes.d.ts +4 -0
- package/dist/routes/git-routes.d.ts.map +1 -0
- package/dist/routes/git-routes.js +66 -0
- package/dist/routes/git-routes.js.map +1 -0
- package/dist/routes/index.d.ts +21 -0
- package/dist/routes/index.d.ts.map +1 -0
- package/dist/routes/index.js +54 -0
- package/dist/routes/index.js.map +1 -0
- package/dist/routes/log-routes.d.ts +4 -0
- package/dist/routes/log-routes.d.ts.map +1 -0
- package/dist/routes/log-routes.js +55 -0
- package/dist/routes/log-routes.js.map +1 -0
- package/dist/routes/model-routes.d.ts +4 -0
- package/dist/routes/model-routes.d.ts.map +1 -0
- package/dist/routes/model-routes.js +8 -0
- package/dist/routes/model-routes.js.map +1 -0
- package/dist/routes/process-routes.d.ts +4 -0
- package/dist/routes/process-routes.d.ts.map +1 -0
- package/dist/routes/process-routes.js +43 -0
- package/dist/routes/process-routes.js.map +1 -0
- package/dist/routes/project-routes.d.ts +4 -0
- package/dist/routes/project-routes.d.ts.map +1 -0
- package/dist/routes/project-routes.js +42 -0
- package/dist/routes/project-routes.js.map +1 -0
- package/dist/routes/provider-catalog-routes.d.ts +4 -0
- package/dist/routes/provider-catalog-routes.d.ts.map +1 -0
- package/dist/routes/provider-catalog-routes.js +46 -0
- package/dist/routes/provider-catalog-routes.js.map +1 -0
- package/dist/routes/settings-routes.d.ts +4 -0
- package/dist/routes/settings-routes.d.ts.map +1 -0
- package/dist/routes/settings-routes.js +19 -0
- package/dist/routes/settings-routes.js.map +1 -0
- package/dist/routes/status-routes.d.ts +4 -0
- package/dist/routes/status-routes.d.ts.map +1 -0
- package/dist/routes/status-routes.js +20 -0
- package/dist/routes/status-routes.js.map +1 -0
- package/dist/routes/storage-routes.d.ts +4 -0
- package/dist/routes/storage-routes.d.ts.map +1 -0
- package/dist/routes/storage-routes.js +23 -0
- package/dist/routes/storage-routes.js.map +1 -0
- package/dist/routes/task-routes.d.ts +4 -0
- package/dist/routes/task-routes.d.ts.map +1 -0
- package/dist/routes/task-routes.js +67 -0
- package/dist/routes/task-routes.js.map +1 -0
- package/dist/routes/tool-routes.d.ts +4 -0
- package/dist/routes/tool-routes.d.ts.map +1 -0
- package/dist/routes/tool-routes.js +89 -0
- package/dist/routes/tool-routes.js.map +1 -0
- package/dist/routes/transcription-routes.d.ts +4 -0
- package/dist/routes/transcription-routes.d.ts.map +1 -0
- package/dist/routes/transcription-routes.js +38 -0
- package/dist/routes/transcription-routes.js.map +1 -0
- package/dist/routes/worker-routes.d.ts +4 -0
- package/dist/routes/worker-routes.d.ts.map +1 -0
- package/dist/routes/worker-routes.js +12 -0
- package/dist/routes/worker-routes.js.map +1 -0
- package/dist/runtime/runtime-composition.d.ts +64 -0
- package/dist/runtime/runtime-composition.d.ts.map +1 -0
- package/dist/runtime/runtime-composition.js +183 -0
- package/dist/runtime/runtime-composition.js.map +1 -0
- package/dist/runtime/runtime-state.d.ts +100 -0
- package/dist/runtime/runtime-state.d.ts.map +1 -0
- package/dist/runtime/runtime-state.js +74 -0
- package/dist/runtime/runtime-state.js.map +1 -0
- package/dist/secrets.d.ts +20 -0
- package/dist/secrets.d.ts.map +1 -0
- package/dist/secrets.js +77 -0
- package/dist/secrets.js.map +1 -0
- package/dist/server.d.ts +43 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +270 -0
- package/dist/server.js.map +1 -0
- package/dist/storage.d.ts +2 -0
- package/dist/storage.d.ts.map +1 -0
- package/dist/storage.js +2 -0
- package/dist/storage.js.map +1 -0
- package/dist/tool-service.d.ts +82 -0
- package/dist/tool-service.d.ts.map +1 -0
- package/dist/tool-service.js +409 -0
- package/dist/tool-service.js.map +1 -0
- package/dist/transcription-service.d.ts +15 -0
- package/dist/transcription-service.d.ts.map +1 -0
- package/dist/transcription-service.js +128 -0
- package/dist/transcription-service.js.map +1 -0
- package/dist/usage/anthropic-client.d.ts +9 -0
- package/dist/usage/anthropic-client.d.ts.map +1 -0
- package/dist/usage/anthropic-client.js +207 -0
- package/dist/usage/anthropic-client.js.map +1 -0
- package/dist/usage/codex-client.d.ts +18 -0
- package/dist/usage/codex-client.d.ts.map +1 -0
- package/dist/usage/codex-client.js +316 -0
- package/dist/usage/codex-client.js.map +1 -0
- package/dist/usage/subscription-usage-service.d.ts +42 -0
- package/dist/usage/subscription-usage-service.d.ts.map +1 -0
- package/dist/usage/subscription-usage-service.js +131 -0
- package/dist/usage/subscription-usage-service.js.map +1 -0
- package/dist/version.d.ts +2 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +17 -0
- package/dist/version.js.map +1 -0
- package/dist/web/apple-touch-icon.png +0 -0
- package/dist/web/assets/bash-B7CDPTg5.js +1 -0
- package/dist/web/assets/css-BsVw1vtW.js +1 -0
- package/dist/web/assets/diff-woXpYk--.js +1 -0
- package/dist/web/assets/dist-DVpGQCt0.js +4 -0
- package/dist/web/assets/dist-FQvzRocB.js +141 -0
- package/dist/web/assets/github-dark-dimmed-Bx1FflLF.js +1 -0
- package/dist/web/assets/github-light-EUqPIrTm.js +1 -0
- package/dist/web/assets/html-BY76lXLH.js +1 -0
- package/dist/web/assets/index-DFKLdj_D.css +2 -0
- package/dist/web/assets/index-DP6SGqvJ.js +165 -0
- package/dist/web/assets/iosevka-latin-400-normal-7stTb90X.woff2 +0 -0
- package/dist/web/assets/iosevka-latin-500-normal-CQO8XnuS.woff2 +0 -0
- package/dist/web/assets/javascript-BgS3c2Ky.js +1 -0
- package/dist/web/assets/json-qhed-kSA.js +1 -0
- package/dist/web/assets/jsonc-CYpm1nAK.js +1 -0
- package/dist/web/assets/jsx-Bz0zcwM4.js +1 -0
- package/dist/web/assets/markdown-BYOwaDjH.js +1 -0
- package/dist/web/assets/outfit-latin-400-normal-BGsTXAXT.woff2 +0 -0
- package/dist/web/assets/outfit-latin-400-normal-DMwTpYkH.woff +0 -0
- package/dist/web/assets/outfit-latin-500-normal-ClnHRwRh.woff +0 -0
- package/dist/web/assets/outfit-latin-500-normal-DKnIMDSk.woff2 +0 -0
- package/dist/web/assets/outfit-latin-600-normal-B7SfZ07L.woff2 +0 -0
- package/dist/web/assets/outfit-latin-600-normal-BEfTtDA7.woff +0 -0
- package/dist/web/assets/outfit-latin-700-normal-Cu9v6i1X.woff2 +0 -0
- package/dist/web/assets/outfit-latin-700-normal-D4itBLBr.woff +0 -0
- package/dist/web/assets/outfit-latin-ext-400-normal-5tcqmc2S.woff2 +0 -0
- package/dist/web/assets/outfit-latin-ext-400-normal-DHm7mdGe.woff +0 -0
- package/dist/web/assets/outfit-latin-ext-500-normal-DrCvqoFD.woff +0 -0
- package/dist/web/assets/outfit-latin-ext-500-normal-zeox_O30.woff2 +0 -0
- package/dist/web/assets/outfit-latin-ext-600-normal-B85nYjL1.woff2 +0 -0
- package/dist/web/assets/outfit-latin-ext-600-normal-CWJcPgd7.woff +0 -0
- package/dist/web/assets/outfit-latin-ext-700-normal-CI4iH74K.woff2 +0 -0
- package/dist/web/assets/outfit-latin-ext-700-normal-fjS8-Gm7.woff +0 -0
- package/dist/web/assets/python-gzcpVVnB.js +1 -0
- package/dist/web/assets/shellscript-CLZ0U2zV.js +1 -0
- package/dist/web/assets/svelte-Uaf2W_lJ.js +1 -0
- package/dist/web/assets/tsx-udAQXfEw.js +1 -0
- package/dist/web/assets/typescript-bsJCZSQ-.js +1 -0
- package/dist/web/assets/workbox-window.prod.es5-Bd17z0YL.js +2 -0
- package/dist/web/assets/yaml-rwi0_p6S.js +1 -0
- package/dist/web/favicon-16.png +0 -0
- package/dist/web/favicon-32.png +0 -0
- package/dist/web/favicon.svg +15 -0
- package/dist/web/index.html +25 -0
- package/dist/web/manifest.webmanifest +1 -0
- package/dist/web/pwa-192x192.png +0 -0
- package/dist/web/pwa-512x512.png +0 -0
- package/dist/web/pwa-maskable-512x512.png +0 -0
- package/dist/web/sw.js +1 -0
- package/dist/web/workbox-2fbc6a65.js +1 -0
- package/dist/worker-manager.d.ts +51 -0
- package/dist/worker-manager.d.ts.map +1 -0
- package/dist/worker-manager.js +116 -0
- package/dist/worker-manager.js.map +1 -0
- package/package.json +58 -0
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { createDecipheriv, constants as cryptoConstants, generateKeyPairSync, privateDecrypt, } from "node:crypto";
|
|
2
|
+
import { createId, } from "@nervekit/shared";
|
|
3
|
+
import { HttpError } from "./http/errors.js";
|
|
4
|
+
const GCM_TAG_BYTES = 16;
|
|
5
|
+
/**
|
|
6
|
+
* Holds an ephemeral RSA-OAEP keypair (in memory only, regenerated per process)
|
|
7
|
+
* used to receive API keys from the UI with application-layer encryption.
|
|
8
|
+
*
|
|
9
|
+
* The UI encrypts an API key with a hybrid envelope: a random AES-256-GCM key
|
|
10
|
+
* encrypts the secret, and the AES key is wrapped with RSA-OAEP-SHA256. This
|
|
11
|
+
* keeps the raw key out of plaintext request bodies and logs even over plain
|
|
12
|
+
* HTTP. It complements, but does not replace, TLS for remote deployments.
|
|
13
|
+
*/
|
|
14
|
+
export class CredentialKeyService {
|
|
15
|
+
keyId = createId("credkey");
|
|
16
|
+
publicKey;
|
|
17
|
+
privateKey;
|
|
18
|
+
constructor() {
|
|
19
|
+
const { publicKey, privateKey } = generateKeyPairSync("rsa", {
|
|
20
|
+
modulusLength: 2048,
|
|
21
|
+
});
|
|
22
|
+
this.publicKey = publicKey;
|
|
23
|
+
this.privateKey = privateKey;
|
|
24
|
+
}
|
|
25
|
+
getPublicKey() {
|
|
26
|
+
return {
|
|
27
|
+
keyId: this.keyId,
|
|
28
|
+
algorithm: "RSA-OAEP-256+A256GCM",
|
|
29
|
+
publicKey: this.publicKey
|
|
30
|
+
.export({ type: "spki", format: "der" })
|
|
31
|
+
.toString("base64"),
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
decryptEnvelope(envelope) {
|
|
35
|
+
if (envelope.keyId !== this.keyId) {
|
|
36
|
+
throw new HttpError(400, "CREDENTIAL_KEY_STALE", "Credential key is stale. Refetch the public key and retry.");
|
|
37
|
+
}
|
|
38
|
+
let aesKey;
|
|
39
|
+
try {
|
|
40
|
+
aesKey = privateDecrypt({
|
|
41
|
+
key: this.privateKey,
|
|
42
|
+
padding: cryptoConstants.RSA_PKCS1_OAEP_PADDING,
|
|
43
|
+
oaepHash: "sha256",
|
|
44
|
+
}, Buffer.from(envelope.encryptedKey, "base64"));
|
|
45
|
+
}
|
|
46
|
+
catch {
|
|
47
|
+
throw new HttpError(400, "CREDENTIAL_DECRYPT_FAILED", "Could not decrypt the credential envelope.");
|
|
48
|
+
}
|
|
49
|
+
// WebCrypto AES-GCM output is ciphertext || authTag (trailing 16 bytes).
|
|
50
|
+
const combined = Buffer.from(envelope.ciphertext, "base64");
|
|
51
|
+
if (combined.length <= GCM_TAG_BYTES) {
|
|
52
|
+
throw new HttpError(400, "CREDENTIAL_DECRYPT_FAILED", "Could not decrypt the credential envelope.");
|
|
53
|
+
}
|
|
54
|
+
const ciphertext = combined.subarray(0, combined.length - GCM_TAG_BYTES);
|
|
55
|
+
const tag = combined.subarray(combined.length - GCM_TAG_BYTES);
|
|
56
|
+
try {
|
|
57
|
+
const decipher = createDecipheriv("aes-256-gcm", aesKey, Buffer.from(envelope.iv, "base64"));
|
|
58
|
+
decipher.setAuthTag(tag);
|
|
59
|
+
const plaintext = Buffer.concat([
|
|
60
|
+
decipher.update(ciphertext),
|
|
61
|
+
decipher.final(),
|
|
62
|
+
]).toString("utf8");
|
|
63
|
+
if (!plaintext) {
|
|
64
|
+
throw new Error("Empty credential.");
|
|
65
|
+
}
|
|
66
|
+
return plaintext;
|
|
67
|
+
}
|
|
68
|
+
catch (error) {
|
|
69
|
+
if (error instanceof HttpError)
|
|
70
|
+
throw error;
|
|
71
|
+
throw new HttpError(400, "CREDENTIAL_DECRYPT_FAILED", "Could not decrypt the credential envelope.");
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=credential-crypto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credential-crypto.js","sourceRoot":"","sources":["../src/credential-crypto.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { AgentRecord, Mode, PermissionLevel } from "@nervekit/shared";
|
|
2
|
+
export declare function assertChildAuthority(parent: AgentRecord, mode: Mode, permissionLevel: PermissionLevel, allowAuthorityExceed: boolean): void;
|
|
3
|
+
export declare function modeRank(mode: Mode): number;
|
|
4
|
+
export declare function permissionRank(permission: PermissionLevel): number;
|
|
5
|
+
//# sourceMappingURL=agent-authority.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-authority.d.ts","sourceRoot":"","sources":["../../../src/domains/agents/agent-authority.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAG3E,wBAAgB,oBAAoB,CAClC,MAAM,EAAE,WAAW,EACnB,IAAI,EAAE,IAAI,EACV,eAAe,EAAE,eAAe,EAChC,oBAAoB,EAAE,OAAO,GAC5B,IAAI,CAyBN;AAED,wBAAgB,QAAQ,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM,CAE3C;AAED,wBAAgB,cAAc,CAAC,UAAU,EAAE,eAAe,GAAG,MAAM,CASlE"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { HttpError } from "../../http/errors.js";
|
|
2
|
+
export function assertChildAuthority(parent, mode, permissionLevel, allowAuthorityExceed) {
|
|
3
|
+
if (parent.budget.depth >= parent.budget.maxDepth) {
|
|
4
|
+
throw new HttpError(403, "SUBAGENT_DEPTH_LIMIT", `Child-agent depth limit reached (${parent.budget.depth}/${parent.budget.maxDepth}).`);
|
|
5
|
+
}
|
|
6
|
+
if (parent.budget.usedRuns >= parent.budget.maxRuns) {
|
|
7
|
+
throw new HttpError(403, "SUBAGENT_BUDGET_EXHAUSTED", `Child-agent run budget exhausted (${parent.budget.usedRuns}/${parent.budget.maxRuns}).`);
|
|
8
|
+
}
|
|
9
|
+
const exceeds = modeRank(mode) > modeRank(parent.mode) ||
|
|
10
|
+
permissionRank(permissionLevel) > permissionRank(parent.permissionLevel);
|
|
11
|
+
if (exceeds && !allowAuthorityExceed) {
|
|
12
|
+
throw new HttpError(403, "SUBAGENT_AUTHORITY_EXCEEDED", "Child agent authority cannot exceed parent authority without an approved agent-spawn tool call.");
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
export function modeRank(mode) {
|
|
16
|
+
return mode === "planning" ? 0 : 1;
|
|
17
|
+
}
|
|
18
|
+
export function permissionRank(permission) {
|
|
19
|
+
switch (permission) {
|
|
20
|
+
case "read_only":
|
|
21
|
+
return 0;
|
|
22
|
+
case "supervised":
|
|
23
|
+
return 1;
|
|
24
|
+
case "autonomous":
|
|
25
|
+
return 2;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=agent-authority.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-authority.js","sourceRoot":"","sources":["../../../src/domains/agents/agent-authority.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEjD,MAAM,UAAU,oBAAoB,CAClC,MAAmB,EACnB,IAAU,EACV,eAAgC,EAChC,oBAA6B;IAE7B,IAAI,MAAM,CAAC,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QAClD,MAAM,IAAI,SAAS,CACjB,GAAG,EACH,sBAAsB,EACtB,oCAAoC,MAAM,CAAC,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ,IAAI,CACtF,CAAC;IACJ,CAAC;IACD,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QACpD,MAAM,IAAI,SAAS,CACjB,GAAG,EACH,2BAA2B,EAC3B,qCAAqC,MAAM,CAAC,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,IAAI,CACzF,CAAC;IACJ,CAAC;IACD,MAAM,OAAO,GACX,QAAQ,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC;QACtC,cAAc,CAAC,eAAe,CAAC,GAAG,cAAc,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;IAC3E,IAAI,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACrC,MAAM,IAAI,SAAS,CACjB,GAAG,EACH,6BAA6B,EAC7B,iGAAiG,CAClG,CAAC;IACJ,CAAC;AACH,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,IAAU;IACjC,OAAO,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACrC,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,UAA2B;IACxD,QAAQ,UAAU,EAAE,CAAC;QACnB,KAAK,WAAW;YACd,OAAO,CAAC,CAAC;QACX,KAAK,YAAY;YACf,OAAO,CAAC,CAAC;QACX,KAAK,YAAY;YACf,OAAO,CAAC,CAAC;IACb,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-budget.d.ts","sourceRoot":"","sources":["../../../src/domains/agents/agent-budget.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAExE,wBAAgB,WAAW,CACzB,MAAM,EAAE,WAAW,GAAG,SAAS,EAC/B,OAAO,EAAE,kBAAkB,CAAC,QAAQ,CAAC,GACpC,WAAW,CAAC,QAAQ,CAAC,CAevB"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export function agentBudget(parent, request) {
|
|
2
|
+
if (!parent) {
|
|
3
|
+
return {
|
|
4
|
+
depth: request?.depth ?? 0,
|
|
5
|
+
maxDepth: request?.maxDepth ?? 3,
|
|
6
|
+
maxRuns: request?.maxRuns ?? 8,
|
|
7
|
+
usedRuns: request?.usedRuns ?? 0,
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
return {
|
|
11
|
+
depth: parent.budget.depth + 1,
|
|
12
|
+
maxDepth: request?.maxDepth ?? parent.budget.maxDepth,
|
|
13
|
+
maxRuns: request?.maxRuns ?? Math.max(1, parent.budget.maxRuns),
|
|
14
|
+
usedRuns: request?.usedRuns ?? 0,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=agent-budget.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-budget.js","sourceRoot":"","sources":["../../../src/domains/agents/agent-budget.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,WAAW,CACzB,MAA+B,EAC/B,OAAqC;IAErC,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,OAAO;YACL,KAAK,EAAE,OAAO,EAAE,KAAK,IAAI,CAAC;YAC1B,QAAQ,EAAE,OAAO,EAAE,QAAQ,IAAI,CAAC;YAChC,OAAO,EAAE,OAAO,EAAE,OAAO,IAAI,CAAC;YAC9B,QAAQ,EAAE,OAAO,EAAE,QAAQ,IAAI,CAAC;SACjC,CAAC;IACJ,CAAC;IACD,OAAO;QACL,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC;QAC9B,QAAQ,EAAE,OAAO,EAAE,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,QAAQ;QACrD,OAAO,EAAE,OAAO,EAAE,OAAO,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC;QAC/D,QAAQ,EAAE,OAAO,EAAE,QAAQ,IAAI,CAAC;KACjC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { type AgentRecord, type CreateAgentRequest, type Mode, type UpdateAgentRequest } from "@nervekit/shared";
|
|
2
|
+
import type { EventBus } from "../../infrastructure/events/index.js";
|
|
3
|
+
import type { IndexStore } from "../../infrastructure/index-store/index.js";
|
|
4
|
+
import type { InitializedStorage } from "../../infrastructure/storage/index.js";
|
|
5
|
+
import type { AgentStatus } from "../../registry/types.js";
|
|
6
|
+
import type { RuntimeState } from "../../runtime/runtime-state.js";
|
|
7
|
+
import type { ConversationService } from "../conversations/conversation-service.js";
|
|
8
|
+
import type { WorkerManager } from "../workers/worker-manager.js";
|
|
9
|
+
import type { AgentRepository } from "./agent.repository.js";
|
|
10
|
+
export declare class AgentLifecycleService {
|
|
11
|
+
private readonly storage;
|
|
12
|
+
private readonly events;
|
|
13
|
+
private readonly index;
|
|
14
|
+
private readonly state;
|
|
15
|
+
private readonly agentRepository;
|
|
16
|
+
private readonly workers;
|
|
17
|
+
private readonly conversationService;
|
|
18
|
+
private readonly updateConversation;
|
|
19
|
+
private readonly abortAgent;
|
|
20
|
+
private readonly childReservationQueues;
|
|
21
|
+
constructor(storage: InitializedStorage, events: EventBus, index: IndexStore, state: RuntimeState, agentRepository: AgentRepository, workers: WorkerManager, conversationService: ConversationService, updateConversation: (conversation: ReturnType<RuntimeState["getConversation"]>) => Promise<void>, abortAgent: (agentId: string) => Promise<void>);
|
|
22
|
+
createAgent(request: CreateAgentRequest, options?: {
|
|
23
|
+
allowChildAuthorityExceed?: boolean;
|
|
24
|
+
}): Promise<AgentRecord>;
|
|
25
|
+
listAgents(): AgentRecord[];
|
|
26
|
+
getAgent(agentId: string): AgentRecord;
|
|
27
|
+
removeAgentInternal(agentId: string): Promise<void>;
|
|
28
|
+
configureAgent(agentId: string, request: UpdateAgentRequest): Promise<AgentRecord>;
|
|
29
|
+
setAgentModeInternal(agentId: string, mode: Mode, reason: string): Promise<AgentRecord>;
|
|
30
|
+
setAgentStatus(agent: AgentRecord, status: AgentStatus): Promise<void>;
|
|
31
|
+
updateAgent(agent: AgentRecord): Promise<void>;
|
|
32
|
+
loadAgents(): Promise<void>;
|
|
33
|
+
private reserveChildRunWithAuthority;
|
|
34
|
+
private reserveChildRun;
|
|
35
|
+
private writeAgent;
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=agent-lifecycle.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-lifecycle.service.d.ts","sourceRoot":"","sources":["../../../src/domains/agents/agent-lifecycle.service.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,KAAK,WAAW,EAChB,KAAK,kBAAkB,EAEvB,KAAK,IAAI,EACT,KAAK,kBAAkB,EACxB,MAAM,kBAAkB,CAAC;AAE1B,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,sCAAsC,CAAC;AACrE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,2CAA2C,CAAC;AAC5E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAChF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,0CAA0C,CAAC;AACpF,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAwB7D,qBAAa,qBAAqB;IAI9B,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,mBAAmB;IACpC,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IAGnC,OAAO,CAAC,QAAQ,CAAC,UAAU;IAb7B,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAoC;gBAGxD,OAAO,EAAE,kBAAkB,EAC3B,MAAM,EAAE,QAAQ,EAChB,KAAK,EAAE,UAAU,EACjB,KAAK,EAAE,YAAY,EACnB,eAAe,EAAE,eAAe,EAChC,OAAO,EAAE,aAAa,EACtB,mBAAmB,EAAE,mBAAmB,EACxC,kBAAkB,EAAE,CACnC,YAAY,EAAE,UAAU,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC,KACtD,OAAO,CAAC,IAAI,CAAC,EACD,UAAU,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC;IAG3D,WAAW,CACf,OAAO,EAAE,kBAAkB,EAC3B,OAAO,GAAE;QAAE,yBAAyB,CAAC,EAAE,OAAO,CAAA;KAAO,GACpD,OAAO,CAAC,WAAW,CAAC;IA6EvB,UAAU,IAAI,WAAW,EAAE;IAI3B,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,WAAW;IAIhC,mBAAmB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAenD,cAAc,CAClB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,kBAAkB,GAC1B,OAAO,CAAC,WAAW,CAAC;IAmDjB,oBAAoB,CACxB,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,IAAI,EACV,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,CAAC;IAkBjB,cAAc,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAStE,WAAW,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAM9C,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;YAuBnB,4BAA4B;YA8B5B,eAAe;YAaf,UAAU;CAIzB"}
|
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
import { resolve } from "node:path";
|
|
2
|
+
import { clampAgentThinkingLevel } from "@nervekit/agent";
|
|
3
|
+
import { createId, } from "@nervekit/shared";
|
|
4
|
+
import { HttpError } from "../../http/errors.js";
|
|
5
|
+
import { assertChildAuthority } from "./agent-authority.js";
|
|
6
|
+
import { agentBudget } from "./agent-budget.js";
|
|
7
|
+
import { setAgentStatus as setAgentStatusHelper } from "./agent-status.js";
|
|
8
|
+
function isModeOnlyUpdate(request) {
|
|
9
|
+
return (request.mode !== undefined &&
|
|
10
|
+
request.permissionLevel === undefined &&
|
|
11
|
+
request.model === undefined &&
|
|
12
|
+
request.thinkingLevel === undefined);
|
|
13
|
+
}
|
|
14
|
+
function isRuntimeModelUpdate(request) {
|
|
15
|
+
return (request.permissionLevel === undefined &&
|
|
16
|
+
request.mode === undefined &&
|
|
17
|
+
(request.model !== undefined || request.thinkingLevel !== undefined));
|
|
18
|
+
}
|
|
19
|
+
export class AgentLifecycleService {
|
|
20
|
+
storage;
|
|
21
|
+
events;
|
|
22
|
+
index;
|
|
23
|
+
state;
|
|
24
|
+
agentRepository;
|
|
25
|
+
workers;
|
|
26
|
+
conversationService;
|
|
27
|
+
updateConversation;
|
|
28
|
+
abortAgent;
|
|
29
|
+
childReservationQueues = new Map();
|
|
30
|
+
constructor(storage, events, index, state, agentRepository, workers, conversationService, updateConversation, abortAgent) {
|
|
31
|
+
this.storage = storage;
|
|
32
|
+
this.events = events;
|
|
33
|
+
this.index = index;
|
|
34
|
+
this.state = state;
|
|
35
|
+
this.agentRepository = agentRepository;
|
|
36
|
+
this.workers = workers;
|
|
37
|
+
this.conversationService = conversationService;
|
|
38
|
+
this.updateConversation = updateConversation;
|
|
39
|
+
this.abortAgent = abortAgent;
|
|
40
|
+
}
|
|
41
|
+
async createAgent(request, options = {}) {
|
|
42
|
+
const conversation = this.state.getConversation(request.conversationId);
|
|
43
|
+
const project = this.state.getProject(request.projectId);
|
|
44
|
+
const parent = request.parentAgentId
|
|
45
|
+
? this.state.agents.get(request.parentAgentId)
|
|
46
|
+
: undefined;
|
|
47
|
+
if (request.parentAgentId && !parent)
|
|
48
|
+
throw new HttpError(404, "PARENT_AGENT_NOT_FOUND", "Parent agent not found.");
|
|
49
|
+
const now = new Date().toISOString();
|
|
50
|
+
const id = createId("agent");
|
|
51
|
+
const projectDir = resolve(request.projectDir ?? project.dir);
|
|
52
|
+
const defaultSelection = this.storage.settings.rememberLastAgentSelection
|
|
53
|
+
? this.storage.settings.lastAgentSelection
|
|
54
|
+
: {
|
|
55
|
+
mode: this.storage.settings.defaultMode,
|
|
56
|
+
permissionLevel: this.storage.settings.defaultPermissionLevel,
|
|
57
|
+
model: this.storage.settings.defaultModel,
|
|
58
|
+
thinkingLevel: this.storage.settings.defaultThinkingLevel,
|
|
59
|
+
};
|
|
60
|
+
const mode = request.mode ?? (parent ? parent.mode : conversation.mode);
|
|
61
|
+
const permissionLevel = request.permissionLevel ??
|
|
62
|
+
(parent ? parent.permissionLevel : conversation.permissionLevel);
|
|
63
|
+
const model = parent
|
|
64
|
+
? request.model
|
|
65
|
+
: (request.model ?? defaultSelection.model);
|
|
66
|
+
const thinkingLevel = parent
|
|
67
|
+
? request.thinkingLevel
|
|
68
|
+
: (request.thinkingLevel ?? defaultSelection.thinkingLevel);
|
|
69
|
+
const workerId = this.workers.requireWorker(request.workerId ?? parent?.workerId, "agent").id;
|
|
70
|
+
if (parent) {
|
|
71
|
+
await this.reserveChildRunWithAuthority(parent.id, mode, permissionLevel, Boolean(options.allowChildAuthorityExceed));
|
|
72
|
+
}
|
|
73
|
+
const agent = {
|
|
74
|
+
id,
|
|
75
|
+
conversationId: conversation.id,
|
|
76
|
+
projectId: project.id,
|
|
77
|
+
projectDir,
|
|
78
|
+
workerId,
|
|
79
|
+
parentAgentId: request.parentAgentId,
|
|
80
|
+
rootAgentId: parent?.rootAgentId ?? id,
|
|
81
|
+
mode,
|
|
82
|
+
permissionLevel,
|
|
83
|
+
workspaceScope: request.workspaceScope ?? { roots: [projectDir] },
|
|
84
|
+
systemPrompt: request.systemPrompt,
|
|
85
|
+
budget: agentBudget(parent, request.budget),
|
|
86
|
+
model,
|
|
87
|
+
thinkingLevel: clampAgentThinkingLevel(model, thinkingLevel),
|
|
88
|
+
status: "idle",
|
|
89
|
+
createdAt: now,
|
|
90
|
+
updatedAt: now,
|
|
91
|
+
};
|
|
92
|
+
this.state.agents.set(agent.id, agent);
|
|
93
|
+
this.index.upsertAgent(agent);
|
|
94
|
+
await this.writeAgent(agent);
|
|
95
|
+
await this.updateConversation({
|
|
96
|
+
...conversation,
|
|
97
|
+
activeAgentId: agent.id,
|
|
98
|
+
updatedAt: now,
|
|
99
|
+
});
|
|
100
|
+
await this.events.publish("agent.created", { agent, task: request.task });
|
|
101
|
+
return agent;
|
|
102
|
+
}
|
|
103
|
+
listAgents() {
|
|
104
|
+
return this.state.listAgents();
|
|
105
|
+
}
|
|
106
|
+
getAgent(agentId) {
|
|
107
|
+
return this.state.getAgent(agentId);
|
|
108
|
+
}
|
|
109
|
+
async removeAgentInternal(agentId) {
|
|
110
|
+
if (!this.state.agents.has(agentId))
|
|
111
|
+
return;
|
|
112
|
+
if (this.state.runs.has(agentId))
|
|
113
|
+
await this.abortAgent(agentId);
|
|
114
|
+
for (const child of [...this.state.agents.values()].filter((candidate) => candidate.parentAgentId === agentId)) {
|
|
115
|
+
await this.removeAgentInternal(child.id);
|
|
116
|
+
}
|
|
117
|
+
this.state.agents.delete(agentId);
|
|
118
|
+
this.conversationService.deleteAgent(agentId);
|
|
119
|
+
this.state.runs.delete(agentId);
|
|
120
|
+
this.index.removeAgent(agentId);
|
|
121
|
+
await this.agentRepository.remove(agentId);
|
|
122
|
+
}
|
|
123
|
+
async configureAgent(agentId, request) {
|
|
124
|
+
const agent = this.getAgent(agentId);
|
|
125
|
+
if (this.state.runs.has(agent.id)) {
|
|
126
|
+
if (isModeOnlyUpdate(request)) {
|
|
127
|
+
return this.setAgentModeInternal(agent.id, request.mode, "Mode changed by user.");
|
|
128
|
+
}
|
|
129
|
+
if (isRuntimeModelUpdate(request)) {
|
|
130
|
+
const model = request.model === null ? undefined : (request.model ?? agent.model);
|
|
131
|
+
const updated = {
|
|
132
|
+
...agent,
|
|
133
|
+
model,
|
|
134
|
+
thinkingLevel: clampAgentThinkingLevel(model, request.thinkingLevel ?? agent.thinkingLevel),
|
|
135
|
+
updatedAt: new Date().toISOString(),
|
|
136
|
+
};
|
|
137
|
+
await this.updateAgent(updated);
|
|
138
|
+
await this.state.runs
|
|
139
|
+
.get(agent.id)
|
|
140
|
+
?.updateAgentRuntimeConfig?.(updated);
|
|
141
|
+
await this.events.publish("agent.configured", { agent: updated });
|
|
142
|
+
return updated;
|
|
143
|
+
}
|
|
144
|
+
throw new HttpError(409, "AGENT_BUSY", "Cannot update a running agent.");
|
|
145
|
+
}
|
|
146
|
+
const model = request.model === null ? undefined : (request.model ?? agent.model);
|
|
147
|
+
const updated = {
|
|
148
|
+
...agent,
|
|
149
|
+
mode: request.mode ?? agent.mode,
|
|
150
|
+
permissionLevel: request.permissionLevel ?? agent.permissionLevel,
|
|
151
|
+
model,
|
|
152
|
+
thinkingLevel: clampAgentThinkingLevel(model, request.thinkingLevel ?? agent.thinkingLevel),
|
|
153
|
+
updatedAt: new Date().toISOString(),
|
|
154
|
+
};
|
|
155
|
+
await this.updateAgent(updated);
|
|
156
|
+
await this.events.publish("agent.configured", { agent: updated });
|
|
157
|
+
return updated;
|
|
158
|
+
}
|
|
159
|
+
async setAgentModeInternal(agentId, mode, reason) {
|
|
160
|
+
const agent = this.getAgent(agentId);
|
|
161
|
+
const updated = {
|
|
162
|
+
...agent,
|
|
163
|
+
mode,
|
|
164
|
+
updatedAt: new Date().toISOString(),
|
|
165
|
+
};
|
|
166
|
+
await this.updateAgent(updated);
|
|
167
|
+
await this.state.runs.get(agentId)?.updateAgentRuntimeConfig?.(updated);
|
|
168
|
+
await this.events.publish("agent.mode_changed", {
|
|
169
|
+
agent: updated,
|
|
170
|
+
previousMode: agent.mode,
|
|
171
|
+
mode,
|
|
172
|
+
reason,
|
|
173
|
+
});
|
|
174
|
+
return updated;
|
|
175
|
+
}
|
|
176
|
+
async setAgentStatus(agent, status) {
|
|
177
|
+
await setAgentStatusHelper(agent, status, (updated) => this.updateAgent(updated), this.events);
|
|
178
|
+
}
|
|
179
|
+
async updateAgent(agent) {
|
|
180
|
+
this.state.agents.set(agent.id, agent);
|
|
181
|
+
this.index.upsertAgent(agent);
|
|
182
|
+
await this.writeAgent(agent);
|
|
183
|
+
}
|
|
184
|
+
async loadAgents() {
|
|
185
|
+
for (const parsedAgent of await this.agentRepository.loadAll()) {
|
|
186
|
+
const localWorkerId = this.workers.requireDefaultLocalWorker().id;
|
|
187
|
+
const needsStatusRecovery = parsedAgent.status === "running";
|
|
188
|
+
const needsWorkerBackfill = !parsedAgent.workerId;
|
|
189
|
+
const agent = needsStatusRecovery || needsWorkerBackfill
|
|
190
|
+
? {
|
|
191
|
+
...parsedAgent,
|
|
192
|
+
workerId: parsedAgent.workerId ?? localWorkerId,
|
|
193
|
+
status: needsStatusRecovery ? "error" : parsedAgent.status,
|
|
194
|
+
updatedAt: needsStatusRecovery
|
|
195
|
+
? new Date().toISOString()
|
|
196
|
+
: parsedAgent.updatedAt,
|
|
197
|
+
}
|
|
198
|
+
: parsedAgent;
|
|
199
|
+
this.state.agents.set(agent.id, agent);
|
|
200
|
+
this.index.upsertAgent(agent);
|
|
201
|
+
if (needsStatusRecovery || needsWorkerBackfill)
|
|
202
|
+
await this.writeAgent(agent);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
async reserveChildRunWithAuthority(parentId, mode, permissionLevel, allowAuthorityExceed) {
|
|
206
|
+
const previous = this.childReservationQueues.get(parentId) ?? Promise.resolve();
|
|
207
|
+
const queued = previous
|
|
208
|
+
.catch(() => undefined)
|
|
209
|
+
.then(async () => {
|
|
210
|
+
const latest = this.getAgent(parentId);
|
|
211
|
+
assertChildAuthority(latest, mode, permissionLevel, allowAuthorityExceed);
|
|
212
|
+
await this.reserveChildRun(latest);
|
|
213
|
+
});
|
|
214
|
+
this.childReservationQueues.set(parentId, queued);
|
|
215
|
+
try {
|
|
216
|
+
await queued;
|
|
217
|
+
}
|
|
218
|
+
finally {
|
|
219
|
+
if (this.childReservationQueues.get(parentId) === queued) {
|
|
220
|
+
this.childReservationQueues.delete(parentId);
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
async reserveChildRun(parent) {
|
|
225
|
+
const latest = this.getAgent(parent.id);
|
|
226
|
+
const updated = {
|
|
227
|
+
...latest,
|
|
228
|
+
budget: {
|
|
229
|
+
...latest.budget,
|
|
230
|
+
usedRuns: latest.budget.usedRuns + 1,
|
|
231
|
+
},
|
|
232
|
+
updatedAt: new Date().toISOString(),
|
|
233
|
+
};
|
|
234
|
+
await this.updateAgent(updated);
|
|
235
|
+
}
|
|
236
|
+
async writeAgent(agent) {
|
|
237
|
+
this.index.upsertAgent(agent);
|
|
238
|
+
await this.agentRepository.write(agent);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
//# sourceMappingURL=agent-lifecycle.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-lifecycle.service.js","sourceRoot":"","sources":["../../../src/domains/agents/agent-lifecycle.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { AgentRecord } from "@nervekit/shared";
|
|
2
|
+
import type { EventBus } from "../../infrastructure/events/index.js";
|
|
3
|
+
export declare function setAgentStatus(agent: AgentRecord, status: AgentRecord["status"], updateAgent: (agent: AgentRecord) => Promise<void>, events: EventBus): Promise<void>;
|
|
4
|
+
//# sourceMappingURL=agent-status.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-status.d.ts","sourceRoot":"","sources":["../../../src/domains/agents/agent-status.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,sCAAsC,CAAC;AAErE,wBAAsB,cAAc,CAClC,KAAK,EAAE,WAAW,EAClB,MAAM,EAAE,WAAW,CAAC,QAAQ,CAAC,EAC7B,WAAW,EAAE,CAAC,KAAK,EAAE,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,EAClD,MAAM,EAAE,QAAQ,GACf,OAAO,CAAC,IAAI,CAAC,CAQf"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export async function setAgentStatus(agent, status, updateAgent, events) {
|
|
2
|
+
const updated = { ...agent, status, updatedAt: new Date().toISOString() };
|
|
3
|
+
await updateAgent(updated);
|
|
4
|
+
await events.publish("agent.status_changed", {
|
|
5
|
+
agent: updated,
|
|
6
|
+
agentId: updated.id,
|
|
7
|
+
status,
|
|
8
|
+
});
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=agent-status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-status.js","sourceRoot":"","sources":["../../../src/domains/agents/agent-status.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAAkB,EAClB,MAA6B,EAC7B,WAAkD,EAClD,MAAgB;IAEhB,MAAM,OAAO,GAAG,EAAE,GAAG,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC;IAC1E,MAAM,WAAW,CAAC,OAAO,CAAC,CAAC;IAC3B,MAAM,MAAM,CAAC,OAAO,CAAC,sBAAsB,EAAE;QAC3C,KAAK,EAAE,OAAO;QACd,OAAO,EAAE,OAAO,CAAC,EAAE;QACnB,MAAM;KACP,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { type AgentSuspensionRecord, type SuspensionStatus } from "@nervekit/shared";
|
|
2
|
+
import type { EventBus } from "../../infrastructure/events/index.js";
|
|
3
|
+
import type { InitializedStorage } from "../../infrastructure/storage/index.js";
|
|
4
|
+
export declare class AgentSuspensionService {
|
|
5
|
+
private readonly storage;
|
|
6
|
+
private readonly events;
|
|
7
|
+
readonly suspensions: Map<string, {
|
|
8
|
+
id: string;
|
|
9
|
+
agentId: string;
|
|
10
|
+
conversationId: string;
|
|
11
|
+
projectId: string;
|
|
12
|
+
runId: string;
|
|
13
|
+
toolCallId: string;
|
|
14
|
+
providerToolCallId: string;
|
|
15
|
+
toolName: "ask_user" | "plan_mode_present";
|
|
16
|
+
remainingToolCalls: {
|
|
17
|
+
id: string;
|
|
18
|
+
name: string;
|
|
19
|
+
arguments: Record<string, unknown>;
|
|
20
|
+
}[];
|
|
21
|
+
status: "error" | "cancelled" | "pending" | "resuming" | "resumed";
|
|
22
|
+
reason: string;
|
|
23
|
+
createdAt: string;
|
|
24
|
+
updatedAt: string;
|
|
25
|
+
turnId?: string | undefined;
|
|
26
|
+
liveMessageId?: string | undefined;
|
|
27
|
+
assistantEntryId?: string | undefined;
|
|
28
|
+
resolvedAt?: string | undefined;
|
|
29
|
+
error?: string | undefined;
|
|
30
|
+
}>;
|
|
31
|
+
constructor(storage: InitializedStorage, events: EventBus);
|
|
32
|
+
hydrate(): Promise<void>;
|
|
33
|
+
listSuspensions(status?: SuspensionStatus): AgentSuspensionRecord[];
|
|
34
|
+
pendingForToolCall(toolCallId: string): AgentSuspensionRecord | undefined;
|
|
35
|
+
pendingForAgent(agentId: string): AgentSuspensionRecord | undefined;
|
|
36
|
+
getSuspension(id: string): AgentSuspensionRecord;
|
|
37
|
+
removeSuspensionsForConversations(conversationIds: Iterable<string>): Promise<void>;
|
|
38
|
+
createSuspension(input: Omit<AgentSuspensionRecord, "id" | "status" | "createdAt" | "updatedAt">): Promise<AgentSuspensionRecord>;
|
|
39
|
+
updateSuspension(id: string, patch: Partial<Omit<AgentSuspensionRecord, "id" | "createdAt">>): Promise<AgentSuspensionRecord>;
|
|
40
|
+
private upsertSuspension;
|
|
41
|
+
private readLatestSuspensions;
|
|
42
|
+
private suspensionsPath;
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=agent-suspension.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-suspension.service.d.ts","sourceRoot":"","sources":["../../../src/domains/agents/agent-suspension.service.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,qBAAqB,EAG1B,KAAK,gBAAgB,EACtB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,sCAAsC,CAAC;AACrE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAOhF,qBAAa,sBAAsB;IAI/B,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,MAAM;IAJzB,QAAQ,CAAC,WAAW;;;;;;;;;;;;;;;;;;;;;;;OAA4C;gBAG7C,OAAO,EAAE,kBAAkB,EAC3B,MAAM,EAAE,QAAQ;IAG7B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAM9B,eAAe,CAAC,MAAM,CAAC,EAAE,gBAAgB,GAAG,qBAAqB,EAAE;IAMnE,kBAAkB,CAAC,UAAU,EAAE,MAAM,GAAG,qBAAqB,GAAG,SAAS;IAMzE,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,qBAAqB,GAAG,SAAS;IAMnE,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,qBAAqB;IAM1C,iCAAiC,CACrC,eAAe,EAAE,QAAQ,CAAC,MAAM,CAAC,GAChC,OAAO,CAAC,IAAI,CAAC;IAeV,gBAAgB,CACpB,KAAK,EAAE,IAAI,CACT,qBAAqB,EACrB,IAAI,GAAG,QAAQ,GAAG,WAAW,GAAG,WAAW,CAC5C,GACA,OAAO,CAAC,qBAAqB,CAAC;IAgB3B,gBAAgB,CACpB,EAAE,EAAE,MAAM,EACV,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,qBAAqB,EAAE,IAAI,GAAG,WAAW,CAAC,CAAC,GAC9D,OAAO,CAAC,qBAAqB,CAAC;YAcnB,gBAAgB;YAOhB,qBAAqB;IAWnC,OAAO,CAAC,eAAe;CAGxB"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { join } from "node:path";
|
|
2
|
+
import { agentSuspensionRecordSchema, createId, } from "@nervekit/shared";
|
|
3
|
+
import { appendJsonLine, readJsonLines, rewriteJsonLines, } from "../../infrastructure/storage/index.js";
|
|
4
|
+
export class AgentSuspensionService {
|
|
5
|
+
storage;
|
|
6
|
+
events;
|
|
7
|
+
suspensions = new Map();
|
|
8
|
+
constructor(storage, events) {
|
|
9
|
+
this.storage = storage;
|
|
10
|
+
this.events = events;
|
|
11
|
+
}
|
|
12
|
+
async hydrate() {
|
|
13
|
+
for (const suspension of await this.readLatestSuspensions()) {
|
|
14
|
+
this.suspensions.set(suspension.id, suspension);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
listSuspensions(status) {
|
|
18
|
+
return [...this.suspensions.values()]
|
|
19
|
+
.filter((suspension) => !status || suspension.status === status)
|
|
20
|
+
.sort((a, b) => b.updatedAt.localeCompare(a.updatedAt));
|
|
21
|
+
}
|
|
22
|
+
pendingForToolCall(toolCallId) {
|
|
23
|
+
return this.listSuspensions("pending").find((suspension) => suspension.toolCallId === toolCallId);
|
|
24
|
+
}
|
|
25
|
+
pendingForAgent(agentId) {
|
|
26
|
+
return this.listSuspensions("pending").find((suspension) => suspension.agentId === agentId);
|
|
27
|
+
}
|
|
28
|
+
getSuspension(id) {
|
|
29
|
+
const suspension = this.suspensions.get(id);
|
|
30
|
+
if (!suspension)
|
|
31
|
+
throw new Error("Agent suspension not found.");
|
|
32
|
+
return suspension;
|
|
33
|
+
}
|
|
34
|
+
async removeSuspensionsForConversations(conversationIds) {
|
|
35
|
+
const conversations = new Set(conversationIds);
|
|
36
|
+
if (conversations.size === 0)
|
|
37
|
+
return;
|
|
38
|
+
for (const [id, suspension] of this.suspensions) {
|
|
39
|
+
if (conversations.has(suspension.conversationId)) {
|
|
40
|
+
this.suspensions.delete(id);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
await rewriteJsonLines(this.suspensionsPath(), this.listSuspensions(), 0o600);
|
|
44
|
+
}
|
|
45
|
+
async createSuspension(input) {
|
|
46
|
+
const existing = this.pendingForToolCall(input.toolCallId);
|
|
47
|
+
if (existing)
|
|
48
|
+
return existing;
|
|
49
|
+
const now = new Date().toISOString();
|
|
50
|
+
const suspension = {
|
|
51
|
+
...input,
|
|
52
|
+
id: createId("susp"),
|
|
53
|
+
status: "pending",
|
|
54
|
+
createdAt: now,
|
|
55
|
+
updatedAt: now,
|
|
56
|
+
};
|
|
57
|
+
await this.upsertSuspension(suspension);
|
|
58
|
+
await this.events.publish("agent.suspension.created", { suspension });
|
|
59
|
+
return suspension;
|
|
60
|
+
}
|
|
61
|
+
async updateSuspension(id, patch) {
|
|
62
|
+
const current = this.getSuspension(id);
|
|
63
|
+
const updated = {
|
|
64
|
+
...current,
|
|
65
|
+
...patch,
|
|
66
|
+
updatedAt: new Date().toISOString(),
|
|
67
|
+
};
|
|
68
|
+
await this.upsertSuspension(updated);
|
|
69
|
+
await this.events.publish("agent.suspension.updated", {
|
|
70
|
+
suspension: updated,
|
|
71
|
+
});
|
|
72
|
+
return updated;
|
|
73
|
+
}
|
|
74
|
+
async upsertSuspension(suspension) {
|
|
75
|
+
this.suspensions.set(suspension.id, suspension);
|
|
76
|
+
await appendJsonLine(this.suspensionsPath(), suspension, 0o600);
|
|
77
|
+
}
|
|
78
|
+
async readLatestSuspensions() {
|
|
79
|
+
const values = await readJsonLines(this.suspensionsPath()).catch(() => []);
|
|
80
|
+
const parsed = values
|
|
81
|
+
.map((value) => agentSuspensionRecordSchema.safeParse(value))
|
|
82
|
+
.filter((result) => result.success)
|
|
83
|
+
.map((result) => result.data);
|
|
84
|
+
return latestById(parsed);
|
|
85
|
+
}
|
|
86
|
+
suspensionsPath() {
|
|
87
|
+
return join(this.storage.paths.home, "suspensions", "suspensions.jsonl");
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
function latestById(values) {
|
|
91
|
+
const byId = new Map();
|
|
92
|
+
for (const value of values)
|
|
93
|
+
byId.set(value.id, value);
|
|
94
|
+
return [...byId.values()];
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=agent-suspension.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-suspension.service.js","sourceRoot":"","sources":["../../../src/domains/agents/agent-suspension.service.ts"],"names":[],"mappings":"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"}
|