@stackmemoryai/stackmemory 0.3.1 → 0.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (734) hide show
  1. package/README.md +52 -272
  2. package/dist/cli/commands/clear.js +191 -0
  3. package/dist/cli/commands/clear.js.map +7 -0
  4. package/dist/cli/commands/config.js +152 -1
  5. package/dist/cli/commands/config.js.map +2 -2
  6. package/dist/cli/commands/dashboard.js +178 -0
  7. package/dist/cli/commands/dashboard.js.map +7 -0
  8. package/dist/cli/commands/handoff.js +125 -8
  9. package/dist/cli/commands/handoff.js.map +2 -2
  10. package/dist/cli/commands/linear-create.js +132 -0
  11. package/dist/cli/commands/linear-create.js.map +7 -0
  12. package/dist/cli/commands/linear-list.js +69 -0
  13. package/dist/cli/commands/linear-list.js.map +7 -0
  14. package/dist/cli/commands/linear-migrate.js +40 -0
  15. package/dist/cli/commands/linear-migrate.js.map +7 -0
  16. package/dist/cli/commands/linear.js +185 -36
  17. package/dist/cli/commands/linear.js.map +2 -2
  18. package/dist/cli/commands/monitor.js +309 -0
  19. package/dist/cli/commands/monitor.js.map +7 -0
  20. package/dist/cli/commands/quality.js +414 -0
  21. package/dist/cli/commands/quality.js.map +7 -0
  22. package/dist/cli/commands/storage.js +275 -0
  23. package/dist/cli/commands/storage.js.map +7 -0
  24. package/dist/cli/commands/tui.js +66 -0
  25. package/dist/cli/commands/tui.js.map +7 -0
  26. package/dist/cli/commands/workflow.js +134 -0
  27. package/dist/cli/commands/workflow.js.map +7 -0
  28. package/dist/cli/index.js +104 -8
  29. package/dist/cli/index.js.map +3 -3
  30. package/dist/core/analytics/team-analytics.js +374 -0
  31. package/dist/core/analytics/team-analytics.js.map +7 -0
  32. package/dist/core/context/context-bridge.js +234 -0
  33. package/dist/core/context/context-bridge.js.map +7 -0
  34. package/dist/core/context/dual-stack-manager.js +850 -0
  35. package/dist/core/context/dual-stack-manager.js.map +7 -0
  36. package/dist/core/context/frame-handoff-manager.js +384 -0
  37. package/dist/core/context/frame-handoff-manager.js.map +7 -0
  38. package/dist/core/context/frame-manager.js +132 -12
  39. package/dist/core/context/frame-manager.js.map +2 -2
  40. package/dist/core/context/permission-manager.js +181 -0
  41. package/dist/core/context/permission-manager.js.map +7 -0
  42. package/dist/core/context/shared-context-layer.js +386 -0
  43. package/dist/core/context/shared-context-layer.js.map +7 -0
  44. package/dist/core/context/stack-merge-resolver.js +600 -0
  45. package/dist/core/context/stack-merge-resolver.js.map +7 -0
  46. package/dist/core/context/validation.js +121 -0
  47. package/dist/core/context/validation.js.map +7 -0
  48. package/dist/core/database/connection-pool.js +266 -175
  49. package/dist/core/database/connection-pool.js.map +2 -2
  50. package/dist/core/database/database-adapter.js +51 -0
  51. package/dist/core/database/database-adapter.js.map +7 -0
  52. package/dist/core/database/migration-manager.js +514 -0
  53. package/dist/core/database/migration-manager.js.map +7 -0
  54. package/dist/core/database/paradedb-adapter.js +970 -0
  55. package/dist/core/database/paradedb-adapter.js.map +7 -0
  56. package/dist/core/database/query-router.js +421 -0
  57. package/dist/core/database/query-router.js.map +7 -0
  58. package/dist/core/database/sqlite-adapter.js +547 -0
  59. package/dist/core/database/sqlite-adapter.js.map +7 -0
  60. package/dist/core/errors/index.js +21 -1
  61. package/dist/core/errors/index.js.map +2 -2
  62. package/dist/core/frame/workflow-templates-stub.js +42 -0
  63. package/dist/core/frame/workflow-templates-stub.js.map +7 -0
  64. package/dist/core/frame/workflow-templates.js +276 -0
  65. package/dist/core/frame/workflow-templates.js.map +7 -0
  66. package/dist/core/merge/conflict-detector.js +5 -2
  67. package/dist/core/merge/conflict-detector.js.map +2 -2
  68. package/dist/core/merge/resolution-engine.js +3 -14
  69. package/dist/core/merge/resolution-engine.js.map +2 -2
  70. package/dist/core/merge/stack-diff.js.map +2 -2
  71. package/dist/core/monitoring/logger.js +18 -3
  72. package/dist/core/monitoring/logger.js.map +2 -2
  73. package/dist/core/monitoring/session-monitor.js +296 -0
  74. package/dist/core/monitoring/session-monitor.js.map +7 -0
  75. package/dist/core/retrieval/context-retriever.js +475 -0
  76. package/dist/core/retrieval/context-retriever.js.map +7 -0
  77. package/dist/core/retrieval/graph-retrieval.js +658 -0
  78. package/dist/core/retrieval/graph-retrieval.js.map +7 -0
  79. package/dist/core/retrieval/hierarchical-retrieval.js +652 -0
  80. package/dist/core/retrieval/hierarchical-retrieval.js.map +7 -0
  81. package/dist/core/retrieval/retrieval-benchmarks.js +517 -0
  82. package/dist/core/retrieval/retrieval-benchmarks.js.map +7 -0
  83. package/dist/core/session/clear-survival-stub.js +49 -0
  84. package/dist/core/session/clear-survival-stub.js.map +7 -0
  85. package/dist/core/session/clear-survival.js +426 -0
  86. package/dist/core/session/clear-survival.js.map +7 -0
  87. package/dist/core/session/handoff-generator.js +339 -0
  88. package/dist/core/session/handoff-generator.js.map +7 -0
  89. package/dist/core/session/session-manager.js +61 -26
  90. package/dist/core/session/session-manager.js.map +3 -3
  91. package/dist/core/skills/index.js +3 -0
  92. package/dist/core/skills/index.js.map +7 -0
  93. package/dist/core/skills/skill-storage.js +749 -0
  94. package/dist/core/skills/skill-storage.js.map +7 -0
  95. package/dist/core/skills/types.js +189 -0
  96. package/dist/core/skills/types.js.map +7 -0
  97. package/dist/core/storage/railway-optimized-storage.js +550 -0
  98. package/dist/core/storage/railway-optimized-storage.js.map +7 -0
  99. package/dist/core/storage/remote-storage.js +456 -0
  100. package/dist/core/storage/remote-storage.js.map +7 -0
  101. package/dist/core/trace/trace-detector.js +136 -5
  102. package/dist/core/trace/trace-detector.js.map +2 -2
  103. package/dist/core/trace/trace-store.js.map +2 -2
  104. package/dist/features/tui/components/analytics-panel.js +136 -0
  105. package/dist/features/tui/components/analytics-panel.js.map +7 -0
  106. package/dist/features/tui/components/frame-visualizer.js +377 -0
  107. package/dist/features/tui/components/frame-visualizer.js.map +7 -0
  108. package/dist/features/tui/components/pr-tracker.js +123 -0
  109. package/dist/features/tui/components/pr-tracker.js.map +7 -0
  110. package/dist/features/tui/components/session-monitor.js +286 -0
  111. package/dist/features/tui/components/session-monitor.js.map +7 -0
  112. package/dist/features/tui/components/subagent-fleet.js +388 -0
  113. package/dist/features/tui/components/subagent-fleet.js.map +7 -0
  114. package/dist/features/tui/components/task-board.js +475 -0
  115. package/dist/features/tui/components/task-board.js.map +7 -0
  116. package/dist/features/tui/index.js +397 -0
  117. package/dist/features/tui/index.js.map +7 -0
  118. package/dist/features/tui/services/data-service.js +654 -0
  119. package/dist/features/tui/services/data-service.js.map +7 -0
  120. package/dist/features/tui/services/websocket-client.js +149 -0
  121. package/dist/features/tui/services/websocket-client.js.map +7 -0
  122. package/dist/features/tui/terminal-compat.js +205 -0
  123. package/dist/features/tui/terminal-compat.js.map +7 -0
  124. package/dist/features/tui/types.js +1 -0
  125. package/dist/features/tui/types.js.map +7 -0
  126. package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js +455 -0
  127. package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js.map +7 -0
  128. package/dist/integrations/claude-code/lifecycle-hooks.js +250 -0
  129. package/dist/integrations/claude-code/lifecycle-hooks.js.map +7 -0
  130. package/dist/integrations/claude-code/post-task-hooks.js +541 -0
  131. package/dist/integrations/claude-code/post-task-hooks.js.map +7 -0
  132. package/dist/integrations/linear/client.js +22 -4
  133. package/dist/integrations/linear/client.js.map +2 -2
  134. package/dist/integrations/linear/migration.js +299 -0
  135. package/dist/integrations/linear/migration.js.map +7 -0
  136. package/dist/integrations/linear/oauth-server.js +396 -0
  137. package/dist/integrations/linear/oauth-server.js.map +7 -0
  138. package/dist/integrations/linear/rest-client.js +199 -0
  139. package/dist/integrations/linear/rest-client.js.map +7 -0
  140. package/dist/integrations/linear/sync.js +14 -2
  141. package/dist/integrations/linear/sync.js.map +2 -2
  142. package/dist/integrations/linear/webhook-handler.js +200 -0
  143. package/dist/integrations/linear/webhook-handler.js.map +7 -0
  144. package/dist/integrations/mcp/handlers/skill-handlers.js +514 -0
  145. package/dist/integrations/mcp/handlers/skill-handlers.js.map +7 -0
  146. package/dist/integrations/mcp/middleware/tool-scoring.js +352 -0
  147. package/dist/integrations/mcp/middleware/tool-scoring.js.map +7 -0
  148. package/dist/integrations/mcp/refactored-server.js +31 -3
  149. package/dist/integrations/mcp/refactored-server.js.map +2 -2
  150. package/dist/integrations/mcp/server.js +25 -7
  151. package/dist/integrations/mcp/server.js.map +2 -2
  152. package/dist/mcp/stackmemory-mcp-server.js.map +1 -1
  153. package/dist/models/user.model.js +3 -0
  154. package/dist/models/user.model.js.map +2 -2
  155. package/dist/services/context-service.js.map +2 -2
  156. package/dist/utils/formatting.js +58 -0
  157. package/dist/utils/formatting.js.map +7 -0
  158. package/package.json +21 -5
  159. package/dist/cli/__tests__/index.test.js +0 -290
  160. package/dist/cli/__tests__/index.test.js.map +0 -7
  161. package/dist/core/config/__tests__/config-manager.test.js +0 -248
  162. package/dist/core/config/__tests__/config-manager.test.js.map +0 -7
  163. package/dist/core/context/__tests__/frame-manager.test.js +0 -879
  164. package/dist/core/context/__tests__/frame-manager.test.js.map +0 -7
  165. package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js +0 -379
  166. package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js.map +0 -7
  167. package/dist/core/digest/__tests__/frame-digest-integration.test.js +0 -230
  168. package/dist/core/digest/__tests__/frame-digest-integration.test.js.map +0 -7
  169. package/dist/core/errors/__tests__/error-handling.test.js +0 -270
  170. package/dist/core/errors/__tests__/error-handling.test.js.map +0 -7
  171. package/dist/core/merge/__tests__/conflict-scenarios.test.js +0 -414
  172. package/dist/core/merge/__tests__/conflict-scenarios.test.js.map +0 -7
  173. package/dist/core/query/__tests__/query-parser.test.js +0 -301
  174. package/dist/core/query/__tests__/query-parser.test.js.map +0 -7
  175. package/dist/core/query/__tests__/query-templates.test.js +0 -210
  176. package/dist/core/query/__tests__/query-templates.test.js.map +0 -7
  177. package/dist/core/trace/trace-detector.test.js +0 -401
  178. package/dist/core/trace/trace-detector.test.js.map +0 -7
  179. package/dist/features/tasks/__tests__/pebbles-task-store.test.js +0 -747
  180. package/dist/features/tasks/__tests__/pebbles-task-store.test.js.map +0 -7
  181. package/dist/integrations/linear/__tests__/auth.test.js +0 -558
  182. package/dist/integrations/linear/__tests__/auth.test.js.map +0 -7
  183. package/dist/integrations/linear/__tests__/sync-service.test.js +0 -760
  184. package/dist/integrations/linear/__tests__/sync-service.test.js.map +0 -7
  185. package/dist/integrations/mcp/__tests__/server.test.js +0 -798
  186. package/dist/integrations/mcp/__tests__/server.test.js.map +0 -7
  187. package/dist/scripts/benchmark-performance.d.ts +0 -7
  188. package/dist/scripts/benchmark-performance.d.ts.map +0 -1
  189. package/dist/scripts/benchmark-performance.js +0 -44
  190. package/dist/scripts/benchmark-performance.js.map +0 -1
  191. package/dist/scripts/cancel-duplicate-tasks.d.ts +0 -7
  192. package/dist/scripts/cancel-duplicate-tasks.d.ts.map +0 -1
  193. package/dist/scripts/cancel-duplicate-tasks.js +0 -172
  194. package/dist/scripts/cancel-duplicate-tasks.js.map +0 -1
  195. package/dist/scripts/cleanup-duplicate-tasks.d.ts +0 -12
  196. package/dist/scripts/cleanup-duplicate-tasks.d.ts.map +0 -1
  197. package/dist/scripts/cleanup-duplicate-tasks.js +0 -215
  198. package/dist/scripts/cleanup-duplicate-tasks.js.map +0 -1
  199. package/dist/scripts/initialize.d.ts +0 -6
  200. package/dist/scripts/initialize.d.ts.map +0 -1
  201. package/dist/scripts/initialize.js +0 -93
  202. package/dist/scripts/initialize.js.map +0 -1
  203. package/dist/scripts/list-linear-tasks.d.ts +0 -6
  204. package/dist/scripts/list-linear-tasks.d.ts.map +0 -1
  205. package/dist/scripts/list-linear-tasks.js +0 -121
  206. package/dist/scripts/list-linear-tasks.js.map +0 -1
  207. package/dist/scripts/merge-linear-duplicates-safe.d.ts +0 -7
  208. package/dist/scripts/merge-linear-duplicates-safe.d.ts.map +0 -1
  209. package/dist/scripts/merge-linear-duplicates-safe.js +0 -267
  210. package/dist/scripts/merge-linear-duplicates-safe.js.map +0 -1
  211. package/dist/scripts/show-linear-summary.d.ts +0 -6
  212. package/dist/scripts/show-linear-summary.d.ts.map +0 -1
  213. package/dist/scripts/show-linear-summary.js +0 -120
  214. package/dist/scripts/show-linear-summary.js.map +0 -1
  215. package/dist/scripts/status.d.ts +0 -6
  216. package/dist/scripts/status.d.ts.map +0 -1
  217. package/dist/scripts/status.js +0 -101
  218. package/dist/scripts/status.js.map +0 -1
  219. package/dist/src/agents/core/agent-task-manager.d.ts +0 -154
  220. package/dist/src/agents/core/agent-task-manager.d.ts.map +0 -1
  221. package/dist/src/agents/core/agent-task-manager.js +0 -504
  222. package/dist/src/agents/core/agent-task-manager.js.map +0 -1
  223. package/dist/src/agents/verifiers/base-verifier.d.ts +0 -112
  224. package/dist/src/agents/verifiers/base-verifier.d.ts.map +0 -1
  225. package/dist/src/agents/verifiers/base-verifier.js +0 -130
  226. package/dist/src/agents/verifiers/base-verifier.js.map +0 -1
  227. package/dist/src/agents/verifiers/formatter-verifier.d.ts +0 -14
  228. package/dist/src/agents/verifiers/formatter-verifier.d.ts.map +0 -1
  229. package/dist/src/agents/verifiers/formatter-verifier.js +0 -107
  230. package/dist/src/agents/verifiers/formatter-verifier.js.map +0 -1
  231. package/dist/src/agents/verifiers/llm-judge.d.ts +0 -46
  232. package/dist/src/agents/verifiers/llm-judge.d.ts.map +0 -1
  233. package/dist/src/agents/verifiers/llm-judge.js +0 -248
  234. package/dist/src/agents/verifiers/llm-judge.js.map +0 -1
  235. package/dist/src/cli/auto-detect.d.ts +0 -61
  236. package/dist/src/cli/auto-detect.d.ts.map +0 -1
  237. package/dist/src/cli/auto-detect.js +0 -350
  238. package/dist/src/cli/auto-detect.js.map +0 -1
  239. package/dist/src/cli/browser-test.d.ts +0 -6
  240. package/dist/src/cli/browser-test.d.ts.map +0 -1
  241. package/dist/src/cli/browser-test.js +0 -32
  242. package/dist/src/cli/browser-test.js.map +0 -1
  243. package/dist/src/cli/claude-sm.d.ts +0 -7
  244. package/dist/src/cli/claude-sm.d.ts.map +0 -1
  245. package/dist/src/cli/claude-sm.js +0 -412
  246. package/dist/src/cli/claude-sm.js.map +0 -1
  247. package/dist/src/cli/commands/agent.d.ts +0 -9
  248. package/dist/src/cli/commands/agent.d.ts.map +0 -1
  249. package/dist/src/cli/commands/agent.js +0 -303
  250. package/dist/src/cli/commands/agent.js.map +0 -1
  251. package/dist/src/cli/commands/config.d.ts +0 -6
  252. package/dist/src/cli/commands/config.d.ts.map +0 -1
  253. package/dist/src/cli/commands/config.js +0 -224
  254. package/dist/src/cli/commands/config.js.map +0 -1
  255. package/dist/src/cli/commands/context.d.ts +0 -7
  256. package/dist/src/cli/commands/context.d.ts.map +0 -1
  257. package/dist/src/cli/commands/context.js +0 -365
  258. package/dist/src/cli/commands/context.js.map +0 -1
  259. package/dist/src/cli/commands/handoff.d.ts +0 -6
  260. package/dist/src/cli/commands/handoff.d.ts.map +0 -1
  261. package/dist/src/cli/commands/handoff.js +0 -212
  262. package/dist/src/cli/commands/handoff.js.map +0 -1
  263. package/dist/src/cli/commands/linear-test.d.ts +0 -6
  264. package/dist/src/cli/commands/linear-test.d.ts.map +0 -1
  265. package/dist/src/cli/commands/linear-test.js +0 -123
  266. package/dist/src/cli/commands/linear-test.js.map +0 -1
  267. package/dist/src/cli/commands/linear.d.ts +0 -6
  268. package/dist/src/cli/commands/linear.d.ts.map +0 -1
  269. package/dist/src/cli/commands/linear.js +0 -393
  270. package/dist/src/cli/commands/linear.js.map +0 -1
  271. package/dist/src/cli/commands/log.d.ts +0 -7
  272. package/dist/src/cli/commands/log.d.ts.map +0 -1
  273. package/dist/src/cli/commands/log.js +0 -168
  274. package/dist/src/cli/commands/log.js.map +0 -1
  275. package/dist/src/cli/commands/onboard.d.ts +0 -8
  276. package/dist/src/cli/commands/onboard.d.ts.map +0 -1
  277. package/dist/src/cli/commands/onboard.js +0 -363
  278. package/dist/src/cli/commands/onboard.js.map +0 -1
  279. package/dist/src/cli/commands/projects.d.ts +0 -8
  280. package/dist/src/cli/commands/projects.d.ts.map +0 -1
  281. package/dist/src/cli/commands/projects.js +0 -220
  282. package/dist/src/cli/commands/projects.js.map +0 -1
  283. package/dist/src/cli/commands/search.d.ts +0 -7
  284. package/dist/src/cli/commands/search.d.ts.map +0 -1
  285. package/dist/src/cli/commands/search.js +0 -162
  286. package/dist/src/cli/commands/search.js.map +0 -1
  287. package/dist/src/cli/commands/session.d.ts +0 -7
  288. package/dist/src/cli/commands/session.d.ts.map +0 -1
  289. package/dist/src/cli/commands/session.js +0 -222
  290. package/dist/src/cli/commands/session.js.map +0 -1
  291. package/dist/src/cli/commands/tasks.d.ts +0 -7
  292. package/dist/src/cli/commands/tasks.d.ts.map +0 -1
  293. package/dist/src/cli/commands/tasks.js +0 -229
  294. package/dist/src/cli/commands/tasks.js.map +0 -1
  295. package/dist/src/cli/commands/webhook.d.ts +0 -3
  296. package/dist/src/cli/commands/webhook.d.ts.map +0 -1
  297. package/dist/src/cli/commands/webhook.js +0 -157
  298. package/dist/src/cli/commands/webhook.js.map +0 -1
  299. package/dist/src/cli/commands/worktree.d.ts +0 -8
  300. package/dist/src/cli/commands/worktree.d.ts.map +0 -1
  301. package/dist/src/cli/commands/worktree.js +0 -339
  302. package/dist/src/cli/commands/worktree.js.map +0 -1
  303. package/dist/src/cli/index.d.ts +0 -8
  304. package/dist/src/cli/index.d.ts.map +0 -1
  305. package/dist/src/cli/index.js +0 -995
  306. package/dist/src/cli/index.js.map +0 -1
  307. package/dist/src/cli/utils/viewer.d.ts +0 -3
  308. package/dist/src/cli/utils/viewer.d.ts.map +0 -1
  309. package/dist/src/cli/utils/viewer.js +0 -91
  310. package/dist/src/cli/utils/viewer.js.map +0 -1
  311. package/dist/src/core/config/config-manager.d.ts +0 -95
  312. package/dist/src/core/config/config-manager.d.ts.map +0 -1
  313. package/dist/src/core/config/config-manager.js +0 -359
  314. package/dist/src/core/config/config-manager.js.map +0 -1
  315. package/dist/src/core/config/types.d.ts +0 -72
  316. package/dist/src/core/config/types.d.ts.map +0 -1
  317. package/dist/src/core/config/types.js +0 -127
  318. package/dist/src/core/config/types.js.map +0 -1
  319. package/dist/src/core/context/auto-context.d.ts +0 -22
  320. package/dist/src/core/context/auto-context.d.ts.map +0 -1
  321. package/dist/src/core/context/auto-context.js +0 -77
  322. package/dist/src/core/context/auto-context.js.map +0 -1
  323. package/dist/src/core/context/compaction-handler.d.ts +0 -119
  324. package/dist/src/core/context/compaction-handler.d.ts.map +0 -1
  325. package/dist/src/core/context/compaction-handler.js +0 -306
  326. package/dist/src/core/context/compaction-handler.js.map +0 -1
  327. package/dist/src/core/context/frame-database.d.ts +0 -59
  328. package/dist/src/core/context/frame-database.d.ts.map +0 -1
  329. package/dist/src/core/context/frame-database.js +0 -333
  330. package/dist/src/core/context/frame-database.js.map +0 -1
  331. package/dist/src/core/context/frame-digest.d.ts +0 -59
  332. package/dist/src/core/context/frame-digest.d.ts.map +0 -1
  333. package/dist/src/core/context/frame-digest.js +0 -264
  334. package/dist/src/core/context/frame-digest.js.map +0 -1
  335. package/dist/src/core/context/frame-manager.d.ts +0 -112
  336. package/dist/src/core/context/frame-manager.d.ts.map +0 -1
  337. package/dist/src/core/context/frame-manager.js +0 -600
  338. package/dist/src/core/context/frame-manager.js.map +0 -1
  339. package/dist/src/core/context/frame-stack.d.ts +0 -85
  340. package/dist/src/core/context/frame-stack.d.ts.map +0 -1
  341. package/dist/src/core/context/frame-stack.js +0 -287
  342. package/dist/src/core/context/frame-stack.js.map +0 -1
  343. package/dist/src/core/context/frame-types.d.ts +0 -67
  344. package/dist/src/core/context/frame-types.d.ts.map +0 -1
  345. package/dist/src/core/context/frame-types.js +0 -6
  346. package/dist/src/core/context/frame-types.js.map +0 -1
  347. package/dist/src/core/context/index.d.ts +0 -11
  348. package/dist/src/core/context/index.d.ts.map +0 -1
  349. package/dist/src/core/context/index.js +0 -14
  350. package/dist/src/core/context/index.js.map +0 -1
  351. package/dist/src/core/context/model-aware-compaction.d.ts +0 -101
  352. package/dist/src/core/context/model-aware-compaction.d.ts.map +0 -1
  353. package/dist/src/core/context/model-aware-compaction.js +0 -616
  354. package/dist/src/core/context/model-aware-compaction.js.map +0 -1
  355. package/dist/src/core/context/refactored-frame-manager.d.ts +0 -99
  356. package/dist/src/core/context/refactored-frame-manager.d.ts.map +0 -1
  357. package/dist/src/core/context/refactored-frame-manager.js +0 -340
  358. package/dist/src/core/context/refactored-frame-manager.js.map +0 -1
  359. package/dist/src/core/database/batch-operations.d.ts +0 -118
  360. package/dist/src/core/database/batch-operations.d.ts.map +0 -1
  361. package/dist/src/core/database/batch-operations.js +0 -339
  362. package/dist/src/core/database/batch-operations.js.map +0 -1
  363. package/dist/src/core/database/connection-pool.d.ts +0 -79
  364. package/dist/src/core/database/connection-pool.d.ts.map +0 -1
  365. package/dist/src/core/database/connection-pool.js +0 -236
  366. package/dist/src/core/database/connection-pool.js.map +0 -1
  367. package/dist/src/core/database/query-cache.d.ts +0 -135
  368. package/dist/src/core/database/query-cache.d.ts.map +0 -1
  369. package/dist/src/core/database/query-cache.js +0 -294
  370. package/dist/src/core/database/query-cache.js.map +0 -1
  371. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts +0 -125
  372. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts.map +0 -1
  373. package/dist/src/core/digest/enhanced-hybrid-digest.js +0 -282
  374. package/dist/src/core/digest/enhanced-hybrid-digest.js.map +0 -1
  375. package/dist/src/core/digest/frame-digest-integration.d.ts +0 -67
  376. package/dist/src/core/digest/frame-digest-integration.d.ts.map +0 -1
  377. package/dist/src/core/digest/frame-digest-integration.js +0 -198
  378. package/dist/src/core/digest/frame-digest-integration.js.map +0 -1
  379. package/dist/src/core/digest/hybrid-digest-generator.d.ts +0 -76
  380. package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +0 -1
  381. package/dist/src/core/digest/hybrid-digest-generator.js +0 -629
  382. package/dist/src/core/digest/hybrid-digest-generator.js.map +0 -1
  383. package/dist/src/core/digest/index.d.ts +0 -9
  384. package/dist/src/core/digest/index.d.ts.map +0 -1
  385. package/dist/src/core/digest/index.js +0 -9
  386. package/dist/src/core/digest/index.js.map +0 -1
  387. package/dist/src/core/digest/types.d.ts +0 -154
  388. package/dist/src/core/digest/types.d.ts.map +0 -1
  389. package/dist/src/core/digest/types.js +0 -18
  390. package/dist/src/core/digest/types.js.map +0 -1
  391. package/dist/src/core/errors/index.d.ts +0 -143
  392. package/dist/src/core/errors/index.d.ts.map +0 -1
  393. package/dist/src/core/errors/index.js +0 -282
  394. package/dist/src/core/errors/index.js.map +0 -1
  395. package/dist/src/core/errors/recovery.d.ts +0 -86
  396. package/dist/src/core/errors/recovery.d.ts.map +0 -1
  397. package/dist/src/core/errors/recovery.js +0 -274
  398. package/dist/src/core/errors/recovery.js.map +0 -1
  399. package/dist/src/core/merge/conflict-detector.d.ts +0 -122
  400. package/dist/src/core/merge/conflict-detector.d.ts.map +0 -1
  401. package/dist/src/core/merge/conflict-detector.js +0 -468
  402. package/dist/src/core/merge/conflict-detector.js.map +0 -1
  403. package/dist/src/core/merge/index.d.ts +0 -9
  404. package/dist/src/core/merge/index.d.ts.map +0 -1
  405. package/dist/src/core/merge/index.js +0 -9
  406. package/dist/src/core/merge/index.js.map +0 -1
  407. package/dist/src/core/merge/resolution-engine.d.ts +0 -120
  408. package/dist/src/core/merge/resolution-engine.d.ts.map +0 -1
  409. package/dist/src/core/merge/resolution-engine.js +0 -573
  410. package/dist/src/core/merge/resolution-engine.js.map +0 -1
  411. package/dist/src/core/merge/stack-diff.d.ts +0 -97
  412. package/dist/src/core/merge/stack-diff.d.ts.map +0 -1
  413. package/dist/src/core/merge/stack-diff.js +0 -516
  414. package/dist/src/core/merge/stack-diff.js.map +0 -1
  415. package/dist/src/core/merge/types.d.ts +0 -110
  416. package/dist/src/core/merge/types.d.ts.map +0 -1
  417. package/dist/src/core/merge/types.js +0 -6
  418. package/dist/src/core/merge/types.js.map +0 -1
  419. package/dist/src/core/monitoring/error-handler.d.ts +0 -46
  420. package/dist/src/core/monitoring/error-handler.d.ts.map +0 -1
  421. package/dist/src/core/monitoring/error-handler.js +0 -212
  422. package/dist/src/core/monitoring/error-handler.js.map +0 -1
  423. package/dist/src/core/monitoring/logger.d.ts +0 -24
  424. package/dist/src/core/monitoring/logger.d.ts.map +0 -1
  425. package/dist/src/core/monitoring/logger.js +0 -126
  426. package/dist/src/core/monitoring/logger.js.map +0 -1
  427. package/dist/src/core/monitoring/metrics.d.ts +0 -10
  428. package/dist/src/core/monitoring/metrics.d.ts.map +0 -1
  429. package/dist/src/core/monitoring/metrics.js +0 -152
  430. package/dist/src/core/monitoring/metrics.js.map +0 -1
  431. package/dist/src/core/monitoring/progress-tracker.d.ts +0 -95
  432. package/dist/src/core/monitoring/progress-tracker.d.ts.map +0 -1
  433. package/dist/src/core/monitoring/progress-tracker.js +0 -178
  434. package/dist/src/core/monitoring/progress-tracker.js.map +0 -1
  435. package/dist/src/core/performance/context-cache.d.ts +0 -109
  436. package/dist/src/core/performance/context-cache.d.ts.map +0 -1
  437. package/dist/src/core/performance/context-cache.js +0 -280
  438. package/dist/src/core/performance/context-cache.js.map +0 -1
  439. package/dist/src/core/performance/index.d.ts +0 -3
  440. package/dist/src/core/performance/index.d.ts.map +0 -1
  441. package/dist/src/core/performance/index.js +0 -3
  442. package/dist/src/core/performance/index.js.map +0 -1
  443. package/dist/src/core/performance/lazy-context-loader.d.ts +0 -93
  444. package/dist/src/core/performance/lazy-context-loader.d.ts.map +0 -1
  445. package/dist/src/core/performance/lazy-context-loader.js +0 -332
  446. package/dist/src/core/performance/lazy-context-loader.js.map +0 -1
  447. package/dist/src/core/performance/monitor.d.ts +0 -48
  448. package/dist/src/core/performance/monitor.d.ts.map +0 -1
  449. package/dist/src/core/performance/monitor.js +0 -226
  450. package/dist/src/core/performance/monitor.js.map +0 -1
  451. package/dist/src/core/performance/optimized-frame-context.d.ts +0 -74
  452. package/dist/src/core/performance/optimized-frame-context.d.ts.map +0 -1
  453. package/dist/src/core/performance/optimized-frame-context.js +0 -330
  454. package/dist/src/core/performance/optimized-frame-context.js.map +0 -1
  455. package/dist/src/core/performance/performance-benchmark.d.ts +0 -50
  456. package/dist/src/core/performance/performance-benchmark.d.ts.map +0 -1
  457. package/dist/src/core/performance/performance-benchmark.js +0 -290
  458. package/dist/src/core/performance/performance-benchmark.js.map +0 -1
  459. package/dist/src/core/performance/performance-profiler.d.ts +0 -151
  460. package/dist/src/core/performance/performance-profiler.d.ts.map +0 -1
  461. package/dist/src/core/performance/performance-profiler.js +0 -346
  462. package/dist/src/core/performance/performance-profiler.js.map +0 -1
  463. package/dist/src/core/performance/streaming-jsonl-parser.d.ts +0 -41
  464. package/dist/src/core/performance/streaming-jsonl-parser.d.ts.map +0 -1
  465. package/dist/src/core/performance/streaming-jsonl-parser.js +0 -193
  466. package/dist/src/core/performance/streaming-jsonl-parser.js.map +0 -1
  467. package/dist/src/core/persistence/postgres-adapter.d.ts +0 -31
  468. package/dist/src/core/persistence/postgres-adapter.d.ts.map +0 -1
  469. package/dist/src/core/persistence/postgres-adapter.js +0 -330
  470. package/dist/src/core/persistence/postgres-adapter.js.map +0 -1
  471. package/dist/src/core/projects/project-manager.d.ts +0 -130
  472. package/dist/src/core/projects/project-manager.d.ts.map +0 -1
  473. package/dist/src/core/projects/project-manager.js +0 -709
  474. package/dist/src/core/projects/project-manager.js.map +0 -1
  475. package/dist/src/core/query/query-parser.d.ts +0 -109
  476. package/dist/src/core/query/query-parser.d.ts.map +0 -1
  477. package/dist/src/core/query/query-parser.js +0 -415
  478. package/dist/src/core/query/query-parser.js.map +0 -1
  479. package/dist/src/core/query/query-templates.d.ts +0 -44
  480. package/dist/src/core/query/query-templates.d.ts.map +0 -1
  481. package/dist/src/core/query/query-templates.js +0 -326
  482. package/dist/src/core/query/query-templates.js.map +0 -1
  483. package/dist/src/core/retrieval/index.d.ts +0 -8
  484. package/dist/src/core/retrieval/index.d.ts.map +0 -1
  485. package/dist/src/core/retrieval/index.js +0 -8
  486. package/dist/src/core/retrieval/index.js.map +0 -1
  487. package/dist/src/core/retrieval/llm-context-retrieval.d.ts +0 -73
  488. package/dist/src/core/retrieval/llm-context-retrieval.d.ts.map +0 -1
  489. package/dist/src/core/retrieval/llm-context-retrieval.js +0 -597
  490. package/dist/src/core/retrieval/llm-context-retrieval.js.map +0 -1
  491. package/dist/src/core/retrieval/summary-generator.d.ts +0 -63
  492. package/dist/src/core/retrieval/summary-generator.d.ts.map +0 -1
  493. package/dist/src/core/retrieval/summary-generator.js +0 -622
  494. package/dist/src/core/retrieval/summary-generator.js.map +0 -1
  495. package/dist/src/core/retrieval/types.d.ts +0 -257
  496. package/dist/src/core/retrieval/types.d.ts.map +0 -1
  497. package/dist/src/core/retrieval/types.js +0 -18
  498. package/dist/src/core/retrieval/types.js.map +0 -1
  499. package/dist/src/core/session/index.d.ts +0 -2
  500. package/dist/src/core/session/index.d.ts.map +0 -1
  501. package/dist/src/core/session/index.js +0 -2
  502. package/dist/src/core/session/index.js.map +0 -1
  503. package/dist/src/core/session/session-manager.d.ts +0 -69
  504. package/dist/src/core/session/session-manager.d.ts.map +0 -1
  505. package/dist/src/core/session/session-manager.js +0 -311
  506. package/dist/src/core/session/session-manager.js.map +0 -1
  507. package/dist/src/core/trace/cli-trace-wrapper.d.ts +0 -23
  508. package/dist/src/core/trace/cli-trace-wrapper.d.ts.map +0 -1
  509. package/dist/src/core/trace/cli-trace-wrapper.js +0 -141
  510. package/dist/src/core/trace/cli-trace-wrapper.js.map +0 -1
  511. package/dist/src/core/trace/db-trace-wrapper.d.ts +0 -36
  512. package/dist/src/core/trace/db-trace-wrapper.d.ts.map +0 -1
  513. package/dist/src/core/trace/db-trace-wrapper.js +0 -252
  514. package/dist/src/core/trace/db-trace-wrapper.js.map +0 -1
  515. package/dist/src/core/trace/debug-trace.d.ts +0 -84
  516. package/dist/src/core/trace/debug-trace.d.ts.map +0 -1
  517. package/dist/src/core/trace/debug-trace.js +0 -402
  518. package/dist/src/core/trace/debug-trace.js.map +0 -1
  519. package/dist/src/core/trace/error-test.d.ts +0 -6
  520. package/dist/src/core/trace/error-test.d.ts.map +0 -1
  521. package/dist/src/core/trace/error-test.js +0 -128
  522. package/dist/src/core/trace/error-test.js.map +0 -1
  523. package/dist/src/core/trace/index.d.ts +0 -25
  524. package/dist/src/core/trace/index.d.ts.map +0 -1
  525. package/dist/src/core/trace/index.js +0 -121
  526. package/dist/src/core/trace/index.js.map +0 -1
  527. package/dist/src/core/trace/linear-api-wrapper.d.ts +0 -17
  528. package/dist/src/core/trace/linear-api-wrapper.d.ts.map +0 -1
  529. package/dist/src/core/trace/linear-api-wrapper.js +0 -205
  530. package/dist/src/core/trace/linear-api-wrapper.js.map +0 -1
  531. package/dist/src/core/trace/performance-test.d.ts +0 -6
  532. package/dist/src/core/trace/performance-test.d.ts.map +0 -1
  533. package/dist/src/core/trace/performance-test.js +0 -111
  534. package/dist/src/core/trace/performance-test.js.map +0 -1
  535. package/dist/src/core/trace/trace-demo.d.ts +0 -8
  536. package/dist/src/core/trace/trace-demo.d.ts.map +0 -1
  537. package/dist/src/core/trace/trace-demo.js +0 -154
  538. package/dist/src/core/trace/trace-demo.js.map +0 -1
  539. package/dist/src/core/trace/trace-detector.d.ts +0 -108
  540. package/dist/src/core/trace/trace-detector.d.ts.map +0 -1
  541. package/dist/src/core/trace/trace-detector.demo.d.ts +0 -5
  542. package/dist/src/core/trace/trace-detector.demo.d.ts.map +0 -1
  543. package/dist/src/core/trace/trace-detector.demo.js +0 -145
  544. package/dist/src/core/trace/trace-detector.demo.js.map +0 -1
  545. package/dist/src/core/trace/trace-detector.js +0 -425
  546. package/dist/src/core/trace/trace-detector.js.map +0 -1
  547. package/dist/src/core/trace/trace-store.d.ts +0 -60
  548. package/dist/src/core/trace/trace-store.d.ts.map +0 -1
  549. package/dist/src/core/trace/trace-store.js +0 -323
  550. package/dist/src/core/trace/trace-store.js.map +0 -1
  551. package/dist/src/core/trace/types.d.ts +0 -81
  552. package/dist/src/core/trace/types.d.ts.map +0 -1
  553. package/dist/src/core/trace/types.js +0 -70
  554. package/dist/src/core/trace/types.js.map +0 -1
  555. package/dist/src/core/types.d.ts +0 -35
  556. package/dist/src/core/types.d.ts.map +0 -1
  557. package/dist/src/core/types.js +0 -2
  558. package/dist/src/core/types.js.map +0 -1
  559. package/dist/src/core/utils/update-checker.d.ts +0 -38
  560. package/dist/src/core/utils/update-checker.d.ts.map +0 -1
  561. package/dist/src/core/utils/update-checker.js +0 -213
  562. package/dist/src/core/utils/update-checker.js.map +0 -1
  563. package/dist/src/core/worktree/worktree-manager.d.ts +0 -110
  564. package/dist/src/core/worktree/worktree-manager.d.ts.map +0 -1
  565. package/dist/src/core/worktree/worktree-manager.js +0 -456
  566. package/dist/src/core/worktree/worktree-manager.js.map +0 -1
  567. package/dist/src/features/analytics/api/analytics-api.d.ts +0 -24
  568. package/dist/src/features/analytics/api/analytics-api.d.ts.map +0 -1
  569. package/dist/src/features/analytics/api/analytics-api.js +0 -289
  570. package/dist/src/features/analytics/api/analytics-api.js.map +0 -1
  571. package/dist/src/features/analytics/core/analytics-service.d.ts +0 -29
  572. package/dist/src/features/analytics/core/analytics-service.d.ts.map +0 -1
  573. package/dist/src/features/analytics/core/analytics-service.js +0 -275
  574. package/dist/src/features/analytics/core/analytics-service.js.map +0 -1
  575. package/dist/src/features/analytics/index.d.ts +0 -12
  576. package/dist/src/features/analytics/index.d.ts.map +0 -1
  577. package/dist/src/features/analytics/index.js +0 -11
  578. package/dist/src/features/analytics/index.js.map +0 -1
  579. package/dist/src/features/analytics/queries/metrics-queries.d.ts +0 -11
  580. package/dist/src/features/analytics/queries/metrics-queries.d.ts.map +0 -1
  581. package/dist/src/features/analytics/queries/metrics-queries.js +0 -240
  582. package/dist/src/features/analytics/queries/metrics-queries.js.map +0 -1
  583. package/dist/src/features/analytics/types/metrics.d.ts +0 -60
  584. package/dist/src/features/analytics/types/metrics.d.ts.map +0 -1
  585. package/dist/src/features/analytics/types/metrics.js +0 -2
  586. package/dist/src/features/analytics/types/metrics.js.map +0 -1
  587. package/dist/src/features/browser/browser-mcp.d.ts +0 -94
  588. package/dist/src/features/browser/browser-mcp.d.ts.map +0 -1
  589. package/dist/src/features/browser/browser-mcp.js +0 -459
  590. package/dist/src/features/browser/browser-mcp.js.map +0 -1
  591. package/dist/src/features/tasks/pebbles-task-store.d.ts +0 -128
  592. package/dist/src/features/tasks/pebbles-task-store.d.ts.map +0 -1
  593. package/dist/src/features/tasks/pebbles-task-store.js +0 -572
  594. package/dist/src/features/tasks/pebbles-task-store.js.map +0 -1
  595. package/dist/src/features/tasks/task-aware-context.d.ts +0 -103
  596. package/dist/src/features/tasks/task-aware-context.d.ts.map +0 -1
  597. package/dist/src/features/tasks/task-aware-context.js +0 -412
  598. package/dist/src/features/tasks/task-aware-context.js.map +0 -1
  599. package/dist/src/index.d.ts +0 -21
  600. package/dist/src/index.d.ts.map +0 -1
  601. package/dist/src/index.js +0 -9
  602. package/dist/src/index.js.map +0 -1
  603. package/dist/src/integrations/linear/auth.d.ts +0 -99
  604. package/dist/src/integrations/linear/auth.d.ts.map +0 -1
  605. package/dist/src/integrations/linear/auth.js +0 -319
  606. package/dist/src/integrations/linear/auth.js.map +0 -1
  607. package/dist/src/integrations/linear/auto-sync.d.ts +0 -77
  608. package/dist/src/integrations/linear/auto-sync.d.ts.map +0 -1
  609. package/dist/src/integrations/linear/auto-sync.js +0 -268
  610. package/dist/src/integrations/linear/auto-sync.js.map +0 -1
  611. package/dist/src/integrations/linear/client.d.ts +0 -127
  612. package/dist/src/integrations/linear/client.d.ts.map +0 -1
  613. package/dist/src/integrations/linear/client.js +0 -446
  614. package/dist/src/integrations/linear/client.js.map +0 -1
  615. package/dist/src/integrations/linear/config.d.ts +0 -51
  616. package/dist/src/integrations/linear/config.d.ts.map +0 -1
  617. package/dist/src/integrations/linear/config.js +0 -103
  618. package/dist/src/integrations/linear/config.js.map +0 -1
  619. package/dist/src/integrations/linear/sync-manager.d.ts +0 -78
  620. package/dist/src/integrations/linear/sync-manager.d.ts.map +0 -1
  621. package/dist/src/integrations/linear/sync-manager.js +0 -235
  622. package/dist/src/integrations/linear/sync-manager.js.map +0 -1
  623. package/dist/src/integrations/linear/sync-service.d.ts +0 -46
  624. package/dist/src/integrations/linear/sync-service.d.ts.map +0 -1
  625. package/dist/src/integrations/linear/sync-service.js +0 -217
  626. package/dist/src/integrations/linear/sync-service.js.map +0 -1
  627. package/dist/src/integrations/linear/sync.d.ts +0 -125
  628. package/dist/src/integrations/linear/sync.d.ts.map +0 -1
  629. package/dist/src/integrations/linear/sync.js +0 -563
  630. package/dist/src/integrations/linear/sync.js.map +0 -1
  631. package/dist/src/integrations/linear/types.d.ts +0 -90
  632. package/dist/src/integrations/linear/types.d.ts.map +0 -1
  633. package/dist/src/integrations/linear/types.js +0 -2
  634. package/dist/src/integrations/linear/types.js.map +0 -1
  635. package/dist/src/integrations/linear/webhook-server.d.ts +0 -32
  636. package/dist/src/integrations/linear/webhook-server.d.ts.map +0 -1
  637. package/dist/src/integrations/linear/webhook-server.js +0 -190
  638. package/dist/src/integrations/linear/webhook-server.js.map +0 -1
  639. package/dist/src/integrations/linear/webhook.d.ts +0 -108
  640. package/dist/src/integrations/linear/webhook.d.ts.map +0 -1
  641. package/dist/src/integrations/linear/webhook.js +0 -291
  642. package/dist/src/integrations/linear/webhook.js.map +0 -1
  643. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts +0 -39
  644. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts.map +0 -1
  645. package/dist/src/integrations/mcp/handlers/context-handlers.js +0 -266
  646. package/dist/src/integrations/mcp/handlers/context-handlers.js.map +0 -1
  647. package/dist/src/integrations/mcp/handlers/index.d.ts +0 -37
  648. package/dist/src/integrations/mcp/handlers/index.d.ts.map +0 -1
  649. package/dist/src/integrations/mcp/handlers/index.js +0 -134
  650. package/dist/src/integrations/mcp/handlers/index.js.map +0 -1
  651. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts +0 -33
  652. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts.map +0 -1
  653. package/dist/src/integrations/mcp/handlers/linear-handlers.js +0 -251
  654. package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +0 -1
  655. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts +0 -42
  656. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts.map +0 -1
  657. package/dist/src/integrations/mcp/handlers/task-handlers.js +0 -238
  658. package/dist/src/integrations/mcp/handlers/task-handlers.js.map +0 -1
  659. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts +0 -41
  660. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts.map +0 -1
  661. package/dist/src/integrations/mcp/handlers/trace-handlers.js +0 -298
  662. package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +0 -1
  663. package/dist/src/integrations/mcp/index.d.ts +0 -13
  664. package/dist/src/integrations/mcp/index.d.ts.map +0 -1
  665. package/dist/src/integrations/mcp/index.js +0 -17
  666. package/dist/src/integrations/mcp/index.js.map +0 -1
  667. package/dist/src/integrations/mcp/refactored-server.d.ts +0 -76
  668. package/dist/src/integrations/mcp/refactored-server.d.ts.map +0 -1
  669. package/dist/src/integrations/mcp/refactored-server.js +0 -351
  670. package/dist/src/integrations/mcp/refactored-server.js.map +0 -1
  671. package/dist/src/integrations/mcp/server.d.ts +0 -54
  672. package/dist/src/integrations/mcp/server.d.ts.map +0 -1
  673. package/dist/src/integrations/mcp/server.js +0 -1616
  674. package/dist/src/integrations/mcp/server.js.map +0 -1
  675. package/dist/src/integrations/mcp/tool-definitions.d.ts +0 -44
  676. package/dist/src/integrations/mcp/tool-definitions.d.ts.map +0 -1
  677. package/dist/src/integrations/mcp/tool-definitions.js +0 -563
  678. package/dist/src/integrations/mcp/tool-definitions.js.map +0 -1
  679. package/dist/src/integrations/mcp/trace-test.d.ts +0 -5
  680. package/dist/src/integrations/mcp/trace-test.d.ts.map +0 -1
  681. package/dist/src/integrations/mcp/trace-test.js +0 -54
  682. package/dist/src/integrations/mcp/trace-test.js.map +0 -1
  683. package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts +0 -48
  684. package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts.map +0 -1
  685. package/dist/src/integrations/pg-aiguide/embedding-provider.js +0 -190
  686. package/dist/src/integrations/pg-aiguide/embedding-provider.js.map +0 -1
  687. package/dist/src/integrations/pg-aiguide/semantic-search.d.ts +0 -34
  688. package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +0 -1
  689. package/dist/src/integrations/pg-aiguide/semantic-search.js +0 -176
  690. package/dist/src/integrations/pg-aiguide/semantic-search.js.map +0 -1
  691. package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts +0 -44
  692. package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts.map +0 -1
  693. package/dist/src/integrations/pg-aiguide/timescale-analytics.js +0 -215
  694. package/dist/src/integrations/pg-aiguide/timescale-analytics.js.map +0 -1
  695. package/dist/src/mcp/stackmemory-mcp-server.d.ts +0 -9
  696. package/dist/src/mcp/stackmemory-mcp-server.d.ts.map +0 -1
  697. package/dist/src/mcp/stackmemory-mcp-server.js +0 -519
  698. package/dist/src/mcp/stackmemory-mcp-server.js.map +0 -1
  699. package/dist/src/middleware/exponential-rate-limiter.d.ts +0 -78
  700. package/dist/src/middleware/exponential-rate-limiter.d.ts.map +0 -1
  701. package/dist/src/middleware/exponential-rate-limiter.js +0 -293
  702. package/dist/src/middleware/exponential-rate-limiter.js.map +0 -1
  703. package/dist/src/models/user.model.d.ts +0 -62
  704. package/dist/src/models/user.model.d.ts.map +0 -1
  705. package/dist/src/models/user.model.js +0 -311
  706. package/dist/src/models/user.model.js.map +0 -1
  707. package/dist/src/servers/production/auth-middleware.d.ts +0 -76
  708. package/dist/src/servers/production/auth-middleware.d.ts.map +0 -1
  709. package/dist/src/servers/production/auth-middleware.js +0 -558
  710. package/dist/src/servers/production/auth-middleware.js.map +0 -1
  711. package/dist/src/servers/railway/index.d.ts +0 -7
  712. package/dist/src/servers/railway/index.d.ts.map +0 -1
  713. package/dist/src/servers/railway/index.js +0 -401
  714. package/dist/src/servers/railway/index.js.map +0 -1
  715. package/dist/src/services/config-service.d.ts +0 -44
  716. package/dist/src/services/config-service.d.ts.map +0 -1
  717. package/dist/src/services/config-service.js +0 -61
  718. package/dist/src/services/config-service.js.map +0 -1
  719. package/dist/src/services/context-service.d.ts +0 -17
  720. package/dist/src/services/context-service.d.ts.map +0 -1
  721. package/dist/src/services/context-service.js +0 -173
  722. package/dist/src/services/context-service.js.map +0 -1
  723. package/dist/src/types/task.d.ts +0 -27
  724. package/dist/src/types/task.d.ts.map +0 -1
  725. package/dist/src/types/task.js +0 -2
  726. package/dist/src/types/task.js.map +0 -1
  727. package/dist/src/utils/logger.d.ts +0 -13
  728. package/dist/src/utils/logger.d.ts.map +0 -1
  729. package/dist/src/utils/logger.js +0 -52
  730. package/dist/src/utils/logger.js.map +0 -1
  731. package/dist/src/validation/schemas.d.ts +0 -633
  732. package/dist/src/validation/schemas.d.ts.map +0 -1
  733. package/dist/src/validation/schemas.js +0 -347
  734. package/dist/src/validation/schemas.js.map +0 -1
