squish-memory 1.1.5 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (499) hide show
  1. package/.env.example +32 -16
  2. package/CHANGELOG.md +147 -0
  3. package/README.md +120 -78
  4. package/{scripts → bin}/dependency-manager.mjs +217 -217
  5. package/{scripts → bin}/detect-clients.mjs +78 -78
  6. package/bin/install-interactive.mjs +321 -0
  7. package/bin/squish-mcp.mjs +46 -0
  8. package/bin/squish.mjs +33 -0
  9. package/config/mcp-migration-map.json +1 -6
  10. package/config/mcp-mode-semantics.json +19 -23
  11. package/config/mcp-remote-auth.json +3 -26
  12. package/config/mcp-universal.schema.json +5 -35
  13. package/config/settings.json +107 -52
  14. package/config.js +5 -0
  15. package/config.ts +218 -0
  16. package/core/adapters/config/claude-code.ts +133 -0
  17. package/core/adapters/config/cursor.ts +90 -0
  18. package/core/adapters/config/opencode.ts +89 -0
  19. package/core/adapters/config/windsurf.ts +90 -0
  20. package/core/adapters/index.ts +102 -0
  21. package/core/adapters/timeline.ts +116 -0
  22. package/core/adapters/types.ts +166 -0
  23. package/core/agent-preferences.ts +140 -0
  24. package/core/algorithms/analytics/token-estimator.ts +216 -0
  25. package/core/algorithms/detection/hash-filters.ts +260 -0
  26. package/core/algorithms/detection/semantic-ranker.ts +194 -0
  27. package/core/algorithms/detection/two-stage-detector.ts +421 -0
  28. package/core/algorithms/handlers/approve-merge.ts +215 -0
  29. package/core/algorithms/handlers/detect-duplicates.ts +192 -0
  30. package/core/algorithms/handlers/get-stats.ts +132 -0
  31. package/core/algorithms/handlers/list-proposals.ts +130 -0
  32. package/core/algorithms/handlers/preview-merge.ts +139 -0
  33. package/core/algorithms/handlers/reject-merge.ts +93 -0
  34. package/core/algorithms/handlers/reverse-merge.ts +155 -0
  35. package/core/algorithms/index.ts +39 -0
  36. package/core/algorithms/operations/cache-maintenance.ts +182 -0
  37. package/core/algorithms/safety/safety-checks.ts +256 -0
  38. package/core/algorithms/strategies/merge-strategies.ts +381 -0
  39. package/core/algorithms/types.ts +140 -0
  40. package/core/algorithms/utils/response-builder.ts +61 -0
  41. package/core/associations.ts +363 -0
  42. package/core/beliefs/decay.ts +289 -0
  43. package/core/beliefs/extractor.ts +131 -0
  44. package/core/beliefs/store.ts +557 -0
  45. package/core/beliefs/types.ts +38 -0
  46. package/core/commands/mcp-server.ts +5 -0
  47. package/core/compression.ts +177 -0
  48. package/core/config.js +2 -0
  49. package/core/consolidation.ts +330 -0
  50. package/core/context/agent-context.ts +388 -0
  51. package/core/context/context-paging.ts +449 -0
  52. package/core/context/context-window.ts +234 -0
  53. package/core/context/context.ts +35 -0
  54. package/core/embeddings/embeddings.ts +616 -0
  55. package/core/embeddings/google-multimodal.ts +200 -0
  56. package/{dist/core/local-embeddings.js → core/embeddings/local-embeddings.ts} +12 -11
  57. package/core/embeddings/qmd-client.ts +495 -0
  58. package/core/embeddings/transformers-local.ts +261 -0
  59. package/core/embeddings.js +4 -0
  60. package/core/error-handling.ts +206 -0
  61. package/core/external +219 -0
  62. package/core/graph/entity-deduplicator.ts +232 -0
  63. package/core/graph/graph-builder.ts +257 -0
  64. package/core/graph/graph-traversal.ts +490 -0
  65. package/core/graph/index.ts +24 -0
  66. package/core/graph/llm-entity-extractor.ts +402 -0
  67. package/core/graph/multi-hop-retrieval.ts +317 -0
  68. package/core/graph/relationship-extractor.ts +465 -0
  69. package/core/hooks/agent-hooks.ts +653 -0
  70. package/core/hooks/auto-tagger.ts +149 -0
  71. package/core/hooks/capture-filter.ts +169 -0
  72. package/core/hot-cache.ts +388 -0
  73. package/core/index.ts +10 -0
  74. package/core/ingestion/agent-memory.ts +167 -0
  75. package/core/ingestion/core-memory.ts +326 -0
  76. package/core/ingestion/learnings.ts +260 -0
  77. package/core/ingestion/signal-engine.ts +266 -0
  78. package/core/integrations/obsidian-vault.ts +197 -0
  79. package/core/layers/generator.ts +115 -0
  80. package/core/lib/db-client.ts +168 -0
  81. package/core/lib/parse-embedding.ts +59 -0
  82. package/core/lib/schemas.ts +102 -0
  83. package/core/lib/types.ts +49 -0
  84. package/core/lib/utils.ts +151 -0
  85. package/core/lib/validation.ts +180 -0
  86. package/core/lifecycle.ts +353 -0
  87. package/core/logger.ts +59 -0
  88. package/core/memory/bridge-discovery.ts +395 -0
  89. package/core/memory/categorizer.ts +390 -0
  90. package/core/memory/conflict-detector.ts +62 -0
  91. package/core/memory/consolidation.ts +372 -0
  92. package/core/memory/context-collector.ts +75 -0
  93. package/core/memory/contradiction-resolver.ts +494 -0
  94. package/core/memory/edit-workflow.ts +174 -0
  95. package/core/memory/entity-extractor.ts +426 -0
  96. package/core/memory/entity-resolver.ts +89 -0
  97. package/core/memory/explain.ts +112 -0
  98. package/core/memory/fact-deriver.ts +300 -0
  99. package/core/memory/fact-extractor.ts +120 -0
  100. package/core/memory/feedback-tracker.ts +200 -0
  101. package/core/memory/hooks.ts +230 -0
  102. package/core/memory/hybrid-retrieval.ts +65 -0
  103. package/core/memory/hybrid-scorer.ts +325 -0
  104. package/core/memory/hybrid-search.ts +748 -0
  105. package/core/memory/importance.ts +319 -0
  106. package/core/memory/index.ts +11 -0
  107. package/core/memory/loader.ts +178 -0
  108. package/core/memory/markdown/markdown-storage.ts +318 -0
  109. package/core/memory/memories.ts +565 -0
  110. package/core/memory/memory-lifecycle.ts +51 -0
  111. package/core/memory/memory-manager.ts +53 -0
  112. package/core/memory/migrate.ts +173 -0
  113. package/core/memory/normalization.ts +30 -0
  114. package/core/memory/path-strengthener.ts +211 -0
  115. package/core/memory/progressive-disclosure.ts +392 -0
  116. package/core/memory/query-processor.ts +130 -0
  117. package/core/memory/query-rewriter.ts +153 -0
  118. package/core/memory/response-analyzer.ts +81 -0
  119. package/core/memory/retrieval-feedback.ts +276 -0
  120. package/core/memory/serialization.ts +83 -0
  121. package/core/memory/stale-cleaner.ts +147 -0
  122. package/core/memory/stats.ts +181 -0
  123. package/core/memory/telemetry.ts +392 -0
  124. package/core/memory/temporal-facts.ts +356 -0
  125. package/core/memory/temporal-parser.ts +477 -0
  126. package/core/memory/trigger-detector.ts +104 -0
  127. package/core/memory/write-gate.ts +288 -0
  128. package/core/places/index.ts +14 -0
  129. package/core/places/memory-places.ts +339 -0
  130. package/core/places/places.ts +406 -0
  131. package/core/places/rules.ts +308 -0
  132. package/core/places/walking.ts +192 -0
  133. package/core/projects +89 -0
  134. package/core/projects.ts +131 -0
  135. package/core/redis.ts +82 -0
  136. package/core/responses.ts +187 -0
  137. package/core/runtime/trust-report.ts +195 -0
  138. package/core/runtime/trust-state.ts +360 -0
  139. package/core/scheduler/cron-scheduler.ts +581 -0
  140. package/core/scheduler/heartbeat.ts +91 -0
  141. package/core/scheduler/index.ts +8 -0
  142. package/core/scheduler/job-runner.ts +197 -0
  143. package/core/search/conversations.ts +166 -0
  144. package/core/search/entities.ts +46 -0
  145. package/core/search/folder-context.ts +154 -0
  146. package/core/search/graph-boost.ts +22 -0
  147. package/core/search/index.ts +4 -0
  148. package/core/search/qmd-wrapper.ts +84 -0
  149. package/core/security/encrypt.ts +51 -0
  150. package/core/security/governance.ts +102 -0
  151. package/core/security/privacy.ts +108 -0
  152. package/core/security/secret-detector.ts +122 -0
  153. package/core/session/auto-load.ts +160 -0
  154. package/core/session/entity-tracker.ts +363 -0
  155. package/core/session/index.ts +7 -0
  156. package/core/session/reference-resolver.ts +158 -0
  157. package/core/session/self-iteration-job.ts +478 -0
  158. package/core/session/session-hooks.ts +69 -0
  159. package/core/session/types.ts +36 -0
  160. package/core/session/working-set.ts +275 -0
  161. package/core/snapshots/cleanup.ts +13 -0
  162. package/core/snapshots/comparison.ts +59 -0
  163. package/core/snapshots/creation.ts +139 -0
  164. package/core/snapshots/retrieval.ts +44 -0
  165. package/core/snapshots/stats.ts +63 -0
  166. package/core/storage/cache.ts +241 -0
  167. package/core/storage/database.ts +23 -0
  168. package/core/summarization/cleanup.ts +13 -0
  169. package/core/summarization/queries.ts +32 -0
  170. package/core/summarization/stats.ts +64 -0
  171. package/core/summarization/strategies.ts +52 -0
  172. package/core/summarization.ts +248 -0
  173. package/core/temporal-facts.ts +244 -0
  174. package/core/tracing/collector.ts +470 -0
  175. package/core/tracing/visualizer.ts +195 -0
  176. package/core/utils/cleanup-operations.ts +50 -0
  177. package/core/utils/content-extraction.ts +95 -0
  178. package/core/utils/filter-builder.ts +56 -0
  179. package/core/utils/history-traversal.ts +63 -0
  180. package/core/utils/memory-operations.ts +56 -0
  181. package/core/utils/query-operations.ts +83 -0
  182. package/core/utils/summarization-helpers.ts +45 -0
  183. package/core/utils/temporal-queries.ts +39 -0
  184. package/core/utils/vector-operations.ts +135 -0
  185. package/core/utils/version-management.ts +74 -0
  186. package/core/worker.ts +324 -0
  187. package/db/adapter.ts +215 -0
  188. package/db/bootstrap.ts +1055 -0
  189. package/db/drizzle/migrations/0000_needy_cerebro.sql +402 -0
  190. package/db/drizzle/migrations/meta/0000_snapshot.json +3451 -0
  191. package/db/drizzle/migrations/meta/_journal.json +13 -0
  192. package/db/drizzle/schema-sqlite.ts +1032 -0
  193. package/db/drizzle/schema.ts +1128 -0
  194. package/db/drizzle.config.ts +12 -0
  195. package/db/index.ts +83 -0
  196. package/db/init.sql +5 -0
  197. package/db/migrations/associations.ts +35 -0
  198. package/db/migrations/beliefs.ts +89 -0
  199. package/db/migrations/core-memory.ts +35 -0
  200. package/db/migrations/fts.ts +59 -0
  201. package/db/migrations/index.ts +54 -0
  202. package/db/migrations/indexes.ts +36 -0
  203. package/db/migrations/learnings.ts +34 -0
  204. package/db/migrations/maintenance.ts +68 -0
  205. package/db/migrations/memories.ts +22 -0
  206. package/db/migrations/memory-places.ts +35 -0
  207. package/db/migrations/places.ts +49 -0
  208. package/db/migrations/projects.ts +21 -0
  209. package/db/migrations/tier-conversion.ts +24 -0
  210. package/db/neon.ts +22 -0
  211. package/db/schema/beliefs.ts +50 -0
  212. package/db/schema/generator.ts +159 -0
  213. package/db/schema/index.ts +58 -0
  214. package/db/schema/learnings.ts +32 -0
  215. package/db/schema/memories.ts +83 -0
  216. package/db/schema/projects.ts +33 -0
  217. package/db/schema.ts +13 -0
  218. package/db/supabase.ts +27 -0
  219. package/dist/config.d.ts +40 -17
  220. package/dist/config.js +150 -198
  221. package/dist/core/adapters/types.d.ts +13 -33
  222. package/dist/core/adapters/types.js +1 -1
  223. package/dist/core/agent-preferences.d.ts +16 -0
  224. package/dist/core/agent-preferences.js +124 -0
  225. package/dist/core/algorithms/safety/safety-checks.d.ts +1 -5
  226. package/dist/core/algorithms/types.d.ts +0 -8
  227. package/dist/core/associations.d.ts +3 -1
  228. package/dist/core/associations.js +37 -1
  229. package/dist/core/beliefs/decay.d.ts +27 -0
  230. package/dist/core/beliefs/decay.js +217 -0
  231. package/dist/core/beliefs/extractor.d.ts +9 -0
  232. package/dist/core/beliefs/extractor.js +113 -0
  233. package/dist/core/beliefs/store.d.ts +46 -0
  234. package/dist/core/beliefs/store.js +466 -0
  235. package/dist/core/beliefs/types.d.ts +28 -0
  236. package/dist/core/beliefs/types.js +2 -0
  237. package/dist/core/commands/mcp-server.d.ts +0 -1
  238. package/dist/core/commands/mcp-server.js +4 -737
  239. package/dist/core/commands/remember.d.ts +24 -0
  240. package/dist/core/commands/remember.js +144 -0
  241. package/dist/core/{toon.d.ts → compression.d.ts} +6 -4
  242. package/dist/core/{toon.js → compression.js} +8 -8
  243. package/dist/core/context/agent-context.js +1 -1
  244. package/dist/core/embeddings/embeddings.d.ts +29 -0
  245. package/dist/core/embeddings/embeddings.js +546 -0
  246. package/dist/core/embeddings/google-multimodal.js +6 -2
  247. package/dist/core/{local-embeddings.d.ts → embeddings/local-embeddings.d.ts} +1 -1
  248. package/dist/core/embeddings/local-embeddings.js +11 -0
  249. package/dist/core/embeddings/qmd-client.js +1 -1
  250. package/dist/core/embeddings/transformers-local.d.ts +64 -0
  251. package/dist/core/embeddings/transformers-local.js +213 -0
  252. package/dist/core/embeddings.d.ts +1 -28
  253. package/dist/core/embeddings.js +2 -453
  254. package/dist/core/graph/entity-deduplicator.d.ts +24 -0
  255. package/dist/core/graph/entity-deduplicator.js +183 -0
  256. package/dist/core/graph/graph-builder.d.ts +46 -0
  257. package/dist/core/graph/graph-builder.js +174 -0
  258. package/dist/core/graph/graph-traversal.d.ts +80 -0
  259. package/dist/core/graph/graph-traversal.js +315 -0
  260. package/dist/core/graph/index.d.ts +19 -0
  261. package/dist/core/graph/index.js +13 -0
  262. package/dist/core/graph/llm-entity-extractor.d.ts +49 -0
  263. package/dist/core/graph/llm-entity-extractor.js +313 -0
  264. package/dist/core/graph/multi-hop-retrieval.d.ts +48 -0
  265. package/dist/core/graph/multi-hop-retrieval.js +215 -0
  266. package/dist/core/graph/relationship-extractor.d.ts +48 -0
  267. package/dist/core/graph/relationship-extractor.js +351 -0
  268. package/dist/core/hooks/agent-hooks.d.ts +10 -1
  269. package/dist/core/hooks/agent-hooks.js +301 -24
  270. package/dist/core/hot-cache.d.ts +86 -0
  271. package/dist/core/hot-cache.js +285 -0
  272. package/dist/core/index.d.ts +9 -9
  273. package/dist/core/index.js +9 -12
  274. package/dist/core/ingestion/core-memory.d.ts +2 -2
  275. package/dist/core/ingestion/core-memory.js +3 -3
  276. package/dist/core/ingestion/learnings.js +3 -0
  277. package/dist/core/ingestion/signal-engine.d.ts +41 -0
  278. package/dist/core/ingestion/signal-engine.js +201 -0
  279. package/dist/core/{obsidian-vault.d.ts → integrations/obsidian-vault.d.ts} +2 -1
  280. package/dist/core/{obsidian-vault.js → integrations/obsidian-vault.js} +69 -7
  281. package/dist/core/lib/parse-embedding.d.ts +9 -0
  282. package/dist/core/lib/parse-embedding.js +58 -0
  283. package/dist/core/lib/schemas.d.ts +57 -54
  284. package/dist/core/lib/types.d.ts +45 -0
  285. package/dist/core/lib/types.js +6 -0
  286. package/dist/core/lib/utils.d.ts +4 -0
  287. package/dist/core/lib/utils.js +55 -0
  288. package/dist/core/lifecycle.d.ts +0 -1
  289. package/dist/core/lifecycle.js +13 -23
  290. package/dist/core/logger.d.ts +1 -0
  291. package/dist/core/logger.js +14 -8
  292. package/dist/core/mcp/tools.d.ts +0 -2
  293. package/dist/core/mcp/tools.js +0 -87
  294. package/dist/core/mcp/types.d.ts +25 -253
  295. package/dist/core/mcp/types.js +2 -2
  296. package/dist/core/memory/categorizer.js +1 -0
  297. package/dist/core/memory/consolidation.js +2 -28
  298. package/dist/core/memory/entity-extractor.d.ts +4 -0
  299. package/dist/core/memory/entity-extractor.js +30 -16
  300. package/dist/core/memory/explain.d.ts +18 -0
  301. package/dist/core/memory/explain.js +92 -0
  302. package/dist/core/memory/fact-deriver.d.ts +31 -0
  303. package/dist/core/memory/fact-deriver.js +236 -0
  304. package/dist/core/memory/hybrid-retrieval.d.ts +14 -16
  305. package/dist/core/memory/hybrid-retrieval.js +25 -127
  306. package/dist/core/memory/hybrid-scorer.js +6 -23
  307. package/dist/core/memory/hybrid-search.d.ts +10 -7
  308. package/dist/core/memory/hybrid-search.js +458 -221
  309. package/dist/core/memory/importance.d.ts +0 -17
  310. package/dist/core/memory/importance.js +1 -58
  311. package/dist/core/memory/index.d.ts +1 -0
  312. package/dist/core/memory/index.js +1 -0
  313. package/dist/core/memory/memories.d.ts +13 -17
  314. package/dist/core/memory/memories.js +78 -75
  315. package/dist/core/memory/memory-lifecycle.d.ts +2 -2
  316. package/dist/core/memory/memory-lifecycle.js +10 -18
  317. package/dist/core/memory/normalization.d.ts +1 -16
  318. package/dist/core/memory/path-strengthener.d.ts +39 -0
  319. package/dist/core/memory/path-strengthener.js +150 -0
  320. package/dist/core/memory/query-processor.js +37 -3
  321. package/dist/core/memory/retrieval-feedback.d.ts +70 -0
  322. package/dist/core/memory/retrieval-feedback.js +213 -0
  323. package/dist/core/memory/stale-cleaner.d.ts +26 -0
  324. package/dist/core/memory/stale-cleaner.js +97 -0
  325. package/dist/core/memory/stats.d.ts +10 -0
  326. package/dist/core/memory/stats.js +8 -3
  327. package/dist/core/memory/trigger-detector.d.ts +8 -1
  328. package/dist/core/memory/trigger-detector.js +42 -5
  329. package/dist/core/places/index.d.ts +1 -1
  330. package/dist/core/places/index.js +1 -1
  331. package/dist/core/places/places.d.ts +13 -13
  332. package/dist/core/places/places.js +27 -27
  333. package/dist/core/places/rules.js +23 -23
  334. package/dist/core/places/walking.d.ts +3 -3
  335. package/dist/core/places/walking.js +7 -7
  336. package/dist/core/projects.js +8 -0
  337. package/dist/core/runtime/trust-report.d.ts +102 -0
  338. package/dist/core/runtime/trust-report.js +107 -0
  339. package/dist/core/runtime/trust-state.d.ts +12 -0
  340. package/dist/core/runtime/trust-state.js +309 -0
  341. package/dist/core/scheduler/cron-scheduler.d.ts +1 -1
  342. package/dist/core/scheduler/cron-scheduler.js +164 -3
  343. package/dist/core/scheduler/job-runner.js +1 -1
  344. package/dist/core/search/qmd-wrapper.d.ts +36 -0
  345. package/dist/core/search/qmd-wrapper.js +58 -0
  346. package/dist/core/session/auto-load.js +28 -3
  347. package/dist/core/session/entity-tracker.d.ts +62 -0
  348. package/dist/core/session/entity-tracker.js +287 -0
  349. package/dist/core/session/reference-resolver.d.ts +26 -0
  350. package/dist/core/session/reference-resolver.js +121 -0
  351. package/dist/core/session/self-iteration-job.d.ts +15 -0
  352. package/dist/core/session/self-iteration-job.js +163 -58
  353. package/dist/core/session/working-set.d.ts +50 -0
  354. package/dist/core/session/working-set.js +212 -0
  355. package/dist/core/snapshots/creation.d.ts +2 -8
  356. package/dist/core/snapshots/creation.js +3 -12
  357. package/dist/core/utils/summarization-helpers.d.ts +0 -4
  358. package/dist/core/utils/summarization-helpers.js +1 -6
  359. package/dist/db/bootstrap.d.ts +2 -0
  360. package/dist/db/bootstrap.js +229 -280
  361. package/dist/db/drizzle/schema-sqlite.d.ts +702 -1
  362. package/dist/db/drizzle/schema-sqlite.js +83 -4
  363. package/dist/db/drizzle/schema.d.ts +653 -1
  364. package/dist/db/drizzle/schema.js +93 -4
  365. package/dist/db/migrations/associations.d.ts +6 -0
  366. package/dist/db/migrations/associations.js +29 -0
  367. package/dist/db/migrations/beliefs.d.ts +10 -0
  368. package/dist/db/migrations/beliefs.js +76 -0
  369. package/dist/db/migrations/core-memory.d.ts +6 -0
  370. package/dist/db/migrations/core-memory.js +29 -0
  371. package/dist/db/migrations/fts.d.ts +6 -0
  372. package/dist/db/migrations/fts.js +52 -0
  373. package/dist/db/migrations/index.d.ts +25 -0
  374. package/dist/db/migrations/index.js +51 -0
  375. package/dist/db/migrations/indexes.d.ts +6 -0
  376. package/dist/db/migrations/indexes.js +30 -0
  377. package/dist/db/migrations/learnings.d.ts +7 -0
  378. package/dist/db/migrations/learnings.js +26 -0
  379. package/dist/db/migrations/maintenance.d.ts +6 -0
  380. package/dist/db/migrations/maintenance.js +61 -0
  381. package/dist/db/migrations/memories.d.ts +7 -0
  382. package/dist/db/migrations/memories.js +16 -0
  383. package/dist/db/migrations/memory-places.d.ts +6 -0
  384. package/dist/db/migrations/memory-places.js +29 -0
  385. package/dist/db/migrations/places.d.ts +6 -0
  386. package/dist/db/migrations/places.js +43 -0
  387. package/dist/db/migrations/projects.d.ts +3 -0
  388. package/dist/db/migrations/projects.js +13 -0
  389. package/dist/db/migrations/tier-conversion.d.ts +7 -0
  390. package/dist/db/migrations/tier-conversion.js +20 -0
  391. package/dist/db/schema/beliefs.d.ts +9 -0
  392. package/dist/db/schema/beliefs.js +46 -0
  393. package/dist/db/schema/generator.d.ts +38 -0
  394. package/dist/db/schema/generator.js +108 -0
  395. package/dist/db/schema/index.d.ts +19 -20
  396. package/dist/db/schema/index.js +25 -79
  397. package/dist/db/schema/learnings.d.ts +7 -0
  398. package/dist/db/schema/learnings.js +30 -0
  399. package/dist/db/schema/memories.d.ts +7 -0
  400. package/dist/db/schema/memories.js +81 -0
  401. package/dist/db/schema/projects.d.ts +4 -0
  402. package/dist/db/schema/projects.js +31 -0
  403. package/dist/packages/mcp/src/index.d.ts +3 -0
  404. package/dist/packages/mcp/src/index.js +733 -0
  405. package/mcp.json.example +8 -11
  406. package/package.json +57 -76
  407. package/packages/cli/package.json +22 -0
  408. package/packages/cli/src/commands/clean.ts +68 -0
  409. package/packages/cli/src/commands/context.ts +79 -0
  410. package/packages/cli/src/commands/doctor.ts +357 -0
  411. package/packages/cli/src/commands/forget.ts +72 -0
  412. package/packages/cli/src/commands/health.ts +36 -0
  413. package/packages/cli/src/commands/inspect.ts +41 -0
  414. package/packages/cli/src/commands/link.ts +50 -0
  415. package/packages/cli/src/commands/migrate.ts +93 -0
  416. package/packages/cli/src/commands/recall.ts +99 -0
  417. package/packages/cli/src/commands/recent.ts +57 -0
  418. package/packages/cli/src/commands/remember.ts +139 -0
  419. package/packages/cli/src/commands/run.ts +58 -0
  420. package/packages/cli/src/commands/stale.ts +43 -0
  421. package/packages/cli/src/commands/stats.ts +42 -0
  422. package/packages/cli/src/index.ts +57 -0
  423. package/packages/cli/tsconfig.json +24 -0
  424. package/packages/mcp/package.json +26 -0
  425. package/packages/mcp/src/index.ts +877 -0
  426. package/packages/mcp/tsconfig.json +20 -0
  427. package/skills/squish-memory/SKILL.md +38 -35
  428. package/skills/squish-memory/{scripts/install.sh → install.sh} +1 -1
  429. package/skills/squish-memory/references/claude-desktop.json +12 -0
  430. package/skills/squish-memory/references/openclaw.json +13 -0
  431. package/skills/squish-memory/references/opencode.json +14 -0
  432. package/config/hooks/claude-code-hooks.json +0 -39
  433. package/config/hooks/cursor-hooks.json +0 -30
  434. package/config/hooks/opencode-hooks.json +0 -30
  435. package/config/hooks/windsurf-hooks.json +0 -30
  436. package/config/mcp-cli-fallback-policy.json +0 -22
  437. package/config/mcp.json +0 -38
  438. package/config/plugin-manifest.json +0 -101
  439. package/config/plugin-manifest.schema.json +0 -244
  440. package/config/plugin.json +0 -32
  441. package/config/remote-memory-policy.json +0 -32
  442. package/core/commands/context-paging.md +0 -51
  443. package/core/commands/context-status.md +0 -22
  444. package/core/commands/context.md +0 -5
  445. package/core/commands/core-memory.md +0 -56
  446. package/core/commands/health.md +0 -5
  447. package/core/commands/init.md +0 -39
  448. package/core/commands/merge.md +0 -113
  449. package/core/commands/recall.md +0 -5
  450. package/core/commands/remember.md +0 -11
  451. package/core/commands/search.md +0 -10
  452. package/dist/core/commands/managed-sync.d.ts +0 -10
  453. package/dist/core/commands/managed-sync.js +0 -64
  454. package/dist/core/external-folder/index.d.ts +0 -102
  455. package/dist/core/external-folder/index.js +0 -294
  456. package/dist/core/namespaces/index.d.ts +0 -71
  457. package/dist/core/namespaces/index.js +0 -305
  458. package/dist/core/namespaces/uri-parser.d.ts +0 -31
  459. package/dist/core/namespaces/uri-parser.js +0 -74
  460. package/dist/core/search/qmd-search.d.ts +0 -61
  461. package/dist/core/search/qmd-search.js +0 -178
  462. package/dist/core/session-hooks/self-iteration-job.d.ts +0 -20
  463. package/dist/core/session-hooks/self-iteration-job.js +0 -282
  464. package/dist/core/session-hooks/session-hooks.d.ts +0 -18
  465. package/dist/core/session-hooks/session-hooks.js +0 -58
  466. package/dist/core/snapshots.d.ts +0 -29
  467. package/dist/core/snapshots.js +0 -220
  468. package/dist/core/sync/qmd-sync.d.ts +0 -94
  469. package/dist/core/sync/qmd-sync.js +0 -201
  470. package/dist/index.d.ts +0 -7
  471. package/dist/index.js +0 -1677
  472. package/dist/vendor/sql.js/sql-wasm.wasm +0 -0
  473. package/dist/webui/server.d.ts +0 -5
  474. package/dist/webui/server.js +0 -642
  475. package/generated/mcp/manifest.json +0 -23
  476. package/generated/mcp/mcp-servers.json +0 -25
  477. package/generated/mcp/mcporter.json +0 -34
  478. package/generated/mcp/openclaw-memory-qmd.json +0 -17
  479. package/generated/mcp/runtime.json +0 -12
  480. package/scripts/README.md +0 -60
  481. package/scripts/build-release.sh +0 -36
  482. package/scripts/check-secrets.js +0 -132
  483. package/scripts/copy-runtime-assets.mjs +0 -26
  484. package/scripts/generate-mcp.mjs +0 -264
  485. package/scripts/github-release.sh +0 -77
  486. package/scripts/init-dirs.mjs +0 -13
  487. package/scripts/install-claude-code.sh +0 -85
  488. package/scripts/install-cursor.sh +0 -56
  489. package/scripts/install-hooks.sh +0 -73
  490. package/scripts/install-interactive.mjs +0 -357
  491. package/scripts/install-opencode.sh +0 -75
  492. package/scripts/install-plugin.mjs +0 -415
  493. package/scripts/install-windsurf.sh +0 -67
  494. package/scripts/remote-preflight.mjs +0 -62
  495. package/scripts/squish-fallback.mjs +0 -132
  496. package/scripts/test-interactive.mjs +0 -131
  497. package/scripts/verify-mcp.mjs +0 -214
  498. package/skills/squish-memory/scripts/install.mjs +0 -335
  499. package/skills/squish-memory/write_skill.js +0 -2
