@remnic/core 1.1.8 → 1.1.10

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 (267) hide show
  1. package/dist/access-cli.js +44 -41
  2. package/dist/access-cli.js.map +1 -1
  3. package/dist/access-http.d.ts +8 -7
  4. package/dist/access-http.js +20 -17
  5. package/dist/access-mcp.d.ts +8 -7
  6. package/dist/access-mcp.js +19 -16
  7. package/dist/{access-service-C0Rkioec.d.ts → access-service-BTTNyo1i.d.ts} +11 -9
  8. package/dist/access-service.d.ts +8 -7
  9. package/dist/access-service.js +18 -15
  10. package/dist/active-memory-bridge.d.ts +2 -1
  11. package/dist/active-recall.d.ts +3 -2
  12. package/dist/active-recall.js +2 -2
  13. package/dist/active-recall.js.map +1 -1
  14. package/dist/behavior-learner.d.ts +2 -1
  15. package/dist/behavior-signals.d.ts +2 -1
  16. package/dist/bootstrap.d.ts +7 -6
  17. package/dist/briefing.d.ts +3 -2
  18. package/dist/briefing.js +6 -6
  19. package/dist/buffer-surprise-report.d.ts +2 -1
  20. package/dist/buffer.d.ts +3 -2
  21. package/dist/calibration.d.ts +4 -1
  22. package/dist/calibration.js +10 -5
  23. package/dist/calibration.js.map +1 -1
  24. package/dist/causal-behavior.d.ts +2 -1
  25. package/dist/causal-consolidation.d.ts +5 -2
  26. package/dist/causal-consolidation.js +17 -11
  27. package/dist/causal-consolidation.js.map +1 -1
  28. package/dist/{chunk-AV2WSYZY.js → chunk-2YMTO4ZJ.js} +2 -2
  29. package/dist/{chunk-SYWJJTNL.js → chunk-363MWCD3.js} +42 -42
  30. package/dist/{chunk-65ZPH7QA.js → chunk-36CTNQY7.js} +7 -7
  31. package/dist/{chunk-GZCUW5IC.js → chunk-3IQ2TR4N.js} +5 -5
  32. package/dist/chunk-3IQ2TR4N.js.map +1 -0
  33. package/dist/{chunk-TUFG6VXY.js → chunk-4DWOBS2A.js} +2 -2
  34. package/dist/chunk-4DWOBS2A.js.map +1 -0
  35. package/dist/{chunk-SRIDOT64.js → chunk-4DXC6HQQ.js} +6 -4
  36. package/dist/chunk-4DXC6HQQ.js.map +1 -0
  37. package/dist/{chunk-L2IO2QPY.js → chunk-4IS4SXIQ.js} +17 -13
  38. package/dist/chunk-4IS4SXIQ.js.map +1 -0
  39. package/dist/{chunk-RJSVRPNU.js → chunk-57QNCUEZ.js} +19 -12
  40. package/dist/chunk-57QNCUEZ.js.map +1 -0
  41. package/dist/{chunk-GRDDGNYQ.js → chunk-5GCNE7CN.js} +105 -499
  42. package/dist/chunk-5GCNE7CN.js.map +1 -0
  43. package/dist/{chunk-LOBRX7VD.js → chunk-5UM2VJ6D.js} +12 -1
  44. package/dist/chunk-5UM2VJ6D.js.map +1 -0
  45. package/dist/{chunk-XVOIMCVW.js → chunk-6XA7UN4Z.js} +2 -2
  46. package/dist/{chunk-QJZ77K7F.js → chunk-6Z6UH6TK.js} +26 -12
  47. package/dist/chunk-6Z6UH6TK.js.map +1 -0
  48. package/dist/{chunk-ODWDQNRE.js → chunk-7SI52C65.js} +7 -3
  49. package/dist/chunk-7SI52C65.js.map +1 -0
  50. package/dist/{chunk-FIXIX6DE.js → chunk-C5HUWVH2.js} +33 -43
  51. package/dist/chunk-C5HUWVH2.js.map +1 -0
  52. package/dist/{chunk-NN3TS5BM.js → chunk-D54LZC5L.js} +4 -4
  53. package/dist/{chunk-KNQ5YJTO.js → chunk-ERUDW6DU.js} +209 -1
  54. package/dist/chunk-ERUDW6DU.js.map +1 -0
  55. package/dist/{chunk-E27HOXMX.js → chunk-EYNQTST2.js} +2 -2
  56. package/dist/chunk-FVQJYWH7.js +52 -0
  57. package/dist/chunk-FVQJYWH7.js.map +1 -0
  58. package/dist/{chunk-3FPTCC3Z.js → chunk-GVPWB7EY.js} +2 -2
  59. package/dist/chunk-HJYHRE4S.js +647 -0
  60. package/dist/chunk-HJYHRE4S.js.map +1 -0
  61. package/dist/{chunk-SWRJFKYW.js → chunk-I6BQZSML.js} +5 -5
  62. package/dist/chunk-IBX3VFOM.js +446 -0
  63. package/dist/chunk-IBX3VFOM.js.map +1 -0
  64. package/dist/{chunk-STB3GUYU.js → chunk-KBYWQWSB.js} +8 -8
  65. package/dist/chunk-KWBPHZUU.js +83 -0
  66. package/dist/chunk-KWBPHZUU.js.map +1 -0
  67. package/dist/{chunk-MYH2IBSP.js → chunk-LIO5X3CM.js} +3 -3
  68. package/dist/{chunk-XGX4TUF6.js → chunk-MCC6KDQF.js} +5 -5
  69. package/dist/{chunk-4KAN3GZ3.js → chunk-NN2DKE4T.js} +1 -1
  70. package/dist/chunk-NN2DKE4T.js.map +1 -0
  71. package/dist/{chunk-R2XRID2N.js → chunk-NN3LPQ5D.js} +5 -5
  72. package/dist/chunk-NN3LPQ5D.js.map +1 -0
  73. package/dist/{chunk-WXPPM426.js → chunk-O4XJUPSF.js} +2 -2
  74. package/dist/{chunk-WSZIHQBK.js → chunk-P77UEOU2.js} +4 -1
  75. package/dist/{chunk-WSZIHQBK.js.map → chunk-P77UEOU2.js.map} +1 -1
  76. package/dist/{chunk-RLV2F337.js → chunk-PB5KW5PL.js} +2 -2
  77. package/dist/{chunk-S5SQDIF5.js → chunk-PHNGXFQ6.js} +7 -5
  78. package/dist/chunk-PHNGXFQ6.js.map +1 -0
  79. package/dist/{chunk-FEMOX5AD.js → chunk-QR3C7BKQ.js} +7 -7
  80. package/dist/chunk-QR3C7BKQ.js.map +1 -0
  81. package/dist/{chunk-ETA2JXP5.js → chunk-RXTFCYQF.js} +2 -2
  82. package/dist/{chunk-Q7FJ5ZHM.js → chunk-S3IP6R6K.js} +8 -2
  83. package/dist/{chunk-Q7FJ5ZHM.js.map → chunk-S3IP6R6K.js.map} +1 -1
  84. package/dist/{chunk-3LCWFNVS.js → chunk-SKE7JYKA.js} +2 -2
  85. package/dist/{chunk-T65SHTJP.js → chunk-VQXK37XA.js} +1 -1
  86. package/dist/chunk-VQXK37XA.js.map +1 -0
  87. package/dist/{chunk-DWMXVUGO.js → chunk-VX2IUQFE.js} +98 -10
  88. package/dist/chunk-VX2IUQFE.js.map +1 -0
  89. package/dist/{chunk-KHJRMWO4.js → chunk-WGK4VHGP.js} +84 -22
  90. package/dist/chunk-WGK4VHGP.js.map +1 -0
  91. package/dist/{chunk-4IT6WL23.js → chunk-WTFWLUSX.js} +2 -2
  92. package/dist/{chunk-67YLUWLG.js → chunk-XJKFSSDW.js} +3 -3
  93. package/dist/chunk-XJKFSSDW.js.map +1 -0
  94. package/dist/{chunk-ASIQZXYO.js → chunk-XMVFHBHT.js} +2 -2
  95. package/dist/{chunk-Q5TJRAGE.js → chunk-Y5KDIOKF.js} +3 -3
  96. package/dist/{chunk-FCGWNWG4.js → chunk-Z5S5HNGY.js} +31 -29
  97. package/dist/chunk-Z5S5HNGY.js.map +1 -0
  98. package/dist/{chunk-OJMD2LIW.js → chunk-ZL4S7ARC.js} +3 -3
  99. package/dist/{cli-CIATRu8o.d.ts → cli-BrEwQTnW.d.ts} +4 -4
  100. package/dist/cli.d.ts +9 -8
  101. package/dist/cli.js +33 -31
  102. package/dist/codex-cli-fallback.d.ts +44 -0
  103. package/dist/codex-cli-fallback.js +12 -0
  104. package/dist/{codex-materialize-xVqbEmcm.d.ts → codex-materialize-CQlLTzke.d.ts} +1 -1
  105. package/dist/compression-optimizer.d.ts +2 -1
  106. package/dist/config.d.ts +2 -1
  107. package/dist/config.js +1 -1
  108. package/dist/consolidation-provenance-check.d.ts +3 -2
  109. package/dist/consolidation-undo.d.ts +3 -2
  110. package/dist/day-summary.d.ts +2 -1
  111. package/dist/day-summary.js +1 -1
  112. package/dist/delinearize.d.ts +2 -1
  113. package/dist/direct-answer-wiring.d.ts +2 -1
  114. package/dist/direct-answer.d.ts +2 -1
  115. package/dist/embedding-fallback.d.ts +2 -1
  116. package/dist/{engine-MEAYUA7A.js → engine-FOC3IJLA.js} +7 -7
  117. package/dist/entity-retrieval.d.ts +3 -2
  118. package/dist/entity-retrieval.js +6 -6
  119. package/dist/entity-schema.d.ts +2 -1
  120. package/dist/explicit-capture.d.ts +7 -6
  121. package/dist/explicit-capture.js +2 -2
  122. package/dist/explicit-cue-recall.js +1 -1
  123. package/dist/extraction-judge-telemetry.d.ts +2 -1
  124. package/dist/extraction-judge-training.d.ts +2 -1
  125. package/dist/extraction-judge.d.ts +2 -1
  126. package/dist/extraction.d.ts +2 -1
  127. package/dist/extraction.js +10 -8
  128. package/dist/fallback-llm.d.ts +8 -1
  129. package/dist/fallback-llm.js +5 -3
  130. package/dist/identity-continuity.d.ts +2 -1
  131. package/dist/importance.d.ts +2 -1
  132. package/dist/index-1qIcnbG1.d.ts +34 -0
  133. package/dist/index.d.ts +15 -13
  134. package/dist/index.js +175 -168
  135. package/dist/index.js.map +1 -1
  136. package/dist/intent.d.ts +2 -1
  137. package/dist/lifecycle.d.ts +2 -1
  138. package/dist/live-connectors-runner.d.ts +2 -1
  139. package/dist/live-connectors-runner.js +2 -2
  140. package/dist/local-llm.d.ts +2 -1
  141. package/dist/local-llm.js +1 -1
  142. package/dist/memory-action-policy.d.ts +2 -1
  143. package/dist/memory-cache.d.ts +2 -1
  144. package/dist/{memory-governance-G3XODEXW.js → memory-governance-F3QOJGEY.js} +7 -7
  145. package/dist/memory-lifecycle-ledger-utils.d.ts +2 -1
  146. package/dist/{memory-projection-store-lCzmu4JX.d.ts → memory-projection-store-CY8TU40w.d.ts} +1 -1
  147. package/dist/memory-projection-store.d.ts +3 -2
  148. package/dist/memory-projection-store.js +1 -1
  149. package/dist/memory-worth-outcomes.d.ts +3 -2
  150. package/dist/{migrate-from-identity-anchor-TTEDEJGX.js → migrate-from-identity-anchor-G27MCD6A.js} +2 -2
  151. package/dist/model-registry.js +1 -1
  152. package/dist/models-json.d.ts +2 -1
  153. package/dist/models-json.js +1 -1
  154. package/dist/native-knowledge.d.ts +2 -1
  155. package/dist/objective-state-writers.d.ts +23 -1
  156. package/dist/objective-state-writers.js +10 -306
  157. package/dist/objective-state-writers.js.map +1 -1
  158. package/dist/objective-state.d.ts +7 -1
  159. package/dist/objective-state.js +3 -1
  160. package/dist/operator-toolkit.d.ts +3 -2
  161. package/dist/operator-toolkit.js +11 -11
  162. package/dist/opik-exporter.js +2 -2
  163. package/dist/opik-exporter.js.map +1 -1
  164. package/dist/{orchestrator-CvUYwuaL.d.ts → orchestrator-6IvQ-Phj.d.ts} +6 -5
  165. package/dist/orchestrator.d.ts +7 -6
  166. package/dist/orchestrator.js +37 -35
  167. package/dist/patterns-cli.d.ts +2 -1
  168. package/dist/{peers-6OSQ3NK6.js → peers-HCVGHMAE.js} +3 -3
  169. package/dist/peers-HCVGHMAE.js.map +1 -0
  170. package/dist/policy-runtime.d.ts +2 -1
  171. package/dist/{port-BkWL7hqo.d.ts → port-B6VEDIkC.d.ts} +7 -1
  172. package/dist/qmd-recall-cache.d.ts +3 -2
  173. package/dist/qmd.d.ts +4 -2
  174. package/dist/qmd.js +1 -1
  175. package/dist/recall-disclosure-escalation.d.ts +2 -1
  176. package/dist/recall-explain-renderer.d.ts +2 -1
  177. package/dist/recall-explain-renderer.js +3 -3
  178. package/dist/recall-state.d.ts +2 -1
  179. package/dist/recall-tag-filter.d.ts +2 -1
  180. package/dist/recall-xray-cli.d.ts +2 -1
  181. package/dist/recall-xray-cli.js +4 -4
  182. package/dist/recall-xray-renderer.d.ts +2 -1
  183. package/dist/recall-xray-renderer.js +3 -3
  184. package/dist/recall-xray.d.ts +2 -1
  185. package/dist/recall-xray.js +2 -2
  186. package/dist/resolve-auth-token.d.ts +2 -1
  187. package/dist/resolve-provider-secret.d.ts +2 -1
  188. package/dist/resolve-provider-secret.js +3 -1
  189. package/dist/resume-bundles.js +4 -4
  190. package/dist/retrieval-agents.d.ts +3 -2
  191. package/dist/retrieval-tiers.d.ts +2 -1
  192. package/dist/sanitize.js +1 -1
  193. package/dist/schemas.d.ts +22 -22
  194. package/dist/{semantic-consolidation-CGiH52qa.d.ts → semantic-consolidation-ByBXb-sf.d.ts} +2 -2
  195. package/dist/semantic-consolidation.d.ts +4 -3
  196. package/dist/semantic-consolidation.js +6 -6
  197. package/dist/semantic-rule-promotion.js +6 -6
  198. package/dist/semantic-rule-verifier.d.ts +2 -1
  199. package/dist/semantic-rule-verifier.js +6 -6
  200. package/dist/session-observer-bands.d.ts +2 -1
  201. package/dist/session-observer-state.d.ts +2 -1
  202. package/dist/signal.d.ts +2 -1
  203. package/dist/source-attribution.d.ts +1 -1
  204. package/dist/source-attribution.js +1 -1
  205. package/dist/storage.d.ts +3 -2
  206. package/dist/storage.js +5 -5
  207. package/dist/summarizer.d.ts +2 -1
  208. package/dist/summarizer.js +8 -6
  209. package/dist/summary-snapshot.d.ts +2 -1
  210. package/dist/temporal-supersession.d.ts +3 -2
  211. package/dist/temporal-validity.d.ts +2 -1
  212. package/dist/threading.d.ts +2 -1
  213. package/dist/tier-migration.d.ts +4 -3
  214. package/dist/tier-routing.d.ts +2 -1
  215. package/dist/topics.d.ts +2 -1
  216. package/dist/transcript.d.ts +2 -1
  217. package/dist/types.d.ts +2693 -1
  218. package/dist/types.js +1 -1
  219. package/dist/utility-runtime.d.ts +2 -1
  220. package/dist/verified-recall.js +6 -6
  221. package/package.json +1 -1
  222. package/dist/chunk-4KAN3GZ3.js.map +0 -1
  223. package/dist/chunk-67YLUWLG.js.map +0 -1
  224. package/dist/chunk-DWMXVUGO.js.map +0 -1
  225. package/dist/chunk-FCGWNWG4.js.map +0 -1
  226. package/dist/chunk-FEMOX5AD.js.map +0 -1
  227. package/dist/chunk-FIXIX6DE.js.map +0 -1
  228. package/dist/chunk-GRDDGNYQ.js.map +0 -1
  229. package/dist/chunk-GZCUW5IC.js.map +0 -1
  230. package/dist/chunk-KHJRMWO4.js.map +0 -1
  231. package/dist/chunk-KNQ5YJTO.js.map +0 -1
  232. package/dist/chunk-L2IO2QPY.js.map +0 -1
  233. package/dist/chunk-LOBRX7VD.js.map +0 -1
  234. package/dist/chunk-M62O4P4T.js +0 -41
  235. package/dist/chunk-M62O4P4T.js.map +0 -1
  236. package/dist/chunk-ODWDQNRE.js.map +0 -1
  237. package/dist/chunk-QJZ77K7F.js.map +0 -1
  238. package/dist/chunk-R2XRID2N.js.map +0 -1
  239. package/dist/chunk-RJSVRPNU.js.map +0 -1
  240. package/dist/chunk-S5SQDIF5.js.map +0 -1
  241. package/dist/chunk-SRIDOT64.js.map +0 -1
  242. package/dist/chunk-T65SHTJP.js.map +0 -1
  243. package/dist/chunk-TUFG6VXY.js.map +0 -1
  244. package/dist/types-H85grL1f.d.ts +0 -2714
  245. /package/dist/{chunk-AV2WSYZY.js.map → chunk-2YMTO4ZJ.js.map} +0 -0
  246. /package/dist/{chunk-SYWJJTNL.js.map → chunk-363MWCD3.js.map} +0 -0
  247. /package/dist/{chunk-65ZPH7QA.js.map → chunk-36CTNQY7.js.map} +0 -0
  248. /package/dist/{chunk-XVOIMCVW.js.map → chunk-6XA7UN4Z.js.map} +0 -0
  249. /package/dist/{chunk-NN3TS5BM.js.map → chunk-D54LZC5L.js.map} +0 -0
  250. /package/dist/{chunk-E27HOXMX.js.map → chunk-EYNQTST2.js.map} +0 -0
  251. /package/dist/{chunk-3FPTCC3Z.js.map → chunk-GVPWB7EY.js.map} +0 -0
  252. /package/dist/{chunk-SWRJFKYW.js.map → chunk-I6BQZSML.js.map} +0 -0
  253. /package/dist/{chunk-STB3GUYU.js.map → chunk-KBYWQWSB.js.map} +0 -0
  254. /package/dist/{chunk-MYH2IBSP.js.map → chunk-LIO5X3CM.js.map} +0 -0
  255. /package/dist/{chunk-XGX4TUF6.js.map → chunk-MCC6KDQF.js.map} +0 -0
  256. /package/dist/{chunk-WXPPM426.js.map → chunk-O4XJUPSF.js.map} +0 -0
  257. /package/dist/{chunk-RLV2F337.js.map → chunk-PB5KW5PL.js.map} +0 -0
  258. /package/dist/{chunk-ETA2JXP5.js.map → chunk-RXTFCYQF.js.map} +0 -0
  259. /package/dist/{chunk-3LCWFNVS.js.map → chunk-SKE7JYKA.js.map} +0 -0
  260. /package/dist/{chunk-4IT6WL23.js.map → chunk-WTFWLUSX.js.map} +0 -0
  261. /package/dist/{chunk-ASIQZXYO.js.map → chunk-XMVFHBHT.js.map} +0 -0
  262. /package/dist/{chunk-Q5TJRAGE.js.map → chunk-Y5KDIOKF.js.map} +0 -0
  263. /package/dist/{chunk-OJMD2LIW.js.map → chunk-ZL4S7ARC.js.map} +0 -0
  264. /package/dist/{engine-MEAYUA7A.js.map → codex-cli-fallback.js.map} +0 -0
  265. /package/dist/{memory-governance-G3XODEXW.js.map → engine-FOC3IJLA.js.map} +0 -0
  266. /package/dist/{migrate-from-identity-anchor-TTEDEJGX.js.map → memory-governance-F3QOJGEY.js.map} +0 -0
  267. /package/dist/{peers-6OSQ3NK6.js.map → migrate-from-identity-anchor-G27MCD6A.js.map} +0 -0
