@stackmemoryai/stackmemory 0.2.8 → 0.3.0

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.
Files changed (608) hide show
  1. package/dist/agents/core/agent-task-manager.js +512 -0
  2. package/dist/agents/core/agent-task-manager.js.map +7 -0
  3. package/dist/agents/verifiers/base-verifier.js +129 -0
  4. package/dist/agents/verifiers/base-verifier.js.map +7 -0
  5. package/dist/agents/verifiers/formatter-verifier.js +126 -0
  6. package/dist/agents/verifiers/formatter-verifier.js.map +7 -0
  7. package/dist/agents/verifiers/llm-judge.js +248 -0
  8. package/dist/agents/verifiers/llm-judge.js.map +7 -0
  9. package/dist/cli/__tests__/index.test.js +290 -0
  10. package/dist/cli/__tests__/index.test.js.map +7 -0
  11. package/dist/cli/auto-detect.js +317 -0
  12. package/dist/cli/auto-detect.js.map +7 -0
  13. package/dist/cli/browser-test.js +29 -0
  14. package/dist/cli/browser-test.js.map +7 -0
  15. package/dist/cli/claude-sm.js +369 -0
  16. package/dist/cli/claude-sm.js.map +7 -0
  17. package/dist/cli/codex-sm.js +283 -0
  18. package/dist/cli/codex-sm.js.map +7 -0
  19. package/dist/cli/commands/agent.js +286 -0
  20. package/dist/cli/commands/agent.js.map +7 -0
  21. package/dist/cli/commands/config.js +199 -0
  22. package/dist/cli/commands/config.js.map +7 -0
  23. package/dist/cli/commands/context.js +327 -0
  24. package/dist/cli/commands/context.js.map +7 -0
  25. package/dist/cli/commands/handoff.js +191 -0
  26. package/dist/cli/commands/handoff.js.map +7 -0
  27. package/dist/cli/commands/linear-test.js +115 -0
  28. package/dist/cli/commands/linear-test.js.map +7 -0
  29. package/dist/cli/commands/linear.js +378 -0
  30. package/dist/cli/commands/linear.js.map +7 -0
  31. package/dist/cli/commands/log.js +165 -0
  32. package/dist/cli/commands/log.js.map +7 -0
  33. package/dist/cli/commands/onboard.js +349 -0
  34. package/dist/cli/commands/onboard.js.map +7 -0
  35. package/dist/cli/commands/projects.js +195 -0
  36. package/dist/cli/commands/projects.js.map +7 -0
  37. package/dist/cli/commands/search.js +152 -0
  38. package/dist/cli/commands/search.js.map +7 -0
  39. package/dist/cli/commands/session.js +179 -0
  40. package/dist/cli/commands/session.js.map +7 -0
  41. package/dist/cli/commands/tasks.js +205 -0
  42. package/dist/cli/commands/tasks.js.map +7 -0
  43. package/dist/cli/commands/webhook.js +131 -0
  44. package/dist/cli/commands/webhook.js.map +7 -0
  45. package/dist/cli/commands/worktree.js +276 -0
  46. package/dist/cli/commands/worktree.js.map +7 -0
  47. package/dist/cli/index.js +953 -0
  48. package/dist/cli/index.js.map +7 -0
  49. package/dist/cli/utils/viewer.js +92 -0
  50. package/dist/cli/utils/viewer.js.map +7 -0
  51. package/dist/core/config/__tests__/config-manager.test.js +248 -0
  52. package/dist/core/config/__tests__/config-manager.test.js.map +7 -0
  53. package/dist/core/config/config-manager.js +368 -0
  54. package/dist/core/config/config-manager.js.map +7 -0
  55. package/dist/core/config/types.js +140 -0
  56. package/dist/core/config/types.js.map +7 -0
  57. package/dist/core/context/__tests__/frame-manager.test.js +879 -0
  58. package/dist/core/context/__tests__/frame-manager.test.js.map +7 -0
  59. package/dist/core/context/auto-context.js +72 -0
  60. package/dist/core/context/auto-context.js.map +7 -0
  61. package/dist/core/context/compaction-handler.js +326 -0
  62. package/dist/core/context/compaction-handler.js.map +7 -0
  63. package/dist/core/context/frame-database.js +376 -0
  64. package/dist/core/context/frame-database.js.map +7 -0
  65. package/dist/core/context/frame-digest.js +239 -0
  66. package/dist/core/context/frame-digest.js.map +7 -0
  67. package/dist/core/context/frame-manager.js +682 -0
  68. package/dist/core/context/frame-manager.js.map +7 -0
  69. package/dist/core/context/frame-stack.js +270 -0
  70. package/dist/core/context/frame-stack.js.map +7 -0
  71. package/dist/core/context/frame-types.js +1 -0
  72. package/dist/core/context/frame-types.js.map +7 -0
  73. package/dist/core/context/index.js +33 -0
  74. package/dist/core/context/index.js.map +7 -0
  75. package/dist/core/context/model-aware-compaction.js +619 -0
  76. package/dist/core/context/model-aware-compaction.js.map +7 -0
  77. package/dist/core/context/refactored-frame-manager.js +393 -0
  78. package/dist/core/context/refactored-frame-manager.js.map +7 -0
  79. package/dist/core/database/batch-operations.js +329 -0
  80. package/dist/core/database/batch-operations.js.map +7 -0
  81. package/dist/core/database/connection-pool.js +224 -0
  82. package/dist/core/database/connection-pool.js.map +7 -0
  83. package/dist/core/database/query-cache.js +284 -0
  84. package/dist/core/database/query-cache.js.map +7 -0
  85. package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js +379 -0
  86. package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js.map +7 -0
  87. package/dist/core/digest/__tests__/frame-digest-integration.test.js +230 -0
  88. package/dist/core/digest/__tests__/frame-digest-integration.test.js.map +7 -0
  89. package/dist/core/digest/enhanced-hybrid-digest.js +267 -0
  90. package/dist/core/digest/enhanced-hybrid-digest.js.map +7 -0
  91. package/dist/core/digest/frame-digest-integration.js +172 -0
  92. package/dist/core/digest/frame-digest-integration.js.map +7 -0
  93. package/dist/core/digest/hybrid-digest-generator.js +549 -0
  94. package/dist/core/digest/hybrid-digest-generator.js.map +7 -0
  95. package/dist/core/digest/index.js +5 -0
  96. package/dist/core/digest/index.js.map +7 -0
  97. package/dist/core/digest/types.js +21 -0
  98. package/dist/core/digest/types.js.map +7 -0
  99. package/dist/core/errors/__tests__/error-handling.test.js +270 -0
  100. package/dist/core/errors/__tests__/error-handling.test.js.map +7 -0
  101. package/dist/core/errors/index.js +239 -0
  102. package/dist/core/errors/index.js.map +7 -0
  103. package/dist/core/errors/recovery.js +258 -0
  104. package/dist/core/errors/recovery.js.map +7 -0
  105. package/dist/core/merge/__tests__/conflict-scenarios.test.js +414 -0
  106. package/dist/core/merge/__tests__/conflict-scenarios.test.js.map +7 -0
  107. package/dist/core/merge/conflict-detector.js +424 -0
  108. package/dist/core/merge/conflict-detector.js.map +7 -0
  109. package/dist/core/merge/index.js +5 -0
  110. package/dist/core/merge/index.js.map +7 -0
  111. package/dist/core/merge/resolution-engine.js +565 -0
  112. package/dist/core/merge/resolution-engine.js.map +7 -0
  113. package/dist/core/merge/stack-diff.js +528 -0
  114. package/dist/core/merge/stack-diff.js.map +7 -0
  115. package/dist/core/merge/types.js +1 -0
  116. package/dist/core/merge/types.js.map +7 -0
  117. package/dist/core/monitoring/error-handler.js +278 -0
  118. package/dist/core/monitoring/error-handler.js.map +7 -0
  119. package/dist/core/monitoring/logger.js +115 -0
  120. package/dist/core/monitoring/logger.js.map +7 -0
  121. package/dist/core/monitoring/metrics.js +157 -0
  122. package/dist/core/monitoring/metrics.js.map +7 -0
  123. package/dist/core/monitoring/progress-tracker.js +174 -0
  124. package/dist/core/monitoring/progress-tracker.js.map +7 -0
  125. package/dist/core/performance/context-cache.js +269 -0
  126. package/dist/core/performance/context-cache.js.map +7 -0
  127. package/dist/core/performance/index.js +7 -0
  128. package/dist/core/performance/index.js.map +7 -0
  129. package/dist/core/performance/lazy-context-loader.js +319 -0
  130. package/dist/core/performance/lazy-context-loader.js.map +7 -0
  131. package/dist/core/performance/monitor.js +217 -0
  132. package/dist/core/performance/monitor.js.map +7 -0
  133. package/dist/core/performance/optimized-frame-context.js +326 -0
  134. package/dist/core/performance/optimized-frame-context.js.map +7 -0
  135. package/dist/core/performance/performance-benchmark.js +269 -0
  136. package/dist/core/performance/performance-benchmark.js.map +7 -0
  137. package/dist/core/performance/performance-profiler.js +318 -0
  138. package/dist/core/performance/performance-profiler.js.map +7 -0
  139. package/dist/core/performance/streaming-jsonl-parser.js +187 -0
  140. package/dist/core/performance/streaming-jsonl-parser.js.map +7 -0
  141. package/dist/core/persistence/postgres-adapter.js +345 -0
  142. package/dist/core/persistence/postgres-adapter.js.map +7 -0
  143. package/dist/core/projects/project-manager.js +699 -0
  144. package/dist/core/projects/project-manager.js.map +7 -0
  145. package/dist/core/query/__tests__/query-parser.test.js +301 -0
  146. package/dist/core/query/__tests__/query-parser.test.js.map +7 -0
  147. package/dist/core/query/__tests__/query-templates.test.js +210 -0
  148. package/dist/core/query/__tests__/query-templates.test.js.map +7 -0
  149. package/dist/core/query/query-parser.js +366 -0
  150. package/dist/core/query/query-parser.js.map +7 -0
  151. package/dist/core/query/query-templates.js +317 -0
  152. package/dist/core/query/query-templates.js.map +7 -0
  153. package/dist/core/retrieval/index.js +4 -0
  154. package/dist/core/retrieval/index.js.map +7 -0
  155. package/dist/core/retrieval/llm-context-retrieval.js +577 -0
  156. package/dist/core/retrieval/llm-context-retrieval.js.map +7 -0
  157. package/dist/core/retrieval/summary-generator.js +585 -0
  158. package/dist/core/retrieval/summary-generator.js.map +7 -0
  159. package/dist/core/retrieval/types.js +17 -0
  160. package/dist/core/retrieval/types.js.map +7 -0
  161. package/dist/core/session/index.js +11 -0
  162. package/dist/core/session/index.js.map +7 -0
  163. package/dist/core/session/session-manager.js +297 -0
  164. package/dist/core/session/session-manager.js.map +7 -0
  165. package/dist/core/trace/cli-trace-wrapper.js +110 -0
  166. package/dist/core/trace/cli-trace-wrapper.js.map +7 -0
  167. package/dist/core/trace/db-trace-wrapper.js +215 -0
  168. package/dist/core/trace/db-trace-wrapper.js.map +7 -0
  169. package/dist/core/trace/debug-trace.js +385 -0
  170. package/dist/core/trace/debug-trace.js.map +7 -0
  171. package/dist/core/trace/index.js +158 -0
  172. package/dist/core/trace/index.js.map +7 -0
  173. package/dist/core/trace/linear-api-wrapper.js +169 -0
  174. package/dist/core/trace/linear-api-wrapper.js.map +7 -0
  175. package/dist/core/trace/trace-demo.js +135 -0
  176. package/dist/core/trace/trace-demo.js.map +7 -0
  177. package/dist/core/trace/trace-detector.demo.js +138 -0
  178. package/dist/core/trace/trace-detector.demo.js.map +7 -0
  179. package/dist/core/trace/trace-detector.js +386 -0
  180. package/dist/core/trace/trace-detector.js.map +7 -0
  181. package/dist/core/trace/trace-detector.test.js +401 -0
  182. package/dist/core/trace/trace-detector.test.js.map +7 -0
  183. package/dist/core/trace/trace-store.js +341 -0
  184. package/dist/core/trace/trace-store.js.map +7 -0
  185. package/dist/core/trace/types.js +73 -0
  186. package/dist/core/trace/types.js.map +7 -0
  187. package/dist/core/types.js +1 -0
  188. package/dist/core/types.js.map +7 -0
  189. package/dist/core/utils/update-checker.js +214 -0
  190. package/dist/core/utils/update-checker.js.map +7 -0
  191. package/dist/core/worktree/worktree-manager.js +450 -0
  192. package/dist/core/worktree/worktree-manager.js.map +7 -0
  193. package/dist/features/analytics/api/analytics-api.js +283 -0
  194. package/dist/features/analytics/api/analytics-api.js.map +7 -0
  195. package/dist/features/analytics/core/analytics-service.js +267 -0
  196. package/dist/features/analytics/core/analytics-service.js.map +7 -0
  197. package/dist/features/analytics/index.js +14 -0
  198. package/dist/features/analytics/index.js.map +7 -0
  199. package/dist/features/analytics/queries/metrics-queries.js +273 -0
  200. package/dist/features/analytics/queries/metrics-queries.js.map +7 -0
  201. package/dist/features/analytics/types/metrics.js +1 -0
  202. package/dist/features/analytics/types/metrics.js.map +7 -0
  203. package/dist/features/browser/browser-mcp.js +488 -0
  204. package/dist/features/browser/browser-mcp.js.map +7 -0
  205. package/dist/features/tasks/__tests__/pebbles-task-store.test.js +747 -0
  206. package/dist/features/tasks/__tests__/pebbles-task-store.test.js.map +7 -0
  207. package/dist/features/tasks/pebbles-task-store.js +647 -0
  208. package/dist/features/tasks/pebbles-task-store.js.map +7 -0
  209. package/dist/features/tasks/task-aware-context.js +406 -0
  210. package/dist/features/tasks/task-aware-context.js.map +7 -0
  211. package/dist/index.js +21 -0
  212. package/dist/index.js.map +7 -0
  213. package/dist/integrations/linear/__tests__/auth.test.js +558 -0
  214. package/dist/integrations/linear/__tests__/auth.test.js.map +7 -0
  215. package/dist/integrations/linear/__tests__/sync-service.test.js +760 -0
  216. package/dist/integrations/linear/__tests__/sync-service.test.js.map +7 -0
  217. package/dist/integrations/linear/auth.js +308 -0
  218. package/dist/integrations/linear/auth.js.map +7 -0
  219. package/dist/integrations/linear/auto-sync.js +244 -0
  220. package/dist/integrations/linear/auto-sync.js.map +7 -0
  221. package/dist/integrations/linear/client.js +448 -0
  222. package/dist/integrations/linear/client.js.map +7 -0
  223. package/dist/integrations/linear/config.js +115 -0
  224. package/dist/integrations/linear/config.js.map +7 -0
  225. package/dist/integrations/linear/sync-manager.js +233 -0
  226. package/dist/integrations/linear/sync-manager.js.map +7 -0
  227. package/dist/integrations/linear/sync-service.js +214 -0
  228. package/dist/integrations/linear/sync-service.js.map +7 -0
  229. package/dist/integrations/linear/sync.js +565 -0
  230. package/dist/integrations/linear/sync.js.map +7 -0
  231. package/dist/integrations/linear/types.js +1 -0
  232. package/dist/integrations/linear/types.js.map +7 -0
  233. package/dist/integrations/linear/webhook-server.js +204 -0
  234. package/dist/integrations/linear/webhook-server.js.map +7 -0
  235. package/dist/integrations/linear/webhook.js +269 -0
  236. package/dist/integrations/linear/webhook.js.map +7 -0
  237. package/dist/integrations/mcp/__tests__/server.test.js +798 -0
  238. package/dist/integrations/mcp/__tests__/server.test.js.map +7 -0
  239. package/dist/integrations/mcp/handlers/context-handlers.js +253 -0
  240. package/dist/integrations/mcp/handlers/context-handlers.js.map +7 -0
  241. package/dist/integrations/mcp/handlers/index.js +134 -0
  242. package/dist/integrations/mcp/handlers/index.js.map +7 -0
  243. package/dist/integrations/mcp/handlers/linear-handlers.js +243 -0
  244. package/dist/integrations/mcp/handlers/linear-handlers.js.map +7 -0
  245. package/dist/integrations/mcp/handlers/task-handlers.js +235 -0
  246. package/dist/integrations/mcp/handlers/task-handlers.js.map +7 -0
  247. package/dist/integrations/mcp/handlers/trace-handlers.js +304 -0
  248. package/dist/integrations/mcp/handlers/trace-handlers.js.map +7 -0
  249. package/dist/integrations/mcp/index.js +19 -0
  250. package/dist/integrations/mcp/index.js.map +7 -0
  251. package/dist/integrations/mcp/refactored-server.js +331 -0
  252. package/dist/integrations/mcp/refactored-server.js.map +7 -0
  253. package/dist/integrations/mcp/server.js +1621 -0
  254. package/dist/integrations/mcp/server.js.map +7 -0
  255. package/dist/integrations/mcp/tool-definitions.js +562 -0
  256. package/dist/integrations/mcp/tool-definitions.js.map +7 -0
  257. package/dist/integrations/mcp/trace-test.js +44 -0
  258. package/dist/integrations/mcp/trace-test.js.map +7 -0
  259. package/dist/integrations/pg-aiguide/embedding-provider.js +174 -0
  260. package/dist/integrations/pg-aiguide/embedding-provider.js.map +7 -0
  261. package/dist/integrations/pg-aiguide/semantic-search.js +183 -0
  262. package/dist/integrations/pg-aiguide/semantic-search.js.map +7 -0
  263. package/dist/integrations/pg-aiguide/timescale-analytics.js +220 -0
  264. package/dist/integrations/pg-aiguide/timescale-analytics.js.map +7 -0
  265. package/dist/mcp/stackmemory-mcp-server.js +550 -0
  266. package/dist/mcp/stackmemory-mcp-server.js.map +7 -0
  267. package/dist/middleware/exponential-rate-limiter.js +285 -0
  268. package/dist/middleware/exponential-rate-limiter.js.map +7 -0
  269. package/dist/models/user.model.js +351 -0
  270. package/dist/models/user.model.js.map +7 -0
  271. package/dist/scripts/benchmark-performance.d.ts +7 -0
  272. package/dist/scripts/benchmark-performance.d.ts.map +1 -0
  273. package/dist/scripts/benchmark-performance.js +44 -0
  274. package/dist/scripts/benchmark-performance.js.map +1 -0
  275. package/dist/scripts/cleanup-duplicate-tasks.d.ts +12 -0
  276. package/dist/scripts/cleanup-duplicate-tasks.d.ts.map +1 -0
  277. package/dist/scripts/cleanup-duplicate-tasks.js +215 -0
  278. package/dist/scripts/cleanup-duplicate-tasks.js.map +1 -0
  279. package/dist/servers/production/auth-middleware.js +513 -0
  280. package/dist/servers/production/auth-middleware.js.map +7 -0
  281. package/dist/servers/railway/index.js +390 -0
  282. package/dist/servers/railway/index.js.map +7 -0
  283. package/dist/services/config-service.js +62 -0
  284. package/dist/services/config-service.js.map +7 -0
  285. package/dist/services/context-service.js +191 -0
  286. package/dist/services/context-service.js.map +7 -0
  287. package/dist/src/agents/core/agent-task-manager.d.ts +154 -0
  288. package/dist/src/agents/core/agent-task-manager.d.ts.map +1 -0
  289. package/dist/src/agents/core/agent-task-manager.js +504 -0
  290. package/dist/src/agents/core/agent-task-manager.js.map +1 -0
  291. package/dist/src/agents/verifiers/base-verifier.d.ts +112 -0
  292. package/dist/src/agents/verifiers/base-verifier.d.ts.map +1 -0
  293. package/dist/src/agents/verifiers/base-verifier.js +130 -0
  294. package/dist/src/agents/verifiers/base-verifier.js.map +1 -0
  295. package/dist/src/agents/verifiers/formatter-verifier.d.ts +14 -0
  296. package/dist/src/agents/verifiers/formatter-verifier.d.ts.map +1 -0
  297. package/dist/src/agents/verifiers/formatter-verifier.js +107 -0
  298. package/dist/src/agents/verifiers/formatter-verifier.js.map +1 -0
  299. package/dist/src/agents/verifiers/llm-judge.d.ts +46 -0
  300. package/dist/src/agents/verifiers/llm-judge.d.ts.map +1 -0
  301. package/dist/src/agents/verifiers/llm-judge.js +248 -0
  302. package/dist/src/agents/verifiers/llm-judge.js.map +1 -0
  303. package/dist/src/cli/claude-sm.js +55 -0
  304. package/dist/src/cli/claude-sm.js.map +1 -1
  305. package/dist/src/cli/commands/agent.d.ts +9 -0
  306. package/dist/src/cli/commands/agent.d.ts.map +1 -0
  307. package/dist/src/cli/commands/agent.js +303 -0
  308. package/dist/src/cli/commands/agent.js.map +1 -0
  309. package/dist/src/cli/commands/handoff.d.ts +6 -0
  310. package/dist/src/cli/commands/handoff.d.ts.map +1 -0
  311. package/dist/src/cli/commands/handoff.js +212 -0
  312. package/dist/src/cli/commands/handoff.js.map +1 -0
  313. package/dist/src/cli/index.d.ts.map +1 -1
  314. package/dist/src/cli/index.js +4 -0
  315. package/dist/src/cli/index.js.map +1 -1
  316. package/dist/src/core/context/compaction-handler.d.ts.map +1 -1
  317. package/dist/src/core/context/compaction-handler.js +1 -1
  318. package/dist/src/core/context/compaction-handler.js.map +1 -1
  319. package/dist/src/core/context/frame-database.d.ts +59 -0
  320. package/dist/src/core/context/frame-database.d.ts.map +1 -0
  321. package/dist/src/core/context/frame-database.js +333 -0
  322. package/dist/src/core/context/frame-database.js.map +1 -0
  323. package/dist/src/core/context/frame-digest.d.ts +59 -0
  324. package/dist/src/core/context/frame-digest.d.ts.map +1 -0
  325. package/dist/src/core/context/frame-digest.js +264 -0
  326. package/dist/src/core/context/frame-digest.js.map +1 -0
  327. package/dist/src/core/context/frame-manager.d.ts +2 -0
  328. package/dist/src/core/context/frame-manager.d.ts.map +1 -1
  329. package/dist/src/core/context/frame-manager.js +7 -0
  330. package/dist/src/core/context/frame-manager.js.map +1 -1
  331. package/dist/src/core/context/frame-stack.d.ts +85 -0
  332. package/dist/src/core/context/frame-stack.d.ts.map +1 -0
  333. package/dist/src/core/context/frame-stack.js +287 -0
  334. package/dist/src/core/context/frame-stack.js.map +1 -0
  335. package/dist/src/core/context/frame-types.d.ts +67 -0
  336. package/dist/src/core/context/frame-types.d.ts.map +1 -0
  337. package/dist/src/core/context/frame-types.js +6 -0
  338. package/dist/src/core/context/frame-types.js.map +1 -0
  339. package/dist/src/core/context/index.d.ts +11 -0
  340. package/dist/src/core/context/index.d.ts.map +1 -0
  341. package/dist/src/core/context/index.js +14 -0
  342. package/dist/src/core/context/index.js.map +1 -0
  343. package/dist/src/core/context/refactored-frame-manager.d.ts +99 -0
  344. package/dist/src/core/context/refactored-frame-manager.d.ts.map +1 -0
  345. package/dist/src/core/context/refactored-frame-manager.js +340 -0
  346. package/dist/src/core/context/refactored-frame-manager.js.map +1 -0
  347. package/dist/src/core/database/batch-operations.d.ts +118 -0
  348. package/dist/src/core/database/batch-operations.d.ts.map +1 -0
  349. package/dist/src/core/database/batch-operations.js +339 -0
  350. package/dist/src/core/database/batch-operations.js.map +1 -0
  351. package/dist/src/core/database/connection-pool.d.ts +79 -0
  352. package/dist/src/core/database/connection-pool.d.ts.map +1 -0
  353. package/dist/src/core/database/connection-pool.js +236 -0
  354. package/dist/src/core/database/connection-pool.js.map +1 -0
  355. package/dist/src/core/database/query-cache.d.ts +135 -0
  356. package/dist/src/core/database/query-cache.d.ts.map +1 -0
  357. package/dist/src/core/database/query-cache.js +294 -0
  358. package/dist/src/core/database/query-cache.js.map +1 -0
  359. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts +125 -0
  360. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts.map +1 -0
  361. package/dist/src/core/digest/enhanced-hybrid-digest.js +282 -0
  362. package/dist/src/core/digest/enhanced-hybrid-digest.js.map +1 -0
  363. package/dist/src/core/digest/frame-digest-integration.d.ts +67 -0
  364. package/dist/src/core/digest/frame-digest-integration.d.ts.map +1 -0
  365. package/dist/src/core/digest/frame-digest-integration.js +198 -0
  366. package/dist/src/core/digest/frame-digest-integration.js.map +1 -0
  367. package/dist/src/core/digest/hybrid-digest-generator.d.ts +76 -0
  368. package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +1 -0
  369. package/dist/src/core/digest/hybrid-digest-generator.js +629 -0
  370. package/dist/src/core/digest/hybrid-digest-generator.js.map +1 -0
  371. package/dist/src/core/digest/index.d.ts +9 -0
  372. package/dist/src/core/digest/index.d.ts.map +1 -0
  373. package/dist/src/core/digest/index.js +9 -0
  374. package/dist/src/core/digest/index.js.map +1 -0
  375. package/dist/src/core/digest/types.d.ts +154 -0
  376. package/dist/src/core/digest/types.d.ts.map +1 -0
  377. package/dist/src/core/digest/types.js +18 -0
  378. package/dist/src/core/digest/types.js.map +1 -0
  379. package/dist/src/core/errors/index.d.ts +13 -5
  380. package/dist/src/core/errors/index.d.ts.map +1 -1
  381. package/dist/src/core/errors/index.js +13 -5
  382. package/dist/src/core/errors/index.js.map +1 -1
  383. package/dist/src/core/merge/conflict-detector.d.ts +122 -0
  384. package/dist/src/core/merge/conflict-detector.d.ts.map +1 -0
  385. package/dist/src/core/merge/conflict-detector.js +468 -0
  386. package/dist/src/core/merge/conflict-detector.js.map +1 -0
  387. package/dist/src/core/merge/index.d.ts +9 -0
  388. package/dist/src/core/merge/index.d.ts.map +1 -0
  389. package/dist/src/core/merge/index.js +9 -0
  390. package/dist/src/core/merge/index.js.map +1 -0
  391. package/dist/src/core/merge/resolution-engine.d.ts +120 -0
  392. package/dist/src/core/merge/resolution-engine.d.ts.map +1 -0
  393. package/dist/src/core/merge/resolution-engine.js +573 -0
  394. package/dist/src/core/merge/resolution-engine.js.map +1 -0
  395. package/dist/src/core/merge/stack-diff.d.ts +97 -0
  396. package/dist/src/core/merge/stack-diff.d.ts.map +1 -0
  397. package/dist/src/core/merge/stack-diff.js +516 -0
  398. package/dist/src/core/merge/stack-diff.js.map +1 -0
  399. package/dist/src/core/merge/types.d.ts +110 -0
  400. package/dist/src/core/merge/types.d.ts.map +1 -0
  401. package/dist/src/core/merge/types.js +6 -0
  402. package/dist/src/core/merge/types.js.map +1 -0
  403. package/dist/src/core/monitoring/logger.d.ts +2 -2
  404. package/dist/src/core/monitoring/logger.d.ts.map +1 -1
  405. package/dist/src/core/monitoring/logger.js +10 -5
  406. package/dist/src/core/monitoring/logger.js.map +1 -1
  407. package/dist/src/core/monitoring/metrics.d.ts +3 -0
  408. package/dist/src/core/monitoring/metrics.d.ts.map +1 -1
  409. package/dist/src/core/monitoring/metrics.js +142 -3
  410. package/dist/src/core/monitoring/metrics.js.map +1 -1
  411. package/dist/src/core/performance/context-cache.d.ts +109 -0
  412. package/dist/src/core/performance/context-cache.d.ts.map +1 -0
  413. package/dist/src/core/performance/context-cache.js +280 -0
  414. package/dist/src/core/performance/context-cache.js.map +1 -0
  415. package/dist/src/core/performance/index.d.ts +3 -0
  416. package/dist/src/core/performance/index.d.ts.map +1 -0
  417. package/dist/src/core/performance/index.js +3 -0
  418. package/dist/src/core/performance/index.js.map +1 -0
  419. package/dist/src/core/performance/lazy-context-loader.d.ts +93 -0
  420. package/dist/src/core/performance/lazy-context-loader.d.ts.map +1 -0
  421. package/dist/src/core/performance/lazy-context-loader.js +332 -0
  422. package/dist/src/core/performance/lazy-context-loader.js.map +1 -0
  423. package/dist/src/core/performance/monitor.d.ts +48 -0
  424. package/dist/src/core/performance/monitor.d.ts.map +1 -0
  425. package/dist/src/core/performance/monitor.js +226 -0
  426. package/dist/src/core/performance/monitor.js.map +1 -0
  427. package/dist/src/core/performance/optimized-frame-context.d.ts +74 -0
  428. package/dist/src/core/performance/optimized-frame-context.d.ts.map +1 -0
  429. package/dist/src/core/performance/optimized-frame-context.js +330 -0
  430. package/dist/src/core/performance/optimized-frame-context.js.map +1 -0
  431. package/dist/src/core/performance/performance-benchmark.d.ts +50 -0
  432. package/dist/src/core/performance/performance-benchmark.d.ts.map +1 -0
  433. package/dist/src/core/performance/performance-benchmark.js +290 -0
  434. package/dist/src/core/performance/performance-benchmark.js.map +1 -0
  435. package/dist/src/core/performance/performance-profiler.d.ts +151 -0
  436. package/dist/src/core/performance/performance-profiler.d.ts.map +1 -0
  437. package/dist/src/core/performance/performance-profiler.js +346 -0
  438. package/dist/src/core/performance/performance-profiler.js.map +1 -0
  439. package/dist/src/core/performance/streaming-jsonl-parser.d.ts +41 -0
  440. package/dist/src/core/performance/streaming-jsonl-parser.d.ts.map +1 -0
  441. package/dist/src/core/performance/streaming-jsonl-parser.js +193 -0
  442. package/dist/src/core/performance/streaming-jsonl-parser.js.map +1 -0
  443. package/dist/src/core/persistence/postgres-adapter.d.ts +31 -0
  444. package/dist/src/core/persistence/postgres-adapter.d.ts.map +1 -0
  445. package/dist/src/core/persistence/postgres-adapter.js +330 -0
  446. package/dist/src/core/persistence/postgres-adapter.js.map +1 -0
  447. package/dist/src/core/query/query-parser.d.ts +5 -0
  448. package/dist/src/core/query/query-parser.d.ts.map +1 -1
  449. package/dist/src/core/query/query-parser.js +86 -18
  450. package/dist/src/core/query/query-parser.js.map +1 -1
  451. package/dist/src/core/query/query-templates.d.ts +44 -0
  452. package/dist/src/core/query/query-templates.d.ts.map +1 -0
  453. package/dist/src/core/query/query-templates.js +326 -0
  454. package/dist/src/core/query/query-templates.js.map +1 -0
  455. package/dist/src/core/retrieval/llm-context-retrieval.d.ts +5 -3
  456. package/dist/src/core/retrieval/llm-context-retrieval.d.ts.map +1 -1
  457. package/dist/src/core/retrieval/llm-context-retrieval.js +73 -21
  458. package/dist/src/core/retrieval/llm-context-retrieval.js.map +1 -1
  459. package/dist/src/core/trace/cli-trace-wrapper.d.ts +23 -0
  460. package/dist/src/core/trace/cli-trace-wrapper.d.ts.map +1 -0
  461. package/dist/src/core/trace/cli-trace-wrapper.js +141 -0
  462. package/dist/src/core/trace/cli-trace-wrapper.js.map +1 -0
  463. package/dist/src/core/trace/db-trace-wrapper.d.ts +36 -0
  464. package/dist/src/core/trace/db-trace-wrapper.d.ts.map +1 -0
  465. package/dist/src/core/trace/db-trace-wrapper.js +252 -0
  466. package/dist/src/core/trace/db-trace-wrapper.js.map +1 -0
  467. package/dist/src/core/trace/debug-trace.d.ts +84 -0
  468. package/dist/src/core/trace/debug-trace.d.ts.map +1 -0
  469. package/dist/src/core/trace/debug-trace.js +402 -0
  470. package/dist/src/core/trace/debug-trace.js.map +1 -0
  471. package/dist/src/core/trace/error-test.d.ts +6 -0
  472. package/dist/src/core/trace/error-test.d.ts.map +1 -0
  473. package/dist/src/core/trace/error-test.js +128 -0
  474. package/dist/src/core/trace/error-test.js.map +1 -0
  475. package/dist/src/core/trace/index.d.ts +25 -0
  476. package/dist/src/core/trace/index.d.ts.map +1 -0
  477. package/dist/src/core/trace/index.js +121 -0
  478. package/dist/src/core/trace/index.js.map +1 -0
  479. package/dist/src/core/trace/linear-api-wrapper.d.ts +17 -0
  480. package/dist/src/core/trace/linear-api-wrapper.d.ts.map +1 -0
  481. package/dist/src/core/trace/linear-api-wrapper.js +205 -0
  482. package/dist/src/core/trace/linear-api-wrapper.js.map +1 -0
  483. package/dist/src/core/trace/performance-test.d.ts +6 -0
  484. package/dist/src/core/trace/performance-test.d.ts.map +1 -0
  485. package/dist/src/core/trace/performance-test.js +111 -0
  486. package/dist/src/core/trace/performance-test.js.map +1 -0
  487. package/dist/src/core/trace/trace-demo.d.ts +8 -0
  488. package/dist/src/core/trace/trace-demo.d.ts.map +1 -0
  489. package/dist/src/core/trace/trace-demo.js +154 -0
  490. package/dist/src/core/trace/trace-demo.js.map +1 -0
  491. package/dist/src/core/trace/trace-detector.d.ts +2 -2
  492. package/dist/src/core/trace/trace-detector.d.ts.map +1 -1
  493. package/dist/src/core/trace/trace-detector.demo.js +6 -6
  494. package/dist/src/core/trace/trace-detector.demo.js.map +1 -1
  495. package/dist/src/core/trace/trace-detector.js +3 -3
  496. package/dist/src/core/trace/trace-detector.js.map +1 -1
  497. package/dist/src/core/types.d.ts +35 -0
  498. package/dist/src/core/types.d.ts.map +1 -0
  499. package/dist/src/core/types.js +2 -0
  500. package/dist/src/core/types.js.map +1 -0
  501. package/dist/src/features/tasks/pebbles-task-store.d.ts +9 -2
  502. package/dist/src/features/tasks/pebbles-task-store.d.ts.map +1 -1
  503. package/dist/src/features/tasks/pebbles-task-store.js +97 -18
  504. package/dist/src/features/tasks/pebbles-task-store.js.map +1 -1
  505. package/dist/src/integrations/linear/auth.d.ts.map +1 -1
  506. package/dist/src/integrations/linear/auth.js.map +1 -1
  507. package/dist/src/integrations/linear/client.d.ts +15 -1
  508. package/dist/src/integrations/linear/client.d.ts.map +1 -1
  509. package/dist/src/integrations/linear/client.js +85 -3
  510. package/dist/src/integrations/linear/client.js.map +1 -1
  511. package/dist/src/integrations/linear/sync-manager.d.ts +2 -0
  512. package/dist/src/integrations/linear/sync-manager.d.ts.map +1 -1
  513. package/dist/src/integrations/linear/sync-manager.js +16 -4
  514. package/dist/src/integrations/linear/sync-manager.js.map +1 -1
  515. package/dist/src/integrations/linear/sync-service.d.ts +23 -2
  516. package/dist/src/integrations/linear/sync-service.d.ts.map +1 -1
  517. package/dist/src/integrations/linear/sync-service.js +44 -25
  518. package/dist/src/integrations/linear/sync-service.js.map +1 -1
  519. package/dist/src/integrations/linear/sync.d.ts +6 -0
  520. package/dist/src/integrations/linear/sync.d.ts.map +1 -1
  521. package/dist/src/integrations/linear/sync.js +27 -2
  522. package/dist/src/integrations/linear/sync.js.map +1 -1
  523. package/dist/src/integrations/linear/types.d.ts +16 -1
  524. package/dist/src/integrations/linear/types.d.ts.map +1 -1
  525. package/dist/src/integrations/linear/webhook-server.d.ts.map +1 -1
  526. package/dist/src/integrations/linear/webhook-server.js +10 -8
  527. package/dist/src/integrations/linear/webhook-server.js.map +1 -1
  528. package/dist/src/integrations/linear/webhook.d.ts +13 -0
  529. package/dist/src/integrations/linear/webhook.d.ts.map +1 -1
  530. package/dist/src/integrations/linear/webhook.js +101 -14
  531. package/dist/src/integrations/linear/webhook.js.map +1 -1
  532. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts +39 -0
  533. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts.map +1 -0
  534. package/dist/src/integrations/mcp/handlers/context-handlers.js +266 -0
  535. package/dist/src/integrations/mcp/handlers/context-handlers.js.map +1 -0
  536. package/dist/src/integrations/mcp/handlers/index.d.ts +37 -0
  537. package/dist/src/integrations/mcp/handlers/index.d.ts.map +1 -0
  538. package/dist/src/integrations/mcp/handlers/index.js +134 -0
  539. package/dist/src/integrations/mcp/handlers/index.js.map +1 -0
  540. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts +33 -0
  541. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts.map +1 -0
  542. package/dist/src/integrations/mcp/handlers/linear-handlers.js +251 -0
  543. package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +1 -0
  544. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts +42 -0
  545. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts.map +1 -0
  546. package/dist/src/integrations/mcp/handlers/task-handlers.js +238 -0
  547. package/dist/src/integrations/mcp/handlers/task-handlers.js.map +1 -0
  548. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts +41 -0
  549. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts.map +1 -0
  550. package/dist/src/integrations/mcp/handlers/trace-handlers.js +298 -0
  551. package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +1 -0
  552. package/dist/src/integrations/mcp/index.d.ts +13 -0
  553. package/dist/src/integrations/mcp/index.d.ts.map +1 -0
  554. package/dist/src/integrations/mcp/index.js +17 -0
  555. package/dist/src/integrations/mcp/index.js.map +1 -0
  556. package/dist/src/integrations/mcp/refactored-server.d.ts +76 -0
  557. package/dist/src/integrations/mcp/refactored-server.d.ts.map +1 -0
  558. package/dist/src/integrations/mcp/refactored-server.js +351 -0
  559. package/dist/src/integrations/mcp/refactored-server.js.map +1 -0
  560. package/dist/src/integrations/mcp/server.js +2 -2
  561. package/dist/src/integrations/mcp/server.js.map +1 -1
  562. package/dist/src/integrations/mcp/tool-definitions.d.ts +44 -0
  563. package/dist/src/integrations/mcp/tool-definitions.d.ts.map +1 -0
  564. package/dist/src/integrations/mcp/tool-definitions.js +563 -0
  565. package/dist/src/integrations/mcp/tool-definitions.js.map +1 -0
  566. package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts +48 -0
  567. package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts.map +1 -0
  568. package/dist/src/integrations/pg-aiguide/embedding-provider.js +190 -0
  569. package/dist/src/integrations/pg-aiguide/embedding-provider.js.map +1 -0
  570. package/dist/src/integrations/pg-aiguide/semantic-search.d.ts +34 -0
  571. package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +1 -0
  572. package/dist/src/integrations/pg-aiguide/semantic-search.js +176 -0
  573. package/dist/src/integrations/pg-aiguide/semantic-search.js.map +1 -0
  574. package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts +44 -0
  575. package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts.map +1 -0
  576. package/dist/src/integrations/pg-aiguide/timescale-analytics.js +215 -0
  577. package/dist/src/integrations/pg-aiguide/timescale-analytics.js.map +1 -0
  578. package/dist/src/mcp/stackmemory-mcp-server.d.ts +9 -0
  579. package/dist/src/mcp/stackmemory-mcp-server.d.ts.map +1 -0
  580. package/dist/src/mcp/stackmemory-mcp-server.js +519 -0
  581. package/dist/src/mcp/stackmemory-mcp-server.js.map +1 -0
  582. package/dist/src/middleware/exponential-rate-limiter.d.ts +78 -0
  583. package/dist/src/middleware/exponential-rate-limiter.d.ts.map +1 -0
  584. package/dist/src/middleware/exponential-rate-limiter.js +293 -0
  585. package/dist/src/middleware/exponential-rate-limiter.js.map +1 -0
  586. package/dist/src/models/user.model.d.ts +62 -0
  587. package/dist/src/models/user.model.d.ts.map +1 -0
  588. package/dist/src/models/user.model.js +311 -0
  589. package/dist/src/models/user.model.js.map +1 -0
  590. package/dist/src/servers/production/auth-middleware.d.ts +12 -2
  591. package/dist/src/servers/production/auth-middleware.d.ts.map +1 -1
  592. package/dist/src/servers/production/auth-middleware.js +240 -28
  593. package/dist/src/servers/production/auth-middleware.js.map +1 -1
  594. package/dist/src/servers/railway/index.js.map +1 -1
  595. package/dist/src/services/context-service.d.ts.map +1 -1
  596. package/dist/src/services/context-service.js +86 -1
  597. package/dist/src/services/context-service.js.map +1 -1
  598. package/dist/src/validation/schemas.d.ts +633 -0
  599. package/dist/src/validation/schemas.d.ts.map +1 -0
  600. package/dist/src/validation/schemas.js +347 -0
  601. package/dist/src/validation/schemas.js.map +1 -0
  602. package/dist/types/task.js +1 -0
  603. package/dist/types/task.js.map +7 -0
  604. package/dist/utils/logger.js +52 -0
  605. package/dist/utils/logger.js.map +7 -0
  606. package/dist/validation/schemas.js +218 -0
  607. package/dist/validation/schemas.js.map +7 -0
  608. package/package.json +12 -3