@@ -0,0 +1,213 @@
1
+ /**
2
+ * Transformers.js Local Embedding Provider
3
+ *
4
+ * Uses ONNX-based transformer models for high-quality local embeddings.
5
+ * Supports Hugging Face ONNX embedding models.
6
+ *
7
+ * Usage:
8
+ * Set SQUISH_EMBEDDINGS_PROVIDER=transformers
9
+ * Required: SQUISH_LOCAL_MODEL=<huggingface-onnx-model>
10
+ *
11
+ * Download models automatically on first use. Models cached in HuggingFace cache directory.
12
+ */
13
+ import { pipeline } from '@huggingface/transformers';
14
+ import { logger } from '../logger.js';
15
+ import { config } from '../../config.js';
16
+ const DEFAULT_CONFIG = {
17
+ model: '',
18
+ device: 'cpu',
19
+ dtype: 'q8', // Quantized for smaller size + faster loading
20
+ };
21
+ // Singleton pipeline instance
22
+ let embeddingPipeline = null;
23
+ let isLoading = false;
24
+ let loadPromise = null;
25
+ /**
26
+ * Get or initialize the embedding pipeline (lazy loading)
27
+ */
28
+ async function getPipeline() {
29
+ // Return existing pipeline
30
+ if (embeddingPipeline) {
31
+ return embeddingPipeline;
32
+ }
33
+ // Already loading - wait for it
34
+ if (isLoading && loadPromise) {
35
+ return loadPromise;
36
+ }
37
+ // Start loading
38
+ isLoading = true;
39
+ const model = config.transformersLocalModel;
40
+ if (!model) {
41
+ isLoading = false;
42
+ throw new Error('Transformers provider requires SQUISH_LOCAL_MODEL to be set');
43
+ }
44
+ logger.info(`Loading transformers local model: ${model}`);
45
+ loadPromise = (async () => {
46
+ try {
47
+ embeddingPipeline = await pipeline('feature-extraction', model, {
48
+ device: DEFAULT_CONFIG.device,
49
+ dtype: DEFAULT_CONFIG.dtype,
50
+ });
51
+ logger.info(`Transformers local model loaded: ${model}`);
52
+ return embeddingPipeline;
53
+ }
54
+ catch (error) {
55
+ logger.error(`Failed to load transformers model: ${error}`);
56
+ embeddingPipeline = null;
57
+ throw error;
58
+ }
59
+ finally {
60
+ isLoading = false;
61
+ loadPromise = null;
62
+ }
63
+ })();
64
+ return loadPromise;
65
+ }
66
+ /**
67
+ * Check if pipeline is loaded
68
+ */
69
+ export function isReady() {
70
+ return embeddingPipeline !== null;
71
+ }
72
+ /**
73
+ * Get embedding dimension for current model
74
+ */
75
+ export function getEmbeddingDimension() {
76
+ return 0;
77
+ }
78
+ /**
79
+ * Generate embedding for a single text input
80
+ * Uses mean pooling + L2 normalization
81
+ */
82
+ export async function getEmbedding(text) {
83
+ if (!text || typeof text !== 'string') {
84
+ return null;
85
+ }
86
+ try {
87
+ const pipeline = await getPipeline();
88
+ if (!pipeline) {
89
+ return null;
90
+ }
91
+ // Truncate to max sequence length (256 tokens)
92
+ const truncatedText = text.slice(0, 512);
93
+ // Run feature extraction with pooling
94
+ const output = await pipeline(truncatedText, {
95
+ pooling: 'mean',
96
+ normalize: true,
97
+ });
98
+ // Convert tensor to array
99
+ const embedding = Array.from(output.data);
100
+ return embedding;
101
+ }
102
+ catch (error) {
103
+ logger.warn(`Transformers embedding error: ${error}`);
104
+ return null;
105
+ }
106
+ }
107
+ /**
108
+ * Generate embeddings for multiple texts in batch
109
+ * Processes efficiently with batching
110
+ */
111
+ export async function getBatchEmbeddings(texts, batchSize = 8) {
112
+ if (texts.length === 0) {
113
+ return [];
114
+ }
115
+ const results = new Array(texts.length).fill(null);
116
+ // Process in batches
117
+ for (let i = 0; i < texts.length; i += batchSize) {
118
+ const batchEnd = Math.min(i + batchSize, texts.length);
119
+ const batch = texts.slice(i, batchEnd);
120
+ const indices = [...Array(batch.length).keys()].map(j => i + j);
121
+ try {
122
+ const pipeline = await getPipeline();
123
+ if (!pipeline) {
124
+ continue;
125
+ }
126
+ // Truncate each text
127
+ const truncatedBatch = batch.map(t => t.slice(0, 512));
128
+ // Process batch
129
+ const outputs = await Promise.all(truncatedBatch.map(text => pipeline(text, { pooling: 'mean', normalize: true })));
130
+ // Store results
131
+ for (let j = 0; j < outputs.length; j++) {
132
+ results[indices[j]] = Array.from(outputs[j].data);
133
+ }
134
+ }
135
+ catch (error) {
136
+ logger.warn(`Transformers batch embedding error: ${error}`);
137
+ }
138
+ }
139
+ return results;
140
+ }
141
+ /**
142
+ * Check health of the transformers provider
143
+ */
144
+ export async function checkHealth() {
145
+ const model = config.transformersLocalModel;
146
+ if (!model) {
147
+ return {
148
+ available: false,
149
+ error: 'SQUISH_LOCAL_MODEL is not configured',
150
+ };
151
+ }
152
+ // Check if library is available
153
+ try {
154
+ await import('@huggingface/transformers');
155
+ }
156
+ catch (error) {
157
+ return {
158
+ available: false,
159
+ error: '@huggingface/transformers not installed',
160
+ };
161
+ }
162
+ // Try quick embedding
163
+ const start = Date.now();
164
+ try {
165
+ const embedding = await getEmbedding('health check test');
166
+ const latency = Date.now() - start;
167
+ return {
168
+ available: embedding !== null && embedding.length > 0,
169
+ latencyMs: latency,
170
+ model,
171
+ dimension: embedding?.length || 0,
172
+ };
173
+ }
174
+ catch (error) {
175
+ return {
176
+ available: false,
177
+ error: error.message,
178
+ model,
179
+ };
180
+ }
181
+ }
182
+ /**
183
+ * Unload the pipeline (for testing or memory management)
184
+ */
185
+ export async function unload() {
186
+ if (embeddingPipeline) {
187
+ // Pipeline doesn't have explicit cleanup, just release reference
188
+ embeddingPipeline = null;
189
+ logger.info('Transformers pipeline unloaded');
190
+ }
191
+ }
192
+ /**
193
+ * Warm up the model with a test input
194
+ */
195
+ export async function warmup() {
196
+ try {
197
+ const result = await getEmbedding('warmup test');
198
+ return result !== null && result.length > 0;
199
+ }
200
+ catch {
201
+ return false;
202
+ }
203
+ }
204
+ export default {
205
+ isReady,
206
+ getEmbeddingDimension,
207
+ getEmbedding,
208
+ getBatchEmbeddings,
209
+ checkHealth,
210
+ unload,
211
+ warmup,
212
+ };
213
+ //# sourceMappingURL=transformers-local.js.map
@@ -1,29 +1,2 @@
1
- import { MultimodalInput } from './embeddings/google-multimodal.js';
2
- export type EmbeddingProvider = 'local' | 'openai' | 'ollama' | 'lmstudio' | 'google' | 'none' | 'auto';
3
- export declare function getEmbedding(input: string | MultimodalInput): Promise<number[] | null>;
4
- /**
5
- * Get embeddings for multiple inputs in parallel batches
6
- * Processes inputs in batches to respect rate limits while parallelizing
7
- */
8
- export declare function getBatchEmbeddings(inputs: string[], batchSize?: number): Promise<Array<number[] | null>>;
9
- /**
10
- * Clear the embedding cache
11
- */
12
- export declare function clearEmbeddingCache(): void;
13
- /**
14
- * Get embedding cache statistics
15
- */
16
- export declare function getEmbeddingCacheStats(): {
17
- size: number;
18
- maxSize: number;
19
- };
20
- /**
21
- * Check health of all configured embedding providers
22
- * Returns availability and latency for each provider
23
- */
24
- export declare function checkEmbeddingProviderHealth(): Promise<Map<string, {
25
- available: boolean;
26
- latencyMs?: number;
27
- error?: string;
28
- }>>;
1
+ export * from './embeddings/embeddings';
29
2
  //# sourceMappingURL=embeddings.d.ts.map
