@remnic/core 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (551) hide show
  1. package/dist/abstraction-nodes.d.ts +52 -0
  2. package/dist/abstraction-nodes.js +15 -0
  3. package/dist/abstraction-nodes.js.map +1 -0
  4. package/dist/access-cli.d.ts +5 -0
  5. package/dist/access-cli.js +308 -0
  6. package/dist/access-cli.js.map +1 -0
  7. package/dist/access-http.d.ts +158 -0
  8. package/dist/access-http.js +32 -0
  9. package/dist/access-http.js.map +1 -0
  10. package/dist/access-idempotency.d.ts +31 -0
  11. package/dist/access-idempotency.js +11 -0
  12. package/dist/access-idempotency.js.map +1 -0
  13. package/dist/access-mcp.d.ts +76 -0
  14. package/dist/access-mcp.js +8 -0
  15. package/dist/access-mcp.js.map +1 -0
  16. package/dist/access-schema.d.ts +266 -0
  17. package/dist/access-schema.js +29 -0
  18. package/dist/access-schema.js.map +1 -0
  19. package/dist/access-service.d.ts +614 -0
  20. package/dist/access-service.js +32 -0
  21. package/dist/access-service.js.map +1 -0
  22. package/dist/behavior-learner.d.ts +16 -0
  23. package/dist/behavior-learner.js +124 -0
  24. package/dist/behavior-learner.js.map +1 -0
  25. package/dist/behavior-signals.d.ts +15 -0
  26. package/dist/behavior-signals.js +11 -0
  27. package/dist/behavior-signals.js.map +1 -0
  28. package/dist/bootstrap.d.ts +46 -0
  29. package/dist/bootstrap.js +9 -0
  30. package/dist/bootstrap.js.map +1 -0
  31. package/dist/boxes.d.ts +93 -0
  32. package/dist/boxes.js +14 -0
  33. package/dist/boxes.js.map +1 -0
  34. package/dist/buffer.d.ts +22 -0
  35. package/dist/buffer.js +9 -0
  36. package/dist/buffer.js.map +1 -0
  37. package/dist/calibration.d.ts +81 -0
  38. package/dist/calibration.js +239 -0
  39. package/dist/calibration.js.map +1 -0
  40. package/dist/causal-behavior.d.ts +79 -0
  41. package/dist/causal-behavior.js +190 -0
  42. package/dist/causal-behavior.js.map +1 -0
  43. package/dist/causal-chain.d.ts +61 -0
  44. package/dist/causal-chain.js +24 -0
  45. package/dist/causal-chain.js.map +1 -0
  46. package/dist/causal-consolidation.d.ts +71 -0
  47. package/dist/causal-consolidation.js +211 -0
  48. package/dist/causal-consolidation.js.map +1 -0
  49. package/dist/causal-retrieval.d.ts +44 -0
  50. package/dist/causal-retrieval.js +184 -0
  51. package/dist/causal-retrieval.js.map +1 -0
  52. package/dist/causal-trajectory-graph.d.ts +13 -0
  53. package/dist/causal-trajectory-graph.js +59 -0
  54. package/dist/causal-trajectory-graph.js.map +1 -0
  55. package/dist/causal-trajectory.d.ts +68 -0
  56. package/dist/causal-trajectory.js +18 -0
  57. package/dist/causal-trajectory.js.map +1 -0
  58. package/dist/chunk-2CJCWDMR.js +87 -0
  59. package/dist/chunk-2CJCWDMR.js.map +1 -0
  60. package/dist/chunk-2NMMFZ5T.js +216 -0
  61. package/dist/chunk-2NMMFZ5T.js.map +1 -0
  62. package/dist/chunk-2PO5ZRKV.js +103 -0
  63. package/dist/chunk-2PO5ZRKV.js.map +1 -0
  64. package/dist/chunk-3QKK7QOS.js +154 -0
  65. package/dist/chunk-3QKK7QOS.js.map +1 -0
  66. package/dist/chunk-3SLRNYNG.js +26 -0
  67. package/dist/chunk-3SLRNYNG.js.map +1 -0
  68. package/dist/chunk-4A24LIM2.js +68 -0
  69. package/dist/chunk-4A24LIM2.js.map +1 -0
  70. package/dist/chunk-6HZ6AO2P.js +164 -0
  71. package/dist/chunk-6HZ6AO2P.js.map +1 -0
  72. package/dist/chunk-763GUIOU.js +302 -0
  73. package/dist/chunk-763GUIOU.js.map +1 -0
  74. package/dist/chunk-AAI7JARD.js +173 -0
  75. package/dist/chunk-AAI7JARD.js.map +1 -0
  76. package/dist/chunk-B7LOFDVE.js +112 -0
  77. package/dist/chunk-B7LOFDVE.js.map +1 -0
  78. package/dist/chunk-BDFZXRSO.js +318 -0
  79. package/dist/chunk-BDFZXRSO.js.map +1 -0
  80. package/dist/chunk-BOUYNNYD.js +707 -0
  81. package/dist/chunk-BOUYNNYD.js.map +1 -0
  82. package/dist/chunk-BRK4ODMI.js +60 -0
  83. package/dist/chunk-BRK4ODMI.js.map +1 -0
  84. package/dist/chunk-C6QPK5GG.js +111 -0
  85. package/dist/chunk-C6QPK5GG.js.map +1 -0
  86. package/dist/chunk-C7VW7C3F.js +117 -0
  87. package/dist/chunk-C7VW7C3F.js.map +1 -0
  88. package/dist/chunk-CDW777AI.js +621 -0
  89. package/dist/chunk-CDW777AI.js.map +1 -0
  90. package/dist/chunk-CULXMQJH.js +185 -0
  91. package/dist/chunk-CULXMQJH.js.map +1 -0
  92. package/dist/chunk-CXWFUJR2.js +1203 -0
  93. package/dist/chunk-CXWFUJR2.js.map +1 -0
  94. package/dist/chunk-DGXUHMOV.js +61 -0
  95. package/dist/chunk-DGXUHMOV.js.map +1 -0
  96. package/dist/chunk-DM2T26WE.js +61 -0
  97. package/dist/chunk-DM2T26WE.js.map +1 -0
  98. package/dist/chunk-DORBM6OB.js +81 -0
  99. package/dist/chunk-DORBM6OB.js.map +1 -0
  100. package/dist/chunk-DT5TVLJE.js +32 -0
  101. package/dist/chunk-DT5TVLJE.js.map +1 -0
  102. package/dist/chunk-EEQLFRUM.js +89 -0
  103. package/dist/chunk-EEQLFRUM.js.map +1 -0
  104. package/dist/chunk-EQINRHYR.js +672 -0
  105. package/dist/chunk-EQINRHYR.js.map +1 -0
  106. package/dist/chunk-ESSMF2FR.js +146 -0
  107. package/dist/chunk-ESSMF2FR.js.map +1 -0
  108. package/dist/chunk-ETOW6ACV.js +158 -0
  109. package/dist/chunk-ETOW6ACV.js.map +1 -0
  110. package/dist/chunk-FYIYMQ5N.js +221 -0
  111. package/dist/chunk-FYIYMQ5N.js.map +1 -0
  112. package/dist/chunk-G3AG3KZN.js +78 -0
  113. package/dist/chunk-G3AG3KZN.js.map +1 -0
  114. package/dist/chunk-GJR6D6KC.js +61 -0
  115. package/dist/chunk-GJR6D6KC.js.map +1 -0
  116. package/dist/chunk-GPGBSNKM.js +380 -0
  117. package/dist/chunk-GPGBSNKM.js.map +1 -0
  118. package/dist/chunk-H63EDPFJ.js +57 -0
  119. package/dist/chunk-H63EDPFJ.js.map +1 -0
  120. package/dist/chunk-HG2NKWR2.js +185 -0
  121. package/dist/chunk-HG2NKWR2.js.map +1 -0
  122. package/dist/chunk-HL4DB7TO.js +13 -0
  123. package/dist/chunk-HL4DB7TO.js.map +1 -0
  124. package/dist/chunk-HLBYLYRD.js +346 -0
  125. package/dist/chunk-HLBYLYRD.js.map +1 -0
  126. package/dist/chunk-HLXVTBF3.js +109 -0
  127. package/dist/chunk-HLXVTBF3.js.map +1 -0
  128. package/dist/chunk-IFFFR3MR.js +68 -0
  129. package/dist/chunk-IFFFR3MR.js.map +1 -0
  130. package/dist/chunk-ISY75RLM.js +1027 -0
  131. package/dist/chunk-ISY75RLM.js.map +1 -0
  132. package/dist/chunk-IZME7KW2.js +1886 -0
  133. package/dist/chunk-IZME7KW2.js.map +1 -0
  134. package/dist/chunk-J3BT33K7.js +720 -0
  135. package/dist/chunk-J3BT33K7.js.map +1 -0
  136. package/dist/chunk-J47FNDR7.js +113 -0
  137. package/dist/chunk-J47FNDR7.js.map +1 -0
  138. package/dist/chunk-JWPLJLDU.js +63 -0
  139. package/dist/chunk-JWPLJLDU.js.map +1 -0
  140. package/dist/chunk-K6WK37A6.js +865 -0
  141. package/dist/chunk-K6WK37A6.js.map +1 -0
  142. package/dist/chunk-KL4CP4SB.js +130 -0
  143. package/dist/chunk-KL4CP4SB.js.map +1 -0
  144. package/dist/chunk-KT4NEUNF.js +315 -0
  145. package/dist/chunk-KT4NEUNF.js.map +1 -0
  146. package/dist/chunk-KWBU5S5U.js +42 -0
  147. package/dist/chunk-KWBU5S5U.js.map +1 -0
  148. package/dist/chunk-L5RPWGFK.js +59 -0
  149. package/dist/chunk-L5RPWGFK.js.map +1 -0
  150. package/dist/chunk-L7WO3MZ4.js +128 -0
  151. package/dist/chunk-L7WO3MZ4.js.map +1 -0
  152. package/dist/chunk-LIRZNNUP.js +74 -0
  153. package/dist/chunk-LIRZNNUP.js.map +1 -0
  154. package/dist/chunk-LK6SGL53.js +22 -0
  155. package/dist/chunk-LK6SGL53.js.map +1 -0
  156. package/dist/chunk-LOBRX7VD.js +200 -0
  157. package/dist/chunk-LOBRX7VD.js.map +1 -0
  158. package/dist/chunk-LPSF4OQH.js +47 -0
  159. package/dist/chunk-LPSF4OQH.js.map +1 -0
  160. package/dist/chunk-LU3GQNDQ.js +152 -0
  161. package/dist/chunk-LU3GQNDQ.js.map +1 -0
  162. package/dist/chunk-M5KEYE5E.js +350 -0
  163. package/dist/chunk-M5KEYE5E.js.map +1 -0
  164. package/dist/chunk-M62O4P4T.js +41 -0
  165. package/dist/chunk-M62O4P4T.js.map +1 -0
  166. package/dist/chunk-MARWOCVP.js +48 -0
  167. package/dist/chunk-MARWOCVP.js.map +1 -0
  168. package/dist/chunk-MDDAA2AO.js +925 -0
  169. package/dist/chunk-MDDAA2AO.js.map +1 -0
  170. package/dist/chunk-MWGVGUIS.js +198 -0
  171. package/dist/chunk-MWGVGUIS.js.map +1 -0
  172. package/dist/chunk-N5AKDXAI.js +74 -0
  173. package/dist/chunk-N5AKDXAI.js.map +1 -0
  174. package/dist/chunk-NGAVDO7E.js +115 -0
  175. package/dist/chunk-NGAVDO7E.js.map +1 -0
  176. package/dist/chunk-NTTLPF7F.js +283 -0
  177. package/dist/chunk-NTTLPF7F.js.map +1 -0
  178. package/dist/chunk-ONRU4L2N.js +240 -0
  179. package/dist/chunk-ONRU4L2N.js.map +1 -0
  180. package/dist/chunk-ORZMT74A.js +209 -0
  181. package/dist/chunk-ORZMT74A.js.map +1 -0
  182. package/dist/chunk-OTAVQCSF.js +268 -0
  183. package/dist/chunk-OTAVQCSF.js.map +1 -0
  184. package/dist/chunk-PGK3VUHN.js +160 -0
  185. package/dist/chunk-PGK3VUHN.js.map +1 -0
  186. package/dist/chunk-Q6FETXJA.js +1362 -0
  187. package/dist/chunk-Q6FETXJA.js.map +1 -0
  188. package/dist/chunk-QANCTXQF.js +271 -0
  189. package/dist/chunk-QANCTXQF.js.map +1 -0
  190. package/dist/chunk-QCCCQT3O.js +189 -0
  191. package/dist/chunk-QCCCQT3O.js.map +1 -0
  192. package/dist/chunk-QDOSNLB4.js +1048 -0
  193. package/dist/chunk-QDOSNLB4.js.map +1 -0
  194. package/dist/chunk-QFQVZOGA.js +2168 -0
  195. package/dist/chunk-QFQVZOGA.js.map +1 -0
  196. package/dist/chunk-QPKFPHOO.js +178 -0
  197. package/dist/chunk-QPKFPHOO.js.map +1 -0
  198. package/dist/chunk-QSVPYQPG.js +268 -0
  199. package/dist/chunk-QSVPYQPG.js.map +1 -0
  200. package/dist/chunk-QWUUMMIK.js +3045 -0
  201. package/dist/chunk-QWUUMMIK.js.map +1 -0
  202. package/dist/chunk-QY2BHY5O.js +2378 -0
  203. package/dist/chunk-QY2BHY5O.js.map +1 -0
  204. package/dist/chunk-SCHEKPYH.js +349 -0
  205. package/dist/chunk-SCHEKPYH.js.map +1 -0
  206. package/dist/chunk-SCU65EZI.js +15 -0
  207. package/dist/chunk-SCU65EZI.js.map +1 -0
  208. package/dist/chunk-T4WRIV2C.js +170 -0
  209. package/dist/chunk-T4WRIV2C.js.map +1 -0
  210. package/dist/chunk-TKO4HZCK.js +1852 -0
  211. package/dist/chunk-TKO4HZCK.js.map +1 -0
  212. package/dist/chunk-TP4FZJIZ.js +93 -0
  213. package/dist/chunk-TP4FZJIZ.js.map +1 -0
  214. package/dist/chunk-TPB3I2AC.js +403 -0
  215. package/dist/chunk-TPB3I2AC.js.map +1 -0
  216. package/dist/chunk-TVVVQQAK.js +1431 -0
  217. package/dist/chunk-TVVVQQAK.js.map +1 -0
  218. package/dist/chunk-U4PV25RD.js +14 -0
  219. package/dist/chunk-U4PV25RD.js.map +1 -0
  220. package/dist/chunk-UCYSTFZR.js +284 -0
  221. package/dist/chunk-UCYSTFZR.js.map +1 -0
  222. package/dist/chunk-UHGBNIOS.js +205 -0
  223. package/dist/chunk-UHGBNIOS.js.map +1 -0
  224. package/dist/chunk-UIYZ5T3I.js +108 -0
  225. package/dist/chunk-UIYZ5T3I.js.map +1 -0
  226. package/dist/chunk-UV2FO7J4.js +747 -0
  227. package/dist/chunk-UV2FO7J4.js.map +1 -0
  228. package/dist/chunk-UZB5KHKX.js +63 -0
  229. package/dist/chunk-UZB5KHKX.js.map +1 -0
  230. package/dist/chunk-V3RXWQIE.js +626 -0
  231. package/dist/chunk-V3RXWQIE.js.map +1 -0
  232. package/dist/chunk-V4YC4LUK.js +444 -0
  233. package/dist/chunk-V4YC4LUK.js.map +1 -0
  234. package/dist/chunk-VEWZZM3H.js +133 -0
  235. package/dist/chunk-VEWZZM3H.js.map +1 -0
  236. package/dist/chunk-WWIQTB2Y.js +98 -0
  237. package/dist/chunk-WWIQTB2Y.js.map +1 -0
  238. package/dist/chunk-X7XN6YU4.js +24 -0
  239. package/dist/chunk-X7XN6YU4.js.map +1 -0
  240. package/dist/chunk-XKECPATV.js +202 -0
  241. package/dist/chunk-XKECPATV.js.map +1 -0
  242. package/dist/chunk-XYIK4LF6.js +75 -0
  243. package/dist/chunk-XYIK4LF6.js.map +1 -0
  244. package/dist/chunk-Y27UJK6V.js +39 -0
  245. package/dist/chunk-Y27UJK6V.js.map +1 -0
  246. package/dist/chunk-Y4Z4I6WK.js +9 -0
  247. package/dist/chunk-Y4Z4I6WK.js.map +1 -0
  248. package/dist/chunk-YAPUAHAY.js +10761 -0
  249. package/dist/chunk-YAPUAHAY.js.map +1 -0
  250. package/dist/chunk-YAZNBMNF.js +92 -0
  251. package/dist/chunk-YAZNBMNF.js.map +1 -0
  252. package/dist/chunk-YCN4BVDK.js +66 -0
  253. package/dist/chunk-YCN4BVDK.js.map +1 -0
  254. package/dist/chunk-YNCQ7E4M.js +388 -0
  255. package/dist/chunk-YNCQ7E4M.js.map +1 -0
  256. package/dist/chunk-YNI4S5WT.js +143 -0
  257. package/dist/chunk-YNI4S5WT.js.map +1 -0
  258. package/dist/chunk-YRMVARQP.js +406 -0
  259. package/dist/chunk-YRMVARQP.js.map +1 -0
  260. package/dist/chunk-Z5AAYHUC.js +79 -0
  261. package/dist/chunk-Z5AAYHUC.js.map +1 -0
  262. package/dist/chunk-Z5LAYHGJ.js +15 -0
  263. package/dist/chunk-Z5LAYHGJ.js.map +1 -0
  264. package/dist/chunk-ZJLY4QSU.js +823 -0
  265. package/dist/chunk-ZJLY4QSU.js.map +1 -0
  266. package/dist/chunk-ZKYI7UVO.js +276 -0
  267. package/dist/chunk-ZKYI7UVO.js.map +1 -0
  268. package/dist/chunk-ZPKBYX2F.js +297 -0
  269. package/dist/chunk-ZPKBYX2F.js.map +1 -0
  270. package/dist/chunking.d.ts +48 -0
  271. package/dist/chunking.js +11 -0
  272. package/dist/chunking.js.map +1 -0
  273. package/dist/cli.d.ts +1162 -0
  274. package/dist/cli.js +7187 -0
  275. package/dist/cli.js.map +1 -0
  276. package/dist/commitment-ledger.d.ts +83 -0
  277. package/dist/commitment-ledger.js +19 -0
  278. package/dist/commitment-ledger.js.map +1 -0
  279. package/dist/compression-optimizer.d.ts +37 -0
  280. package/dist/compression-optimizer.js +13 -0
  281. package/dist/compression-optimizer.js.map +1 -0
  282. package/dist/config.d.ts +6 -0
  283. package/dist/config.js +12 -0
  284. package/dist/config.js.map +1 -0
  285. package/dist/cue-anchors.d.ts +50 -0
  286. package/dist/cue-anchors.js +15 -0
  287. package/dist/cue-anchors.js.map +1 -0
  288. package/dist/dashboard-runtime.d.ts +46 -0
  289. package/dist/dashboard-runtime.js +10 -0
  290. package/dist/dashboard-runtime.js.map +1 -0
  291. package/dist/day-summary.d.ts +6 -0
  292. package/dist/day-summary.js +10 -0
  293. package/dist/day-summary.js.map +1 -0
  294. package/dist/delinearize.d.ts +34 -0
  295. package/dist/delinearize.js +11 -0
  296. package/dist/delinearize.js.map +1 -0
  297. package/dist/embedding-fallback.d.ts +22 -0
  298. package/dist/embedding-fallback.js +8 -0
  299. package/dist/embedding-fallback.js.map +1 -0
  300. package/dist/engine-P26JFSVY.js +19 -0
  301. package/dist/engine-P26JFSVY.js.map +1 -0
  302. package/dist/entity-retrieval.d.ts +23 -0
  303. package/dist/entity-retrieval.js +24 -0
  304. package/dist/entity-retrieval.js.map +1 -0
  305. package/dist/evals.d.ts +282 -0
  306. package/dist/evals.js +32 -0
  307. package/dist/evals.js.map +1 -0
  308. package/dist/explicit-capture.d.ts +60 -0
  309. package/dist/explicit-capture.js +23 -0
  310. package/dist/explicit-capture.js.map +1 -0
  311. package/dist/extraction.d.ts +141 -0
  312. package/dist/extraction.js +22 -0
  313. package/dist/extraction.js.map +1 -0
  314. package/dist/fallback-llm.d.ts +95 -0
  315. package/dist/fallback-llm.js +12 -0
  316. package/dist/fallback-llm.js.map +1 -0
  317. package/dist/graph-dashboard-diff.d.ts +12 -0
  318. package/dist/graph-dashboard-diff.js +8 -0
  319. package/dist/graph-dashboard-diff.js.map +1 -0
  320. package/dist/graph-dashboard-key.d.ts +5 -0
  321. package/dist/graph-dashboard-key.js +7 -0
  322. package/dist/graph-dashboard-key.js.map +1 -0
  323. package/dist/graph-dashboard-parser.d.ts +20 -0
  324. package/dist/graph-dashboard-parser.js +8 -0
  325. package/dist/graph-dashboard-parser.js.map +1 -0
  326. package/dist/graph.d.ts +157 -0
  327. package/dist/graph.js +27 -0
  328. package/dist/graph.js.map +1 -0
  329. package/dist/harmonic-retrieval.d.ts +27 -0
  330. package/dist/harmonic-retrieval.js +12 -0
  331. package/dist/harmonic-retrieval.js.map +1 -0
  332. package/dist/himem.d.ts +23 -0
  333. package/dist/himem.js +7 -0
  334. package/dist/himem.js.map +1 -0
  335. package/dist/hygiene.d.ts +24 -0
  336. package/dist/hygiene.js +9 -0
  337. package/dist/hygiene.js.map +1 -0
  338. package/dist/identity-continuity.d.ts +17 -0
  339. package/dist/identity-continuity.js +19 -0
  340. package/dist/identity-continuity.js.map +1 -0
  341. package/dist/importance.d.ts +25 -0
  342. package/dist/importance.js +11 -0
  343. package/dist/importance.js.map +1 -0
  344. package/dist/index.d.ts +923 -0
  345. package/dist/index.js +2512 -0
  346. package/dist/index.js.map +1 -0
  347. package/dist/intent.d.ts +8 -0
  348. package/dist/intent.js +13 -0
  349. package/dist/intent.js.map +1 -0
  350. package/dist/json-extract.d.ts +14 -0
  351. package/dist/json-extract.js +9 -0
  352. package/dist/json-extract.js.map +1 -0
  353. package/dist/json-store.d.ts +5 -0
  354. package/dist/json-store.js +11 -0
  355. package/dist/json-store.js.map +1 -0
  356. package/dist/legacy-hook-compat.d.ts +3 -0
  357. package/dist/legacy-hook-compat.js +35 -0
  358. package/dist/legacy-hook-compat.js.map +1 -0
  359. package/dist/lifecycle.d.ts +52 -0
  360. package/dist/lifecycle.js +21 -0
  361. package/dist/lifecycle.js.map +1 -0
  362. package/dist/local-llm.d.ts +154 -0
  363. package/dist/local-llm.js +10 -0
  364. package/dist/local-llm.js.map +1 -0
  365. package/dist/logger.d.ts +15 -0
  366. package/dist/logger.js +9 -0
  367. package/dist/logger.js.map +1 -0
  368. package/dist/memory-action-policy.d.ts +13 -0
  369. package/dist/memory-action-policy.js +7 -0
  370. package/dist/memory-action-policy.js.map +1 -0
  371. package/dist/memory-cache.d.ts +35 -0
  372. package/dist/memory-cache.js +37 -0
  373. package/dist/memory-cache.js.map +1 -0
  374. package/dist/memory-lifecycle-ledger-utils.d.ts +13 -0
  375. package/dist/memory-lifecycle-ledger-utils.js +23 -0
  376. package/dist/memory-lifecycle-ledger-utils.js.map +1 -0
  377. package/dist/memory-projection-format.d.ts +4 -0
  378. package/dist/memory-projection-format.js +9 -0
  379. package/dist/memory-projection-format.js.map +1 -0
  380. package/dist/memory-projection-store-NxMkbocT.d.ts +221 -0
  381. package/dist/memory-projection-store.d.ts +3 -0
  382. package/dist/memory-projection-store.js +31 -0
  383. package/dist/memory-projection-store.js.map +1 -0
  384. package/dist/model-registry.d.ts +60 -0
  385. package/dist/model-registry.js +8 -0
  386. package/dist/model-registry.js.map +1 -0
  387. package/dist/native-knowledge.d.ts +94 -0
  388. package/dist/native-knowledge.js +26 -0
  389. package/dist/native-knowledge.js.map +1 -0
  390. package/dist/negative.d.ts +26 -0
  391. package/dist/negative.js +8 -0
  392. package/dist/negative.js.map +1 -0
  393. package/dist/objective-state-writers.d.ts +22 -0
  394. package/dist/objective-state-writers.js +313 -0
  395. package/dist/objective-state-writers.js.map +1 -0
  396. package/dist/objective-state.d.ts +75 -0
  397. package/dist/objective-state.js +17 -0
  398. package/dist/objective-state.js.map +1 -0
  399. package/dist/openai-chat-compat.d.ts +13 -0
  400. package/dist/openai-chat-compat.js +11 -0
  401. package/dist/openai-chat-compat.js.map +1 -0
  402. package/dist/operator-toolkit.d.ts +304 -0
  403. package/dist/operator-toolkit.js +41 -0
  404. package/dist/operator-toolkit.js.map +1 -0
  405. package/dist/opik-exporter.d.ts +72 -0
  406. package/dist/opik-exporter.js +361 -0
  407. package/dist/opik-exporter.js.map +1 -0
  408. package/dist/orchestrator-zTa-Qo-1.d.ts +1104 -0
  409. package/dist/orchestrator.d.ts +21 -0
  410. package/dist/orchestrator.js +145 -0
  411. package/dist/orchestrator.js.map +1 -0
  412. package/dist/policy-runtime.d.ts +37 -0
  413. package/dist/policy-runtime.js +13 -0
  414. package/dist/policy-runtime.js.map +1 -0
  415. package/dist/port-C1GZFv8h.d.ts +41 -0
  416. package/dist/profiling.d.ts +80 -0
  417. package/dist/profiling.js +10 -0
  418. package/dist/profiling.js.map +1 -0
  419. package/dist/qmd-recall-cache.d.ts +29 -0
  420. package/dist/qmd-recall-cache.js +13 -0
  421. package/dist/qmd-recall-cache.js.map +1 -0
  422. package/dist/qmd.d.ts +105 -0
  423. package/dist/qmd.js +13 -0
  424. package/dist/qmd.js.map +1 -0
  425. package/dist/recall-qos.d.ts +33 -0
  426. package/dist/recall-qos.js +10 -0
  427. package/dist/recall-qos.js.map +1 -0
  428. package/dist/recall-query-policy.d.ts +20 -0
  429. package/dist/recall-query-policy.js +11 -0
  430. package/dist/recall-query-policy.js.map +1 -0
  431. package/dist/recall-state.d.ts +113 -0
  432. package/dist/recall-state.js +12 -0
  433. package/dist/recall-state.js.map +1 -0
  434. package/dist/recall-tokenization.d.ts +4 -0
  435. package/dist/recall-tokenization.js +9 -0
  436. package/dist/recall-tokenization.js.map +1 -0
  437. package/dist/reconstruct.d.ts +16 -0
  438. package/dist/reconstruct.js +7 -0
  439. package/dist/reconstruct.js.map +1 -0
  440. package/dist/release-changelog.d.ts +7 -0
  441. package/dist/release-changelog.js +30 -0
  442. package/dist/release-changelog.js.map +1 -0
  443. package/dist/relevance.d.ts +18 -0
  444. package/dist/relevance.js +8 -0
  445. package/dist/relevance.js.map +1 -0
  446. package/dist/rerank.d.ts +57 -0
  447. package/dist/rerank.js +11 -0
  448. package/dist/rerank.js.map +1 -0
  449. package/dist/resolve-provider-secret.d.ts +16 -0
  450. package/dist/resolve-provider-secret.js +11 -0
  451. package/dist/resolve-provider-secret.js.map +1 -0
  452. package/dist/resume-bundles.d.ts +66 -0
  453. package/dist/resume-bundles.js +27 -0
  454. package/dist/resume-bundles.js.map +1 -0
  455. package/dist/retrieval-agents.d.ts +129 -0
  456. package/dist/retrieval-agents.js +23 -0
  457. package/dist/retrieval-agents.js.map +1 -0
  458. package/dist/retrieval.d.ts +19 -0
  459. package/dist/retrieval.js +10 -0
  460. package/dist/retrieval.js.map +1 -0
  461. package/dist/sanitize.d.ts +9 -0
  462. package/dist/sanitize.js +9 -0
  463. package/dist/sanitize.js.map +1 -0
  464. package/dist/schemas.d.ts +688 -0
  465. package/dist/schemas.js +51 -0
  466. package/dist/schemas.js.map +1 -0
  467. package/dist/sdk-compat.d.ts +21 -0
  468. package/dist/sdk-compat.js +28 -0
  469. package/dist/sdk-compat.js.map +1 -0
  470. package/dist/semantic-consolidation.d.ts +42 -0
  471. package/dist/semantic-consolidation.js +12 -0
  472. package/dist/semantic-consolidation.js.map +1 -0
  473. package/dist/semantic-rule-promotion.d.ts +28 -0
  474. package/dist/semantic-rule-promotion.js +17 -0
  475. package/dist/semantic-rule-promotion.js.map +1 -0
  476. package/dist/semantic-rule-verifier.d.ts +19 -0
  477. package/dist/semantic-rule-verifier.js +18 -0
  478. package/dist/semantic-rule-verifier.js.map +1 -0
  479. package/dist/session-integrity.d.ts +67 -0
  480. package/dist/session-integrity.js +11 -0
  481. package/dist/session-integrity.js.map +1 -0
  482. package/dist/session-observer-bands.d.ts +6 -0
  483. package/dist/session-observer-bands.js +9 -0
  484. package/dist/session-observer-bands.js.map +1 -0
  485. package/dist/session-observer-state.d.ts +40 -0
  486. package/dist/session-observer-state.js +11 -0
  487. package/dist/session-observer-state.js.map +1 -0
  488. package/dist/signal.d.ts +6 -0
  489. package/dist/signal.js +9 -0
  490. package/dist/signal.js.map +1 -0
  491. package/dist/storage.d.ts +453 -0
  492. package/dist/storage.js +24 -0
  493. package/dist/storage.js.map +1 -0
  494. package/dist/store-contract.d.ts +10 -0
  495. package/dist/store-contract.js +21 -0
  496. package/dist/store-contract.js.map +1 -0
  497. package/dist/summarizer.d.ts +35 -0
  498. package/dist/summarizer.js +17 -0
  499. package/dist/summarizer.js.map +1 -0
  500. package/dist/summary-snapshot.d.ts +8 -0
  501. package/dist/summary-snapshot.js +13 -0
  502. package/dist/summary-snapshot.js.map +1 -0
  503. package/dist/temporal-index.d.ts +139 -0
  504. package/dist/temporal-index.js +29 -0
  505. package/dist/temporal-index.js.map +1 -0
  506. package/dist/threading.d.ts +62 -0
  507. package/dist/threading.js +8 -0
  508. package/dist/threading.js.map +1 -0
  509. package/dist/tier-migration.d.ts +44 -0
  510. package/dist/tier-migration.js +7 -0
  511. package/dist/tier-migration.js.map +1 -0
  512. package/dist/tier-routing.d.ts +21 -0
  513. package/dist/tier-routing.js +10 -0
  514. package/dist/tier-routing.js.map +1 -0
  515. package/dist/tmt.d.ts +79 -0
  516. package/dist/tmt.js +29 -0
  517. package/dist/tmt.js.map +1 -0
  518. package/dist/tokens.d.ts +24 -0
  519. package/dist/tokens.js +21 -0
  520. package/dist/tokens.js.map +1 -0
  521. package/dist/topics.d.ts +29 -0
  522. package/dist/topics.js +9 -0
  523. package/dist/topics.js.map +1 -0
  524. package/dist/transcript.d.ts +171 -0
  525. package/dist/transcript.js +9 -0
  526. package/dist/transcript.js.map +1 -0
  527. package/dist/trust-zones.d.ts +170 -0
  528. package/dist/trust-zones.js +32 -0
  529. package/dist/trust-zones.js.map +1 -0
  530. package/dist/types.d.ts +1243 -0
  531. package/dist/types.js +9 -0
  532. package/dist/types.js.map +1 -0
  533. package/dist/utility-learner.d.ts +59 -0
  534. package/dist/utility-learner.js +17 -0
  535. package/dist/utility-learner.js.map +1 -0
  536. package/dist/utility-runtime.d.ts +21 -0
  537. package/dist/utility-runtime.js +16 -0
  538. package/dist/utility-runtime.js.map +1 -0
  539. package/dist/utility-telemetry.d.ts +68 -0
  540. package/dist/utility-telemetry.js +17 -0
  541. package/dist/utility-telemetry.js.map +1 -0
  542. package/dist/verified-recall.d.ts +17 -0
  543. package/dist/verified-recall.js +19 -0
  544. package/dist/verified-recall.js.map +1 -0
  545. package/dist/version-utils.d.ts +4 -0
  546. package/dist/version-utils.js +7 -0
  547. package/dist/version-utils.js.map +1 -0
  548. package/dist/work-product-ledger.d.ts +65 -0
  549. package/dist/work-product-ledger.js +18 -0
  550. package/dist/work-product-ledger.js.map +1 -0
  551. package/package.json +58 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/native-knowledge.ts"],"sourcesContent":["import { createHash } from \"node:crypto\";\nimport path from \"node:path\";\nimport { mkdir, readFile, readdir, stat, writeFile } from \"node:fs/promises\";\nimport { log } from \"./logger.js\";\nimport type {\n NativeKnowledgeConfig,\n NativeKnowledgeObsidianVaultConfig,\n} from \"./types.js\";\n\nexport type NativeKnowledgeChunk = {\n chunkId: string;\n sourcePath: string;\n title: string;\n sourceKind:\n | \"identity\"\n | \"memory\"\n | \"workspace_doc\"\n | \"obsidian_note\"\n | \"bootstrap_doc\"\n | \"handoff\"\n | \"daily_summary\"\n | \"automation_note\";\n startLine: number;\n endLine: number;\n content: string;\n vaultId?: string;\n notePath?: string;\n noteKey?: string;\n derivedDate?: string;\n tags?: string[];\n aliases?: string[];\n wikilinks?: string[];\n backlinks?: string[];\n namespace?: string;\n privacyClass?: string;\n sourceHash?: string;\n mtimeMs?: number;\n sessionKey?: string;\n workflowKey?: string;\n author?: string;\n agent?: string;\n};\n\nexport type NativeKnowledgeSearchResult = NativeKnowledgeChunk & {\n score: number;\n};\n\ninterface ParsedFrontmatter {\n body: string;\n bodyStartLine: number;\n data: Record<string, string | string[]>;\n}\n\ninterface ObsidianNoteState {\n noteKey: string;\n notePath: string;\n title: string;\n derivedDate?: string;\n tags: string[];\n aliases: string[];\n wikilinks: string[];\n backlinks: string[];\n namespace?: string;\n privacyClass?: string;\n sourceHash: string;\n mtimeMs: number;\n deleted: boolean;\n deletedAt?: string;\n chunks: NativeKnowledgeChunk[];\n}\n\ninterface ObsidianVaultState {\n vaultId: string;\n rootDir: string;\n syncedAt: string;\n notes: Record<string, ObsidianNoteState>;\n}\n\ninterface ObsidianSyncState {\n version: 1;\n updatedAt: string;\n vaults: Record<string, ObsidianVaultState>;\n}\n\ninterface OpenClawWorkspaceFileState {\n sourcePath: string;\n sourceKind: Exclude<NativeKnowledgeChunk[\"sourceKind\"], \"obsidian_note\">;\n title: string;\n namespace?: string;\n privacyClass?: string;\n derivedDate?: string;\n sessionKey?: string;\n workflowKey?: string;\n author?: string;\n agent?: string;\n sourceHash: string;\n syncConfigHash: string;\n mtimeMs: number;\n deleted: boolean;\n deletedAt?: string;\n chunks: NativeKnowledgeChunk[];\n}\n\ninterface OpenClawWorkspaceSyncState {\n version: 1;\n updatedAt: string;\n files: Record<string, OpenClawWorkspaceFileState>;\n}\n\ninterface CuratedIncludeFileState {\n sourcePath: string;\n sourceKind: Extract<NativeKnowledgeChunk[\"sourceKind\"], \"identity\" | \"memory\" | \"workspace_doc\">;\n title: string;\n namespace?: string;\n privacyClass?: string;\n derivedDate?: string;\n sourceHash: string;\n syncConfigHash: string;\n mtimeMs: number;\n deleted: boolean;\n deletedAt?: string;\n chunks: NativeKnowledgeChunk[];\n}\n\ninterface CuratedIncludeFilesSyncState {\n version: 1;\n updatedAt: string;\n files: Record<string, CuratedIncludeFileState>;\n}\n\nexport interface NativeKnowledgeSyncResult {\n statePath: string;\n vaultCount: number;\n touchedNotes: number;\n deletedNotes: number;\n chunkCount: number;\n activeChunks: NativeKnowledgeChunk[];\n}\n\nconst PERSISTED_NATIVE_KNOWLEDGE_STATE_FILES = new Set([\n \"obsidian-sync.json\",\n \"curated-include-sync.json\",\n \"openclaw-workspace-sync.json\",\n]);\n\nfunction normalizeText(value: string): string {\n return value.toLowerCase().replace(/[^a-z0-9]+/g, \" \").trim();\n}\n\nfunction tokenize(value: string): string[] {\n return normalizeText(value).split(/\\s+/).filter((token) => token.length >= 2);\n}\n\nfunction uniqueSorted(values: string[]): string[] {\n return [...new Set(values.filter((value) => value.trim().length > 0).map((value) => value.trim()))].sort();\n}\n\nfunction detectSourceKind(filePath: string): CuratedIncludeFileState[\"sourceKind\"] {\n const base = path.basename(filePath).toLowerCase();\n if (base.startsWith(\"identity\")) return \"identity\";\n if (base === \"memory.md\") return \"memory\";\n return \"workspace_doc\";\n}\n\nfunction parseInlineArray(raw: string): string[] {\n const trimmed = raw.trim();\n if (!trimmed.startsWith(\"[\") || !trimmed.endsWith(\"]\")) return [];\n return trimmed\n .slice(1, -1)\n .split(\",\")\n .map((value) => value.trim().replace(/^['\"]|['\"]$/g, \"\"))\n .filter(Boolean);\n}\n\nfunction parseFrontmatter(content: string): ParsedFrontmatter {\n const normalized = content.replace(/\\r\\n/g, \"\\n\");\n if (!normalized.startsWith(\"---\\n\")) return { body: normalized, bodyStartLine: 1, data: {} };\n const closing = normalized.indexOf(\"\\n---\\n\", 4);\n if (closing === -1) return { body: normalized, bodyStartLine: 1, data: {} };\n\n const data: Record<string, string | string[]> = {};\n const lines = normalized.slice(4, closing).split(\"\\n\");\n let index = 0;\n while (index < lines.length) {\n const line = lines[index] ?? \"\";\n const match = /^([A-Za-z0-9_-]+):\\s*(.*)$/.exec(line);\n if (!match) {\n index += 1;\n continue;\n }\n const [, key, rawValue] = match;\n if (rawValue.trim().length > 0) {\n const inlineArray = parseInlineArray(rawValue);\n data[key] = inlineArray.length > 0 ? inlineArray : rawValue.trim().replace(/^['\"]|['\"]$/g, \"\");\n index += 1;\n continue;\n }\n\n const items: string[] = [];\n let cursor = index + 1;\n while (cursor < lines.length) {\n const next = lines[cursor] ?? \"\";\n const itemMatch = /^\\s*-\\s*(.+)$/.exec(next);\n if (!itemMatch) break;\n items.push(itemMatch[1]!.trim().replace(/^['\"]|['\"]$/g, \"\"));\n cursor += 1;\n }\n data[key] = items;\n index = cursor;\n }\n\n return {\n body: normalized.slice(closing + 5),\n bodyStartLine: normalized.slice(0, closing + 5).split(\"\\n\").length,\n data,\n };\n}\n\nfunction firstStringValue(\n data: Record<string, string | string[]>,\n keys: string[],\n): string | undefined {\n for (const key of keys) {\n const value = data[key];\n if (typeof value === \"string\" && value.trim().length > 0) return value.trim();\n }\n return undefined;\n}\n\nfunction normalizeIsoDate(value: string | undefined): string | undefined {\n if (!value) return undefined;\n const trimmed = value.trim();\n const isoDateMatch = /^(\\d{4}-\\d{2}-\\d{2})/.exec(trimmed);\n if (isoDateMatch) return isoDateMatch[1];\n const slashDateMatch = /^(\\d{4})[\\/_](\\d{2})[\\/_](\\d{2})$/.exec(trimmed);\n if (slashDateMatch) return `${slashDateMatch[1]}-${slashDateMatch[2]}-${slashDateMatch[3]}`;\n return undefined;\n}\n\nfunction deriveDateFromPath(filePath: string): string | undefined {\n const normalized = filePath.replace(/\\\\/g, \"/\");\n const hyphenated = /(\\d{4}-\\d{2}-\\d{2})/.exec(normalized);\n if (hyphenated) return hyphenated[1];\n const split = /(^|\\/)(\\d{4})\\/(\\d{2})\\/(\\d{2})(?=\\/|[^/\\n]*\\.md$)/.exec(normalized);\n if (split) return `${split[2]}-${split[3]}-${split[4]}`;\n return undefined;\n}\n\nfunction deriveArtifactDate(filePath: string, parsed: ParsedFrontmatter): string | undefined {\n return (\n normalizeIsoDate(firstStringValue(parsed.data, [\"date\", \"recordedAt\", \"generatedAt\", \"summaryDate\", \"day\"]))\n ?? deriveDateFromPath(filePath)\n );\n}\n\nfunction deriveNamespaceFromIncludePath(sourcePath: string): string | undefined {\n const basename = path.basename(sourcePath);\n const match = /^identity\\.([^.\\/]+)\\.md$/i.exec(basename);\n return match?.[1];\n}\n\nfunction compileDailyNotePattern(pattern: string): RegExp {\n const escaped = pattern.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n const regex = escaped\n .replace(/YYYY/g, \"(?<year>\\\\d{4})\")\n .replace(/MM/g, \"(?<month>\\\\d{2})\")\n .replace(/DD/g, \"(?<day>\\\\d{2})\");\n return new RegExp(`^${regex}$`);\n}\n\nfunction deriveDailyNoteDate(notePath: string, patterns: string[]): string | undefined {\n const withoutExt = notePath.replace(/\\.md$/i, \"\");\n for (const pattern of patterns) {\n const match = compileDailyNotePattern(pattern).exec(withoutExt);\n if (!match?.groups) continue;\n const { year, month, day } = match.groups;\n if (!year || !month || !day) continue;\n return `${year}-${month}-${day}`;\n }\n return undefined;\n}\n\nfunction extractInlineTags(content: string): string[] {\n const matches = [...content.matchAll(/(^|\\s)#([a-z0-9/_-]+)/gi)];\n return uniqueSorted(matches.map((match) => match[2] ?? \"\"));\n}\n\nfunction extractWikilinks(content: string): { targets: string[]; aliases: string[] } {\n const targets: string[] = [];\n const aliases: string[] = [];\n const regex = /\\[\\[([^\\]|#]+)(?:#[^\\]|]+)?(?:\\|([^\\]]+))?\\]\\]/g;\n for (const match of content.matchAll(regex)) {\n const target = (match[1] ?? \"\").trim();\n const alias = (match[2] ?? \"\").trim();\n if (target) targets.push(target);\n if (alias) aliases.push(alias);\n }\n return {\n targets: uniqueSorted(targets),\n aliases: uniqueSorted(aliases),\n };\n}\n\nfunction normalizePathPrefix(prefix: string): string {\n const fwd = prefix.replace(/\\\\/g, \"/\");\n let start = 0;\n while (start < fwd.length && fwd[start] === \"/\") start++;\n let end = fwd.length;\n while (end > start && fwd[end - 1] === \"/\") end--;\n return fwd.substring(start, end);\n}\n\nfunction classifyObsidianNote(\n notePath: string,\n vault: NativeKnowledgeObsidianVaultConfig,\n): { namespace?: string; privacyClass?: string } {\n let namespace = vault.namespace;\n let privacyClass = vault.privacyClass;\n const normalizedPath = notePath.replace(/\\\\/g, \"/\");\n const rules = [...vault.folderRules].sort(\n (a, b) => normalizePathPrefix(b.pathPrefix).length - normalizePathPrefix(a.pathPrefix).length,\n );\n\n for (const rule of rules) {\n const prefix = normalizePathPrefix(rule.pathPrefix);\n if (!prefix) continue;\n if (normalizedPath === prefix || normalizedPath.startsWith(`${prefix}/`)) {\n namespace = rule.namespace ?? namespace;\n privacyClass = rule.privacyClass ?? privacyClass;\n break;\n }\n }\n\n return { namespace, privacyClass };\n}\n\nfunction chunkHeadingAware(options: {\n sourcePath: string;\n content: string;\n maxChunkChars: number;\n startLineOffset?: number;\n createChunk: (args: {\n title: string;\n startLine: number;\n endLine: number;\n content: string;\n }) => NativeKnowledgeChunk;\n}): NativeKnowledgeChunk[] {\n const lines = options.content.replace(/\\r\\n/g, \"\\n\").split(\"\\n\");\n const chunks: NativeKnowledgeChunk[] = [];\n let currentTitle = path.basename(options.sourcePath);\n let currentLines: string[] = [];\n let startLine = 1 + (options.startLineOffset ?? 0);\n\n const flush = () => {\n const paragraphs: Array<{\n content: string;\n startLine: number;\n endLine: number;\n }> = [];\n let paragraphLines: string[] = [];\n let paragraphStartOffset: number | null = null;\n\n const pushParagraph = (lineOffsetExclusive: number) => {\n if (paragraphLines.length === 0 || paragraphStartOffset === null) return;\n paragraphs.push({\n content: paragraphLines.join(\"\\n\").trim(),\n startLine: startLine + paragraphStartOffset,\n endLine: startLine + lineOffsetExclusive - 1,\n });\n paragraphLines = [];\n paragraphStartOffset = null;\n };\n\n for (let index = 0; index < currentLines.length; index += 1) {\n const line = currentLines[index] ?? \"\";\n const isListLine = /^\\s*(?:[-*+]|\\d+\\.)\\s+/.test(line);\n const previousLine = index > 0 ? (currentLines[index - 1] ?? \"\") : \"\";\n const previousWasList = /^\\s*(?:[-*+]|\\d+\\.)\\s+/.test(previousLine);\n if (line.trim().length === 0) {\n pushParagraph(index);\n continue;\n }\n if (isListLine && paragraphLines.length > 0 && !previousWasList) {\n pushParagraph(index);\n }\n if (paragraphStartOffset === null) paragraphStartOffset = index;\n paragraphLines.push(line);\n }\n pushParagraph(currentLines.length);\n\n if (paragraphs.length === 0) return;\n\n const body = paragraphs.map((paragraph) => paragraph.content).join(\"\\n\\n\");\n if (body.length <= options.maxChunkChars) {\n chunks.push(options.createChunk({\n title: currentTitle,\n startLine: paragraphs[0]!.startLine,\n endLine: paragraphs[paragraphs.length - 1]!.endLine,\n content: body,\n }));\n return;\n }\n\n let buffer = \"\";\n let bufferStartLine = paragraphs[0]!.startLine;\n let bufferEndLine = paragraphs[0]!.endLine;\n\n for (const paragraph of paragraphs) {\n const next = buffer.length > 0 ? `${buffer}\\n\\n${paragraph.content}` : paragraph.content;\n if (next.length > options.maxChunkChars && buffer.length > 0) {\n chunks.push(options.createChunk({\n title: currentTitle,\n startLine: bufferStartLine,\n endLine: bufferEndLine,\n content: buffer,\n }));\n buffer = paragraph.content;\n bufferStartLine = paragraph.startLine;\n bufferEndLine = paragraph.endLine;\n } else {\n buffer = next;\n bufferEndLine = paragraph.endLine;\n }\n }\n\n if (buffer.length > 0) {\n chunks.push(options.createChunk({\n title: currentTitle,\n startLine: bufferStartLine,\n endLine: bufferEndLine,\n content: buffer,\n }));\n }\n };\n\n for (let index = 0; index < lines.length; index += 1) {\n const line = lines[index] ?? \"\";\n if (/^#{1,6}\\s+/.test(line) && currentLines.length > 0) {\n flush();\n currentLines = [];\n currentTitle = line.replace(/^#{1,6}\\s+/, \"\").trim() || currentTitle;\n startLine = index + 2 + (options.startLineOffset ?? 0);\n continue;\n }\n if (/^#{1,6}\\s+/.test(line)) {\n currentTitle = line.replace(/^#{1,6}\\s+/, \"\").trim() || currentTitle;\n startLine = index + 2 + (options.startLineOffset ?? 0);\n continue;\n }\n currentLines.push(line);\n }\n\n flush();\n return chunks;\n}\n\nasync function readableFile(filePath: string): Promise<boolean> {\n try {\n const info = await stat(filePath);\n return info.isFile();\n } catch {\n return false;\n }\n}\n\nasync function resolveCandidatePaths(options: {\n workspaceDir: string;\n includeFiles: string[];\n recallNamespaces?: string[];\n defaultNamespace: string;\n identityVariantMode: \"recall\" | \"disk\";\n}): Promise<string[]> {\n const out = new Set<string>();\n for (const rel of options.includeFiles) {\n const trimmed = rel.trim();\n if (!trimmed) continue;\n const candidatePath = path.join(options.workspaceDir, trimmed);\n out.add(candidatePath);\n if (path.basename(trimmed).toLowerCase() !== \"identity.md\") continue;\n\n const relativeDir = path.dirname(trimmed);\n if (options.identityVariantMode === \"recall\") {\n if (!Array.isArray(options.recallNamespaces)) continue;\n for (const namespace of options.recallNamespaces) {\n if (!namespace || namespace === options.defaultNamespace) continue;\n out.add(path.join(options.workspaceDir, relativeDir, `IDENTITY.${namespace}.md`));\n }\n continue;\n }\n\n const absoluteDir = path.dirname(candidatePath);\n let entries: string[] = [];\n try {\n entries = await readdir(absoluteDir);\n } catch {\n continue;\n }\n for (const entry of entries) {\n if (!/^identity\\.[^.\\/]+\\.md$/i.test(entry)) continue;\n out.add(path.join(options.workspaceDir, relativeDir, entry));\n }\n }\n return Array.from(out);\n}\n\nfunction resolveNoteTitle(notePath: string, parsed: ParsedFrontmatter): string {\n const rawTitle = parsed.data.title;\n if (typeof rawTitle === \"string\" && rawTitle.trim().length > 0) return rawTitle.trim();\n const heading = parsed.body.match(/^#{1,6}\\s+(.+)$/m)?.[1]?.trim();\n if (heading) return heading;\n return path.basename(notePath, path.extname(notePath));\n}\n\nfunction parseFrontmatterList(value: string | string[] | undefined): string[] {\n if (Array.isArray(value)) return uniqueSorted(value);\n if (typeof value === \"string\" && value.trim().length > 0) return [value.trim()];\n return [];\n}\n\nfunction toPosixRelative(rootDir: string, filePath: string): string {\n return path.relative(rootDir, filePath).split(path.sep).join(\"/\");\n}\n\nfunction globToRegExp(glob: string): RegExp {\n let regex = \"^\";\n for (let index = 0; index < glob.length; index += 1) {\n const char = glob[index]!;\n const next = glob[index + 1];\n if (char === \"*\") {\n if (next === \"*\") {\n if (glob[index + 2] === \"/\") {\n regex += \"(?:.*/)?\";\n index += 2;\n } else {\n regex += \".*\";\n index += 1;\n }\n } else {\n regex += \"[^/]*\";\n }\n continue;\n }\n if (char === \"?\") {\n regex += \".\";\n continue;\n }\n if (char === \"/\") {\n regex += \"/\";\n continue;\n }\n regex += char.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n }\n regex += \"$\";\n return new RegExp(regex);\n}\n\nfunction compileGlobs(patterns: string[]): RegExp[] {\n return patterns.map((pattern) => globToRegExp(pattern));\n}\n\nfunction matchesCompiledGlobs(notePath: string, patterns: RegExp[]): boolean {\n if (patterns.length === 0) return false;\n return patterns.some((pattern) => pattern.test(notePath));\n}\n\nasync function listMarkdownFiles(rootDir: string): Promise<string[] | null> {\n const results: string[] = [];\n async function walk(currentDir: string): Promise<void> {\n const entries = await readdir(currentDir, { withFileTypes: true }).catch(() => []);\n for (const entry of entries) {\n const fullPath = path.join(currentDir, entry.name);\n if (entry.isDirectory()) {\n await walk(fullPath);\n continue;\n }\n if (!entry.isFile() || !entry.name.toLowerCase().endsWith(\".md\")) continue;\n results.push(toPosixRelative(rootDir, fullPath));\n }\n }\n const rootInfo = await stat(rootDir).catch(() => null);\n if (!rootInfo?.isDirectory()) return null;\n await walk(rootDir);\n return results.sort();\n}\n\nfunction resolveFileCandidates(options: {\n listedFiles: string[];\n bootstrapFiles: string[];\n handoffGlobs: string[];\n dailySummaryGlobs: string[];\n automationNoteGlobs: string[];\n workspaceDocGlobs: string[];\n excludeGlobs: string[];\n}): Array<{\n sourcePath: string;\n sourceKind: \"bootstrap_doc\" | \"handoff\" | \"daily_summary\" | \"automation_note\" | \"workspace_doc\";\n}> {\n const out = new Map<string, \"bootstrap_doc\" | \"handoff\" | \"daily_summary\" | \"automation_note\" | \"workspace_doc\">();\n const excludes = compileGlobs(options.excludeGlobs);\n const handoff = compileGlobs(options.handoffGlobs);\n const dailySummary = compileGlobs(options.dailySummaryGlobs);\n const automation = compileGlobs(options.automationNoteGlobs);\n const workspaceDocs = compileGlobs(options.workspaceDocGlobs);\n const listedFiles = new Set(options.listedFiles.map((value) => value.replace(/\\\\/g, \"/\")));\n\n for (const file of options.bootstrapFiles.map((value) => value.replace(/\\\\/g, \"/\"))) {\n if (listedFiles.has(file) && !matchesCompiledGlobs(file, excludes)) out.set(file, \"bootstrap_doc\");\n }\n\n for (const sourcePath of listedFiles) {\n if (matchesCompiledGlobs(sourcePath, excludes)) continue;\n if (out.has(sourcePath)) continue;\n if (matchesCompiledGlobs(sourcePath, handoff)) {\n out.set(sourcePath, \"handoff\");\n continue;\n }\n if (matchesCompiledGlobs(sourcePath, dailySummary)) {\n out.set(sourcePath, \"daily_summary\");\n continue;\n }\n if (matchesCompiledGlobs(sourcePath, automation)) {\n out.set(sourcePath, \"automation_note\");\n continue;\n }\n if (matchesCompiledGlobs(sourcePath, workspaceDocs)) {\n out.set(sourcePath, \"workspace_doc\");\n }\n }\n\n return [...out.entries()]\n .map(([sourcePath, sourceKind]) => ({ sourcePath, sourceKind }))\n .sort((left, right) => left.sourcePath.localeCompare(right.sourcePath));\n}\n\nexport function resolveNativeKnowledgeStatePath(memoryDir: string, config: NativeKnowledgeConfig): string {\n return path.join(memoryDir, config.stateDir, \"obsidian-sync.json\");\n}\n\nexport function resolveCuratedIncludeFilesStatePath(memoryDir: string, config: NativeKnowledgeConfig): string {\n return path.join(memoryDir, config.stateDir, \"curated-include-sync.json\");\n}\n\nexport function resolveOpenClawWorkspaceStatePath(memoryDir: string, config: NativeKnowledgeConfig): string {\n return path.join(memoryDir, config.stateDir, \"openclaw-workspace-sync.json\");\n}\n\nasync function loadSyncState(memoryDir: string, config: NativeKnowledgeConfig): Promise<ObsidianSyncState> {\n const statePath = resolveNativeKnowledgeStatePath(memoryDir, config);\n try {\n const raw = JSON.parse(await readFile(statePath, \"utf-8\")) as Partial<ObsidianSyncState>;\n if (raw.version !== 1 || typeof raw.vaults !== \"object\" || !raw.vaults) {\n throw new Error(\"invalid obsidian native knowledge state\");\n }\n return {\n version: 1,\n updatedAt: typeof raw.updatedAt === \"string\" ? raw.updatedAt : new Date(0).toISOString(),\n vaults: raw.vaults as Record<string, ObsidianVaultState>,\n };\n } catch {\n return {\n version: 1,\n updatedAt: new Date(0).toISOString(),\n vaults: {},\n };\n }\n}\n\nasync function loadOpenClawWorkspaceState(\n memoryDir: string,\n config: NativeKnowledgeConfig,\n): Promise<OpenClawWorkspaceSyncState> {\n const statePath = resolveOpenClawWorkspaceStatePath(memoryDir, config);\n try {\n const raw = JSON.parse(await readFile(statePath, \"utf-8\")) as Partial<OpenClawWorkspaceSyncState>;\n if (raw.version !== 1 || typeof raw.files !== \"object\" || !raw.files) {\n throw new Error(\"invalid openclaw workspace native knowledge state\");\n }\n return {\n version: 1,\n updatedAt: typeof raw.updatedAt === \"string\" ? raw.updatedAt : new Date(0).toISOString(),\n files: raw.files as Record<string, OpenClawWorkspaceFileState>,\n };\n } catch {\n return {\n version: 1,\n updatedAt: new Date(0).toISOString(),\n files: {},\n };\n }\n}\n\nasync function loadCuratedIncludeFilesState(\n memoryDir: string,\n config: NativeKnowledgeConfig,\n): Promise<CuratedIncludeFilesSyncState> {\n const statePath = resolveCuratedIncludeFilesStatePath(memoryDir, config);\n try {\n const raw = JSON.parse(await readFile(statePath, \"utf-8\")) as Partial<CuratedIncludeFilesSyncState>;\n if (raw.version !== 1 || typeof raw.files !== \"object\" || !raw.files) {\n throw new Error(\"invalid curated include native knowledge state\");\n }\n return {\n version: 1,\n updatedAt: typeof raw.updatedAt === \"string\" ? raw.updatedAt : new Date(0).toISOString(),\n files: raw.files as Record<string, CuratedIncludeFileState>,\n };\n } catch {\n return {\n version: 1,\n updatedAt: new Date(0).toISOString(),\n files: {},\n };\n }\n}\n\nfunction deriveOpenClawArtifactMetadata(options: {\n sourcePath: string;\n parsed: ParsedFrontmatter;\n sharedSafeGlobs: string[];\n}): Pick<NativeKnowledgeChunk, \"derivedDate\" | \"sessionKey\" | \"workflowKey\" | \"author\" | \"agent\" | \"namespace\" | \"privacyClass\"> {\n const sharedSafe = compileGlobs(options.sharedSafeGlobs);\n return {\n derivedDate: deriveArtifactDate(options.sourcePath, options.parsed),\n sessionKey: firstStringValue(options.parsed.data, [\"sessionKey\", \"session\"]),\n workflowKey: firstStringValue(options.parsed.data, [\"workflowKey\", \"workflow\"]),\n author: firstStringValue(options.parsed.data, [\"author\"]),\n agent: firstStringValue(options.parsed.data, [\"agent\"]),\n namespace: firstStringValue(options.parsed.data, [\"namespace\"]),\n privacyClass:\n firstStringValue(options.parsed.data, [\"privacyClass\", \"privacy\"])\n ?? (matchesCompiledGlobs(options.sourcePath, sharedSafe) ? \"shared_safe\" : undefined),\n };\n}\n\nfunction buildOpenClawWorkspaceChunks(options: {\n sourcePath: string;\n sourceKind: \"bootstrap_doc\" | \"handoff\" | \"daily_summary\" | \"automation_note\" | \"workspace_doc\";\n body: string;\n bodyStartLine: number;\n maxChunkChars: number;\n sourceHash: string;\n mtimeMs: number;\n metadata: Pick<NativeKnowledgeChunk, \"derivedDate\" | \"sessionKey\" | \"workflowKey\" | \"author\" | \"agent\" | \"namespace\" | \"privacyClass\">;\n}): NativeKnowledgeChunk[] {\n return chunkHeadingAware({\n sourcePath: options.sourcePath,\n content: options.body,\n maxChunkChars: options.maxChunkChars,\n startLineOffset: options.bodyStartLine - 1,\n createChunk: ({ title, startLine, endLine, content }) => ({\n chunkId: `${options.sourceKind}:${options.sourcePath}:${startLine}-${endLine}`,\n sourcePath: options.sourcePath,\n title,\n sourceKind: options.sourceKind,\n startLine,\n endLine,\n content,\n derivedDate: options.metadata.derivedDate,\n sessionKey: options.metadata.sessionKey,\n workflowKey: options.metadata.workflowKey,\n author: options.metadata.author,\n agent: options.metadata.agent,\n namespace: options.metadata.namespace,\n privacyClass: options.metadata.privacyClass,\n sourceHash: options.sourceHash,\n mtimeMs: options.mtimeMs,\n }),\n });\n}\n\nfunction buildObsidianChunks(options: {\n vault: NativeKnowledgeObsidianVaultConfig;\n notePath: string;\n title: string;\n content: string;\n startLineOffset: number;\n derivedDate?: string;\n tags: string[];\n aliases: string[];\n wikilinks: string[];\n backlinks?: string[];\n namespace?: string;\n privacyClass?: string;\n sourceHash: string;\n mtimeMs: number;\n maxChunkChars: number;\n}): NativeKnowledgeChunk[] {\n const noteKey = `${options.vault.id}:${options.notePath}`;\n return chunkHeadingAware({\n sourcePath: options.notePath,\n content: options.content,\n maxChunkChars: options.maxChunkChars,\n startLineOffset: options.startLineOffset,\n createChunk: ({ title, startLine, endLine, content }) => ({\n chunkId: `${noteKey}:${startLine}-${endLine}`,\n sourcePath: `${options.vault.id}/${options.notePath}`,\n title,\n sourceKind: \"obsidian_note\",\n startLine,\n endLine,\n content,\n vaultId: options.vault.id,\n notePath: options.notePath,\n noteKey,\n derivedDate: options.derivedDate,\n tags: options.tags,\n aliases: options.aliases,\n wikilinks: options.wikilinks,\n backlinks: options.backlinks ?? [],\n namespace: options.namespace,\n privacyClass: options.privacyClass,\n sourceHash: options.sourceHash,\n mtimeMs: options.mtimeMs,\n }),\n });\n}\n\nfunction buildAliasIndex(notes: Record<string, ObsidianNoteState>): Map<string, string[]> {\n const index = new Map<string, string[]>();\n for (const note of Object.values(notes)) {\n if (note.deleted) continue;\n const candidates = [\n note.title,\n path.basename(note.notePath, path.extname(note.notePath)),\n note.notePath.replace(/\\.md$/i, \"\"),\n ...note.aliases,\n ];\n for (const candidate of candidates) {\n const key = normalizeText(candidate);\n if (!key) continue;\n const existing = index.get(key) ?? [];\n existing.push(note.noteKey);\n index.set(key, uniqueSorted(existing));\n }\n }\n return index;\n}\n\nfunction materializeBacklinks(notes: Record<string, ObsidianNoteState>): Record<string, string[]> {\n const backlinks = new Map<string, Set<string>>();\n const aliasIndex = buildAliasIndex(notes);\n for (const note of Object.values(notes)) {\n if (note.deleted) continue;\n for (const target of note.wikilinks) {\n const matches = aliasIndex.get(normalizeText(target)) ?? [];\n for (const match of matches) {\n if (match === note.noteKey) continue;\n const bucket = backlinks.get(match) ?? new Set<string>();\n bucket.add(note.notePath);\n backlinks.set(match, bucket);\n }\n }\n }\n return Object.fromEntries(\n [...backlinks.entries()].map(([noteKey, refs]) => [noteKey, [...refs].sort()]),\n );\n}\n\nexport async function syncObsidianVaults(options: {\n memoryDir: string;\n config: NativeKnowledgeConfig;\n}): Promise<NativeKnowledgeSyncResult> {\n if (options.config.obsidianVaults.length === 0) {\n return {\n statePath: resolveNativeKnowledgeStatePath(options.memoryDir, options.config),\n vaultCount: 0,\n touchedNotes: 0,\n deletedNotes: 0,\n chunkCount: 0,\n activeChunks: [],\n };\n }\n\n const state = await loadSyncState(options.memoryDir, options.config);\n const nextVaults: Record<string, ObsidianVaultState> = {};\n let touchedNotes = 0;\n let deletedNotes = 0;\n let chunkCount = 0;\n\n for (const vault of options.config.obsidianVaults) {\n const previousVault = state.vaults[vault.id];\n const previousNotes = previousVault?.notes ?? {};\n const notePaths = await listMarkdownFiles(vault.rootDir);\n if (notePaths === null) {\n nextVaults[vault.id] = previousVault ?? {\n vaultId: vault.id,\n rootDir: vault.rootDir,\n syncedAt: new Date().toISOString(),\n notes: previousNotes,\n };\n chunkCount += Object.values(previousNotes)\n .filter((note) => !note.deleted)\n .reduce((total, note) => total + note.chunks.length, 0);\n continue;\n }\n\n const includePatterns = compileGlobs(vault.includeGlobs);\n const excludePatterns = compileGlobs(vault.excludeGlobs);\n const includedNotePaths = notePaths.filter((notePath) => {\n if (!matchesCompiledGlobs(notePath, includePatterns)) return false;\n if (matchesCompiledGlobs(notePath, excludePatterns)) return false;\n return true;\n });\n\n const nextNotes: Record<string, ObsidianNoteState> = {};\n const seenNoteKeys = new Set<string>();\n\n for (const notePath of includedNotePaths) {\n const absPath = path.join(vault.rootDir, notePath);\n const content = await readFile(absPath, \"utf-8\").catch(() => null);\n if (content === null) continue;\n const info = await stat(absPath).catch(() => null);\n if (!info?.isFile()) continue;\n\n const sourceHash = createHash(\"sha256\").update(content).digest(\"hex\");\n const noteKey = `${vault.id}:${notePath}`;\n seenNoteKeys.add(noteKey);\n const previous = previousNotes[noteKey];\n if (previous && previous.deleted !== true && previous.sourceHash === sourceHash && previous.mtimeMs === info.mtimeMs) {\n nextNotes[noteKey] = {\n ...previous,\n deleted: false,\n deletedAt: undefined,\n };\n chunkCount += previous.chunks.length;\n continue;\n }\n\n const parsed = parseFrontmatter(content);\n const { targets } = extractWikilinks(parsed.body);\n const tags = uniqueSorted([\n ...parseFrontmatterList(parsed.data.tags),\n ...extractInlineTags(parsed.body),\n ]);\n const aliases = parseFrontmatterList(parsed.data.aliases);\n const { namespace, privacyClass } = classifyObsidianNote(notePath, vault);\n const title = resolveNoteTitle(notePath, parsed);\n const derivedDate = deriveDailyNoteDate(notePath, vault.dailyNotePatterns);\n const chunks = buildObsidianChunks({\n vault,\n notePath,\n title,\n content: parsed.body,\n startLineOffset: parsed.bodyStartLine - 1,\n derivedDate,\n tags,\n aliases,\n wikilinks: targets,\n namespace,\n privacyClass,\n sourceHash,\n mtimeMs: info.mtimeMs,\n maxChunkChars: options.config.maxChunkChars,\n });\n\n nextNotes[noteKey] = {\n noteKey,\n notePath,\n title,\n derivedDate,\n tags,\n aliases,\n wikilinks: targets,\n backlinks: [],\n namespace,\n privacyClass,\n sourceHash,\n mtimeMs: info.mtimeMs,\n deleted: false,\n chunks,\n };\n touchedNotes += 1;\n chunkCount += chunks.length;\n }\n\n for (const [noteKey, previous] of Object.entries(previousNotes)) {\n if (seenNoteKeys.has(noteKey)) continue;\n nextNotes[noteKey] = {\n ...previous,\n deleted: true,\n deletedAt: new Date().toISOString(),\n chunks: [],\n };\n deletedNotes += 1;\n }\n\n if (vault.materializeBacklinks) {\n const backlinks = materializeBacklinks(nextNotes);\n for (const note of Object.values(nextNotes)) {\n if (note.deleted) continue;\n note.backlinks = backlinks[note.noteKey] ?? [];\n note.chunks = note.chunks.map((chunk) => ({\n ...chunk,\n backlinks: note.backlinks,\n }));\n }\n }\n\n nextVaults[vault.id] = {\n vaultId: vault.id,\n rootDir: vault.rootDir,\n syncedAt: new Date().toISOString(),\n notes: nextNotes,\n };\n }\n\n const nextState: ObsidianSyncState = {\n version: 1,\n updatedAt: new Date().toISOString(),\n vaults: nextVaults,\n };\n const activeChunks = loadActiveObsidianChunks({\n state: nextState,\n defaultNamespace: \"default\",\n });\n const statePath = resolveNativeKnowledgeStatePath(options.memoryDir, options.config);\n try {\n await mkdir(path.dirname(statePath), { recursive: true });\n await writeFile(statePath, `${JSON.stringify(nextState, null, 2)}\\n`, \"utf-8\");\n } catch (error) {\n log.warn(`native knowledge: failed to persist obsidian sync state (fail-open): ${String(error)}`);\n }\n\n return {\n statePath,\n vaultCount: options.config.obsidianVaults.length,\n touchedNotes,\n deletedNotes,\n chunkCount,\n activeChunks,\n };\n}\n\nfunction loadActiveObsidianChunks(options: {\n state: ObsidianSyncState;\n recallNamespaces?: string[];\n defaultNamespace: string;\n}): NativeKnowledgeChunk[] {\n const out: NativeKnowledgeChunk[] = [];\n for (const vault of Object.values(options.state.vaults)) {\n for (const note of Object.values(vault.notes)) {\n if (note.deleted) continue;\n if (!isChunkAllowedForRecall(note, options.recallNamespaces, options.defaultNamespace)) continue;\n out.push(...note.chunks);\n }\n }\n return out;\n}\n\nfunction isChunkAllowedForRecall(\n chunk: Pick<NativeKnowledgeChunk, \"namespace\" | \"privacyClass\">,\n recallNamespaces: string[] | undefined,\n defaultNamespace: string,\n): boolean {\n const namespace = chunk.namespace?.trim() || defaultNamespace;\n if (\n Array.isArray(recallNamespaces) &&\n namespace !== defaultNamespace &&\n !recallNamespaces.includes(namespace)\n ) {\n return false;\n }\n const privacyClass = chunk.privacyClass?.trim().toLowerCase();\n if (\n privacyClass === \"private\" &&\n Array.isArray(recallNamespaces) &&\n (namespace !== defaultNamespace || !recallNamespaces.includes(defaultNamespace))\n ) {\n return false;\n }\n return true;\n}\n\nfunction loadActiveOpenClawWorkspaceChunks(options: {\n state: OpenClawWorkspaceSyncState;\n recallNamespaces?: string[];\n defaultNamespace: string;\n}): NativeKnowledgeChunk[] {\n const out: NativeKnowledgeChunk[] = [];\n for (const file of Object.values(options.state.files)) {\n if (file.deleted) continue;\n if (!isChunkAllowedForRecall(file, options.recallNamespaces, options.defaultNamespace)) continue;\n out.push(...file.chunks);\n }\n return out;\n}\n\nfunction deriveCuratedFileMetadata(options: {\n sourcePath: string;\n parsed: ParsedFrontmatter;\n}): Pick<NativeKnowledgeChunk, \"derivedDate\" | \"namespace\" | \"privacyClass\"> {\n return {\n derivedDate: deriveArtifactDate(options.sourcePath, options.parsed),\n namespace: firstStringValue(options.parsed.data, [\"namespace\"]) ?? deriveNamespaceFromIncludePath(options.sourcePath),\n privacyClass: firstStringValue(options.parsed.data, [\"privacyClass\", \"privacy\"]),\n };\n}\n\nfunction buildCuratedIncludeChunks(options: {\n sourcePath: string;\n body: string;\n bodyStartLine: number;\n maxChunkChars: number;\n sourceHash: string;\n mtimeMs: number;\n metadata: Pick<NativeKnowledgeChunk, \"derivedDate\" | \"namespace\" | \"privacyClass\">;\n}): NativeKnowledgeChunk[] {\n return chunkHeadingAware({\n sourcePath: options.sourcePath,\n content: options.body,\n maxChunkChars: options.maxChunkChars,\n startLineOffset: options.bodyStartLine - 1,\n createChunk: ({ title, startLine, endLine, content }) => ({\n chunkId: `${options.sourcePath}:${startLine}-${endLine}`,\n sourcePath: options.sourcePath,\n title,\n sourceKind: detectSourceKind(options.sourcePath),\n startLine,\n endLine,\n content,\n derivedDate: options.metadata.derivedDate,\n namespace: options.metadata.namespace,\n privacyClass: options.metadata.privacyClass,\n sourceHash: options.sourceHash,\n mtimeMs: options.mtimeMs,\n }),\n });\n}\n\nfunction loadActiveCuratedIncludeChunks(options: {\n state: CuratedIncludeFilesSyncState;\n recallNamespaces?: string[];\n defaultNamespace: string;\n}): NativeKnowledgeChunk[] {\n const out: NativeKnowledgeChunk[] = [];\n for (const file of Object.values(options.state.files)) {\n if (file.deleted) continue;\n if (!isChunkAllowedForRecall(file, options.recallNamespaces, options.defaultNamespace)) continue;\n out.push(...file.chunks);\n }\n return out;\n}\n\nfunction dedupeNativeKnowledgeChunks(chunks: NativeKnowledgeChunk[]): NativeKnowledgeChunk[] {\n const seen = new Set<string>();\n const priority = new Map<NativeKnowledgeChunk[\"sourceKind\"], number>([\n [\"handoff\", 1],\n [\"daily_summary\", 2],\n [\"bootstrap_doc\", 3],\n [\"automation_note\", 4],\n [\"workspace_doc\", 5],\n [\"identity\", 6],\n [\"memory\", 7],\n [\"obsidian_note\", 8],\n ]);\n return [...chunks]\n .sort((left, right) => {\n const leftPriority = priority.get(left.sourceKind) ?? 99;\n const rightPriority = priority.get(right.sourceKind) ?? 99;\n return (\n leftPriority - rightPriority\n || left.sourcePath.localeCompare(right.sourcePath)\n || left.startLine - right.startLine\n );\n })\n .filter((chunk) => {\n const key = [\n chunk.sourcePath,\n chunk.startLine,\n chunk.endLine,\n chunk.content,\n ].join(\"::\");\n if (seen.has(key)) return false;\n seen.add(key);\n return true;\n });\n}\n\nasync function findPersistedNativeKnowledgeStateFiles(\n rootDir: string,\n maxDepth: number,\n currentDepth: number = 0,\n): Promise<string[]> {\n if (currentDepth > maxDepth) return [];\n const entries = await readdir(rootDir, { withFileTypes: true }).catch(() => []);\n const out: string[] = [];\n for (const entry of entries) {\n const fullPath = path.join(rootDir, entry.name);\n if (entry.isFile() && PERSISTED_NATIVE_KNOWLEDGE_STATE_FILES.has(entry.name)) {\n out.push(fullPath);\n continue;\n }\n if (!entry.isDirectory()) continue;\n out.push(...await findPersistedNativeKnowledgeStateFiles(fullPath, maxDepth, currentDepth + 1));\n }\n return out;\n}\n\nexport async function loadPersistedNativeKnowledgeChunks(options: {\n memoryDir: string;\n recallNamespaces?: string[];\n defaultNamespace: string;\n}): Promise<NativeKnowledgeChunk[]> {\n const stateFiles = await findPersistedNativeKnowledgeStateFiles(options.memoryDir, 4);\n if (stateFiles.length === 0) return [];\n\n const chunks: NativeKnowledgeChunk[] = [];\n for (const statePath of stateFiles.sort()) {\n const raw = await readFile(statePath, \"utf-8\").catch(() => \"\");\n if (!raw) continue;\n try {\n const parsed = JSON.parse(raw) as { vaults?: unknown; files?: unknown };\n if (typeof parsed.vaults === \"object\" && parsed.vaults) {\n const state: ObsidianSyncState = {\n version: 1,\n updatedAt: new Date(0).toISOString(),\n vaults: parsed.vaults as Record<string, ObsidianVaultState>,\n };\n chunks.push(...loadActiveObsidianChunks({\n state,\n recallNamespaces: options.recallNamespaces,\n defaultNamespace: options.defaultNamespace,\n }).map((chunk) => {\n const note = Object.values(state.vaults)\n .flatMap((vault) => Object.values(vault.notes))\n .find((entry) => entry.chunks.some((candidate) => candidate.chunkId === chunk.chunkId));\n if (!note) return chunk;\n return {\n ...chunk,\n derivedDate: chunk.derivedDate ?? note.derivedDate,\n namespace: chunk.namespace ?? note.namespace,\n privacyClass: chunk.privacyClass ?? note.privacyClass,\n aliases: chunk.aliases ?? note.aliases,\n tags: chunk.tags ?? note.tags,\n wikilinks: chunk.wikilinks ?? note.wikilinks,\n backlinks: chunk.backlinks ?? note.backlinks,\n };\n }));\n continue;\n }\n if (typeof parsed.files === \"object\" && parsed.files) {\n if (path.basename(statePath) === \"openclaw-workspace-sync.json\") {\n const state: OpenClawWorkspaceSyncState = {\n version: 1,\n updatedAt: new Date(0).toISOString(),\n files: parsed.files as Record<string, OpenClawWorkspaceFileState>,\n };\n chunks.push(...loadActiveOpenClawWorkspaceChunks({\n state,\n recallNamespaces: options.recallNamespaces,\n defaultNamespace: options.defaultNamespace,\n }).map((chunk) => {\n const file = state.files[chunk.sourcePath];\n if (!file) return chunk;\n return {\n ...chunk,\n derivedDate: chunk.derivedDate ?? file.derivedDate,\n namespace: chunk.namespace ?? file.namespace,\n privacyClass: chunk.privacyClass ?? file.privacyClass,\n sessionKey: chunk.sessionKey ?? file.sessionKey,\n workflowKey: chunk.workflowKey ?? file.workflowKey,\n author: chunk.author ?? file.author,\n agent: chunk.agent ?? file.agent,\n };\n }));\n continue;\n }\n const state: CuratedIncludeFilesSyncState = {\n version: 1,\n updatedAt: new Date(0).toISOString(),\n files: parsed.files as Record<string, CuratedIncludeFileState>,\n };\n chunks.push(...loadActiveCuratedIncludeChunks({\n state,\n recallNamespaces: options.recallNamespaces,\n defaultNamespace: options.defaultNamespace,\n }).map((chunk) => {\n const file = state.files[chunk.sourcePath];\n if (!file) return chunk;\n return {\n ...chunk,\n derivedDate: chunk.derivedDate ?? file.derivedDate,\n namespace: chunk.namespace ?? file.namespace,\n privacyClass: chunk.privacyClass ?? file.privacyClass,\n };\n }));\n }\n } catch {\n continue;\n }\n }\n\n return dedupeNativeKnowledgeChunks(chunks);\n}\n\nexport async function syncOpenClawWorkspaceArtifacts(options: {\n workspaceDir: string;\n memoryDir: string;\n config: NativeKnowledgeConfig;\n}): Promise<{\n statePath: string;\n touchedFiles: number;\n deletedFiles: number;\n chunkCount: number;\n activeChunks: NativeKnowledgeChunk[];\n}> {\n const adapter = options.config.openclawWorkspace;\n const statePath = resolveOpenClawWorkspaceStatePath(options.memoryDir, options.config);\n if (!adapter?.enabled) {\n return { statePath, touchedFiles: 0, deletedFiles: 0, chunkCount: 0, activeChunks: [] };\n }\n\n const previousState = await loadOpenClawWorkspaceState(options.memoryDir, options.config);\n const listedFiles = await listMarkdownFiles(options.workspaceDir);\n if (listedFiles === null) {\n return {\n statePath,\n touchedFiles: 0,\n deletedFiles: 0,\n chunkCount: Object.values(previousState.files)\n .filter((file) => !file.deleted)\n .reduce((total, file) => total + file.chunks.length, 0),\n activeChunks: loadActiveOpenClawWorkspaceChunks({\n state: previousState,\n defaultNamespace: \"default\",\n }),\n };\n }\n\n const candidates = resolveFileCandidates({\n listedFiles,\n bootstrapFiles: adapter.bootstrapFiles,\n handoffGlobs: adapter.handoffGlobs,\n dailySummaryGlobs: adapter.dailySummaryGlobs,\n automationNoteGlobs: adapter.automationNoteGlobs,\n workspaceDocGlobs: adapter.workspaceDocGlobs,\n excludeGlobs: adapter.excludeGlobs,\n });\n const nextFiles: Record<string, OpenClawWorkspaceFileState> = {};\n const seen = new Set<string>();\n let touchedFiles = 0;\n let deletedFiles = 0;\n\n for (const candidate of candidates) {\n const absPath = path.join(options.workspaceDir, candidate.sourcePath);\n const content = await readFile(absPath, \"utf-8\").catch(() => null);\n if (content === null) continue;\n const info = await stat(absPath).catch(() => null);\n if (!info?.isFile()) continue;\n\n const sourceHash = createHash(\"sha256\").update(content).digest(\"hex\");\n const parsed = parseFrontmatter(content);\n const metadata = deriveOpenClawArtifactMetadata({\n sourcePath: candidate.sourcePath,\n parsed,\n sharedSafeGlobs: adapter.sharedSafeGlobs,\n });\n const title = resolveNoteTitle(candidate.sourcePath, parsed);\n const syncConfigHash = createHash(\"sha256\")\n .update(JSON.stringify({\n sourceKind: candidate.sourceKind,\n maxChunkChars: options.config.maxChunkChars,\n metadata,\n }))\n .digest(\"hex\");\n const previous = previousState.files[candidate.sourcePath];\n if (\n previous &&\n previous.deleted !== true &&\n previous.sourceHash === sourceHash &&\n previous.mtimeMs === info.mtimeMs &&\n previous.syncConfigHash === syncConfigHash\n ) {\n nextFiles[candidate.sourcePath] = {\n ...previous,\n deleted: false,\n deletedAt: undefined,\n };\n seen.add(candidate.sourcePath);\n continue;\n }\n\n const chunks = buildOpenClawWorkspaceChunks({\n sourcePath: candidate.sourcePath,\n sourceKind: candidate.sourceKind,\n body: parsed.body,\n bodyStartLine: parsed.bodyStartLine,\n maxChunkChars: options.config.maxChunkChars,\n sourceHash,\n mtimeMs: info.mtimeMs,\n metadata,\n });\n\n nextFiles[candidate.sourcePath] = {\n sourcePath: candidate.sourcePath,\n sourceKind: candidate.sourceKind,\n title,\n namespace: metadata.namespace,\n privacyClass: metadata.privacyClass,\n derivedDate: metadata.derivedDate,\n sessionKey: metadata.sessionKey,\n workflowKey: metadata.workflowKey,\n author: metadata.author,\n agent: metadata.agent,\n sourceHash,\n syncConfigHash,\n mtimeMs: info.mtimeMs,\n deleted: false,\n chunks,\n };\n touchedFiles += 1;\n seen.add(candidate.sourcePath);\n }\n\n for (const [sourcePath, previous] of Object.entries(previousState.files)) {\n if (seen.has(sourcePath)) continue;\n nextFiles[sourcePath] = {\n ...previous,\n deleted: true,\n deletedAt: new Date().toISOString(),\n chunks: [],\n };\n deletedFiles += 1;\n }\n\n const nextState: OpenClawWorkspaceSyncState = {\n version: 1,\n updatedAt: new Date().toISOString(),\n files: nextFiles,\n };\n const activeChunks = loadActiveOpenClawWorkspaceChunks({\n state: nextState,\n defaultNamespace: \"default\",\n });\n const chunkCount = activeChunks.length;\n try {\n await mkdir(path.dirname(statePath), { recursive: true });\n await writeFile(statePath, `${JSON.stringify(nextState, null, 2)}\\n`, \"utf-8\");\n } catch (error) {\n log.warn(`native knowledge: failed to persist openclaw workspace sync state (fail-open): ${String(error)}`);\n }\n\n return {\n statePath,\n touchedFiles,\n deletedFiles,\n chunkCount,\n activeChunks,\n };\n}\n\nexport async function syncCuratedIncludeFiles(options: {\n workspaceDir: string;\n memoryDir: string;\n config: NativeKnowledgeConfig;\n recallNamespaces?: string[];\n defaultNamespace: string;\n skipSourcePaths?: string[];\n}): Promise<{\n statePath: string;\n touchedFiles: number;\n deletedFiles: number;\n chunkCount: number;\n activeChunks: NativeKnowledgeChunk[];\n}> {\n const statePath = resolveCuratedIncludeFilesStatePath(options.memoryDir, options.config);\n const previousState = await loadCuratedIncludeFilesState(options.memoryDir, options.config);\n const workspaceInfo = await stat(options.workspaceDir).catch(() => null);\n if (!workspaceInfo?.isDirectory()) {\n return {\n statePath,\n touchedFiles: 0,\n deletedFiles: 0,\n chunkCount: Object.values(previousState.files)\n .filter((file) => !file.deleted)\n .reduce((total, file) => total + file.chunks.length, 0),\n activeChunks: loadActiveCuratedIncludeChunks({\n state: previousState,\n recallNamespaces: options.recallNamespaces,\n defaultNamespace: options.defaultNamespace,\n }),\n };\n }\n\n const skipped = new Set((options.skipSourcePaths ?? []).map((value) => value.replace(/\\\\/g, \"/\")));\n const candidatePaths = await resolveCandidatePaths({\n workspaceDir: options.workspaceDir,\n includeFiles: options.config.includeFiles,\n defaultNamespace: options.defaultNamespace,\n identityVariantMode: \"disk\",\n });\n const nextFiles: Record<string, CuratedIncludeFileState> = {};\n const seen = new Set<string>();\n let touchedFiles = 0;\n let deletedFiles = 0;\n\n for (const filePath of candidatePaths) {\n if (!(await readableFile(filePath))) continue;\n const content = await readFile(filePath, \"utf-8\").catch(() => null);\n if (content === null) continue;\n const info = await stat(filePath).catch(() => null);\n if (!info?.isFile()) continue;\n\n const sourcePath = path.relative(options.workspaceDir, filePath).replace(/\\\\/g, \"/\");\n if (skipped.has(sourcePath)) continue;\n\n const parsed = parseFrontmatter(content);\n const metadata = deriveCuratedFileMetadata({\n sourcePath,\n parsed,\n });\n const sourceKind = detectSourceKind(sourcePath);\n const sourceHash = createHash(\"sha256\").update(content).digest(\"hex\");\n const title = resolveNoteTitle(sourcePath, parsed);\n const syncConfigHash = createHash(\"sha256\")\n .update(JSON.stringify({\n sourceKind,\n maxChunkChars: options.config.maxChunkChars,\n metadata,\n }))\n .digest(\"hex\");\n const previous = previousState.files[sourcePath];\n if (\n previous &&\n previous.deleted !== true &&\n previous.sourceHash === sourceHash &&\n previous.mtimeMs === info.mtimeMs &&\n previous.syncConfigHash === syncConfigHash\n ) {\n nextFiles[sourcePath] = {\n ...previous,\n deleted: false,\n deletedAt: undefined,\n };\n seen.add(sourcePath);\n continue;\n }\n\n const chunks = buildCuratedIncludeChunks({\n sourcePath,\n body: parsed.body,\n bodyStartLine: parsed.bodyStartLine,\n maxChunkChars: options.config.maxChunkChars,\n sourceHash,\n mtimeMs: info.mtimeMs,\n metadata,\n });\n nextFiles[sourcePath] = {\n sourcePath,\n sourceKind,\n title,\n namespace: metadata.namespace,\n privacyClass: metadata.privacyClass,\n derivedDate: metadata.derivedDate,\n sourceHash,\n syncConfigHash,\n mtimeMs: info.mtimeMs,\n deleted: false,\n chunks,\n };\n touchedFiles += 1;\n seen.add(sourcePath);\n }\n\n for (const [sourcePath, previous] of Object.entries(previousState.files)) {\n if (seen.has(sourcePath) || skipped.has(sourcePath)) continue;\n if (previous.deleted) {\n nextFiles[sourcePath] = previous;\n continue;\n }\n nextFiles[sourcePath] = {\n ...previous,\n deleted: true,\n deletedAt: new Date().toISOString(),\n chunks: [],\n };\n deletedFiles += 1;\n }\n\n const nextState: CuratedIncludeFilesSyncState = {\n version: 1,\n updatedAt: new Date().toISOString(),\n files: nextFiles,\n };\n const activeChunks = loadActiveCuratedIncludeChunks({\n state: nextState,\n recallNamespaces: options.recallNamespaces,\n defaultNamespace: options.defaultNamespace,\n });\n const chunkCount = Object.values(nextFiles)\n .filter((file) => !file.deleted)\n .reduce((total, file) => total + file.chunks.length, 0);\n try {\n await mkdir(path.dirname(statePath), { recursive: true });\n await writeFile(statePath, `${JSON.stringify(nextState, null, 2)}\\n`, \"utf-8\");\n } catch (error) {\n log.warn(`native knowledge: failed to persist curated include sync state (fail-open): ${String(error)}`);\n }\n\n return {\n statePath,\n touchedFiles,\n deletedFiles,\n chunkCount,\n activeChunks,\n };\n}\n\nexport async function collectNativeKnowledgeChunks(options: {\n workspaceDir: string;\n memoryDir?: string;\n config: NativeKnowledgeConfig;\n recallNamespaces?: string[];\n defaultNamespace: string;\n abortSignal?: AbortSignal;\n}): Promise<NativeKnowledgeChunk[]> {\n throwIfNativeKnowledgeAborted(options.abortSignal);\n if (!options.config.enabled) return [];\n\n const chunks: NativeKnowledgeChunk[] = [];\n const openclawBootstrapFiles = new Set(\n (options.memoryDir && options.config.openclawWorkspace?.enabled\n ? options.config.openclawWorkspace.bootstrapFiles\n : []\n )\n .map((value) => value.replace(/\\\\/g, \"/\")),\n );\n if (options.memoryDir) {\n throwIfNativeKnowledgeAborted(options.abortSignal);\n const syncResult = await syncCuratedIncludeFiles({\n workspaceDir: options.workspaceDir,\n memoryDir: options.memoryDir,\n config: options.config,\n recallNamespaces: options.recallNamespaces,\n defaultNamespace: options.defaultNamespace,\n skipSourcePaths: [...openclawBootstrapFiles],\n });\n chunks.push(...syncResult.activeChunks);\n } else {\n throwIfNativeKnowledgeAborted(options.abortSignal);\n const candidatePaths = await resolveCandidatePaths({\n workspaceDir: options.workspaceDir,\n includeFiles: options.config.includeFiles,\n recallNamespaces: options.recallNamespaces,\n defaultNamespace: options.defaultNamespace,\n identityVariantMode: \"recall\",\n });\n for (const filePath of candidatePaths) {\n throwIfNativeKnowledgeAborted(options.abortSignal);\n if (!(await readableFile(filePath))) continue;\n const content = await readFile(filePath, \"utf-8\").catch(() => null);\n if (!content) continue;\n const sourcePath = path.relative(options.workspaceDir, filePath).replace(/\\\\/g, \"/\");\n if (openclawBootstrapFiles.has(sourcePath)) continue;\n const parsed = parseFrontmatter(content);\n const metadata = deriveCuratedFileMetadata({\n sourcePath,\n parsed,\n });\n const directChunks = buildCuratedIncludeChunks({\n sourcePath,\n body: parsed.body,\n bodyStartLine: parsed.bodyStartLine,\n maxChunkChars: options.config.maxChunkChars,\n sourceHash: createHash(\"sha256\").update(content).digest(\"hex\"),\n mtimeMs: 0,\n metadata,\n }).filter((chunk) => isChunkAllowedForRecall(chunk, options.recallNamespaces, options.defaultNamespace));\n chunks.push(...directChunks);\n }\n }\n\n if (options.memoryDir && options.config.openclawWorkspace?.enabled) {\n throwIfNativeKnowledgeAborted(options.abortSignal);\n const syncResult = await syncOpenClawWorkspaceArtifacts({\n workspaceDir: options.workspaceDir,\n memoryDir: options.memoryDir,\n config: options.config,\n });\n chunks.push(\n ...syncResult.activeChunks.filter((chunk) =>\n isChunkAllowedForRecall(chunk, options.recallNamespaces, options.defaultNamespace),\n ),\n );\n }\n\n if (options.memoryDir && options.config.obsidianVaults.length > 0) {\n throwIfNativeKnowledgeAborted(options.abortSignal);\n const syncResult = await syncObsidianVaults({\n memoryDir: options.memoryDir,\n config: options.config,\n });\n chunks.push(\n ...syncResult.activeChunks.filter((chunk) =>\n isChunkAllowedForRecall(chunk, options.recallNamespaces, options.defaultNamespace),\n ),\n );\n }\n\n return dedupeNativeKnowledgeChunks(chunks);\n}\n\nfunction throwIfNativeKnowledgeAborted(signal?: AbortSignal): void {\n if (!signal?.aborted) return;\n const err = new Error(\"native knowledge collection aborted\");\n Object.defineProperty(err, \"name\", { value: \"AbortError\" });\n throw err;\n}\n\nexport function searchNativeKnowledge(options: {\n query: string;\n chunks: NativeKnowledgeChunk[];\n maxResults: number;\n}): NativeKnowledgeSearchResult[] {\n const normalizedQuery = normalizeText(options.query);\n const queryTokens = new Set(tokenize(options.query));\n if (!normalizedQuery || queryTokens.size === 0 || options.maxResults <= 0) return [];\n const temporalQuery = /\\b(today|yesterday|recent|latest|current|next|handoff|summary)\\b/i.test(options.query);\n const now = Date.now();\n\n return options.chunks\n .map((chunk) => {\n const metadataText = [\n chunk.title,\n chunk.content,\n chunk.sourcePath,\n chunk.notePath,\n chunk.derivedDate,\n chunk.sessionKey,\n chunk.workflowKey,\n chunk.author,\n chunk.agent,\n ...(chunk.tags ?? []),\n ...(chunk.aliases ?? []),\n ...(chunk.wikilinks ?? []),\n ...(chunk.backlinks ?? []),\n ]\n .filter((value): value is string => typeof value === \"string\" && value.length > 0)\n .join(\"\\n\");\n const normalizedContent = normalizeText(metadataText);\n const contentTokens = new Set(tokenize(normalizedContent));\n let overlap = 0;\n for (const token of queryTokens) {\n if (contentTokens.has(token)) overlap += 1;\n }\n if (overlap === 0 && !normalizedContent.includes(normalizedQuery)) return null;\n const kindBoost =\n chunk.sourceKind === \"handoff\"\n ? 0.2\n : chunk.sourceKind === \"daily_summary\"\n ? 0.16\n : chunk.sourceKind === \"bootstrap_doc\" || chunk.sourceKind === \"identity\"\n ? 0.15\n : chunk.sourceKind === \"memory\"\n ? 0.1\n : chunk.sourceKind === \"obsidian_note\"\n ? 0.08\n : chunk.sourceKind === \"automation_note\"\n ? 0.06\n : 0.05;\n const phraseBoost = normalizedContent.includes(normalizedQuery) ? 0.35 : 0;\n const metadataBoost =\n (chunk.aliases?.some((alias) => normalizeText(alias).includes(normalizedQuery)) ? 0.12 : 0) +\n (chunk.tags?.some((tag) => normalizeText(tag).includes(normalizedQuery)) ? 0.08 : 0) +\n (chunk.derivedDate && normalizeText(chunk.derivedDate).includes(normalizedQuery) ? 0.08 : 0) +\n (chunk.sessionKey && normalizeText(chunk.sessionKey).includes(normalizedQuery) ? 0.1 : 0) +\n (chunk.workflowKey && normalizeText(chunk.workflowKey).includes(normalizedQuery) ? 0.08 : 0) +\n (chunk.agent && normalizeText(chunk.agent).includes(normalizedQuery) ? 0.06 : 0) +\n (chunk.author && normalizeText(chunk.author).includes(normalizedQuery) ? 0.05 : 0);\n let temporalBoost = 0;\n if (chunk.derivedDate) {\n const parsed = Date.parse(`${chunk.derivedDate}T00:00:00Z`);\n if (Number.isFinite(parsed)) {\n const ageDays = Math.max(0, Math.floor((now - parsed) / (24 * 60 * 60 * 1000)));\n if (ageDays <= 1) temporalBoost += temporalQuery ? 0.12 : 0.04;\n else if (ageDays <= 7) temporalBoost += temporalQuery ? 0.08 : 0.02;\n else if (temporalQuery && ageDays >= 90) temporalBoost -= 0.08;\n }\n }\n return {\n ...chunk,\n score: overlap / Math.max(queryTokens.size, 1) + kindBoost + phraseBoost + metadataBoost + temporalBoost,\n };\n })\n .filter((chunk): chunk is NativeKnowledgeSearchResult => chunk !== null)\n .sort((a, b) => b.score - a.score || a.sourcePath.localeCompare(b.sourcePath) || a.startLine - b.startLine)\n .slice(0, options.maxResults);\n}\n\nexport function formatNativeKnowledgeSection(options: {\n results: NativeKnowledgeSearchResult[];\n maxChars: number;\n}): string | null {\n if (options.results.length === 0 || options.maxChars <= 0) return null;\n const lines = [\"## Curated Workspace Knowledge\", \"\"];\n let used = lines.join(\"\\n\").length;\n\n for (const result of options.results) {\n const snippet = result.content.length > 500 ? `${result.content.slice(0, 497)}...` : result.content;\n const meta = [\n `kind=${result.sourceKind}`,\n result.derivedDate ? `date=${result.derivedDate}` : null,\n result.sessionKey ? `session=${result.sessionKey}` : null,\n result.workflowKey ? `workflow=${result.workflowKey}` : null,\n result.agent ? `agent=${result.agent}` : null,\n result.author ? `author=${result.author}` : null,\n result.tags && result.tags.length > 0 ? `tags=${result.tags.join(\",\")}` : null,\n result.vaultId ? `vault=${result.vaultId}` : null,\n ]\n .filter((value): value is string => value !== null)\n .join(\" \");\n const block =\n `- ${result.sourcePath}:${result.startLine}-${result.endLine} [${result.title}] ` +\n `(score: ${result.score.toFixed(3)}${meta ? `; ${meta}` : \"\"})\\n ${snippet.replace(/\\n/g, \"\\n \")}`;\n if (used + block.length > options.maxChars && lines.length > 2) break;\n if (used + block.length > options.maxChars) return null;\n lines.push(block);\n used += block.length + 1;\n }\n\n return lines.length > 2 ? lines.join(\"\\n\") : null;\n}\n"],"mappings":"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","names":["state"]}