@@ -1,15 +1,17 @@
1
1
  import {
2
2
  getObjectiveStateStoreStatus,
3
+ objectiveStateStoreOverrideForNamespace,
3
4
  recordObjectiveStateSnapshot,
4
5
  resolveObjectiveStateStoreDir,
5
6
  searchObjectiveStateSnapshots,
6
7
  validateObjectiveStateSnapshot
7
- } from "./chunk-LOBRX7VD.js";
8
+ } from "./chunk-5UM2VJ6D.js";
8
9
  import "./chunk-DGXUHMOV.js";
9
10
  import "./chunk-LPSF4OQH.js";
10
11
  import "./chunk-PZ5AY32C.js";
11
12
  export {
12
13
  getObjectiveStateStoreStatus,
14
+ objectiveStateStoreOverrideForNamespace,
13
15
  recordObjectiveStateSnapshot,
14
16
  resolveObjectiveStateStoreDir,
15
17
  searchObjectiveStateSnapshots,
@@ -2,11 +2,12 @@ import { StorageManager } from './storage.js';
2
2
  import { EvalHarnessStatus, validateEvalBenchmarkPack, EvalBaselineDeltaReport, EvalCiGateReport } from './evals.js';
3
3
  import { GraphHealthReport } from './graph.js';
4
4
  import { SessionIntegrityReport, SessionRepairPlan, SessionRepairApplyResult } from './session-integrity.js';
5
- import { P as PluginConfig } from './types-H85grL1f.js';
5
+ import { PluginConfig } from './types.js';
6
6
  import './page-versioning.js';
7
7
  import './consolidation-operator.js';
8
- import './memory-projection-store-lCzmu4JX.js';
8
+ import './memory-projection-store-CY8TU40w.js';
9
9
  import 'better-sqlite3';
10
+ import './index-1qIcnbG1.js';
10
11
 
11
12
  interface QmdRuntimeLike {
12
13
  probe(): Promise<boolean>;
@@ -11,37 +11,37 @@ import {
11
11
  summarizeMemoryWorthLegacyCounters,
12
12
  summarizeObservationThroughput,
13
13
  summarizeTierDistribution
14
- } from "./chunk-SWRJFKYW.js";
14
+ } from "./chunk-I6BQZSML.js";
15
15
  import "./chunk-5HRY2WRF.js";
16
16
  import "./chunk-ASAITVLA.js";
17
- import "./chunk-RJSVRPNU.js";
17
+ import "./chunk-57QNCUEZ.js";
18
18
  import "./chunk-YRMVARQP.js";
19
- import "./chunk-WSZIHQBK.js";
19
+ import "./chunk-P77UEOU2.js";
20
20
  import "./chunk-U66YHYC7.js";
21
21
  import "./chunk-K6WK37A6.js";
22
22
  import "./chunk-AJU4PJGY.js";
23
23
  import "./chunk-7SEAZFFB.js";
24
- import "./chunk-QJZ77K7F.js";
24
+ import "./chunk-6Z6UH6TK.js";
25
25
  import "./chunk-Z5LAYHGJ.js";
26
26
  import "./chunk-PVGDJXVK.js";
27
- import "./chunk-E27HOXMX.js";
28
- import "./chunk-2LGMW3DJ.js";
27
+ import "./chunk-EYNQTST2.js";
29
28
  import "./chunk-OR64ZGRZ.js";
29
+ import "./chunk-2LGMW3DJ.js";
30
30
  import "./chunk-RK2Y4XOM.js";
31
31
  import "./chunk-2LSZVONP.js";
32
32
  import "./chunk-WIICJPET.js";
33
33
  import "./chunk-TBBDFYXW.js";
34
- import "./chunk-XGX4TUF6.js";
34
+ import "./chunk-MCC6KDQF.js";
35
35
  import "./chunk-YNJHCGDT.js";
36
- import "./chunk-4KAN3GZ3.js";
37
- import "./chunk-T65SHTJP.js";
36
+ import "./chunk-NN2DKE4T.js";
37
+ import "./chunk-VQXK37XA.js";
38
38
  import "./chunk-PFV5C235.js";
39
39
  import "./chunk-RULE4VG5.js";
40
40
  import "./chunk-SCU65EZI.js";
41
- import "./chunk-67YLUWLG.js";
41
+ import "./chunk-XJKFSSDW.js";
42
42
  import "./chunk-DM2T26WE.js";
43
43
  import "./chunk-QSVPYQPG.js";
44
- import "./chunk-M62O4P4T.js";
44
+ import "./chunk-FVQJYWH7.js";
45
45
  import "./chunk-4DJQYKMN.js";
46
46
  import "./chunk-G7D6GZ5J.js";
47
47
  import "./chunk-FAAFWE4G.js";
@@ -6,13 +6,13 @@ import "./chunk-PZ5AY32C.js";
6
6
 
7
7
  // src/opik-exporter.ts
8
8
  import { createHash, randomBytes } from "crypto";
9
- import { readFileSync } from "fs";
9
+ import fs from "fs";
10
10
  import path from "path";
11
11
  var OPIK_EXPORTER_SLOT = "__openclawOpikExporter";
12
12
  function readOpikOpenclawConfig(log) {
13
13
  try {
14
14
  const configPath = readEnvVar("OPENCLAW_ENGRAM_CONFIG_PATH") || readEnvVar("OPENCLAW_CONFIG_PATH") || path.join(resolveHomeDir(), ".openclaw", "openclaw.json");
15
- const raw = JSON.parse(readFileSync(configPath, "utf-8"));
15
+ const raw = JSON.parse(fs.readFileSync(configPath, "utf-8"));
16
16
  const entry = raw?.plugins?.entries?.["opik-openclaw"];
17
17
  if (!entry?.enabled || !entry?.config) return {};
18
18
  const c = entry.config;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/opik-exporter.ts"],"sourcesContent":["import { createHash, randomBytes } from \"node:crypto\";\n/**\n * opik-exporter.ts — Engram-native Opik trace exporter\n *\n * Subscribes to the globalThis.__openclawEngramTrace slot that Engram already\n * emits on, and forwards recall + LLM events to a self-hosted (or cloud) Opik\n * instance via its REST API. No extra npm dependencies — uses Node's built-in\n * fetch.\n *\n * Auto-detects apiUrl / projectName from the opik-openclaw plugin config so\n * traces land in the same project and are grouped by session thread.\n */\n\nimport { readFileSync } from \"node:fs\";\nimport path from \"node:path\";\n\nimport type { LoggerBackend } from \"./logger.js\";\nimport { readEnvVar, resolveHomeDir } from \"./runtime/env.js\";\n\n// GlobalThis slot that tracks the active OpikExporter instance.\n// Used to make subscribe() idempotent across hot-reload / stop-start cycles.\nconst OPIK_EXPORTER_SLOT = \"__openclawOpikExporter\";\n\n// ---------------------------------------------------------------------------\n// Engram event types (mirrors types.ts without importing from it)\n// ---------------------------------------------------------------------------\n\ntype EngramLlmTraceEvent = {\n kind: \"llm_start\" | \"llm_end\" | \"llm_error\";\n traceId: string;\n model: string;\n operation: \"extraction\" | \"consolidation\" | \"profile_consolidation\" | \"identity_consolidation\" | \"day_summary\";\n input?: string;\n output?: string;\n durationMs?: number;\n error?: string;\n tokenUsage?: { input?: number; output?: number; total?: number };\n};\n\ntype EngramRecallTraceEvent = {\n kind: \"recall_summary\";\n traceId: string;\n operation: \"recall\";\n sessionKey?: string;\n promptLength: number;\n retrievalQueryLength: number;\n recallMode: string;\n recallResultLimit: number;\n qmdEnabled: boolean;\n qmdAvailable: boolean;\n recallNamespaces: string[];\n source: string;\n recalledMemoryCount: number;\n injected: boolean;\n contextChars: number;\n identityInjectionMode?: string;\n identityInjectedChars?: number;\n durationMs: number;\n timings?: Record<string, string>;\n recalledContent?: string;\n};\n\ntype EngramTraceEvent = EngramLlmTraceEvent | EngramRecallTraceEvent;\n\n// ---------------------------------------------------------------------------\n// Config\n// ---------------------------------------------------------------------------\n\nexport interface OpikExporterConfig {\n enabled: boolean;\n /** Base URL of the Opik API, e.g. http://192.168.3.147:5173/api */\n apiUrl: string;\n projectName: string;\n workspaceName: string;\n /** Optional API key (not required for self-hosted deployments) */\n apiKey?: string;\n /** Include recalled memory text in spans (default false) */\n traceRecallContent: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// Auto-detect from opik-openclaw plugin config\n// ---------------------------------------------------------------------------\n\nfunction readOpikOpenclawConfig(log?: LoggerBackend): Partial<OpikExporterConfig> {\n try {\n const configPath =\n readEnvVar(\"OPENCLAW_ENGRAM_CONFIG_PATH\") ||\n readEnvVar(\"OPENCLAW_CONFIG_PATH\") ||\n path.join(resolveHomeDir(), \".openclaw\", \"openclaw.json\");\n const raw = JSON.parse(readFileSync(configPath, \"utf-8\"));\n const entry = raw?.plugins?.entries?.[\"opik-openclaw\"];\n if (!entry?.enabled || !entry?.config) return {};\n const c = entry.config as Record<string, unknown>;\n return {\n apiUrl: typeof c.apiUrl === \"string\" && c.apiUrl.length > 0 ? c.apiUrl : undefined,\n projectName: typeof c.projectName === \"string\" ? c.projectName : undefined,\n workspaceName: typeof c.workspaceName === \"string\" ? c.workspaceName : undefined,\n apiKey: typeof c.apiKey === \"string\" && c.apiKey.length > 0 ? c.apiKey : undefined,\n };\n } catch (err) {\n log?.debug?.(`[opik-exporter] could not read opik-openclaw config: ${err}`);\n return {};\n }\n}\n\n// ---------------------------------------------------------------------------\n// UUID v7 generator (Opik requires v7, not v4)\n// ---------------------------------------------------------------------------\n\nfunction uuidV7(): string {\n const now = Date.now();\n const bytes = randomBytes(16);\n // Timestamp: 48-bit ms since epoch in bytes 0-5\n bytes[0] = (now / 2 ** 40) & 0xff;\n bytes[1] = (now / 2 ** 32) & 0xff;\n bytes[2] = (now / 2 ** 24) & 0xff;\n bytes[3] = (now / 2 ** 16) & 0xff;\n bytes[4] = (now / 2 ** 8) & 0xff;\n bytes[5] = now & 0xff;\n // Version 7\n bytes[6] = (bytes[6] & 0x0f) | 0x70;\n // Variant 10xx\n bytes[8] = (bytes[8] & 0x3f) | 0x80;\n const hex = bytes.toString(\"hex\");\n return `${hex.slice(0, 8)}-${hex.slice(8, 12)}-${hex.slice(12, 16)}-${hex.slice(16, 20)}-${hex.slice(20)}`;\n}\n\n// ---------------------------------------------------------------------------\n// REST helpers\n// ---------------------------------------------------------------------------\n\nfunction buildHeaders(cfg: OpikExporterConfig): Record<string, string> {\n const headers: Record<string, string> = { \"Content-Type\": \"application/json\" };\n if (cfg.workspaceName) headers[\"Comet-Workspace\"] = cfg.workspaceName;\n // Opik expects the raw API key in the authorization header without a Bearer prefix.\n if (cfg.apiKey) headers[\"authorization\"] = cfg.apiKey;\n return headers;\n}\n\nasync function postSpanBatch(\n cfg: OpikExporterConfig,\n spans: unknown[],\n log: LoggerBackend,\n): Promise<void> {\n const url = `${cfg.apiUrl.replace(/\\/$/, \"\")}/v1/private/spans/batch`;\n try {\n const res = await fetch(url, {\n method: \"POST\",\n headers: buildHeaders(cfg),\n body: JSON.stringify({ spans }),\n });\n if (!res.ok) {\n const text = await res.text().catch(() => \"\");\n log.debug?.(`[opik-exporter] span batch failed ${res.status}: ${text}`);\n }\n } catch (err) {\n log.debug?.(`[opik-exporter] span batch error: ${err}`);\n }\n}\n\nasync function postTraceBatch(\n cfg: OpikExporterConfig,\n traces: unknown[],\n log: LoggerBackend,\n): Promise<boolean> {\n const url = `${cfg.apiUrl.replace(/\\/$/, \"\")}/v1/private/traces/batch`;\n try {\n const res = await fetch(url, {\n method: \"POST\",\n headers: buildHeaders(cfg),\n body: JSON.stringify({ traces }),\n });\n if (!res.ok) {\n const text = await res.text().catch(() => \"\");\n log.debug?.(`[opik-exporter] trace batch failed ${res.status}: ${text}`);\n return false;\n }\n return true;\n } catch (err) {\n log.debug?.(`[opik-exporter] trace batch error: ${err}`);\n return false;\n }\n}\n\n// ---------------------------------------------------------------------------\n// In-flight LLM span tracking\n// ---------------------------------------------------------------------------\n\ntype InFlightLlm = {\n startedAt: number;\n startTime: string;\n model: string;\n operation: string;\n input?: string;\n spanId: string;\n traceId: string;\n};\n\n// ---------------------------------------------------------------------------\n// Main exporter class\n// ---------------------------------------------------------------------------\n\nexport class OpikExporter {\n private readonly cfg: OpikExporterConfig;\n private readonly log: LoggerBackend;\n private _handler: ((e: EngramTraceEvent) => void) | undefined;\n private readonly inFlight = new Map<string, InFlightLlm>();\n /** Track which trace_ids we have already created parent trace objects for. */\n private readonly createdTraces = new Set<string>();\n /** In-flight ensureTrace promises keyed by traceId — concurrent callers await the same promise. */\n private readonly pendingTraces = new Map<string, Promise<void>>();\n /** TTL for in-flight LLM entries (ms). Entries older than this are discarded. */\n private static readonly IN_FLIGHT_TTL_MS = 5 * 60 * 1000; // 5 minutes\n\n constructor(cfg: OpikExporterConfig, log: LoggerBackend) {\n this.cfg = cfg;\n this.log = log;\n }\n\n /**\n * Subscribe to Engram's global trace slot. Safe to call multiple times —\n * chains with existing subscribers (e.g. Langfuse) rather than replacing.\n */\n subscribe(): void {\n if (!this.cfg.enabled) return;\n\n // Idempotency guard: if this exact instance is already registered on globalThis,\n // skip re-wrapping to avoid stacking callbacks on hot-reload / stop-start cycles.\n const g = globalThis as Record<string, unknown>;\n const active = g[OPIK_EXPORTER_SLOT] as OpikExporter | undefined;\n if (active === this) {\n this.log.debug?.(\"[opik-exporter] already subscribed — skipping duplicate\");\n return;\n }\n // If a different (stale) exporter instance is registered, evict it first.\n if (active) active._detach();\n\n g[OPIK_EXPORTER_SLOT] = this;\n\n const existing = g.__openclawEngramTrace as\n | ((e: EngramTraceEvent) => void)\n | undefined;\n\n const handler = (event: EngramTraceEvent) => {\n try {\n this.handleEvent(event);\n } catch (err) {\n this.log.debug?.(`[opik-exporter] handler error: ${err}`);\n }\n };\n // Store handler ref so _detach() can remove it from the chain.\n this._handler = handler;\n\n // Chain: call existing subscribers first, then ours.\n // NOTE: when _detach() is later called, it marks this.cfg.enabled = false\n // rather than restoring the chain, so that any subscriber that chained\n // *after* us is not dropped. The cost is one disabled no-op wrapper\n // remaining in the chain per stop/start cycle. In practice, Engram\n // restarts Opik only a handful of times per process lifetime, so the\n // overhead is negligible (one boolean check per leftover closure).\n g.__openclawEngramTrace =\n typeof existing === \"function\"\n ? (event: EngramTraceEvent) => {\n try { existing(event); } catch { /* prior subscriber threw; continue */ }\n handler(event);\n }\n : handler;\n\n this.log.info(\n `[opik-exporter] subscribed — apiUrl=${this.cfg.apiUrl} project=${this.cfg.projectName}`,\n );\n }\n\n /** Deactivate this exporter instance.\n *\n * We intentionally do NOT restore __openclawEngramTrace to a prior handler\n * because any subscriber that chained *after* us would be silently dropped\n * by such a restoration. Instead we mark the instance as disabled so that\n * handleEvent() becomes a no-op while the callback chain itself is left\n * untouched. The next subscribe() call from a fresh instance will re-enter\n * the chain on top of whatever is there at that point.\n */\n _detach(): void {\n const g = globalThis as Record<string, unknown>;\n // Only clear the global slot if we are still the active exporter.\n // A stale instance must not evict a newer exporter that already took over.\n if (g[OPIK_EXPORTER_SLOT] === this) delete g[OPIK_EXPORTER_SLOT];\n // Disable event processing; the wrapper closure in the chain becomes a no-op.\n (this.cfg as OpikExporterConfig & { enabled: boolean }).enabled = false;\n this._handler = undefined;\n this.log.debug?.(\"[opik-exporter] detached — events silenced, chain preserved\");\n }\n\n unsubscribe(): void {\n this._detach();\n }\n\n private handleEvent(event: EngramTraceEvent): void {\n if (!this.cfg.enabled) return; // guard for after _detach()\n if (event.kind === \"recall_summary\") {\n void this.onRecall(event);\n } else if (event.kind === \"llm_start\") {\n this.onLlmStart(event);\n } else if (event.kind === \"llm_end\" || event.kind === \"llm_error\") {\n void this.onLlmEnd(event);\n }\n }\n\n // -------------------------------------------------------------------------\n // Recall events → general span\n // -------------------------------------------------------------------------\n\n private async onRecall(evt: EngramRecallTraceEvent): Promise<void> {\n const now = new Date();\n const startTime = new Date(now.getTime() - evt.durationMs).toISOString();\n const endTime = now.toISOString();\n\n const input: Record<string, unknown> = {\n recallMode: evt.recallMode,\n recalledMemoryCount: evt.recalledMemoryCount,\n recallNamespaces: evt.recallNamespaces,\n source: evt.source,\n qmdEnabled: evt.qmdEnabled,\n qmdAvailable: evt.qmdAvailable,\n retrievalQueryLength: evt.retrievalQueryLength,\n recallResultLimit: evt.recallResultLimit,\n promptLength: evt.promptLength,\n };\n\n if (this.cfg.traceRecallContent && evt.recalledContent) {\n input.recalledContent = evt.recalledContent;\n }\n\n const metadata: Record<string, unknown> = {\n source: \"engram\",\n injected: evt.injected,\n contextChars: evt.contextChars,\n durationMs: evt.durationMs,\n };\n\n if (evt.identityInjectionMode) {\n metadata.identityInjectionMode = evt.identityInjectionMode;\n metadata.identityInjectedChars = evt.identityInjectedChars;\n }\n\n if (evt.timings) metadata.timings = evt.timings;\n\n const traceId = evt.sessionKey ? this.sessionToTraceId(evt.sessionKey) : uuidV7();\n\n // Ensure parent trace exists so the span is not orphaned in Opik.\n await this.ensureTrace(traceId, evt.sessionKey ?? \"engram:recall\", startTime, endTime);\n\n const output: Record<string, unknown> = {\n injected: evt.injected,\n recalledMemoryCount: evt.recalledMemoryCount,\n contextChars: evt.contextChars,\n durationMs: evt.durationMs,\n };\n if (this.cfg.traceRecallContent && evt.recalledContent) {\n output.recalledContent = evt.recalledContent;\n }\n\n const span = {\n id: uuidV7(),\n trace_id: traceId,\n project_name: this.cfg.projectName,\n name: \"engram:recall\",\n type: \"general\",\n start_time: startTime,\n end_time: endTime,\n input,\n output,\n metadata,\n tags: [\"engram\", \"recall\"],\n };\n\n await postSpanBatch(this.cfg, [span], this.log);\n }\n\n // -------------------------------------------------------------------------\n // Engram internal LLM events (extraction / consolidation) → llm span\n // -------------------------------------------------------------------------\n\n private onLlmStart(evt: EngramLlmTraceEvent): void {\n // Use evt.traceId (Engram's correlation key) as the Opik spanId so spans\n // are deterministic and stable across retries. Derive a per-call Opik\n // trace_id from the same key so each LLM call maps to its own trace.\n this.inFlight.set(evt.traceId, {\n startedAt: Date.now(),\n startTime: new Date().toISOString(),\n model: evt.model,\n operation: evt.operation,\n input: evt.input,\n spanId: this.sessionToTraceId(evt.traceId + \":span\"),\n traceId: this.sessionToTraceId(evt.traceId),\n });\n }\n\n private sweepStaleInFlight(): void {\n const cutoff = Date.now() - OpikExporter.IN_FLIGHT_TTL_MS;\n for (const [id, entry] of this.inFlight) {\n if (entry.startedAt < cutoff) {\n this.inFlight.delete(id);\n }\n }\n }\n\n private async onLlmEnd(evt: EngramLlmTraceEvent): Promise<void> {\n // Opportunistically sweep stale entries to prevent unbounded map growth.\n if (this.inFlight.size > 20) this.sweepStaleInFlight();\n const state = this.inFlight.get(evt.traceId);\n this.inFlight.delete(evt.traceId);\n\n const startTime = state?.startTime ?? new Date().toISOString();\n const endTime = new Date().toISOString();\n\n const usage: Record<string, number> = {};\n if (evt.tokenUsage?.input != null) usage.prompt_tokens = evt.tokenUsage.input;\n if (evt.tokenUsage?.output != null) usage.completion_tokens = evt.tokenUsage.output;\n if (evt.tokenUsage?.total != null) usage.total_tokens = evt.tokenUsage.total;\n\n const traceId = state?.traceId ?? uuidV7();\n\n // Ensure parent trace exists so the span is not orphaned in Opik.\n await this.ensureTrace(traceId, `engram:${evt.operation}`, startTime, endTime);\n\n const span: Record<string, unknown> = {\n id: state?.spanId ?? uuidV7(),\n trace_id: traceId,\n project_name: this.cfg.projectName,\n name: `engram:${evt.operation}`,\n type: \"llm\",\n model: evt.model,\n start_time: startTime,\n end_time: endTime,\n input: state?.input != null ? { prompt: state.input } : undefined,\n output:\n evt.kind === \"llm_end\" && evt.output != null\n ? { completion: evt.output }\n : evt.kind === \"llm_error\"\n ? { error: evt.error }\n : undefined,\n metadata: {\n source: \"engram\",\n operation: evt.operation,\n durationMs: evt.durationMs ?? (state ? Date.now() - state.startedAt : undefined),\n },\n tags: [\"engram\", evt.operation],\n usage: Object.keys(usage).length > 0 ? usage : undefined,\n };\n\n await postSpanBatch(this.cfg, [span], this.log);\n }\n\n // -------------------------------------------------------------------------\n // Helpers\n // -------------------------------------------------------------------------\n\n /**\n * Create a parent trace object in Opik if we haven't already.\n * Opik does NOT auto-create traces from spans, so without this\n * the spans are orphaned and don't show up in the trace list UI.\n */\n private async ensureTrace(\n traceId: string,\n name: string,\n startTime: string,\n endTime: string,\n ): Promise<void> {\n if (this.createdTraces.has(traceId)) return;\n\n // If another call is already creating this trace, wait for it and then\n // re-check — if the first attempt failed we'll retry below.\n const existing = this.pendingTraces.get(traceId);\n if (existing) {\n await existing;\n if (this.createdTraces.has(traceId)) return;\n // First attempt failed — check if another waiter is already retrying.\n const retrying = this.pendingTraces.get(traceId);\n if (retrying) {\n await retrying;\n // Only return if the retry actually succeeded.\n if (this.createdTraces.has(traceId)) return;\n }\n // No one else retrying; fall through to create.\n }\n\n const work = (async () => {\n const trace = {\n id: traceId,\n project_name: this.cfg.projectName,\n name,\n start_time: startTime,\n end_time: endTime,\n tags: [\"engram\"],\n };\n\n const ok = await postTraceBatch(this.cfg, [trace], this.log);\n if (!ok) {\n this.pendingTraces.delete(traceId);\n return; // transient failure — allow retry on next span\n }\n\n this.createdTraces.add(traceId);\n this.pendingTraces.delete(traceId);\n\n // Cap the set size to prevent unbounded growth in long-running processes.\n if (this.createdTraces.size > 10_000) {\n const first = this.createdTraces.values().next().value;\n if (first) this.createdTraces.delete(first);\n }\n })();\n\n this.pendingTraces.set(traceId, work);\n await work;\n }\n\n /**\n * Convert a sessionKey to a stable, deterministic UUID v7-shaped ID so that\n * spans for the same session share a trace_id and are threaded in Opik.\n * Uses SHA-256 for collision resistance. The timestamp bytes (0-5) come from\n * the hash itself — they don't reflect real time, but Opik only validates\n * the version/variant bits, not timestamp ordering.\n */\n private sessionToTraceId(sessionKey: string): string {\n const digest = createHash(\"sha256\").update(sessionKey).digest();\n // Version 7 (bytes 0-5 are hash-derived, not real timestamps)\n digest[6] = (digest[6] & 0x0f) | 0x70;\n // Variant 10xx\n digest[8] = (digest[8] & 0x3f) | 0x80;\n const hex = digest.slice(0, 16).toString(\"hex\");\n return `${hex.slice(0, 8)}-${hex.slice(8, 12)}-${hex.slice(12, 16)}-${hex.slice(16, 20)}-${hex.slice(20)}`;\n }\n}\n\n// ---------------------------------------------------------------------------\n// Factory: build from Engram resolved config + auto-detect from opik-openclaw\n// ---------------------------------------------------------------------------\n\nexport interface OpikExporterRawConfig {\n opikTraceEnabled?: boolean;\n opikApiUrl?: string;\n opikProjectName?: string;\n opikWorkspaceName?: string;\n opikApiKey?: string;\n opikTraceRecallContent?: boolean;\n}\n\nexport function createOpikExporter(\n raw: OpikExporterRawConfig,\n log: LoggerBackend,\n): OpikExporter | null {\n // Explicit opt-out: if set to false, never enable.\n if (raw.opikTraceEnabled === false) return null;\n\n // Auto-detect from opik-openclaw plugin config.\n // If opikTraceEnabled is not set (undefined), we enable automatically\n // whenever opik-openclaw is configured — avoids needing extra fields in\n // Engram's openclaw.json config section (which would fail schema validation).\n const detected = readOpikOpenclawConfig(log);\n\n const apiUrl = raw.opikApiUrl ?? detected.apiUrl;\n if (!apiUrl) {\n // Only warn when the user explicitly opted in but forgot to set the URL.\n // When auto-detecting (opikTraceEnabled not set), return silently so non-Opik\n // users see no log noise on every startup.\n if (raw.opikTraceEnabled === true) {\n log.warn(\n \"[opik-exporter] opikTraceEnabled=true but no apiUrl found — \" +\n \"set opikApiUrl in Engram config or ensure opik-openclaw plugin is configured\",\n );\n }\n return null;\n }\n\n const cfg: OpikExporterConfig = {\n enabled: true,\n apiUrl,\n projectName: raw.opikProjectName ?? detected.projectName ?? \"openclaw\",\n workspaceName: raw.opikWorkspaceName ?? detected.workspaceName ?? \"default\",\n apiKey: raw.opikApiKey ?? detected.apiKey,\n traceRecallContent: raw.opikTraceRecallContent === true,\n };\n\n return new OpikExporter(cfg, log);\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../src/opik-exporter.ts"],"sourcesContent":["import { createHash, randomBytes } from \"node:crypto\";\n/**\n * opik-exporter.ts — Engram-native Opik trace exporter\n *\n * Subscribes to the globalThis.__openclawEngramTrace slot that Engram already\n * emits on, and forwards recall + LLM events to a self-hosted (or cloud) Opik\n * instance via its REST API. No extra npm dependencies — uses Node's built-in\n * fetch.\n *\n * Auto-detects apiUrl / projectName from the opik-openclaw plugin config so\n * traces land in the same project and are grouped by session thread.\n */\n\nimport fs from \"node:fs\";\nimport path from \"node:path\";\n\nimport type { LoggerBackend } from \"./logger.js\";\nimport { readEnvVar, resolveHomeDir } from \"./runtime/env.js\";\n\n// GlobalThis slot that tracks the active OpikExporter instance.\n// Used to make subscribe() idempotent across hot-reload / stop-start cycles.\nconst OPIK_EXPORTER_SLOT = \"__openclawOpikExporter\";\n\n// ---------------------------------------------------------------------------\n// Engram event types (mirrors types.ts without importing from it)\n// ---------------------------------------------------------------------------\n\ntype EngramLlmTraceEvent = {\n kind: \"llm_start\" | \"llm_end\" | \"llm_error\";\n traceId: string;\n model: string;\n operation: \"extraction\" | \"consolidation\" | \"profile_consolidation\" | \"identity_consolidation\" | \"day_summary\";\n input?: string;\n output?: string;\n durationMs?: number;\n error?: string;\n tokenUsage?: { input?: number; output?: number; total?: number };\n};\n\ntype EngramRecallTraceEvent = {\n kind: \"recall_summary\";\n traceId: string;\n operation: \"recall\";\n sessionKey?: string;\n promptLength: number;\n retrievalQueryLength: number;\n recallMode: string;\n recallResultLimit: number;\n qmdEnabled: boolean;\n qmdAvailable: boolean;\n recallNamespaces: string[];\n source: string;\n recalledMemoryCount: number;\n injected: boolean;\n contextChars: number;\n identityInjectionMode?: string;\n identityInjectedChars?: number;\n durationMs: number;\n timings?: Record<string, string>;\n recalledContent?: string;\n};\n\ntype EngramTraceEvent = EngramLlmTraceEvent | EngramRecallTraceEvent;\n\n// ---------------------------------------------------------------------------\n// Config\n// ---------------------------------------------------------------------------\n\nexport interface OpikExporterConfig {\n enabled: boolean;\n /** Base URL of the Opik API, e.g. http://192.168.3.147:5173/api */\n apiUrl: string;\n projectName: string;\n workspaceName: string;\n /** Optional API key (not required for self-hosted deployments) */\n apiKey?: string;\n /** Include recalled memory text in spans (default false) */\n traceRecallContent: boolean;\n}\n\n// ---------------------------------------------------------------------------\n// Auto-detect from opik-openclaw plugin config\n// ---------------------------------------------------------------------------\n\nfunction readOpikOpenclawConfig(log?: LoggerBackend): Partial<OpikExporterConfig> {\n try {\n const configPath =\n readEnvVar(\"OPENCLAW_ENGRAM_CONFIG_PATH\") ||\n readEnvVar(\"OPENCLAW_CONFIG_PATH\") ||\n path.join(resolveHomeDir(), \".openclaw\", \"openclaw.json\");\n const raw = JSON.parse(fs.readFileSync(configPath, \"utf-8\"));\n const entry = raw?.plugins?.entries?.[\"opik-openclaw\"];\n if (!entry?.enabled || !entry?.config) return {};\n const c = entry.config as Record<string, unknown>;\n return {\n apiUrl: typeof c.apiUrl === \"string\" && c.apiUrl.length > 0 ? c.apiUrl : undefined,\n projectName: typeof c.projectName === \"string\" ? c.projectName : undefined,\n workspaceName: typeof c.workspaceName === \"string\" ? c.workspaceName : undefined,\n apiKey: typeof c.apiKey === \"string\" && c.apiKey.length > 0 ? c.apiKey : undefined,\n };\n } catch (err) {\n log?.debug?.(`[opik-exporter] could not read opik-openclaw config: ${err}`);\n return {};\n }\n}\n\n// ---------------------------------------------------------------------------\n// UUID v7 generator (Opik requires v7, not v4)\n// ---------------------------------------------------------------------------\n\nfunction uuidV7(): string {\n const now = Date.now();\n const bytes = randomBytes(16);\n // Timestamp: 48-bit ms since epoch in bytes 0-5\n bytes[0] = (now / 2 ** 40) & 0xff;\n bytes[1] = (now / 2 ** 32) & 0xff;\n bytes[2] = (now / 2 ** 24) & 0xff;\n bytes[3] = (now / 2 ** 16) & 0xff;\n bytes[4] = (now / 2 ** 8) & 0xff;\n bytes[5] = now & 0xff;\n // Version 7\n bytes[6] = (bytes[6] & 0x0f) | 0x70;\n // Variant 10xx\n bytes[8] = (bytes[8] & 0x3f) | 0x80;\n const hex = bytes.toString(\"hex\");\n return `${hex.slice(0, 8)}-${hex.slice(8, 12)}-${hex.slice(12, 16)}-${hex.slice(16, 20)}-${hex.slice(20)}`;\n}\n\n// ---------------------------------------------------------------------------\n// REST helpers\n// ---------------------------------------------------------------------------\n\nfunction buildHeaders(cfg: OpikExporterConfig): Record<string, string> {\n const headers: Record<string, string> = { \"Content-Type\": \"application/json\" };\n if (cfg.workspaceName) headers[\"Comet-Workspace\"] = cfg.workspaceName;\n // Opik expects the raw API key in the authorization header without a Bearer prefix.\n if (cfg.apiKey) headers[\"authorization\"] = cfg.apiKey;\n return headers;\n}\n\nasync function postSpanBatch(\n cfg: OpikExporterConfig,\n spans: unknown[],\n log: LoggerBackend,\n): Promise<void> {\n const url = `${cfg.apiUrl.replace(/\\/$/, \"\")}/v1/private/spans/batch`;\n try {\n const res = await fetch(url, {\n method: \"POST\",\n headers: buildHeaders(cfg),\n body: JSON.stringify({ spans }),\n });\n if (!res.ok) {\n const text = await res.text().catch(() => \"\");\n log.debug?.(`[opik-exporter] span batch failed ${res.status}: ${text}`);\n }\n } catch (err) {\n log.debug?.(`[opik-exporter] span batch error: ${err}`);\n }\n}\n\nasync function postTraceBatch(\n cfg: OpikExporterConfig,\n traces: unknown[],\n log: LoggerBackend,\n): Promise<boolean> {\n const url = `${cfg.apiUrl.replace(/\\/$/, \"\")}/v1/private/traces/batch`;\n try {\n const res = await fetch(url, {\n method: \"POST\",\n headers: buildHeaders(cfg),\n body: JSON.stringify({ traces }),\n });\n if (!res.ok) {\n const text = await res.text().catch(() => \"\");\n log.debug?.(`[opik-exporter] trace batch failed ${res.status}: ${text}`);\n return false;\n }\n return true;\n } catch (err) {\n log.debug?.(`[opik-exporter] trace batch error: ${err}`);\n return false;\n }\n}\n\n// ---------------------------------------------------------------------------\n// In-flight LLM span tracking\n// ---------------------------------------------------------------------------\n\ntype InFlightLlm = {\n startedAt: number;\n startTime: string;\n model: string;\n operation: string;\n input?: string;\n spanId: string;\n traceId: string;\n};\n\n// ---------------------------------------------------------------------------\n// Main exporter class\n// ---------------------------------------------------------------------------\n\nexport class OpikExporter {\n private readonly cfg: OpikExporterConfig;\n private readonly log: LoggerBackend;\n private _handler: ((e: EngramTraceEvent) => void) | undefined;\n private readonly inFlight = new Map<string, InFlightLlm>();\n /** Track which trace_ids we have already created parent trace objects for. */\n private readonly createdTraces = new Set<string>();\n /** In-flight ensureTrace promises keyed by traceId — concurrent callers await the same promise. */\n private readonly pendingTraces = new Map<string, Promise<void>>();\n /** TTL for in-flight LLM entries (ms). Entries older than this are discarded. */\n private static readonly IN_FLIGHT_TTL_MS = 5 * 60 * 1000; // 5 minutes\n\n constructor(cfg: OpikExporterConfig, log: LoggerBackend) {\n this.cfg = cfg;\n this.log = log;\n }\n\n /**\n * Subscribe to Engram's global trace slot. Safe to call multiple times —\n * chains with existing subscribers (e.g. Langfuse) rather than replacing.\n */\n subscribe(): void {\n if (!this.cfg.enabled) return;\n\n // Idempotency guard: if this exact instance is already registered on globalThis,\n // skip re-wrapping to avoid stacking callbacks on hot-reload / stop-start cycles.\n const g = globalThis as Record<string, unknown>;\n const active = g[OPIK_EXPORTER_SLOT] as OpikExporter | undefined;\n if (active === this) {\n this.log.debug?.(\"[opik-exporter] already subscribed — skipping duplicate\");\n return;\n }\n // If a different (stale) exporter instance is registered, evict it first.\n if (active) active._detach();\n\n g[OPIK_EXPORTER_SLOT] = this;\n\n const existing = g.__openclawEngramTrace as\n | ((e: EngramTraceEvent) => void)\n | undefined;\n\n const handler = (event: EngramTraceEvent) => {\n try {\n this.handleEvent(event);\n } catch (err) {\n this.log.debug?.(`[opik-exporter] handler error: ${err}`);\n }\n };\n // Store handler ref so _detach() can remove it from the chain.\n this._handler = handler;\n\n // Chain: call existing subscribers first, then ours.\n // NOTE: when _detach() is later called, it marks this.cfg.enabled = false\n // rather than restoring the chain, so that any subscriber that chained\n // *after* us is not dropped. The cost is one disabled no-op wrapper\n // remaining in the chain per stop/start cycle. In practice, Engram\n // restarts Opik only a handful of times per process lifetime, so the\n // overhead is negligible (one boolean check per leftover closure).\n g.__openclawEngramTrace =\n typeof existing === \"function\"\n ? (event: EngramTraceEvent) => {\n try { existing(event); } catch { /* prior subscriber threw; continue */ }\n handler(event);\n }\n : handler;\n\n this.log.info(\n `[opik-exporter] subscribed — apiUrl=${this.cfg.apiUrl} project=${this.cfg.projectName}`,\n );\n }\n\n /** Deactivate this exporter instance.\n *\n * We intentionally do NOT restore __openclawEngramTrace to a prior handler\n * because any subscriber that chained *after* us would be silently dropped\n * by such a restoration. Instead we mark the instance as disabled so that\n * handleEvent() becomes a no-op while the callback chain itself is left\n * untouched. The next subscribe() call from a fresh instance will re-enter\n * the chain on top of whatever is there at that point.\n */\n _detach(): void {\n const g = globalThis as Record<string, unknown>;\n // Only clear the global slot if we are still the active exporter.\n // A stale instance must not evict a newer exporter that already took over.\n if (g[OPIK_EXPORTER_SLOT] === this) delete g[OPIK_EXPORTER_SLOT];\n // Disable event processing; the wrapper closure in the chain becomes a no-op.\n (this.cfg as OpikExporterConfig & { enabled: boolean }).enabled = false;\n this._handler = undefined;\n this.log.debug?.(\"[opik-exporter] detached — events silenced, chain preserved\");\n }\n\n unsubscribe(): void {\n this._detach();\n }\n\n private handleEvent(event: EngramTraceEvent): void {\n if (!this.cfg.enabled) return; // guard for after _detach()\n if (event.kind === \"recall_summary\") {\n void this.onRecall(event);\n } else if (event.kind === \"llm_start\") {\n this.onLlmStart(event);\n } else if (event.kind === \"llm_end\" || event.kind === \"llm_error\") {\n void this.onLlmEnd(event);\n }\n }\n\n // -------------------------------------------------------------------------\n // Recall events → general span\n // -------------------------------------------------------------------------\n\n private async onRecall(evt: EngramRecallTraceEvent): Promise<void> {\n const now = new Date();\n const startTime = new Date(now.getTime() - evt.durationMs).toISOString();\n const endTime = now.toISOString();\n\n const input: Record<string, unknown> = {\n recallMode: evt.recallMode,\n recalledMemoryCount: evt.recalledMemoryCount,\n recallNamespaces: evt.recallNamespaces,\n source: evt.source,\n qmdEnabled: evt.qmdEnabled,\n qmdAvailable: evt.qmdAvailable,\n retrievalQueryLength: evt.retrievalQueryLength,\n recallResultLimit: evt.recallResultLimit,\n promptLength: evt.promptLength,\n };\n\n if (this.cfg.traceRecallContent && evt.recalledContent) {\n input.recalledContent = evt.recalledContent;\n }\n\n const metadata: Record<string, unknown> = {\n source: \"engram\",\n injected: evt.injected,\n contextChars: evt.contextChars,\n durationMs: evt.durationMs,\n };\n\n if (evt.identityInjectionMode) {\n metadata.identityInjectionMode = evt.identityInjectionMode;\n metadata.identityInjectedChars = evt.identityInjectedChars;\n }\n\n if (evt.timings) metadata.timings = evt.timings;\n\n const traceId = evt.sessionKey ? this.sessionToTraceId(evt.sessionKey) : uuidV7();\n\n // Ensure parent trace exists so the span is not orphaned in Opik.\n await this.ensureTrace(traceId, evt.sessionKey ?? \"engram:recall\", startTime, endTime);\n\n const output: Record<string, unknown> = {\n injected: evt.injected,\n recalledMemoryCount: evt.recalledMemoryCount,\n contextChars: evt.contextChars,\n durationMs: evt.durationMs,\n };\n if (this.cfg.traceRecallContent && evt.recalledContent) {\n output.recalledContent = evt.recalledContent;\n }\n\n const span = {\n id: uuidV7(),\n trace_id: traceId,\n project_name: this.cfg.projectName,\n name: \"engram:recall\",\n type: \"general\",\n start_time: startTime,\n end_time: endTime,\n input,\n output,\n metadata,\n tags: [\"engram\", \"recall\"],\n };\n\n await postSpanBatch(this.cfg, [span], this.log);\n }\n\n // -------------------------------------------------------------------------\n // Engram internal LLM events (extraction / consolidation) → llm span\n // -------------------------------------------------------------------------\n\n private onLlmStart(evt: EngramLlmTraceEvent): void {\n // Use evt.traceId (Engram's correlation key) as the Opik spanId so spans\n // are deterministic and stable across retries. Derive a per-call Opik\n // trace_id from the same key so each LLM call maps to its own trace.\n this.inFlight.set(evt.traceId, {\n startedAt: Date.now(),\n startTime: new Date().toISOString(),\n model: evt.model,\n operation: evt.operation,\n input: evt.input,\n spanId: this.sessionToTraceId(evt.traceId + \":span\"),\n traceId: this.sessionToTraceId(evt.traceId),\n });\n }\n\n private sweepStaleInFlight(): void {\n const cutoff = Date.now() - OpikExporter.IN_FLIGHT_TTL_MS;\n for (const [id, entry] of this.inFlight) {\n if (entry.startedAt < cutoff) {\n this.inFlight.delete(id);\n }\n }\n }\n\n private async onLlmEnd(evt: EngramLlmTraceEvent): Promise<void> {\n // Opportunistically sweep stale entries to prevent unbounded map growth.\n if (this.inFlight.size > 20) this.sweepStaleInFlight();\n const state = this.inFlight.get(evt.traceId);\n this.inFlight.delete(evt.traceId);\n\n const startTime = state?.startTime ?? new Date().toISOString();\n const endTime = new Date().toISOString();\n\n const usage: Record<string, number> = {};\n if (evt.tokenUsage?.input != null) usage.prompt_tokens = evt.tokenUsage.input;\n if (evt.tokenUsage?.output != null) usage.completion_tokens = evt.tokenUsage.output;\n if (evt.tokenUsage?.total != null) usage.total_tokens = evt.tokenUsage.total;\n\n const traceId = state?.traceId ?? uuidV7();\n\n // Ensure parent trace exists so the span is not orphaned in Opik.\n await this.ensureTrace(traceId, `engram:${evt.operation}`, startTime, endTime);\n\n const span: Record<string, unknown> = {\n id: state?.spanId ?? uuidV7(),\n trace_id: traceId,\n project_name: this.cfg.projectName,\n name: `engram:${evt.operation}`,\n type: \"llm\",\n model: evt.model,\n start_time: startTime,\n end_time: endTime,\n input: state?.input != null ? { prompt: state.input } : undefined,\n output:\n evt.kind === \"llm_end\" && evt.output != null\n ? { completion: evt.output }\n : evt.kind === \"llm_error\"\n ? { error: evt.error }\n : undefined,\n metadata: {\n source: \"engram\",\n operation: evt.operation,\n durationMs: evt.durationMs ?? (state ? Date.now() - state.startedAt : undefined),\n },\n tags: [\"engram\", evt.operation],\n usage: Object.keys(usage).length > 0 ? usage : undefined,\n };\n\n await postSpanBatch(this.cfg, [span], this.log);\n }\n\n // -------------------------------------------------------------------------\n // Helpers\n // -------------------------------------------------------------------------\n\n /**\n * Create a parent trace object in Opik if we haven't already.\n * Opik does NOT auto-create traces from spans, so without this\n * the spans are orphaned and don't show up in the trace list UI.\n */\n private async ensureTrace(\n traceId: string,\n name: string,\n startTime: string,\n endTime: string,\n ): Promise<void> {\n if (this.createdTraces.has(traceId)) return;\n\n // If another call is already creating this trace, wait for it and then\n // re-check — if the first attempt failed we'll retry below.\n const existing = this.pendingTraces.get(traceId);\n if (existing) {\n await existing;\n if (this.createdTraces.has(traceId)) return;\n // First attempt failed — check if another waiter is already retrying.\n const retrying = this.pendingTraces.get(traceId);\n if (retrying) {\n await retrying;\n // Only return if the retry actually succeeded.\n if (this.createdTraces.has(traceId)) return;\n }\n // No one else retrying; fall through to create.\n }\n\n const work = (async () => {\n const trace = {\n id: traceId,\n project_name: this.cfg.projectName,\n name,\n start_time: startTime,\n end_time: endTime,\n tags: [\"engram\"],\n };\n\n const ok = await postTraceBatch(this.cfg, [trace], this.log);\n if (!ok) {\n this.pendingTraces.delete(traceId);\n return; // transient failure — allow retry on next span\n }\n\n this.createdTraces.add(traceId);\n this.pendingTraces.delete(traceId);\n\n // Cap the set size to prevent unbounded growth in long-running processes.\n if (this.createdTraces.size > 10_000) {\n const first = this.createdTraces.values().next().value;\n if (first) this.createdTraces.delete(first);\n }\n })();\n\n this.pendingTraces.set(traceId, work);\n await work;\n }\n\n /**\n * Convert a sessionKey to a stable, deterministic UUID v7-shaped ID so that\n * spans for the same session share a trace_id and are threaded in Opik.\n * Uses SHA-256 for collision resistance. The timestamp bytes (0-5) come from\n * the hash itself — they don't reflect real time, but Opik only validates\n * the version/variant bits, not timestamp ordering.\n */\n private sessionToTraceId(sessionKey: string): string {\n const digest = createHash(\"sha256\").update(sessionKey).digest();\n // Version 7 (bytes 0-5 are hash-derived, not real timestamps)\n digest[6] = (digest[6] & 0x0f) | 0x70;\n // Variant 10xx\n digest[8] = (digest[8] & 0x3f) | 0x80;\n const hex = digest.slice(0, 16).toString(\"hex\");\n return `${hex.slice(0, 8)}-${hex.slice(8, 12)}-${hex.slice(12, 16)}-${hex.slice(16, 20)}-${hex.slice(20)}`;\n }\n}\n\n// ---------------------------------------------------------------------------\n// Factory: build from Engram resolved config + auto-detect from opik-openclaw\n// ---------------------------------------------------------------------------\n\nexport interface OpikExporterRawConfig {\n opikTraceEnabled?: boolean;\n opikApiUrl?: string;\n opikProjectName?: string;\n opikWorkspaceName?: string;\n opikApiKey?: string;\n opikTraceRecallContent?: boolean;\n}\n\nexport function createOpikExporter(\n raw: OpikExporterRawConfig,\n log: LoggerBackend,\n): OpikExporter | null {\n // Explicit opt-out: if set to false, never enable.\n if (raw.opikTraceEnabled === false) return null;\n\n // Auto-detect from opik-openclaw plugin config.\n // If opikTraceEnabled is not set (undefined), we enable automatically\n // whenever opik-openclaw is configured — avoids needing extra fields in\n // Engram's openclaw.json config section (which would fail schema validation).\n const detected = readOpikOpenclawConfig(log);\n\n const apiUrl = raw.opikApiUrl ?? detected.apiUrl;\n if (!apiUrl) {\n // Only warn when the user explicitly opted in but forgot to set the URL.\n // When auto-detecting (opikTraceEnabled not set), return silently so non-Opik\n // users see no log noise on every startup.\n if (raw.opikTraceEnabled === true) {\n log.warn(\n \"[opik-exporter] opikTraceEnabled=true but no apiUrl found — \" +\n \"set opikApiUrl in Engram config or ensure opik-openclaw plugin is configured\",\n );\n }\n return null;\n }\n\n const cfg: OpikExporterConfig = {\n enabled: true,\n apiUrl,\n projectName: raw.opikProjectName ?? detected.projectName ?? \"openclaw\",\n workspaceName: raw.opikWorkspaceName ?? detected.workspaceName ?? \"default\",\n apiKey: raw.opikApiKey ?? detected.apiKey,\n traceRecallContent: raw.opikTraceRecallContent === true,\n };\n\n return new OpikExporter(cfg, log);\n}\n"],"mappings":"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","names":[]}
@@ -1,5 +1,5 @@
1
1
  import { SmartBuffer } from './buffer.js';
2
- import { S as SearchBackend, a as SearchQueryOptions, b as SearchExecutionOptions } from './port-BkWL7hqo.js';
2
+ import { S as SearchBackend, a as SearchQueryOptions, b as SearchExecutionOptions } from './port-B6VEDIkC.js';
3
3
  import { StorageManager } from './storage.js';
4
4
  import { TranscriptManager } from './transcript.js';
5
5
  import { HourlySummarizer } from './summarizer.js';
@@ -13,8 +13,9 @@ import { LastRecallStore, TierMigrationStatusStore, GraphRecallExpandedEntry, Ti
13
13
  import { RecallXraySnapshot } from './recall-xray.js';
14
14
  import { SessionObserverState } from './session-observer-state.js';
15
15
  import { EmbeddingFallback } from './embedding-fallback.js';
16
- import { L as LcmMessagePartInput, j as MessagePartSourceFormat, P as PluginConfig, S as CodingContext, U as QmdSearchResult, e as BehaviorLoopPolicyState, V as BootstrapOptions, W as BootstrapResult, X as ConsolidationObservation, f as MemoryFile, D as DaySummaryResult, s as MemoryActionEvent, R as RecallPlanMode, Y as MemoryIntent, Z as EntityTimelineEntry, _ as ExtractionResult, o as MemoryFrontmatter, $ as IdentityInjectionMode } from './types-H85grL1f.js';
17
- import { S as SemanticConsolidationResult } from './semantic-consolidation-CGiH52qa.js';
16
+ import { L as LcmMessagePartInput, M as MessagePartSourceFormat } from './index-1qIcnbG1.js';
17
+ import { PluginConfig, CodingContext, QmdSearchResult, BehaviorLoopPolicyState, BootstrapOptions, BootstrapResult, ConsolidationObservation, MemoryFile, DaySummaryResult, MemoryActionEvent, RecallPlanMode, MemoryIntent, EntityTimelineEntry, ExtractionResult, MemoryFrontmatter, IdentityInjectionMode } from './types.js';
18
+ import { S as SemanticConsolidationResult } from './semantic-consolidation-ByBXb-sf.js';
18
19
  import { z } from 'zod';
19
20
  import { RuntimePolicyValues } from './policy-runtime.js';
20
21
  import { ProfilingCollector } from './profiling.js';
@@ -1009,7 +1010,7 @@ declare class Orchestrator {
1009
1010
  private readonly memoryWorthCounterCache;
1010
1011
  private static readonly MEMORY_WORTH_CACHE_TTL_MS;
1011
1012
  /**
1012
- * Per-session workspace overrides keyed by sessionKey.
1013
+ * Per-session workspace selections keyed by sessionKey.
1013
1014
  * Set by the before_agent_start hook so recall() uses the correct
1014
1015
  * agent workspace for BOOT.md injection. Cleared after each recall.
1015
1016
  * Using a Map prevents concurrent sessions from overwriting each other.
@@ -1098,7 +1099,7 @@ declare class Orchestrator {
1098
1099
  private disposeSearchBackendIfNeeded;
1099
1100
  /** Set per-session workspace for the next recall() call (compaction reset). @internal */
1100
1101
  setRecallWorkspaceOverride(sessionKey: string, dir: string): void;
1101
- /** Remove a per-session workspace override (cleanup on error or early return). @internal */
1102
+ /** Remove a per-session workspace selection (cleanup on error or early return). @internal */
1102
1103
  clearRecallWorkspaceOverride(sessionKey: string): void;
1103
1104
  resolvePrincipal(sessionKey?: string): string;
1104
1105
  resolveSelfNamespace(sessionKey?: string): string;
@@ -1,12 +1,12 @@
1
1
  import './buffer.js';
2
- import './port-BkWL7hqo.js';
2
+ import './port-B6VEDIkC.js';
3
3
  import './storage.js';
4
4
  import './transcript.js';
5
5
  import './summarizer.js';
6
6
  import './local-llm.js';
7
7
  import './fallback-llm.js';
8
8
  import './live-connectors-runner.js';
9
- export { q as GraphRecallRankedResult, r as GraphRecallShadowComparison, G as GraphRecallSnapshot, I as IntentDebugSnapshot, O as Orchestrator, Q as QmdRecallSnapshot, t as RecallInvocationOptions, u as RecallModeDecision, w as appendMemoryToGraphContext, x as blendGraphExpandedRecallScore, y as buildCompressionGuidelinesMarkdown, z as buildMemoryPathById, A as computeArtifactCandidateFetchLimit, D as computeArtifactRecallLimit, E as computeQmdHybridFetchLimit, F as dedupeEntitySynthesisEvidenceEntries, n as defaultWorkspaceDir, H as deriveTopicsFromExtraction, J as filterRecallCandidates, K as formatCompressionGuidelinesForRecall, L as graphPathRelativeToStorage, M as hasIdentityRecoveryIntent, N as isArtifactMemoryPath, T as lifecycleRecallScoreAdjustment, U as mergeArtifactRecallCandidates, V as mergeGraphExpandedResults, W as resolveEffectiveIdentityInjectionMode, X as resolveEffectiveRecallMode, Y as resolvePersistedMemoryRelativePath, Z as resolveRecallModeDecision, _ as resolveRecentThreadMemoryPaths, s as sanitizeSessionKeyForFilename, $ as shouldFilterLifecycleRecallCandidate, a0 as summarizeGraphShadowComparison } from './orchestrator-CvUYwuaL.js';
9
+ export { q as GraphRecallRankedResult, r as GraphRecallShadowComparison, G as GraphRecallSnapshot, I as IntentDebugSnapshot, O as Orchestrator, Q as QmdRecallSnapshot, t as RecallInvocationOptions, u as RecallModeDecision, w as appendMemoryToGraphContext, x as blendGraphExpandedRecallScore, y as buildCompressionGuidelinesMarkdown, z as buildMemoryPathById, A as computeArtifactCandidateFetchLimit, D as computeArtifactRecallLimit, E as computeQmdHybridFetchLimit, F as dedupeEntitySynthesisEvidenceEntries, n as defaultWorkspaceDir, H as deriveTopicsFromExtraction, J as filterRecallCandidates, K as formatCompressionGuidelinesForRecall, L as graphPathRelativeToStorage, M as hasIdentityRecoveryIntent, N as isArtifactMemoryPath, T as lifecycleRecallScoreAdjustment, U as mergeArtifactRecallCandidates, V as mergeGraphExpandedResults, W as resolveEffectiveIdentityInjectionMode, X as resolveEffectiveRecallMode, Y as resolvePersistedMemoryRelativePath, Z as resolveRecallModeDecision, _ as resolveRecentThreadMemoryPaths, s as sanitizeSessionKeyForFilename, $ as shouldFilterLifecycleRecallCandidate, a0 as summarizeGraphShadowComparison } from './orchestrator-6IvQ-Phj.js';
10
10
  import './model-registry.js';
11
11
  import './relevance.js';
12
12
  import './negative.js';
@@ -14,16 +14,17 @@ import './recall-state.js';
14
14
  import './recall-xray.js';
15
15
  import './session-observer-state.js';
16
16
  import './embedding-fallback.js';
17
- import './types-H85grL1f.js';
18
- import './semantic-consolidation-CGiH52qa.js';
17
+ import './types.js';
18
+ import './semantic-consolidation-ByBXb-sf.js';
19
19
  import './policy-runtime.js';
20
20
  import './profiling.js';
21
21
  import './page-versioning.js';
22
22
  import './consolidation-operator.js';
23
- import './memory-projection-store-lCzmu4JX.js';
23
+ import './memory-projection-store-CY8TU40w.js';
24
24
  import 'better-sqlite3';
25
+ import './index-1qIcnbG1.js';
25
26
  import './session-integrity.js';
26
27
  import './framework-CyHYDcri.js';
27
28
  import 'zod';
28
- import './codex-materialize-xVqbEmcm.js';
29
+ import './codex-materialize-CQlLTzke.js';
29
30
  import './logger.js';
@@ -26,18 +26,18 @@ import {
26
26
  sanitizeSessionKeyForFilename,
27
27
  shouldFilterLifecycleRecallCandidate,
28
28
  summarizeGraphShadowComparison
29
- } from "./chunk-GRDDGNYQ.js";
30
- import "./chunk-SRIDOT64.js";
29
+ } from "./chunk-5GCNE7CN.js";
30
+ import "./chunk-4DXC6HQQ.js";
31
31
  import "./chunk-CK5NTM2S.js";
32
32
  import "./chunk-FSFEQI74.js";
33
+ import "./chunk-MDYG7VI7.js";
33
34
  import "./chunk-Z5AAYHUC.js";
34
35
  import "./chunk-S75M5ZRK.js";
35
36
  import "./chunk-TPB3I2AC.js";
36
37
  import "./chunk-UHGBNIOS.js";
37
- import "./chunk-S5SQDIF5.js";
38
+ import "./chunk-PHNGXFQ6.js";
38
39
  import "./chunk-ETOW6ACV.js";
39
40
  import "./chunk-ZTSE2ZJ6.js";
40
- import "./chunk-MDYG7VI7.js";
41
41
  import "./chunk-JR4ZC3G4.js";
42
42
  import "./chunk-K4FLSOR5.js";
43
43
  import "./chunk-V3RXWQIE.js";
@@ -55,59 +55,59 @@ import "./chunk-H63EDPFJ.js";
55
55
  import "./chunk-3GPTTA4J.js";
56
56
  import "./chunk-IISBCCWR.js";
57
57
  import "./chunk-GGD5W7TB.js";
58
- import "./chunk-ASIQZXYO.js";
58
+ import "./chunk-XMVFHBHT.js";
59
59
  import "./chunk-YAZNBMNF.js";
60
- import "./chunk-KNQ5YJTO.js";
60
+ import "./chunk-Z5S5HNGY.js";
61
+ import "./chunk-WW3QQF4H.js";
62
+ import "./chunk-54V4BZWP.js";
63
+ import "./chunk-QR3C7BKQ.js";
64
+ import "./chunk-NN3LPQ5D.js";
65
+ import "./chunk-ERUDW6DU.js";
61
66
  import "./chunk-74WWN7ZW.js";
62
67
  import "./chunk-DF3RVK3X.js";
63
68
  import "./chunk-C4SQJZAF.js";
64
- import "./chunk-FCGWNWG4.js";
65
- import "./chunk-WW3QQF4H.js";
66
- import "./chunk-54V4BZWP.js";
67
- import "./chunk-FEMOX5AD.js";
68
- import "./chunk-R2XRID2N.js";
69
- import "./chunk-GZCUW5IC.js";
69
+ import "./chunk-3IQ2TR4N.js";
70
70
  import "./chunk-VEWZZM3H.js";
71
71
  import "./chunk-6AUUAZEX.js";
72
72
  import "./chunk-Y4FHOFJ2.js";
73
73
  import "./chunk-Z2E7VW55.js";
74
- import "./chunk-MYH2IBSP.js";
74
+ import "./chunk-LIO5X3CM.js";
75
75
  import "./chunk-2NMMFZ5T.js";
76
76
  import "./chunk-SRBJUAMP.js";
77
77
  import "./chunk-PYXS46O7.js";
78
78
  import "./chunk-3QKK7QOS.js";
79
- import "./chunk-ETA2JXP5.js";
79
+ import "./chunk-RXTFCYQF.js";
80
80
  import "./chunk-JRNQ3RNA.js";
81
- import "./chunk-RLV2F337.js";
81
+ import "./chunk-PB5KW5PL.js";
82
82
  import "./chunk-CULXMQJH.js";
83
83
  import "./chunk-E6K4NIEU.js";
84
- import "./chunk-RJSVRPNU.js";
84
+ import "./chunk-57QNCUEZ.js";
85
85
  import "./chunk-YRMVARQP.js";
86
- import "./chunk-WSZIHQBK.js";
86
+ import "./chunk-P77UEOU2.js";
87
87
  import "./chunk-EABGC2TL.js";
88
- import "./chunk-LOBRX7VD.js";
89
- import "./chunk-L2IO2QPY.js";
88
+ import "./chunk-4IS4SXIQ.js";
90
89
  import "./chunk-6TBWYBJ3.js";
91
90
  import "./chunk-HMDCOMYU.js";
92
91
  import "./chunk-JXS5PDQ7.js";
93
92
  import "./chunk-K6WK37A6.js";
94
93
  import "./chunk-AJU4PJGY.js";
94
+ import "./chunk-C6QPK5GG.js";
95
95
  import "./chunk-7SEAZFFB.js";
96
+ import "./chunk-FYIYMQ5N.js";
96
97
  import "./chunk-Z5LAYHGJ.js";
97
98
  import "./chunk-OZHRDTDX.js";
98
- import "./chunk-C6QPK5GG.js";
99
99
  import "./chunk-3PG3H5TD.js";
100
- import "./chunk-FYIYMQ5N.js";
101
100
  import "./chunk-KVE7R4CG.js";
102
101
  import "./chunk-4WMCPJWX.js";
103
102
  import "./chunk-JBMSGZEQ.js";
104
- import "./chunk-FIXIX6DE.js";
103
+ import "./chunk-C5HUWVH2.js";
105
104
  import "./chunk-EJI5XIBB.js";
106
- import "./chunk-DWMXVUGO.js";
107
- import "./chunk-Q7FJ5ZHM.js";
108
- import "./chunk-ODWDQNRE.js";
105
+ import "./chunk-VX2IUQFE.js";
106
+ import "./chunk-S3IP6R6K.js";
109
107
  import "./chunk-L2EXJQJP.js";
108
+ import "./chunk-7SI52C65.js";
110
109
  import "./chunk-UZB5KHKX.js";
110
+ import "./chunk-KWBPHZUU.js";
111
111
  import "./chunk-6HZ6AO2P.js";
112
112
  import "./chunk-JWPLJLDU.js";
113
113
  import "./chunk-N53K2EXC.js";
@@ -115,34 +115,36 @@ import "./chunk-XYIK4LF6.js";
115
115
  import "./chunk-URB2WSKZ.js";
116
116
  import "./chunk-PVGDJXVK.js";
117
117
  import "./chunk-NGAVDO7E.js";
118
- import "./chunk-NN3TS5BM.js";
118
+ import "./chunk-D54LZC5L.js";
119
119
  import "./chunk-EQINRHYR.js";
120
- import "./chunk-AV2WSYZY.js";
121
- import "./chunk-IXEJRKCZ.js";
122
- import "./chunk-3FPTCC3Z.js";
123
- import "./chunk-2LGMW3DJ.js";
120
+ import "./chunk-2YMTO4ZJ.js";
121
+ import "./chunk-IBX3VFOM.js";
122
+ import "./chunk-5UM2VJ6D.js";
124
123
  import "./chunk-EEQLFRUM.js";
125
124
  import "./chunk-NBNN5GOB.js";
126
125
  import "./chunk-OR64ZGRZ.js";
126
+ import "./chunk-GVPWB7EY.js";
127
+ import "./chunk-2LGMW3DJ.js";
127
128
  import "./chunk-QDW3E4RD.js";
128
129
  import "./chunk-RK2Y4XOM.js";
129
130
  import "./chunk-2LSZVONP.js";
130
131
  import "./chunk-WIICJPET.js";
131
132
  import "./chunk-G2WADRQ3.js";
133
+ import "./chunk-IXEJRKCZ.js";
132
134
  import "./chunk-DT5TVLJE.js";
133
135
  import "./chunk-N5AKDXAI.js";
134
136
  import "./chunk-TBBDFYXW.js";
135
- import "./chunk-XGX4TUF6.js";
137
+ import "./chunk-MCC6KDQF.js";
136
138
  import "./chunk-YNJHCGDT.js";
137
- import "./chunk-4KAN3GZ3.js";
138
- import "./chunk-T65SHTJP.js";
139
+ import "./chunk-NN2DKE4T.js";
140
+ import "./chunk-VQXK37XA.js";
139
141
  import "./chunk-PFV5C235.js";
140
142
  import "./chunk-RULE4VG5.js";
141
143
  import "./chunk-SCU65EZI.js";
142
- import "./chunk-67YLUWLG.js";
144
+ import "./chunk-XJKFSSDW.js";
143
145
  import "./chunk-DM2T26WE.js";
144
146
  import "./chunk-QSVPYQPG.js";
145
- import "./chunk-M62O4P4T.js";
147
+ import "./chunk-FVQJYWH7.js";
146
148
  import "./chunk-4DJQYKMN.js";
147
149
  import "./chunk-G7D6GZ5J.js";
148
150
  import "./chunk-FAAFWE4G.js";
@@ -1,4 +1,5 @@
1
- import { M as MemoryCategory, f as MemoryFile } from './types-H85grL1f.js';
1
+ import { MemoryCategory, MemoryFile } from './types.js';
2
+ import './index-1qIcnbG1.js';
2
3
 
3
4
  /**
4
5
  * `remnic patterns` CLI helpers (issue #687 PR 4/4).
@@ -2,7 +2,7 @@ import {
2
2
  buildPeerProfileReasonerPrompt,
3
3
  parsePeerProfileReasonerResponse,
4
4
  runPeerProfileReasoner
5
- } from "./chunk-3LCWFNVS.js";
5
+ } from "./chunk-SKE7JYKA.js";
6
6
  import {
7
7
  PEERS_DIR_NAME,
8
8
  PEER_ID_MAX_LENGTH,
@@ -19,7 +19,7 @@ import {
19
19
  readPeerProfile,
20
20
  writePeer,
21
21
  writePeerProfile
22
- } from "./chunk-TUFG6VXY.js";
22
+ } from "./chunk-4DWOBS2A.js";
23
23
  import "./chunk-PZ5AY32C.js";
24
24
  export {
25
25
  PEERS_DIR_NAME,
@@ -41,4 +41,4 @@ export {
41
41
  writePeer,
42
42
  writePeerProfile
43
43
  };
44
- //# sourceMappingURL=peers-6OSQ3NK6.js.map
44
+ //# sourceMappingURL=peers-HCVGHMAE.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -1,4 +1,5 @@
1
- import { P as PluginConfig, e as BehaviorLoopPolicyState } from './types-H85grL1f.js';
1
+ import { PluginConfig, BehaviorLoopPolicyState } from './types.js';
2
+ import './index-1qIcnbG1.js';
2
3
 
3
4
  interface RuntimePolicyValues {
4
5
  recencyWeight?: number;
@@ -1,4 +1,4 @@
1
- import { U as QmdSearchResult } from './types-H85grL1f.js';
1
+ import { QmdSearchResult } from './types.js';
2
2
 
3
3
  /** Alias so consumers don't need to reference "Qmd" in a backend-agnostic context. */
4
4
  type SearchResult = QmdSearchResult;
@@ -33,6 +33,12 @@ interface SearchBackend {
33
33
  hybridSearch(query: string, collection?: string, maxResults?: number, execution?: SearchExecutionOptions): Promise<SearchResult[]>;
34
34
  update(execution?: SearchExecutionOptions): Promise<void>;
35
35
  updateCollection(collection: string, execution?: SearchExecutionOptions): Promise<void>;
36
+ /**
37
+ * True when update() refreshes every indexed collection, not just this
38
+ * backend's configured collection. Namespace routers use this to avoid
39
+ * repeating the same expensive global update once per namespace.
40
+ */
41
+ updatesAllCollections?(): boolean;
36
42
  /**
37
43
  * Optional strict refresh used by callers that must know whether a collection
38
44
  * was actually refreshed before writing success markers. Ordinary update
@@ -1,5 +1,6 @@
1
- import { R as RecallPlanMode } from './types-H85grL1f.js';
2
- import { a as SearchQueryOptions } from './port-BkWL7hqo.js';
1
+ import { RecallPlanMode } from './types.js';
2
+ import { a as SearchQueryOptions } from './port-B6VEDIkC.js';
3
+ import './index-1qIcnbG1.js';
3
4
 
4
5
  type QmdRecallCacheSource = "fresh" | "stale";
5
6
  interface QmdRecallCacheHit<T> {
package/dist/qmd.d.ts CHANGED
@@ -1,5 +1,6 @@
1
- import { U as QmdSearchResult, aM as QmdSearchExplain } from './types-H85grL1f.js';
2
- import { S as SearchBackend, a as SearchQueryOptions, b as SearchExecutionOptions } from './port-BkWL7hqo.js';
1
+ import { QmdSearchResult, QmdSearchExplain } from './types.js';
2
+ import { S as SearchBackend, a as SearchQueryOptions, b as SearchExecutionOptions } from './port-B6VEDIkC.js';
3
+ import './index-1qIcnbG1.js';
3
4
 
4
5
  interface QmdClientOptions {
5
6
  slowLog?: {
@@ -102,6 +103,7 @@ declare class QmdClient implements SearchBackend {
102
103
  update(execution?: SearchExecutionOptions): Promise<void>;
103
104
  updateCollection(collection: string, execution?: SearchExecutionOptions): Promise<void>;
104
105
  updateCollectionStrict(collection: string, execution?: SearchExecutionOptions): Promise<void>;
106
+ updatesAllCollections(): boolean;
105
107
  private runUpdateForCollection;
106
108
  embed(): Promise<void>;
107
109
  embedCollection(collection: string): Promise<void>;
package/dist/qmd.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  QmdClient,
3
3
  parseQmdExplain
4
- } from "./chunk-WSZIHQBK.js";
4
+ } from "./chunk-P77UEOU2.js";
5
5
  import "./chunk-PVGDJXVK.js";
6
6
  import "./chunk-OR64ZGRZ.js";
7
7
  import "./chunk-PFV5C235.js";
@@ -1,4 +1,5 @@
1
- import { g as RecallDisclosure } from './types-H85grL1f.js';
1
+ import { RecallDisclosure } from './types.js';
2
+ import './index-1qIcnbG1.js';
2
3
 
3
4
  /**
4
5
  * Recall disclosure auto-escalation policy (issue #677 PR 4/4).
@@ -1,6 +1,7 @@
1
1
  import { LastRecallSnapshot } from './recall-state.js';
2
- import { Q as RecallTierExplain } from './types-H85grL1f.js';
2
+ import { RecallTierExplain } from './types.js';
3
3
  import { RecallXraySnapshot } from './recall-xray.js';
4
+ import './index-1qIcnbG1.js';
4
5
 
5
6
  /**
6
7
  * Renderers for RecallTierExplain (issue #518).
@@ -5,10 +5,10 @@ import {
5
5
  toRecallExplainJson,
6
6
  toRecallExplainText,
7
7
  toRecallXraySnapshotFromLegacy
8
- } from "./chunk-WXPPM426.js";
8
+ } from "./chunk-O4XJUPSF.js";
9
9
  import "./chunk-SOBJ6NEY.js";
10
- import "./chunk-AV2WSYZY.js";
11
- import "./chunk-T65SHTJP.js";
10
+ import "./chunk-2YMTO4ZJ.js";
11
+ import "./chunk-VQXK37XA.js";
12
12
  import "./chunk-PZ5AY32C.js";
13
13
  export {
14
14
  parseRecallExplainFormat,
@@ -1,4 +1,5 @@
1
- import { R as RecallPlanMode, $ as IdentityInjectionMode, Q as RecallTierExplain } from './types-H85grL1f.js';
1
+ import { RecallPlanMode, IdentityInjectionMode, RecallTierExplain } from './types.js';
2
+ import './index-1qIcnbG1.js';
2
3
 
3
4
  interface LastRecallBudgetSummary {
4
5
  requestedTopK?: number;