@archipelagolab/lobi 1.0.0 → 1.0.5

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 (1165) hide show
  1. package/LICENSE +13 -17
  2. package/README.md +136 -0
  3. package/dist/APEv2Parser-6EMKXRZS.js +15 -0
  4. package/dist/APEv2Parser-6EMKXRZS.js.map +7 -0
  5. package/dist/AiffParser-E6XWRTXM.js +194 -0
  6. package/dist/AiffParser-E6XWRTXM.js.map +7 -0
  7. package/dist/AsfParser-WSOH2JQY.js +620 -0
  8. package/dist/AsfParser-WSOH2JQY.js.map +7 -0
  9. package/dist/DsdiffParser-EUWJ4YAR.js +192 -0
  10. package/dist/DsdiffParser-EUWJ4YAR.js.map +7 -0
  11. package/dist/DsfParser-R6TPBJIY.js +114 -0
  12. package/dist/DsfParser-R6TPBJIY.js.map +7 -0
  13. package/dist/FlacParser-VDASGZ3E.js +16 -0
  14. package/dist/FlacParser-VDASGZ3E.js.map +7 -0
  15. package/dist/MP4Parser-64RGJLUM.js +1145 -0
  16. package/dist/MP4Parser-64RGJLUM.js.map +7 -0
  17. package/dist/MatroskaParser-O6RXAKYA.js +662 -0
  18. package/dist/MatroskaParser-O6RXAKYA.js.map +7 -0
  19. package/dist/MpegParser-B6NX6DS3.js +652 -0
  20. package/dist/MpegParser-B6NX6DS3.js.map +7 -0
  21. package/dist/MusepackParser-WUBT63DS.js +331 -0
  22. package/dist/MusepackParser-WUBT63DS.js.map +7 -0
  23. package/dist/OggParser-ZY6E5C2P.js +448 -0
  24. package/dist/OggParser-ZY6E5C2P.js.map +7 -0
  25. package/dist/WavPackParser-5KTCSQEU.js +209 -0
  26. package/dist/WavPackParser-5KTCSQEU.js.map +7 -0
  27. package/dist/WaveParser-RZSHVQPZ.js +300 -0
  28. package/dist/WaveParser-RZSHVQPZ.js.map +7 -0
  29. package/dist/auth-presence.js +46 -0
  30. package/dist/auth-presence.js.map +7 -0
  31. package/dist/channel-plugin-api.js +79 -0
  32. package/dist/channel-plugin-api.js.map +7 -0
  33. package/dist/chunk-22WAAZ6I.js +114 -0
  34. package/dist/chunk-22WAAZ6I.js.map +7 -0
  35. package/dist/chunk-2A6HEFSO.js +676 -0
  36. package/dist/chunk-2A6HEFSO.js.map +7 -0
  37. package/dist/chunk-2KGHUHKU.js +169 -0
  38. package/dist/chunk-2KGHUHKU.js.map +7 -0
  39. package/dist/chunk-2NEQI4K6.js +171 -0
  40. package/dist/chunk-2NEQI4K6.js.map +7 -0
  41. package/dist/chunk-2OSJ3MTW.js +175 -0
  42. package/dist/chunk-2OSJ3MTW.js.map +7 -0
  43. package/dist/chunk-2Q626TDO.js +27 -0
  44. package/dist/chunk-2Q626TDO.js.map +7 -0
  45. package/dist/chunk-2U6OZ7N2.js +155 -0
  46. package/dist/chunk-2U6OZ7N2.js.map +7 -0
  47. package/dist/chunk-2Z4IOUDZ.js +129 -0
  48. package/dist/chunk-2Z4IOUDZ.js.map +7 -0
  49. package/dist/chunk-2ZEPAW7U.js +154 -0
  50. package/dist/chunk-2ZEPAW7U.js.map +7 -0
  51. package/dist/chunk-2ZI6JK5O.js +63 -0
  52. package/dist/chunk-2ZI6JK5O.js.map +7 -0
  53. package/dist/chunk-34UY6D6X.js +36 -0
  54. package/dist/chunk-34UY6D6X.js.map +7 -0
  55. package/dist/chunk-3JD6JSJD.js +111 -0
  56. package/dist/chunk-3JD6JSJD.js.map +7 -0
  57. package/dist/chunk-3TOEIHG5.js +314 -0
  58. package/dist/chunk-3TOEIHG5.js.map +7 -0
  59. package/dist/chunk-3TRKKAVT.js +130 -0
  60. package/dist/chunk-3TRKKAVT.js.map +7 -0
  61. package/dist/chunk-3UFTTK7C.js +418 -0
  62. package/dist/chunk-3UFTTK7C.js.map +7 -0
  63. package/dist/chunk-3XO6AAIC.js +25 -0
  64. package/dist/chunk-3XO6AAIC.js.map +7 -0
  65. package/dist/chunk-427SAQME.js +321 -0
  66. package/dist/chunk-427SAQME.js.map +7 -0
  67. package/dist/chunk-4JVNTZAI.js +80 -0
  68. package/dist/chunk-4JVNTZAI.js.map +7 -0
  69. package/dist/chunk-4O3BEYYM.js +187 -0
  70. package/dist/chunk-4O3BEYYM.js.map +7 -0
  71. package/dist/chunk-4Z2N4GW6.js +247 -0
  72. package/dist/chunk-4Z2N4GW6.js.map +7 -0
  73. package/dist/chunk-56HN4SH6.js +46 -0
  74. package/dist/chunk-56HN4SH6.js.map +7 -0
  75. package/dist/chunk-5APBBTGW.js +7 -0
  76. package/dist/chunk-5APBBTGW.js.map +7 -0
  77. package/dist/chunk-5LNGMBWW.js +93 -0
  78. package/dist/chunk-5LNGMBWW.js.map +7 -0
  79. package/dist/chunk-5XFQSYZ4.js +52 -0
  80. package/dist/chunk-5XFQSYZ4.js.map +7 -0
  81. package/dist/chunk-62N5N4AC.js +241 -0
  82. package/dist/chunk-62N5N4AC.js.map +7 -0
  83. package/dist/chunk-6HX3DEXK.js +178 -0
  84. package/dist/chunk-6HX3DEXK.js.map +7 -0
  85. package/dist/chunk-6NO5VEVV.js +18 -0
  86. package/dist/chunk-6NO5VEVV.js.map +7 -0
  87. package/dist/chunk-6PZGDVLR.js +465 -0
  88. package/dist/chunk-6PZGDVLR.js.map +7 -0
  89. package/dist/chunk-6SOGH3TW.js +163 -0
  90. package/dist/chunk-6SOGH3TW.js.map +7 -0
  91. package/dist/chunk-72TGY3LX.js +104 -0
  92. package/dist/chunk-72TGY3LX.js.map +7 -0
  93. package/dist/chunk-76IE55K7.js +392 -0
  94. package/dist/chunk-76IE55K7.js.map +7 -0
  95. package/dist/chunk-7F3242AO.js +86 -0
  96. package/dist/chunk-7F3242AO.js.map +7 -0
  97. package/dist/chunk-7FLQSTPG.js +57 -0
  98. package/dist/chunk-7FLQSTPG.js.map +7 -0
  99. package/dist/chunk-7MP46JBP.js +177 -0
  100. package/dist/chunk-7MP46JBP.js.map +7 -0
  101. package/dist/chunk-7MVZYR2T.js +87 -0
  102. package/dist/chunk-7MVZYR2T.js.map +7 -0
  103. package/dist/chunk-7N7ISMPG.js +50 -0
  104. package/dist/chunk-7N7ISMPG.js.map +7 -0
  105. package/dist/chunk-7S7LQQPX.js +127 -0
  106. package/dist/chunk-7S7LQQPX.js.map +7 -0
  107. package/dist/chunk-7TTNY5FK.js +21 -0
  108. package/dist/chunk-7TTNY5FK.js.map +7 -0
  109. package/dist/chunk-7W73QCTR.js +244 -0
  110. package/dist/chunk-7W73QCTR.js.map +7 -0
  111. package/dist/chunk-7XXLU33Y.js +76 -0
  112. package/dist/chunk-7XXLU33Y.js.map +7 -0
  113. package/dist/chunk-AAO7BQEV.js +258 -0
  114. package/dist/chunk-AAO7BQEV.js.map +7 -0
  115. package/dist/chunk-AH4MLRYT.js +91 -0
  116. package/dist/chunk-AH4MLRYT.js.map +7 -0
  117. package/dist/chunk-AHKR32FH.js +7 -0
  118. package/dist/chunk-AHKR32FH.js.map +7 -0
  119. package/dist/chunk-ALKRFDAW.js +94 -0
  120. package/dist/chunk-ALKRFDAW.js.map +7 -0
  121. package/dist/chunk-AQQGAE7N.js +12 -0
  122. package/dist/chunk-AQQGAE7N.js.map +7 -0
  123. package/dist/chunk-AWW3YUGJ.js +193 -0
  124. package/dist/chunk-AWW3YUGJ.js.map +7 -0
  125. package/dist/chunk-AX7VEEWJ.js +158 -0
  126. package/dist/chunk-AX7VEEWJ.js.map +7 -0
  127. package/dist/chunk-BAX7Q6GR.js +55 -0
  128. package/dist/chunk-BAX7Q6GR.js.map +7 -0
  129. package/dist/chunk-BBM6BR3Z.js +28 -0
  130. package/dist/chunk-BBM6BR3Z.js.map +7 -0
  131. package/dist/chunk-BHXZMHSX.js +109 -0
  132. package/dist/chunk-BHXZMHSX.js.map +7 -0
  133. package/dist/chunk-BIUXDLVY.js +62 -0
  134. package/dist/chunk-BIUXDLVY.js.map +7 -0
  135. package/dist/chunk-BMFZL2P4.js +97 -0
  136. package/dist/chunk-BMFZL2P4.js.map +7 -0
  137. package/dist/chunk-BQXEXK4H.js +114 -0
  138. package/dist/chunk-BQXEXK4H.js.map +7 -0
  139. package/dist/chunk-BU2CTWBG.js +30 -0
  140. package/dist/chunk-BU2CTWBG.js.map +7 -0
  141. package/dist/chunk-BVKSCLF7.js +195 -0
  142. package/dist/chunk-BVKSCLF7.js.map +7 -0
  143. package/dist/chunk-BWA3D22L.js +88 -0
  144. package/dist/chunk-BWA3D22L.js.map +7 -0
  145. package/dist/chunk-CE24RSPL.js +506 -0
  146. package/dist/chunk-CE24RSPL.js.map +7 -0
  147. package/dist/chunk-CETZGSCP.js +71 -0
  148. package/dist/chunk-CETZGSCP.js.map +7 -0
  149. package/dist/chunk-CGBWMONK.js +412 -0
  150. package/dist/chunk-CGBWMONK.js.map +7 -0
  151. package/dist/chunk-CPNIXMGX.js +127 -0
  152. package/dist/chunk-CPNIXMGX.js.map +7 -0
  153. package/dist/chunk-CSJO73LD.js +84 -0
  154. package/dist/chunk-CSJO73LD.js.map +7 -0
  155. package/dist/chunk-CTKBDSL6.js +81 -0
  156. package/dist/chunk-CTKBDSL6.js.map +7 -0
  157. package/dist/chunk-CY6WHUCW.js +54 -0
  158. package/dist/chunk-CY6WHUCW.js.map +7 -0
  159. package/dist/chunk-D7Q6Z74D.js +123 -0
  160. package/dist/chunk-D7Q6Z74D.js.map +7 -0
  161. package/dist/chunk-DZIM4OWK.js +17 -0
  162. package/dist/chunk-DZIM4OWK.js.map +7 -0
  163. package/dist/chunk-E3GC4V5V.js +30 -0
  164. package/dist/chunk-E3GC4V5V.js.map +7 -0
  165. package/dist/chunk-E5HPDHCW.js +34 -0
  166. package/dist/chunk-E5HPDHCW.js.map +7 -0
  167. package/dist/chunk-E75BJJZ2.js +635 -0
  168. package/dist/chunk-E75BJJZ2.js.map +7 -0
  169. package/dist/chunk-EE4DHUUZ.js +472 -0
  170. package/dist/chunk-EE4DHUUZ.js.map +7 -0
  171. package/dist/chunk-EHELTAAD.js +198 -0
  172. package/dist/chunk-EHELTAAD.js.map +7 -0
  173. package/dist/chunk-EKXPSI7Z.js +135 -0
  174. package/dist/chunk-EKXPSI7Z.js.map +7 -0
  175. package/dist/chunk-ERCH75SH.js +292 -0
  176. package/dist/chunk-ERCH75SH.js.map +7 -0
  177. package/dist/chunk-EVFWZGFL.js +235 -0
  178. package/dist/chunk-EVFWZGFL.js.map +7 -0
  179. package/dist/chunk-EVPBRKMZ.js +45 -0
  180. package/dist/chunk-EVPBRKMZ.js.map +7 -0
  181. package/dist/chunk-F6AFJHWV.js +45 -0
  182. package/dist/chunk-F6AFJHWV.js.map +7 -0
  183. package/dist/chunk-FG4NVFKM.js +455 -0
  184. package/dist/chunk-FG4NVFKM.js.map +7 -0
  185. package/dist/chunk-FHNEN6IR.js +14 -0
  186. package/dist/chunk-FHNEN6IR.js.map +7 -0
  187. package/dist/chunk-FQ4R7IOX.js +32 -0
  188. package/dist/chunk-FQ4R7IOX.js.map +7 -0
  189. package/dist/chunk-FQPYAPJJ.js +124 -0
  190. package/dist/chunk-FQPYAPJJ.js.map +7 -0
  191. package/dist/chunk-FQTLJO4W.js +335 -0
  192. package/dist/chunk-FQTLJO4W.js.map +7 -0
  193. package/dist/chunk-FVLJSB2W.js +124 -0
  194. package/dist/chunk-FVLJSB2W.js.map +7 -0
  195. package/dist/chunk-FYRKBNTI.js +18 -0
  196. package/dist/chunk-FYRKBNTI.js.map +7 -0
  197. package/dist/chunk-GD6L3SLC.js +30 -0
  198. package/dist/chunk-GD6L3SLC.js.map +7 -0
  199. package/dist/chunk-GI2ZANRY.js +24 -0
  200. package/dist/chunk-GI2ZANRY.js.map +7 -0
  201. package/dist/chunk-GK3XVKXT.js +737 -0
  202. package/dist/chunk-GK3XVKXT.js.map +7 -0
  203. package/dist/chunk-GKOWCDQV.js +699 -0
  204. package/dist/chunk-GKOWCDQV.js.map +7 -0
  205. package/dist/chunk-GLLRCKKE.js +26 -0
  206. package/dist/chunk-GLLRCKKE.js.map +7 -0
  207. package/dist/chunk-GNYG6I36.js +175 -0
  208. package/dist/chunk-GNYG6I36.js.map +7 -0
  209. package/dist/chunk-GVYGUH2V.js +7 -0
  210. package/dist/chunk-GVYGUH2V.js.map +7 -0
  211. package/dist/chunk-GZAGAWSU.js +28 -0
  212. package/dist/chunk-GZAGAWSU.js.map +7 -0
  213. package/dist/chunk-H23E72SB.js +163 -0
  214. package/dist/chunk-H23E72SB.js.map +7 -0
  215. package/dist/chunk-H6YVV7GE.js +22 -0
  216. package/dist/chunk-H6YVV7GE.js.map +7 -0
  217. package/dist/chunk-HDPICD3P.js +4890 -0
  218. package/dist/chunk-HDPICD3P.js.map +7 -0
  219. package/dist/chunk-HP5HMWOM.js +123 -0
  220. package/dist/chunk-HP5HMWOM.js.map +7 -0
  221. package/dist/chunk-HQSHS6IB.js +88 -0
  222. package/dist/chunk-HQSHS6IB.js.map +7 -0
  223. package/dist/chunk-HTV3R73W.js +51 -0
  224. package/dist/chunk-HTV3R73W.js.map +7 -0
  225. package/dist/chunk-IJCMYMZB.js +239 -0
  226. package/dist/chunk-IJCMYMZB.js.map +7 -0
  227. package/dist/chunk-INNENDEE.js +472 -0
  228. package/dist/chunk-INNENDEE.js.map +7 -0
  229. package/dist/chunk-IOTLSMEQ.js +177 -0
  230. package/dist/chunk-IOTLSMEQ.js.map +7 -0
  231. package/dist/chunk-IQYYEHSM.js +300 -0
  232. package/dist/chunk-IQYYEHSM.js.map +7 -0
  233. package/dist/chunk-IRA5NJ4Q.js +21 -0
  234. package/dist/chunk-IRA5NJ4Q.js.map +7 -0
  235. package/dist/chunk-IU7EXXK7.js +1662 -0
  236. package/dist/chunk-IU7EXXK7.js.map +7 -0
  237. package/dist/chunk-IUXAKDAY.js +102 -0
  238. package/dist/chunk-IUXAKDAY.js.map +7 -0
  239. package/dist/chunk-JMYIFYY5.js +233 -0
  240. package/dist/chunk-JMYIFYY5.js.map +7 -0
  241. package/dist/chunk-JSZBX2TA.js +5853 -0
  242. package/dist/chunk-JSZBX2TA.js.map +7 -0
  243. package/dist/chunk-KHFWQ334.js +138 -0
  244. package/dist/chunk-KHFWQ334.js.map +7 -0
  245. package/dist/chunk-KJW6JLM6.js +95 -0
  246. package/dist/chunk-KJW6JLM6.js.map +7 -0
  247. package/dist/chunk-KSEANSJE.js +40 -0
  248. package/dist/chunk-KSEANSJE.js.map +7 -0
  249. package/dist/chunk-KVU54E6W.js +63 -0
  250. package/dist/chunk-KVU54E6W.js.map +7 -0
  251. package/dist/chunk-L5OUVMHK.js +174 -0
  252. package/dist/chunk-L5OUVMHK.js.map +7 -0
  253. package/dist/chunk-LIVQ7GIO.js +86 -0
  254. package/dist/chunk-LIVQ7GIO.js.map +7 -0
  255. package/dist/chunk-LO4F6E3N.js +163 -0
  256. package/dist/chunk-LO4F6E3N.js.map +7 -0
  257. package/dist/chunk-LSVKDUNM.js +151 -0
  258. package/dist/chunk-LSVKDUNM.js.map +7 -0
  259. package/dist/chunk-LVMK2GPM.js +18 -0
  260. package/dist/chunk-LVMK2GPM.js.map +7 -0
  261. package/dist/chunk-LXVPETLK.js +1405 -0
  262. package/dist/chunk-LXVPETLK.js.map +7 -0
  263. package/dist/chunk-LZNW24OB.js +78 -0
  264. package/dist/chunk-LZNW24OB.js.map +7 -0
  265. package/dist/chunk-MAF6PSCJ.js +44 -0
  266. package/dist/chunk-MAF6PSCJ.js.map +7 -0
  267. package/dist/chunk-MBIX6Z7U.js +80 -0
  268. package/dist/chunk-MBIX6Z7U.js.map +7 -0
  269. package/dist/chunk-MDLLXMC3.js +183 -0
  270. package/dist/chunk-MDLLXMC3.js.map +7 -0
  271. package/dist/chunk-MEI5HTWV.js +127 -0
  272. package/dist/chunk-MEI5HTWV.js.map +7 -0
  273. package/dist/chunk-MH74AJ3A.js +82 -0
  274. package/dist/chunk-MH74AJ3A.js.map +7 -0
  275. package/dist/chunk-MIFIM4PI.js +163 -0
  276. package/dist/chunk-MIFIM4PI.js.map +7 -0
  277. package/dist/chunk-MISZB5QJ.js +22 -0
  278. package/dist/chunk-MISZB5QJ.js.map +7 -0
  279. package/dist/chunk-MJ27XQYG.js +125 -0
  280. package/dist/chunk-MJ27XQYG.js.map +7 -0
  281. package/dist/chunk-MLQY5SKR.js +52 -0
  282. package/dist/chunk-MLQY5SKR.js.map +7 -0
  283. package/dist/chunk-MTMHGC3G.js +39 -0
  284. package/dist/chunk-MTMHGC3G.js.map +7 -0
  285. package/dist/chunk-MWBAW3YV.js +244 -0
  286. package/dist/chunk-MWBAW3YV.js.map +7 -0
  287. package/dist/chunk-MZGGB2YT.js +50 -0
  288. package/dist/chunk-MZGGB2YT.js.map +7 -0
  289. package/dist/chunk-N5SNGZJV.js +217 -0
  290. package/dist/chunk-N5SNGZJV.js.map +7 -0
  291. package/dist/chunk-NGCTBYQ3.js +181 -0
  292. package/dist/chunk-NGCTBYQ3.js.map +7 -0
  293. package/dist/chunk-NMUX7SGU.js +676 -0
  294. package/dist/chunk-NMUX7SGU.js.map +7 -0
  295. package/dist/chunk-NO7GMLNU.js +292 -0
  296. package/dist/chunk-NO7GMLNU.js.map +7 -0
  297. package/dist/chunk-NTOGVX2Y.js +92 -0
  298. package/dist/chunk-NTOGVX2Y.js.map +7 -0
  299. package/dist/chunk-O5IVKDX7.js +30 -0
  300. package/dist/chunk-O5IVKDX7.js.map +7 -0
  301. package/dist/chunk-OFWMLQMU.js +7287 -0
  302. package/dist/chunk-OFWMLQMU.js.map +7 -0
  303. package/dist/chunk-OJ3ZUKBI.js +73 -0
  304. package/dist/chunk-OJ3ZUKBI.js.map +7 -0
  305. package/dist/chunk-OJTHE4B7.js +50 -0
  306. package/dist/chunk-OJTHE4B7.js.map +7 -0
  307. package/dist/chunk-OOYPYBTA.js +446 -0
  308. package/dist/chunk-OOYPYBTA.js.map +7 -0
  309. package/dist/chunk-OQP4W4AR.js +105 -0
  310. package/dist/chunk-OQP4W4AR.js.map +7 -0
  311. package/dist/chunk-OVTT2EKA.js +516 -0
  312. package/dist/chunk-OVTT2EKA.js.map +7 -0
  313. package/dist/chunk-P5N63LBS.js +94 -0
  314. package/dist/chunk-P5N63LBS.js.map +7 -0
  315. package/dist/chunk-PARITZ7F.js +28 -0
  316. package/dist/chunk-PARITZ7F.js.map +7 -0
  317. package/dist/chunk-PBQK4KY4.js +195 -0
  318. package/dist/chunk-PBQK4KY4.js.map +7 -0
  319. package/dist/chunk-PSL2AHIA.js +27 -0
  320. package/dist/chunk-PSL2AHIA.js.map +7 -0
  321. package/dist/chunk-Q5QT7JBM.js +92 -0
  322. package/dist/chunk-Q5QT7JBM.js.map +7 -0
  323. package/dist/chunk-Q7WA5DCR.js +62 -0
  324. package/dist/chunk-Q7WA5DCR.js.map +7 -0
  325. package/dist/chunk-QATEENP2.js +7 -0
  326. package/dist/chunk-QATEENP2.js.map +7 -0
  327. package/dist/chunk-QDT24CIA.js +485 -0
  328. package/dist/chunk-QDT24CIA.js.map +7 -0
  329. package/dist/chunk-QI3NB7D5.js +455 -0
  330. package/dist/chunk-QI3NB7D5.js.map +7 -0
  331. package/dist/chunk-QIDAVXSX.js +106 -0
  332. package/dist/chunk-QIDAVXSX.js.map +7 -0
  333. package/dist/chunk-QKIGQVP2.js +104 -0
  334. package/dist/chunk-QKIGQVP2.js.map +7 -0
  335. package/dist/chunk-QNJENPK2.js +81 -0
  336. package/dist/chunk-QNJENPK2.js.map +7 -0
  337. package/dist/chunk-REVXXWAS.js +31 -0
  338. package/dist/chunk-REVXXWAS.js.map +7 -0
  339. package/dist/chunk-RFH4HRZP.js +94 -0
  340. package/dist/chunk-RFH4HRZP.js.map +7 -0
  341. package/dist/chunk-RNGAGYCL.js +49 -0
  342. package/dist/chunk-RNGAGYCL.js.map +7 -0
  343. package/dist/chunk-RPCVN3JA.js +261 -0
  344. package/dist/chunk-RPCVN3JA.js.map +7 -0
  345. package/dist/chunk-RQQE5DDT.js +193 -0
  346. package/dist/chunk-RQQE5DDT.js.map +7 -0
  347. package/dist/chunk-RVOD3ESA.js +38 -0
  348. package/dist/chunk-RVOD3ESA.js.map +7 -0
  349. package/dist/chunk-SAOUP24A.js +70 -0
  350. package/dist/chunk-SAOUP24A.js.map +7 -0
  351. package/dist/chunk-SFZL2TCV.js +55 -0
  352. package/dist/chunk-SFZL2TCV.js.map +7 -0
  353. package/dist/chunk-SJPFUXBV.js +45 -0
  354. package/dist/chunk-SJPFUXBV.js.map +7 -0
  355. package/dist/chunk-SLIUQWAR.js +58 -0
  356. package/dist/chunk-SLIUQWAR.js.map +7 -0
  357. package/dist/chunk-SSEX66OL.js +39 -0
  358. package/dist/chunk-SSEX66OL.js.map +7 -0
  359. package/dist/chunk-SX2LOHOX.js +251 -0
  360. package/dist/chunk-SX2LOHOX.js.map +7 -0
  361. package/dist/chunk-T72EMFTX.js +74 -0
  362. package/dist/chunk-T72EMFTX.js.map +7 -0
  363. package/dist/chunk-TA2QJPPG.js +169 -0
  364. package/dist/chunk-TA2QJPPG.js.map +7 -0
  365. package/dist/chunk-TFEETDNY.js +78 -0
  366. package/dist/chunk-TFEETDNY.js.map +7 -0
  367. package/dist/chunk-THM2QV25.js +108 -0
  368. package/dist/chunk-THM2QV25.js.map +7 -0
  369. package/dist/chunk-TRWT2N6Z.js +15 -0
  370. package/dist/chunk-TRWT2N6Z.js.map +7 -0
  371. package/dist/chunk-TTXEM54Y.js +76 -0
  372. package/dist/chunk-TTXEM54Y.js.map +7 -0
  373. package/dist/chunk-U4LVIY5F.js +1405 -0
  374. package/dist/chunk-U4LVIY5F.js.map +7 -0
  375. package/dist/chunk-U767LCSG.js +78 -0
  376. package/dist/chunk-U767LCSG.js.map +7 -0
  377. package/dist/chunk-U7GKLHU6.js +120 -0
  378. package/dist/chunk-U7GKLHU6.js.map +7 -0
  379. package/dist/chunk-UAB5P5QO.js +60 -0
  380. package/dist/chunk-UAB5P5QO.js.map +7 -0
  381. package/dist/chunk-UEHPJQBL.js +38 -0
  382. package/dist/chunk-UEHPJQBL.js.map +7 -0
  383. package/dist/chunk-UIBV6IGR.js +31 -0
  384. package/dist/chunk-UIBV6IGR.js.map +7 -0
  385. package/dist/chunk-UIYFRUET.js +16352 -0
  386. package/dist/chunk-UIYFRUET.js.map +7 -0
  387. package/dist/chunk-UJS3TIVS.js +52 -0
  388. package/dist/chunk-UJS3TIVS.js.map +7 -0
  389. package/dist/chunk-UU5PSBSI.js +176 -0
  390. package/dist/chunk-UU5PSBSI.js.map +7 -0
  391. package/dist/chunk-UV63XYFU.js +173 -0
  392. package/dist/chunk-UV63XYFU.js.map +7 -0
  393. package/dist/chunk-UWPHOAOC.js +29 -0
  394. package/dist/chunk-UWPHOAOC.js.map +7 -0
  395. package/dist/chunk-UXDDOSJC.js +52 -0
  396. package/dist/chunk-UXDDOSJC.js.map +7 -0
  397. package/dist/chunk-V3VAOMCO.js +465 -0
  398. package/dist/chunk-V3VAOMCO.js.map +7 -0
  399. package/dist/chunk-VA7ENH2S.js +38 -0
  400. package/dist/chunk-VA7ENH2S.js.map +7 -0
  401. package/dist/chunk-VFPDFLVE.js +516 -0
  402. package/dist/chunk-VFPDFLVE.js.map +7 -0
  403. package/dist/chunk-VHG4FNIJ.js +93 -0
  404. package/dist/chunk-VHG4FNIJ.js.map +7 -0
  405. package/dist/chunk-VKOO6MIZ.js +51 -0
  406. package/dist/chunk-VKOO6MIZ.js.map +7 -0
  407. package/dist/chunk-VKXKRZG7.js +62 -0
  408. package/dist/chunk-VKXKRZG7.js.map +7 -0
  409. package/dist/chunk-VUOLPEUZ.js +7 -0
  410. package/dist/chunk-VUOLPEUZ.js.map +7 -0
  411. package/dist/chunk-W6SOBS7M.js +138 -0
  412. package/dist/chunk-W6SOBS7M.js.map +7 -0
  413. package/dist/chunk-WDOKKRTE.js +7 -0
  414. package/dist/chunk-WDOKKRTE.js.map +7 -0
  415. package/dist/chunk-WGXXKFN5.js +7 -0
  416. package/dist/chunk-WGXXKFN5.js.map +7 -0
  417. package/dist/chunk-WHPUUP3J.js +25 -0
  418. package/dist/chunk-WHPUUP3J.js.map +7 -0
  419. package/dist/chunk-XF7LD6VV.js +122 -0
  420. package/dist/chunk-XF7LD6VV.js.map +7 -0
  421. package/dist/chunk-XFTXM3RE.js +64 -0
  422. package/dist/chunk-XFTXM3RE.js.map +7 -0
  423. package/dist/chunk-XJABPO2T.js +235 -0
  424. package/dist/chunk-XJABPO2T.js.map +7 -0
  425. package/dist/chunk-XK6VF3H7.js +3586 -0
  426. package/dist/chunk-XK6VF3H7.js.map +7 -0
  427. package/dist/chunk-XQYIIPOJ.js +266 -0
  428. package/dist/chunk-XQYIIPOJ.js.map +7 -0
  429. package/dist/chunk-XZSAN55E.js +58 -0
  430. package/dist/chunk-XZSAN55E.js.map +7 -0
  431. package/dist/chunk-Y3KJR4OG.js +64 -0
  432. package/dist/chunk-Y3KJR4OG.js.map +7 -0
  433. package/dist/chunk-Y4JKH7FF.js +45 -0
  434. package/dist/chunk-Y4JKH7FF.js.map +7 -0
  435. package/dist/chunk-Y6CJN4ID.js +31 -0
  436. package/dist/chunk-Y6CJN4ID.js.map +7 -0
  437. package/dist/chunk-YABGJU5M.js +271 -0
  438. package/dist/chunk-YABGJU5M.js.map +7 -0
  439. package/dist/chunk-YEJH7ZC2.js +34 -0
  440. package/dist/chunk-YEJH7ZC2.js.map +7 -0
  441. package/dist/chunk-YFTE4H54.js +44117 -0
  442. package/dist/chunk-YFTE4H54.js.map +7 -0
  443. package/dist/chunk-YNJYMD43.js +392 -0
  444. package/dist/chunk-YNJYMD43.js.map +7 -0
  445. package/dist/chunk-YNYEQGVN.js +251 -0
  446. package/dist/chunk-YNYEQGVN.js.map +7 -0
  447. package/dist/chunk-YUPBD27Z.js +70 -0
  448. package/dist/chunk-YUPBD27Z.js.map +7 -0
  449. package/dist/chunk-YXJ52FD5.js +271 -0
  450. package/dist/chunk-YXJ52FD5.js.map +7 -0
  451. package/dist/chunk-YZGORRQN.js +3101 -0
  452. package/dist/chunk-YZGORRQN.js.map +7 -0
  453. package/dist/chunk-Z6IVJ6ZW.js +30 -0
  454. package/dist/chunk-Z6IVJ6ZW.js.map +7 -0
  455. package/dist/chunk-ZFC44XJJ.js +86 -0
  456. package/dist/chunk-ZFC44XJJ.js.map +7 -0
  457. package/dist/chunk-ZJDJC5TP.js +82 -0
  458. package/dist/chunk-ZJDJC5TP.js.map +7 -0
  459. package/dist/chunk-ZJGZNPDK.js +171 -0
  460. package/dist/chunk-ZJGZNPDK.js.map +7 -0
  461. package/dist/chunk-ZJHBJWZX.js +699 -0
  462. package/dist/chunk-ZJHBJWZX.js.map +7 -0
  463. package/dist/chunk-ZNOTD65D.js +95 -0
  464. package/dist/chunk-ZNOTD65D.js.map +7 -0
  465. package/dist/chunk-ZQ2QIFXW.js +122 -0
  466. package/dist/chunk-ZQ2QIFXW.js.map +7 -0
  467. package/dist/chunk-ZRMXPQGY.js +241 -0
  468. package/dist/chunk-ZRMXPQGY.js.map +7 -0
  469. package/dist/chunk-ZVEE5IDC.js +3101 -0
  470. package/dist/chunk-ZVEE5IDC.js.map +7 -0
  471. package/dist/cli-metadata.js +12 -0
  472. package/dist/cli-metadata.js.map +7 -0
  473. package/dist/contract-api.js +104 -0
  474. package/dist/contract-api.js.map +7 -0
  475. package/dist/dist-F3K7S5SS.js +549 -0
  476. package/dist/dist-F3K7S5SS.js.map +7 -0
  477. package/dist/helper-api.js +51 -0
  478. package/dist/helper-api.js.map +7 -0
  479. package/dist/index.js +71 -0
  480. package/dist/index.js.map +7 -0
  481. package/dist/magic-string.es-V5NOGTUV.js +1315 -0
  482. package/dist/magic-string.es-V5NOGTUV.js.map +7 -0
  483. package/dist/openclaw.plugin.json +23 -0
  484. package/dist/package.json +59 -0
  485. package/dist/plugin-entry.handlers.runtime-POD4CSHM.js +20 -0
  486. package/dist/plugin-entry.handlers.runtime-POD4CSHM.js.map +7 -0
  487. package/dist/plugin-entry.handlers.runtime-YOSG6V6U.js +20 -0
  488. package/dist/plugin-entry.handlers.runtime-YOSG6V6U.js.map +7 -0
  489. package/dist/runtime-api.js +104 -0
  490. package/dist/runtime-api.js.map +7 -0
  491. package/dist/rust-crypto-H35BXWUU.js +5323 -0
  492. package/dist/rust-crypto-H35BXWUU.js.map +7 -0
  493. package/dist/secret-contract-api.js +18 -0
  494. package/dist/secret-contract-api.js.map +7 -0
  495. package/dist/setup-entry.js +23 -0
  496. package/dist/setup-entry.js.map +7 -0
  497. package/dist/src/account-selection.js +19 -0
  498. package/dist/src/account-selection.js.map +7 -0
  499. package/dist/src/actions.js +24 -0
  500. package/dist/src/actions.js.map +7 -0
  501. package/dist/src/approval-auth.js +27 -0
  502. package/dist/src/approval-auth.js.map +7 -0
  503. package/dist/src/approval-handler.runtime.js +378 -0
  504. package/dist/src/approval-handler.runtime.js.map +7 -0
  505. package/dist/src/approval-ids.js +9 -0
  506. package/dist/src/approval-ids.js.map +7 -0
  507. package/dist/src/approval-native.js +28 -0
  508. package/dist/src/approval-native.js.map +7 -0
  509. package/dist/src/approval-reactions.js +20 -0
  510. package/dist/src/approval-reactions.js.map +7 -0
  511. package/dist/src/auth-precedence.js +8 -0
  512. package/dist/src/auth-precedence.js.map +7 -0
  513. package/dist/src/channel-account-paths.js +11 -0
  514. package/dist/src/channel-account-paths.js.map +7 -0
  515. package/dist/src/channel.js +74 -0
  516. package/dist/src/channel.js.map +7 -0
  517. package/dist/src/channel.runtime.js +82 -0
  518. package/dist/src/channel.runtime.js.map +7 -0
  519. package/dist/src/cli-metadata.js +8 -0
  520. package/dist/src/cli-metadata.js.map +7 -0
  521. package/dist/src/cli.js +936 -0
  522. package/dist/src/cli.js.map +7 -0
  523. package/dist/src/config-adapter.js +26 -0
  524. package/dist/src/config-adapter.js.map +7 -0
  525. package/dist/src/config-schema.js +8 -0
  526. package/dist/src/config-schema.js.map +7 -0
  527. package/dist/src/directory-live.js +35 -0
  528. package/dist/src/directory-live.js.map +7 -0
  529. package/dist/src/doctor-contract.js +11 -0
  530. package/dist/src/doctor-contract.js.map +7 -0
  531. package/dist/src/doctor.js +42 -0
  532. package/dist/src/doctor.js.map +7 -0
  533. package/dist/src/env-vars.js +12 -0
  534. package/dist/src/env-vars.js.map +7 -0
  535. package/dist/src/exec-approval-resolver.js +10 -0
  536. package/dist/src/exec-approval-resolver.js.map +7 -0
  537. package/dist/src/exec-approvals.js +51 -0
  538. package/dist/src/exec-approvals.js.map +7 -0
  539. package/dist/src/group-mentions.js +28 -0
  540. package/dist/src/group-mentions.js.map +7 -0
  541. package/dist/src/legacy-crypto-inspector-availability.js +8 -0
  542. package/dist/src/legacy-crypto-inspector-availability.js.map +7 -0
  543. package/dist/src/legacy-crypto.js +26 -0
  544. package/dist/src/legacy-crypto.js.map +7 -0
  545. package/dist/src/legacy-state.js +24 -0
  546. package/dist/src/legacy-state.js.map +7 -0
  547. package/dist/src/matrix/account-config.js +16 -0
  548. package/dist/src/matrix/account-config.js.map +7 -0
  549. package/dist/src/matrix/accounts.js +31 -0
  550. package/dist/src/matrix/accounts.js.map +7 -0
  551. package/dist/src/matrix/actions/client.js +40 -0
  552. package/dist/src/matrix/actions/client.js.map +7 -0
  553. package/dist/src/matrix/actions/devices.js +42 -0
  554. package/dist/src/matrix/actions/devices.js.map +7 -0
  555. package/dist/src/matrix/actions/limits.js +8 -0
  556. package/dist/src/matrix/actions/limits.js.map +7 -0
  557. package/dist/src/matrix/actions/messages.js +49 -0
  558. package/dist/src/matrix/actions/messages.js.map +7 -0
  559. package/dist/src/matrix/actions/pins.js +46 -0
  560. package/dist/src/matrix/actions/pins.js.map +7 -0
  561. package/dist/src/matrix/actions/polls.js +37 -0
  562. package/dist/src/matrix/actions/polls.js.map +7 -0
  563. package/dist/src/matrix/actions/profile.js +38 -0
  564. package/dist/src/matrix/actions/profile.js.map +7 -0
  565. package/dist/src/matrix/actions/reactions.js +40 -0
  566. package/dist/src/matrix/actions/reactions.js.map +7 -0
  567. package/dist/src/matrix/actions/room.js +40 -0
  568. package/dist/src/matrix/actions/room.js.map +7 -0
  569. package/dist/src/matrix/actions/summary.js +19 -0
  570. package/dist/src/matrix/actions/summary.js.map +7 -0
  571. package/dist/src/matrix/actions/types.js +13 -0
  572. package/dist/src/matrix/actions/types.js.map +7 -0
  573. package/dist/src/matrix/actions/verification.js +77 -0
  574. package/dist/src/matrix/actions/verification.js.map +7 -0
  575. package/dist/src/matrix/actions.js +126 -0
  576. package/dist/src/matrix/actions.js.map +7 -0
  577. package/dist/src/matrix/active-client.js +10 -0
  578. package/dist/src/matrix/active-client.js.map +7 -0
  579. package/dist/src/matrix/async-lock.js +8 -0
  580. package/dist/src/matrix/async-lock.js.map +7 -0
  581. package/dist/src/matrix/backup-health.js +10 -0
  582. package/dist/src/matrix/backup-health.js.map +7 -0
  583. package/dist/src/matrix/client/config-runtime-api.js +24 -0
  584. package/dist/src/matrix/client/config-runtime-api.js.map +7 -0
  585. package/dist/src/matrix/client/config-secret-input.runtime.js +11 -0
  586. package/dist/src/matrix/client/config-secret-input.runtime.js.map +7 -0
  587. package/dist/src/matrix/client/config.js +42 -0
  588. package/dist/src/matrix/client/config.js.map +7 -0
  589. package/dist/src/matrix/client/create-client.js +20 -0
  590. package/dist/src/matrix/client/create-client.js.map +7 -0
  591. package/dist/src/matrix/client/env-auth.js +26 -0
  592. package/dist/src/matrix/client/env-auth.js.map +7 -0
  593. package/dist/src/matrix/client/file-sync-store.js +23 -0
  594. package/dist/src/matrix/client/file-sync-store.js.map +7 -0
  595. package/dist/src/matrix/client/logging.js +17 -0
  596. package/dist/src/matrix/client/logging.js.map +7 -0
  597. package/dist/src/matrix/client/migration-snapshot.runtime.js +13 -0
  598. package/dist/src/matrix/client/migration-snapshot.runtime.js.map +7 -0
  599. package/dist/src/matrix/client/private-network-host.js +8 -0
  600. package/dist/src/matrix/client/private-network-host.js.map +7 -0
  601. package/dist/src/matrix/client/runtime.js +8 -0
  602. package/dist/src/matrix/client/runtime.js.map +7 -0
  603. package/dist/src/matrix/client/shared.js +34 -0
  604. package/dist/src/matrix/client/shared.js.map +7 -0
  605. package/dist/src/matrix/client/storage.js +26 -0
  606. package/dist/src/matrix/client/storage.js.map +7 -0
  607. package/dist/src/matrix/client/types.js +7 -0
  608. package/dist/src/matrix/client/types.js.map +7 -0
  609. package/dist/src/matrix/client-bootstrap.js +15 -0
  610. package/dist/src/matrix/client-bootstrap.js.map +7 -0
  611. package/dist/src/matrix/client-resolver.test-helpers.js +122 -0
  612. package/dist/src/matrix/client-resolver.test-helpers.js.map +7 -0
  613. package/dist/src/matrix/client.js +63 -0
  614. package/dist/src/matrix/client.js.map +7 -0
  615. package/dist/src/matrix/config-paths.js +12 -0
  616. package/dist/src/matrix/config-paths.js.map +7 -0
  617. package/dist/src/matrix/config-update.js +17 -0
  618. package/dist/src/matrix/config-update.js.map +7 -0
  619. package/dist/src/matrix/credentials-read.js +22 -0
  620. package/dist/src/matrix/credentials-read.js.map +7 -0
  621. package/dist/src/matrix/credentials-write.runtime.js +24 -0
  622. package/dist/src/matrix/credentials-write.runtime.js.map +7 -0
  623. package/dist/src/matrix/credentials.js +90 -0
  624. package/dist/src/matrix/credentials.js.map +7 -0
  625. package/dist/src/matrix/deps.js +12 -0
  626. package/dist/src/matrix/deps.js.map +7 -0
  627. package/dist/src/matrix/device-health.js +10 -0
  628. package/dist/src/matrix/device-health.js.map +7 -0
  629. package/dist/src/matrix/direct-management.js +18 -0
  630. package/dist/src/matrix/direct-management.js.map +7 -0
  631. package/dist/src/matrix/direct-room.js +18 -0
  632. package/dist/src/matrix/direct-room.js.map +7 -0
  633. package/dist/src/matrix/draft-stream.js +33 -0
  634. package/dist/src/matrix/draft-stream.js.map +7 -0
  635. package/dist/src/matrix/encryption-guidance.js +17 -0
  636. package/dist/src/matrix/encryption-guidance.js.map +7 -0
  637. package/dist/src/matrix/errors.js +12 -0
  638. package/dist/src/matrix/errors.js.map +7 -0
  639. package/dist/src/matrix/format.js +13 -0
  640. package/dist/src/matrix/format.js.map +7 -0
  641. package/dist/src/matrix/legacy-crypto-inspector.js +73 -0
  642. package/dist/src/matrix/legacy-crypto-inspector.js.map +7 -0
  643. package/dist/src/matrix/media-errors.js +12 -0
  644. package/dist/src/matrix/media-errors.js.map +7 -0
  645. package/dist/src/matrix/media-text.js +22 -0
  646. package/dist/src/matrix/media-text.js.map +7 -0
  647. package/dist/src/matrix/monitor/access-state.js +9 -0
  648. package/dist/src/matrix/monitor/access-state.js.map +7 -0
  649. package/dist/src/matrix/monitor/ack-config.js +10 -0
  650. package/dist/src/matrix/monitor/ack-config.js.map +7 -0
  651. package/dist/src/matrix/monitor/allowlist.js +12 -0
  652. package/dist/src/matrix/monitor/allowlist.js.map +7 -0
  653. package/dist/src/matrix/monitor/auto-join.js +9 -0
  654. package/dist/src/matrix/monitor/auto-join.js.map +7 -0
  655. package/dist/src/matrix/monitor/config.js +37 -0
  656. package/dist/src/matrix/monitor/config.js.map +7 -0
  657. package/dist/src/matrix/monitor/context-summary.js +13 -0
  658. package/dist/src/matrix/monitor/context-summary.js.map +7 -0
  659. package/dist/src/matrix/monitor/direct.js +13 -0
  660. package/dist/src/matrix/monitor/direct.js.map +7 -0
  661. package/dist/src/matrix/monitor/events.js +20 -0
  662. package/dist/src/matrix/monitor/events.js.map +7 -0
  663. package/dist/src/matrix/monitor/handler.js +76 -0
  664. package/dist/src/matrix/monitor/handler.js.map +7 -0
  665. package/dist/src/matrix/monitor/handler.test-helpers.js +268 -0
  666. package/dist/src/matrix/monitor/handler.test-helpers.js.map +7 -0
  667. package/dist/src/matrix/monitor/inbound-dedupe.js +17 -0
  668. package/dist/src/matrix/monitor/inbound-dedupe.js.map +7 -0
  669. package/dist/src/matrix/monitor/index.js +502 -0
  670. package/dist/src/matrix/monitor/index.js.map +7 -0
  671. package/dist/src/matrix/monitor/legacy-crypto-restore.js +99 -0
  672. package/dist/src/matrix/monitor/legacy-crypto-restore.js.map +7 -0
  673. package/dist/src/matrix/monitor/location.js +11 -0
  674. package/dist/src/matrix/monitor/location.js.map +7 -0
  675. package/dist/src/matrix/monitor/media.js +10 -0
  676. package/dist/src/matrix/monitor/media.js.map +7 -0
  677. package/dist/src/matrix/monitor/mentions.js +9 -0
  678. package/dist/src/matrix/monitor/mentions.js.map +7 -0
  679. package/dist/src/matrix/monitor/reaction-events.js +38 -0
  680. package/dist/src/matrix/monitor/reaction-events.js.map +7 -0
  681. package/dist/src/matrix/monitor/recent-invite.js +10 -0
  682. package/dist/src/matrix/monitor/recent-invite.js.map +7 -0
  683. package/dist/src/matrix/monitor/replies.js +33 -0
  684. package/dist/src/matrix/monitor/replies.js.map +7 -0
  685. package/dist/src/matrix/monitor/reply-context.js +14 -0
  686. package/dist/src/matrix/monitor/reply-context.js.map +7 -0
  687. package/dist/src/matrix/monitor/room-history.js +10 -0
  688. package/dist/src/matrix/monitor/room-history.js.map +7 -0
  689. package/dist/src/matrix/monitor/room-info.js +9 -0
  690. package/dist/src/matrix/monitor/room-info.js.map +7 -0
  691. package/dist/src/matrix/monitor/rooms.js +9 -0
  692. package/dist/src/matrix/monitor/rooms.js.map +7 -0
  693. package/dist/src/matrix/monitor/route.js +12 -0
  694. package/dist/src/matrix/monitor/route.js.map +7 -0
  695. package/dist/src/matrix/monitor/runtime-api.js +40 -0
  696. package/dist/src/matrix/monitor/runtime-api.js.map +7 -0
  697. package/dist/src/matrix/monitor/startup-verification.js +174 -0
  698. package/dist/src/matrix/monitor/startup-verification.js.map +7 -0
  699. package/dist/src/matrix/monitor/startup.js +9 -0
  700. package/dist/src/matrix/monitor/startup.js.map +7 -0
  701. package/dist/src/matrix/monitor/status.js +10 -0
  702. package/dist/src/matrix/monitor/status.js.map +7 -0
  703. package/dist/src/matrix/monitor/sync-lifecycle.js +9 -0
  704. package/dist/src/matrix/monitor/sync-lifecycle.js.map +7 -0
  705. package/dist/src/matrix/monitor/task-runner.js +8 -0
  706. package/dist/src/matrix/monitor/task-runner.js.map +7 -0
  707. package/dist/src/matrix/monitor/thread-context.js +14 -0
  708. package/dist/src/matrix/monitor/thread-context.js.map +7 -0
  709. package/dist/src/matrix/monitor/threads.js +16 -0
  710. package/dist/src/matrix/monitor/threads.js.map +7 -0
  711. package/dist/src/matrix/monitor/types.js +11 -0
  712. package/dist/src/matrix/monitor/types.js.map +7 -0
  713. package/dist/src/matrix/monitor/verification-events.js +13 -0
  714. package/dist/src/matrix/monitor/verification-events.js.map +7 -0
  715. package/dist/src/matrix/monitor/verification-utils.js +16 -0
  716. package/dist/src/matrix/monitor/verification-utils.js.map +7 -0
  717. package/dist/src/matrix/outbound-media-runtime.js +9 -0
  718. package/dist/src/matrix/outbound-media-runtime.js.map +7 -0
  719. package/dist/src/matrix/poll-summary.js +14 -0
  720. package/dist/src/matrix/poll-summary.js.map +7 -0
  721. package/dist/src/matrix/poll-types.js +55 -0
  722. package/dist/src/matrix/poll-types.js.map +7 -0
  723. package/dist/src/matrix/probe.js +9 -0
  724. package/dist/src/matrix/probe.js.map +7 -0
  725. package/dist/src/matrix/probe.runtime.js +30 -0
  726. package/dist/src/matrix/probe.runtime.js.map +7 -0
  727. package/dist/src/matrix/profile.js +16 -0
  728. package/dist/src/matrix/profile.js.map +7 -0
  729. package/dist/src/matrix/reaction-common.js +26 -0
  730. package/dist/src/matrix/reaction-common.js.map +7 -0
  731. package/dist/src/matrix/sdk/crypto-bootstrap.js +15 -0
  732. package/dist/src/matrix/sdk/crypto-bootstrap.js.map +7 -0
  733. package/dist/src/matrix/sdk/crypto-facade.js +8 -0
  734. package/dist/src/matrix/sdk/crypto-facade.js.map +7 -0
  735. package/dist/src/matrix/sdk/crypto-node.runtime.js +15 -0
  736. package/dist/src/matrix/sdk/crypto-node.runtime.js.map +7 -0
  737. package/dist/src/matrix/sdk/crypto-runtime.js +84 -0
  738. package/dist/src/matrix/sdk/crypto-runtime.js.map +7 -0
  739. package/dist/src/matrix/sdk/decrypt-bridge.js +11 -0
  740. package/dist/src/matrix/sdk/decrypt-bridge.js.map +7 -0
  741. package/dist/src/matrix/sdk/event-helpers.js +12 -0
  742. package/dist/src/matrix/sdk/event-helpers.js.map +7 -0
  743. package/dist/src/matrix/sdk/http-client.js +13 -0
  744. package/dist/src/matrix/sdk/http-client.js.map +7 -0
  745. package/dist/src/matrix/sdk/idb-persistence-lock.js +12 -0
  746. package/dist/src/matrix/sdk/idb-persistence-lock.js.map +7 -0
  747. package/dist/src/matrix/sdk/idb-persistence.js +13 -0
  748. package/dist/src/matrix/sdk/idb-persistence.js.map +7 -0
  749. package/dist/src/matrix/sdk/idb-persistence.test-helpers.js +83 -0
  750. package/dist/src/matrix/sdk/idb-persistence.test-helpers.js.map +7 -0
  751. package/dist/src/matrix/sdk/logger.js +15 -0
  752. package/dist/src/matrix/sdk/logger.js.map +7 -0
  753. package/dist/src/matrix/sdk/read-response-with-limit.js +8 -0
  754. package/dist/src/matrix/sdk/read-response-with-limit.js.map +7 -0
  755. package/dist/src/matrix/sdk/recovery-key-store.js +14 -0
  756. package/dist/src/matrix/sdk/recovery-key-store.js.map +7 -0
  757. package/dist/src/matrix/sdk/transport.js +13 -0
  758. package/dist/src/matrix/sdk/transport.js.map +7 -0
  759. package/dist/src/matrix/sdk/types.js +7 -0
  760. package/dist/src/matrix/sdk/types.js.map +7 -0
  761. package/dist/src/matrix/sdk/verification-manager.js +11 -0
  762. package/dist/src/matrix/sdk/verification-manager.js.map +7 -0
  763. package/dist/src/matrix/sdk/verification-status.js +12 -0
  764. package/dist/src/matrix/sdk/verification-status.js.map +7 -0
  765. package/dist/src/matrix/sdk.js +1375 -0
  766. package/dist/src/matrix/sdk.js.map +7 -0
  767. package/dist/src/matrix/send/client.js +14 -0
  768. package/dist/src/matrix/send/client.js.map +7 -0
  769. package/dist/src/matrix/send/formatting.js +29 -0
  770. package/dist/src/matrix/send/formatting.js.map +7 -0
  771. package/dist/src/matrix/send/media.js +26 -0
  772. package/dist/src/matrix/send/media.js.map +7 -0
  773. package/dist/src/matrix/send/targets.js +15 -0
  774. package/dist/src/matrix/send/targets.js.map +7 -0
  775. package/dist/src/matrix/send/types.js +17 -0
  776. package/dist/src/matrix/send/types.js.map +7 -0
  777. package/dist/src/matrix/send.js +51 -0
  778. package/dist/src/matrix/send.js.map +7 -0
  779. package/dist/src/matrix/session-store-metadata.js +15 -0
  780. package/dist/src/matrix/session-store-metadata.js.map +7 -0
  781. package/dist/src/matrix/startup-abort.js +14 -0
  782. package/dist/src/matrix/startup-abort.js.map +7 -0
  783. package/dist/src/matrix/sync-state.js +12 -0
  784. package/dist/src/matrix/sync-state.js.map +7 -0
  785. package/dist/src/matrix/target-ids.js +20 -0
  786. package/dist/src/matrix/target-ids.js.map +7 -0
  787. package/dist/src/matrix/thread-bindings-shared.js +34 -0
  788. package/dist/src/matrix/thread-bindings-shared.js.map +7 -0
  789. package/dist/src/matrix/thread-bindings.js +49 -0
  790. package/dist/src/matrix/thread-bindings.js.map +7 -0
  791. package/dist/src/matrix-migration.runtime.js +45 -0
  792. package/dist/src/matrix-migration.runtime.js.map +7 -0
  793. package/dist/src/migration-config.js +29 -0
  794. package/dist/src/migration-config.js.map +7 -0
  795. package/dist/src/migration-snapshot-backup.js +12 -0
  796. package/dist/src/migration-snapshot-backup.js.map +7 -0
  797. package/dist/src/migration-snapshot.js +38 -0
  798. package/dist/src/migration-snapshot.js.map +7 -0
  799. package/dist/src/onboarding.js +43 -0
  800. package/dist/src/onboarding.js.map +7 -0
  801. package/dist/src/onboarding.test-harness.js +124 -0
  802. package/dist/src/onboarding.test-harness.js.map +7 -0
  803. package/dist/src/outbound.js +33 -0
  804. package/dist/src/outbound.js.map +7 -0
  805. package/dist/src/plugin-entry.runtime.js +15 -0
  806. package/dist/src/plugin-entry.runtime.js.map +7 -0
  807. package/dist/src/profile-update.js +41 -0
  808. package/dist/src/profile-update.js.map +7 -0
  809. package/dist/src/record-shared.js +8 -0
  810. package/dist/src/record-shared.js.map +7 -0
  811. package/dist/src/resolve-targets.js +34 -0
  812. package/dist/src/resolve-targets.js.map +7 -0
  813. package/dist/src/resolver.js +8 -0
  814. package/dist/src/resolver.js.map +7 -0
  815. package/dist/src/runtime-api.js +120 -0
  816. package/dist/src/runtime-api.js.map +7 -0
  817. package/dist/src/runtime.js +10 -0
  818. package/dist/src/runtime.js.map +7 -0
  819. package/dist/src/secret-contract.js +13 -0
  820. package/dist/src/secret-contract.js.map +7 -0
  821. package/dist/src/session-route.js +25 -0
  822. package/dist/src/session-route.js.map +7 -0
  823. package/dist/src/setup-bootstrap.js +124 -0
  824. package/dist/src/setup-bootstrap.js.map +7 -0
  825. package/dist/src/setup-config.js +28 -0
  826. package/dist/src/setup-config.js.map +7 -0
  827. package/dist/src/setup-contract.js +16 -0
  828. package/dist/src/setup-contract.js.map +7 -0
  829. package/dist/src/setup-core.js +25 -0
  830. package/dist/src/setup-core.js.map +7 -0
  831. package/dist/src/setup-surface.js +45 -0
  832. package/dist/src/setup-surface.js.map +7 -0
  833. package/dist/src/startup-maintenance.js +29 -0
  834. package/dist/src/startup-maintenance.js.map +7 -0
  835. package/dist/src/storage-paths.js +24 -0
  836. package/dist/src/storage-paths.js.map +7 -0
  837. package/dist/src/test-helpers.js +49 -0
  838. package/dist/src/test-helpers.js.map +7 -0
  839. package/dist/src/test-mocks.js +40 -0
  840. package/dist/src/test-mocks.js.map +7 -0
  841. package/dist/src/test-runtime.js +65 -0
  842. package/dist/src/test-runtime.js.map +7 -0
  843. package/dist/src/tool-actions.js +68 -0
  844. package/dist/src/tool-actions.js.map +7 -0
  845. package/dist/src/tool-actions.runtime.js +73 -0
  846. package/dist/src/tool-actions.runtime.js.map +7 -0
  847. package/dist/src/types.js +7 -0
  848. package/dist/src/types.js.map +7 -0
  849. package/dist/test-api.js +82 -0
  850. package/dist/test-api.js.map +7 -0
  851. package/dist/thread-bindings-runtime.js +15 -0
  852. package/dist/thread-bindings-runtime.js.map +7 -0
  853. package/package.json +12 -6
  854. package/CHANGELOG.md +0 -164
  855. package/ENDOFFILE +0 -0
  856. package/EOF +0 -0
  857. package/SPEC-SUPPORT.md +0 -116
  858. package/YAMLEND +0 -0
  859. package/api.ts +0 -18
  860. package/archipelagolab-lobi-1.0.0.tgz +0 -0
  861. package/auth-presence.ts +0 -56
  862. package/channel-plugin-api.ts +0 -3
  863. package/cli-metadata.ts +0 -11
  864. package/contract-api.ts +0 -17
  865. package/docs/CHECKLIST.md +0 -83
  866. package/docs/FORK_SDK_GUIDE.md +0 -279
  867. package/helper-api.ts +0 -3
  868. package/index.test.ts +0 -61
  869. package/index.ts +0 -65
  870. package/plugin-entry.handlers.runtime.ts +0 -1
  871. package/runtime-api.ts +0 -54
  872. package/runtime-heavy-api.ts +0 -1
  873. package/scripts/migrate-to-lobi.sh +0 -72
  874. package/secret-contract-api.ts +0 -5
  875. package/setup-entry.ts +0 -13
  876. package/src/account-selection.test.ts +0 -124
  877. package/src/account-selection.ts +0 -226
  878. package/src/actions.account-propagation.test.ts +0 -251
  879. package/src/actions.test.ts +0 -251
  880. package/src/actions.ts +0 -336
  881. package/src/approval-auth.test.ts +0 -23
  882. package/src/approval-auth.ts +0 -25
  883. package/src/approval-handler.runtime.test.ts +0 -46
  884. package/src/approval-handler.runtime.ts +0 -400
  885. package/src/approval-ids.ts +0 -6
  886. package/src/approval-native.test.ts +0 -329
  887. package/src/approval-native.ts +0 -336
  888. package/src/approval-reactions.test.ts +0 -107
  889. package/src/approval-reactions.ts +0 -158
  890. package/src/auth-precedence.ts +0 -61
  891. package/src/channel-account-paths.ts +0 -92
  892. package/src/channel.account-paths.test.ts +0 -102
  893. package/src/channel.directory.test.ts +0 -601
  894. package/src/channel.resolve.test.ts +0 -38
  895. package/src/channel.runtime.ts +0 -16
  896. package/src/channel.setup.test.ts +0 -269
  897. package/src/channel.ts +0 -570
  898. package/src/cli-metadata.ts +0 -19
  899. package/src/cli.test.ts +0 -1015
  900. package/src/cli.ts +0 -1198
  901. package/src/config-adapter.ts +0 -41
  902. package/src/config-schema.test.ts +0 -90
  903. package/src/config-schema.ts +0 -114
  904. package/src/directory-live.test.ts +0 -200
  905. package/src/directory-live.ts +0 -238
  906. package/src/doctor-contract.ts +0 -287
  907. package/src/doctor.test.ts +0 -440
  908. package/src/doctor.ts +0 -262
  909. package/src/env-vars.ts +0 -92
  910. package/src/exec-approval-resolver.test.ts +0 -68
  911. package/src/exec-approval-resolver.ts +0 -23
  912. package/src/exec-approvals.test.ts +0 -483
  913. package/src/exec-approvals.ts +0 -290
  914. package/src/group-mentions.ts +0 -41
  915. package/src/legacy-crypto-inspector-availability.test.ts +0 -81
  916. package/src/legacy-crypto-inspector-availability.ts +0 -60
  917. package/src/legacy-crypto.test.ts +0 -234
  918. package/src/legacy-crypto.ts +0 -549
  919. package/src/legacy-state.test.ts +0 -86
  920. package/src/legacy-state.ts +0 -156
  921. package/src/matrix/account-config.ts +0 -150
  922. package/src/matrix/accounts.readiness.test.ts +0 -27
  923. package/src/matrix/accounts.test.ts +0 -757
  924. package/src/matrix/accounts.ts +0 -194
  925. package/src/matrix/actions/client.test.ts +0 -215
  926. package/src/matrix/actions/client.ts +0 -31
  927. package/src/matrix/actions/devices.test.ts +0 -114
  928. package/src/matrix/actions/devices.ts +0 -34
  929. package/src/matrix/actions/limits.test.ts +0 -15
  930. package/src/matrix/actions/limits.ts +0 -6
  931. package/src/matrix/actions/messages.test.ts +0 -289
  932. package/src/matrix/actions/messages.ts +0 -123
  933. package/src/matrix/actions/pins.test.ts +0 -74
  934. package/src/matrix/actions/pins.ts +0 -64
  935. package/src/matrix/actions/polls.test.ts +0 -71
  936. package/src/matrix/actions/polls.ts +0 -109
  937. package/src/matrix/actions/profile.test.ts +0 -109
  938. package/src/matrix/actions/profile.ts +0 -37
  939. package/src/matrix/actions/reactions.test.ts +0 -135
  940. package/src/matrix/actions/reactions.ts +0 -59
  941. package/src/matrix/actions/room.test.ts +0 -79
  942. package/src/matrix/actions/room.ts +0 -71
  943. package/src/matrix/actions/summary.test.ts +0 -87
  944. package/src/matrix/actions/summary.ts +0 -88
  945. package/src/matrix/actions/types.ts +0 -82
  946. package/src/matrix/actions/verification.test.ts +0 -105
  947. package/src/matrix/actions/verification.ts +0 -237
  948. package/src/matrix/actions.ts +0 -37
  949. package/src/matrix/active-client.ts +0 -26
  950. package/src/matrix/async-lock.ts +0 -18
  951. package/src/matrix/backup-health.ts +0 -115
  952. package/src/matrix/client/config-runtime-api.ts +0 -14
  953. package/src/matrix/client/config-secret-input.runtime.ts +0 -1
  954. package/src/matrix/client/config.ts +0 -982
  955. package/src/matrix/client/create-client.test.ts +0 -115
  956. package/src/matrix/client/create-client.ts +0 -101
  957. package/src/matrix/client/env-auth.ts +0 -6
  958. package/src/matrix/client/file-sync-store.test.ts +0 -265
  959. package/src/matrix/client/file-sync-store.ts +0 -289
  960. package/src/matrix/client/logging.ts +0 -123
  961. package/src/matrix/client/migration-snapshot.runtime.ts +0 -1
  962. package/src/matrix/client/private-network-host.ts +0 -56
  963. package/src/matrix/client/runtime.ts +0 -4
  964. package/src/matrix/client/shared.test.ts +0 -344
  965. package/src/matrix/client/shared.ts +0 -306
  966. package/src/matrix/client/storage.test.ts +0 -634
  967. package/src/matrix/client/storage.ts +0 -544
  968. package/src/matrix/client/types.ts +0 -50
  969. package/src/matrix/client-bootstrap.test.ts +0 -84
  970. package/src/matrix/client-bootstrap.ts +0 -164
  971. package/src/matrix/client-resolver.test-helpers.ts +0 -147
  972. package/src/matrix/client.test.ts +0 -1521
  973. package/src/matrix/client.ts +0 -23
  974. package/src/matrix/config-paths.ts +0 -31
  975. package/src/matrix/config-update.test.ts +0 -237
  976. package/src/matrix/config-update.ts +0 -291
  977. package/src/matrix/credentials-read.ts +0 -206
  978. package/src/matrix/credentials-write.runtime.ts +0 -26
  979. package/src/matrix/credentials.test.ts +0 -501
  980. package/src/matrix/credentials.ts +0 -95
  981. package/src/matrix/deps.test.ts +0 -74
  982. package/src/matrix/deps.ts +0 -225
  983. package/src/matrix/device-health.test.ts +0 -45
  984. package/src/matrix/device-health.ts +0 -31
  985. package/src/matrix/direct-management.test.ts +0 -350
  986. package/src/matrix/direct-management.ts +0 -347
  987. package/src/matrix/direct-room.test.ts +0 -61
  988. package/src/matrix/direct-room.ts +0 -128
  989. package/src/matrix/draft-stream.test.ts +0 -406
  990. package/src/matrix/draft-stream.ts +0 -216
  991. package/src/matrix/encryption-guidance.ts +0 -27
  992. package/src/matrix/errors.ts +0 -21
  993. package/src/matrix/format.test.ts +0 -340
  994. package/src/matrix/format.ts +0 -428
  995. package/src/matrix/legacy-crypto-inspector.ts +0 -95
  996. package/src/matrix/media-errors.ts +0 -20
  997. package/src/matrix/media-text.ts +0 -169
  998. package/src/matrix/monitor/access-state.test.ts +0 -45
  999. package/src/matrix/monitor/access-state.ts +0 -77
  1000. package/src/matrix/monitor/ack-config.test.ts +0 -57
  1001. package/src/matrix/monitor/ack-config.ts +0 -26
  1002. package/src/matrix/monitor/allowlist.test.ts +0 -45
  1003. package/src/matrix/monitor/allowlist.ts +0 -94
  1004. package/src/matrix/monitor/auto-join.test.ts +0 -203
  1005. package/src/matrix/monitor/auto-join.ts +0 -86
  1006. package/src/matrix/monitor/config.test.ts +0 -197
  1007. package/src/matrix/monitor/config.ts +0 -303
  1008. package/src/matrix/monitor/context-summary.ts +0 -43
  1009. package/src/matrix/monitor/direct.test.ts +0 -529
  1010. package/src/matrix/monitor/direct.ts +0 -270
  1011. package/src/matrix/monitor/events.test.ts +0 -1524
  1012. package/src/matrix/monitor/events.ts +0 -213
  1013. package/src/matrix/monitor/handler.body-for-agent.test.ts +0 -396
  1014. package/src/matrix/monitor/handler.group-history.test.ts +0 -648
  1015. package/src/matrix/monitor/handler.media-failure.test.ts +0 -267
  1016. package/src/matrix/monitor/handler.test-helpers.ts +0 -308
  1017. package/src/matrix/monitor/handler.test.ts +0 -2952
  1018. package/src/matrix/monitor/handler.thread-root-media.test.ts +0 -82
  1019. package/src/matrix/monitor/handler.ts +0 -1679
  1020. package/src/matrix/monitor/inbound-dedupe.test.ts +0 -146
  1021. package/src/matrix/monitor/inbound-dedupe.ts +0 -267
  1022. package/src/matrix/monitor/index.test.ts +0 -920
  1023. package/src/matrix/monitor/index.ts +0 -434
  1024. package/src/matrix/monitor/legacy-crypto-restore.test.ts +0 -206
  1025. package/src/matrix/monitor/legacy-crypto-restore.ts +0 -139
  1026. package/src/matrix/monitor/location.ts +0 -100
  1027. package/src/matrix/monitor/media.test.ts +0 -159
  1028. package/src/matrix/monitor/media.ts +0 -119
  1029. package/src/matrix/monitor/mentions.test.ts +0 -289
  1030. package/src/matrix/monitor/mentions.ts +0 -177
  1031. package/src/matrix/monitor/reaction-events.test.ts +0 -326
  1032. package/src/matrix/monitor/reaction-events.ts +0 -187
  1033. package/src/matrix/monitor/recent-invite.test.ts +0 -92
  1034. package/src/matrix/monitor/recent-invite.ts +0 -30
  1035. package/src/matrix/monitor/replies.test.ts +0 -265
  1036. package/src/matrix/monitor/replies.ts +0 -136
  1037. package/src/matrix/monitor/reply-context.test.ts +0 -276
  1038. package/src/matrix/monitor/reply-context.ts +0 -92
  1039. package/src/matrix/monitor/room-history.test.ts +0 -258
  1040. package/src/matrix/monitor/room-history.ts +0 -301
  1041. package/src/matrix/monitor/room-info.test.ts +0 -201
  1042. package/src/matrix/monitor/room-info.ts +0 -126
  1043. package/src/matrix/monitor/rooms.test.ts +0 -121
  1044. package/src/matrix/monitor/rooms.ts +0 -52
  1045. package/src/matrix/monitor/route.test.ts +0 -255
  1046. package/src/matrix/monitor/route.ts +0 -178
  1047. package/src/matrix/monitor/runtime-api.ts +0 -31
  1048. package/src/matrix/monitor/startup-verification.test.ts +0 -294
  1049. package/src/matrix/monitor/startup-verification.ts +0 -237
  1050. package/src/matrix/monitor/startup.test.ts +0 -257
  1051. package/src/matrix/monitor/startup.ts +0 -218
  1052. package/src/matrix/monitor/status.ts +0 -111
  1053. package/src/matrix/monitor/sync-lifecycle.test.ts +0 -224
  1054. package/src/matrix/monitor/sync-lifecycle.ts +0 -91
  1055. package/src/matrix/monitor/task-runner.ts +0 -38
  1056. package/src/matrix/monitor/thread-context.test.ts +0 -149
  1057. package/src/matrix/monitor/thread-context.ts +0 -108
  1058. package/src/matrix/monitor/threads.test.ts +0 -68
  1059. package/src/matrix/monitor/threads.ts +0 -85
  1060. package/src/matrix/monitor/types.ts +0 -30
  1061. package/src/matrix/monitor/verification-events.ts +0 -627
  1062. package/src/matrix/monitor/verification-utils.test.ts +0 -47
  1063. package/src/matrix/monitor/verification-utils.ts +0 -46
  1064. package/src/matrix/outbound-media-runtime.ts +0 -1
  1065. package/src/matrix/poll-summary.ts +0 -110
  1066. package/src/matrix/poll-types.test.ts +0 -205
  1067. package/src/matrix/poll-types.ts +0 -433
  1068. package/src/matrix/probe.runtime.ts +0 -4
  1069. package/src/matrix/probe.test.ts +0 -154
  1070. package/src/matrix/probe.ts +0 -96
  1071. package/src/matrix/profile.test.ts +0 -154
  1072. package/src/matrix/profile.ts +0 -184
  1073. package/src/matrix/reaction-common.test.ts +0 -96
  1074. package/src/matrix/reaction-common.ts +0 -147
  1075. package/src/matrix/sdk/crypto-bootstrap.test.ts +0 -505
  1076. package/src/matrix/sdk/crypto-bootstrap.ts +0 -341
  1077. package/src/matrix/sdk/crypto-facade.test.ts +0 -197
  1078. package/src/matrix/sdk/crypto-facade.ts +0 -207
  1079. package/src/matrix/sdk/crypto-node.runtime.test.ts +0 -27
  1080. package/src/matrix/sdk/crypto-node.runtime.ts +0 -9
  1081. package/src/matrix/sdk/crypto-runtime.ts +0 -11
  1082. package/src/matrix/sdk/decrypt-bridge.ts +0 -356
  1083. package/src/matrix/sdk/event-helpers.test.ts +0 -60
  1084. package/src/matrix/sdk/event-helpers.ts +0 -71
  1085. package/src/matrix/sdk/http-client.test.ts +0 -134
  1086. package/src/matrix/sdk/http-client.ts +0 -87
  1087. package/src/matrix/sdk/idb-persistence-lock.ts +0 -51
  1088. package/src/matrix/sdk/idb-persistence.lock-order.test.ts +0 -108
  1089. package/src/matrix/sdk/idb-persistence.test-helpers.ts +0 -88
  1090. package/src/matrix/sdk/idb-persistence.test.ts +0 -149
  1091. package/src/matrix/sdk/idb-persistence.ts +0 -283
  1092. package/src/matrix/sdk/logger.test.ts +0 -25
  1093. package/src/matrix/sdk/logger.ts +0 -108
  1094. package/src/matrix/sdk/read-response-with-limit.ts +0 -19
  1095. package/src/matrix/sdk/recovery-key-store.test.ts +0 -385
  1096. package/src/matrix/sdk/recovery-key-store.ts +0 -430
  1097. package/src/matrix/sdk/transport.test.ts +0 -161
  1098. package/src/matrix/sdk/transport.ts +0 -344
  1099. package/src/matrix/sdk/types.ts +0 -236
  1100. package/src/matrix/sdk/verification-manager.test.ts +0 -509
  1101. package/src/matrix/sdk/verification-manager.ts +0 -694
  1102. package/src/matrix/sdk/verification-status.ts +0 -23
  1103. package/src/matrix/sdk.test.ts +0 -2568
  1104. package/src/matrix/sdk.ts +0 -1789
  1105. package/src/matrix/send/client.test.ts +0 -174
  1106. package/src/matrix/send/client.ts +0 -90
  1107. package/src/matrix/send/formatting.ts +0 -189
  1108. package/src/matrix/send/media.ts +0 -244
  1109. package/src/matrix/send/targets.test.ts +0 -254
  1110. package/src/matrix/send/targets.ts +0 -104
  1111. package/src/matrix/send/types.ts +0 -134
  1112. package/src/matrix/send.test.ts +0 -958
  1113. package/src/matrix/send.ts +0 -609
  1114. package/src/matrix/session-store-metadata.ts +0 -108
  1115. package/src/matrix/startup-abort.ts +0 -44
  1116. package/src/matrix/sync-state.ts +0 -27
  1117. package/src/matrix/target-ids.ts +0 -102
  1118. package/src/matrix/thread-bindings-shared.ts +0 -201
  1119. package/src/matrix/thread-bindings.test.ts +0 -673
  1120. package/src/matrix/thread-bindings.ts +0 -577
  1121. package/src/matrix-migration.runtime.ts +0 -9
  1122. package/src/migration-config.test.ts +0 -228
  1123. package/src/migration-config.ts +0 -243
  1124. package/src/migration-snapshot-backup.ts +0 -117
  1125. package/src/migration-snapshot.test.ts +0 -184
  1126. package/src/migration-snapshot.ts +0 -55
  1127. package/src/onboarding.resolve.test.ts +0 -55
  1128. package/src/onboarding.test-harness.ts +0 -158
  1129. package/src/onboarding.test.ts +0 -665
  1130. package/src/onboarding.ts +0 -773
  1131. package/src/outbound.test.ts +0 -173
  1132. package/src/outbound.ts +0 -78
  1133. package/src/plugin-entry.runtime.js +0 -159
  1134. package/src/plugin-entry.runtime.test.ts +0 -108
  1135. package/src/plugin-entry.runtime.ts +0 -68
  1136. package/src/profile-update.ts +0 -68
  1137. package/src/record-shared.ts +0 -3
  1138. package/src/resolve-targets.test.ts +0 -178
  1139. package/src/resolve-targets.ts +0 -175
  1140. package/src/resolver.ts +0 -21
  1141. package/src/runtime-api.ts +0 -144
  1142. package/src/runtime.ts +0 -7
  1143. package/src/secret-contract.ts +0 -174
  1144. package/src/session-route.test.ts +0 -315
  1145. package/src/session-route.ts +0 -113
  1146. package/src/setup-bootstrap.ts +0 -94
  1147. package/src/setup-config.ts +0 -222
  1148. package/src/setup-contract.ts +0 -89
  1149. package/src/setup-core.test.ts +0 -326
  1150. package/src/setup-core.ts +0 -50
  1151. package/src/setup-surface.ts +0 -4
  1152. package/src/startup-maintenance.test.ts +0 -227
  1153. package/src/startup-maintenance.ts +0 -114
  1154. package/src/storage-paths.ts +0 -92
  1155. package/src/test-helpers.ts +0 -42
  1156. package/src/test-mocks.ts +0 -55
  1157. package/src/test-runtime.ts +0 -72
  1158. package/src/test-support/monitor-route-test-support.ts +0 -8
  1159. package/src/tool-actions.runtime.ts +0 -1
  1160. package/src/tool-actions.test.ts +0 -422
  1161. package/src/tool-actions.ts +0 -498
  1162. package/src/types.ts +0 -230
  1163. package/test-api.ts +0 -2
  1164. package/thread-bindings-runtime.ts +0 -4
  1165. package/tsconfig.json +0 -16
