pulseed 0.6.1 → 0.6.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/adapters/agents/claude-api.d.ts +2 -2
- package/dist/adapters/agents/claude-api.d.ts.map +1 -1
- package/dist/adapters/agents/claude-api.js +3 -2
- package/dist/adapters/agents/claude-api.js.map +1 -1
- package/dist/adapters/agents/openai-codex.d.ts +3 -0
- package/dist/adapters/agents/openai-codex.d.ts.map +1 -1
- package/dist/adapters/agents/openai-codex.js +5 -0
- package/dist/adapters/agents/openai-codex.js.map +1 -1
- package/dist/adapters/datasources/artifact-metric-datasource.d.ts +3 -0
- package/dist/adapters/datasources/artifact-metric-datasource.d.ts.map +1 -1
- package/dist/adapters/datasources/artifact-metric-datasource.js +20 -1
- package/dist/adapters/datasources/artifact-metric-datasource.js.map +1 -1
- package/dist/adapters/types/a2a.d.ts +24 -24
- package/dist/base/config/global-config.d.ts +4 -4
- package/dist/base/llm/codex-llm-client.d.ts +3 -0
- package/dist/base/llm/codex-llm-client.d.ts.map +1 -1
- package/dist/base/llm/codex-llm-client.js +71 -7
- package/dist/base/llm/codex-llm-client.js.map +1 -1
- package/dist/base/llm/llm-client.d.ts +2 -0
- package/dist/base/llm/llm-client.d.ts.map +1 -1
- package/dist/base/llm/llm-client.js +2 -2
- package/dist/base/llm/llm-client.js.map +1 -1
- package/dist/base/llm/ollama-client.d.ts.map +1 -1
- package/dist/base/llm/ollama-client.js +12 -0
- package/dist/base/llm/ollama-client.js.map +1 -1
- package/dist/base/llm/openai-client.d.ts +4 -0
- package/dist/base/llm/openai-client.d.ts.map +1 -1
- package/dist/base/llm/openai-client.js +29 -15
- package/dist/base/llm/openai-client.js.map +1 -1
- package/dist/base/llm/provider-config.d.ts +12 -2
- package/dist/base/llm/provider-config.d.ts.map +1 -1
- package/dist/base/llm/provider-config.js +46 -5
- package/dist/base/llm/provider-config.js.map +1 -1
- package/dist/base/llm/provider-factory.d.ts +1 -1
- package/dist/base/llm/provider-factory.d.ts.map +1 -1
- package/dist/base/llm/provider-factory.js +7 -2
- package/dist/base/llm/provider-factory.js.map +1 -1
- package/dist/base/state/state-manager-goal-write.d.ts +1 -1
- package/dist/base/state/state-manager-goal-write.d.ts.map +1 -1
- package/dist/base/state/state-manager.d.ts +2 -6
- package/dist/base/state/state-manager.d.ts.map +1 -1
- package/dist/base/state/state-manager.js.map +1 -1
- package/dist/base/state/state-write-fence.d.ts +7 -0
- package/dist/base/state/state-write-fence.d.ts.map +1 -0
- package/dist/base/state/state-write-fence.js +2 -0
- package/dist/base/state/state-write-fence.js.map +1 -0
- package/dist/base/types/companion.d.ts +2 -0
- package/dist/base/types/companion.d.ts.map +1 -0
- package/dist/base/types/companion.js +2 -0
- package/dist/base/types/companion.js.map +1 -0
- package/dist/base/types/core.d.ts +1 -1
- package/dist/base/types/core.d.ts.map +1 -1
- package/dist/base/types/core.js +1 -0
- package/dist/base/types/core.js.map +1 -1
- package/dist/base/types/index.d.ts +1 -0
- package/dist/base/types/index.d.ts.map +1 -1
- package/dist/base/types/index.js +1 -0
- package/dist/base/types/index.js.map +1 -1
- package/dist/base/utils/execFileNoThrow.d.ts +4 -0
- package/dist/base/utils/execFileNoThrow.d.ts.map +1 -1
- package/dist/base/utils/execFileNoThrow.js +81 -2
- package/dist/base/utils/execFileNoThrow.js.map +1 -1
- package/dist/index.d.ts +4 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -1
- package/dist/index.js.map +1 -1
- package/dist/interface/chat/chat-event-state.d.ts +2 -0
- package/dist/interface/chat/chat-event-state.d.ts.map +1 -1
- package/dist/interface/chat/chat-event-state.js +28 -11
- package/dist/interface/chat/chat-event-state.js.map +1 -1
- package/dist/interface/chat/chat-events.d.ts +9 -1
- package/dist/interface/chat/chat-events.d.ts.map +1 -1
- package/dist/interface/chat/chat-history.d.ts +4739 -1
- package/dist/interface/chat/chat-history.d.ts.map +1 -1
- package/dist/interface/chat/chat-history.js +40 -2
- package/dist/interface/chat/chat-history.js.map +1 -1
- package/dist/interface/chat/chat-runner-command-helpers.d.ts +1 -0
- package/dist/interface/chat/chat-runner-command-helpers.d.ts.map +1 -1
- package/dist/interface/chat/chat-runner-command-helpers.js +1 -0
- package/dist/interface/chat/chat-runner-command-helpers.js.map +1 -1
- package/dist/interface/chat/chat-runner-commands.d.ts +4 -32
- package/dist/interface/chat/chat-runner-commands.d.ts.map +1 -1
- package/dist/interface/chat/chat-runner-commands.js +156 -7
- package/dist/interface/chat/chat-runner-commands.js.map +1 -1
- package/dist/interface/chat/chat-runner-contracts.d.ts +153 -0
- package/dist/interface/chat/chat-runner-contracts.d.ts.map +1 -0
- package/dist/interface/chat/chat-runner-contracts.js +2 -0
- package/dist/interface/chat/chat-runner-contracts.js.map +1 -0
- package/dist/interface/chat/chat-runner-event-bridge.d.ts +8 -2
- package/dist/interface/chat/chat-runner-event-bridge.d.ts.map +1 -1
- package/dist/interface/chat/chat-runner-event-bridge.js +76 -11
- package/dist/interface/chat/chat-runner-event-bridge.js.map +1 -1
- package/dist/interface/chat/chat-runner-routes.d.ts +66 -12
- package/dist/interface/chat/chat-runner-routes.d.ts.map +1 -1
- package/dist/interface/chat/chat-runner-routes.js +322 -30
- package/dist/interface/chat/chat-runner-routes.js.map +1 -1
- package/dist/interface/chat/chat-runner-runtime.d.ts +1 -1
- package/dist/interface/chat/chat-runner-runtime.d.ts.map +1 -1
- package/dist/interface/chat/chat-runner-runtime.js +4 -0
- package/dist/interface/chat/chat-runner-runtime.js.map +1 -1
- package/dist/interface/chat/chat-runner.d.ts +11 -71
- package/dist/interface/chat/chat-runner.d.ts.map +1 -1
- package/dist/interface/chat/chat-runner.js +440 -58
- package/dist/interface/chat/chat-runner.js.map +1 -1
- package/dist/interface/chat/chat-session-store.d.ts +2 -0
- package/dist/interface/chat/chat-session-store.d.ts.map +1 -1
- package/dist/interface/chat/chat-session-store.js +3 -6
- package/dist/interface/chat/chat-session-store.js.map +1 -1
- package/dist/interface/chat/chat-state-service.d.ts +1 -0
- package/dist/interface/chat/chat-state-service.d.ts.map +1 -1
- package/dist/interface/chat/chat-state-service.js +1 -0
- package/dist/interface/chat/chat-state-service.js.map +1 -1
- package/dist/interface/chat/cross-platform-session-global.d.ts +2 -1
- package/dist/interface/chat/cross-platform-session-global.d.ts.map +1 -1
- package/dist/interface/chat/cross-platform-session-global.js +4 -10
- package/dist/interface/chat/cross-platform-session-global.js.map +1 -1
- package/dist/interface/chat/cross-platform-session.d.ts +30 -1
- package/dist/interface/chat/cross-platform-session.d.ts.map +1 -1
- package/dist/interface/chat/cross-platform-session.js +413 -52
- package/dist/interface/chat/cross-platform-session.js.map +1 -1
- package/dist/interface/chat/event-subscriber.js +2 -2
- package/dist/interface/chat/event-subscriber.js.map +1 -1
- package/dist/interface/chat/failure-recovery.js +1 -1
- package/dist/interface/chat/failure-recovery.js.map +1 -1
- package/dist/interface/chat/freeform-route-classifier.d.ts +5 -5
- package/dist/interface/chat/freeform-route-classifier.js +3 -2
- package/dist/interface/chat/freeform-route-classifier.js.map +1 -1
- package/dist/interface/chat/gateway-setup-status.d.ts +33 -0
- package/dist/interface/chat/gateway-setup-status.d.ts.map +1 -0
- package/dist/interface/chat/gateway-setup-status.js +44 -0
- package/dist/interface/chat/gateway-setup-status.js.map +1 -0
- package/dist/interface/chat/ingress-router.d.ts +22 -0
- package/dist/interface/chat/ingress-router.d.ts.map +1 -1
- package/dist/interface/chat/ingress-router.js +148 -11
- package/dist/interface/chat/ingress-router.js.map +1 -1
- package/dist/interface/chat/operation-progress.d.ts +17 -0
- package/dist/interface/chat/operation-progress.d.ts.map +1 -0
- package/dist/interface/chat/operation-progress.js +29 -0
- package/dist/interface/chat/operation-progress.js.map +1 -0
- package/dist/interface/chat/setup-config-write.d.ts +27 -0
- package/dist/interface/chat/setup-config-write.d.ts.map +1 -0
- package/dist/interface/chat/setup-config-write.js +79 -0
- package/dist/interface/chat/setup-config-write.js.map +1 -0
- package/dist/interface/chat/setup-dialogue.d.ts +199 -0
- package/dist/interface/chat/setup-dialogue.d.ts.map +1 -0
- package/dist/interface/chat/setup-dialogue.js +97 -0
- package/dist/interface/chat/setup-dialogue.js.map +1 -0
- package/dist/interface/chat/setup-secret-intake.d.ts +68 -0
- package/dist/interface/chat/setup-secret-intake.d.ts.map +1 -0
- package/dist/interface/chat/setup-secret-intake.js +84 -0
- package/dist/interface/chat/setup-secret-intake.js.map +1 -0
- package/dist/interface/chat/turn-language.d.ts +23 -0
- package/dist/interface/chat/turn-language.d.ts.map +1 -0
- package/dist/interface/chat/turn-language.js +46 -0
- package/dist/interface/chat/turn-language.js.map +1 -0
- package/dist/interface/cli/cli-command-registry.d.ts +1 -1
- package/dist/interface/cli/cli-command-registry.d.ts.map +1 -1
- package/dist/interface/cli/cli-runner.js +1 -1
- package/dist/interface/cli/cli-runner.js.map +1 -1
- package/dist/interface/cli/commands/config.d.ts.map +1 -1
- package/dist/interface/cli/commands/config.js +12 -1
- package/dist/interface/cli/commands/config.js.map +1 -1
- package/dist/interface/cli/commands/daemon.d.ts.map +1 -1
- package/dist/interface/cli/commands/daemon.js +62 -1
- package/dist/interface/cli/commands/daemon.js.map +1 -1
- package/dist/interface/cli/commands/doctor.d.ts +1 -0
- package/dist/interface/cli/commands/doctor.d.ts.map +1 -1
- package/dist/interface/cli/commands/doctor.js +69 -0
- package/dist/interface/cli/commands/doctor.js.map +1 -1
- package/dist/interface/cli/commands/goal-dispatch.d.ts.map +1 -1
- package/dist/interface/cli/commands/goal-dispatch.js +9 -1
- package/dist/interface/cli/commands/goal-dispatch.js.map +1 -1
- package/dist/interface/cli/commands/goal-raw.d.ts +1 -0
- package/dist/interface/cli/commands/goal-raw.d.ts.map +1 -1
- package/dist/interface/cli/commands/goal-raw.js +34 -2
- package/dist/interface/cli/commands/goal-raw.js.map +1 -1
- package/dist/interface/cli/commands/operator-binding-status.d.ts +59 -0
- package/dist/interface/cli/commands/operator-binding-status.d.ts.map +1 -0
- package/dist/interface/cli/commands/operator-binding-status.js +257 -0
- package/dist/interface/cli/commands/operator-binding-status.js.map +1 -0
- package/dist/interface/cli/commands/run.d.ts +2 -2
- package/dist/interface/cli/commands/run.d.ts.map +1 -1
- package/dist/interface/cli/commands/run.js.map +1 -1
- package/dist/interface/cli/commands/runtime.d.ts.map +1 -1
- package/dist/interface/cli/commands/runtime.js +8 -1
- package/dist/interface/cli/commands/runtime.js.map +1 -1
- package/dist/interface/cli/commands/setup/import/flow.d.ts.map +1 -1
- package/dist/interface/cli/commands/setup/import/flow.js +2 -0
- package/dist/interface/cli/commands/setup/import/flow.js.map +1 -1
- package/dist/interface/cli/commands/setup/import/provider.d.ts.map +1 -1
- package/dist/interface/cli/commands/setup/import/provider.js +5 -1
- package/dist/interface/cli/commands/setup/import/provider.js.map +1 -1
- package/dist/interface/cli/commands/setup/import/types.d.ts +1 -0
- package/dist/interface/cli/commands/setup/import/types.d.ts.map +1 -1
- package/dist/interface/cli/commands/setup/steps-gateway.js +14 -3
- package/dist/interface/cli/commands/setup/steps-gateway.js.map +1 -1
- package/dist/interface/cli/commands/setup-shared.d.ts +2 -0
- package/dist/interface/cli/commands/setup-shared.d.ts.map +1 -1
- package/dist/interface/cli/commands/setup-shared.js +4 -1
- package/dist/interface/cli/commands/setup-shared.js.map +1 -1
- package/dist/interface/cli/commands/setup-wizard.d.ts +33 -0
- package/dist/interface/cli/commands/setup-wizard.d.ts.map +1 -1
- package/dist/interface/cli/commands/setup-wizard.js +124 -4
- package/dist/interface/cli/commands/setup-wizard.js.map +1 -1
- package/dist/interface/cli/commands/setup.d.ts.map +1 -1
- package/dist/interface/cli/commands/setup.js +13 -1
- package/dist/interface/cli/commands/setup.js.map +1 -1
- package/dist/interface/cli/commands/telegram.d.ts.map +1 -1
- package/dist/interface/cli/commands/telegram.js +27 -3
- package/dist/interface/cli/commands/telegram.js.map +1 -1
- package/dist/interface/cli/setup.d.ts +3 -3
- package/dist/interface/cli/setup.d.ts.map +1 -1
- package/dist/interface/cli/setup.js +3 -2
- package/dist/interface/cli/setup.js.map +1 -1
- package/dist/interface/cli/utils/loop-runner.d.ts +1 -1
- package/dist/interface/cli/utils/loop-runner.d.ts.map +1 -1
- package/dist/interface/cli/utils.js +1 -1
- package/dist/interface/tui/actions.d.ts.map +1 -1
- package/dist/interface/tui/actions.js +14 -6
- package/dist/interface/tui/actions.js.map +1 -1
- package/dist/interface/tui/app.d.ts +1 -7
- package/dist/interface/tui/app.d.ts.map +1 -1
- package/dist/interface/tui/app.js +71 -120
- package/dist/interface/tui/app.js.map +1 -1
- package/dist/interface/tui/chat/suggestions.js +1 -1
- package/dist/interface/tui/chat/suggestions.js.map +1 -1
- package/dist/interface/tui/chat-surface.d.ts +1 -0
- package/dist/interface/tui/chat-surface.d.ts.map +1 -1
- package/dist/interface/tui/chat-surface.js +15 -0
- package/dist/interface/tui/chat-surface.js.map +1 -1
- package/dist/interface/tui/entry-approval.js +2 -2
- package/dist/interface/tui/entry-approval.js.map +1 -1
- package/dist/interface/tui/entry-deps.d.ts +1 -1
- package/dist/interface/tui/entry-deps.d.ts.map +1 -1
- package/dist/interface/tui/entry-deps.js +54 -8
- package/dist/interface/tui/entry-deps.js.map +1 -1
- package/dist/interface/tui/input-action.d.ts +49 -0
- package/dist/interface/tui/input-action.d.ts.map +1 -0
- package/dist/interface/tui/input-action.js +46 -0
- package/dist/interface/tui/input-action.js.map +1 -0
- package/dist/interface/tui/markdown-renderer.d.ts.map +1 -1
- package/dist/interface/tui/markdown-renderer.js +4 -1
- package/dist/interface/tui/markdown-renderer.js.map +1 -1
- package/dist/interface/tui/use-loop.d.ts +1 -1
- package/dist/interface/tui/use-loop.d.ts.map +1 -1
- package/dist/orchestrator/execution/adapter-layer.d.ts +1 -1
- package/dist/orchestrator/execution/adapter-layer.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-context-assembler.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-context-assembler.js +12 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-context-assembler.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.d.ts +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.js +18 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-default-profile.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-events.d.ts +3 -0
- package/dist/orchestrator/execution/agent-loop/agent-loop-events.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-events.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-model-client.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-model-client.js +1 -0
- package/dist/orchestrator/execution/agent-loop/agent-loop-model-client.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-model.d.ts +2 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-model.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-model.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-result.d.ts +17 -0
- package/dist/orchestrator/execution/agent-loop/agent-loop-result.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-tool-output.d.ts +3 -0
- package/dist/orchestrator/execution/agent-loop/agent-loop-tool-output.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.d.ts +1 -0
- package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.js +20 -3
- package/dist/orchestrator/execution/agent-loop/agent-loop-tool-runtime.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-trace-store.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-loop-trace-store.js +5 -3
- package/dist/orchestrator/execution/agent-loop/agent-loop-trace-store.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-timeline.d.ts +3 -1
- package/dist/orchestrator/execution/agent-loop/agent-timeline.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/agent-timeline.js +8 -20
- package/dist/orchestrator/execution/agent-loop/agent-timeline.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/anthropic-messages-agent-loop-model-client.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/anthropic-messages-agent-loop-model-client.js +5 -2
- package/dist/orchestrator/execution/agent-loop/anthropic-messages-agent-loop-model-client.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/bounded-agent-loop-runner.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/bounded-agent-loop-runner.js +43 -25
- package/dist/orchestrator/execution/agent-loop/bounded-agent-loop-runner.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/chat-agent-loop-runner.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/chat-agent-loop-runner.js +20 -4
- package/dist/orchestrator/execution/agent-loop/chat-agent-loop-runner.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.d.ts +1 -51
- package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.js +3 -239
- package/dist/orchestrator/execution/agent-loop/core-loop-control-tools.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.d.ts +60 -0
- package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.d.ts.map +1 -0
- package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.js +244 -0
- package/dist/orchestrator/execution/agent-loop/durable-loop-control-tools.js.map +1 -0
- package/dist/orchestrator/execution/agent-loop/index.d.ts +1 -1
- package/dist/orchestrator/execution/agent-loop/index.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/index.js +1 -1
- package/dist/orchestrator/execution/agent-loop/index.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/openai-responses-agent-loop-model-client.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/openai-responses-agent-loop-model-client.js +5 -2
- package/dist/orchestrator/execution/agent-loop/openai-responses-agent-loop-model-client.js.map +1 -1
- package/dist/orchestrator/execution/agent-loop/task-agent-loop-result.d.ts.map +1 -1
- package/dist/orchestrator/execution/agent-loop/task-agent-loop-result.js +2 -1
- package/dist/orchestrator/execution/agent-loop/task-agent-loop-result.js.map +1 -1
- package/dist/orchestrator/execution/task/task-generation.d.ts +50 -2
- package/dist/orchestrator/execution/task/task-generation.d.ts.map +1 -1
- package/dist/orchestrator/execution/task/task-generation.js +19 -1
- package/dist/orchestrator/execution/task/task-generation.js.map +1 -1
- package/dist/orchestrator/execution/task/task-lifecycle-runner.d.ts +2 -1
- package/dist/orchestrator/execution/task/task-lifecycle-runner.d.ts.map +1 -1
- package/dist/orchestrator/execution/task/task-lifecycle-runner.js +1 -1
- package/dist/orchestrator/execution/task/task-lifecycle-runner.js.map +1 -1
- package/dist/orchestrator/execution/task/task-lifecycle.d.ts +2 -1
- package/dist/orchestrator/execution/task/task-lifecycle.d.ts.map +1 -1
- package/dist/orchestrator/execution/task/task-lifecycle.js +20 -14
- package/dist/orchestrator/execution/task/task-lifecycle.js.map +1 -1
- package/dist/orchestrator/execution/task/task-prompt-builder.d.ts.map +1 -1
- package/dist/orchestrator/execution/task/task-prompt-builder.js +9 -0
- package/dist/orchestrator/execution/task/task-prompt-builder.js.map +1 -1
- package/dist/orchestrator/execution/task/task-verifier-rules.d.ts +3 -1
- package/dist/orchestrator/execution/task/task-verifier-rules.d.ts.map +1 -1
- package/dist/orchestrator/execution/task/task-verifier-rules.js +37 -33
- package/dist/orchestrator/execution/task/task-verifier-rules.js.map +1 -1
- package/dist/orchestrator/execution/task/task-verifier.d.ts.map +1 -1
- package/dist/orchestrator/execution/task/task-verifier.js +10 -2
- package/dist/orchestrator/execution/task/task-verifier.js.map +1 -1
- package/dist/orchestrator/execution/task/task-workspace.d.ts +8 -0
- package/dist/orchestrator/execution/task/task-workspace.d.ts.map +1 -0
- package/dist/orchestrator/execution/task/task-workspace.js +22 -0
- package/dist/orchestrator/execution/task/task-workspace.js.map +1 -0
- package/dist/orchestrator/execution/types/task-group.d.ts +73 -9
- package/dist/orchestrator/execution/types/task-group.d.ts.map +1 -1
- package/dist/orchestrator/execution/types/task.d.ts +103 -5
- package/dist/orchestrator/execution/types/task.d.ts.map +1 -1
- package/dist/orchestrator/execution/types/task.js +10 -0
- package/dist/orchestrator/execution/types/task.js.map +1 -1
- package/dist/orchestrator/goal/goal-decomposer.d.ts.map +1 -1
- package/dist/orchestrator/goal/goal-decomposer.js +2 -1
- package/dist/orchestrator/goal/goal-decomposer.js.map +1 -1
- package/dist/orchestrator/goal/goal-negotiator.d.ts.map +1 -1
- package/dist/orchestrator/goal/goal-negotiator.js +5 -2
- package/dist/orchestrator/goal/goal-negotiator.js.map +1 -1
- package/dist/orchestrator/goal/goal-suggest.d.ts +6 -6
- package/dist/orchestrator/goal/goal-validation.d.ts +4 -5
- package/dist/orchestrator/goal/goal-validation.d.ts.map +1 -1
- package/dist/orchestrator/goal/goal-validation.js +11 -17
- package/dist/orchestrator/goal/goal-validation.js.map +1 -1
- package/dist/orchestrator/goal/negotiator-prompts.d.ts.map +1 -1
- package/dist/orchestrator/goal/negotiator-prompts.js +8 -4
- package/dist/orchestrator/goal/negotiator-prompts.js.map +1 -1
- package/dist/orchestrator/goal/negotiator-steps.d.ts.map +1 -1
- package/dist/orchestrator/goal/negotiator-steps.js +7 -11
- package/dist/orchestrator/goal/negotiator-steps.js.map +1 -1
- package/dist/orchestrator/goal/types/goal-refiner.d.ts +6 -6
- package/dist/orchestrator/goal/types/goal.d.ts +167 -6
- package/dist/orchestrator/goal/types/goal.d.ts.map +1 -1
- package/dist/orchestrator/goal/types/goal.js +8 -0
- package/dist/orchestrator/goal/types/goal.js.map +1 -1
- package/dist/orchestrator/goal/types/negotiation.d.ts +120 -6
- package/dist/orchestrator/goal/types/negotiation.d.ts.map +1 -1
- package/dist/orchestrator/goal/types/negotiation.js +3 -0
- package/dist/orchestrator/goal/types/negotiation.js.map +1 -1
- package/dist/orchestrator/goal/types/suggest.d.ts +6 -6
- package/dist/orchestrator/loop/checkpoint-manager-loop.d.ts +1 -1
- package/dist/orchestrator/loop/checkpoint-manager-loop.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/capability.d.ts +1 -21
- package/dist/orchestrator/loop/core-loop/capability.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/capability.js +1 -150
- package/dist/orchestrator/loop/core-loop/capability.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/contracts.d.ts +1 -318
- package/dist/orchestrator/loop/core-loop/contracts.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/contracts.js +1 -39
- package/dist/orchestrator/loop/core-loop/contracts.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/control.d.ts +1 -26
- package/dist/orchestrator/loop/core-loop/control.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/control.js +1 -71
- package/dist/orchestrator/loop/core-loop/control.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/decision-engine.d.ts +1 -78
- package/dist/orchestrator/loop/core-loop/decision-engine.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/decision-engine.js +1 -144
- package/dist/orchestrator/loop/core-loop/decision-engine.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.d.ts +1 -47
- package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.js +1 -385
- package/dist/orchestrator/loop/core-loop/dream-review-checkpoint.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/evidence-ledger.d.ts +1 -21
- package/dist/orchestrator/loop/core-loop/evidence-ledger.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/evidence-ledger.js +1 -35
- package/dist/orchestrator/loop/core-loop/evidence-ledger.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.d.ts +1 -6
- package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.js +1 -42
- package/dist/orchestrator/loop/core-loop/iteration-kernel-knowledge.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.d.ts +1 -13
- package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.js +1 -40
- package/dist/orchestrator/loop/core-loop/iteration-kernel-wait.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/iteration-kernel.d.ts +1 -36
- package/dist/orchestrator/loop/core-loop/iteration-kernel.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/iteration-kernel.js +1 -834
- package/dist/orchestrator/loop/core-loop/iteration-kernel.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/learning.d.ts +1 -30
- package/dist/orchestrator/loop/core-loop/learning.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/learning.js +1 -91
- package/dist/orchestrator/loop/core-loop/learning.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/phase-policy.d.ts +1 -19
- package/dist/orchestrator/loop/core-loop/phase-policy.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/phase-policy.js +1 -157
- package/dist/orchestrator/loop/core-loop/phase-policy.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/phase-runtime.d.ts +1 -30
- package/dist/orchestrator/loop/core-loop/phase-runtime.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/phase-runtime.js +1 -102
- package/dist/orchestrator/loop/core-loop/phase-runtime.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/phase-specs.d.ts +1 -1268
- package/dist/orchestrator/loop/core-loop/phase-specs.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/phase-specs.js +1 -348
- package/dist/orchestrator/loop/core-loop/phase-specs.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/preparation.d.ts +1 -58
- package/dist/orchestrator/loop/core-loop/preparation.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/preparation.js +1 -367
- package/dist/orchestrator/loop/core-loop/preparation.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/public-research.d.ts +1 -31
- package/dist/orchestrator/loop/core-loop/public-research.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/public-research.js +1 -111
- package/dist/orchestrator/loop/core-loop/public-research.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/task-cycle-stall.d.ts +1 -8
- package/dist/orchestrator/loop/core-loop/task-cycle-stall.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/task-cycle-stall.js +1 -432
- package/dist/orchestrator/loop/core-loop/task-cycle-stall.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/task-cycle-wait.d.ts +1 -10
- package/dist/orchestrator/loop/core-loop/task-cycle-wait.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/task-cycle-wait.js +1 -175
- package/dist/orchestrator/loop/core-loop/task-cycle-wait.js.map +1 -1
- package/dist/orchestrator/loop/core-loop/task-cycle.d.ts +1 -40
- package/dist/orchestrator/loop/core-loop/task-cycle.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop/task-cycle.js +1 -429
- package/dist/orchestrator/loop/core-loop/task-cycle.js.map +1 -1
- package/dist/orchestrator/loop/core-loop.d.ts +1 -85
- package/dist/orchestrator/loop/core-loop.d.ts.map +1 -1
- package/dist/orchestrator/loop/core-loop.js +3 -625
- package/dist/orchestrator/loop/core-loop.js.map +1 -1
- package/dist/orchestrator/loop/durable-loop/capability.d.ts +22 -0
- package/dist/orchestrator/loop/durable-loop/capability.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/capability.js +151 -0
- package/dist/orchestrator/loop/durable-loop/capability.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/contracts.d.ts +319 -0
- package/dist/orchestrator/loop/durable-loop/contracts.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/contracts.js +40 -0
- package/dist/orchestrator/loop/durable-loop/contracts.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/control.d.ts +27 -0
- package/dist/orchestrator/loop/durable-loop/control.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/control.js +72 -0
- package/dist/orchestrator/loop/durable-loop/control.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/decision-engine.d.ts +79 -0
- package/dist/orchestrator/loop/durable-loop/decision-engine.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/decision-engine.js +145 -0
- package/dist/orchestrator/loop/durable-loop/decision-engine.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.d.ts +48 -0
- package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.js +386 -0
- package/dist/orchestrator/loop/durable-loop/dream-review-checkpoint.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/evidence-ledger.d.ts +22 -0
- package/dist/orchestrator/loop/durable-loop/evidence-ledger.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/evidence-ledger.js +36 -0
- package/dist/orchestrator/loop/durable-loop/evidence-ledger.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.d.ts +7 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.js +43 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel-knowledge.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.d.ts +14 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.js +41 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel-wait.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel.d.ts +38 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel.js +835 -0
- package/dist/orchestrator/loop/durable-loop/iteration-kernel.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/learning.d.ts +31 -0
- package/dist/orchestrator/loop/durable-loop/learning.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/learning.js +92 -0
- package/dist/orchestrator/loop/durable-loop/learning.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/phase-policy.d.ts +20 -0
- package/dist/orchestrator/loop/durable-loop/phase-policy.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/phase-policy.js +158 -0
- package/dist/orchestrator/loop/durable-loop/phase-policy.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/phase-runtime.d.ts +31 -0
- package/dist/orchestrator/loop/durable-loop/phase-runtime.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/phase-runtime.js +103 -0
- package/dist/orchestrator/loop/durable-loop/phase-runtime.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/phase-specs.d.ts +1269 -0
- package/dist/orchestrator/loop/durable-loop/phase-specs.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/phase-specs.js +349 -0
- package/dist/orchestrator/loop/durable-loop/phase-specs.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/preparation.d.ts +59 -0
- package/dist/orchestrator/loop/durable-loop/preparation.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/preparation.js +368 -0
- package/dist/orchestrator/loop/durable-loop/preparation.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/public-research.d.ts +32 -0
- package/dist/orchestrator/loop/durable-loop/public-research.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/public-research.js +112 -0
- package/dist/orchestrator/loop/durable-loop/public-research.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle-stall.d.ts +9 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle-stall.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle-stall.js +464 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle-stall.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle-wait.d.ts +11 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle-wait.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle-wait.js +176 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle-wait.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle.d.ts +42 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle.js +430 -0
- package/dist/orchestrator/loop/durable-loop/task-cycle.js.map +1 -0
- package/dist/orchestrator/loop/durable-loop.d.ts +93 -0
- package/dist/orchestrator/loop/durable-loop.d.ts.map +1 -0
- package/dist/orchestrator/loop/durable-loop.js +651 -0
- package/dist/orchestrator/loop/durable-loop.js.map +1 -0
- package/dist/orchestrator/loop/loop-report-helper.d.ts +1 -1
- package/dist/orchestrator/loop/loop-report-helper.d.ts.map +1 -1
- package/dist/orchestrator/loop/loop-result-types.d.ts +1 -1
- package/dist/orchestrator/loop/loop-result-types.d.ts.map +1 -1
- package/dist/orchestrator/loop/parallel-dispatch.d.ts +2 -2
- package/dist/orchestrator/loop/parallel-dispatch.d.ts.map +1 -1
- package/dist/orchestrator/loop/post-loop-hooks.d.ts +1 -1
- package/dist/orchestrator/loop/post-loop-hooks.d.ts.map +1 -1
- package/dist/orchestrator/loop/run-policy.d.ts +1 -1
- package/dist/orchestrator/loop/run-policy.d.ts.map +1 -1
- package/dist/orchestrator/loop/tree-loop-runner.d.ts +1 -1
- package/dist/orchestrator/loop/tree-loop-runner.d.ts.map +1 -1
- package/dist/orchestrator/loop/tree-loop-runner.js +1 -1
- package/dist/orchestrator/loop/tree-loop-runner.js.map +1 -1
- package/dist/orchestrator/strategy/divergent-exploration.d.ts +2 -1
- package/dist/orchestrator/strategy/divergent-exploration.d.ts.map +1 -1
- package/dist/orchestrator/strategy/divergent-exploration.js +119 -36
- package/dist/orchestrator/strategy/divergent-exploration.js.map +1 -1
- package/dist/orchestrator/strategy/strategy-helpers.d.ts +86 -4
- package/dist/orchestrator/strategy/strategy-helpers.d.ts.map +1 -1
- package/dist/orchestrator/strategy/strategy-manager-base.d.ts +6 -2
- package/dist/orchestrator/strategy/strategy-manager-base.d.ts.map +1 -1
- package/dist/orchestrator/strategy/strategy-manager-base.js +71 -18
- package/dist/orchestrator/strategy/strategy-manager-base.js.map +1 -1
- package/dist/orchestrator/strategy/types/strategy.d.ts +450 -14
- package/dist/orchestrator/strategy/types/strategy.d.ts.map +1 -1
- package/dist/orchestrator/strategy/types/strategy.js +30 -0
- package/dist/orchestrator/strategy/types/strategy.js.map +1 -1
- package/dist/platform/code-search/contracts.d.ts +3 -0
- package/dist/platform/code-search/contracts.d.ts.map +1 -1
- package/dist/platform/code-search/contracts.js.map +1 -1
- package/dist/platform/code-search/indexes/indexer.d.ts.map +1 -1
- package/dist/platform/code-search/indexes/indexer.js +3 -0
- package/dist/platform/code-search/indexes/indexer.js.map +1 -1
- package/dist/platform/code-search/indexes/semantic-index.d.ts.map +1 -1
- package/dist/platform/code-search/indexes/semantic-index.js +3 -0
- package/dist/platform/code-search/indexes/semantic-index.js.map +1 -1
- package/dist/platform/code-search/orchestrator.d.ts.map +1 -1
- package/dist/platform/code-search/orchestrator.js +14 -3
- package/dist/platform/code-search/orchestrator.js.map +1 -1
- package/dist/platform/code-search/query-planner.d.ts.map +1 -1
- package/dist/platform/code-search/query-planner.js +1 -17
- package/dist/platform/code-search/query-planner.js.map +1 -1
- package/dist/platform/code-search/reranker.d.ts +5 -1
- package/dist/platform/code-search/reranker.d.ts.map +1 -1
- package/dist/platform/code-search/reranker.js +9 -5
- package/dist/platform/code-search/reranker.js.map +1 -1
- package/dist/platform/corrections/memory-correction-ledger.d.ts +30 -30
- package/dist/platform/dream/dream-activation.d.ts +161 -1
- package/dist/platform/dream/dream-activation.d.ts.map +1 -1
- package/dist/platform/dream/dream-activation.js +63 -14
- package/dist/platform/dream/dream-activation.js.map +1 -1
- package/dist/platform/dream/dream-event-workflows.d.ts +2 -2
- package/dist/platform/dream/dream-types.d.ts +52 -52
- package/dist/platform/dream/playbook-memory.d.ts +3 -3
- package/dist/platform/drive/stall-detector/repetitive.d.ts.map +1 -1
- package/dist/platform/drive/stall-detector/repetitive.js +50 -5
- package/dist/platform/drive/stall-detector/repetitive.js.map +1 -1
- package/dist/platform/drive/stall-detector.d.ts +19 -0
- package/dist/platform/drive/stall-detector.d.ts.map +1 -1
- package/dist/platform/drive/stall-detector.js.map +1 -1
- package/dist/platform/drive/types/stall.d.ts +1 -1
- package/dist/platform/knowledge/memory/memory-selection.d.ts.map +1 -1
- package/dist/platform/knowledge/memory/memory-selection.js +24 -18
- package/dist/platform/knowledge/memory/memory-selection.js.map +1 -1
- package/dist/platform/knowledge/transfer/knowledge-transfer-apply.d.ts.map +1 -1
- package/dist/platform/knowledge/transfer/knowledge-transfer-apply.js +7 -3
- package/dist/platform/knowledge/transfer/knowledge-transfer-apply.js.map +1 -1
- package/dist/platform/knowledge/types/agent-memory.d.ts +46 -46
- package/dist/platform/knowledge/types/embedding.d.ts +4 -4
- package/dist/platform/knowledge/types/knowledge.d.ts +53 -0
- package/dist/platform/knowledge/types/knowledge.d.ts.map +1 -1
- package/dist/platform/knowledge/types/knowledge.js +15 -0
- package/dist/platform/knowledge/types/knowledge.js.map +1 -1
- package/dist/platform/knowledge/types/memory-lifecycle.d.ts +2 -2
- package/dist/platform/observation/capability-detector/types.d.ts +4 -4
- package/dist/platform/observation/context-provider/collector.d.ts +2 -0
- package/dist/platform/observation/context-provider/collector.d.ts.map +1 -1
- package/dist/platform/observation/context-provider/collector.js +27 -2
- package/dist/platform/observation/context-provider/collector.js.map +1 -1
- package/dist/platform/observation/context-provider.d.ts +4 -0
- package/dist/platform/observation/context-provider.d.ts.map +1 -1
- package/dist/platform/observation/context-provider.js.map +1 -1
- package/dist/platform/observation/engine/observe-datasource-stage.d.ts +3 -2
- package/dist/platform/observation/engine/observe-datasource-stage.d.ts.map +1 -1
- package/dist/platform/observation/engine/observe-datasource-stage.js +2 -2
- package/dist/platform/observation/engine/observe-datasource-stage.js.map +1 -1
- package/dist/platform/observation/observation-apply.d.ts +1 -1
- package/dist/platform/observation/observation-apply.d.ts.map +1 -1
- package/dist/platform/observation/observation-apply.js +3 -3
- package/dist/platform/observation/observation-apply.js.map +1 -1
- package/dist/platform/observation/observation-datasource.d.ts +2 -2
- package/dist/platform/observation/observation-datasource.d.ts.map +1 -1
- package/dist/platform/observation/observation-datasource.js +13 -7
- package/dist/platform/observation/observation-datasource.js.map +1 -1
- package/dist/platform/observation/observation-engine.d.ts +1 -1
- package/dist/platform/observation/observation-engine.d.ts.map +1 -1
- package/dist/platform/observation/observation-engine.js +48 -7
- package/dist/platform/observation/observation-engine.js.map +1 -1
- package/dist/platform/observation/types/capability.d.ts +16 -16
- package/dist/platform/observation/types/data-source.d.ts +12 -0
- package/dist/platform/observation/types/data-source.d.ts.map +1 -1
- package/dist/platform/observation/types/data-source.js +1 -0
- package/dist/platform/observation/types/data-source.js.map +1 -1
- package/dist/platform/observation/workspace-context.d.ts +8 -1
- package/dist/platform/observation/workspace-context.d.ts.map +1 -1
- package/dist/platform/observation/workspace-context.js +35 -14
- package/dist/platform/observation/workspace-context.js.map +1 -1
- package/dist/platform/profile/profile-change-proposal.d.ts +20 -20
- package/dist/platform/profile/relationship-profile.d.ts +6 -6
- package/dist/platform/profile/user-md-profile-import.d.ts +2 -2
- package/dist/platform/soil/contracts.d.ts +98 -98
- package/dist/platform/soil/types.d.ts +8 -8
- package/dist/platform/traits/curiosity-engine.d.ts +2 -5
- package/dist/platform/traits/curiosity-engine.d.ts.map +1 -1
- package/dist/platform/traits/curiosity-engine.js.map +1 -1
- package/dist/platform/traits/curiosity-proposals.d.ts +2 -0
- package/dist/platform/traits/curiosity-proposals.d.ts.map +1 -1
- package/dist/platform/traits/curiosity-proposals.js +36 -17
- package/dist/platform/traits/curiosity-proposals.js.map +1 -1
- package/dist/platform/traits/curiosity-transfer.d.ts +9 -5
- package/dist/platform/traits/curiosity-transfer.d.ts.map +1 -1
- package/dist/platform/traits/curiosity-transfer.js +4 -1
- package/dist/platform/traits/curiosity-transfer.js.map +1 -1
- package/dist/platform/traits/ethics-gate.d.ts +16 -17
- package/dist/platform/traits/ethics-gate.d.ts.map +1 -1
- package/dist/platform/traits/ethics-gate.js +83 -47
- package/dist/platform/traits/ethics-gate.js.map +1 -1
- package/dist/platform/traits/ethics-rules.d.ts +4 -6
- package/dist/platform/traits/ethics-rules.d.ts.map +1 -1
- package/dist/platform/traits/ethics-rules.js +19 -261
- package/dist/platform/traits/ethics-rules.js.map +1 -1
- package/dist/platform/traits/types/curiosity.d.ts +157 -10
- package/dist/platform/traits/types/curiosity.d.ts.map +1 -1
- package/dist/platform/traits/types/curiosity.js +10 -0
- package/dist/platform/traits/types/curiosity.js.map +1 -1
- package/dist/platform/traits/types/guardrail.d.ts +6 -6
- package/dist/prompt/purposes/curiosity.d.ts +4 -4
- package/dist/runtime/approval-broker.d.ts +33 -0
- package/dist/runtime/approval-broker.d.ts.map +1 -1
- package/dist/runtime/approval-broker.js +155 -17
- package/dist/runtime/approval-broker.js.map +1 -1
- package/dist/runtime/companion-policy.d.ts +27 -0
- package/dist/runtime/companion-policy.d.ts.map +1 -0
- package/dist/runtime/companion-policy.js +135 -0
- package/dist/runtime/companion-policy.js.map +1 -0
- package/dist/runtime/confirmation-decision.d.ts +2 -2
- package/dist/runtime/control/daemon-runtime-control-executor.d.ts +0 -6
- package/dist/runtime/control/daemon-runtime-control-executor.d.ts.map +1 -1
- package/dist/runtime/control/daemon-runtime-control-executor.js +1 -1
- package/dist/runtime/control/daemon-runtime-control-executor.js.map +1 -1
- package/dist/runtime/control/index.d.ts +6 -3
- package/dist/runtime/control/index.d.ts.map +1 -1
- package/dist/runtime/control/index.js +2 -1
- package/dist/runtime/control/index.js.map +1 -1
- package/dist/runtime/control/runtime-control-intent.d.ts +16 -1
- package/dist/runtime/control/runtime-control-intent.d.ts.map +1 -1
- package/dist/runtime/control/runtime-control-intent.js +26 -13
- package/dist/runtime/control/runtime-control-intent.js.map +1 -1
- package/dist/runtime/control/runtime-control-service.d.ts +1 -1
- package/dist/runtime/control/runtime-control-service.d.ts.map +1 -1
- package/dist/runtime/control/runtime-control-service.js +29 -64
- package/dist/runtime/control/runtime-control-service.js.map +1 -1
- package/dist/runtime/control/runtime-target-resolver.d.ts +39 -0
- package/dist/runtime/control/runtime-target-resolver.d.ts.map +1 -0
- package/dist/runtime/control/runtime-target-resolver.js +112 -0
- package/dist/runtime/control/runtime-target-resolver.js.map +1 -0
- package/dist/runtime/conversational-approval-decision.d.ts +29 -0
- package/dist/runtime/conversational-approval-decision.d.ts.map +1 -0
- package/dist/runtime/conversational-approval-decision.js +92 -0
- package/dist/runtime/conversational-approval-decision.js.map +1 -0
- package/dist/runtime/daemon/client.d.ts +1 -4
- package/dist/runtime/daemon/client.d.ts.map +1 -1
- package/dist/runtime/daemon/client.js +0 -3
- package/dist/runtime/daemon/client.js.map +1 -1
- package/dist/runtime/daemon/control-contracts.d.ts +7 -0
- package/dist/runtime/daemon/control-contracts.d.ts.map +1 -0
- package/dist/runtime/daemon/control-contracts.js +2 -0
- package/dist/runtime/daemon/control-contracts.js.map +1 -0
- package/dist/runtime/daemon/runner-startup.js +1 -1
- package/dist/runtime/daemon/runner-startup.js.map +1 -1
- package/dist/runtime/daemon/runner.d.ts +1 -1
- package/dist/runtime/daemon/runner.d.ts.map +1 -1
- package/dist/runtime/executor/goal-worker.d.ts +9 -4
- package/dist/runtime/executor/goal-worker.d.ts.map +1 -1
- package/dist/runtime/executor/goal-worker.js +18 -1
- package/dist/runtime/executor/goal-worker.js.map +1 -1
- package/dist/runtime/executor/loop-supervisor.d.ts +3 -2
- package/dist/runtime/executor/loop-supervisor.d.ts.map +1 -1
- package/dist/runtime/executor/loop-supervisor.js +60 -8
- package/dist/runtime/executor/loop-supervisor.js.map +1 -1
- package/dist/runtime/gateway/channel-adapter.d.ts +19 -0
- package/dist/runtime/gateway/channel-adapter.d.ts.map +1 -1
- package/dist/runtime/gateway/channel-policy.d.ts +1 -0
- package/dist/runtime/gateway/channel-policy.d.ts.map +1 -1
- package/dist/runtime/gateway/channel-policy.js +6 -4
- package/dist/runtime/gateway/channel-policy.js.map +1 -1
- package/dist/runtime/gateway/chat-event-rendering.d.ts +34 -0
- package/dist/runtime/gateway/chat-event-rendering.d.ts.map +1 -0
- package/dist/runtime/gateway/chat-event-rendering.js +61 -0
- package/dist/runtime/gateway/chat-event-rendering.js.map +1 -0
- package/dist/runtime/gateway/chat-session-dispatch.d.ts +2 -13
- package/dist/runtime/gateway/chat-session-dispatch.d.ts.map +1 -1
- package/dist/runtime/gateway/chat-session-dispatch.js +6 -3
- package/dist/runtime/gateway/chat-session-dispatch.js.map +1 -1
- package/dist/runtime/gateway/chat-session-port.d.ts +25 -0
- package/dist/runtime/gateway/chat-session-port.d.ts.map +1 -0
- package/dist/runtime/gateway/chat-session-port.js +20 -0
- package/dist/runtime/gateway/chat-session-port.js.map +1 -0
- package/dist/runtime/gateway/discord-gateway-adapter.d.ts +3 -1
- package/dist/runtime/gateway/discord-gateway-adapter.d.ts.map +1 -1
- package/dist/runtime/gateway/discord-gateway-adapter.js +34 -2
- package/dist/runtime/gateway/discord-gateway-adapter.js.map +1 -1
- package/dist/runtime/gateway/index.d.ts +2 -0
- package/dist/runtime/gateway/index.d.ts.map +1 -1
- package/dist/runtime/gateway/index.js +1 -0
- package/dist/runtime/gateway/index.js.map +1 -1
- package/dist/runtime/gateway/ingress-gateway.d.ts.map +1 -1
- package/dist/runtime/gateway/ingress-gateway.js +1 -0
- package/dist/runtime/gateway/ingress-gateway.js.map +1 -1
- package/dist/runtime/gateway/signal-gateway-adapter.d.ts +2 -1
- package/dist/runtime/gateway/signal-gateway-adapter.d.ts.map +1 -1
- package/dist/runtime/gateway/signal-gateway-adapter.js +13 -3
- package/dist/runtime/gateway/signal-gateway-adapter.js.map +1 -1
- package/dist/runtime/gateway/slack-channel-adapter.d.ts +2 -1
- package/dist/runtime/gateway/slack-channel-adapter.d.ts.map +1 -1
- package/dist/runtime/gateway/slack-channel-adapter.js +6 -2
- package/dist/runtime/gateway/slack-channel-adapter.js.map +1 -1
- package/dist/runtime/gateway/telegram-gateway-adapter.d.ts +9 -2
- package/dist/runtime/gateway/telegram-gateway-adapter.d.ts.map +1 -1
- package/dist/runtime/gateway/telegram-gateway-adapter.js +141 -13
- package/dist/runtime/gateway/telegram-gateway-adapter.js.map +1 -1
- package/dist/runtime/gateway/typing-indicator.d.ts +11 -0
- package/dist/runtime/gateway/typing-indicator.d.ts.map +1 -0
- package/dist/runtime/gateway/typing-indicator.js +68 -0
- package/dist/runtime/gateway/typing-indicator.js.map +1 -0
- package/dist/runtime/gateway/whatsapp-gateway-adapter.d.ts +2 -1
- package/dist/runtime/gateway/whatsapp-gateway-adapter.d.ts.map +1 -1
- package/dist/runtime/gateway/whatsapp-gateway-adapter.js +22 -8
- package/dist/runtime/gateway/whatsapp-gateway-adapter.js.map +1 -1
- package/dist/runtime/gateway/ws-channel-adapter.d.ts.map +1 -1
- package/dist/runtime/gateway/ws-channel-adapter.js +1 -0
- package/dist/runtime/gateway/ws-channel-adapter.js.map +1 -1
- package/dist/runtime/interactive-automation/failure-classifier.d.ts +0 -1
- package/dist/runtime/interactive-automation/failure-classifier.d.ts.map +1 -1
- package/dist/runtime/interactive-automation/failure-classifier.js +0 -19
- package/dist/runtime/interactive-automation/failure-classifier.js.map +1 -1
- package/dist/runtime/interactive-automation/providers/manus-browser.d.ts.map +1 -1
- package/dist/runtime/interactive-automation/providers/manus-browser.js +30 -1
- package/dist/runtime/interactive-automation/providers/manus-browser.js.map +1 -1
- package/dist/runtime/logger.d.ts.map +1 -1
- package/dist/runtime/logger.js +5 -2
- package/dist/runtime/logger.js.map +1 -1
- package/dist/runtime/plugin-loader.js +2 -2
- package/dist/runtime/plugin-loader.js.map +1 -1
- package/dist/runtime/run-spec/derive.d.ts +24 -24
- package/dist/runtime/run-spec/derive.d.ts.map +1 -1
- package/dist/runtime/run-spec/derive.js +6 -0
- package/dist/runtime/run-spec/derive.js.map +1 -1
- package/dist/runtime/run-spec/handoff.d.ts +74 -0
- package/dist/runtime/run-spec/handoff.d.ts.map +1 -0
- package/dist/runtime/run-spec/handoff.js +496 -0
- package/dist/runtime/run-spec/handoff.js.map +1 -0
- package/dist/runtime/run-spec/index.d.ts +2 -0
- package/dist/runtime/run-spec/index.d.ts.map +1 -1
- package/dist/runtime/run-spec/index.js +2 -0
- package/dist/runtime/run-spec/index.js.map +1 -1
- package/dist/runtime/run-spec/pending-dialogue-arbiter.d.ts +25 -0
- package/dist/runtime/run-spec/pending-dialogue-arbiter.d.ts.map +1 -0
- package/dist/runtime/run-spec/pending-dialogue-arbiter.js +81 -0
- package/dist/runtime/run-spec/pending-dialogue-arbiter.js.map +1 -0
- package/dist/runtime/run-spec/types.d.ts +91 -42
- package/dist/runtime/run-spec/types.d.ts.map +1 -1
- package/dist/runtime/run-spec/types.js +7 -0
- package/dist/runtime/run-spec/types.js.map +1 -1
- package/dist/runtime/schedule/engine-execution.js +2 -35
- package/dist/runtime/schedule/engine-execution.js.map +1 -1
- package/dist/runtime/schedule/history.d.ts +2 -2
- package/dist/runtime/schedule/presets.d.ts +4 -4
- package/dist/runtime/schedule/source.d.ts +1 -1
- package/dist/runtime/session-registry/registry.d.ts.map +1 -1
- package/dist/runtime/session-registry/registry.js +27 -2
- package/dist/runtime/session-registry/registry.js.map +1 -1
- package/dist/runtime/session-registry/types.d.ts +120 -112
- package/dist/runtime/session-registry/types.d.ts.map +1 -1
- package/dist/runtime/session-registry/types.js +1 -0
- package/dist/runtime/session-registry/types.js.map +1 -1
- package/dist/runtime/store/artifact-retention.d.ts +11 -6
- package/dist/runtime/store/artifact-retention.d.ts.map +1 -1
- package/dist/runtime/store/artifact-retention.js +0 -13
- package/dist/runtime/store/artifact-retention.js.map +1 -1
- package/dist/runtime/store/background-run-store.d.ts +1 -0
- package/dist/runtime/store/background-run-store.d.ts.map +1 -1
- package/dist/runtime/store/background-run-store.js +1 -0
- package/dist/runtime/store/background-run-store.js.map +1 -1
- package/dist/runtime/store/budget-store.d.ts +8 -8
- package/dist/runtime/store/dream-checkpoints.d.ts +1 -1
- package/dist/runtime/store/dream-checkpoints.d.ts.map +1 -1
- package/dist/runtime/store/evaluator-results.d.ts +1 -1
- package/dist/runtime/store/evaluator-results.d.ts.map +1 -1
- package/dist/runtime/store/evidence-ledger.d.ts +39 -6377
- package/dist/runtime/store/evidence-ledger.d.ts.map +1 -1
- package/dist/runtime/store/evidence-ledger.js +415 -501
- package/dist/runtime/store/evidence-ledger.js.map +1 -1
- package/dist/runtime/store/evidence-types.d.ts +6378 -0
- package/dist/runtime/store/evidence-types.d.ts.map +1 -0
- package/dist/runtime/store/evidence-types.js +459 -0
- package/dist/runtime/store/evidence-types.js.map +1 -0
- package/dist/runtime/store/experiment-queue-store.d.ts +109 -109
- package/dist/runtime/store/experiment-queue-store.d.ts.map +1 -1
- package/dist/runtime/store/experiment-queue-store.js +1 -1
- package/dist/runtime/store/experiment-queue-store.js.map +1 -1
- package/dist/runtime/store/index.d.ts +4 -4
- package/dist/runtime/store/index.d.ts.map +1 -1
- package/dist/runtime/store/index.js +2 -2
- package/dist/runtime/store/index.js.map +1 -1
- package/dist/runtime/store/metric-history.d.ts +1 -1
- package/dist/runtime/store/metric-history.d.ts.map +1 -1
- package/dist/runtime/store/operator-handoff-store.d.ts +12 -12
- package/dist/runtime/store/postmortem-report.d.ts +40 -40
- package/dist/runtime/store/postmortem-report.js.map +1 -1
- package/dist/runtime/store/proactive-intervention-store.d.ts +8 -8
- package/dist/runtime/store/reproducibility-manifest.d.ts +27 -27
- package/dist/runtime/store/reproducibility-manifest.d.ts.map +1 -1
- package/dist/runtime/store/reproducibility-manifest.js.map +1 -1
- package/dist/runtime/store/research-evidence.d.ts +1 -1
- package/dist/runtime/store/research-evidence.d.ts.map +1 -1
- package/dist/runtime/store/runtime-operation-schemas.d.ts +46 -46
- package/dist/runtime/store/runtime-schemas.d.ts +73 -12
- package/dist/runtime/store/runtime-schemas.d.ts.map +1 -1
- package/dist/runtime/store/runtime-schemas.js +9 -0
- package/dist/runtime/store/runtime-schemas.js.map +1 -1
- package/dist/runtime/types/companion.d.ts +394 -0
- package/dist/runtime/types/companion.d.ts.map +1 -0
- package/dist/runtime/types/companion.js +87 -0
- package/dist/runtime/types/companion.js.map +1 -0
- package/dist/runtime/types/daemon.d.ts +3 -3
- package/dist/runtime/types/hook.d.ts +12 -12
- package/dist/runtime/types/schedule.d.ts +32 -32
- package/dist/tools/builtin/exports.d.ts +2 -0
- package/dist/tools/builtin/exports.d.ts.map +1 -1
- package/dist/tools/builtin/exports.js +2 -0
- package/dist/tools/builtin/exports.js.map +1 -1
- package/dist/tools/builtin/factory.d.ts +10 -1
- package/dist/tools/builtin/factory.d.ts.map +1 -1
- package/dist/tools/builtin/factory.js +18 -1
- package/dist/tools/builtin/factory.js.map +1 -1
- package/dist/tools/executor.d.ts.map +1 -1
- package/dist/tools/executor.js +8 -6
- package/dist/tools/executor.js.map +1 -1
- package/dist/tools/fs/ApplyPatchTool/ApplyPatchTool.d.ts.map +1 -1
- package/dist/tools/fs/ApplyPatchTool/ApplyPatchTool.js +1 -0
- package/dist/tools/fs/ApplyPatchTool/ApplyPatchTool.js.map +1 -1
- package/dist/tools/fs/FileEditTool/FileEditTool.d.ts.map +1 -1
- package/dist/tools/fs/FileEditTool/FileEditTool.js +1 -0
- package/dist/tools/fs/FileEditTool/FileEditTool.js.map +1 -1
- package/dist/tools/fs/FileWriteTool/FileWriteTool.d.ts.map +1 -1
- package/dist/tools/fs/FileWriteTool/FileWriteTool.js +1 -0
- package/dist/tools/fs/FileWriteTool/FileWriteTool.js.map +1 -1
- package/dist/tools/fs/GlobTool/GlobTool.d.ts.map +1 -1
- package/dist/tools/fs/GlobTool/GlobTool.js +1 -0
- package/dist/tools/fs/GlobTool/GlobTool.js.map +1 -1
- package/dist/tools/fs/GrepTool/GrepTool.d.ts.map +1 -1
- package/dist/tools/fs/GrepTool/GrepTool.js +1 -0
- package/dist/tools/fs/GrepTool/GrepTool.js.map +1 -1
- package/dist/tools/fs/JsonQueryTool/JsonQueryTool.d.ts.map +1 -1
- package/dist/tools/fs/JsonQueryTool/JsonQueryTool.js +1 -0
- package/dist/tools/fs/JsonQueryTool/JsonQueryTool.js.map +1 -1
- package/dist/tools/fs/ListDirTool/ListDirTool.d.ts.map +1 -1
- package/dist/tools/fs/ListDirTool/ListDirTool.js +1 -0
- package/dist/tools/fs/ListDirTool/ListDirTool.js.map +1 -1
- package/dist/tools/fs/ReadTool/ReadTool.d.ts.map +1 -1
- package/dist/tools/fs/ReadTool/ReadTool.js +1 -0
- package/dist/tools/fs/ReadTool/ReadTool.js.map +1 -1
- package/dist/tools/kaggle/KaggleSubmissionTools.d.ts +4 -4
- package/dist/tools/kaggle/metrics.d.ts +4 -4
- package/dist/tools/mutation/TaskCreateTool/TaskCreateTool.d.ts +4 -4
- package/dist/tools/mutation/TaskUpdateTool/TaskUpdateTool.d.ts +10 -10
- package/dist/tools/network/GitHubCliTool/GitHubCliTool.d.ts +8 -8
- package/dist/tools/network/HttpFetchTool/HttpFetchTool.d.ts.map +1 -1
- package/dist/tools/network/HttpFetchTool/HttpFetchTool.js +1 -0
- package/dist/tools/network/HttpFetchTool/HttpFetchTool.js.map +1 -1
- package/dist/tools/network/WebSearchTool/WebSearchTool.d.ts.map +1 -1
- package/dist/tools/network/WebSearchTool/WebSearchTool.js +1 -0
- package/dist/tools/network/WebSearchTool/WebSearchTool.js.map +1 -1
- package/dist/tools/query/ArchitectureTool/ArchitectureTool.js +3 -3
- package/dist/tools/query/ArchitectureTool/ArchitectureTool.js.map +1 -1
- package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.d.ts +20 -20
- package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.d.ts.map +1 -1
- package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.js +1 -0
- package/dist/tools/query/CodeReadContextTool/CodeReadContextTool.js.map +1 -1
- package/dist/tools/query/CodeSearchRepairTool/CodeSearchRepairTool.d.ts.map +1 -1
- package/dist/tools/query/CodeSearchRepairTool/CodeSearchRepairTool.js +1 -0
- package/dist/tools/query/CodeSearchRepairTool/CodeSearchRepairTool.js.map +1 -1
- package/dist/tools/query/CodeSearchTool/CodeSearchTool.d.ts.map +1 -1
- package/dist/tools/query/CodeSearchTool/CodeSearchTool.js +1 -0
- package/dist/tools/query/CodeSearchTool/CodeSearchTool.js.map +1 -1
- package/dist/tools/query/ConfigTool/ConfigTool.d.ts.map +1 -1
- package/dist/tools/query/ConfigTool/ConfigTool.js +1 -0
- package/dist/tools/query/ConfigTool/ConfigTool.js.map +1 -1
- package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.d.ts.map +1 -1
- package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.js +1 -0
- package/dist/tools/query/KnowledgeQueryTool/KnowledgeQueryTool.js.map +1 -1
- package/dist/tools/query/SkillSearchTool/SkillSearchTool.d.ts.map +1 -1
- package/dist/tools/query/SkillSearchTool/SkillSearchTool.js +1 -0
- package/dist/tools/query/SkillSearchTool/SkillSearchTool.js.map +1 -1
- package/dist/tools/query/ToolSearchTool/ToolSearchTool.d.ts.map +1 -1
- package/dist/tools/query/ToolSearchTool/ToolSearchTool.js +1 -0
- package/dist/tools/query/ToolSearchTool/ToolSearchTool.js.map +1 -1
- package/dist/tools/runtime/LongRunningRuntimeTools.d.ts +32 -32
- package/dist/tools/runtime/RunSpecHandoffTools.d.ts +12 -0
- package/dist/tools/runtime/RunSpecHandoffTools.d.ts.map +1 -0
- package/dist/tools/runtime/RunSpecHandoffTools.js +224 -0
- package/dist/tools/runtime/RunSpecHandoffTools.js.map +1 -0
- package/dist/tools/runtime/SetupRuntimeControlTools.d.ts +11 -0
- package/dist/tools/runtime/SetupRuntimeControlTools.d.ts.map +1 -0
- package/dist/tools/runtime/SetupRuntimeControlTools.js +463 -0
- package/dist/tools/runtime/SetupRuntimeControlTools.js.map +1 -0
- package/dist/tools/schedule/CreateScheduleTool/CreateScheduleTool.d.ts +28 -28
- package/dist/tools/schedule/UpdateScheduleTool/UpdateScheduleTool.d.ts +32 -32
- package/dist/tools/system/GitDiffTool/GitDiffTool.d.ts.map +1 -1
- package/dist/tools/system/GitDiffTool/GitDiffTool.js +1 -0
- package/dist/tools/system/GitDiffTool/GitDiffTool.js.map +1 -1
- package/dist/tools/system/GitLogTool/GitLogTool.d.ts.map +1 -1
- package/dist/tools/system/GitLogTool/GitLogTool.js +1 -0
- package/dist/tools/system/GitLogTool/GitLogTool.js.map +1 -1
- package/dist/tools/system/ShellTool/ShellTool.d.ts.map +1 -1
- package/dist/tools/system/ShellTool/ShellTool.js +2 -1
- package/dist/tools/system/ShellTool/ShellTool.js.map +1 -1
- package/dist/tools/system/TestRunnerTool/TestRunnerTool.d.ts.map +1 -1
- package/dist/tools/system/TestRunnerTool/TestRunnerTool.js +2 -1
- package/dist/tools/system/TestRunnerTool/TestRunnerTool.js.map +1 -1
- package/dist/tools/system/UpdatePlanTool/UpdatePlanTool.d.ts.map +1 -1
- package/dist/tools/system/UpdatePlanTool/UpdatePlanTool.js +1 -0
- package/dist/tools/system/UpdatePlanTool/UpdatePlanTool.js.map +1 -1
- package/dist/tools/types.d.ts +62 -2
- package/dist/tools/types.d.ts.map +1 -1
- package/dist/tools/types.js +25 -0
- package/dist/tools/types.js.map +1 -1
- package/package.json +1 -1
- package/dist/interface/tui/approval-overlay.d.ts +0 -8
- package/dist/interface/tui/approval-overlay.d.ts.map +0 -1
- package/dist/interface/tui/approval-overlay.js +0 -21
- package/dist/interface/tui/approval-overlay.js.map +0 -1
|
@@ -2,8 +2,10 @@ import { randomUUID } from "node:crypto";
|
|
|
2
2
|
import * as path from "node:path";
|
|
3
3
|
import { ChatRunner } from "./chat-runner.js";
|
|
4
4
|
import { createIngressRouter, } from "./ingress-router.js";
|
|
5
|
-
import {
|
|
5
|
+
import { classifyRuntimeControlIntent } from "../../runtime/control/index.js";
|
|
6
6
|
import { classifyFreeformRouteIntent } from "./freeform-route-classifier.js";
|
|
7
|
+
import { deriveRunSpecFromText } from "../../runtime/run-spec/index.js";
|
|
8
|
+
import { intakeSetupSecrets } from "./setup-secret-intake.js";
|
|
7
9
|
import { StateManager } from "../../base/state/state-manager.js";
|
|
8
10
|
import { buildAdapterRegistry, buildLLMClient } from "../../base/llm/provider-factory.js";
|
|
9
11
|
import { loadProviderConfig } from "../../base/llm/provider-config.js";
|
|
@@ -20,7 +22,11 @@ import { buildCliDataSourceRegistry } from "../cli/data-source-bootstrap.js";
|
|
|
20
22
|
import { ConcurrencyController, createBuiltinTools, ToolExecutor, ToolPermissionManager, ToolRegistry, } from "../../tools/index.js";
|
|
21
23
|
import { createNativeChatAgentLoopRunner, createNativeReviewAgentLoopRunner, shouldUseNativeTaskAgentLoop, } from "../../orchestrator/execution/agent-loop/index.js";
|
|
22
24
|
import { RuntimeControlService, createDaemonRuntimeControlExecutor, } from "../../runtime/control/index.js";
|
|
25
|
+
import { ApprovalBroker } from "../../runtime/approval-broker.js";
|
|
26
|
+
import { ApprovalStore, createRuntimeStorePaths } from "../../runtime/store/index.js";
|
|
27
|
+
import { classifyConversationalApprovalDecision } from "../../runtime/conversational-approval-decision.js";
|
|
23
28
|
import { registerGlobalCrossPlatformChatSessionManager } from "./cross-platform-session-global.js";
|
|
29
|
+
import { buildCompanionRuntimeContract, evaluateCompanionOutputPolicy, } from "../../runtime/companion-policy.js";
|
|
24
30
|
function normalizeIdentity(value) {
|
|
25
31
|
const trimmed = value?.trim();
|
|
26
32
|
return trimmed ? trimmed : null;
|
|
@@ -83,9 +89,11 @@ function resolveRuntimeControl(channel, runtimeControl, metadata) {
|
|
|
83
89
|
const approvalMode = runtimeControl?.approvalMode
|
|
84
90
|
?? (metadata?.["runtime_control_approved"] === true
|
|
85
91
|
? "preapproved"
|
|
86
|
-
:
|
|
87
|
-
? "
|
|
88
|
-
: "
|
|
92
|
+
: metadata?.["runtime_control_denied"] === true
|
|
93
|
+
? "disallowed"
|
|
94
|
+
: channel === "tui" || channel === "cli"
|
|
95
|
+
? "interactive"
|
|
96
|
+
: "disallowed");
|
|
89
97
|
return {
|
|
90
98
|
allowed: runtimeControl?.allowed ?? approvalMode !== "disallowed",
|
|
91
99
|
approvalMode,
|
|
@@ -126,22 +134,46 @@ function normalizeActor(channel, input) {
|
|
|
126
134
|
...input.actor,
|
|
127
135
|
};
|
|
128
136
|
}
|
|
129
|
-
function safeInvoke(handler, event) {
|
|
137
|
+
async function safeInvoke(handler, event) {
|
|
130
138
|
if (!handler)
|
|
131
139
|
return;
|
|
132
140
|
try {
|
|
133
|
-
|
|
134
|
-
if (result && typeof result.catch === "function") {
|
|
135
|
-
void result.catch(() => undefined);
|
|
136
|
-
}
|
|
141
|
+
await handler(event);
|
|
137
142
|
}
|
|
138
|
-
catch {
|
|
143
|
+
catch (err) {
|
|
139
144
|
// Event streaming should not break chat delivery.
|
|
145
|
+
console.warn("[chat] event delivery failed", {
|
|
146
|
+
eventType: event.type,
|
|
147
|
+
error: err instanceof Error ? err.message : String(err),
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
class ChatEventDeliveryQueue {
|
|
152
|
+
handler;
|
|
153
|
+
upstream;
|
|
154
|
+
queue = Promise.resolve();
|
|
155
|
+
constructor(handler, upstream) {
|
|
156
|
+
this.handler = handler;
|
|
157
|
+
this.upstream = upstream;
|
|
158
|
+
}
|
|
159
|
+
dispatch = (event) => {
|
|
160
|
+
this.queue = this.queue.then(async () => {
|
|
161
|
+
await safeInvoke(this.handler, event);
|
|
162
|
+
if (this.upstream && this.upstream !== this.handler) {
|
|
163
|
+
await safeInvoke(this.upstream, event);
|
|
164
|
+
}
|
|
165
|
+
});
|
|
166
|
+
return this.queue;
|
|
167
|
+
};
|
|
168
|
+
async drain() {
|
|
169
|
+
await this.queue;
|
|
140
170
|
}
|
|
141
171
|
}
|
|
142
172
|
export class CrossPlatformChatSessionManager {
|
|
143
173
|
deps;
|
|
144
174
|
sessions = new Map();
|
|
175
|
+
activeApprovalEventHandlers = new Map();
|
|
176
|
+
approvalSideTurnIngressIds = new Set();
|
|
145
177
|
ingressRouter = createIngressRouter();
|
|
146
178
|
constructor(deps) {
|
|
147
179
|
this.deps = deps;
|
|
@@ -165,51 +197,154 @@ export class CrossPlatformChatSessionManager {
|
|
|
165
197
|
channel: options.channel ?? (options.platform ? "plugin_gateway" : "cli"),
|
|
166
198
|
actor: options.actor,
|
|
167
199
|
replyTarget: options.replyTarget,
|
|
168
|
-
runtimeControl: options.runtimeControl
|
|
169
|
-
|
|
170
|
-
approvalMode: "interactive",
|
|
171
|
-
},
|
|
200
|
+
runtimeControl: options.runtimeControl,
|
|
201
|
+
companion: options.companion,
|
|
172
202
|
cwd: options.cwd,
|
|
173
203
|
timeoutMs: options.timeoutMs,
|
|
174
|
-
metadata:
|
|
204
|
+
metadata: {
|
|
205
|
+
...(options.metadata ?? {}),
|
|
206
|
+
...(options.runtimeControl ? { runtime_control_explicit: true } : {}),
|
|
207
|
+
},
|
|
175
208
|
onEvent: options.onEvent,
|
|
176
209
|
});
|
|
210
|
+
const approvalReply = await this.tryResolveConversationalApprovalReply(ingress);
|
|
211
|
+
if (approvalReply) {
|
|
212
|
+
return {
|
|
213
|
+
success: true,
|
|
214
|
+
output: approvalReply,
|
|
215
|
+
elapsed_ms: 0,
|
|
216
|
+
};
|
|
217
|
+
}
|
|
177
218
|
const session = this.getOrCreateSession(ingress, options.cwd);
|
|
219
|
+
if (ingress.ingress_id && this.approvalSideTurnIngressIds.delete(ingress.ingress_id)) {
|
|
220
|
+
return this.executeInSession(session, ingress, options);
|
|
221
|
+
}
|
|
178
222
|
const queueEntry = session.queue.then(() => this.executeInSession(session, ingress, options));
|
|
179
223
|
session.queue = queueEntry.then(() => undefined, () => undefined);
|
|
180
224
|
return queueEntry;
|
|
181
225
|
}
|
|
182
226
|
async processIncomingMessage(input) {
|
|
183
|
-
const
|
|
227
|
+
const ingress = this.createIngressMessage(input);
|
|
228
|
+
if (input.approvalResponse) {
|
|
229
|
+
return this.resolveConversationalApprovalIngress(ingress, input.approvalResponse);
|
|
230
|
+
}
|
|
231
|
+
const approvalReply = await this.tryResolveConversationalApprovalReply(ingress);
|
|
232
|
+
if (approvalReply) {
|
|
233
|
+
return approvalReply;
|
|
234
|
+
}
|
|
235
|
+
const result = await this.executeIngress(ingress, input);
|
|
184
236
|
return result.output;
|
|
185
237
|
}
|
|
186
238
|
async interruptAndRedirect(input) {
|
|
187
|
-
const ingress = this.createIngressMessage(input);
|
|
239
|
+
const ingress = this.ensureCompanionContract(this.createIngressMessage(input));
|
|
240
|
+
const approvalReply = await this.tryResolveConversationalApprovalReply(ingress);
|
|
241
|
+
if (approvalReply) {
|
|
242
|
+
return {
|
|
243
|
+
success: true,
|
|
244
|
+
output: approvalReply,
|
|
245
|
+
elapsed_ms: 0,
|
|
246
|
+
};
|
|
247
|
+
}
|
|
188
248
|
const session = this.getOrCreateSession(ingress, input.cwd);
|
|
249
|
+
const decision = evaluateCompanionOutputPolicy(ingress.companion.turn_policy);
|
|
250
|
+
if (!decision.delivered) {
|
|
251
|
+
return {
|
|
252
|
+
success: true,
|
|
253
|
+
output: formatCompanionPolicyDecision(decision),
|
|
254
|
+
elapsed_ms: 0,
|
|
255
|
+
};
|
|
256
|
+
}
|
|
189
257
|
const previousOnEvent = session.runner.onEvent;
|
|
258
|
+
let deliveryQueue = null;
|
|
190
259
|
if (input.onEvent) {
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
session.runner.onEvent = (event) => {
|
|
194
|
-
safeInvoke(handler, event);
|
|
195
|
-
if (upstream && upstream !== handler) {
|
|
196
|
-
safeInvoke(upstream, event);
|
|
197
|
-
}
|
|
198
|
-
};
|
|
260
|
+
deliveryQueue = new ChatEventDeliveryQueue(input.onEvent, this.deps.onEvent);
|
|
261
|
+
session.runner.onEvent = deliveryQueue.dispatch;
|
|
199
262
|
}
|
|
200
263
|
try {
|
|
201
264
|
return await session.runner.interruptAndRedirect(input.text, session.info.cwd, input.timeoutMs);
|
|
202
265
|
}
|
|
203
266
|
finally {
|
|
267
|
+
await deliveryQueue?.drain();
|
|
204
268
|
session.runner.onEvent = previousOnEvent;
|
|
205
269
|
}
|
|
206
270
|
}
|
|
207
271
|
async executeIngress(ingress, options = {}) {
|
|
208
|
-
const
|
|
209
|
-
const
|
|
272
|
+
const normalizedIngress = this.ensureCompanionContract(ingress);
|
|
273
|
+
const decision = evaluateCompanionOutputPolicy(normalizedIngress.companion.turn_policy);
|
|
274
|
+
if (!decision.delivered) {
|
|
275
|
+
return {
|
|
276
|
+
success: true,
|
|
277
|
+
output: formatCompanionPolicyDecision(decision),
|
|
278
|
+
elapsed_ms: 0,
|
|
279
|
+
};
|
|
280
|
+
}
|
|
281
|
+
const session = this.getOrCreateSession(normalizedIngress, options.cwd);
|
|
282
|
+
if (normalizedIngress.ingress_id && this.approvalSideTurnIngressIds.delete(normalizedIngress.ingress_id)) {
|
|
283
|
+
return this.executeInSession(session, normalizedIngress, options);
|
|
284
|
+
}
|
|
285
|
+
const queueEntry = session.queue.then(() => this.executeInSession(session, normalizedIngress, options));
|
|
210
286
|
session.queue = queueEntry.then(() => undefined, () => undefined);
|
|
211
287
|
return queueEntry;
|
|
212
288
|
}
|
|
289
|
+
async resolveConversationalApprovalIngress(ingress, response) {
|
|
290
|
+
const broker = this.deps.approvalBroker;
|
|
291
|
+
if (!broker) {
|
|
292
|
+
return "Approval response could not be recorded because approval handling is unavailable.";
|
|
293
|
+
}
|
|
294
|
+
const origin = createApprovalOriginFromIngress(ingress);
|
|
295
|
+
if (!origin) {
|
|
296
|
+
return "Approval response could not be recorded because the conversation origin is incomplete.";
|
|
297
|
+
}
|
|
298
|
+
const resolved = await broker.resolveConversationalApproval(response.approval_id, response.approved, origin);
|
|
299
|
+
return resolved
|
|
300
|
+
? "Approval response recorded."
|
|
301
|
+
: "Approval response did not match an active approval for this conversation.";
|
|
302
|
+
}
|
|
303
|
+
async tryResolveConversationalApprovalReply(ingress) {
|
|
304
|
+
const broker = this.deps.approvalBroker;
|
|
305
|
+
if (!broker) {
|
|
306
|
+
return null;
|
|
307
|
+
}
|
|
308
|
+
const origin = createApprovalOriginFromIngress(ingress);
|
|
309
|
+
if (!origin) {
|
|
310
|
+
return null;
|
|
311
|
+
}
|
|
312
|
+
const lookup = await broker.findPendingConversationalApproval(origin);
|
|
313
|
+
if (lookup.status === "none") {
|
|
314
|
+
return null;
|
|
315
|
+
}
|
|
316
|
+
if (lookup.status === "ambiguous") {
|
|
317
|
+
return "Multiple active approvals match this conversation. Please use the specific approval response.";
|
|
318
|
+
}
|
|
319
|
+
const approval = lookup.approval;
|
|
320
|
+
const decision = await classifyConversationalApprovalDecision(ingress.text, {
|
|
321
|
+
approval,
|
|
322
|
+
replyOrigin: origin,
|
|
323
|
+
llmClient: this.deps.llmClient,
|
|
324
|
+
priorTurnState: this.describeLastRouteForApproval(ingress),
|
|
325
|
+
});
|
|
326
|
+
if (decision.decision === "approve" || decision.decision === "reject") {
|
|
327
|
+
const resolved = await broker.resolveConversationalApproval(approval.approval_id, decision.decision === "approve", approval.origin ?? origin);
|
|
328
|
+
return resolved
|
|
329
|
+
? "Approval response recorded."
|
|
330
|
+
: "Approval response did not match an active approval for this conversation.";
|
|
331
|
+
}
|
|
332
|
+
if (decision.decision === "clarify") {
|
|
333
|
+
return decision.clarification ?? "Approval is still pending. Please clarify what you need before approving or rejecting.";
|
|
334
|
+
}
|
|
335
|
+
if (decision.decision === "side_question" || decision.decision === "new_intent") {
|
|
336
|
+
if (ingress.ingress_id) {
|
|
337
|
+
this.approvalSideTurnIngressIds.add(ingress.ingress_id);
|
|
338
|
+
}
|
|
339
|
+
return null;
|
|
340
|
+
}
|
|
341
|
+
return decision.clarification ?? "Approval reply was ambiguous. The approval remains pending.";
|
|
342
|
+
}
|
|
343
|
+
describeLastRouteForApproval(ingress) {
|
|
344
|
+
const session = this.sessions.get(buildSessionKeyFromParts(ingress));
|
|
345
|
+
const route = session?.lastRoute;
|
|
346
|
+
return route ? JSON.stringify(route) : "none";
|
|
347
|
+
}
|
|
213
348
|
handleIncomingMessage(input) {
|
|
214
349
|
return this.processIncomingMessage(input);
|
|
215
350
|
}
|
|
@@ -238,6 +373,16 @@ export class CrossPlatformChatSessionManager {
|
|
|
238
373
|
const identityKey = normalizeIdentity(input.identity_key) ?? undefined;
|
|
239
374
|
const conversationId = normalizeIdentity(input.conversation_id) ?? undefined;
|
|
240
375
|
const messageId = normalizeIdentity(input.message_id) ?? undefined;
|
|
376
|
+
const companion = this.buildCompanionContractForIngress({
|
|
377
|
+
identity_key: identityKey,
|
|
378
|
+
platform,
|
|
379
|
+
conversation_id: conversationId,
|
|
380
|
+
user_id: userId,
|
|
381
|
+
message_id: messageId,
|
|
382
|
+
goal_id: goalId,
|
|
383
|
+
replyTarget: input.replyTarget,
|
|
384
|
+
companion: input.companion,
|
|
385
|
+
});
|
|
241
386
|
return {
|
|
242
387
|
ingress_id: randomUUID(),
|
|
243
388
|
received_at: new Date().toISOString(),
|
|
@@ -257,6 +402,7 @@ export class CrossPlatformChatSessionManager {
|
|
|
257
402
|
actor: input.actor,
|
|
258
403
|
}),
|
|
259
404
|
runtimeControl: resolveRuntimeControl(channel, input.runtimeControl, metadata),
|
|
405
|
+
companion,
|
|
260
406
|
metadata,
|
|
261
407
|
replyTarget: normalizeReplyTarget(channel, {
|
|
262
408
|
platform,
|
|
@@ -269,6 +415,43 @@ export class CrossPlatformChatSessionManager {
|
|
|
269
415
|
}),
|
|
270
416
|
};
|
|
271
417
|
}
|
|
418
|
+
ensureCompanionContract(ingress) {
|
|
419
|
+
if (ingress.companion) {
|
|
420
|
+
return ingress;
|
|
421
|
+
}
|
|
422
|
+
return {
|
|
423
|
+
...ingress,
|
|
424
|
+
companion: this.buildCompanionContractForIngress({
|
|
425
|
+
identity_key: ingress.identity_key,
|
|
426
|
+
platform: ingress.platform,
|
|
427
|
+
conversation_id: ingress.conversation_id,
|
|
428
|
+
user_id: ingress.user_id,
|
|
429
|
+
message_id: ingress.message_id,
|
|
430
|
+
goal_id: ingress.goal_id,
|
|
431
|
+
replyTarget: ingress.replyTarget,
|
|
432
|
+
}),
|
|
433
|
+
};
|
|
434
|
+
}
|
|
435
|
+
buildCompanionContractForIngress(input) {
|
|
436
|
+
const sessionKey = buildSessionKeyFromParts({
|
|
437
|
+
identity_key: input.identity_key,
|
|
438
|
+
platform: input.platform,
|
|
439
|
+
conversation_id: input.conversation_id,
|
|
440
|
+
user_id: input.user_id,
|
|
441
|
+
});
|
|
442
|
+
const replyTargetId = normalizeIdentity(input.replyTarget?.conversation_id ?? input.conversation_id ?? input.replyTarget?.identity_key ?? input.identity_key) ?? undefined;
|
|
443
|
+
return buildCompanionRuntimeContract({
|
|
444
|
+
sessionKey,
|
|
445
|
+
conversationId: input.conversation_id,
|
|
446
|
+
messageId: input.message_id,
|
|
447
|
+
goalId: input.goal_id,
|
|
448
|
+
replyTargetId,
|
|
449
|
+
presence: input.companion?.presence,
|
|
450
|
+
turnPolicy: input.companion?.turnPolicy,
|
|
451
|
+
inputModality: input.companion?.inputModality ?? "text",
|
|
452
|
+
outputMode: input.companion?.outputMode,
|
|
453
|
+
});
|
|
454
|
+
}
|
|
272
455
|
/**
|
|
273
456
|
* Returns the active session info if a matching session is already loaded.
|
|
274
457
|
*/
|
|
@@ -295,8 +478,6 @@ export class CrossPlatformChatSessionManager {
|
|
|
295
478
|
return existing;
|
|
296
479
|
}
|
|
297
480
|
const cwd = resolveGitRoot(cwdOverride?.trim() || process.cwd());
|
|
298
|
-
const runner = new ChatRunner(this.deps);
|
|
299
|
-
runner.startSession(cwd);
|
|
300
481
|
const now = new Date().toISOString();
|
|
301
482
|
const info = {
|
|
302
483
|
session_key: sessionKey,
|
|
@@ -309,6 +490,13 @@ export class CrossPlatformChatSessionManager {
|
|
|
309
490
|
last_used_at: now,
|
|
310
491
|
metadata: {},
|
|
311
492
|
};
|
|
493
|
+
const approvalFn = this.createApprovalFn(info);
|
|
494
|
+
const runner = new ChatRunner({
|
|
495
|
+
...this.deps,
|
|
496
|
+
approvalFn: approvalFn ?? this.deps.approvalFn,
|
|
497
|
+
runtimeControlApprovalFn: approvalFn ?? this.deps.runtimeControlApprovalFn,
|
|
498
|
+
});
|
|
499
|
+
runner.startSession(cwd);
|
|
312
500
|
const created = {
|
|
313
501
|
runner,
|
|
314
502
|
info,
|
|
@@ -318,6 +506,55 @@ export class CrossPlatformChatSessionManager {
|
|
|
318
506
|
this.sessions.set(sessionKey, created);
|
|
319
507
|
return created;
|
|
320
508
|
}
|
|
509
|
+
createApprovalFn(info) {
|
|
510
|
+
const broker = this.deps.approvalBroker;
|
|
511
|
+
if (!broker) {
|
|
512
|
+
return null;
|
|
513
|
+
}
|
|
514
|
+
return async (description) => {
|
|
515
|
+
const origin = createApprovalOriginFromSessionInfo(info);
|
|
516
|
+
if (!origin) {
|
|
517
|
+
return false;
|
|
518
|
+
}
|
|
519
|
+
const goalId = typeof info.metadata.goal_id === "string" && info.metadata.goal_id.trim()
|
|
520
|
+
? info.metadata.goal_id.trim()
|
|
521
|
+
: "chat";
|
|
522
|
+
return broker.requestConversationalApproval(goalId, {
|
|
523
|
+
id: info.last_message_id ?? info.session_key,
|
|
524
|
+
description,
|
|
525
|
+
action: "chat_approval",
|
|
526
|
+
}, {
|
|
527
|
+
origin,
|
|
528
|
+
deliverConversationalApproval: async ({ prompt }) => {
|
|
529
|
+
const handler = this.activeApprovalEventHandlers.get(info.session_key);
|
|
530
|
+
if (!handler) {
|
|
531
|
+
return {
|
|
532
|
+
delivered: false,
|
|
533
|
+
reason: "originating_conversation_unreachable",
|
|
534
|
+
};
|
|
535
|
+
}
|
|
536
|
+
try {
|
|
537
|
+
await handler({
|
|
538
|
+
type: "activity",
|
|
539
|
+
kind: "checkpoint",
|
|
540
|
+
message: prompt,
|
|
541
|
+
sourceId: `approval:${info.last_message_id ?? info.session_key}`,
|
|
542
|
+
runId: info.session_key,
|
|
543
|
+
turnId: info.last_message_id ?? info.session_key,
|
|
544
|
+
createdAt: new Date().toISOString(),
|
|
545
|
+
});
|
|
546
|
+
return { delivered: true };
|
|
547
|
+
}
|
|
548
|
+
catch (err) {
|
|
549
|
+
return {
|
|
550
|
+
delivered: false,
|
|
551
|
+
reason: err instanceof Error ? err.message : "originating_conversation_unreachable",
|
|
552
|
+
};
|
|
553
|
+
}
|
|
554
|
+
},
|
|
555
|
+
});
|
|
556
|
+
};
|
|
557
|
+
}
|
|
321
558
|
async executeInSession(session, ingress, options = {}) {
|
|
322
559
|
session.info.last_used_at = new Date().toISOString();
|
|
323
560
|
session.info.conversation_name = options.conversation_name?.trim() || session.info.conversation_name;
|
|
@@ -328,6 +565,9 @@ export class CrossPlatformChatSessionManager {
|
|
|
328
565
|
...ingress.replyTarget,
|
|
329
566
|
metadata: cloneMetadata(ingress.replyTarget.metadata),
|
|
330
567
|
};
|
|
568
|
+
if (ingress.companion) {
|
|
569
|
+
session.info.active_companion_contract = ingress.companion;
|
|
570
|
+
}
|
|
331
571
|
session.info.metadata = cloneMetadata(buildSessionMetadata({
|
|
332
572
|
metadata: ingress.metadata,
|
|
333
573
|
channel: ingress.channel,
|
|
@@ -342,44 +582,157 @@ export class CrossPlatformChatSessionManager {
|
|
|
342
582
|
hasToolLoop: this.deps.llmClient !== undefined,
|
|
343
583
|
hasRuntimeControlService: this.deps.runtimeControlService !== undefined,
|
|
344
584
|
};
|
|
345
|
-
const
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
585
|
+
const setupSecretIntake = intakeSetupSecrets(ingress.text);
|
|
586
|
+
const safeIngressText = setupSecretIntake.redactedText;
|
|
587
|
+
const hasSetupSecret = setupSecretIntake.suppliedSecrets.length > 0;
|
|
588
|
+
const shouldPreferFreeformBeforeDeniedRuntimeControl = !hasSetupSecret
|
|
589
|
+
&& !capabilities.hasAgentLoop
|
|
590
|
+
&& ingress.metadata["runtime_control_denied"] === true
|
|
591
|
+
&& ingress.metadata["runtime_control_approved"] !== true
|
|
592
|
+
&& ingress.metadata["runtime_control_explicit"] !== true;
|
|
593
|
+
const shouldClassifyRuntimeControlForSafety = !hasSetupSecret
|
|
594
|
+
&& capabilities.hasAgentLoop
|
|
595
|
+
&& (ingress.metadata["runtime_control_approved"] === true
|
|
596
|
+
|| ingress.metadata["runtime_control_denied"] === true
|
|
597
|
+
|| ingress.metadata["runtime_control_explicit"] === true);
|
|
598
|
+
const shouldClassifyRuntimeControl = shouldClassifyRuntimeControlForSafety
|
|
599
|
+
|| (!hasSetupSecret && !capabilities.hasAgentLoop && ((capabilities.hasRuntimeControlService && ingress.runtimeControl.approvalMode !== "disallowed")
|
|
600
|
+
|| ingress.metadata["runtime_control_approved"] === true
|
|
601
|
+
|| ingress.metadata["runtime_control_denied"] === true
|
|
602
|
+
|| ingress.metadata["runtime_control_explicit"] === true));
|
|
603
|
+
let freeformRouteIntent = shouldPreferFreeformBeforeDeniedRuntimeControl
|
|
604
|
+
? await classifyFreeformRouteIntent(safeIngressText, this.deps.llmClient)
|
|
605
|
+
: null;
|
|
606
|
+
const runtimeControlClassification = freeformRouteIntent == null && shouldClassifyRuntimeControl
|
|
607
|
+
? await classifyRuntimeControlIntent(safeIngressText, this.deps.llmClient)
|
|
351
608
|
: null;
|
|
352
|
-
const
|
|
353
|
-
?
|
|
609
|
+
const runtimeControlIntent = runtimeControlClassification?.status === "intent"
|
|
610
|
+
? runtimeControlClassification.intent
|
|
611
|
+
: null;
|
|
612
|
+
if (!hasSetupSecret && !capabilities.hasAgentLoop && freeformRouteIntent == null && runtimeControlIntent === null) {
|
|
613
|
+
freeformRouteIntent = await classifyFreeformRouteIntent(safeIngressText, this.deps.llmClient);
|
|
614
|
+
}
|
|
615
|
+
const shouldDeriveRunSpecDraft = !capabilities.hasAgentLoop
|
|
616
|
+
&& !hasSetupSecret
|
|
617
|
+
&& runtimeControlIntent === null
|
|
618
|
+
&& freeformRouteIntent != null
|
|
619
|
+
&& (freeformRouteIntent.kind === "run_spec"
|
|
620
|
+
|| freeformRouteIntent.kind === "configure"
|
|
621
|
+
|| freeformRouteIntent.kind === "clarify")
|
|
622
|
+
&& freeformRouteIntent.confidence >= 0.7;
|
|
623
|
+
const runSpecDraft = shouldDeriveRunSpecDraft
|
|
624
|
+
? await deriveRunSpecFromText(safeIngressText, {
|
|
625
|
+
cwd: ingress.cwd ?? session.info.cwd,
|
|
626
|
+
conversationId: ingress.conversation_id ?? null,
|
|
627
|
+
channel: ingress.channel,
|
|
628
|
+
sessionId: session.runner.getSessionId() ?? ingress.conversation_id ?? null,
|
|
629
|
+
replyTarget: ingress.replyTarget,
|
|
630
|
+
originMetadata: {
|
|
631
|
+
ingress_id: ingress.ingress_id ?? null,
|
|
632
|
+
platform: ingress.platform ?? null,
|
|
633
|
+
message_id: ingress.message_id ?? null,
|
|
634
|
+
deliveryMode: ingress.deliveryMode ?? null,
|
|
635
|
+
metadata: ingress.metadata,
|
|
636
|
+
},
|
|
637
|
+
llmClient: this.deps.llmClient,
|
|
638
|
+
})
|
|
354
639
|
: null;
|
|
355
640
|
const selectedRoute = this.ingressRouter.selectRoute(ingress, {
|
|
356
641
|
...capabilities,
|
|
357
642
|
runtimeControlIntent,
|
|
643
|
+
runtimeControlUnclassified: shouldClassifyRuntimeControlForSafety
|
|
644
|
+
&& runtimeControlClassification?.status === "unclassified"
|
|
645
|
+
&& ingress.metadata["runtime_control_explicit"] === true,
|
|
358
646
|
freeformRouteIntent,
|
|
647
|
+
setupSecretIntake,
|
|
648
|
+
runSpecDraft,
|
|
359
649
|
});
|
|
360
650
|
session.lastRoute = selectedRoute;
|
|
361
651
|
const previousOnEvent = session.runner.onEvent;
|
|
652
|
+
let deliveryQueue = null;
|
|
362
653
|
if (options.onEvent) {
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
session.runner.onEvent =
|
|
366
|
-
safeInvoke(handler, event);
|
|
367
|
-
if (upstream && upstream !== handler) {
|
|
368
|
-
safeInvoke(upstream, event);
|
|
369
|
-
}
|
|
370
|
-
};
|
|
654
|
+
deliveryQueue = new ChatEventDeliveryQueue(options.onEvent, this.deps.onEvent);
|
|
655
|
+
this.activeApprovalEventHandlers.set(session.info.session_key, options.onEvent);
|
|
656
|
+
session.runner.onEvent = deliveryQueue.dispatch;
|
|
371
657
|
}
|
|
372
658
|
else {
|
|
659
|
+
this.activeApprovalEventHandlers.delete(session.info.session_key);
|
|
373
660
|
session.runner.onEvent = undefined;
|
|
374
661
|
}
|
|
375
662
|
try {
|
|
376
663
|
return await session.runner.executeIngressMessage(ingress, session.info.cwd, options.timeoutMs, selectedRoute);
|
|
377
664
|
}
|
|
378
665
|
finally {
|
|
666
|
+
await deliveryQueue?.drain();
|
|
667
|
+
this.activeApprovalEventHandlers.delete(session.info.session_key);
|
|
379
668
|
session.runner.onEvent = previousOnEvent;
|
|
380
669
|
}
|
|
381
670
|
}
|
|
382
671
|
}
|
|
672
|
+
function formatCompanionPolicyDecision(decision) {
|
|
673
|
+
if (decision.reason === "interruption_requires_explicit_request") {
|
|
674
|
+
return "The current companion turn is non-interruptible. Send an explicit interruption request before redirecting it.";
|
|
675
|
+
}
|
|
676
|
+
if (decision.reason === "suppressed_by_quieting") {
|
|
677
|
+
return "Companion output was suppressed by the current quieting policy.";
|
|
678
|
+
}
|
|
679
|
+
if (decision.reason === "deferred_by_quieting") {
|
|
680
|
+
return "Companion output was deferred by the current quieting policy.";
|
|
681
|
+
}
|
|
682
|
+
return "Companion output is allowed.";
|
|
683
|
+
}
|
|
684
|
+
export function createApprovalOriginFromSessionInfo(info) {
|
|
685
|
+
const replyTarget = info.active_reply_target;
|
|
686
|
+
const channel = normalizeIdentity(replyTarget?.platform
|
|
687
|
+
?? replyTarget?.channel
|
|
688
|
+
?? replyTarget?.surface
|
|
689
|
+
?? info.platform);
|
|
690
|
+
const conversationId = normalizeIdentity(replyTarget?.conversation_id
|
|
691
|
+
?? info.conversation_id
|
|
692
|
+
?? info.identity_key
|
|
693
|
+
?? info.session_key);
|
|
694
|
+
if (!channel || !conversationId) {
|
|
695
|
+
return null;
|
|
696
|
+
}
|
|
697
|
+
const userId = normalizeIdentity(replyTarget?.user_id ?? info.user_id) ?? undefined;
|
|
698
|
+
const turnId = normalizeIdentity(replyTarget?.message_id ?? info.last_message_id) ?? undefined;
|
|
699
|
+
return {
|
|
700
|
+
channel,
|
|
701
|
+
conversation_id: conversationId,
|
|
702
|
+
...(userId ? { user_id: userId } : {}),
|
|
703
|
+
session_id: info.session_key,
|
|
704
|
+
...(turnId ? { turn_id: turnId } : {}),
|
|
705
|
+
reply_target: {
|
|
706
|
+
...replyTarget,
|
|
707
|
+
metadata: replyTarget?.metadata ? { ...replyTarget.metadata } : undefined,
|
|
708
|
+
},
|
|
709
|
+
};
|
|
710
|
+
}
|
|
711
|
+
function createApprovalOriginFromIngress(ingress) {
|
|
712
|
+
const channel = normalizeIdentity(ingress.replyTarget.platform
|
|
713
|
+
?? ingress.replyTarget.channel
|
|
714
|
+
?? ingress.replyTarget.surface
|
|
715
|
+
?? ingress.platform);
|
|
716
|
+
const conversationId = normalizeIdentity(ingress.replyTarget.conversation_id
|
|
717
|
+
?? ingress.conversation_id
|
|
718
|
+
?? ingress.identity_key);
|
|
719
|
+
const userId = normalizeIdentity(ingress.replyTarget.user_id ?? ingress.user_id) ?? undefined;
|
|
720
|
+
const turnId = normalizeIdentity(ingress.replyTarget.message_id ?? ingress.message_id) ?? undefined;
|
|
721
|
+
if (!channel || !conversationId || !userId || !turnId) {
|
|
722
|
+
return null;
|
|
723
|
+
}
|
|
724
|
+
return {
|
|
725
|
+
channel,
|
|
726
|
+
conversation_id: conversationId,
|
|
727
|
+
user_id: userId,
|
|
728
|
+
session_id: buildSessionKeyFromParts(ingress),
|
|
729
|
+
turn_id: turnId,
|
|
730
|
+
reply_target: {
|
|
731
|
+
...ingress.replyTarget,
|
|
732
|
+
metadata: cloneMetadata(ingress.replyTarget.metadata),
|
|
733
|
+
},
|
|
734
|
+
};
|
|
735
|
+
}
|
|
383
736
|
let globalManagerPromise = null;
|
|
384
737
|
export function getGlobalCrossPlatformChatSessionManager() {
|
|
385
738
|
if (globalManagerPromise === null) {
|
|
@@ -420,10 +773,20 @@ async function createGlobalCrossPlatformChatSessionManager() {
|
|
|
420
773
|
});
|
|
421
774
|
await pluginLoader.loadAll().catch(() => []);
|
|
422
775
|
await scheduleEngine.syncExternalSources(pluginLoader.getScheduleSources()).catch(() => undefined);
|
|
776
|
+
const runtimeRoot = path.join(stateManager.getBaseDir(), "runtime");
|
|
777
|
+
const runtimeControlService = new RuntimeControlService({
|
|
778
|
+
runtimeRoot,
|
|
779
|
+
stateManager,
|
|
780
|
+
executor: createDaemonRuntimeControlExecutor({
|
|
781
|
+
baseDir: stateManager.getBaseDir(),
|
|
782
|
+
}),
|
|
783
|
+
});
|
|
423
784
|
for (const tool of createBuiltinTools({
|
|
424
785
|
stateManager,
|
|
425
786
|
trustManager,
|
|
426
787
|
registry: toolRegistry,
|
|
788
|
+
llmClient,
|
|
789
|
+
runtimeControlService,
|
|
427
790
|
adapterRegistry,
|
|
428
791
|
knowledgeManager,
|
|
429
792
|
observationEngine,
|
|
@@ -456,6 +819,9 @@ async function createGlobalCrossPlatformChatSessionManager() {
|
|
|
456
819
|
traceBaseDir: stateManager.getBaseDir(),
|
|
457
820
|
})
|
|
458
821
|
: undefined;
|
|
822
|
+
const approvalBroker = new ApprovalBroker({
|
|
823
|
+
store: new ApprovalStore(createRuntimeStorePaths(runtimeRoot)),
|
|
824
|
+
});
|
|
459
825
|
return new CrossPlatformChatSessionManager({
|
|
460
826
|
stateManager,
|
|
461
827
|
adapter,
|
|
@@ -464,13 +830,8 @@ async function createGlobalCrossPlatformChatSessionManager() {
|
|
|
464
830
|
toolExecutor,
|
|
465
831
|
chatAgentLoopRunner,
|
|
466
832
|
reviewAgentLoopRunner,
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
stateManager,
|
|
470
|
-
executor: createDaemonRuntimeControlExecutor({
|
|
471
|
-
baseDir: stateManager.getBaseDir(),
|
|
472
|
-
}),
|
|
473
|
-
}),
|
|
833
|
+
approvalBroker,
|
|
834
|
+
runtimeControlService,
|
|
474
835
|
});
|
|
475
836
|
}
|
|
476
837
|
registerGlobalCrossPlatformChatSessionManager(getGlobalCrossPlatformChatSessionManager);
|