@viewportai/daemon 0.1.0 → 0.2.1
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 +18 -6
- package/bin/vpd.js +0 -1
- package/dist/adapters/claude-message-normalizer.d.ts +24 -0
- package/dist/adapters/claude-message-normalizer.d.ts.map +1 -0
- package/dist/adapters/claude-message-normalizer.js +192 -0
- package/dist/adapters/claude-message-normalizer.js.map +1 -0
- package/dist/adapters/claude.d.ts +1 -23
- package/dist/adapters/claude.d.ts.map +1 -1
- package/dist/adapters/claude.js +20 -215
- package/dist/adapters/claude.js.map +1 -1
- package/dist/adapters/codex-sdk-loader.d.ts +1 -0
- package/dist/adapters/codex-sdk-loader.d.ts.map +1 -1
- package/dist/adapters/codex.d.ts +6 -2
- package/dist/adapters/codex.d.ts.map +1 -1
- package/dist/adapters/codex.js +44 -19
- package/dist/adapters/codex.js.map +1 -1
- package/dist/adapters/gemini-cli.js +2 -2
- package/dist/adapters/gemini-cli.js.map +1 -1
- package/dist/adapters/pty.d.ts.map +1 -1
- package/dist/adapters/pty.js +12 -10
- package/dist/adapters/pty.js.map +1 -1
- package/dist/agents/codex-defaults.d.ts +2 -0
- package/dist/agents/codex-defaults.d.ts.map +1 -0
- package/dist/agents/codex-defaults.js +2 -0
- package/dist/agents/codex-defaults.js.map +1 -0
- package/dist/agents/codex.d.ts.map +1 -1
- package/dist/agents/codex.js +15 -3
- package/dist/agents/codex.js.map +1 -1
- package/dist/cli/agent-commands.d.ts.map +1 -1
- package/dist/cli/agent-commands.js +12 -2
- package/dist/cli/agent-commands.js.map +1 -1
- package/dist/cli/command-shared.d.ts +30 -2
- package/dist/cli/command-shared.d.ts.map +1 -1
- package/dist/cli/command-shared.js +25 -27
- package/dist/cli/command-shared.js.map +1 -1
- package/dist/cli/commands.d.ts +8 -2
- package/dist/cli/commands.d.ts.map +1 -1
- package/dist/cli/commands.js +8 -2
- package/dist/cli/commands.js.map +1 -1
- package/dist/cli/context-access-command.d.ts +9 -0
- package/dist/cli/context-access-command.d.ts.map +1 -0
- package/dist/cli/context-access-command.js +133 -0
- package/dist/cli/context-access-command.js.map +1 -0
- package/dist/cli/context-add-command.d.ts +2 -0
- package/dist/cli/context-add-command.d.ts.map +1 -0
- package/dist/cli/context-add-command.js +74 -0
- package/dist/cli/context-add-command.js.map +1 -0
- package/dist/cli/context-command-parsers.d.ts +4 -0
- package/dist/cli/context-command-parsers.d.ts.map +1 -0
- package/dist/cli/context-command-parsers.js +32 -0
- package/dist/cli/context-command-parsers.js.map +1 -0
- package/dist/cli/context-command.d.ts +2 -0
- package/dist/cli/context-command.d.ts.map +1 -0
- package/dist/cli/context-command.js +306 -0
- package/dist/cli/context-command.js.map +1 -0
- package/dist/cli/context-provider-command.d.ts +4 -0
- package/dist/cli/context-provider-command.d.ts.map +1 -0
- package/dist/cli/context-provider-command.js +268 -0
- package/dist/cli/context-provider-command.js.map +1 -0
- package/dist/cli/context-provider-propose.d.ts +22 -0
- package/dist/cli/context-provider-propose.d.ts.map +1 -0
- package/dist/cli/context-provider-propose.js +26 -0
- package/dist/cli/context-provider-propose.js.map +1 -0
- package/dist/cli/context-provider-resolve.d.ts +11 -0
- package/dist/cli/context-provider-resolve.d.ts.map +1 -0
- package/dist/cli/context-provider-resolve.js +22 -0
- package/dist/cli/context-provider-resolve.js.map +1 -0
- package/dist/cli/context-sync-target.d.ts +9 -0
- package/dist/cli/context-sync-target.d.ts.map +1 -0
- package/dist/cli/context-sync-target.js +54 -0
- package/dist/cli/context-sync-target.js.map +1 -0
- package/dist/cli/context-vault-metadata-command.d.ts +3 -0
- package/dist/cli/context-vault-metadata-command.d.ts.map +1 -0
- package/dist/cli/context-vault-metadata-command.js +239 -0
- package/dist/cli/context-vault-metadata-command.js.map +1 -0
- package/dist/cli/context-vault-use-command.d.ts +2 -0
- package/dist/cli/context-vault-use-command.d.ts.map +1 -0
- package/dist/cli/context-vault-use-command.js +35 -0
- package/dist/cli/context-vault-use-command.js.map +1 -0
- package/dist/cli/contract-authorization.d.ts +25 -0
- package/dist/cli/contract-authorization.d.ts.map +1 -0
- package/dist/cli/contract-authorization.js +99 -0
- package/dist/cli/contract-authorization.js.map +1 -0
- package/dist/cli/daemon-client.d.ts.map +1 -1
- package/dist/cli/daemon-client.js +49 -14
- package/dist/cli/daemon-client.js.map +1 -1
- package/dist/cli/daemon-lifecycle.d.ts +2 -30
- package/dist/cli/daemon-lifecycle.d.ts.map +1 -1
- package/dist/cli/daemon-lifecycle.js +53 -17
- package/dist/cli/daemon-lifecycle.js.map +1 -1
- package/dist/cli/daemon-runtime-state.d.ts +47 -0
- package/dist/cli/daemon-runtime-state.d.ts.map +1 -0
- package/dist/cli/daemon-runtime-state.js +2 -0
- package/dist/cli/daemon-runtime-state.js.map +1 -0
- package/dist/cli/daemon-settings.d.ts.map +1 -1
- package/dist/cli/daemon-settings.js +135 -4
- package/dist/cli/daemon-settings.js.map +1 -1
- package/dist/cli/directory-commands.js +1 -1
- package/dist/cli/directory-commands.js.map +1 -1
- package/dist/cli/global-flags.d.ts +2 -0
- package/dist/cli/global-flags.d.ts.map +1 -0
- package/dist/cli/global-flags.js +8 -0
- package/dist/cli/global-flags.js.map +1 -0
- package/dist/cli/guard-command.d.ts +34 -0
- package/dist/cli/guard-command.d.ts.map +1 -0
- package/dist/cli/guard-command.js +161 -0
- package/dist/cli/guard-command.js.map +1 -0
- package/dist/cli/hook-command.d.ts +3 -1
- package/dist/cli/hook-command.d.ts.map +1 -1
- package/dist/cli/hook-command.js +33 -3
- package/dist/cli/hook-command.js.map +1 -1
- package/dist/cli/lifecycle-commands.d.ts +7 -2
- package/dist/cli/lifecycle-commands.d.ts.map +1 -1
- package/dist/cli/lifecycle-commands.js +170 -338
- package/dist/cli/lifecycle-commands.js.map +1 -1
- package/dist/cli/lifecycle-doctor-command.d.ts +2 -0
- package/dist/cli/lifecycle-doctor-command.d.ts.map +1 -0
- package/dist/cli/lifecycle-doctor-command.js +100 -0
- package/dist/cli/lifecycle-doctor-command.js.map +1 -0
- package/dist/cli/lifecycle-pair-command.d.ts +6 -0
- package/dist/cli/lifecycle-pair-command.d.ts.map +1 -0
- package/dist/cli/lifecycle-pair-command.js +286 -0
- package/dist/cli/lifecycle-pair-command.js.map +1 -0
- package/dist/cli/lifecycle-pair-server.d.ts +26 -0
- package/dist/cli/lifecycle-pair-server.d.ts.map +1 -0
- package/dist/cli/lifecycle-pair-server.js +166 -0
- package/dist/cli/lifecycle-pair-server.js.map +1 -0
- package/dist/cli/lifecycle-status-command.d.ts +2 -0
- package/dist/cli/lifecycle-status-command.d.ts.map +1 -0
- package/dist/cli/lifecycle-status-command.js +184 -0
- package/dist/cli/lifecycle-status-command.js.map +1 -0
- package/dist/cli/lifecycle-update-command.d.ts +2 -0
- package/dist/cli/lifecycle-update-command.d.ts.map +1 -0
- package/dist/cli/lifecycle-update-command.js +71 -0
- package/dist/cli/lifecycle-update-command.js.map +1 -0
- package/dist/cli/local-tls.d.ts +9 -0
- package/dist/cli/local-tls.d.ts.map +1 -0
- package/dist/cli/local-tls.js +84 -0
- package/dist/cli/local-tls.js.map +1 -0
- package/dist/cli/network.d.ts +11 -0
- package/dist/cli/network.d.ts.map +1 -0
- package/dist/cli/network.js +172 -0
- package/dist/cli/network.js.map +1 -0
- package/dist/cli/pairing-name-resolver.d.ts +2 -0
- package/dist/cli/pairing-name-resolver.d.ts.map +1 -0
- package/dist/cli/pairing-name-resolver.js +48 -0
- package/dist/cli/pairing-name-resolver.js.map +1 -0
- package/dist/cli/permission-commands.d.ts.map +1 -1
- package/dist/cli/permission-commands.js +11 -1
- package/dist/cli/permission-commands.js.map +1 -1
- package/dist/cli/relay-diagnostics.d.ts +8 -0
- package/dist/cli/relay-diagnostics.d.ts.map +1 -0
- package/dist/cli/relay-diagnostics.js +45 -0
- package/dist/cli/relay-diagnostics.js.map +1 -0
- package/dist/cli/remote-commands.d.ts +3 -0
- package/dist/cli/remote-commands.d.ts.map +1 -0
- package/dist/cli/remote-commands.js +253 -0
- package/dist/cli/remote-commands.js.map +1 -0
- package/dist/cli/resource-config-command.d.ts +9 -0
- package/dist/cli/resource-config-command.d.ts.map +1 -0
- package/dist/cli/resource-config-command.js +292 -0
- package/dist/cli/resource-config-command.js.map +1 -0
- package/dist/cli/service-commands.d.ts +2 -0
- package/dist/cli/service-commands.d.ts.map +1 -1
- package/dist/cli/service-commands.js +23 -1
- package/dist/cli/service-commands.js.map +1 -1
- package/dist/cli/session-commands.d.ts +2 -0
- package/dist/cli/session-commands.d.ts.map +1 -1
- package/dist/cli/session-commands.js +94 -3
- package/dist/cli/session-commands.js.map +1 -1
- package/dist/cli/setup-command.d.ts.map +1 -1
- package/dist/cli/setup-command.js +4 -1
- package/dist/cli/setup-command.js.map +1 -1
- package/dist/cli/skills-command.d.ts +2 -0
- package/dist/cli/skills-command.d.ts.map +1 -0
- package/dist/cli/skills-command.js +170 -0
- package/dist/cli/skills-command.js.map +1 -0
- package/dist/cli/supervisor-protocol.d.ts +17 -0
- package/dist/cli/supervisor-protocol.d.ts.map +1 -1
- package/dist/cli/supervisor-runtime-config.d.ts +4 -0
- package/dist/cli/supervisor-runtime-config.d.ts.map +1 -0
- package/dist/cli/supervisor-runtime-config.js +67 -0
- package/dist/cli/supervisor-runtime-config.js.map +1 -0
- package/dist/cli/supervisor.d.ts.map +1 -1
- package/dist/cli/supervisor.js +84 -50
- package/dist/cli/supervisor.js.map +1 -1
- package/dist/cli/workflow-commands.d.ts +3 -0
- package/dist/cli/workflow-commands.d.ts.map +1 -0
- package/dist/cli/workflow-commands.js +271 -0
- package/dist/cli/workflow-commands.js.map +1 -0
- package/dist/cli/workflow-contract-resolver.d.ts +13 -0
- package/dist/cli/workflow-contract-resolver.d.ts.map +1 -0
- package/dist/cli/workflow-contract-resolver.js +68 -0
- package/dist/cli/workflow-contract-resolver.js.map +1 -0
- package/dist/cli/workflow-run-json.d.ts +34 -0
- package/dist/cli/workflow-run-json.d.ts.map +1 -0
- package/dist/cli/workflow-run-json.js +118 -0
- package/dist/cli/workflow-run-json.js.map +1 -0
- package/dist/cli/worktree-commands.d.ts.map +1 -1
- package/dist/cli/worktree-commands.js +12 -2
- package/dist/cli/worktree-commands.js.map +1 -1
- package/dist/cli/ws-client.js +22 -2
- package/dist/cli/ws-client.js.map +1 -1
- package/dist/config-resolution/approval-rules.d.ts +5 -0
- package/dist/config-resolution/approval-rules.d.ts.map +1 -0
- package/dist/config-resolution/approval-rules.js +14 -0
- package/dist/config-resolution/approval-rules.js.map +1 -0
- package/dist/config-resolution/config-writer.d.ts +18 -0
- package/dist/config-resolution/config-writer.d.ts.map +1 -0
- package/dist/config-resolution/config-writer.js +97 -0
- package/dist/config-resolution/config-writer.js.map +1 -0
- package/dist/config-resolution/discovery.d.ts +18 -0
- package/dist/config-resolution/discovery.d.ts.map +1 -0
- package/dist/config-resolution/discovery.js +225 -0
- package/dist/config-resolution/discovery.js.map +1 -0
- package/dist/config-resolution/index.d.ts +4 -0
- package/dist/config-resolution/index.d.ts.map +1 -0
- package/dist/config-resolution/index.js +4 -0
- package/dist/config-resolution/index.js.map +1 -0
- package/dist/config-resolution/resolver.d.ts +16 -0
- package/dist/config-resolution/resolver.d.ts.map +1 -0
- package/dist/config-resolution/resolver.js +327 -0
- package/dist/config-resolution/resolver.js.map +1 -0
- package/dist/config-resolution/schema.d.ts +112 -0
- package/dist/config-resolution/schema.d.ts.map +1 -0
- package/dist/config-resolution/schema.js +177 -0
- package/dist/config-resolution/schema.js.map +1 -0
- package/dist/config-resolution/stable-json.d.ts +3 -0
- package/dist/config-resolution/stable-json.d.ts.map +1 -0
- package/dist/config-resolution/stable-json.js +18 -0
- package/dist/config-resolution/stable-json.js.map +1 -0
- package/dist/config-resolution/types.d.ts +120 -0
- package/dist/config-resolution/types.d.ts.map +1 -0
- package/dist/config-resolution/types.js +5 -0
- package/dist/config-resolution/types.js.map +1 -0
- package/dist/context/local-edge-candidates.d.ts +24 -0
- package/dist/context/local-edge-candidates.d.ts.map +1 -0
- package/dist/context/local-edge-candidates.js +184 -0
- package/dist/context/local-edge-candidates.js.map +1 -0
- package/dist/context/local-edge-crypto.d.ts +28 -0
- package/dist/context/local-edge-crypto.d.ts.map +1 -0
- package/dist/context/local-edge-crypto.js +76 -0
- package/dist/context/local-edge-crypto.js.map +1 -0
- package/dist/context/local-edge-decision-applications.d.ts +13 -0
- package/dist/context/local-edge-decision-applications.d.ts.map +1 -0
- package/dist/context/local-edge-decision-applications.js +78 -0
- package/dist/context/local-edge-decision-applications.js.map +1 -0
- package/dist/context/local-edge-decision-signature.d.ts +3 -0
- package/dist/context/local-edge-decision-signature.d.ts.map +1 -0
- package/dist/context/local-edge-decision-signature.js +67 -0
- package/dist/context/local-edge-decision-signature.js.map +1 -0
- package/dist/context/local-edge-engine.d.ts +38 -0
- package/dist/context/local-edge-engine.d.ts.map +1 -0
- package/dist/context/local-edge-engine.js +138 -0
- package/dist/context/local-edge-engine.js.map +1 -0
- package/dist/context/local-edge-key-store.d.ts +4 -0
- package/dist/context/local-edge-key-store.d.ts.map +1 -0
- package/dist/context/local-edge-key-store.js +21 -0
- package/dist/context/local-edge-key-store.js.map +1 -0
- package/dist/context/local-edge-metadata.d.ts +8 -0
- package/dist/context/local-edge-metadata.d.ts.map +1 -0
- package/dist/context/local-edge-metadata.js +95 -0
- package/dist/context/local-edge-metadata.js.map +1 -0
- package/dist/context/local-edge-paths.d.ts +4 -0
- package/dist/context/local-edge-paths.d.ts.map +1 -0
- package/dist/context/local-edge-paths.js +11 -0
- package/dist/context/local-edge-paths.js.map +1 -0
- package/dist/context/local-edge-store.d.ts +115 -0
- package/dist/context/local-edge-store.d.ts.map +1 -0
- package/dist/context/local-edge-store.js +233 -0
- package/dist/context/local-edge-store.js.map +1 -0
- package/dist/context/local-edge-sync.d.ts +32 -0
- package/dist/context/local-edge-sync.d.ts.map +1 -0
- package/dist/context/local-edge-sync.js +181 -0
- package/dist/context/local-edge-sync.js.map +1 -0
- package/dist/context/local-edge-types.d.ts +309 -0
- package/dist/context/local-edge-types.d.ts.map +1 -0
- package/dist/context/local-edge-types.js +5 -0
- package/dist/context/local-edge-types.js.map +1 -0
- package/dist/context-providers/registry.d.ts +5 -0
- package/dist/context-providers/registry.d.ts.map +1 -0
- package/dist/context-providers/registry.js +10 -0
- package/dist/context-providers/registry.js.map +1 -0
- package/dist/context-providers/repo-docs-provider.d.ts +19 -0
- package/dist/context-providers/repo-docs-provider.d.ts.map +1 -0
- package/dist/context-providers/repo-docs-provider.js +188 -0
- package/dist/context-providers/repo-docs-provider.js.map +1 -0
- package/dist/context-providers/types.d.ts +53 -0
- package/dist/context-providers/types.d.ts.map +1 -0
- package/dist/context-providers/types.js +2 -0
- package/dist/context-providers/types.js.map +1 -0
- package/dist/context-providers/viewport-vault-provider.d.ts +3 -0
- package/dist/context-providers/viewport-vault-provider.d.ts.map +1 -0
- package/dist/context-providers/viewport-vault-provider.js +73 -0
- package/dist/context-providers/viewport-vault-provider.js.map +1 -0
- package/dist/core/agent-registry.d.ts +2 -0
- package/dist/core/agent-registry.d.ts.map +1 -1
- package/dist/core/agent-registry.js +1 -1
- package/dist/core/agent-registry.js.map +1 -1
- package/dist/core/config-schema.d.ts +33 -3
- package/dist/core/config-schema.d.ts.map +1 -1
- package/dist/core/config-schema.js +27 -3
- package/dist/core/config-schema.js.map +1 -1
- package/dist/core/config.d.ts +63 -10
- package/dist/core/config.d.ts.map +1 -1
- package/dist/core/config.js +222 -17
- package/dist/core/config.js.map +1 -1
- package/dist/core/daemon.d.ts +14 -0
- package/dist/core/daemon.d.ts.map +1 -1
- package/dist/core/daemon.js +63 -0
- package/dist/core/daemon.js.map +1 -1
- package/dist/core/discovered-sessions.d.ts.map +1 -1
- package/dist/core/discovered-sessions.js +5 -0
- package/dist/core/discovered-sessions.js.map +1 -1
- package/dist/core/error-codes.d.ts +1 -0
- package/dist/core/error-codes.d.ts.map +1 -1
- package/dist/core/error-codes.js +1 -0
- package/dist/core/error-codes.js.map +1 -1
- package/dist/core/errors.js +2 -0
- package/dist/core/errors.js.map +1 -1
- package/dist/core/events.d.ts +30 -0
- package/dist/core/events.d.ts.map +1 -1
- package/dist/core/events.js.map +1 -1
- package/dist/core/interfaces.d.ts +15 -0
- package/dist/core/interfaces.d.ts.map +1 -1
- package/dist/core/machine-name.d.ts +3 -0
- package/dist/core/machine-name.d.ts.map +1 -0
- package/dist/core/machine-name.js +11 -0
- package/dist/core/machine-name.js.map +1 -0
- package/dist/core/package-meta.d.ts +12 -0
- package/dist/core/package-meta.d.ts.map +1 -0
- package/dist/core/package-meta.js +87 -0
- package/dist/core/package-meta.js.map +1 -0
- package/dist/core/runtime-identity.d.ts +45 -0
- package/dist/core/runtime-identity.d.ts.map +1 -0
- package/dist/core/runtime-identity.js +130 -0
- package/dist/core/runtime-identity.js.map +1 -0
- package/dist/core/session-context-prompt.d.ts +5 -0
- package/dist/core/session-context-prompt.d.ts.map +1 -0
- package/dist/core/session-context-prompt.js +85 -0
- package/dist/core/session-context-prompt.js.map +1 -0
- package/dist/core/session-manager.d.ts +6 -0
- package/dist/core/session-manager.d.ts.map +1 -1
- package/dist/core/session-manager.js +32 -0
- package/dist/core/session-manager.js.map +1 -1
- package/dist/core/session-state-file.d.ts.map +1 -1
- package/dist/core/session-state-file.js +3 -1
- package/dist/core/session-state-file.js.map +1 -1
- package/dist/core/types.d.ts +9 -0
- package/dist/core/types.d.ts.map +1 -1
- package/dist/core/workflow-linked-discovery.d.ts +17 -0
- package/dist/core/workflow-linked-discovery.d.ts.map +1 -0
- package/dist/core/workflow-linked-discovery.js +53 -0
- package/dist/core/workflow-linked-discovery.js.map +1 -0
- package/dist/directories/manager.d.ts +1 -0
- package/dist/directories/manager.d.ts.map +1 -1
- package/dist/directories/manager.js +46 -3
- package/dist/directories/manager.js.map +1 -1
- package/dist/discovery/claude.js +1 -0
- package/dist/discovery/claude.js.map +1 -1
- package/dist/discovery/codex-parser.d.ts +10 -0
- package/dist/discovery/codex-parser.d.ts.map +1 -0
- package/dist/discovery/codex-parser.js +246 -0
- package/dist/discovery/codex-parser.js.map +1 -0
- package/dist/discovery/codex-summary.d.ts +6 -0
- package/dist/discovery/codex-summary.d.ts.map +1 -0
- package/dist/discovery/codex-summary.js +27 -0
- package/dist/discovery/codex-summary.js.map +1 -0
- package/dist/discovery/codex.d.ts +23 -2
- package/dist/discovery/codex.d.ts.map +1 -1
- package/dist/discovery/codex.js +65 -271
- package/dist/discovery/codex.js.map +1 -1
- package/dist/discovery/dedupe.d.ts +3 -0
- package/dist/discovery/dedupe.d.ts.map +1 -0
- package/dist/discovery/dedupe.js +13 -0
- package/dist/discovery/dedupe.js.map +1 -0
- package/dist/discovery/jsonl-entry-parser.d.ts +36 -0
- package/dist/discovery/jsonl-entry-parser.d.ts.map +1 -0
- package/dist/discovery/jsonl-entry-parser.js +332 -0
- package/dist/discovery/jsonl-entry-parser.js.map +1 -0
- package/dist/discovery/jsonl-paths.d.ts +17 -0
- package/dist/discovery/jsonl-paths.d.ts.map +1 -0
- package/dist/discovery/jsonl-paths.js +56 -0
- package/dist/discovery/jsonl-paths.js.map +1 -0
- package/dist/discovery/jsonl-reader.d.ts +37 -48
- package/dist/discovery/jsonl-reader.d.ts.map +1 -1
- package/dist/discovery/jsonl-reader.js +103 -315
- package/dist/discovery/jsonl-reader.js.map +1 -1
- package/dist/hooks/capabilities.d.ts +17 -0
- package/dist/hooks/capabilities.d.ts.map +1 -0
- package/dist/hooks/capabilities.js +114 -0
- package/dist/hooks/capabilities.js.map +1 -0
- package/dist/hooks/index.d.ts +2 -0
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +1 -0
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/installers/claude.js +4 -1
- package/dist/hooks/installers/claude.js.map +1 -1
- package/dist/hooks/plan-extractor.d.ts +20 -0
- package/dist/hooks/plan-extractor.d.ts.map +1 -0
- package/dist/hooks/plan-extractor.js +123 -0
- package/dist/hooks/plan-extractor.js.map +1 -0
- package/dist/hooks/platform-plan-sync.d.ts +19 -0
- package/dist/hooks/platform-plan-sync.d.ts.map +1 -0
- package/dist/hooks/platform-plan-sync.js +57 -0
- package/dist/hooks/platform-plan-sync.js.map +1 -0
- package/dist/hooks/router.d.ts +1 -0
- package/dist/hooks/router.d.ts.map +1 -1
- package/dist/hooks/router.js +39 -75
- package/dist/hooks/router.js.map +1 -1
- package/dist/hooks/specific-events.d.ts +11 -0
- package/dist/hooks/specific-events.d.ts.map +1 -0
- package/dist/hooks/specific-events.js +125 -0
- package/dist/hooks/specific-events.js.map +1 -0
- package/dist/hooks/supervision.d.ts +2 -0
- package/dist/hooks/supervision.d.ts.map +1 -1
- package/dist/hooks/supervision.js +12 -0
- package/dist/hooks/supervision.js.map +1 -1
- package/dist/hooks/types.d.ts +17 -1
- package/dist/hooks/types.d.ts.map +1 -1
- package/dist/hooks/types.js +29 -0
- package/dist/hooks/types.js.map +1 -1
- package/dist/index.d.ts +6 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +81 -4
- package/dist/index.js.map +1 -1
- package/dist/plugins/loader.d.ts.map +1 -1
- package/dist/plugins/loader.js +14 -0
- package/dist/plugins/loader.js.map +1 -1
- package/dist/relay/bridge-backoff.d.ts +3 -0
- package/dist/relay/bridge-backoff.d.ts.map +1 -0
- package/dist/relay/bridge-backoff.js +10 -0
- package/dist/relay/bridge-backoff.js.map +1 -0
- package/dist/relay/bridge-connections.d.ts +26 -0
- package/dist/relay/bridge-connections.d.ts.map +1 -0
- package/dist/relay/bridge-connections.js +34 -0
- package/dist/relay/bridge-connections.js.map +1 -0
- package/dist/relay/bridge-constants.d.ts +12 -0
- package/dist/relay/bridge-constants.d.ts.map +1 -0
- package/dist/relay/bridge-constants.js +12 -0
- package/dist/relay/bridge-constants.js.map +1 -0
- package/dist/relay/bridge-crypto.d.ts +19 -0
- package/dist/relay/bridge-crypto.d.ts.map +1 -0
- package/dist/relay/bridge-crypto.js +72 -0
- package/dist/relay/bridge-crypto.js.map +1 -0
- package/dist/relay/bridge-daemon-key-registration.d.ts +16 -0
- package/dist/relay/bridge-daemon-key-registration.d.ts.map +1 -0
- package/dist/relay/bridge-daemon-key-registration.js +70 -0
- package/dist/relay/bridge-daemon-key-registration.js.map +1 -0
- package/dist/relay/bridge-errors.d.ts +8 -0
- package/dist/relay/bridge-errors.d.ts.map +1 -0
- package/dist/relay/bridge-errors.js +23 -0
- package/dist/relay/bridge-errors.js.map +1 -0
- package/dist/relay/bridge-frame-logger.d.ts +2 -0
- package/dist/relay/bridge-frame-logger.d.ts.map +1 -0
- package/dist/relay/bridge-frame-logger.js +37 -0
- package/dist/relay/bridge-frame-logger.js.map +1 -0
- package/dist/relay/bridge-handshake-profile.d.ts +3 -0
- package/dist/relay/bridge-handshake-profile.d.ts.map +1 -0
- package/dist/relay/bridge-handshake-profile.js +7 -0
- package/dist/relay/bridge-handshake-profile.js.map +1 -0
- package/dist/relay/bridge-identity-store.d.ts +9 -0
- package/dist/relay/bridge-identity-store.d.ts.map +1 -0
- package/dist/relay/bridge-identity-store.js +73 -0
- package/dist/relay/bridge-identity-store.js.map +1 -0
- package/dist/relay/bridge-jwt.d.ts +18 -0
- package/dist/relay/bridge-jwt.d.ts.map +1 -0
- package/dist/relay/bridge-jwt.js +130 -0
- package/dist/relay/bridge-jwt.js.map +1 -0
- package/dist/relay/bridge-key-exchange.d.ts +46 -0
- package/dist/relay/bridge-key-exchange.d.ts.map +1 -0
- package/dist/relay/bridge-key-exchange.js +186 -0
- package/dist/relay/bridge-key-exchange.js.map +1 -0
- package/dist/relay/bridge-network.d.ts +12 -0
- package/dist/relay/bridge-network.d.ts.map +1 -0
- package/dist/relay/bridge-network.js +90 -0
- package/dist/relay/bridge-network.js.map +1 -0
- package/dist/relay/bridge-noise-v3.d.ts +74 -0
- package/dist/relay/bridge-noise-v3.d.ts.map +1 -0
- package/dist/relay/bridge-noise-v3.js +406 -0
- package/dist/relay/bridge-noise-v3.js.map +1 -0
- package/dist/relay/bridge-pairing-channel.d.ts +12 -0
- package/dist/relay/bridge-pairing-channel.d.ts.map +1 -0
- package/dist/relay/bridge-pairing-channel.js +30 -0
- package/dist/relay/bridge-pairing-channel.js.map +1 -0
- package/dist/relay/bridge-pairing-control-handler.d.ts +26 -0
- package/dist/relay/bridge-pairing-control-handler.d.ts.map +1 -0
- package/dist/relay/bridge-pairing-control-handler.js +136 -0
- package/dist/relay/bridge-pairing-control-handler.js.map +1 -0
- package/dist/relay/bridge-relay-sessions.d.ts +45 -0
- package/dist/relay/bridge-relay-sessions.d.ts.map +1 -0
- package/dist/relay/bridge-relay-sessions.js +88 -0
- package/dist/relay/bridge-relay-sessions.js.map +1 -0
- package/dist/relay/bridge-token-issuer.d.ts +32 -0
- package/dist/relay/bridge-token-issuer.d.ts.map +1 -0
- package/dist/relay/bridge-token-issuer.js +173 -0
- package/dist/relay/bridge-token-issuer.js.map +1 -0
- package/dist/relay/daemon-relay-bridge.d.ts +89 -0
- package/dist/relay/daemon-relay-bridge.d.ts.map +1 -0
- package/dist/relay/daemon-relay-bridge.js +541 -0
- package/dist/relay/daemon-relay-bridge.js.map +1 -0
- package/dist/relay/relay-control-frames.d.ts +31 -0
- package/dist/relay/relay-control-frames.d.ts.map +1 -0
- package/dist/relay/relay-control-frames.js +65 -0
- package/dist/relay/relay-control-frames.js.map +1 -0
- package/dist/server/auth.d.ts +3 -2
- package/dist/server/auth.d.ts.map +1 -1
- package/dist/server/auth.js +14 -10
- package/dist/server/auth.js.map +1 -1
- package/dist/server/discovered-session-window.d.ts +4 -0
- package/dist/server/discovered-session-window.d.ts.map +1 -0
- package/dist/server/discovered-session-window.js +5 -0
- package/dist/server/discovered-session-window.js.map +1 -0
- package/dist/server/hello-builder.d.ts +66 -3
- package/dist/server/hello-builder.d.ts.map +1 -1
- package/dist/server/hello-builder.js +145 -20
- package/dist/server/hello-builder.js.map +1 -1
- package/dist/server/http-context-routes.d.ts +3 -0
- package/dist/server/http-context-routes.d.ts.map +1 -0
- package/dist/server/http-context-routes.js +119 -0
- package/dist/server/http-context-routes.js.map +1 -0
- package/dist/server/http-health-routes.d.ts +10 -0
- package/dist/server/http-health-routes.d.ts.map +1 -0
- package/dist/server/http-health-routes.js +58 -0
- package/dist/server/http-health-routes.js.map +1 -0
- package/dist/server/http-lifecycle-routes.d.ts +6 -0
- package/dist/server/http-lifecycle-routes.d.ts.map +1 -0
- package/dist/server/http-lifecycle-routes.js +17 -0
- package/dist/server/http-lifecycle-routes.js.map +1 -0
- package/dist/server/http-pairing-routes.d.ts +14 -0
- package/dist/server/http-pairing-routes.d.ts.map +1 -0
- package/dist/server/http-pairing-routes.js +110 -0
- package/dist/server/http-pairing-routes.js.map +1 -0
- package/dist/server/http-request-schemas.d.ts +114 -0
- package/dist/server/http-request-schemas.d.ts.map +1 -0
- package/dist/server/http-request-schemas.js +137 -0
- package/dist/server/http-request-schemas.js.map +1 -0
- package/dist/server/http-route-types.d.ts +11 -0
- package/dist/server/http-route-types.d.ts.map +1 -0
- package/dist/server/http-route-types.js +2 -0
- package/dist/server/http-route-types.js.map +1 -0
- package/dist/server/http-server.d.ts +4 -9
- package/dist/server/http-server.d.ts.map +1 -1
- package/dist/server/http-server.js +152 -348
- package/dist/server/http-server.js.map +1 -1
- package/dist/server/http-session-routes.d.ts +4 -0
- package/dist/server/http-session-routes.d.ts.map +1 -0
- package/dist/server/http-session-routes.js +234 -0
- package/dist/server/http-session-routes.js.map +1 -0
- package/dist/server/pairing-file-store.d.ts +10 -0
- package/dist/server/pairing-file-store.d.ts.map +1 -0
- package/dist/server/pairing-file-store.js +69 -0
- package/dist/server/pairing-file-store.js.map +1 -0
- package/dist/server/pairing-identity-store.d.ts +5 -0
- package/dist/server/pairing-identity-store.d.ts.map +1 -0
- package/dist/server/pairing-identity-store.js +121 -0
- package/dist/server/pairing-identity-store.js.map +1 -0
- package/dist/server/pairing-offer-types.d.ts +98 -0
- package/dist/server/pairing-offer-types.d.ts.map +1 -0
- package/dist/server/pairing-offer-types.js +2 -0
- package/dist/server/pairing-offer-types.js.map +1 -0
- package/dist/server/pairing-offers.d.ts +4 -53
- package/dist/server/pairing-offers.d.ts.map +1 -1
- package/dist/server/pairing-offers.js +235 -386
- package/dist/server/pairing-offers.js.map +1 -1
- package/dist/server/pairing-peer-bindings.d.ts +18 -0
- package/dist/server/pairing-peer-bindings.d.ts.map +1 -0
- package/dist/server/pairing-peer-bindings.js +198 -0
- package/dist/server/pairing-peer-bindings.js.map +1 -0
- package/dist/server/rate-limiter.d.ts.map +1 -1
- package/dist/server/rate-limiter.js +4 -1
- package/dist/server/rate-limiter.js.map +1 -1
- package/dist/server/replay-events.d.ts +6 -0
- package/dist/server/replay-events.d.ts.map +1 -0
- package/dist/server/replay-events.js +104 -0
- package/dist/server/replay-events.js.map +1 -0
- package/dist/server/replay-persistence.d.ts +18 -0
- package/dist/server/replay-persistence.d.ts.map +1 -0
- package/dist/server/replay-persistence.js +123 -0
- package/dist/server/replay-persistence.js.map +1 -0
- package/dist/server/replay-types.d.ts +25 -0
- package/dist/server/replay-types.d.ts.map +1 -0
- package/dist/server/replay-types.js +2 -0
- package/dist/server/replay-types.js.map +1 -0
- package/dist/server/ring-buffer.d.ts +33 -19
- package/dist/server/ring-buffer.d.ts.map +1 -1
- package/dist/server/ring-buffer.js +176 -14
- package/dist/server/ring-buffer.js.map +1 -1
- package/dist/server/security.d.ts.map +1 -1
- package/dist/server/security.js +5 -1
- package/dist/server/security.js.map +1 -1
- package/dist/server/session-message-reader.d.ts +15 -0
- package/dist/server/session-message-reader.d.ts.map +1 -0
- package/dist/server/session-message-reader.js +107 -0
- package/dist/server/session-message-reader.js.map +1 -0
- package/dist/server/ws-command-handlers.d.ts +4 -1
- package/dist/server/ws-command-handlers.d.ts.map +1 -1
- package/dist/server/ws-command-handlers.js +39 -76
- package/dist/server/ws-command-handlers.js.map +1 -1
- package/dist/server/ws-daemon-event-bridge.d.ts.map +1 -1
- package/dist/server/ws-daemon-event-bridge.js +66 -5
- package/dist/server/ws-daemon-event-bridge.js.map +1 -1
- package/dist/server/ws-protocol.d.ts +178 -5
- package/dist/server/ws-protocol.d.ts.map +1 -1
- package/dist/server/ws-protocol.js +114 -5
- package/dist/server/ws-protocol.js.map +1 -1
- package/dist/server/ws-server.d.ts.map +1 -1
- package/dist/server/ws-server.js +27 -3
- package/dist/server/ws-server.js.map +1 -1
- package/dist/server/ws-session-command-handlers.d.ts +29 -0
- package/dist/server/ws-session-command-handlers.d.ts.map +1 -0
- package/dist/server/ws-session-command-handlers.js +276 -0
- package/dist/server/ws-session-command-handlers.js.map +1 -0
- package/dist/server/ws-workflow-command-handlers.d.ts +17 -0
- package/dist/server/ws-workflow-command-handlers.d.ts.map +1 -0
- package/dist/server/ws-workflow-command-handlers.js +68 -0
- package/dist/server/ws-workflow-command-handlers.js.map +1 -0
- package/dist/session-enrichment/git.d.ts +9 -0
- package/dist/session-enrichment/git.d.ts.map +1 -0
- package/dist/session-enrichment/git.js +48 -0
- package/dist/session-enrichment/git.js.map +1 -0
- package/dist/startup-relay-security.d.ts +3 -0
- package/dist/startup-relay-security.d.ts.map +1 -0
- package/dist/startup-relay-security.js +61 -0
- package/dist/startup-relay-security.js.map +1 -0
- package/dist/startup-session-persistence.d.ts +7 -0
- package/dist/startup-session-persistence.d.ts.map +1 -0
- package/dist/startup-session-persistence.js +72 -0
- package/dist/startup-session-persistence.js.map +1 -0
- package/dist/startup.d.ts +9 -0
- package/dist/startup.d.ts.map +1 -1
- package/dist/startup.js +184 -77
- package/dist/startup.js.map +1 -1
- package/dist/tracking/git-tracker.d.ts +4 -0
- package/dist/tracking/git-tracker.d.ts.map +1 -1
- package/dist/tracking/git-tracker.js +80 -15
- package/dist/tracking/git-tracker.js.map +1 -1
- package/dist/workflows/approval-on-reject.d.ts +17 -0
- package/dist/workflows/approval-on-reject.d.ts.map +1 -0
- package/dist/workflows/approval-on-reject.js +62 -0
- package/dist/workflows/approval-on-reject.js.map +1 -0
- package/dist/workflows/artifact-collector.d.ts +11 -0
- package/dist/workflows/artifact-collector.d.ts.map +1 -0
- package/dist/workflows/artifact-collector.js +59 -0
- package/dist/workflows/artifact-collector.js.map +1 -0
- package/dist/workflows/contract-binding.d.ts +3 -0
- package/dist/workflows/contract-binding.d.ts.map +1 -0
- package/dist/workflows/contract-binding.js +19 -0
- package/dist/workflows/contract-binding.js.map +1 -0
- package/dist/workflows/daemon-session.d.ts +36 -0
- package/dist/workflows/daemon-session.d.ts.map +1 -0
- package/dist/workflows/daemon-session.js +115 -0
- package/dist/workflows/daemon-session.js.map +1 -0
- package/dist/workflows/event-types.d.ts +10 -0
- package/dist/workflows/event-types.d.ts.map +1 -0
- package/dist/workflows/event-types.js +2 -0
- package/dist/workflows/event-types.js.map +1 -0
- package/dist/workflows/expression.d.ts +74 -0
- package/dist/workflows/expression.d.ts.map +1 -0
- package/dist/workflows/expression.js +132 -0
- package/dist/workflows/expression.js.map +1 -0
- package/dist/workflows/hook-registry.d.ts +24 -0
- package/dist/workflows/hook-registry.d.ts.map +1 -0
- package/dist/workflows/hook-registry.js +52 -0
- package/dist/workflows/hook-registry.js.map +1 -0
- package/dist/workflows/hook-types.d.ts +21 -0
- package/dist/workflows/hook-types.d.ts.map +1 -0
- package/dist/workflows/hook-types.js +2 -0
- package/dist/workflows/hook-types.js.map +1 -0
- package/dist/workflows/inline-agent-types.d.ts +21 -0
- package/dist/workflows/inline-agent-types.d.ts.map +1 -0
- package/dist/workflows/inline-agent-types.js +2 -0
- package/dist/workflows/inline-agent-types.js.map +1 -0
- package/dist/workflows/inline-agents.d.ts +5 -0
- package/dist/workflows/inline-agents.d.ts.map +1 -0
- package/dist/workflows/inline-agents.js +89 -0
- package/dist/workflows/inline-agents.js.map +1 -0
- package/dist/workflows/loop-executor.d.ts +17 -0
- package/dist/workflows/loop-executor.d.ts.map +1 -0
- package/dist/workflows/loop-executor.js +173 -0
- package/dist/workflows/loop-executor.js.map +1 -0
- package/dist/workflows/node-executor.d.ts +12 -0
- package/dist/workflows/node-executor.d.ts.map +1 -0
- package/dist/workflows/node-executor.js +179 -0
- package/dist/workflows/node-executor.js.map +1 -0
- package/dist/workflows/node-registry.d.ts +42 -0
- package/dist/workflows/node-registry.d.ts.map +1 -0
- package/dist/workflows/node-registry.js +124 -0
- package/dist/workflows/node-registry.js.map +1 -0
- package/dist/workflows/parser.d.ts +17 -0
- package/dist/workflows/parser.d.ts.map +1 -0
- package/dist/workflows/parser.js +250 -0
- package/dist/workflows/parser.js.map +1 -0
- package/dist/workflows/platform-command-applier.d.ts +11 -0
- package/dist/workflows/platform-command-applier.d.ts.map +1 -0
- package/dist/workflows/platform-command-applier.js +41 -0
- package/dist/workflows/platform-command-applier.js.map +1 -0
- package/dist/workflows/platform-runtime-command.d.ts +12 -0
- package/dist/workflows/platform-runtime-command.d.ts.map +1 -0
- package/dist/workflows/platform-runtime-command.js +37 -0
- package/dist/workflows/platform-runtime-command.js.map +1 -0
- package/dist/workflows/platform-sync.d.ts +37 -0
- package/dist/workflows/platform-sync.d.ts.map +1 -0
- package/dist/workflows/platform-sync.js +306 -0
- package/dist/workflows/platform-sync.js.map +1 -0
- package/dist/workflows/plugin-loader.d.ts +28 -0
- package/dist/workflows/plugin-loader.d.ts.map +1 -0
- package/dist/workflows/plugin-loader.js +134 -0
- package/dist/workflows/plugin-loader.js.map +1 -0
- package/dist/workflows/preflight.d.ts +9 -0
- package/dist/workflows/preflight.d.ts.map +1 -0
- package/dist/workflows/preflight.js +147 -0
- package/dist/workflows/preflight.js.map +1 -0
- package/dist/workflows/prompt-output.d.ts +6 -0
- package/dist/workflows/prompt-output.d.ts.map +1 -0
- package/dist/workflows/prompt-output.js +78 -0
- package/dist/workflows/prompt-output.js.map +1 -0
- package/dist/workflows/retry-classifier.d.ts +18 -0
- package/dist/workflows/retry-classifier.d.ts.map +1 -0
- package/dist/workflows/retry-classifier.js +30 -0
- package/dist/workflows/retry-classifier.js.map +1 -0
- package/dist/workflows/review-packet.d.ts +3 -0
- package/dist/workflows/review-packet.d.ts.map +1 -0
- package/dist/workflows/review-packet.js +149 -0
- package/dist/workflows/review-packet.js.map +1 -0
- package/dist/workflows/run-types.d.ts +191 -0
- package/dist/workflows/run-types.d.ts.map +1 -0
- package/dist/workflows/run-types.js +2 -0
- package/dist/workflows/run-types.js.map +1 -0
- package/dist/workflows/runner-canceler.d.ts +22 -0
- package/dist/workflows/runner-canceler.d.ts.map +1 -0
- package/dist/workflows/runner-canceler.js +91 -0
- package/dist/workflows/runner-canceler.js.map +1 -0
- package/dist/workflows/runner-reconciler.d.ts +19 -0
- package/dist/workflows/runner-reconciler.d.ts.map +1 -0
- package/dist/workflows/runner-reconciler.js +109 -0
- package/dist/workflows/runner-reconciler.js.map +1 -0
- package/dist/workflows/runner-resumer.d.ts +33 -0
- package/dist/workflows/runner-resumer.d.ts.map +1 -0
- package/dist/workflows/runner-resumer.js +81 -0
- package/dist/workflows/runner-resumer.js.map +1 -0
- package/dist/workflows/runner-scheduler.d.ts +35 -0
- package/dist/workflows/runner-scheduler.d.ts.map +1 -0
- package/dist/workflows/runner-scheduler.js +211 -0
- package/dist/workflows/runner-scheduler.js.map +1 -0
- package/dist/workflows/runner-shared.d.ts +21 -0
- package/dist/workflows/runner-shared.d.ts.map +1 -0
- package/dist/workflows/runner-shared.js +59 -0
- package/dist/workflows/runner-shared.js.map +1 -0
- package/dist/workflows/runner.d.ts +36 -0
- package/dist/workflows/runner.d.ts.map +1 -0
- package/dist/workflows/runner.js +289 -0
- package/dist/workflows/runner.js.map +1 -0
- package/dist/workflows/runtime-helpers.d.ts +40 -0
- package/dist/workflows/runtime-helpers.d.ts.map +1 -0
- package/dist/workflows/runtime-helpers.js +170 -0
- package/dist/workflows/runtime-helpers.js.map +1 -0
- package/dist/workflows/session-completion.d.ts +7 -0
- package/dist/workflows/session-completion.d.ts.map +1 -0
- package/dist/workflows/session-completion.js +89 -0
- package/dist/workflows/session-completion.js.map +1 -0
- package/dist/workflows/session-links.d.ts +21 -0
- package/dist/workflows/session-links.d.ts.map +1 -0
- package/dist/workflows/session-links.js +77 -0
- package/dist/workflows/session-links.js.map +1 -0
- package/dist/workflows/session-output.d.ts +21 -0
- package/dist/workflows/session-output.d.ts.map +1 -0
- package/dist/workflows/session-output.js +75 -0
- package/dist/workflows/session-output.js.map +1 -0
- package/dist/workflows/shell-abort-registry.d.ts +11 -0
- package/dist/workflows/shell-abort-registry.d.ts.map +1 -0
- package/dist/workflows/shell-abort-registry.js +35 -0
- package/dist/workflows/shell-abort-registry.js.map +1 -0
- package/dist/workflows/store.d.ts +14 -0
- package/dist/workflows/store.d.ts.map +1 -0
- package/dist/workflows/store.js +160 -0
- package/dist/workflows/store.js.map +1 -0
- package/dist/workflows/structured-outputs.d.ts +19 -0
- package/dist/workflows/structured-outputs.d.ts.map +1 -0
- package/dist/workflows/structured-outputs.js +95 -0
- package/dist/workflows/structured-outputs.js.map +1 -0
- package/dist/workflows/subflow-executor.d.ts +15 -0
- package/dist/workflows/subflow-executor.d.ts.map +1 -0
- package/dist/workflows/subflow-executor.js +177 -0
- package/dist/workflows/subflow-executor.js.map +1 -0
- package/dist/workflows/trigger-rule.d.ts +22 -0
- package/dist/workflows/trigger-rule.d.ts.map +1 -0
- package/dist/workflows/trigger-rule.js +57 -0
- package/dist/workflows/trigger-rule.js.map +1 -0
- package/dist/workflows/types.d.ts +240 -0
- package/dist/workflows/types.d.ts.map +1 -0
- package/dist/workflows/types.js +2 -0
- package/dist/workflows/types.js.map +1 -0
- package/dist/workflows/workflow-executor-schema.d.ts +51 -0
- package/dist/workflows/workflow-executor-schema.d.ts.map +1 -0
- package/dist/workflows/workflow-executor-schema.js +81 -0
- package/dist/workflows/workflow-executor-schema.js.map +1 -0
- package/dist/workflows/workflow-schema.d.ts +573 -0
- package/dist/workflows/workflow-schema.d.ts.map +1 -0
- package/dist/workflows/workflow-schema.js +294 -0
- package/dist/workflows/workflow-schema.js.map +1 -0
- package/dist/workflows/workflow-source.d.ts +3 -0
- package/dist/workflows/workflow-source.d.ts.map +1 -0
- package/dist/workflows/workflow-source.js +29 -0
- package/dist/workflows/workflow-source.js.map +1 -0
- package/docs/configuration.md +97 -14
- package/docs/developer-workflows.md +18 -2
- package/docs/protocol-matrix.json +120 -11
- package/docs/relay-noise-conformance-vectors.json +41 -0
- package/docs/relay-noise-v3-conformance-vectors.json +50 -0
- package/docs/releasing.md +19 -51
- package/docs/security.md +9 -11
- package/docs/testing.md +3 -3
- package/node_modules/@viewportai/context-engine/README.md +33 -0
- package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/README.md +37 -0
- package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/bundle-manifest.json +50 -0
- package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/erase-receipt.json +10 -0
- package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/event.json +29 -0
- package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/hpke-key-grant.json +24 -0
- package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/key-grant.json +21 -0
- package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/profile.json +12 -0
- package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/signed-event.json +28 -0
- package/node_modules/@viewportai/context-engine/fixtures/protocol-vectors/standalone-decoder.mjs +124 -0
- package/node_modules/@viewportai/context-engine/package.json +11 -0
- package/node_modules/@viewportai/context-engine/schemas/context_bundle_manifest_v1.schema.json +134 -0
- package/node_modules/@viewportai/context-engine/schemas/context_erase_receipt_v1.schema.json +27 -0
- package/node_modules/@viewportai/context-engine/schemas/context_event_v1.schema.json +214 -0
- package/node_modules/@viewportai/context-engine/schemas/context_key_grant_hpke_draft_01.schema.json +27 -0
- package/node_modules/@viewportai/context-engine/schemas/context_key_grant_v1.schema.json +24 -0
- package/node_modules/@viewportai/context-engine/schemas/context_profile_v1.schema.json +24 -0
- package/node_modules/@viewportai/context-engine/src/cli.js +177 -0
- package/node_modules/@viewportai/context-engine/src/crypto/canonical.js +21 -0
- package/node_modules/@viewportai/context-engine/src/crypto/envelope.js +37 -0
- package/node_modules/@viewportai/context-engine/src/crypto/hpke-grants.js +298 -0
- package/node_modules/@viewportai/context-engine/src/crypto/keys.js +122 -0
- package/node_modules/@viewportai/context-engine/src/crypto/signatures.js +23 -0
- package/node_modules/@viewportai/context-engine/src/index.js +12 -0
- package/node_modules/@viewportai/context-engine/src/protocol/schemas.js +50 -0
- package/node_modules/@viewportai/context-engine/src/repo/access-model.js +170 -0
- package/node_modules/@viewportai/context-engine/src/repo/bundles.js +180 -0
- package/node_modules/@viewportai/context-engine/src/repo/candidates.js +205 -0
- package/node_modules/@viewportai/context-engine/src/repo/devices.js +141 -0
- package/node_modules/@viewportai/context-engine/src/repo/events.js +87 -0
- package/node_modules/@viewportai/context-engine/src/repo/files.js +33 -0
- package/node_modules/@viewportai/context-engine/src/repo/identities.js +128 -0
- package/node_modules/@viewportai/context-engine/src/repo/key-store.js +126 -0
- package/node_modules/@viewportai/context-engine/src/repo/materializer.js +299 -0
- package/node_modules/@viewportai/context-engine/src/repo/membership.js +177 -0
- package/node_modules/@viewportai/context-engine/src/repo/paths.js +25 -0
- package/node_modules/@viewportai/context-engine/src/repo/profiles.js +54 -0
- package/node_modules/@viewportai/context-engine/src/repo/receipts.js +68 -0
- package/node_modules/@viewportai/context-engine/src/repo/sync.js +163 -0
- package/node_modules/@viewportai/context-engine/src/repo/users.js +134 -0
- package/node_modules/@viewportai/context-engine/src/repo/vault.js +527 -0
- package/node_modules/@viewportai/context-engine/src/store/local-semantic.js +69 -0
- package/node_modules/@viewportai/context-engine/src/store/search.js +25 -0
- package/node_modules/@viewportai/context-engine/src/store/sqlite.js +76 -0
- package/package.json +22 -7
- package/schemas/viewport-config-v1.schema.json +209 -0
- package/schemas/workflow-v1.schema.json +245 -0
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
import { addEvent, renderTemplate, ShellNodeError } from './runtime-helpers.js';
|
|
2
|
+
import { collectNodeArtifacts } from './artifact-collector.js';
|
|
3
|
+
import { readPromptNodeOutput, readPromptNodeTranscriptExcerpt } from './prompt-output.js';
|
|
4
|
+
import { classifyRetry } from './retry-classifier.js';
|
|
5
|
+
import { NODE_EXECUTORS } from './node-registry.js';
|
|
6
|
+
import { runWorkflowDaemonSession } from './daemon-session.js';
|
|
7
|
+
import { appendInlineAgentResults, runInlineAgents } from './inline-agents.js';
|
|
8
|
+
export async function executeWorkflowNode(context, run, nodeId, node) {
|
|
9
|
+
const state = run.nodes[nodeId];
|
|
10
|
+
if (!state)
|
|
11
|
+
return 'completed';
|
|
12
|
+
if (state.status === 'completed' || state.status === 'skipped')
|
|
13
|
+
return 'completed';
|
|
14
|
+
state.status = 'running';
|
|
15
|
+
state.startedAt = Date.now();
|
|
16
|
+
run.updatedAt = state.startedAt;
|
|
17
|
+
addEvent(run, 'node-started', `Node ${nodeId} started`, undefined, nodeId);
|
|
18
|
+
await context.saveAndEmit(run);
|
|
19
|
+
const maxAttempts = node.retry?.maxAttempts ?? 1;
|
|
20
|
+
const backoffMs = (node.retry?.backoffSeconds ?? 0) * 1000;
|
|
21
|
+
let attempt = 0;
|
|
22
|
+
let lastError = null;
|
|
23
|
+
while (attempt < maxAttempts) {
|
|
24
|
+
attempt += 1;
|
|
25
|
+
try {
|
|
26
|
+
// Look up the per-type executor in the registry. Built-ins are
|
|
27
|
+
// registered in `node-registry.ts`; the plugin loader will extend the
|
|
28
|
+
// same map with `defineNode()` registrations from
|
|
29
|
+
// `~/.viewport/plugins.json` once that integration ships.
|
|
30
|
+
const executor = NODE_EXECUTORS.get(node.type);
|
|
31
|
+
if (!executor) {
|
|
32
|
+
throw new Error(`No executor registered for node type '${node.type}' on node ${nodeId}.`);
|
|
33
|
+
}
|
|
34
|
+
const outcome = await executor(context, run, nodeId, node, {
|
|
35
|
+
executePromptNode,
|
|
36
|
+
executeGateNode,
|
|
37
|
+
blockForApproval,
|
|
38
|
+
});
|
|
39
|
+
if (outcome.result === 'blocked')
|
|
40
|
+
return 'blocked';
|
|
41
|
+
await collectAndRecordArtifacts(context, run, nodeId, node, outcome.artifactCwd ?? run.directoryPath);
|
|
42
|
+
state.status = 'completed';
|
|
43
|
+
state.completedAt = Date.now();
|
|
44
|
+
run.updatedAt = state.completedAt;
|
|
45
|
+
addEvent(run, 'node-completed', `Node ${nodeId} completed`, undefined, nodeId);
|
|
46
|
+
await context.saveAndEmit(run);
|
|
47
|
+
return 'completed';
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
lastError = error;
|
|
51
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
52
|
+
if (error instanceof ShellNodeError) {
|
|
53
|
+
state.output = error.output || state.output;
|
|
54
|
+
state.exitCode = error.exitCode ?? undefined;
|
|
55
|
+
}
|
|
56
|
+
const decision = classifyRetry(message, node.retry);
|
|
57
|
+
const remaining = maxAttempts - attempt;
|
|
58
|
+
if (decision === 'retry' && remaining > 0) {
|
|
59
|
+
addEvent(run, 'node-retry', `Node ${nodeId} retry ${attempt + 1}/${maxAttempts}: ${message}`, { attempt, message, backoffMs }, nodeId);
|
|
60
|
+
run.updatedAt = Date.now();
|
|
61
|
+
await context.saveAndEmit(run);
|
|
62
|
+
if (backoffMs > 0)
|
|
63
|
+
await new Promise((resolve) => setTimeout(resolve, backoffMs));
|
|
64
|
+
continue;
|
|
65
|
+
}
|
|
66
|
+
break;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
const message = lastError instanceof Error ? lastError.message : String(lastError);
|
|
70
|
+
state.status = 'failed';
|
|
71
|
+
state.error = message;
|
|
72
|
+
state.completedAt = Date.now();
|
|
73
|
+
state.attempts = attempt;
|
|
74
|
+
run.updatedAt = state.completedAt;
|
|
75
|
+
addEvent(run, 'node-failed', `Node ${nodeId} failed: ${message}`, { attempts: attempt }, nodeId);
|
|
76
|
+
await context.saveAndEmit(run);
|
|
77
|
+
throw lastError instanceof Error ? lastError : new Error(message);
|
|
78
|
+
}
|
|
79
|
+
async function executeGateNode(context, run, nodeId, node) {
|
|
80
|
+
const gate = node.gate;
|
|
81
|
+
if (gate.type === 'human_review') {
|
|
82
|
+
await blockForApproval(context, run, nodeId, await renderTemplate(gate.prompt, run));
|
|
83
|
+
addEvent(run, 'gate-blocked', `Human review gate ${nodeId} is waiting`, { gate }, nodeId);
|
|
84
|
+
await context.saveAndEmit(run);
|
|
85
|
+
return 'blocked';
|
|
86
|
+
}
|
|
87
|
+
if (gate.type === 'schedule') {
|
|
88
|
+
const waitUntil = new Date(await renderTemplate(gate.waitUntil, run));
|
|
89
|
+
if (!Number.isFinite(waitUntil.getTime())) {
|
|
90
|
+
throw new Error(`Schedule gate ${nodeId} has an invalid waitUntil value`);
|
|
91
|
+
}
|
|
92
|
+
if (waitUntil.getTime() > Date.now()) {
|
|
93
|
+
const state = run.nodes[nodeId];
|
|
94
|
+
if (state) {
|
|
95
|
+
state.status = 'blocked';
|
|
96
|
+
state.output = `Waiting until ${waitUntil.toISOString()}`;
|
|
97
|
+
}
|
|
98
|
+
run.status = 'blocked';
|
|
99
|
+
run.updatedAt = Date.now();
|
|
100
|
+
addEvent(run, 'gate-blocked', `Schedule gate ${nodeId} is waiting until ${waitUntil.toISOString()}`, { gate, waitUntil: waitUntil.toISOString() }, nodeId);
|
|
101
|
+
await context.saveAndEmit(run);
|
|
102
|
+
return 'blocked';
|
|
103
|
+
}
|
|
104
|
+
setGateOutput(run, nodeId, `Schedule reached: ${waitUntil.toISOString()}`);
|
|
105
|
+
addEvent(run, 'gate-passed', `Schedule gate ${nodeId} passed`, { gate, waitUntil: waitUntil.toISOString() }, nodeId);
|
|
106
|
+
return 'completed';
|
|
107
|
+
}
|
|
108
|
+
const rendered = await renderTemplate(gate.expression, run);
|
|
109
|
+
if (!isTruthyGateValue(rendered)) {
|
|
110
|
+
throw new Error(`${gate.type} gate ${nodeId} failed: ${rendered || 'false'}`);
|
|
111
|
+
}
|
|
112
|
+
setGateOutput(run, nodeId, rendered);
|
|
113
|
+
addEvent(run, 'gate-passed', `${gate.type} gate ${nodeId} passed`, { gate, result: rendered }, nodeId);
|
|
114
|
+
return 'completed';
|
|
115
|
+
}
|
|
116
|
+
function setGateOutput(run, nodeId, output) {
|
|
117
|
+
const state = run.nodes[nodeId];
|
|
118
|
+
if (state)
|
|
119
|
+
state.output = output;
|
|
120
|
+
}
|
|
121
|
+
function isTruthyGateValue(value) {
|
|
122
|
+
const normalized = value.trim().toLowerCase();
|
|
123
|
+
return ['true', '1', 'yes', 'y', 'pass', 'passed', 'ok'].includes(normalized);
|
|
124
|
+
}
|
|
125
|
+
async function collectAndRecordArtifacts(context, run, nodeId, node, cwd) {
|
|
126
|
+
if (!node.artifacts || Object.keys(node.artifacts).length === 0)
|
|
127
|
+
return;
|
|
128
|
+
const result = await collectNodeArtifacts(run, nodeId, node, cwd);
|
|
129
|
+
for (const artifact of result.artifacts) {
|
|
130
|
+
run.artifacts ??= [];
|
|
131
|
+
run.artifacts = run.artifacts.filter((existing) => existing.nodeId !== artifact.nodeId || existing.name !== artifact.name);
|
|
132
|
+
run.artifacts.push(artifact);
|
|
133
|
+
addEvent(run, 'artifact-collected', `Node ${nodeId} collected artifact ${artifact.name}`, { artifact }, nodeId);
|
|
134
|
+
}
|
|
135
|
+
for (const missing of result.missing) {
|
|
136
|
+
addEvent(run, 'artifact-missing', `Node ${nodeId} did not collect artifact ${missing.name}: ${missing.reason}`, missing, nodeId);
|
|
137
|
+
}
|
|
138
|
+
if (result.artifacts.length > 0 || result.missing.length > 0) {
|
|
139
|
+
run.updatedAt = Date.now();
|
|
140
|
+
await context.saveAndEmit(run);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
async function executePromptNode(context, run, nodeId, node) {
|
|
144
|
+
const state = run.nodes[nodeId];
|
|
145
|
+
if (!state)
|
|
146
|
+
return;
|
|
147
|
+
const inlineAgents = await runInlineAgents(context, run, nodeId, node);
|
|
148
|
+
await runWorkflowDaemonSession(context, {
|
|
149
|
+
run,
|
|
150
|
+
nodeId,
|
|
151
|
+
target: state,
|
|
152
|
+
prompt: appendInlineAgentResults(await renderTemplate(node.prompt, run), inlineAgents),
|
|
153
|
+
...(node.agent ? { agent: node.agent } : {}),
|
|
154
|
+
...(node.model ? { model: node.model } : {}),
|
|
155
|
+
...(node.hooks ? { hooks: node.hooks } : {}),
|
|
156
|
+
...(node.timeoutSeconds ? { timeoutSeconds: node.timeoutSeconds } : {}),
|
|
157
|
+
outputFallback: () => readPromptNodeOutput(run, state),
|
|
158
|
+
outputData: async () => {
|
|
159
|
+
const transcriptExcerpt = await readPromptNodeTranscriptExcerpt(run, state);
|
|
160
|
+
return transcriptExcerpt.length > 0 ? { transcriptExcerpt } : {};
|
|
161
|
+
},
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
async function blockForApproval(context, run, nodeId, prompt) {
|
|
165
|
+
const state = run.nodes[nodeId];
|
|
166
|
+
if (!state)
|
|
167
|
+
return;
|
|
168
|
+
state.status = 'blocked';
|
|
169
|
+
state.approval = {
|
|
170
|
+
prompt,
|
|
171
|
+
requestedAt: Date.now(),
|
|
172
|
+
};
|
|
173
|
+
run.status = 'blocked';
|
|
174
|
+
run.updatedAt = state.approval.requestedAt;
|
|
175
|
+
addEvent(run, 'approval-requested', `Approval requested for node ${nodeId}`, { prompt }, nodeId);
|
|
176
|
+
addEvent(run, 'run-blocked', `Workflow blocked by approval gate: ${nodeId}`, undefined, nodeId);
|
|
177
|
+
await context.saveAndEmit(run);
|
|
178
|
+
}
|
|
179
|
+
//# sourceMappingURL=node-executor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node-executor.js","sourceRoot":"","sources":["../../src/workflows/node-executor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import type { WorkflowNodeExecutorContext } from './node-executor.js';
|
|
2
|
+
import type { WorkflowNode, WorkflowRunRecord } from './types.js';
|
|
3
|
+
/**
|
|
4
|
+
* Outcome of a per-type executor handler. The orchestrator in
|
|
5
|
+
* `executeWorkflowNode` reads this to decide whether to record artifacts and
|
|
6
|
+
* mark the node complete, or to leave the run in a blocked state waiting on
|
|
7
|
+
* an external event.
|
|
8
|
+
*/
|
|
9
|
+
export interface NodeExecutorOutcome {
|
|
10
|
+
/** 'completed' lets the orchestrator finish bookkeeping; 'blocked' returns early. */
|
|
11
|
+
result: 'completed' | 'blocked';
|
|
12
|
+
/**
|
|
13
|
+
* Working directory used for artifact collection. Defaults to the run's
|
|
14
|
+
* directory; shell nodes override based on their `cwd` field.
|
|
15
|
+
*/
|
|
16
|
+
artifactCwd?: string;
|
|
17
|
+
}
|
|
18
|
+
export type BuiltinNodeExecutor = (context: WorkflowNodeExecutorContext, run: WorkflowRunRecord, nodeId: string, node: WorkflowNode, helpers: BuiltinExecutorHelpers) => Promise<NodeExecutorOutcome>;
|
|
19
|
+
/**
|
|
20
|
+
* Helpers the orchestrator hands every executor. Plugins (Phase 5) will
|
|
21
|
+
* receive an analogous, more constrained surface so they cannot mutate the
|
|
22
|
+
* run record directly.
|
|
23
|
+
*/
|
|
24
|
+
export interface BuiltinExecutorHelpers {
|
|
25
|
+
executePromptNode: (context: WorkflowNodeExecutorContext, run: WorkflowRunRecord, nodeId: string, node: Extract<WorkflowNode, {
|
|
26
|
+
type: 'prompt';
|
|
27
|
+
}>) => Promise<void>;
|
|
28
|
+
executeGateNode: (context: WorkflowNodeExecutorContext, run: WorkflowRunRecord, nodeId: string, node: Extract<WorkflowNode, {
|
|
29
|
+
type: 'gate';
|
|
30
|
+
}>) => Promise<'completed' | 'blocked'>;
|
|
31
|
+
blockForApproval: (context: WorkflowNodeExecutorContext, run: WorkflowRunRecord, nodeId: string, prompt: string) => Promise<void>;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Mutable registry of node executors keyed by `node.type`. Built-ins are
|
|
35
|
+
* registered at module load (immediately below); the plugin loader extends
|
|
36
|
+
* this map at daemon boot with `defineNode()` entries from
|
|
37
|
+
* `~/.viewport/plugins.json`. Keep this table-driven so adding a node type
|
|
38
|
+
* is one entry, not five files.
|
|
39
|
+
*/
|
|
40
|
+
export declare const NODE_EXECUTORS: Map<string, BuiltinNodeExecutor>;
|
|
41
|
+
export declare function registerNodeExecutor(type: string, executor: BuiltinNodeExecutor): void;
|
|
42
|
+
//# sourceMappingURL=node-registry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node-registry.d.ts","sourceRoot":"","sources":["../../src/workflows/node-registry.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,oBAAoB,CAAC;AACtE,OAAO,KAAK,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAGlE;;;;;GAKG;AACH,MAAM,WAAW,mBAAmB;IAClC,qFAAqF;IACrF,MAAM,EAAE,WAAW,GAAG,SAAS,CAAC;IAChC;;;OAGG;IACH,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,MAAM,mBAAmB,GAAG,CAChC,OAAO,EAAE,2BAA2B,EACpC,GAAG,EAAE,iBAAiB,EACtB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,YAAY,EAClB,OAAO,EAAE,sBAAsB,KAC5B,OAAO,CAAC,mBAAmB,CAAC,CAAC;AAElC;;;;GAIG;AACH,MAAM,WAAW,sBAAsB;IACrC,iBAAiB,EAAE,CACjB,OAAO,EAAE,2BAA2B,EACpC,GAAG,EAAE,iBAAiB,EACtB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,OAAO,CAAC,YAAY,EAAE;QAAE,IAAI,EAAE,QAAQ,CAAA;KAAE,CAAC,KAC5C,OAAO,CAAC,IAAI,CAAC,CAAC;IACnB,eAAe,EAAE,CACf,OAAO,EAAE,2BAA2B,EACpC,GAAG,EAAE,iBAAiB,EACtB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,OAAO,CAAC,YAAY,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC,KAC1C,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC,CAAC;IACtC,gBAAgB,EAAE,CAChB,OAAO,EAAE,2BAA2B,EACpC,GAAG,EAAE,iBAAiB,EACtB,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,KACX,OAAO,CAAC,IAAI,CAAC,CAAC;CACpB;AAED;;;;;;GAMG;AACH,eAAO,MAAM,cAAc,kCAAyC,CAAC;AAErE,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,mBAAmB,GAAG,IAAI,CAEtF"}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { executeLoopNode } from './loop-executor.js';
|
|
2
|
+
import { addEvent, renderOptionalTemplate, renderTemplate, resolveNodeCwd, runShellNode, } from './runtime-helpers.js';
|
|
3
|
+
import { executeSubflowNode } from './subflow-executor.js';
|
|
4
|
+
import { sanitizePlanProposalMetadata } from '../hooks/plan-extractor.js';
|
|
5
|
+
/**
|
|
6
|
+
* Mutable registry of node executors keyed by `node.type`. Built-ins are
|
|
7
|
+
* registered at module load (immediately below); the plugin loader extends
|
|
8
|
+
* this map at daemon boot with `defineNode()` entries from
|
|
9
|
+
* `~/.viewport/plugins.json`. Keep this table-driven so adding a node type
|
|
10
|
+
* is one entry, not five files.
|
|
11
|
+
*/
|
|
12
|
+
export const NODE_EXECUTORS = new Map();
|
|
13
|
+
export function registerNodeExecutor(type, executor) {
|
|
14
|
+
NODE_EXECUTORS.set(type, executor);
|
|
15
|
+
}
|
|
16
|
+
const BUILTIN_NODE_EXECUTORS = {
|
|
17
|
+
shell: async (context, run, nodeId, node) => {
|
|
18
|
+
if (node.type !== 'shell')
|
|
19
|
+
return { result: 'completed' };
|
|
20
|
+
const state = run.nodes[nodeId];
|
|
21
|
+
const artifactCwd = resolveNodeCwd(run.directoryPath, await renderOptionalTemplate(node.cwd, run));
|
|
22
|
+
const abort = context.shellAbortRegistry.create(run.id, `node:${nodeId}`);
|
|
23
|
+
let result;
|
|
24
|
+
try {
|
|
25
|
+
result = await runShellNode(await renderTemplate(node.command, run), {
|
|
26
|
+
cwd: artifactCwd,
|
|
27
|
+
timeoutSeconds: node.timeoutSeconds,
|
|
28
|
+
signal: abort.signal,
|
|
29
|
+
onOutput: ({ source, chunk, output }) => {
|
|
30
|
+
addEvent(run, 'node-log', `Node ${nodeId} wrote ${source}`, { source, chunk, output }, nodeId);
|
|
31
|
+
run.updatedAt = Date.now();
|
|
32
|
+
void context.saveAndEmit(run);
|
|
33
|
+
},
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
finally {
|
|
37
|
+
abort.dispose();
|
|
38
|
+
}
|
|
39
|
+
if (state) {
|
|
40
|
+
state.output = result.output;
|
|
41
|
+
state.exitCode = result.exitCode;
|
|
42
|
+
}
|
|
43
|
+
addEvent(run, 'node-output', `Node ${nodeId} produced shell output`, { output: result.output, exitCode: result.exitCode }, nodeId);
|
|
44
|
+
return { result: 'completed', artifactCwd };
|
|
45
|
+
},
|
|
46
|
+
prompt: async (context, run, nodeId, node, helpers) => {
|
|
47
|
+
if (node.type !== 'prompt')
|
|
48
|
+
return { result: 'completed' };
|
|
49
|
+
await helpers.executePromptNode(context, run, nodeId, node);
|
|
50
|
+
return { result: 'completed' };
|
|
51
|
+
},
|
|
52
|
+
approval: async (context, run, nodeId, node, helpers) => {
|
|
53
|
+
if (node.type !== 'approval')
|
|
54
|
+
return { result: 'completed' };
|
|
55
|
+
await helpers.blockForApproval(context, run, nodeId, await renderTemplate(node.prompt, run));
|
|
56
|
+
return { result: 'blocked' };
|
|
57
|
+
},
|
|
58
|
+
gate: async (context, run, nodeId, node, helpers) => {
|
|
59
|
+
if (node.type !== 'gate')
|
|
60
|
+
return { result: 'completed' };
|
|
61
|
+
const gateResult = await helpers.executeGateNode(context, run, nodeId, node);
|
|
62
|
+
return { result: gateResult };
|
|
63
|
+
},
|
|
64
|
+
loop: async (context, run, nodeId, node) => {
|
|
65
|
+
if (node.type !== 'loop')
|
|
66
|
+
return { result: 'completed' };
|
|
67
|
+
await executeLoopNode(context, run, nodeId, node);
|
|
68
|
+
return { result: 'completed' };
|
|
69
|
+
},
|
|
70
|
+
subflow: async (context, run, nodeId, node) => {
|
|
71
|
+
if (node.type !== 'subflow')
|
|
72
|
+
return { result: 'completed' };
|
|
73
|
+
await executeSubflowNode(context, run, nodeId, node);
|
|
74
|
+
return { result: 'completed' };
|
|
75
|
+
},
|
|
76
|
+
plan: async (context, run, nodeId, node, helpers) => {
|
|
77
|
+
if (node.type !== 'plan')
|
|
78
|
+
return { result: 'completed' };
|
|
79
|
+
const state = run.nodes[nodeId];
|
|
80
|
+
const title = await renderTemplate(node.title, run);
|
|
81
|
+
const body = await renderTemplate(node.body, run);
|
|
82
|
+
const summary = await renderOptionalTemplate(node.summary, run);
|
|
83
|
+
const sourceRef = await renderOptionalTemplate(node.sourceRef, run);
|
|
84
|
+
if (state) {
|
|
85
|
+
state.output = body;
|
|
86
|
+
state.metadata = {
|
|
87
|
+
...(state.metadata ?? {}),
|
|
88
|
+
plan: {
|
|
89
|
+
title,
|
|
90
|
+
summary,
|
|
91
|
+
body,
|
|
92
|
+
source: node.source ?? 'workflow',
|
|
93
|
+
sourceRef: sourceRef || `viewport://workflow-runs/${run.id}/nodes/${nodeId}`,
|
|
94
|
+
},
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
context.daemon.emit('hook:plan-proposed', {
|
|
98
|
+
sessionId: `${run.id}:${nodeId}`,
|
|
99
|
+
adapter: 'viewport-workflow',
|
|
100
|
+
cwd: run.directoryPath,
|
|
101
|
+
title,
|
|
102
|
+
summary,
|
|
103
|
+
body,
|
|
104
|
+
source: node.source ?? 'workflow',
|
|
105
|
+
sourceRef: sourceRef || `viewport://workflow-runs/${run.id}/nodes/${nodeId}`,
|
|
106
|
+
metadata: sanitizePlanProposalMetadata({
|
|
107
|
+
workflowRunId: run.id,
|
|
108
|
+
workflowNodeId: nodeId,
|
|
109
|
+
resourceId: run.resourceId ?? null,
|
|
110
|
+
}),
|
|
111
|
+
});
|
|
112
|
+
addEvent(run, 'plan-proposed', `Plan node ${nodeId} proposed ${title}`, { title, summary, sourceRef: sourceRef || null }, nodeId);
|
|
113
|
+
if (node.waitForApproval === false) {
|
|
114
|
+
return { result: 'completed' };
|
|
115
|
+
}
|
|
116
|
+
await helpers.blockForApproval(context, run, nodeId, `Approve plan: ${title}`);
|
|
117
|
+
return { result: 'blocked' };
|
|
118
|
+
},
|
|
119
|
+
};
|
|
120
|
+
// Seed the mutable registry with built-ins. Plugin entries register at boot.
|
|
121
|
+
for (const [type, executor] of Object.entries(BUILTIN_NODE_EXECUTORS)) {
|
|
122
|
+
NODE_EXECUTORS.set(type, executor);
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=node-registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node-registry.js","sourceRoot":"","sources":["../../src/workflows/node-registry.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { WORKFLOW_SCHEMA_VERSION } from './workflow-schema.js';
|
|
2
|
+
import type { ParsedWorkflow, WorkflowDefinition } from './types.js';
|
|
3
|
+
export { WORKFLOW_SCHEMA_VERSION };
|
|
4
|
+
export interface WorkflowValidationIssue {
|
|
5
|
+
path: string;
|
|
6
|
+
message: string;
|
|
7
|
+
}
|
|
8
|
+
export interface WorkflowValidationResult {
|
|
9
|
+
ok: boolean;
|
|
10
|
+
workflow?: ParsedWorkflow;
|
|
11
|
+
issues: WorkflowValidationIssue[];
|
|
12
|
+
}
|
|
13
|
+
export declare function parseWorkflowFile(filePath: string): Promise<ParsedWorkflow>;
|
|
14
|
+
export declare function validateWorkflowText(sourceText: string, sourcePath: string): WorkflowValidationResult;
|
|
15
|
+
export declare function parseWorkflow(sourceText: string, sourcePath: string): ParsedWorkflow;
|
|
16
|
+
export declare function workflowNodeOrder(definition: WorkflowDefinition): string[];
|
|
17
|
+
//# sourceMappingURL=parser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parser.d.ts","sourceRoot":"","sources":["../../src/workflows/parser.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,uBAAuB,EAA4B,MAAM,sBAAsB,CAAC;AACzF,OAAO,KAAK,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAErE,OAAO,EAAE,uBAAuB,EAAE,CAAC;AAEnC,MAAM,WAAW,uBAAuB;IACtC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,wBAAwB;IACvC,EAAE,EAAE,OAAO,CAAC;IACZ,QAAQ,CAAC,EAAE,cAAc,CAAC;IAC1B,MAAM,EAAE,uBAAuB,EAAE,CAAC;CACnC;AAED,wBAAsB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC,CAIjF;AAED,wBAAgB,oBAAoB,CAClC,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,MAAM,GACjB,wBAAwB,CAY1B;AAED,wBAAgB,aAAa,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,cAAc,CA4BpF;AAED,wBAAgB,iBAAiB,CAAC,UAAU,EAAE,kBAAkB,GAAG,MAAM,EAAE,CAwB1E"}
|
|
@@ -0,0 +1,250 @@
|
|
|
1
|
+
import crypto from 'node:crypto';
|
|
2
|
+
import fs from 'node:fs/promises';
|
|
3
|
+
import path from 'node:path';
|
|
4
|
+
import YAML from 'yaml';
|
|
5
|
+
import { WORKFLOW_SCHEMA_VERSION, WorkflowDefinitionSchema } from './workflow-schema.js';
|
|
6
|
+
export { WORKFLOW_SCHEMA_VERSION };
|
|
7
|
+
export async function parseWorkflowFile(filePath) {
|
|
8
|
+
const sourcePath = path.resolve(filePath);
|
|
9
|
+
const sourceText = await fs.readFile(sourcePath, 'utf-8');
|
|
10
|
+
return parseWorkflow(sourceText, sourcePath);
|
|
11
|
+
}
|
|
12
|
+
export function validateWorkflowText(sourceText, sourcePath) {
|
|
13
|
+
try {
|
|
14
|
+
const workflow = parseWorkflow(sourceText, sourcePath);
|
|
15
|
+
return { ok: true, workflow, issues: [] };
|
|
16
|
+
}
|
|
17
|
+
catch (error) {
|
|
18
|
+
return {
|
|
19
|
+
ok: false,
|
|
20
|
+
issues: [
|
|
21
|
+
{ path: sourcePath, message: error instanceof Error ? error.message : String(error) },
|
|
22
|
+
],
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export function parseWorkflow(sourceText, sourcePath) {
|
|
27
|
+
let raw;
|
|
28
|
+
try {
|
|
29
|
+
raw = YAML.parse(sourceText);
|
|
30
|
+
}
|
|
31
|
+
catch (error) {
|
|
32
|
+
throw new Error(`Invalid workflow YAML: ${error instanceof Error ? error.message : String(error)}`);
|
|
33
|
+
}
|
|
34
|
+
const parsed = WorkflowDefinitionSchema.safeParse(raw);
|
|
35
|
+
if (!parsed.success) {
|
|
36
|
+
const issue = parsed.error.issues[0];
|
|
37
|
+
const issuePath = issue?.path.join('.') || '<root>';
|
|
38
|
+
throw new Error(`Invalid workflow at ${issuePath}: ${issue?.message ?? 'schema mismatch'}`);
|
|
39
|
+
}
|
|
40
|
+
validateWorkflowGraph(parsed.data);
|
|
41
|
+
const normalizedJson = stableJson(parsed.data);
|
|
42
|
+
const digest = crypto.createHash('sha256').update(normalizedJson).digest('hex');
|
|
43
|
+
return {
|
|
44
|
+
definition: parsed.data,
|
|
45
|
+
digest,
|
|
46
|
+
sourcePath: path.resolve(sourcePath),
|
|
47
|
+
sourceText,
|
|
48
|
+
normalizedJson,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
export function workflowNodeOrder(definition) {
|
|
52
|
+
const pending = new Set(Object.keys(definition.nodes));
|
|
53
|
+
const complete = new Set();
|
|
54
|
+
const ordered = [];
|
|
55
|
+
while (pending.size > 0) {
|
|
56
|
+
const ready = [...pending].filter((nodeId) => {
|
|
57
|
+
const needs = definition.nodes[nodeId]?.needs ?? [];
|
|
58
|
+
return needs.every((dependency) => complete.has(dependency));
|
|
59
|
+
});
|
|
60
|
+
if (ready.length === 0) {
|
|
61
|
+
throw new Error('Workflow contains a dependency cycle');
|
|
62
|
+
}
|
|
63
|
+
ready.sort((a, b) => a.localeCompare(b));
|
|
64
|
+
for (const nodeId of ready) {
|
|
65
|
+
pending.delete(nodeId);
|
|
66
|
+
complete.add(nodeId);
|
|
67
|
+
ordered.push(nodeId);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
return ordered;
|
|
71
|
+
}
|
|
72
|
+
function validateWorkflowGraph(definition) {
|
|
73
|
+
const nodeIds = new Set(Object.keys(definition.nodes));
|
|
74
|
+
if (nodeIds.size === 0) {
|
|
75
|
+
throw new Error('Workflow must define at least one node');
|
|
76
|
+
}
|
|
77
|
+
for (const [nodeId, node] of Object.entries(definition.nodes)) {
|
|
78
|
+
if (!/^[a-zA-Z0-9._/-]+$/.test(nodeId)) {
|
|
79
|
+
throw new Error(`Invalid workflow node id: ${nodeId}`);
|
|
80
|
+
}
|
|
81
|
+
for (const dependency of node.needs ?? []) {
|
|
82
|
+
if (!nodeIds.has(dependency)) {
|
|
83
|
+
throw new Error(`Workflow node ${nodeId} depends on missing node ${dependency}`);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
workflowNodeOrder(definition);
|
|
88
|
+
validateTemplateReferences(definition);
|
|
89
|
+
}
|
|
90
|
+
function validateTemplateReferences(definition) {
|
|
91
|
+
for (const [nodeId, node] of Object.entries(definition.nodes)) {
|
|
92
|
+
const templates = nodeTemplates(node);
|
|
93
|
+
if (templates.length === 0)
|
|
94
|
+
continue;
|
|
95
|
+
const dependencies = transitiveDependencies(definition, nodeId);
|
|
96
|
+
for (const template of templates) {
|
|
97
|
+
for (const reference of nodeReferences(template)) {
|
|
98
|
+
if (!definition.nodes[reference.nodeId]) {
|
|
99
|
+
throw new Error(`Workflow node ${nodeId} references missing node ${reference.nodeId}`);
|
|
100
|
+
}
|
|
101
|
+
if (!dependencies.has(reference.nodeId)) {
|
|
102
|
+
throw new Error(`Workflow node ${nodeId} references ${reference.nodeId} output but does not depend on it`);
|
|
103
|
+
}
|
|
104
|
+
if (reference.kind === 'output') {
|
|
105
|
+
const upstream = definition.nodes[reference.nodeId];
|
|
106
|
+
if (!upstream?.outputs?.[declaredReferenceName(reference.name, upstream.outputs)]) {
|
|
107
|
+
throw new Error(`Workflow node ${nodeId} references undeclared output ${reference.nodeId}.${reference.name}`);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
if (reference.kind === 'artifact') {
|
|
111
|
+
const upstream = definition.nodes[reference.nodeId];
|
|
112
|
+
if (!upstream?.artifacts?.[declaredReferenceName(reference.name, upstream.artifacts)]) {
|
|
113
|
+
throw new Error(`Workflow node ${nodeId} references undeclared artifact ${reference.nodeId}.${reference.name}`);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
function nodeTemplates(node) {
|
|
121
|
+
if (node.type === 'prompt') {
|
|
122
|
+
return [node.prompt, ...Object.values(node.agents ?? {}).map((agent) => agent.prompt)];
|
|
123
|
+
}
|
|
124
|
+
if (node.type === 'shell')
|
|
125
|
+
return [node.command, node.cwd].filter((value) => typeof value === 'string');
|
|
126
|
+
if (node.type === 'approval') {
|
|
127
|
+
const templates = [node.prompt];
|
|
128
|
+
if (node.onReject) {
|
|
129
|
+
if ('command' in node.onReject) {
|
|
130
|
+
templates.push(node.onReject.command);
|
|
131
|
+
if (node.onReject.cwd)
|
|
132
|
+
templates.push(node.onReject.cwd);
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
templates.push(node.onReject.prompt);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
return templates;
|
|
139
|
+
}
|
|
140
|
+
if (node.type === 'gate') {
|
|
141
|
+
if (node.gate.type === 'check' || node.gate.type === 'policy')
|
|
142
|
+
return [node.gate.expression];
|
|
143
|
+
if (node.gate.type === 'human_review')
|
|
144
|
+
return [node.gate.prompt];
|
|
145
|
+
return [node.gate.waitUntil];
|
|
146
|
+
}
|
|
147
|
+
if (node.type === 'loop') {
|
|
148
|
+
const templates = [];
|
|
149
|
+
if (node.foreach)
|
|
150
|
+
templates.push(node.foreach);
|
|
151
|
+
if (node.while)
|
|
152
|
+
templates.push(node.while);
|
|
153
|
+
if (node.until)
|
|
154
|
+
templates.push(node.until);
|
|
155
|
+
if (node.body.type === 'shell') {
|
|
156
|
+
templates.push(node.body.command);
|
|
157
|
+
if (node.body.cwd)
|
|
158
|
+
templates.push(node.body.cwd);
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
templates.push(node.body.prompt);
|
|
162
|
+
}
|
|
163
|
+
return templates;
|
|
164
|
+
}
|
|
165
|
+
if (node.type === 'subflow') {
|
|
166
|
+
const templates = [];
|
|
167
|
+
for (const value of Object.values(node.inputs ?? {})) {
|
|
168
|
+
templates.push(value);
|
|
169
|
+
}
|
|
170
|
+
// Child node templates reference *child* node ids, not parent ids — they
|
|
171
|
+
// resolve in a separate scope, so we don't validate their refs against
|
|
172
|
+
// the parent dependency graph here. The runner enforces child references
|
|
173
|
+
// at execution time.
|
|
174
|
+
return templates;
|
|
175
|
+
}
|
|
176
|
+
return [];
|
|
177
|
+
}
|
|
178
|
+
function nodeReferences(template) {
|
|
179
|
+
const references = new Map();
|
|
180
|
+
const rawPatterns = [
|
|
181
|
+
/\{\{\s*nodes\.([A-Za-z0-9._/-]+)\.(?:output|status|sessionId|error)\s*\}\}/g,
|
|
182
|
+
/\{\{\s*outputs\.([A-Za-z0-9._/-]+)\s*\}\}/g,
|
|
183
|
+
];
|
|
184
|
+
for (const pattern of rawPatterns) {
|
|
185
|
+
for (const match of template.matchAll(pattern)) {
|
|
186
|
+
if (match[1])
|
|
187
|
+
references.set(`raw:${match[1]}`, { kind: 'raw', nodeId: match[1] });
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
const namedPatterns = [
|
|
191
|
+
[/\{\{\s*nodes\.([A-Za-z0-9._/-]+)\.outputs\.([A-Za-z0-9._/-]+)\s*\}\}/g, 'output'],
|
|
192
|
+
[/\{\{\s*nodes\.([A-Za-z0-9._/-]+)\.artifacts\.([A-Za-z0-9._/-]+)\s*\}\}/g, 'artifact'],
|
|
193
|
+
[/\{\{\s*artifacts\.([A-Za-z0-9._/-]+)\.([A-Za-z0-9._/-]+)\s*\}\}/g, 'artifact'],
|
|
194
|
+
];
|
|
195
|
+
for (const [pattern, kind] of namedPatterns) {
|
|
196
|
+
for (const match of template.matchAll(pattern)) {
|
|
197
|
+
if (!match[1] || !match[2])
|
|
198
|
+
continue;
|
|
199
|
+
if (kind === 'output') {
|
|
200
|
+
references.set(`output:${match[1]}:${match[2]}`, {
|
|
201
|
+
kind: 'output',
|
|
202
|
+
nodeId: match[1],
|
|
203
|
+
name: match[2],
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
else {
|
|
207
|
+
references.set(`artifact:${match[1]}:${match[2]}`, {
|
|
208
|
+
kind: 'artifact',
|
|
209
|
+
nodeId: match[1],
|
|
210
|
+
name: match[2],
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
return [...references.values()];
|
|
216
|
+
}
|
|
217
|
+
function declaredReferenceName(referenceName, declared) {
|
|
218
|
+
if (!declared)
|
|
219
|
+
return referenceName;
|
|
220
|
+
if (Object.hasOwn(declared, referenceName))
|
|
221
|
+
return referenceName;
|
|
222
|
+
return referenceName.split('.')[0] ?? referenceName;
|
|
223
|
+
}
|
|
224
|
+
function transitiveDependencies(definition, nodeId) {
|
|
225
|
+
const result = new Set();
|
|
226
|
+
const visit = (current) => {
|
|
227
|
+
const node = definition.nodes[current];
|
|
228
|
+
for (const dependency of node?.needs ?? []) {
|
|
229
|
+
if (result.has(dependency))
|
|
230
|
+
continue;
|
|
231
|
+
result.add(dependency);
|
|
232
|
+
visit(dependency);
|
|
233
|
+
}
|
|
234
|
+
};
|
|
235
|
+
visit(nodeId);
|
|
236
|
+
return result;
|
|
237
|
+
}
|
|
238
|
+
function stableJson(value) {
|
|
239
|
+
if (Array.isArray(value)) {
|
|
240
|
+
return `[${value.map((item) => stableJson(item)).join(',')}]`;
|
|
241
|
+
}
|
|
242
|
+
if (value && typeof value === 'object') {
|
|
243
|
+
const entries = Object.entries(value).sort(([a], [b]) => a.localeCompare(b));
|
|
244
|
+
return `{${entries
|
|
245
|
+
.map(([key, entryValue]) => `${JSON.stringify(key)}:${stableJson(entryValue)}`)
|
|
246
|
+
.join(',')}}`;
|
|
247
|
+
}
|
|
248
|
+
return JSON.stringify(value);
|
|
249
|
+
}
|
|
250
|
+
//# sourceMappingURL=parser.js.map
|