@remnic/core 1.1.12 → 1.1.14

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 (1324) hide show
  1. package/dist/access-cli.d.ts +2 -1
  2. package/dist/access-cli.js +263 -82
  3. package/dist/access-cli.js.map +1 -1
  4. package/dist/access-http.d.ts +26 -60
  5. package/dist/access-http.js +43 -29
  6. package/dist/access-mcp.d.ts +24 -6
  7. package/dist/access-mcp.js +35 -28
  8. package/dist/access-schema.d.ts +9 -6
  9. package/dist/access-schema.js +7 -5
  10. package/dist/access-service-DcCDmNYC.d.ts +1542 -0
  11. package/dist/access-service.d.ts +25 -7
  12. package/dist/access-service.js +33 -26
  13. package/dist/active-memory-bridge.js +2 -2
  14. package/dist/active-recall.js +11 -3
  15. package/dist/active-recall.js.map +1 -1
  16. package/dist/adapters/claude-code.d.ts +24 -0
  17. package/dist/adapters/claude-code.js +9 -0
  18. package/dist/adapters/codex.d.ts +25 -0
  19. package/dist/adapters/codex.js +9 -0
  20. package/dist/adapters/hermes.d.ts +35 -0
  21. package/dist/adapters/hermes.js +9 -0
  22. package/dist/adapters/index.d.ts +6 -0
  23. package/dist/adapters/index.js +26 -0
  24. package/dist/adapters/registry.d.ts +20 -0
  25. package/dist/adapters/registry.js +13 -0
  26. package/dist/adapters/replit.d.ts +28 -0
  27. package/dist/adapters/replit.js +9 -0
  28. package/dist/adapters/types.d.ts +43 -0
  29. package/dist/adapters/types.js +8 -0
  30. package/dist/bootstrap.d.ts +20 -5
  31. package/dist/boxes.d.ts +7 -0
  32. package/dist/boxes.js +1 -1
  33. package/dist/briefing.d.ts +5 -3
  34. package/dist/briefing.js +9 -6
  35. package/dist/buffer-surprise-report.js +1 -1
  36. package/dist/buffer.d.ts +18 -4
  37. package/dist/buffer.js +1 -1
  38. package/dist/calibration.js +4 -4
  39. package/dist/capsule-cli.d.ts +4 -4
  40. package/dist/capsule-cli.js +1 -1
  41. package/dist/capsule-crypto-5CYAGVC5.js +18 -0
  42. package/dist/capsule-merge-4MGKE7C5.js +189 -0
  43. package/dist/causal-behavior.d.ts +8 -28
  44. package/dist/causal-behavior.js +6 -3
  45. package/dist/causal-behavior.js.map +1 -1
  46. package/dist/causal-chain.js +3 -2
  47. package/dist/causal-consolidation.d.ts +1 -1
  48. package/dist/causal-consolidation.js +24 -13
  49. package/dist/causal-consolidation.js.map +1 -1
  50. package/dist/causal-retrieval.js +3 -3
  51. package/dist/causal-trajectory.js +1 -1
  52. package/dist/chunk-25MQ7IHJ.js +427 -0
  53. package/dist/chunk-25MQ7IHJ.js.map +1 -0
  54. package/dist/chunk-2F2W355T.js +256 -0
  55. package/dist/chunk-2F2W355T.js.map +1 -0
  56. package/dist/chunk-2KI4QFHU.js +228 -0
  57. package/dist/chunk-2KI4QFHU.js.map +1 -0
  58. package/dist/chunk-2PRQG7PV.js +86 -0
  59. package/dist/chunk-2PRQG7PV.js.map +1 -0
  60. package/dist/chunk-2QR3XXIC.js +2272 -0
  61. package/dist/chunk-2QR3XXIC.js.map +1 -0
  62. package/dist/chunk-2WWLHTZY.js +121 -0
  63. package/dist/chunk-326G7DJK.js +2185 -0
  64. package/dist/chunk-326G7DJK.js.map +1 -0
  65. package/dist/chunk-34DQE4KF.js +174 -0
  66. package/dist/chunk-34DQE4KF.js.map +1 -0
  67. package/dist/chunk-3APJ5EVB.js +601 -0
  68. package/dist/chunk-3APJ5EVB.js.map +1 -0
  69. package/dist/chunk-3HPAPHUK.js +51 -0
  70. package/dist/chunk-3HPAPHUK.js.map +1 -0
  71. package/dist/chunk-3JXBXXM2.js +69 -0
  72. package/dist/chunk-3JXBXXM2.js.map +1 -0
  73. package/dist/chunk-3KW65B36.js +681 -0
  74. package/dist/chunk-3KW65B36.js.map +1 -0
  75. package/dist/chunk-3UXOZBHV.js +20 -0
  76. package/dist/chunk-3UXOZBHV.js.map +1 -0
  77. package/dist/chunk-3VAL7ZL2.js +266 -0
  78. package/dist/chunk-3VAL7ZL2.js.map +1 -0
  79. package/dist/chunk-3Y4P7RXM.js +31 -0
  80. package/dist/chunk-3Y4P7RXM.js.map +1 -0
  81. package/dist/chunk-47VWKCAF.js +273 -0
  82. package/dist/chunk-47VWKCAF.js.map +1 -0
  83. package/dist/chunk-4CRG46BG.js +271 -0
  84. package/dist/chunk-5375UYTQ.js +914 -0
  85. package/dist/chunk-5375UYTQ.js.map +1 -0
  86. package/dist/chunk-56K5QLHX.js +506 -0
  87. package/dist/chunk-56K5QLHX.js.map +1 -0
  88. package/dist/chunk-5RGLBDQF.js +596 -0
  89. package/dist/chunk-5RGLBDQF.js.map +1 -0
  90. package/dist/chunk-5UZXUTVO.js +9 -0
  91. package/dist/chunk-5UZXUTVO.js.map +1 -0
  92. package/dist/chunk-65PG43EQ.js +105 -0
  93. package/dist/chunk-65PG43EQ.js.map +1 -0
  94. package/dist/chunk-66DHUKLO.js +57 -0
  95. package/dist/chunk-66DHUKLO.js.map +1 -0
  96. package/dist/chunk-6FC5EGNV.js +46 -0
  97. package/dist/chunk-6FC5EGNV.js.map +1 -0
  98. package/dist/chunk-6H2TESSP.js +62 -0
  99. package/dist/chunk-6H2TESSP.js.map +1 -0
  100. package/dist/chunk-6LVVDPJ4.js +32 -0
  101. package/dist/chunk-6LVVDPJ4.js.map +1 -0
  102. package/dist/chunk-6RVI47ZR.js +159 -0
  103. package/dist/chunk-6RVI47ZR.js.map +1 -0
  104. package/dist/chunk-7AAT6G4Q.js +5117 -0
  105. package/dist/chunk-7AAT6G4Q.js.map +1 -0
  106. package/dist/chunk-7DTASS5T.js +29 -0
  107. package/dist/chunk-7DTASS5T.js.map +1 -0
  108. package/dist/chunk-7IASACLB.js +596 -0
  109. package/dist/chunk-7MNMYOFP.js +32 -0
  110. package/dist/chunk-7MNMYOFP.js.map +1 -0
  111. package/dist/chunk-7N4KAIGN.js +133 -0
  112. package/dist/chunk-7N4KAIGN.js.map +1 -0
  113. package/dist/chunk-7OZ53EXP.js +101 -0
  114. package/dist/chunk-7OZ53EXP.js.map +1 -0
  115. package/dist/chunk-7XYTQGCC.js +134 -0
  116. package/dist/chunk-7XYTQGCC.js.map +1 -0
  117. package/dist/chunk-A2XUIMJ3.js +341 -0
  118. package/dist/chunk-A2XUIMJ3.js.map +1 -0
  119. package/dist/chunk-AGZQD76C.js +201 -0
  120. package/dist/chunk-AGZQD76C.js.map +1 -0
  121. package/dist/chunk-APO3DCMU.js +361 -0
  122. package/dist/chunk-APO3DCMU.js.map +1 -0
  123. package/dist/chunk-BFBF3XEF.js +283 -0
  124. package/dist/chunk-BFBF3XEF.js.map +1 -0
  125. package/dist/chunk-BJ3KMYTB.js +1974 -0
  126. package/dist/chunk-BJ3KMYTB.js.map +1 -0
  127. package/dist/chunk-CHEL3SKB.js +6758 -0
  128. package/dist/chunk-CHEL3SKB.js.map +1 -0
  129. package/dist/chunk-CQZRLNMV.js +1491 -0
  130. package/dist/chunk-CQZRLNMV.js.map +1 -0
  131. package/dist/chunk-D46YSIYX.js +892 -0
  132. package/dist/chunk-D46YSIYX.js.map +1 -0
  133. package/dist/chunk-DINWEURR.js +648 -0
  134. package/dist/chunk-DINWEURR.js.map +1 -0
  135. package/dist/chunk-DK5LDEQM.js +530 -0
  136. package/dist/chunk-DK5LDEQM.js.map +1 -0
  137. package/dist/chunk-DOM4GKSW.js +34 -0
  138. package/dist/chunk-DOM4GKSW.js.map +1 -0
  139. package/dist/chunk-EDTHC6UD.js +1075 -0
  140. package/dist/chunk-EFJ3MQ4V.js +721 -0
  141. package/dist/chunk-EHRTFRWW.js +89 -0
  142. package/dist/chunk-EHRTFRWW.js.map +1 -0
  143. package/dist/chunk-FAJ7FZYM.js +11 -0
  144. package/dist/chunk-FAJ7FZYM.js.map +1 -0
  145. package/dist/chunk-FBYESMQ2.js +570 -0
  146. package/dist/chunk-FDU6HUUL.js +147 -0
  147. package/dist/chunk-FF4KLI5W.js +99 -0
  148. package/dist/chunk-FF4KLI5W.js.map +1 -0
  149. package/dist/chunk-FIT6DMX6.js +310 -0
  150. package/dist/chunk-FIT6DMX6.js.map +1 -0
  151. package/dist/chunk-FJ43PRLT.js +272 -0
  152. package/dist/chunk-FJ43PRLT.js.map +1 -0
  153. package/dist/chunk-FKFMOY3N.js +32 -0
  154. package/dist/chunk-FKFMOY3N.js.map +1 -0
  155. package/dist/chunk-FLTNHQK6.js +262 -0
  156. package/dist/chunk-FLTNHQK6.js.map +1 -0
  157. package/dist/chunk-GA454ALV.js +12436 -0
  158. package/dist/chunk-GA454ALV.js.map +1 -0
  159. package/dist/chunk-GGKRUQOO.js +228 -0
  160. package/dist/chunk-GIF42EW3.js +63 -0
  161. package/dist/chunk-GIF42EW3.js.map +1 -0
  162. package/dist/chunk-GL6I6MEQ.js +647 -0
  163. package/dist/chunk-H3ME6L6D.js +709 -0
  164. package/dist/chunk-H3ME6L6D.js.map +1 -0
  165. package/dist/chunk-HHLLAQGZ.js +1 -0
  166. package/dist/chunk-HXXBL2KD.js +2040 -0
  167. package/dist/chunk-I5V2VDIW.js +219 -0
  168. package/dist/chunk-I5V2VDIW.js.map +1 -0
  169. package/dist/chunk-I6K5FBRQ.js +35 -0
  170. package/dist/chunk-I6K5FBRQ.js.map +1 -0
  171. package/dist/chunk-ICRIXAP2.js +121 -0
  172. package/dist/chunk-ICRIXAP2.js.map +1 -0
  173. package/dist/chunk-J4EB7DNW.js +11 -0
  174. package/dist/chunk-J4EB7DNW.js.map +1 -0
  175. package/dist/chunk-JLFA7DQG.js +62 -0
  176. package/dist/chunk-JLFA7DQG.js.map +1 -0
  177. package/dist/chunk-KJTKLXTH.js +9 -0
  178. package/dist/chunk-KJTKLXTH.js.map +1 -0
  179. package/dist/chunk-KLAO5DGL.js +917 -0
  180. package/dist/chunk-KLAO5DGL.js.map +1 -0
  181. package/dist/chunk-KNKUID7G.js +183 -0
  182. package/dist/chunk-KOSORCJG.js +624 -0
  183. package/dist/chunk-KOSORCJG.js.map +1 -0
  184. package/dist/chunk-KUJVMMZQ.js +1262 -0
  185. package/dist/chunk-KUJVMMZQ.js.map +1 -0
  186. package/dist/chunk-LCR46JY5.js +123 -0
  187. package/dist/chunk-LCR46JY5.js.map +1 -0
  188. package/dist/chunk-LLQ2LLWF.js +148 -0
  189. package/dist/chunk-LLQ2LLWF.js.map +1 -0
  190. package/dist/chunk-LPMVBPA3.js +236 -0
  191. package/dist/chunk-LT3NLYSI.js +50 -0
  192. package/dist/chunk-LT3NLYSI.js.map +1 -0
  193. package/dist/chunk-LUDTDZLK.js +287 -0
  194. package/dist/chunk-LUDTDZLK.js.map +1 -0
  195. package/dist/chunk-M23FSH32.js +3963 -0
  196. package/dist/chunk-M23FSH32.js.map +1 -0
  197. package/dist/chunk-MC26UJIM.js +118 -0
  198. package/dist/chunk-ME6ESPZU.js +119 -0
  199. package/dist/chunk-ME6ESPZU.js.map +1 -0
  200. package/dist/chunk-MGKYQQYF.js +272 -0
  201. package/dist/chunk-MJFNCJXV.js +66 -0
  202. package/dist/chunk-MJFNCJXV.js.map +1 -0
  203. package/dist/chunk-MSWG7JI6.js +237 -0
  204. package/dist/chunk-MSWG7JI6.js.map +1 -0
  205. package/dist/chunk-MT25YHYH.js +141 -0
  206. package/dist/chunk-MT25YHYH.js.map +1 -0
  207. package/dist/chunk-MT4HVDUZ.js +53 -0
  208. package/dist/chunk-MY6TPVXW.js +219 -0
  209. package/dist/chunk-N2D6GXBM.js +267 -0
  210. package/dist/chunk-N2D6GXBM.js.map +1 -0
  211. package/dist/chunk-NJ3MJQZX.js +46 -0
  212. package/dist/chunk-NJ3MJQZX.js.map +1 -0
  213. package/dist/chunk-NMZY542O.js +335 -0
  214. package/dist/chunk-NMZY542O.js.map +1 -0
  215. package/dist/chunk-NNVTUXEB.js +23 -0
  216. package/dist/chunk-NZL6GGQE.js +375 -0
  217. package/dist/chunk-NZL6GGQE.js.map +1 -0
  218. package/dist/chunk-P4NEIHUT.js +108 -0
  219. package/dist/chunk-P7FMDTKL.js +103 -0
  220. package/dist/chunk-P7FMDTKL.js.map +1 -0
  221. package/dist/chunk-PHK3HARR.js +32 -0
  222. package/dist/chunk-PHK3HARR.js.map +1 -0
  223. package/dist/chunk-PIRJPV5T.js +98 -0
  224. package/dist/chunk-PIRJPV5T.js.map +1 -0
  225. package/dist/chunk-PK7H5L6Y.js +159 -0
  226. package/dist/chunk-PK7H5L6Y.js.map +1 -0
  227. package/dist/chunk-PR5FBTFU.js +233 -0
  228. package/dist/chunk-PR5FBTFU.js.map +1 -0
  229. package/dist/chunk-PU63GXWS.js +174 -0
  230. package/dist/chunk-PU63GXWS.js.map +1 -0
  231. package/dist/chunk-PZIAX57I.js +124 -0
  232. package/dist/chunk-PZIAX57I.js.map +1 -0
  233. package/dist/chunk-Q7P4WJDP.js +26 -0
  234. package/dist/chunk-Q7P4WJDP.js.map +1 -0
  235. package/dist/chunk-QQUAB63I.js +63 -0
  236. package/dist/chunk-QQUAB63I.js.map +1 -0
  237. package/dist/chunk-QRNI5JBH.js +18 -0
  238. package/dist/chunk-RHY3HH7P.js +601 -0
  239. package/dist/chunk-RHY3HH7P.js.map +1 -0
  240. package/dist/chunk-RRF5UOBJ.js +91 -0
  241. package/dist/chunk-RXDLTSWT.js +124 -0
  242. package/dist/chunk-RXDLTSWT.js.map +1 -0
  243. package/dist/chunk-RYED3SPJ.js +42 -0
  244. package/dist/chunk-RYED3SPJ.js.map +1 -0
  245. package/dist/chunk-S7KDBTWT.js +106 -0
  246. package/dist/chunk-S7KDBTWT.js.map +1 -0
  247. package/dist/chunk-SEDEKFYQ.js +1 -0
  248. package/dist/chunk-TECVW3JP.js +36 -0
  249. package/dist/chunk-TECVW3JP.js.map +1 -0
  250. package/dist/chunk-TFO23QT4.js +88 -0
  251. package/dist/chunk-TFO23QT4.js.map +1 -0
  252. package/dist/chunk-TK4UEOSK.js +76 -0
  253. package/dist/chunk-TK4UEOSK.js.map +1 -0
  254. package/dist/chunk-TKWGAOLV.js +122 -0
  255. package/dist/chunk-TKWGAOLV.js.map +1 -0
  256. package/dist/chunk-TMM4S4IJ.js +597 -0
  257. package/dist/chunk-TMM4S4IJ.js.map +1 -0
  258. package/dist/chunk-TMQLARTH.js +188 -0
  259. package/dist/chunk-TMQLARTH.js.map +1 -0
  260. package/dist/chunk-TPDBFYEG.js +130 -0
  261. package/dist/chunk-TPDBFYEG.js.map +1 -0
  262. package/dist/chunk-TPMQ3G6Z.js +145 -0
  263. package/dist/chunk-TPMQ3G6Z.js.map +1 -0
  264. package/dist/chunk-TZOLIGIG.js +61 -0
  265. package/dist/chunk-TZOLIGIG.js.map +1 -0
  266. package/dist/chunk-U3PN77QT.js +113 -0
  267. package/dist/chunk-U3WSW6PZ.js +277 -0
  268. package/dist/chunk-U4SCL7B7.js +640 -0
  269. package/dist/chunk-U4SCL7B7.js.map +1 -0
  270. package/dist/chunk-UWK5OXUJ.js +156 -0
  271. package/dist/chunk-UWK5OXUJ.js.map +1 -0
  272. package/dist/chunk-UWVJF25J.js +74 -0
  273. package/dist/chunk-UXHQAFNA.js +1317 -0
  274. package/dist/chunk-UXHQAFNA.js.map +1 -0
  275. package/dist/chunk-V5OCT34X.js +1 -0
  276. package/dist/chunk-VLXA6PI2.js +304 -0
  277. package/dist/chunk-VLXA6PI2.js.map +1 -0
  278. package/dist/chunk-VNO6ZJ35.js +500 -0
  279. package/dist/chunk-VNO6ZJ35.js.map +1 -0
  280. package/dist/chunk-VW676BEI.js +827 -0
  281. package/dist/chunk-VW676BEI.js.map +1 -0
  282. package/dist/chunk-W3LR522O.js +2296 -0
  283. package/dist/chunk-W4L6CZKA.js +96 -0
  284. package/dist/chunk-W4L6CZKA.js.map +1 -0
  285. package/dist/chunk-W4RVMTHR.js +372 -0
  286. package/dist/chunk-W4RVMTHR.js.map +1 -0
  287. package/dist/chunk-WEHSQBFR.js +188 -0
  288. package/dist/chunk-WEHSQBFR.js.map +1 -0
  289. package/dist/chunk-WELDCG6C.js +380 -0
  290. package/dist/chunk-WELDCG6C.js.map +1 -0
  291. package/dist/chunk-WZYKANL3.js +2800 -0
  292. package/dist/chunk-WZYKANL3.js.map +1 -0
  293. package/dist/chunk-XIG5PDM7.js +48 -0
  294. package/dist/chunk-XJNBEDFE.js +193 -0
  295. package/dist/chunk-XJNBEDFE.js.map +1 -0
  296. package/dist/chunk-XVVIG67A.js +291 -0
  297. package/dist/chunk-XVVIG67A.js.map +1 -0
  298. package/dist/chunk-XVZ7B3HG.js +135 -0
  299. package/dist/chunk-YBPYIAA5.js +73 -0
  300. package/dist/chunk-YBPYIAA5.js.map +1 -0
  301. package/dist/chunk-Z734BLO3.js +21 -0
  302. package/dist/chunk-Z734BLO3.js.map +1 -0
  303. package/dist/chunk-ZKSK55RC.js +269 -0
  304. package/dist/chunk-ZKSK55RC.js.map +1 -0
  305. package/dist/chunk-ZTFCYYEZ.js +69 -0
  306. package/dist/chunk-ZTFCYYEZ.js.map +1 -0
  307. package/dist/chunk-ZY2MNJR6.js +329 -0
  308. package/dist/chunk-ZY2MNJR6.js.map +1 -0
  309. package/dist/cli-D3VpkVwB.d.ts +1136 -0
  310. package/dist/cli.d.ts +39 -10
  311. package/dist/cli.js +108 -49
  312. package/dist/commitment-ledger.js +1 -1
  313. package/dist/compat/checks.d.ts +5 -0
  314. package/dist/compat/checks.js +11 -0
  315. package/dist/compat/checks.js.map +1 -0
  316. package/dist/compat/types.d.ts +30 -0
  317. package/dist/compat/types.js +1 -0
  318. package/dist/compat/types.js.map +1 -0
  319. package/dist/compounding/engine.d.ts +221 -0
  320. package/dist/compounding/engine.js +32 -0
  321. package/dist/compounding/engine.js.map +1 -0
  322. package/dist/compounding/preference-consolidator.d.ts +92 -0
  323. package/dist/compounding/preference-consolidator.js +553 -0
  324. package/dist/compounding/preference-consolidator.js.map +1 -0
  325. package/dist/config.d.ts +4 -2
  326. package/dist/config.js +9 -4
  327. package/dist/conflict-policy-DyJ2wd-h.d.ts +4 -0
  328. package/dist/connectors/codex-materialize-runner.d.ts +64 -0
  329. package/dist/connectors/codex-materialize-runner.js +33 -0
  330. package/dist/connectors/codex-materialize-runner.js.map +1 -0
  331. package/dist/connectors/codex-materialize.d.ts +195 -0
  332. package/dist/connectors/codex-materialize.js +38 -0
  333. package/dist/connectors/codex-materialize.js.map +1 -0
  334. package/dist/connectors/index.d.ts +444 -0
  335. package/dist/connectors/index.js +115 -0
  336. package/dist/connectors/index.js.map +1 -0
  337. package/dist/connectors-cli-CwbyjGR7.d.ts +257 -0
  338. package/dist/connectors-cli.d.ts +1 -1
  339. package/dist/consolidation-provenance-check.d.ts +3 -1
  340. package/dist/consolidation-undo.d.ts +3 -1
  341. package/dist/contradiction/index.d.ts +258 -0
  342. package/dist/contradiction/index.js +43 -0
  343. package/dist/contradiction/index.js.map +1 -0
  344. package/dist/contradiction-review-ATP4S6IC.js +30 -0
  345. package/dist/contradiction-review-ATP4S6IC.js.map +1 -0
  346. package/dist/contradiction-scan-5A4IDZV5.js +13 -0
  347. package/dist/contradiction-scan-5A4IDZV5.js.map +1 -0
  348. package/dist/conversation-index/backend.d.ts +97 -0
  349. package/dist/conversation-index/backend.js +13 -0
  350. package/dist/conversation-index/backend.js.map +1 -0
  351. package/dist/conversation-index/chunker.d.ts +16 -0
  352. package/dist/conversation-index/chunker.js +8 -0
  353. package/dist/conversation-index/chunker.js.map +1 -0
  354. package/dist/conversation-index/cleanup.d.ts +11 -0
  355. package/dist/conversation-index/cleanup.js +9 -0
  356. package/dist/conversation-index/cleanup.js.map +1 -0
  357. package/dist/conversation-index/faiss-adapter.d.ts +6 -0
  358. package/dist/conversation-index/faiss-adapter.js +16 -0
  359. package/dist/conversation-index/faiss-adapter.js.map +1 -0
  360. package/dist/conversation-index/indexer.d.ts +23 -0
  361. package/dist/conversation-index/indexer.js +15 -0
  362. package/dist/conversation-index/indexer.js.map +1 -0
  363. package/dist/conversation-index/search.d.ts +6 -0
  364. package/dist/conversation-index/search.js +11 -0
  365. package/dist/conversation-index/search.js.map +1 -0
  366. package/dist/embedding-fallback.js +2 -2
  367. package/dist/enrichment/index.d.ts +163 -0
  368. package/dist/enrichment/index.js +18 -0
  369. package/dist/enrichment/index.js.map +1 -0
  370. package/dist/entity-retrieval.d.ts +4 -2
  371. package/dist/entity-retrieval.js +8 -5
  372. package/dist/evals.js +1 -1
  373. package/dist/explicit-capture.d.ts +20 -5
  374. package/dist/explicit-capture.js +2 -2
  375. package/dist/extraction-judge-training.js +1 -1
  376. package/dist/extraction.js +8 -8
  377. package/dist/faiss-adapter-CzPghc4C.d.ts +70 -0
  378. package/dist/fallback-llm.d.ts +2 -0
  379. package/dist/fallback-llm.js +4 -4
  380. package/dist/graph-edge-decay-5DI5GUNL.js +207 -0
  381. package/dist/index.d.ts +66 -711
  382. package/dist/index.js +556 -2680
  383. package/dist/index.js.map +1 -1
  384. package/dist/lcm/archive.d.ts +89 -0
  385. package/dist/lcm/archive.js +12 -0
  386. package/dist/lcm/archive.js.map +1 -0
  387. package/dist/lcm/dag.d.ts +48 -0
  388. package/dist/lcm/dag.js +8 -0
  389. package/dist/lcm/dag.js.map +1 -0
  390. package/dist/lcm/engine.d.ts +116 -0
  391. package/dist/lcm/engine.js +20 -0
  392. package/dist/lcm/engine.js.map +1 -0
  393. package/dist/lcm/index.d.ts +12 -0
  394. package/dist/lcm/index.js +44 -0
  395. package/dist/lcm/index.js.map +1 -0
  396. package/dist/lcm/queue.d.ts +62 -0
  397. package/dist/lcm/queue.js +8 -0
  398. package/dist/lcm/queue.js.map +1 -0
  399. package/dist/lcm/recall.d.ts +20 -0
  400. package/dist/lcm/recall.js +8 -0
  401. package/dist/lcm/recall.js.map +1 -0
  402. package/dist/lcm/schema.d.ts +16 -0
  403. package/dist/lcm/schema.js +14 -0
  404. package/dist/lcm/schema.js.map +1 -0
  405. package/dist/lcm/summarizer.d.ts +38 -0
  406. package/dist/lcm/summarizer.js +12 -0
  407. package/dist/lcm/summarizer.js.map +1 -0
  408. package/dist/lcm/tools.d.ts +29 -0
  409. package/dist/lcm/tools.js +8 -0
  410. package/dist/lcm/tools.js.map +1 -0
  411. package/dist/live-connectors-runner.js +5 -5
  412. package/dist/local-llm.js +3 -3
  413. package/dist/maintenance/archive-observations.d.ts +18 -0
  414. package/dist/maintenance/archive-observations.js +8 -0
  415. package/dist/maintenance/archive-observations.js.map +1 -0
  416. package/dist/maintenance/backup-stamp.d.ts +3 -0
  417. package/dist/maintenance/backup-stamp.js +8 -0
  418. package/dist/maintenance/backup-stamp.js.map +1 -0
  419. package/dist/maintenance/memory-governance-cron.d.ts +85 -0
  420. package/dist/maintenance/memory-governance-cron.js +22 -0
  421. package/dist/maintenance/memory-governance-cron.js.map +1 -0
  422. package/dist/maintenance/memory-governance.d.ts +137 -0
  423. package/dist/maintenance/memory-governance.js +40 -0
  424. package/dist/maintenance/memory-governance.js.map +1 -0
  425. package/dist/maintenance/migrate-observations.d.ts +18 -0
  426. package/dist/maintenance/migrate-observations.js +9 -0
  427. package/dist/maintenance/migrate-observations.js.map +1 -0
  428. package/dist/maintenance/observation-ledger-utils.d.ts +10 -0
  429. package/dist/maintenance/observation-ledger-utils.js +10 -0
  430. package/dist/maintenance/observation-ledger-utils.js.map +1 -0
  431. package/dist/maintenance/rebuild-memory-lifecycle-ledger.d.ts +15 -0
  432. package/dist/maintenance/rebuild-memory-lifecycle-ledger.js +28 -0
  433. package/dist/maintenance/rebuild-memory-lifecycle-ledger.js.map +1 -0
  434. package/dist/maintenance/rebuild-memory-projection.d.ts +77 -0
  435. package/dist/maintenance/rebuild-memory-projection.js +35 -0
  436. package/dist/maintenance/rebuild-memory-projection.js.map +1 -0
  437. package/dist/maintenance/rebuild-observations.d.ts +17 -0
  438. package/dist/maintenance/rebuild-observations.js +9 -0
  439. package/dist/maintenance/rebuild-observations.js.map +1 -0
  440. package/dist/mcp-memory-inspector-app.d.ts +24 -6
  441. package/dist/memory-projection-store.d.ts +108 -3
  442. package/dist/memory-projection-store.js +2 -1
  443. package/dist/memory-worth-outcomes.d.ts +4 -2
  444. package/dist/migrate/from-engram.d.ts +24 -0
  445. package/dist/migrate/from-engram.js +12 -0
  446. package/dist/migrate/from-engram.js.map +1 -0
  447. package/dist/namespaces/migrate.d.ts +50 -0
  448. package/dist/namespaces/migrate.js +50 -0
  449. package/dist/namespaces/migrate.js.map +1 -0
  450. package/dist/namespaces/principal.d.ts +17 -0
  451. package/dist/namespaces/principal.js +16 -0
  452. package/dist/namespaces/principal.js.map +1 -0
  453. package/dist/namespaces/search.d.ts +46 -0
  454. package/dist/namespaces/search.js +28 -0
  455. package/dist/namespaces/search.js.map +1 -0
  456. package/dist/namespaces/storage.d.ts +32 -0
  457. package/dist/namespaces/storage.js +28 -0
  458. package/dist/namespaces/storage.js.map +1 -0
  459. package/dist/network/tailscale.d.ts +41 -0
  460. package/dist/network/tailscale.js +9 -0
  461. package/dist/network/tailscale.js.map +1 -0
  462. package/dist/network/webdav.d.ts +39 -0
  463. package/dist/network/webdav.js +10 -0
  464. package/dist/network/webdav.js.map +1 -0
  465. package/dist/objective-state-writers.js +2 -2
  466. package/dist/operator-toolkit.d.ts +4 -2
  467. package/dist/operator-toolkit.js +32 -14
  468. package/dist/opik-exporter.js +2 -2
  469. package/dist/opik-exporter.js.map +1 -1
  470. package/dist/orchestrator-DuWl9Hwx.d.ts +1244 -0
  471. package/dist/orchestrator.d.ts +22 -7
  472. package/dist/orchestrator.js +79 -44
  473. package/dist/path-MR5JPYOP.js +9 -0
  474. package/dist/path-MR5JPYOP.js.map +1 -0
  475. package/dist/qmd-recall-cache.d.ts +1 -1
  476. package/dist/qmd.d.ts +102 -3
  477. package/dist/qmd.js +23 -5
  478. package/dist/recall-explain-renderer.js +3 -3
  479. package/dist/recall-xray-cli.js +4 -4
  480. package/dist/recall-xray-renderer.js +3 -3
  481. package/dist/recall-xray.js +2 -2
  482. package/dist/replay/normalizers/chatgpt.d.ts +6 -0
  483. package/dist/replay/normalizers/chatgpt.js +11 -0
  484. package/dist/replay/normalizers/chatgpt.js.map +1 -0
  485. package/dist/replay/normalizers/claude.d.ts +6 -0
  486. package/dist/replay/normalizers/claude.js +11 -0
  487. package/dist/replay/normalizers/claude.js.map +1 -0
  488. package/dist/replay/normalizers/openclaw.d.ts +6 -0
  489. package/dist/replay/normalizers/openclaw.js +11 -0
  490. package/dist/replay/normalizers/openclaw.js.map +1 -0
  491. package/dist/replay/normalizers/shared.d.ts +16 -0
  492. package/dist/replay/normalizers/shared.js +14 -0
  493. package/dist/replay/normalizers/shared.js.map +1 -0
  494. package/dist/replay/runner.d.ts +35 -0
  495. package/dist/replay/runner.js +16 -0
  496. package/dist/replay/runner.js.map +1 -0
  497. package/dist/replay/types.d.ts +57 -0
  498. package/dist/replay/types.js +19 -0
  499. package/dist/replay/types.js.map +1 -0
  500. package/dist/resolution-B7FNQSSP.js +12 -0
  501. package/dist/resolution-B7FNQSSP.js.map +1 -0
  502. package/dist/resolve-provider-secret.js +2 -2
  503. package/dist/resume-bundles.js +8 -6
  504. package/dist/retrieval-agents.d.ts +1 -1
  505. package/dist/routing/engine.d.ts +35 -0
  506. package/dist/routing/engine.js +16 -0
  507. package/dist/routing/engine.js.map +1 -0
  508. package/dist/routing/store.d.ts +27 -0
  509. package/dist/routing/store.js +10 -0
  510. package/dist/routing/store.js.map +1 -0
  511. package/dist/runtime/better-sqlite.d.ts +8 -0
  512. package/dist/runtime/better-sqlite.js +10 -0
  513. package/dist/runtime/better-sqlite.js.map +1 -0
  514. package/dist/runtime/child-process.d.ts +32 -0
  515. package/dist/runtime/child-process.js +10 -0
  516. package/dist/runtime/child-process.js.map +1 -0
  517. package/dist/runtime/env.d.ts +5 -0
  518. package/dist/runtime/env.js +12 -0
  519. package/dist/runtime/env.js.map +1 -0
  520. package/dist/schemas.d.ts +22 -22
  521. package/dist/sdk-compat.js +1 -1
  522. package/dist/search/document-scanner.d.ts +22 -0
  523. package/dist/search/document-scanner.js +8 -0
  524. package/dist/search/document-scanner.js.map +1 -0
  525. package/dist/search/embed-helper.d.ts +35 -0
  526. package/dist/search/embed-helper.js +9 -0
  527. package/dist/search/embed-helper.js.map +1 -0
  528. package/dist/search/factory.d.ts +32 -0
  529. package/dist/search/factory.js +29 -0
  530. package/dist/search/factory.js.map +1 -0
  531. package/dist/search/index.d.ts +15 -0
  532. package/dist/search/index.js +50 -0
  533. package/dist/search/index.js.map +1 -0
  534. package/dist/search/lancedb-backend.d.ts +51 -0
  535. package/dist/search/lancedb-backend.js +10 -0
  536. package/dist/search/lancedb-backend.js.map +1 -0
  537. package/dist/search/meilisearch-backend.d.ts +48 -0
  538. package/dist/search/meilisearch-backend.js +10 -0
  539. package/dist/search/meilisearch-backend.js.map +1 -0
  540. package/dist/search/noop-backend.d.ts +26 -0
  541. package/dist/search/noop-backend.js +8 -0
  542. package/dist/search/noop-backend.js.map +1 -0
  543. package/dist/search/orama-backend.d.ts +53 -0
  544. package/dist/search/orama-backend.js +10 -0
  545. package/dist/search/orama-backend.js.map +1 -0
  546. package/dist/search/port.d.ts +61 -0
  547. package/dist/search/port.js +1 -0
  548. package/dist/search/port.js.map +1 -0
  549. package/dist/search/remote-backend.d.ts +39 -0
  550. package/dist/search/remote-backend.js +9 -0
  551. package/dist/search/remote-backend.js.map +1 -0
  552. package/dist/secure-store/index.d.ts +890 -0
  553. package/dist/secure-store/index.js +156 -0
  554. package/dist/secure-store/index.js.map +1 -0
  555. package/dist/semantic-VwGI14Ok.d.ts +69 -0
  556. package/dist/semantic-consolidation-4HkHWgeI.d.ts +180 -0
  557. package/dist/semantic-consolidation.d.ts +2 -2
  558. package/dist/semantic-consolidation.js +13 -6
  559. package/dist/semantic-rule-promotion.js +8 -5
  560. package/dist/semantic-rule-verifier.js +8 -5
  561. package/dist/shared-context/manager.d.ts +131 -0
  562. package/dist/shared-context/manager.js +15 -0
  563. package/dist/shared-context/manager.js.map +1 -0
  564. package/dist/skills-registry.js +13 -1
  565. package/dist/skills-registry.js.map +1 -1
  566. package/dist/state-store-VZU2IA53.js +16 -0
  567. package/dist/state-store-VZU2IA53.js.map +1 -0
  568. package/dist/storage-paths.d.ts +9 -0
  569. package/dist/storage-paths.js +20 -0
  570. package/dist/storage-paths.js.map +1 -0
  571. package/dist/storage.d.ts +3 -1
  572. package/dist/storage.js +7 -4
  573. package/dist/summarizer.d.ts +5 -0
  574. package/dist/summarizer.js +9 -8
  575. package/dist/summary-snapshot.js +2 -1
  576. package/dist/surfaces/dreams.d.ts +16 -0
  577. package/dist/surfaces/dreams.js +282 -0
  578. package/dist/surfaces/dreams.js.map +1 -0
  579. package/dist/surfaces/heartbeat.d.ts +17 -0
  580. package/dist/surfaces/heartbeat.js +265 -0
  581. package/dist/surfaces/heartbeat.js.map +1 -0
  582. package/dist/temporal-supersession.d.ts +3 -1
  583. package/dist/threading.d.ts +5 -0
  584. package/dist/threading.js +2 -1
  585. package/dist/tier-migration.d.ts +4 -2
  586. package/dist/tokens.js +2 -2
  587. package/dist/transcript.d.ts +15 -1
  588. package/dist/transcript.js +2 -1
  589. package/dist/transfer/autodetect.d.ts +4 -0
  590. package/dist/transfer/autodetect.js +15 -0
  591. package/dist/transfer/autodetect.js.map +1 -0
  592. package/dist/transfer/backup.d.ts +21 -0
  593. package/dist/transfer/backup.js +17 -0
  594. package/dist/transfer/backup.js.map +1 -0
  595. package/dist/transfer/capsule-export.d.ts +113 -0
  596. package/dist/transfer/capsule-export.js +19 -0
  597. package/dist/transfer/capsule-export.js.map +1 -0
  598. package/dist/transfer/capsule-import.d.ts +124 -0
  599. package/dist/transfer/capsule-import.js +16 -0
  600. package/dist/transfer/capsule-import.js.map +1 -0
  601. package/dist/transfer/constants.d.ts +13 -0
  602. package/dist/transfer/constants.js +12 -0
  603. package/dist/transfer/constants.js.map +1 -0
  604. package/dist/transfer/export-json.d.ts +11 -0
  605. package/dist/transfer/export-json.js +11 -0
  606. package/dist/transfer/export-json.js.map +1 -0
  607. package/dist/transfer/export-md.d.ts +10 -0
  608. package/dist/transfer/export-md.js +13 -0
  609. package/dist/transfer/export-md.js.map +1 -0
  610. package/dist/transfer/export-sqlite.d.ts +9 -0
  611. package/dist/transfer/export-sqlite.js +12 -0
  612. package/dist/transfer/export-sqlite.js.map +1 -0
  613. package/dist/transfer/fs-utils.d.ts +61 -0
  614. package/dist/transfer/fs-utils.js +40 -0
  615. package/dist/transfer/fs-utils.js.map +1 -0
  616. package/dist/transfer/import-json.d.ts +16 -0
  617. package/dist/transfer/import-json.js +13 -0
  618. package/dist/transfer/import-json.js.map +1 -0
  619. package/dist/transfer/import-md.d.ts +14 -0
  620. package/dist/transfer/import-md.js +11 -0
  621. package/dist/transfer/import-md.js.map +1 -0
  622. package/dist/transfer/import-sqlite.d.ts +14 -0
  623. package/dist/transfer/import-sqlite.js +12 -0
  624. package/dist/transfer/import-sqlite.js.map +1 -0
  625. package/dist/transfer/sqlite-schema.d.ts +4 -0
  626. package/dist/transfer/sqlite-schema.js +10 -0
  627. package/dist/transfer/sqlite-schema.js.map +1 -0
  628. package/dist/transfer/types.d.ts +916 -0
  629. package/dist/transfer/types.js +30 -0
  630. package/dist/transfer/types.js.map +1 -0
  631. package/dist/types.d.ts +28 -1
  632. package/dist/types.js +1 -1
  633. package/dist/verified-recall.js +9 -6
  634. package/dist/work/board.d.ts +43 -0
  635. package/dist/work/board.js +14 -0
  636. package/dist/work/board.js.map +1 -0
  637. package/dist/work/boundary.d.ts +8 -0
  638. package/dist/work/boundary.js +14 -0
  639. package/dist/work/boundary.js.map +1 -0
  640. package/dist/work/storage.d.ts +39 -0
  641. package/dist/work/storage.js +11 -0
  642. package/dist/work/storage.js.map +1 -0
  643. package/dist/work/types.d.ts +75 -0
  644. package/dist/work/types.js +1 -0
  645. package/dist/work/types.js.map +1 -0
  646. package/package.json +2767 -6
  647. package/scripts/faiss_index.py +816 -0
  648. package/scripts/faiss_requirements.txt +3 -0
  649. package/skills/remnic-entities/SKILL.md +51 -0
  650. package/skills/remnic-memory-workflow/SKILL.md +61 -0
  651. package/skills/remnic-recall/SKILL.md +51 -0
  652. package/skills/remnic-remember/SKILL.md +56 -0
  653. package/skills/remnic-search/SKILL.md +51 -0
  654. package/skills/remnic-status/SKILL.md +51 -0
  655. package/src/abort-error.test.ts +49 -0
  656. package/src/abort-error.ts +46 -0
  657. package/src/abstraction-nodes.ts +162 -0
  658. package/src/access-audit.test.ts +178 -0
  659. package/src/access-audit.ts +125 -0
  660. package/src/access-cli.test.ts +439 -0
  661. package/src/access-cli.ts +438 -0
  662. package/src/access-http.test.ts +225 -0
  663. package/src/access-http.ts +1899 -0
  664. package/src/access-idempotency.ts +232 -0
  665. package/src/access-mcp.test.ts +568 -0
  666. package/src/access-mcp.ts +3056 -0
  667. package/src/access-schema-pi.test.ts +60 -0
  668. package/src/access-schema.ts +522 -0
  669. package/src/access-service-namespace.test.ts +123 -0
  670. package/src/access-service.ts +5629 -0
  671. package/src/action-confidence.test.ts +206 -0
  672. package/src/action-confidence.ts +466 -0
  673. package/src/active-memory-bridge.test.ts +285 -0
  674. package/src/active-memory-bridge.ts +217 -0
  675. package/src/active-recall.test.ts +484 -0
  676. package/src/active-recall.ts +459 -0
  677. package/src/adapters/claude-code.ts +56 -0
  678. package/src/adapters/codex.ts +57 -0
  679. package/src/adapters/hermes.ts +64 -0
  680. package/src/adapters/index.ts +6 -0
  681. package/src/adapters/registry.ts +41 -0
  682. package/src/adapters/replit.ts +55 -0
  683. package/src/adapters/types.ts +51 -0
  684. package/src/behavior-learner.ts +144 -0
  685. package/src/behavior-signals.ts +73 -0
  686. package/src/binary-lifecycle/backend.ts +117 -0
  687. package/src/binary-lifecycle/index.ts +35 -0
  688. package/src/binary-lifecycle/manifest.ts +79 -0
  689. package/src/binary-lifecycle/pipeline.ts +352 -0
  690. package/src/binary-lifecycle/scanner.ts +89 -0
  691. package/src/binary-lifecycle/types.ts +89 -0
  692. package/src/bootstrap.ts +178 -0
  693. package/src/boxes.ts +521 -0
  694. package/src/briefing.test.ts +1535 -0
  695. package/src/briefing.ts +1382 -0
  696. package/src/buffer-session.test.ts +443 -0
  697. package/src/buffer-surprise-report.ts +176 -0
  698. package/src/buffer-surprise-telemetry.test.ts +606 -0
  699. package/src/buffer-surprise-trigger.test.ts +766 -0
  700. package/src/buffer-surprise.test.ts +339 -0
  701. package/src/buffer-surprise.ts +203 -0
  702. package/src/buffer.ts +900 -0
  703. package/src/bulk-import/cli-command.test.ts +204 -0
  704. package/src/bulk-import/index.ts +34 -0
  705. package/src/bulk-import/pipeline.test.ts +445 -0
  706. package/src/bulk-import/pipeline.ts +178 -0
  707. package/src/bulk-import/registry.test.ts +151 -0
  708. package/src/bulk-import/registry.ts +72 -0
  709. package/src/bulk-import/types.test.ts +272 -0
  710. package/src/bulk-import/types.ts +145 -0
  711. package/src/calibration.ts +394 -0
  712. package/src/capsule-cli.test.ts +398 -0
  713. package/src/capsule-cli.ts +565 -0
  714. package/src/causal-behavior.ts +308 -0
  715. package/src/causal-chain.ts +419 -0
  716. package/src/causal-consolidation.ts +370 -0
  717. package/src/causal-retrieval.ts +286 -0
  718. package/src/causal-trajectory-graph.ts +60 -0
  719. package/src/causal-trajectory.ts +303 -0
  720. package/src/chunking.ts +220 -0
  721. package/src/citations.ts +232 -0
  722. package/src/cli.ts +9403 -0
  723. package/src/codex-cli-fallback.ts +162 -0
  724. package/src/codex-thread-key.ts +1 -0
  725. package/src/coding/access-coding-context.test.ts +197 -0
  726. package/src/coding/coding-branch-scope.test.ts +281 -0
  727. package/src/coding/coding-namespace.test.ts +360 -0
  728. package/src/coding/coding-namespace.ts +412 -0
  729. package/src/coding/coding-orchestrator.test.ts +249 -0
  730. package/src/coding/git-context.test.ts +507 -0
  731. package/src/coding/git-context.ts +336 -0
  732. package/src/coding/mcp-set-coding-context.test.ts +174 -0
  733. package/src/coding/review-context.test.ts +316 -0
  734. package/src/coding/review-context.ts +349 -0
  735. package/src/coding/wire-coding-context.test.ts +468 -0
  736. package/src/commitment-ledger.test.ts +78 -0
  737. package/src/commitment-ledger.ts +337 -0
  738. package/src/compat/checks.test.ts +206 -0
  739. package/src/compat/checks.ts +716 -0
  740. package/src/compat/types.ts +33 -0
  741. package/src/compounding/engine.ts +1686 -0
  742. package/src/compounding/preference-consolidator.ts +778 -0
  743. package/src/compression-optimizer.ts +312 -0
  744. package/src/config.test.ts +930 -0
  745. package/src/config.ts +3807 -0
  746. package/src/connectors/codex/instructions.md +160 -0
  747. package/src/connectors/codex/resources/namespace-cheatsheet.md +48 -0
  748. package/src/connectors/codex-marketplace.ts +500 -0
  749. package/src/connectors/codex-materialize-runner.ts +212 -0
  750. package/src/connectors/codex-materialize.ts +983 -0
  751. package/src/connectors/coerce.ts +62 -0
  752. package/src/connectors/index.test.ts +1570 -0
  753. package/src/connectors/index.ts +3222 -0
  754. package/src/connectors/live/framework.ts +164 -0
  755. package/src/connectors/live/github.test.ts +1218 -0
  756. package/src/connectors/live/github.ts +1068 -0
  757. package/src/connectors/live/gmail.test.ts +1706 -0
  758. package/src/connectors/live/gmail.ts +1293 -0
  759. package/src/connectors/live/google-drive.test.ts +696 -0
  760. package/src/connectors/live/google-drive.ts +724 -0
  761. package/src/connectors/live/index.ts +101 -0
  762. package/src/connectors/live/live-connectors.test.ts +689 -0
  763. package/src/connectors/live/notion.test.ts +1109 -0
  764. package/src/connectors/live/notion.ts +978 -0
  765. package/src/connectors/live/registry.ts +103 -0
  766. package/src/connectors/live/state-store.ts +399 -0
  767. package/src/connectors/live/transient-errors.ts +150 -0
  768. package/src/connectors/weclone-installer.test.ts +850 -0
  769. package/src/connectors-cli.ts +513 -0
  770. package/src/console/state.test.ts +224 -0
  771. package/src/console/state.ts +514 -0
  772. package/src/console/trace.test.ts +813 -0
  773. package/src/console/trace.ts +603 -0
  774. package/src/console/tui.test.ts +582 -0
  775. package/src/console/tui.ts +508 -0
  776. package/src/consolidation-operator.ts +182 -0
  777. package/src/consolidation-provenance-check.ts +551 -0
  778. package/src/consolidation-undo.ts +718 -0
  779. package/src/contradiction/contradiction-judge.test.ts +189 -0
  780. package/src/contradiction/contradiction-judge.ts +333 -0
  781. package/src/contradiction/contradiction-review.ts +574 -0
  782. package/src/contradiction/contradiction-scan.ts +504 -0
  783. package/src/contradiction/contradiction.test.ts +2230 -0
  784. package/src/contradiction/index.ts +37 -0
  785. package/src/contradiction/resolution.ts +383 -0
  786. package/src/conversation-index/backend.ts +323 -0
  787. package/src/conversation-index/chunker.ts +47 -0
  788. package/src/conversation-index/cleanup.ts +53 -0
  789. package/src/conversation-index/faiss-adapter.ts +384 -0
  790. package/src/conversation-index/indexer.test.ts +164 -0
  791. package/src/conversation-index/indexer.ts +192 -0
  792. package/src/conversation-index/search.ts +37 -0
  793. package/src/cross-namespace-budget.test.ts +275 -0
  794. package/src/cross-namespace-budget.ts +365 -0
  795. package/src/cue-anchors.ts +163 -0
  796. package/src/curation/index.ts +544 -0
  797. package/src/dashboard-runtime.ts +337 -0
  798. package/src/day-summary.ts +122 -0
  799. package/src/dedup/index.ts +330 -0
  800. package/src/dedup/semantic.test.ts +1577 -0
  801. package/src/dedup/semantic.ts +148 -0
  802. package/src/delinearize.ts +193 -0
  803. package/src/direct-answer-wiring.test.ts +473 -0
  804. package/src/direct-answer-wiring.ts +180 -0
  805. package/src/direct-answer.test.ts +484 -0
  806. package/src/direct-answer.ts +273 -0
  807. package/src/embedding-fallback.ts +565 -0
  808. package/src/enrichment/audit.ts +89 -0
  809. package/src/enrichment/index.ts +27 -0
  810. package/src/enrichment/pipeline.ts +197 -0
  811. package/src/enrichment/provider-registry.ts +85 -0
  812. package/src/enrichment/types.ts +100 -0
  813. package/src/enrichment/web-search-provider.ts +63 -0
  814. package/src/entity-retrieval.ts +774 -0
  815. package/src/entity-schema.ts +239 -0
  816. package/src/evals.ts +1312 -0
  817. package/src/event-order-recall.test.ts +4164 -0
  818. package/src/event-order-recall.ts +2802 -0
  819. package/src/evidence-pack.test.ts +89 -0
  820. package/src/evidence-pack.ts +388 -0
  821. package/src/explicit-capture.ts +530 -0
  822. package/src/explicit-cue-recall.test.ts +3019 -0
  823. package/src/explicit-cue-recall.ts +5545 -0
  824. package/src/extraction-judge-telemetry.ts +234 -0
  825. package/src/extraction-judge-training.ts +221 -0
  826. package/src/extraction-judge.ts +846 -0
  827. package/src/extraction-timeout.test.ts +265 -0
  828. package/src/extraction.ts +2719 -0
  829. package/src/fallback-llm.test.ts +1060 -0
  830. package/src/fallback-llm.ts +918 -0
  831. package/src/focused-list-recall.test.ts +734 -0
  832. package/src/focused-list-recall.ts +1160 -0
  833. package/src/graph-dashboard-diff.ts +35 -0
  834. package/src/graph-dashboard-key.ts +5 -0
  835. package/src/graph-dashboard-parser.ts +104 -0
  836. package/src/graph-edge-reinforcement.ts +192 -0
  837. package/src/graph-events.ts +151 -0
  838. package/src/graph-recall.test.ts +164 -0
  839. package/src/graph-recall.ts +189 -0
  840. package/src/graph-retrieval.test.ts +809 -0
  841. package/src/graph-retrieval.ts +823 -0
  842. package/src/graph-snapshot.ts +329 -0
  843. package/src/graph.ts +813 -0
  844. package/src/harmonic-retrieval.ts +223 -0
  845. package/src/himem.ts +154 -0
  846. package/src/hygiene.ts +87 -0
  847. package/src/identity-continuity.ts +333 -0
  848. package/src/importance.ts +328 -0
  849. package/src/importers/base.test.ts +294 -0
  850. package/src/importers/base.ts +436 -0
  851. package/src/importers/index.ts +21 -0
  852. package/src/index.ts +1204 -0
  853. package/src/intent.ts +154 -0
  854. package/src/json-extract.ts +85 -0
  855. package/src/json-store.ts +42 -0
  856. package/src/lcm/archive.ts +617 -0
  857. package/src/lcm/dag.ts +199 -0
  858. package/src/lcm/engine.ts +645 -0
  859. package/src/lcm/index.ts +7 -0
  860. package/src/lcm/queue.test.ts +178 -0
  861. package/src/lcm/queue.ts +200 -0
  862. package/src/lcm/recall.ts +117 -0
  863. package/src/lcm/schema.ts +154 -0
  864. package/src/lcm/summarizer.ts +235 -0
  865. package/src/lcm/tools.ts +191 -0
  866. package/src/lcm-engine.test.ts +660 -0
  867. package/src/legacy-hook-compat.test.ts +20 -0
  868. package/src/legacy-hook-compat.ts +45 -0
  869. package/src/lifecycle.ts +289 -0
  870. package/src/live-connectors-runner.ts +385 -0
  871. package/src/local-llm-qos.test.ts +303 -0
  872. package/src/local-llm-thinking.test.ts +292 -0
  873. package/src/local-llm.ts +1464 -0
  874. package/src/logger.ts +49 -0
  875. package/src/maintenance/archive-observations.ts +147 -0
  876. package/src/maintenance/backup-stamp.ts +3 -0
  877. package/src/maintenance/dreams-ledger.ts +516 -0
  878. package/src/maintenance/first-start-migration.ts +362 -0
  879. package/src/maintenance/forget.test.ts +206 -0
  880. package/src/maintenance/forget.ts +126 -0
  881. package/src/maintenance/graph-edge-decay.test.ts +409 -0
  882. package/src/maintenance/graph-edge-decay.ts +394 -0
  883. package/src/maintenance/memory-governance-cron.ts +447 -0
  884. package/src/maintenance/memory-governance.ts +1039 -0
  885. package/src/maintenance/migrate-observations.ts +216 -0
  886. package/src/maintenance/observation-ledger-utils.ts +54 -0
  887. package/src/maintenance/pattern-reinforcement.test.ts +875 -0
  888. package/src/maintenance/pattern-reinforcement.ts +369 -0
  889. package/src/maintenance/purge.ts +334 -0
  890. package/src/maintenance/rebuild-memory-lifecycle-ledger.ts +78 -0
  891. package/src/maintenance/rebuild-memory-projection.ts +1234 -0
  892. package/src/maintenance/rebuild-observations.ts +178 -0
  893. package/src/maintenance/tier-stats.test.ts +378 -0
  894. package/src/maintenance/tier-stats.ts +222 -0
  895. package/src/mcp-memory-inspector-app.ts +421 -0
  896. package/src/memory-action-policy.ts +80 -0
  897. package/src/memory-cache.ts +208 -0
  898. package/src/memory-extension/claude-code-publisher.ts +51 -0
  899. package/src/memory-extension/codex-publisher.ts +149 -0
  900. package/src/memory-extension/hermes-publisher.ts +51 -0
  901. package/src/memory-extension/index.ts +100 -0
  902. package/src/memory-extension/shared-instructions.ts +133 -0
  903. package/src/memory-extension/types.ts +86 -0
  904. package/src/memory-extension-host/host-discovery.ts +276 -0
  905. package/src/memory-extension-host/index.ts +14 -0
  906. package/src/memory-extension-host/render-extensions-block.ts +73 -0
  907. package/src/memory-extension-host/types.ts +21 -0
  908. package/src/memory-lifecycle-ledger-utils.ts +116 -0
  909. package/src/memory-projection-format.ts +11 -0
  910. package/src/memory-projection-store.ts +951 -0
  911. package/src/memory-provenance.test.ts +196 -0
  912. package/src/memory-provenance.ts +484 -0
  913. package/src/memory-worth-bench.test.ts +71 -0
  914. package/src/memory-worth-bench.ts +265 -0
  915. package/src/memory-worth-filter.test.ts +209 -0
  916. package/src/memory-worth-filter.ts +204 -0
  917. package/src/memory-worth-frontmatter.test.ts +311 -0
  918. package/src/memory-worth-outcomes.test.ts +316 -0
  919. package/src/memory-worth-outcomes.ts +286 -0
  920. package/src/memory-worth.test.ts +317 -0
  921. package/src/memory-worth.ts +215 -0
  922. package/src/message-parts/index.ts +806 -0
  923. package/src/message-parts/message-parts.test.ts +421 -0
  924. package/src/migrate/from-engram.ts +789 -0
  925. package/src/model-registry.ts +313 -0
  926. package/src/models-json.ts +76 -0
  927. package/src/namespaces/migrate.ts +187 -0
  928. package/src/namespaces/path.ts +25 -0
  929. package/src/namespaces/principal.test.ts +195 -0
  930. package/src/namespaces/principal.ts +86 -0
  931. package/src/namespaces/search.test.ts +105 -0
  932. package/src/namespaces/search.ts +233 -0
  933. package/src/namespaces/storage.ts +74 -0
  934. package/src/native-knowledge.ts +1823 -0
  935. package/src/negative.ts +72 -0
  936. package/src/network/tailscale.ts +179 -0
  937. package/src/network/webdav.ts +385 -0
  938. package/src/objective-state-writers.ts +951 -0
  939. package/src/objective-state.ts +320 -0
  940. package/src/onboarding/index.ts +529 -0
  941. package/src/openai-chat-compat.ts +56 -0
  942. package/src/operator-toolkit.ts +2132 -0
  943. package/src/opik-exporter.test.ts +72 -0
  944. package/src/opik-exporter.ts +587 -0
  945. package/src/orchestrator-extraction-queue.test.ts +197 -0
  946. package/src/orchestrator-flush.test.ts +1171 -0
  947. package/src/orchestrator-pattern-reinforcement.test.ts +128 -0
  948. package/src/orchestrator-source-attribution.test.ts +701 -0
  949. package/src/orchestrator.ts +16368 -0
  950. package/src/page-versioning.ts +450 -0
  951. package/src/patterns-cli.ts +574 -0
  952. package/src/peers/index.ts +54 -0
  953. package/src/peers/migrate-from-identity-anchor.test.ts +291 -0
  954. package/src/peers/migrate-from-identity-anchor.ts +350 -0
  955. package/src/peers/peers.test.ts +419 -0
  956. package/src/peers/profile-reasoner.ts +694 -0
  957. package/src/peers/storage.ts +1350 -0
  958. package/src/peers/types.ts +138 -0
  959. package/src/plugin-id.ts +84 -0
  960. package/src/policy-runtime.ts +209 -0
  961. package/src/procedural/procedure-miner.ts +150 -0
  962. package/src/procedural/procedure-recall.ts +93 -0
  963. package/src/procedural/procedure-stats.ts +213 -0
  964. package/src/procedural/procedure-types.ts +132 -0
  965. package/src/procedural/reinforcement-core.test.ts +132 -0
  966. package/src/procedural/reinforcement-core.ts +73 -0
  967. package/src/profiling.test.ts +263 -0
  968. package/src/profiling.ts +435 -0
  969. package/src/projection/index.ts +398 -0
  970. package/src/qmd-recall-cache.test.ts +138 -0
  971. package/src/qmd-recall-cache.ts +111 -0
  972. package/src/qmd.test.ts +258 -0
  973. package/src/qmd.ts +2614 -0
  974. package/src/reasoning-trace-recall.ts +201 -0
  975. package/src/reasoning-trace-types.ts +235 -0
  976. package/src/recall-audit-anomaly.test.ts +246 -0
  977. package/src/recall-audit-anomaly.ts +297 -0
  978. package/src/recall-audit.test.ts +51 -0
  979. package/src/recall-audit.ts +72 -0
  980. package/src/recall-budget-config.test.ts +87 -0
  981. package/src/recall-disclosure-escalation.test.ts +196 -0
  982. package/src/recall-disclosure-escalation.ts +158 -0
  983. package/src/recall-disclosure-shaping.test.ts +146 -0
  984. package/src/recall-disclosure.test.ts +214 -0
  985. package/src/recall-explain-renderer.test.ts +140 -0
  986. package/src/recall-explain-renderer.ts +356 -0
  987. package/src/recall-mmr.test.ts +808 -0
  988. package/src/recall-mmr.ts +607 -0
  989. package/src/recall-qos.test.ts +85 -0
  990. package/src/recall-qos.ts +82 -0
  991. package/src/recall-query-policy.ts +221 -0
  992. package/src/recall-state.test.ts +233 -0
  993. package/src/recall-state.ts +456 -0
  994. package/src/recall-tag-filter.ts +143 -0
  995. package/src/recall-tokenization.ts +35 -0
  996. package/src/recall-xray-cli.test.ts +118 -0
  997. package/src/recall-xray-cli.ts +100 -0
  998. package/src/recall-xray-disclosure-telemetry.test.ts +183 -0
  999. package/src/recall-xray-renderer.test.ts +539 -0
  1000. package/src/recall-xray-renderer.ts +487 -0
  1001. package/src/recall-xray.test.ts +503 -0
  1002. package/src/recall-xray.ts +621 -0
  1003. package/src/reconstruct.ts +41 -0
  1004. package/src/release-changelog.ts +35 -0
  1005. package/src/relevance.ts +67 -0
  1006. package/src/replay/normalizers/chatgpt.ts +133 -0
  1007. package/src/replay/normalizers/claude.ts +102 -0
  1008. package/src/replay/normalizers/openclaw.ts +119 -0
  1009. package/src/replay/normalizers/shared.ts +69 -0
  1010. package/src/replay/runner.ts +197 -0
  1011. package/src/replay/types.ts +143 -0
  1012. package/src/rerank.test.ts +48 -0
  1013. package/src/rerank.ts +176 -0
  1014. package/src/resolve-auth-token.test.ts +226 -0
  1015. package/src/resolve-auth-token.ts +151 -0
  1016. package/src/resolve-provider-secret.test.ts +187 -0
  1017. package/src/resolve-provider-secret.ts +410 -0
  1018. package/src/response-guidance-recall.test.ts +3952 -0
  1019. package/src/response-guidance-recall.ts +4431 -0
  1020. package/src/resume-bundles.ts +415 -0
  1021. package/src/retrieval-agents.ts +623 -0
  1022. package/src/retrieval-tiers.ts +25 -0
  1023. package/src/retrieval.ts +104 -0
  1024. package/src/review/index.test.ts +201 -0
  1025. package/src/review/index.ts +536 -0
  1026. package/src/routing/engine.ts +162 -0
  1027. package/src/routing/store.ts +321 -0
  1028. package/src/runtime/better-sqlite.test.ts +32 -0
  1029. package/src/runtime/better-sqlite.ts +76 -0
  1030. package/src/runtime/child-process.ts +67 -0
  1031. package/src/runtime/env.ts +48 -0
  1032. package/src/sanitize.ts +58 -0
  1033. package/src/schemas.ts +449 -0
  1034. package/src/sdk-compat.ts +87 -0
  1035. package/src/search/document-scanner.ts +96 -0
  1036. package/src/search/embed-helper.ts +142 -0
  1037. package/src/search/factory.ts +189 -0
  1038. package/src/search/index.ts +10 -0
  1039. package/src/search/lancedb-backend.ts +342 -0
  1040. package/src/search/meilisearch-backend.ts +232 -0
  1041. package/src/search/noop-backend.ts +57 -0
  1042. package/src/search/orama-backend.ts +358 -0
  1043. package/src/search/port.ts +86 -0
  1044. package/src/search/remote-backend.ts +124 -0
  1045. package/src/secure-store/cipher.ts +271 -0
  1046. package/src/secure-store/cli-handlers.ts +355 -0
  1047. package/src/secure-store/cli-renderer.ts +131 -0
  1048. package/src/secure-store/header.ts +373 -0
  1049. package/src/secure-store/index.ts +137 -0
  1050. package/src/secure-store/kdf.ts +263 -0
  1051. package/src/secure-store/keyring.ts +106 -0
  1052. package/src/secure-store/metadata.ts +394 -0
  1053. package/src/secure-store/passphrase-reader.ts +252 -0
  1054. package/src/secure-store/secure-fs.ts +571 -0
  1055. package/src/secure-store/secure-store.test.ts +755 -0
  1056. package/src/semantic-chunking.ts +545 -0
  1057. package/src/semantic-consolidation.test.ts +182 -0
  1058. package/src/semantic-consolidation.ts +432 -0
  1059. package/src/semantic-rule-promotion.ts +183 -0
  1060. package/src/semantic-rule-verifier.ts +160 -0
  1061. package/src/session-integrity.ts +569 -0
  1062. package/src/session-observer-bands.ts +11 -0
  1063. package/src/session-observer-state.ts +346 -0
  1064. package/src/session-toggles.test.ts +96 -0
  1065. package/src/session-toggles.ts +159 -0
  1066. package/src/shared-context/manager.ts +810 -0
  1067. package/src/signal.ts +84 -0
  1068. package/src/skills-registry.test.ts +277 -0
  1069. package/src/skills-registry.ts +120 -0
  1070. package/src/source-attribution-roundtrip.test.ts +215 -0
  1071. package/src/source-attribution.test.ts +1425 -0
  1072. package/src/source-attribution.ts +639 -0
  1073. package/src/spaces/index.ts +627 -0
  1074. package/src/storage-paths.ts +117 -0
  1075. package/src/storage.ts +6657 -0
  1076. package/src/store-contract.ts +55 -0
  1077. package/src/summarizer.ts +844 -0
  1078. package/src/summary-snapshot.test.ts +681 -0
  1079. package/src/summary-snapshot.ts +238 -0
  1080. package/src/surfaces/dreams.test.ts +394 -0
  1081. package/src/surfaces/dreams.ts +346 -0
  1082. package/src/surfaces/heartbeat.test.ts +415 -0
  1083. package/src/surfaces/heartbeat.ts +325 -0
  1084. package/src/sync/index.ts +308 -0
  1085. package/src/targeted-fact-recall.test.ts +1694 -0
  1086. package/src/targeted-fact-recall.ts +2905 -0
  1087. package/src/taxonomy/default-taxonomy.ts +87 -0
  1088. package/src/taxonomy/index.ts +26 -0
  1089. package/src/taxonomy/resolver-doc-generator.ts +57 -0
  1090. package/src/taxonomy/resolver.ts +184 -0
  1091. package/src/taxonomy/taxonomy-loader.ts +186 -0
  1092. package/src/taxonomy/types.ts +48 -0
  1093. package/src/telemetry-transcript.ts +70 -0
  1094. package/src/temporal-index.ts +890 -0
  1095. package/src/temporal-supersession.test.ts +2703 -0
  1096. package/src/temporal-supersession.ts +493 -0
  1097. package/src/temporal-validity.test.ts +448 -0
  1098. package/src/temporal-validity.ts +123 -0
  1099. package/src/threading.ts +395 -0
  1100. package/src/tier-migration.ts +124 -0
  1101. package/src/tier-routing.ts +102 -0
  1102. package/src/tmt.ts +462 -0
  1103. package/src/tokens.test.ts +178 -0
  1104. package/src/tokens.ts +279 -0
  1105. package/src/topics.ts +147 -0
  1106. package/src/training-export/cli-date-validation.test.ts +258 -0
  1107. package/src/training-export/converter.test.ts +452 -0
  1108. package/src/training-export/converter.ts +319 -0
  1109. package/src/training-export/date-parse.ts +117 -0
  1110. package/src/training-export/index.ts +26 -0
  1111. package/src/training-export/registry.test.ts +85 -0
  1112. package/src/training-export/registry.ts +57 -0
  1113. package/src/training-export/types.ts +31 -0
  1114. package/src/transcript.ts +1179 -0
  1115. package/src/transfer/autodetect.ts +30 -0
  1116. package/src/transfer/backup.ts +138 -0
  1117. package/src/transfer/capsule-crypto.ts +485 -0
  1118. package/src/transfer/capsule-encrypt.test.ts +690 -0
  1119. package/src/transfer/capsule-export.ts +543 -0
  1120. package/src/transfer/capsule-fork.ts +375 -0
  1121. package/src/transfer/capsule-import.ts +564 -0
  1122. package/src/transfer/capsule-merge.ts +433 -0
  1123. package/src/transfer/conflict-policy.ts +16 -0
  1124. package/src/transfer/constants.ts +13 -0
  1125. package/src/transfer/exclusions.ts +37 -0
  1126. package/src/transfer/export-json.ts +65 -0
  1127. package/src/transfer/export-md.ts +59 -0
  1128. package/src/transfer/export-sqlite.ts +52 -0
  1129. package/src/transfer/fs-utils.ts +269 -0
  1130. package/src/transfer/import-json.ts +108 -0
  1131. package/src/transfer/import-md.ts +84 -0
  1132. package/src/transfer/import-sqlite.ts +100 -0
  1133. package/src/transfer/integrity.ts +71 -0
  1134. package/src/transfer/sqlite-schema.ts +16 -0
  1135. package/src/transfer/types.ts +297 -0
  1136. package/src/trust-zones.ts +1186 -0
  1137. package/src/types.ts +3074 -0
  1138. package/src/user-model.test.ts +124 -0
  1139. package/src/user-model.ts +162 -0
  1140. package/src/utility-learner.ts +353 -0
  1141. package/src/utility-runtime.ts +88 -0
  1142. package/src/utility-telemetry.ts +215 -0
  1143. package/src/utils/category-dir.ts +44 -0
  1144. package/src/utils/errno.ts +6 -0
  1145. package/src/utils/iso-timestamp.test.ts +37 -0
  1146. package/src/utils/iso-timestamp.ts +164 -0
  1147. package/src/utils/path.ts +26 -0
  1148. package/src/verified-recall.ts +138 -0
  1149. package/src/version-utils.test.ts +10 -0
  1150. package/src/version-utils.ts +9 -0
  1151. package/src/whitespace.ts +10 -0
  1152. package/src/work/board.ts +359 -0
  1153. package/src/work/boundary.ts +107 -0
  1154. package/src/work/storage.ts +436 -0
  1155. package/src/work/types.ts +82 -0
  1156. package/src/work-product-ledger.ts +265 -0
  1157. package/dist/access-service-DDjzFALq.d.ts +0 -2088
  1158. package/dist/capsule-crypto-SJS5VVAP.js +0 -18
  1159. package/dist/capsule-export-7QNCBZOQ.js +0 -17
  1160. package/dist/capsule-import-EPBHD2EN.js +0 -16
  1161. package/dist/capsule-merge-DI7PNQ2H.js +0 -189
  1162. package/dist/chunk-23ZZK64Y.js +0 -26
  1163. package/dist/chunk-23ZZK64Y.js.map +0 -1
  1164. package/dist/chunk-242S3I2A.js +0 -647
  1165. package/dist/chunk-2LGMW3DJ.js +0 -111
  1166. package/dist/chunk-3B6KIRBH.js +0 -5213
  1167. package/dist/chunk-3B6KIRBH.js.map +0 -1
  1168. package/dist/chunk-457A4P3L.js +0 -119
  1169. package/dist/chunk-457A4P3L.js.map +0 -1
  1170. package/dist/chunk-4IS4SXIQ.js +0 -2040
  1171. package/dist/chunk-4YM32CRU.js +0 -721
  1172. package/dist/chunk-6TBWYBJ3.js +0 -236
  1173. package/dist/chunk-74EMIVE4.js +0 -329
  1174. package/dist/chunk-74EMIVE4.js.map +0 -1
  1175. package/dist/chunk-767ODGE6.js +0 -183
  1176. package/dist/chunk-7V22HTMD.js +0 -623
  1177. package/dist/chunk-7V22HTMD.js.map +0 -1
  1178. package/dist/chunk-7ZM3BFKK.js +0 -9705
  1179. package/dist/chunk-7ZM3BFKK.js.map +0 -1
  1180. package/dist/chunk-AQJNPMOA.js +0 -643
  1181. package/dist/chunk-AQJNPMOA.js.map +0 -1
  1182. package/dist/chunk-ASAITVLA.js +0 -64
  1183. package/dist/chunk-ASAITVLA.js.map +0 -1
  1184. package/dist/chunk-BBE34QBJ.js +0 -275
  1185. package/dist/chunk-BBE34QBJ.js.map +0 -1
  1186. package/dist/chunk-BZSQEPRW.js +0 -14710
  1187. package/dist/chunk-BZSQEPRW.js.map +0 -1
  1188. package/dist/chunk-CPKTBRS2.js +0 -891
  1189. package/dist/chunk-CPKTBRS2.js.map +0 -1
  1190. package/dist/chunk-D4GAOFF6.js +0 -562
  1191. package/dist/chunk-D4GAOFF6.js.map +0 -1
  1192. package/dist/chunk-D54LZC5L.js +0 -147
  1193. package/dist/chunk-DF3RVK3X.js +0 -119
  1194. package/dist/chunk-DF3RVK3X.js.map +0 -1
  1195. package/dist/chunk-DZZPC36E.js +0 -1451
  1196. package/dist/chunk-DZZPC36E.js.map +0 -1
  1197. package/dist/chunk-E2UCDP5S.js +0 -570
  1198. package/dist/chunk-E6K4NIEU.js +0 -747
  1199. package/dist/chunk-E6K4NIEU.js.map +0 -1
  1200. package/dist/chunk-EEQLFRUM.js +0 -89
  1201. package/dist/chunk-ETOW6ACV.js +0 -158
  1202. package/dist/chunk-ETOW6ACV.js.map +0 -1
  1203. package/dist/chunk-FMEBPEAO.js +0 -347
  1204. package/dist/chunk-FMEBPEAO.js.map +0 -1
  1205. package/dist/chunk-FQDPCE3I.js +0 -1837
  1206. package/dist/chunk-FQDPCE3I.js.map +0 -1
  1207. package/dist/chunk-FYIYMQ5N.js +0 -221
  1208. package/dist/chunk-FYIYMQ5N.js.map +0 -1
  1209. package/dist/chunk-G2WADRQ3.js +0 -219
  1210. package/dist/chunk-G4SK7DSQ.js +0 -121
  1211. package/dist/chunk-GVPWB7EY.js +0 -390
  1212. package/dist/chunk-GVPWB7EY.js.map +0 -1
  1213. package/dist/chunk-HELQZFZO.js +0 -1075
  1214. package/dist/chunk-HL5LRPNA.js +0 -1914
  1215. package/dist/chunk-HL5LRPNA.js.map +0 -1
  1216. package/dist/chunk-HQZVVSVB.js +0 -147
  1217. package/dist/chunk-HQZVVSVB.js.map +0 -1
  1218. package/dist/chunk-HY3L4WKC.js +0 -2195
  1219. package/dist/chunk-HY3L4WKC.js.map +0 -1
  1220. package/dist/chunk-IB3BFHGN.js +0 -228
  1221. package/dist/chunk-IXEJRKCZ.js +0 -18
  1222. package/dist/chunk-JBMSGZEQ.js +0 -441
  1223. package/dist/chunk-JBMSGZEQ.js.map +0 -1
  1224. package/dist/chunk-JESOB2HO.js +0 -108
  1225. package/dist/chunk-JKDVIE52.js +0 -272
  1226. package/dist/chunk-JRNQ3RNA.js +0 -284
  1227. package/dist/chunk-JRNQ3RNA.js.map +0 -1
  1228. package/dist/chunk-K6WK37A6.js +0 -865
  1229. package/dist/chunk-K6WK37A6.js.map +0 -1
  1230. package/dist/chunk-MARWOCVP.js +0 -48
  1231. package/dist/chunk-MNU6ZBWT.js +0 -4454
  1232. package/dist/chunk-MNU6ZBWT.js.map +0 -1
  1233. package/dist/chunk-N5AKDXAI.js +0 -74
  1234. package/dist/chunk-OA3L7BFR.js +0 -183
  1235. package/dist/chunk-OA3L7BFR.js.map +0 -1
  1236. package/dist/chunk-OR64ZGRZ.js +0 -23
  1237. package/dist/chunk-P77UEOU2.js +0 -1521
  1238. package/dist/chunk-P77UEOU2.js.map +0 -1
  1239. package/dist/chunk-PH4C2U43.js +0 -239
  1240. package/dist/chunk-PH4C2U43.js.map +0 -1
  1241. package/dist/chunk-RVPLBATS.js +0 -1586
  1242. package/dist/chunk-RVPLBATS.js.map +0 -1
  1243. package/dist/chunk-U5JMRGKX.js +0 -340
  1244. package/dist/chunk-U5JMRGKX.js.map +0 -1
  1245. package/dist/chunk-URB2WSKZ.js +0 -350
  1246. package/dist/chunk-URB2WSKZ.js.map +0 -1
  1247. package/dist/chunk-UVMUAWVT.js +0 -596
  1248. package/dist/chunk-WEJG4TB5.js +0 -118
  1249. package/dist/chunk-X7HPGUVG.js +0 -271
  1250. package/dist/chunk-XAMBKFQS.js +0 -2777
  1251. package/dist/chunk-XAMBKFQS.js.map +0 -1
  1252. package/dist/chunk-XJKFSSDW.js +0 -726
  1253. package/dist/chunk-XJKFSSDW.js.map +0 -1
  1254. package/dist/chunk-XMHBH5H6.js +0 -283
  1255. package/dist/chunk-XMHBH5H6.js.map +0 -1
  1256. package/dist/chunk-XMVFHBHT.js +0 -277
  1257. package/dist/chunk-Y3VMVTYX.js +0 -53
  1258. package/dist/chunk-YNB73F22.js +0 -137
  1259. package/dist/chunk-YNB73F22.js.map +0 -1
  1260. package/dist/chunk-Z2E7VW55.js +0 -335
  1261. package/dist/chunk-Z2E7VW55.js.map +0 -1
  1262. package/dist/chunk-ZG7PTKBK.js +0 -2296
  1263. package/dist/chunk-ZNQN6ZTA.js +0 -135
  1264. package/dist/chunk-ZVTKDVVM.js +0 -827
  1265. package/dist/chunk-ZVTKDVVM.js.map +0 -1
  1266. package/dist/cli-BR8KpIU0.d.ts +0 -1259
  1267. package/dist/codex-materialize-CQlLTzke.d.ts +0 -139
  1268. package/dist/connectors-cli-DFGtY2DB.d.ts +0 -257
  1269. package/dist/contradiction-review-5LTTVDQV.js +0 -22
  1270. package/dist/contradiction-scan-QTXAMBUA.js +0 -414
  1271. package/dist/contradiction-scan-QTXAMBUA.js.map +0 -1
  1272. package/dist/engine-35M5BKQ7.js +0 -28
  1273. package/dist/fs-utils-IRVUFB6G.js +0 -30
  1274. package/dist/graph-edge-decay-PWB63GRE.js +0 -207
  1275. package/dist/memory-governance-IMPQZXFC.js +0 -37
  1276. package/dist/memory-projection-store-CY8TU40w.d.ts +0 -222
  1277. package/dist/orchestrator-DDMPqU6R.d.ts +0 -1792
  1278. package/dist/path-RMTY5Y5A.js +0 -9
  1279. package/dist/port-B6VEDIkC.d.ts +0 -53
  1280. package/dist/resolution-YGIBORXI.js +0 -101
  1281. package/dist/resolution-YGIBORXI.js.map +0 -1
  1282. package/dist/secure-store-4R2GSO7S.js +0 -156
  1283. package/dist/semantic-consolidation-ByBXb-sf.d.ts +0 -180
  1284. package/dist/state-store-3EH7HYIN.js +0 -16
  1285. package/dist/types-V3FJ26TF.js +0 -30
  1286. /package/dist/{capsule-crypto-SJS5VVAP.js.map → adapters/claude-code.js.map} +0 -0
  1287. /package/dist/{capsule-export-7QNCBZOQ.js.map → adapters/codex.js.map} +0 -0
  1288. /package/dist/{capsule-import-EPBHD2EN.js.map → adapters/hermes.js.map} +0 -0
  1289. /package/dist/{contradiction-review-5LTTVDQV.js.map → adapters/index.js.map} +0 -0
  1290. /package/dist/{engine-35M5BKQ7.js.map → adapters/registry.js.map} +0 -0
  1291. /package/dist/{fs-utils-IRVUFB6G.js.map → adapters/replit.js.map} +0 -0
  1292. /package/dist/{memory-governance-IMPQZXFC.js.map → adapters/types.js.map} +0 -0
  1293. /package/dist/{path-RMTY5Y5A.js.map → capsule-crypto-5CYAGVC5.js.map} +0 -0
  1294. /package/dist/{capsule-merge-DI7PNQ2H.js.map → capsule-merge-4MGKE7C5.js.map} +0 -0
  1295. /package/dist/{chunk-G4SK7DSQ.js.map → chunk-2WWLHTZY.js.map} +0 -0
  1296. /package/dist/{chunk-X7HPGUVG.js.map → chunk-4CRG46BG.js.map} +0 -0
  1297. /package/dist/{chunk-UVMUAWVT.js.map → chunk-7IASACLB.js.map} +0 -0
  1298. /package/dist/{chunk-HELQZFZO.js.map → chunk-EDTHC6UD.js.map} +0 -0
  1299. /package/dist/{chunk-4YM32CRU.js.map → chunk-EFJ3MQ4V.js.map} +0 -0
  1300. /package/dist/{chunk-E2UCDP5S.js.map → chunk-FBYESMQ2.js.map} +0 -0
  1301. /package/dist/{chunk-D54LZC5L.js.map → chunk-FDU6HUUL.js.map} +0 -0
  1302. /package/dist/{chunk-IB3BFHGN.js.map → chunk-GGKRUQOO.js.map} +0 -0
  1303. /package/dist/{chunk-242S3I2A.js.map → chunk-GL6I6MEQ.js.map} +0 -0
  1304. /package/dist/{secure-store-4R2GSO7S.js.map → chunk-HHLLAQGZ.js.map} +0 -0
  1305. /package/dist/{chunk-4IS4SXIQ.js.map → chunk-HXXBL2KD.js.map} +0 -0
  1306. /package/dist/{chunk-767ODGE6.js.map → chunk-KNKUID7G.js.map} +0 -0
  1307. /package/dist/{chunk-6TBWYBJ3.js.map → chunk-LPMVBPA3.js.map} +0 -0
  1308. /package/dist/{chunk-WEJG4TB5.js.map → chunk-MC26UJIM.js.map} +0 -0
  1309. /package/dist/{chunk-JKDVIE52.js.map → chunk-MGKYQQYF.js.map} +0 -0
  1310. /package/dist/{chunk-Y3VMVTYX.js.map → chunk-MT4HVDUZ.js.map} +0 -0
  1311. /package/dist/{chunk-G2WADRQ3.js.map → chunk-MY6TPVXW.js.map} +0 -0
  1312. /package/dist/{chunk-OR64ZGRZ.js.map → chunk-NNVTUXEB.js.map} +0 -0
  1313. /package/dist/{chunk-JESOB2HO.js.map → chunk-P4NEIHUT.js.map} +0 -0
  1314. /package/dist/{chunk-IXEJRKCZ.js.map → chunk-QRNI5JBH.js.map} +0 -0
  1315. /package/dist/{chunk-EEQLFRUM.js.map → chunk-RRF5UOBJ.js.map} +0 -0
  1316. /package/dist/{state-store-3EH7HYIN.js.map → chunk-SEDEKFYQ.js.map} +0 -0
  1317. /package/dist/{chunk-2LGMW3DJ.js.map → chunk-U3PN77QT.js.map} +0 -0
  1318. /package/dist/{chunk-XMVFHBHT.js.map → chunk-U3WSW6PZ.js.map} +0 -0
  1319. /package/dist/{chunk-N5AKDXAI.js.map → chunk-UWVJF25J.js.map} +0 -0
  1320. /package/dist/{types-V3FJ26TF.js.map → chunk-V5OCT34X.js.map} +0 -0
  1321. /package/dist/{chunk-ZG7PTKBK.js.map → chunk-W3LR522O.js.map} +0 -0
  1322. /package/dist/{chunk-MARWOCVP.js.map → chunk-XIG5PDM7.js.map} +0 -0
  1323. /package/dist/{chunk-ZNQN6ZTA.js.map → chunk-XVZ7B3HG.js.map} +0 -0
  1324. /package/dist/{graph-edge-decay-PWB63GRE.js.map → graph-edge-decay-5DI5GUNL.js.map} +0 -0
