@stackmemoryai/stackmemory 0.2.9 → 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 (575) 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/frame-database.d.ts +59 -0
  317. package/dist/src/core/context/frame-database.d.ts.map +1 -0
  318. package/dist/src/core/context/frame-database.js +333 -0
  319. package/dist/src/core/context/frame-database.js.map +1 -0
  320. package/dist/src/core/context/frame-digest.d.ts +59 -0
  321. package/dist/src/core/context/frame-digest.d.ts.map +1 -0
  322. package/dist/src/core/context/frame-digest.js +264 -0
  323. package/dist/src/core/context/frame-digest.js.map +1 -0
  324. package/dist/src/core/context/frame-manager.d.ts +2 -0
  325. package/dist/src/core/context/frame-manager.d.ts.map +1 -1
  326. package/dist/src/core/context/frame-manager.js +7 -0
  327. package/dist/src/core/context/frame-manager.js.map +1 -1
  328. package/dist/src/core/context/frame-stack.d.ts +85 -0
  329. package/dist/src/core/context/frame-stack.d.ts.map +1 -0
  330. package/dist/src/core/context/frame-stack.js +287 -0
  331. package/dist/src/core/context/frame-stack.js.map +1 -0
  332. package/dist/src/core/context/frame-types.d.ts +67 -0
  333. package/dist/src/core/context/frame-types.d.ts.map +1 -0
  334. package/dist/src/core/context/frame-types.js +6 -0
  335. package/dist/src/core/context/frame-types.js.map +1 -0
  336. package/dist/src/core/context/index.d.ts +11 -0
  337. package/dist/src/core/context/index.d.ts.map +1 -0
  338. package/dist/src/core/context/index.js +14 -0
  339. package/dist/src/core/context/index.js.map +1 -0
  340. package/dist/src/core/context/refactored-frame-manager.d.ts +99 -0
  341. package/dist/src/core/context/refactored-frame-manager.d.ts.map +1 -0
  342. package/dist/src/core/context/refactored-frame-manager.js +340 -0
  343. package/dist/src/core/context/refactored-frame-manager.js.map +1 -0
  344. package/dist/src/core/database/batch-operations.d.ts +118 -0
  345. package/dist/src/core/database/batch-operations.d.ts.map +1 -0
  346. package/dist/src/core/database/batch-operations.js +339 -0
  347. package/dist/src/core/database/batch-operations.js.map +1 -0
  348. package/dist/src/core/database/connection-pool.d.ts +79 -0
  349. package/dist/src/core/database/connection-pool.d.ts.map +1 -0
  350. package/dist/src/core/database/connection-pool.js +236 -0
  351. package/dist/src/core/database/connection-pool.js.map +1 -0
  352. package/dist/src/core/database/query-cache.d.ts +135 -0
  353. package/dist/src/core/database/query-cache.d.ts.map +1 -0
  354. package/dist/src/core/database/query-cache.js +294 -0
  355. package/dist/src/core/database/query-cache.js.map +1 -0
  356. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts +125 -0
  357. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts.map +1 -0
  358. package/dist/src/core/digest/enhanced-hybrid-digest.js +282 -0
  359. package/dist/src/core/digest/enhanced-hybrid-digest.js.map +1 -0
  360. package/dist/src/core/digest/frame-digest-integration.d.ts +67 -0
  361. package/dist/src/core/digest/frame-digest-integration.d.ts.map +1 -0
  362. package/dist/src/core/digest/frame-digest-integration.js +198 -0
  363. package/dist/src/core/digest/frame-digest-integration.js.map +1 -0
  364. package/dist/src/core/digest/hybrid-digest-generator.d.ts +3 -3
  365. package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +1 -1
  366. package/dist/src/core/digest/hybrid-digest-generator.js.map +1 -1
  367. package/dist/src/core/digest/index.d.ts +3 -1
  368. package/dist/src/core/digest/index.d.ts.map +1 -1
  369. package/dist/src/core/digest/index.js +3 -1
  370. package/dist/src/core/digest/index.js.map +1 -1
  371. package/dist/src/core/errors/index.d.ts +13 -5
  372. package/dist/src/core/errors/index.d.ts.map +1 -1
  373. package/dist/src/core/errors/index.js +13 -5
  374. package/dist/src/core/errors/index.js.map +1 -1
  375. package/dist/src/core/merge/conflict-detector.d.ts +122 -0
  376. package/dist/src/core/merge/conflict-detector.d.ts.map +1 -0
  377. package/dist/src/core/merge/conflict-detector.js +468 -0
  378. package/dist/src/core/merge/conflict-detector.js.map +1 -0
  379. package/dist/src/core/merge/index.d.ts +9 -0
  380. package/dist/src/core/merge/index.d.ts.map +1 -0
  381. package/dist/src/core/merge/index.js +9 -0
  382. package/dist/src/core/merge/index.js.map +1 -0
  383. package/dist/src/core/merge/resolution-engine.d.ts +120 -0
  384. package/dist/src/core/merge/resolution-engine.d.ts.map +1 -0
  385. package/dist/src/core/merge/resolution-engine.js +573 -0
  386. package/dist/src/core/merge/resolution-engine.js.map +1 -0
  387. package/dist/src/core/merge/stack-diff.d.ts +97 -0
  388. package/dist/src/core/merge/stack-diff.d.ts.map +1 -0
  389. package/dist/src/core/merge/stack-diff.js +516 -0
  390. package/dist/src/core/merge/stack-diff.js.map +1 -0
  391. package/dist/src/core/merge/types.d.ts +110 -0
  392. package/dist/src/core/merge/types.d.ts.map +1 -0
  393. package/dist/src/core/merge/types.js +6 -0
  394. package/dist/src/core/merge/types.js.map +1 -0
  395. package/dist/src/core/performance/context-cache.d.ts +109 -0
  396. package/dist/src/core/performance/context-cache.d.ts.map +1 -0
  397. package/dist/src/core/performance/context-cache.js +280 -0
  398. package/dist/src/core/performance/context-cache.js.map +1 -0
  399. package/dist/src/core/performance/index.d.ts +3 -0
  400. package/dist/src/core/performance/index.d.ts.map +1 -0
  401. package/dist/src/core/performance/index.js +3 -0
  402. package/dist/src/core/performance/index.js.map +1 -0
  403. package/dist/src/core/performance/lazy-context-loader.d.ts +93 -0
  404. package/dist/src/core/performance/lazy-context-loader.d.ts.map +1 -0
  405. package/dist/src/core/performance/lazy-context-loader.js +332 -0
  406. package/dist/src/core/performance/lazy-context-loader.js.map +1 -0
  407. package/dist/src/core/performance/monitor.d.ts +48 -0
  408. package/dist/src/core/performance/monitor.d.ts.map +1 -0
  409. package/dist/src/core/performance/monitor.js +226 -0
  410. package/dist/src/core/performance/monitor.js.map +1 -0
  411. package/dist/src/core/performance/optimized-frame-context.d.ts +74 -0
  412. package/dist/src/core/performance/optimized-frame-context.d.ts.map +1 -0
  413. package/dist/src/core/performance/optimized-frame-context.js +330 -0
  414. package/dist/src/core/performance/optimized-frame-context.js.map +1 -0
  415. package/dist/src/core/performance/performance-benchmark.d.ts +50 -0
  416. package/dist/src/core/performance/performance-benchmark.d.ts.map +1 -0
  417. package/dist/src/core/performance/performance-benchmark.js +290 -0
  418. package/dist/src/core/performance/performance-benchmark.js.map +1 -0
  419. package/dist/src/core/performance/performance-profiler.d.ts +151 -0
  420. package/dist/src/core/performance/performance-profiler.d.ts.map +1 -0
  421. package/dist/src/core/performance/performance-profiler.js +346 -0
  422. package/dist/src/core/performance/performance-profiler.js.map +1 -0
  423. package/dist/src/core/performance/streaming-jsonl-parser.d.ts +41 -0
  424. package/dist/src/core/performance/streaming-jsonl-parser.d.ts.map +1 -0
  425. package/dist/src/core/performance/streaming-jsonl-parser.js +193 -0
  426. package/dist/src/core/performance/streaming-jsonl-parser.js.map +1 -0
  427. package/dist/src/core/persistence/postgres-adapter.d.ts.map +1 -1
  428. package/dist/src/core/persistence/postgres-adapter.js +18 -4
  429. package/dist/src/core/persistence/postgres-adapter.js.map +1 -1
  430. package/dist/src/core/query/query-parser.d.ts +5 -0
  431. package/dist/src/core/query/query-parser.d.ts.map +1 -1
  432. package/dist/src/core/query/query-parser.js +86 -18
  433. package/dist/src/core/query/query-parser.js.map +1 -1
  434. package/dist/src/core/query/query-templates.d.ts +44 -0
  435. package/dist/src/core/query/query-templates.d.ts.map +1 -0
  436. package/dist/src/core/query/query-templates.js +326 -0
  437. package/dist/src/core/query/query-templates.js.map +1 -0
  438. package/dist/src/core/retrieval/llm-context-retrieval.d.ts +5 -3
  439. package/dist/src/core/retrieval/llm-context-retrieval.d.ts.map +1 -1
  440. package/dist/src/core/retrieval/llm-context-retrieval.js +73 -21
  441. package/dist/src/core/retrieval/llm-context-retrieval.js.map +1 -1
  442. package/dist/src/core/trace/cli-trace-wrapper.d.ts +23 -0
  443. package/dist/src/core/trace/cli-trace-wrapper.d.ts.map +1 -0
  444. package/dist/src/core/trace/cli-trace-wrapper.js +141 -0
  445. package/dist/src/core/trace/cli-trace-wrapper.js.map +1 -0
  446. package/dist/src/core/trace/db-trace-wrapper.d.ts +36 -0
  447. package/dist/src/core/trace/db-trace-wrapper.d.ts.map +1 -0
  448. package/dist/src/core/trace/db-trace-wrapper.js +252 -0
  449. package/dist/src/core/trace/db-trace-wrapper.js.map +1 -0
  450. package/dist/src/core/trace/debug-trace.d.ts +84 -0
  451. package/dist/src/core/trace/debug-trace.d.ts.map +1 -0
  452. package/dist/src/core/trace/debug-trace.js +402 -0
  453. package/dist/src/core/trace/debug-trace.js.map +1 -0
  454. package/dist/src/core/trace/error-test.d.ts +6 -0
  455. package/dist/src/core/trace/error-test.d.ts.map +1 -0
  456. package/dist/src/core/trace/error-test.js +128 -0
  457. package/dist/src/core/trace/error-test.js.map +1 -0
  458. package/dist/src/core/trace/index.d.ts +25 -0
  459. package/dist/src/core/trace/index.d.ts.map +1 -0
  460. package/dist/src/core/trace/index.js +121 -0
  461. package/dist/src/core/trace/index.js.map +1 -0
  462. package/dist/src/core/trace/linear-api-wrapper.d.ts +17 -0
  463. package/dist/src/core/trace/linear-api-wrapper.d.ts.map +1 -0
  464. package/dist/src/core/trace/linear-api-wrapper.js +205 -0
  465. package/dist/src/core/trace/linear-api-wrapper.js.map +1 -0
  466. package/dist/src/core/trace/performance-test.d.ts +6 -0
  467. package/dist/src/core/trace/performance-test.d.ts.map +1 -0
  468. package/dist/src/core/trace/performance-test.js +111 -0
  469. package/dist/src/core/trace/performance-test.js.map +1 -0
  470. package/dist/src/core/trace/trace-demo.d.ts +8 -0
  471. package/dist/src/core/trace/trace-demo.d.ts.map +1 -0
  472. package/dist/src/core/trace/trace-demo.js +154 -0
  473. package/dist/src/core/trace/trace-demo.js.map +1 -0
  474. package/dist/src/core/trace/trace-detector.d.ts +2 -2
  475. package/dist/src/core/trace/trace-detector.d.ts.map +1 -1
  476. package/dist/src/core/trace/trace-detector.demo.js +1 -1
  477. package/dist/src/core/trace/trace-detector.demo.js.map +1 -1
  478. package/dist/src/core/trace/trace-detector.js +3 -3
  479. package/dist/src/core/trace/trace-detector.js.map +1 -1
  480. package/dist/src/features/tasks/pebbles-task-store.d.ts +9 -2
  481. package/dist/src/features/tasks/pebbles-task-store.d.ts.map +1 -1
  482. package/dist/src/features/tasks/pebbles-task-store.js +97 -18
  483. package/dist/src/features/tasks/pebbles-task-store.js.map +1 -1
  484. package/dist/src/integrations/linear/auth.d.ts.map +1 -1
  485. package/dist/src/integrations/linear/auth.js.map +1 -1
  486. package/dist/src/integrations/linear/client.d.ts +15 -1
  487. package/dist/src/integrations/linear/client.d.ts.map +1 -1
  488. package/dist/src/integrations/linear/client.js +85 -3
  489. package/dist/src/integrations/linear/client.js.map +1 -1
  490. package/dist/src/integrations/linear/sync-manager.d.ts +2 -0
  491. package/dist/src/integrations/linear/sync-manager.d.ts.map +1 -1
  492. package/dist/src/integrations/linear/sync-manager.js +16 -4
  493. package/dist/src/integrations/linear/sync-manager.js.map +1 -1
  494. package/dist/src/integrations/linear/sync-service.d.ts +23 -2
  495. package/dist/src/integrations/linear/sync-service.d.ts.map +1 -1
  496. package/dist/src/integrations/linear/sync-service.js +44 -25
  497. package/dist/src/integrations/linear/sync-service.js.map +1 -1
  498. package/dist/src/integrations/linear/sync.d.ts +6 -0
  499. package/dist/src/integrations/linear/sync.d.ts.map +1 -1
  500. package/dist/src/integrations/linear/sync.js +27 -2
  501. package/dist/src/integrations/linear/sync.js.map +1 -1
  502. package/dist/src/integrations/linear/types.d.ts +16 -1
  503. package/dist/src/integrations/linear/types.d.ts.map +1 -1
  504. package/dist/src/integrations/linear/webhook-server.d.ts.map +1 -1
  505. package/dist/src/integrations/linear/webhook-server.js +10 -8
  506. package/dist/src/integrations/linear/webhook-server.js.map +1 -1
  507. package/dist/src/integrations/linear/webhook.d.ts +13 -0
  508. package/dist/src/integrations/linear/webhook.d.ts.map +1 -1
  509. package/dist/src/integrations/linear/webhook.js +101 -14
  510. package/dist/src/integrations/linear/webhook.js.map +1 -1
  511. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts +39 -0
  512. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts.map +1 -0
  513. package/dist/src/integrations/mcp/handlers/context-handlers.js +266 -0
  514. package/dist/src/integrations/mcp/handlers/context-handlers.js.map +1 -0
  515. package/dist/src/integrations/mcp/handlers/index.d.ts +37 -0
  516. package/dist/src/integrations/mcp/handlers/index.d.ts.map +1 -0
  517. package/dist/src/integrations/mcp/handlers/index.js +134 -0
  518. package/dist/src/integrations/mcp/handlers/index.js.map +1 -0
  519. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts +33 -0
  520. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts.map +1 -0
  521. package/dist/src/integrations/mcp/handlers/linear-handlers.js +251 -0
  522. package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +1 -0
  523. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts +42 -0
  524. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts.map +1 -0
  525. package/dist/src/integrations/mcp/handlers/task-handlers.js +238 -0
  526. package/dist/src/integrations/mcp/handlers/task-handlers.js.map +1 -0
  527. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts +41 -0
  528. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts.map +1 -0
  529. package/dist/src/integrations/mcp/handlers/trace-handlers.js +298 -0
  530. package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +1 -0
  531. package/dist/src/integrations/mcp/index.d.ts +13 -0
  532. package/dist/src/integrations/mcp/index.d.ts.map +1 -0
  533. package/dist/src/integrations/mcp/index.js +17 -0
  534. package/dist/src/integrations/mcp/index.js.map +1 -0
  535. package/dist/src/integrations/mcp/refactored-server.d.ts +76 -0
  536. package/dist/src/integrations/mcp/refactored-server.d.ts.map +1 -0
  537. package/dist/src/integrations/mcp/refactored-server.js +351 -0
  538. package/dist/src/integrations/mcp/refactored-server.js.map +1 -0
  539. package/dist/src/integrations/mcp/tool-definitions.d.ts +44 -0
  540. package/dist/src/integrations/mcp/tool-definitions.d.ts.map +1 -0
  541. package/dist/src/integrations/mcp/tool-definitions.js +563 -0
  542. package/dist/src/integrations/mcp/tool-definitions.js.map +1 -0
  543. package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +1 -1
  544. package/dist/src/integrations/pg-aiguide/semantic-search.js +43 -21
  545. package/dist/src/integrations/pg-aiguide/semantic-search.js.map +1 -1
  546. package/dist/src/mcp/stackmemory-mcp-server.d.ts +9 -0
  547. package/dist/src/mcp/stackmemory-mcp-server.d.ts.map +1 -0
  548. package/dist/src/mcp/stackmemory-mcp-server.js +519 -0
  549. package/dist/src/mcp/stackmemory-mcp-server.js.map +1 -0
  550. package/dist/src/middleware/exponential-rate-limiter.d.ts +78 -0
  551. package/dist/src/middleware/exponential-rate-limiter.d.ts.map +1 -0
  552. package/dist/src/middleware/exponential-rate-limiter.js +293 -0
  553. package/dist/src/middleware/exponential-rate-limiter.js.map +1 -0
  554. package/dist/src/models/user.model.d.ts +8 -1
  555. package/dist/src/models/user.model.d.ts.map +1 -1
  556. package/dist/src/models/user.model.js +62 -14
  557. package/dist/src/models/user.model.js.map +1 -1
  558. package/dist/src/servers/production/auth-middleware.d.ts +5 -2
  559. package/dist/src/servers/production/auth-middleware.d.ts.map +1 -1
  560. package/dist/src/servers/production/auth-middleware.js +71 -34
  561. package/dist/src/servers/production/auth-middleware.js.map +1 -1
  562. package/dist/src/services/context-service.d.ts.map +1 -1
  563. package/dist/src/services/context-service.js +86 -1
  564. package/dist/src/services/context-service.js.map +1 -1
  565. package/dist/src/validation/schemas.d.ts +633 -0
  566. package/dist/src/validation/schemas.d.ts.map +1 -0
  567. package/dist/src/validation/schemas.js +347 -0
  568. package/dist/src/validation/schemas.js.map +1 -0
  569. package/dist/types/task.js +1 -0
  570. package/dist/types/task.js.map +7 -0
  571. package/dist/utils/logger.js +52 -0
  572. package/dist/utils/logger.js.map +7 -0
  573. package/dist/validation/schemas.js +218 -0
  574. package/dist/validation/schemas.js.map +7 -0
  575. package/package.json +7 -3