@@ -0,0 +1,970 @@
1
+ import { Pool } from "pg";
2
+ import {
3
+ FeatureAwareDatabaseAdapter
4
+ } from "./database-adapter.js";
5
+ import { logger } from "../monitoring/logger.js";
6
+ class ParadeDBAdapter extends FeatureAwareDatabaseAdapter {
7
+ pool = null;
8
+ activeClient = null;
9
+ constructor(projectId, config) {
10
+ super(projectId, config);
11
+ }
12
+ getFeatures() {
13
+ const config = this.config;
14
+ return {
15
+ supportsFullTextSearch: config.enableBM25 !== false,
16
+ supportsVectorSearch: config.enableVector !== false,
17
+ supportsPartitioning: true,
18
+ supportsAnalytics: config.enableAnalytics !== false,
19
+ supportsCompression: true,
20
+ supportsMaterializedViews: true,
21
+ supportsParallelQueries: true
22
+ };
23
+ }
24
+ async connect() {
25
+ if (this.pool) return;
26
+ const config = this.config;
27
+ this.pool = new Pool({
28
+ connectionString: config.connectionString,
29
+ host: config.host || "localhost",
30
+ port: config.port || 5432,
31
+ database: config.database || "stackmemory",
32
+ user: config.user,
33
+ password: config.password,
34
+ ssl: config.ssl,
35
+ max: config.max || 20,
36
+ idleTimeoutMillis: config.idleTimeoutMillis || 3e4,
37
+ connectionTimeoutMillis: config.connectionTimeoutMillis || 2e3,
38
+ statement_timeout: config.statementTimeout || 3e4
39
+ });
40
+ const client = await this.pool.connect();
41
+ try {
42
+ await client.query("SELECT 1");
43
+ logger.info("ParadeDB connected successfully");
44
+ } finally {
45
+ client.release();
46
+ }
47
+ }
48
+ async disconnect() {
49
+ if (!this.pool) return;
50
+ await this.pool.end();
51
+ this.pool = null;
52
+ logger.info("ParadeDB disconnected");
53
+ }
54
+ isConnected() {
55
+ return this.pool !== null && !this.pool.ended;
56
+ }
57
+ async ping() {
58
+ if (!this.pool) return false;
59
+ try {
60
+ const client = await this.pool.connect();
61
+ try {
62
+ await client.query("SELECT 1");
63
+ return true;
64
+ } finally {
65
+ client.release();
66
+ }
67
+ } catch {
68
+ return false;
69
+ }
70
+ }
71
+ async initializeSchema() {
72
+ const client = await this.getClient();
73
+ try {
74
+ await client.query("BEGIN");
75
+ await client.query(`
76
+ CREATE EXTENSION IF NOT EXISTS "uuid-ossp";
77
+ CREATE EXTENSION IF NOT EXISTS "pg_trgm";
78
+ CREATE EXTENSION IF NOT EXISTS "btree_gin";
79
+ `);
80
+ const config = this.config;
81
+ if (config.enableBM25 !== false) {
82
+ await client.query("CREATE EXTENSION IF NOT EXISTS pg_search;");
83
+ }
84
+ if (config.enableVector !== false) {
85
+ await client.query("CREATE EXTENSION IF NOT EXISTS vector;");
86
+ }
87
+ if (config.enableAnalytics !== false) {
88
+ await client.query("CREATE EXTENSION IF NOT EXISTS pg_analytics;");
89
+ }
90
+ await client.query(`
91
+ -- Main frames table
92
+ CREATE TABLE IF NOT EXISTS frames (
93
+ frame_id UUID PRIMARY KEY DEFAULT uuid_generate_v4(),
94
+ run_id UUID NOT NULL,
95
+ project_id TEXT NOT NULL,
96
+ parent_frame_id UUID REFERENCES frames(frame_id) ON DELETE CASCADE,
97
+ depth INTEGER NOT NULL DEFAULT 0,
98
+ type TEXT NOT NULL,
99
+ name TEXT NOT NULL,
100
+ state TEXT DEFAULT 'active',
101
+ score FLOAT DEFAULT 0.5,
102
+ inputs JSONB DEFAULT '{}',
103
+ outputs JSONB DEFAULT '{}',
104
+ metadata JSONB DEFAULT '{}',
105
+ digest_text TEXT,
106
+ digest_json JSONB DEFAULT '{}',
107
+ content TEXT, -- For full-text search
108
+ embedding vector(768), -- For vector search
109
+ created_at TIMESTAMPTZ DEFAULT NOW(),
110
+ closed_at TIMESTAMPTZ,
111
+ CONSTRAINT check_state CHECK (state IN ('active', 'closed', 'suspended'))
112
+ ) PARTITION BY RANGE (created_at);
113
+
114
+ -- Create partitions for time-based data
115
+ CREATE TABLE IF NOT EXISTS frames_recent PARTITION OF frames
116
+ FOR VALUES FROM (NOW() - INTERVAL '30 days') TO (NOW() + INTERVAL '1 day');
117
+
118
+ CREATE TABLE IF NOT EXISTS frames_archive PARTITION OF frames
119
+ FOR VALUES FROM ('2020-01-01') TO (NOW() - INTERVAL '30 days');
120
+
121
+ -- Events table
122
+ CREATE TABLE IF NOT EXISTS events (
123
+ event_id UUID PRIMARY KEY DEFAULT uuid_generate_v4(),
124
+ run_id UUID NOT NULL,
125
+ frame_id UUID NOT NULL REFERENCES frames(frame_id) ON DELETE CASCADE,
126
+ seq INTEGER NOT NULL,
127
+ event_type TEXT NOT NULL,
128
+ payload JSONB NOT NULL DEFAULT '{}',
129
+ ts TIMESTAMPTZ DEFAULT NOW()
130
+ );
131
+
132
+ -- Anchors table
133
+ CREATE TABLE IF NOT EXISTS anchors (
134
+ anchor_id UUID PRIMARY KEY DEFAULT uuid_generate_v4(),
135
+ frame_id UUID NOT NULL REFERENCES frames(frame_id) ON DELETE CASCADE,
136
+ project_id TEXT NOT NULL,
137
+ type TEXT NOT NULL,
138
+ text TEXT NOT NULL,
139
+ priority INTEGER DEFAULT 0,
140
+ metadata JSONB DEFAULT '{}',
141
+ created_at TIMESTAMPTZ DEFAULT NOW()
142
+ );
143
+
144
+ -- Schema version tracking
145
+ CREATE TABLE IF NOT EXISTS schema_version (
146
+ version INTEGER PRIMARY KEY,
147
+ applied_at TIMESTAMPTZ DEFAULT NOW(),
148
+ description TEXT
149
+ );
150
+ `);
151
+ await client.query(`
152
+ -- Standard B-tree indexes
153
+ CREATE INDEX IF NOT EXISTS idx_frames_run_id ON frames USING btree(run_id);
154
+ CREATE INDEX IF NOT EXISTS idx_frames_project_id ON frames USING btree(project_id);
155
+ CREATE INDEX IF NOT EXISTS idx_frames_parent ON frames USING btree(parent_frame_id);
156
+ CREATE INDEX IF NOT EXISTS idx_frames_state ON frames USING btree(state);
157
+ CREATE INDEX IF NOT EXISTS idx_frames_type ON frames USING btree(type);
158
+ CREATE INDEX IF NOT EXISTS idx_frames_created_at ON frames USING btree(created_at DESC);
159
+ CREATE INDEX IF NOT EXISTS idx_frames_score ON frames USING btree(score DESC);
160
+
161
+ -- GIN indexes for JSONB
162
+ CREATE INDEX IF NOT EXISTS idx_frames_inputs ON frames USING gin(inputs);
163
+ CREATE INDEX IF NOT EXISTS idx_frames_outputs ON frames USING gin(outputs);
164
+ CREATE INDEX IF NOT EXISTS idx_frames_metadata ON frames USING gin(metadata);
165
+ CREATE INDEX IF NOT EXISTS idx_frames_digest ON frames USING gin(digest_json);
166
+
167
+ -- Trigram index for fuzzy text search
168
+ CREATE INDEX IF NOT EXISTS idx_frames_name_trgm ON frames USING gin(name gin_trgm_ops);
169
+ CREATE INDEX IF NOT EXISTS idx_frames_content_trgm ON frames USING gin(content gin_trgm_ops);
170
+
171
+ -- Event indexes
172
+ CREATE INDEX IF NOT EXISTS idx_events_frame ON events USING btree(frame_id);
173
+ CREATE INDEX IF NOT EXISTS idx_events_seq ON events USING btree(frame_id, seq);
174
+ CREATE INDEX IF NOT EXISTS idx_events_type ON events USING btree(event_type);
175
+ CREATE INDEX IF NOT EXISTS idx_events_ts ON events USING btree(ts DESC);
176
+
177
+ -- Anchor indexes
178
+ CREATE INDEX IF NOT EXISTS idx_anchors_frame ON anchors USING btree(frame_id);
179
+ CREATE INDEX IF NOT EXISTS idx_anchors_type ON anchors USING btree(type);
180
+ CREATE INDEX IF NOT EXISTS idx_anchors_priority ON anchors USING btree(priority DESC);
181
+ `);
182
+ if (config.enableBM25 !== false) {
183
+ await client.query(`
184
+ -- Create BM25 index for full-text search
185
+ CALL paradedb.create_bm25_test_table(
186
+ index_name => 'frames_search_idx',
187
+ table_name => 'frames',
188
+ schema_name => 'public',
189
+ key_field => 'frame_id',
190
+ text_fields => paradedb.field('name') ||
191
+ paradedb.field('content') ||
192
+ paradedb.field('digest_text'),
193
+ numeric_fields => paradedb.field('score') ||
194
+ paradedb.field('depth'),
195
+ json_fields => paradedb.field('metadata', flatten => true),
196
+ datetime_fields => paradedb.field('created_at')
197
+ );
198
+ `);
199
+ }
200
+ if (config.enableVector !== false) {
201
+ await client.query(`
202
+ -- HNSW index for vector similarity search
203
+ CREATE INDEX IF NOT EXISTS idx_frames_embedding
204
+ ON frames USING hnsw (embedding vector_cosine_ops)
205
+ WITH (m = 16, ef_construction = 64);
206
+ `);
207
+ }
208
+ await client.query(`
209
+ CREATE MATERIALIZED VIEW IF NOT EXISTS pattern_summary AS
210
+ WITH pattern_extraction AS (
211
+ SELECT
212
+ project_id,
213
+ type as pattern_type,
214
+ metadata->>'error' as error_pattern,
215
+ COUNT(*) as frequency,
216
+ MAX(score) as max_score,
217
+ MAX(created_at) as last_seen,
218
+ MIN(created_at) as first_seen
219
+ FROM frames
220
+ WHERE created_at > NOW() - INTERVAL '30 days'
221
+ GROUP BY project_id, pattern_type, error_pattern
222
+ )
223
+ SELECT * FROM pattern_extraction
224
+ WHERE frequency > 3;
225
+
226
+ CREATE UNIQUE INDEX IF NOT EXISTS idx_pattern_summary_unique
227
+ ON pattern_summary(project_id, pattern_type, error_pattern);
228
+ `);
229
+ await client.query(`
230
+ INSERT INTO schema_version (version, description)
231
+ VALUES (1, 'Initial ParadeDB schema with search and analytics')
232
+ ON CONFLICT (version) DO NOTHING;
233
+ `);
234
+ await client.query("COMMIT");
235
+ logger.info("ParadeDB schema initialized successfully");
236
+ } catch (error) {
237
+ await client.query("ROLLBACK");
238
+ throw error;
239
+ } finally {
240
+ this.releaseClient(client);
241
+ }
242
+ }
243
+ async migrateSchema(targetVersion) {
244
+ const client = await this.getClient();
245
+ try {
246
+ const result = await client.query(
247
+ "SELECT MAX(version) as version FROM schema_version"
248
+ );
249
+ const currentVersion = result.rows[0]?.version || 0;
250
+ if (currentVersion >= targetVersion) {
251
+ logger.info("Schema already at target version", {
252
+ currentVersion,
253
+ targetVersion
254
+ });
255
+ return;
256
+ }
257
+ for (let v = currentVersion + 1; v <= targetVersion; v++) {
258
+ logger.info(`Applying migration to version ${v}`);
259
+ await client.query(
260
+ "INSERT INTO schema_version (version, description) VALUES ($1, $2)",
261
+ [v, `Migration to version ${v}`]
262
+ );
263
+ }
264
+ } finally {
265
+ this.releaseClient(client);
266
+ }
267
+ }
268
+ async getSchemaVersion() {
269
+ const client = await this.getClient();
270
+ try {
271
+ const result = await client.query(
272
+ "SELECT MAX(version) as version FROM schema_version"
273
+ );
274
+ return result.rows[0]?.version || 0;
275
+ } finally {
276
+ this.releaseClient(client);
277
+ }
278
+ }
279
+ // Frame operations
280
+ async createFrame(frame) {
281
+ const client = await this.getClient();
282
+ try {
283
+ const result = await client.query(
284
+ `
285
+ INSERT INTO frames (
286
+ frame_id, run_id, project_id, parent_frame_id, depth,
287
+ type, name, state, score, inputs, outputs, metadata,
288
+ digest_text, digest_json, content
289
+ ) VALUES (
290
+ COALESCE($1::uuid, uuid_generate_v4()), $2, $3, $4, $5,
291
+ $6, $7, $8, $9, $10, $11, $12, $13, $14, $15
292
+ ) RETURNING frame_id
293
+ `,
294
+ [
295
+ frame.frame_id || null,
296
+ frame.run_id,
297
+ frame.project_id || this.projectId,
298
+ frame.parent_frame_id || null,
299
+ frame.depth || 0,
300
+ frame.type,
301
+ frame.name,
302
+ frame.state || "active",
303
+ frame.score || 0.5,
304
+ JSON.stringify(frame.inputs || {}),
305
+ JSON.stringify(frame.outputs || {}),
306
+ JSON.stringify(frame.metadata || {}),
307
+ frame.digest_text || null,
308
+ JSON.stringify(frame.digest_json || {}),
309
+ frame.content || `${frame.name} ${frame.digest_text || ""}`
310
+ ]
311
+ );
312
+ return result.rows[0].frame_id;
313
+ } finally {
314
+ this.releaseClient(client);
315
+ }
316
+ }
317
+ async getFrame(frameId) {
318
+ const client = await this.getClient();
319
+ try {
320
+ const result = await client.query(
321
+ "SELECT * FROM frames WHERE frame_id = $1",
322
+ [frameId]
323
+ );
324
+ if (result.rows.length === 0) return null;
325
+ const row = result.rows[0];
326
+ return {
327
+ ...row,
328
+ frame_id: row.frame_id,
329
+ run_id: row.run_id,
330
+ created_at: row.created_at.getTime(),
331
+ closed_at: row.closed_at?.getTime()
332
+ };
333
+ } finally {
334
+ this.releaseClient(client);
335
+ }
336
+ }
337
+ async updateFrame(frameId, updates) {
338
+ const client = await this.getClient();
339
+ try {
340
+ const fields = [];
341
+ const values = [];
342
+ let paramCount = 1;
343
+ if (updates.state !== void 0) {
344
+ fields.push(`state = $${paramCount++}`);
345
+ values.push(updates.state);
346
+ }
347
+ if (updates.outputs !== void 0) {
348
+ fields.push(`outputs = $${paramCount++}`);
349
+ values.push(JSON.stringify(updates.outputs));
350
+ }
351
+ if (updates.score !== void 0) {
352
+ fields.push(`score = $${paramCount++}`);
353
+ values.push(updates.score);
354
+ }
355
+ if (updates.digest_text !== void 0) {
356
+ fields.push(`digest_text = $${paramCount++}`);
357
+ values.push(updates.digest_text);
358
+ }
359
+ if (updates.digest_json !== void 0) {
360
+ fields.push(`digest_json = $${paramCount++}`);
361
+ values.push(JSON.stringify(updates.digest_json));
362
+ }
363
+ if (updates.closed_at !== void 0) {
364
+ fields.push(`closed_at = $${paramCount++}`);
365
+ values.push(new Date(updates.closed_at));
366
+ }
367
+ if (fields.length === 0) return;
368
+ values.push(frameId);
369
+ await client.query(
370
+ `
371
+ UPDATE frames SET ${fields.join(", ")} WHERE frame_id = $${paramCount}
372
+ `,
373
+ values
374
+ );
375
+ } finally {
376
+ this.releaseClient(client);
377
+ }
378
+ }
379
+ async deleteFrame(frameId) {
380
+ const client = await this.getClient();
381
+ try {
382
+ await client.query("DELETE FROM frames WHERE frame_id = $1", [frameId]);
383
+ } finally {
384
+ this.releaseClient(client);
385
+ }
386
+ }
387
+ async getActiveFrames(runId) {
388
+ const client = await this.getClient();
389
+ try {
390
+ let query = "SELECT * FROM frames WHERE state = $1";
391
+ const params = ["active"];
392
+ if (runId) {
393
+ query += " AND run_id = $2";
394
+ params.push(runId);
395
+ }
396
+ query += " ORDER BY depth ASC, created_at ASC";
397
+ const result = await client.query(query, params);
398
+ return result.rows.map((row) => ({
399
+ ...row,
400
+ created_at: row.created_at.getTime(),
401
+ closed_at: row.closed_at?.getTime()
402
+ }));
403
+ } finally {
404
+ this.releaseClient(client);
405
+ }
406
+ }
407
+ async closeFrame(frameId, outputs) {
408
+ await this.updateFrame(frameId, {
409
+ state: "closed",
410
+ outputs,
411
+ closed_at: Date.now()
412
+ });
413
+ }
414
+ // Event operations
415
+ async createEvent(event) {
416
+ const client = await this.getClient();
417
+ try {
418
+ const result = await client.query(
419
+ `
420
+ INSERT INTO events (event_id, run_id, frame_id, seq, event_type, payload, ts)
421
+ VALUES (COALESCE($1::uuid, uuid_generate_v4()), $2, $3, $4, $5, $6, $7)
422
+ RETURNING event_id
423
+ `,
424
+ [
425
+ event.event_id || null,
426
+ event.run_id,
427
+ event.frame_id,
428
+ event.seq || 0,
429
+ event.event_type,
430
+ JSON.stringify(event.payload || {}),
431
+ event.ts ? new Date(event.ts) : /* @__PURE__ */ new Date()
432
+ ]
433
+ );
434
+ return result.rows[0].event_id;
435
+ } finally {
436
+ this.releaseClient(client);
437
+ }
438
+ }
439
+ async getFrameEvents(frameId, options) {
440
+ const client = await this.getClient();
441
+ try {
442
+ let query = "SELECT * FROM events WHERE frame_id = $1";
443
+ const params = [frameId];
444
+ query += this.buildOrderByClause(
445
+ options?.orderBy || "seq",
446
+ options?.orderDirection
447
+ );
448
+ query += this.buildLimitClause(options?.limit, options?.offset);
449
+ const result = await client.query(query, params);
450
+ return result.rows.map((row) => ({
451
+ ...row,
452
+ ts: row.ts.getTime()
453
+ }));
454
+ } finally {
455
+ this.releaseClient(client);
456
+ }
457
+ }
458
+ async deleteFrameEvents(frameId) {
459
+ const client = await this.getClient();
460
+ try {
461
+ await client.query("DELETE FROM events WHERE frame_id = $1", [frameId]);
462
+ } finally {
463
+ this.releaseClient(client);
464
+ }
465
+ }
466
+ // Anchor operations
467
+ async createAnchor(anchor) {
468
+ const client = await this.getClient();
469
+ try {
470
+ const result = await client.query(
471
+ `
472
+ INSERT INTO anchors (anchor_id, frame_id, project_id, type, text, priority, metadata)
473
+ VALUES (COALESCE($1::uuid, uuid_generate_v4()), $2, $3, $4, $5, $6, $7)
474
+ RETURNING anchor_id
475
+ `,
476
+ [
477
+ anchor.anchor_id || null,
478
+ anchor.frame_id,
479
+ anchor.project_id || this.projectId,
480
+ anchor.type,
481
+ anchor.text,
482
+ anchor.priority || 0,
483
+ JSON.stringify(anchor.metadata || {})
484
+ ]
485
+ );
486
+ return result.rows[0].anchor_id;
487
+ } finally {
488
+ this.releaseClient(client);
489
+ }
490
+ }
491
+ async getFrameAnchors(frameId) {
492
+ const client = await this.getClient();
493
+ try {
494
+ const result = await client.query(
495
+ `
496
+ SELECT * FROM anchors WHERE frame_id = $1
497
+ ORDER BY priority DESC, created_at ASC
498
+ `,
499
+ [frameId]
500
+ );
501
+ return result.rows.map((row) => ({
502
+ ...row,
503
+ created_at: row.created_at.getTime()
504
+ }));
505
+ } finally {
506
+ this.releaseClient(client);
507
+ }
508
+ }
509
+ async deleteFrameAnchors(frameId) {
510
+ const client = await this.getClient();
511
+ try {
512
+ await client.query("DELETE FROM anchors WHERE frame_id = $1", [frameId]);
513
+ } finally {
514
+ this.releaseClient(client);
515
+ }
516
+ }
517
+ // Advanced search with BM25
518
+ async search(options) {
519
+ const client = await this.getClient();
520
+ try {
521
+ const config = this.config;
522
+ if (config.enableBM25 !== false) {
523
+ const result = await client.query(
524
+ `
525
+ SELECT f.*, s.score_bm25 as score
526
+ FROM frames_search_idx.search(
527
+ query => $1,
528
+ limit_rows => $2,
529
+ offset_rows => $3
530
+ ) s
531
+ JOIN frames f ON f.frame_id = s.frame_id
532
+ WHERE ($4::float IS NULL OR s.score_bm25 >= $4)
533
+ ORDER BY s.score_bm25 DESC
534
+ `,
535
+ [
536
+ options.query,
537
+ options.limit || 100,
538
+ options.offset || 0,
539
+ options.scoreThreshold || null
540
+ ]
541
+ );
542
+ return result.rows.map((row) => ({
543
+ ...row,
544
+ created_at: row.created_at.getTime(),
545
+ closed_at: row.closed_at?.getTime()
546
+ }));
547
+ } else {
548
+ const result = await client.query(
549
+ `
550
+ SELECT *,
551
+ ts_rank(
552
+ to_tsvector('english', COALESCE(name, '') || ' ' || COALESCE(content, '')),
553
+ plainto_tsquery('english', $1)
554
+ ) as score
555
+ FROM frames
556
+ WHERE to_tsvector('english', COALESCE(name, '') || ' ' || COALESCE(content, ''))
557
+ @@ plainto_tsquery('english', $1)
558
+ ORDER BY score DESC
559
+ LIMIT $2 OFFSET $3
560
+ `,
561
+ [options.query, options.limit || 100, options.offset || 0]
562
+ );
563
+ return result.rows.map((row) => ({
564
+ ...row,
565
+ created_at: row.created_at.getTime(),
566
+ closed_at: row.closed_at?.getTime()
567
+ }));
568
+ }
569
+ } finally {
570
+ this.releaseClient(client);
571
+ }
572
+ }
573
+ // Vector similarity search
574
+ async searchByVector(embedding, options) {
575
+ const client = await this.getClient();
576
+ try {
577
+ const config = this.config;
578
+ if (config.enableVector === false) {
579
+ logger.warn("Vector search not enabled in ParadeDB configuration");
580
+ return [];
581
+ }
582
+ const result = await client.query(
583
+ `
584
+ SELECT *,
585
+ 1 - (embedding <=> $1::vector) as similarity
586
+ FROM frames
587
+ WHERE embedding IS NOT NULL
588
+ ORDER BY embedding <=> $1::vector
589
+ LIMIT $2 OFFSET $3
590
+ `,
591
+ [
592
+ `[${embedding.join(",")}]`,
593
+ options?.limit || 100,
594
+ options?.offset || 0
595
+ ]
596
+ );
597
+ return result.rows.map((row) => ({
598
+ ...row,
599
+ created_at: row.created_at.getTime(),
600
+ closed_at: row.closed_at?.getTime()
601
+ }));
602
+ } finally {
603
+ this.releaseClient(client);
604
+ }
605
+ }
606
+ // Hybrid search combining BM25 and vector
607
+ async searchHybrid(textQuery, embedding, weights) {
608
+ const client = await this.getClient();
609
+ try {
610
+ const textWeight = weights?.text || 0.6;
611
+ const vectorWeight = weights?.vector || 0.4;
612
+ const result = await client.query(
613
+ `
614
+ WITH bm25_results AS (
615
+ SELECT frame_id, score_bm25
616
+ FROM frames_search_idx.search(
617
+ query => $1,
618
+ limit_rows => 200
619
+ )
620
+ ),
621
+ vector_results AS (
622
+ SELECT frame_id,
623
+ 1 - (embedding <=> $2::vector) as score_vector
624
+ FROM frames
625
+ WHERE embedding IS NOT NULL
626
+ ORDER BY embedding <=> $2::vector
627
+ LIMIT 200
628
+ )
629
+ SELECT f.*,
630
+ (COALESCE(b.score_bm25, 0) * $3 +
631
+ COALESCE(v.score_vector, 0) * $4) as score
632
+ FROM frames f
633
+ LEFT JOIN bm25_results b ON f.frame_id = b.frame_id
634
+ LEFT JOIN vector_results v ON f.frame_id = v.frame_id
635
+ WHERE b.frame_id IS NOT NULL OR v.frame_id IS NOT NULL
636
+ ORDER BY score DESC
637
+ LIMIT $5
638
+ `,
639
+ [textQuery, `[${embedding.join(",")}]`, textWeight, vectorWeight, 100]
640
+ );
641
+ return result.rows.map((row) => ({
642
+ ...row,
643
+ created_at: row.created_at.getTime(),
644
+ closed_at: row.closed_at?.getTime()
645
+ }));
646
+ } finally {
647
+ this.releaseClient(client);
648
+ }
649
+ }
650
+ // Advanced aggregation
651
+ async aggregate(table, options) {
652
+ const client = await this.getClient();
653
+ try {
654
+ const metrics = options.metrics.map((m) => {
655
+ const alias = m.alias || `${m.operation}_${m.field}`;
656
+ return `${m.operation}(${m.field}) AS "${alias}"`;
657
+ }).join(", ");
658
+ let query = `
659
+ SELECT ${options.groupBy.map((g) => `"${g}"`).join(", ")}, ${metrics}
660
+ FROM ${table}
661
+ GROUP BY ${options.groupBy.map((g) => `"${g}"`).join(", ")}
662
+ `;
663
+ if (options.having) {
664
+ const havingClauses = Object.entries(options.having).map(
665
+ ([key, value], i) => {
666
+ return `${key} ${typeof value === "object" ? value.op : "="} $${i + 1}`;
667
+ }
668
+ );
669
+ query += ` HAVING ${havingClauses.join(" AND ")}`;
670
+ }
671
+ const result = await client.query(
672
+ query,
673
+ Object.values(options.having || {})
674
+ );
675
+ return result.rows;
676
+ } finally {
677
+ this.releaseClient(client);
678
+ }
679
+ }
680
+ // Pattern detection with analytics
681
+ async detectPatterns(timeRange) {
682
+ const client = await this.getClient();
683
+ try {
684
+ const result = await client.query(
685
+ `
686
+ SELECT
687
+ COALESCE(error_pattern, pattern_type) as pattern,
688
+ pattern_type as type,
689
+ frequency,
690
+ last_seen
691
+ FROM pattern_summary
692
+ WHERE project_id = $1
693
+ AND ($2::timestamptz IS NULL OR last_seen >= $2)
694
+ AND ($3::timestamptz IS NULL OR first_seen <= $3)
695
+ ORDER BY frequency DESC, last_seen DESC
696
+ LIMIT 100
697
+ `,
698
+ [this.projectId, timeRange?.start || null, timeRange?.end || null]
699
+ );
700
+ return result.rows.map((row) => ({
701
+ pattern: row.pattern,
702
+ type: row.type,
703
+ frequency: row.frequency,
704
+ lastSeen: row.last_seen
705
+ }));
706
+ } finally {
707
+ this.releaseClient(client);
708
+ }
709
+ }
710
+ // Bulk operations
711
+ async executeBulk(operations) {
712
+ await this.inTransaction(async () => {
713
+ const client = this.activeClient;
714
+ for (const op of operations) {
715
+ switch (op.type) {
716
+ case "insert": {
717
+ const cols = Object.keys(op.data);
718
+ const values = Object.values(op.data);
719
+ const placeholders = values.map((_, i) => `$${i + 1}`).join(",");
720
+ await client.query(
721
+ `INSERT INTO ${op.table} (${cols.join(",")}) VALUES (${placeholders})`,
722
+ values
723
+ );
724
+ break;
725
+ }
726
+ case "update": {
727
+ const sets = Object.keys(op.data).map((k, i) => `${k} = $${i + 1}`).join(",");
728
+ const whereClause = this.buildWhereClausePostgres(
729
+ op.where || {},
730
+ Object.keys(op.data).length
731
+ );
732
+ const values = [
733
+ ...Object.values(op.data),
734
+ ...Object.values(op.where || {})
735
+ ];
736
+ await client.query(
737
+ `UPDATE ${op.table} SET ${sets} ${whereClause}`,
738
+ values
739
+ );
740
+ break;
741
+ }
742
+ case "delete": {
743
+ const whereClause = this.buildWhereClausePostgres(
744
+ op.where || {},
745
+ 0
746
+ );
747
+ await client.query(
748
+ `DELETE FROM ${op.table} ${whereClause}`,
749
+ Object.values(op.where || {})
750
+ );
751
+ break;
752
+ }
753
+ }
754
+ }
755
+ });
756
+ }
757
+ async vacuum() {
758
+ const client = await this.getClient();
759
+ try {
760
+ await client.query("VACUUM ANALYZE frames");
761
+ await client.query("VACUUM ANALYZE events");
762
+ await client.query("VACUUM ANALYZE anchors");
763
+ await client.query(
764
+ "REFRESH MATERIALIZED VIEW CONCURRENTLY pattern_summary"
765
+ );
766
+ logger.info("ParadeDB vacuum and analyze completed");
767
+ } finally {
768
+ this.releaseClient(client);
769
+ }
770
+ }
771
+ async analyze() {
772
+ const client = await this.getClient();
773
+ try {
774
+ await client.query("ANALYZE frames");
775
+ await client.query("ANALYZE events");
776
+ await client.query("ANALYZE anchors");
777
+ logger.info("ParadeDB analyze completed");
778
+ } finally {
779
+ this.releaseClient(client);
780
+ }
781
+ }
782
+ // Statistics
783
+ async getStats() {
784
+ const client = await this.getClient();
785
+ try {
786
+ const result = await client.query(`
787
+ SELECT
788
+ (SELECT COUNT(*) FROM frames) as total_frames,
789
+ (SELECT COUNT(*) FROM frames WHERE state = 'active') as active_frames,
790
+ (SELECT COUNT(*) FROM events) as total_events,
791
+ (SELECT COUNT(*) FROM anchors) as total_anchors,
792
+ pg_database_size(current_database()) as disk_usage
793
+ `);
794
+ return {
795
+ totalFrames: parseInt(result.rows[0].total_frames),
796
+ activeFrames: parseInt(result.rows[0].active_frames),
797
+ totalEvents: parseInt(result.rows[0].total_events),
798
+ totalAnchors: parseInt(result.rows[0].total_anchors),
799
+ diskUsage: parseInt(result.rows[0].disk_usage)
800
+ };
801
+ } finally {
802
+ this.releaseClient(client);
803
+ }
804
+ }
805
+ async getQueryStats() {
806
+ const client = await this.getClient();
807
+ try {
808
+ const result = await client.query(`
809
+ SELECT
810
+ query,
811
+ calls,
812
+ mean_exec_time as mean_time,
813
+ total_exec_time as total_time
814
+ FROM pg_stat_statements
815
+ WHERE query NOT LIKE '%pg_stat_statements%'
816
+ ORDER BY total_exec_time DESC
817
+ LIMIT 100
818
+ `);
819
+ return result.rows.map((row) => ({
820
+ query: row.query,
821
+ calls: parseInt(row.calls),
822
+ meanTime: parseFloat(row.mean_time),
823
+ totalTime: parseFloat(row.total_time)
824
+ }));
825
+ } catch (error) {
826
+ logger.warn("pg_stat_statements not available", error);
827
+ return [];
828
+ } finally {
829
+ this.releaseClient(client);
830
+ }
831
+ }
832
+ // Transaction support
833
+ async beginTransaction() {
834
+ this.activeClient = await this.pool.connect();
835
+ await this.activeClient.query("BEGIN");
836
+ }
837
+ async commitTransaction() {
838
+ if (!this.activeClient) throw new Error("No active transaction");
839
+ await this.activeClient.query("COMMIT");
840
+ this.activeClient.release();
841
+ this.activeClient = null;
842
+ }
843
+ async rollbackTransaction() {
844
+ if (!this.activeClient) throw new Error("No active transaction");
845
+ await this.activeClient.query("ROLLBACK");
846
+ this.activeClient.release();
847
+ this.activeClient = null;
848
+ }
849
+ async inTransaction(callback) {
850
+ await this.beginTransaction();
851
+ try {
852
+ await callback(this);
853
+ await this.commitTransaction();
854
+ } catch (error) {
855
+ try {
856
+ await this.rollbackTransaction();
857
+ } catch (rollbackError) {
858
+ console.error("Transaction rollback failed:", rollbackError);
859
+ if (this.connectionPool) {
860
+ this.connectionPool.markConnectionAsBad(this.client);
861
+ }
862
+ }
863
+ throw error;
864
+ }
865
+ }
866
+ // Export/Import
867
+ async exportData(tables, format) {
868
+ const client = await this.getClient();
869
+ try {
870
+ if (format === "json") {
871
+ const data = {};
872
+ for (const table of tables) {
873
+ const result = await client.query(`SELECT * FROM ${table}`);
874
+ data[table] = result.rows;
875
+ }
876
+ return Buffer.from(JSON.stringify(data, null, 2));
877
+ } else if (format === "csv") {
878
+ const chunks = [];
879
+ for (const table of tables) {
880
+ const result = await client.query(`
881
+ COPY (SELECT * FROM ${table}) TO STDOUT WITH CSV HEADER
882
+ `);
883
+ chunks.push(result.toString());
884
+ }
885
+ return Buffer.from(chunks.join("\n\n"));
886
+ } else {
887
+ throw new Error(
888
+ `Format ${format} not yet implemented for ParadeDB export`
889
+ );
890
+ }
891
+ } finally {
892
+ this.releaseClient(client);
893
+ }
894
+ }
895
+ async importData(data, format, options) {
896
+ const client = await this.getClient();
897
+ try {
898
+ if (format === "json") {
899
+ const parsed = JSON.parse(data.toString());
900
+ await client.query("BEGIN");
901
+ for (const [table, rows] of Object.entries(parsed)) {
902
+ if (options?.truncate) {
903
+ await client.query(`TRUNCATE TABLE ${table} CASCADE`);
904
+ }
905
+ for (const row of rows) {
906
+ const cols = Object.keys(row);
907
+ const values = Object.values(row);
908
+ const placeholders = values.map((_, i) => `$${i + 1}`).join(",");
909
+ if (options?.upsert) {
910
+ const updates = cols.map((c) => `${c} = EXCLUDED.${c}`).join(",");
911
+ await client.query(
912
+ `INSERT INTO ${table} (${cols.join(",")}) VALUES (${placeholders})
913
+ ON CONFLICT DO UPDATE SET ${updates}`,
914
+ values
915
+ );
916
+ } else {
917
+ await client.query(
918
+ `INSERT INTO ${table} (${cols.join(",")}) VALUES (${placeholders})`,
919
+ values
920
+ );
921
+ }
922
+ }
923
+ }
924
+ await client.query("COMMIT");
925
+ } else {
926
+ throw new Error(
927
+ `Format ${format} not yet implemented for ParadeDB import`
928
+ );
929
+ }
930
+ } catch (error) {
931
+ await client.query("ROLLBACK");
932
+ throw error;
933
+ } finally {
934
+ this.releaseClient(client);
935
+ }
936
+ }
937
+ // Helper methods
938
+ async getClient() {
939
+ if (this.activeClient) {
940
+ return this.activeClient;
941
+ }
942
+ if (!this.pool) {
943
+ throw new Error("Database not connected");
944
+ }
945
+ return await this.pool.connect();
946
+ }
947
+ releaseClient(client) {
948
+ if (client !== this.activeClient) {
949
+ client.release();
950
+ }
951
+ }
952
+ buildWhereClausePostgres(conditions, startParam) {
953
+ const clauses = Object.entries(conditions).map(([key, value], i) => {
954
+ const paramNum = startParam + i + 1;
955
+ if (value === null) {
956
+ return `${key} IS NULL`;
957
+ } else if (Array.isArray(value)) {
958
+ const placeholders = value.map((_, j) => `$${paramNum + j}`).join(",");
959
+ return `${key} IN (${placeholders})`;
960
+ } else {
961
+ return `${key} = $${paramNum}`;
962
+ }
963
+ });
964
+ return clauses.length > 0 ? `WHERE ${clauses.join(" AND ")}` : "";
965
+ }
966
+ }
967
+ export {
968
+ ParadeDBAdapter
969
+ };
970
+ //# sourceMappingURL=paradedb-adapter.js.map