@getpaseo/server 0.1.61 → 0.1.63
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 +4 -0
- package/dist/server/client/daemon-client-runtime-metrics.d.ts +6 -6
- package/dist/server/client/daemon-client-runtime-metrics.d.ts.map +1 -1
- package/dist/server/client/daemon-client-transport-types.d.ts +13 -13
- package/dist/server/client/daemon-client-transport-types.d.ts.map +1 -1
- package/dist/server/client/daemon-client-websocket-transport.d.ts +1 -1
- package/dist/server/client/daemon-client-websocket-transport.d.ts.map +1 -1
- package/dist/server/client/daemon-client-websocket-transport.js +5 -4
- package/dist/server/client/daemon-client-websocket-transport.js.map +1 -1
- package/dist/server/client/daemon-client.d.ts +59 -37
- package/dist/server/client/daemon-client.d.ts.map +1 -1
- package/dist/server/client/daemon-client.js +62 -17
- package/dist/server/client/daemon-client.js.map +1 -1
- package/dist/server/server/agent/agent-loading.d.ts.map +1 -1
- package/dist/server/server/agent/agent-loading.js +5 -3
- package/dist/server/server/agent/agent-loading.js.map +1 -1
- package/dist/server/server/agent/agent-manager.d.ts +45 -19
- package/dist/server/server/agent/agent-manager.d.ts.map +1 -1
- package/dist/server/server/agent/agent-manager.js +393 -290
- package/dist/server/server/agent/agent-manager.js.map +1 -1
- package/dist/server/server/agent/agent-metadata-generator.d.ts +6 -6
- package/dist/server/server/agent/agent-metadata-generator.d.ts.map +1 -1
- package/dist/server/server/agent/agent-metadata-generator.js +46 -38
- package/dist/server/server/agent/agent-metadata-generator.js.map +1 -1
- package/dist/server/server/agent/agent-projections.d.ts +4 -6
- package/dist/server/server/agent/agent-projections.d.ts.map +1 -1
- package/dist/server/server/agent/agent-projections.js +59 -65
- package/dist/server/server/agent/agent-projections.js.map +1 -1
- package/dist/server/server/agent/agent-response-loop.d.ts +4 -4
- package/dist/server/server/agent/agent-response-loop.d.ts.map +1 -1
- package/dist/server/server/agent/agent-response-loop.js +58 -45
- package/dist/server/server/agent/agent-response-loop.js.map +1 -1
- package/dist/server/server/agent/agent-sdk-types.d.ts +43 -40
- package/dist/server/server/agent/agent-sdk-types.d.ts.map +1 -1
- package/dist/server/server/agent/agent-sdk-types.js.map +1 -1
- package/dist/server/server/agent/agent-storage.d.ts +2 -2
- package/dist/server/server/agent/agent-storage.d.ts.map +1 -1
- package/dist/server/server/agent/agent-storage.js +29 -36
- package/dist/server/server/agent/agent-storage.js.map +1 -1
- package/dist/server/server/agent/agent-stream-coalescer.d.ts +6 -6
- package/dist/server/server/agent/agent-stream-coalescer.d.ts.map +1 -1
- package/dist/server/server/agent/agent-timeline-store-types.d.ts +10 -10
- package/dist/server/server/agent/agent-timeline-store-types.d.ts.map +1 -1
- package/dist/server/server/agent/agent-timeline-store.d.ts +2 -2
- package/dist/server/server/agent/agent-timeline-store.d.ts.map +1 -1
- package/dist/server/server/agent/agent-timeline-store.js +85 -64
- package/dist/server/server/agent/agent-timeline-store.js.map +1 -1
- package/dist/server/server/agent/mcp-server.d.ts.map +1 -1
- package/dist/server/server/agent/mcp-server.js +185 -148
- package/dist/server/server/agent/mcp-server.js.map +1 -1
- package/dist/server/server/agent/mcp-shared.d.ts +9 -2
- package/dist/server/server/agent/mcp-shared.d.ts.map +1 -1
- package/dist/server/server/agent/mcp-shared.js +2 -0
- package/dist/server/server/agent/mcp-shared.js.map +1 -1
- package/dist/server/server/agent/model-resolver.d.ts +2 -2
- package/dist/server/server/agent/model-resolver.d.ts.map +1 -1
- package/dist/server/server/agent/model-resolver.js +9 -5
- package/dist/server/server/agent/model-resolver.js.map +1 -1
- package/dist/server/server/agent/provider-launch-config.d.ts +28 -17
- package/dist/server/server/agent/provider-launch-config.d.ts.map +1 -1
- package/dist/server/server/agent/provider-launch-config.js +20 -9
- package/dist/server/server/agent/provider-launch-config.js.map +1 -1
- package/dist/server/server/agent/provider-registry.d.ts +4 -2
- package/dist/server/server/agent/provider-registry.d.ts.map +1 -1
- package/dist/server/server/agent/provider-registry.js +24 -21
- package/dist/server/server/agent/provider-registry.js.map +1 -1
- package/dist/server/server/agent/provider-snapshot-manager.d.ts +6 -5
- package/dist/server/server/agent/provider-snapshot-manager.d.ts.map +1 -1
- package/dist/server/server/agent/provider-snapshot-manager.js +40 -31
- package/dist/server/server/agent/provider-snapshot-manager.js.map +1 -1
- package/dist/server/server/agent/providers/acp-agent.d.ts +11 -12
- package/dist/server/server/agent/providers/acp-agent.d.ts.map +1 -1
- package/dist/server/server/agent/providers/acp-agent.js +148 -122
- package/dist/server/server/agent/providers/acp-agent.js.map +1 -1
- package/dist/server/server/agent/providers/claude/sidechain-tracker.d.ts +2 -0
- package/dist/server/server/agent/providers/claude/sidechain-tracker.d.ts.map +1 -1
- package/dist/server/server/agent/providers/claude/sidechain-tracker.js +47 -45
- package/dist/server/server/agent/providers/claude/sidechain-tracker.js.map +1 -1
- package/dist/server/server/agent/providers/claude/task-notification-tool-call.d.ts +2 -2
- package/dist/server/server/agent/providers/claude/task-notification-tool-call.d.ts.map +1 -1
- package/dist/server/server/agent/providers/claude/task-notification-tool-call.js +10 -5
- package/dist/server/server/agent/providers/claude/task-notification-tool-call.js.map +1 -1
- package/dist/server/server/agent/providers/claude/tool-call-detail-parser.d.ts.map +1 -1
- package/dist/server/server/agent/providers/claude/tool-call-detail-parser.js +11 -2
- package/dist/server/server/agent/providers/claude/tool-call-detail-parser.js.map +1 -1
- package/dist/server/server/agent/providers/claude/tool-call-mapper.d.ts +2 -2
- package/dist/server/server/agent/providers/claude/tool-call-mapper.d.ts.map +1 -1
- package/dist/server/server/agent/providers/claude/tool-call-mapper.js +20 -13
- package/dist/server/server/agent/providers/claude/tool-call-mapper.js.map +1 -1
- package/dist/server/server/agent/providers/claude-agent.d.ts +20 -8
- package/dist/server/server/agent/providers/claude-agent.d.ts.map +1 -1
- package/dist/server/server/agent/providers/claude-agent.js +610 -460
- package/dist/server/server/agent/providers/claude-agent.js.map +1 -1
- package/dist/server/server/agent/providers/codex/tool-call-detail-parser.d.ts +2 -2
- package/dist/server/server/agent/providers/codex/tool-call-detail-parser.d.ts.map +1 -1
- package/dist/server/server/agent/providers/codex/tool-call-mapper.d.ts +2 -2
- package/dist/server/server/agent/providers/codex/tool-call-mapper.d.ts.map +1 -1
- package/dist/server/server/agent/providers/codex/tool-call-mapper.js +49 -44
- package/dist/server/server/agent/providers/codex/tool-call-mapper.js.map +1 -1
- package/dist/server/server/agent/providers/codex-app-server-agent.d.ts +27 -8
- package/dist/server/server/agent/providers/codex-app-server-agent.d.ts.map +1 -1
- package/dist/server/server/agent/providers/codex-app-server-agent.js +564 -492
- package/dist/server/server/agent/providers/codex-app-server-agent.js.map +1 -1
- package/dist/server/server/agent/providers/codex-rollout-timeline.d.ts +2 -2
- package/dist/server/server/agent/providers/codex-rollout-timeline.d.ts.map +1 -1
- package/dist/server/server/agent/providers/codex-rollout-timeline.js +58 -47
- package/dist/server/server/agent/providers/codex-rollout-timeline.js.map +1 -1
- package/dist/server/server/agent/providers/copilot-acp-agent.d.ts +2 -2
- package/dist/server/server/agent/providers/copilot-acp-agent.d.ts.map +1 -1
- package/dist/server/server/agent/providers/diagnostic-utils.d.ts +3 -3
- package/dist/server/server/agent/providers/diagnostic-utils.d.ts.map +1 -1
- package/dist/server/server/agent/providers/diagnostic-utils.js +82 -9
- package/dist/server/server/agent/providers/diagnostic-utils.js.map +1 -1
- package/dist/server/server/agent/providers/generic-acp-agent.d.ts +2 -2
- package/dist/server/server/agent/providers/generic-acp-agent.d.ts.map +1 -1
- package/dist/server/server/agent/providers/mock-load-test-agent.d.ts.map +1 -1
- package/dist/server/server/agent/providers/mock-load-test-agent.js.map +1 -1
- package/dist/server/server/agent/providers/opencode/tool-call-mapper.d.ts +2 -2
- package/dist/server/server/agent/providers/opencode/tool-call-mapper.d.ts.map +1 -1
- package/dist/server/server/agent/providers/opencode-agent.d.ts +2 -2
- package/dist/server/server/agent/providers/opencode-agent.d.ts.map +1 -1
- package/dist/server/server/agent/providers/opencode-agent.js +385 -360
- package/dist/server/server/agent/providers/opencode-agent.js.map +1 -1
- package/dist/server/server/agent/providers/pi-direct-agent.d.ts +1 -0
- package/dist/server/server/agent/providers/pi-direct-agent.d.ts.map +1 -1
- package/dist/server/server/agent/providers/pi-direct-agent.js +109 -140
- package/dist/server/server/agent/providers/pi-direct-agent.js.map +1 -1
- package/dist/server/server/agent/providers/test-utils/session-stream-adapter.d.ts.map +1 -1
- package/dist/server/server/agent/providers/test-utils/session-stream-adapter.js +3 -1
- package/dist/server/server/agent/providers/test-utils/session-stream-adapter.js.map +1 -1
- package/dist/server/server/agent/providers/tool-call-detail-primitives.d.ts +3 -3
- package/dist/server/server/agent/providers/tool-call-detail-primitives.d.ts.map +1 -1
- package/dist/server/server/agent/providers/tool-call-detail-primitives.js +102 -73
- package/dist/server/server/agent/providers/tool-call-detail-primitives.js.map +1 -1
- package/dist/server/server/agent/providers/tool-call-mapper-utils.d.ts +2 -2
- package/dist/server/server/agent/providers/tool-call-mapper-utils.d.ts.map +1 -1
- package/dist/server/server/agent/stt-manager.d.ts.map +1 -1
- package/dist/server/server/agent/stt-manager.js +63 -53
- package/dist/server/server/agent/stt-manager.js.map +1 -1
- package/dist/server/server/agent/timeline-projection.d.ts +6 -6
- package/dist/server/server/agent/timeline-projection.d.ts.map +1 -1
- package/dist/server/server/agent/timeline-projection.js +11 -6
- package/dist/server/server/agent/timeline-projection.js.map +1 -1
- package/dist/server/server/agent/tts-manager.d.ts.map +1 -1
- package/dist/server/server/agent/tts-manager.js +1 -0
- package/dist/server/server/agent/tts-manager.js.map +1 -1
- package/dist/server/server/agent-attention-policy.d.ts +2 -2
- package/dist/server/server/agent-attention-policy.d.ts.map +1 -1
- package/dist/server/server/bootstrap.d.ts +4 -4
- package/dist/server/server/bootstrap.d.ts.map +1 -1
- package/dist/server/server/bootstrap.js +493 -485
- package/dist/server/server/bootstrap.js.map +1 -1
- package/dist/server/server/chat/chat-service.d.ts +1 -1
- package/dist/server/server/chat/chat-service.d.ts.map +1 -1
- package/dist/server/server/chat/chat-service.js +3 -3
- package/dist/server/server/chat/chat-service.js.map +1 -1
- package/dist/server/server/checkout-diff-manager.d.ts +2 -2
- package/dist/server/server/checkout-diff-manager.d.ts.map +1 -1
- package/dist/server/server/checkout-git-utils.d.ts +5 -3
- package/dist/server/server/checkout-git-utils.d.ts.map +1 -1
- package/dist/server/server/checkout-git-utils.js +1 -2
- package/dist/server/server/checkout-git-utils.js.map +1 -1
- package/dist/server/server/config.d.ts.map +1 -1
- package/dist/server/server/config.js +68 -39
- package/dist/server/server/config.js.map +1 -1
- package/dist/server/server/connection-offer.d.ts +2 -2
- package/dist/server/server/connection-offer.d.ts.map +1 -1
- package/dist/server/server/daemon-config-store.d.ts +5 -3
- package/dist/server/server/daemon-config-store.d.ts.map +1 -1
- package/dist/server/server/daemon-config-store.js +26 -0
- package/dist/server/server/daemon-config-store.js.map +1 -1
- package/dist/server/server/daemon-keypair.d.ts +2 -2
- package/dist/server/server/daemon-keypair.d.ts.map +1 -1
- package/dist/server/server/editor-targets.d.ts +4 -4
- package/dist/server/server/editor-targets.d.ts.map +1 -1
- package/dist/server/server/editor-targets.js +11 -15
- package/dist/server/server/editor-targets.js.map +1 -1
- package/dist/server/server/exports.d.ts +3 -3
- package/dist/server/server/exports.d.ts.map +1 -1
- package/dist/server/server/exports.js +1 -3
- package/dist/server/server/exports.js.map +1 -1
- package/dist/server/server/file-download/token-store.d.ts +4 -4
- package/dist/server/server/file-download/token-store.d.ts.map +1 -1
- package/dist/server/server/index.js +16 -12
- package/dist/server/server/index.js.map +1 -1
- package/dist/server/server/logger.d.ts +4 -4
- package/dist/server/server/logger.d.ts.map +1 -1
- package/dist/server/server/logger.js +26 -20
- package/dist/server/server/logger.js.map +1 -1
- package/dist/server/server/loop/rpc-schemas.d.ts +52 -52
- package/dist/server/server/loop-service.d.ts +13 -12
- package/dist/server/server/loop-service.d.ts.map +1 -1
- package/dist/server/server/loop-service.js +22 -18
- package/dist/server/server/loop-service.js.map +1 -1
- package/dist/server/server/package-version.d.ts +2 -2
- package/dist/server/server/package-version.d.ts.map +1 -1
- package/dist/server/server/package-version.js +19 -17
- package/dist/server/server/package-version.js.map +1 -1
- package/dist/server/server/pairing-offer.d.ts +2 -2
- package/dist/server/server/pairing-offer.d.ts.map +1 -1
- package/dist/server/server/paseo-env.d.ts +9 -0
- package/dist/server/server/paseo-env.d.ts.map +1 -0
- package/dist/server/server/paseo-env.js +70 -0
- package/dist/server/server/paseo-env.js.map +1 -0
- package/dist/server/server/paseo-worktree-archive-service.d.ts +4 -4
- package/dist/server/server/paseo-worktree-archive-service.d.ts.map +1 -1
- package/dist/server/server/paseo-worktree-archive-service.js +11 -11
- package/dist/server/server/paseo-worktree-archive-service.js.map +1 -1
- package/dist/server/server/persisted-config.d.ts +62 -62
- package/dist/server/server/persisted-config.d.ts.map +1 -1
- package/dist/server/server/persisted-config.js +4 -4
- package/dist/server/server/persisted-config.js.map +1 -1
- package/dist/server/server/persistence-hooks.d.ts +8 -9
- package/dist/server/server/persistence-hooks.d.ts.map +1 -1
- package/dist/server/server/persistence-hooks.js +4 -12
- package/dist/server/server/persistence-hooks.js.map +1 -1
- package/dist/server/server/pid-lock.js.map +1 -1
- package/dist/server/server/push/push-service.d.ts.map +1 -1
- package/dist/server/server/push/push-service.js +1 -3
- package/dist/server/server/push/push-service.js.map +1 -1
- package/dist/server/server/relay-transport.d.ts +8 -8
- package/dist/server/server/relay-transport.d.ts.map +1 -1
- package/dist/server/server/relay-transport.js +27 -16
- package/dist/server/server/relay-transport.js.map +1 -1
- package/dist/server/server/schedule/service.d.ts.map +1 -1
- package/dist/server/server/schedule/service.js +2 -2
- package/dist/server/server/schedule/service.js.map +1 -1
- package/dist/server/server/script-health-monitor.d.ts.map +1 -1
- package/dist/server/server/script-health-monitor.js +7 -6
- package/dist/server/server/script-health-monitor.js.map +1 -1
- package/dist/server/server/script-proxy.js +1 -1
- package/dist/server/server/script-proxy.js.map +1 -1
- package/dist/server/server/script-status-projection.d.ts +4 -4
- package/dist/server/server/script-status-projection.d.ts.map +1 -1
- package/dist/server/server/script-status-projection.js +54 -44
- package/dist/server/server/script-status-projection.js.map +1 -1
- package/dist/server/server/server-id.d.ts +4 -4
- package/dist/server/server/server-id.d.ts.map +1 -1
- package/dist/server/server/session.d.ts +50 -19
- package/dist/server/server/session.d.ts.map +1 -1
- package/dist/server/server/session.js +1116 -783
- package/dist/server/server/session.js.map +1 -1
- package/dist/server/server/speech/audio.js +1 -1
- package/dist/server/server/speech/audio.js.map +1 -1
- package/dist/server/server/speech/providers/local/config.d.ts +6 -6
- package/dist/server/server/speech/providers/local/config.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/config.js +41 -16
- package/dist/server/server/speech/providers/local/config.js.map +1 -1
- package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.d.ts +2 -2
- package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.js +42 -19
- package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.js.map +1 -1
- package/dist/server/server/speech/providers/local/runtime.d.ts +4 -4
- package/dist/server/server/speech/providers/local/runtime.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/runtime.js +108 -77
- package/dist/server/server/speech/providers/local/runtime.js.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/model-catalog.d.ts +2 -2
- package/dist/server/server/speech/providers/local/sherpa/model-catalog.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/model-catalog.js +1 -4
- package/dist/server/server/speech/providers/local/sherpa/model-catalog.js.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/model-downloader.d.ts +2 -2
- package/dist/server/server/speech/providers/local/sherpa/model-downloader.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/model-downloader.js +19 -19
- package/dist/server/server/speech/providers/local/sherpa/model-downloader.js.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-offline-recognizer.d.ts +28 -7
- package/dist/server/server/speech/providers/local/sherpa/sherpa-offline-recognizer.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-offline-recognizer.js.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.d.ts +23 -4
- package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.js +35 -28
- package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.js.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-loader.d.ts +5 -5
- package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-loader.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.d.ts +7 -7
- package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.js +5 -0
- package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.js.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-realtime-session.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-realtime-session.js +3 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-realtime-session.js.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.d.ts +2 -2
- package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.js +3 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.js.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-realtime-session.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-realtime-session.js +10 -4
- package/dist/server/server/speech/providers/local/sherpa/sherpa-realtime-session.js.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-runtime-env.d.ts +2 -2
- package/dist/server/server/speech/providers/local/sherpa/sherpa-runtime-env.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.d.ts +2 -2
- package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.js +4 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.js.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.d.ts +2 -2
- package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.d.ts.map +1 -1
- package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.js +18 -11
- package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.js.map +1 -1
- package/dist/server/server/speech/providers/openai/config.d.ts +2 -2
- package/dist/server/server/speech/providers/openai/config.d.ts.map +1 -1
- package/dist/server/server/speech/providers/openai/config.js +58 -31
- package/dist/server/server/speech/providers/openai/config.js.map +1 -1
- package/dist/server/server/speech/providers/openai/realtime-transcription-session.d.ts.map +1 -1
- package/dist/server/server/speech/providers/openai/realtime-transcription-session.js +2 -2
- package/dist/server/server/speech/providers/openai/realtime-transcription-session.js.map +1 -1
- package/dist/server/server/speech/providers/openai/runtime.d.ts +4 -4
- package/dist/server/server/speech/providers/openai/runtime.d.ts.map +1 -1
- package/dist/server/server/speech/providers/openai/runtime.js +37 -32
- package/dist/server/server/speech/providers/openai/runtime.js.map +1 -1
- package/dist/server/server/speech/providers/openai/stt.d.ts.map +1 -1
- package/dist/server/server/speech/providers/openai/stt.js +4 -3
- package/dist/server/server/speech/providers/openai/stt.js.map +1 -1
- package/dist/server/server/speech/providers/openai/tts.d.ts.map +1 -1
- package/dist/server/server/speech/providers/openai/tts.js +3 -2
- package/dist/server/server/speech/providers/openai/tts.js.map +1 -1
- package/dist/server/server/speech/speech-config-resolver.d.ts.map +1 -1
- package/dist/server/server/speech/speech-config-resolver.js +46 -17
- package/dist/server/server/speech/speech-config-resolver.js.map +1 -1
- package/dist/server/server/speech/speech-provider.d.ts +2 -2
- package/dist/server/server/speech/speech-provider.d.ts.map +1 -1
- package/dist/server/server/speech/speech-runtime.d.ts +6 -6
- package/dist/server/server/speech/speech-runtime.d.ts.map +1 -1
- package/dist/server/server/speech/speech-runtime.js +17 -17
- package/dist/server/server/speech/speech-runtime.js.map +1 -1
- package/dist/server/server/speech/speech-types.d.ts +2 -2
- package/dist/server/server/speech/speech-types.d.ts.map +1 -1
- package/dist/server/server/speech/turn-detection-provider.d.ts +2 -2
- package/dist/server/server/speech/turn-detection-provider.d.ts.map +1 -1
- package/dist/server/server/utils/diff-highlighter.d.ts +0 -3
- package/dist/server/server/utils/diff-highlighter.d.ts.map +1 -1
- package/dist/server/server/utils/diff-highlighter.js +67 -66
- package/dist/server/server/utils/diff-highlighter.js.map +1 -1
- package/dist/server/server/voice/voice-turn-controller.d.ts.map +1 -1
- package/dist/server/server/voice/voice-turn-controller.js +1 -0
- package/dist/server/server/voice/voice-turn-controller.js.map +1 -1
- package/dist/server/server/voice-types.d.ts +2 -2
- package/dist/server/server/voice-types.d.ts.map +1 -1
- package/dist/server/server/websocket-server.d.ts +33 -23
- package/dist/server/server/websocket-server.d.ts.map +1 -1
- package/dist/server/server/websocket-server.js +349 -241
- package/dist/server/server/websocket-server.js.map +1 -1
- package/dist/server/server/workspace-git-metadata.d.ts +2 -2
- package/dist/server/server/workspace-git-metadata.d.ts.map +1 -1
- package/dist/server/server/workspace-git-metadata.js +2 -32
- package/dist/server/server/workspace-git-metadata.js.map +1 -1
- package/dist/server/server/workspace-git-service.d.ts +17 -13
- package/dist/server/server/workspace-git-service.d.ts.map +1 -1
- package/dist/server/server/workspace-git-service.js +232 -140
- package/dist/server/server/workspace-git-service.js.map +1 -1
- package/dist/server/server/workspace-reconciliation-service.d.ts +5 -4
- package/dist/server/server/workspace-reconciliation-service.d.ts.map +1 -1
- package/dist/server/server/workspace-reconciliation-service.js +82 -82
- package/dist/server/server/workspace-reconciliation-service.js.map +1 -1
- package/dist/server/server/workspace-registry-bootstrap.d.ts.map +1 -1
- package/dist/server/server/workspace-registry-bootstrap.js +40 -33
- package/dist/server/server/workspace-registry-bootstrap.js.map +1 -1
- package/dist/server/server/workspace-registry-model.d.ts +19 -6
- package/dist/server/server/workspace-registry-model.d.ts.map +1 -1
- package/dist/server/server/workspace-registry-model.js +35 -21
- package/dist/server/server/workspace-registry-model.js.map +1 -1
- package/dist/server/server/workspace-registry.d.ts +2 -2
- package/dist/server/server/workspace-script-runtime-store.d.ts +2 -2
- package/dist/server/server/workspace-script-runtime-store.d.ts.map +1 -1
- package/dist/server/server/workspace-service-env.js +3 -3
- package/dist/server/server/workspace-service-env.js.map +1 -1
- package/dist/server/server/worktree-bootstrap.d.ts +4 -4
- package/dist/server/server/worktree-bootstrap.d.ts.map +1 -1
- package/dist/server/server/worktree-bootstrap.js +95 -67
- package/dist/server/server/worktree-bootstrap.js.map +1 -1
- package/dist/server/server/worktree-session.d.ts +8 -8
- package/dist/server/server/worktree-session.d.ts.map +1 -1
- package/dist/server/server/worktree-session.js +27 -19
- package/dist/server/server/worktree-session.js.map +1 -1
- package/dist/server/services/github-service.d.ts +2 -7
- package/dist/server/services/github-service.d.ts.map +1 -1
- package/dist/server/services/github-service.js +156 -157
- package/dist/server/services/github-service.js.map +1 -1
- package/dist/server/shared/agent-attention-notification.d.ts +9 -8
- package/dist/server/shared/agent-attention-notification.d.ts.map +1 -1
- package/dist/server/shared/agent-attention-notification.js +27 -17
- package/dist/server/shared/agent-attention-notification.js.map +1 -1
- package/dist/server/shared/daemon-endpoints.d.ts +2 -2
- package/dist/server/shared/daemon-endpoints.d.ts.map +1 -1
- package/dist/server/shared/daemon-endpoints.js +17 -2
- package/dist/server/shared/daemon-endpoints.js.map +1 -1
- package/dist/server/shared/messages.d.ts +21962 -3049
- package/dist/server/shared/messages.d.ts.map +1 -1
- package/dist/server/shared/messages.js +79 -2
- package/dist/server/shared/messages.js.map +1 -1
- package/dist/server/shared/terminal-stream-protocol.d.ts +2 -2
- package/dist/server/shared/terminal-stream-protocol.d.ts.map +1 -1
- package/dist/server/shared/tool-call-display.d.ts +2 -2
- package/dist/server/shared/tool-call-display.d.ts.map +1 -1
- package/dist/server/terminal/terminal-manager.d.ts.map +1 -1
- package/dist/server/terminal/terminal-manager.js +1 -3
- package/dist/server/terminal/terminal-manager.js.map +1 -1
- package/dist/server/terminal/terminal-output-coalescer.d.ts +6 -6
- package/dist/server/terminal/terminal-output-coalescer.d.ts.map +1 -1
- package/dist/server/terminal/terminal.d.ts +3 -2
- package/dist/server/terminal/terminal.d.ts.map +1 -1
- package/dist/server/terminal/terminal.js +57 -19
- package/dist/server/terminal/terminal.js.map +1 -1
- package/dist/server/utils/checkout-git.d.ts +13 -12
- package/dist/server/utils/checkout-git.d.ts.map +1 -1
- package/dist/server/utils/checkout-git.js +416 -282
- package/dist/server/utils/checkout-git.js.map +1 -1
- package/dist/server/utils/directory-suggestions.js +12 -33
- package/dist/server/utils/directory-suggestions.js.map +1 -1
- package/dist/server/utils/executable.d.ts +1 -14
- package/dist/server/utils/executable.d.ts.map +1 -1
- package/dist/server/utils/executable.js +13 -49
- package/dist/server/utils/executable.js.map +1 -1
- package/dist/server/utils/github-remote.d.ts +13 -0
- package/dist/server/utils/github-remote.d.ts.map +1 -0
- package/dist/server/utils/github-remote.js +128 -0
- package/dist/server/utils/github-remote.js.map +1 -0
- package/dist/server/utils/paseo-config-file.d.ts +30 -0
- package/dist/server/utils/paseo-config-file.d.ts.map +1 -0
- package/dist/server/utils/paseo-config-file.js +90 -0
- package/dist/server/utils/paseo-config-file.js.map +1 -0
- package/dist/server/utils/paseo-config-schema.d.ts +290 -0
- package/dist/server/utils/paseo-config-schema.d.ts.map +1 -0
- package/dist/server/utils/paseo-config-schema.js +60 -0
- package/dist/server/utils/paseo-config-schema.js.map +1 -0
- package/dist/server/utils/project-icon.d.ts.map +1 -1
- package/dist/server/utils/project-icon.js +84 -109
- package/dist/server/utils/project-icon.js.map +1 -1
- package/dist/server/utils/promise-timeout.d.ts +2 -2
- package/dist/server/utils/promise-timeout.d.ts.map +1 -1
- package/dist/server/utils/run-git-command.d.ts +3 -1
- package/dist/server/utils/run-git-command.d.ts.map +1 -1
- package/dist/server/utils/run-git-command.js +10 -1
- package/dist/server/utils/run-git-command.js.map +1 -1
- package/dist/server/utils/script-hostname.d.ts +2 -2
- package/dist/server/utils/script-hostname.d.ts.map +1 -1
- package/dist/server/utils/spawn.d.ts +10 -3
- package/dist/server/utils/spawn.d.ts.map +1 -1
- package/dist/server/utils/spawn.js +30 -5
- package/dist/server/utils/spawn.js.map +1 -1
- package/dist/server/utils/windows-command.d.ts +15 -0
- package/dist/server/utils/windows-command.d.ts.map +1 -0
- package/dist/server/utils/windows-command.js +37 -0
- package/dist/server/utils/windows-command.js.map +1 -0
- package/dist/server/utils/worktree.d.ts +10 -7
- package/dist/server/utils/worktree.d.ts.map +1 -1
- package/dist/server/utils/worktree.js +64 -55
- package/dist/server/utils/worktree.js.map +1 -1
- package/dist/src/server/pid-lock.js.map +1 -1
- package/package.json +15 -20
- package/dist/server/server/agent/llm-openai.d.ts +0 -7
- package/dist/server/server/agent/llm-openai.d.ts.map +0 -1
- package/dist/server/server/agent/llm-openai.js +0 -8
- package/dist/server/server/agent/llm-openai.js.map +0 -1
- package/dist/server/server/agent/orchestrator.d.ts +0 -12
- package/dist/server/server/agent/orchestrator.d.ts.map +0 -1
- package/dist/server/server/agent/orchestrator.js +0 -12
- package/dist/server/server/agent/orchestrator.js.map +0 -1
- package/dist/server/server/types.d.ts +0 -5
- package/dist/server/server/types.d.ts.map +0 -1
- package/dist/server/server/types.js +0 -3
- package/dist/server/server/types.js.map +0 -1
- package/dist/server/server/workspace-registry.test-helpers.d.ts +0 -37
- package/dist/server/server/workspace-registry.test-helpers.d.ts.map +0 -1
- package/dist/server/server/workspace-registry.test-helpers.js +0 -121
- package/dist/server/server/workspace-registry.test-helpers.js.map +0 -1
|
@@ -1,68 +1,84 @@
|
|
|
1
1
|
import { WebSocketServer } from "ws";
|
|
2
|
-
import { join } from "path";
|
|
2
|
+
import { basename, join } from "path";
|
|
3
3
|
import { hostname as getHostname } from "node:os";
|
|
4
|
+
import { applyMutableProviderConfigToOverrides } from "./daemon-config-store.js";
|
|
4
5
|
import { WSInboundMessageSchema, wrapSessionMessage, } from "./messages.js";
|
|
5
6
|
import { asUint8Array, decodeTerminalStreamFrame } from "../shared/terminal-stream-protocol.js";
|
|
6
7
|
import { isHostnameAllowed } from "./hostnames.js";
|
|
7
8
|
import { Session } from "./session.js";
|
|
8
9
|
import { ProviderSnapshotManager } from "./agent/provider-snapshot-manager.js";
|
|
9
|
-
import { buildProviderRegistry } from "./agent/provider-registry.js";
|
|
10
|
+
import { buildProviderRegistry, createClientsFromRegistry } from "./agent/provider-registry.js";
|
|
11
|
+
import { buildWorkspaceGitMetadataFromSnapshot } from "./workspace-git-metadata.js";
|
|
10
12
|
import { PushTokenStore } from "./push/token-store.js";
|
|
11
13
|
import { PushService } from "./push/push-service.js";
|
|
12
14
|
import { computeNotificationPlan } from "./agent-attention-policy.js";
|
|
13
15
|
import { buildAgentAttentionNotificationPayload, findLatestPermissionRequest, } from "../shared/agent-attention-notification.js";
|
|
14
16
|
import { createGitHubService } from "../services/github-service.js";
|
|
17
|
+
function createFallbackWorkspaceGitSnapshot(cwd) {
|
|
18
|
+
return {
|
|
19
|
+
cwd,
|
|
20
|
+
git: {
|
|
21
|
+
isGit: false,
|
|
22
|
+
repoRoot: null,
|
|
23
|
+
mainRepoRoot: null,
|
|
24
|
+
currentBranch: null,
|
|
25
|
+
remoteUrl: null,
|
|
26
|
+
isPaseoOwnedWorktree: false,
|
|
27
|
+
isDirty: null,
|
|
28
|
+
baseRef: null,
|
|
29
|
+
aheadBehind: null,
|
|
30
|
+
aheadOfOrigin: null,
|
|
31
|
+
behindOfOrigin: null,
|
|
32
|
+
hasRemote: false,
|
|
33
|
+
diffStat: null,
|
|
34
|
+
},
|
|
35
|
+
github: {
|
|
36
|
+
featuresEnabled: false,
|
|
37
|
+
pullRequest: null,
|
|
38
|
+
error: null,
|
|
39
|
+
},
|
|
40
|
+
};
|
|
41
|
+
}
|
|
15
42
|
function createFallbackWorkspaceGitService() {
|
|
16
43
|
return {
|
|
17
|
-
|
|
18
|
-
initial: {
|
|
19
|
-
cwd,
|
|
20
|
-
git: {
|
|
21
|
-
isGit: false,
|
|
22
|
-
repoRoot: null,
|
|
23
|
-
mainRepoRoot: null,
|
|
24
|
-
currentBranch: null,
|
|
25
|
-
remoteUrl: null,
|
|
26
|
-
isPaseoOwnedWorktree: false,
|
|
27
|
-
isDirty: null,
|
|
28
|
-
aheadBehind: null,
|
|
29
|
-
aheadOfOrigin: null,
|
|
30
|
-
behindOfOrigin: null,
|
|
31
|
-
diffStat: null,
|
|
32
|
-
},
|
|
33
|
-
github: {
|
|
34
|
-
featuresEnabled: false,
|
|
35
|
-
pullRequest: null,
|
|
36
|
-
error: null,
|
|
37
|
-
},
|
|
38
|
-
},
|
|
44
|
+
registerWorkspace: () => ({
|
|
39
45
|
unsubscribe: () => { },
|
|
40
46
|
}),
|
|
41
47
|
peekSnapshot: () => null,
|
|
42
|
-
|
|
48
|
+
getCheckout: async (cwd) => ({
|
|
43
49
|
cwd,
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
isPaseoOwnedWorktree: false,
|
|
51
|
-
isDirty: null,
|
|
52
|
-
aheadBehind: null,
|
|
53
|
-
aheadOfOrigin: null,
|
|
54
|
-
behindOfOrigin: null,
|
|
55
|
-
diffStat: null,
|
|
56
|
-
},
|
|
57
|
-
github: {
|
|
58
|
-
featuresEnabled: false,
|
|
59
|
-
pullRequest: null,
|
|
60
|
-
error: null,
|
|
61
|
-
},
|
|
50
|
+
isGit: false,
|
|
51
|
+
currentBranch: null,
|
|
52
|
+
remoteUrl: null,
|
|
53
|
+
worktreeRoot: null,
|
|
54
|
+
isPaseoOwnedWorktree: false,
|
|
55
|
+
mainRepoRoot: null,
|
|
62
56
|
}),
|
|
57
|
+
getSnapshot: async (cwd) => createFallbackWorkspaceGitSnapshot(cwd),
|
|
58
|
+
getCheckoutDiff: async () => ({ diff: "" }),
|
|
59
|
+
validateBranchRef: async () => ({ kind: "not-found" }),
|
|
60
|
+
hasLocalBranch: async () => false,
|
|
61
|
+
suggestBranchesForCwd: async () => [],
|
|
62
|
+
listStashes: async () => [],
|
|
63
|
+
listWorktrees: async () => [],
|
|
64
|
+
getWorkspaceGitMetadata: async (cwd, options) => {
|
|
65
|
+
const snapshot = createFallbackWorkspaceGitSnapshot(cwd);
|
|
66
|
+
return buildWorkspaceGitMetadataFromSnapshot({
|
|
67
|
+
cwd,
|
|
68
|
+
directoryName: options?.directoryName ?? basename(cwd),
|
|
69
|
+
isGit: snapshot.git.isGit,
|
|
70
|
+
repoRoot: snapshot.git.repoRoot,
|
|
71
|
+
mainRepoRoot: snapshot.git.mainRepoRoot,
|
|
72
|
+
currentBranch: snapshot.git.currentBranch,
|
|
73
|
+
remoteUrl: snapshot.git.remoteUrl,
|
|
74
|
+
});
|
|
75
|
+
},
|
|
76
|
+
resolveRepoRoot: async (cwd) => cwd,
|
|
77
|
+
resolveDefaultBranch: async () => "main",
|
|
78
|
+
resolveRepoRemoteUrl: async () => null,
|
|
63
79
|
refresh: async () => { },
|
|
64
|
-
requestWorkingTreeWatch: async (
|
|
65
|
-
repoRoot:
|
|
80
|
+
requestWorkingTreeWatch: async () => ({
|
|
81
|
+
repoRoot: null,
|
|
66
82
|
unsubscribe: () => { },
|
|
67
83
|
}),
|
|
68
84
|
scheduleRefreshForCwd: () => { },
|
|
@@ -163,6 +179,22 @@ export class MissingDaemonVersionError extends Error {
|
|
|
163
179
|
this.name = "MissingDaemonVersionError";
|
|
164
180
|
}
|
|
165
181
|
}
|
|
182
|
+
function requireWebSocketServices(params) {
|
|
183
|
+
const { chatService, loopService, scheduleService, checkoutDiffManager } = params;
|
|
184
|
+
if (!chatService) {
|
|
185
|
+
throw new Error("VoiceAssistantWebSocketServer requires a chat service.");
|
|
186
|
+
}
|
|
187
|
+
if (!loopService) {
|
|
188
|
+
throw new Error("VoiceAssistantWebSocketServer requires a loop service.");
|
|
189
|
+
}
|
|
190
|
+
if (!scheduleService) {
|
|
191
|
+
throw new Error("VoiceAssistantWebSocketServer requires a schedule service.");
|
|
192
|
+
}
|
|
193
|
+
if (!checkoutDiffManager) {
|
|
194
|
+
throw new Error("VoiceAssistantWebSocketServer requires a checkout diff manager.");
|
|
195
|
+
}
|
|
196
|
+
return { chatService, loopService, scheduleService, checkoutDiffManager };
|
|
197
|
+
}
|
|
166
198
|
/**
|
|
167
199
|
* WebSocket server that only accepts sockets + parses/forwards messages to the session layer.
|
|
168
200
|
*/
|
|
@@ -214,47 +246,43 @@ export class VoiceAssistantWebSocketServer {
|
|
|
214
246
|
this.agentStorage = agentStorage;
|
|
215
247
|
this.projectRegistry = projectRegistry ?? createNoopProjectRegistry();
|
|
216
248
|
this.workspaceRegistry = workspaceRegistry ?? createNoopWorkspaceRegistry();
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
this.loopService = loopService;
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
}
|
|
228
|
-
this.scheduleService = scheduleService;
|
|
229
|
-
if (!checkoutDiffManager) {
|
|
230
|
-
throw new Error("VoiceAssistantWebSocketServer requires a checkout diff manager.");
|
|
231
|
-
}
|
|
232
|
-
this.checkoutDiffManager = checkoutDiffManager;
|
|
249
|
+
const requiredServices = requireWebSocketServices({
|
|
250
|
+
chatService,
|
|
251
|
+
loopService,
|
|
252
|
+
scheduleService,
|
|
253
|
+
checkoutDiffManager,
|
|
254
|
+
});
|
|
255
|
+
this.chatService = requiredServices.chatService;
|
|
256
|
+
this.loopService = requiredServices.loopService;
|
|
257
|
+
this.scheduleService = requiredServices.scheduleService;
|
|
258
|
+
this.checkoutDiffManager = requiredServices.checkoutDiffManager;
|
|
233
259
|
this.github = github ?? createGitHubService();
|
|
234
260
|
this.workspaceGitService = workspaceGitService ?? createFallbackWorkspaceGitService();
|
|
235
261
|
this.downloadTokenStore = downloadTokenStore;
|
|
236
262
|
this.paseoHome = paseoHome;
|
|
237
263
|
this.daemonConfigStore = daemonConfigStore;
|
|
238
264
|
this.mcpBaseUrl = mcpBaseUrl;
|
|
239
|
-
this.
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
265
|
+
this.assignOptionalServices({
|
|
266
|
+
speech,
|
|
267
|
+
terminalManager,
|
|
268
|
+
dictation,
|
|
269
|
+
agentProviderRuntimeSettings,
|
|
270
|
+
providerOverrides,
|
|
271
|
+
isDev,
|
|
272
|
+
onLifecycleIntent,
|
|
273
|
+
scriptRouteStore,
|
|
274
|
+
scriptRuntimeStore,
|
|
275
|
+
onBranchChanged,
|
|
276
|
+
getDaemonTcpPort,
|
|
277
|
+
getDaemonTcpHost,
|
|
278
|
+
resolveScriptHealth,
|
|
279
|
+
});
|
|
245
280
|
const providerSnapshotLogger = this.logger.child({ module: "provider-snapshot-manager" });
|
|
246
281
|
this.providerSnapshotManager = new ProviderSnapshotManager(buildProviderRegistry(providerSnapshotLogger, {
|
|
247
282
|
runtimeSettings: this.agentProviderRuntimeSettings,
|
|
248
283
|
providerOverrides: this.providerOverrides,
|
|
249
284
|
isDev: this.isDev,
|
|
250
285
|
}), providerSnapshotLogger);
|
|
251
|
-
this.onLifecycleIntent = onLifecycleIntent ?? null;
|
|
252
|
-
this.scriptRouteStore = scriptRouteStore ?? null;
|
|
253
|
-
this.scriptRuntimeStore = scriptRuntimeStore ?? null;
|
|
254
|
-
this.onBranchChanged = onBranchChanged ?? null;
|
|
255
|
-
this.getDaemonTcpPort = getDaemonTcpPort ?? null;
|
|
256
|
-
this.getDaemonTcpHost = getDaemonTcpHost ?? null;
|
|
257
|
-
this.resolveScriptHealth = resolveScriptHealth ?? null;
|
|
258
286
|
this.serverCapabilities = buildServerCapabilities({
|
|
259
287
|
readiness: this.speech?.getReadiness() ?? null,
|
|
260
288
|
});
|
|
@@ -263,6 +291,15 @@ export class VoiceAssistantWebSocketServer {
|
|
|
263
291
|
this.publishSpeechReadiness(snapshot);
|
|
264
292
|
}) ?? null;
|
|
265
293
|
this.unsubscribeDaemonConfigChange = this.daemonConfigStore.onChange((config) => {
|
|
294
|
+
this.providerOverrides = applyMutableProviderConfigToOverrides(this.providerOverrides, config.providers);
|
|
295
|
+
const registry = buildProviderRegistry(providerSnapshotLogger, {
|
|
296
|
+
runtimeSettings: this.agentProviderRuntimeSettings,
|
|
297
|
+
providerOverrides: this.providerOverrides,
|
|
298
|
+
isDev: this.isDev,
|
|
299
|
+
});
|
|
300
|
+
const clients = createClientsFromRegistry(registry, providerSnapshotLogger);
|
|
301
|
+
this.providerSnapshotManager.replaceRegistry(registry);
|
|
302
|
+
this.agentManager.updateProviderRegistry({ providerDefinitions: registry, clients });
|
|
266
303
|
this.broadcastDaemonConfigChanged(config);
|
|
267
304
|
});
|
|
268
305
|
const pushLogger = this.logger.child({ module: "push" });
|
|
@@ -273,42 +310,67 @@ export class VoiceAssistantWebSocketServer {
|
|
|
273
310
|
this.logger.warn({ err, agentId: params.agentId }, "Failed to broadcast agent attention");
|
|
274
311
|
});
|
|
275
312
|
});
|
|
313
|
+
this.wss = this.createWebSocketServer(server, wsConfig);
|
|
314
|
+
this.startRuntimeMetricsInterval();
|
|
315
|
+
this.logger.info("WebSocket server initialized on /ws");
|
|
316
|
+
}
|
|
317
|
+
assignOptionalServices(params) {
|
|
318
|
+
this.speech = params.speech ?? null;
|
|
319
|
+
this.terminalManager = params.terminalManager ?? null;
|
|
320
|
+
this.dictation = params.dictation ?? null;
|
|
321
|
+
this.agentProviderRuntimeSettings = params.agentProviderRuntimeSettings;
|
|
322
|
+
this.providerOverrides = params.providerOverrides;
|
|
323
|
+
this.isDev = params.isDev === true;
|
|
324
|
+
this.onLifecycleIntent = params.onLifecycleIntent ?? null;
|
|
325
|
+
this.scriptRouteStore = params.scriptRouteStore ?? null;
|
|
326
|
+
this.scriptRuntimeStore = params.scriptRuntimeStore ?? null;
|
|
327
|
+
this.onBranchChanged = params.onBranchChanged ?? null;
|
|
328
|
+
this.getDaemonTcpPort = params.getDaemonTcpPort ?? null;
|
|
329
|
+
this.getDaemonTcpHost = params.getDaemonTcpHost ?? null;
|
|
330
|
+
this.resolveScriptHealth = params.resolveScriptHealth ?? null;
|
|
331
|
+
}
|
|
332
|
+
createWebSocketServer(server, wsConfig) {
|
|
276
333
|
const { allowedOrigins, hostnames } = wsConfig;
|
|
277
|
-
|
|
334
|
+
const wss = new WebSocketServer({
|
|
278
335
|
server,
|
|
279
336
|
path: "/ws",
|
|
280
337
|
verifyClient: ({ req }, callback) => {
|
|
281
|
-
|
|
282
|
-
const origin = requestMetadata.origin;
|
|
283
|
-
const requestHost = requestMetadata.host ?? null;
|
|
284
|
-
if (requestHost && !isHostnameAllowed(requestHost, hostnames)) {
|
|
285
|
-
this.incrementRuntimeCounter("hostRejected");
|
|
286
|
-
this.logger.warn({ ...requestMetadata, host: requestHost }, "Rejected connection from disallowed host");
|
|
287
|
-
callback(false, 403, "Host not allowed");
|
|
288
|
-
return;
|
|
289
|
-
}
|
|
290
|
-
const sameOrigin = !!origin &&
|
|
291
|
-
!!requestHost &&
|
|
292
|
-
(origin === `http://${requestHost}` || origin === `https://${requestHost}`);
|
|
293
|
-
if (!origin || allowedOrigins.has("*") || allowedOrigins.has(origin) || sameOrigin) {
|
|
294
|
-
callback(true);
|
|
295
|
-
}
|
|
296
|
-
else {
|
|
297
|
-
this.incrementRuntimeCounter("originRejected");
|
|
298
|
-
this.logger.warn({ ...requestMetadata, origin }, "Rejected connection from origin");
|
|
299
|
-
callback(false, 403, "Origin not allowed");
|
|
300
|
-
}
|
|
338
|
+
this.verifyWsClient(req, allowedOrigins, hostnames, callback);
|
|
301
339
|
},
|
|
302
340
|
});
|
|
303
|
-
|
|
341
|
+
wss.on("connection", (ws, request) => {
|
|
304
342
|
void this.attachSocket(ws, request);
|
|
305
343
|
});
|
|
344
|
+
return wss;
|
|
345
|
+
}
|
|
346
|
+
startRuntimeMetricsInterval() {
|
|
306
347
|
const runtimeMetricsInterval = setInterval(() => {
|
|
307
348
|
this.flushRuntimeMetrics();
|
|
308
349
|
}, WS_RUNTIME_METRICS_FLUSH_MS);
|
|
309
350
|
this.runtimeMetricsInterval = runtimeMetricsInterval;
|
|
310
351
|
runtimeMetricsInterval.unref?.();
|
|
311
|
-
|
|
352
|
+
}
|
|
353
|
+
verifyWsClient(req, allowedOrigins, hostnames, callback) {
|
|
354
|
+
const requestMetadata = extractSocketRequestMetadata(req);
|
|
355
|
+
const origin = requestMetadata.origin;
|
|
356
|
+
const requestHost = requestMetadata.host ?? null;
|
|
357
|
+
if (requestHost && !isHostnameAllowed(requestHost, hostnames)) {
|
|
358
|
+
this.incrementRuntimeCounter("hostRejected");
|
|
359
|
+
this.logger.warn({ ...requestMetadata, host: requestHost }, "Rejected connection from disallowed host");
|
|
360
|
+
callback(false, 403, "Host not allowed");
|
|
361
|
+
return;
|
|
362
|
+
}
|
|
363
|
+
const sameOrigin = !!origin &&
|
|
364
|
+
!!requestHost &&
|
|
365
|
+
(origin === `http://${requestHost}` || origin === `https://${requestHost}`);
|
|
366
|
+
if (!origin || allowedOrigins.has("*") || allowedOrigins.has(origin) || sameOrigin) {
|
|
367
|
+
callback(true);
|
|
368
|
+
}
|
|
369
|
+
else {
|
|
370
|
+
this.incrementRuntimeCounter("originRejected");
|
|
371
|
+
this.logger.warn({ ...requestMetadata, origin }, "Rejected connection from origin");
|
|
372
|
+
callback(false, 403, "Origin not allowed");
|
|
373
|
+
}
|
|
312
374
|
}
|
|
313
375
|
broadcast(message) {
|
|
314
376
|
const payload = JSON.stringify(message);
|
|
@@ -672,16 +734,20 @@ export class VoiceAssistantWebSocketServer {
|
|
|
672
734
|
this.broadcast(this.createDaemonConfigChangedMessage(config));
|
|
673
735
|
}
|
|
674
736
|
bindSocketHandlers(ws) {
|
|
675
|
-
ws.on("message", (
|
|
737
|
+
ws.on("message", (...args) => {
|
|
738
|
+
const data = args[0];
|
|
676
739
|
void this.handleRawMessage(ws, data);
|
|
677
740
|
});
|
|
678
|
-
ws.on("close", async (
|
|
741
|
+
ws.on("close", async (...args) => {
|
|
742
|
+
const code = args[0];
|
|
743
|
+
const reason = args[1];
|
|
679
744
|
await this.detachSocket(ws, {
|
|
680
745
|
code: typeof code === "number" ? code : undefined,
|
|
681
746
|
reason,
|
|
682
747
|
});
|
|
683
748
|
});
|
|
684
|
-
ws.on("error", async (
|
|
749
|
+
ws.on("error", async (...args) => {
|
|
750
|
+
const error = args[0];
|
|
685
751
|
const err = error instanceof Error ? error : new Error(String(error));
|
|
686
752
|
const active = this.sessions.get(ws);
|
|
687
753
|
const pending = this.pendingConnections.get(ws);
|
|
@@ -762,81 +828,126 @@ export class VoiceAssistantWebSocketServer {
|
|
|
762
828
|
connection.connectionLogger.trace({ clientId: connection.clientId, totalSessions: this.sessions.size }, logMessage);
|
|
763
829
|
await connection.session.cleanup();
|
|
764
830
|
}
|
|
831
|
+
handleInvalidInboundMessage(args) {
|
|
832
|
+
const { ws, parsed, parsedMessage, pendingConnection, activeConnection, log } = args;
|
|
833
|
+
this.incrementRuntimeCounter("validationFailed");
|
|
834
|
+
if (pendingConnection) {
|
|
835
|
+
pendingConnection.connectionLogger.warn({ error: parsedMessage.error.message }, "Rejected pending message before hello");
|
|
836
|
+
this.clearPendingConnection(ws);
|
|
837
|
+
try {
|
|
838
|
+
ws.close(WS_CLOSE_INVALID_HELLO, "Invalid hello");
|
|
839
|
+
}
|
|
840
|
+
catch {
|
|
841
|
+
// ignore close errors
|
|
842
|
+
}
|
|
843
|
+
return;
|
|
844
|
+
}
|
|
845
|
+
const requestInfo = extractRequestInfoFromUnknownWsInbound(parsed);
|
|
846
|
+
const isUnknownSchema = requestInfo?.requestId != null &&
|
|
847
|
+
typeof parsed === "object" &&
|
|
848
|
+
parsed != null &&
|
|
849
|
+
"type" in parsed &&
|
|
850
|
+
parsed.type === "session";
|
|
851
|
+
log.warn({
|
|
852
|
+
clientId: activeConnection?.clientId,
|
|
853
|
+
requestId: requestInfo?.requestId,
|
|
854
|
+
requestType: requestInfo?.requestType,
|
|
855
|
+
error: parsedMessage.error.message,
|
|
856
|
+
}, "WS inbound message validation failed");
|
|
857
|
+
if (requestInfo) {
|
|
858
|
+
this.sendToClient(ws, wrapSessionMessage({
|
|
859
|
+
type: "rpc_error",
|
|
860
|
+
payload: {
|
|
861
|
+
requestId: requestInfo.requestId,
|
|
862
|
+
requestType: requestInfo.requestType,
|
|
863
|
+
error: isUnknownSchema ? "Unknown request schema" : "Invalid message",
|
|
864
|
+
code: isUnknownSchema ? "unknown_schema" : "invalid_message",
|
|
865
|
+
},
|
|
866
|
+
}));
|
|
867
|
+
return;
|
|
868
|
+
}
|
|
869
|
+
const errorMessage = `Invalid message: ${parsedMessage.error.message}`;
|
|
870
|
+
this.sendToClient(ws, wrapSessionMessage({
|
|
871
|
+
type: "status",
|
|
872
|
+
payload: {
|
|
873
|
+
status: "error",
|
|
874
|
+
message: errorMessage,
|
|
875
|
+
},
|
|
876
|
+
}));
|
|
877
|
+
}
|
|
878
|
+
maybeHandleBinaryFrame(params) {
|
|
879
|
+
const { ws, buffer, activeConnection, log } = params;
|
|
880
|
+
const asBytes = asUint8Array(buffer);
|
|
881
|
+
if (!asBytes) {
|
|
882
|
+
return false;
|
|
883
|
+
}
|
|
884
|
+
const frame = decodeTerminalStreamFrame(asBytes);
|
|
885
|
+
if (!frame) {
|
|
886
|
+
return false;
|
|
887
|
+
}
|
|
888
|
+
if (!activeConnection) {
|
|
889
|
+
this.incrementRuntimeCounter("binaryBeforeHelloRejected");
|
|
890
|
+
log.warn("Rejected binary frame before hello");
|
|
891
|
+
this.clearPendingConnection(ws);
|
|
892
|
+
try {
|
|
893
|
+
ws.close(WS_CLOSE_INVALID_HELLO, "Session message before hello");
|
|
894
|
+
}
|
|
895
|
+
catch {
|
|
896
|
+
// ignore close errors
|
|
897
|
+
}
|
|
898
|
+
return true;
|
|
899
|
+
}
|
|
900
|
+
activeConnection.session.handleBinaryFrame(frame);
|
|
901
|
+
return true;
|
|
902
|
+
}
|
|
903
|
+
handlePendingConnectionMessage(params) {
|
|
904
|
+
const { ws, message, pendingConnection } = params;
|
|
905
|
+
if (message.type === "hello") {
|
|
906
|
+
this.handleHello({
|
|
907
|
+
ws,
|
|
908
|
+
message,
|
|
909
|
+
pending: pendingConnection,
|
|
910
|
+
});
|
|
911
|
+
return;
|
|
912
|
+
}
|
|
913
|
+
pendingConnection.connectionLogger.warn({
|
|
914
|
+
messageType: message.type,
|
|
915
|
+
}, "Rejected pending message before hello");
|
|
916
|
+
this.incrementRuntimeCounter("pendingMessageRejectedBeforeHello");
|
|
917
|
+
this.clearPendingConnection(ws);
|
|
918
|
+
try {
|
|
919
|
+
ws.close(WS_CLOSE_INVALID_HELLO, "Session message before hello");
|
|
920
|
+
}
|
|
921
|
+
catch {
|
|
922
|
+
// ignore close errors
|
|
923
|
+
}
|
|
924
|
+
}
|
|
765
925
|
async handleRawMessage(ws, data) {
|
|
766
926
|
const activeConnection = this.sessions.get(ws);
|
|
767
927
|
const pendingConnection = this.pendingConnections.get(ws);
|
|
768
928
|
const log = activeConnection?.connectionLogger ?? pendingConnection?.connectionLogger ?? this.logger;
|
|
769
929
|
try {
|
|
770
930
|
const buffer = bufferFromWsData(data);
|
|
771
|
-
const
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
try {
|
|
780
|
-
ws.close(WS_CLOSE_INVALID_HELLO, "Session message before hello");
|
|
781
|
-
}
|
|
782
|
-
catch {
|
|
783
|
-
// ignore close errors
|
|
784
|
-
}
|
|
785
|
-
return;
|
|
786
|
-
}
|
|
787
|
-
activeConnection.session.handleBinaryFrame(frame);
|
|
788
|
-
return;
|
|
789
|
-
}
|
|
931
|
+
const binaryHandled = this.maybeHandleBinaryFrame({
|
|
932
|
+
ws,
|
|
933
|
+
buffer,
|
|
934
|
+
activeConnection,
|
|
935
|
+
log,
|
|
936
|
+
});
|
|
937
|
+
if (binaryHandled) {
|
|
938
|
+
return;
|
|
790
939
|
}
|
|
791
940
|
const parsed = JSON.parse(buffer.toString());
|
|
792
941
|
const parsedMessage = WSInboundMessageSchema.safeParse(parsed);
|
|
793
942
|
if (!parsedMessage.success) {
|
|
794
|
-
this.
|
|
795
|
-
|
|
796
|
-
|
|
797
|
-
|
|
798
|
-
|
|
799
|
-
|
|
800
|
-
|
|
801
|
-
|
|
802
|
-
}
|
|
803
|
-
catch {
|
|
804
|
-
// ignore close errors
|
|
805
|
-
}
|
|
806
|
-
return;
|
|
807
|
-
}
|
|
808
|
-
const requestInfo = extractRequestInfoFromUnknownWsInbound(parsed);
|
|
809
|
-
const isUnknownSchema = requestInfo?.requestId != null &&
|
|
810
|
-
typeof parsed === "object" &&
|
|
811
|
-
parsed != null &&
|
|
812
|
-
"type" in parsed &&
|
|
813
|
-
parsed.type === "session";
|
|
814
|
-
log.warn({
|
|
815
|
-
clientId: activeConnection?.clientId,
|
|
816
|
-
requestId: requestInfo?.requestId,
|
|
817
|
-
requestType: requestInfo?.requestType,
|
|
818
|
-
error: parsedMessage.error.message,
|
|
819
|
-
}, "WS inbound message validation failed");
|
|
820
|
-
if (requestInfo) {
|
|
821
|
-
this.sendToClient(ws, wrapSessionMessage({
|
|
822
|
-
type: "rpc_error",
|
|
823
|
-
payload: {
|
|
824
|
-
requestId: requestInfo.requestId,
|
|
825
|
-
requestType: requestInfo.requestType,
|
|
826
|
-
error: isUnknownSchema ? "Unknown request schema" : "Invalid message",
|
|
827
|
-
code: isUnknownSchema ? "unknown_schema" : "invalid_message",
|
|
828
|
-
},
|
|
829
|
-
}));
|
|
830
|
-
return;
|
|
831
|
-
}
|
|
832
|
-
const errorMessage = `Invalid message: ${parsedMessage.error.message}`;
|
|
833
|
-
this.sendToClient(ws, wrapSessionMessage({
|
|
834
|
-
type: "status",
|
|
835
|
-
payload: {
|
|
836
|
-
status: "error",
|
|
837
|
-
message: errorMessage,
|
|
838
|
-
},
|
|
839
|
-
}));
|
|
943
|
+
this.handleInvalidInboundMessage({
|
|
944
|
+
ws,
|
|
945
|
+
parsed,
|
|
946
|
+
parsedMessage,
|
|
947
|
+
pendingConnection,
|
|
948
|
+
activeConnection,
|
|
949
|
+
log,
|
|
950
|
+
});
|
|
840
951
|
return;
|
|
841
952
|
}
|
|
842
953
|
const message = parsedMessage.data;
|
|
@@ -849,25 +960,11 @@ export class VoiceAssistantWebSocketServer {
|
|
|
849
960
|
return;
|
|
850
961
|
}
|
|
851
962
|
if (pendingConnection) {
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
});
|
|
858
|
-
return;
|
|
859
|
-
}
|
|
860
|
-
pendingConnection.connectionLogger.warn({
|
|
861
|
-
messageType: message.type,
|
|
862
|
-
}, "Rejected pending message before hello");
|
|
863
|
-
this.incrementRuntimeCounter("pendingMessageRejectedBeforeHello");
|
|
864
|
-
this.clearPendingConnection(ws);
|
|
865
|
-
try {
|
|
866
|
-
ws.close(WS_CLOSE_INVALID_HELLO, "Session message before hello");
|
|
867
|
-
}
|
|
868
|
-
catch {
|
|
869
|
-
// ignore close errors
|
|
870
|
-
}
|
|
963
|
+
this.handlePendingConnectionMessage({
|
|
964
|
+
ws,
|
|
965
|
+
message,
|
|
966
|
+
pendingConnection,
|
|
967
|
+
});
|
|
871
968
|
return;
|
|
872
969
|
}
|
|
873
970
|
if (!activeConnection) {
|
|
@@ -887,74 +984,85 @@ export class VoiceAssistantWebSocketServer {
|
|
|
887
984
|
return;
|
|
888
985
|
}
|
|
889
986
|
if (message.type === "session") {
|
|
890
|
-
this.
|
|
891
|
-
const startMs = performance.now();
|
|
892
|
-
await activeConnection.session.handleMessage(message.message);
|
|
893
|
-
const durationMs = performance.now() - startMs;
|
|
894
|
-
this.recordRequestLatency(message.message.type, durationMs);
|
|
895
|
-
if (durationMs >= SLOW_REQUEST_THRESHOLD_MS) {
|
|
896
|
-
activeConnection.connectionLogger.warn({
|
|
897
|
-
requestType: message.message.type,
|
|
898
|
-
durationMs: Math.round(durationMs),
|
|
899
|
-
inflightRequests: activeConnection.session.getRuntimeMetrics().inflightRequests,
|
|
900
|
-
}, "ws_slow_request");
|
|
901
|
-
}
|
|
987
|
+
await this.dispatchSessionMessage(activeConnection, message);
|
|
902
988
|
}
|
|
903
989
|
}
|
|
904
990
|
catch (error) {
|
|
905
|
-
|
|
906
|
-
|
|
907
|
-
|
|
991
|
+
this.handleRawMessageError({ ws, data, error, log });
|
|
992
|
+
}
|
|
993
|
+
}
|
|
994
|
+
async dispatchSessionMessage(activeConnection, message) {
|
|
995
|
+
this.recordInboundSessionRequestType(message.message.type);
|
|
996
|
+
const startMs = performance.now();
|
|
997
|
+
await activeConnection.session.handleMessage(message.message);
|
|
998
|
+
const durationMs = performance.now() - startMs;
|
|
999
|
+
this.recordRequestLatency(message.message.type, durationMs);
|
|
1000
|
+
if (durationMs >= SLOW_REQUEST_THRESHOLD_MS) {
|
|
1001
|
+
activeConnection.connectionLogger.warn({
|
|
1002
|
+
requestType: message.message.type,
|
|
1003
|
+
durationMs: Math.round(durationMs),
|
|
1004
|
+
inflightRequests: activeConnection.session.getRuntimeMetrics().inflightRequests,
|
|
1005
|
+
}, "ws_slow_request");
|
|
1006
|
+
}
|
|
1007
|
+
}
|
|
1008
|
+
handleRawMessageError(params) {
|
|
1009
|
+
const { ws, data, error, log } = params;
|
|
1010
|
+
const err = error instanceof Error ? error : new Error(String(error));
|
|
1011
|
+
const { rawPayload, parsedPayload } = this.decodeRawMessagePayloadForError(data);
|
|
1012
|
+
const trimmedRawPayload = typeof rawPayload === "string" && rawPayload.length > 2000
|
|
1013
|
+
? `${rawPayload.slice(0, 2000)}... (truncated)`
|
|
1014
|
+
: rawPayload;
|
|
1015
|
+
log.error({
|
|
1016
|
+
err,
|
|
1017
|
+
rawPayload: trimmedRawPayload,
|
|
1018
|
+
parsedPayload,
|
|
1019
|
+
}, "Failed to parse/handle message");
|
|
1020
|
+
if (this.pendingConnections.has(ws)) {
|
|
1021
|
+
this.clearPendingConnection(ws);
|
|
908
1022
|
try {
|
|
909
|
-
|
|
910
|
-
rawPayload = buffer.toString();
|
|
911
|
-
parsedPayload = JSON.parse(rawPayload);
|
|
912
|
-
}
|
|
913
|
-
catch (payloadError) {
|
|
914
|
-
rawPayload = rawPayload ?? "<unreadable>";
|
|
915
|
-
parsedPayload = parsedPayload ?? rawPayload;
|
|
916
|
-
const payloadErr = payloadError instanceof Error ? payloadError : new Error(String(payloadError));
|
|
917
|
-
this.logger.error({ err: payloadErr }, "Failed to decode raw payload");
|
|
918
|
-
}
|
|
919
|
-
const trimmedRawPayload = typeof rawPayload === "string" && rawPayload.length > 2000
|
|
920
|
-
? `${rawPayload.slice(0, 2000)}... (truncated)`
|
|
921
|
-
: rawPayload;
|
|
922
|
-
log.error({
|
|
923
|
-
err,
|
|
924
|
-
rawPayload: trimmedRawPayload,
|
|
925
|
-
parsedPayload,
|
|
926
|
-
}, "Failed to parse/handle message");
|
|
927
|
-
if (this.pendingConnections.has(ws)) {
|
|
928
|
-
this.clearPendingConnection(ws);
|
|
929
|
-
try {
|
|
930
|
-
ws.close(WS_CLOSE_INVALID_HELLO, "Invalid hello");
|
|
931
|
-
}
|
|
932
|
-
catch {
|
|
933
|
-
// ignore close errors
|
|
934
|
-
}
|
|
935
|
-
return;
|
|
1023
|
+
ws.close(WS_CLOSE_INVALID_HELLO, "Invalid hello");
|
|
936
1024
|
}
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
this.sendToClient(ws, wrapSessionMessage({
|
|
940
|
-
type: "rpc_error",
|
|
941
|
-
payload: {
|
|
942
|
-
requestId: requestInfo.requestId,
|
|
943
|
-
requestType: requestInfo.requestType,
|
|
944
|
-
error: "Invalid message",
|
|
945
|
-
code: "invalid_message",
|
|
946
|
-
},
|
|
947
|
-
}));
|
|
948
|
-
return;
|
|
1025
|
+
catch {
|
|
1026
|
+
// ignore close errors
|
|
949
1027
|
}
|
|
1028
|
+
return;
|
|
1029
|
+
}
|
|
1030
|
+
const requestInfo = extractRequestInfoFromUnknownWsInbound(parsedPayload);
|
|
1031
|
+
if (requestInfo) {
|
|
950
1032
|
this.sendToClient(ws, wrapSessionMessage({
|
|
951
|
-
type: "
|
|
1033
|
+
type: "rpc_error",
|
|
952
1034
|
payload: {
|
|
953
|
-
|
|
954
|
-
|
|
1035
|
+
requestId: requestInfo.requestId,
|
|
1036
|
+
requestType: requestInfo.requestType,
|
|
1037
|
+
error: "Invalid message",
|
|
1038
|
+
code: "invalid_message",
|
|
955
1039
|
},
|
|
956
1040
|
}));
|
|
1041
|
+
return;
|
|
1042
|
+
}
|
|
1043
|
+
this.sendToClient(ws, wrapSessionMessage({
|
|
1044
|
+
type: "status",
|
|
1045
|
+
payload: {
|
|
1046
|
+
status: "error",
|
|
1047
|
+
message: `Invalid message: ${err.message}`,
|
|
1048
|
+
},
|
|
1049
|
+
}));
|
|
1050
|
+
}
|
|
1051
|
+
decodeRawMessagePayloadForError(data) {
|
|
1052
|
+
let rawPayload = null;
|
|
1053
|
+
let parsedPayload = null;
|
|
1054
|
+
try {
|
|
1055
|
+
const buffer = bufferFromWsData(data);
|
|
1056
|
+
rawPayload = buffer.toString();
|
|
1057
|
+
parsedPayload = JSON.parse(rawPayload);
|
|
1058
|
+
}
|
|
1059
|
+
catch (payloadError) {
|
|
1060
|
+
rawPayload = rawPayload ?? "<unreadable>";
|
|
1061
|
+
parsedPayload = parsedPayload ?? rawPayload;
|
|
1062
|
+
const payloadErr = payloadError instanceof Error ? payloadError : new Error(String(payloadError));
|
|
1063
|
+
this.logger.error({ err: payloadErr }, "Failed to decode raw payload");
|
|
957
1064
|
}
|
|
1065
|
+
return { rawPayload, parsedPayload };
|
|
958
1066
|
}
|
|
959
1067
|
incrementRuntimeCounter(counter) {
|
|
960
1068
|
this.runtimeCounters[counter] += 1;
|