@@ -0,0 +1,346 @@
1
+ /**
2
+ * Performance Profiler
3
+ * Identifies and optimizes hot paths in StackMemory operations
4
+ */
5
+ import { logger } from '../monitoring/logger.js';
6
+ import { getQueryStatistics } from '../trace/db-trace-wrapper.js';
7
+ /**
8
+ * Performance profiler with hot path detection
9
+ */
10
+ export class PerformanceProfiler {
11
+ metrics = new Map();
12
+ hotPaths = new Map();
13
+ samples = new Map();
14
+ isEnabled = true;
15
+ sampleLimit = 1000;
16
+ hotPathThreshold = 5; // Operations taking > 5ms are considered hot
17
+ constructor(options = {}) {
18
+ this.isEnabled = options.enabled ?? true;
19
+ this.sampleLimit = options.sampleLimit ?? 1000;
20
+ this.hotPathThreshold = options.hotPathThreshold ?? 5;
21
+ }
22
+ /**
23
+ * Start timing an operation
24
+ */
25
+ startTiming(operationName) {
26
+ if (!this.isEnabled) {
27
+ return () => { }; // No-op
28
+ }
29
+ const startTime = performance.now();
30
+ return (metadata) => {
31
+ this.endTiming(operationName, startTime, metadata);
32
+ };
33
+ }
34
+ /**
35
+ * Time a function execution
36
+ */
37
+ async timeFunction(operationName, fn, metadata) {
38
+ if (!this.isEnabled) {
39
+ return await fn();
40
+ }
41
+ const endTimer = this.startTiming(operationName);
42
+ try {
43
+ const result = await fn();
44
+ endTimer(metadata);
45
+ return result;
46
+ }
47
+ catch (error) {
48
+ endTimer({ ...metadata, error: true });
49
+ throw error;
50
+ }
51
+ }
52
+ /**
53
+ * Record timing manually
54
+ */
55
+ recordTiming(operationName, durationMs, metadata) {
56
+ if (!this.isEnabled)
57
+ return;
58
+ this.endTiming(operationName, performance.now() - durationMs, metadata);
59
+ }
60
+ /**
61
+ * Get performance metrics for an operation
62
+ */
63
+ getMetrics(operationName) {
64
+ return this.metrics.get(operationName);
65
+ }
66
+ /**
67
+ * Get all performance metrics
68
+ */
69
+ getAllMetrics() {
70
+ return new Map(this.metrics);
71
+ }
72
+ /**
73
+ * Get hot paths sorted by impact
74
+ */
75
+ getHotPaths(limit = 10) {
76
+ return Array.from(this.hotPaths.values())
77
+ .sort((a, b) => (b.frequency * b.avgDuration) - (a.frequency * a.avgDuration))
78
+ .slice(0, limit);
79
+ }
80
+ /**
81
+ * Generate comprehensive performance report
82
+ */
83
+ generateReport(db) {
84
+ const hotPaths = this.getHotPaths(20);
85
+ const recommendations = this.generateRecommendations(hotPaths);
86
+ const report = {
87
+ timestamp: Date.now(),
88
+ hotPaths,
89
+ databaseMetrics: db ? getQueryStatistics(db) : null,
90
+ memoryUsage: process.memoryUsage(),
91
+ cacheMetrics: null, // Will be filled by query cache if available
92
+ recommendations,
93
+ };
94
+ logger.info('Performance report generated', {
95
+ hotPathsCount: hotPaths.length,
96
+ recommendationsCount: recommendations.length,
97
+ topHotPath: hotPaths[0]?.path,
98
+ });
99
+ return report;
100
+ }
101
+ /**
102
+ * Reset all metrics
103
+ */
104
+ reset() {
105
+ this.metrics.clear();
106
+ this.hotPaths.clear();
107
+ this.samples.clear();
108
+ logger.info('Performance metrics reset');
109
+ }
110
+ /**
111
+ * Export metrics to JSON
112
+ */
113
+ exportMetrics() {
114
+ const data = {
115
+ timestamp: Date.now(),
116
+ metrics: Object.fromEntries(this.metrics),
117
+ hotPaths: Object.fromEntries(this.hotPaths),
118
+ config: {
119
+ sampleLimit: this.sampleLimit,
120
+ hotPathThreshold: this.hotPathThreshold,
121
+ enabled: this.isEnabled,
122
+ },
123
+ };
124
+ return JSON.stringify(data, null, 2);
125
+ }
126
+ /**
127
+ * Enable/disable profiling
128
+ */
129
+ setEnabled(enabled) {
130
+ this.isEnabled = enabled;
131
+ logger.info(`Performance profiling ${enabled ? 'enabled' : 'disabled'}`);
132
+ }
133
+ /**
134
+ * End timing for an operation
135
+ */
136
+ endTiming(operationName, startTime, metadata) {
137
+ const duration = performance.now() - startTime;
138
+ const timestamp = Date.now();
139
+ // Update metrics
140
+ this.updateMetrics(operationName, duration, timestamp);
141
+ // Track hot paths
142
+ if (duration > this.hotPathThreshold) {
143
+ this.trackHotPath(operationName, duration, timestamp, metadata);
144
+ }
145
+ // Store sample
146
+ this.storeSample(operationName, duration, timestamp, metadata);
147
+ }
148
+ /**
149
+ * Update performance metrics for an operation
150
+ */
151
+ updateMetrics(operationName, duration, timestamp) {
152
+ const existing = this.metrics.get(operationName);
153
+ if (!existing) {
154
+ this.metrics.set(operationName, {
155
+ operationName,
156
+ callCount: 1,
157
+ totalTimeMs: duration,
158
+ avgTimeMs: duration,
159
+ minTimeMs: duration,
160
+ maxTimeMs: duration,
161
+ p95TimeMs: duration,
162
+ lastExecuted: timestamp,
163
+ });
164
+ }
165
+ else {
166
+ existing.callCount++;
167
+ existing.totalTimeMs += duration;
168
+ existing.avgTimeMs = existing.totalTimeMs / existing.callCount;
169
+ existing.minTimeMs = Math.min(existing.minTimeMs, duration);
170
+ existing.maxTimeMs = Math.max(existing.maxTimeMs, duration);
171
+ existing.lastExecuted = timestamp;
172
+ // Update p95 from samples
173
+ existing.p95TimeMs = this.calculateP95(operationName);
174
+ }
175
+ }
176
+ /**
177
+ * Track hot path
178
+ */
179
+ trackHotPath(operationName, duration, timestamp, metadata) {
180
+ const existing = this.hotPaths.get(operationName);
181
+ if (!existing) {
182
+ this.hotPaths.set(operationName, {
183
+ path: operationName,
184
+ frequency: 1,
185
+ avgDuration: duration,
186
+ totalDuration: duration,
187
+ lastSeen: timestamp,
188
+ samples: [{ timestamp, duration, metadata }],
189
+ });
190
+ }
191
+ else {
192
+ existing.frequency++;
193
+ existing.totalDuration += duration;
194
+ existing.avgDuration = existing.totalDuration / existing.frequency;
195
+ existing.lastSeen = timestamp;
196
+ // Keep limited samples
197
+ existing.samples.push({ timestamp, duration, metadata });
198
+ if (existing.samples.length > 100) {
199
+ existing.samples = existing.samples.slice(-100);
200
+ }
201
+ }
202
+ }
203
+ /**
204
+ * Store performance sample
205
+ */
206
+ storeSample(operationName, duration, timestamp, metadata) {
207
+ if (!this.samples.has(operationName)) {
208
+ this.samples.set(operationName, []);
209
+ }
210
+ const samples = this.samples.get(operationName);
211
+ samples.push({ timestamp, duration, metadata });
212
+ // Limit samples to prevent memory growth
213
+ if (samples.length > this.sampleLimit) {
214
+ samples.splice(0, samples.length - this.sampleLimit);
215
+ }
216
+ }
217
+ /**
218
+ * Calculate 95th percentile from samples
219
+ */
220
+ calculateP95(operationName) {
221
+ const samples = this.samples.get(operationName);
222
+ if (!samples || samples.length === 0)
223
+ return 0;
224
+ const durations = samples.map(s => s.duration).sort((a, b) => a - b);
225
+ const index = Math.floor(durations.length * 0.95);
226
+ return durations[index] || 0;
227
+ }
228
+ /**
229
+ * Generate optimization recommendations
230
+ */
231
+ generateRecommendations(hotPaths) {
232
+ const recommendations = [];
233
+ for (const hotPath of hotPaths.slice(0, 5)) {
234
+ const impact = hotPath.frequency * hotPath.avgDuration;
235
+ if (hotPath.path.includes('getFrameContext') && hotPath.avgDuration > 10) {
236
+ recommendations.push(`Consider caching frame context for ${hotPath.path} (avg: ${hotPath.avgDuration.toFixed(1)}ms)`);
237
+ }
238
+ if (hotPath.path.includes('getFrameEvents') && hotPath.frequency > 100) {
239
+ recommendations.push(`High frequency event queries detected in ${hotPath.path} (${hotPath.frequency} calls). Consider pagination or caching.`);
240
+ }
241
+ if (hotPath.path.includes('bulkInsert') && hotPath.avgDuration > 50) {
242
+ recommendations.push(`Slow bulk insertion in ${hotPath.path}. Consider increasing batch size or using prepared statements.`);
243
+ }
244
+ if (impact > 1000) {
245
+ recommendations.push(`High impact operation: ${hotPath.path} (${impact.toFixed(0)}ms total impact). Consider optimization.`);
246
+ }
247
+ }
248
+ // Memory recommendations
249
+ const memUsage = process.memoryUsage();
250
+ if (memUsage.heapUsed / memUsage.heapTotal > 0.8) {
251
+ recommendations.push('High memory usage detected. Consider implementing cleanup routines or reducing cache sizes.');
252
+ }
253
+ if (recommendations.length === 0) {
254
+ recommendations.push('No significant performance issues detected.');
255
+ }
256
+ return recommendations;
257
+ }
258
+ }
259
+ // Global profiler instance
260
+ let globalProfiler = null;
261
+ /**
262
+ * Get or create global profiler
263
+ */
264
+ export function getProfiler() {
265
+ if (!globalProfiler) {
266
+ globalProfiler = new PerformanceProfiler({
267
+ enabled: process.env.NODE_ENV !== 'production' || process.env.STACKMEMORY_PROFILING === 'true',
268
+ });
269
+ }
270
+ return globalProfiler;
271
+ }
272
+ /**
273
+ * Convenience function to time operations
274
+ */
275
+ export async function timeOperation(operationName, fn, metadata) {
276
+ return getProfiler().timeFunction(operationName, fn, metadata);
277
+ }
278
+ /**
279
+ * Create a performance monitoring decorator
280
+ */
281
+ export function performanceMonitor(operationName) {
282
+ return function (target, propertyKey, descriptor) {
283
+ const originalMethod = descriptor.value;
284
+ const finalOperationName = operationName || `${target.constructor.name}.${propertyKey}`;
285
+ descriptor.value = async function (...args) {
286
+ return getProfiler().timeFunction(finalOperationName, () => originalMethod.apply(this, args));
287
+ };
288
+ return descriptor;
289
+ };
290
+ }
291
+ /**
292
+ * Monitor specific StackMemory operations
293
+ */
294
+ export class StackMemoryPerformanceMonitor {
295
+ profiler = getProfiler();
296
+ /**
297
+ * Monitor frame operations
298
+ */
299
+ monitorFrameOperations(frameManager) {
300
+ this.wrapMethod(frameManager, 'getFrame', 'FrameManager.getFrame');
301
+ this.wrapMethod(frameManager, 'getFrameEvents', 'FrameManager.getFrameEvents');
302
+ this.wrapMethod(frameManager, 'getFrameAnchors', 'FrameManager.getFrameAnchors');
303
+ this.wrapMethod(frameManager, 'getHotStackContext', 'FrameManager.getHotStackContext');
304
+ }
305
+ /**
306
+ * Monitor database operations
307
+ */
308
+ monitorDatabaseOperations(db) {
309
+ const originalPrepare = db.prepare;
310
+ db.prepare = function (sql) {
311
+ const stmt = originalPrepare.call(this, sql);
312
+ return wrapStatement(stmt, sql);
313
+ };
314
+ }
315
+ /**
316
+ * Wrap a method with performance monitoring
317
+ */
318
+ wrapMethod(obj, methodName, operationName) {
319
+ const original = obj[methodName];
320
+ if (typeof original !== 'function')
321
+ return;
322
+ obj[methodName] = async function (...args) {
323
+ return getProfiler().timeFunction(operationName, () => original.apply(this, args));
324
+ };
325
+ }
326
+ }
327
+ /**
328
+ * Wrap a database statement with performance monitoring
329
+ */
330
+ function wrapStatement(stmt, sql) {
331
+ const operationName = `SQL.${sql.trim().split(' ')[0].toUpperCase()}`;
332
+ const originalRun = stmt.run;
333
+ const originalGet = stmt.get;
334
+ const originalAll = stmt.all;
335
+ stmt.run = function (...args) {
336
+ return getProfiler().timeFunction(`${operationName}.run`, () => originalRun.apply(this, args));
337
+ };
338
+ stmt.get = function (...args) {
339
+ return getProfiler().timeFunction(`${operationName}.get`, () => originalGet.apply(this, args));
340
+ };
341
+ stmt.all = function (...args) {
342
+ return getProfiler().timeFunction(`${operationName}.all`, () => originalAll.apply(this, args));
343
+ };
344
+ return stmt;
345
+ }
346
+ //# sourceMappingURL=performance-profiler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"performance-profiler.js","sourceRoot":"","sources":["../../../../src/core/performance/performance-profiler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,41 @@
1
+ /**
2
+ * Optimized Streaming JSONL Parser
3
+ * Memory-efficient parsing for large JSONL files with async streaming
4
+ */
5
+ import { Transform } from 'stream';
6
+ export interface ParseOptions {
7
+ maxLineLength?: number;
8
+ batchSize?: number;
9
+ filter?: (obj: any) => boolean;
10
+ transform?: (obj: any) => any;
11
+ onProgress?: (processed: number, total?: number) => void;
12
+ }
13
+ export declare class StreamingJSONLParser {
14
+ private readonly DEFAULT_BATCH_SIZE;
15
+ private readonly DEFAULT_MAX_LINE_LENGTH;
16
+ /**
17
+ * Stream-parse a JSONL file with batching and backpressure handling
18
+ */
19
+ parseStream<T = any>(filePath: string, options?: ParseOptions): AsyncGenerator<T[], void, unknown>;
20
+ /**
21
+ * Parse entire file into memory (use for smaller files)
22
+ */
23
+ parseAll<T = any>(filePath: string, options?: Omit<ParseOptions, 'batchSize'>): Promise<T[]>;
24
+ /**
25
+ * Process JSONL file with a custom processor function
26
+ */
27
+ process<T = any, R = void>(filePath: string, processor: (items: T[]) => Promise<R>, options?: ParseOptions): Promise<R[]>;
28
+ /**
29
+ * Create a transform stream for JSONL parsing
30
+ */
31
+ createTransformStream<T = any>(options?: ParseOptions): Transform;
32
+ /**
33
+ * Count lines in JSONL file without parsing
34
+ */
35
+ countLines(filePath: string): Promise<number>;
36
+ /**
37
+ * Sample random lines from JSONL file
38
+ */
39
+ sampleLines<T = any>(filePath: string, sampleRate: number, options?: Omit<ParseOptions, 'batchSize'>): AsyncGenerator<T, void, unknown>;
40
+ }
41
+ //# sourceMappingURL=streaming-jsonl-parser.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"streaming-jsonl-parser.d.ts","sourceRoot":"","sources":["../../../../src/core/performance/streaming-jsonl-parser.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,EAAE,SAAS,EAAY,MAAM,QAAQ,CAAC;AAM7C,MAAM,WAAW,YAAY;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,OAAO,CAAC;IAC/B,SAAS,CAAC,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,CAAC;IAC9B,UAAU,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;CAC1D;AAED,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAO;IAC1C,OAAO,CAAC,QAAQ,CAAC,uBAAuB,CAAe;IAEvD;;OAEG;IACI,WAAW,CAAC,CAAC,GAAG,GAAG,EACxB,QAAQ,EAAE,MAAM,EAChB,OAAO,GAAE,YAAiB,GACzB,cAAc,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC;IAmFrC;;OAEG;IACG,QAAQ,CAAC,CAAC,GAAG,GAAG,EACpB,QAAQ,EAAE,MAAM,EAChB,OAAO,GAAE,IAAI,CAAC,YAAY,EAAE,WAAW,CAAM,GAC5C,OAAO,CAAC,CAAC,EAAE,CAAC;IAaf;;OAEG;IACG,OAAO,CAAC,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,IAAI,EAC7B,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC,CAAC,EACrC,OAAO,GAAE,YAAiB,GACzB,OAAO,CAAC,CAAC,EAAE,CAAC;IAWf;;OAEG;IACH,qBAAqB,CAAC,CAAC,GAAG,GAAG,EAC3B,OAAO,GAAE,YAAiB,GACzB,SAAS;IAwDZ;;OAEG;IACG,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAYnD;;OAEG;IACI,WAAW,CAAC,CAAC,GAAG,GAAG,EACxB,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,OAAO,GAAE,IAAI,CAAC,YAAY,EAAE,WAAW,CAAM,GAC5C,cAAc,CAAC,CAAC,EAAE,IAAI,EAAE,OAAO,CAAC;CAapC"}
@@ -0,0 +1,193 @@
1
+ /**
2
+ * Optimized Streaming JSONL Parser
3
+ * Memory-efficient parsing for large JSONL files with async streaming
4
+ */
5
+ import { createReadStream } from 'fs';
6
+ import { createInterface } from 'readline';
7
+ import { Transform, pipeline } from 'stream';
8
+ import { promisify } from 'util';
9
+ import { logger } from '../monitoring/logger.js';
10
+ const pipelineAsync = promisify(pipeline);
11
+ export class StreamingJSONLParser {
12
+ DEFAULT_BATCH_SIZE = 100;
13
+ DEFAULT_MAX_LINE_LENGTH = 1024 * 1024; // 1MB per line
14
+ /**
15
+ * Stream-parse a JSONL file with batching and backpressure handling
16
+ */
17
+ async *parseStream(filePath, options = {}) {
18
+ const { batchSize = this.DEFAULT_BATCH_SIZE, maxLineLength = this.DEFAULT_MAX_LINE_LENGTH, filter, transform, onProgress, } = options;
19
+ const stream = createReadStream(filePath, {
20
+ encoding: 'utf8',
21
+ highWaterMark: 64 * 1024, // 64KB chunks
22
+ });
23
+ const rl = createInterface({
24
+ input: stream,
25
+ crlfDelay: Infinity,
26
+ historySize: 0, // Disable history for memory efficiency
27
+ });
28
+ let batch = [];
29
+ let lineCount = 0;
30
+ let processedCount = 0;
31
+ let errorCount = 0;
32
+ try {
33
+ for await (const line of rl) {
34
+ lineCount++;
35
+ if (line.length > maxLineLength) {
36
+ logger.warn('Skipping oversized line', {
37
+ lineNumber: lineCount,
38
+ length: line.length,
39
+ maxLength: maxLineLength,
40
+ });
41
+ errorCount++;
42
+ continue;
43
+ }
44
+ if (!line.trim())
45
+ continue;
46
+ try {
47
+ let obj = JSON.parse(line);
48
+ if (filter && !filter(obj))
49
+ continue;
50
+ if (transform)
51
+ obj = transform(obj);
52
+ batch.push(obj);
53
+ processedCount++;
54
+ if (batch.length >= batchSize) {
55
+ yield batch;
56
+ batch = [];
57
+ onProgress?.(processedCount);
58
+ }
59
+ }
60
+ catch (parseError) {
61
+ errorCount++;
62
+ logger.debug('Failed to parse JSONL line', {
63
+ lineNumber: lineCount,
64
+ error: parseError,
65
+ preview: line.substring(0, 100),
66
+ });
67
+ }
68
+ }
69
+ // Yield remaining items
70
+ if (batch.length > 0) {
71
+ yield batch;
72
+ onProgress?.(processedCount);
73
+ }
74
+ }
75
+ finally {
76
+ rl.close();
77
+ stream.destroy();
78
+ logger.debug('JSONL parsing complete', {
79
+ filePath,
80
+ totalLines: lineCount,
81
+ processed: processedCount,
82
+ errors: errorCount,
83
+ });
84
+ }
85
+ }
86
+ /**
87
+ * Parse entire file into memory (use for smaller files)
88
+ */
89
+ async parseAll(filePath, options = {}) {
90
+ const results = [];
91
+ for await (const batch of this.parseStream(filePath, {
92
+ ...options,
93
+ batchSize: Number.MAX_SAFE_INTEGER,
94
+ })) {
95
+ results.push(...batch);
96
+ }
97
+ return results;
98
+ }
99
+ /**
100
+ * Process JSONL file with a custom processor function
101
+ */
102
+ async process(filePath, processor, options = {}) {
103
+ const results = [];
104
+ for await (const batch of this.parseStream(filePath, options)) {
105
+ const result = await processor(batch);
106
+ results.push(result);
107
+ }
108
+ return results;
109
+ }
110
+ /**
111
+ * Create a transform stream for JSONL parsing
112
+ */
113
+ createTransformStream(options = {}) {
114
+ const { filter, transform, maxLineLength = this.DEFAULT_MAX_LINE_LENGTH } = options;
115
+ let buffer = '';
116
+ let lineCount = 0;
117
+ return new Transform({
118
+ objectMode: true,
119
+ transform(chunk, encoding, callback) {
120
+ buffer += chunk.toString();
121
+ const lines = buffer.split('\n');
122
+ // Keep incomplete line in buffer
123
+ buffer = lines.pop() || '';
124
+ for (const line of lines) {
125
+ lineCount++;
126
+ if (!line.trim())
127
+ continue;
128
+ if (line.length > maxLineLength) {
129
+ logger.warn('Skipping oversized line in transform', { lineCount });
130
+ continue;
131
+ }
132
+ try {
133
+ let obj = JSON.parse(line);
134
+ if (filter && !filter(obj))
135
+ continue;
136
+ if (transform)
137
+ obj = transform(obj);
138
+ this.push(obj);
139
+ }
140
+ catch (error) {
141
+ logger.debug('Transform parse error', { lineCount, error });
142
+ }
143
+ }
144
+ callback();
145
+ },
146
+ flush(callback) {
147
+ // Process any remaining data
148
+ if (buffer.trim()) {
149
+ try {
150
+ let obj = JSON.parse(buffer);
151
+ if (!filter || filter(obj)) {
152
+ if (transform)
153
+ obj = transform(obj);
154
+ this.push(obj);
155
+ }
156
+ }
157
+ catch (error) {
158
+ logger.debug('Flush parse error', { error });
159
+ }
160
+ }
161
+ callback();
162
+ }
163
+ });
164
+ }
165
+ /**
166
+ * Count lines in JSONL file without parsing
167
+ */
168
+ async countLines(filePath) {
169
+ const stream = createReadStream(filePath, { encoding: 'utf8' });
170
+ const rl = createInterface({ input: stream, historySize: 0 });
171
+ let count = 0;
172
+ for await (const _ of rl) {
173
+ count++;
174
+ }
175
+ return count;
176
+ }
177
+ /**
178
+ * Sample random lines from JSONL file
179
+ */
180
+ async *sampleLines(filePath, sampleRate, options = {}) {
181
+ if (sampleRate <= 0 || sampleRate > 1) {
182
+ throw new Error('Sample rate must be between 0 and 1');
183
+ }
184
+ for await (const batch of this.parseStream(filePath, options)) {
185
+ for (const item of batch) {
186
+ if (Math.random() < sampleRate) {
187
+ yield item;
188
+ }
189
+ }
190
+ }
191
+ }
192
+ }
193
+ //# sourceMappingURL=streaming-jsonl-parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"streaming-jsonl-parser.js","sourceRoot":"","sources":["../../../../src/core/performance/streaming-jsonl-parser.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"postgres-adapter.d.ts","sourceRoot":"","sources":["../../../../src/core/persistence/postgres-adapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,UAAU,EAAgC,MAAM,IAAI,CAAC;AACpE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EACL,kBAAkB,EAClB,WAAW,EACX,SAAS,EACT,WAAW,EACZ,MAAM,aAAa,CAAC;AAGrB,MAAM,WAAW,cAAe,SAAQ,UAAU;IAChD,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,qBAAa,eAAgB,YAAW,kBAAkB;IACxD,OAAO,CAAC,IAAI,CAAO;IACnB,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,aAAa,CAAS;gBAElB,MAAM,EAAE,cAAc;IAQ5B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAexB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAM3B,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IAqB5D,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIjC,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAIvB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAI/B,WAAW,IAAI,OAAO;YAIR,UAAU;YAaV,gBAAgB;YA+DhB,eAAe;YA6Bf,cAAc;IAiCtB,SAAS,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAe1C,WAAW,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAgBhD,eAAe,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,SAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IAmBrE,gBAAgB,CACpB,SAAS,EAAE,MAAM,EACjB,MAAM,CAAC,EAAE,MAAM,EACf,KAAK,SAAK,GACT,OAAO,CAAC,WAAW,EAAE,CAAC;IA0BnB,iBAAiB,CAAC,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;CAuG3D"}
1
+ {"version":3,"file":"postgres-adapter.d.ts","sourceRoot":"","sources":["../../../../src/core/persistence/postgres-adapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,UAAU,EAAgC,MAAM,IAAI,CAAC;AACpE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EACL,kBAAkB,EAClB,WAAW,EACX,SAAS,EACT,WAAW,EACZ,MAAM,aAAa,CAAC;AAGrB,MAAM,WAAW,cAAe,SAAQ,UAAU;IAChD,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,qBAAa,eAAgB,YAAW,kBAAkB;IACxD,OAAO,CAAC,IAAI,CAAO;IACnB,OAAO,CAAC,MAAM,CAAiB;IAC/B,OAAO,CAAC,aAAa,CAAS;gBAElB,MAAM,EAAE,cAAc;IAQ5B,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAexB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAM3B,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IAqB5D,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIjC,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAIvB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAI/B,WAAW,IAAI,OAAO;YAIR,UAAU;YAaV,gBAAgB;YA+EhB,eAAe;YA6Bf,cAAc;IAiCtB,SAAS,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAe1C,WAAW,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAgBhD,eAAe,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,SAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IAmBrE,gBAAgB,CACpB,SAAS,EAAE,MAAM,EACjB,MAAM,CAAC,EAAE,MAAM,EACf,KAAK,SAAK,GACT,OAAO,CAAC,WAAW,EAAE,CAAC;IA0BnB,iBAAiB,CAAC,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;CAuG3D"}
@@ -95,8 +95,7 @@ export class PostgresAdapter {
95
95
  timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
96
96
  type VARCHAR(100) NOT NULL,
97
97
  data JSONB NOT NULL,
98
- metadata JSONB,
99
- INDEX idx_traces_session_timestamp (session_id, timestamp)
98
+ metadata JSONB
100
99
  )`,
101
100
  // Context frames table
102
101
  `CREATE TABLE IF NOT EXISTS context_frames (
@@ -107,8 +106,7 @@ export class PostgresAdapter {
107
106
  summary TEXT,
108
107
  timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
109
108
  type VARCHAR(100) NOT NULL,
110
- metadata JSONB,
111
- INDEX idx_context_project_branch (project_id, branch)
109
+ metadata JSONB
112
110
  )`,
113
111
  // Decisions table
114
112
  `CREATE TABLE IF NOT EXISTS decisions (
@@ -124,6 +122,22 @@ export class PostgresAdapter {
124
122
  for (const query of queries) {
125
123
  await this.execute(query);
126
124
  }
125
+ // Create indexes separately (PostgreSQL doesn't support inline INDEX in CREATE TABLE)
126
+ const indexes = [
127
+ `CREATE INDEX IF NOT EXISTS idx_traces_session_timestamp
128
+ ON traces(session_id, timestamp)`,
129
+ `CREATE INDEX IF NOT EXISTS idx_context_project_branch
130
+ ON context_frames(project_id, branch)`,
131
+ `CREATE INDEX IF NOT EXISTS idx_traces_type
132
+ ON traces(type)`,
133
+ `CREATE INDEX IF NOT EXISTS idx_context_frames_timestamp
134
+ ON context_frames(timestamp)`,
135
+ `CREATE INDEX IF NOT EXISTS idx_decisions_project_session
136
+ ON decisions(project_id, session_id)`,
137
+ ];
138
+ for (const index of indexes) {
139
+ await this.execute(index);
140
+ }
127
141
  }
128
142
  async enableTimescale() {
129
143
  try {