@@ -0,0 +1,682 @@
1
+ import { v4 as uuidv4 } from "uuid";
2
+ import { logger } from "../monitoring/logger.js";
3
+ import { trace } from "../trace/index.js";
4
+ import {
5
+ DatabaseError,
6
+ FrameError,
7
+ ErrorCode,
8
+ createErrorHandler
9
+ } from "../errors/index.js";
10
+ import { sessionManager, FrameQueryMode } from "../session/index.js";
11
+ class FrameManager {
12
+ db;
13
+ currentRunId;
14
+ sessionId;
15
+ projectId;
16
+ activeStack = [];
17
+ // Stack of active frame IDs
18
+ queryMode = FrameQueryMode.PROJECT_ACTIVE;
19
+ constructor(db, projectId, runId) {
20
+ this.db = db;
21
+ this.projectId = projectId;
22
+ const session = sessionManager.getCurrentSession();
23
+ if (session) {
24
+ this.currentRunId = session.runId;
25
+ this.sessionId = session.sessionId;
26
+ } else {
27
+ this.currentRunId = runId || uuidv4();
28
+ this.sessionId = this.currentRunId;
29
+ }
30
+ this.initializeSchema();
31
+ this.loadActiveStack();
32
+ }
33
+ setQueryMode(mode) {
34
+ this.queryMode = mode;
35
+ this.loadActiveStack();
36
+ }
37
+ initializeSchema() {
38
+ const errorHandler = createErrorHandler({
39
+ operation: "initializeSchema",
40
+ projectId: this.projectId,
41
+ runId: this.currentRunId
42
+ });
43
+ try {
44
+ this.db.exec(`
45
+ CREATE TABLE IF NOT EXISTS frames (
46
+ frame_id TEXT PRIMARY KEY,
47
+ run_id TEXT NOT NULL,
48
+ project_id TEXT NOT NULL,
49
+ parent_frame_id TEXT REFERENCES frames(frame_id),
50
+ depth INTEGER NOT NULL DEFAULT 0,
51
+ type TEXT NOT NULL,
52
+ name TEXT NOT NULL,
53
+ state TEXT DEFAULT 'active',
54
+ inputs TEXT DEFAULT '{}',
55
+ outputs TEXT DEFAULT '{}',
56
+ digest_text TEXT,
57
+ digest_json TEXT DEFAULT '{}',
58
+ created_at INTEGER DEFAULT (unixepoch()),
59
+ closed_at INTEGER
60
+ );
61
+
62
+ CREATE TABLE IF NOT EXISTS events (
63
+ event_id TEXT PRIMARY KEY,
64
+ run_id TEXT NOT NULL,
65
+ frame_id TEXT NOT NULL,
66
+ seq INTEGER NOT NULL,
67
+ event_type TEXT NOT NULL,
68
+ payload TEXT NOT NULL,
69
+ ts INTEGER DEFAULT (unixepoch()),
70
+ FOREIGN KEY(frame_id) REFERENCES frames(frame_id)
71
+ );
72
+
73
+ CREATE TABLE IF NOT EXISTS anchors (
74
+ anchor_id TEXT PRIMARY KEY,
75
+ frame_id TEXT NOT NULL,
76
+ project_id TEXT NOT NULL,
77
+ type TEXT NOT NULL,
78
+ text TEXT NOT NULL,
79
+ priority INTEGER DEFAULT 0,
80
+ created_at INTEGER DEFAULT (unixepoch()),
81
+ metadata TEXT DEFAULT '{}',
82
+ FOREIGN KEY(frame_id) REFERENCES frames(frame_id)
83
+ );
84
+
85
+ CREATE INDEX IF NOT EXISTS idx_frames_run ON frames(run_id);
86
+ CREATE INDEX IF NOT EXISTS idx_frames_parent ON frames(parent_frame_id);
87
+ CREATE INDEX IF NOT EXISTS idx_frames_state ON frames(state);
88
+ CREATE INDEX IF NOT EXISTS idx_events_frame ON events(frame_id);
89
+ CREATE INDEX IF NOT EXISTS idx_events_seq ON events(frame_id, seq);
90
+ CREATE INDEX IF NOT EXISTS idx_anchors_frame ON anchors(frame_id);
91
+ `);
92
+ } catch (error) {
93
+ const dbError = errorHandler(error, {
94
+ operation: "initializeSchema",
95
+ schema: "frames"
96
+ });
97
+ if (dbError instanceof DatabaseError) {
98
+ throw new DatabaseError(
99
+ "Failed to initialize frame database schema",
100
+ ErrorCode.DB_MIGRATION_FAILED,
101
+ {
102
+ projectId: this.projectId,
103
+ operation: "initializeSchema",
104
+ originalError: error
105
+ },
106
+ error instanceof Error ? error : void 0
107
+ );
108
+ }
109
+ throw dbError;
110
+ }
111
+ }
112
+ loadActiveStack() {
113
+ const errorHandler = createErrorHandler({
114
+ operation: "loadActiveStack",
115
+ runId: this.currentRunId,
116
+ projectId: this.projectId
117
+ });
118
+ try {
119
+ let query;
120
+ let params;
121
+ switch (this.queryMode) {
122
+ case FrameQueryMode.ALL_ACTIVE:
123
+ query = `
124
+ SELECT frame_id, parent_frame_id, depth
125
+ FROM frames
126
+ WHERE state = 'active'
127
+ ORDER BY created_at DESC, depth ASC
128
+ `;
129
+ params = [];
130
+ break;
131
+ case FrameQueryMode.PROJECT_ACTIVE:
132
+ query = `
133
+ SELECT frame_id, parent_frame_id, depth, run_id
134
+ FROM frames
135
+ WHERE state = 'active' AND project_id = ?
136
+ ORDER BY created_at DESC, depth ASC
137
+ `;
138
+ params = [this.projectId];
139
+ break;
140
+ case FrameQueryMode.HISTORICAL:
141
+ query = `
142
+ SELECT frame_id, parent_frame_id, depth
143
+ FROM frames
144
+ WHERE project_id = ?
145
+ ORDER BY created_at DESC, depth ASC
146
+ `;
147
+ params = [this.projectId];
148
+ break;
149
+ case FrameQueryMode.CURRENT_SESSION:
150
+ default:
151
+ query = `
152
+ SELECT frame_id, parent_frame_id, depth
153
+ FROM frames
154
+ WHERE run_id = ? AND state = 'active'
155
+ ORDER BY depth ASC
156
+ `;
157
+ params = [this.currentRunId];
158
+ break;
159
+ }
160
+ const activeFrames = this.db.prepare(query).all(...params);
161
+ this.activeStack = this.buildStackOrder(activeFrames);
162
+ logger.info("Loaded active stack", {
163
+ runId: this.currentRunId,
164
+ stackDepth: this.activeStack.length,
165
+ activeFrames: this.activeStack,
166
+ queryMode: this.queryMode
167
+ });
168
+ } catch (error) {
169
+ const dbError = errorHandler(error, {
170
+ query: "Frame loading query",
171
+ runId: this.currentRunId,
172
+ queryMode: this.queryMode
173
+ });
174
+ if (dbError instanceof DatabaseError) {
175
+ throw new DatabaseError(
176
+ "Failed to load active frame stack",
177
+ ErrorCode.DB_QUERY_FAILED,
178
+ {
179
+ runId: this.currentRunId,
180
+ projectId: this.projectId,
181
+ operation: "loadActiveStack"
182
+ },
183
+ error instanceof Error ? error : void 0
184
+ );
185
+ }
186
+ throw dbError;
187
+ }
188
+ }
189
+ buildStackOrder(frames) {
190
+ const stack = [];
191
+ const rootFrame = frames.find((f) => !f.parent_frame_id);
192
+ if (!rootFrame) return [];
193
+ let currentFrame = rootFrame;
194
+ stack.push(currentFrame.frame_id);
195
+ while (currentFrame) {
196
+ const childFrame = frames.find(
197
+ (f) => f.parent_frame_id === currentFrame.frame_id
198
+ );
199
+ if (!childFrame) break;
200
+ stack.push(childFrame.frame_id);
201
+ currentFrame = childFrame;
202
+ }
203
+ return stack;
204
+ }
205
+ /**
206
+ * Create a new frame and push to stack
207
+ */
208
+ createFrame(options) {
209
+ return trace.traceSync("function", "FrameManager.createFrame", options, () => this._createFrame(options));
210
+ }
211
+ _createFrame(options) {
212
+ const frameId = uuidv4();
213
+ const parentFrameId = options.parentFrameId || this.getCurrentFrameId();
214
+ const depth = parentFrameId ? this.getFrameDepth(parentFrameId) + 1 : 0;
215
+ const frame = {
216
+ frame_id: frameId,
217
+ run_id: this.currentRunId,
218
+ project_id: this.projectId,
219
+ parent_frame_id: parentFrameId,
220
+ depth,
221
+ type: options.type,
222
+ name: options.name,
223
+ state: "active",
224
+ inputs: options.inputs || {},
225
+ created_at: Math.floor(Date.now() / 1e3)
226
+ };
227
+ try {
228
+ this.db.prepare(
229
+ `
230
+ INSERT INTO frames (
231
+ frame_id, run_id, project_id, parent_frame_id, depth, type, name, state, inputs, created_at
232
+ ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
233
+ `
234
+ ).run(
235
+ frame.frame_id,
236
+ frame.run_id,
237
+ frame.project_id,
238
+ frame.parent_frame_id,
239
+ frame.depth,
240
+ frame.type,
241
+ frame.name,
242
+ frame.state,
243
+ JSON.stringify(frame.inputs),
244
+ frame.created_at
245
+ );
246
+ } catch (error) {
247
+ throw new DatabaseError(
248
+ `Failed to create frame: ${options.name}`,
249
+ ErrorCode.DB_QUERY_FAILED,
250
+ {
251
+ frameId,
252
+ frameType: options.type,
253
+ frameName: options.name,
254
+ parentFrameId,
255
+ depth,
256
+ operation: "createFrame"
257
+ },
258
+ error instanceof Error ? error : void 0
259
+ );
260
+ }
261
+ this.activeStack.push(frameId);
262
+ logger.info("Created frame", {
263
+ frameId,
264
+ type: options.type,
265
+ name: options.name,
266
+ depth,
267
+ parentFrameId,
268
+ stackDepth: this.activeStack.length
269
+ });
270
+ return frameId;
271
+ }
272
+ /**
273
+ * Close the current frame and generate digest
274
+ */
275
+ closeFrame(frameId, outputs) {
276
+ trace.traceSync("function", "FrameManager.closeFrame", { frameId, outputs }, () => this._closeFrame(frameId, outputs));
277
+ }
278
+ _closeFrame(frameId, outputs) {
279
+ const targetFrameId = frameId || this.getCurrentFrameId();
280
+ if (!targetFrameId) {
281
+ throw new FrameError(
282
+ "No active frame to close",
283
+ ErrorCode.FRAME_INVALID_STATE,
284
+ {
285
+ operation: "closeFrame",
286
+ activeStack: this.activeStack,
287
+ stackDepth: this.activeStack.length
288
+ }
289
+ );
290
+ }
291
+ const frame = this.getFrame(targetFrameId);
292
+ if (!frame) {
293
+ throw new FrameError(
294
+ `Frame not found: ${targetFrameId}`,
295
+ ErrorCode.FRAME_NOT_FOUND,
296
+ {
297
+ frameId: targetFrameId,
298
+ operation: "closeFrame",
299
+ runId: this.currentRunId
300
+ }
301
+ );
302
+ }
303
+ if (frame.state === "closed") {
304
+ logger.warn("Attempted to close already closed frame", {
305
+ frameId: targetFrameId
306
+ });
307
+ return;
308
+ }
309
+ const digest = this.generateDigest(targetFrameId);
310
+ const finalOutputs = { ...outputs, ...digest.structured };
311
+ try {
312
+ this.db.prepare(
313
+ `
314
+ UPDATE frames
315
+ SET state = 'closed',
316
+ outputs = ?,
317
+ digest_text = ?,
318
+ digest_json = ?,
319
+ closed_at = unixepoch()
320
+ WHERE frame_id = ?
321
+ `
322
+ ).run(
323
+ JSON.stringify(finalOutputs),
324
+ digest.text,
325
+ JSON.stringify(digest.structured),
326
+ targetFrameId
327
+ );
328
+ } catch (error) {
329
+ throw new DatabaseError(
330
+ `Failed to close frame: ${targetFrameId}`,
331
+ ErrorCode.DB_QUERY_FAILED,
332
+ {
333
+ frameId: targetFrameId,
334
+ frameName: frame.name,
335
+ operation: "closeFrame"
336
+ },
337
+ error instanceof Error ? error : void 0
338
+ );
339
+ }
340
+ this.activeStack = this.activeStack.filter((id) => id !== targetFrameId);
341
+ this.closeChildFrames(targetFrameId);
342
+ logger.info("Closed frame", {
343
+ frameId: targetFrameId,
344
+ name: frame.name,
345
+ duration: Math.floor(Date.now() / 1e3) - frame.created_at,
346
+ digestLength: digest.text.length,
347
+ stackDepth: this.activeStack.length
348
+ });
349
+ }
350
+ closeChildFrames(parentFrameId) {
351
+ try {
352
+ const children = this.db.prepare(
353
+ `
354
+ SELECT frame_id FROM frames
355
+ WHERE parent_frame_id = ? AND state = 'active'
356
+ `
357
+ ).all(parentFrameId);
358
+ children.forEach((child) => {
359
+ try {
360
+ this.closeFrame(child.frame_id);
361
+ } catch (error) {
362
+ logger.error(
363
+ "Failed to close child frame",
364
+ error instanceof Error ? error : new Error(String(error)),
365
+ {
366
+ parentFrameId,
367
+ childFrameId: child.frame_id
368
+ }
369
+ );
370
+ }
371
+ });
372
+ } catch (error) {
373
+ throw new DatabaseError(
374
+ `Failed to close child frames for parent: ${parentFrameId}`,
375
+ ErrorCode.DB_QUERY_FAILED,
376
+ {
377
+ parentFrameId,
378
+ operation: "closeChildFrames"
379
+ },
380
+ error instanceof Error ? error : void 0
381
+ );
382
+ }
383
+ }
384
+ /**
385
+ * Generate digest for a frame
386
+ */
387
+ generateDigest(frameId) {
388
+ const frame = this.getFrame(frameId);
389
+ const events = this.getFrameEvents(frameId);
390
+ const anchors = this.getFrameAnchors(frameId);
391
+ if (!frame) {
392
+ throw new FrameError(
393
+ `Cannot generate digest: frame not found ${frameId}`,
394
+ ErrorCode.FRAME_NOT_FOUND,
395
+ {
396
+ frameId,
397
+ operation: "generateDigest",
398
+ runId: this.currentRunId
399
+ }
400
+ );
401
+ }
402
+ const decisions = anchors.filter((a) => a.type === "DECISION");
403
+ const constraints = anchors.filter((a) => a.type === "CONSTRAINT");
404
+ const risks = anchors.filter((a) => a.type === "RISK");
405
+ const toolCalls = events.filter((e) => e.event_type === "tool_call");
406
+ const artifacts = events.filter((e) => e.event_type === "artifact");
407
+ const structured = {
408
+ result: frame.name,
409
+ decisions: decisions.map((d) => ({ id: d.anchor_id, text: d.text })),
410
+ constraints: constraints.map((c) => ({ id: c.anchor_id, text: c.text })),
411
+ risks: risks.map((r) => ({ id: r.anchor_id, text: r.text })),
412
+ artifacts: artifacts.map((a) => ({
413
+ kind: a.payload.kind || "unknown",
414
+ ref: a.payload.ref
415
+ })),
416
+ tool_calls_count: toolCalls.length,
417
+ duration_seconds: frame.closed_at ? frame.closed_at - frame.created_at : 0
418
+ };
419
+ const text = this.generateDigestText(frame, structured, events.length);
420
+ return { text, structured };
421
+ }
422
+ generateDigestText(frame, structured, eventCount) {
423
+ let summary = `Completed: ${frame.name}
424
+ `;
425
+ if (structured.decisions.length > 0) {
426
+ summary += `
427
+ Decisions made:
428
+ ${structured.decisions.map((d) => `- ${d.text}`).join("\n")}`;
429
+ }
430
+ if (structured.constraints.length > 0) {
431
+ summary += `
432
+ Constraints established:
433
+ ${structured.constraints.map((c) => `- ${c.text}`).join("\n")}`;
434
+ }
435
+ if (structured.risks.length > 0) {
436
+ summary += `
437
+ Risks identified:
438
+ ${structured.risks.map((r) => `- ${r.text}`).join("\n")}`;
439
+ }
440
+ summary += `
441
+ Activity: ${eventCount} events, ${structured.tool_calls_count} tool calls`;
442
+ if (structured.duration_seconds > 0) {
443
+ summary += `, ${Math.floor(structured.duration_seconds / 60)}m ${structured.duration_seconds % 60}s duration`;
444
+ }
445
+ return summary;
446
+ }
447
+ /**
448
+ * Add event to current frame
449
+ */
450
+ addEvent(eventType, payload, frameId) {
451
+ const targetFrameId = frameId || this.getCurrentFrameId();
452
+ if (!targetFrameId) {
453
+ throw new FrameError(
454
+ "No active frame for event",
455
+ ErrorCode.FRAME_INVALID_STATE,
456
+ {
457
+ operation: "addEvent",
458
+ eventType,
459
+ activeStack: this.activeStack
460
+ }
461
+ );
462
+ }
463
+ const eventId = uuidv4();
464
+ const seq = this.getNextEventSequence(targetFrameId);
465
+ try {
466
+ this.db.prepare(
467
+ `
468
+ INSERT INTO events (event_id, run_id, frame_id, seq, event_type, payload)
469
+ VALUES (?, ?, ?, ?, ?, ?)
470
+ `
471
+ ).run(
472
+ eventId,
473
+ this.currentRunId,
474
+ targetFrameId,
475
+ seq,
476
+ eventType,
477
+ JSON.stringify(payload)
478
+ );
479
+ } catch (error) {
480
+ throw new DatabaseError(
481
+ `Failed to add event to frame: ${targetFrameId}`,
482
+ ErrorCode.DB_QUERY_FAILED,
483
+ {
484
+ eventId,
485
+ frameId: targetFrameId,
486
+ eventType,
487
+ seq,
488
+ operation: "addEvent"
489
+ },
490
+ error instanceof Error ? error : void 0
491
+ );
492
+ }
493
+ return eventId;
494
+ }
495
+ /**
496
+ * Add anchor to frame
497
+ */
498
+ addAnchor(type, text, priority = 0, metadata = {}, frameId) {
499
+ const targetFrameId = frameId || this.getCurrentFrameId();
500
+ if (!targetFrameId) {
501
+ throw new FrameError(
502
+ "No active frame for anchor",
503
+ ErrorCode.FRAME_INVALID_STATE,
504
+ {
505
+ operation: "addAnchor",
506
+ anchorType: type,
507
+ text: text.substring(0, 100),
508
+ activeStack: this.activeStack
509
+ }
510
+ );
511
+ }
512
+ const anchorId = uuidv4();
513
+ try {
514
+ this.db.prepare(
515
+ `
516
+ INSERT INTO anchors (anchor_id, frame_id, project_id, type, text, priority, metadata)
517
+ VALUES (?, ?, ?, ?, ?, ?, ?)
518
+ `
519
+ ).run(
520
+ anchorId,
521
+ targetFrameId,
522
+ this.projectId,
523
+ type,
524
+ text,
525
+ priority,
526
+ JSON.stringify(metadata)
527
+ );
528
+ } catch (error) {
529
+ throw new DatabaseError(
530
+ `Failed to add anchor to frame: ${targetFrameId}`,
531
+ ErrorCode.DB_QUERY_FAILED,
532
+ {
533
+ anchorId,
534
+ frameId: targetFrameId,
535
+ anchorType: type,
536
+ operation: "addAnchor"
537
+ },
538
+ error instanceof Error ? error : void 0
539
+ );
540
+ }
541
+ return anchorId;
542
+ }
543
+ /**
544
+ * Get hot stack context for current active frames
545
+ */
546
+ getHotStackContext(maxEvents = 20) {
547
+ return this.activeStack.map((frameId) => {
548
+ const frame = this.getFrame(frameId);
549
+ if (!frame) return null;
550
+ return {
551
+ frameId,
552
+ header: {
553
+ goal: frame.name,
554
+ constraints: this.extractConstraints(frame.inputs),
555
+ definitions: frame.inputs.definitions
556
+ },
557
+ anchors: this.getFrameAnchors(frameId),
558
+ recentEvents: this.getFrameEvents(frameId, maxEvents),
559
+ activeArtifacts: this.getActiveArtifacts(frameId)
560
+ };
561
+ }).filter(Boolean);
562
+ }
563
+ /**
564
+ * Get active frame path (root to current)
565
+ */
566
+ getActiveFramePath() {
567
+ return this.activeStack.map((frameId) => this.getFrame(frameId)).filter(Boolean);
568
+ }
569
+ // Utility methods
570
+ getCurrentFrameId() {
571
+ return this.activeStack[this.activeStack.length - 1];
572
+ }
573
+ getStackDepth() {
574
+ return this.activeStack.length;
575
+ }
576
+ getFrameDepth(frameId) {
577
+ const frame = this.getFrame(frameId);
578
+ return frame?.depth || 0;
579
+ }
580
+ getFrame(frameId) {
581
+ try {
582
+ const row = this.db.prepare(
583
+ `
584
+ SELECT * FROM frames WHERE frame_id = ?
585
+ `
586
+ ).get(frameId);
587
+ if (!row) return void 0;
588
+ return {
589
+ ...row,
590
+ inputs: JSON.parse(row.inputs || "{}"),
591
+ outputs: JSON.parse(row.outputs || "{}"),
592
+ digest_json: JSON.parse(row.digest_json || "{}")
593
+ };
594
+ } catch (error) {
595
+ throw new DatabaseError(
596
+ `Failed to get frame: ${frameId}`,
597
+ ErrorCode.DB_QUERY_FAILED,
598
+ {
599
+ frameId,
600
+ operation: "getFrame"
601
+ },
602
+ error instanceof Error ? error : void 0
603
+ );
604
+ }
605
+ }
606
+ getFrameEvents(frameId, limit) {
607
+ try {
608
+ const query = limit ? `SELECT * FROM events WHERE frame_id = ? ORDER BY seq DESC LIMIT ?` : `SELECT * FROM events WHERE frame_id = ? ORDER BY seq ASC`;
609
+ const params = limit ? [frameId, limit] : [frameId];
610
+ const rows = this.db.prepare(query).all(...params);
611
+ return rows.map((row) => ({
612
+ ...row,
613
+ payload: JSON.parse(row.payload)
614
+ }));
615
+ } catch (error) {
616
+ throw new DatabaseError(
617
+ `Failed to get frame events: ${frameId}`,
618
+ ErrorCode.DB_QUERY_FAILED,
619
+ {
620
+ frameId,
621
+ limit,
622
+ operation: "getFrameEvents"
623
+ },
624
+ error instanceof Error ? error : void 0
625
+ );
626
+ }
627
+ }
628
+ getFrameAnchors(frameId) {
629
+ try {
630
+ const rows = this.db.prepare(
631
+ `
632
+ SELECT * FROM anchors WHERE frame_id = ? ORDER BY priority DESC, created_at ASC
633
+ `
634
+ ).all(frameId);
635
+ return rows.map((row) => ({
636
+ ...row,
637
+ metadata: JSON.parse(row.metadata || "{}")
638
+ }));
639
+ } catch (error) {
640
+ throw new DatabaseError(
641
+ `Failed to get frame anchors: ${frameId}`,
642
+ ErrorCode.DB_QUERY_FAILED,
643
+ {
644
+ frameId,
645
+ operation: "getFrameAnchors"
646
+ },
647
+ error instanceof Error ? error : void 0
648
+ );
649
+ }
650
+ }
651
+ getNextEventSequence(frameId) {
652
+ try {
653
+ const result = this.db.prepare(
654
+ `
655
+ SELECT MAX(seq) as max_seq FROM events WHERE frame_id = ?
656
+ `
657
+ ).get(frameId);
658
+ return (result.max_seq || 0) + 1;
659
+ } catch (error) {
660
+ throw new DatabaseError(
661
+ `Failed to get next event sequence for frame: ${frameId}`,
662
+ ErrorCode.DB_QUERY_FAILED,
663
+ {
664
+ frameId,
665
+ operation: "getNextEventSequence"
666
+ },
667
+ error instanceof Error ? error : void 0
668
+ );
669
+ }
670
+ }
671
+ extractConstraints(inputs) {
672
+ return inputs.constraints;
673
+ }
674
+ getActiveArtifacts(frameId) {
675
+ const artifacts = this.getFrameEvents(frameId).filter((e) => e.event_type === "artifact").map((e) => e.payload.ref).filter(Boolean);
676
+ return artifacts;
677
+ }
678
+ }
679
+ export {
680
+ FrameManager
681
+ };
682
+ //# sourceMappingURL=frame-manager.js.map