@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,96 @@
|
|
|
1
|
+
import { join } from "node:path";
|
|
2
|
+
import { agentSuspensionRecordSchema, createId, } from "@nerve/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/agent-suspension-service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { ImageContent, TextContent } from "@earendil-works/pi-ai";
|
|
2
|
+
import { type AgentTool, type AgentToolResult } from "@nerve/agent";
|
|
3
|
+
import type { AgentRecord, ToolCallRecord, ToolName } from "@nerve/shared";
|
|
4
|
+
import type { ToolAnchor } from "./domains/conversations/conversation-runtime.js";
|
|
5
|
+
import type { ToolService } from "./tool-service.js";
|
|
6
|
+
export type AgentToolPromptMetadata = {
|
|
7
|
+
activeToolNames: string[];
|
|
8
|
+
snippets: Record<string, string>;
|
|
9
|
+
guidelines: string[];
|
|
10
|
+
};
|
|
11
|
+
export declare function createAgentToolsForAgent(agent: AgentRecord, tools: ToolService, options?: {
|
|
12
|
+
runId?: string;
|
|
13
|
+
resolveToolAnchor?: (providerToolCallId: string) => ToolAnchor | undefined;
|
|
14
|
+
}): AgentTool[];
|
|
15
|
+
export declare function activeToolNamesForAgent(agent: AgentRecord): ToolName[];
|
|
16
|
+
export declare function toolPromptMetadata(activeToolNames: string[]): AgentToolPromptMetadata;
|
|
17
|
+
export declare function completedToolResult(toolCall: ToolCallRecord): AgentToolResult<unknown>;
|
|
18
|
+
export declare function contentBlocksFromResult(result: unknown): Array<TextContent | ImageContent> | undefined;
|
|
19
|
+
export declare function formatToolResultForModel(toolCall: ToolCallRecord): string;
|
|
20
|
+
//# sourceMappingURL=agent-tool-adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-tool-adapter.d.ts","sourceRoot":"","sources":["../src/agent-tool-adapter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACvE,OAAO,EACL,KAAK,SAAS,EACd,KAAK,eAAe,EAErB,MAAM,cAAc,CAAC;AACtB,OAAO,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAE3E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iDAAiD,CAAC;AAClF,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAErD,MAAM,MAAM,uBAAuB,GAAG;IACpC,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,UAAU,EAAE,MAAM,EAAE,CAAC;CACtB,CAAC;AAEF,wBAAgB,wBAAwB,CACtC,KAAK,EAAE,WAAW,EAClB,KAAK,EAAE,WAAW,EAClB,OAAO,GAAE;IACP,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,iBAAiB,CAAC,EAAE,CAAC,kBAAkB,EAAE,MAAM,KAAK,UAAU,GAAG,SAAS,CAAC;CACvE,GACL,SAAS,EAAE,CAIb;AAED,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,WAAW,GAAG,QAAQ,EAAE,CA8DtE;AAED,wBAAgB,kBAAkB,CAChC,eAAe,EAAE,MAAM,EAAE,GACxB,uBAAuB,CAmBzB;AAmDD,wBAAgB,mBAAmB,CACjC,QAAQ,EAAE,cAAc,GACvB,eAAe,CAAC,OAAO,CAAC,CAU1B;AAED,wBAAgB,uBAAuB,CACrC,MAAM,EAAE,OAAO,GACd,KAAK,CAAC,WAAW,GAAG,YAAY,CAAC,GAAG,SAAS,CA8B/C;AAED,wBAAgB,wBAAwB,CAAC,QAAQ,EAAE,cAAc,GAAG,MAAM,CAkDzE"}
|
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
import { AgentToolSuspension, } from "@nerve/agent";
|
|
2
|
+
import { allToolDefinitions } from "@nerve/tools";
|
|
3
|
+
export function createAgentToolsForAgent(agent, tools, options = {}) {
|
|
4
|
+
return allToolDefinitions.map((definition) => wrapCoreToolDefinition(definition, agent, tools, options));
|
|
5
|
+
}
|
|
6
|
+
export function activeToolNamesForAgent(agent) {
|
|
7
|
+
if (agent.permissionLevel === "read_only") {
|
|
8
|
+
const tools = [
|
|
9
|
+
"read",
|
|
10
|
+
"grep",
|
|
11
|
+
"find",
|
|
12
|
+
"ls",
|
|
13
|
+
"process_list",
|
|
14
|
+
"process_logs",
|
|
15
|
+
"ask_user",
|
|
16
|
+
"todos_set",
|
|
17
|
+
"todos_get",
|
|
18
|
+
"plan_mode_enter",
|
|
19
|
+
];
|
|
20
|
+
if (agent.mode === "planning") {
|
|
21
|
+
tools.push("plan_mode_present", "plan_mode_force_exit");
|
|
22
|
+
}
|
|
23
|
+
return tools;
|
|
24
|
+
}
|
|
25
|
+
if (agent.mode === "planning") {
|
|
26
|
+
return [
|
|
27
|
+
"read",
|
|
28
|
+
"bash",
|
|
29
|
+
"edit",
|
|
30
|
+
"write",
|
|
31
|
+
"grep",
|
|
32
|
+
"find",
|
|
33
|
+
"ls",
|
|
34
|
+
"process_list",
|
|
35
|
+
"process_logs",
|
|
36
|
+
"subagent_run",
|
|
37
|
+
"ask_user",
|
|
38
|
+
"todos_set",
|
|
39
|
+
"todos_get",
|
|
40
|
+
"web_search",
|
|
41
|
+
"web_fetch",
|
|
42
|
+
"plan_mode_enter",
|
|
43
|
+
"plan_mode_present",
|
|
44
|
+
"plan_mode_force_exit",
|
|
45
|
+
];
|
|
46
|
+
}
|
|
47
|
+
return [
|
|
48
|
+
"read",
|
|
49
|
+
"bash",
|
|
50
|
+
"edit",
|
|
51
|
+
"write",
|
|
52
|
+
"grep",
|
|
53
|
+
"find",
|
|
54
|
+
"ls",
|
|
55
|
+
"process_start",
|
|
56
|
+
"process_stop",
|
|
57
|
+
"process_restart",
|
|
58
|
+
"process_list",
|
|
59
|
+
"process_logs",
|
|
60
|
+
"subagent_run",
|
|
61
|
+
"ask_user",
|
|
62
|
+
"todos_set",
|
|
63
|
+
"todos_get",
|
|
64
|
+
"web_search",
|
|
65
|
+
"web_fetch",
|
|
66
|
+
"plan_mode_enter",
|
|
67
|
+
];
|
|
68
|
+
}
|
|
69
|
+
export function toolPromptMetadata(activeToolNames) {
|
|
70
|
+
const active = new Set(activeToolNames);
|
|
71
|
+
const snippets = {};
|
|
72
|
+
const guidelines = [];
|
|
73
|
+
const seenGuidelines = new Set();
|
|
74
|
+
for (const definition of allToolDefinitions) {
|
|
75
|
+
if (!active.has(definition.name))
|
|
76
|
+
continue;
|
|
77
|
+
if (definition.promptSnippet)
|
|
78
|
+
snippets[definition.name] = definition.promptSnippet;
|
|
79
|
+
for (const guideline of definition.promptGuidelines ?? []) {
|
|
80
|
+
const normalized = guideline.trim();
|
|
81
|
+
if (!normalized || seenGuidelines.has(normalized))
|
|
82
|
+
continue;
|
|
83
|
+
seenGuidelines.add(normalized);
|
|
84
|
+
guidelines.push(normalized);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return { activeToolNames: [...active], snippets, guidelines };
|
|
88
|
+
}
|
|
89
|
+
function wrapCoreToolDefinition(definition, agent, tools, options) {
|
|
90
|
+
return {
|
|
91
|
+
name: definition.name,
|
|
92
|
+
label: definition.label,
|
|
93
|
+
description: definition.description,
|
|
94
|
+
parameters: definition.parameters,
|
|
95
|
+
prepareArguments: definition.prepareArguments,
|
|
96
|
+
executionMode: definition.executionMode,
|
|
97
|
+
execute: async (sourceToolCallId, params, signal) => {
|
|
98
|
+
const toolCall = await tools.requestToolAndWait(agent, definition.name, params, {
|
|
99
|
+
signal,
|
|
100
|
+
sourceToolCallId,
|
|
101
|
+
providerToolCallId: sourceToolCallId,
|
|
102
|
+
runId: options.runId,
|
|
103
|
+
anchor: options.resolveToolAnchor?.(sourceToolCallId),
|
|
104
|
+
durableSuspend: true,
|
|
105
|
+
});
|
|
106
|
+
if (toolCall.status === "completed")
|
|
107
|
+
return completedToolResult(toolCall);
|
|
108
|
+
if (toolCall.status === "waiting_for_user" &&
|
|
109
|
+
(definition.name === "ask_user" ||
|
|
110
|
+
definition.name === "plan_mode_present")) {
|
|
111
|
+
throw new AgentToolSuspension({
|
|
112
|
+
toolCallId: toolCall.id,
|
|
113
|
+
toolName: definition.name,
|
|
114
|
+
reason: `Tool ${definition.name} is awaiting user input.`,
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
const message = toolCall.error ?? `Tool ${definition.name} ${toolCall.status}.`;
|
|
118
|
+
throw new Error(message);
|
|
119
|
+
},
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
export function completedToolResult(toolCall) {
|
|
123
|
+
return {
|
|
124
|
+
content: contentBlocksFromResult(toolCall.result) ?? [
|
|
125
|
+
{ type: "text", text: formatToolResultForModel(toolCall) },
|
|
126
|
+
],
|
|
127
|
+
details: {
|
|
128
|
+
toolCall,
|
|
129
|
+
result: toolCall.result,
|
|
130
|
+
},
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
export function contentBlocksFromResult(result) {
|
|
134
|
+
if (!result || typeof result !== "object")
|
|
135
|
+
return undefined;
|
|
136
|
+
const contentBlocks = result.contentBlocks;
|
|
137
|
+
if (!Array.isArray(contentBlocks) || contentBlocks.length === 0) {
|
|
138
|
+
return undefined;
|
|
139
|
+
}
|
|
140
|
+
const blocks = [];
|
|
141
|
+
for (const block of contentBlocks) {
|
|
142
|
+
if (!block || typeof block !== "object")
|
|
143
|
+
return undefined;
|
|
144
|
+
const record = block;
|
|
145
|
+
if (record.type === "text" && typeof record.text === "string") {
|
|
146
|
+
blocks.push({ type: "text", text: record.text });
|
|
147
|
+
continue;
|
|
148
|
+
}
|
|
149
|
+
if (record.type === "image" &&
|
|
150
|
+
typeof record.data === "string" &&
|
|
151
|
+
typeof record.mimeType === "string") {
|
|
152
|
+
blocks.push({
|
|
153
|
+
type: "image",
|
|
154
|
+
data: record.data,
|
|
155
|
+
mimeType: record.mimeType,
|
|
156
|
+
});
|
|
157
|
+
continue;
|
|
158
|
+
}
|
|
159
|
+
return undefined;
|
|
160
|
+
}
|
|
161
|
+
return blocks;
|
|
162
|
+
}
|
|
163
|
+
export function formatToolResultForModel(toolCall) {
|
|
164
|
+
const result = toolCall.result;
|
|
165
|
+
if (result === undefined)
|
|
166
|
+
return "Tool completed.";
|
|
167
|
+
if (toolCall.toolName === "ask_user" &&
|
|
168
|
+
result &&
|
|
169
|
+
typeof result === "object") {
|
|
170
|
+
const record = result;
|
|
171
|
+
if (record.dismissed === true) {
|
|
172
|
+
return `User dismissed the question.${typeof record.dismissedReason === "string"
|
|
173
|
+
? `\nReason: ${record.dismissedReason}`
|
|
174
|
+
: ""}`;
|
|
175
|
+
}
|
|
176
|
+
if (typeof record.response === "string") {
|
|
177
|
+
return `User replied:\n${record.response}`;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
if (typeof result === "string")
|
|
181
|
+
return truncate(result, 24_000);
|
|
182
|
+
if (result && typeof result === "object") {
|
|
183
|
+
const record = result;
|
|
184
|
+
const parts = [];
|
|
185
|
+
if (typeof record.content === "string")
|
|
186
|
+
parts.push(record.content);
|
|
187
|
+
if (typeof record.stdout === "string" && record.stdout.length > 0) {
|
|
188
|
+
parts.push(`stdout:\n${record.stdout}`);
|
|
189
|
+
}
|
|
190
|
+
if (typeof record.stderr === "string" && record.stderr.length > 0) {
|
|
191
|
+
parts.push(`stderr:\n${record.stderr}`);
|
|
192
|
+
}
|
|
193
|
+
if (typeof record.exitCode === "number")
|
|
194
|
+
parts.push(`exitCode: ${record.exitCode}`);
|
|
195
|
+
if (Array.isArray(record.entries)) {
|
|
196
|
+
parts.push(`entries:\n${record.entries
|
|
197
|
+
.map((entry) => JSON.stringify(entry))
|
|
198
|
+
.join("\n")}`);
|
|
199
|
+
}
|
|
200
|
+
if (Array.isArray(record.matches)) {
|
|
201
|
+
parts.push(`matches:\n${record.matches
|
|
202
|
+
.map((entry) => JSON.stringify(entry))
|
|
203
|
+
.join("\n")}`);
|
|
204
|
+
}
|
|
205
|
+
if (parts.length > 0)
|
|
206
|
+
return truncate(parts.join("\n\n"), 24_000);
|
|
207
|
+
}
|
|
208
|
+
return truncate(JSON.stringify(result, null, 2), 24_000);
|
|
209
|
+
}
|
|
210
|
+
function truncate(text, maxChars) {
|
|
211
|
+
if (text.length <= maxChars)
|
|
212
|
+
return text;
|
|
213
|
+
return `${text.slice(0, maxChars)}\n\n[...${text.length - maxChars} more characters truncated]`;
|
|
214
|
+
}
|
|
215
|
+
//# sourceMappingURL=agent-tool-adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-tool-adapter.js","sourceRoot":"","sources":["../src/agent-tool-adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { AgentRecord, Mode, PermissionLevel } from "@nerve/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/agents/agent-authority.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAGxE,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 subagent_run 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/agents/agent-authority.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE9C,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,kGAAkG,CACnG,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/agents/agent-budget.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAErE,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/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,4 @@
|
|
|
1
|
+
import type { AgentRecord } from "@nerve/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/agents/agent-status.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAC;AAElE,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/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"}
|
package/dist/auth.d.ts
ADDED
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { OAuthCredentials } from "@earendil-works/pi-ai/oauth";
|
|
2
|
+
import type { AgentRequestAuth, AuthProviderMetadata, ModelInfo, ModelSelection } from "@nervekit/shared";
|
|
3
|
+
import type { SecretProvider } from "./secrets.js";
|
|
4
|
+
export type ApiKeyCredential = {
|
|
5
|
+
type: "api_key";
|
|
6
|
+
key: string;
|
|
7
|
+
};
|
|
8
|
+
export type OAuthCredential = {
|
|
9
|
+
type: "oauth";
|
|
10
|
+
} & OAuthCredentials;
|
|
11
|
+
export type ProviderCredential = ApiKeyCredential | OAuthCredential;
|
|
12
|
+
export declare function providerApiKeySecretName(provider: string): string;
|
|
13
|
+
export declare function providerOAuthSecretName(provider: string): string;
|
|
14
|
+
export declare function providerEnvVarName(provider: string): string;
|
|
15
|
+
export declare function supportsStoredApiKey(provider: string): boolean;
|
|
16
|
+
export declare class AuthManager {
|
|
17
|
+
private readonly secrets;
|
|
18
|
+
private readonly refreshLocks;
|
|
19
|
+
constructor(secrets: SecretProvider);
|
|
20
|
+
getCredential(provider: string): Promise<ProviderCredential | undefined>;
|
|
21
|
+
setApiKey(provider: string, apiKey: string): Promise<void>;
|
|
22
|
+
setOAuth(provider: string, credential: OAuthCredentials): Promise<void>;
|
|
23
|
+
deleteCredential(provider: string): Promise<void>;
|
|
24
|
+
credentialType(provider: string): Promise<ProviderCredential["type"] | undefined>;
|
|
25
|
+
getApiKey(provider: string): Promise<string | undefined>;
|
|
26
|
+
requestAuthForModel(model: ModelSelection | undefined): Promise<AgentRequestAuth | undefined>;
|
|
27
|
+
listProviderMetadata(models: ModelInfo[], customProviderNames?: ReadonlyMap<string, string>): Promise<AuthProviderMetadata[]>;
|
|
28
|
+
private refreshOAuth;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../src/auth.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,gBAAgB,EAEjB,MAAM,6BAA6B,CAAC;AAErC,OAAO,KAAK,EACV,gBAAgB,EAChB,oBAAoB,EACpB,SAAS,EACT,cAAc,EACf,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAEnD,MAAM,MAAM,gBAAgB,GAAG;IAC7B,IAAI,EAAE,SAAS,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,IAAI,EAAE,OAAO,CAAC;CACf,GAAG,gBAAgB,CAAC;AAErB,MAAM,MAAM,kBAAkB,GAAG,gBAAgB,GAAG,eAAe,CAAC;AAKpE,wBAAgB,wBAAwB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAEjE;AAED,wBAAgB,uBAAuB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAEhE;AASD,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAc3D;AAED,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAE9D;AAiBD,qBAAa,WAAW;IAMV,OAAO,CAAC,QAAQ,CAAC,OAAO;IALpC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAGzB;gBAEyB,OAAO,EAAE,cAAc;IAE9C,aAAa,CACjB,QAAQ,EAAE,MAAM,GACf,OAAO,CAAC,kBAAkB,GAAG,SAAS,CAAC;IAUpC,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAK1D,QAAQ,CACZ,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,gBAAgB,GAC3B,OAAO,CAAC,IAAI,CAAC;IASV,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKjD,cAAc,CAClB,QAAQ,EAAE,MAAM,GACf,OAAO,CAAC,kBAAkB,CAAC,MAAM,CAAC,GAAG,SAAS,CAAC;IAI5C,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAoBxD,mBAAmB,CACvB,KAAK,EAAE,cAAc,GAAG,SAAS,GAChC,OAAO,CAAC,gBAAgB,GAAG,SAAS,CAAC;IAMlC,oBAAoB,CACxB,MAAM,EAAE,SAAS,EAAE,EACnB,mBAAmB,CAAC,EAAE,WAAW,CAAC,MAAM,EAAE,MAAM,CAAC,GAChD,OAAO,CAAC,oBAAoB,EAAE,CAAC;YAkDpB,YAAY;CAc3B"}
|
package/dist/auth.js
ADDED
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import { getOAuthApiKey, getOAuthProviders } from "@earendil-works/pi-ai/oauth";
|
|
2
|
+
const ANTHROPIC_OAUTH_WARNING = "Anthropic subscription auth may use paid extra usage outside normal Claude plan limits.";
|
|
3
|
+
export function providerApiKeySecretName(provider) {
|
|
4
|
+
return `provider:${provider}:apiKey`;
|
|
5
|
+
}
|
|
6
|
+
export function providerOAuthSecretName(provider) {
|
|
7
|
+
return `provider:${provider}:oauth`;
|
|
8
|
+
}
|
|
9
|
+
function displayNameForProvider(provider) {
|
|
10
|
+
const known = {
|
|
11
|
+
tavily: "Tavily",
|
|
12
|
+
};
|
|
13
|
+
return known[provider] ?? provider;
|
|
14
|
+
}
|
|
15
|
+
export function providerEnvVarName(provider) {
|
|
16
|
+
const known = {
|
|
17
|
+
anthropic: "ANTHROPIC_API_KEY",
|
|
18
|
+
google: "GOOGLE_API_KEY",
|
|
19
|
+
groq: "GROQ_API_KEY",
|
|
20
|
+
openai: "OPENAI_API_KEY",
|
|
21
|
+
openrouter: "OPENROUTER_API_KEY",
|
|
22
|
+
tavily: "TAVILY_API_KEY",
|
|
23
|
+
xai: "XAI_API_KEY",
|
|
24
|
+
};
|
|
25
|
+
return (known[provider] ??
|
|
26
|
+
`${provider.replaceAll(/[^a-zA-Z0-9]/g, "_").toUpperCase()}_API_KEY`);
|
|
27
|
+
}
|
|
28
|
+
export function supportsStoredApiKey(provider) {
|
|
29
|
+
return provider !== "openai-codex" && provider !== "github-copilot";
|
|
30
|
+
}
|
|
31
|
+
function parseOAuthCredential(value) {
|
|
32
|
+
if (!value)
|
|
33
|
+
return undefined;
|
|
34
|
+
const parsed = JSON.parse(value);
|
|
35
|
+
if (parsed.type !== "oauth")
|
|
36
|
+
return undefined;
|
|
37
|
+
return parsed;
|
|
38
|
+
}
|
|
39
|
+
function oauthProvidersById() {
|
|
40
|
+
return new Map(getOAuthProviders().map((provider) => [provider.id, provider]));
|
|
41
|
+
}
|
|
42
|
+
export class AuthManager {
|
|
43
|
+
secrets;
|
|
44
|
+
refreshLocks = new Map();
|
|
45
|
+
constructor(secrets) {
|
|
46
|
+
this.secrets = secrets;
|
|
47
|
+
}
|
|
48
|
+
async getCredential(provider) {
|
|
49
|
+
const oauth = parseOAuthCredential(await this.secrets.get(providerOAuthSecretName(provider)));
|
|
50
|
+
if (oauth)
|
|
51
|
+
return oauth;
|
|
52
|
+
const key = await this.secrets.get(providerApiKeySecretName(provider));
|
|
53
|
+
return key ? { type: "api_key", key } : undefined;
|
|
54
|
+
}
|
|
55
|
+
async setApiKey(provider, apiKey) {
|
|
56
|
+
await this.secrets.set(providerApiKeySecretName(provider), apiKey);
|
|
57
|
+
await this.secrets.delete(providerOAuthSecretName(provider));
|
|
58
|
+
}
|
|
59
|
+
async setOAuth(provider, credential) {
|
|
60
|
+
const stored = { type: "oauth", ...credential };
|
|
61
|
+
await this.secrets.set(providerOAuthSecretName(provider), JSON.stringify(stored));
|
|
62
|
+
await this.secrets.delete(providerApiKeySecretName(provider));
|
|
63
|
+
}
|
|
64
|
+
async deleteCredential(provider) {
|
|
65
|
+
await this.secrets.delete(providerApiKeySecretName(provider));
|
|
66
|
+
await this.secrets.delete(providerOAuthSecretName(provider));
|
|
67
|
+
}
|
|
68
|
+
async credentialType(provider) {
|
|
69
|
+
return (await this.getCredential(provider))?.type;
|
|
70
|
+
}
|
|
71
|
+
async getApiKey(provider) {
|
|
72
|
+
const credential = await this.getCredential(provider);
|
|
73
|
+
if (!credential)
|
|
74
|
+
return undefined;
|
|
75
|
+
if (credential.type === "api_key")
|
|
76
|
+
return credential.key;
|
|
77
|
+
const oauthProvider = oauthProvidersById().get(provider);
|
|
78
|
+
if (!oauthProvider)
|
|
79
|
+
return undefined;
|
|
80
|
+
if (Date.now() < credential.expires)
|
|
81
|
+
return oauthProvider.getApiKey(credential);
|
|
82
|
+
const existing = this.refreshLocks.get(provider);
|
|
83
|
+
if (existing)
|
|
84
|
+
return existing;
|
|
85
|
+
const refresh = this.refreshOAuth(provider).finally(() => {
|
|
86
|
+
this.refreshLocks.delete(provider);
|
|
87
|
+
});
|
|
88
|
+
this.refreshLocks.set(provider, refresh);
|
|
89
|
+
return refresh;
|
|
90
|
+
}
|
|
91
|
+
async requestAuthForModel(model) {
|
|
92
|
+
if (!model || model.provider === "nerve-faux")
|
|
93
|
+
return undefined;
|
|
94
|
+
const apiKey = await this.getApiKey(model.provider);
|
|
95
|
+
return apiKey ? { apiKey } : undefined;
|
|
96
|
+
}
|
|
97
|
+
async listProviderMetadata(models, customProviderNames) {
|
|
98
|
+
const oauthProviders = oauthProvidersById();
|
|
99
|
+
const providers = new Set();
|
|
100
|
+
for (const model of models) {
|
|
101
|
+
if (model.provider !== "nerve-faux")
|
|
102
|
+
providers.add(model.provider);
|
|
103
|
+
}
|
|
104
|
+
providers.add("tavily");
|
|
105
|
+
for (const provider of oauthProviders.keys()) {
|
|
106
|
+
if (provider === "openai-codex" || provider === "anthropic") {
|
|
107
|
+
providers.add(provider);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
for (const name of await this.secrets.list()) {
|
|
111
|
+
const apiKeyMatch = /^provider:(.+):apiKey$/.exec(name);
|
|
112
|
+
const oauthMatch = /^provider:(.+):oauth$/.exec(name);
|
|
113
|
+
if (apiKeyMatch)
|
|
114
|
+
providers.add(apiKeyMatch[1]);
|
|
115
|
+
if (oauthMatch)
|
|
116
|
+
providers.add(oauthMatch[1]);
|
|
117
|
+
}
|
|
118
|
+
const items = await Promise.all([...providers].sort().map(async (provider) => {
|
|
119
|
+
const oauthProvider = oauthProviders.get(provider);
|
|
120
|
+
const credential = await this.getCredential(provider);
|
|
121
|
+
return {
|
|
122
|
+
provider,
|
|
123
|
+
displayName: oauthProvider?.name ??
|
|
124
|
+
customProviderNames?.get(provider) ??
|
|
125
|
+
displayNameForProvider(provider),
|
|
126
|
+
supportsApiKey: supportsStoredApiKey(provider),
|
|
127
|
+
supportsOAuth: provider === "openai-codex" || provider === "anthropic",
|
|
128
|
+
oauthName: oauthProvider?.name,
|
|
129
|
+
configured: Boolean(credential),
|
|
130
|
+
credentialType: credential?.type,
|
|
131
|
+
envVar: supportsStoredApiKey(provider) && provider !== "tavily"
|
|
132
|
+
? providerEnvVarName(provider)
|
|
133
|
+
: undefined,
|
|
134
|
+
warning: provider === "anthropic" && credential?.type === "oauth"
|
|
135
|
+
? ANTHROPIC_OAUTH_WARNING
|
|
136
|
+
: undefined,
|
|
137
|
+
};
|
|
138
|
+
}));
|
|
139
|
+
return items.filter((item) => item.supportsApiKey || item.supportsOAuth);
|
|
140
|
+
}
|
|
141
|
+
async refreshOAuth(provider) {
|
|
142
|
+
const oauthCredentials = {};
|
|
143
|
+
for (const name of await this.secrets.list()) {
|
|
144
|
+
const match = /^provider:(.+):oauth$/.exec(name);
|
|
145
|
+
if (!match)
|
|
146
|
+
continue;
|
|
147
|
+
const credential = parseOAuthCredential(await this.secrets.get(name));
|
|
148
|
+
if (credential)
|
|
149
|
+
oauthCredentials[match[1]] = credential;
|
|
150
|
+
}
|
|
151
|
+
const result = await getOAuthApiKey(provider, oauthCredentials);
|
|
152
|
+
if (!result)
|
|
153
|
+
return undefined;
|
|
154
|
+
await this.setOAuth(provider, result.newCredentials);
|
|
155
|
+
return result.apiKey;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
//# sourceMappingURL=auth.js.map
|