@stackmemoryai/stackmemory 0.3.0 → 0.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +52 -272
- package/dist/cli/codex-sm.js +48 -19
- package/dist/cli/codex-sm.js.map +2 -2
- package/dist/cli/commands/clear.js +191 -0
- package/dist/cli/commands/clear.js.map +7 -0
- package/dist/cli/commands/config.js +152 -1
- package/dist/cli/commands/config.js.map +2 -2
- package/dist/cli/commands/dashboard.js +178 -0
- package/dist/cli/commands/dashboard.js.map +7 -0
- package/dist/cli/commands/handoff.js +125 -8
- package/dist/cli/commands/handoff.js.map +2 -2
- package/dist/cli/commands/linear-create.js +132 -0
- package/dist/cli/commands/linear-create.js.map +7 -0
- package/dist/cli/commands/linear-list.js +69 -0
- package/dist/cli/commands/linear-list.js.map +7 -0
- package/dist/cli/commands/linear-migrate.js +40 -0
- package/dist/cli/commands/linear-migrate.js.map +7 -0
- package/dist/cli/commands/linear.js +185 -36
- package/dist/cli/commands/linear.js.map +2 -2
- package/dist/cli/commands/monitor.js +309 -0
- package/dist/cli/commands/monitor.js.map +7 -0
- package/dist/cli/commands/quality.js +414 -0
- package/dist/cli/commands/quality.js.map +7 -0
- package/dist/cli/commands/storage.js +275 -0
- package/dist/cli/commands/storage.js.map +7 -0
- package/dist/cli/commands/tui.js +66 -0
- package/dist/cli/commands/tui.js.map +7 -0
- package/dist/cli/commands/workflow.js +134 -0
- package/dist/cli/commands/workflow.js.map +7 -0
- package/dist/cli/index.js +105 -9
- package/dist/cli/index.js.map +3 -3
- package/dist/core/analytics/team-analytics.js +374 -0
- package/dist/core/analytics/team-analytics.js.map +7 -0
- package/dist/core/context/context-bridge.js +234 -0
- package/dist/core/context/context-bridge.js.map +7 -0
- package/dist/core/context/dual-stack-manager.js +850 -0
- package/dist/core/context/dual-stack-manager.js.map +7 -0
- package/dist/core/context/frame-handoff-manager.js +384 -0
- package/dist/core/context/frame-handoff-manager.js.map +7 -0
- package/dist/core/context/frame-manager.js +132 -12
- package/dist/core/context/frame-manager.js.map +2 -2
- package/dist/core/context/permission-manager.js +181 -0
- package/dist/core/context/permission-manager.js.map +7 -0
- package/dist/core/context/shared-context-layer.js +386 -0
- package/dist/core/context/shared-context-layer.js.map +7 -0
- package/dist/core/context/stack-merge-resolver.js +600 -0
- package/dist/core/context/stack-merge-resolver.js.map +7 -0
- package/dist/core/context/validation.js +121 -0
- package/dist/core/context/validation.js.map +7 -0
- package/dist/core/database/connection-pool.js +266 -175
- package/dist/core/database/connection-pool.js.map +2 -2
- package/dist/core/database/database-adapter.js +51 -0
- package/dist/core/database/database-adapter.js.map +7 -0
- package/dist/core/database/migration-manager.js +514 -0
- package/dist/core/database/migration-manager.js.map +7 -0
- package/dist/core/database/paradedb-adapter.js +970 -0
- package/dist/core/database/paradedb-adapter.js.map +7 -0
- package/dist/core/database/query-router.js +421 -0
- package/dist/core/database/query-router.js.map +7 -0
- package/dist/core/database/sqlite-adapter.js +547 -0
- package/dist/core/database/sqlite-adapter.js.map +7 -0
- package/dist/core/errors/index.js +21 -1
- package/dist/core/errors/index.js.map +2 -2
- package/dist/core/frame/workflow-templates-stub.js +42 -0
- package/dist/core/frame/workflow-templates-stub.js.map +7 -0
- package/dist/core/frame/workflow-templates.js +276 -0
- package/dist/core/frame/workflow-templates.js.map +7 -0
- package/dist/core/merge/conflict-detector.js +5 -2
- package/dist/core/merge/conflict-detector.js.map +2 -2
- package/dist/core/merge/resolution-engine.js +3 -14
- package/dist/core/merge/resolution-engine.js.map +2 -2
- package/dist/core/merge/stack-diff.js.map +2 -2
- package/dist/core/monitoring/logger.js +18 -3
- package/dist/core/monitoring/logger.js.map +2 -2
- package/dist/core/monitoring/session-monitor.js +296 -0
- package/dist/core/monitoring/session-monitor.js.map +7 -0
- package/dist/core/retrieval/context-retriever.js +475 -0
- package/dist/core/retrieval/context-retriever.js.map +7 -0
- package/dist/core/retrieval/graph-retrieval.js +658 -0
- package/dist/core/retrieval/graph-retrieval.js.map +7 -0
- package/dist/core/retrieval/hierarchical-retrieval.js +652 -0
- package/dist/core/retrieval/hierarchical-retrieval.js.map +7 -0
- package/dist/core/retrieval/retrieval-benchmarks.js +517 -0
- package/dist/core/retrieval/retrieval-benchmarks.js.map +7 -0
- package/dist/core/session/clear-survival-stub.js +49 -0
- package/dist/core/session/clear-survival-stub.js.map +7 -0
- package/dist/core/session/clear-survival.js +426 -0
- package/dist/core/session/clear-survival.js.map +7 -0
- package/dist/core/session/handoff-generator.js +339 -0
- package/dist/core/session/handoff-generator.js.map +7 -0
- package/dist/core/session/session-manager.js +61 -26
- package/dist/core/session/session-manager.js.map +3 -3
- package/dist/core/skills/index.js +3 -0
- package/dist/core/skills/index.js.map +7 -0
- package/dist/core/skills/skill-storage.js +749 -0
- package/dist/core/skills/skill-storage.js.map +7 -0
- package/dist/core/skills/types.js +189 -0
- package/dist/core/skills/types.js.map +7 -0
- package/dist/core/storage/railway-optimized-storage.js +550 -0
- package/dist/core/storage/railway-optimized-storage.js.map +7 -0
- package/dist/core/storage/remote-storage.js +456 -0
- package/dist/core/storage/remote-storage.js.map +7 -0
- package/dist/core/trace/trace-detector.js +136 -5
- package/dist/core/trace/trace-detector.js.map +2 -2
- package/dist/core/trace/trace-store.js.map +2 -2
- package/dist/features/tui/components/analytics-panel.js +136 -0
- package/dist/features/tui/components/analytics-panel.js.map +7 -0
- package/dist/features/tui/components/frame-visualizer.js +377 -0
- package/dist/features/tui/components/frame-visualizer.js.map +7 -0
- package/dist/features/tui/components/pr-tracker.js +123 -0
- package/dist/features/tui/components/pr-tracker.js.map +7 -0
- package/dist/features/tui/components/session-monitor.js +286 -0
- package/dist/features/tui/components/session-monitor.js.map +7 -0
- package/dist/features/tui/components/subagent-fleet.js +388 -0
- package/dist/features/tui/components/subagent-fleet.js.map +7 -0
- package/dist/features/tui/components/task-board.js +475 -0
- package/dist/features/tui/components/task-board.js.map +7 -0
- package/dist/features/tui/index.js +397 -0
- package/dist/features/tui/index.js.map +7 -0
- package/dist/features/tui/services/data-service.js +654 -0
- package/dist/features/tui/services/data-service.js.map +7 -0
- package/dist/features/tui/services/websocket-client.js +149 -0
- package/dist/features/tui/services/websocket-client.js.map +7 -0
- package/dist/features/tui/terminal-compat.js +205 -0
- package/dist/features/tui/terminal-compat.js.map +7 -0
- package/dist/features/tui/types.js +1 -0
- package/dist/features/tui/types.js.map +7 -0
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js +455 -0
- package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js.map +7 -0
- package/dist/integrations/claude-code/lifecycle-hooks.js +250 -0
- package/dist/integrations/claude-code/lifecycle-hooks.js.map +7 -0
- package/dist/integrations/claude-code/post-task-hooks.js +541 -0
- package/dist/integrations/claude-code/post-task-hooks.js.map +7 -0
- package/dist/integrations/linear/client.js +22 -4
- package/dist/integrations/linear/client.js.map +2 -2
- package/dist/integrations/linear/migration.js +299 -0
- package/dist/integrations/linear/migration.js.map +7 -0
- package/dist/integrations/linear/oauth-server.js +396 -0
- package/dist/integrations/linear/oauth-server.js.map +7 -0
- package/dist/integrations/linear/rest-client.js +199 -0
- package/dist/integrations/linear/rest-client.js.map +7 -0
- package/dist/integrations/linear/sync.js +14 -2
- package/dist/integrations/linear/sync.js.map +2 -2
- package/dist/integrations/linear/webhook-handler.js +200 -0
- package/dist/integrations/linear/webhook-handler.js.map +7 -0
- package/dist/integrations/mcp/handlers/skill-handlers.js +514 -0
- package/dist/integrations/mcp/handlers/skill-handlers.js.map +7 -0
- package/dist/integrations/mcp/middleware/tool-scoring.js +352 -0
- package/dist/integrations/mcp/middleware/tool-scoring.js.map +7 -0
- package/dist/integrations/mcp/refactored-server.js +31 -3
- package/dist/integrations/mcp/refactored-server.js.map +2 -2
- package/dist/integrations/mcp/server.js +25 -7
- package/dist/integrations/mcp/server.js.map +2 -2
- package/dist/mcp/stackmemory-mcp-server.js.map +1 -1
- package/dist/models/user.model.js +3 -0
- package/dist/models/user.model.js.map +2 -2
- package/dist/services/context-service.js.map +2 -2
- package/dist/utils/formatting.js +58 -0
- package/dist/utils/formatting.js.map +7 -0
- package/package.json +24 -5
- package/dist/cli/__tests__/index.test.js +0 -290
- package/dist/cli/__tests__/index.test.js.map +0 -7
- package/dist/core/config/__tests__/config-manager.test.js +0 -248
- package/dist/core/config/__tests__/config-manager.test.js.map +0 -7
- package/dist/core/context/__tests__/frame-manager.test.js +0 -879
- package/dist/core/context/__tests__/frame-manager.test.js.map +0 -7
- package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js +0 -379
- package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js.map +0 -7
- package/dist/core/digest/__tests__/frame-digest-integration.test.js +0 -230
- package/dist/core/digest/__tests__/frame-digest-integration.test.js.map +0 -7
- package/dist/core/errors/__tests__/error-handling.test.js +0 -270
- package/dist/core/errors/__tests__/error-handling.test.js.map +0 -7
- package/dist/core/merge/__tests__/conflict-scenarios.test.js +0 -414
- package/dist/core/merge/__tests__/conflict-scenarios.test.js.map +0 -7
- package/dist/core/query/__tests__/query-parser.test.js +0 -301
- package/dist/core/query/__tests__/query-parser.test.js.map +0 -7
- package/dist/core/query/__tests__/query-templates.test.js +0 -210
- package/dist/core/query/__tests__/query-templates.test.js.map +0 -7
- package/dist/core/trace/trace-detector.test.js +0 -401
- package/dist/core/trace/trace-detector.test.js.map +0 -7
- package/dist/features/tasks/__tests__/pebbles-task-store.test.js +0 -747
- package/dist/features/tasks/__tests__/pebbles-task-store.test.js.map +0 -7
- package/dist/integrations/linear/__tests__/auth.test.js +0 -558
- package/dist/integrations/linear/__tests__/auth.test.js.map +0 -7
- package/dist/integrations/linear/__tests__/sync-service.test.js +0 -760
- package/dist/integrations/linear/__tests__/sync-service.test.js.map +0 -7
- package/dist/integrations/mcp/__tests__/server.test.js +0 -798
- package/dist/integrations/mcp/__tests__/server.test.js.map +0 -7
- package/dist/scripts/benchmark-performance.d.ts +0 -7
- package/dist/scripts/benchmark-performance.d.ts.map +0 -1
- package/dist/scripts/benchmark-performance.js +0 -44
- package/dist/scripts/benchmark-performance.js.map +0 -1
- package/dist/scripts/cancel-duplicate-tasks.d.ts +0 -7
- package/dist/scripts/cancel-duplicate-tasks.d.ts.map +0 -1
- package/dist/scripts/cancel-duplicate-tasks.js +0 -172
- package/dist/scripts/cancel-duplicate-tasks.js.map +0 -1
- package/dist/scripts/cleanup-duplicate-tasks.d.ts +0 -12
- package/dist/scripts/cleanup-duplicate-tasks.d.ts.map +0 -1
- package/dist/scripts/cleanup-duplicate-tasks.js +0 -215
- package/dist/scripts/cleanup-duplicate-tasks.js.map +0 -1
- package/dist/scripts/initialize.d.ts +0 -6
- package/dist/scripts/initialize.d.ts.map +0 -1
- package/dist/scripts/initialize.js +0 -93
- package/dist/scripts/initialize.js.map +0 -1
- package/dist/scripts/list-linear-tasks.d.ts +0 -6
- package/dist/scripts/list-linear-tasks.d.ts.map +0 -1
- package/dist/scripts/list-linear-tasks.js +0 -121
- package/dist/scripts/list-linear-tasks.js.map +0 -1
- package/dist/scripts/merge-linear-duplicates-safe.d.ts +0 -7
- package/dist/scripts/merge-linear-duplicates-safe.d.ts.map +0 -1
- package/dist/scripts/merge-linear-duplicates-safe.js +0 -267
- package/dist/scripts/merge-linear-duplicates-safe.js.map +0 -1
- package/dist/scripts/show-linear-summary.d.ts +0 -6
- package/dist/scripts/show-linear-summary.d.ts.map +0 -1
- package/dist/scripts/show-linear-summary.js +0 -120
- package/dist/scripts/show-linear-summary.js.map +0 -1
- package/dist/scripts/status.d.ts +0 -6
- package/dist/scripts/status.d.ts.map +0 -1
- package/dist/scripts/status.js +0 -101
- package/dist/scripts/status.js.map +0 -1
- package/dist/src/agents/core/agent-task-manager.d.ts +0 -154
- package/dist/src/agents/core/agent-task-manager.d.ts.map +0 -1
- package/dist/src/agents/core/agent-task-manager.js +0 -504
- package/dist/src/agents/core/agent-task-manager.js.map +0 -1
- package/dist/src/agents/verifiers/base-verifier.d.ts +0 -112
- package/dist/src/agents/verifiers/base-verifier.d.ts.map +0 -1
- package/dist/src/agents/verifiers/base-verifier.js +0 -130
- package/dist/src/agents/verifiers/base-verifier.js.map +0 -1
- package/dist/src/agents/verifiers/formatter-verifier.d.ts +0 -14
- package/dist/src/agents/verifiers/formatter-verifier.d.ts.map +0 -1
- package/dist/src/agents/verifiers/formatter-verifier.js +0 -107
- package/dist/src/agents/verifiers/formatter-verifier.js.map +0 -1
- package/dist/src/agents/verifiers/llm-judge.d.ts +0 -46
- package/dist/src/agents/verifiers/llm-judge.d.ts.map +0 -1
- package/dist/src/agents/verifiers/llm-judge.js +0 -248
- package/dist/src/agents/verifiers/llm-judge.js.map +0 -1
- package/dist/src/cli/auto-detect.d.ts +0 -61
- package/dist/src/cli/auto-detect.d.ts.map +0 -1
- package/dist/src/cli/auto-detect.js +0 -350
- package/dist/src/cli/auto-detect.js.map +0 -1
- package/dist/src/cli/browser-test.d.ts +0 -6
- package/dist/src/cli/browser-test.d.ts.map +0 -1
- package/dist/src/cli/browser-test.js +0 -32
- package/dist/src/cli/browser-test.js.map +0 -1
- package/dist/src/cli/claude-sm.d.ts +0 -7
- package/dist/src/cli/claude-sm.d.ts.map +0 -1
- package/dist/src/cli/claude-sm.js +0 -412
- package/dist/src/cli/claude-sm.js.map +0 -1
- package/dist/src/cli/commands/agent.d.ts +0 -9
- package/dist/src/cli/commands/agent.d.ts.map +0 -1
- package/dist/src/cli/commands/agent.js +0 -303
- package/dist/src/cli/commands/agent.js.map +0 -1
- package/dist/src/cli/commands/config.d.ts +0 -6
- package/dist/src/cli/commands/config.d.ts.map +0 -1
- package/dist/src/cli/commands/config.js +0 -224
- package/dist/src/cli/commands/config.js.map +0 -1
- package/dist/src/cli/commands/context.d.ts +0 -7
- package/dist/src/cli/commands/context.d.ts.map +0 -1
- package/dist/src/cli/commands/context.js +0 -365
- package/dist/src/cli/commands/context.js.map +0 -1
- package/dist/src/cli/commands/handoff.d.ts +0 -6
- package/dist/src/cli/commands/handoff.d.ts.map +0 -1
- package/dist/src/cli/commands/handoff.js +0 -212
- package/dist/src/cli/commands/handoff.js.map +0 -1
- package/dist/src/cli/commands/linear-test.d.ts +0 -6
- package/dist/src/cli/commands/linear-test.d.ts.map +0 -1
- package/dist/src/cli/commands/linear-test.js +0 -123
- package/dist/src/cli/commands/linear-test.js.map +0 -1
- package/dist/src/cli/commands/linear.d.ts +0 -6
- package/dist/src/cli/commands/linear.d.ts.map +0 -1
- package/dist/src/cli/commands/linear.js +0 -393
- package/dist/src/cli/commands/linear.js.map +0 -1
- package/dist/src/cli/commands/log.d.ts +0 -7
- package/dist/src/cli/commands/log.d.ts.map +0 -1
- package/dist/src/cli/commands/log.js +0 -168
- package/dist/src/cli/commands/log.js.map +0 -1
- package/dist/src/cli/commands/onboard.d.ts +0 -8
- package/dist/src/cli/commands/onboard.d.ts.map +0 -1
- package/dist/src/cli/commands/onboard.js +0 -363
- package/dist/src/cli/commands/onboard.js.map +0 -1
- package/dist/src/cli/commands/projects.d.ts +0 -8
- package/dist/src/cli/commands/projects.d.ts.map +0 -1
- package/dist/src/cli/commands/projects.js +0 -220
- package/dist/src/cli/commands/projects.js.map +0 -1
- package/dist/src/cli/commands/search.d.ts +0 -7
- package/dist/src/cli/commands/search.d.ts.map +0 -1
- package/dist/src/cli/commands/search.js +0 -162
- package/dist/src/cli/commands/search.js.map +0 -1
- package/dist/src/cli/commands/session.d.ts +0 -7
- package/dist/src/cli/commands/session.d.ts.map +0 -1
- package/dist/src/cli/commands/session.js +0 -222
- package/dist/src/cli/commands/session.js.map +0 -1
- package/dist/src/cli/commands/tasks.d.ts +0 -7
- package/dist/src/cli/commands/tasks.d.ts.map +0 -1
- package/dist/src/cli/commands/tasks.js +0 -229
- package/dist/src/cli/commands/tasks.js.map +0 -1
- package/dist/src/cli/commands/webhook.d.ts +0 -3
- package/dist/src/cli/commands/webhook.d.ts.map +0 -1
- package/dist/src/cli/commands/webhook.js +0 -157
- package/dist/src/cli/commands/webhook.js.map +0 -1
- package/dist/src/cli/commands/worktree.d.ts +0 -8
- package/dist/src/cli/commands/worktree.d.ts.map +0 -1
- package/dist/src/cli/commands/worktree.js +0 -339
- package/dist/src/cli/commands/worktree.js.map +0 -1
- package/dist/src/cli/index.d.ts +0 -8
- package/dist/src/cli/index.d.ts.map +0 -1
- package/dist/src/cli/index.js +0 -995
- package/dist/src/cli/index.js.map +0 -1
- package/dist/src/cli/utils/viewer.d.ts +0 -3
- package/dist/src/cli/utils/viewer.d.ts.map +0 -1
- package/dist/src/cli/utils/viewer.js +0 -91
- package/dist/src/cli/utils/viewer.js.map +0 -1
- package/dist/src/core/config/config-manager.d.ts +0 -95
- package/dist/src/core/config/config-manager.d.ts.map +0 -1
- package/dist/src/core/config/config-manager.js +0 -359
- package/dist/src/core/config/config-manager.js.map +0 -1
- package/dist/src/core/config/types.d.ts +0 -72
- package/dist/src/core/config/types.d.ts.map +0 -1
- package/dist/src/core/config/types.js +0 -127
- package/dist/src/core/config/types.js.map +0 -1
- package/dist/src/core/context/auto-context.d.ts +0 -22
- package/dist/src/core/context/auto-context.d.ts.map +0 -1
- package/dist/src/core/context/auto-context.js +0 -77
- package/dist/src/core/context/auto-context.js.map +0 -1
- package/dist/src/core/context/compaction-handler.d.ts +0 -119
- package/dist/src/core/context/compaction-handler.d.ts.map +0 -1
- package/dist/src/core/context/compaction-handler.js +0 -306
- package/dist/src/core/context/compaction-handler.js.map +0 -1
- package/dist/src/core/context/frame-database.d.ts +0 -59
- package/dist/src/core/context/frame-database.d.ts.map +0 -1
- package/dist/src/core/context/frame-database.js +0 -333
- package/dist/src/core/context/frame-database.js.map +0 -1
- package/dist/src/core/context/frame-digest.d.ts +0 -59
- package/dist/src/core/context/frame-digest.d.ts.map +0 -1
- package/dist/src/core/context/frame-digest.js +0 -264
- package/dist/src/core/context/frame-digest.js.map +0 -1
- package/dist/src/core/context/frame-manager.d.ts +0 -112
- package/dist/src/core/context/frame-manager.d.ts.map +0 -1
- package/dist/src/core/context/frame-manager.js +0 -600
- package/dist/src/core/context/frame-manager.js.map +0 -1
- package/dist/src/core/context/frame-stack.d.ts +0 -85
- package/dist/src/core/context/frame-stack.d.ts.map +0 -1
- package/dist/src/core/context/frame-stack.js +0 -287
- package/dist/src/core/context/frame-stack.js.map +0 -1
- package/dist/src/core/context/frame-types.d.ts +0 -67
- package/dist/src/core/context/frame-types.d.ts.map +0 -1
- package/dist/src/core/context/frame-types.js +0 -6
- package/dist/src/core/context/frame-types.js.map +0 -1
- package/dist/src/core/context/index.d.ts +0 -11
- package/dist/src/core/context/index.d.ts.map +0 -1
- package/dist/src/core/context/index.js +0 -14
- package/dist/src/core/context/index.js.map +0 -1
- package/dist/src/core/context/model-aware-compaction.d.ts +0 -101
- package/dist/src/core/context/model-aware-compaction.d.ts.map +0 -1
- package/dist/src/core/context/model-aware-compaction.js +0 -616
- package/dist/src/core/context/model-aware-compaction.js.map +0 -1
- package/dist/src/core/context/refactored-frame-manager.d.ts +0 -99
- package/dist/src/core/context/refactored-frame-manager.d.ts.map +0 -1
- package/dist/src/core/context/refactored-frame-manager.js +0 -340
- package/dist/src/core/context/refactored-frame-manager.js.map +0 -1
- package/dist/src/core/database/batch-operations.d.ts +0 -118
- package/dist/src/core/database/batch-operations.d.ts.map +0 -1
- package/dist/src/core/database/batch-operations.js +0 -339
- package/dist/src/core/database/batch-operations.js.map +0 -1
- package/dist/src/core/database/connection-pool.d.ts +0 -79
- package/dist/src/core/database/connection-pool.d.ts.map +0 -1
- package/dist/src/core/database/connection-pool.js +0 -236
- package/dist/src/core/database/connection-pool.js.map +0 -1
- package/dist/src/core/database/query-cache.d.ts +0 -135
- package/dist/src/core/database/query-cache.d.ts.map +0 -1
- package/dist/src/core/database/query-cache.js +0 -294
- package/dist/src/core/database/query-cache.js.map +0 -1
- package/dist/src/core/digest/enhanced-hybrid-digest.d.ts +0 -125
- package/dist/src/core/digest/enhanced-hybrid-digest.d.ts.map +0 -1
- package/dist/src/core/digest/enhanced-hybrid-digest.js +0 -282
- package/dist/src/core/digest/enhanced-hybrid-digest.js.map +0 -1
- package/dist/src/core/digest/frame-digest-integration.d.ts +0 -67
- package/dist/src/core/digest/frame-digest-integration.d.ts.map +0 -1
- package/dist/src/core/digest/frame-digest-integration.js +0 -198
- package/dist/src/core/digest/frame-digest-integration.js.map +0 -1
- package/dist/src/core/digest/hybrid-digest-generator.d.ts +0 -76
- package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +0 -1
- package/dist/src/core/digest/hybrid-digest-generator.js +0 -629
- package/dist/src/core/digest/hybrid-digest-generator.js.map +0 -1
- package/dist/src/core/digest/index.d.ts +0 -9
- package/dist/src/core/digest/index.d.ts.map +0 -1
- package/dist/src/core/digest/index.js +0 -9
- package/dist/src/core/digest/index.js.map +0 -1
- package/dist/src/core/digest/types.d.ts +0 -154
- package/dist/src/core/digest/types.d.ts.map +0 -1
- package/dist/src/core/digest/types.js +0 -18
- package/dist/src/core/digest/types.js.map +0 -1
- package/dist/src/core/errors/index.d.ts +0 -143
- package/dist/src/core/errors/index.d.ts.map +0 -1
- package/dist/src/core/errors/index.js +0 -282
- package/dist/src/core/errors/index.js.map +0 -1
- package/dist/src/core/errors/recovery.d.ts +0 -86
- package/dist/src/core/errors/recovery.d.ts.map +0 -1
- package/dist/src/core/errors/recovery.js +0 -274
- package/dist/src/core/errors/recovery.js.map +0 -1
- package/dist/src/core/merge/conflict-detector.d.ts +0 -122
- package/dist/src/core/merge/conflict-detector.d.ts.map +0 -1
- package/dist/src/core/merge/conflict-detector.js +0 -468
- package/dist/src/core/merge/conflict-detector.js.map +0 -1
- package/dist/src/core/merge/index.d.ts +0 -9
- package/dist/src/core/merge/index.d.ts.map +0 -1
- package/dist/src/core/merge/index.js +0 -9
- package/dist/src/core/merge/index.js.map +0 -1
- package/dist/src/core/merge/resolution-engine.d.ts +0 -120
- package/dist/src/core/merge/resolution-engine.d.ts.map +0 -1
- package/dist/src/core/merge/resolution-engine.js +0 -573
- package/dist/src/core/merge/resolution-engine.js.map +0 -1
- package/dist/src/core/merge/stack-diff.d.ts +0 -97
- package/dist/src/core/merge/stack-diff.d.ts.map +0 -1
- package/dist/src/core/merge/stack-diff.js +0 -516
- package/dist/src/core/merge/stack-diff.js.map +0 -1
- package/dist/src/core/merge/types.d.ts +0 -110
- package/dist/src/core/merge/types.d.ts.map +0 -1
- package/dist/src/core/merge/types.js +0 -6
- package/dist/src/core/merge/types.js.map +0 -1
- package/dist/src/core/monitoring/error-handler.d.ts +0 -46
- package/dist/src/core/monitoring/error-handler.d.ts.map +0 -1
- package/dist/src/core/monitoring/error-handler.js +0 -212
- package/dist/src/core/monitoring/error-handler.js.map +0 -1
- package/dist/src/core/monitoring/logger.d.ts +0 -24
- package/dist/src/core/monitoring/logger.d.ts.map +0 -1
- package/dist/src/core/monitoring/logger.js +0 -126
- package/dist/src/core/monitoring/logger.js.map +0 -1
- package/dist/src/core/monitoring/metrics.d.ts +0 -10
- package/dist/src/core/monitoring/metrics.d.ts.map +0 -1
- package/dist/src/core/monitoring/metrics.js +0 -152
- package/dist/src/core/monitoring/metrics.js.map +0 -1
- package/dist/src/core/monitoring/progress-tracker.d.ts +0 -95
- package/dist/src/core/monitoring/progress-tracker.d.ts.map +0 -1
- package/dist/src/core/monitoring/progress-tracker.js +0 -178
- package/dist/src/core/monitoring/progress-tracker.js.map +0 -1
- package/dist/src/core/performance/context-cache.d.ts +0 -109
- package/dist/src/core/performance/context-cache.d.ts.map +0 -1
- package/dist/src/core/performance/context-cache.js +0 -280
- package/dist/src/core/performance/context-cache.js.map +0 -1
- package/dist/src/core/performance/index.d.ts +0 -3
- package/dist/src/core/performance/index.d.ts.map +0 -1
- package/dist/src/core/performance/index.js +0 -3
- package/dist/src/core/performance/index.js.map +0 -1
- package/dist/src/core/performance/lazy-context-loader.d.ts +0 -93
- package/dist/src/core/performance/lazy-context-loader.d.ts.map +0 -1
- package/dist/src/core/performance/lazy-context-loader.js +0 -332
- package/dist/src/core/performance/lazy-context-loader.js.map +0 -1
- package/dist/src/core/performance/monitor.d.ts +0 -48
- package/dist/src/core/performance/monitor.d.ts.map +0 -1
- package/dist/src/core/performance/monitor.js +0 -226
- package/dist/src/core/performance/monitor.js.map +0 -1
- package/dist/src/core/performance/optimized-frame-context.d.ts +0 -74
- package/dist/src/core/performance/optimized-frame-context.d.ts.map +0 -1
- package/dist/src/core/performance/optimized-frame-context.js +0 -330
- package/dist/src/core/performance/optimized-frame-context.js.map +0 -1
- package/dist/src/core/performance/performance-benchmark.d.ts +0 -50
- package/dist/src/core/performance/performance-benchmark.d.ts.map +0 -1
- package/dist/src/core/performance/performance-benchmark.js +0 -290
- package/dist/src/core/performance/performance-benchmark.js.map +0 -1
- package/dist/src/core/performance/performance-profiler.d.ts +0 -151
- package/dist/src/core/performance/performance-profiler.d.ts.map +0 -1
- package/dist/src/core/performance/performance-profiler.js +0 -346
- package/dist/src/core/performance/performance-profiler.js.map +0 -1
- package/dist/src/core/performance/streaming-jsonl-parser.d.ts +0 -41
- package/dist/src/core/performance/streaming-jsonl-parser.d.ts.map +0 -1
- package/dist/src/core/performance/streaming-jsonl-parser.js +0 -193
- package/dist/src/core/performance/streaming-jsonl-parser.js.map +0 -1
- package/dist/src/core/persistence/postgres-adapter.d.ts +0 -31
- package/dist/src/core/persistence/postgres-adapter.d.ts.map +0 -1
- package/dist/src/core/persistence/postgres-adapter.js +0 -330
- package/dist/src/core/persistence/postgres-adapter.js.map +0 -1
- package/dist/src/core/projects/project-manager.d.ts +0 -130
- package/dist/src/core/projects/project-manager.d.ts.map +0 -1
- package/dist/src/core/projects/project-manager.js +0 -709
- package/dist/src/core/projects/project-manager.js.map +0 -1
- package/dist/src/core/query/query-parser.d.ts +0 -109
- package/dist/src/core/query/query-parser.d.ts.map +0 -1
- package/dist/src/core/query/query-parser.js +0 -415
- package/dist/src/core/query/query-parser.js.map +0 -1
- package/dist/src/core/query/query-templates.d.ts +0 -44
- package/dist/src/core/query/query-templates.d.ts.map +0 -1
- package/dist/src/core/query/query-templates.js +0 -326
- package/dist/src/core/query/query-templates.js.map +0 -1
- package/dist/src/core/retrieval/index.d.ts +0 -8
- package/dist/src/core/retrieval/index.d.ts.map +0 -1
- package/dist/src/core/retrieval/index.js +0 -8
- package/dist/src/core/retrieval/index.js.map +0 -1
- package/dist/src/core/retrieval/llm-context-retrieval.d.ts +0 -73
- package/dist/src/core/retrieval/llm-context-retrieval.d.ts.map +0 -1
- package/dist/src/core/retrieval/llm-context-retrieval.js +0 -597
- package/dist/src/core/retrieval/llm-context-retrieval.js.map +0 -1
- package/dist/src/core/retrieval/summary-generator.d.ts +0 -63
- package/dist/src/core/retrieval/summary-generator.d.ts.map +0 -1
- package/dist/src/core/retrieval/summary-generator.js +0 -622
- package/dist/src/core/retrieval/summary-generator.js.map +0 -1
- package/dist/src/core/retrieval/types.d.ts +0 -257
- package/dist/src/core/retrieval/types.d.ts.map +0 -1
- package/dist/src/core/retrieval/types.js +0 -18
- package/dist/src/core/retrieval/types.js.map +0 -1
- package/dist/src/core/session/index.d.ts +0 -2
- package/dist/src/core/session/index.d.ts.map +0 -1
- package/dist/src/core/session/index.js +0 -2
- package/dist/src/core/session/index.js.map +0 -1
- package/dist/src/core/session/session-manager.d.ts +0 -69
- package/dist/src/core/session/session-manager.d.ts.map +0 -1
- package/dist/src/core/session/session-manager.js +0 -311
- package/dist/src/core/session/session-manager.js.map +0 -1
- package/dist/src/core/trace/cli-trace-wrapper.d.ts +0 -23
- package/dist/src/core/trace/cli-trace-wrapper.d.ts.map +0 -1
- package/dist/src/core/trace/cli-trace-wrapper.js +0 -141
- package/dist/src/core/trace/cli-trace-wrapper.js.map +0 -1
- package/dist/src/core/trace/db-trace-wrapper.d.ts +0 -36
- package/dist/src/core/trace/db-trace-wrapper.d.ts.map +0 -1
- package/dist/src/core/trace/db-trace-wrapper.js +0 -252
- package/dist/src/core/trace/db-trace-wrapper.js.map +0 -1
- package/dist/src/core/trace/debug-trace.d.ts +0 -84
- package/dist/src/core/trace/debug-trace.d.ts.map +0 -1
- package/dist/src/core/trace/debug-trace.js +0 -402
- package/dist/src/core/trace/debug-trace.js.map +0 -1
- package/dist/src/core/trace/error-test.d.ts +0 -6
- package/dist/src/core/trace/error-test.d.ts.map +0 -1
- package/dist/src/core/trace/error-test.js +0 -128
- package/dist/src/core/trace/error-test.js.map +0 -1
- package/dist/src/core/trace/index.d.ts +0 -25
- package/dist/src/core/trace/index.d.ts.map +0 -1
- package/dist/src/core/trace/index.js +0 -121
- package/dist/src/core/trace/index.js.map +0 -1
- package/dist/src/core/trace/linear-api-wrapper.d.ts +0 -17
- package/dist/src/core/trace/linear-api-wrapper.d.ts.map +0 -1
- package/dist/src/core/trace/linear-api-wrapper.js +0 -205
- package/dist/src/core/trace/linear-api-wrapper.js.map +0 -1
- package/dist/src/core/trace/performance-test.d.ts +0 -6
- package/dist/src/core/trace/performance-test.d.ts.map +0 -1
- package/dist/src/core/trace/performance-test.js +0 -111
- package/dist/src/core/trace/performance-test.js.map +0 -1
- package/dist/src/core/trace/trace-demo.d.ts +0 -8
- package/dist/src/core/trace/trace-demo.d.ts.map +0 -1
- package/dist/src/core/trace/trace-demo.js +0 -154
- package/dist/src/core/trace/trace-demo.js.map +0 -1
- package/dist/src/core/trace/trace-detector.d.ts +0 -108
- package/dist/src/core/trace/trace-detector.d.ts.map +0 -1
- package/dist/src/core/trace/trace-detector.demo.d.ts +0 -5
- package/dist/src/core/trace/trace-detector.demo.d.ts.map +0 -1
- package/dist/src/core/trace/trace-detector.demo.js +0 -145
- package/dist/src/core/trace/trace-detector.demo.js.map +0 -1
- package/dist/src/core/trace/trace-detector.js +0 -425
- package/dist/src/core/trace/trace-detector.js.map +0 -1
- package/dist/src/core/trace/trace-store.d.ts +0 -60
- package/dist/src/core/trace/trace-store.d.ts.map +0 -1
- package/dist/src/core/trace/trace-store.js +0 -323
- package/dist/src/core/trace/trace-store.js.map +0 -1
- package/dist/src/core/trace/types.d.ts +0 -81
- package/dist/src/core/trace/types.d.ts.map +0 -1
- package/dist/src/core/trace/types.js +0 -70
- package/dist/src/core/trace/types.js.map +0 -1
- package/dist/src/core/types.d.ts +0 -35
- package/dist/src/core/types.d.ts.map +0 -1
- package/dist/src/core/types.js +0 -2
- package/dist/src/core/types.js.map +0 -1
- package/dist/src/core/utils/update-checker.d.ts +0 -38
- package/dist/src/core/utils/update-checker.d.ts.map +0 -1
- package/dist/src/core/utils/update-checker.js +0 -213
- package/dist/src/core/utils/update-checker.js.map +0 -1
- package/dist/src/core/worktree/worktree-manager.d.ts +0 -110
- package/dist/src/core/worktree/worktree-manager.d.ts.map +0 -1
- package/dist/src/core/worktree/worktree-manager.js +0 -456
- package/dist/src/core/worktree/worktree-manager.js.map +0 -1
- package/dist/src/features/analytics/api/analytics-api.d.ts +0 -24
- package/dist/src/features/analytics/api/analytics-api.d.ts.map +0 -1
- package/dist/src/features/analytics/api/analytics-api.js +0 -289
- package/dist/src/features/analytics/api/analytics-api.js.map +0 -1
- package/dist/src/features/analytics/core/analytics-service.d.ts +0 -29
- package/dist/src/features/analytics/core/analytics-service.d.ts.map +0 -1
- package/dist/src/features/analytics/core/analytics-service.js +0 -275
- package/dist/src/features/analytics/core/analytics-service.js.map +0 -1
- package/dist/src/features/analytics/index.d.ts +0 -12
- package/dist/src/features/analytics/index.d.ts.map +0 -1
- package/dist/src/features/analytics/index.js +0 -11
- package/dist/src/features/analytics/index.js.map +0 -1
- package/dist/src/features/analytics/queries/metrics-queries.d.ts +0 -11
- package/dist/src/features/analytics/queries/metrics-queries.d.ts.map +0 -1
- package/dist/src/features/analytics/queries/metrics-queries.js +0 -240
- package/dist/src/features/analytics/queries/metrics-queries.js.map +0 -1
- package/dist/src/features/analytics/types/metrics.d.ts +0 -60
- package/dist/src/features/analytics/types/metrics.d.ts.map +0 -1
- package/dist/src/features/analytics/types/metrics.js +0 -2
- package/dist/src/features/analytics/types/metrics.js.map +0 -1
- package/dist/src/features/browser/browser-mcp.d.ts +0 -94
- package/dist/src/features/browser/browser-mcp.d.ts.map +0 -1
- package/dist/src/features/browser/browser-mcp.js +0 -459
- package/dist/src/features/browser/browser-mcp.js.map +0 -1
- package/dist/src/features/tasks/pebbles-task-store.d.ts +0 -128
- package/dist/src/features/tasks/pebbles-task-store.d.ts.map +0 -1
- package/dist/src/features/tasks/pebbles-task-store.js +0 -572
- package/dist/src/features/tasks/pebbles-task-store.js.map +0 -1
- package/dist/src/features/tasks/task-aware-context.d.ts +0 -103
- package/dist/src/features/tasks/task-aware-context.d.ts.map +0 -1
- package/dist/src/features/tasks/task-aware-context.js +0 -412
- package/dist/src/features/tasks/task-aware-context.js.map +0 -1
- package/dist/src/index.d.ts +0 -21
- package/dist/src/index.d.ts.map +0 -1
- package/dist/src/index.js +0 -9
- package/dist/src/index.js.map +0 -1
- package/dist/src/integrations/linear/auth.d.ts +0 -99
- package/dist/src/integrations/linear/auth.d.ts.map +0 -1
- package/dist/src/integrations/linear/auth.js +0 -319
- package/dist/src/integrations/linear/auth.js.map +0 -1
- package/dist/src/integrations/linear/auto-sync.d.ts +0 -77
- package/dist/src/integrations/linear/auto-sync.d.ts.map +0 -1
- package/dist/src/integrations/linear/auto-sync.js +0 -268
- package/dist/src/integrations/linear/auto-sync.js.map +0 -1
- package/dist/src/integrations/linear/client.d.ts +0 -127
- package/dist/src/integrations/linear/client.d.ts.map +0 -1
- package/dist/src/integrations/linear/client.js +0 -446
- package/dist/src/integrations/linear/client.js.map +0 -1
- package/dist/src/integrations/linear/config.d.ts +0 -51
- package/dist/src/integrations/linear/config.d.ts.map +0 -1
- package/dist/src/integrations/linear/config.js +0 -103
- package/dist/src/integrations/linear/config.js.map +0 -1
- package/dist/src/integrations/linear/sync-manager.d.ts +0 -78
- package/dist/src/integrations/linear/sync-manager.d.ts.map +0 -1
- package/dist/src/integrations/linear/sync-manager.js +0 -235
- package/dist/src/integrations/linear/sync-manager.js.map +0 -1
- package/dist/src/integrations/linear/sync-service.d.ts +0 -46
- package/dist/src/integrations/linear/sync-service.d.ts.map +0 -1
- package/dist/src/integrations/linear/sync-service.js +0 -217
- package/dist/src/integrations/linear/sync-service.js.map +0 -1
- package/dist/src/integrations/linear/sync.d.ts +0 -125
- package/dist/src/integrations/linear/sync.d.ts.map +0 -1
- package/dist/src/integrations/linear/sync.js +0 -563
- package/dist/src/integrations/linear/sync.js.map +0 -1
- package/dist/src/integrations/linear/types.d.ts +0 -90
- package/dist/src/integrations/linear/types.d.ts.map +0 -1
- package/dist/src/integrations/linear/types.js +0 -2
- package/dist/src/integrations/linear/types.js.map +0 -1
- package/dist/src/integrations/linear/webhook-server.d.ts +0 -32
- package/dist/src/integrations/linear/webhook-server.d.ts.map +0 -1
- package/dist/src/integrations/linear/webhook-server.js +0 -190
- package/dist/src/integrations/linear/webhook-server.js.map +0 -1
- package/dist/src/integrations/linear/webhook.d.ts +0 -108
- package/dist/src/integrations/linear/webhook.d.ts.map +0 -1
- package/dist/src/integrations/linear/webhook.js +0 -291
- package/dist/src/integrations/linear/webhook.js.map +0 -1
- package/dist/src/integrations/mcp/handlers/context-handlers.d.ts +0 -39
- package/dist/src/integrations/mcp/handlers/context-handlers.d.ts.map +0 -1
- package/dist/src/integrations/mcp/handlers/context-handlers.js +0 -266
- package/dist/src/integrations/mcp/handlers/context-handlers.js.map +0 -1
- package/dist/src/integrations/mcp/handlers/index.d.ts +0 -37
- package/dist/src/integrations/mcp/handlers/index.d.ts.map +0 -1
- package/dist/src/integrations/mcp/handlers/index.js +0 -134
- package/dist/src/integrations/mcp/handlers/index.js.map +0 -1
- package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts +0 -33
- package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts.map +0 -1
- package/dist/src/integrations/mcp/handlers/linear-handlers.js +0 -251
- package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +0 -1
- package/dist/src/integrations/mcp/handlers/task-handlers.d.ts +0 -42
- package/dist/src/integrations/mcp/handlers/task-handlers.d.ts.map +0 -1
- package/dist/src/integrations/mcp/handlers/task-handlers.js +0 -238
- package/dist/src/integrations/mcp/handlers/task-handlers.js.map +0 -1
- package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts +0 -41
- package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts.map +0 -1
- package/dist/src/integrations/mcp/handlers/trace-handlers.js +0 -298
- package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +0 -1
- package/dist/src/integrations/mcp/index.d.ts +0 -13
- package/dist/src/integrations/mcp/index.d.ts.map +0 -1
- package/dist/src/integrations/mcp/index.js +0 -17
- package/dist/src/integrations/mcp/index.js.map +0 -1
- package/dist/src/integrations/mcp/refactored-server.d.ts +0 -76
- package/dist/src/integrations/mcp/refactored-server.d.ts.map +0 -1
- package/dist/src/integrations/mcp/refactored-server.js +0 -351
- package/dist/src/integrations/mcp/refactored-server.js.map +0 -1
- package/dist/src/integrations/mcp/server.d.ts +0 -54
- package/dist/src/integrations/mcp/server.d.ts.map +0 -1
- package/dist/src/integrations/mcp/server.js +0 -1616
- package/dist/src/integrations/mcp/server.js.map +0 -1
- package/dist/src/integrations/mcp/tool-definitions.d.ts +0 -44
- package/dist/src/integrations/mcp/tool-definitions.d.ts.map +0 -1
- package/dist/src/integrations/mcp/tool-definitions.js +0 -563
- package/dist/src/integrations/mcp/tool-definitions.js.map +0 -1
- package/dist/src/integrations/mcp/trace-test.d.ts +0 -5
- package/dist/src/integrations/mcp/trace-test.d.ts.map +0 -1
- package/dist/src/integrations/mcp/trace-test.js +0 -54
- package/dist/src/integrations/mcp/trace-test.js.map +0 -1
- package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts +0 -48
- package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts.map +0 -1
- package/dist/src/integrations/pg-aiguide/embedding-provider.js +0 -190
- package/dist/src/integrations/pg-aiguide/embedding-provider.js.map +0 -1
- package/dist/src/integrations/pg-aiguide/semantic-search.d.ts +0 -34
- package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +0 -1
- package/dist/src/integrations/pg-aiguide/semantic-search.js +0 -176
- package/dist/src/integrations/pg-aiguide/semantic-search.js.map +0 -1
- package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts +0 -44
- package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts.map +0 -1
- package/dist/src/integrations/pg-aiguide/timescale-analytics.js +0 -215
- package/dist/src/integrations/pg-aiguide/timescale-analytics.js.map +0 -1
- package/dist/src/mcp/stackmemory-mcp-server.d.ts +0 -9
- package/dist/src/mcp/stackmemory-mcp-server.d.ts.map +0 -1
- package/dist/src/mcp/stackmemory-mcp-server.js +0 -519
- package/dist/src/mcp/stackmemory-mcp-server.js.map +0 -1
- package/dist/src/middleware/exponential-rate-limiter.d.ts +0 -78
- package/dist/src/middleware/exponential-rate-limiter.d.ts.map +0 -1
- package/dist/src/middleware/exponential-rate-limiter.js +0 -293
- package/dist/src/middleware/exponential-rate-limiter.js.map +0 -1
- package/dist/src/models/user.model.d.ts +0 -62
- package/dist/src/models/user.model.d.ts.map +0 -1
- package/dist/src/models/user.model.js +0 -311
- package/dist/src/models/user.model.js.map +0 -1
- package/dist/src/servers/production/auth-middleware.d.ts +0 -76
- package/dist/src/servers/production/auth-middleware.d.ts.map +0 -1
- package/dist/src/servers/production/auth-middleware.js +0 -558
- package/dist/src/servers/production/auth-middleware.js.map +0 -1
- package/dist/src/servers/railway/index.d.ts +0 -7
- package/dist/src/servers/railway/index.d.ts.map +0 -1
- package/dist/src/servers/railway/index.js +0 -401
- package/dist/src/servers/railway/index.js.map +0 -1
- package/dist/src/services/config-service.d.ts +0 -44
- package/dist/src/services/config-service.d.ts.map +0 -1
- package/dist/src/services/config-service.js +0 -61
- package/dist/src/services/config-service.js.map +0 -1
- package/dist/src/services/context-service.d.ts +0 -17
- package/dist/src/services/context-service.d.ts.map +0 -1
- package/dist/src/services/context-service.js +0 -173
- package/dist/src/services/context-service.js.map +0 -1
- package/dist/src/types/task.d.ts +0 -27
- package/dist/src/types/task.d.ts.map +0 -1
- package/dist/src/types/task.js +0 -2
- package/dist/src/types/task.js.map +0 -1
- package/dist/src/utils/logger.d.ts +0 -13
- package/dist/src/utils/logger.d.ts.map +0 -1
- package/dist/src/utils/logger.js +0 -52
- package/dist/src/utils/logger.js.map +0 -1
- package/dist/src/validation/schemas.d.ts +0 -633
- package/dist/src/validation/schemas.d.ts.map +0 -1
- package/dist/src/validation/schemas.js +0 -347
- package/dist/src/validation/schemas.js.map +0 -1
|
@@ -0,0 +1,456 @@
|
|
|
1
|
+
import { S3Client, PutObjectCommand, GetObjectCommand } from "@aws-sdk/client-s3";
|
|
2
|
+
import { Storage } from "@google-cloud/storage";
|
|
3
|
+
import { logger } from "../monitoring/logger.js";
|
|
4
|
+
var StorageTier = /* @__PURE__ */ ((StorageTier2) => {
|
|
5
|
+
StorageTier2["HOT"] = "hot";
|
|
6
|
+
StorageTier2["NEARLINE"] = "nearline";
|
|
7
|
+
StorageTier2["COLDLINE"] = "coldline";
|
|
8
|
+
StorageTier2["ARCHIVE"] = "archive";
|
|
9
|
+
return StorageTier2;
|
|
10
|
+
})(StorageTier || {});
|
|
11
|
+
const DEFAULT_REMOTE_CONFIG = {
|
|
12
|
+
provider: "gcs",
|
|
13
|
+
// Default to GCS for better pricing
|
|
14
|
+
gcs: {
|
|
15
|
+
bucketName: "stackmemory-traces",
|
|
16
|
+
projectId: process.env.GCP_PROJECT_ID || "stackmemory"
|
|
17
|
+
},
|
|
18
|
+
timeseries: {
|
|
19
|
+
type: "sqlite",
|
|
20
|
+
// Use SQLite for development
|
|
21
|
+
host: "localhost",
|
|
22
|
+
port: 0,
|
|
23
|
+
database: "stackmemory_timeseries"
|
|
24
|
+
},
|
|
25
|
+
migration: {
|
|
26
|
+
batchSize: 100,
|
|
27
|
+
hotAgeHours: 168,
|
|
28
|
+
// 7 days
|
|
29
|
+
nearlineAgeHours: 720,
|
|
30
|
+
// 30 days
|
|
31
|
+
coldlineAgeHours: 2160,
|
|
32
|
+
// 90 days
|
|
33
|
+
archiveAgeHours: 8760,
|
|
34
|
+
// 365 days
|
|
35
|
+
scoreThreshold: 0.4
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
class RemoteStorageManager {
|
|
39
|
+
storageClient;
|
|
40
|
+
config;
|
|
41
|
+
localDb;
|
|
42
|
+
migrationInProgress = false;
|
|
43
|
+
constructor(localDb, config) {
|
|
44
|
+
this.localDb = localDb;
|
|
45
|
+
this.config = { ...DEFAULT_REMOTE_CONFIG, ...config };
|
|
46
|
+
this.initializeStorageClient();
|
|
47
|
+
this.initializeSchema();
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Initialize storage client based on provider
|
|
51
|
+
*/
|
|
52
|
+
initializeStorageClient() {
|
|
53
|
+
switch (this.config.provider) {
|
|
54
|
+
case "gcs":
|
|
55
|
+
if (this.config.gcs) {
|
|
56
|
+
this.storageClient = new Storage({
|
|
57
|
+
projectId: this.config.gcs.projectId,
|
|
58
|
+
keyFilename: this.config.gcs.keyFilename
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
break;
|
|
62
|
+
case "s3":
|
|
63
|
+
case "railway":
|
|
64
|
+
if (this.config.s3?.accessKeyId && this.config.s3?.secretAccessKey) {
|
|
65
|
+
this.storageClient = new S3Client({
|
|
66
|
+
region: this.config.s3.region,
|
|
67
|
+
credentials: {
|
|
68
|
+
accessKeyId: this.config.s3.accessKeyId,
|
|
69
|
+
secretAccessKey: this.config.s3.secretAccessKey
|
|
70
|
+
},
|
|
71
|
+
endpoint: this.config.s3.endpoint
|
|
72
|
+
// Railway buckets endpoint
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
break;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Initialize migration tracking schema
|
|
80
|
+
*/
|
|
81
|
+
initializeSchema() {
|
|
82
|
+
this.localDb.exec(`
|
|
83
|
+
CREATE TABLE IF NOT EXISTS remote_migrations (
|
|
84
|
+
trace_id TEXT PRIMARY KEY,
|
|
85
|
+
migrated_at INTEGER NOT NULL,
|
|
86
|
+
storage_tier TEXT NOT NULL,
|
|
87
|
+
s3_key TEXT,
|
|
88
|
+
timeseries_id TEXT,
|
|
89
|
+
compression_level TEXT,
|
|
90
|
+
original_size INTEGER,
|
|
91
|
+
compressed_size INTEGER,
|
|
92
|
+
retrieval_count INTEGER DEFAULT 0,
|
|
93
|
+
last_retrieved INTEGER,
|
|
94
|
+
FOREIGN KEY (trace_id) REFERENCES traces(id) ON DELETE CASCADE
|
|
95
|
+
)
|
|
96
|
+
`);
|
|
97
|
+
this.localDb.exec(`
|
|
98
|
+
CREATE INDEX IF NOT EXISTS idx_migrations_tier ON remote_migrations(storage_tier);
|
|
99
|
+
CREATE INDEX IF NOT EXISTS idx_migrations_migrated ON remote_migrations(migrated_at);
|
|
100
|
+
`);
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Identify traces for migration based on age and importance
|
|
104
|
+
*/
|
|
105
|
+
async identifyMigrationCandidates() {
|
|
106
|
+
const now = Date.now();
|
|
107
|
+
const traces = this.localDb.prepare(`
|
|
108
|
+
SELECT
|
|
109
|
+
t.id,
|
|
110
|
+
t.score,
|
|
111
|
+
t.start_time,
|
|
112
|
+
LENGTH(t.compressed_data) +
|
|
113
|
+
COALESCE((SELECT SUM(LENGTH(tc.arguments) + LENGTH(tc.result))
|
|
114
|
+
FROM tool_calls tc WHERE tc.trace_id = t.id), 0) as size,
|
|
115
|
+
rm.trace_id as already_migrated
|
|
116
|
+
FROM traces t
|
|
117
|
+
LEFT JOIN remote_migrations rm ON t.id = rm.trace_id
|
|
118
|
+
WHERE rm.trace_id IS NULL -- Not already migrated
|
|
119
|
+
ORDER BY t.start_time ASC
|
|
120
|
+
`).all();
|
|
121
|
+
const candidates = [];
|
|
122
|
+
for (const trace of traces) {
|
|
123
|
+
const ageHours = (now - trace.start_time) / (1e3 * 60 * 60);
|
|
124
|
+
const candidate = this.evaluateTrace(
|
|
125
|
+
trace.id,
|
|
126
|
+
ageHours,
|
|
127
|
+
trace.score,
|
|
128
|
+
trace.size || 0
|
|
129
|
+
);
|
|
130
|
+
candidates.push(candidate);
|
|
131
|
+
}
|
|
132
|
+
return candidates;
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Evaluate a trace for migration based on GCS storage classes
|
|
136
|
+
*/
|
|
137
|
+
evaluateTrace(traceId, ageHours, score, size) {
|
|
138
|
+
let tier = "hot" /* HOT */;
|
|
139
|
+
let shouldMigrate = false;
|
|
140
|
+
let compressionLevel = "none";
|
|
141
|
+
if (ageHours > this.config.migration.archiveAgeHours) {
|
|
142
|
+
tier = "archive" /* ARCHIVE */;
|
|
143
|
+
shouldMigrate = true;
|
|
144
|
+
compressionLevel = "heavy";
|
|
145
|
+
} else if (ageHours > this.config.migration.coldlineAgeHours) {
|
|
146
|
+
tier = "coldline" /* COLDLINE */;
|
|
147
|
+
shouldMigrate = true;
|
|
148
|
+
compressionLevel = "heavy";
|
|
149
|
+
} else if (ageHours > this.config.migration.nearlineAgeHours) {
|
|
150
|
+
tier = "nearline" /* NEARLINE */;
|
|
151
|
+
shouldMigrate = true;
|
|
152
|
+
compressionLevel = "medium";
|
|
153
|
+
} else if (ageHours > this.config.migration.hotAgeHours) {
|
|
154
|
+
tier = "hot" /* HOT */;
|
|
155
|
+
if (score < this.config.migration.scoreThreshold) {
|
|
156
|
+
shouldMigrate = true;
|
|
157
|
+
compressionLevel = "light";
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
const localSizeLimit = 2 * 1024 * 1024 * 1024;
|
|
161
|
+
const currentLocalSize = this.getLocalStorageSize();
|
|
162
|
+
if (currentLocalSize > localSizeLimit * 0.75) {
|
|
163
|
+
shouldMigrate = true;
|
|
164
|
+
if (compressionLevel === "none") {
|
|
165
|
+
compressionLevel = "light";
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
return {
|
|
169
|
+
traceId,
|
|
170
|
+
age: ageHours,
|
|
171
|
+
score,
|
|
172
|
+
size,
|
|
173
|
+
tier,
|
|
174
|
+
shouldMigrate,
|
|
175
|
+
compressionLevel
|
|
176
|
+
};
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* Migrate traces to remote storage
|
|
180
|
+
*/
|
|
181
|
+
async migrateTraces(candidates, dryRun = false) {
|
|
182
|
+
if (this.migrationInProgress) {
|
|
183
|
+
return {
|
|
184
|
+
migrated: 0,
|
|
185
|
+
failed: 0,
|
|
186
|
+
totalSize: 0,
|
|
187
|
+
errors: ["Migration already in progress"]
|
|
188
|
+
};
|
|
189
|
+
}
|
|
190
|
+
this.migrationInProgress = true;
|
|
191
|
+
const results = {
|
|
192
|
+
migrated: 0,
|
|
193
|
+
failed: 0,
|
|
194
|
+
totalSize: 0,
|
|
195
|
+
errors: []
|
|
196
|
+
};
|
|
197
|
+
try {
|
|
198
|
+
const toMigrate = candidates.filter((c) => c.shouldMigrate);
|
|
199
|
+
const batches = this.createBatches(toMigrate, this.config.migration.batchSize);
|
|
200
|
+
for (const batch of batches) {
|
|
201
|
+
if (dryRun) {
|
|
202
|
+
logger.info("Dry run - would migrate batch", {
|
|
203
|
+
count: batch.length,
|
|
204
|
+
totalSize: batch.reduce((sum, c) => sum + c.size, 0)
|
|
205
|
+
});
|
|
206
|
+
results.migrated += batch.length;
|
|
207
|
+
continue;
|
|
208
|
+
}
|
|
209
|
+
const batchResults = await this.migrateBatch(batch);
|
|
210
|
+
results.migrated += batchResults.success;
|
|
211
|
+
results.failed += batchResults.failed;
|
|
212
|
+
results.totalSize += batchResults.totalSize;
|
|
213
|
+
results.errors.push(...batchResults.errors);
|
|
214
|
+
await new Promise((resolve) => setTimeout(resolve, 100));
|
|
215
|
+
}
|
|
216
|
+
} finally {
|
|
217
|
+
this.migrationInProgress = false;
|
|
218
|
+
}
|
|
219
|
+
logger.info("Migration completed", results);
|
|
220
|
+
return results;
|
|
221
|
+
}
|
|
222
|
+
/**
|
|
223
|
+
* Migrate a batch of traces
|
|
224
|
+
*/
|
|
225
|
+
async migrateBatch(batch) {
|
|
226
|
+
const results = {
|
|
227
|
+
success: 0,
|
|
228
|
+
failed: 0,
|
|
229
|
+
totalSize: 0,
|
|
230
|
+
errors: []
|
|
231
|
+
};
|
|
232
|
+
for (const candidate of batch) {
|
|
233
|
+
try {
|
|
234
|
+
const trace = this.getTraceData(candidate.traceId);
|
|
235
|
+
if (!trace) {
|
|
236
|
+
throw new Error(`Trace ${candidate.traceId} not found`);
|
|
237
|
+
}
|
|
238
|
+
const compressed = this.compressTrace(trace, candidate.compressionLevel);
|
|
239
|
+
if (this.s3Client) {
|
|
240
|
+
const s3Key = this.generateS3Key(candidate);
|
|
241
|
+
await this.uploadToS3(s3Key, compressed);
|
|
242
|
+
this.recordMigration(candidate, s3Key, trace, compressed);
|
|
243
|
+
} else {
|
|
244
|
+
this.recordMigration(candidate, "simulated", trace, compressed);
|
|
245
|
+
}
|
|
246
|
+
if (candidate.tier === StorageTier.COLD || candidate.tier === "archive" /* ARCHIVE */) {
|
|
247
|
+
this.removeLocalTrace(candidate.traceId);
|
|
248
|
+
}
|
|
249
|
+
results.success++;
|
|
250
|
+
results.totalSize += candidate.size;
|
|
251
|
+
} catch (error) {
|
|
252
|
+
results.failed++;
|
|
253
|
+
results.errors.push(
|
|
254
|
+
`Failed to migrate ${candidate.traceId}: ${error}`
|
|
255
|
+
);
|
|
256
|
+
logger.error("Migration failed for trace", {
|
|
257
|
+
traceId: candidate.traceId,
|
|
258
|
+
error
|
|
259
|
+
});
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
return results;
|
|
263
|
+
}
|
|
264
|
+
/**
|
|
265
|
+
* Get full trace data for migration
|
|
266
|
+
*/
|
|
267
|
+
getTraceData(traceId) {
|
|
268
|
+
const traceRow = this.localDb.prepare(
|
|
269
|
+
"SELECT * FROM traces WHERE id = ?"
|
|
270
|
+
).get(traceId);
|
|
271
|
+
if (!traceRow) return null;
|
|
272
|
+
const toolCalls = this.localDb.prepare(
|
|
273
|
+
"SELECT * FROM tool_calls WHERE trace_id = ? ORDER BY sequence_number"
|
|
274
|
+
).all(traceId);
|
|
275
|
+
return {
|
|
276
|
+
trace: traceRow,
|
|
277
|
+
toolCalls
|
|
278
|
+
};
|
|
279
|
+
}
|
|
280
|
+
/**
|
|
281
|
+
* Compress trace based on compression level
|
|
282
|
+
*/
|
|
283
|
+
compressTrace(data, level) {
|
|
284
|
+
let jsonData = JSON.stringify(data);
|
|
285
|
+
switch (level) {
|
|
286
|
+
case "none":
|
|
287
|
+
return Buffer.from(jsonData);
|
|
288
|
+
case "light":
|
|
289
|
+
return Buffer.from(JSON.stringify(JSON.parse(jsonData)));
|
|
290
|
+
case "medium":
|
|
291
|
+
const cleaned = JSON.parse(
|
|
292
|
+
jsonData,
|
|
293
|
+
(key, value) => value === null || value === void 0 ? void 0 : value
|
|
294
|
+
);
|
|
295
|
+
return Buffer.from(JSON.stringify(cleaned));
|
|
296
|
+
case "heavy":
|
|
297
|
+
const minimal = {
|
|
298
|
+
id: data.trace.id,
|
|
299
|
+
type: data.trace.type,
|
|
300
|
+
score: data.trace.score,
|
|
301
|
+
summary: data.trace.summary,
|
|
302
|
+
timestamps: {
|
|
303
|
+
start: data.trace.start_time,
|
|
304
|
+
end: data.trace.end_time
|
|
305
|
+
},
|
|
306
|
+
toolCount: data.toolCalls.length,
|
|
307
|
+
toolTypes: [...new Set(data.toolCalls.map((t) => t.tool))]
|
|
308
|
+
};
|
|
309
|
+
return Buffer.from(JSON.stringify(minimal));
|
|
310
|
+
default:
|
|
311
|
+
return Buffer.from(jsonData);
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
/**
|
|
315
|
+
* Generate S3 key for trace
|
|
316
|
+
*/
|
|
317
|
+
generateS3Key(candidate) {
|
|
318
|
+
const date = new Date(Date.now() - candidate.age * 60 * 60 * 1e3);
|
|
319
|
+
const year = date.getFullYear();
|
|
320
|
+
const month = String(date.getMonth() + 1).padStart(2, "0");
|
|
321
|
+
const day = String(date.getDate()).padStart(2, "0");
|
|
322
|
+
return `traces/${year}/${month}/${day}/${candidate.tier}/${candidate.traceId}.json`;
|
|
323
|
+
}
|
|
324
|
+
/**
|
|
325
|
+
* Upload to S3
|
|
326
|
+
*/
|
|
327
|
+
async uploadToS3(key, data) {
|
|
328
|
+
if (!this.s3Client) {
|
|
329
|
+
throw new Error("S3 client not configured");
|
|
330
|
+
}
|
|
331
|
+
const command = new PutObjectCommand({
|
|
332
|
+
Bucket: this.config.s3.bucket,
|
|
333
|
+
Key: key,
|
|
334
|
+
Body: data,
|
|
335
|
+
ContentType: "application/json",
|
|
336
|
+
Metadata: {
|
|
337
|
+
"trace-version": "1.0",
|
|
338
|
+
"compression": "true"
|
|
339
|
+
}
|
|
340
|
+
});
|
|
341
|
+
await this.s3Client.send(command);
|
|
342
|
+
}
|
|
343
|
+
/**
|
|
344
|
+
* Record migration in local database
|
|
345
|
+
*/
|
|
346
|
+
recordMigration(candidate, s3Key, originalData, compressedData) {
|
|
347
|
+
const stmt = this.localDb.prepare(`
|
|
348
|
+
INSERT INTO remote_migrations (
|
|
349
|
+
trace_id, migrated_at, storage_tier, s3_key,
|
|
350
|
+
compression_level, original_size, compressed_size
|
|
351
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?)
|
|
352
|
+
`);
|
|
353
|
+
stmt.run(
|
|
354
|
+
candidate.traceId,
|
|
355
|
+
Date.now(),
|
|
356
|
+
candidate.tier,
|
|
357
|
+
s3Key,
|
|
358
|
+
candidate.compressionLevel,
|
|
359
|
+
JSON.stringify(originalData).length,
|
|
360
|
+
compressedData.length
|
|
361
|
+
);
|
|
362
|
+
}
|
|
363
|
+
/**
|
|
364
|
+
* Remove local trace after migration
|
|
365
|
+
*/
|
|
366
|
+
removeLocalTrace(traceId) {
|
|
367
|
+
this.localDb.prepare("DELETE FROM tool_calls WHERE trace_id = ?").run(traceId);
|
|
368
|
+
this.localDb.prepare("DELETE FROM traces WHERE id = ?").run(traceId);
|
|
369
|
+
}
|
|
370
|
+
/**
|
|
371
|
+
* Get current local storage size
|
|
372
|
+
*/
|
|
373
|
+
getLocalStorageSize() {
|
|
374
|
+
const result = this.localDb.prepare(`
|
|
375
|
+
SELECT
|
|
376
|
+
SUM(LENGTH(compressed_data)) +
|
|
377
|
+
COALESCE((SELECT SUM(LENGTH(arguments) + LENGTH(result))
|
|
378
|
+
FROM tool_calls), 0) as total_size
|
|
379
|
+
FROM traces
|
|
380
|
+
`).get();
|
|
381
|
+
return result?.total_size || 0;
|
|
382
|
+
}
|
|
383
|
+
/**
|
|
384
|
+
* Create batches from candidates
|
|
385
|
+
*/
|
|
386
|
+
createBatches(items, batchSize) {
|
|
387
|
+
const batches = [];
|
|
388
|
+
for (let i = 0; i < items.length; i += batchSize) {
|
|
389
|
+
batches.push(items.slice(i, i + batchSize));
|
|
390
|
+
}
|
|
391
|
+
return batches;
|
|
392
|
+
}
|
|
393
|
+
/**
|
|
394
|
+
* Retrieve trace from remote storage
|
|
395
|
+
*/
|
|
396
|
+
async retrieveTrace(traceId) {
|
|
397
|
+
const migration = this.localDb.prepare(`
|
|
398
|
+
SELECT * FROM remote_migrations WHERE trace_id = ?
|
|
399
|
+
`).get(traceId);
|
|
400
|
+
if (!migration) {
|
|
401
|
+
throw new Error(`Trace ${traceId} not found in remote storage`);
|
|
402
|
+
}
|
|
403
|
+
this.localDb.prepare(`
|
|
404
|
+
UPDATE remote_migrations
|
|
405
|
+
SET retrieval_count = retrieval_count + 1, last_retrieved = ?
|
|
406
|
+
WHERE trace_id = ?
|
|
407
|
+
`).run(Date.now(), traceId);
|
|
408
|
+
if (!this.s3Client) {
|
|
409
|
+
throw new Error("S3 client not configured");
|
|
410
|
+
}
|
|
411
|
+
const command = new GetObjectCommand({
|
|
412
|
+
Bucket: this.config.s3.bucket,
|
|
413
|
+
Key: migration.s3_key
|
|
414
|
+
});
|
|
415
|
+
const response = await this.s3Client.send(command);
|
|
416
|
+
const data = await response.Body?.transformToString();
|
|
417
|
+
if (!data) {
|
|
418
|
+
throw new Error("No data retrieved from S3");
|
|
419
|
+
}
|
|
420
|
+
return JSON.parse(data);
|
|
421
|
+
}
|
|
422
|
+
/**
|
|
423
|
+
* Get migration statistics
|
|
424
|
+
*/
|
|
425
|
+
getMigrationStats() {
|
|
426
|
+
const stats = this.localDb.prepare(`
|
|
427
|
+
SELECT
|
|
428
|
+
storage_tier,
|
|
429
|
+
COUNT(*) as count,
|
|
430
|
+
SUM(original_size) as original_size,
|
|
431
|
+
SUM(compressed_size) as compressed_size,
|
|
432
|
+
AVG(retrieval_count) as avg_retrievals
|
|
433
|
+
FROM remote_migrations
|
|
434
|
+
GROUP BY storage_tier
|
|
435
|
+
`).all();
|
|
436
|
+
const total = this.localDb.prepare(`
|
|
437
|
+
SELECT
|
|
438
|
+
COUNT(*) as total_migrated,
|
|
439
|
+
SUM(original_size) as total_original,
|
|
440
|
+
SUM(compressed_size) as total_compressed
|
|
441
|
+
FROM remote_migrations
|
|
442
|
+
`).get();
|
|
443
|
+
return {
|
|
444
|
+
byTier: stats,
|
|
445
|
+
total,
|
|
446
|
+
compressionRatio: total ? (1 - total.total_compressed / total.total_original).toFixed(2) : 0,
|
|
447
|
+
localSize: this.getLocalStorageSize()
|
|
448
|
+
};
|
|
449
|
+
}
|
|
450
|
+
}
|
|
451
|
+
export {
|
|
452
|
+
DEFAULT_REMOTE_CONFIG,
|
|
453
|
+
RemoteStorageManager,
|
|
454
|
+
StorageTier
|
|
455
|
+
};
|
|
456
|
+
//# sourceMappingURL=remote-storage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/core/storage/remote-storage.ts"],
|
|
4
|
+
"sourcesContent": ["/**\n * Remote Storage Interface for Two-Tier Storage System\n * Implements infinite retention with TimeSeries DB + S3\n */\n\nimport { S3Client, PutObjectCommand, GetObjectCommand, DeleteObjectCommand } from '@aws-sdk/client-s3';\nimport { Storage } from '@google-cloud/storage';\nimport { logger } from '../monitoring/logger.js';\nimport { Trace, CompressedTrace } from '../trace/types.js';\nimport Database from 'better-sqlite3';\n\nexport enum StorageTier {\n HOT = 'hot', // < 7 days - Railway Buckets or GCS Standard\n NEARLINE = 'nearline', // 7-30 days - GCS Nearline ($0.01/GB)\n COLDLINE = 'coldline', // 30-90 days - GCS Coldline ($0.004/GB)\n ARCHIVE = 'archive' // > 90 days - GCS Archive ($0.0012/GB)\n}\n\nexport interface RemoteStorageConfig {\n provider: 'gcs' | 's3' | 'railway';\n gcs?: {\n bucketName: string;\n projectId: string;\n keyFilename?: string; // Path to service account key\n };\n s3?: {\n bucket: string;\n region: string;\n accessKeyId?: string;\n secretAccessKey?: string;\n endpoint?: string; // For Railway buckets or MinIO\n };\n timeseries: {\n type: 'clickhouse' | 'timescale' | 'influxdb' | 'sqlite'; // SQLite for dev\n host: string;\n port: number;\n database: string;\n username?: string;\n password?: string;\n };\n migration: {\n batchSize: number;\n hotAgeHours: number; // < 7 days\n nearlineAgeHours: number; // 7-30 days \n coldlineAgeHours: number; // 30-90 days\n archiveAgeHours: number; // > 90 days\n scoreThreshold: number; // Score threshold for early migration\n };\n}\n\nexport const DEFAULT_REMOTE_CONFIG: RemoteStorageConfig = {\n provider: 'gcs', // Default to GCS for better pricing\n gcs: {\n bucketName: 'stackmemory-traces',\n projectId: process.env.GCP_PROJECT_ID || 'stackmemory',\n },\n timeseries: {\n type: 'sqlite', // Use SQLite for development\n host: 'localhost',\n port: 0,\n database: 'stackmemory_timeseries',\n },\n migration: {\n batchSize: 100,\n hotAgeHours: 168, // 7 days\n nearlineAgeHours: 720, // 30 days\n coldlineAgeHours: 2160, // 90 days\n archiveAgeHours: 8760, // 365 days\n scoreThreshold: 0.4,\n }\n};\n\nexport interface MigrationCandidate {\n traceId: string;\n age: number;\n score: number;\n size: number;\n tier: StorageTier;\n shouldMigrate: boolean;\n compressionLevel: 'none' | 'light' | 'medium' | 'heavy';\n}\n\n/**\n * Remote storage manager for infinite trace retention\n */\nexport class RemoteStorageManager {\n private storageClient?: S3Client | Storage;\n private config: RemoteStorageConfig;\n private localDb: Database.Database;\n private migrationInProgress = false;\n \n constructor(\n localDb: Database.Database,\n config?: Partial<RemoteStorageConfig>\n ) {\n this.localDb = localDb;\n this.config = { ...DEFAULT_REMOTE_CONFIG, ...config };\n \n this.initializeStorageClient();\n this.initializeSchema();\n }\n \n /**\n * Initialize storage client based on provider\n */\n private initializeStorageClient(): void {\n switch (this.config.provider) {\n case 'gcs':\n if (this.config.gcs) {\n this.storageClient = new Storage({\n projectId: this.config.gcs.projectId,\n keyFilename: this.config.gcs.keyFilename,\n });\n }\n break;\n \n case 's3':\n case 'railway':\n if (this.config.s3?.accessKeyId && this.config.s3?.secretAccessKey) {\n this.storageClient = new S3Client({\n region: this.config.s3.region,\n credentials: {\n accessKeyId: this.config.s3.accessKeyId,\n secretAccessKey: this.config.s3.secretAccessKey,\n },\n endpoint: this.config.s3.endpoint, // Railway buckets endpoint\n });\n }\n break;\n }\n }\n \n /**\n * Initialize migration tracking schema\n */\n private initializeSchema(): void {\n this.localDb.exec(`\n CREATE TABLE IF NOT EXISTS remote_migrations (\n trace_id TEXT PRIMARY KEY,\n migrated_at INTEGER NOT NULL,\n storage_tier TEXT NOT NULL,\n s3_key TEXT,\n timeseries_id TEXT,\n compression_level TEXT,\n original_size INTEGER,\n compressed_size INTEGER,\n retrieval_count INTEGER DEFAULT 0,\n last_retrieved INTEGER,\n FOREIGN KEY (trace_id) REFERENCES traces(id) ON DELETE CASCADE\n )\n `);\n \n this.localDb.exec(`\n CREATE INDEX IF NOT EXISTS idx_migrations_tier ON remote_migrations(storage_tier);\n CREATE INDEX IF NOT EXISTS idx_migrations_migrated ON remote_migrations(migrated_at);\n `);\n }\n \n /**\n * Identify traces for migration based on age and importance\n */\n async identifyMigrationCandidates(): Promise<MigrationCandidate[]> {\n const now = Date.now();\n \n // Query all traces with their metadata\n const traces = this.localDb.prepare(`\n SELECT \n t.id,\n t.score,\n t.start_time,\n LENGTH(t.compressed_data) + \n COALESCE((SELECT SUM(LENGTH(tc.arguments) + LENGTH(tc.result)) \n FROM tool_calls tc WHERE tc.trace_id = t.id), 0) as size,\n rm.trace_id as already_migrated\n FROM traces t\n LEFT JOIN remote_migrations rm ON t.id = rm.trace_id\n WHERE rm.trace_id IS NULL -- Not already migrated\n ORDER BY t.start_time ASC\n `).all() as any[];\n \n const candidates: MigrationCandidate[] = [];\n \n for (const trace of traces) {\n const ageHours = (now - trace.start_time) / (1000 * 60 * 60);\n const candidate = this.evaluateTrace(\n trace.id,\n ageHours,\n trace.score,\n trace.size || 0\n );\n \n candidates.push(candidate);\n }\n \n return candidates;\n }\n \n /**\n * Evaluate a trace for migration based on GCS storage classes\n */\n private evaluateTrace(\n traceId: string,\n ageHours: number,\n score: number,\n size: number\n ): MigrationCandidate {\n let tier = StorageTier.HOT;\n let shouldMigrate = false;\n let compressionLevel: 'none' | 'light' | 'medium' | 'heavy' = 'none';\n \n // Determine storage tier based on age and GCS storage classes\n if (ageHours > this.config.migration.archiveAgeHours) {\n // GCS Archive: $0.0012/GB - accessed < once per year\n tier = StorageTier.ARCHIVE;\n shouldMigrate = true;\n compressionLevel = 'heavy';\n } else if (ageHours > this.config.migration.coldlineAgeHours) {\n // GCS Coldline: $0.004/GB - accessed < once per quarter \n tier = StorageTier.COLDLINE;\n shouldMigrate = true;\n compressionLevel = 'heavy';\n } else if (ageHours > this.config.migration.nearlineAgeHours) {\n // GCS Nearline: $0.01/GB - accessed < once per month\n tier = StorageTier.NEARLINE;\n shouldMigrate = true;\n compressionLevel = 'medium';\n } else if (ageHours > this.config.migration.hotAgeHours) {\n // Still hot but consider migration if low importance\n tier = StorageTier.HOT;\n if (score < this.config.migration.scoreThreshold) {\n shouldMigrate = true;\n compressionLevel = 'light';\n }\n }\n \n // Force migration for size pressure\n const localSizeLimit = 2 * 1024 * 1024 * 1024; // 2GB\n const currentLocalSize = this.getLocalStorageSize();\n \n if (currentLocalSize > localSizeLimit * 0.75) {\n // Start migrating when 75% full\n shouldMigrate = true;\n if (compressionLevel === 'none') {\n compressionLevel = 'light';\n }\n }\n \n return {\n traceId,\n age: ageHours,\n score,\n size,\n tier,\n shouldMigrate,\n compressionLevel,\n };\n }\n \n /**\n * Migrate traces to remote storage\n */\n async migrateTraces(\n candidates: MigrationCandidate[],\n dryRun: boolean = false\n ): Promise<{\n migrated: number;\n failed: number;\n totalSize: number;\n errors: string[];\n }> {\n if (this.migrationInProgress) {\n return {\n migrated: 0,\n failed: 0,\n totalSize: 0,\n errors: ['Migration already in progress'],\n };\n }\n \n this.migrationInProgress = true;\n const results = {\n migrated: 0,\n failed: 0,\n totalSize: 0,\n errors: [] as string[],\n };\n \n try {\n // Process in batches\n const toMigrate = candidates.filter(c => c.shouldMigrate);\n const batches = this.createBatches(toMigrate, this.config.migration.batchSize);\n \n for (const batch of batches) {\n if (dryRun) {\n logger.info('Dry run - would migrate batch', {\n count: batch.length,\n totalSize: batch.reduce((sum, c) => sum + c.size, 0),\n });\n results.migrated += batch.length;\n continue;\n }\n \n const batchResults = await this.migrateBatch(batch);\n results.migrated += batchResults.success;\n results.failed += batchResults.failed;\n results.totalSize += batchResults.totalSize;\n results.errors.push(...batchResults.errors);\n \n // Small delay between batches\n await new Promise(resolve => setTimeout(resolve, 100));\n }\n \n } finally {\n this.migrationInProgress = false;\n }\n \n logger.info('Migration completed', results);\n return results;\n }\n \n /**\n * Migrate a batch of traces\n */\n private async migrateBatch(\n batch: MigrationCandidate[]\n ): Promise<{\n success: number;\n failed: number;\n totalSize: number;\n errors: string[];\n }> {\n const results = {\n success: 0,\n failed: 0,\n totalSize: 0,\n errors: [] as string[],\n };\n \n for (const candidate of batch) {\n try {\n // Get full trace data\n const trace = this.getTraceData(candidate.traceId);\n if (!trace) {\n throw new Error(`Trace ${candidate.traceId} not found`);\n }\n \n // Compress based on level\n const compressed = this.compressTrace(trace, candidate.compressionLevel);\n \n // Upload to S3\n if (this.s3Client) {\n const s3Key = this.generateS3Key(candidate);\n await this.uploadToS3(s3Key, compressed);\n \n // Record migration\n this.recordMigration(candidate, s3Key, trace, compressed);\n } else {\n // Local simulation for testing\n this.recordMigration(candidate, 'simulated', trace, compressed);\n }\n \n // Optionally remove from local after successful migration\n if (candidate.tier === StorageTier.COLD || \n candidate.tier === StorageTier.ARCHIVE) {\n this.removeLocalTrace(candidate.traceId);\n }\n \n results.success++;\n results.totalSize += candidate.size;\n \n } catch (error) {\n results.failed++;\n results.errors.push(\n `Failed to migrate ${candidate.traceId}: ${error}`\n );\n logger.error('Migration failed for trace', { \n traceId: candidate.traceId, \n error \n });\n }\n }\n \n return results;\n }\n \n /**\n * Get full trace data for migration\n */\n private getTraceData(traceId: string): any {\n const traceRow = this.localDb.prepare(\n 'SELECT * FROM traces WHERE id = ?'\n ).get(traceId);\n \n if (!traceRow) return null;\n \n const toolCalls = this.localDb.prepare(\n 'SELECT * FROM tool_calls WHERE trace_id = ? ORDER BY sequence_number'\n ).all(traceId);\n \n return {\n trace: traceRow,\n toolCalls,\n };\n }\n \n /**\n * Compress trace based on compression level\n */\n private compressTrace(\n data: any,\n level: 'none' | 'light' | 'medium' | 'heavy'\n ): Buffer {\n let jsonData = JSON.stringify(data);\n \n // Apply different compression based on level\n switch (level) {\n case 'none':\n return Buffer.from(jsonData);\n \n case 'light':\n // Remove formatting, keep all data\n return Buffer.from(JSON.stringify(JSON.parse(jsonData)));\n \n case 'medium':\n // Remove null fields and compress\n const cleaned = JSON.parse(jsonData, (key, value) => \n value === null || value === undefined ? undefined : value\n );\n return Buffer.from(JSON.stringify(cleaned));\n \n case 'heavy':\n // Remove tool results and arguments, keep only essential\n const minimal = {\n id: data.trace.id,\n type: data.trace.type,\n score: data.trace.score,\n summary: data.trace.summary,\n timestamps: {\n start: data.trace.start_time,\n end: data.trace.end_time,\n },\n toolCount: data.toolCalls.length,\n toolTypes: [...new Set(data.toolCalls.map((t: any) => t.tool))],\n };\n return Buffer.from(JSON.stringify(minimal));\n \n default:\n return Buffer.from(jsonData);\n }\n }\n \n /**\n * Generate S3 key for trace\n */\n private generateS3Key(candidate: MigrationCandidate): string {\n const date = new Date(Date.now() - candidate.age * 60 * 60 * 1000);\n const year = date.getFullYear();\n const month = String(date.getMonth() + 1).padStart(2, '0');\n const day = String(date.getDate()).padStart(2, '0');\n \n return `traces/${year}/${month}/${day}/${candidate.tier}/${candidate.traceId}.json`;\n }\n \n /**\n * Upload to S3\n */\n private async uploadToS3(key: string, data: Buffer): Promise<void> {\n if (!this.s3Client) {\n throw new Error('S3 client not configured');\n }\n \n const command = new PutObjectCommand({\n Bucket: this.config.s3.bucket,\n Key: key,\n Body: data,\n ContentType: 'application/json',\n Metadata: {\n 'trace-version': '1.0',\n 'compression': 'true',\n },\n });\n \n await this.s3Client.send(command);\n }\n \n /**\n * Record migration in local database\n */\n private recordMigration(\n candidate: MigrationCandidate,\n s3Key: string,\n originalData: any,\n compressedData: Buffer\n ): void {\n const stmt = this.localDb.prepare(`\n INSERT INTO remote_migrations (\n trace_id, migrated_at, storage_tier, s3_key,\n compression_level, original_size, compressed_size\n ) VALUES (?, ?, ?, ?, ?, ?, ?)\n `);\n \n stmt.run(\n candidate.traceId,\n Date.now(),\n candidate.tier,\n s3Key,\n candidate.compressionLevel,\n JSON.stringify(originalData).length,\n compressedData.length\n );\n }\n \n /**\n * Remove local trace after migration\n */\n private removeLocalTrace(traceId: string): void {\n this.localDb.prepare('DELETE FROM tool_calls WHERE trace_id = ?').run(traceId);\n this.localDb.prepare('DELETE FROM traces WHERE id = ?').run(traceId);\n }\n \n /**\n * Get current local storage size\n */\n private getLocalStorageSize(): number {\n const result = this.localDb.prepare(`\n SELECT \n SUM(LENGTH(compressed_data)) +\n COALESCE((SELECT SUM(LENGTH(arguments) + LENGTH(result)) \n FROM tool_calls), 0) as total_size\n FROM traces\n `).get() as any;\n \n return result?.total_size || 0;\n }\n \n /**\n * Create batches from candidates\n */\n private createBatches<T>(items: T[], batchSize: number): T[][] {\n const batches: T[][] = [];\n for (let i = 0; i < items.length; i += batchSize) {\n batches.push(items.slice(i, i + batchSize));\n }\n return batches;\n }\n \n /**\n * Retrieve trace from remote storage\n */\n async retrieveTrace(traceId: string): Promise<any> {\n const migration = this.localDb.prepare(`\n SELECT * FROM remote_migrations WHERE trace_id = ?\n `).get(traceId) as any;\n \n if (!migration) {\n throw new Error(`Trace ${traceId} not found in remote storage`);\n }\n \n // Update retrieval count\n this.localDb.prepare(`\n UPDATE remote_migrations \n SET retrieval_count = retrieval_count + 1, last_retrieved = ?\n WHERE trace_id = ?\n `).run(Date.now(), traceId);\n \n if (!this.s3Client) {\n throw new Error('S3 client not configured');\n }\n \n // Retrieve from S3\n const command = new GetObjectCommand({\n Bucket: this.config.s3.bucket,\n Key: migration.s3_key,\n });\n \n const response = await this.s3Client.send(command);\n const data = await response.Body?.transformToString();\n \n if (!data) {\n throw new Error('No data retrieved from S3');\n }\n \n return JSON.parse(data);\n }\n \n /**\n * Get migration statistics\n */\n getMigrationStats(): any {\n const stats = this.localDb.prepare(`\n SELECT \n storage_tier,\n COUNT(*) as count,\n SUM(original_size) as original_size,\n SUM(compressed_size) as compressed_size,\n AVG(retrieval_count) as avg_retrievals\n FROM remote_migrations\n GROUP BY storage_tier\n `).all();\n \n const total = this.localDb.prepare(`\n SELECT \n COUNT(*) as total_migrated,\n SUM(original_size) as total_original,\n SUM(compressed_size) as total_compressed\n FROM remote_migrations\n `).get();\n \n return {\n byTier: stats,\n total,\n compressionRatio: total \n ? (1 - (total as any).total_compressed / (total as any).total_original).toFixed(2)\n : 0,\n localSize: this.getLocalStorageSize(),\n };\n }\n}"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["StorageTier"]
|
|
7
|
+
}
|
|
@@ -2,7 +2,8 @@ import { v4 as uuidv4 } from "uuid";
|
|
|
2
2
|
import {
|
|
3
3
|
TraceType,
|
|
4
4
|
DEFAULT_TRACE_CONFIG,
|
|
5
|
-
TRACE_PATTERNS
|
|
5
|
+
TRACE_PATTERNS,
|
|
6
|
+
CompressionStrategy
|
|
6
7
|
} from "./types.js";
|
|
7
8
|
import { ConfigManager } from "../config/config-manager.js";
|
|
8
9
|
import { TraceStore } from "./trace-store.js";
|
|
@@ -280,9 +281,41 @@ class TraceDetector {
|
|
|
280
281
|
}
|
|
281
282
|
}
|
|
282
283
|
/**
|
|
283
|
-
* Compress a trace for long-term storage
|
|
284
|
+
* Compress a trace for long-term storage using strategy
|
|
284
285
|
*/
|
|
285
|
-
compressTrace(trace) {
|
|
286
|
+
compressTrace(trace, strategy = CompressionStrategy.PATTERN_BASED) {
|
|
287
|
+
switch (strategy) {
|
|
288
|
+
case CompressionStrategy.SUMMARY_ONLY:
|
|
289
|
+
return this.compressSummaryOnly(trace);
|
|
290
|
+
case CompressionStrategy.PATTERN_BASED:
|
|
291
|
+
return this.compressPatternBased(trace);
|
|
292
|
+
case CompressionStrategy.SELECTIVE:
|
|
293
|
+
return this.compressSelective(trace);
|
|
294
|
+
case CompressionStrategy.FULL_COMPRESSION:
|
|
295
|
+
return this.compressMaximal(trace);
|
|
296
|
+
default:
|
|
297
|
+
return this.compressPatternBased(trace);
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
/**
|
|
301
|
+
* Summary-only compression - minimal data retention
|
|
302
|
+
*/
|
|
303
|
+
compressSummaryOnly(trace) {
|
|
304
|
+
return {
|
|
305
|
+
pattern: "",
|
|
306
|
+
// No pattern stored
|
|
307
|
+
summary: trace.summary.substring(0, 100),
|
|
308
|
+
// Limit summary
|
|
309
|
+
score: trace.score,
|
|
310
|
+
toolCount: trace.tools.length,
|
|
311
|
+
duration: trace.metadata.endTime - trace.metadata.startTime,
|
|
312
|
+
timestamp: trace.metadata.startTime
|
|
313
|
+
};
|
|
314
|
+
}
|
|
315
|
+
/**
|
|
316
|
+
* Pattern-based compression - keep tool sequence
|
|
317
|
+
*/
|
|
318
|
+
compressPatternBased(trace) {
|
|
286
319
|
const pattern = trace.tools.map((t) => t.tool).join("\u2192");
|
|
287
320
|
const duration = trace.metadata.endTime - trace.metadata.startTime;
|
|
288
321
|
return {
|
|
@@ -294,6 +327,84 @@ class TraceDetector {
|
|
|
294
327
|
timestamp: trace.metadata.startTime
|
|
295
328
|
};
|
|
296
329
|
}
|
|
330
|
+
/**
|
|
331
|
+
* Selective compression - keep high-score tools only
|
|
332
|
+
*/
|
|
333
|
+
compressSelective(trace, threshold = 0.5) {
|
|
334
|
+
const significantTools = trace.tools.filter((tool) => {
|
|
335
|
+
const score = this.configManager.calculateScore(tool.tool, {
|
|
336
|
+
filesAffected: tool.filesAffected?.length || 0,
|
|
337
|
+
isPermanent: this.isPermanentChange(tool),
|
|
338
|
+
referenceCount: 0
|
|
339
|
+
});
|
|
340
|
+
return score >= threshold;
|
|
341
|
+
});
|
|
342
|
+
const pattern = significantTools.length > 0 ? significantTools.map((t) => t.tool).join("\u2192") : trace.tools.map((t) => t.tool).join("\u2192");
|
|
343
|
+
return {
|
|
344
|
+
pattern,
|
|
345
|
+
summary: `${trace.summary} [${significantTools.length}/${trace.tools.length} significant]`,
|
|
346
|
+
score: trace.score,
|
|
347
|
+
toolCount: significantTools.length,
|
|
348
|
+
duration: trace.metadata.endTime - trace.metadata.startTime,
|
|
349
|
+
timestamp: trace.metadata.startTime
|
|
350
|
+
};
|
|
351
|
+
}
|
|
352
|
+
/**
|
|
353
|
+
* Maximal compression - absolute minimum data
|
|
354
|
+
*/
|
|
355
|
+
compressMaximal(trace) {
|
|
356
|
+
const typeAbbrev = this.getTraceTypeAbbreviation(trace.type);
|
|
357
|
+
const pattern = `${typeAbbrev}:${trace.tools.length}`;
|
|
358
|
+
return {
|
|
359
|
+
pattern,
|
|
360
|
+
summary: trace.type,
|
|
361
|
+
// Just the type
|
|
362
|
+
score: Math.round(trace.score * 10) / 10,
|
|
363
|
+
// Round to 1 decimal
|
|
364
|
+
toolCount: trace.tools.length,
|
|
365
|
+
duration: Math.round((trace.metadata.endTime - trace.metadata.startTime) / 1e3) * 1e3,
|
|
366
|
+
// Round to seconds
|
|
367
|
+
timestamp: trace.metadata.startTime
|
|
368
|
+
};
|
|
369
|
+
}
|
|
370
|
+
/**
|
|
371
|
+
* Get abbreviated trace type
|
|
372
|
+
*/
|
|
373
|
+
getTraceTypeAbbreviation(type) {
|
|
374
|
+
const abbreviations = {
|
|
375
|
+
[TraceType.SEARCH_DRIVEN]: "SD",
|
|
376
|
+
[TraceType.ERROR_RECOVERY]: "ER",
|
|
377
|
+
[TraceType.FEATURE_IMPLEMENTATION]: "FI",
|
|
378
|
+
[TraceType.REFACTORING]: "RF",
|
|
379
|
+
[TraceType.TESTING]: "TS",
|
|
380
|
+
[TraceType.EXPLORATION]: "EX",
|
|
381
|
+
[TraceType.DEBUGGING]: "DB",
|
|
382
|
+
[TraceType.DOCUMENTATION]: "DC",
|
|
383
|
+
[TraceType.BUILD_DEPLOY]: "BD",
|
|
384
|
+
[TraceType.UNKNOWN]: "UN"
|
|
385
|
+
};
|
|
386
|
+
return abbreviations[type] || "UN";
|
|
387
|
+
}
|
|
388
|
+
/**
|
|
389
|
+
* Choose compression strategy based on trace age and importance
|
|
390
|
+
*/
|
|
391
|
+
selectCompressionStrategy(trace) {
|
|
392
|
+
const ageHours = (Date.now() - trace.metadata.startTime) / (1e3 * 60 * 60);
|
|
393
|
+
const score = trace.score;
|
|
394
|
+
if (ageHours < 24 && score > 0.7) {
|
|
395
|
+
return CompressionStrategy.PATTERN_BASED;
|
|
396
|
+
}
|
|
397
|
+
if (ageHours < 24) {
|
|
398
|
+
return CompressionStrategy.SELECTIVE;
|
|
399
|
+
}
|
|
400
|
+
if (ageHours < 168 && score > 0.5) {
|
|
401
|
+
return CompressionStrategy.SELECTIVE;
|
|
402
|
+
}
|
|
403
|
+
if (ageHours < 720) {
|
|
404
|
+
return CompressionStrategy.SUMMARY_ONLY;
|
|
405
|
+
}
|
|
406
|
+
return CompressionStrategy.FULL_COMPRESSION;
|
|
407
|
+
}
|
|
297
408
|
/**
|
|
298
409
|
* Get directory from file path
|
|
299
410
|
*/
|
|
@@ -329,7 +440,7 @@ class TraceDetector {
|
|
|
329
440
|
return this.traces.filter((t) => t.score >= threshold);
|
|
330
441
|
}
|
|
331
442
|
/**
|
|
332
|
-
* Compress old traces
|
|
443
|
+
* Compress old traces with intelligent strategy selection
|
|
333
444
|
*/
|
|
334
445
|
compressOldTraces(ageHours = 24) {
|
|
335
446
|
let compressed = 0;
|
|
@@ -337,8 +448,28 @@ class TraceDetector {
|
|
|
337
448
|
for (const trace of this.traces) {
|
|
338
449
|
const age = (now - trace.metadata.startTime) / (1e3 * 60 * 60);
|
|
339
450
|
if (age > ageHours && !trace.compressed) {
|
|
340
|
-
|
|
451
|
+
const strategy = this.selectCompressionStrategy(trace);
|
|
452
|
+
trace.compressed = this.compressTrace(trace, strategy);
|
|
453
|
+
if (strategy === CompressionStrategy.FULL_COMPRESSION || strategy === CompressionStrategy.SUMMARY_ONLY) {
|
|
454
|
+
trace.tools = [];
|
|
455
|
+
} else if (strategy === CompressionStrategy.SELECTIVE) {
|
|
456
|
+
trace.tools = trace.tools.filter((tool) => {
|
|
457
|
+
const score = this.configManager.calculateScore(tool.tool, {
|
|
458
|
+
filesAffected: tool.filesAffected?.length || 0,
|
|
459
|
+
isPermanent: this.isPermanentChange(tool),
|
|
460
|
+
referenceCount: 0
|
|
461
|
+
});
|
|
462
|
+
return score >= 0.5;
|
|
463
|
+
});
|
|
464
|
+
}
|
|
341
465
|
compressed++;
|
|
466
|
+
if (this.traceStore) {
|
|
467
|
+
try {
|
|
468
|
+
this.traceStore.updateCompression(trace.id, trace.compressed, strategy);
|
|
469
|
+
} catch (error) {
|
|
470
|
+
console.error("Failed to update trace compression in store:", error);
|
|
471
|
+
}
|
|
472
|
+
}
|
|
342
473
|
}
|
|
343
474
|
}
|
|
344
475
|
return compressed;
|