@@ -0,0 +1,1317 @@
1
+ import {
2
+ listNamespaces
3
+ } from "./chunk-MT25YHYH.js";
4
+ import {
5
+ runConsolidationProvenanceCheck
6
+ } from "./chunk-5HRY2WRF.js";
7
+ import {
8
+ reportBufferSurpriseDistribution
9
+ } from "./chunk-YBPYIAA5.js";
10
+ import {
11
+ analyzeSessionIntegrity,
12
+ applySessionRepair,
13
+ planSessionRepair
14
+ } from "./chunk-YRMVARQP.js";
15
+ import {
16
+ resolveRemnicPluginEntry
17
+ } from "./chunk-U66YHYC7.js";
18
+ import {
19
+ resolveCuratedIncludeFilesStatePath,
20
+ resolveNativeKnowledgeStatePath,
21
+ resolveOpenClawWorkspaceStatePath
22
+ } from "./chunk-7SEAZFFB.js";
23
+ import {
24
+ createEvalBaselineSnapshot,
25
+ getEvalHarnessStatus,
26
+ runEvalBaselineDeltaReport,
27
+ runEvalBenchmarkCiGate,
28
+ validateEvalBenchmarkPack
29
+ } from "./chunk-D46YSIYX.js";
30
+ import {
31
+ readJudgeVerdictStats
32
+ } from "./chunk-AJU4PJGY.js";
33
+ import {
34
+ parseConfig
35
+ } from "./chunk-2QR3XXIC.js";
36
+ import {
37
+ listMemoryGovernanceRuns,
38
+ readMemoryGovernanceRunArtifact
39
+ } from "./chunk-EFJ3MQ4V.js";
40
+ import {
41
+ analyzeGraphHealth
42
+ } from "./chunk-RK2Y4XOM.js";
43
+ import {
44
+ StorageManager
45
+ } from "./chunk-7AAT6G4Q.js";
46
+ import {
47
+ lintWorkspaceFiles
48
+ } from "./chunk-DM2T26WE.js";
49
+ import {
50
+ readEnvVar,
51
+ resolveHomeDir
52
+ } from "./chunk-XIG5PDM7.js";
53
+
54
+ // src/operator-toolkit.ts
55
+ import path from "path";
56
+ import { constants as fsConstants } from "fs";
57
+ import { access, mkdir, readFile, readdir, stat, unlink, writeFile } from "fs/promises";
58
+ function isMissingPathError(error) {
59
+ return typeof error === "object" && error !== null && "code" in error && error.code === "ENOENT";
60
+ }
61
+ function formatUnknownError(error) {
62
+ return error instanceof Error ? error.message : String(error);
63
+ }
64
+ function resolveConfigPath(explicitPath) {
65
+ if (explicitPath && explicitPath.trim().length > 0) return explicitPath.trim();
66
+ const configured = readEnvVar("OPENCLAW_CONFIG_PATH") || readEnvVar("OPENCLAW_ENGRAM_CONFIG_PATH");
67
+ if (configured && configured.trim().length > 0) return configured.trim();
68
+ return path.join(resolveHomeDir(), ".openclaw", "openclaw.json");
69
+ }
70
+ async function loadCliPluginConfig(configPath) {
71
+ const resolvedPath = resolveConfigPath(configPath);
72
+ try {
73
+ const raw = JSON.parse(await readFile(resolvedPath, "utf-8"));
74
+ const entry = resolveRemnicPluginEntry(raw);
75
+ const parsedConfig = parseConfig(
76
+ entry && typeof entry === "object" ? entry["config"] ?? {} : {}
77
+ );
78
+ return {
79
+ found: true,
80
+ path: resolvedPath,
81
+ parsed: true,
82
+ memoryDir: parsedConfig.memoryDir,
83
+ workspaceDir: parsedConfig.workspaceDir
84
+ };
85
+ } catch (error) {
86
+ const message = error instanceof Error ? error.message : String(error);
87
+ return {
88
+ found: !/ENOENT/i.test(message),
89
+ path: resolvedPath,
90
+ parsed: false,
91
+ error: message
92
+ };
93
+ }
94
+ }
95
+ async function isWritable(targetPath) {
96
+ try {
97
+ await access(targetPath, fsConstants.W_OK);
98
+ return true;
99
+ } catch {
100
+ return false;
101
+ }
102
+ }
103
+ async function pathExists(targetPath) {
104
+ try {
105
+ await access(targetPath, fsConstants.F_OK);
106
+ return true;
107
+ } catch {
108
+ return false;
109
+ }
110
+ }
111
+ function formatConfigValue(value) {
112
+ if (value === void 0 || value === null) return "(unset)";
113
+ if (typeof value === "string") return value.length > 0 ? value : "(unset)";
114
+ if (typeof value === "number" || typeof value === "boolean") return String(value);
115
+ return JSON.stringify(value);
116
+ }
117
+ async function gatherDirectoryStatus(paths) {
118
+ return Promise.all(paths.map(async (targetPath) => {
119
+ try {
120
+ await access(targetPath, fsConstants.F_OK);
121
+ return {
122
+ path: targetPath,
123
+ exists: true,
124
+ writable: await isWritable(targetPath)
125
+ };
126
+ } catch {
127
+ return {
128
+ path: targetPath,
129
+ exists: false,
130
+ writable: false
131
+ };
132
+ }
133
+ }));
134
+ }
135
+ function getSetupPaths(config) {
136
+ return [
137
+ config.memoryDir,
138
+ config.workspaceDir,
139
+ path.join(config.memoryDir, "facts"),
140
+ path.join(config.memoryDir, "entities"),
141
+ path.join(config.memoryDir, "state"),
142
+ path.join(config.memoryDir, "questions"),
143
+ path.join(config.memoryDir, "artifacts"),
144
+ path.join(config.memoryDir, "config")
145
+ ];
146
+ }
147
+ async function readJsonIfExists(filePath) {
148
+ try {
149
+ return JSON.parse(await readFile(filePath, "utf-8"));
150
+ } catch {
151
+ return null;
152
+ }
153
+ }
154
+ async function summarizeNativeKnowledgeStatus(config) {
155
+ const nativeKnowledge = config.nativeKnowledge;
156
+ const nativeKnowledgeStateDir = nativeKnowledge?.stateDir ?? "state/native-knowledge";
157
+ const curatedStatePath = nativeKnowledge ? resolveCuratedIncludeFilesStatePath(config.memoryDir, nativeKnowledge) : path.join(config.memoryDir, nativeKnowledgeStateDir, "curated-include-sync.json");
158
+ const obsidianStatePath = nativeKnowledge ? resolveNativeKnowledgeStatePath(config.memoryDir, nativeKnowledge) : path.join(config.memoryDir, nativeKnowledgeStateDir, "obsidian-sync.json");
159
+ const openclawStatePath = nativeKnowledge ? resolveOpenClawWorkspaceStatePath(config.memoryDir, nativeKnowledge) : path.join(config.memoryDir, nativeKnowledgeStateDir, "openclaw-workspace-sync.json");
160
+ const [curatedRaw, obsidianRaw, openclawRaw] = await Promise.all([
161
+ readJsonIfExists(curatedStatePath),
162
+ readJsonIfExists(obsidianStatePath),
163
+ readJsonIfExists(openclawStatePath)
164
+ ]);
165
+ const curatedFiles = curatedRaw && typeof curatedRaw === "object" && curatedRaw !== null && "files" in curatedRaw && typeof curatedRaw.files === "object" && curatedRaw.files !== null ? curatedRaw : null;
166
+ let curatedActiveChunkCount = 0;
167
+ let curatedDeletedFileCount = 0;
168
+ for (const file of Object.values(curatedFiles?.files ?? {})) {
169
+ if (file.deleted) {
170
+ curatedDeletedFileCount += 1;
171
+ continue;
172
+ }
173
+ curatedActiveChunkCount += Array.isArray(file.chunks) ? file.chunks.length : 0;
174
+ }
175
+ const obsidianVaults = obsidianRaw && typeof obsidianRaw === "object" && obsidianRaw !== null && "vaults" in obsidianRaw && typeof obsidianRaw.vaults === "object" && obsidianRaw.vaults !== null ? obsidianRaw : null;
176
+ let obsidianActiveChunkCount = 0;
177
+ let obsidianDeletedNoteCount = 0;
178
+ for (const vault of Object.values(obsidianVaults?.vaults ?? {})) {
179
+ for (const note of Object.values(vault.notes ?? {})) {
180
+ if (note.deleted) {
181
+ obsidianDeletedNoteCount += 1;
182
+ continue;
183
+ }
184
+ obsidianActiveChunkCount += Array.isArray(note.chunks) ? note.chunks.length : 0;
185
+ }
186
+ }
187
+ const openclawFiles = openclawRaw && typeof openclawRaw === "object" && openclawRaw !== null && "files" in openclawRaw && typeof openclawRaw.files === "object" && openclawRaw.files !== null ? openclawRaw : null;
188
+ let openclawActiveChunkCount = 0;
189
+ let openclawDeletedFileCount = 0;
190
+ for (const file of Object.values(openclawFiles?.files ?? {})) {
191
+ if (file.deleted) {
192
+ openclawDeletedFileCount += 1;
193
+ continue;
194
+ }
195
+ openclawActiveChunkCount += Array.isArray(file.chunks) ? file.chunks.length : 0;
196
+ }
197
+ return {
198
+ enabled: nativeKnowledge?.enabled === true,
199
+ includeFiles: nativeKnowledge?.includeFiles ?? [],
200
+ curatedIncludeSync: {
201
+ statePath: curatedStatePath,
202
+ exists: curatedFiles !== null,
203
+ updatedAt: typeof curatedFiles?.updatedAt === "string" ? curatedFiles.updatedAt : null,
204
+ fileCount: Object.keys(curatedFiles?.files ?? {}).length,
205
+ activeChunkCount: curatedActiveChunkCount,
206
+ deletedFileCount: curatedDeletedFileCount
207
+ },
208
+ openclawWorkspaceAdapterEnabled: nativeKnowledge?.openclawWorkspace?.enabled === true,
209
+ obsidianVaultAdapterEnabled: (nativeKnowledge?.obsidianVaults?.length ?? 0) > 0,
210
+ obsidianSync: {
211
+ statePath: obsidianStatePath,
212
+ exists: obsidianVaults !== null,
213
+ updatedAt: typeof obsidianVaults?.updatedAt === "string" ? obsidianVaults.updatedAt : null,
214
+ vaultCount: Object.keys(obsidianVaults?.vaults ?? {}).length,
215
+ activeChunkCount: obsidianActiveChunkCount,
216
+ deletedNoteCount: obsidianDeletedNoteCount
217
+ },
218
+ openclawWorkspaceSync: {
219
+ statePath: openclawStatePath,
220
+ exists: openclawFiles !== null,
221
+ updatedAt: typeof openclawFiles?.updatedAt === "string" ? openclawFiles.updatedAt : null,
222
+ fileCount: Object.keys(openclawFiles?.files ?? {}).length,
223
+ activeChunkCount: openclawActiveChunkCount,
224
+ deletedFileCount: openclawDeletedFileCount
225
+ }
226
+ };
227
+ }
228
+ var CAPTURE_INSTRUCTIONS_START = "<!-- BEGIN ENGRAM EXPLICIT CAPTURE INSTRUCTIONS -->";
229
+ var CAPTURE_INSTRUCTIONS_END = "<!-- END ENGRAM EXPLICIT CAPTURE INSTRUCTIONS -->";
230
+ function buildCaptureInstructions() {
231
+ return [
232
+ CAPTURE_INSTRUCTIONS_START,
233
+ "# Memory",
234
+ "",
235
+ "Use this file for explicit memory capture notes when Engram runs in explicit or hybrid mode.",
236
+ "",
237
+ "## Suggested format",
238
+ "",
239
+ "- Write durable facts, decisions, commitments, or corrections.",
240
+ "- Keep entries concise and specific.",
241
+ "- Avoid secrets, tokens, and private credentials.",
242
+ "",
243
+ "## Example",
244
+ "",
245
+ "- Decision: recall benchmark packs live under `state/evals/benchmarks/`.",
246
+ "- Commitment: rerun `openclaw engram doctor --json` after changing retrieval settings.",
247
+ "",
248
+ CAPTURE_INSTRUCTIONS_END
249
+ ].join("\n");
250
+ }
251
+ function upsertManagedCaptureInstructions(existing, snippet) {
252
+ if (!existing || existing.trim().length === 0) {
253
+ return { content: `${snippet}
254
+ `, updated: false, installed: true };
255
+ }
256
+ if (existing.includes(CAPTURE_INSTRUCTIONS_START) && existing.includes(CAPTURE_INSTRUCTIONS_END)) {
257
+ const next = existing.replace(
258
+ new RegExp(`${CAPTURE_INSTRUCTIONS_START}[\\s\\S]*?${CAPTURE_INSTRUCTIONS_END}`),
259
+ snippet
260
+ );
261
+ return { content: next.endsWith("\n") ? next : `${next}
262
+ `, updated: next !== existing, installed: false };
263
+ }
264
+ const trimmed = existing.trimEnd();
265
+ return {
266
+ content: `${trimmed}
267
+
268
+ ${snippet}
269
+ `,
270
+ updated: false,
271
+ installed: true
272
+ };
273
+ }
274
+ function removeManagedCaptureInstructions(existing) {
275
+ if (!existing.includes(CAPTURE_INSTRUCTIONS_START) || !existing.includes(CAPTURE_INSTRUCTIONS_END)) {
276
+ return { content: existing, removed: false };
277
+ }
278
+ const stripped = existing.replace(new RegExp(`\\n*${CAPTURE_INSTRUCTIONS_START}[\\s\\S]*?${CAPTURE_INSTRUCTIONS_END}\\n*`), "\n").replace(/\n{3,}/g, "\n\n").trim();
279
+ return {
280
+ content: stripped.length > 0 ? `${stripped}
281
+ ` : "",
282
+ removed: true
283
+ };
284
+ }
285
+ async function runOperatorSetup(options) {
286
+ const now = options.now ?? /* @__PURE__ */ new Date();
287
+ const configStatus = await loadCliPluginConfig(options.configPath);
288
+ const storage = options.orchestrator.storage;
289
+ await storage.ensureDirectories();
290
+ await mkdir(options.orchestrator.config.workspaceDir, { recursive: true });
291
+ const qmdAvailable = await options.orchestrator.qmd.probe();
292
+ const collectionState = options.orchestrator.config.qmdEnabled ? await options.orchestrator.qmd.ensureCollection(options.orchestrator.config.memoryDir) : "skipped";
293
+ const nativeKnowledgeStatus = await summarizeNativeKnowledgeStatus(options.orchestrator.config);
294
+ const memoryDocPath = path.join(options.orchestrator.config.workspaceDir, "MEMORY.md");
295
+ const captureInstructionsMode = options.captureInstructionsMode ?? (options.installCaptureInstructions ? "install" : void 0);
296
+ let memoryDocExists = false;
297
+ try {
298
+ await access(memoryDocPath, fsConstants.F_OK);
299
+ memoryDocExists = true;
300
+ } catch {
301
+ memoryDocExists = false;
302
+ }
303
+ let memoryDocInstalled = false;
304
+ let memoryDocUpdated = false;
305
+ let memoryDocRemoved = false;
306
+ const explicitCaptureEnabled = options.orchestrator.config.captureMode === "explicit" || options.orchestrator.config.captureMode === "hybrid";
307
+ const captureInstructionsPreview = captureInstructionsMode ? buildCaptureInstructions() : null;
308
+ if (captureInstructionsMode) {
309
+ if (captureInstructionsMode === "preview") {
310
+ } else if (captureInstructionsMode === "install") {
311
+ const existing = memoryDocExists ? await readFile(memoryDocPath, "utf-8") : null;
312
+ const next = upsertManagedCaptureInstructions(existing, captureInstructionsPreview ?? "");
313
+ if (!existing || next.content !== existing) {
314
+ await writeFile(memoryDocPath, next.content, "utf-8");
315
+ }
316
+ memoryDocExists = true;
317
+ memoryDocInstalled = next.installed;
318
+ memoryDocUpdated = next.updated;
319
+ } else if (captureInstructionsMode === "remove" && memoryDocExists) {
320
+ const existing = await readFile(memoryDocPath, "utf-8");
321
+ const next = removeManagedCaptureInstructions(existing);
322
+ if (next.removed) {
323
+ if (next.content.length === 0) {
324
+ await unlink(memoryDocPath);
325
+ memoryDocExists = false;
326
+ } else {
327
+ await writeFile(memoryDocPath, next.content, "utf-8");
328
+ memoryDocExists = true;
329
+ }
330
+ memoryDocRemoved = true;
331
+ }
332
+ }
333
+ }
334
+ const directories = await gatherDirectoryStatus(getSetupPaths(options.orchestrator.config));
335
+ const nextSteps = [
336
+ `Run \`openclaw engram doctor${options.installCaptureInstructions ? "" : " --json"}\` to verify runtime health.`,
337
+ "Run `openclaw engram inventory --json` to capture a baseline footprint.",
338
+ "If QMD is enabled and the collection is missing, add the collection to `~/.config/qmd/index.yml` and run `qmd update && qmd embed`."
339
+ ];
340
+ if (explicitCaptureEnabled && !memoryDocExists) {
341
+ nextSteps.push("Run `openclaw engram setup --preview-capture-instructions` to review the managed explicit-capture snippet, then `--install-capture-instructions` to write it.");
342
+ }
343
+ return {
344
+ schemaVersion: 1,
345
+ generatedAt: now.toISOString(),
346
+ config: configStatus,
347
+ memoryDir: options.orchestrator.config.memoryDir,
348
+ workspaceDir: options.orchestrator.config.workspaceDir,
349
+ directories,
350
+ qmd: {
351
+ enabled: options.orchestrator.config.qmdEnabled,
352
+ available: qmdAvailable,
353
+ collectionState,
354
+ debugStatus: options.orchestrator.qmd.debugStatus()
355
+ },
356
+ nativeKnowledge: nativeKnowledgeStatus,
357
+ explicitCapture: {
358
+ captureMode: options.orchestrator.config.captureMode,
359
+ enabled: explicitCaptureEnabled,
360
+ memoryDocPath,
361
+ memoryDocExists,
362
+ memoryDocInstalled,
363
+ memoryDocUpdated,
364
+ memoryDocRemoved,
365
+ preview: captureInstructionsMode === "preview" ? captureInstructionsPreview : null
366
+ },
367
+ nextSteps,
368
+ verificationCommands: [
369
+ "openclaw engram doctor --json",
370
+ "openclaw engram inventory --json",
371
+ "openclaw engram benchmark recall --json"
372
+ ]
373
+ };
374
+ }
375
+ function summarizeHygieneWarnings(warnings, hygiene) {
376
+ if (!hygiene?.enabled || hygiene.lintEnabled !== true) {
377
+ return {
378
+ key: "file_hygiene",
379
+ status: "warn",
380
+ summary: "File hygiene linting is disabled; bootstrap file truncation warnings are not active.",
381
+ remediation: "Enable `fileHygiene.enabled` and `fileHygiene.lintEnabled` if large workspace bootstrap files are common.",
382
+ details: {
383
+ enabled: hygiene?.enabled === true,
384
+ lintEnabled: hygiene?.lintEnabled === true
385
+ }
386
+ };
387
+ }
388
+ if (warnings.length > 0) {
389
+ return {
390
+ key: "file_hygiene",
391
+ status: "warn",
392
+ summary: `${warnings.length} bootstrap file(s) are near or above the configured budget.`,
393
+ remediation: "Archive/split the listed files or adjust `fileHygiene` budgets.",
394
+ details: { warnings }
395
+ };
396
+ }
397
+ return {
398
+ key: "file_hygiene",
399
+ status: "ok",
400
+ summary: "Bootstrap file hygiene is within budget.",
401
+ details: {
402
+ enabled: true,
403
+ lintPaths: hygiene.lintPaths,
404
+ budgetBytes: hygiene.lintBudgetBytes
405
+ }
406
+ };
407
+ }
408
+ function buildConfigReviewFinding(input) {
409
+ return {
410
+ key: input.key,
411
+ status: input.status,
412
+ setting: input.setting,
413
+ currentValue: formatConfigValue(input.currentValue),
414
+ defaultValue: formatConfigValue(input.defaultValue),
415
+ recommendedValue: formatConfigValue(input.recommendedValue),
416
+ summary: input.summary,
417
+ rationale: input.rationale
418
+ };
419
+ }
420
+ async function runOperatorConfigReview(options) {
421
+ const now = options.now ?? /* @__PURE__ */ new Date();
422
+ const configStatus = await loadCliPluginConfig(options.configPath);
423
+ return buildOperatorConfigReviewReport({
424
+ now,
425
+ configStatus,
426
+ config: options.orchestrator.config
427
+ });
428
+ }
429
+ async function buildOperatorConfigReviewReport(input) {
430
+ const { now, configStatus, config } = input;
431
+ const findings = [];
432
+ const searchBackend = config.searchBackend ?? "qmd";
433
+ const workspaceBootstrapFiles = [
434
+ path.join(config.workspaceDir, "IDENTITY.md"),
435
+ path.join(config.workspaceDir, "MEMORY.md"),
436
+ path.join(config.workspaceDir, "USER.md")
437
+ ];
438
+ const workspaceBootstrapExists = (await Promise.all(workspaceBootstrapFiles.map(pathExists))).some(Boolean);
439
+ if (config.memoryOsPreset !== "conservative" && config.memoryOsPreset !== "balanced" && config.memoryOsPreset !== "research-max" && config.memoryOsPreset !== "local-llm-heavy" && config.queryAwareIndexingEnabled === false && config.verbatimArtifactsEnabled === false && config.rerankEnabled === false) {
440
+ findings.push(buildConfigReviewFinding({
441
+ key: "balanced_preset",
442
+ status: "recommend",
443
+ setting: "memoryOsPreset",
444
+ currentValue: config.memoryOsPreset,
445
+ defaultValue: "(unset)",
446
+ recommendedValue: "balanced",
447
+ summary: "Adopt the balanced preset as the baseline configuration profile.",
448
+ rationale: "The balanced preset enables the recommended indexing, reranking, and artifact defaults without turning on the higher-churn graph and learning loops."
449
+ }));
450
+ }
451
+ if (config.qmdEnabled && config.qmdDaemonEnabled === false) {
452
+ findings.push(buildConfigReviewFinding({
453
+ key: "qmd_daemon",
454
+ status: "recommend",
455
+ setting: "qmdDaemonEnabled",
456
+ currentValue: config.qmdDaemonEnabled,
457
+ defaultValue: true,
458
+ recommendedValue: true,
459
+ summary: "Enable the QMD daemon path when QMD powers recall.",
460
+ rationale: "The daemon path reduces recall/search contention by preferring the MCP transport instead of repeated subprocess calls when QMD is available."
461
+ }));
462
+ }
463
+ if (workspaceBootstrapExists && config.nativeKnowledge?.enabled !== true) {
464
+ findings.push(buildConfigReviewFinding({
465
+ key: "native_knowledge_enabled",
466
+ status: "recommend",
467
+ setting: "nativeKnowledge.enabled",
468
+ currentValue: config.nativeKnowledge?.enabled,
469
+ defaultValue: false,
470
+ recommendedValue: true,
471
+ summary: "Enable native knowledge recall for workspace bootstrap documents.",
472
+ rationale: "When files like IDENTITY.md or MEMORY.md already exist, native knowledge recall can chunk and inject them directly instead of relying only on extracted memories."
473
+ }));
474
+ }
475
+ if (workspaceBootstrapExists && config.fileHygiene?.enabled !== true) {
476
+ findings.push(buildConfigReviewFinding({
477
+ key: "file_hygiene_enabled",
478
+ status: "recommend",
479
+ setting: "fileHygiene.enabled",
480
+ currentValue: config.fileHygiene?.enabled,
481
+ defaultValue: false,
482
+ recommendedValue: true,
483
+ summary: "Enable file hygiene to avoid silent workspace-file truncation.",
484
+ rationale: "OpenClaw bootstrap files can grow quietly; file hygiene warns before oversized files are truncated during prompt bootstrap."
485
+ }));
486
+ }
487
+ if (searchBackend === "qmd" && config.qmdEnabled === false) {
488
+ findings.push(buildConfigReviewFinding({
489
+ key: "qmd_search_backend_disabled",
490
+ status: "problem",
491
+ setting: "qmdEnabled",
492
+ currentValue: config.qmdEnabled,
493
+ defaultValue: true,
494
+ recommendedValue: true,
495
+ summary: "QMD search is selected but QMD is disabled.",
496
+ rationale: "When searchBackend resolves to qmd while qmdEnabled is false, Engram falls back to the noop backend and disables the primary search path."
497
+ }));
498
+ }
499
+ if (config.qmdColdTierEnabled === true && config.qmdEnabled === false) {
500
+ findings.push(buildConfigReviewFinding({
501
+ key: "qmd_cold_tier_requires_qmd",
502
+ status: "problem",
503
+ setting: "qmdEnabled",
504
+ currentValue: config.qmdEnabled,
505
+ defaultValue: true,
506
+ recommendedValue: true,
507
+ summary: "Cold-tier QMD recall is enabled while QMD itself is disabled.",
508
+ rationale: "The cold tier depends on the same QMD runtime as the hot tier, so turning QMD off leaves the extra tiering path unusable."
509
+ }));
510
+ }
511
+ if (config.qmdTierMigrationEnabled && config.qmdColdTierEnabled !== true) {
512
+ findings.push(buildConfigReviewFinding({
513
+ key: "qmd_tier_migration_requires_cold_tier",
514
+ status: "problem",
515
+ setting: "qmdColdTierEnabled",
516
+ currentValue: config.qmdColdTierEnabled,
517
+ defaultValue: false,
518
+ recommendedValue: true,
519
+ summary: "Hot/cold tier migration is enabled without the cold tier itself.",
520
+ rationale: "Tier migration depends on the cold-tier collection and recall path, so enabling migration while the cold tier is off leaves the feature in a contradictory state."
521
+ }));
522
+ }
523
+ if (config.conversationIndexEnabled && config.conversationIndexBackend === "qmd" && config.qmdEnabled === false) {
524
+ findings.push(buildConfigReviewFinding({
525
+ key: "conversation_index_qmd_requires_qmd",
526
+ status: "problem",
527
+ setting: "qmdEnabled",
528
+ currentValue: config.qmdEnabled,
529
+ defaultValue: true,
530
+ recommendedValue: true,
531
+ summary: "The conversation index is configured for QMD while QMD is disabled.",
532
+ rationale: "A QMD-backed conversation index cannot rebuild or serve queries when the underlying QMD runtime is disabled."
533
+ }));
534
+ }
535
+ const summary = findings.reduce(
536
+ (acc, finding) => {
537
+ acc[finding.status] += 1;
538
+ return acc;
539
+ },
540
+ { recommend: 0, problem: 0 }
541
+ );
542
+ return {
543
+ schemaVersion: 1,
544
+ generatedAt: now.toISOString(),
545
+ ok: configStatus.parsed && summary.problem === 0,
546
+ config: configStatus,
547
+ profile: {
548
+ memoryOsPreset: config.memoryOsPreset,
549
+ searchBackend,
550
+ qmdEnabled: config.qmdEnabled,
551
+ qmdDaemonEnabled: config.qmdDaemonEnabled,
552
+ nativeKnowledgeEnabled: config.nativeKnowledge?.enabled === true,
553
+ fileHygieneEnabled: config.fileHygiene?.enabled === true,
554
+ conversationIndexEnabled: config.conversationIndexEnabled
555
+ },
556
+ summary,
557
+ findings
558
+ };
559
+ }
560
+ async function runOperatorDoctor(options) {
561
+ const now = options.now ?? /* @__PURE__ */ new Date();
562
+ const configStatus = await loadCliPluginConfig(options.configPath);
563
+ const checks = [];
564
+ const config = options.orchestrator.config;
565
+ const storage = options.orchestrator.storage;
566
+ const configReview = await buildOperatorConfigReviewReport({
567
+ now,
568
+ configStatus,
569
+ config
570
+ });
571
+ const nativeKnowledgeStatus = await summarizeNativeKnowledgeStatus(config);
572
+ const setupPaths = await gatherDirectoryStatus(getSetupPaths(config));
573
+ const missingPaths = setupPaths.filter((entry) => !entry.exists).map((entry) => entry.path);
574
+ checks.push({
575
+ key: "config",
576
+ status: configStatus.parsed ? "ok" : options.configPath ? "error" : "warn",
577
+ summary: configStatus.parsed ? "OpenClaw config loaded and Engram config parsed successfully." : "Config file could not be parsed.",
578
+ remediation: configStatus.parsed ? void 0 : "Fix the config file or set OPENCLAW_ENGRAM_CONFIG_PATH/OPENCLAW_CONFIG_PATH.",
579
+ details: configStatus
580
+ });
581
+ checks.push({
582
+ key: "memory_dir",
583
+ status: missingPaths.length === 0 ? "ok" : "warn",
584
+ summary: missingPaths.length === 0 ? "Expected Engram directories exist." : `${missingPaths.length} expected directory path(s) are missing.`,
585
+ remediation: missingPaths.length === 0 ? void 0 : "Run `openclaw engram setup` to create missing directories.",
586
+ details: { directories: setupPaths }
587
+ });
588
+ checks.push({
589
+ key: "config_review",
590
+ status: configReview.summary.problem > 0 ? "error" : configReview.summary.recommend > 0 ? "warn" : "ok",
591
+ summary: configReview.summary.problem > 0 ? `${configReview.summary.problem} configuration problem(s) detected.` : configReview.summary.recommend > 0 ? `No configuration problems detected; ${configReview.summary.recommend} optional recommendation(s) are available.` : "No configuration problems detected.",
592
+ remediation: configReview.summary.problem > 0 || configReview.summary.recommend > 0 ? "Run `openclaw engram config-review` to inspect and fix the flagged configuration combinations." : void 0,
593
+ details: configReview
594
+ });
595
+ const qmdAvailable = await options.orchestrator.qmd.probe();
596
+ const collectionState = config.qmdEnabled ? await options.orchestrator.qmd.ensureCollection(config.memoryDir) : "skipped";
597
+ checks.push({
598
+ key: "qmd",
599
+ status: !config.qmdEnabled ? "warn" : !qmdAvailable ? "error" : collectionState === "present" ? "ok" : collectionState === "missing" ? "error" : "warn",
600
+ summary: !config.qmdEnabled ? "QMD is disabled in config." : qmdAvailable ? `QMD is reachable (${collectionState}).` : "QMD is not currently reachable.",
601
+ remediation: !config.qmdEnabled ? "Enable `qmdEnabled` if you expect hybrid search." : !qmdAvailable ? "Ensure the `qmd` binary is installed and on PATH, or set `qmdPath`." : collectionState === "missing" ? "Add the configured collection to `~/.config/qmd/index.yml`." : collectionState === "present" ? void 0 : "Re-run `openclaw engram setup` after restoring QMD access.",
602
+ details: {
603
+ available: qmdAvailable,
604
+ collectionState,
605
+ debugStatus: options.orchestrator.qmd.debugStatus()
606
+ }
607
+ });
608
+ const conversationIndex = await options.orchestrator.getConversationIndexHealth();
609
+ checks.push({
610
+ key: "conversation_index",
611
+ status: conversationIndex.status === "ok" ? "ok" : conversationIndex.enabled ? "error" : "warn",
612
+ summary: conversationIndex.enabled ? `Conversation index backend is ${conversationIndex.status}.` : "Conversation index is disabled.",
613
+ remediation: conversationIndex.enabled && conversationIndex.status !== "ok" ? "Run `openclaw engram rebuild-index` to refresh the conversation index artifacts." : void 0,
614
+ details: conversationIndex
615
+ });
616
+ const meta = await storage.loadMeta();
617
+ checks.push({
618
+ key: "maintenance",
619
+ status: meta.lastExtractionAt || meta.lastConsolidationAt ? "ok" : "warn",
620
+ summary: meta.lastExtractionAt || meta.lastConsolidationAt ? "Extraction/consolidation metadata is present." : "No extraction or consolidation metadata found yet.",
621
+ remediation: meta.lastExtractionAt || meta.lastConsolidationAt ? void 0 : "Run a normal agent turn or `openclaw engram consolidate` after seeding memory.",
622
+ details: meta
623
+ });
624
+ const syncedChunkCount = nativeKnowledgeStatus.curatedIncludeSync.activeChunkCount + nativeKnowledgeStatus.obsidianSync.activeChunkCount + nativeKnowledgeStatus.openclawWorkspaceSync.activeChunkCount;
625
+ const hasSyncState = nativeKnowledgeStatus.curatedIncludeSync.exists || nativeKnowledgeStatus.obsidianSync.exists || nativeKnowledgeStatus.openclawWorkspaceSync.exists;
626
+ checks.push({
627
+ key: "native_knowledge",
628
+ status: !nativeKnowledgeStatus.enabled ? "warn" : hasSyncState ? "ok" : "warn",
629
+ summary: !nativeKnowledgeStatus.enabled ? "Native knowledge sync is disabled." : hasSyncState ? `Native knowledge sync state is present (${syncedChunkCount} active chunks).` : "Native knowledge sync is enabled but no sync state has been written yet.",
630
+ remediation: !nativeKnowledgeStatus.enabled ? "Enable `nativeKnowledge.enabled` if curated workspace recall should participate in retrieval." : hasSyncState ? void 0 : "Run a recall, sync, or setup flow that touches native knowledge sources, then rerun `openclaw engram doctor --json`.",
631
+ details: nativeKnowledgeStatus
632
+ });
633
+ const agentAccessEnabled = config.agentAccessHttp?.enabled === true;
634
+ const rawAuthToken = config.agentAccessHttp?.authToken;
635
+ const authTokenConfigured = typeof rawAuthToken === "string" && rawAuthToken.length > 0 || rawAuthToken !== null && typeof rawAuthToken === "object" && typeof rawAuthToken.source === "string";
636
+ checks.push({
637
+ key: "access_http_auth",
638
+ status: !agentAccessEnabled ? "warn" : authTokenConfigured ? "ok" : "error",
639
+ summary: !agentAccessEnabled ? "Agent access HTTP bridge is disabled." : authTokenConfigured ? "Agent access HTTP bridge has an auth token configured." : "Agent access HTTP bridge is enabled without an auth token.",
640
+ remediation: !agentAccessEnabled ? "Ignore unless you plan to enable the HTTP bridge." : authTokenConfigured ? void 0 : "Set `agentAccessHttp.authToken` before exposing the bridge."
641
+ });
642
+ const warnings = config.fileHygiene?.lintEnabled ? await lintWorkspaceFiles({
643
+ workspaceDir: config.workspaceDir,
644
+ paths: config.fileHygiene.lintPaths,
645
+ budgetBytes: config.fileHygiene.lintBudgetBytes,
646
+ warnRatio: config.fileHygiene.lintWarnRatio
647
+ }) : [];
648
+ checks.push(summarizeHygieneWarnings(warnings, config.fileHygiene));
649
+ checks.push(await summarizeMemoryWorthLegacyCounters(storage));
650
+ checks.push(
651
+ await summarizeBufferSurpriseDistribution(storage, config)
652
+ );
653
+ checks.push(await summarizeConsolidationProvenance(storage, config));
654
+ checks.push(await summarizeGraphEdgeDecayStatus(config));
655
+ checks.push(await summarizeTierDistribution(options.orchestrator.storage));
656
+ checks.push(await summarizeDreamsPhases(config, storage));
657
+ checks.push(summarizeSecurityMitigations(config));
658
+ checks.push(await summarizeObservationThroughput(config.memoryDir));
659
+ const summary = checks.reduce(
660
+ (acc, check) => {
661
+ acc[check.status] += 1;
662
+ return acc;
663
+ },
664
+ { ok: 0, warn: 0, error: 0 }
665
+ );
666
+ return {
667
+ schemaVersion: 1,
668
+ generatedAt: now.toISOString(),
669
+ ok: summary.error === 0,
670
+ summary,
671
+ config: configStatus,
672
+ checks
673
+ };
674
+ }
675
+ var MEMORY_WORTH_ELIGIBLE_CATEGORIES = /* @__PURE__ */ new Set(["fact"]);
676
+ async function summarizeMemoryWorthLegacyCounters(storage) {
677
+ let legacy = 0;
678
+ let instrumented = 0;
679
+ let ineligible = 0;
680
+ try {
681
+ const memories = await storage.readAllMemories();
682
+ for (const memory of memories) {
683
+ if (!MEMORY_WORTH_ELIGIBLE_CATEGORIES.has(memory.frontmatter.category)) {
684
+ ineligible += 1;
685
+ continue;
686
+ }
687
+ const { mw_success, mw_fail } = memory.frontmatter;
688
+ if (mw_success === void 0 && mw_fail === void 0) {
689
+ legacy += 1;
690
+ } else {
691
+ instrumented += 1;
692
+ }
693
+ }
694
+ } catch (err) {
695
+ return {
696
+ key: "memory_worth_legacy",
697
+ status: "warn",
698
+ summary: "Could not enumerate memories to count Memory Worth instrumentation.",
699
+ remediation: "Retry `remnic doctor` after ensuring the memory directory is readable.",
700
+ details: { error: String(err) }
701
+ };
702
+ }
703
+ const total = legacy + instrumented;
704
+ return {
705
+ key: "memory_worth_legacy",
706
+ status: "ok",
707
+ summary: total === 0 ? "No Memory Worth\u2013eligible memories on disk yet \u2014 counters will populate as facts are extracted." : `${legacy} of ${total} eligible memories have no Memory Worth counters yet (${instrumented} instrumented).`,
708
+ details: { legacy, instrumented, total, ineligible }
709
+ };
710
+ }
711
+ async function summarizeBufferSurpriseDistribution(storage, config) {
712
+ const storageWithLedger = storage;
713
+ if (typeof storageWithLedger.readBufferSurpriseEvents !== "function") {
714
+ return {
715
+ key: "buffer_surprise_distribution",
716
+ status: "ok",
717
+ summary: "Buffer-surprise telemetry reader unavailable in this build.",
718
+ details: { available: false }
719
+ };
720
+ }
721
+ try {
722
+ const dist = await reportBufferSurpriseDistribution(
723
+ async (opts) => storageWithLedger.readBufferSurpriseEvents({ limit: opts.limit }),
724
+ { limit: 200 }
725
+ );
726
+ if (dist.count === 0) {
727
+ return {
728
+ key: "buffer_surprise_distribution",
729
+ status: "ok",
730
+ summary: config.bufferSurpriseTriggerEnabled ? "Surprise trigger is enabled but no telemetry has been recorded yet." : "Surprise trigger is disabled; no telemetry expected.",
731
+ details: {
732
+ enabled: config.bufferSurpriseTriggerEnabled,
733
+ distribution: dist
734
+ }
735
+ };
736
+ }
737
+ const pct = (value) => (value * 100).toFixed(1);
738
+ return {
739
+ key: "buffer_surprise_distribution",
740
+ status: "ok",
741
+ summary: `Recent surprise: mean=${dist.mean.toFixed(3)}, median=${dist.median.toFixed(3)}, p90=${dist.p90.toFixed(3)}, triggered=${pct(dist.triggeredRate)}% over ${dist.count} turns (threshold=${dist.currentThreshold ?? config.bufferSurpriseThreshold}).`,
742
+ details: {
743
+ enabled: config.bufferSurpriseTriggerEnabled,
744
+ distribution: dist
745
+ }
746
+ };
747
+ } catch (err) {
748
+ return {
749
+ key: "buffer_surprise_distribution",
750
+ status: "warn",
751
+ summary: "Could not read buffer-surprise telemetry ledger.",
752
+ remediation: "Retry `remnic doctor` after ensuring the memory state directory is readable.",
753
+ details: { error: String(err) }
754
+ };
755
+ }
756
+ }
757
+ async function summarizeGraphEdgeDecayStatus(config) {
758
+ const { readGraphEdgeDecayStatus } = await import("./graph-edge-decay-5DI5GUNL.js");
759
+ const enabled = config.graphEdgeDecayEnabled === true;
760
+ if (!enabled) {
761
+ return {
762
+ key: "graph_edge_decay",
763
+ status: "ok",
764
+ summary: "Graph-edge decay maintenance is disabled (graphEdgeDecayEnabled = false).",
765
+ remediation: "Set graphEdgeDecayEnabled = true to opt into the periodic decay job (issue #681).",
766
+ details: { enabled: false }
767
+ };
768
+ }
769
+ const status = await readGraphEdgeDecayStatus(config.memoryDir);
770
+ if (!status) {
771
+ return {
772
+ key: "graph_edge_decay",
773
+ status: "warn",
774
+ summary: "Graph-edge decay is enabled but has not run yet (no status file present).",
775
+ remediation: "Trigger the cron, run `engram.graph_edge_decay_run` via MCP, or wait for the scheduled cadence to fire.",
776
+ details: { enabled: true, lastRun: null, cadenceMs: config.graphEdgeDecayCadenceMs }
777
+ };
778
+ }
779
+ return {
780
+ key: "graph_edge_decay",
781
+ status: "ok",
782
+ summary: `Graph-edge decay last ran at ${status.ranAt} (${status.edgesDecayed}/${status.edgesTotal} edges decayed, ${status.edgesBelowVisibilityThreshold} below visibility threshold).`,
783
+ details: {
784
+ enabled: true,
785
+ lastRun: status.ranAt,
786
+ durationMs: status.durationMs,
787
+ edgesTotal: status.edgesTotal,
788
+ edgesDecayed: status.edgesDecayed,
789
+ edgesBelowVisibilityThreshold: status.edgesBelowVisibilityThreshold,
790
+ topDecayedEntities: status.topDecayedEntities,
791
+ cadenceMs: config.graphEdgeDecayCadenceMs
792
+ }
793
+ };
794
+ }
795
+ async function summarizeTierDistribution(storage) {
796
+ try {
797
+ const { summarizeTiers } = await import("./tier-stats-62ZVDFKS.js");
798
+ const summary = await summarizeTiers(storage);
799
+ const storageDir = storage.dir ?? "";
800
+ const journalPath = storageDir.length > 0 ? path.join(storageDir, "state", "tier-migration-journal.jsonl") : null;
801
+ let recentMigrations = 0;
802
+ const demotionReasons = {};
803
+ const sevenDaysAgoMs = Date.now() - 7 * 864e5;
804
+ if (journalPath) {
805
+ try {
806
+ const { readFile: readFile2 } = await import("fs/promises");
807
+ const raw = await readFile2(journalPath, "utf-8");
808
+ for (const line of raw.split("\n")) {
809
+ const trimmed = line.trim();
810
+ if (trimmed.length === 0) continue;
811
+ try {
812
+ const entry = JSON.parse(trimmed);
813
+ const tsMs = entry.ts ? Date.parse(entry.ts) : NaN;
814
+ if (Number.isFinite(tsMs) && tsMs >= sevenDaysAgoMs && entry.changed === true) {
815
+ recentMigrations += 1;
816
+ if (entry.fromTier === "hot" && entry.toTier === "cold" && typeof entry.reason === "string") {
817
+ const reason = entry.reason;
818
+ demotionReasons[reason] = (demotionReasons[reason] ?? 0) + 1;
819
+ }
820
+ }
821
+ } catch {
822
+ }
823
+ }
824
+ } catch {
825
+ }
826
+ }
827
+ const topDemotionReasons = Object.entries(demotionReasons).sort((a, b) => b[1] - a[1] || a[0].localeCompare(b[0])).slice(0, 5).map(([reason, count]) => ({ reason, count }));
828
+ const statusParts = Object.entries(summary.byStatus).sort((a, b) => b[1] - a[1] || a[0].localeCompare(b[0])).slice(0, 6).map(([s, n]) => `${s}: ${n}`).join(", ");
829
+ return {
830
+ key: "tier_distribution",
831
+ status: "ok",
832
+ summary: `Tier distribution: hot=${summary.byTier.hot}, cold=${summary.byTier.cold}` + (summary.forgottenCount > 0 ? `, forgotten=${summary.forgottenCount}` : "") + `. Total: ${summary.total}.` + (recentMigrations > 0 ? ` Recent migrations (7d): ${recentMigrations}.` : ""),
833
+ details: {
834
+ total: summary.total,
835
+ byTier: summary.byTier,
836
+ byStatus: summary.byStatus,
837
+ forgottenCount: summary.forgottenCount,
838
+ statusSummary: statusParts,
839
+ recentMigrations,
840
+ topDemotionReasons
841
+ }
842
+ };
843
+ } catch (err) {
844
+ return {
845
+ key: "tier_distribution",
846
+ status: "ok",
847
+ summary: "Tier distribution unavailable \u2014 could not enumerate memories.",
848
+ details: { error: String(err) }
849
+ };
850
+ }
851
+ }
852
+ async function summarizeDreamsPhases(config, storage = new StorageManager(config.memoryDir)) {
853
+ const phases = config.dreamsPhases;
854
+ const meta = await storage.loadMeta();
855
+ let deepSleepLastRun = null;
856
+ let deepSleepLastRunWarning = null;
857
+ try {
858
+ const runsDir = path.join(config.memoryDir, "state", "memory-governance", "runs");
859
+ const runIds = (await readdir(runsDir)).sort().reverse();
860
+ if (runIds.length > 0) {
861
+ const latestRunId = runIds[0];
862
+ const manifestPath = path.join(
863
+ runsDir,
864
+ latestRunId,
865
+ "manifest.json"
866
+ );
867
+ const raw = await readFile(manifestPath, "utf-8");
868
+ const parsed = JSON.parse(raw);
869
+ if (typeof parsed.createdAt === "string" && parsed.createdAt.length > 0) {
870
+ deepSleepLastRun = parsed.createdAt;
871
+ }
872
+ }
873
+ } catch (error) {
874
+ if (!isMissingPathError(error)) {
875
+ deepSleepLastRunWarning = `Could not read latest governance run manifest: ${formatUnknownError(error)}`;
876
+ }
877
+ }
878
+ const phaseLines = [
879
+ `lightSleep: enabled=${phases.lightSleep.enabled}, cadenceMs=${phases.lightSleep.cadenceMs}, promoteHeat=${phases.lightSleep.promoteHeatThreshold}, staleDecay=${phases.lightSleep.staleDecayThreshold}, archiveDecay=${phases.lightSleep.archiveDecayThreshold}, filterStale=${phases.lightSleep.filterStaleEnabled}, lastRun=${meta.lastExtractionAt ?? "never"}`,
880
+ `rem: enabled=${phases.rem.enabled}, cadenceMs=${phases.rem.cadenceMs}, similarity=${phases.rem.similarityThreshold}, minCluster=${phases.rem.minClusterSize}, maxPerRun=${phases.rem.maxPerRun}, minIntervalMs=${phases.rem.minIntervalMs}, lastRun=${meta.lastConsolidationAt ?? "never"}`,
881
+ `deepSleep: enabled=${phases.deepSleep.enabled}, cadenceMs=${phases.deepSleep.cadenceMs}, versioning=${phases.deepSleep.versioningEnabled}, versioningMaxPerPage=${phases.deepSleep.versioningMaxPerPage}, lastRun=${deepSleepLastRun ?? "never"}`
882
+ ];
883
+ return {
884
+ key: "dreams_phases",
885
+ status: deepSleepLastRunWarning ? "warn" : "ok",
886
+ summary: `Dreams pipeline phases: ${phaseLines.join("; ")}${deepSleepLastRunWarning ? `; ${deepSleepLastRunWarning}` : ""}`,
887
+ remediation: deepSleepLastRunWarning ? "Inspect state/memory-governance/runs and repair or remove unreadable governance run artifacts." : void 0,
888
+ details: {
889
+ lightSleep: {
890
+ enabled: phases.lightSleep.enabled,
891
+ cadenceMs: phases.lightSleep.cadenceMs,
892
+ promoteHeatThreshold: phases.lightSleep.promoteHeatThreshold,
893
+ staleDecayThreshold: phases.lightSleep.staleDecayThreshold,
894
+ archiveDecayThreshold: phases.lightSleep.archiveDecayThreshold,
895
+ filterStaleEnabled: phases.lightSleep.filterStaleEnabled,
896
+ lastRun: meta.lastExtractionAt ?? null
897
+ },
898
+ rem: {
899
+ enabled: phases.rem.enabled,
900
+ cadenceMs: phases.rem.cadenceMs,
901
+ similarityThreshold: phases.rem.similarityThreshold,
902
+ minClusterSize: phases.rem.minClusterSize,
903
+ maxPerRun: phases.rem.maxPerRun,
904
+ minIntervalMs: phases.rem.minIntervalMs,
905
+ lastRun: meta.lastConsolidationAt ?? null
906
+ },
907
+ deepSleep: {
908
+ enabled: phases.deepSleep.enabled,
909
+ cadenceMs: phases.deepSleep.cadenceMs,
910
+ versioningEnabled: phases.deepSleep.versioningEnabled,
911
+ versioningMaxPerPage: phases.deepSleep.versioningMaxPerPage,
912
+ lastRun: deepSleepLastRun,
913
+ warning: deepSleepLastRunWarning
914
+ }
915
+ }
916
+ };
917
+ }
918
+ function summarizeSecurityMitigations(config) {
919
+ const budgetEnabled = config.recallCrossNamespaceBudgetEnabled === true;
920
+ const anomalyEnabled = config.recallAuditAnomalyDetectionEnabled === true;
921
+ if (!budgetEnabled && !anomalyEnabled) {
922
+ return {
923
+ key: "security_mitigations",
924
+ status: "warn",
925
+ summary: "Memory-extraction mitigations are disabled (cross-namespace budget and anomaly detection off).",
926
+ remediation: "Enable recallCrossNamespaceBudgetEnabled and/or recallAuditAnomalyDetectionEnabled for production deployments. See docs/security/memory-extraction-threat-model.md.",
927
+ details: {
928
+ budgetEnabled: false,
929
+ anomalyDetectionEnabled: false
930
+ }
931
+ };
932
+ }
933
+ const details = {
934
+ budgetEnabled,
935
+ anomalyDetectionEnabled: anomalyEnabled
936
+ };
937
+ if (budgetEnabled) {
938
+ details.budgetConfig = {
939
+ windowMs: config.recallCrossNamespaceBudgetWindowMs,
940
+ softLimit: config.recallCrossNamespaceBudgetSoftLimit,
941
+ hardLimit: config.recallCrossNamespaceBudgetHardLimit
942
+ };
943
+ }
944
+ if (anomalyEnabled) {
945
+ details.anomalyConfig = {
946
+ windowMs: config.recallAuditAnomalyWindowMs,
947
+ repeatQueryLimit: config.recallAuditAnomalyRepeatQueryLimit,
948
+ namespaceWalkLimit: config.recallAuditAnomalyNamespaceWalkLimit,
949
+ highCardinalityLimit: config.recallAuditAnomalyHighCardinalityLimit,
950
+ rapidFireLimit: config.recallAuditAnomalyRapidFireLimit
951
+ };
952
+ }
953
+ return {
954
+ key: "security_mitigations",
955
+ status: "ok",
956
+ summary: `Memory-extraction mitigation config enabled: ${budgetEnabled ? "budget" : ""}${budgetEnabled && anomalyEnabled ? ", " : ""}${anomalyEnabled ? "anomaly detection" : ""}.`,
957
+ details: { ...details, configOnly: true }
958
+ };
959
+ }
960
+ async function summarizeObservationThroughput(memoryDir) {
961
+ try {
962
+ const stats = await readJudgeVerdictStats(memoryDir);
963
+ if (stats.total === 0) {
964
+ return {
965
+ key: "observations",
966
+ status: "ok",
967
+ summary: "No observations recorded yet (extraction-judge telemetry ledger is empty or missing).",
968
+ details: { total: 0, accept: 0, reject: 0, defer: 0, lastObservedAt: null }
969
+ };
970
+ }
971
+ const acceptPct = (stats.accept / stats.total * 100).toFixed(1);
972
+ const rejectPct = (stats.reject / stats.total * 100).toFixed(1);
973
+ const deferPct = (stats.defer / stats.total * 100).toFixed(1);
974
+ return {
975
+ key: "observations",
976
+ status: "ok",
977
+ summary: `${stats.total} observations recorded: accept=${acceptPct}%, reject=${rejectPct}%, defer=${deferPct}%. Last observed: ${stats.lastTs ?? "unknown"}.`,
978
+ details: {
979
+ total: stats.total,
980
+ accept: stats.accept,
981
+ reject: stats.reject,
982
+ defer: stats.defer,
983
+ deferCapTriggered: stats.deferCapTriggered,
984
+ deferRate: stats.deferRate,
985
+ meanElapsedMs: stats.meanElapsedMs,
986
+ firstObservedAt: stats.firstTs ?? null,
987
+ lastObservedAt: stats.lastTs ?? null
988
+ }
989
+ };
990
+ } catch (err) {
991
+ return {
992
+ key: "observations",
993
+ status: "warn",
994
+ summary: "Could not read observation telemetry ledger.",
995
+ remediation: "Retry `remnic doctor` after ensuring the memory state directory is readable.",
996
+ details: { error: String(err) }
997
+ };
998
+ }
999
+ }
1000
+ async function summarizeConsolidationProvenance(storage, config) {
1001
+ let report;
1002
+ try {
1003
+ report = await runConsolidationProvenanceCheck({
1004
+ storage,
1005
+ memoryDir: config.memoryDir,
1006
+ // Honor the configured sidecar directory (PR #634 review): when an
1007
+ // operator overrides `versioningSidecarDir`, the default `.versions`
1008
+ // would point at the wrong location and every entry would report as
1009
+ // missing. Undefined falls back to the helper's default.
1010
+ sidecarDir: config.versioningSidecarDir
1011
+ });
1012
+ } catch (err) {
1013
+ return {
1014
+ key: "consolidation_provenance",
1015
+ status: "warn",
1016
+ summary: "Could not run consolidation-provenance integrity check.",
1017
+ remediation: "Ensure the memory directory is readable and rerun `remnic doctor`.",
1018
+ details: { error: String(err) }
1019
+ };
1020
+ }
1021
+ if (report.issues.length === 0) {
1022
+ return {
1023
+ key: "consolidation_provenance",
1024
+ status: "ok",
1025
+ summary: report.withProvenance === 0 ? "No consolidation-provenance memories on disk yet." : `${report.withProvenance} consolidation-provenance memories verified (no broken references).`,
1026
+ details: report
1027
+ };
1028
+ }
1029
+ return {
1030
+ key: "consolidation_provenance",
1031
+ status: "warn",
1032
+ summary: `${report.issues.length} consolidation-provenance integrity issue(s) detected across ${report.withProvenance} memories with provenance frontmatter.`,
1033
+ remediation: "Broken pointers are informational. Inspect flagged memories, and if they should resolve, re-snapshot via a consolidation pass or accept pruning.",
1034
+ details: report
1035
+ };
1036
+ }
1037
+ function getMemoryAgeBand(memory, now) {
1038
+ const created = Date.parse(memory.frontmatter.created ?? "");
1039
+ if (!Number.isFinite(created)) return "unknown";
1040
+ const ageDays = Math.max(0, Math.floor((now.getTime() - created) / 864e5));
1041
+ if (ageDays < 7) return "0_6d";
1042
+ if (ageDays < 30) return "7_29d";
1043
+ if (ageDays < 90) return "30_89d";
1044
+ return "90d_plus";
1045
+ }
1046
+ async function dirSize(targetPath) {
1047
+ try {
1048
+ const info = await stat(targetPath);
1049
+ if (info.isFile()) return info.size;
1050
+ if (!info.isDirectory()) return 0;
1051
+ } catch {
1052
+ return 0;
1053
+ }
1054
+ let total = 0;
1055
+ let entries;
1056
+ try {
1057
+ entries = await readdir(targetPath, { withFileTypes: true });
1058
+ } catch {
1059
+ return 0;
1060
+ }
1061
+ for (const entry of entries) {
1062
+ total += await dirSize(path.join(targetPath, entry.name));
1063
+ }
1064
+ return total;
1065
+ }
1066
+ async function summarizeStorageFootprint(memoryDir) {
1067
+ const topLevel = [
1068
+ "facts",
1069
+ "entities",
1070
+ "questions",
1071
+ "corrections",
1072
+ "artifacts",
1073
+ "state",
1074
+ "identity",
1075
+ "namespaces",
1076
+ "summaries",
1077
+ "profile.md"
1078
+ ];
1079
+ const byTopLevel = {};
1080
+ let bytes = 0;
1081
+ for (const name of topLevel) {
1082
+ const size = await dirSize(path.join(memoryDir, name));
1083
+ if (size > 0) {
1084
+ byTopLevel[name] = size;
1085
+ bytes += size;
1086
+ }
1087
+ }
1088
+ return { bytes, byTopLevel };
1089
+ }
1090
+ async function runOperatorInventory(options) {
1091
+ const now = options.now ?? /* @__PURE__ */ new Date();
1092
+ const config = options.orchestrator.config;
1093
+ const namespaceEntries = await listNamespaces({ config });
1094
+ const uniqueRootEntries = /* @__PURE__ */ new Map();
1095
+ for (const entry of namespaceEntries) {
1096
+ if (!uniqueRootEntries.has(entry.rootDir)) {
1097
+ uniqueRootEntries.set(entry.rootDir, { namespace: entry.namespace, rootDir: entry.rootDir });
1098
+ }
1099
+ }
1100
+ const categories = {};
1101
+ const statuses = {};
1102
+ const ageBands = {
1103
+ "0_6d": 0,
1104
+ "7_29d": 0,
1105
+ "30_89d": 0,
1106
+ "90d_plus": 0,
1107
+ unknown: 0
1108
+ };
1109
+ const namespaces = [];
1110
+ let totalMemories = 0;
1111
+ let totalEntities = 0;
1112
+ let archived = 0;
1113
+ let pendingReview = 0;
1114
+ let quarantined = 0;
1115
+ let rejected = 0;
1116
+ for (const entry of uniqueRootEntries.values()) {
1117
+ const storage = new StorageManager(entry.rootDir);
1118
+ const memories = await storage.readAllMemories();
1119
+ const entities = await storage.readAllEntityFiles();
1120
+ namespaces.push({
1121
+ namespace: entry.namespace,
1122
+ memoryCount: memories.length,
1123
+ entityCount: entities.length
1124
+ });
1125
+ totalMemories += memories.length;
1126
+ totalEntities += entities.length;
1127
+ for (const memory of memories) {
1128
+ const category = memory.frontmatter.category;
1129
+ categories[category] = (categories[category] ?? 0) + 1;
1130
+ const status = memory.frontmatter.status ?? "active";
1131
+ statuses[status] = (statuses[status] ?? 0) + 1;
1132
+ ageBands[getMemoryAgeBand(memory, now)] += 1;
1133
+ if (status === "archived") archived += 1;
1134
+ if (status === "pending_review") pendingReview += 1;
1135
+ if (status === "quarantined") quarantined += 1;
1136
+ if (status === "rejected") rejected += 1;
1137
+ }
1138
+ }
1139
+ const defaultStorage = new StorageManager(config.memoryDir);
1140
+ const profile = await defaultStorage.readProfile();
1141
+ const footprint = await summarizeStorageFootprint(config.memoryDir);
1142
+ const reviewRunId = (await listMemoryGovernanceRuns(config.memoryDir))[0];
1143
+ let reviewQueue = 0;
1144
+ if (reviewRunId) {
1145
+ try {
1146
+ reviewQueue = (await readMemoryGovernanceRunArtifact(config.memoryDir, reviewRunId)).reviewQueue.length;
1147
+ } catch {
1148
+ reviewQueue = 0;
1149
+ }
1150
+ }
1151
+ const conversationIndex = await options.orchestrator.getConversationIndexHealth();
1152
+ const nativeKnowledgeStatus = await summarizeNativeKnowledgeStatus(config);
1153
+ return {
1154
+ schemaVersion: 1,
1155
+ generatedAt: now.toISOString(),
1156
+ memoryDir: config.memoryDir,
1157
+ totals: {
1158
+ memories: totalMemories,
1159
+ entities: totalEntities,
1160
+ namespaces: namespaceEntries.length,
1161
+ reviewQueue,
1162
+ storageBytes: footprint.bytes
1163
+ },
1164
+ categories,
1165
+ statuses,
1166
+ namespaces,
1167
+ ageBands,
1168
+ profile: {
1169
+ exists: profile.length > 0,
1170
+ chars: profile.length,
1171
+ lines: profile.length > 0 ? profile.split("\n").length : 0
1172
+ },
1173
+ storageFootprint: footprint,
1174
+ archivePressure: {
1175
+ archived,
1176
+ pendingReview,
1177
+ quarantined,
1178
+ rejected
1179
+ },
1180
+ conversationIndex: {
1181
+ enabled: conversationIndex.enabled,
1182
+ backend: conversationIndex.backend,
1183
+ status: conversationIndex.status,
1184
+ chunkDocCount: conversationIndex.chunkDocCount,
1185
+ lastUpdateAt: conversationIndex.lastUpdateAt
1186
+ },
1187
+ nativeKnowledge: {
1188
+ enabled: nativeKnowledgeStatus.enabled,
1189
+ curatedIncludeSync: nativeKnowledgeStatus.curatedIncludeSync,
1190
+ obsidianSync: nativeKnowledgeStatus.obsidianSync,
1191
+ openclawWorkspaceSync: nativeKnowledgeStatus.openclawWorkspaceSync
1192
+ }
1193
+ };
1194
+ }
1195
+ async function runBenchmarkRecall(options) {
1196
+ const now = options.now ?? /* @__PURE__ */ new Date();
1197
+ const status = await getEvalHarnessStatus({
1198
+ memoryDir: options.config.memoryDir,
1199
+ evalStoreDir: options.config.evalStoreDir,
1200
+ enabled: options.config.evalHarnessEnabled,
1201
+ shadowModeEnabled: options.config.evalShadowModeEnabled,
1202
+ baselineSnapshotsEnabled: options.config.benchmarkBaselineSnapshotsEnabled,
1203
+ memoryRedTeamBenchEnabled: options.config.memoryRedTeamBenchEnabled
1204
+ });
1205
+ if (options.createSnapshot && options.snapshotId) {
1206
+ const snapshot = await createEvalBaselineSnapshot({
1207
+ memoryDir: options.config.memoryDir,
1208
+ evalStoreDir: options.config.evalStoreDir,
1209
+ baselineSnapshotsEnabled: options.config.benchmarkBaselineSnapshotsEnabled,
1210
+ snapshotId: options.snapshotId,
1211
+ notes: options.snapshotNotes,
1212
+ gitRef: options.gitRef,
1213
+ createdAt: options.createdAt
1214
+ });
1215
+ return {
1216
+ schemaVersion: 1,
1217
+ generatedAt: now.toISOString(),
1218
+ mode: "snapshot",
1219
+ status,
1220
+ snapshot: {
1221
+ targetPath: snapshot.targetPath,
1222
+ snapshotId: snapshot.snapshot.snapshotId
1223
+ }
1224
+ };
1225
+ }
1226
+ if (options.baseEvalStoreDir && options.candidateEvalStoreDir) {
1227
+ const ciGate = await runEvalBenchmarkCiGate({
1228
+ baseEvalStoreDir: options.baseEvalStoreDir,
1229
+ candidateEvalStoreDir: options.candidateEvalStoreDir
1230
+ });
1231
+ return {
1232
+ schemaVersion: 1,
1233
+ generatedAt: now.toISOString(),
1234
+ mode: "ci-gate",
1235
+ status,
1236
+ ciGate
1237
+ };
1238
+ }
1239
+ if (options.snapshotId) {
1240
+ const baselineReport = await runEvalBaselineDeltaReport({
1241
+ memoryDir: options.config.memoryDir,
1242
+ evalStoreDir: options.config.evalStoreDir,
1243
+ benchmarkDeltaReporterEnabled: options.config.benchmarkDeltaReporterEnabled,
1244
+ snapshotId: options.snapshotId
1245
+ });
1246
+ return {
1247
+ schemaVersion: 1,
1248
+ generatedAt: now.toISOString(),
1249
+ mode: "baseline-report",
1250
+ status,
1251
+ baselineReport
1252
+ };
1253
+ }
1254
+ if (options.validatePath) {
1255
+ const validate = await validateEvalBenchmarkPack(options.validatePath, {
1256
+ memoryRedTeamBenchEnabled: options.config.memoryRedTeamBenchEnabled
1257
+ });
1258
+ return {
1259
+ schemaVersion: 1,
1260
+ generatedAt: now.toISOString(),
1261
+ mode: "validate",
1262
+ status,
1263
+ validate
1264
+ };
1265
+ }
1266
+ return {
1267
+ schemaVersion: 1,
1268
+ generatedAt: now.toISOString(),
1269
+ mode: "status",
1270
+ status
1271
+ };
1272
+ }
1273
+ async function runOperatorRepair(options) {
1274
+ const now = options.now ?? /* @__PURE__ */ new Date();
1275
+ const dryRun = options.dryRun === true || options.apply !== true;
1276
+ const sessionCheck = await analyzeSessionIntegrity({ memoryDir: options.config.memoryDir });
1277
+ const sessionRepairPlan = planSessionRepair({
1278
+ report: sessionCheck,
1279
+ dryRun,
1280
+ allowSessionFileRepair: options.allowSessionFileRepair,
1281
+ sessionFilesDir: options.sessionFilesDir
1282
+ });
1283
+ const sessionRepairApply = await applySessionRepair({
1284
+ plan: sessionRepairPlan
1285
+ });
1286
+ const graphHealth = await analyzeGraphHealth(options.config.memoryDir, {
1287
+ entityGraphEnabled: options.config.entityGraphEnabled,
1288
+ timeGraphEnabled: options.config.timeGraphEnabled,
1289
+ causalGraphEnabled: options.config.causalGraphEnabled,
1290
+ includeRepairGuidance: true
1291
+ });
1292
+ return {
1293
+ schemaVersion: 1,
1294
+ generatedAt: now.toISOString(),
1295
+ dryRun,
1296
+ sessionCheck,
1297
+ sessionRepairPlan,
1298
+ sessionRepairApply,
1299
+ graphHealth
1300
+ };
1301
+ }
1302
+
1303
+ export {
1304
+ runOperatorSetup,
1305
+ runOperatorConfigReview,
1306
+ runOperatorDoctor,
1307
+ summarizeMemoryWorthLegacyCounters,
1308
+ summarizeBufferSurpriseDistribution,
1309
+ summarizeTierDistribution,
1310
+ summarizeDreamsPhases,
1311
+ summarizeObservationThroughput,
1312
+ summarizeConsolidationProvenance,
1313
+ runOperatorInventory,
1314
+ runBenchmarkRecall,
1315
+ runOperatorRepair
1316
+ };
1317
+ //# sourceMappingURL=chunk-UXHQAFNA.js.map