@pellux/goodvibes-tui 0.18.8 → 0.18.9
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/CHANGELOG.md +36 -0
- package/README.md +1 -1
- package/docs/foundation-artifacts/operator-contract.json +1 -1
- package/package.json +2 -2
- package/src/acp/connection.ts +5 -5
- package/src/acp/index.ts +1 -1
- package/src/acp/manager.ts +1 -133
- package/src/adapters/bluebubbles/index.ts +1 -1
- package/src/adapters/discord/index.ts +2 -2
- package/src/adapters/github/index.ts +1 -1
- package/src/adapters/google-chat/index.ts +1 -1
- package/src/adapters/imessage/index.ts +1 -1
- package/src/adapters/index.ts +15 -15
- package/src/adapters/matrix/index.ts +1 -1
- package/src/adapters/mattermost/index.ts +1 -1
- package/src/adapters/msteams/index.ts +2 -2
- package/src/adapters/ntfy/index.ts +1 -1
- package/src/adapters/signal/index.ts +1 -1
- package/src/adapters/slack/index.ts +2 -2
- package/src/adapters/telegram/index.ts +1 -1
- package/src/adapters/types.ts +4 -4
- package/src/adapters/webhook/index.ts +1 -1
- package/src/adapters/whatsapp/index.ts +1 -1
- package/src/agents/message-bus-core.ts +2 -2
- package/src/agents/message-bus.ts +2 -2
- package/src/agents/orchestrator-prompts.ts +4 -4
- package/src/agents/orchestrator-runner.ts +11 -11
- package/src/agents/orchestrator.ts +14 -13
- package/src/agents/session.ts +1 -1
- package/src/agents/worktree.ts +1 -1
- package/src/agents/wrfc-config.ts +2 -2
- package/src/agents/wrfc-controller.ts +12 -12
- package/src/agents/wrfc-gate-runtime.ts +5 -5
- package/src/agents/wrfc-reporting.ts +1 -1
- package/src/agents/wrfc-runtime-events.ts +3 -3
- package/src/agents/wrfc-types.ts +1 -1
- package/src/automation/delivery-manager.ts +4 -4
- package/src/automation/index.ts +4 -4
- package/src/automation/manager-runtime-delivery.ts +1 -1
- package/src/automation/manager-runtime-events.ts +3 -3
- package/src/automation/manager-runtime-execution.ts +5 -5
- package/src/automation/manager-runtime-helpers.ts +2 -2
- package/src/automation/manager-runtime-job-mutations.ts +3 -3
- package/src/automation/manager-runtime-reconcile.ts +4 -4
- package/src/automation/manager-runtime-scheduling.ts +2 -2
- package/src/automation/manager-runtime.ts +18 -18
- package/src/automation/manager.ts +2 -2
- package/src/automation/service.ts +2 -2
- package/src/channels/builtin/account-actions.ts +5 -5
- package/src/channels/builtin/accounts.ts +2 -2
- package/src/channels/builtin/contracts.ts +3 -3
- package/src/channels/builtin/plugins.ts +5 -5
- package/src/channels/builtin/rendering.ts +4 -4
- package/src/channels/builtin/setup-schema.ts +1 -1
- package/src/channels/builtin/shared.ts +7 -7
- package/src/channels/builtin/surfaces.ts +2 -2
- package/src/channels/builtin/targets.ts +3 -3
- package/src/channels/builtin-runtime.ts +11 -11
- package/src/channels/delivery/shared.ts +2 -2
- package/src/channels/delivery/strategies-bridge.ts +3 -3
- package/src/channels/delivery/strategies-core.ts +5 -5
- package/src/channels/delivery/strategies-enterprise.ts +3 -3
- package/src/channels/delivery/types.ts +2 -2
- package/src/channels/delivery-router.ts +9 -9
- package/src/channels/index.ts +12 -12
- package/src/channels/plugin-registry.ts +1 -1
- package/src/channels/provider-runtime.ts +3 -3
- package/src/channels/reply-pipeline.ts +3 -3
- package/src/channels/route-manager.ts +2 -2
- package/src/channels/surface-registry.ts +2 -2
- package/src/config/helper-model.ts +1 -233
- package/src/config/index.ts +3 -3
- package/src/config/manager.ts +8 -404
- package/src/config/secrets.ts +21 -542
- package/src/config/service-registry.ts +1 -329
- package/src/config/tool-llm.ts +3 -3
- package/src/control-plane/approval-broker.ts +1 -1
- package/src/control-plane/gateway.ts +1 -713
- package/src/control-plane/index.ts +7 -7
- package/src/control-plane/media-contract-schemas.ts +1 -208
- package/src/control-plane/method-catalog-admin.ts +1 -136
- package/src/control-plane/method-catalog-channels.ts +1 -591
- package/src/control-plane/method-catalog-control-automation.ts +1 -475
- package/src/control-plane/method-catalog-control-core.ts +1 -594
- package/src/control-plane/method-catalog-control.ts +1 -8
- package/src/control-plane/method-catalog-events.ts +1 -74
- package/src/control-plane/method-catalog-knowledge.ts +1 -531
- package/src/control-plane/method-catalog-media.ts +1 -279
- package/src/control-plane/method-catalog-runtime.ts +1 -304
- package/src/control-plane/method-catalog-shared.ts +1 -223
- package/src/control-plane/method-catalog.ts +1 -242
- package/src/control-plane/operator-contract-schemas-admin.ts +1 -639
- package/src/control-plane/operator-contract-schemas-channels.ts +1 -375
- package/src/control-plane/operator-contract-schemas-control.ts +1 -226
- package/src/control-plane/operator-contract-schemas-domains.ts +1 -4
- package/src/control-plane/operator-contract-schemas-knowledge.ts +1 -582
- package/src/control-plane/operator-contract-schemas-media.ts +1 -297
- package/src/control-plane/operator-contract-schemas-permissions.ts +1 -100
- package/src/control-plane/operator-contract-schemas-remote.ts +1 -38
- package/src/control-plane/operator-contract-schemas-runtime.ts +1 -563
- package/src/control-plane/operator-contract-schemas-shared.ts +1 -85
- package/src/control-plane/operator-contract-schemas-telemetry.ts +1 -349
- package/src/control-plane/operator-contract-schemas.ts +1 -6
- package/src/control-plane/operator-contract.ts +5 -3
- package/src/control-plane/session-broker.ts +1 -1
- package/src/core/compaction-sections.ts +5 -5
- package/src/core/compaction-types.ts +3 -3
- package/src/core/composer-state.ts +1 -1
- package/src/core/context-compaction.ts +7 -7
- package/src/core/conversation-compaction.ts +4 -4
- package/src/core/conversation-diff.ts +1 -1
- package/src/core/conversation-rendering.ts +5 -5
- package/src/core/conversation-utils.ts +2 -2
- package/src/core/conversation.ts +10 -10
- package/src/core/event-replay.ts +1 -1
- package/src/core/orchestrator-context-runtime.ts +8 -8
- package/src/core/orchestrator-follow-up-runtime.ts +2 -2
- package/src/core/orchestrator-runtime.ts +4 -4
- package/src/core/orchestrator-tool-runtime.ts +7 -7
- package/src/core/orchestrator-turn-helpers.ts +7 -7
- package/src/core/orchestrator-turn-loop.ts +10 -10
- package/src/core/orchestrator.ts +17 -17
- package/src/core/plan-command-handler.ts +2 -2
- package/src/core/system-message-router.ts +2 -2
- package/src/core/transcript-events/classify.ts +1 -1
- package/src/core/transcript-events/index.ts +3 -3
- package/src/daemon/cli.ts +6 -6
- package/src/daemon/control-plane.ts +7 -7
- package/src/daemon/facade-composition.ts +16 -15
- package/src/daemon/facade.ts +17 -17
- package/src/daemon/helpers.ts +2 -2
- package/src/daemon/http/router-route-contexts.ts +11 -11
- package/src/daemon/http/router.ts +25 -25
- package/src/daemon/http-listener.ts +3 -3
- package/src/daemon/index.ts +1 -3
- package/src/daemon/service-manager.ts +1 -1
- package/src/daemon/surface-actions.ts +8 -8
- package/src/daemon/surface-delivery.ts +7 -7
- package/src/daemon/surface-policy.ts +1 -1
- package/src/daemon/transport-events.ts +4 -4
- package/src/daemon/types.ts +24 -24
- package/src/export/markdown.ts +1 -1
- package/src/export/session-export.ts +1 -633
- package/src/git/index.ts +1 -1
- package/src/git/service.ts +1 -1
- package/src/hooks/chain-engine.ts +1 -1
- package/src/hooks/dispatcher.ts +4 -4
- package/src/hooks/hook-api.ts +1 -1
- package/src/hooks/index.ts +8 -8
- package/src/hooks/runners/agent.ts +1 -1
- package/src/hooks/runners/prompt.ts +1 -1
- package/src/hooks/workbench.ts +2 -2
- package/src/input/command-registry.ts +24 -17
- package/src/input/commands/config.ts +1 -1
- package/src/input/commands/control-room-runtime.ts +2 -2
- package/src/input/commands/conversation-runtime.ts +1 -1
- package/src/input/commands/eval.ts +2 -2
- package/src/input/commands/git-runtime.ts +1 -1
- package/src/input/commands/guidance-runtime.ts +3 -3
- package/src/input/commands/health-runtime.ts +7 -7
- package/src/input/commands/incident-runtime.ts +1 -1
- package/src/input/commands/integration-runtime.ts +3 -3
- package/src/input/commands/local-provider-runtime.ts +1 -1
- package/src/input/commands/local-runtime.ts +1 -1
- package/src/input/commands/local-setup-review.ts +1 -1
- package/src/input/commands/local-setup.ts +1 -1
- package/src/input/commands/managed-runtime.ts +2 -2
- package/src/input/commands/marketplace-runtime.ts +1 -1
- package/src/input/commands/platform-access-runtime.ts +1 -1
- package/src/input/commands/policy-dispatch.ts +2 -2
- package/src/input/commands/product-runtime.ts +2 -2
- package/src/input/commands/profile-sync-runtime.ts +1 -1
- package/src/input/commands/provider-accounts-runtime.ts +1 -1
- package/src/input/commands/provider.ts +3 -3
- package/src/input/commands/quit-shared.ts +1 -1
- package/src/input/commands/recall-bundle.ts +1 -1
- package/src/input/commands/recall-capture.ts +2 -2
- package/src/input/commands/recall-query.ts +2 -2
- package/src/input/commands/recall-shared.ts +1 -1
- package/src/input/commands/remote-runtime-setup.ts +1 -1
- package/src/input/commands/remote-runtime.ts +1 -1
- package/src/input/commands/runtime-services.ts +13 -11
- package/src/input/commands/schedule-runtime.ts +2 -2
- package/src/input/commands/session-content.ts +1 -1
- package/src/input/commands/session-workflow.ts +4 -4
- package/src/input/commands/settings-sync-runtime.ts +1 -1
- package/src/input/commands/share-runtime.ts +9 -4
- package/src/input/commands/shell-core.ts +1 -1
- package/src/input/commands/skills-runtime.ts +1 -1
- package/src/input/commands/subscription-runtime.ts +1 -1
- package/src/input/commands/tasks-runtime.ts +1 -1
- package/src/input/commands/teamwork-runtime.ts +1 -1
- package/src/input/commands/worktree-runtime.ts +1 -1
- package/src/input/handler-command-route.ts +1 -1
- package/src/input/handler-content-actions.ts +3 -3
- package/src/input/handler-feed-routes.ts +2 -2
- package/src/input/handler-feed.ts +1 -1
- package/src/input/handler-shortcuts.ts +1 -1
- package/src/input/handler.ts +1 -1
- package/src/input/keybindings.ts +5 -0
- package/src/input/model-picker.ts +2 -2
- package/src/input/profile-picker-modal.ts +1 -1
- package/src/input/session-picker-modal.ts +1 -1
- package/src/input/settings-modal.ts +4 -4
- package/src/integrations/index.ts +1 -1
- package/src/integrations/notifier.ts +1 -1
- package/src/integrations/webhooks.ts +1 -177
- package/src/knowledge/consolidation.ts +2 -2
- package/src/knowledge/graphql.ts +1 -1
- package/src/knowledge/index.ts +5 -5
- package/src/knowledge/ingest-compile.ts +3 -3
- package/src/knowledge/ingest-context.ts +1 -1
- package/src/knowledge/ingest-inputs.ts +4 -4
- package/src/knowledge/ingest.ts +1 -20
- package/src/knowledge/internal.ts +1 -1
- package/src/knowledge/knowledge-api.ts +7 -7
- package/src/knowledge/lint.ts +3 -3
- package/src/knowledge/memory-sync.ts +2 -2
- package/src/knowledge/packet.ts +3 -3
- package/src/knowledge/scheduling.ts +2 -2
- package/src/knowledge/service.ts +10 -10
- package/src/main.ts +11 -10
- package/src/mcp/index.ts +4 -4
- package/src/mcp/mcp-api.ts +1 -1
- package/src/mcp/registry.ts +1 -506
- package/src/media/builtin-image-understanding.ts +2 -2
- package/src/media/builtin-providers.ts +2 -2
- package/src/media/index.ts +1 -1
- package/src/multimodal/index.ts +1 -1
- package/src/multimodal/service.ts +2 -2
- package/src/panels/agent-inspector-panel.ts +2 -2
- package/src/panels/agent-logs-panel.ts +3 -3
- package/src/panels/approval-panel.ts +2 -2
- package/src/panels/builtin/operations.ts +3 -1
- package/src/panels/builtin/shared.ts +13 -13
- package/src/panels/context-visualizer-panel.ts +2 -2
- package/src/panels/cost-tracker-panel.ts +2 -2
- package/src/panels/debug-panel.ts +3 -3
- package/src/panels/git-panel.ts +1 -1
- package/src/panels/hooks-panel.ts +4 -4
- package/src/panels/knowledge-panel.ts +1 -1
- package/src/panels/marketplace-panel.ts +1 -1
- package/src/panels/mcp-panel.ts +1 -1
- package/src/panels/memory-panel.ts +2 -2
- package/src/panels/ops-control-panel.ts +2 -2
- package/src/panels/ops-strategy-panel.ts +2 -2
- package/src/panels/plugins-panel.ts +1 -1
- package/src/panels/policy-panel.ts +1 -1
- package/src/panels/provider-health-panel.ts +3 -3
- package/src/panels/provider-stats-panel.ts +2 -2
- package/src/panels/sandbox-panel.ts +1 -1
- package/src/panels/schedule-panel.ts +1 -1
- package/src/panels/settings-sync-panel.ts +1 -1
- package/src/panels/system-messages-panel.ts +1 -1
- package/src/panels/tasks-panel.ts +1 -1
- package/src/panels/thinking-panel.ts +2 -2
- package/src/panels/token-budget-panel.ts +1 -1
- package/src/panels/tool-inspector-panel.ts +2 -2
- package/src/panels/worktree-panel.ts +1 -1
- package/src/panels/wrfc-panel.ts +4 -4
- package/src/permissions/briefs/build.ts +1 -1
- package/src/permissions/manager.ts +1 -356
- package/src/permissions/prompt.ts +1 -1
- package/src/plugins/api.ts +9 -9
- package/src/plugins/loader.ts +8 -8
- package/src/plugins/manager.ts +5 -5
- package/src/providers/amazon-bedrock-mantle.ts +1 -1
- package/src/providers/amazon-bedrock.ts +1 -1
- package/src/providers/anthropic-compat.ts +4 -4
- package/src/providers/anthropic-sdk-provider.ts +5 -5
- package/src/providers/anthropic-vertex.ts +1 -1
- package/src/providers/anthropic.ts +4 -4
- package/src/providers/auto-register.ts +6 -6
- package/src/providers/builtin-catalog.ts +2 -2
- package/src/providers/builtin-registry.ts +15 -15
- package/src/providers/cache-planner.ts +2 -2
- package/src/providers/capabilities.ts +1 -601
- package/src/providers/custom-loader.ts +6 -6
- package/src/providers/discovered-compat.ts +7 -18
- package/src/providers/discovered-factory.ts +7 -7
- package/src/providers/discovered-traits.ts +1 -1
- package/src/providers/gemini.ts +4 -4
- package/src/providers/github-copilot.ts +4 -4
- package/src/providers/index.ts +1 -47
- package/src/providers/interface.ts +1 -1
- package/src/providers/llama-cpp.ts +4 -4
- package/src/providers/lm-studio-helpers.ts +1 -1
- package/src/providers/lm-studio.ts +4 -4
- package/src/providers/model-catalog-cache.ts +1 -1
- package/src/providers/model-catalog-notifications.ts +1 -1
- package/src/providers/model-catalog-synthetic.ts +2 -2
- package/src/providers/model-catalog.ts +7 -7
- package/src/providers/model-limits.ts +1 -280
- package/src/providers/ollama.ts +4 -4
- package/src/providers/openai-codex.ts +2 -2
- package/src/providers/openai-compat.ts +4 -4
- package/src/providers/openai.ts +3 -3
- package/src/providers/optimizer.ts +1 -381
- package/src/providers/provider-api.ts +1 -553
- package/src/providers/registry-helpers.ts +1 -1
- package/src/providers/registry-models.ts +2 -2
- package/src/providers/registry-types.ts +5 -5
- package/src/providers/registry.ts +1 -729
- package/src/providers/runtime-metadata.ts +1 -1
- package/src/providers/runtime-snapshot.ts +3 -3
- package/src/providers/synthetic.ts +3 -3
- package/src/providers/tier-prompts.ts +1 -1
- package/src/providers/tool-formats.ts +1 -1
- package/src/renderer/agent-detail-modal.ts +2 -2
- package/src/renderer/block-actions.ts +1 -1
- package/src/renderer/context-inspector.ts +1 -1
- package/src/renderer/conversation-layout.ts +1 -1
- package/src/renderer/conversation-overlays.ts +1 -1
- package/src/renderer/git-status.ts +1 -1
- package/src/renderer/live-tail-modal.ts +1 -1
- package/src/renderer/process-modal.ts +2 -2
- package/src/runtime/bootstrap-background.ts +4 -4
- package/src/runtime/bootstrap-command-context.ts +23 -23
- package/src/runtime/bootstrap-command-parts.ts +23 -23
- package/src/runtime/bootstrap-core.ts +12 -10
- package/src/runtime/bootstrap-helpers.ts +2 -2
- package/src/runtime/bootstrap-hook-bridge.ts +9 -9
- package/src/runtime/bootstrap-runtime-events.ts +4 -4
- package/src/runtime/bootstrap-services.ts +4 -4
- package/src/runtime/bootstrap-shell.ts +11 -11
- package/src/runtime/bootstrap.ts +28 -10
- package/src/runtime/compaction/index.ts +1 -90
- package/src/runtime/compaction/lifecycle.ts +1 -167
- package/src/runtime/compaction/manager.ts +11 -11
- package/src/runtime/compaction/quality-score.ts +1 -279
- package/src/runtime/compaction/resume-repair.ts +1 -183
- package/src/runtime/compaction/strategies/autocompact.ts +1 -65
- package/src/runtime/compaction/strategies/boundary-commit.ts +1 -106
- package/src/runtime/compaction/strategies/collapse.ts +1 -90
- package/src/runtime/compaction/strategies/index.ts +1 -23
- package/src/runtime/compaction/strategies/microcompact.ts +1 -74
- package/src/runtime/compaction/strategies/reactive.ts +1 -89
- package/src/runtime/compaction/types.ts +1 -221
- package/src/runtime/context.ts +9 -9
- package/src/runtime/diagnostics/actions.ts +1 -1
- package/src/runtime/diagnostics/index.ts +5 -5
- package/src/runtime/diagnostics/panels/agents.ts +2 -2
- package/src/runtime/diagnostics/panels/events.ts +2 -2
- package/src/runtime/diagnostics/panels/health.ts +2 -2
- package/src/runtime/diagnostics/panels/ops.ts +2 -2
- package/src/runtime/diagnostics/panels/policy.ts +2 -2
- package/src/runtime/diagnostics/panels/tasks.ts +2 -2
- package/src/runtime/diagnostics/panels/tool-calls.ts +2 -2
- package/src/runtime/diagnostics/provider.ts +1 -1
- package/src/runtime/ecosystem/recommendations.ts +1 -1
- package/src/runtime/emitters/agents.ts +2 -2
- package/src/runtime/emitters/automation.ts +2 -2
- package/src/runtime/emitters/communication.ts +2 -2
- package/src/runtime/emitters/compaction.ts +2 -2
- package/src/runtime/emitters/control-plane.ts +2 -2
- package/src/runtime/emitters/deliveries.ts +2 -2
- package/src/runtime/emitters/forensics.ts +2 -2
- package/src/runtime/emitters/index.ts +27 -27
- package/src/runtime/emitters/knowledge.ts +2 -2
- package/src/runtime/emitters/mcp.ts +2 -2
- package/src/runtime/emitters/ops.ts +2 -2
- package/src/runtime/emitters/orchestration.ts +2 -2
- package/src/runtime/emitters/permissions.ts +2 -2
- package/src/runtime/emitters/planner.ts +2 -2
- package/src/runtime/emitters/plugins.ts +2 -2
- package/src/runtime/emitters/providers.ts +2 -2
- package/src/runtime/emitters/routes.ts +2 -2
- package/src/runtime/emitters/security.ts +2 -2
- package/src/runtime/emitters/session.ts +2 -2
- package/src/runtime/emitters/surfaces.ts +2 -2
- package/src/runtime/emitters/tasks.ts +2 -2
- package/src/runtime/emitters/tools.ts +2 -2
- package/src/runtime/emitters/transport.ts +2 -2
- package/src/runtime/emitters/turn.ts +3 -3
- package/src/runtime/emitters/ui.ts +2 -2
- package/src/runtime/emitters/watchers.ts +2 -2
- package/src/runtime/emitters/workflows.ts +3 -3
- package/src/runtime/eval/index.ts +3 -3
- package/src/runtime/eval/runner.ts +1 -1
- package/src/runtime/eval/suites.ts +1 -1
- package/src/runtime/events/domain-map.ts +2 -2
- package/src/runtime/events/index.ts +1 -194
- package/src/runtime/events/turn.ts +1 -60
- package/src/runtime/events/workflows.ts +1 -17
- package/src/runtime/forensics/collector.ts +4 -4
- package/src/runtime/forensics/index.ts +1 -1
- package/src/runtime/foundation-clients.ts +14 -14
- package/src/runtime/foundation-services.ts +8 -8
- package/src/runtime/guidance.ts +3 -3
- package/src/runtime/health/effect-handlers.ts +3 -3
- package/src/runtime/health/index.ts +4 -4
- package/src/runtime/health/wiring.ts +2 -2
- package/src/runtime/index.ts +29 -29
- package/src/runtime/integration/helpers.ts +12 -12
- package/src/runtime/lifecycle.ts +4 -4
- package/src/runtime/mcp/index.ts +3 -3
- package/src/runtime/mcp/manager.ts +1 -1
- package/src/runtime/network/inbound.ts +2 -2
- package/src/runtime/network/index.ts +5 -5
- package/src/runtime/network/outbound.ts +2 -2
- package/src/runtime/network/shared.ts +1 -1
- package/src/runtime/operator-client.ts +9 -9
- package/src/runtime/ops/control-plane.ts +2 -2
- package/src/runtime/ops/index.ts +3 -3
- package/src/runtime/ops/playbooks/index.ts +2 -2
- package/src/runtime/ops/playbooks/session-unrecoverable.ts +2 -2
- package/src/runtime/ops/playbooks/stuck-turn.ts +1 -1
- package/src/runtime/ops/runtime-context.ts +1 -1
- package/src/runtime/orchestration/spawn-policy.ts +1 -1
- package/src/runtime/peer-client.ts +3 -3
- package/src/runtime/perf/index.ts +1 -1
- package/src/runtime/perf/slo-collector.ts +1 -1
- package/src/runtime/permissions/index.ts +5 -5
- package/src/runtime/permissions/policy-runtime.ts +1 -175
- package/src/runtime/permissions/rule-suggestions.ts +1 -1
- package/src/runtime/plugins/hot-reload.ts +4 -4
- package/src/runtime/plugins/index.ts +13 -13
- package/src/runtime/plugins/lifecycle.ts +1 -1
- package/src/runtime/plugins/manager.ts +10 -10
- package/src/runtime/plugins/manifest.ts +2 -2
- package/src/runtime/plugins/quarantine.ts +2 -2
- package/src/runtime/plugins/trust.ts +2 -2
- package/src/runtime/plugins/types.ts +1 -1
- package/src/runtime/provider-accounts/registry.ts +2 -2
- package/src/runtime/remote/distributed-runtime-contract-schemas.ts +3 -3
- package/src/runtime/remote/index.ts +3 -3
- package/src/runtime/remote/runner-registry.ts +2 -2
- package/src/runtime/remote/supervisor.ts +1 -1
- package/src/runtime/runtime-hook-api.ts +1 -1
- package/src/runtime/runtime-knowledge-api.ts +1 -1
- package/src/runtime/runtime-mcp-api.ts +1 -1
- package/src/runtime/runtime-ops-api.ts +2 -2
- package/src/runtime/runtime-provider-api.ts +1 -1
- package/src/runtime/services.ts +35 -32
- package/src/runtime/session-maintenance.ts +1 -1
- package/src/runtime/session-persistence.ts +2 -2
- package/src/runtime/session-return-context.ts +3 -3
- package/src/runtime/settings/control-plane-store.ts +1 -1
- package/src/runtime/settings/control-plane.ts +2 -2
- package/src/runtime/shell-command-extensions.ts +7 -7
- package/src/runtime/shell-command-ops.ts +6 -6
- package/src/runtime/shell-command-platform.ts +1 -1
- package/src/runtime/shell-command-services.ts +17 -17
- package/src/runtime/shell-command-workspace.ts +1 -1
- package/src/runtime/store/domains/conversation.ts +1 -1
- package/src/runtime/store/domains/index.ts +4 -4
- package/src/runtime/store/domains/permissions.ts +1 -1
- package/src/runtime/store/helpers/reducers/conversation.ts +3 -3
- package/src/runtime/store/helpers/reducers/lifecycle.ts +3 -3
- package/src/runtime/store/helpers/reducers/shared.ts +2 -2
- package/src/runtime/store/helpers/reducers/sync.ts +1 -1
- package/src/runtime/store/helpers/reducers.ts +4 -4
- package/src/runtime/store/index.ts +4 -4
- package/src/runtime/store/selectors/index.ts +2 -2
- package/src/runtime/store/state.ts +4 -4
- package/src/runtime/tasks/adapters/acp-adapter.ts +1 -1
- package/src/runtime/tasks/adapters/index.ts +6 -6
- package/src/runtime/tasks/index.ts +3 -3
- package/src/runtime/tasks/manager.ts +3 -3
- package/src/runtime/telemetry/api-helpers.ts +2 -2
- package/src/runtime/telemetry/api.ts +2 -2
- package/src/runtime/telemetry/index.ts +5 -5
- package/src/runtime/telemetry/instrumentation/domain-bridge-agent-session.ts +1 -1
- package/src/runtime/telemetry/instrumentation/domain-bridge-plugin-mcp.ts +1 -1
- package/src/runtime/telemetry/instrumentation/domain-bridge-shared.ts +1 -1
- package/src/runtime/telemetry/instrumentation/domain-bridge-transport-task.ts +1 -1
- package/src/runtime/telemetry/instrumentation/domain-bridge.ts +5 -5
- package/src/runtime/telemetry/instrumentation/index.ts +3 -3
- package/src/runtime/tools/context.ts +3 -3
- package/src/runtime/tools/index.ts +4 -4
- package/src/runtime/tools/phased-executor.ts +3 -3
- package/src/runtime/tools/phases/budget.ts +1 -1
- package/src/runtime/tools/phases/execute.ts +1 -1
- package/src/runtime/tools/phases/index.ts +7 -7
- package/src/runtime/tools/phases/map-output.ts +1 -1
- package/src/runtime/tools/phases/permission.ts +2 -2
- package/src/runtime/tools/phases/posthook.ts +1 -1
- package/src/runtime/tools/phases/prehook.ts +1 -1
- package/src/runtime/tools/phases/validate.ts +1 -1
- package/src/runtime/transports/direct.ts +4 -4
- package/src/runtime/transports/http-helpers.ts +3 -3
- package/src/runtime/transports/http-types.ts +6 -6
- package/src/runtime/transports/http.ts +8 -8
- package/src/runtime/transports/realtime.ts +4 -4
- package/src/runtime/transports/remote-events.ts +1 -1
- package/src/runtime/transports/shared.ts +2 -2
- package/src/runtime/transports/ui-runtime-events.ts +2 -2
- package/src/runtime/ui/index.ts +7 -7
- package/src/runtime/ui/model-picker/data-provider.ts +4 -4
- package/src/runtime/ui/model-picker/health-enrichment.ts +3 -3
- package/src/runtime/ui/model-picker/index.ts +8 -8
- package/src/runtime/ui/provider-health/data-provider.ts +2 -2
- package/src/runtime/ui/provider-health/fallback-visualizer.ts +1 -1
- package/src/runtime/ui/provider-health/index.ts +5 -5
- package/src/runtime/ui-events.ts +1 -1
- package/src/runtime/ui-read-models-core.ts +2 -2
- package/src/runtime/ui-read-models-observability-maintenance.ts +4 -4
- package/src/runtime/ui-read-models-observability-options.ts +1 -1
- package/src/runtime/ui-read-models-observability-remote.ts +2 -2
- package/src/runtime/ui-read-models-observability-security.ts +3 -3
- package/src/runtime/ui-read-models-observability-system.ts +6 -6
- package/src/runtime/ui-read-models-observability.ts +10 -10
- package/src/runtime/ui-read-models-operations.ts +2 -2
- package/src/runtime/ui-read-models.ts +7 -7
- package/src/runtime/ui-service-queries.ts +2 -2
- package/src/runtime/ui-services.ts +7 -7
- package/src/runtime/worktree/registry.ts +1 -1
- package/src/scripts/process-messages.ts +1 -1
- package/src/sessions/manager.ts +9 -383
- package/src/shell/blocking-input.ts +3 -3
- package/src/shell/ui-openers.ts +3 -3
- package/src/state/file-watcher.ts +1 -1
- package/src/state/index.ts +10 -10
- package/src/state/knowledge-injection.ts +2 -2
- package/src/state/memory-embedding-http.ts +2 -2
- package/src/state/memory-embeddings.ts +1 -1
- package/src/state/memory-ingest.ts +3 -3
- package/src/state/memory-registry.ts +3 -3
- package/src/state/memory-store-helpers.ts +1 -1
- package/src/state/memory-store.ts +4 -4
- package/src/state/memory-vector-store.ts +3 -3
- package/src/tools/agent/index.ts +7 -7
- package/src/tools/agent/manager.ts +8 -8
- package/src/tools/analyze/git-modes.ts +2 -2
- package/src/tools/analyze/index.ts +2 -2
- package/src/tools/channel/agent-tools.ts +1 -1
- package/src/tools/channel/index.ts +2 -2
- package/src/tools/edit/core.ts +3 -3
- package/src/tools/edit/index.ts +2 -2
- package/src/tools/edit/phased.ts +2 -2
- package/src/tools/fetch/index.ts +2 -2
- package/src/tools/fetch/phased.ts +1 -1
- package/src/tools/index.ts +21 -21
- package/src/tools/mcp/index.ts +1 -1
- package/src/tools/remote-trigger/index.ts +1 -1
- package/src/tools/shared/auto-heal.ts +2 -2
- package/src/tools/state/index.ts +1 -1
- package/src/tools/web-search/index.ts +1 -1
- package/src/tools/write/index.ts +3 -3
- package/src/tools/write/phased.ts +1 -1
- package/src/version.ts +1 -1
- package/src/watchers/index.ts +2 -2
- package/src/watchers/registry.ts +2 -2
- package/src/web-search/index.ts +10 -10
- package/src/web-search/provider-registry.ts +8 -8
- package/src/web-search/providers/brave.ts +1 -1
- package/src/web-search/providers/duckduckgo.ts +1 -1
- package/src/web-search/providers/exa.ts +1 -1
- package/src/web-search/providers/firecrawl.ts +1 -1
- package/src/web-search/providers/perplexity.ts +1 -1
- package/src/web-search/providers/searxng.ts +1 -1
- package/src/web-search/providers/shared.ts +1 -1
- package/src/web-search/providers/tavily.ts +1 -1
- package/src/web-search/service.ts +2 -2
- package/src/runtime/ecosystem/catalog.ts +0 -606
|
@@ -1,65 +1 @@
|
|
|
1
|
-
|
|
2
|
-
* strategies/autocompact.ts
|
|
3
|
-
*
|
|
4
|
-
* Auto-compaction strategy for the session compaction pipeline.
|
|
5
|
-
*
|
|
6
|
-
* This strategy is used when token pressure is in the 50–85% range. It runs
|
|
7
|
-
* the full semantic compaction pipeline including section-based extraction,
|
|
8
|
-
* lineage tracking, and post-compaction validation.
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import type { ProviderMessage } from '../../../providers/interface.ts';
|
|
12
|
-
import { estimateTokens } from '../../../core/compaction-types.ts';
|
|
13
|
-
import type { StrategyInput, StrategyOutput } from '../types.ts';
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Applies automatic threshold-based compaction.
|
|
17
|
-
*
|
|
18
|
-
* This uses the standard compaction pipeline. If a registry-backed context
|
|
19
|
-
* summary is unavailable, it falls back to a structural compaction that keeps
|
|
20
|
-
* a wider recent-message window than microcompact.
|
|
21
|
-
*
|
|
22
|
-
* @param input - Strategy input.
|
|
23
|
-
* @returns Strategy output.
|
|
24
|
-
*/
|
|
25
|
-
export function runAutocompact(input: StrategyInput): StrategyOutput {
|
|
26
|
-
const startMs = Date.now();
|
|
27
|
-
const { messages, tokensBefore, strategy } = input;
|
|
28
|
-
const warnings: string[] = [];
|
|
29
|
-
|
|
30
|
-
// Keep the most recent 60% of messages by count, drop the oldest 40%
|
|
31
|
-
const keepCount = Math.max(1, Math.ceil(messages.length * 0.6));
|
|
32
|
-
const dropped = messages.length - keepCount;
|
|
33
|
-
const kept = messages.slice(-keepCount) as ProviderMessage[];
|
|
34
|
-
|
|
35
|
-
const handoff: ProviderMessage = {
|
|
36
|
-
role: 'user',
|
|
37
|
-
content: [
|
|
38
|
-
{
|
|
39
|
-
type: 'text',
|
|
40
|
-
text: [
|
|
41
|
-
'[Session Auto-Compaction]',
|
|
42
|
-
`${dropped} earlier message(s) compacted to reduce context size.`,
|
|
43
|
-
`Retaining the ${keepCount} most recent messages.`,
|
|
44
|
-
'Context window pressure was above threshold — automatic compaction applied.',
|
|
45
|
-
].join('\n'),
|
|
46
|
-
},
|
|
47
|
-
],
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
const compacted: ProviderMessage[] = [handoff, ...kept];
|
|
51
|
-
const tokensAfter = estimateTokens(JSON.stringify(compacted));
|
|
52
|
-
|
|
53
|
-
if (dropped === 0) {
|
|
54
|
-
warnings.push('autocompact: no messages were dropped; context may still be near limit');
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
return {
|
|
58
|
-
messages: compacted,
|
|
59
|
-
tokensAfter,
|
|
60
|
-
summary: `Auto-compaction: dropped ${dropped} messages (~${Math.round((1 - tokensAfter / tokensBefore) * 100)}% reduction).`,
|
|
61
|
-
strategy,
|
|
62
|
-
durationMs: Date.now() - startMs,
|
|
63
|
-
warnings,
|
|
64
|
-
};
|
|
65
|
-
}
|
|
1
|
+
export * from '@pellux/goodvibes-sdk/platform/runtime/compaction/strategies/autocompact';
|
|
@@ -1,106 +1 @@
|
|
|
1
|
-
|
|
2
|
-
* strategies/boundary-commit.ts
|
|
3
|
-
*
|
|
4
|
-
* Boundary commit — persists a compacted snapshot as a named checkpoint with
|
|
5
|
-
* full lineage tracking for replay-safe session resumption.
|
|
6
|
-
*
|
|
7
|
-
* A boundary commit is always created after a successful compaction strategy
|
|
8
|
-
* run (microcompact, collapse, autocompact, or reactive). It forms the
|
|
9
|
-
* persistent anchor point that the resume-repair pipeline uses to restore
|
|
10
|
-
* a session from a corrupted or partial state.
|
|
11
|
-
*
|
|
12
|
-
* Lineage is append-only: each commit appends its own checkpointId to the
|
|
13
|
-
* parent's lineage array. This means any checkpoint can be sliced from any
|
|
14
|
-
* earlier commit without re-ordering.
|
|
15
|
-
*/
|
|
16
|
-
|
|
17
|
-
import type { BoundaryCommit } from '../types.ts';
|
|
18
|
-
import type { StrategyOutput } from '../types.ts';
|
|
19
|
-
|
|
20
|
-
/** Simple prefix for generated checkpoint IDs. */
|
|
21
|
-
const CHECKPOINT_PREFIX = 'cpt';
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Generates a checkpoint ID using the current timestamp and a random suffix.
|
|
25
|
-
* Format: `cpt_<timestamp>_<random>`
|
|
26
|
-
*/
|
|
27
|
-
function generateCheckpointId(): string {
|
|
28
|
-
const ts = Date.now().toString(36);
|
|
29
|
-
const rand = Math.random().toString(36).slice(2, 8);
|
|
30
|
-
return `${CHECKPOINT_PREFIX}_${ts}_${rand}`;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
* Options for creating a boundary commit.
|
|
35
|
-
*/
|
|
36
|
-
export interface BoundaryCommitOptions {
|
|
37
|
-
/** Session ID this commit belongs to. */
|
|
38
|
-
sessionId: string;
|
|
39
|
-
/** The compaction strategy output to commit. */
|
|
40
|
-
strategyOutput: StrategyOutput;
|
|
41
|
-
/** Parent boundary commit, or null for the first commit. */
|
|
42
|
-
parent: BoundaryCommit | null;
|
|
43
|
-
/** Estimated token count before compaction (for audit). */
|
|
44
|
-
tokensBefore: number;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Creates a new BoundaryCommit from a strategy output.
|
|
49
|
-
*
|
|
50
|
-
* The new commit's lineage is derived by appending its own checkpointId
|
|
51
|
-
* to the parent's lineage (or starting a fresh lineage if `parent` is null).
|
|
52
|
-
*
|
|
53
|
-
* @param options - Commit options.
|
|
54
|
-
* @returns A fully populated BoundaryCommit.
|
|
55
|
-
*/
|
|
56
|
-
export function createBoundaryCommit(
|
|
57
|
-
options: BoundaryCommitOptions,
|
|
58
|
-
): BoundaryCommit {
|
|
59
|
-
const { sessionId, strategyOutput, parent, tokensBefore } = options;
|
|
60
|
-
const checkpointId = generateCheckpointId();
|
|
61
|
-
|
|
62
|
-
const parentLineage: readonly string[] = parent?.lineage ?? [];
|
|
63
|
-
const lineage: readonly string[] = [...parentLineage, checkpointId];
|
|
64
|
-
|
|
65
|
-
return {
|
|
66
|
-
checkpointId,
|
|
67
|
-
sessionId,
|
|
68
|
-
createdAt: Date.now(),
|
|
69
|
-
strategy: strategyOutput.strategy,
|
|
70
|
-
parentCheckpointId: parent?.checkpointId ?? null,
|
|
71
|
-
lineage,
|
|
72
|
-
messages: strategyOutput.messages,
|
|
73
|
-
tokenCount: strategyOutput.tokensAfter,
|
|
74
|
-
tokensBefore,
|
|
75
|
-
summary: strategyOutput.summary,
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* Validates a BoundaryCommit for replay-safety.
|
|
81
|
-
*
|
|
82
|
-
* A commit is replay-safe if:
|
|
83
|
-
* - It has at least one message
|
|
84
|
-
* - Its lineage is ordered and contains its own checkpointId
|
|
85
|
-
* - Its tokenCount is positive
|
|
86
|
-
*
|
|
87
|
-
* @returns An array of validation error strings (empty = valid).
|
|
88
|
-
*/
|
|
89
|
-
export function validateBoundaryCommit(commit: BoundaryCommit): string[] {
|
|
90
|
-
const errors: string[] = [];
|
|
91
|
-
|
|
92
|
-
if (commit.messages.length === 0) {
|
|
93
|
-
errors.push('boundary_commit: no messages in checkpoint');
|
|
94
|
-
}
|
|
95
|
-
if (commit.tokenCount <= 0) {
|
|
96
|
-
errors.push('boundary_commit: tokenCount must be positive');
|
|
97
|
-
}
|
|
98
|
-
if (!commit.lineage.includes(commit.checkpointId)) {
|
|
99
|
-
errors.push('boundary_commit: checkpointId not found in lineage (lineage is corrupted)');
|
|
100
|
-
}
|
|
101
|
-
if (commit.lineage.length === 0) {
|
|
102
|
-
errors.push('boundary_commit: lineage is empty');
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
return errors;
|
|
106
|
-
}
|
|
1
|
+
export * from '@pellux/goodvibes-sdk/platform/runtime/compaction/strategies/boundary-commit';
|
|
@@ -1,90 +1 @@
|
|
|
1
|
-
|
|
2
|
-
* strategies/collapse.ts
|
|
3
|
-
*
|
|
4
|
-
* Collapse strategy — full context collapse into a single compacted summary
|
|
5
|
-
* message. This is the most aggressive strategy, used when token pressure
|
|
6
|
-
* exceeds 85% or when manually triggered.
|
|
7
|
-
*
|
|
8
|
-
* All messages are reduced to a structured handoff that preserves:
|
|
9
|
-
* - The original task context (if known)
|
|
10
|
-
* - Key decisions and outcomes
|
|
11
|
-
* - The most recent user/assistant exchange
|
|
12
|
-
*/
|
|
13
|
-
|
|
14
|
-
import type { ProviderMessage } from '../../../providers/interface.ts';
|
|
15
|
-
import { estimateTokens } from '../../../core/compaction-types.ts';
|
|
16
|
-
import type { StrategyInput, StrategyOutput } from '../types.ts';
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* Applies the collapse strategy: reduces all messages to a single structured
|
|
20
|
-
* handoff message that preserves the essential session context.
|
|
21
|
-
*
|
|
22
|
-
* @param input - Strategy input containing messages and context.
|
|
23
|
-
* @returns Strategy output with a single collapsed message.
|
|
24
|
-
*/
|
|
25
|
-
export function runCollapse(input: StrategyInput): StrategyOutput {
|
|
26
|
-
const startMs = Date.now();
|
|
27
|
-
const { messages, tokensBefore, sessionId, strategy } = input;
|
|
28
|
-
const warnings: string[] = [];
|
|
29
|
-
|
|
30
|
-
// Extract the last user/assistant exchange to preserve conversational context
|
|
31
|
-
const lastUserMsg = messages.findLast((m) => m.role === 'user');
|
|
32
|
-
const lastAssistantMsg = messages.findLast((m) => m.role === 'assistant');
|
|
33
|
-
|
|
34
|
-
const recentExchange: string[] = [];
|
|
35
|
-
if (lastUserMsg) {
|
|
36
|
-
const text = extractText(lastUserMsg);
|
|
37
|
-
if (text) recentExchange.push(`User: ${text.slice(0, 500)}`);
|
|
38
|
-
}
|
|
39
|
-
if (lastAssistantMsg) {
|
|
40
|
-
const text = extractText(lastAssistantMsg);
|
|
41
|
-
if (text) recentExchange.push(`Assistant: ${text.slice(0, 500)}`);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
const handoffLines: string[] = [
|
|
45
|
-
`[Session Collapse — ${new Date().toISOString()}]`,
|
|
46
|
-
`Session: ${sessionId}`,
|
|
47
|
-
`${messages.length} message(s) collapsed to reduce context from ~${tokensBefore} tokens.`,
|
|
48
|
-
'',
|
|
49
|
-
'## Most Recent Exchange',
|
|
50
|
-
recentExchange.length > 0
|
|
51
|
-
? recentExchange.join('\n')
|
|
52
|
-
: '(no user/assistant exchange found)',
|
|
53
|
-
'',
|
|
54
|
-
'## Context Note',
|
|
55
|
-
'The full conversation history has been collapsed. Please resume from the above context.',
|
|
56
|
-
];
|
|
57
|
-
|
|
58
|
-
const handoff: ProviderMessage = {
|
|
59
|
-
role: 'user',
|
|
60
|
-
content: [{ type: 'text', text: handoffLines.join('\n') }],
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
const compacted: ProviderMessage[] = [handoff];
|
|
64
|
-
const tokensAfter = estimateTokens(JSON.stringify(compacted));
|
|
65
|
-
|
|
66
|
-
if (tokensAfter >= tokensBefore) {
|
|
67
|
-
warnings.push('collapse: compacted output is not smaller than input; possible data issue');
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return {
|
|
71
|
-
messages: compacted,
|
|
72
|
-
tokensAfter,
|
|
73
|
-
summary: `Collapse: ${messages.length} messages → 1 handoff message (~${tokensAfter} tokens).`,
|
|
74
|
-
strategy,
|
|
75
|
-
durationMs: Date.now() - startMs,
|
|
76
|
-
warnings,
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
/** Extracts plain text from a ProviderMessage. */
|
|
81
|
-
function extractText(msg: ProviderMessage): string {
|
|
82
|
-
if (typeof msg.content === 'string') return msg.content;
|
|
83
|
-
if (Array.isArray(msg.content)) {
|
|
84
|
-
return msg.content
|
|
85
|
-
.filter((b): b is { type: 'text'; text: string } => b.type === 'text')
|
|
86
|
-
.map((b) => b.text)
|
|
87
|
-
.join(' ');
|
|
88
|
-
}
|
|
89
|
-
return '';
|
|
90
|
-
}
|
|
1
|
+
export * from '@pellux/goodvibes-sdk/platform/runtime/compaction/strategies/collapse';
|
|
@@ -1,23 +1 @@
|
|
|
1
|
-
|
|
2
|
-
* strategies/index.ts
|
|
3
|
-
*
|
|
4
|
-
* Barrel re-export for all compaction strategy modules.
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
export { runMicrocompact } from './microcompact.ts';
|
|
8
|
-
export { runCollapse } from './collapse.ts';
|
|
9
|
-
export { runAutocompact } from './autocompact.ts';
|
|
10
|
-
export { runReactive } from './reactive.ts';
|
|
11
|
-
export { createBoundaryCommit, validateBoundaryCommit } from './boundary-commit.ts';
|
|
12
|
-
export type { BoundaryCommitOptions } from './boundary-commit.ts';
|
|
13
|
-
export {
|
|
14
|
-
computeQualityScore,
|
|
15
|
-
describeScore,
|
|
16
|
-
escalateStrategy,
|
|
17
|
-
LOW_QUALITY_THRESHOLD,
|
|
18
|
-
} from '../quality-score.ts';
|
|
19
|
-
export type {
|
|
20
|
-
CompactionQualityScore,
|
|
21
|
-
CompactionQualityGrade,
|
|
22
|
-
SemanticRetentionSignals,
|
|
23
|
-
} from '../quality-score.ts';
|
|
1
|
+
export * from '@pellux/goodvibes-sdk/platform/runtime/compaction/strategies/index';
|
|
@@ -1,74 +1 @@
|
|
|
1
|
-
|
|
2
|
-
* strategies/microcompact.ts
|
|
3
|
-
*
|
|
4
|
-
* Micro-compaction strategy — lightweight token reduction by summarising only
|
|
5
|
-
* the oldest turns in the conversation, preserving recent messages intact.
|
|
6
|
-
*
|
|
7
|
-
* This is the lowest-latency strategy: no LLM call, purely structural.
|
|
8
|
-
* It drops assistant/tool messages beyond a configurable "keep recent" window
|
|
9
|
-
* and prepends a short handoff note summarising what was dropped.
|
|
10
|
-
*/
|
|
11
|
-
|
|
12
|
-
import type { ProviderMessage } from '../../../providers/interface.ts';
|
|
13
|
-
import { estimateTokens } from '../../../core/compaction-types.ts';
|
|
14
|
-
import type { StrategyInput, StrategyOutput } from '../types.ts';
|
|
15
|
-
|
|
16
|
-
/** Number of recent messages preserved without modification. */
|
|
17
|
-
const DEFAULT_KEEP_RECENT = 20;
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Applies micro-compaction: keep the last N messages, drop earlier ones,
|
|
21
|
-
* and prepend a brief handoff note.
|
|
22
|
-
*
|
|
23
|
-
* @param input - Strategy input containing messages and context.
|
|
24
|
-
* @returns Strategy output with compacted messages and token estimates.
|
|
25
|
-
*/
|
|
26
|
-
export function runMicrocompact(input: StrategyInput): StrategyOutput {
|
|
27
|
-
const startMs = Date.now();
|
|
28
|
-
const { messages, tokensBefore, strategy } = input;
|
|
29
|
-
|
|
30
|
-
const keepRecent = DEFAULT_KEEP_RECENT;
|
|
31
|
-
const warnings: string[] = [];
|
|
32
|
-
|
|
33
|
-
if (messages.length <= keepRecent) {
|
|
34
|
-
// Nothing to compact — return messages unchanged
|
|
35
|
-
warnings.push('microcompact: message count within keep window; no reduction applied');
|
|
36
|
-
return {
|
|
37
|
-
messages: [...messages] as ProviderMessage[],
|
|
38
|
-
tokensAfter: tokensBefore,
|
|
39
|
-
summary: 'No compaction applied — message count within keep window.',
|
|
40
|
-
strategy,
|
|
41
|
-
durationMs: Date.now() - startMs,
|
|
42
|
-
warnings,
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
const kept = messages.slice(-keepRecent) as ProviderMessage[];
|
|
47
|
-
const droppedCount = messages.length - keepRecent;
|
|
48
|
-
|
|
49
|
-
const handoff: ProviderMessage = {
|
|
50
|
-
role: 'user',
|
|
51
|
-
content: [
|
|
52
|
-
{
|
|
53
|
-
type: 'text',
|
|
54
|
-
text: [
|
|
55
|
-
`[Session Micro-Compaction]`,
|
|
56
|
-
`${droppedCount} earlier message(s) were summarised to reduce context size.`,
|
|
57
|
-
`The conversation continues from the most recent ${keepRecent} messages.`,
|
|
58
|
-
].join('\n'),
|
|
59
|
-
},
|
|
60
|
-
],
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
const compacted: ProviderMessage[] = [handoff, ...kept];
|
|
64
|
-
const tokensAfter = estimateTokens(JSON.stringify(compacted));
|
|
65
|
-
|
|
66
|
-
return {
|
|
67
|
-
messages: compacted,
|
|
68
|
-
tokensAfter,
|
|
69
|
-
summary: `Micro-compaction: dropped ${droppedCount} messages, kept ${keepRecent} recent.`,
|
|
70
|
-
strategy,
|
|
71
|
-
durationMs: Date.now() - startMs,
|
|
72
|
-
warnings,
|
|
73
|
-
};
|
|
74
|
-
}
|
|
1
|
+
export * from '@pellux/goodvibes-sdk/platform/runtime/compaction/strategies/microcompact';
|
|
@@ -1,89 +1 @@
|
|
|
1
|
-
|
|
2
|
-
* strategies/reactive.ts
|
|
3
|
-
*
|
|
4
|
-
* Reactive compaction strategy — emergency compaction triggered when the
|
|
5
|
-
* provider returns a prompt-too-long error.
|
|
6
|
-
*
|
|
7
|
-
* This strategy must shrink the context aggressively and immediately, with
|
|
8
|
-
* minimal latency. It uses a fixed-percentage drop that guarantees the
|
|
9
|
-
* compacted context fits within a conservative safety margin (50% of the
|
|
10
|
-
* context window).
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
import type { ProviderMessage } from '../../../providers/interface.ts';
|
|
14
|
-
import { estimateTokens } from '../../../core/compaction-types.ts';
|
|
15
|
-
import type { StrategyInput, StrategyOutput } from '../types.ts';
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* Target fraction of context window to fill after reactive compaction.
|
|
19
|
-
* Keeping below 50% provides a comfortable buffer for the next turn.
|
|
20
|
-
*/
|
|
21
|
-
const REACTIVE_TARGET_FRACTION = 0.45;
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Applies reactive compaction to handle a prompt-too-long error.
|
|
25
|
-
*
|
|
26
|
-
* Drops messages from the oldest end until the estimated token count
|
|
27
|
-
* falls below `contextWindow * REACTIVE_TARGET_FRACTION`, then prepends
|
|
28
|
-
* a reactive handoff note.
|
|
29
|
-
*
|
|
30
|
-
* @param input - Strategy input. `input.meta.limit` may carry the provider's
|
|
31
|
-
* reported token limit for logging purposes.
|
|
32
|
-
* @returns Strategy output with a drastically reduced message list.
|
|
33
|
-
*/
|
|
34
|
-
export function runReactive(input: StrategyInput): StrategyOutput {
|
|
35
|
-
const startMs = Date.now();
|
|
36
|
-
const { messages, tokensBefore, contextWindow, strategy, meta } = input;
|
|
37
|
-
const warnings: string[] = [];
|
|
38
|
-
|
|
39
|
-
const targetTokens = Math.floor(contextWindow * REACTIVE_TARGET_FRACTION);
|
|
40
|
-
const providerLimit = typeof meta?.['limit'] === 'number' ? meta['limit'] : null;
|
|
41
|
-
|
|
42
|
-
// Pre-compute per-message token estimates, then use a running sum (O(n) not O(n²))
|
|
43
|
-
const perMessageTokens = (messages as ProviderMessage[]).map((m) =>
|
|
44
|
-
estimateTokens(JSON.stringify(m)),
|
|
45
|
-
);
|
|
46
|
-
let totalTokens = perMessageTokens.reduce((a, b) => a + b, 0);
|
|
47
|
-
let cutIndex = 0;
|
|
48
|
-
while (cutIndex < messages.length - 1 && totalTokens > targetTokens) {
|
|
49
|
-
totalTokens -= perMessageTokens[cutIndex];
|
|
50
|
-
cutIndex++;
|
|
51
|
-
}
|
|
52
|
-
const remaining: ProviderMessage[] = (messages as ProviderMessage[]).slice(cutIndex);
|
|
53
|
-
|
|
54
|
-
const droppedCount = messages.length - remaining.length;
|
|
55
|
-
|
|
56
|
-
if (droppedCount === 0) {
|
|
57
|
-
warnings.push('reactive: could not reduce context below target; context may still exceed limit');
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
const handoffLines: string[] = [
|
|
61
|
-
'[Reactive Compaction — Context Overflow Recovery]',
|
|
62
|
-
`Provider returned prompt-too-long${providerLimit !== null ? ` (limit: ${providerLimit} tokens)` : ''}.`,
|
|
63
|
-
`${droppedCount} message(s) dropped to recover from overflow.`,
|
|
64
|
-
`Estimated tokens before: ${tokensBefore}, target: ≤${targetTokens}.`,
|
|
65
|
-
];
|
|
66
|
-
|
|
67
|
-
const handoff: ProviderMessage = {
|
|
68
|
-
role: 'user',
|
|
69
|
-
content: [{ type: 'text', text: handoffLines.join('\n') }],
|
|
70
|
-
};
|
|
71
|
-
|
|
72
|
-
const compacted: ProviderMessage[] = [handoff, ...remaining];
|
|
73
|
-
const tokensAfter = estimateTokens(JSON.stringify(compacted));
|
|
74
|
-
|
|
75
|
-
if (tokensAfter > targetTokens) {
|
|
76
|
-
warnings.push(
|
|
77
|
-
`reactive: final token estimate (${tokensAfter}) still exceeds target (${targetTokens})`,
|
|
78
|
-
);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
return {
|
|
82
|
-
messages: compacted,
|
|
83
|
-
tokensAfter,
|
|
84
|
-
summary: `Reactive compaction: dropped ${droppedCount} messages to recover from overflow (~${tokensAfter} tokens remaining).`,
|
|
85
|
-
strategy,
|
|
86
|
-
durationMs: Date.now() - startMs,
|
|
87
|
-
warnings,
|
|
88
|
-
};
|
|
89
|
-
}
|
|
1
|
+
export * from '@pellux/goodvibes-sdk/platform/runtime/compaction/strategies/reactive';
|
|
@@ -1,221 +1 @@
|
|
|
1
|
-
|
|
2
|
-
* types.ts
|
|
3
|
-
*
|
|
4
|
-
* Core types for the session compaction lifecycle engine.
|
|
5
|
-
*
|
|
6
|
-
* These are distinct from `src/core/compaction-types.ts` (the prompt compaction
|
|
7
|
-
* section types). This module defines the *lifecycle* layer: state machine
|
|
8
|
-
* states, strategies, boundary commits, and repair records.
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import type { ProviderMessage } from '../../providers/interface.ts';
|
|
12
|
-
import type { CompactionQualityScore } from './quality-score.ts';
|
|
13
|
-
|
|
14
|
-
export type { CompactionQualityScore };
|
|
15
|
-
|
|
16
|
-
// ---------------------------------------------------------------------------
|
|
17
|
-
// Compaction lifecycle states
|
|
18
|
-
// ---------------------------------------------------------------------------
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* All states of the compaction lifecycle state machine.
|
|
22
|
-
*
|
|
23
|
-
* Transition map:
|
|
24
|
-
* idle → checking_threshold
|
|
25
|
-
* checking_threshold → microcompact | collapse | autocompact | reactive_compact | done
|
|
26
|
-
* microcompact → boundary_commit | failed
|
|
27
|
-
* collapse → boundary_commit | failed
|
|
28
|
-
* autocompact → boundary_commit | failed
|
|
29
|
-
* reactive_compact → boundary_commit | failed
|
|
30
|
-
* boundary_commit → done | failed
|
|
31
|
-
* done → idle
|
|
32
|
-
* failed → idle
|
|
33
|
-
*/
|
|
34
|
-
export type CompactionLifecycleState =
|
|
35
|
-
| 'idle'
|
|
36
|
-
| 'checking_threshold'
|
|
37
|
-
| 'microcompact'
|
|
38
|
-
| 'collapse'
|
|
39
|
-
| 'autocompact'
|
|
40
|
-
| 'reactive_compact'
|
|
41
|
-
| 'boundary_commit'
|
|
42
|
-
| 'done'
|
|
43
|
-
| 'failed';
|
|
44
|
-
|
|
45
|
-
// ---------------------------------------------------------------------------
|
|
46
|
-
// Strategy types
|
|
47
|
-
// ---------------------------------------------------------------------------
|
|
48
|
-
|
|
49
|
-
/**
|
|
50
|
-
* Discriminated union identifying which compaction strategy to apply.
|
|
51
|
-
*
|
|
52
|
-
* - `microcompact` — lightweight summary of recent turns; lowest latency
|
|
53
|
-
* - `collapse` — full context collapse into a single summary message
|
|
54
|
-
* - `autocompact` — threshold-based automatic compaction
|
|
55
|
-
* - `reactive` — emergency compaction triggered by prompt-too-long errors
|
|
56
|
-
*/
|
|
57
|
-
export type CompactionStrategy =
|
|
58
|
-
| 'microcompact'
|
|
59
|
-
| 'collapse'
|
|
60
|
-
| 'autocompact'
|
|
61
|
-
| 'reactive';
|
|
62
|
-
|
|
63
|
-
// ---------------------------------------------------------------------------
|
|
64
|
-
// Strategy input/output
|
|
65
|
-
// ---------------------------------------------------------------------------
|
|
66
|
-
|
|
67
|
-
/** Input passed to every compaction strategy. */
|
|
68
|
-
export interface StrategyInput {
|
|
69
|
-
/** Session ID for event correlation. */
|
|
70
|
-
sessionId: string;
|
|
71
|
-
/** Messages at the time compaction is triggered. */
|
|
72
|
-
messages: readonly ProviderMessage[];
|
|
73
|
-
/** Estimated token count before compaction. */
|
|
74
|
-
tokensBefore: number;
|
|
75
|
-
/** Context window size for the current model. */
|
|
76
|
-
contextWindow: number;
|
|
77
|
-
/** Which strategy is being applied (for self-identification in results). */
|
|
78
|
-
strategy: CompactionStrategy;
|
|
79
|
-
/** Optional additional metadata from the trigger. */
|
|
80
|
-
meta?: Record<string, unknown>;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
/** Output produced by every compaction strategy. */
|
|
84
|
-
export interface StrategyOutput {
|
|
85
|
-
/** Compacted message list to replace the current conversation. */
|
|
86
|
-
messages: ProviderMessage[];
|
|
87
|
-
/** Estimated token count after compaction. */
|
|
88
|
-
tokensAfter: number;
|
|
89
|
-
/** Human-readable summary of what was compacted. */
|
|
90
|
-
summary: string;
|
|
91
|
-
/** Strategy that produced this output. */
|
|
92
|
-
strategy: CompactionStrategy;
|
|
93
|
-
/** Wall-clock duration for this strategy's execution. */
|
|
94
|
-
durationMs: number;
|
|
95
|
-
/** Any warnings or non-fatal issues encountered. */
|
|
96
|
-
warnings: string[];
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
// ---------------------------------------------------------------------------
|
|
100
|
-
// Boundary commit
|
|
101
|
-
// ---------------------------------------------------------------------------
|
|
102
|
-
|
|
103
|
-
/**
|
|
104
|
-
* A boundary commit persists a compacted snapshot for replay-safe resumption.
|
|
105
|
-
*
|
|
106
|
-
* Each boundary commit stores:
|
|
107
|
-
* - A unique checkpoint ID
|
|
108
|
-
* - The compacted message slice (replay-safe: can be sliced from any prior state)
|
|
109
|
-
* - A lineage reference to its parent (or null for the root commit)
|
|
110
|
-
* - The strategy that produced this checkpoint
|
|
111
|
-
*/
|
|
112
|
-
export interface BoundaryCommit {
|
|
113
|
-
/** Unique monotonic checkpoint identifier (e.g. `cpt_<ulid>`). */
|
|
114
|
-
checkpointId: string;
|
|
115
|
-
/** Session ID this commit belongs to. */
|
|
116
|
-
sessionId: string;
|
|
117
|
-
/** Unix timestamp (ms) when this commit was created. */
|
|
118
|
-
createdAt: number;
|
|
119
|
-
/** Strategy that produced the compacted snapshot. */
|
|
120
|
-
strategy: CompactionStrategy;
|
|
121
|
-
/**
|
|
122
|
-
* Parent checkpoint ID in the lineage chain.
|
|
123
|
-
* `null` for the root commit (no prior compaction).
|
|
124
|
-
*/
|
|
125
|
-
parentCheckpointId: string | null;
|
|
126
|
-
/**
|
|
127
|
-
* Ordered lineage of all prior checkpoint IDs from root to this commit.
|
|
128
|
-
* Used for replay-safe slicing — always append-only.
|
|
129
|
-
*/
|
|
130
|
-
lineage: readonly string[];
|
|
131
|
-
/** The compacted messages at this boundary. */
|
|
132
|
-
messages: readonly ProviderMessage[];
|
|
133
|
-
/** Token count of the compacted messages. */
|
|
134
|
-
tokenCount: number;
|
|
135
|
-
/** Estimated token count before compaction (for audit). */
|
|
136
|
-
tokensBefore: number;
|
|
137
|
-
/** Human-readable summary stored with this checkpoint. */
|
|
138
|
-
summary: string;
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
// ---------------------------------------------------------------------------
|
|
142
|
-
// Lifecycle result
|
|
143
|
-
// ---------------------------------------------------------------------------
|
|
144
|
-
|
|
145
|
-
/**
|
|
146
|
-
* Result produced at the end of a complete compaction lifecycle run.
|
|
147
|
-
*
|
|
148
|
-
* Populated after transitioning through boundary_commit → done.
|
|
149
|
-
*/
|
|
150
|
-
export interface CompactionLifecycleResult {
|
|
151
|
-
/** Session ID this run was executed for. */
|
|
152
|
-
sessionId: string;
|
|
153
|
-
/** Strategy that was selected and executed. */
|
|
154
|
-
strategy: CompactionStrategy;
|
|
155
|
-
/** Tokens before compaction. */
|
|
156
|
-
tokensBefore: number;
|
|
157
|
-
/** Tokens after compaction. */
|
|
158
|
-
tokensAfter: number;
|
|
159
|
-
/** Total wall-clock duration from trigger to done. */
|
|
160
|
-
durationMs: number;
|
|
161
|
-
/** Boundary commit produced during this run (null if boundary_commit was skipped). */
|
|
162
|
-
commit: BoundaryCommit | null;
|
|
163
|
-
/** Compacted message list. */
|
|
164
|
-
messages: ProviderMessage[];
|
|
165
|
-
/** Strategy output warnings. */
|
|
166
|
-
warnings: string[];
|
|
167
|
-
/** Quality score for the strategy run (null when scoring was skipped). */
|
|
168
|
-
qualityScore: CompactionQualityScore | null;
|
|
169
|
-
/** Strategy switch reason if auto-escalation occurred (null otherwise). */
|
|
170
|
-
strategySwitchReason: string | null;
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
// ---------------------------------------------------------------------------
|
|
174
|
-
// Trigger
|
|
175
|
-
// ---------------------------------------------------------------------------
|
|
176
|
-
|
|
177
|
-
/**
|
|
178
|
-
* What initiated the compaction lifecycle run.
|
|
179
|
-
*
|
|
180
|
-
* - `auto` — threshold check determined compaction is needed
|
|
181
|
-
* - `manual` — user or orchestrator explicitly requested compaction
|
|
182
|
-
* - `prompt_too_long` — reactive trigger from a provider prompt-too-long error
|
|
183
|
-
*/
|
|
184
|
-
export type CompactionTrigger = 'auto' | 'manual' | 'prompt_too_long';
|
|
185
|
-
|
|
186
|
-
// ---------------------------------------------------------------------------
|
|
187
|
-
// Resume repair
|
|
188
|
-
// ---------------------------------------------------------------------------
|
|
189
|
-
|
|
190
|
-
/**
|
|
191
|
-
* Severity of a repair action applied during session resume.
|
|
192
|
-
*/
|
|
193
|
-
export type RepairSeverity = 'info' | 'warn' | 'error';
|
|
194
|
-
|
|
195
|
-
/** A single repair action applied during session resume. */
|
|
196
|
-
export interface RepairAction {
|
|
197
|
-
/** Short identifier for this repair type (e.g. `'truncate_overflow'`). */
|
|
198
|
-
kind: string;
|
|
199
|
-
/** Human-readable description of what was repaired. */
|
|
200
|
-
description: string;
|
|
201
|
-
/** Severity classification. */
|
|
202
|
-
severity: RepairSeverity;
|
|
203
|
-
/** Optional metadata about what was changed. */
|
|
204
|
-
meta?: Record<string, unknown>;
|
|
205
|
-
}
|
|
206
|
-
|
|
207
|
-
/** Result of the session resume repair pipeline. */
|
|
208
|
-
export interface ResumeRepairResult {
|
|
209
|
-
/** Session ID that was repaired. */
|
|
210
|
-
sessionId: string;
|
|
211
|
-
/** Whether any repairs were applied. */
|
|
212
|
-
repaired: boolean;
|
|
213
|
-
/** List of repair actions applied (empty if no repairs were needed). */
|
|
214
|
-
actions: RepairAction[];
|
|
215
|
-
/** Messages after repair (may be unchanged if no repairs were needed). */
|
|
216
|
-
messages: ProviderMessage[];
|
|
217
|
-
/** Whether the session is safe to resume after repair. */
|
|
218
|
-
safeToResume: boolean;
|
|
219
|
-
/** Human-readable reason if not safe to resume. */
|
|
220
|
-
failReason?: string;
|
|
221
|
-
}
|
|
1
|
+
export * from '@pellux/goodvibes-sdk/platform/runtime/compaction/types';
|