@stackmemoryai/stackmemory 0.3.0 → 0.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (736) hide show
  1. package/README.md +52 -272
  2. package/dist/cli/codex-sm.js +48 -19
  3. package/dist/cli/codex-sm.js.map +2 -2
  4. package/dist/cli/commands/clear.js +191 -0
  5. package/dist/cli/commands/clear.js.map +7 -0
  6. package/dist/cli/commands/config.js +152 -1
  7. package/dist/cli/commands/config.js.map +2 -2
  8. package/dist/cli/commands/dashboard.js +178 -0
  9. package/dist/cli/commands/dashboard.js.map +7 -0
  10. package/dist/cli/commands/handoff.js +125 -8
  11. package/dist/cli/commands/handoff.js.map +2 -2
  12. package/dist/cli/commands/linear-create.js +132 -0
  13. package/dist/cli/commands/linear-create.js.map +7 -0
  14. package/dist/cli/commands/linear-list.js +69 -0
  15. package/dist/cli/commands/linear-list.js.map +7 -0
  16. package/dist/cli/commands/linear-migrate.js +40 -0
  17. package/dist/cli/commands/linear-migrate.js.map +7 -0
  18. package/dist/cli/commands/linear.js +185 -36
  19. package/dist/cli/commands/linear.js.map +2 -2
  20. package/dist/cli/commands/monitor.js +309 -0
  21. package/dist/cli/commands/monitor.js.map +7 -0
  22. package/dist/cli/commands/quality.js +414 -0
  23. package/dist/cli/commands/quality.js.map +7 -0
  24. package/dist/cli/commands/storage.js +275 -0
  25. package/dist/cli/commands/storage.js.map +7 -0
  26. package/dist/cli/commands/tui.js +66 -0
  27. package/dist/cli/commands/tui.js.map +7 -0
  28. package/dist/cli/commands/workflow.js +134 -0
  29. package/dist/cli/commands/workflow.js.map +7 -0
  30. package/dist/cli/index.js +105 -9
  31. package/dist/cli/index.js.map +3 -3
  32. package/dist/core/analytics/team-analytics.js +374 -0
  33. package/dist/core/analytics/team-analytics.js.map +7 -0
  34. package/dist/core/context/context-bridge.js +234 -0
  35. package/dist/core/context/context-bridge.js.map +7 -0
  36. package/dist/core/context/dual-stack-manager.js +850 -0
  37. package/dist/core/context/dual-stack-manager.js.map +7 -0
  38. package/dist/core/context/frame-handoff-manager.js +384 -0
  39. package/dist/core/context/frame-handoff-manager.js.map +7 -0
  40. package/dist/core/context/frame-manager.js +132 -12
  41. package/dist/core/context/frame-manager.js.map +2 -2
  42. package/dist/core/context/permission-manager.js +181 -0
  43. package/dist/core/context/permission-manager.js.map +7 -0
  44. package/dist/core/context/shared-context-layer.js +386 -0
  45. package/dist/core/context/shared-context-layer.js.map +7 -0
  46. package/dist/core/context/stack-merge-resolver.js +600 -0
  47. package/dist/core/context/stack-merge-resolver.js.map +7 -0
  48. package/dist/core/context/validation.js +121 -0
  49. package/dist/core/context/validation.js.map +7 -0
  50. package/dist/core/database/connection-pool.js +266 -175
  51. package/dist/core/database/connection-pool.js.map +2 -2
  52. package/dist/core/database/database-adapter.js +51 -0
  53. package/dist/core/database/database-adapter.js.map +7 -0
  54. package/dist/core/database/migration-manager.js +514 -0
  55. package/dist/core/database/migration-manager.js.map +7 -0
  56. package/dist/core/database/paradedb-adapter.js +970 -0
  57. package/dist/core/database/paradedb-adapter.js.map +7 -0
  58. package/dist/core/database/query-router.js +421 -0
  59. package/dist/core/database/query-router.js.map +7 -0
  60. package/dist/core/database/sqlite-adapter.js +547 -0
  61. package/dist/core/database/sqlite-adapter.js.map +7 -0
  62. package/dist/core/errors/index.js +21 -1
  63. package/dist/core/errors/index.js.map +2 -2
  64. package/dist/core/frame/workflow-templates-stub.js +42 -0
  65. package/dist/core/frame/workflow-templates-stub.js.map +7 -0
  66. package/dist/core/frame/workflow-templates.js +276 -0
  67. package/dist/core/frame/workflow-templates.js.map +7 -0
  68. package/dist/core/merge/conflict-detector.js +5 -2
  69. package/dist/core/merge/conflict-detector.js.map +2 -2
  70. package/dist/core/merge/resolution-engine.js +3 -14
  71. package/dist/core/merge/resolution-engine.js.map +2 -2
  72. package/dist/core/merge/stack-diff.js.map +2 -2
  73. package/dist/core/monitoring/logger.js +18 -3
  74. package/dist/core/monitoring/logger.js.map +2 -2
  75. package/dist/core/monitoring/session-monitor.js +296 -0
  76. package/dist/core/monitoring/session-monitor.js.map +7 -0
  77. package/dist/core/retrieval/context-retriever.js +475 -0
  78. package/dist/core/retrieval/context-retriever.js.map +7 -0
  79. package/dist/core/retrieval/graph-retrieval.js +658 -0
  80. package/dist/core/retrieval/graph-retrieval.js.map +7 -0
  81. package/dist/core/retrieval/hierarchical-retrieval.js +652 -0
  82. package/dist/core/retrieval/hierarchical-retrieval.js.map +7 -0
  83. package/dist/core/retrieval/retrieval-benchmarks.js +517 -0
  84. package/dist/core/retrieval/retrieval-benchmarks.js.map +7 -0
  85. package/dist/core/session/clear-survival-stub.js +49 -0
  86. package/dist/core/session/clear-survival-stub.js.map +7 -0
  87. package/dist/core/session/clear-survival.js +426 -0
  88. package/dist/core/session/clear-survival.js.map +7 -0
  89. package/dist/core/session/handoff-generator.js +339 -0
  90. package/dist/core/session/handoff-generator.js.map +7 -0
  91. package/dist/core/session/session-manager.js +61 -26
  92. package/dist/core/session/session-manager.js.map +3 -3
  93. package/dist/core/skills/index.js +3 -0
  94. package/dist/core/skills/index.js.map +7 -0
  95. package/dist/core/skills/skill-storage.js +749 -0
  96. package/dist/core/skills/skill-storage.js.map +7 -0
  97. package/dist/core/skills/types.js +189 -0
  98. package/dist/core/skills/types.js.map +7 -0
  99. package/dist/core/storage/railway-optimized-storage.js +550 -0
  100. package/dist/core/storage/railway-optimized-storage.js.map +7 -0
  101. package/dist/core/storage/remote-storage.js +456 -0
  102. package/dist/core/storage/remote-storage.js.map +7 -0
  103. package/dist/core/trace/trace-detector.js +136 -5
  104. package/dist/core/trace/trace-detector.js.map +2 -2
  105. package/dist/core/trace/trace-store.js.map +2 -2
  106. package/dist/features/tui/components/analytics-panel.js +136 -0
  107. package/dist/features/tui/components/analytics-panel.js.map +7 -0
  108. package/dist/features/tui/components/frame-visualizer.js +377 -0
  109. package/dist/features/tui/components/frame-visualizer.js.map +7 -0
  110. package/dist/features/tui/components/pr-tracker.js +123 -0
  111. package/dist/features/tui/components/pr-tracker.js.map +7 -0
  112. package/dist/features/tui/components/session-monitor.js +286 -0
  113. package/dist/features/tui/components/session-monitor.js.map +7 -0
  114. package/dist/features/tui/components/subagent-fleet.js +388 -0
  115. package/dist/features/tui/components/subagent-fleet.js.map +7 -0
  116. package/dist/features/tui/components/task-board.js +475 -0
  117. package/dist/features/tui/components/task-board.js.map +7 -0
  118. package/dist/features/tui/index.js +397 -0
  119. package/dist/features/tui/index.js.map +7 -0
  120. package/dist/features/tui/services/data-service.js +654 -0
  121. package/dist/features/tui/services/data-service.js.map +7 -0
  122. package/dist/features/tui/services/websocket-client.js +149 -0
  123. package/dist/features/tui/services/websocket-client.js.map +7 -0
  124. package/dist/features/tui/terminal-compat.js +205 -0
  125. package/dist/features/tui/terminal-compat.js.map +7 -0
  126. package/dist/features/tui/types.js +1 -0
  127. package/dist/features/tui/types.js.map +7 -0
  128. package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js +455 -0
  129. package/dist/integrations/claude-code/enhanced-pre-clear-hooks.js.map +7 -0
  130. package/dist/integrations/claude-code/lifecycle-hooks.js +250 -0
  131. package/dist/integrations/claude-code/lifecycle-hooks.js.map +7 -0
  132. package/dist/integrations/claude-code/post-task-hooks.js +541 -0
  133. package/dist/integrations/claude-code/post-task-hooks.js.map +7 -0
  134. package/dist/integrations/linear/client.js +22 -4
  135. package/dist/integrations/linear/client.js.map +2 -2
  136. package/dist/integrations/linear/migration.js +299 -0
  137. package/dist/integrations/linear/migration.js.map +7 -0
  138. package/dist/integrations/linear/oauth-server.js +396 -0
  139. package/dist/integrations/linear/oauth-server.js.map +7 -0
  140. package/dist/integrations/linear/rest-client.js +199 -0
  141. package/dist/integrations/linear/rest-client.js.map +7 -0
  142. package/dist/integrations/linear/sync.js +14 -2
  143. package/dist/integrations/linear/sync.js.map +2 -2
  144. package/dist/integrations/linear/webhook-handler.js +200 -0
  145. package/dist/integrations/linear/webhook-handler.js.map +7 -0
  146. package/dist/integrations/mcp/handlers/skill-handlers.js +514 -0
  147. package/dist/integrations/mcp/handlers/skill-handlers.js.map +7 -0
  148. package/dist/integrations/mcp/middleware/tool-scoring.js +352 -0
  149. package/dist/integrations/mcp/middleware/tool-scoring.js.map +7 -0
  150. package/dist/integrations/mcp/refactored-server.js +31 -3
  151. package/dist/integrations/mcp/refactored-server.js.map +2 -2
  152. package/dist/integrations/mcp/server.js +25 -7
  153. package/dist/integrations/mcp/server.js.map +2 -2
  154. package/dist/mcp/stackmemory-mcp-server.js.map +1 -1
  155. package/dist/models/user.model.js +3 -0
  156. package/dist/models/user.model.js.map +2 -2
  157. package/dist/services/context-service.js.map +2 -2
  158. package/dist/utils/formatting.js +58 -0
  159. package/dist/utils/formatting.js.map +7 -0
  160. package/package.json +24 -5
  161. package/dist/cli/__tests__/index.test.js +0 -290
  162. package/dist/cli/__tests__/index.test.js.map +0 -7
  163. package/dist/core/config/__tests__/config-manager.test.js +0 -248
  164. package/dist/core/config/__tests__/config-manager.test.js.map +0 -7
  165. package/dist/core/context/__tests__/frame-manager.test.js +0 -879
  166. package/dist/core/context/__tests__/frame-manager.test.js.map +0 -7
  167. package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js +0 -379
  168. package/dist/core/digest/__tests__/enhanced-hybrid-digest.test.js.map +0 -7
  169. package/dist/core/digest/__tests__/frame-digest-integration.test.js +0 -230
  170. package/dist/core/digest/__tests__/frame-digest-integration.test.js.map +0 -7
  171. package/dist/core/errors/__tests__/error-handling.test.js +0 -270
  172. package/dist/core/errors/__tests__/error-handling.test.js.map +0 -7
  173. package/dist/core/merge/__tests__/conflict-scenarios.test.js +0 -414
  174. package/dist/core/merge/__tests__/conflict-scenarios.test.js.map +0 -7
  175. package/dist/core/query/__tests__/query-parser.test.js +0 -301
  176. package/dist/core/query/__tests__/query-parser.test.js.map +0 -7
  177. package/dist/core/query/__tests__/query-templates.test.js +0 -210
  178. package/dist/core/query/__tests__/query-templates.test.js.map +0 -7
  179. package/dist/core/trace/trace-detector.test.js +0 -401
  180. package/dist/core/trace/trace-detector.test.js.map +0 -7
  181. package/dist/features/tasks/__tests__/pebbles-task-store.test.js +0 -747
  182. package/dist/features/tasks/__tests__/pebbles-task-store.test.js.map +0 -7
  183. package/dist/integrations/linear/__tests__/auth.test.js +0 -558
  184. package/dist/integrations/linear/__tests__/auth.test.js.map +0 -7
  185. package/dist/integrations/linear/__tests__/sync-service.test.js +0 -760
  186. package/dist/integrations/linear/__tests__/sync-service.test.js.map +0 -7
  187. package/dist/integrations/mcp/__tests__/server.test.js +0 -798
  188. package/dist/integrations/mcp/__tests__/server.test.js.map +0 -7
  189. package/dist/scripts/benchmark-performance.d.ts +0 -7
  190. package/dist/scripts/benchmark-performance.d.ts.map +0 -1
  191. package/dist/scripts/benchmark-performance.js +0 -44
  192. package/dist/scripts/benchmark-performance.js.map +0 -1
  193. package/dist/scripts/cancel-duplicate-tasks.d.ts +0 -7
  194. package/dist/scripts/cancel-duplicate-tasks.d.ts.map +0 -1
  195. package/dist/scripts/cancel-duplicate-tasks.js +0 -172
  196. package/dist/scripts/cancel-duplicate-tasks.js.map +0 -1
  197. package/dist/scripts/cleanup-duplicate-tasks.d.ts +0 -12
  198. package/dist/scripts/cleanup-duplicate-tasks.d.ts.map +0 -1
  199. package/dist/scripts/cleanup-duplicate-tasks.js +0 -215
  200. package/dist/scripts/cleanup-duplicate-tasks.js.map +0 -1
  201. package/dist/scripts/initialize.d.ts +0 -6
  202. package/dist/scripts/initialize.d.ts.map +0 -1
  203. package/dist/scripts/initialize.js +0 -93
  204. package/dist/scripts/initialize.js.map +0 -1
  205. package/dist/scripts/list-linear-tasks.d.ts +0 -6
  206. package/dist/scripts/list-linear-tasks.d.ts.map +0 -1
  207. package/dist/scripts/list-linear-tasks.js +0 -121
  208. package/dist/scripts/list-linear-tasks.js.map +0 -1
  209. package/dist/scripts/merge-linear-duplicates-safe.d.ts +0 -7
  210. package/dist/scripts/merge-linear-duplicates-safe.d.ts.map +0 -1
  211. package/dist/scripts/merge-linear-duplicates-safe.js +0 -267
  212. package/dist/scripts/merge-linear-duplicates-safe.js.map +0 -1
  213. package/dist/scripts/show-linear-summary.d.ts +0 -6
  214. package/dist/scripts/show-linear-summary.d.ts.map +0 -1
  215. package/dist/scripts/show-linear-summary.js +0 -120
  216. package/dist/scripts/show-linear-summary.js.map +0 -1
  217. package/dist/scripts/status.d.ts +0 -6
  218. package/dist/scripts/status.d.ts.map +0 -1
  219. package/dist/scripts/status.js +0 -101
  220. package/dist/scripts/status.js.map +0 -1
  221. package/dist/src/agents/core/agent-task-manager.d.ts +0 -154
  222. package/dist/src/agents/core/agent-task-manager.d.ts.map +0 -1
  223. package/dist/src/agents/core/agent-task-manager.js +0 -504
  224. package/dist/src/agents/core/agent-task-manager.js.map +0 -1
  225. package/dist/src/agents/verifiers/base-verifier.d.ts +0 -112
  226. package/dist/src/agents/verifiers/base-verifier.d.ts.map +0 -1
  227. package/dist/src/agents/verifiers/base-verifier.js +0 -130
  228. package/dist/src/agents/verifiers/base-verifier.js.map +0 -1
  229. package/dist/src/agents/verifiers/formatter-verifier.d.ts +0 -14
  230. package/dist/src/agents/verifiers/formatter-verifier.d.ts.map +0 -1
  231. package/dist/src/agents/verifiers/formatter-verifier.js +0 -107
  232. package/dist/src/agents/verifiers/formatter-verifier.js.map +0 -1
  233. package/dist/src/agents/verifiers/llm-judge.d.ts +0 -46
  234. package/dist/src/agents/verifiers/llm-judge.d.ts.map +0 -1
  235. package/dist/src/agents/verifiers/llm-judge.js +0 -248
  236. package/dist/src/agents/verifiers/llm-judge.js.map +0 -1
  237. package/dist/src/cli/auto-detect.d.ts +0 -61
  238. package/dist/src/cli/auto-detect.d.ts.map +0 -1
  239. package/dist/src/cli/auto-detect.js +0 -350
  240. package/dist/src/cli/auto-detect.js.map +0 -1
  241. package/dist/src/cli/browser-test.d.ts +0 -6
  242. package/dist/src/cli/browser-test.d.ts.map +0 -1
  243. package/dist/src/cli/browser-test.js +0 -32
  244. package/dist/src/cli/browser-test.js.map +0 -1
  245. package/dist/src/cli/claude-sm.d.ts +0 -7
  246. package/dist/src/cli/claude-sm.d.ts.map +0 -1
  247. package/dist/src/cli/claude-sm.js +0 -412
  248. package/dist/src/cli/claude-sm.js.map +0 -1
  249. package/dist/src/cli/commands/agent.d.ts +0 -9
  250. package/dist/src/cli/commands/agent.d.ts.map +0 -1
  251. package/dist/src/cli/commands/agent.js +0 -303
  252. package/dist/src/cli/commands/agent.js.map +0 -1
  253. package/dist/src/cli/commands/config.d.ts +0 -6
  254. package/dist/src/cli/commands/config.d.ts.map +0 -1
  255. package/dist/src/cli/commands/config.js +0 -224
  256. package/dist/src/cli/commands/config.js.map +0 -1
  257. package/dist/src/cli/commands/context.d.ts +0 -7
  258. package/dist/src/cli/commands/context.d.ts.map +0 -1
  259. package/dist/src/cli/commands/context.js +0 -365
  260. package/dist/src/cli/commands/context.js.map +0 -1
  261. package/dist/src/cli/commands/handoff.d.ts +0 -6
  262. package/dist/src/cli/commands/handoff.d.ts.map +0 -1
  263. package/dist/src/cli/commands/handoff.js +0 -212
  264. package/dist/src/cli/commands/handoff.js.map +0 -1
  265. package/dist/src/cli/commands/linear-test.d.ts +0 -6
  266. package/dist/src/cli/commands/linear-test.d.ts.map +0 -1
  267. package/dist/src/cli/commands/linear-test.js +0 -123
  268. package/dist/src/cli/commands/linear-test.js.map +0 -1
  269. package/dist/src/cli/commands/linear.d.ts +0 -6
  270. package/dist/src/cli/commands/linear.d.ts.map +0 -1
  271. package/dist/src/cli/commands/linear.js +0 -393
  272. package/dist/src/cli/commands/linear.js.map +0 -1
  273. package/dist/src/cli/commands/log.d.ts +0 -7
  274. package/dist/src/cli/commands/log.d.ts.map +0 -1
  275. package/dist/src/cli/commands/log.js +0 -168
  276. package/dist/src/cli/commands/log.js.map +0 -1
  277. package/dist/src/cli/commands/onboard.d.ts +0 -8
  278. package/dist/src/cli/commands/onboard.d.ts.map +0 -1
  279. package/dist/src/cli/commands/onboard.js +0 -363
  280. package/dist/src/cli/commands/onboard.js.map +0 -1
  281. package/dist/src/cli/commands/projects.d.ts +0 -8
  282. package/dist/src/cli/commands/projects.d.ts.map +0 -1
  283. package/dist/src/cli/commands/projects.js +0 -220
  284. package/dist/src/cli/commands/projects.js.map +0 -1
  285. package/dist/src/cli/commands/search.d.ts +0 -7
  286. package/dist/src/cli/commands/search.d.ts.map +0 -1
  287. package/dist/src/cli/commands/search.js +0 -162
  288. package/dist/src/cli/commands/search.js.map +0 -1
  289. package/dist/src/cli/commands/session.d.ts +0 -7
  290. package/dist/src/cli/commands/session.d.ts.map +0 -1
  291. package/dist/src/cli/commands/session.js +0 -222
  292. package/dist/src/cli/commands/session.js.map +0 -1
  293. package/dist/src/cli/commands/tasks.d.ts +0 -7
  294. package/dist/src/cli/commands/tasks.d.ts.map +0 -1
  295. package/dist/src/cli/commands/tasks.js +0 -229
  296. package/dist/src/cli/commands/tasks.js.map +0 -1
  297. package/dist/src/cli/commands/webhook.d.ts +0 -3
  298. package/dist/src/cli/commands/webhook.d.ts.map +0 -1
  299. package/dist/src/cli/commands/webhook.js +0 -157
  300. package/dist/src/cli/commands/webhook.js.map +0 -1
  301. package/dist/src/cli/commands/worktree.d.ts +0 -8
  302. package/dist/src/cli/commands/worktree.d.ts.map +0 -1
  303. package/dist/src/cli/commands/worktree.js +0 -339
  304. package/dist/src/cli/commands/worktree.js.map +0 -1
  305. package/dist/src/cli/index.d.ts +0 -8
  306. package/dist/src/cli/index.d.ts.map +0 -1
  307. package/dist/src/cli/index.js +0 -995
  308. package/dist/src/cli/index.js.map +0 -1
  309. package/dist/src/cli/utils/viewer.d.ts +0 -3
  310. package/dist/src/cli/utils/viewer.d.ts.map +0 -1
  311. package/dist/src/cli/utils/viewer.js +0 -91
  312. package/dist/src/cli/utils/viewer.js.map +0 -1
  313. package/dist/src/core/config/config-manager.d.ts +0 -95
  314. package/dist/src/core/config/config-manager.d.ts.map +0 -1
  315. package/dist/src/core/config/config-manager.js +0 -359
  316. package/dist/src/core/config/config-manager.js.map +0 -1
  317. package/dist/src/core/config/types.d.ts +0 -72
  318. package/dist/src/core/config/types.d.ts.map +0 -1
  319. package/dist/src/core/config/types.js +0 -127
  320. package/dist/src/core/config/types.js.map +0 -1
  321. package/dist/src/core/context/auto-context.d.ts +0 -22
  322. package/dist/src/core/context/auto-context.d.ts.map +0 -1
  323. package/dist/src/core/context/auto-context.js +0 -77
  324. package/dist/src/core/context/auto-context.js.map +0 -1
  325. package/dist/src/core/context/compaction-handler.d.ts +0 -119
  326. package/dist/src/core/context/compaction-handler.d.ts.map +0 -1
  327. package/dist/src/core/context/compaction-handler.js +0 -306
  328. package/dist/src/core/context/compaction-handler.js.map +0 -1
  329. package/dist/src/core/context/frame-database.d.ts +0 -59
  330. package/dist/src/core/context/frame-database.d.ts.map +0 -1
  331. package/dist/src/core/context/frame-database.js +0 -333
  332. package/dist/src/core/context/frame-database.js.map +0 -1
  333. package/dist/src/core/context/frame-digest.d.ts +0 -59
  334. package/dist/src/core/context/frame-digest.d.ts.map +0 -1
  335. package/dist/src/core/context/frame-digest.js +0 -264
  336. package/dist/src/core/context/frame-digest.js.map +0 -1
  337. package/dist/src/core/context/frame-manager.d.ts +0 -112
  338. package/dist/src/core/context/frame-manager.d.ts.map +0 -1
  339. package/dist/src/core/context/frame-manager.js +0 -600
  340. package/dist/src/core/context/frame-manager.js.map +0 -1
  341. package/dist/src/core/context/frame-stack.d.ts +0 -85
  342. package/dist/src/core/context/frame-stack.d.ts.map +0 -1
  343. package/dist/src/core/context/frame-stack.js +0 -287
  344. package/dist/src/core/context/frame-stack.js.map +0 -1
  345. package/dist/src/core/context/frame-types.d.ts +0 -67
  346. package/dist/src/core/context/frame-types.d.ts.map +0 -1
  347. package/dist/src/core/context/frame-types.js +0 -6
  348. package/dist/src/core/context/frame-types.js.map +0 -1
  349. package/dist/src/core/context/index.d.ts +0 -11
  350. package/dist/src/core/context/index.d.ts.map +0 -1
  351. package/dist/src/core/context/index.js +0 -14
  352. package/dist/src/core/context/index.js.map +0 -1
  353. package/dist/src/core/context/model-aware-compaction.d.ts +0 -101
  354. package/dist/src/core/context/model-aware-compaction.d.ts.map +0 -1
  355. package/dist/src/core/context/model-aware-compaction.js +0 -616
  356. package/dist/src/core/context/model-aware-compaction.js.map +0 -1
  357. package/dist/src/core/context/refactored-frame-manager.d.ts +0 -99
  358. package/dist/src/core/context/refactored-frame-manager.d.ts.map +0 -1
  359. package/dist/src/core/context/refactored-frame-manager.js +0 -340
  360. package/dist/src/core/context/refactored-frame-manager.js.map +0 -1
  361. package/dist/src/core/database/batch-operations.d.ts +0 -118
  362. package/dist/src/core/database/batch-operations.d.ts.map +0 -1
  363. package/dist/src/core/database/batch-operations.js +0 -339
  364. package/dist/src/core/database/batch-operations.js.map +0 -1
  365. package/dist/src/core/database/connection-pool.d.ts +0 -79
  366. package/dist/src/core/database/connection-pool.d.ts.map +0 -1
  367. package/dist/src/core/database/connection-pool.js +0 -236
  368. package/dist/src/core/database/connection-pool.js.map +0 -1
  369. package/dist/src/core/database/query-cache.d.ts +0 -135
  370. package/dist/src/core/database/query-cache.d.ts.map +0 -1
  371. package/dist/src/core/database/query-cache.js +0 -294
  372. package/dist/src/core/database/query-cache.js.map +0 -1
  373. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts +0 -125
  374. package/dist/src/core/digest/enhanced-hybrid-digest.d.ts.map +0 -1
  375. package/dist/src/core/digest/enhanced-hybrid-digest.js +0 -282
  376. package/dist/src/core/digest/enhanced-hybrid-digest.js.map +0 -1
  377. package/dist/src/core/digest/frame-digest-integration.d.ts +0 -67
  378. package/dist/src/core/digest/frame-digest-integration.d.ts.map +0 -1
  379. package/dist/src/core/digest/frame-digest-integration.js +0 -198
  380. package/dist/src/core/digest/frame-digest-integration.js.map +0 -1
  381. package/dist/src/core/digest/hybrid-digest-generator.d.ts +0 -76
  382. package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +0 -1
  383. package/dist/src/core/digest/hybrid-digest-generator.js +0 -629
  384. package/dist/src/core/digest/hybrid-digest-generator.js.map +0 -1
  385. package/dist/src/core/digest/index.d.ts +0 -9
  386. package/dist/src/core/digest/index.d.ts.map +0 -1
  387. package/dist/src/core/digest/index.js +0 -9
  388. package/dist/src/core/digest/index.js.map +0 -1
  389. package/dist/src/core/digest/types.d.ts +0 -154
  390. package/dist/src/core/digest/types.d.ts.map +0 -1
  391. package/dist/src/core/digest/types.js +0 -18
  392. package/dist/src/core/digest/types.js.map +0 -1
  393. package/dist/src/core/errors/index.d.ts +0 -143
  394. package/dist/src/core/errors/index.d.ts.map +0 -1
  395. package/dist/src/core/errors/index.js +0 -282
  396. package/dist/src/core/errors/index.js.map +0 -1
  397. package/dist/src/core/errors/recovery.d.ts +0 -86
  398. package/dist/src/core/errors/recovery.d.ts.map +0 -1
  399. package/dist/src/core/errors/recovery.js +0 -274
  400. package/dist/src/core/errors/recovery.js.map +0 -1
  401. package/dist/src/core/merge/conflict-detector.d.ts +0 -122
  402. package/dist/src/core/merge/conflict-detector.d.ts.map +0 -1
  403. package/dist/src/core/merge/conflict-detector.js +0 -468
  404. package/dist/src/core/merge/conflict-detector.js.map +0 -1
  405. package/dist/src/core/merge/index.d.ts +0 -9
  406. package/dist/src/core/merge/index.d.ts.map +0 -1
  407. package/dist/src/core/merge/index.js +0 -9
  408. package/dist/src/core/merge/index.js.map +0 -1
  409. package/dist/src/core/merge/resolution-engine.d.ts +0 -120
  410. package/dist/src/core/merge/resolution-engine.d.ts.map +0 -1
  411. package/dist/src/core/merge/resolution-engine.js +0 -573
  412. package/dist/src/core/merge/resolution-engine.js.map +0 -1
  413. package/dist/src/core/merge/stack-diff.d.ts +0 -97
  414. package/dist/src/core/merge/stack-diff.d.ts.map +0 -1
  415. package/dist/src/core/merge/stack-diff.js +0 -516
  416. package/dist/src/core/merge/stack-diff.js.map +0 -1
  417. package/dist/src/core/merge/types.d.ts +0 -110
  418. package/dist/src/core/merge/types.d.ts.map +0 -1
  419. package/dist/src/core/merge/types.js +0 -6
  420. package/dist/src/core/merge/types.js.map +0 -1
  421. package/dist/src/core/monitoring/error-handler.d.ts +0 -46
  422. package/dist/src/core/monitoring/error-handler.d.ts.map +0 -1
  423. package/dist/src/core/monitoring/error-handler.js +0 -212
  424. package/dist/src/core/monitoring/error-handler.js.map +0 -1
  425. package/dist/src/core/monitoring/logger.d.ts +0 -24
  426. package/dist/src/core/monitoring/logger.d.ts.map +0 -1
  427. package/dist/src/core/monitoring/logger.js +0 -126
  428. package/dist/src/core/monitoring/logger.js.map +0 -1
  429. package/dist/src/core/monitoring/metrics.d.ts +0 -10
  430. package/dist/src/core/monitoring/metrics.d.ts.map +0 -1
  431. package/dist/src/core/monitoring/metrics.js +0 -152
  432. package/dist/src/core/monitoring/metrics.js.map +0 -1
  433. package/dist/src/core/monitoring/progress-tracker.d.ts +0 -95
  434. package/dist/src/core/monitoring/progress-tracker.d.ts.map +0 -1
  435. package/dist/src/core/monitoring/progress-tracker.js +0 -178
  436. package/dist/src/core/monitoring/progress-tracker.js.map +0 -1
  437. package/dist/src/core/performance/context-cache.d.ts +0 -109
  438. package/dist/src/core/performance/context-cache.d.ts.map +0 -1
  439. package/dist/src/core/performance/context-cache.js +0 -280
  440. package/dist/src/core/performance/context-cache.js.map +0 -1
  441. package/dist/src/core/performance/index.d.ts +0 -3
  442. package/dist/src/core/performance/index.d.ts.map +0 -1
  443. package/dist/src/core/performance/index.js +0 -3
  444. package/dist/src/core/performance/index.js.map +0 -1
  445. package/dist/src/core/performance/lazy-context-loader.d.ts +0 -93
  446. package/dist/src/core/performance/lazy-context-loader.d.ts.map +0 -1
  447. package/dist/src/core/performance/lazy-context-loader.js +0 -332
  448. package/dist/src/core/performance/lazy-context-loader.js.map +0 -1
  449. package/dist/src/core/performance/monitor.d.ts +0 -48
  450. package/dist/src/core/performance/monitor.d.ts.map +0 -1
  451. package/dist/src/core/performance/monitor.js +0 -226
  452. package/dist/src/core/performance/monitor.js.map +0 -1
  453. package/dist/src/core/performance/optimized-frame-context.d.ts +0 -74
  454. package/dist/src/core/performance/optimized-frame-context.d.ts.map +0 -1
  455. package/dist/src/core/performance/optimized-frame-context.js +0 -330
  456. package/dist/src/core/performance/optimized-frame-context.js.map +0 -1
  457. package/dist/src/core/performance/performance-benchmark.d.ts +0 -50
  458. package/dist/src/core/performance/performance-benchmark.d.ts.map +0 -1
  459. package/dist/src/core/performance/performance-benchmark.js +0 -290
  460. package/dist/src/core/performance/performance-benchmark.js.map +0 -1
  461. package/dist/src/core/performance/performance-profiler.d.ts +0 -151
  462. package/dist/src/core/performance/performance-profiler.d.ts.map +0 -1
  463. package/dist/src/core/performance/performance-profiler.js +0 -346
  464. package/dist/src/core/performance/performance-profiler.js.map +0 -1
  465. package/dist/src/core/performance/streaming-jsonl-parser.d.ts +0 -41
  466. package/dist/src/core/performance/streaming-jsonl-parser.d.ts.map +0 -1
  467. package/dist/src/core/performance/streaming-jsonl-parser.js +0 -193
  468. package/dist/src/core/performance/streaming-jsonl-parser.js.map +0 -1
  469. package/dist/src/core/persistence/postgres-adapter.d.ts +0 -31
  470. package/dist/src/core/persistence/postgres-adapter.d.ts.map +0 -1
  471. package/dist/src/core/persistence/postgres-adapter.js +0 -330
  472. package/dist/src/core/persistence/postgres-adapter.js.map +0 -1
  473. package/dist/src/core/projects/project-manager.d.ts +0 -130
  474. package/dist/src/core/projects/project-manager.d.ts.map +0 -1
  475. package/dist/src/core/projects/project-manager.js +0 -709
  476. package/dist/src/core/projects/project-manager.js.map +0 -1
  477. package/dist/src/core/query/query-parser.d.ts +0 -109
  478. package/dist/src/core/query/query-parser.d.ts.map +0 -1
  479. package/dist/src/core/query/query-parser.js +0 -415
  480. package/dist/src/core/query/query-parser.js.map +0 -1
  481. package/dist/src/core/query/query-templates.d.ts +0 -44
  482. package/dist/src/core/query/query-templates.d.ts.map +0 -1
  483. package/dist/src/core/query/query-templates.js +0 -326
  484. package/dist/src/core/query/query-templates.js.map +0 -1
  485. package/dist/src/core/retrieval/index.d.ts +0 -8
  486. package/dist/src/core/retrieval/index.d.ts.map +0 -1
  487. package/dist/src/core/retrieval/index.js +0 -8
  488. package/dist/src/core/retrieval/index.js.map +0 -1
  489. package/dist/src/core/retrieval/llm-context-retrieval.d.ts +0 -73
  490. package/dist/src/core/retrieval/llm-context-retrieval.d.ts.map +0 -1
  491. package/dist/src/core/retrieval/llm-context-retrieval.js +0 -597
  492. package/dist/src/core/retrieval/llm-context-retrieval.js.map +0 -1
  493. package/dist/src/core/retrieval/summary-generator.d.ts +0 -63
  494. package/dist/src/core/retrieval/summary-generator.d.ts.map +0 -1
  495. package/dist/src/core/retrieval/summary-generator.js +0 -622
  496. package/dist/src/core/retrieval/summary-generator.js.map +0 -1
  497. package/dist/src/core/retrieval/types.d.ts +0 -257
  498. package/dist/src/core/retrieval/types.d.ts.map +0 -1
  499. package/dist/src/core/retrieval/types.js +0 -18
  500. package/dist/src/core/retrieval/types.js.map +0 -1
  501. package/dist/src/core/session/index.d.ts +0 -2
  502. package/dist/src/core/session/index.d.ts.map +0 -1
  503. package/dist/src/core/session/index.js +0 -2
  504. package/dist/src/core/session/index.js.map +0 -1
  505. package/dist/src/core/session/session-manager.d.ts +0 -69
  506. package/dist/src/core/session/session-manager.d.ts.map +0 -1
  507. package/dist/src/core/session/session-manager.js +0 -311
  508. package/dist/src/core/session/session-manager.js.map +0 -1
  509. package/dist/src/core/trace/cli-trace-wrapper.d.ts +0 -23
  510. package/dist/src/core/trace/cli-trace-wrapper.d.ts.map +0 -1
  511. package/dist/src/core/trace/cli-trace-wrapper.js +0 -141
  512. package/dist/src/core/trace/cli-trace-wrapper.js.map +0 -1
  513. package/dist/src/core/trace/db-trace-wrapper.d.ts +0 -36
  514. package/dist/src/core/trace/db-trace-wrapper.d.ts.map +0 -1
  515. package/dist/src/core/trace/db-trace-wrapper.js +0 -252
  516. package/dist/src/core/trace/db-trace-wrapper.js.map +0 -1
  517. package/dist/src/core/trace/debug-trace.d.ts +0 -84
  518. package/dist/src/core/trace/debug-trace.d.ts.map +0 -1
  519. package/dist/src/core/trace/debug-trace.js +0 -402
  520. package/dist/src/core/trace/debug-trace.js.map +0 -1
  521. package/dist/src/core/trace/error-test.d.ts +0 -6
  522. package/dist/src/core/trace/error-test.d.ts.map +0 -1
  523. package/dist/src/core/trace/error-test.js +0 -128
  524. package/dist/src/core/trace/error-test.js.map +0 -1
  525. package/dist/src/core/trace/index.d.ts +0 -25
  526. package/dist/src/core/trace/index.d.ts.map +0 -1
  527. package/dist/src/core/trace/index.js +0 -121
  528. package/dist/src/core/trace/index.js.map +0 -1
  529. package/dist/src/core/trace/linear-api-wrapper.d.ts +0 -17
  530. package/dist/src/core/trace/linear-api-wrapper.d.ts.map +0 -1
  531. package/dist/src/core/trace/linear-api-wrapper.js +0 -205
  532. package/dist/src/core/trace/linear-api-wrapper.js.map +0 -1
  533. package/dist/src/core/trace/performance-test.d.ts +0 -6
  534. package/dist/src/core/trace/performance-test.d.ts.map +0 -1
  535. package/dist/src/core/trace/performance-test.js +0 -111
  536. package/dist/src/core/trace/performance-test.js.map +0 -1
  537. package/dist/src/core/trace/trace-demo.d.ts +0 -8
  538. package/dist/src/core/trace/trace-demo.d.ts.map +0 -1
  539. package/dist/src/core/trace/trace-demo.js +0 -154
  540. package/dist/src/core/trace/trace-demo.js.map +0 -1
  541. package/dist/src/core/trace/trace-detector.d.ts +0 -108
  542. package/dist/src/core/trace/trace-detector.d.ts.map +0 -1
  543. package/dist/src/core/trace/trace-detector.demo.d.ts +0 -5
  544. package/dist/src/core/trace/trace-detector.demo.d.ts.map +0 -1
  545. package/dist/src/core/trace/trace-detector.demo.js +0 -145
  546. package/dist/src/core/trace/trace-detector.demo.js.map +0 -1
  547. package/dist/src/core/trace/trace-detector.js +0 -425
  548. package/dist/src/core/trace/trace-detector.js.map +0 -1
  549. package/dist/src/core/trace/trace-store.d.ts +0 -60
  550. package/dist/src/core/trace/trace-store.d.ts.map +0 -1
  551. package/dist/src/core/trace/trace-store.js +0 -323
  552. package/dist/src/core/trace/trace-store.js.map +0 -1
  553. package/dist/src/core/trace/types.d.ts +0 -81
  554. package/dist/src/core/trace/types.d.ts.map +0 -1
  555. package/dist/src/core/trace/types.js +0 -70
  556. package/dist/src/core/trace/types.js.map +0 -1
  557. package/dist/src/core/types.d.ts +0 -35
  558. package/dist/src/core/types.d.ts.map +0 -1
  559. package/dist/src/core/types.js +0 -2
  560. package/dist/src/core/types.js.map +0 -1
  561. package/dist/src/core/utils/update-checker.d.ts +0 -38
  562. package/dist/src/core/utils/update-checker.d.ts.map +0 -1
  563. package/dist/src/core/utils/update-checker.js +0 -213
  564. package/dist/src/core/utils/update-checker.js.map +0 -1
  565. package/dist/src/core/worktree/worktree-manager.d.ts +0 -110
  566. package/dist/src/core/worktree/worktree-manager.d.ts.map +0 -1
  567. package/dist/src/core/worktree/worktree-manager.js +0 -456
  568. package/dist/src/core/worktree/worktree-manager.js.map +0 -1
  569. package/dist/src/features/analytics/api/analytics-api.d.ts +0 -24
  570. package/dist/src/features/analytics/api/analytics-api.d.ts.map +0 -1
  571. package/dist/src/features/analytics/api/analytics-api.js +0 -289
  572. package/dist/src/features/analytics/api/analytics-api.js.map +0 -1
  573. package/dist/src/features/analytics/core/analytics-service.d.ts +0 -29
  574. package/dist/src/features/analytics/core/analytics-service.d.ts.map +0 -1
  575. package/dist/src/features/analytics/core/analytics-service.js +0 -275
  576. package/dist/src/features/analytics/core/analytics-service.js.map +0 -1
  577. package/dist/src/features/analytics/index.d.ts +0 -12
  578. package/dist/src/features/analytics/index.d.ts.map +0 -1
  579. package/dist/src/features/analytics/index.js +0 -11
  580. package/dist/src/features/analytics/index.js.map +0 -1
  581. package/dist/src/features/analytics/queries/metrics-queries.d.ts +0 -11
  582. package/dist/src/features/analytics/queries/metrics-queries.d.ts.map +0 -1
  583. package/dist/src/features/analytics/queries/metrics-queries.js +0 -240
  584. package/dist/src/features/analytics/queries/metrics-queries.js.map +0 -1
  585. package/dist/src/features/analytics/types/metrics.d.ts +0 -60
  586. package/dist/src/features/analytics/types/metrics.d.ts.map +0 -1
  587. package/dist/src/features/analytics/types/metrics.js +0 -2
  588. package/dist/src/features/analytics/types/metrics.js.map +0 -1
  589. package/dist/src/features/browser/browser-mcp.d.ts +0 -94
  590. package/dist/src/features/browser/browser-mcp.d.ts.map +0 -1
  591. package/dist/src/features/browser/browser-mcp.js +0 -459
  592. package/dist/src/features/browser/browser-mcp.js.map +0 -1
  593. package/dist/src/features/tasks/pebbles-task-store.d.ts +0 -128
  594. package/dist/src/features/tasks/pebbles-task-store.d.ts.map +0 -1
  595. package/dist/src/features/tasks/pebbles-task-store.js +0 -572
  596. package/dist/src/features/tasks/pebbles-task-store.js.map +0 -1
  597. package/dist/src/features/tasks/task-aware-context.d.ts +0 -103
  598. package/dist/src/features/tasks/task-aware-context.d.ts.map +0 -1
  599. package/dist/src/features/tasks/task-aware-context.js +0 -412
  600. package/dist/src/features/tasks/task-aware-context.js.map +0 -1
  601. package/dist/src/index.d.ts +0 -21
  602. package/dist/src/index.d.ts.map +0 -1
  603. package/dist/src/index.js +0 -9
  604. package/dist/src/index.js.map +0 -1
  605. package/dist/src/integrations/linear/auth.d.ts +0 -99
  606. package/dist/src/integrations/linear/auth.d.ts.map +0 -1
  607. package/dist/src/integrations/linear/auth.js +0 -319
  608. package/dist/src/integrations/linear/auth.js.map +0 -1
  609. package/dist/src/integrations/linear/auto-sync.d.ts +0 -77
  610. package/dist/src/integrations/linear/auto-sync.d.ts.map +0 -1
  611. package/dist/src/integrations/linear/auto-sync.js +0 -268
  612. package/dist/src/integrations/linear/auto-sync.js.map +0 -1
  613. package/dist/src/integrations/linear/client.d.ts +0 -127
  614. package/dist/src/integrations/linear/client.d.ts.map +0 -1
  615. package/dist/src/integrations/linear/client.js +0 -446
  616. package/dist/src/integrations/linear/client.js.map +0 -1
  617. package/dist/src/integrations/linear/config.d.ts +0 -51
  618. package/dist/src/integrations/linear/config.d.ts.map +0 -1
  619. package/dist/src/integrations/linear/config.js +0 -103
  620. package/dist/src/integrations/linear/config.js.map +0 -1
  621. package/dist/src/integrations/linear/sync-manager.d.ts +0 -78
  622. package/dist/src/integrations/linear/sync-manager.d.ts.map +0 -1
  623. package/dist/src/integrations/linear/sync-manager.js +0 -235
  624. package/dist/src/integrations/linear/sync-manager.js.map +0 -1
  625. package/dist/src/integrations/linear/sync-service.d.ts +0 -46
  626. package/dist/src/integrations/linear/sync-service.d.ts.map +0 -1
  627. package/dist/src/integrations/linear/sync-service.js +0 -217
  628. package/dist/src/integrations/linear/sync-service.js.map +0 -1
  629. package/dist/src/integrations/linear/sync.d.ts +0 -125
  630. package/dist/src/integrations/linear/sync.d.ts.map +0 -1
  631. package/dist/src/integrations/linear/sync.js +0 -563
  632. package/dist/src/integrations/linear/sync.js.map +0 -1
  633. package/dist/src/integrations/linear/types.d.ts +0 -90
  634. package/dist/src/integrations/linear/types.d.ts.map +0 -1
  635. package/dist/src/integrations/linear/types.js +0 -2
  636. package/dist/src/integrations/linear/types.js.map +0 -1
  637. package/dist/src/integrations/linear/webhook-server.d.ts +0 -32
  638. package/dist/src/integrations/linear/webhook-server.d.ts.map +0 -1
  639. package/dist/src/integrations/linear/webhook-server.js +0 -190
  640. package/dist/src/integrations/linear/webhook-server.js.map +0 -1
  641. package/dist/src/integrations/linear/webhook.d.ts +0 -108
  642. package/dist/src/integrations/linear/webhook.d.ts.map +0 -1
  643. package/dist/src/integrations/linear/webhook.js +0 -291
  644. package/dist/src/integrations/linear/webhook.js.map +0 -1
  645. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts +0 -39
  646. package/dist/src/integrations/mcp/handlers/context-handlers.d.ts.map +0 -1
  647. package/dist/src/integrations/mcp/handlers/context-handlers.js +0 -266
  648. package/dist/src/integrations/mcp/handlers/context-handlers.js.map +0 -1
  649. package/dist/src/integrations/mcp/handlers/index.d.ts +0 -37
  650. package/dist/src/integrations/mcp/handlers/index.d.ts.map +0 -1
  651. package/dist/src/integrations/mcp/handlers/index.js +0 -134
  652. package/dist/src/integrations/mcp/handlers/index.js.map +0 -1
  653. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts +0 -33
  654. package/dist/src/integrations/mcp/handlers/linear-handlers.d.ts.map +0 -1
  655. package/dist/src/integrations/mcp/handlers/linear-handlers.js +0 -251
  656. package/dist/src/integrations/mcp/handlers/linear-handlers.js.map +0 -1
  657. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts +0 -42
  658. package/dist/src/integrations/mcp/handlers/task-handlers.d.ts.map +0 -1
  659. package/dist/src/integrations/mcp/handlers/task-handlers.js +0 -238
  660. package/dist/src/integrations/mcp/handlers/task-handlers.js.map +0 -1
  661. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts +0 -41
  662. package/dist/src/integrations/mcp/handlers/trace-handlers.d.ts.map +0 -1
  663. package/dist/src/integrations/mcp/handlers/trace-handlers.js +0 -298
  664. package/dist/src/integrations/mcp/handlers/trace-handlers.js.map +0 -1
  665. package/dist/src/integrations/mcp/index.d.ts +0 -13
  666. package/dist/src/integrations/mcp/index.d.ts.map +0 -1
  667. package/dist/src/integrations/mcp/index.js +0 -17
  668. package/dist/src/integrations/mcp/index.js.map +0 -1
  669. package/dist/src/integrations/mcp/refactored-server.d.ts +0 -76
  670. package/dist/src/integrations/mcp/refactored-server.d.ts.map +0 -1
  671. package/dist/src/integrations/mcp/refactored-server.js +0 -351
  672. package/dist/src/integrations/mcp/refactored-server.js.map +0 -1
  673. package/dist/src/integrations/mcp/server.d.ts +0 -54
  674. package/dist/src/integrations/mcp/server.d.ts.map +0 -1
  675. package/dist/src/integrations/mcp/server.js +0 -1616
  676. package/dist/src/integrations/mcp/server.js.map +0 -1
  677. package/dist/src/integrations/mcp/tool-definitions.d.ts +0 -44
  678. package/dist/src/integrations/mcp/tool-definitions.d.ts.map +0 -1
  679. package/dist/src/integrations/mcp/tool-definitions.js +0 -563
  680. package/dist/src/integrations/mcp/tool-definitions.js.map +0 -1
  681. package/dist/src/integrations/mcp/trace-test.d.ts +0 -5
  682. package/dist/src/integrations/mcp/trace-test.d.ts.map +0 -1
  683. package/dist/src/integrations/mcp/trace-test.js +0 -54
  684. package/dist/src/integrations/mcp/trace-test.js.map +0 -1
  685. package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts +0 -48
  686. package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts.map +0 -1
  687. package/dist/src/integrations/pg-aiguide/embedding-provider.js +0 -190
  688. package/dist/src/integrations/pg-aiguide/embedding-provider.js.map +0 -1
  689. package/dist/src/integrations/pg-aiguide/semantic-search.d.ts +0 -34
  690. package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +0 -1
  691. package/dist/src/integrations/pg-aiguide/semantic-search.js +0 -176
  692. package/dist/src/integrations/pg-aiguide/semantic-search.js.map +0 -1
  693. package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts +0 -44
  694. package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts.map +0 -1
  695. package/dist/src/integrations/pg-aiguide/timescale-analytics.js +0 -215
  696. package/dist/src/integrations/pg-aiguide/timescale-analytics.js.map +0 -1
  697. package/dist/src/mcp/stackmemory-mcp-server.d.ts +0 -9
  698. package/dist/src/mcp/stackmemory-mcp-server.d.ts.map +0 -1
  699. package/dist/src/mcp/stackmemory-mcp-server.js +0 -519
  700. package/dist/src/mcp/stackmemory-mcp-server.js.map +0 -1
  701. package/dist/src/middleware/exponential-rate-limiter.d.ts +0 -78
  702. package/dist/src/middleware/exponential-rate-limiter.d.ts.map +0 -1
  703. package/dist/src/middleware/exponential-rate-limiter.js +0 -293
  704. package/dist/src/middleware/exponential-rate-limiter.js.map +0 -1
  705. package/dist/src/models/user.model.d.ts +0 -62
  706. package/dist/src/models/user.model.d.ts.map +0 -1
  707. package/dist/src/models/user.model.js +0 -311
  708. package/dist/src/models/user.model.js.map +0 -1
  709. package/dist/src/servers/production/auth-middleware.d.ts +0 -76
  710. package/dist/src/servers/production/auth-middleware.d.ts.map +0 -1
  711. package/dist/src/servers/production/auth-middleware.js +0 -558
  712. package/dist/src/servers/production/auth-middleware.js.map +0 -1
  713. package/dist/src/servers/railway/index.d.ts +0 -7
  714. package/dist/src/servers/railway/index.d.ts.map +0 -1
  715. package/dist/src/servers/railway/index.js +0 -401
  716. package/dist/src/servers/railway/index.js.map +0 -1
  717. package/dist/src/services/config-service.d.ts +0 -44
  718. package/dist/src/services/config-service.d.ts.map +0 -1
  719. package/dist/src/services/config-service.js +0 -61
  720. package/dist/src/services/config-service.js.map +0 -1
  721. package/dist/src/services/context-service.d.ts +0 -17
  722. package/dist/src/services/context-service.d.ts.map +0 -1
  723. package/dist/src/services/context-service.js +0 -173
  724. package/dist/src/services/context-service.js.map +0 -1
  725. package/dist/src/types/task.d.ts +0 -27
  726. package/dist/src/types/task.d.ts.map +0 -1
  727. package/dist/src/types/task.js +0 -2
  728. package/dist/src/types/task.js.map +0 -1
  729. package/dist/src/utils/logger.d.ts +0 -13
  730. package/dist/src/utils/logger.d.ts.map +0 -1
  731. package/dist/src/utils/logger.js +0 -52
  732. package/dist/src/utils/logger.js.map +0 -1
  733. package/dist/src/validation/schemas.d.ts +0 -633
  734. package/dist/src/validation/schemas.d.ts.map +0 -1
  735. package/dist/src/validation/schemas.js +0 -347
  736. 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