@@ -1,982 +0,0 @@
1
- import { formatErrorMessage, type PinnedDispatcherPolicy } from "openclaw/plugin-sdk/infra-runtime";
2
- import { coerceSecretRef } from "openclaw/plugin-sdk/provider-auth";
3
- import { retryAsync } from "openclaw/plugin-sdk/retry-runtime";
4
- import { normalizeResolvedSecretInputString } from "openclaw/plugin-sdk/secret-input";
5
- import {
6
- requiresExplicitMatrixDefaultAccount,
7
- resolveMatrixDefaultOrOnlyAccountId,
8
- } from "../../account-selection.js";
9
- import { resolveMatrixAccountStringValues } from "../../auth-precedence.js";
10
- import { getLobiScopedEnvVarNames as getMatrixScopedEnvVarNames } from "../../env-vars.js";
11
- import { getMatrixRuntime } from "../../runtime.js";
12
- import type { CoreConfig } from "../../types.js";
13
- import {
14
- findMatrixAccountConfig,
15
- resolveMatrixBaseConfig,
16
- listNormalizedMatrixAccountIds,
17
- } from "../account-config.js";
18
- import { resolveMatrixConfigFieldPath } from "../config-paths.js";
19
- import type { MatrixStoredCredentials } from "../credentials-read.js";
20
- import {
21
- DEFAULT_ACCOUNT_ID,
22
- assertHttpUrlTargetsPrivateNetwork,
23
- isPrivateOrLoopbackHost,
24
- isPrivateNetworkOptInEnabled,
25
- type LookupFn,
26
- normalizeAccountId,
27
- normalizeOptionalAccountId,
28
- ssrfPolicyFromDangerouslyAllowPrivateNetwork,
29
- } from "./config-runtime-api.js";
30
- import { repairCurrentTokenStorageMetaDeviceId } from "./storage.js";
31
- import type { MatrixAuth, MatrixResolvedConfig } from "./types.js";
32
-
33
- type MatrixAuthClientDeps = {
34
- MatrixClient: typeof import("../sdk.js").MatrixClient;
35
- ensureMatrixSdkLoggingConfigured: typeof import("./logging.js").ensureMatrixSdkLoggingConfigured;
36
- };
37
-
38
- type MatrixCredentialsReadDeps = {
39
- loadMatrixCredentials: typeof import("../credentials-read.js").loadMatrixCredentials;
40
- credentialsMatchConfig: typeof import("../credentials-read.js").credentialsMatchConfig;
41
- };
42
-
43
- type MatrixSecretInputDeps = {
44
- resolveConfiguredSecretInputString: typeof import("./config-secret-input.runtime.js").resolveConfiguredSecretInputString;
45
- };
46
-
47
- let matrixAuthClientDepsPromise: Promise<MatrixAuthClientDeps> | undefined;
48
- let matrixCredentialsReadDepsPromise: Promise<MatrixCredentialsReadDeps> | undefined;
49
- let matrixSecretInputDepsPromise: Promise<MatrixSecretInputDeps> | undefined;
50
- let matrixAuthClientDepsForTest: MatrixAuthClientDeps | undefined;
51
-
52
- const MATRIX_AUTH_REQUEST_RETRY_RE =
53
- /\b(fetch failed|econnreset|econnrefused|enotfound|etimedout|ehostunreach|enetunreach|eai_again|und_err_|socket hang up|network|headers timeout|body timeout|connect timeout)\b/i;
54
-
55
- export function setMatrixAuthClientDepsForTest(deps?: {
56
- MatrixClient: typeof import("../sdk.js").MatrixClient;
57
- ensureMatrixSdkLoggingConfigured: typeof import("./logging.js").ensureMatrixSdkLoggingConfigured;
58
- }): void {
59
- matrixAuthClientDepsForTest = deps;
60
- }
61
-
62
- async function loadMatrixAuthClientDeps(): Promise<MatrixAuthClientDeps> {
63
- if (matrixAuthClientDepsForTest) {
64
- return matrixAuthClientDepsForTest;
65
- }
66
- matrixAuthClientDepsPromise ??= Promise.all([import("../sdk.js"), import("./logging.js")]).then(
67
- ([sdkModule, loggingModule]) => ({
68
- MatrixClient: sdkModule.MatrixClient,
69
- ensureMatrixSdkLoggingConfigured: loggingModule.ensureMatrixSdkLoggingConfigured,
70
- }),
71
- );
72
- return await matrixAuthClientDepsPromise;
73
- }
74
-
75
- async function loadMatrixCredentialsReadDeps(): Promise<MatrixCredentialsReadDeps> {
76
- matrixCredentialsReadDepsPromise ??= import("../credentials-read.js").then(
77
- (credentialsReadModule) => ({
78
- loadMatrixCredentials: credentialsReadModule.loadMatrixCredentials,
79
- credentialsMatchConfig: credentialsReadModule.credentialsMatchConfig,
80
- }),
81
- );
82
- return await matrixCredentialsReadDepsPromise;
83
- }
84
-
85
- async function loadMatrixSecretInputDeps(): Promise<MatrixSecretInputDeps> {
86
- matrixSecretInputDepsPromise ??= import("./config-secret-input.runtime.js").then((runtime) => ({
87
- resolveConfiguredSecretInputString: runtime.resolveConfiguredSecretInputString,
88
- }));
89
- return await matrixSecretInputDepsPromise;
90
- }
91
-
92
- function shouldRetryMatrixAuthRequest(err: unknown): boolean {
93
- return MATRIX_AUTH_REQUEST_RETRY_RE.test(formatErrorMessage(err));
94
- }
95
-
96
- function isAbortSignalTriggered(signal?: AbortSignal): boolean {
97
- return signal?.aborted === true;
98
- }
99
-
100
- function credentialsMatchBackfillAuthLineage(params: {
101
- stored: MatrixStoredCredentials | null;
102
- auth: Pick<MatrixAuth, "homeserver" | "userId" | "accessToken">;
103
- }): boolean {
104
- if (!params.stored) {
105
- return true;
106
- }
107
- return (
108
- params.stored.homeserver === params.auth.homeserver &&
109
- params.stored.userId === params.auth.userId &&
110
- params.stored.accessToken === params.auth.accessToken
111
- );
112
- }
113
-
114
- async function retryMatrixAuthRequest<T>(label: string, run: () => Promise<T>): Promise<T> {
115
- return await retryAsync(run, {
116
- attempts: 3,
117
- minDelayMs: 250,
118
- maxDelayMs: 1_500,
119
- jitter: 0.1,
120
- label,
121
- shouldRetry: (err) => shouldRetryMatrixAuthRequest(err),
122
- });
123
- }
124
-
125
- async function fetchMatrixWhoamiIdentity(params: {
126
- homeserver: string;
127
- accessToken: string;
128
- userId?: string;
129
- ssrfPolicy?: MatrixResolvedConfig["ssrfPolicy"];
130
- dispatcherPolicy?: PinnedDispatcherPolicy;
131
- }): Promise<{
132
- user_id?: string;
133
- device_id?: string;
134
- }> {
135
- const { MatrixClient, ensureMatrixSdkLoggingConfigured } = await loadMatrixAuthClientDeps();
136
- ensureMatrixSdkLoggingConfigured();
137
- const tempClient = new MatrixClient(params.homeserver, params.accessToken, {
138
- userId: params.userId,
139
- ssrfPolicy: params.ssrfPolicy,
140
- dispatcherPolicy: params.dispatcherPolicy,
141
- });
142
- return (await retryMatrixAuthRequest("matrix auth whoami", async () => {
143
- return (await tempClient.doRequest("GET", "/_matrix/client/v3/account/whoami")) as {
144
- user_id?: string;
145
- device_id?: string;
146
- };
147
- })) as {
148
- user_id?: string;
149
- device_id?: string;
150
- };
151
- }
152
-
153
- function readEnvSecretRefFallback(params: {
154
- value: unknown;
155
- env?: NodeJS.ProcessEnv;
156
- config?: Pick<CoreConfig, "secrets">;
157
- }): string | undefined {
158
- const ref = coerceSecretRef(params.value, params.config?.secrets?.defaults);
159
- if (!ref || ref.source !== "env" || !params.env) {
160
- return undefined;
161
- }
162
-
163
- const providerConfig = params.config?.secrets?.providers?.[ref.provider];
164
- if (providerConfig) {
165
- if (providerConfig.source !== "env") {
166
- throw new Error(
167
- `Secret provider "${ref.provider}" has source "${providerConfig.source}" but ref requests "env".`,
168
- );
169
- }
170
- if (providerConfig.allowlist && !providerConfig.allowlist.includes(ref.id)) {
171
- throw new Error(
172
- `Environment variable "${ref.id}" is not allowlisted in secrets.providers.${ref.provider}.allowlist.`,
173
- );
174
- }
175
- } else if (ref.provider !== (params.config?.secrets?.defaults?.env?.trim() || "default")) {
176
- throw new Error(
177
- `Secret provider "${ref.provider}" is not configured (ref: ${ref.source}:${ref.provider}:${ref.id}).`,
178
- );
179
- }
180
-
181
- const resolved = params.env[ref.id];
182
- if (typeof resolved !== "string") {
183
- return undefined;
184
- }
185
-
186
- const trimmed = resolved.trim();
187
- return trimmed.length > 0 ? trimmed : undefined;
188
- }
189
-
190
- function clean(
191
- value: unknown,
192
- path: string,
193
- opts?: {
194
- env?: NodeJS.ProcessEnv;
195
- config?: Pick<CoreConfig, "secrets">;
196
- allowEnvSecretRefFallback?: boolean;
197
- suppressSecretRef?: boolean;
198
- },
199
- ): string {
200
- const ref = coerceSecretRef(value, opts?.config?.secrets?.defaults);
201
- if (opts?.suppressSecretRef && ref) {
202
- return "";
203
- }
204
- const normalizedValue = opts?.allowEnvSecretRefFallback
205
- ? ref?.source === "env"
206
- ? (readEnvSecretRefFallback({
207
- value,
208
- env: opts.env,
209
- config: opts.config,
210
- }) ?? value)
211
- : ref
212
- ? ""
213
- : value
214
- : value;
215
- return (
216
- normalizeResolvedSecretInputString({
217
- value: normalizedValue,
218
- path,
219
- defaults: opts?.config?.secrets?.defaults,
220
- }) ?? ""
221
- );
222
- }
223
-
224
- type MatrixEnvConfig = {
225
- homeserver: string;
226
- userId: string;
227
- accessToken?: string;
228
- password?: string;
229
- deviceId?: string;
230
- deviceName?: string;
231
- };
232
-
233
- type MatrixConfigStringField =
234
- | "homeserver"
235
- | "userId"
236
- | "accessToken"
237
- | "password"
238
- | "deviceId"
239
- | "deviceName";
240
-
241
- function resolveMatrixBaseConfigFieldPath(field: MatrixConfigStringField): string {
242
- return `channels.lobi.${field}`;
243
- }
244
-
245
- function shouldAllowEnvSecretRefFallback(field: MatrixConfigStringField): boolean {
246
- return field === "accessToken" || field === "password";
247
- }
248
-
249
- type MatrixAuthSecretField = "accessToken" | "password";
250
-
251
- type MatrixConfiguredAuthInput = {
252
- value: unknown;
253
- path: string;
254
- };
255
-
256
- function hasConfiguredSecretInputValue(value: unknown, cfg: Pick<CoreConfig, "secrets">): boolean {
257
- return (
258
- (typeof value === "string" && value.trim().length > 0) ||
259
- Boolean(coerceSecretRef(value, cfg.secrets?.defaults))
260
- );
261
- }
262
-
263
- function hasConfiguredMatrixAccessTokenSource(params: {
264
- cfg: CoreConfig;
265
- env: NodeJS.ProcessEnv;
266
- accountId: string;
267
- }): boolean {
268
- const normalizedAccountId = normalizeAccountId(params.accountId);
269
- const account = findMatrixAccountConfig(params.cfg, normalizedAccountId) ?? {};
270
- const scopedAccessTokenVar = getMatrixScopedEnvVarNames(normalizedAccountId).accessToken;
271
- if (
272
- hasConfiguredSecretInputValue(account.accessToken, params.cfg) ||
273
- clean(params.env[scopedAccessTokenVar], scopedAccessTokenVar).length > 0
274
- ) {
275
- return true;
276
- }
277
- if (normalizedAccountId !== DEFAULT_ACCOUNT_ID) {
278
- return false;
279
- }
280
- const matrix = resolveMatrixBaseConfig(params.cfg);
281
- return (
282
- hasConfiguredSecretInputValue(matrix.accessToken, params.cfg) ||
283
- clean(params.env.LOBI_ACCESS_TOKEN, "LOBI_ACCESS_TOKEN").length > 0
284
- );
285
- }
286
-
287
- function resolveConfiguredMatrixAuthInput(params: {
288
- cfg: CoreConfig;
289
- env: NodeJS.ProcessEnv;
290
- accountId: string;
291
- field: MatrixAuthSecretField;
292
- }): MatrixConfiguredAuthInput | undefined {
293
- const normalizedAccountId = normalizeAccountId(params.accountId);
294
- const account = findMatrixAccountConfig(params.cfg, normalizedAccountId) ?? {};
295
- const accountValue = account[params.field];
296
- if (accountValue !== undefined) {
297
- return {
298
- value: accountValue,
299
- path: resolveMatrixConfigFieldPath(params.cfg, normalizedAccountId, params.field),
300
- };
301
- }
302
-
303
- const scopedKeys = getMatrixScopedEnvVarNames(normalizedAccountId);
304
- const scopedEnv = resolveScopedMatrixEnvConfig(normalizedAccountId, params.env);
305
- const scopedValue = scopedEnv[params.field];
306
- if (scopedValue !== undefined) {
307
- return {
308
- value: scopedValue,
309
- path: params.field === "accessToken" ? scopedKeys.accessToken : scopedKeys.password,
310
- };
311
- }
312
-
313
- if (normalizedAccountId !== DEFAULT_ACCOUNT_ID) {
314
- return undefined;
315
- }
316
-
317
- const matrix = resolveMatrixBaseConfig(params.cfg);
318
- const baseValue = matrix[params.field];
319
- if (baseValue !== undefined) {
320
- return {
321
- value: baseValue,
322
- path: resolveMatrixBaseConfigFieldPath(params.field),
323
- };
324
- }
325
-
326
- const globalValue =
327
- params.field === "accessToken" ? params.env.LOBI_ACCESS_TOKEN : params.env.LOBI_PASSWORD;
328
- if (globalValue !== undefined) {
329
- return {
330
- value: globalValue,
331
- path: params.field === "accessToken" ? "LOBI_ACCESS_TOKEN" : "LOBI_PASSWORD",
332
- };
333
- }
334
-
335
- return undefined;
336
- }
337
-
338
- async function resolveConfiguredMatrixAuthSecretInput(params: {
339
- cfg: CoreConfig;
340
- env: NodeJS.ProcessEnv;
341
- accountId: string;
342
- field: MatrixAuthSecretField;
343
- }): Promise<string | undefined> {
344
- const configured = resolveConfiguredMatrixAuthInput(params);
345
- if (!configured) {
346
- return undefined;
347
- }
348
-
349
- const { resolveConfiguredSecretInputString } = await loadMatrixSecretInputDeps();
350
- const resolved = await resolveConfiguredSecretInputString({
351
- config: params.cfg,
352
- env: params.env,
353
- value: configured.value,
354
- path: configured.path,
355
- unresolvedReasonStyle: "detailed",
356
- });
357
- if (resolved.value !== undefined) {
358
- return resolved.value;
359
- }
360
-
361
- if (coerceSecretRef(configured.value, params.cfg.secrets?.defaults)) {
362
- throw new Error(
363
- resolved.unresolvedRefReason ?? `${configured.path} SecretRef could not be resolved.`,
364
- );
365
- }
366
-
367
- return undefined;
368
- }
369
-
370
- function readMatrixBaseConfigField(
371
- matrix: ReturnType<typeof resolveMatrixBaseConfig>,
372
- field: MatrixConfigStringField,
373
- opts?: {
374
- env?: NodeJS.ProcessEnv;
375
- config?: Pick<CoreConfig, "secrets">;
376
- suppressSecretRef?: boolean;
377
- },
378
- ): string {
379
- return clean(matrix[field], resolveMatrixBaseConfigFieldPath(field), {
380
- env: opts?.env,
381
- config: opts?.config,
382
- allowEnvSecretRefFallback: shouldAllowEnvSecretRefFallback(field),
383
- suppressSecretRef: opts?.suppressSecretRef,
384
- });
385
- }
386
-
387
- function readMatrixAccountConfigField(
388
- cfg: CoreConfig,
389
- accountId: string,
390
- account: Partial<Record<MatrixConfigStringField, unknown>>,
391
- field: MatrixConfigStringField,
392
- opts?: {
393
- env?: NodeJS.ProcessEnv;
394
- config?: Pick<CoreConfig, "secrets">;
395
- suppressSecretRef?: boolean;
396
- },
397
- ): string {
398
- return clean(account[field], resolveMatrixConfigFieldPath(cfg, accountId, field), {
399
- env: opts?.env,
400
- config: opts?.config,
401
- allowEnvSecretRefFallback: shouldAllowEnvSecretRefFallback(field),
402
- suppressSecretRef: opts?.suppressSecretRef,
403
- });
404
- }
405
-
406
- function clampMatrixInitialSyncLimit(value: unknown): number | undefined {
407
- return typeof value === "number" ? Math.max(0, Math.floor(value)) : undefined;
408
- }
409
-
410
- const MATRIX_HTTP_HOMESERVER_ERROR =
411
- "Matrix homeserver must use https:// unless it targets a private or loopback host";
412
-
413
- function buildMatrixNetworkFields(params: {
414
- allowPrivateNetwork: boolean | undefined;
415
- proxy?: string;
416
- dispatcherPolicy?: PinnedDispatcherPolicy;
417
- }): Pick<MatrixResolvedConfig, "allowPrivateNetwork" | "ssrfPolicy" | "dispatcherPolicy"> {
418
- const dispatcherPolicy: PinnedDispatcherPolicy | undefined =
419
- params.dispatcherPolicy ??
420
- (params.proxy ? { mode: "explicit-proxy", proxyUrl: params.proxy } : undefined);
421
- if (!params.allowPrivateNetwork && !dispatcherPolicy) {
422
- return {};
423
- }
424
- return {
425
- ...(params.allowPrivateNetwork
426
- ? {
427
- allowPrivateNetwork: true,
428
- ssrfPolicy: ssrfPolicyFromDangerouslyAllowPrivateNetwork(true),
429
- }
430
- : {}),
431
- ...(dispatcherPolicy ? { dispatcherPolicy } : {}),
432
- };
433
- }
434
-
435
- const DEFAULT_LOBI_HOMESERVER = "https://lobi.lobisland.com/";
436
-
437
- export function resolveGlobalMatrixEnvConfig(env: NodeJS.ProcessEnv): MatrixEnvConfig {
438
- const homeserver = clean(env.LOBI_HOMESERVER, "LOBI_HOMESERVER");
439
- return {
440
- homeserver: homeserver || DEFAULT_LOBI_HOMESERVER,
441
- userId: clean(env.LOBI_USER_ID, "LOBI_USER_ID"),
442
- accessToken: clean(env.LOBI_ACCESS_TOKEN, "LOBI_ACCESS_TOKEN") || undefined,
443
- password: clean(env.LOBI_PASSWORD, "LOBI_PASSWORD") || undefined,
444
- deviceId: clean(env.LOBI_DEVICE_ID, "LOBI_DEVICE_ID") || undefined,
445
- deviceName: clean(env.LOBI_DEVICE_NAME, "LOBI_DEVICE_NAME") || undefined,
446
- };
447
- }
448
-
449
- export { getLobiScopedEnvVarNames as getMatrixScopedEnvVarNames } from "../../env-vars.js";
450
-
451
- export function resolveMatrixEnvAuthReadiness(
452
- accountId: string,
453
- env: NodeJS.ProcessEnv = process.env,
454
- ): {
455
- ready: boolean;
456
- homeserver?: string;
457
- userId?: string;
458
- sourceHint: string;
459
- missingMessage: string;
460
- } {
461
- const normalizedAccountId = normalizeAccountId(accountId);
462
- const scoped = resolveScopedMatrixEnvConfig(normalizedAccountId, env);
463
- const scopedReady = hasReadyMatrixEnvAuth(scoped);
464
- if (normalizedAccountId !== DEFAULT_ACCOUNT_ID) {
465
- const keys = getMatrixScopedEnvVarNames(normalizedAccountId);
466
- return {
467
- ready: scopedReady,
468
- homeserver: scoped.homeserver || undefined,
469
- userId: scoped.userId || undefined,
470
- sourceHint: `${keys.homeserver} (+ auth vars)`,
471
- missingMessage: `Set per-account env vars for "${normalizedAccountId}" (for example ${keys.homeserver} + ${keys.accessToken} or ${keys.userId} + ${keys.password}).`,
472
- };
473
- }
474
-
475
- const defaultScoped = resolveScopedMatrixEnvConfig(DEFAULT_ACCOUNT_ID, env);
476
- const global = resolveGlobalMatrixEnvConfig(env);
477
- const defaultScopedReady = hasReadyMatrixEnvAuth(defaultScoped);
478
- const globalReady = hasReadyMatrixEnvAuth(global);
479
- const defaultKeys = getMatrixScopedEnvVarNames(DEFAULT_ACCOUNT_ID);
480
- return {
481
- ready: defaultScopedReady || globalReady,
482
- homeserver: defaultScoped.homeserver || global.homeserver || undefined,
483
- userId: defaultScoped.userId || global.userId || undefined,
484
- sourceHint: "LOBI_* or LOBI_DEFAULT_*",
485
- missingMessage:
486
- `Set Lobi env vars for the default account ` +
487
- `(for example LOBI_HOMESERVER + LOBI_ACCESS_TOKEN, LOBI_USER_ID + LOBI_PASSWORD, ` +
488
- `or ${defaultKeys.homeserver} + ${defaultKeys.accessToken}).`,
489
- };
490
- }
491
-
492
- export function resolveScopedMatrixEnvConfig(
493
- accountId: string,
494
- env: NodeJS.ProcessEnv = process.env,
495
- ): MatrixEnvConfig {
496
- const keys = getMatrixScopedEnvVarNames(accountId);
497
- return {
498
- homeserver: clean(env[keys.homeserver], keys.homeserver),
499
- userId: clean(env[keys.userId], keys.userId),
500
- accessToken: clean(env[keys.accessToken], keys.accessToken) || undefined,
501
- password: clean(env[keys.password], keys.password) || undefined,
502
- deviceId: clean(env[keys.deviceId], keys.deviceId) || undefined,
503
- deviceName: clean(env[keys.deviceName], keys.deviceName) || undefined,
504
- };
505
- }
506
-
507
- function hasScopedMatrixEnvConfig(accountId: string, env: NodeJS.ProcessEnv): boolean {
508
- const scoped = resolveScopedMatrixEnvConfig(accountId, env);
509
- return Boolean(
510
- scoped.homeserver ||
511
- scoped.userId ||
512
- scoped.accessToken ||
513
- scoped.password ||
514
- scoped.deviceId ||
515
- scoped.deviceName,
516
- );
517
- }
518
-
519
- export function hasReadyMatrixEnvAuth(config: {
520
- homeserver?: string;
521
- userId?: string;
522
- accessToken?: string;
523
- password?: string;
524
- }): boolean {
525
- const homeserver = clean(config.homeserver, "matrix.env.homeserver");
526
- const userId = clean(config.userId, "matrix.env.userId");
527
- const accessToken = clean(config.accessToken, "matrix.env.accessToken");
528
- const password = clean(config.password, "matrix.env.password");
529
- return Boolean(homeserver && (accessToken || (userId && password)));
530
- }
531
-
532
- export function validateMatrixHomeserverUrl(
533
- homeserver: string,
534
- opts?: { allowPrivateNetwork?: boolean },
535
- ): string {
536
- const trimmed = clean(homeserver, "matrix.homeserver");
537
- if (!trimmed) {
538
- throw new Error("Matrix homeserver is required (matrix.homeserver)");
539
- }
540
-
541
- let parsed: URL;
542
- try {
543
- parsed = new URL(trimmed);
544
- } catch {
545
- throw new Error("Matrix homeserver must be a valid http(s) URL");
546
- }
547
-
548
- if (parsed.protocol !== "https:" && parsed.protocol !== "http:") {
549
- throw new Error("Matrix homeserver must use http:// or https://");
550
- }
551
- if (!parsed.hostname) {
552
- throw new Error("Matrix homeserver must include a hostname");
553
- }
554
- if (parsed.username || parsed.password) {
555
- throw new Error("Matrix homeserver URL must not include embedded credentials");
556
- }
557
- if (parsed.search || parsed.hash) {
558
- throw new Error("Matrix homeserver URL must not include query strings or fragments");
559
- }
560
- if (
561
- parsed.protocol === "http:" &&
562
- opts?.allowPrivateNetwork !== true &&
563
- !isPrivateOrLoopbackHost(parsed.hostname)
564
- ) {
565
- throw new Error(MATRIX_HTTP_HOMESERVER_ERROR);
566
- }
567
-
568
- return trimmed;
569
- }
570
-
571
- export async function resolveValidatedMatrixHomeserverUrl(
572
- homeserver: string,
573
- opts?: {
574
- dangerouslyAllowPrivateNetwork?: boolean;
575
- allowPrivateNetwork?: boolean;
576
- lookupFn?: LookupFn;
577
- },
578
- ): Promise<string> {
579
- const allowPrivateNetwork =
580
- typeof opts?.dangerouslyAllowPrivateNetwork === "boolean"
581
- ? opts.dangerouslyAllowPrivateNetwork
582
- : opts?.allowPrivateNetwork;
583
- const normalized = validateMatrixHomeserverUrl(homeserver, {
584
- allowPrivateNetwork,
585
- });
586
- await assertHttpUrlTargetsPrivateNetwork(normalized, {
587
- dangerouslyAllowPrivateNetwork: opts?.dangerouslyAllowPrivateNetwork,
588
- allowPrivateNetwork,
589
- lookupFn: opts?.lookupFn,
590
- errorMessage: MATRIX_HTTP_HOMESERVER_ERROR,
591
- });
592
- return normalized;
593
- }
594
-
595
- export function resolveMatrixConfigForAccount(
596
- cfg: CoreConfig,
597
- accountId: string,
598
- env: NodeJS.ProcessEnv = process.env,
599
- ): MatrixResolvedConfig {
600
- const matrix = resolveMatrixBaseConfig(cfg);
601
- const account = findMatrixAccountConfig(cfg, accountId) ?? {};
602
- const normalizedAccountId = normalizeAccountId(accountId);
603
- const suppressInactivePasswordSecretRef = hasConfiguredMatrixAccessTokenSource({
604
- cfg,
605
- env,
606
- accountId: normalizedAccountId,
607
- });
608
- const fieldReadOptions = {
609
- env,
610
- config: cfg,
611
- };
612
- const scopedEnv = resolveScopedMatrixEnvConfig(normalizedAccountId, env);
613
- const globalEnv = resolveGlobalMatrixEnvConfig(env);
614
- const accountField = (field: MatrixConfigStringField) =>
615
- readMatrixAccountConfigField(cfg, normalizedAccountId, account, field, {
616
- ...fieldReadOptions,
617
- suppressSecretRef: field === "password" ? suppressInactivePasswordSecretRef : undefined,
618
- });
619
- const resolvedStrings = resolveMatrixAccountStringValues({
620
- accountId: normalizedAccountId,
621
- account: {
622
- homeserver: accountField("homeserver"),
623
- userId: accountField("userId"),
624
- accessToken: accountField("accessToken"),
625
- password: accountField("password"),
626
- deviceId: accountField("deviceId"),
627
- deviceName: accountField("deviceName"),
628
- },
629
- scopedEnv,
630
- channel: {
631
- homeserver: readMatrixBaseConfigField(matrix, "homeserver", fieldReadOptions),
632
- userId: readMatrixBaseConfigField(matrix, "userId", fieldReadOptions),
633
- accessToken: readMatrixBaseConfigField(matrix, "accessToken", fieldReadOptions),
634
- password: readMatrixBaseConfigField(matrix, "password", {
635
- ...fieldReadOptions,
636
- suppressSecretRef: suppressInactivePasswordSecretRef,
637
- }),
638
- deviceId: readMatrixBaseConfigField(matrix, "deviceId", fieldReadOptions),
639
- deviceName: readMatrixBaseConfigField(matrix, "deviceName", fieldReadOptions),
640
- },
641
- globalEnv,
642
- });
643
-
644
- const accountInitialSyncLimit = clampMatrixInitialSyncLimit(account.initialSyncLimit);
645
- const initialSyncLimit =
646
- accountInitialSyncLimit ?? clampMatrixInitialSyncLimit(matrix.initialSyncLimit);
647
- const encryption =
648
- typeof account.encryption === "boolean" ? account.encryption : (matrix.encryption ?? false);
649
- const allowPrivateNetwork =
650
- isPrivateNetworkOptInEnabled(account) || isPrivateNetworkOptInEnabled(matrix)
651
- ? true
652
- : undefined;
653
-
654
- return {
655
- homeserver: resolvedStrings.homeserver,
656
- userId: resolvedStrings.userId,
657
- accessToken: resolvedStrings.accessToken || undefined,
658
- password: resolvedStrings.password || undefined,
659
- deviceId: resolvedStrings.deviceId || undefined,
660
- deviceName: resolvedStrings.deviceName || undefined,
661
- initialSyncLimit,
662
- encryption,
663
- ...buildMatrixNetworkFields({
664
- allowPrivateNetwork,
665
- proxy: account.proxy ?? matrix.proxy,
666
- }),
667
- };
668
- }
669
-
670
- function resolveImplicitMatrixAccountId(
671
- cfg: CoreConfig,
672
- env: NodeJS.ProcessEnv = process.env,
673
- ): string | null {
674
- if (requiresExplicitMatrixDefaultAccount(cfg, env)) {
675
- return null;
676
- }
677
- return normalizeAccountId(resolveMatrixDefaultOrOnlyAccountId(cfg, env));
678
- }
679
-
680
- export function resolveMatrixAuthContext(params?: {
681
- cfg?: CoreConfig;
682
- env?: NodeJS.ProcessEnv;
683
- accountId?: string | null;
684
- }): {
685
- cfg: CoreConfig;
686
- env: NodeJS.ProcessEnv;
687
- accountId: string;
688
- resolved: MatrixResolvedConfig;
689
- } {
690
- const cfg = params?.cfg ?? (getMatrixRuntime().config.loadConfig() as CoreConfig);
691
- const env = params?.env ?? process.env;
692
- const explicitAccountId = normalizeOptionalAccountId(params?.accountId);
693
- const effectiveAccountId = explicitAccountId ?? resolveImplicitMatrixAccountId(cfg, env);
694
- if (!effectiveAccountId) {
695
- throw new Error(
696
- 'Multiple Lobi accounts are configured and channels.lobi.defaultAccount is not set. Set "channels.lobi.defaultAccount" to the intended account or pass --account <id>.',
697
- );
698
- }
699
- if (
700
- explicitAccountId &&
701
- explicitAccountId !== DEFAULT_ACCOUNT_ID &&
702
- !listNormalizedMatrixAccountIds(cfg).includes(explicitAccountId) &&
703
- !hasScopedMatrixEnvConfig(explicitAccountId, env)
704
- ) {
705
- throw new Error(
706
- `Lobi account "${explicitAccountId}" is not configured. Add channels.lobi.accounts.${explicitAccountId} or define scoped ${getMatrixScopedEnvVarNames(explicitAccountId).accessToken.replace(/_ACCESS_TOKEN$/, "")}_* variables.`,
707
- );
708
- }
709
- const resolved = resolveMatrixConfigForAccount(cfg, effectiveAccountId, env);
710
-
711
- return {
712
- cfg,
713
- env,
714
- accountId: effectiveAccountId,
715
- resolved,
716
- };
717
- }
718
-
719
- export async function resolveMatrixAuth(params?: {
720
- cfg?: CoreConfig;
721
- env?: NodeJS.ProcessEnv;
722
- accountId?: string | null;
723
- }): Promise<MatrixAuth> {
724
- const { cfg, env, accountId, resolved } = resolveMatrixAuthContext(params);
725
- const accessToken =
726
- (await resolveConfiguredMatrixAuthSecretInput({
727
- cfg,
728
- env,
729
- accountId,
730
- field: "accessToken",
731
- })) ?? resolved.accessToken;
732
- const tokenAuthPassword = resolved.password;
733
- const homeserver = await resolveValidatedMatrixHomeserverUrl(resolved.homeserver, {
734
- dangerouslyAllowPrivateNetwork: resolved.allowPrivateNetwork,
735
- });
736
- let credentialsWriter: typeof import("../credentials-write.runtime.js") | undefined;
737
- const loadCredentialsWriter = async () => {
738
- credentialsWriter ??= await import("../credentials-write.runtime.js");
739
- return credentialsWriter;
740
- };
741
-
742
- const { loadMatrixCredentials, credentialsMatchConfig } = await loadMatrixCredentialsReadDeps();
743
- const cached = loadMatrixCredentials(env, accountId);
744
- const cachedCredentials =
745
- cached &&
746
- credentialsMatchConfig(cached, {
747
- homeserver,
748
- userId: resolved.userId || "",
749
- accessToken,
750
- })
751
- ? cached
752
- : null;
753
-
754
- // If we have an access token, we can fetch userId via whoami if not provided
755
- if (accessToken) {
756
- let userId = resolved.userId;
757
- const hasMatchingCachedToken = cachedCredentials?.accessToken === accessToken;
758
- let knownDeviceId = hasMatchingCachedToken
759
- ? cachedCredentials?.deviceId || resolved.deviceId
760
- : resolved.deviceId;
761
-
762
- if (!userId) {
763
- // Only block startup on whoami when token auth still needs the user ID.
764
- // A missing device ID alone is optional and should not force a network round-trip.
765
- const whoami = await fetchMatrixWhoamiIdentity({
766
- homeserver,
767
- accessToken,
768
- userId,
769
- ssrfPolicy: resolved.ssrfPolicy,
770
- dispatcherPolicy: resolved.dispatcherPolicy,
771
- });
772
- const fetchedUserId = whoami.user_id?.trim();
773
- if (!fetchedUserId) {
774
- throw new Error("Matrix whoami did not return user_id");
775
- }
776
- userId = fetchedUserId;
777
- knownDeviceId = knownDeviceId || whoami.device_id?.trim() || resolved.deviceId;
778
- }
779
-
780
- const shouldRefreshCachedCredentials =
781
- !cachedCredentials ||
782
- !hasMatchingCachedToken ||
783
- cachedCredentials.userId !== userId ||
784
- (cachedCredentials.deviceId || undefined) !== knownDeviceId;
785
- if (shouldRefreshCachedCredentials) {
786
- const { saveMatrixCredentials } = await loadCredentialsWriter();
787
- await saveMatrixCredentials(
788
- {
789
- homeserver,
790
- userId,
791
- accessToken,
792
- deviceId: knownDeviceId,
793
- },
794
- env,
795
- accountId,
796
- );
797
- } else if (hasMatchingCachedToken) {
798
- const { touchMatrixCredentials } = await loadCredentialsWriter();
799
- await touchMatrixCredentials(env, accountId);
800
- }
801
- return {
802
- accountId,
803
- homeserver,
804
- userId,
805
- accessToken,
806
- password: tokenAuthPassword,
807
- deviceId: knownDeviceId,
808
- deviceName: resolved.deviceName,
809
- initialSyncLimit: resolved.initialSyncLimit,
810
- encryption: resolved.encryption,
811
- ...buildMatrixNetworkFields({
812
- allowPrivateNetwork: resolved.allowPrivateNetwork,
813
- dispatcherPolicy: resolved.dispatcherPolicy,
814
- }),
815
- };
816
- }
817
-
818
- if (cachedCredentials) {
819
- const { touchMatrixCredentials } = await loadCredentialsWriter();
820
- await touchMatrixCredentials(env, accountId);
821
- return {
822
- accountId,
823
- homeserver: cachedCredentials.homeserver,
824
- userId: cachedCredentials.userId,
825
- accessToken: cachedCredentials.accessToken,
826
- password: tokenAuthPassword,
827
- deviceId: cachedCredentials.deviceId || resolved.deviceId,
828
- deviceName: resolved.deviceName,
829
- initialSyncLimit: resolved.initialSyncLimit,
830
- encryption: resolved.encryption,
831
- ...buildMatrixNetworkFields({
832
- allowPrivateNetwork: resolved.allowPrivateNetwork,
833
- dispatcherPolicy: resolved.dispatcherPolicy,
834
- }),
835
- };
836
- }
837
-
838
- if (!resolved.userId) {
839
- throw new Error("Matrix userId is required when no access token is configured (matrix.userId)");
840
- }
841
-
842
- const password =
843
- (await resolveConfiguredMatrixAuthSecretInput({
844
- cfg,
845
- env,
846
- accountId,
847
- field: "password",
848
- })) ?? resolved.password;
849
- if (!password) {
850
- throw new Error(
851
- "Matrix password is required when no access token is configured (matrix.password)",
852
- );
853
- }
854
-
855
- // Login with password using the same hardened request path as other Matrix HTTP calls.
856
- const { MatrixClient, ensureMatrixSdkLoggingConfigured } = await loadMatrixAuthClientDeps();
857
- ensureMatrixSdkLoggingConfigured();
858
- const loginClient = new MatrixClient(homeserver, "", {
859
- ssrfPolicy: resolved.ssrfPolicy,
860
- dispatcherPolicy: resolved.dispatcherPolicy,
861
- });
862
- const login = (await retryMatrixAuthRequest("matrix auth login", async () => {
863
- return (await loginClient.doRequest("POST", "/_matrix/client/v3/login", undefined, {
864
- type: "m.login.password",
865
- identifier: { type: "m.id.user", user: resolved.userId },
866
- password,
867
- device_id: resolved.deviceId,
868
- initial_device_display_name: resolved.deviceName ?? "OpenClaw Gateway",
869
- })) as {
870
- access_token?: string;
871
- user_id?: string;
872
- device_id?: string;
873
- };
874
- })) as {
875
- access_token?: string;
876
- user_id?: string;
877
- device_id?: string;
878
- };
879
-
880
- const loginAccessToken = login.access_token?.trim();
881
- if (!loginAccessToken) {
882
- throw new Error("Matrix login did not return an access token");
883
- }
884
-
885
- const auth: MatrixAuth = {
886
- accountId,
887
- homeserver,
888
- userId: login.user_id ?? resolved.userId,
889
- accessToken: loginAccessToken,
890
- password,
891
- deviceId: login.device_id ?? resolved.deviceId,
892
- deviceName: resolved.deviceName,
893
- initialSyncLimit: resolved.initialSyncLimit,
894
- encryption: resolved.encryption,
895
- ...buildMatrixNetworkFields({
896
- allowPrivateNetwork: resolved.allowPrivateNetwork,
897
- dispatcherPolicy: resolved.dispatcherPolicy,
898
- }),
899
- };
900
-
901
- const { saveMatrixCredentials } = await loadCredentialsWriter();
902
- await saveMatrixCredentials(
903
- {
904
- homeserver: auth.homeserver,
905
- userId: auth.userId,
906
- accessToken: auth.accessToken,
907
- deviceId: auth.deviceId,
908
- },
909
- env,
910
- accountId,
911
- );
912
-
913
- return auth;
914
- }
915
-
916
- export async function backfillMatrixAuthDeviceIdAfterStartup(params: {
917
- auth: MatrixAuth;
918
- env?: NodeJS.ProcessEnv;
919
- abortSignal?: AbortSignal;
920
- }): Promise<string | undefined> {
921
- const knownDeviceId = params.auth.deviceId?.trim();
922
- if (knownDeviceId) {
923
- return knownDeviceId;
924
- }
925
- if (isAbortSignalTriggered(params.abortSignal)) {
926
- return undefined;
927
- }
928
-
929
- const whoami = await fetchMatrixWhoamiIdentity({
930
- homeserver: params.auth.homeserver,
931
- accessToken: params.auth.accessToken,
932
- userId: params.auth.userId,
933
- ssrfPolicy: params.auth.ssrfPolicy,
934
- dispatcherPolicy: params.auth.dispatcherPolicy,
935
- });
936
- const deviceId = whoami.device_id?.trim();
937
- if (!deviceId) {
938
- return undefined;
939
- }
940
- if (isAbortSignalTriggered(params.abortSignal)) {
941
- return undefined;
942
- }
943
-
944
- const env = params.env ?? process.env;
945
- const { loadMatrixCredentials } = await loadMatrixCredentialsReadDeps();
946
- if (
947
- !credentialsMatchBackfillAuthLineage({
948
- stored: loadMatrixCredentials(env, params.auth.accountId),
949
- auth: params.auth,
950
- })
951
- ) {
952
- return undefined;
953
- }
954
-
955
- const repairedStorageMeta = repairCurrentTokenStorageMetaDeviceId({
956
- homeserver: params.auth.homeserver,
957
- userId: params.auth.userId,
958
- accessToken: params.auth.accessToken,
959
- accountId: params.auth.accountId,
960
- deviceId,
961
- env: params.env,
962
- });
963
- if (!repairedStorageMeta) {
964
- throw new Error("Matrix deviceId backfill failed to repair current-token storage metadata");
965
- }
966
- if (isAbortSignalTriggered(params.abortSignal)) {
967
- return undefined;
968
- }
969
-
970
- const credentialsWriter = await import("../credentials-write.runtime.js");
971
- const saved = await credentialsWriter.saveBackfilledMatrixDeviceId(
972
- {
973
- homeserver: params.auth.homeserver,
974
- userId: params.auth.userId,
975
- accessToken: params.auth.accessToken,
976
- deviceId,
977
- },
978
- env,
979
- params.auth.accountId,
980
- );
981
- return saved === "saved" ? deviceId : undefined;
982
- }