@@ -1,454 +1,3 @@
1
- import { config } from '../config.js';
2
- import { getGoogleMultimodalEmbedding, isMultimodalInput } from './embeddings/google-multimodal.js';
3
- import { logger } from './logger.js';
4
- // Retry utility with exponential backoff
5
- async function withRetry(fn, maxRetries = config.embeddingsMaxRetries, baseDelayMs = config.embeddingsRetryDelayMs) {
6
- let lastError;
7
- for (let attempt = 0; attempt < maxRetries; attempt++) {
8
- try {
9
- return await fn();
10
- }
11
- catch (error) {
12
- lastError = error;
13
- // Only retry on network errors (5xx, ECONNRESET, ETIMEDOUT, etc.)
14
- if (error instanceof Error && shouldRetryError(error)) {
15
- const delay = baseDelayMs * Math.pow(2, attempt) + Math.random() * baseDelayMs;
16
- logger.debug(`Embedding request failed (attempt ${attempt + 1}/${maxRetries}), retrying in ${delay.toFixed(0)}ms`, { error: error });
17
- await new Promise(resolve => setTimeout(resolve, delay));
18
- continue;
19
- }
20
- // Don't retry on 4xx errors or non-retryable errors
21
- break;
22
- }
23
- }
24
- throw lastError;
25
- }
26
- function shouldRetryError(error) {
27
- const message = error.message.toLowerCase();
28
- // Network errors that are typically transient
29
- const retryablePatterns = [
30
- 'econnreset',
31
- 'etimedout',
32
- 'econnrefused',
33
- 'esocket',
34
- 'network error',
35
- 'fetch failed',
36
- 'timeout',
37
- 'request timed out',
38
- 'service unavailable',
39
- 'too many requests',
40
- 'rate limit',
41
- 'internal server error',
42
- 'bad gateway',
43
- 'gateway timeout',
44
- ];
45
- return retryablePatterns.some(pattern => message.includes(pattern));
46
- }
47
- // Timeout wrapper using AbortController
48
- async function withTimeout(promise, timeoutMs) {
49
- const controller = new AbortController();
50
- const timeoutId = setTimeout(() => controller.abort(), timeoutMs);
51
- try {
52
- return await promise;
53
- }
54
- finally {
55
- clearTimeout(timeoutId);
56
- }
57
- }
58
- // Fetch wrapper that combines retry and timeout
59
- async function fetchWithRetryAndTimeout(url, options, timeoutMs = config.embeddingsTimeoutMs) {
60
- return withRetry(async () => {
61
- return withTimeout(fetch(url, options), timeoutMs);
62
- });
63
- }
64
- // Simple in-memory cache for embeddings (LRU with 1000 entries)
65
- const embeddingCache = new Map();
66
- const MAX_CACHE_SIZE = 1000;
67
- function getCacheKey(input, provider) {
68
- // Simple hash of input + provider
69
- let hash = 0;
70
- const str = input + provider;
71
- for (let i = 0; i < str.length; i++) {
72
- const char = str.charCodeAt(i);
73
- hash = ((hash << 5) - hash) + char;
74
- hash = hash & hash; // Convert to 32bit integer
75
- }
76
- return hash.toString();
77
- }
78
- function getCachedEmbedding(key) {
79
- return embeddingCache.get(key);
80
- }
81
- function setCachedEmbedding(key, embedding) {
82
- if (embeddingCache.size >= MAX_CACHE_SIZE) {
83
- // Remove oldest entry (first one)
84
- const firstKey = embeddingCache.keys().next().value;
85
- if (firstKey) {
86
- embeddingCache.delete(firstKey);
87
- }
88
- }
89
- embeddingCache.set(key, embedding);
90
- }
91
- export async function getEmbedding(input) {
92
- if (!input || (typeof input !== 'string' && !isMultimodalInput(input))) {
93
- return null;
94
- }
95
- const provider = config.embeddingsProvider;
96
- const cacheKey = typeof input === 'string'
97
- ? getCacheKey(input, provider)
98
- : getCacheKey(JSON.stringify(input), provider);
99
- // Check cache first
100
- const cached = getCachedEmbedding(cacheKey);
101
- if (cached) {
102
- return cached;
103
- }
104
- let result = null;
105
- // Handle multimodal input
106
- if (isMultimodalInput(input) && provider === 'google') {
107
- const multimodalResult = await getGoogleMultimodalEmbedding(input);
108
- if (multimodalResult) {
109
- result = multimodalResult.embedding;
110
- }
111
- }
112
- // Handle text-only input
113
- if (!result && typeof input === 'string') {
114
- const textInput = input;
115
- if (provider === 'none') {
116
- result = null;
117
- }
118
- else if (provider === 'google') {
119
- const multimodalResult = await getGoogleMultimodalEmbedding({ text: textInput });
120
- result = multimodalResult?.embedding || null;
121
- }
122
- else if (provider === 'openai') {
123
- result = await getOpenAiEmbedding(textInput);
124
- }
125
- else if (provider === 'ollama') {
126
- result = await getOllamaEmbedding(textInput);
127
- }
128
- else if (provider === 'lmstudio') {
129
- result = await getLmStudioEmbedding(textInput);
130
- }
131
- else if (provider === 'local') {
132
- result = getLocalEmbedding(textInput);
133
- }
134
- else {
135
- // Auto mode: try cloud providers first if configured, then fall back to local
136
- if (config.openAiApiKey) {
137
- result = await getOpenAiEmbedding(textInput);
138
- }
139
- if (!result && config.ollamaUrl) {
140
- result = await getOllamaEmbedding(textInput);
141
- }
142
- if (!result && config.lmStudioUrl) {
143
- result = await getLmStudioEmbedding(textInput);
144
- }
145
- if (!result) {
146
- result = getLocalEmbedding(textInput);
147
- }
148
- }
149
- }
150
- // Cache the result if valid
151
- if (result) {
152
- setCachedEmbedding(cacheKey, result);
153
- }
154
- return result;
155
- }
156
- /**
157
- * Get embeddings for multiple inputs in parallel batches
158
- * Processes inputs in batches to respect rate limits while parallelizing
159
- */
160
- export async function getBatchEmbeddings(inputs, batchSize = 20) {
161
- if (inputs.length === 0)
162
- return [];
163
- const results = new Array(inputs.length).fill(null);
164
- const provider = config.embeddingsProvider;
165
- // Check cache for all inputs first
166
- const uncachedIndices = [];
167
- const uncachedInputs = [];
168
- for (let i = 0; i < inputs.length; i++) {
169
- const cacheKey = getCacheKey(inputs[i], provider);
170
- const cached = getCachedEmbedding(cacheKey);
171
- if (cached) {
172
- results[i] = cached;
173
- }
174
- else {
175
- uncachedIndices.push(i);
176
- uncachedInputs.push(inputs[i]);
177
- }
178
- }
179
- // Process only uncached inputs in batches
180
- for (let i = 0; i < uncachedInputs.length; i += batchSize) {
181
- const batchEnd = Math.min(i + batchSize, uncachedInputs.length);
182
- const batch = uncachedInputs.slice(i, batchEnd);
183
- const indices = uncachedIndices.slice(i, batchEnd);
184
- // Parallelize embeddings within batch using Promise.all
185
- const batchResults = await Promise.all(batch.map((input) => getEmbedding(input)));
186
- // Store results in correct positions and cache
187
- for (let j = 0; j < batchResults.length; j++) {
188
- results[indices[j]] = batchResults[j];
189
- }
190
- }
191
- return results;
192
- }
193
- /**
194
- * Clear the embedding cache
195
- */
196
- export function clearEmbeddingCache() {
197
- embeddingCache.clear();
198
- }
199
- /**
200
- * Get embedding cache statistics
201
- */
202
- export function getEmbeddingCacheStats() {
203
- return {
204
- size: embeddingCache.size,
205
- maxSize: MAX_CACHE_SIZE,
206
- };
207
- }
208
- /**
209
- * Local TF-IDF embedding using character n-grams and word hashing
210
- * Creates a 768-dimensional vector (same size as OpenAI text-embedding-3-small)
211
- * Fast, no API calls, works offline
212
- */
213
- function getLocalEmbedding(input) {
214
- if (!input || typeof input !== 'string') {
215
- return null;
216
- }
217
- // Normalize text
218
- const text = input.toLowerCase()
219
- .replace(/[^a-z0-9\s]/g, ' ')
220
- .replace(/\s+/g, ' ')
221
- .trim();
222
- if (text.length === 0) {
223
- return null;
224
- }
225
- // Embedding dimensions
226
- const dimensions = 768;
227
- const vector = new Array(dimensions).fill(0);
228
- // Character n-grams (3-5 grams for semantic similarity)
229
- const ngrams = [3, 4, 5];
230
- for (const n of ngrams) {
231
- for (let i = 0; i <= text.length - n; i++) {
232
- const gram = text.substring(i, i + n);
233
- const hash = djb2Hash(gram);
234
- const idx = Math.abs(hash) % dimensions;
235
- vector[idx] += 1;
236
- }
237
- }
238
- // Word-level hashing for semantic capture
239
- const words = text.split(/\s+/).filter(w => w.length > 2);
240
- for (const word of words) {
241
- const hash = djb2Hash(word);
242
- const idx = Math.abs(hash) % dimensions;
243
- vector[idx] += 2; // Words weighted higher than n-grams
244
- // Bigrams
245
- if (words.length > 1) {
246
- const idx2 = words.indexOf(word);
247
- if (idx2 < words.length - 1) {
248
- const bigram = `${word}_${words[idx2 + 1]}`;
249
- const bigramHash = djb2Hash(bigram);
250
- const bigramIdx = Math.abs(bigramHash) % dimensions;
251
- vector[bigramIdx] += 3; // Bigrams weighted highest
252
- }
253
- }
254
- }
255
- // Apply TF-IDF-like scaling: square root to dampen high frequencies
256
- for (let i = 0; i < dimensions; i++) {
257
- if (vector[i] > 0) {
258
- vector[i] = Math.sqrt(vector[i]);
259
- }
260
- }
261
- // L2 normalize
262
- const norm = Math.sqrt(vector.reduce((sum, val) => sum + val * val, 0));
263
- if (norm > 0) {
264
- for (let i = 0; i < dimensions; i++) {
265
- vector[i] /= norm;
266
- }
267
- }
268
- return vector;
269
- }
270
- /**
271
- * DJB2 hash function - fast, good distribution
272
- */
273
- function djb2Hash(str) {
274
- let hash = 5381;
275
- for (let i = 0; i < str.length; i++) {
276
- hash = ((hash << 5) + hash) + str.charCodeAt(i);
277
- }
278
- return hash;
279
- }
280
- async function getOpenAiEmbedding(input) {
281
- if (!config.openAiApiKey)
282
- return null;
283
- try {
284
- const response = await fetchWithRetryAndTimeout(config.openAiApiUrl, {
285
- method: 'POST',
286
- headers: {
287
- 'Content-Type': 'application/json',
288
- Authorization: `Bearer ${config.openAiApiKey}`,
289
- },
290
- body: JSON.stringify({
291
- model: config.openAiEmbeddingModel,
292
- input,
293
- }),
294
- }, config.openAiTimeoutMs);
295
- if (!response.ok) {
296
- const message = await response.text();
297
- logger.warn(`OpenAI embeddings failed: ${response.status} ${message}`);
298
- return null; // Return null to allow fallback
299
- }
300
- const payload = await response.json();
301
- const embedding = payload.data?.[0]?.embedding;
302
- return embedding ?? null;
303
- }
304
- catch (error) {
305
- logger.warn('OpenAI embeddings error:', { error: error });
306
- return null; // Return null to allow fallback
307
- }
308
- }
309
- async function getOllamaEmbedding(input) {
310
- try {
311
- const response = await fetchWithRetryAndTimeout(`${config.ollamaUrl}/api/embeddings`, {
312
- method: 'POST',
313
- headers: { 'Content-Type': 'application/json' },
314
- body: JSON.stringify({
315
- model: config.ollamaEmbeddingModel || 'nomic-embed-text',
316
- prompt: input,
317
- }),
318
- }, config.ollamaTimeoutMs);
319
- if (!response.ok) {
320
- const message = await response.text();
321
- logger.warn(`Ollama embeddings failed: ${response.status} ${message}`);
322
- return null; // Return null to allow fallback
323
- }
324
- const payload = await response.json();
325
- return payload.embedding ?? null;
326
- }
327
- catch (error) {
328
- logger.warn('Ollama embeddings error:', { error: error });
329
- return null; // Return null to allow fallback
330
- }
331
- }
332
- // LM Studio uses OpenAI-compatible API
333
- async function getLmStudioEmbedding(input) {
334
- try {
335
- const response = await fetchWithRetryAndTimeout(`${config.lmStudioUrl}/v1/embeddings`, {
336
- method: 'POST',
337
- headers: { 'Content-Type': 'application/json' },
338
- body: JSON.stringify({
339
- model: config.lmStudioEmbeddingModel || 'text-embedding-nomic-embed-text-v1.5',
340
- input: input,
341
- }),
342
- }, config.ollamaTimeoutMs); // Reuse Ollama timeout
343
- if (!response.ok) {
344
- const message = await response.text();
345
- logger.warn(`LM Studio embeddings failed: ${response.status} ${message}`);
346
- return null; // Return null to allow fallback
347
- }
348
- const payload = await response.json();
349
- return payload.data?.[0]?.embedding ?? null;
350
- }
351
- catch (error) {
352
- logger.warn('LM Studio embeddings error:', { error: error });
353
- return null; // Return null to allow fallback
354
- }
355
- }
356
- /**
357
- * Check health of all configured embedding providers
358
- * Returns availability and latency for each provider
359
- */
360
- export async function checkEmbeddingProviderHealth() {
361
- const results = new Map();
362
- const providers = ['local', 'openai', 'ollama', 'lmstudio', 'google', 'none', 'auto'];
363
- // Test local provider (always available)
364
- results.set('local', { available: true, latencyMs: 0 });
365
- // Test OpenAI if configured
366
- if (config.openAiApiKey) {
367
- const start = Date.now();
368
- try {
369
- const testInput = 'health check';
370
- const embedding = await withRetry(() => withTimeout(getOpenAiEmbedding(testInput), config.openAiTimeoutMs), config.embeddingsMaxRetries, config.embeddingsRetryDelayMs);
371
- const latency = Date.now() - start;
372
- results.set('openai', {
373
- available: embedding !== null && embedding.length > 0,
374
- latencyMs: latency
375
- });
376
- }
377
- catch (error) {
378
- results.set('openai', {
379
- available: false,
380
- error: error.message
381
- });
382
- }
383
- }
384
- else {
385
- results.set('openai', { available: false, error: 'Not configured' });
386
- }
387
- // Test Ollama if configured
388
- if (config.ollamaUrl) {
389
- const start = Date.now();
390
- try {
391
- const testInput = 'health check';
392
- const embedding = await withRetry(() => withTimeout(getOllamaEmbedding(testInput), config.ollamaTimeoutMs), config.embeddingsMaxRetries, config.embeddingsRetryDelayMs);
393
- const latency = Date.now() - start;
394
- results.set('ollama', {
395
- available: embedding !== null && embedding.length > 0,
396
- latencyMs: latency
397
- });
398
- }
399
- catch (error) {
400
- results.set('ollama', {
401
- available: false,
402
- error: error.message
403
- });
404
- }
405
- }
406
- else {
407
- results.set('ollama', { available: false, error: 'Not configured' });
408
- }
409
- // Test LM Studio if configured
410
- if (config.lmStudioUrl) {
411
- const start = Date.now();
412
- try {
413
- const testInput = 'health check';
414
- const embedding = await withRetry(() => withTimeout(getLmStudioEmbedding(testInput), config.ollamaTimeoutMs), config.embeddingsMaxRetries, config.embeddingsRetryDelayMs);
415
- const latency = Date.now() - start;
416
- results.set('lmstudio', {
417
- available: embedding !== null && embedding.length > 0,
418
- latencyMs: latency
419
- });
420
- }
421
- catch (error) {
422
- results.set('lmstudio', {
423
- available: false,
424
- error: error.message
425
- });
426
- }
427
- }
428
- else {
429
- results.set('lmstudio', { available: false, error: 'Not configured' });
430
- }
431
- // Test Google if configured
432
- if (config.googleCloudApiKey || config.googleCloudProject) {
433
- const start = Date.now();
434
- try {
435
- const result = await withRetry(() => withTimeout(getGoogleMultimodalEmbedding({ text: 'health check' }), config.googleTimeoutMs), config.embeddingsMaxRetries, config.embeddingsRetryDelayMs);
436
- const latency = Date.now() - start;
437
- results.set('google', {
438
- available: result !== null && result.embedding.length > 0,
439
- latencyMs: latency
440
- });
441
- }
442
- catch (error) {
443
- results.set('google', {
444
- available: false,
445
- error: error.message
446
- });
447
- }
448
- }
449
- else {
450
- results.set('google', { available: false, error: 'Not configured' });
451
- }
452
- return results;
453
- }
1
+ // Re-export from embeddings directory
2
+ export * from './embeddings/embeddings';
454
3
  //# sourceMappingURL=embeddings.js.map