@@ -0,0 +1,271 @@
1
+ import {
2
+ resolveWorkProductLedgerDir,
3
+ validateWorkProductLedgerEntry
4
+ } from "./chunk-CULXMQJH.js";
5
+ import {
6
+ TranscriptManager
7
+ } from "./chunk-UV2FO7J4.js";
8
+ import {
9
+ resolveObjectiveStateStoreDir,
10
+ validateObjectiveStateSnapshot
11
+ } from "./chunk-LOBRX7VD.js";
12
+ import {
13
+ resolveCommitmentLedgerDir,
14
+ validateCommitmentLedgerEntry
15
+ } from "./chunk-FYIYMQ5N.js";
16
+ import {
17
+ parseConfig
18
+ } from "./chunk-ISY75RLM.js";
19
+ import {
20
+ assertIsoRecordedAt,
21
+ assertSafePathSegment,
22
+ assertString,
23
+ isRecord,
24
+ optionalStringArray,
25
+ recordStoreDay,
26
+ validateStringRecord
27
+ } from "./chunk-DGXUHMOV.js";
28
+ import {
29
+ listJsonFiles,
30
+ readJsonFile
31
+ } from "./chunk-LPSF4OQH.js";
32
+
33
+ // src/resume-bundles.ts
34
+ import path from "path";
35
+ import { mkdir, writeFile } from "fs/promises";
36
+ var DEFAULT_RESUME_BUNDLE_REF_LIMIT = 5;
37
+ function resolveResumeBundleDir(memoryDir, overrideDir) {
38
+ if (typeof overrideDir === "string" && overrideDir.trim().length > 0) {
39
+ return overrideDir.trim();
40
+ }
41
+ return path.join(memoryDir, "state", "resume-bundles");
42
+ }
43
+ function validateResumeBundle(raw) {
44
+ if (!isRecord(raw)) throw new Error("resume bundle must be an object");
45
+ if (raw.schemaVersion !== 1) throw new Error("schemaVersion must be 1");
46
+ const source = assertString(raw.source, "source");
47
+ if (!["tool_result", "cli", "system", "manual"].includes(source)) {
48
+ throw new Error("source must be one of tool_result|cli|system|manual");
49
+ }
50
+ const recordedAt = assertIsoRecordedAt(assertString(raw.recordedAt, "recordedAt"));
51
+ if (!Number.isFinite(Date.parse(recordedAt))) {
52
+ throw new Error("recordedAt must be an ISO timestamp");
53
+ }
54
+ return {
55
+ schemaVersion: 1,
56
+ bundleId: assertSafePathSegment(assertString(raw.bundleId, "bundleId"), "bundleId"),
57
+ recordedAt,
58
+ sessionKey: assertString(raw.sessionKey, "sessionKey"),
59
+ source,
60
+ scope: assertString(raw.scope, "scope"),
61
+ summary: assertString(raw.summary, "summary"),
62
+ objectiveStateSnapshotRefs: optionalStringArray(raw.objectiveStateSnapshotRefs, "objectiveStateSnapshotRefs"),
63
+ workProductEntryRefs: optionalStringArray(raw.workProductEntryRefs, "workProductEntryRefs"),
64
+ commitmentEntryRefs: optionalStringArray(raw.commitmentEntryRefs, "commitmentEntryRefs"),
65
+ keyFacts: optionalStringArray(raw.keyFacts, "keyFacts"),
66
+ nextActions: optionalStringArray(raw.nextActions, "nextActions"),
67
+ riskFlags: optionalStringArray(raw.riskFlags, "riskFlags"),
68
+ metadata: validateStringRecord(raw.metadata, "metadata")
69
+ };
70
+ }
71
+ async function readValidatedItems(options) {
72
+ const files = await listJsonFiles(options.rootDir);
73
+ const items = [];
74
+ for (const filePath of files) {
75
+ try {
76
+ items.push(options.validate(await readJsonFile(filePath)));
77
+ } catch {
78
+ }
79
+ }
80
+ return items;
81
+ }
82
+ async function readObjectiveStateSnapshotsForSession(options) {
83
+ const rootDir = resolveObjectiveStateStoreDir(options.memoryDir, options.objectiveStateStoreDir);
84
+ const items = await readValidatedItems({
85
+ rootDir: path.join(rootDir, "snapshots"),
86
+ validate: validateObjectiveStateSnapshot
87
+ });
88
+ return items.filter((item) => item.sessionKey === options.sessionKey).sort((left, right) => right.recordedAt.localeCompare(left.recordedAt)).slice(0, options.maxResults ?? DEFAULT_RESUME_BUNDLE_REF_LIMIT);
89
+ }
90
+ async function readWorkProductEntriesForSession(options) {
91
+ const rootDir = resolveWorkProductLedgerDir(options.memoryDir, options.workProductLedgerDir);
92
+ const items = await readValidatedItems({
93
+ rootDir: path.join(rootDir, "entries"),
94
+ validate: validateWorkProductLedgerEntry
95
+ });
96
+ return items.filter((item) => item.sessionKey === options.sessionKey).sort((left, right) => right.recordedAt.localeCompare(left.recordedAt)).slice(0, options.maxResults ?? DEFAULT_RESUME_BUNDLE_REF_LIMIT);
97
+ }
98
+ async function readCommitmentEntriesForSession(options) {
99
+ const rootDir = resolveCommitmentLedgerDir(options.memoryDir, options.commitmentLedgerDir);
100
+ const items = await readValidatedItems({
101
+ rootDir: path.join(rootDir, "entries"),
102
+ validate: validateCommitmentLedgerEntry
103
+ });
104
+ return items.filter((item) => item.sessionKey === options.sessionKey).filter((item) => options.state ? item.state === options.state : true).sort((left, right) => right.recordedAt.localeCompare(left.recordedAt)).slice(0, options.maxResults ?? DEFAULT_RESUME_BUNDLE_REF_LIMIT);
105
+ }
106
+ function buildRecoveryFact(recoverySummary) {
107
+ return recoverySummary.healthy ? `Transcript recovery healthy with ${recoverySummary.issueCount} issue(s), ${recoverySummary.incompleteTurns} incomplete turn(s), and ${recoverySummary.brokenChains} broken chain(s).` : `Transcript recovery flagged ${recoverySummary.issueCount} issue(s), ${recoverySummary.incompleteTurns} incomplete turn(s), and ${recoverySummary.brokenChains} broken chain(s); checkpoint healthy: ${recoverySummary.checkpointHealthy ? "yes" : "no"}.`;
108
+ }
109
+ function buildBundleSummary(options) {
110
+ const parts = [
111
+ `${options.openCommitmentCount} open commitment(s)`,
112
+ `${options.workProductCount} recent work product(s)`,
113
+ `${options.objectiveSnapshotCount} recent objective-state snapshot(s)`
114
+ ];
115
+ if (options.recoveryHealthy === false) {
116
+ parts.push("transcript recovery issues remain");
117
+ }
118
+ return `Resume ${options.sessionKey}: ${parts.join(", ")}.`;
119
+ }
120
+ async function buildResumeBundleFromState(options) {
121
+ const recordedAt = assertIsoRecordedAt(options.recordedAt, "recordedAt");
122
+ const maxRefsPerStore = Math.max(1, Math.floor(options.maxRefsPerStore ?? DEFAULT_RESUME_BUNDLE_REF_LIMIT));
123
+ const objectiveSnapshots = options.objectiveStateMemoryEnabled ? await readObjectiveStateSnapshotsForSession({
124
+ memoryDir: options.memoryDir,
125
+ objectiveStateStoreDir: options.objectiveStateStoreDir,
126
+ sessionKey: options.sessionKey,
127
+ maxResults: maxRefsPerStore
128
+ }) : [];
129
+ const workProducts = options.creationMemoryEnabled ? await readWorkProductEntriesForSession({
130
+ memoryDir: options.memoryDir,
131
+ workProductLedgerDir: options.workProductLedgerDir,
132
+ sessionKey: options.sessionKey,
133
+ maxResults: maxRefsPerStore
134
+ }) : [];
135
+ const commitments = options.creationMemoryEnabled && options.commitmentLedgerEnabled ? await readCommitmentEntriesForSession({
136
+ memoryDir: options.memoryDir,
137
+ commitmentLedgerDir: options.commitmentLedgerDir,
138
+ sessionKey: options.sessionKey,
139
+ maxResults: maxRefsPerStore,
140
+ state: "open"
141
+ }) : [];
142
+ const openCommitments = commitments;
143
+ const recordedAtMs = Date.parse(recordedAt);
144
+ const overdueCommitments = openCommitments.filter((entry) => {
145
+ if (!entry.dueAt) return false;
146
+ const dueAtMs = Date.parse(entry.dueAt);
147
+ return Number.isFinite(dueAtMs) && dueAtMs < recordedAtMs;
148
+ });
149
+ let recoverySummary;
150
+ if (options.transcriptEnabled) {
151
+ const transcript = new TranscriptManager(parseConfig({
152
+ memoryDir: options.memoryDir,
153
+ transcriptEnabled: true
154
+ }));
155
+ await transcript.initialize();
156
+ recoverySummary = await transcript.getRecoverySummary(options.sessionKey);
157
+ }
158
+ const keyFacts = [
159
+ recoverySummary ? buildRecoveryFact(recoverySummary) : void 0,
160
+ workProducts[0]?.summary,
161
+ objectiveSnapshots[0]?.summary
162
+ ].filter((value) => typeof value === "string" && value.length > 0);
163
+ const nextActions = openCommitments.map((entry) => entry.summary).filter((summary, index, values) => values.indexOf(summary) === index).slice(0, maxRefsPerStore);
164
+ const riskFlags = [
165
+ recoverySummary && !recoverySummary.healthy ? buildRecoveryFact(recoverySummary) : void 0,
166
+ ...objectiveSnapshots.filter((snapshot) => snapshot.outcome === "failure" || snapshot.outcome === "partial").map((snapshot) => snapshot.summary),
167
+ ...overdueCommitments.map((entry) => `Overdue commitment: ${entry.summary}`)
168
+ ].filter(
169
+ (value, index, values) => typeof value === "string" && value.length > 0 && values.indexOf(value) === index
170
+ );
171
+ return validateResumeBundle({
172
+ schemaVersion: 1,
173
+ bundleId: options.bundleId,
174
+ recordedAt,
175
+ sessionKey: options.sessionKey,
176
+ source: options.source ?? "system",
177
+ scope: options.scope,
178
+ summary: buildBundleSummary({
179
+ sessionKey: options.sessionKey,
180
+ openCommitmentCount: openCommitments.length,
181
+ workProductCount: workProducts.length,
182
+ objectiveSnapshotCount: objectiveSnapshots.length,
183
+ recoveryHealthy: recoverySummary?.healthy
184
+ }),
185
+ objectiveStateSnapshotRefs: objectiveSnapshots.map((snapshot) => snapshot.snapshotId),
186
+ workProductEntryRefs: workProducts.map((entry) => entry.entryId),
187
+ commitmentEntryRefs: openCommitments.map((entry) => entry.entryId),
188
+ keyFacts: keyFacts.length > 0 ? keyFacts : void 0,
189
+ nextActions: nextActions.length > 0 ? nextActions : void 0,
190
+ riskFlags: riskFlags.length > 0 ? riskFlags : void 0
191
+ });
192
+ }
193
+ async function recordResumeBundle(options) {
194
+ const rootDir = resolveResumeBundleDir(options.memoryDir, options.resumeBundleDir);
195
+ const validated = validateResumeBundle(options.bundle);
196
+ const day = recordStoreDay(validated.recordedAt);
197
+ const bundlesDir = path.join(rootDir, "bundles", day);
198
+ const filePath = path.join(bundlesDir, `${validated.bundleId}.json`);
199
+ await mkdir(bundlesDir, { recursive: true });
200
+ await writeFile(filePath, JSON.stringify(validated, null, 2), "utf8");
201
+ return filePath;
202
+ }
203
+ async function readResumeBundles(options) {
204
+ const rootDir = resolveResumeBundleDir(options.memoryDir, options.resumeBundleDir);
205
+ const files = await listJsonFiles(path.join(rootDir, "bundles"));
206
+ const bundles = [];
207
+ const invalidBundles = [];
208
+ for (const filePath of files) {
209
+ try {
210
+ bundles.push(validateResumeBundle(await readJsonFile(filePath)));
211
+ } catch (error) {
212
+ invalidBundles.push({
213
+ path: filePath,
214
+ error: error instanceof Error ? error.message : String(error)
215
+ });
216
+ }
217
+ }
218
+ return { files, bundles, invalidBundles };
219
+ }
220
+ async function getResumeBundleStatus(options) {
221
+ const rootDir = resolveResumeBundleDir(options.memoryDir, options.resumeBundleDir);
222
+ const bundlesDir = path.join(rootDir, "bundles");
223
+ if (!options.enabled) {
224
+ return {
225
+ enabled: false,
226
+ rootDir,
227
+ bundlesDir,
228
+ bundles: {
229
+ total: 0,
230
+ valid: 0,
231
+ invalid: 0,
232
+ bySource: {}
233
+ },
234
+ invalidBundles: []
235
+ };
236
+ }
237
+ const { files, bundles, invalidBundles } = await readResumeBundles(options);
238
+ let latestBundle;
239
+ const bySource = {};
240
+ for (const bundle of bundles) {
241
+ bySource[bundle.source] = (bySource[bundle.source] ?? 0) + 1;
242
+ if (!latestBundle || Date.parse(bundle.recordedAt) > Date.parse(latestBundle.recordedAt)) {
243
+ latestBundle = bundle;
244
+ }
245
+ }
246
+ return {
247
+ enabled: options.enabled,
248
+ rootDir,
249
+ bundlesDir,
250
+ bundles: {
251
+ total: files.length,
252
+ valid: bundles.length,
253
+ invalid: invalidBundles.length,
254
+ bySource,
255
+ latestBundleId: latestBundle?.bundleId,
256
+ latestRecordedAt: latestBundle?.recordedAt,
257
+ latestSessionKey: latestBundle?.sessionKey
258
+ },
259
+ latestBundle,
260
+ invalidBundles
261
+ };
262
+ }
263
+
264
+ export {
265
+ resolveResumeBundleDir,
266
+ validateResumeBundle,
267
+ buildResumeBundleFromState,
268
+ recordResumeBundle,
269
+ getResumeBundleStatus
270
+ };
271
+ //# sourceMappingURL=chunk-QANCTXQF.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/resume-bundles.ts"],"sourcesContent":["import path from \"node:path\";\nimport { mkdir, writeFile } from \"node:fs/promises\";\nimport { listJsonFiles, readJsonFile } from \"./json-store.js\";\nimport {\n resolveObjectiveStateStoreDir,\n validateObjectiveStateSnapshot,\n type ObjectiveStateSnapshot,\n} from \"./objective-state.js\";\nimport {\n resolveWorkProductLedgerDir,\n validateWorkProductLedgerEntry,\n type WorkProductLedgerEntry,\n} from \"./work-product-ledger.js\";\nimport {\n resolveCommitmentLedgerDir,\n validateCommitmentLedgerEntry,\n type CommitmentLedgerEntry,\n} from \"./commitment-ledger.js\";\nimport { parseConfig } from \"./config.js\";\nimport { TranscriptManager } from \"./transcript.js\";\nimport {\n assertIsoRecordedAt,\n assertSafePathSegment,\n assertString,\n isRecord,\n optionalStringArray,\n recordStoreDay,\n validateStringRecord,\n} from \"./store-contract.js\";\n\nexport type ResumeBundleSource = \"tool_result\" | \"cli\" | \"system\" | \"manual\";\n\nexport interface ResumeBundle {\n schemaVersion: 1;\n bundleId: string;\n recordedAt: string;\n sessionKey: string;\n source: ResumeBundleSource;\n scope: string;\n summary: string;\n objectiveStateSnapshotRefs?: string[];\n workProductEntryRefs?: string[];\n commitmentEntryRefs?: string[];\n keyFacts?: string[];\n nextActions?: string[];\n riskFlags?: string[];\n metadata?: Record<string, string>;\n}\n\nexport interface ResumeBundleStatus {\n enabled: boolean;\n rootDir: string;\n bundlesDir: string;\n bundles: {\n total: number;\n valid: number;\n invalid: number;\n bySource: Partial<Record<ResumeBundleSource, number>>;\n latestBundleId?: string;\n latestRecordedAt?: string;\n latestSessionKey?: string;\n };\n latestBundle?: ResumeBundle;\n invalidBundles: Array<{\n path: string;\n error: string;\n }>;\n}\n\nconst DEFAULT_RESUME_BUNDLE_REF_LIMIT = 5;\n\nexport function resolveResumeBundleDir(memoryDir: string, overrideDir?: string): string {\n if (typeof overrideDir === \"string\" && overrideDir.trim().length > 0) {\n return overrideDir.trim();\n }\n return path.join(memoryDir, \"state\", \"resume-bundles\");\n}\n\nexport function validateResumeBundle(raw: unknown): ResumeBundle {\n if (!isRecord(raw)) throw new Error(\"resume bundle must be an object\");\n if (raw.schemaVersion !== 1) throw new Error(\"schemaVersion must be 1\");\n\n const source = assertString(raw.source, \"source\");\n if (![\"tool_result\", \"cli\", \"system\", \"manual\"].includes(source)) {\n throw new Error(\"source must be one of tool_result|cli|system|manual\");\n }\n\n const recordedAt = assertIsoRecordedAt(assertString(raw.recordedAt, \"recordedAt\"));\n if (!Number.isFinite(Date.parse(recordedAt))) {\n throw new Error(\"recordedAt must be an ISO timestamp\");\n }\n\n return {\n schemaVersion: 1,\n bundleId: assertSafePathSegment(assertString(raw.bundleId, \"bundleId\"), \"bundleId\"),\n recordedAt,\n sessionKey: assertString(raw.sessionKey, \"sessionKey\"),\n source: source as ResumeBundleSource,\n scope: assertString(raw.scope, \"scope\"),\n summary: assertString(raw.summary, \"summary\"),\n objectiveStateSnapshotRefs: optionalStringArray(raw.objectiveStateSnapshotRefs, \"objectiveStateSnapshotRefs\"),\n workProductEntryRefs: optionalStringArray(raw.workProductEntryRefs, \"workProductEntryRefs\"),\n commitmentEntryRefs: optionalStringArray(raw.commitmentEntryRefs, \"commitmentEntryRefs\"),\n keyFacts: optionalStringArray(raw.keyFacts, \"keyFacts\"),\n nextActions: optionalStringArray(raw.nextActions, \"nextActions\"),\n riskFlags: optionalStringArray(raw.riskFlags, \"riskFlags\"),\n metadata: validateStringRecord(raw.metadata, \"metadata\"),\n };\n}\n\nasync function readValidatedItems<T>(options: {\n rootDir: string;\n validate: (raw: unknown) => T;\n}): Promise<T[]> {\n const files = await listJsonFiles(options.rootDir);\n const items: T[] = [];\n for (const filePath of files) {\n try {\n items.push(options.validate(await readJsonFile(filePath)));\n } catch {\n // Status inspection already reports invalid artifacts. Bundle assembly fail-opens.\n }\n }\n return items;\n}\n\nasync function readObjectiveStateSnapshotsForSession(options: {\n memoryDir: string;\n objectiveStateStoreDir?: string;\n sessionKey: string;\n maxResults?: number;\n}): Promise<ObjectiveStateSnapshot[]> {\n const rootDir = resolveObjectiveStateStoreDir(options.memoryDir, options.objectiveStateStoreDir);\n const items = await readValidatedItems({\n rootDir: path.join(rootDir, \"snapshots\"),\n validate: validateObjectiveStateSnapshot,\n });\n return items\n .filter((item) => item.sessionKey === options.sessionKey)\n .sort((left, right) => right.recordedAt.localeCompare(left.recordedAt))\n .slice(0, options.maxResults ?? DEFAULT_RESUME_BUNDLE_REF_LIMIT);\n}\n\nasync function readWorkProductEntriesForSession(options: {\n memoryDir: string;\n workProductLedgerDir?: string;\n sessionKey: string;\n maxResults?: number;\n}): Promise<WorkProductLedgerEntry[]> {\n const rootDir = resolveWorkProductLedgerDir(options.memoryDir, options.workProductLedgerDir);\n const items = await readValidatedItems({\n rootDir: path.join(rootDir, \"entries\"),\n validate: validateWorkProductLedgerEntry,\n });\n return items\n .filter((item) => item.sessionKey === options.sessionKey)\n .sort((left, right) => right.recordedAt.localeCompare(left.recordedAt))\n .slice(0, options.maxResults ?? DEFAULT_RESUME_BUNDLE_REF_LIMIT);\n}\n\nasync function readCommitmentEntriesForSession(options: {\n memoryDir: string;\n commitmentLedgerDir?: string;\n sessionKey: string;\n maxResults?: number;\n state?: CommitmentLedgerEntry[\"state\"];\n}): Promise<CommitmentLedgerEntry[]> {\n const rootDir = resolveCommitmentLedgerDir(options.memoryDir, options.commitmentLedgerDir);\n const items = await readValidatedItems({\n rootDir: path.join(rootDir, \"entries\"),\n validate: validateCommitmentLedgerEntry,\n });\n return items\n .filter((item) => item.sessionKey === options.sessionKey)\n .filter((item) => (options.state ? item.state === options.state : true))\n .sort((left, right) => right.recordedAt.localeCompare(left.recordedAt))\n .slice(0, options.maxResults ?? DEFAULT_RESUME_BUNDLE_REF_LIMIT);\n}\n\nfunction buildRecoveryFact(recoverySummary: {\n healthy: boolean;\n issueCount: number;\n incompleteTurns: number;\n brokenChains: number;\n checkpointHealthy: boolean;\n}): string {\n return recoverySummary.healthy\n ? `Transcript recovery healthy with ${recoverySummary.issueCount} issue(s), ${recoverySummary.incompleteTurns} incomplete turn(s), and ${recoverySummary.brokenChains} broken chain(s).`\n : `Transcript recovery flagged ${recoverySummary.issueCount} issue(s), ${recoverySummary.incompleteTurns} incomplete turn(s), and ${recoverySummary.brokenChains} broken chain(s); checkpoint healthy: ${recoverySummary.checkpointHealthy ? \"yes\" : \"no\"}.`;\n}\n\nfunction buildBundleSummary(options: {\n sessionKey: string;\n openCommitmentCount: number;\n workProductCount: number;\n objectiveSnapshotCount: number;\n recoveryHealthy?: boolean;\n}): string {\n const parts = [\n `${options.openCommitmentCount} open commitment(s)`,\n `${options.workProductCount} recent work product(s)`,\n `${options.objectiveSnapshotCount} recent objective-state snapshot(s)`,\n ];\n if (options.recoveryHealthy === false) {\n parts.push(\"transcript recovery issues remain\");\n }\n return `Resume ${options.sessionKey}: ${parts.join(\", \")}.`;\n}\n\nexport async function buildResumeBundleFromState(options: {\n memoryDir: string;\n sessionKey: string;\n bundleId: string;\n recordedAt: string;\n scope: string;\n source?: ResumeBundleSource;\n transcriptEnabled?: boolean;\n objectiveStateMemoryEnabled?: boolean;\n objectiveStateStoreDir?: string;\n creationMemoryEnabled?: boolean;\n workProductLedgerDir?: string;\n commitmentLedgerEnabled?: boolean;\n commitmentLedgerDir?: string;\n maxRefsPerStore?: number;\n}): Promise<ResumeBundle> {\n const recordedAt = assertIsoRecordedAt(options.recordedAt, \"recordedAt\");\n const maxRefsPerStore = Math.max(1, Math.floor(options.maxRefsPerStore ?? DEFAULT_RESUME_BUNDLE_REF_LIMIT));\n\n const objectiveSnapshots = options.objectiveStateMemoryEnabled\n ? await readObjectiveStateSnapshotsForSession({\n memoryDir: options.memoryDir,\n objectiveStateStoreDir: options.objectiveStateStoreDir,\n sessionKey: options.sessionKey,\n maxResults: maxRefsPerStore,\n })\n : [];\n\n const workProducts = options.creationMemoryEnabled\n ? await readWorkProductEntriesForSession({\n memoryDir: options.memoryDir,\n workProductLedgerDir: options.workProductLedgerDir,\n sessionKey: options.sessionKey,\n maxResults: maxRefsPerStore,\n })\n : [];\n\n const commitments = options.creationMemoryEnabled && options.commitmentLedgerEnabled\n ? await readCommitmentEntriesForSession({\n memoryDir: options.memoryDir,\n commitmentLedgerDir: options.commitmentLedgerDir,\n sessionKey: options.sessionKey,\n maxResults: maxRefsPerStore,\n state: \"open\",\n })\n : [];\n\n const openCommitments = commitments;\n const recordedAtMs = Date.parse(recordedAt);\n const overdueCommitments = openCommitments.filter((entry) => {\n if (!entry.dueAt) return false;\n const dueAtMs = Date.parse(entry.dueAt);\n return Number.isFinite(dueAtMs) && dueAtMs < recordedAtMs;\n });\n\n let recoverySummary:\n | {\n healthy: boolean;\n issueCount: number;\n incompleteTurns: number;\n brokenChains: number;\n checkpointHealthy: boolean;\n }\n | undefined;\n if (options.transcriptEnabled) {\n const transcript = new TranscriptManager(parseConfig({\n memoryDir: options.memoryDir,\n transcriptEnabled: true,\n }));\n await transcript.initialize();\n recoverySummary = await transcript.getRecoverySummary(options.sessionKey);\n }\n\n const keyFacts = [\n recoverySummary ? buildRecoveryFact(recoverySummary) : undefined,\n workProducts[0]?.summary,\n objectiveSnapshots[0]?.summary,\n ].filter((value): value is string => typeof value === \"string\" && value.length > 0);\n\n const nextActions = openCommitments\n .map((entry) => entry.summary)\n .filter((summary, index, values) => values.indexOf(summary) === index)\n .slice(0, maxRefsPerStore);\n\n const riskFlags = [\n recoverySummary && !recoverySummary.healthy ? buildRecoveryFact(recoverySummary) : undefined,\n ...objectiveSnapshots\n .filter((snapshot) => snapshot.outcome === \"failure\" || snapshot.outcome === \"partial\")\n .map((snapshot) => snapshot.summary),\n ...overdueCommitments.map((entry) => `Overdue commitment: ${entry.summary}`),\n ].filter((value, index, values): value is string =>\n typeof value === \"string\" && value.length > 0 && values.indexOf(value) === index,\n );\n\n return validateResumeBundle({\n schemaVersion: 1,\n bundleId: options.bundleId,\n recordedAt,\n sessionKey: options.sessionKey,\n source: options.source ?? \"system\",\n scope: options.scope,\n summary: buildBundleSummary({\n sessionKey: options.sessionKey,\n openCommitmentCount: openCommitments.length,\n workProductCount: workProducts.length,\n objectiveSnapshotCount: objectiveSnapshots.length,\n recoveryHealthy: recoverySummary?.healthy,\n }),\n objectiveStateSnapshotRefs: objectiveSnapshots.map((snapshot) => snapshot.snapshotId),\n workProductEntryRefs: workProducts.map((entry) => entry.entryId),\n commitmentEntryRefs: openCommitments.map((entry) => entry.entryId),\n keyFacts: keyFacts.length > 0 ? keyFacts : undefined,\n nextActions: nextActions.length > 0 ? nextActions : undefined,\n riskFlags: riskFlags.length > 0 ? riskFlags : undefined,\n });\n}\n\nexport async function recordResumeBundle(options: {\n memoryDir: string;\n resumeBundleDir?: string;\n bundle: ResumeBundle;\n}): Promise<string> {\n const rootDir = resolveResumeBundleDir(options.memoryDir, options.resumeBundleDir);\n const validated = validateResumeBundle(options.bundle);\n const day = recordStoreDay(validated.recordedAt);\n const bundlesDir = path.join(rootDir, \"bundles\", day);\n const filePath = path.join(bundlesDir, `${validated.bundleId}.json`);\n await mkdir(bundlesDir, { recursive: true });\n await writeFile(filePath, JSON.stringify(validated, null, 2), \"utf8\");\n return filePath;\n}\n\nasync function readResumeBundles(options: {\n memoryDir: string;\n resumeBundleDir?: string;\n}): Promise<{\n files: string[];\n bundles: ResumeBundle[];\n invalidBundles: Array<{ path: string; error: string }>;\n}> {\n const rootDir = resolveResumeBundleDir(options.memoryDir, options.resumeBundleDir);\n const files = await listJsonFiles(path.join(rootDir, \"bundles\"));\n const bundles: ResumeBundle[] = [];\n const invalidBundles: Array<{ path: string; error: string }> = [];\n for (const filePath of files) {\n try {\n bundles.push(validateResumeBundle(await readJsonFile(filePath)));\n } catch (error) {\n invalidBundles.push({\n path: filePath,\n error: error instanceof Error ? error.message : String(error),\n });\n }\n }\n return { files, bundles, invalidBundles };\n}\n\nexport async function getResumeBundleStatus(options: {\n memoryDir: string;\n resumeBundleDir?: string;\n enabled: boolean;\n}): Promise<ResumeBundleStatus> {\n const rootDir = resolveResumeBundleDir(options.memoryDir, options.resumeBundleDir);\n const bundlesDir = path.join(rootDir, \"bundles\");\n if (!options.enabled) {\n return {\n enabled: false,\n rootDir,\n bundlesDir,\n bundles: {\n total: 0,\n valid: 0,\n invalid: 0,\n bySource: {},\n },\n invalidBundles: [],\n };\n }\n const { files, bundles, invalidBundles } = await readResumeBundles(options);\n\n let latestBundle: ResumeBundle | undefined;\n const bySource: Partial<Record<ResumeBundleSource, number>> = {};\n for (const bundle of bundles) {\n bySource[bundle.source] = (bySource[bundle.source] ?? 0) + 1;\n if (!latestBundle || Date.parse(bundle.recordedAt) > Date.parse(latestBundle.recordedAt)) {\n latestBundle = bundle;\n }\n }\n\n return {\n enabled: options.enabled,\n rootDir,\n bundlesDir,\n bundles: {\n total: files.length,\n valid: bundles.length,\n invalid: invalidBundles.length,\n bySource,\n latestBundleId: latestBundle?.bundleId,\n latestRecordedAt: latestBundle?.recordedAt,\n latestSessionKey: latestBundle?.sessionKey,\n },\n latestBundle,\n invalidBundles,\n };\n}\n"],"mappings":"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","names":[]}