silentlake 2026.3.24

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 (1893) hide show
  1. package/CHANGELOG.md +4587 -0
  2. package/LICENSE +21 -0
  3. package/README.md +248 -0
  4. package/assets/avatar-placeholder.svg +19 -0
  5. package/assets/chrome-extension/icons/icon128.png +0 -0
  6. package/assets/chrome-extension/icons/icon16.png +0 -0
  7. package/assets/chrome-extension/icons/icon32.png +0 -0
  8. package/assets/chrome-extension/icons/icon48.png +0 -0
  9. package/assets/dmg-background-small.png +0 -0
  10. package/assets/dmg-background.png +0 -0
  11. package/assets/silentlake-banner.png +0 -0
  12. package/dist/APEv2Parser-BZv_dP9t.js +269 -0
  13. package/dist/APEv2Parser-CPzxFNBB.js +5 -0
  14. package/dist/AbstractID3Parser-mvDFcjYV.js +47 -0
  15. package/dist/AiffParser-BXQ9SRZk.js +145 -0
  16. package/dist/AsfParser-CmBDUlZE.js +631 -0
  17. package/dist/BasicParser-DhmXREDo.js +853 -0
  18. package/dist/DsdiffParser-CTKKGyZg.js +150 -0
  19. package/dist/DsfParser-Ds-YQe4Z.js +101 -0
  20. package/dist/FlacParser-B1XVPgXF.js +5 -0
  21. package/dist/FlacParser-DMPyL1y4.js +367 -0
  22. package/dist/ID3v1Parser-BICWWVDG.js +289 -0
  23. package/dist/ID3v2Parser-BmZHSUqs.js +650 -0
  24. package/dist/ID3v2Token-DeJf4tYQ.js +145 -0
  25. package/dist/MP4Parser-Cjf-Zs8T.js +1061 -0
  26. package/dist/MatroskaParser-DgBzBe8t.js +909 -0
  27. package/dist/MpegParser-D5swTpA1.js +744 -0
  28. package/dist/MusepackParser-D8EQXnpK.js +285 -0
  29. package/dist/OggParser-BcIYPHwP.js +390 -0
  30. package/dist/Util-D_zGsr97.js +170 -0
  31. package/dist/WavPackParser-hosU8gfo.js +166 -0
  32. package/dist/WaveParser-CA00FZrC.js +273 -0
  33. package/dist/abort-cutoff-CERmtgZI.js +56 -0
  34. package/dist/abort-cutoff.runtime-DZkGKKzv.js +61 -0
  35. package/dist/abort-signal-CsrBEr94.js +13 -0
  36. package/dist/account-helpers-D3c_eI7c.js +37 -0
  37. package/dist/account-helpers-ru3jdZSV.js +12 -0
  38. package/dist/account-id-DZnNZg8x.js +1 -0
  39. package/dist/account-id-ZCrgXl7Z.js +44 -0
  40. package/dist/account-lookup-nkoa-foB.js +10 -0
  41. package/dist/account-snapshot-fields-Cvq7803C.js +116 -0
  42. package/dist/account-summary-B5Xzvntm.js +36 -0
  43. package/dist/accounts-43SvCDEA.js +212 -0
  44. package/dist/accounts-CYgFhv2o.js +105 -0
  45. package/dist/accounts-ChlyF7cx.js +112 -0
  46. package/dist/ack-reactions-CNVwfOBj.js +43 -0
  47. package/dist/acp-cli-B4Rv7-xU.js +2033 -0
  48. package/dist/acp-runtime-BdLdT-QY.js +1 -0
  49. package/dist/actions.runtime-CqnQssoB.js +217 -0
  50. package/dist/actions.runtime-FLmCvVRd.js +236 -0
  51. package/dist/agent-CBOdzEvR.js +1 -0
  52. package/dist/agent-scope-BLhzf-o0.js +17 -0
  53. package/dist/agent-scope-DPP4Z_UU.js +193 -0
  54. package/dist/agents-D8pBK0II.js +855 -0
  55. package/dist/agents-Dihz1Ihx.js +323 -0
  56. package/dist/agents.config-C_lrnc9J.js +18 -0
  57. package/dist/agents.config-D1VqC78r.js +121 -0
  58. package/dist/allow-from-BPSBITdd.js +9 -0
  59. package/dist/allow-from-BwTLpvhp.js +20 -0
  60. package/dist/allow-from-C4iBpqFI.js +62 -0
  61. package/dist/allowlist-config-edit-CKbnMmwS.js +279 -0
  62. package/dist/allowlist-match-CYmPgg1K.js +63 -0
  63. package/dist/ansi-BEJF8NKS.js +54 -0
  64. package/dist/anthropic-vertex-provider-Dd5agCN9.js +60 -0
  65. package/dist/apply.runtime-DhKxNSJE.js +370 -0
  66. package/dist/apply.runtime-ghlh-P6X.js +211 -0
  67. package/dist/archive-Tr0wIUO-.js +532 -0
  68. package/dist/arg-split-Dtda0YDl.js +38 -0
  69. package/dist/artifacts-C_4LekPC.js +39 -0
  70. package/dist/audit-BOPSQQtd.js +54 -0
  71. package/dist/audit-C5kdrCi_.js +788 -0
  72. package/dist/audit-channel.allow-from.runtime-B7BHNblL.js +17 -0
  73. package/dist/audit-channel.collect.runtime-CjAbXFBV.js +521 -0
  74. package/dist/audit-channel.discord.runtime-BBY6S9lg.js +5 -0
  75. package/dist/audit-channel.telegram.runtime-SJnxOJH2.js +8 -0
  76. package/dist/audit-channel.zalouser.runtime-SGRWvHxT.js +5 -0
  77. package/dist/audit-extra.async-DY8v7LXH.js +817 -0
  78. package/dist/audit-fs-oDMUa5N_.js +375 -0
  79. package/dist/audit-membership-runtime-BPjFryEx.js +261 -0
  80. package/dist/audit.deep.runtime-WFf-TpsD.js +31 -0
  81. package/dist/audit.nondeep.runtime-B4BaEaRU.js +842 -0
  82. package/dist/audit.runtime-rFjCrods.js +74 -0
  83. package/dist/auth-O6LQFLHJ.js +416 -0
  84. package/dist/auth-choice-DIBaxmAQ.js +219 -0
  85. package/dist/auth-choice-PrbpIjyg.js +610 -0
  86. package/dist/auth-choice-legacy-Clyw2lVc.js +17 -0
  87. package/dist/auth-choice-options-ohUw8QR-.js +127 -0
  88. package/dist/auth-choice-prompt-Cm0s-9Du.js +215 -0
  89. package/dist/auth-choice-prompt-DI-Xl1Nv.js +36 -0
  90. package/dist/auth-choice-rKBOd02a.js +64 -0
  91. package/dist/auth-choice.apply-helpers-BibBSEl9.js +66 -0
  92. package/dist/auth-choice.plugin-providers.runtime-gqF9NO7_.js +219 -0
  93. package/dist/auth-health-TWboMYA5.js +166 -0
  94. package/dist/auth-mode-policy-DywddkT-.js +18 -0
  95. package/dist/auth-profiles-CWEIQV77.js +1047 -0
  96. package/dist/auth-profiles.runtime-B98lwopF.js +48 -0
  97. package/dist/avatar-policy-Ds9e6uHI.js +67 -0
  98. package/dist/axios-xDDnM0KG.js +12831 -0
  99. package/dist/backup-create-B6JAR6jJ.js +461 -0
  100. package/dist/banner-bez5CpOK.js +351 -0
  101. package/dist/base-session-key-Cf2rkwag.js +14 -0
  102. package/dist/bindings-BV4AtNSY.js +21 -0
  103. package/dist/bindings-kjwuC11Q.js +69 -0
  104. package/dist/bluebubbles-C1M3Geg0.js +87 -0
  105. package/dist/bluebubbles-DRW3JdOY.js +603 -0
  106. package/dist/bluebubbles-dEl4QpYz.js +37 -0
  107. package/dist/bonjour-discovery-C2oY96BG.js +376 -0
  108. package/dist/boolean-DKtCJu_W.js +29 -0
  109. package/dist/boolean-param-xAGXUSSN.js +13 -0
  110. package/dist/boundary-file-read-BP6VMpqH.js +106 -0
  111. package/dist/boundary-path-B3FFLYNx.js +557 -0
  112. package/dist/brave-CkimJe4j.js +405 -0
  113. package/dist/brew-DSwWqzLd.js +44 -0
  114. package/dist/browser-cli-D3kBUBNc.js +1502 -0
  115. package/dist/bundled/boot-md/handler.js +381 -0
  116. package/dist/bundled/bootstrap-extra-files/handler.js +56 -0
  117. package/dist/bundled/command-logger/handler.js +62 -0
  118. package/dist/bundled/session-memory/handler.js +401 -0
  119. package/dist/call-BDvaXe4i.js +44 -0
  120. package/dist/call-BmLt3xO1.js +639 -0
  121. package/dist/catalog-BwAYUfL7.js +240 -0
  122. package/dist/channel-BBCuV5OT.js +4945 -0
  123. package/dist/channel-BDBXuqeg.js +321 -0
  124. package/dist/channel-C8h1Irxm.js +1284 -0
  125. package/dist/channel-CbGpFzo4.js +1602 -0
  126. package/dist/channel-Ci3K8fI9.js +1006 -0
  127. package/dist/channel-DGT5N1v7.js +1077 -0
  128. package/dist/channel-account-context-Bwa-YH_o.js +104 -0
  129. package/dist/channel-actions-DU2CR3xW.js +37 -0
  130. package/dist/channel-activity-B8aReQoE.js +35 -0
  131. package/dist/channel-config-3Uv6ve2_.js +115 -0
  132. package/dist/channel-config-helpers-CieQWILI.js +377 -0
  133. package/dist/channel-config-schema-DEVsCZpj.js +1 -0
  134. package/dist/channel-feedback-G6zh8efr.js +245 -0
  135. package/dist/channel-inbound-DwzVf2PK.js +395 -0
  136. package/dist/channel-lifecycle-CpU1dRbh.js +354 -0
  137. package/dist/channel-options-DJaIP4Dv.js +38 -0
  138. package/dist/channel-pairing-D54mn51y.js +66 -0
  139. package/dist/channel-plugin-common-BhTxCE5t.js +1 -0
  140. package/dist/channel-plugin-ids-CFeS3qir.js +26 -0
  141. package/dist/channel-plugin-resolution-DUngfdFj.js +112 -0
  142. package/dist/channel-policy-C4GKHvhz.js +1 -0
  143. package/dist/channel-reply-pipeline-CPTuaW8n.js +15 -0
  144. package/dist/channel-send-result-By8EpCPw.js +40 -0
  145. package/dist/channel-setup-Ck35g7zI.js +49 -0
  146. package/dist/channel-shared-LkXtTPXk.js +308 -0
  147. package/dist/channel-summary-CdYLGMVt.js +137 -0
  148. package/dist/channel-summary-D33z52ft.js +41 -0
  149. package/dist/channel-targets-DfnKGXez.js +87 -0
  150. package/dist/channel.runtime-DAyBR2A5.js +324 -0
  151. package/dist/channel.runtime-DVq5tC2D.js +35 -0
  152. package/dist/channel.runtime-DaLTDGtF.js +288 -0
  153. package/dist/channel.runtime-FKfTev2g.js +512 -0
  154. package/dist/channel.runtime-owqedh1t.js +268 -0
  155. package/dist/channel.runtime-wOTeiifp.js +230 -0
  156. package/dist/channels-CIHgkPea.js +408 -0
  157. package/dist/channels-ZXK6Jiuk.js +1393 -0
  158. package/dist/channels-cli-Bj6qSlkE.js +412 -0
  159. package/dist/channels-status-issues-C_U44M8Y.js +16 -0
  160. package/dist/chat-type-C-n03mQY.js +10 -0
  161. package/dist/clack-prompter-DuzDnaLi.js +112 -0
  162. package/dist/clawbot-cli-YNPuwmTB.js +218 -0
  163. package/dist/cli/daemon-cli.js +88 -0
  164. package/dist/cli-CW46WAZn.js +254 -0
  165. package/dist/cli-name-Daok7A7-.js +25 -0
  166. package/dist/cli-runtime-aAVwbEYy.js +7 -0
  167. package/dist/cli-utils-Np4NAAtt.js +39 -0
  168. package/dist/command-format-CYK9XiUC.js +16 -0
  169. package/dist/command-format-g8YUHNir.js +2 -0
  170. package/dist/command-gating-BQXGSqc9.js +40 -0
  171. package/dist/command-options-5coRiipK.js +25 -0
  172. package/dist/command-poll-backoff-CpkSns-6.js +56 -0
  173. package/dist/command-poll-backoff.runtime-YT6EGcLN.js +7 -0
  174. package/dist/command-registry-BI2MOs89.js +242 -0
  175. package/dist/command-registry-BMsxnuoC.js +14 -0
  176. package/dist/command-secret-gateway-ChXyZwos.js +211 -0
  177. package/dist/command-secret-targets-COcwhn-D.js +88 -0
  178. package/dist/command-secret-targets-CQJT3viO.js +3 -0
  179. package/dist/commands-Bb9xUwz9.js +42 -0
  180. package/dist/commands-core-C1usZXC2.js +4923 -0
  181. package/dist/commands-core.runtime-OTZivlO2.js +232 -0
  182. package/dist/commands-registry-ChCep1KJ.js +295 -0
  183. package/dist/commands-registry.data-XyUTELK9.js +904 -0
  184. package/dist/commands-registry.runtime-m5WTxFtv.js +25 -0
  185. package/dist/commands-status.runtime-C8_hpNgj.js +211 -0
  186. package/dist/commands.runtime-BZPnQKcW.js +232 -0
  187. package/dist/common-CUBlLRXB.js +457 -0
  188. package/dist/compact.runtime-Djmzpbn6.js +216 -0
  189. package/dist/completion-cli-D8tLgE5W.js +445 -0
  190. package/dist/completion-cli-Dz89naVA.js +17 -0
  191. package/dist/config-6sZwvXJD.js +88 -0
  192. package/dist/config-B7tPwoHZ.js +38 -0
  193. package/dist/config-DdDLrP_v.js +273 -0
  194. package/dist/config-cli-C10R8azD.js +945 -0
  195. package/dist/config-guard-B1c73BYQ.js +126 -0
  196. package/dist/config-helpers-3u5wfLBu.js +117 -0
  197. package/dist/config-pn7LKJdW.js +23 -0
  198. package/dist/config-presence-BmUF_5K9.js +79 -0
  199. package/dist/config-regex-CvZFnWkO.js +39 -0
  200. package/dist/config-runtime-CstET7fq.js +142 -0
  201. package/dist/config-schema-5YkIW1xw.js +270 -0
  202. package/dist/config-schema-B1UGMwZ8.js +31 -0
  203. package/dist/config-schema-DzlnsY3D.js +33 -0
  204. package/dist/config-state-CE0CGjey.js +288 -0
  205. package/dist/config-validation-CkVqgkHr.js +272 -0
  206. package/dist/config-value-DgJrpclm.js +25 -0
  207. package/dist/configure-DMkp7Sr4.js +1126 -0
  208. package/dist/configure-DOrQthLy.js +344 -0
  209. package/dist/connection-auth-BSQJeDOU.js +30 -0
  210. package/dist/constants-C_Scc680.js +71 -0
  211. package/dist/control-ui-assets-DjqeIg6A.js +232 -0
  212. package/dist/control-ui-shared-DP000Pxd.js +29 -0
  213. package/dist/conversation-runtime-1O0Aaolb.js +1458 -0
  214. package/dist/core-C7aHA4Aq.js +187 -0
  215. package/dist/core-command-descriptors-DCUYAEZd.js +96 -0
  216. package/dist/credentials-BPwBlm1X.js +265 -0
  217. package/dist/cron-cli-N2Hw_02d.js +579 -0
  218. package/dist/daemon-cli-DgfaF9xx.js +354 -0
  219. package/dist/daemon-install-CbclJo5M.js +134 -0
  220. package/dist/daemon-install-plan.shared-DK6BHlWI.js +222 -0
  221. package/dist/daemon-runtime-CbClrCwc.js +12 -0
  222. package/dist/dangerous-config-flags-BJtLWIk7.js +15 -0
  223. package/dist/dangerous-name-matching-DZa_t0RM.js +44 -0
  224. package/dist/dangerous-tools-yGPDFTHh.js +27 -0
  225. package/dist/date-time-DCAyaBop.js +118 -0
  226. package/dist/dedupe-Cgnk5BbX.js +55 -0
  227. package/dist/defaults-CEdZhIIb.js +6 -0
  228. package/dist/delegate-D4ql5N70.js +43 -0
  229. package/dist/deliver-B004w1Mv.js +212 -0
  230. package/dist/deliver-runtime-IYvc0giI.js +211 -0
  231. package/dist/delivery-queue-B19wDCjT.js +3 -0
  232. package/dist/delivery-queue-DrrqB4Hi.js +299 -0
  233. package/dist/device-auth-GEXe9vqR.js +15 -0
  234. package/dist/device-bootstrap-CwwokLEY.js +96 -0
  235. package/dist/device-bootstrap-Dbhe6oe8.js +1 -0
  236. package/dist/device-metadata-normalization-BDSQ_eA7.js +21 -0
  237. package/dist/device-pairing-cFWbBray.js +553 -0
  238. package/dist/devices-cli-DzycjFzS.js +366 -0
  239. package/dist/diagnostic-DqJXx_4Q.js +310 -0
  240. package/dist/diagnostic-events-ktCoG8Br.js +48 -0
  241. package/dist/diagnostics-CMhyGsPu.js +33 -0
  242. package/dist/diagnostics-DpLHpQ9c.js +14 -0
  243. package/dist/directive-handling.fast-lane-toP_ri_H.js +273 -0
  244. package/dist/directive-handling.impl-BRARyrsT.js +638 -0
  245. package/dist/directive-handling.impl-CUB4MOnK.js +214 -0
  246. package/dist/directive-handling.levels-8vnMeuGX.js +2 -0
  247. package/dist/directive-handling.levels-CoruY1AA.js +13 -0
  248. package/dist/directive-handling.persist.runtime-78Du6PgL.js +170 -0
  249. package/dist/directive-handling.shared-DCGUCHjn.js +147 -0
  250. package/dist/directory-cli-DVsDcgIU.js +437 -0
  251. package/dist/directory-config-helpers-CURJ8mj7.js +129 -0
  252. package/dist/directory-runtime-DhC8QkMq.js +19 -0
  253. package/dist/directory.static-DQaG9ohH.js +44 -0
  254. package/dist/discord-CYj8s73O.js +214 -0
  255. package/dist/discord-L9zvSHVn.js +635 -0
  256. package/dist/discord-core-5tkl-BzP.js +1 -0
  257. package/dist/dm-policy-shared-6bCJzHOS.js +188 -0
  258. package/dist/dns-cli-BMvHy265.js +223 -0
  259. package/dist/docker-XFNiArwM.js +1254 -0
  260. package/dist/docs-cli-BTaH94wD.js +176 -0
  261. package/dist/doctor-completion-DKx5m2UC.js +90 -0
  262. package/dist/doctor-config-preflight-BzQgc3_t.js +40 -0
  263. package/dist/doctor-config-preflight-DxVCut8L.js +150 -0
  264. package/dist/doctor-state-migrations-CTF66iAy.js +732 -0
  265. package/dist/doctor-state-migrations-D0VP4dUh.js +212 -0
  266. package/dist/entry-status-B2OWAf0s.js +172 -0
  267. package/dist/entry.js +210 -0
  268. package/dist/env-BP70DGuy.js +30 -0
  269. package/dist/env-overrides-JneV60sd.js +434 -0
  270. package/dist/env-overrides.runtime-DLrwions.js +18 -0
  271. package/dist/env-substitution-D6t_sLS_.js +136 -0
  272. package/dist/errors-BxyFnvP3.js +58 -0
  273. package/dist/exec-Dmex2w_d.js +310 -0
  274. package/dist/exec-approvals-BJhuySBz.js +386 -0
  275. package/dist/exec-approvals-allowlist-B_wPddCb.js +384 -0
  276. package/dist/exec-approvals-cli-C2dwhSkX.js +427 -0
  277. package/dist/exec-safe-bin-runtime-policy-BZkObC8r.js +89 -0
  278. package/dist/exec-safety-CaaBy-Zw.js +24 -0
  279. package/dist/extension-shared-5txN7IXK.js +74 -0
  280. package/dist/extensionAPI.js +218 -0
  281. package/dist/extensions/amazon-bedrock/index.js +231 -0
  282. package/dist/extensions/anthropic/index.js +330 -0
  283. package/dist/extensions/bluebubbles/index.js +224 -0
  284. package/dist/extensions/bluebubbles/setup-entry.js +289 -0
  285. package/dist/extensions/brave/index.js +23 -0
  286. package/dist/extensions/byteplus/index.js +112 -0
  287. package/dist/extensions/chutes/index.js +221 -0
  288. package/dist/extensions/cloudflare-ai-gateway/index.js +218 -0
  289. package/dist/extensions/copilot-proxy/index.js +125 -0
  290. package/dist/extensions/device-pair/index.js +1040 -0
  291. package/dist/extensions/discord/index.js +215 -0
  292. package/dist/extensions/discord/setup-entry.js +215 -0
  293. package/dist/extensions/elevenlabs/index.js +223 -0
  294. package/dist/extensions/fal/index.js +112 -0
  295. package/dist/extensions/feishu/index.js +227 -0
  296. package/dist/extensions/feishu/setup-entry.js +112 -0
  297. package/dist/extensions/firecrawl/index.js +211 -0
  298. package/dist/extensions/github-copilot/index.js +490 -0
  299. package/dist/extensions/google/index.js +211 -0
  300. package/dist/extensions/huggingface/index.js +108 -0
  301. package/dist/extensions/imessage/index.js +223 -0
  302. package/dist/extensions/imessage/setup-entry.js +220 -0
  303. package/dist/extensions/irc/index.js +220 -0
  304. package/dist/extensions/irc/setup-entry.js +222 -0
  305. package/dist/extensions/kilocode/index.js +282 -0
  306. package/dist/extensions/kimi-coding/index.js +148 -0
  307. package/dist/extensions/line/index.js +57 -0
  308. package/dist/extensions/line/setup-entry.js +49 -0
  309. package/dist/extensions/llm-task/index.js +157 -0
  310. package/dist/extensions/lobster/index.js +261 -0
  311. package/dist/extensions/mattermost/index.js +220 -0
  312. package/dist/extensions/mattermost/setup-entry.js +222 -0
  313. package/dist/extensions/memory-core/index.js +36 -0
  314. package/dist/extensions/microsoft/index.js +223 -0
  315. package/dist/extensions/minimax/index.js +437 -0
  316. package/dist/extensions/mistral/index.js +149 -0
  317. package/dist/extensions/modelstudio/index.js +144 -0
  318. package/dist/extensions/moonshot/index.js +211 -0
  319. package/dist/extensions/nextcloud-talk/index.js +221 -0
  320. package/dist/extensions/nextcloud-talk/setup-entry.js +223 -0
  321. package/dist/extensions/nvidia/index.js +29 -0
  322. package/dist/extensions/ollama/index.js +118 -0
  323. package/dist/extensions/open-prose/index.js +10 -0
  324. package/dist/extensions/openai/index.js +677 -0
  325. package/dist/extensions/opencode/index.js +116 -0
  326. package/dist/extensions/opencode-go/index.js +114 -0
  327. package/dist/extensions/openrouter/index.js +398 -0
  328. package/dist/extensions/openshell/index.js +923 -0
  329. package/dist/extensions/perplexity/index.js +23 -0
  330. package/dist/extensions/phone-control/index.js +276 -0
  331. package/dist/extensions/qianfan/index.js +114 -0
  332. package/dist/extensions/qwen-portal-auth/index.js +350 -0
  333. package/dist/extensions/sglang/index.js +285 -0
  334. package/dist/extensions/signal/index.js +218 -0
  335. package/dist/extensions/signal/setup-entry.js +218 -0
  336. package/dist/extensions/slack/index.js +222 -0
  337. package/dist/extensions/slack/setup-entry.js +220 -0
  338. package/dist/extensions/synology-chat/index.js +56 -0
  339. package/dist/extensions/synology-chat/setup-entry.js +58 -0
  340. package/dist/extensions/synthetic/index.js +112 -0
  341. package/dist/extensions/talk-voice/index.js +197 -0
  342. package/dist/extensions/tavily/index.js +211 -0
  343. package/dist/extensions/telegram/index.js +221 -0
  344. package/dist/extensions/telegram/setup-entry.js +221 -0
  345. package/dist/extensions/thread-ownership/index.js +70 -0
  346. package/dist/extensions/together/index.js +113 -0
  347. package/dist/extensions/venice/index.js +132 -0
  348. package/dist/extensions/vercel-ai-gateway/index.js +86 -0
  349. package/dist/extensions/vllm/index.js +285 -0
  350. package/dist/extensions/voice-call/index.js +5715 -0
  351. package/dist/extensions/volcengine/index.js +112 -0
  352. package/dist/extensions/xai/index.js +211 -0
  353. package/dist/extensions/xiaomi/index.js +115 -0
  354. package/dist/extensions/zai/index.js +559 -0
  355. package/dist/extensions/zalo/index.js +225 -0
  356. package/dist/extensions/zalo/setup-entry.js +226 -0
  357. package/dist/external-content-BUdUOqkv.js +238 -0
  358. package/dist/feishu-CgbwAF0e.js +2664 -0
  359. package/dist/feishu-Dh5fEbh5.js +59127 -0
  360. package/dist/fetch-guard-DIyN1HW5.js +165 -0
  361. package/dist/fetch-timeout-C5xpMuGd.js +36 -0
  362. package/dist/file-identity-Cw0fQxYY.js +11 -0
  363. package/dist/file-lock-WbEmczmY.js +107 -0
  364. package/dist/filter-oMGaNOM1.js +20 -0
  365. package/dist/format-DH8ysi7s.js +19 -0
  366. package/dist/format-datetime-BGS6tLDE.js +73 -0
  367. package/dist/format-duration-CO0BGWB0.js +57 -0
  368. package/dist/format-relative-C3nDxnXz.js +54 -0
  369. package/dist/frontmatter-S5vS-I4a.js +309 -0
  370. package/dist/fs-safe-D3qzH-ab.js +731 -0
  371. package/dist/gateway-cli-PQNp7o0j.js +28378 -0
  372. package/dist/gateway-install-token-DV5KjD4F.js +164 -0
  373. package/dist/gateway-rpc-C0Ey-rik.js +26 -0
  374. package/dist/gateway-runtime-ih2e7a2K.js +42 -0
  375. package/dist/gaxios-fetch-compat-KX6bsqFm.js +165 -0
  376. package/dist/gemini-auth-B5ljg7jr.js +29 -0
  377. package/dist/git-commit-BIdLubm5.js +2 -0
  378. package/dist/git-commit-OvUvjri2.js +177 -0
  379. package/dist/github-copilot-auth-Ccm-cBwy.js +104 -0
  380. package/dist/global-singleton-4KwY5RvX.js +13 -0
  381. package/dist/globals-41sdSaKv.js +38 -0
  382. package/dist/gmail-setup-utils-BX68dZla.js +419 -0
  383. package/dist/group-access-DJZrYPx1.js +113 -0
  384. package/dist/group-keys-BD_IYSMs.js +44 -0
  385. package/dist/group-policy-CWFxv3iB.js +201 -0
  386. package/dist/group-policy-warnings-Ddu6lBkh.js +175 -0
  387. package/dist/health-Bu1sbyYy.js +573 -0
  388. package/dist/health-Cbxc9Bn3.js +59 -0
  389. package/dist/health-format-B5XfOTuJ.js +26 -0
  390. package/dist/heartbeat-7aHh0m3d.js +169 -0
  391. package/dist/heartbeat-summary-Das49TYq.js +57 -0
  392. package/dist/help-CcbF7-ha.js +81 -0
  393. package/dist/help-format-Dv45FpYu.js +15 -0
  394. package/dist/helpers-DJ-5HEbE.js +24 -0
  395. package/dist/helpers-MxyaLZUk.js +32 -0
  396. package/dist/history-CHjo8B5W.js +102 -0
  397. package/dist/hook-runtime-BnNBi_q4.js +1 -0
  398. package/dist/hooks-cli-DUYK4RM1.js +1102 -0
  399. package/dist/hooks-policy-BL6HDLUn.js +20 -0
  400. package/dist/hooks-status-gzNmo3li.js +78 -0
  401. package/dist/host-env-security-BogNN146.js +223 -0
  402. package/dist/http-body-CCiSfloA.js +237 -0
  403. package/dist/http-registry-WFFbLYRd.js +153 -0
  404. package/dist/identity-DovQV4zD.js +112 -0
  405. package/dist/identity-cyBYcoXS.js +84 -0
  406. package/dist/identity-file-EndG1nfc.js +60 -0
  407. package/dist/image-generation-CNKc-mFK.js +441 -0
  408. package/dist/image-kJ7Tbov4.js +211 -0
  409. package/dist/image-ops-j01UkxEv.js +371 -0
  410. package/dist/imessage-B5pSMT47.js +219 -0
  411. package/dist/imessage-CoIuY1Ro.js +1451 -0
  412. package/dist/imessage-Cqjsq4VW.js +190 -0
  413. package/dist/imessage-core-CsYJuaRZ.js +1 -0
  414. package/dist/inbound-envelope-4P3IIJc3.js +61 -0
  415. package/dist/inbound-reply-dispatch-i2Vekqyy.js +72 -0
  416. package/dist/includes-7XyL3p1c.js +188 -0
  417. package/dist/includes-scan-y-rS6tTw.js +55 -0
  418. package/dist/index.js +57 -0
  419. package/dist/infra/warning-filter.js +2 -0
  420. package/dist/inspect-CcxlJ1ba.js +279 -0
  421. package/dist/install-safe-path-Rwbw1XCZ.js +62 -0
  422. package/dist/installs-iHi2aSjM.js +532 -0
  423. package/dist/interactive-F7iY0yED.js +8 -0
  424. package/dist/interactive-runtime-OweOj_Vv.js +90 -0
  425. package/dist/internal-hooks-0uipqzRY.js +156 -0
  426. package/dist/io-BX49DsSJ.js +35 -0
  427. package/dist/io-jOnQRia2.js +7178 -0
  428. package/dist/ip-C8vmzVu0.js +203 -0
  429. package/dist/ipv4-DAmsJVOV.js +82 -0
  430. package/dist/irc-AZ-Ec8be.js +12 -0
  431. package/dist/irc-CCSRuEC2.js +660 -0
  432. package/dist/is-main-YViS6wOn.js +27 -0
  433. package/dist/issue-format-CBEXVico.js +31 -0
  434. package/dist/issue-format-D3HehoKZ.js +4 -0
  435. package/dist/json-file-C2zjA0Gv.js +23 -0
  436. package/dist/json-files-WW-H_psG.js +60 -0
  437. package/dist/json-pointer-f9dEnBoR.js +43 -0
  438. package/dist/json-store-O1LwpnBH.js +37 -0
  439. package/dist/kb-cli-DMZs6PCu.js +65 -0
  440. package/dist/keyed-async-queue-CPUWV5Pm.js +32 -0
  441. package/dist/kill-tree-CbjXBw3z.js +149 -0
  442. package/dist/kilocode-shared-DS7_0IMs.js +29 -0
  443. package/dist/launchd-tyqGVx9U.js +491 -0
  444. package/dist/lazy-runtime-BcXbyAaC.js +1 -0
  445. package/dist/lazy-runtime-bWkd2cs3.js +29 -0
  446. package/dist/legacy-names-CUNZ4vHN.js +7 -0
  447. package/dist/legacy-web-search-BgZjNG2h.js +222 -0
  448. package/dist/lib-CERS7N4b.js +503 -0
  449. package/dist/lib-PPICrHv1.js +1938 -0
  450. package/dist/library-CZ461krl.js +211 -0
  451. package/dist/lifecycle-core-Dnxnw0oy.js +382 -0
  452. package/dist/line/accounts.js +10 -0
  453. package/dist/line/send.js +39 -0
  454. package/dist/line/template-messages.js +2 -0
  455. package/dist/line-CJSvwApm.js +1 -0
  456. package/dist/line-N9vL-2JB.js +688 -0
  457. package/dist/line-core-BOIxkjgu.js +1 -0
  458. package/dist/links-Bilm-v0z.js +13 -0
  459. package/dist/llm-slug-generator-BuAuQ5Ft.js +68 -0
  460. package/dist/llm-slug-generator.js +212 -0
  461. package/dist/llm-task-Dx8ymRFr.js +1 -0
  462. package/dist/local-roots-DAzCjWbC.js +34 -0
  463. package/dist/location-DefAH9WS.js +42 -0
  464. package/dist/logger-CoEtkjhn.js +550 -0
  465. package/dist/logger-Cqy7-Maj.js +70 -0
  466. package/dist/logging-B2wMcpWV.js +13 -0
  467. package/dist/logging-Bz1qZDPg.js +16 -0
  468. package/dist/logging-CArEWRgI.js +36 -0
  469. package/dist/logging-CbTTfADU.js +1 -0
  470. package/dist/logs-cli-BSjKwaur.js +261 -0
  471. package/dist/magic-string.es-DJPWMt-n.js +1011 -0
  472. package/dist/main-session-DKr0lBVk.js +36 -0
  473. package/dist/manager-ChTGDe87.js +2005 -0
  474. package/dist/manager-DuwFn87U.js +4226 -0
  475. package/dist/manager-runtime-E16jsvRe.js +59 -0
  476. package/dist/manager.runtime-F9F1eFiB.js +827 -0
  477. package/dist/manifest-registry-B90TyTWl.js +1350 -0
  478. package/dist/map-size-CMTQVKUV.js +15 -0
  479. package/dist/markdown-to-line-BWwaRx5F.js +640 -0
  480. package/dist/mask-api-key-CprzEe7l.js +10 -0
  481. package/dist/matrix-DzvdUw97.js +228 -0
  482. package/dist/matrix-migration-snapshot-adoDbNii.js +702 -0
  483. package/dist/mattermost-DO0BCfF3.js +1 -0
  484. package/dist/mattermost-SjOt4QDb.js +15 -0
  485. package/dist/mcp-cli-BC_VPl_o.js +94 -0
  486. package/dist/mcp-config-Coky4zS4.js +108 -0
  487. package/dist/media-limits-Cuvmmhop.js +14 -0
  488. package/dist/media-understanding-DD2uMjK8.js +48 -0
  489. package/dist/media-understanding.runtime-Kbb2bRmk.js +216 -0
  490. package/dist/memory-DBjQ0TPd.js +1 -0
  491. package/dist/memory-cli-Cm4Df0hJ.js +215 -0
  492. package/dist/memory-cli-yzqneSF8.js +541 -0
  493. package/dist/memory-search-Das1tiuB.js +204 -0
  494. package/dist/memory-search-DxmSTjHq.js +18 -0
  495. package/dist/mention-gating-B_q-EHFx.js +25 -0
  496. package/dist/mentions-Bxys_va0.js +154 -0
  497. package/dist/message-channel-Cy-gN4K2.js +106 -0
  498. package/dist/message-hook-mappers-BBTV3JRQ.js +249 -0
  499. package/dist/method-scopes-DgypDW23.js +2649 -0
  500. package/dist/mime-C4vVTBso.js +150 -0
  501. package/dist/minimal-C5yUxtHy.js +2120 -0
  502. package/dist/model-auth-B__TJTPw.js +309 -0
  503. package/dist/model-auth-env-CF9ts7Th.js +111 -0
  504. package/dist/model-catalog.runtime-CWh17vcc.js +211 -0
  505. package/dist/model-id-normalization-Y-MIsyK_.js +16 -0
  506. package/dist/model-input-BB2wSAHb.js +20 -0
  507. package/dist/model-overrides-sIzKU2wo.js +84 -0
  508. package/dist/model-param-b-DIFEhICm.js +15 -0
  509. package/dist/model-picker-CAPjetT3.js +400 -0
  510. package/dist/model-picker-DEw9viWc.js +215 -0
  511. package/dist/model-picker.runtime-ixYl7lB5.js +224 -0
  512. package/dist/model-selection-BTpJnslv.js +437 -0
  513. package/dist/model-selection-Ci9cPkL2.js +765 -0
  514. package/dist/model-suppression.runtime-D8cIb6Y5.js +216 -0
  515. package/dist/models-BQtc3khN.js +226 -0
  516. package/dist/models-CQgBV5dW.js +2536 -0
  517. package/dist/models-cli-DbQ-QpQk.js +418 -0
  518. package/dist/models-config-D2xK-G6c.js +211 -0
  519. package/dist/models-config.providers.discovery-BaIk1NKL.js +141 -0
  520. package/dist/models-config.runtime-Cf7q9uAQ.js +211 -0
  521. package/dist/monitor-B5QmKaD7.js +3272 -0
  522. package/dist/monitor-CL5OYLih.js +878 -0
  523. package/dist/monitor-CNZxrM4d.js +3145 -0
  524. package/dist/monitor-CyQVZdDh.js +223 -0
  525. package/dist/multimodal-DC43jYNv.js +75 -0
  526. package/dist/mutable-allowlist-detectors-C6EAzWYE.js +62 -0
  527. package/dist/net-DlJFp95v.js +270 -0
  528. package/dist/network-mode-DOgvmom4.js +17 -0
  529. package/dist/nextcloud-talk-ChMP88s-.js +12 -0
  530. package/dist/nextcloud-talk-CwnkUy8E.js +1 -0
  531. package/dist/node-cli-BZDC7rXg.js +2484 -0
  532. package/dist/node-command-policy-Bg2g6Xjp.js +192 -0
  533. package/dist/node-commands-B6W6Eo0b.js +11 -0
  534. package/dist/node-require-BgDD9bTi.js +14 -0
  535. package/dist/node-resolve-BunMro3f.js +69 -0
  536. package/dist/node-service-CEZZaqba.js +65 -0
  537. package/dist/node-startup-env-Gz8ZQniA.js +50 -0
  538. package/dist/nodes-cli-B4Jr9vct.js +1330 -0
  539. package/dist/nodes-screen-CQ7IvP62.js +401 -0
  540. package/dist/normalize-secret-input-_PgpexOG.js +32 -0
  541. package/dist/note-dfjacCV8.js +109 -0
  542. package/dist/npm-pack-install-CYNRv-vM.js +574 -0
  543. package/dist/npm-resolution-Ml2aA6Nu.js +60 -0
  544. package/dist/oauth.runtime-DA_48MPQ.js +687 -0
  545. package/dist/oauth.runtime-DS1ry5__.js +318 -0
  546. package/dist/oauth.runtime-qCkidk8J.js +180 -0
  547. package/dist/ollama-defaults-asNuGW4_.js +4 -0
  548. package/dist/onboard-BM6gO6Uw.js +589 -0
  549. package/dist/onboard-D9IU-7uw.js +48 -0
  550. package/dist/onboard-DQaHGPRm.js +25 -0
  551. package/dist/onboard-channels-BdQtLjYb.js +300 -0
  552. package/dist/onboard-channels-DIVUygs5.js +1257 -0
  553. package/dist/onboard-config-DFKb-0sE.js +29 -0
  554. package/dist/onboard-config-DYykzJhx.js +2 -0
  555. package/dist/onboard-custom-CDP4w1AT.js +216 -0
  556. package/dist/onboard-custom-DhJN13UV.js +644 -0
  557. package/dist/onboard-helpers-B7XTd4Pw.js +335 -0
  558. package/dist/onboard-helpers-BUKtx5Bq.js +54 -0
  559. package/dist/onboard-hooks-BHSSLAhI.js +73 -0
  560. package/dist/onboard-remote-BOzEPdHA.js +59 -0
  561. package/dist/onboard-remote-DVza19_k.js +182 -0
  562. package/dist/onboard-search-CrS-n9_3.js +446 -0
  563. package/dist/onboard-skills-BojzIPvk.js +133 -0
  564. package/dist/onboard-skills-D7HyCVjz.js +69 -0
  565. package/dist/openai-codex-provider.runtime-BFsopDHI.js +2 -0
  566. package/dist/openai-defaults-B7FUywsh.js +10 -0
  567. package/dist/openclaw-exec-env-AcZ9we1N.js +14 -0
  568. package/dist/openclaw-root-TUHYdr9B.js +88 -0
  569. package/dist/openclaw-tools.runtime-draZJo5r.js +211 -0
  570. package/dist/outbound-media-69yrWRDt.js +11 -0
  571. package/dist/outbound-runtime-ic_7ulJJ.js +1 -0
  572. package/dist/pairing-challenge-CNrPmmi9.js +48 -0
  573. package/dist/pairing-cli-BohXW2BK.js +150 -0
  574. package/dist/pairing-labels-CNKCSmBK.js +7 -0
  575. package/dist/pairing-message-CBv2njJT.js +4 -0
  576. package/dist/pairing-store-C4lsd4pO.js +590 -0
  577. package/dist/pairing-token-gKj4SNFJ.js +55 -0
  578. package/dist/parse-duration-BBGYkY0S.js +41 -0
  579. package/dist/parse-finite-number-CP4MQF_w.js +30 -0
  580. package/dist/parse-log-line-CVh9zu3Q.js +43 -0
  581. package/dist/parse-port-COyt3COn.js +8 -0
  582. package/dist/path-alias-guards-ZTKqurNH.js +40 -0
  583. package/dist/path-env-CPkz6U0Y.js +87 -0
  584. package/dist/paths-CTjJI9l0.js +179 -0
  585. package/dist/paths-GHJ97ebE.js +268 -0
  586. package/dist/paths-nCHyK08H.js +56 -0
  587. package/dist/perplexity-Beshd9zu.js +422 -0
  588. package/dist/persistent-dedupe-bjKjVI5u.js +116 -0
  589. package/dist/pi-embedded-CSQySvOV.js +168518 -0
  590. package/dist/pi-model-discovery-CuX5CDyZ.js +125 -0
  591. package/dist/pi-model-discovery-runtime-DNsMrX1n.js +44 -0
  592. package/dist/pi-tools.before-tool-call.runtime-DxVqzMVf.js +387 -0
  593. package/dist/platform-launcher-CqGy6UhP.js +83 -0
  594. package/dist/plugin-entry-CwuwM1jC.js +17 -0
  595. package/dist/plugin-install-JJwfOXtg.js +216 -0
  596. package/dist/plugin-install-plan-cixz1_W4.js +49 -0
  597. package/dist/plugin-install-vkpI1UNd.js +184 -0
  598. package/dist/plugin-registry-C3j_DUnj.js +51 -0
  599. package/dist/plugin-registry-DB_yxabS.js +213 -0
  600. package/dist/plugin-sdk/account-helpers.js +3 -0
  601. package/dist/plugin-sdk/account-id.js +2 -0
  602. package/dist/plugin-sdk/account-resolution.js +216 -0
  603. package/dist/plugin-sdk/acp-runtime.js +46 -0
  604. package/dist/plugin-sdk/agent-runtime.js +215 -0
  605. package/dist/plugin-sdk/allow-from.js +17 -0
  606. package/dist/plugin-sdk/allowlist-config-edit.js +2 -0
  607. package/dist/plugin-sdk/bluebubbles.js +232 -0
  608. package/dist/plugin-sdk/boolean-param.js +2 -0
  609. package/dist/plugin-sdk/channel-actions.js +16 -0
  610. package/dist/plugin-sdk/channel-config-helpers.js +15 -0
  611. package/dist/plugin-sdk/channel-config-schema.js +5 -0
  612. package/dist/plugin-sdk/channel-contract.js +1 -0
  613. package/dist/plugin-sdk/channel-feedback.js +4 -0
  614. package/dist/plugin-sdk/channel-inbound.js +53 -0
  615. package/dist/plugin-sdk/channel-lifecycle.js +2 -0
  616. package/dist/plugin-sdk/channel-pairing.js +2 -0
  617. package/dist/plugin-sdk/channel-policy.js +19 -0
  618. package/dist/plugin-sdk/channel-reply-pipeline.js +23 -0
  619. package/dist/plugin-sdk/channel-runtime.js +33 -0
  620. package/dist/plugin-sdk/channel-send-result.js +2 -0
  621. package/dist/plugin-sdk/channel-setup.js +24 -0
  622. package/dist/plugin-sdk/channel-targets.js +3 -0
  623. package/dist/plugin-sdk/cli-runtime.js +5 -0
  624. package/dist/plugin-sdk/command-auth.js +212 -0
  625. package/dist/plugin-sdk/compat.js +59 -0
  626. package/dist/plugin-sdk/config-runtime.js +51 -0
  627. package/dist/plugin-sdk/conversation-runtime.js +55 -0
  628. package/dist/plugin-sdk/core.js +40 -0
  629. package/dist/plugin-sdk/device-bootstrap.js +6 -0
  630. package/dist/plugin-sdk/diagnostics-otel.js +7 -0
  631. package/dist/plugin-sdk/diffs.js +3 -0
  632. package/dist/plugin-sdk/directory-runtime.js +5 -0
  633. package/dist/plugin-sdk/discord-core.js +26 -0
  634. package/dist/plugin-sdk/discord.js +219 -0
  635. package/dist/plugin-sdk/extension-shared.js +15 -0
  636. package/dist/plugin-sdk/feishu.js +101 -0
  637. package/dist/plugin-sdk/gateway-runtime.js +46 -0
  638. package/dist/plugin-sdk/googlechat.js +93 -0
  639. package/dist/plugin-sdk/group-access.js +2 -0
  640. package/dist/plugin-sdk/hook-runtime.js +12 -0
  641. package/dist/plugin-sdk/image-generation.js +51 -0
  642. package/dist/plugin-sdk/imessage-core.js +214 -0
  643. package/dist/plugin-sdk/imessage.js +223 -0
  644. package/dist/plugin-sdk/index.js +55 -0
  645. package/dist/plugin-sdk/infra-runtime.js +223 -0
  646. package/dist/plugin-sdk/interactive-runtime.js +3 -0
  647. package/dist/plugin-sdk/irc.js +232 -0
  648. package/dist/plugin-sdk/json-store.js +9 -0
  649. package/dist/plugin-sdk/keyed-async-queue.js +2 -0
  650. package/dist/plugin-sdk/lazy-runtime.js +2 -0
  651. package/dist/plugin-sdk/line-core.js +29 -0
  652. package/dist/plugin-sdk/line.js +22 -0
  653. package/dist/plugin-sdk/llm-task.js +7 -0
  654. package/dist/plugin-sdk/matrix-runtime-heavy.js +223 -0
  655. package/dist/plugin-sdk/matrix-runtime-shared.js +2 -0
  656. package/dist/plugin-sdk/matrix.js +84 -0
  657. package/dist/plugin-sdk/mattermost.js +233 -0
  658. package/dist/plugin-sdk/media-runtime.js +212 -0
  659. package/dist/plugin-sdk/media-understanding-runtime.js +211 -0
  660. package/dist/plugin-sdk/media-understanding.js +15 -0
  661. package/dist/plugin-sdk/memory-core.js +2 -0
  662. package/dist/plugin-sdk/memory-lancedb.js +2 -0
  663. package/dist/plugin-sdk/msteams.js +244 -0
  664. package/dist/plugin-sdk/nextcloud-talk.js +231 -0
  665. package/dist/plugin-sdk/nostr.js +50 -0
  666. package/dist/plugin-sdk/ollama-setup.js +33 -0
  667. package/dist/plugin-sdk/outbound-runtime.js +23 -0
  668. package/dist/plugin-sdk/plugin-entry.js +3 -0
  669. package/dist/plugin-sdk/plugin-runtime.js +211 -0
  670. package/dist/plugin-sdk/process-runtime.js +12 -0
  671. package/dist/plugin-sdk/provider-auth-api-key.js +53 -0
  672. package/dist/plugin-sdk/provider-auth-login.js +2 -0
  673. package/dist/plugin-sdk/provider-auth.js +37 -0
  674. package/dist/plugin-sdk/provider-catalog.js +2 -0
  675. package/dist/plugin-sdk/provider-env-vars.js +2 -0
  676. package/dist/plugin-sdk/provider-google.js +3 -0
  677. package/dist/plugin-sdk/provider-models.js +27 -0
  678. package/dist/plugin-sdk/provider-onboard.js +20 -0
  679. package/dist/plugin-sdk/provider-setup.js +58 -0
  680. package/dist/plugin-sdk/provider-stream.js +211 -0
  681. package/dist/plugin-sdk/provider-usage.js +18 -0
  682. package/dist/plugin-sdk/provider-web-search.js +23 -0
  683. package/dist/plugin-sdk/provider-zai-endpoint.js +3 -0
  684. package/dist/plugin-sdk/reply-history.js +23 -0
  685. package/dist/plugin-sdk/reply-payload.js +2 -0
  686. package/dist/plugin-sdk/reply-runtime.js +211 -0
  687. package/dist/plugin-sdk/request-url.js +2 -0
  688. package/dist/plugin-sdk/routing.js +25 -0
  689. package/dist/plugin-sdk/runtime-env.js +15 -0
  690. package/dist/plugin-sdk/runtime-store.js +2 -0
  691. package/dist/plugin-sdk/runtime.js +15 -0
  692. package/dist/plugin-sdk/sandbox.js +66 -0
  693. package/dist/plugin-sdk/secret-input.js +3 -0
  694. package/dist/plugin-sdk/security-runtime.js +18 -0
  695. package/dist/plugin-sdk/self-hosted-provider-setup.js +33 -0
  696. package/dist/plugin-sdk/setup-adapter-runtime.js +2 -0
  697. package/dist/plugin-sdk/setup-runtime.js +17 -0
  698. package/dist/plugin-sdk/setup-tools.js +21 -0
  699. package/dist/plugin-sdk/setup.js +26 -0
  700. package/dist/plugin-sdk/signal.js +220 -0
  701. package/dist/plugin-sdk/slack-core.js +22 -0
  702. package/dist/plugin-sdk/slack.js +223 -0
  703. package/dist/plugin-sdk/speech-runtime.js +213 -0
  704. package/dist/plugin-sdk/speech.js +212 -0
  705. package/dist/plugin-sdk/ssrf-runtime.js +5 -0
  706. package/dist/plugin-sdk/state-paths.js +3 -0
  707. package/dist/plugin-sdk/status-helpers.js +9 -0
  708. package/dist/plugin-sdk/telegram-core.js +23 -0
  709. package/dist/plugin-sdk/telegram.js +224 -0
  710. package/dist/plugin-sdk/testing.js +13174 -0
  711. package/dist/plugin-sdk/text-runtime.js +45 -0
  712. package/dist/plugin-sdk/thread-bindings-runtime.js +2 -0
  713. package/dist/plugin-sdk/thread-ownership.js +2 -0
  714. package/dist/plugin-sdk/tlon.js +57 -0
  715. package/dist/plugin-sdk/tool-send.js +2 -0
  716. package/dist/plugin-sdk/twitch.js +46 -0
  717. package/dist/plugin-sdk/voice-call.js +213 -0
  718. package/dist/plugin-sdk/web-media.js +28 -0
  719. package/dist/plugin-sdk/webhook-ingress.js +7 -0
  720. package/dist/plugin-sdk/webhook-path.js +2 -0
  721. package/dist/plugin-sdk/whatsapp-core.js +219 -0
  722. package/dist/plugin-sdk/whatsapp-shared.js +18 -0
  723. package/dist/plugin-sdk/windows-spawn.js +2 -0
  724. package/dist/plugin-sdk/zalo.js +239 -0
  725. package/dist/plugin-sdk/zalouser.js +240 -0
  726. package/dist/plugins/build-smoke-entry.js +211 -0
  727. package/dist/plugins/runtime/index.js +229 -0
  728. package/dist/plugins-1Z50ecJ6.js +1 -0
  729. package/dist/plugins-C6fKmNuA.js +7 -0
  730. package/dist/plugins-cli-BkgQkGaU.js +1192 -0
  731. package/dist/policy-CpkbSAfm.js +60 -0
  732. package/dist/polls-B2VH7SN9.js +35 -0
  733. package/dist/ports-BjWuIIQw.js +262 -0
  734. package/dist/ports-DFiK_Jc-.js +385 -0
  735. package/dist/ports-lsof-DtJqhFOr.js +25 -0
  736. package/dist/ports-probe-BQqp8l8E.js +14 -0
  737. package/dist/preflight-audio.runtime-Fi9mofpp.js +216 -0
  738. package/dist/probe-BM9sbCgS.js +20 -0
  739. package/dist/probe-DLBOZftS.js +134 -0
  740. package/dist/probe-auth-Bjp3G4CI.js +48 -0
  741. package/dist/probe-auth-DMSPTRRk.js +45 -0
  742. package/dist/process-runtime-C7el-Ri4.js +1 -0
  743. package/dist/process-scoped-map-C4gOa-gv.js +61 -0
  744. package/dist/profile-utils-BcMYGFPT.js +15 -0
  745. package/dist/profiles-D17eMKQZ.js +683 -0
  746. package/dist/program-Ch-76sgl.js +155 -0
  747. package/dist/program-context-BMWNUfqL.js +10 -0
  748. package/dist/program-context-CD_RvRYh.js +2 -0
  749. package/dist/progress-D1r9bZU1.js +132 -0
  750. package/dist/prompt-select-styled-NUKYS9QR.js +4879 -0
  751. package/dist/prompt-style-BvciNCqy.js +7 -0
  752. package/dist/prompts-NtuylUyl.js +9 -0
  753. package/dist/prototype-keys-Cm_8mWvq.js +11 -0
  754. package/dist/provider-api-key-auth-BE0taXiB.js +108 -0
  755. package/dist/provider-api-key-auth.runtime-jDZZUAMX.js +34 -0
  756. package/dist/provider-auth-Bw8x1a3o.js +58 -0
  757. package/dist/provider-auth-api-key-BrQYvdxi.js +1 -0
  758. package/dist/provider-auth-choice-BYbPq0eC.js +128 -0
  759. package/dist/provider-auth-choice-helpers-Bj1GkOSn.js +48 -0
  760. package/dist/provider-auth-choice-preference-tKq5gaJL.js +192 -0
  761. package/dist/provider-auth-choice.runtime-DegPpvRJ.js +223 -0
  762. package/dist/provider-auth-choices-QSilukI1.js +58 -0
  763. package/dist/provider-auth-guidance-gninjjq8.js +34 -0
  764. package/dist/provider-auth-helpers-B0dS-1WK.js +86 -0
  765. package/dist/provider-auth-input-BftBdgvW.js +112 -0
  766. package/dist/provider-auth-login-D0n0lMuc.js +8 -0
  767. package/dist/provider-auth-login.runtime-LvuBkQrc.js +243 -0
  768. package/dist/provider-auth-mode-sTdccIKL.js +20 -0
  769. package/dist/provider-auth-ref-BS3gwrNr.js +168 -0
  770. package/dist/provider-auth-ref-BmEcEN7K.js +3 -0
  771. package/dist/provider-catalog--18-pW5t.js +11 -0
  772. package/dist/provider-catalog-2P2hel74.js +48 -0
  773. package/dist/provider-catalog-B0FqWSwe.js +48 -0
  774. package/dist/provider-catalog-BvORKzzD.js +91 -0
  775. package/dist/provider-catalog-C34j1_or.js +26 -0
  776. package/dist/provider-catalog-C5vmXjmb.js +11 -0
  777. package/dist/provider-catalog-CBufm2Dr.js +36 -0
  778. package/dist/provider-catalog-D7QvsUXS.js +12 -0
  779. package/dist/provider-catalog-DKy_dzQZ.js +41 -0
  780. package/dist/provider-env-vars-CsQlY7bF.js +110 -0
  781. package/dist/provider-id-BpXo5t6v.js +31 -0
  782. package/dist/provider-model-allowlist-4HSOnlX-.js +24 -0
  783. package/dist/provider-model-primary-NJ-xlhec.js +53 -0
  784. package/dist/provider-models-C2EjYMwW.js +2416 -0
  785. package/dist/provider-oauth-flow-BQN6F6EC.js +33 -0
  786. package/dist/provider-ollama-setup-DhQvDwAj.js +309 -0
  787. package/dist/provider-onboard-CjOfyeQG.js +1 -0
  788. package/dist/provider-onboarding-config-DOZ3pFA6.js +165 -0
  789. package/dist/provider-openai-codex-oauth-tls-Bo8U4D3E.js +101 -0
  790. package/dist/provider-runtime.runtime-DnP2jpoM.js +211 -0
  791. package/dist/provider-self-hosted-setup-CUrmsugW.js +182 -0
  792. package/dist/provider-usage-ClDVmkhl.js +633 -0
  793. package/dist/provider-usage-DIC6cn-3.js +211 -0
  794. package/dist/provider-web-search-NzK8ep1E.js +507 -0
  795. package/dist/provider-wizard-C6jCuyQe.js +236 -0
  796. package/dist/provider-zai-endpoint-DeDABzT4.js +106 -0
  797. package/dist/proxy-H5O2p6AP.js +121 -0
  798. package/dist/proxy-env-DG2u55RW.js +40 -0
  799. package/dist/push-apns-D4zD2tmP.js +1050 -0
  800. package/dist/pw-ai-BuPUVeUK.js +1876 -0
  801. package/dist/qmd-manager-BpygGMW9.js +1571 -0
  802. package/dist/qr-cli-DnWHXcxh.js +370 -0
  803. package/dist/qr-cli-yaZ0FZ6z.js +213 -0
  804. package/dist/query-expansion-Do45hILP.js +1114 -0
  805. package/dist/reactions-BcC_XZqD.js +281 -0
  806. package/dist/read-only-account-inspect-DPJzadPo.js +42 -0
  807. package/dist/read-only-account-inspect.discord.runtime-CW9DDKH8.js +216 -0
  808. package/dist/read-only-account-inspect.slack.runtime-BcXBPyh3.js +216 -0
  809. package/dist/read-only-account-inspect.telegram.runtime-Y7h0Jbdj.js +216 -0
  810. package/dist/redact-BDinS1q9.js +102 -0
  811. package/dist/redact-identifier-FUiWQxv5.js +13 -0
  812. package/dist/redact-snapshot-DBPmeYy2.js +2654 -0
  813. package/dist/ref-contract-CCBBbf1r.js +53 -0
  814. package/dist/register-CppP7Ddc.js +43 -0
  815. package/dist/register.agent-BOD5ROGQ.js +546 -0
  816. package/dist/register.backup-Y2VGqcRu.js +269 -0
  817. package/dist/register.configure-1qiTINph.js +354 -0
  818. package/dist/register.maintenance-shn-zigv.js +694 -0
  819. package/dist/register.message-mR4CLSoo.js +812 -0
  820. package/dist/register.onboard-CkDryVid.js +298 -0
  821. package/dist/register.setup-B0xW5olD.js +318 -0
  822. package/dist/register.status-health-sessions-CuhWc03j.js +604 -0
  823. package/dist/register.subclis-BazXM5TW.js +315 -0
  824. package/dist/register.subclis-C2d8UDhH.js +13 -0
  825. package/dist/registry-C3q59Qj0.js +55 -0
  826. package/dist/registry-CPsHw6xU.js +219 -0
  827. package/dist/registry-CxgtJ09C.js +28 -0
  828. package/dist/registry-rgYi7KoO.js +160 -0
  829. package/dist/repair-qXnOAvDy.js +105 -0
  830. package/dist/replies-EiwmmZ_W.js +122 -0
  831. package/dist/reply-history-CVCD5oE9.js +1 -0
  832. package/dist/reply-payload-DBGc074f.js +232 -0
  833. package/dist/report-cli-DB1jQx32.js +42 -0
  834. package/dist/request-url-BKfWAQx8.js +10 -0
  835. package/dist/resolve-Ckjd8TAk.js +14 -0
  836. package/dist/resolve-T2q_0ARF.js +619 -0
  837. package/dist/resolve-route-vEY3ONZ2.js +466 -0
  838. package/dist/resolve-utils-CbqJY2bs.js +102 -0
  839. package/dist/response-generator-VdoCcQ3y.js +153 -0
  840. package/dist/restart-stale-pids-CLGiqU2E.js +187 -0
  841. package/dist/retry-D15TD1S3.js +168 -0
  842. package/dist/root-help-B9Aou4ho.js +32 -0
  843. package/dist/routes-TpLEcKO8.js +7084 -0
  844. package/dist/routing-Y3m0o-kB.js +26 -0
  845. package/dist/rpc-C6MN-nVc.js +67 -0
  846. package/dist/run-command-DRKv5Lj6.js +32 -0
  847. package/dist/run-main-YZSMdx0B.js +424 -0
  848. package/dist/run-with-concurrency-BrSjWzpg.js +41 -0
  849. package/dist/runtime-B66W9flm.js +43 -0
  850. package/dist/runtime-C9VaVKYZ.js +2338 -0
  851. package/dist/runtime-CT2LIJZu.js +91 -0
  852. package/dist/runtime-CqDQ81eY.js +143 -0
  853. package/dist/runtime-CuvWMN7E.js +89 -0
  854. package/dist/runtime-D4_OpzA1.js +5 -0
  855. package/dist/runtime-DP-4DZja.js +5 -0
  856. package/dist/runtime-Dl17x_cV.js +1 -0
  857. package/dist/runtime-Z35JoYPC.js +30 -0
  858. package/dist/runtime-api-D79M0lQN.js +1 -0
  859. package/dist/runtime-api-y3zfnQGK.js +39 -0
  860. package/dist/runtime-discord-ops.runtime-Bg5h5v9-.js +234 -0
  861. package/dist/runtime-env-a_iwdJIv.js +1 -0
  862. package/dist/runtime-forwarders-DtMc8rBP.js +44 -0
  863. package/dist/runtime-group-policy-B7irU4eu.js +59 -0
  864. package/dist/runtime-guard-y62lPDGY.js +58 -0
  865. package/dist/runtime-parse-CeqXmZHJ.js +84 -0
  866. package/dist/runtime-paths-CstaCCMi.js +334 -0
  867. package/dist/runtime-slack-ops.runtime-BumgKDhS.js +226 -0
  868. package/dist/runtime-status-CgL02wYX.js +15 -0
  869. package/dist/runtime-store-Bt3Sdbrn.js +22 -0
  870. package/dist/runtime-telegram-ops.runtime-rSLQ3KrE.js +233 -0
  871. package/dist/runtime-whatsapp-boundary-xZem0NyQ.js +364 -0
  872. package/dist/safe-open-sync-Bt9R1Mnf.js +83 -0
  873. package/dist/safe-regex-tLlDZYfM.js +244 -0
  874. package/dist/safe-text-B_CQuica.js +16 -0
  875. package/dist/sandbox-CUUouiKs.js +2795 -0
  876. package/dist/sandbox-cli-BN8y0Get.js +499 -0
  877. package/dist/sandbox-paths-fqp_TZdO.js +144 -0
  878. package/dist/sandbox-qSs4h3sk.js +1 -0
  879. package/dist/sanitize-env-vars-vNSNqm0y.js +74 -0
  880. package/dist/scan-paths-BJmvUZ1E.js +28 -0
  881. package/dist/search-manager-DWhFgwyp.js +17 -0
  882. package/dist/search-manager-r8Cw4ZRv.js +392 -0
  883. package/dist/secret-equal-ObQfyZGa.js +9 -0
  884. package/dist/secret-file-Ch0yuOXR.js +11 -0
  885. package/dist/secret-file-DYJtH6kf.js +92 -0
  886. package/dist/secret-input-4REZ4sHo.js +35 -0
  887. package/dist/secrets-cli-D1df8b0o.js +2304 -0
  888. package/dist/secure-random-Cs8tw_HQ.js +10 -0
  889. package/dist/security-cli-V66ESmdT.js +676 -0
  890. package/dist/security-runtime-BuEhpJVE.js +23 -0
  891. package/dist/send-3tabvle6.js +100 -0
  892. package/dist/send-CC5J3tyW.js +1026 -0
  893. package/dist/send-deps-CrFMNvqO.js +19 -0
  894. package/dist/send-i2-mdtiE.js +250 -0
  895. package/dist/server-BTOjmlyi.js +116 -0
  896. package/dist/server-middleware-CCqKhKUb.js +106 -0
  897. package/dist/server-node-events-D6y22Tt8.js +611 -0
  898. package/dist/server-startup-matrix-migration-DHWSoS73.js +1595 -0
  899. package/dist/service-Bxc9uL2e.js +774 -0
  900. package/dist/service-CBLajPZL.js +21 -0
  901. package/dist/session-cost-usage-BmbaBvk4.js +212 -0
  902. package/dist/session-cost-usage-C30Jl2SI.js +615 -0
  903. package/dist/session-fork.runtime-BZfcC1Nc.js +51 -0
  904. package/dist/session-key-gFFk3uv9.js +216 -0
  905. package/dist/session-write-lock-DNKvpjKf.js +324 -0
  906. package/dist/sessions-BIH_j_XS.js +222 -0
  907. package/dist/sessions-D5dWcxC_.js +212 -0
  908. package/dist/sessions-DaSBVNwD.js +669 -0
  909. package/dist/setup-C2XF1YH3.js +397 -0
  910. package/dist/setup-CN-teRpz.js +8 -0
  911. package/dist/setup-adapter-runtime-Bjv2adwG.js +1 -0
  912. package/dist/setup-binary-BOJA7zdN.js +30 -0
  913. package/dist/setup-browser-BhNPCUtK.js +71 -0
  914. package/dist/setup-core-BsG09DZH.js +149 -0
  915. package/dist/setup-core-D-O1GQax.js +162 -0
  916. package/dist/setup-core-Dtm54Rcq.js +510 -0
  917. package/dist/setup-entry-B1mTa7bU.js +10 -0
  918. package/dist/setup-entry-CTMgw-K5.js +13 -0
  919. package/dist/setup-entry-Cmd_cufO.js +13 -0
  920. package/dist/setup-entry-CybgA3zP.js +12 -0
  921. package/dist/setup-entry-DED_hL6i.js +12 -0
  922. package/dist/setup-entry-WCq9VMWx.js +14 -0
  923. package/dist/setup-group-access-BtPApRvE.js +70 -0
  924. package/dist/setup-helpers-B62Ecg9r.js +362 -0
  925. package/dist/setup-surface-B7A7qowY.js +452 -0
  926. package/dist/setup-surface-BBYJVRXc.js +380 -0
  927. package/dist/setup-surface-CFUz_BJi.js +298 -0
  928. package/dist/setup-tools-BPiMjAN7.js +1 -0
  929. package/dist/setup-wizard-helpers-COZ1UAdX.js +770 -0
  930. package/dist/setup-wizard-proxy-Slwi-1gX.js +116 -0
  931. package/dist/setup.finalize-B8O01nge.js +633 -0
  932. package/dist/setup.gateway-config-BPDIFk__.js +288 -0
  933. package/dist/setup.secret-input-BL-bqJpt.js +25 -0
  934. package/dist/shared-AygSbeCK.js +50 -0
  935. package/dist/shared-BHqDLkMG.js +127 -0
  936. package/dist/shared-BPtG8PgB.js +70 -0
  937. package/dist/shared-BU0QgVMZ.js +36 -0
  938. package/dist/shared-Bzr2UyEm.js +351 -0
  939. package/dist/shared-C_XXbGIF.js +87 -0
  940. package/dist/shared-Diw3KzwZ.js +82 -0
  941. package/dist/shared-DngjQumT.js +196 -0
  942. package/dist/shared-DzH3zmAy.js +64 -0
  943. package/dist/shared-LeP8iUTz.js +54 -0
  944. package/dist/shell-argv-DWV43Vya.js +72 -0
  945. package/dist/shell-env-cD92jEyV.js +181 -0
  946. package/dist/signal-BQd9f9dF.js +315 -0
  947. package/dist/signal-Ca7y47bM.js +46 -0
  948. package/dist/signal-Did9U_fa.js +214 -0
  949. package/dist/signal-cli-install-DxoL8CgF.js +188 -0
  950. package/dist/skill-commands-CiSwTFBQ.js +652 -0
  951. package/dist/skill-commands.runtime-CEwlWT4j.js +34 -0
  952. package/dist/skill-scanner-DG7MT7pu.js +354 -0
  953. package/dist/skills-BC8GJ9Rp.js +22 -0
  954. package/dist/skills-CCgKs_NJ.js +863 -0
  955. package/dist/skills-cli-dhYXJCuL.js +339 -0
  956. package/dist/skills-install-DiriUXJd.js +763 -0
  957. package/dist/skills-status-BmQTn4jL.js +23 -0
  958. package/dist/skills-status-a9b899Y3.js +169 -0
  959. package/dist/slack-CXgv7nu7.js +730 -0
  960. package/dist/slack-CcSByPzI.js +217 -0
  961. package/dist/slack-CtcCh0Lj.js +24537 -0
  962. package/dist/slack-core-DcsbATUs.js +1 -0
  963. package/dist/slash-commands.runtime-kO8EUKYW.js +228 -0
  964. package/dist/slash-dispatch.runtime-Bu2yMeFy.js +238 -0
  965. package/dist/slash-skill-commands.runtime-wwX3tF84.js +216 -0
  966. package/dist/speech-bSreRuDH.js +1 -0
  967. package/dist/speech-runtime-y1FcnGVA.js +1 -0
  968. package/dist/src-CmXHIz5f.js +846 -0
  969. package/dist/ssh-config-ChqR6ijV.js +77 -0
  970. package/dist/ssh-tunnel-Cz51VBAt.js +159 -0
  971. package/dist/ssh-tunnel-DWze2IQS.js +16 -0
  972. package/dist/ssrf-Dk9XaoKN.js +220 -0
  973. package/dist/ssrf-policy-Dk6oMa20.js +69 -0
  974. package/dist/ssrf-runtime-C-mAQLVA.js +1 -0
  975. package/dist/stagger-DU7FjHYo.js +54 -0
  976. package/dist/state-paths-DJIGEFq_.js +1 -0
  977. package/dist/status-69r8-Zey.js +75 -0
  978. package/dist/status-BdLTvZOL.js +44 -0
  979. package/dist/status-Bt7DQmRI.js +1665 -0
  980. package/dist/status-CoUFSBgt.js +202 -0
  981. package/dist/status-DbI3Kbh5.js +235 -0
  982. package/dist/status-DeKlzu_o.js +212 -0
  983. package/dist/status-Haie42Fc.js +606 -0
  984. package/dist/status-helpers-Cda-rGLX.js +101 -0
  985. package/dist/status-json-DS1M_MWJ.js +322 -0
  986. package/dist/status.link-channel-Cb8bZ_Od.js +40 -0
  987. package/dist/status.scan.deps.runtime-7_6VUs50.js +77 -0
  988. package/dist/status.scan.runtime-DtR8BIE9.js +14 -0
  989. package/dist/status.summary-l_Bi1buR.js +600 -0
  990. package/dist/status.summary.runtime-Cng6MzRU.js +151 -0
  991. package/dist/status.update-DtbnnPKx.js +79 -0
  992. package/dist/store-CvL8MPei.js +1446 -0
  993. package/dist/store.runtime-hgnvmZgO.js +43 -0
  994. package/dist/string-normalization-CvzuCAZv.js +19 -0
  995. package/dist/string-sample-BOLqzr4Y.js +11 -0
  996. package/dist/subagent-orphan-recovery-si1z2iBu.js +407 -0
  997. package/dist/subagent-registry-runtime-CXUDI8gL.js +211 -0
  998. package/dist/subcli-descriptors-CY_nHzpZ.js +151 -0
  999. package/dist/subsystem-CUp-6QQf.js +421 -0
  1000. package/dist/synology-chat-CdejNfs0.js +12 -0
  1001. package/dist/system-cli-DkOaXHkQ.js +99 -0
  1002. package/dist/system-events-mAu6Ap6K.js +75 -0
  1003. package/dist/system-message-DA9eUYzB.js +16 -0
  1004. package/dist/system-run-command-Cxq2F1MB.js +258 -0
  1005. package/dist/systemd-CrxZBFae.js +557 -0
  1006. package/dist/systemd-hints-y-zJ9aTm.js +315 -0
  1007. package/dist/systemd-linger-BdklDcLg.js +16 -0
  1008. package/dist/systemd-linger-DLrbG9_d.js +68 -0
  1009. package/dist/table-DFMOhmNZ.js +305 -0
  1010. package/dist/tailnet-ofqBrXzu.js +38 -0
  1011. package/dist/tailscale-Cbsx-2HB.js +254 -0
  1012. package/dist/target-errors-ksphhzJg.js +26 -0
  1013. package/dist/target-registry-krAVlXi_.js +1321 -0
  1014. package/dist/telegram/audit.js +2 -0
  1015. package/dist/telegram/token.js +211 -0
  1016. package/dist/telegram-BjDUP22F.js +10910 -0
  1017. package/dist/telegram-DMiNSGAJ.js +575 -0
  1018. package/dist/telegram-Dt11B3JL.js +218 -0
  1019. package/dist/telegram-core-B4Jo-uko.js +1 -0
  1020. package/dist/template-messages-kh7VfgOb.js +214 -0
  1021. package/dist/text-chunking-CUf5WgqG.js +19 -0
  1022. package/dist/text-format-sFXlJfHH.js +8 -0
  1023. package/dist/text-runtime-C_Roi_Je.js +1418 -0
  1024. package/dist/theme-B5HDbQfl.js +2 -0
  1025. package/dist/theme-CdOoMzRk.js +34 -0
  1026. package/dist/thinking-BBD_0HSp.js +68 -0
  1027. package/dist/thinking.shared-CncvRHts.js +246 -0
  1028. package/dist/thread-bindings-messages-Cdo8jSa9.js +229 -0
  1029. package/dist/thread-bindings-policy-DMjOaNyR.js +119 -0
  1030. package/dist/thread-bindings-runtime-Ckwk3Uuz.js +1 -0
  1031. package/dist/threading-helpers-Cq55SUtb.js +14 -0
  1032. package/dist/timeouts-BwR1sGom.js +72 -0
  1033. package/dist/tmp-openclaw-dir-idKIOMmb.js +102 -0
  1034. package/dist/token-Bgv8XEsC.js +50 -0
  1035. package/dist/tool-catalog-BV6FcEWS.js +337 -0
  1036. package/dist/tool-policy-match-CHqTCSdK.js +46 -0
  1037. package/dist/tool-send-9LXKcrda.js +16 -0
  1038. package/dist/topology-cli-BhUXVViF.js +43 -0
  1039. package/dist/transcript-events-B1V6z5ct.js +29 -0
  1040. package/dist/tui-DDJMGCFK.js +3838 -0
  1041. package/dist/tui-cli-ByN-ZH6y.js +237 -0
  1042. package/dist/typebox-D0SHDJST.js +175 -0
  1043. package/dist/types-BCKGVVld.js +83 -0
  1044. package/dist/types-CtpUGsDP.js +30 -0
  1045. package/dist/types.secrets-BWSeXrF4.js +80 -0
  1046. package/dist/types.tools-BBO8HCi6.js +22 -0
  1047. package/dist/typing-DG_YqWJ7.js +224 -0
  1048. package/dist/unhandled-rejections-CDJ8dOVP.js +170 -0
  1049. package/dist/unhandled-rejections-O6cVOz2D.js +4 -0
  1050. package/dist/update-Br8U-txJ.js +1039 -0
  1051. package/dist/update-check-C3TeQaWg.js +464 -0
  1052. package/dist/update-cli-XHfIntD0.js +1625 -0
  1053. package/dist/update-offset-store-36vzzZXw.js +211 -0
  1054. package/dist/upsert-with-lock-Bb96JHpb.js +34 -0
  1055. package/dist/url-userinfo-Db63ng4y.js +14 -0
  1056. package/dist/utils-Bxk6BLTg.js +236 -0
  1057. package/dist/utils-vDeUf98G.js +7 -0
  1058. package/dist/version-DCY9_obP.js +64 -0
  1059. package/dist/version-DRF-wKTV.js +2 -0
  1060. package/dist/voice-call-D4fgwZNO.js +1 -0
  1061. package/dist/warning-filter-CgvLQB4Y.js +56 -0
  1062. package/dist/web-media-BfBb8i48.js +1 -0
  1063. package/dist/web-media-CtU6jM5V.js +498 -0
  1064. package/dist/webhook-ingress-CupqYpKM.js +338 -0
  1065. package/dist/webhook-memory-guards-BHrFZ4yq.js +129 -0
  1066. package/dist/webhook-path-BGFZ55ML.js +22 -0
  1067. package/dist/webhook-shared-Cvk3b0ac.js +349 -0
  1068. package/dist/webhooks-cli-vOAoBF9b.js +357 -0
  1069. package/dist/whatsapp-D5nD0rGG.js +58 -0
  1070. package/dist/whatsapp-DXbWlm3A.js +82 -0
  1071. package/dist/whatsapp-core-C2WGMsaY.js +89451 -0
  1072. package/dist/whatsapp-heartbeat-CSWnPQ7q.js +84 -0
  1073. package/dist/whatsapp-shared-BmHKqTtR.js +95 -0
  1074. package/dist/widearea-dns-CXimgJzu.js +125 -0
  1075. package/dist/windows-argv-IXrdWrJj.js +145 -0
  1076. package/dist/windows-spawn-vMJGZo89.js +154 -0
  1077. package/dist/with-timeout-2AKTISee.js +58 -0
  1078. package/dist/workspace-BH7CXmrr.js +479 -0
  1079. package/dist/workspace-dirs-_O4V3xCR.js +13 -0
  1080. package/dist/workspace-v5XppK5M.js +302 -0
  1081. package/dist/ws-By-QcLjg.js +11 -0
  1082. package/dist/wsl-BV3Cb66X.js +57 -0
  1083. package/dist/zalo-CHQzsLhE.js +301 -0
  1084. package/dist/zalo-CcJ3J9f2.js +13 -0
  1085. package/dist/zod-schema.agent-runtime-T_EC_6fg.js +600 -0
  1086. package/dist/zod-schema.core-BdgRr-F1.js +545 -0
  1087. package/dist/zod-schema.providers-core-Dgq7MTqU.js +1613 -0
  1088. package/docs/.i18n/README.md +31 -0
  1089. package/docs/.i18n/glossary.ja-JP.json +14 -0
  1090. package/docs/.i18n/glossary.zh-CN.json +242 -0
  1091. package/docs/.i18n/ja-JP.tm.jsonl +0 -0
  1092. package/docs/assets/install-script.svg +1 -0
  1093. package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
  1094. package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
  1095. package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
  1096. package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
  1097. package/docs/assets/macos-onboarding/05-permissions.png +0 -0
  1098. package/docs/assets/openclaw-logo-text-dark.png +0 -0
  1099. package/docs/assets/openclaw-logo-text-dark.svg +418 -0
  1100. package/docs/assets/openclaw-logo-text.png +0 -0
  1101. package/docs/assets/openclaw-logo-text.svg +418 -0
  1102. package/docs/assets/pixel-lobster.svg +60 -0
  1103. package/docs/assets/showcase/agents-ui.jpg +0 -0
  1104. package/docs/assets/showcase/bambu-cli.png +0 -0
  1105. package/docs/assets/showcase/codexmonitor.png +0 -0
  1106. package/docs/assets/showcase/gohome-grafana.png +0 -0
  1107. package/docs/assets/showcase/ios-testflight.jpg +0 -0
  1108. package/docs/assets/showcase/oura-health.png +0 -0
  1109. package/docs/assets/showcase/padel-cli.svg +11 -0
  1110. package/docs/assets/showcase/padel-screenshot.jpg +0 -0
  1111. package/docs/assets/showcase/papla-tts.jpg +0 -0
  1112. package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
  1113. package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
  1114. package/docs/assets/showcase/roborock-status.svg +13 -0
  1115. package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
  1116. package/docs/assets/showcase/snag.png +0 -0
  1117. package/docs/assets/showcase/tesco-shop.jpg +0 -0
  1118. package/docs/assets/showcase/wienerlinien.png +0 -0
  1119. package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
  1120. package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
  1121. package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
  1122. package/docs/assets/sponsors/blacksmith.svg +14 -0
  1123. package/docs/assets/sponsors/convex.svg +16 -0
  1124. package/docs/assets/sponsors/openai.svg +3 -0
  1125. package/docs/assets/sponsors/vercel.svg +5 -0
  1126. package/docs/auth-credential-semantics.md +53 -0
  1127. package/docs/automation/auth-monitoring.md +44 -0
  1128. package/docs/automation/cron-jobs.md +727 -0
  1129. package/docs/automation/cron-vs-heartbeat.md +286 -0
  1130. package/docs/automation/gmail-pubsub.md +256 -0
  1131. package/docs/automation/hooks.md +1049 -0
  1132. package/docs/automation/poll.md +86 -0
  1133. package/docs/automation/standing-orders.md +251 -0
  1134. package/docs/automation/troubleshooting.md +122 -0
  1135. package/docs/automation/webhook.md +217 -0
  1136. package/docs/brave-search.md +93 -0
  1137. package/docs/channels/bluebubbles.md +347 -0
  1138. package/docs/channels/broadcast-groups.md +442 -0
  1139. package/docs/channels/channel-routing.md +139 -0
  1140. package/docs/channels/discord.md +1229 -0
  1141. package/docs/channels/feishu.md +747 -0
  1142. package/docs/channels/googlechat.md +261 -0
  1143. package/docs/channels/group-messages.md +84 -0
  1144. package/docs/channels/groups.md +379 -0
  1145. package/docs/channels/imessage.md +367 -0
  1146. package/docs/channels/index.md +47 -0
  1147. package/docs/channels/irc.md +242 -0
  1148. package/docs/channels/line.md +194 -0
  1149. package/docs/channels/location.md +56 -0
  1150. package/docs/channels/matrix.md +677 -0
  1151. package/docs/channels/mattermost.md +427 -0
  1152. package/docs/channels/msteams.md +780 -0
  1153. package/docs/channels/nextcloud-talk.md +138 -0
  1154. package/docs/channels/nostr.md +242 -0
  1155. package/docs/channels/pairing.md +114 -0
  1156. package/docs/channels/signal.md +329 -0
  1157. package/docs/channels/slack.md +603 -0
  1158. package/docs/channels/synology-chat.md +132 -0
  1159. package/docs/channels/telegram.md +987 -0
  1160. package/docs/channels/tlon.md +276 -0
  1161. package/docs/channels/troubleshooting.md +118 -0
  1162. package/docs/channels/twitch.md +379 -0
  1163. package/docs/channels/whatsapp.md +460 -0
  1164. package/docs/channels/zalo.md +243 -0
  1165. package/docs/channels/zalouser.md +181 -0
  1166. package/docs/ci.md +55 -0
  1167. package/docs/cli/acp.md +288 -0
  1168. package/docs/cli/agent.md +29 -0
  1169. package/docs/cli/agents.md +123 -0
  1170. package/docs/cli/approvals.md +50 -0
  1171. package/docs/cli/backup.md +76 -0
  1172. package/docs/cli/browser.md +106 -0
  1173. package/docs/cli/channels.md +102 -0
  1174. package/docs/cli/clawbot.md +21 -0
  1175. package/docs/cli/completion.md +35 -0
  1176. package/docs/cli/config.md +295 -0
  1177. package/docs/cli/configure.md +36 -0
  1178. package/docs/cli/cron.md +77 -0
  1179. package/docs/cli/daemon.md +53 -0
  1180. package/docs/cli/dashboard.md +22 -0
  1181. package/docs/cli/devices.md +139 -0
  1182. package/docs/cli/directory.md +63 -0
  1183. package/docs/cli/dns.md +23 -0
  1184. package/docs/cli/docs.md +15 -0
  1185. package/docs/cli/doctor.md +48 -0
  1186. package/docs/cli/gateway.md +235 -0
  1187. package/docs/cli/health.md +21 -0
  1188. package/docs/cli/hooks.md +318 -0
  1189. package/docs/cli/index.md +1147 -0
  1190. package/docs/cli/logs.md +28 -0
  1191. package/docs/cli/memory.md +66 -0
  1192. package/docs/cli/message.md +278 -0
  1193. package/docs/cli/models.md +81 -0
  1194. package/docs/cli/node.md +127 -0
  1195. package/docs/cli/nodes.md +75 -0
  1196. package/docs/cli/onboard.md +157 -0
  1197. package/docs/cli/pairing.md +32 -0
  1198. package/docs/cli/plugins.md +186 -0
  1199. package/docs/cli/qr.md +46 -0
  1200. package/docs/cli/reset.md +20 -0
  1201. package/docs/cli/sandbox.md +197 -0
  1202. package/docs/cli/secrets.md +188 -0
  1203. package/docs/cli/security.md +79 -0
  1204. package/docs/cli/sessions.md +110 -0
  1205. package/docs/cli/setup.md +29 -0
  1206. package/docs/cli/skills.md +26 -0
  1207. package/docs/cli/status.md +30 -0
  1208. package/docs/cli/system.md +60 -0
  1209. package/docs/cli/tui.md +30 -0
  1210. package/docs/cli/uninstall.md +20 -0
  1211. package/docs/cli/update.md +103 -0
  1212. package/docs/cli/voicecall.md +34 -0
  1213. package/docs/cli/webhooks.md +25 -0
  1214. package/docs/concepts/agent-loop.md +148 -0
  1215. package/docs/concepts/agent-workspace.md +236 -0
  1216. package/docs/concepts/agent.md +122 -0
  1217. package/docs/concepts/architecture.md +137 -0
  1218. package/docs/concepts/compaction.md +123 -0
  1219. package/docs/concepts/context-engine.md +268 -0
  1220. package/docs/concepts/context.md +172 -0
  1221. package/docs/concepts/delegate-architecture.md +296 -0
  1222. package/docs/concepts/features.md +73 -0
  1223. package/docs/concepts/markdown-formatting.md +130 -0
  1224. package/docs/concepts/memory.md +108 -0
  1225. package/docs/concepts/messages.md +154 -0
  1226. package/docs/concepts/model-failover.md +152 -0
  1227. package/docs/concepts/model-providers.md +607 -0
  1228. package/docs/concepts/models.md +225 -0
  1229. package/docs/concepts/multi-agent.md +552 -0
  1230. package/docs/concepts/oauth.md +158 -0
  1231. package/docs/concepts/presence.md +102 -0
  1232. package/docs/concepts/queue.md +89 -0
  1233. package/docs/concepts/retry.md +69 -0
  1234. package/docs/concepts/session-pruning.md +121 -0
  1235. package/docs/concepts/session-tool.md +242 -0
  1236. package/docs/concepts/session.md +310 -0
  1237. package/docs/concepts/streaming.md +155 -0
  1238. package/docs/concepts/system-prompt.md +132 -0
  1239. package/docs/concepts/timezone.md +91 -0
  1240. package/docs/concepts/typebox.md +291 -0
  1241. package/docs/concepts/typing-indicators.md +68 -0
  1242. package/docs/concepts/usage-tracking.md +35 -0
  1243. package/docs/date-time.md +128 -0
  1244. package/docs/debug/node-issue.md +85 -0
  1245. package/docs/diagnostics/flags.md +91 -0
  1246. package/docs/docs.json +2061 -0
  1247. package/docs/gateway/authentication.md +179 -0
  1248. package/docs/gateway/background-process.md +97 -0
  1249. package/docs/gateway/bonjour.md +177 -0
  1250. package/docs/gateway/bridge-protocol.md +91 -0
  1251. package/docs/gateway/cli-backends.md +225 -0
  1252. package/docs/gateway/configuration-examples.md +651 -0
  1253. package/docs/gateway/configuration-reference.md +3123 -0
  1254. package/docs/gateway/configuration.md +633 -0
  1255. package/docs/gateway/discovery.md +123 -0
  1256. package/docs/gateway/doctor.md +362 -0
  1257. package/docs/gateway/gateway-lock.md +34 -0
  1258. package/docs/gateway/health.md +44 -0
  1259. package/docs/gateway/heartbeat.md +393 -0
  1260. package/docs/gateway/index.md +261 -0
  1261. package/docs/gateway/local-models.md +152 -0
  1262. package/docs/gateway/logging.md +113 -0
  1263. package/docs/gateway/multiple-gateways.md +112 -0
  1264. package/docs/gateway/network-model.md +22 -0
  1265. package/docs/gateway/openai-http-api.md +132 -0
  1266. package/docs/gateway/openresponses-http-api.md +295 -0
  1267. package/docs/gateway/openshell.md +307 -0
  1268. package/docs/gateway/pairing.md +99 -0
  1269. package/docs/gateway/protocol.md +267 -0
  1270. package/docs/gateway/remote-gateway-readme.md +158 -0
  1271. package/docs/gateway/remote.md +153 -0
  1272. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +134 -0
  1273. package/docs/gateway/sandboxing.md +469 -0
  1274. package/docs/gateway/secrets-plan-contract.md +116 -0
  1275. package/docs/gateway/secrets.md +503 -0
  1276. package/docs/gateway/security/index.md +1213 -0
  1277. package/docs/gateway/tailscale.md +132 -0
  1278. package/docs/gateway/tools-invoke-http-api.md +110 -0
  1279. package/docs/gateway/troubleshooting.md +378 -0
  1280. package/docs/gateway/trusted-proxy-auth.md +330 -0
  1281. package/docs/help/debugging.md +168 -0
  1282. package/docs/help/environment.md +163 -0
  1283. package/docs/help/faq.md +2999 -0
  1284. package/docs/help/index.md +28 -0
  1285. package/docs/help/scripts.md +28 -0
  1286. package/docs/help/testing.md +524 -0
  1287. package/docs/help/troubleshooting.md +297 -0
  1288. package/docs/images/configure-model-picker-unsearchable.png +0 -0
  1289. package/docs/images/feishu-step2-create-app.png +0 -0
  1290. package/docs/images/feishu-step3-credentials.png +0 -0
  1291. package/docs/images/feishu-step4-permissions.png +0 -0
  1292. package/docs/images/feishu-step5-bot-capability.png +0 -0
  1293. package/docs/images/feishu-step6-event-subscription.png +0 -0
  1294. package/docs/images/feishu-verification-token.png +0 -0
  1295. package/docs/images/groups-flow.svg +52 -0
  1296. package/docs/images/mobile-ui-screenshot.png +0 -0
  1297. package/docs/index.md +196 -0
  1298. package/docs/install/ansible.md +230 -0
  1299. package/docs/install/azure.md +311 -0
  1300. package/docs/install/bun.md +55 -0
  1301. package/docs/install/development-channels.md +120 -0
  1302. package/docs/install/digitalocean.md +129 -0
  1303. package/docs/install/docker-vm-runtime.md +142 -0
  1304. package/docs/install/docker.md +375 -0
  1305. package/docs/install/exe-dev.md +126 -0
  1306. package/docs/install/fly.md +501 -0
  1307. package/docs/install/gcp.md +402 -0
  1308. package/docs/install/hetzner.md +251 -0
  1309. package/docs/install/index.md +183 -0
  1310. package/docs/install/installer.md +415 -0
  1311. package/docs/install/kubernetes.md +191 -0
  1312. package/docs/install/macos-vm.md +281 -0
  1313. package/docs/install/migrating-matrix.md +346 -0
  1314. package/docs/install/migrating.md +110 -0
  1315. package/docs/install/nix.md +89 -0
  1316. package/docs/install/node.md +138 -0
  1317. package/docs/install/northflank.mdx +54 -0
  1318. package/docs/install/oracle.md +156 -0
  1319. package/docs/install/podman.md +133 -0
  1320. package/docs/install/railway.mdx +100 -0
  1321. package/docs/install/raspberry-pi.md +159 -0
  1322. package/docs/install/render.mdx +169 -0
  1323. package/docs/install/uninstall.md +128 -0
  1324. package/docs/install/updating.md +128 -0
  1325. package/docs/ja-JP/index.md +186 -0
  1326. package/docs/ja-JP/start/getting-started.md +125 -0
  1327. package/docs/ja-JP/start/wizard.md +77 -0
  1328. package/docs/logging.md +352 -0
  1329. package/docs/nav-tabs-underline.js +100 -0
  1330. package/docs/network.md +54 -0
  1331. package/docs/nodes/audio.md +187 -0
  1332. package/docs/nodes/camera.md +162 -0
  1333. package/docs/nodes/images.md +72 -0
  1334. package/docs/nodes/index.md +393 -0
  1335. package/docs/nodes/location-command.md +98 -0
  1336. package/docs/nodes/media-understanding.md +394 -0
  1337. package/docs/nodes/talk.md +92 -0
  1338. package/docs/nodes/troubleshooting.md +114 -0
  1339. package/docs/nodes/voicewake.md +66 -0
  1340. package/docs/perplexity.md +174 -0
  1341. package/docs/pi-dev.md +80 -0
  1342. package/docs/pi.md +567 -0
  1343. package/docs/platforms/android.md +168 -0
  1344. package/docs/platforms/digitalocean.md +266 -0
  1345. package/docs/platforms/index.md +54 -0
  1346. package/docs/platforms/ios.md +220 -0
  1347. package/docs/platforms/linux.md +94 -0
  1348. package/docs/platforms/mac/bundled-gateway.md +73 -0
  1349. package/docs/platforms/mac/canvas.md +125 -0
  1350. package/docs/platforms/mac/child-process.md +69 -0
  1351. package/docs/platforms/mac/dev-setup.md +104 -0
  1352. package/docs/platforms/mac/health.md +34 -0
  1353. package/docs/platforms/mac/icon.md +31 -0
  1354. package/docs/platforms/mac/logging.md +57 -0
  1355. package/docs/platforms/mac/menu-bar.md +81 -0
  1356. package/docs/platforms/mac/peekaboo.md +65 -0
  1357. package/docs/platforms/mac/permissions.md +50 -0
  1358. package/docs/platforms/mac/remote.md +84 -0
  1359. package/docs/platforms/mac/signing.md +47 -0
  1360. package/docs/platforms/mac/skills.md +33 -0
  1361. package/docs/platforms/mac/voice-overlay.md +60 -0
  1362. package/docs/platforms/mac/voicewake.md +67 -0
  1363. package/docs/platforms/mac/webchat.md +43 -0
  1364. package/docs/platforms/mac/xpc.md +61 -0
  1365. package/docs/platforms/macos.md +226 -0
  1366. package/docs/platforms/oracle.md +303 -0
  1367. package/docs/platforms/raspberry-pi.md +412 -0
  1368. package/docs/platforms/windows.md +241 -0
  1369. package/docs/plugins/agent-tools.md +10 -0
  1370. package/docs/plugins/architecture.md +1363 -0
  1371. package/docs/plugins/building-extensions.md +10 -0
  1372. package/docs/plugins/building-plugins.md +376 -0
  1373. package/docs/plugins/bundles.md +181 -0
  1374. package/docs/plugins/community.md +141 -0
  1375. package/docs/plugins/manifest.md +145 -0
  1376. package/docs/plugins/sdk-migration.md +169 -0
  1377. package/docs/plugins/voice-call.md +380 -0
  1378. package/docs/plugins/zalouser.md +77 -0
  1379. package/docs/prose.md +134 -0
  1380. package/docs/providers/anthropic.md +259 -0
  1381. package/docs/providers/bedrock.md +176 -0
  1382. package/docs/providers/claude-max-api-proxy.md +154 -0
  1383. package/docs/providers/cloudflare-ai-gateway.md +71 -0
  1384. package/docs/providers/deepgram.md +93 -0
  1385. package/docs/providers/github-copilot.md +72 -0
  1386. package/docs/providers/glm.md +43 -0
  1387. package/docs/providers/google.md +78 -0
  1388. package/docs/providers/groq.md +96 -0
  1389. package/docs/providers/huggingface.md +209 -0
  1390. package/docs/providers/index.md +69 -0
  1391. package/docs/providers/kilocode.md +74 -0
  1392. package/docs/providers/litellm.md +154 -0
  1393. package/docs/providers/minimax.md +224 -0
  1394. package/docs/providers/mistral.md +54 -0
  1395. package/docs/providers/models.md +45 -0
  1396. package/docs/providers/modelstudio.md +66 -0
  1397. package/docs/providers/moonshot.md +175 -0
  1398. package/docs/providers/nvidia.md +55 -0
  1399. package/docs/providers/ollama.md +352 -0
  1400. package/docs/providers/openai.md +303 -0
  1401. package/docs/providers/opencode-go.md +45 -0
  1402. package/docs/providers/opencode.md +64 -0
  1403. package/docs/providers/openrouter.md +37 -0
  1404. package/docs/providers/perplexity-provider.md +62 -0
  1405. package/docs/providers/qianfan.md +38 -0
  1406. package/docs/providers/qwen.md +53 -0
  1407. package/docs/providers/sglang.md +104 -0
  1408. package/docs/providers/synthetic.md +99 -0
  1409. package/docs/providers/together.md +66 -0
  1410. package/docs/providers/venice.md +282 -0
  1411. package/docs/providers/vercel-ai-gateway.md +60 -0
  1412. package/docs/providers/vllm.md +92 -0
  1413. package/docs/providers/volcengine.md +74 -0
  1414. package/docs/providers/xai.md +60 -0
  1415. package/docs/providers/xiaomi.md +86 -0
  1416. package/docs/providers/zai.md +46 -0
  1417. package/docs/reference/AGENTS.default.md +126 -0
  1418. package/docs/reference/RELEASING.md +42 -0
  1419. package/docs/reference/api-usage-costs.md +144 -0
  1420. package/docs/reference/credits.md +30 -0
  1421. package/docs/reference/device-models.md +47 -0
  1422. package/docs/reference/memory-config.md +711 -0
  1423. package/docs/reference/prompt-caching.md +185 -0
  1424. package/docs/reference/rpc.md +43 -0
  1425. package/docs/reference/secretref-credential-surface.md +140 -0
  1426. package/docs/reference/secretref-user-supplied-credentials-matrix.json +563 -0
  1427. package/docs/reference/session-management-compaction.md +324 -0
  1428. package/docs/reference/templates/AGENTS.dev.md +83 -0
  1429. package/docs/reference/templates/AGENTS.md +219 -0
  1430. package/docs/reference/templates/BOOT.md +11 -0
  1431. package/docs/reference/templates/BOOTSTRAP.md +62 -0
  1432. package/docs/reference/templates/HEARTBEAT.md +14 -0
  1433. package/docs/reference/templates/IDENTITY.dev.md +47 -0
  1434. package/docs/reference/templates/IDENTITY.md +29 -0
  1435. package/docs/reference/templates/SOUL.dev.md +76 -0
  1436. package/docs/reference/templates/SOUL.md +43 -0
  1437. package/docs/reference/templates/TOOLS.dev.md +24 -0
  1438. package/docs/reference/templates/TOOLS.md +47 -0
  1439. package/docs/reference/templates/USER.dev.md +18 -0
  1440. package/docs/reference/templates/USER.md +23 -0
  1441. package/docs/reference/test.md +90 -0
  1442. package/docs/reference/token-use.md +175 -0
  1443. package/docs/reference/transcript-hygiene.md +151 -0
  1444. package/docs/reference/wizard.md +235 -0
  1445. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +98 -0
  1446. package/docs/security/THREAT-MODEL-ATLAS.md +611 -0
  1447. package/docs/security/formal-verification.md +167 -0
  1448. package/docs/start/bootstrapping.md +41 -0
  1449. package/docs/start/docs-directory.md +66 -0
  1450. package/docs/start/getting-started.md +116 -0
  1451. package/docs/start/hubs.md +198 -0
  1452. package/docs/start/lore.md +219 -0
  1453. package/docs/start/onboarding-overview.md +67 -0
  1454. package/docs/start/onboarding.md +91 -0
  1455. package/docs/start/openclaw.md +216 -0
  1456. package/docs/start/quickstart.md +22 -0
  1457. package/docs/start/setup.md +164 -0
  1458. package/docs/start/showcase.md +418 -0
  1459. package/docs/start/wizard-cli-automation.md +215 -0
  1460. package/docs/start/wizard-cli-reference.md +299 -0
  1461. package/docs/start/wizard.md +125 -0
  1462. package/docs/style.css +37 -0
  1463. package/docs/tools/acp-agents.md +623 -0
  1464. package/docs/tools/agent-send.md +100 -0
  1465. package/docs/tools/apply-patch.md +51 -0
  1466. package/docs/tools/brave-search.md +93 -0
  1467. package/docs/tools/browser-linux-troubleshooting.md +138 -0
  1468. package/docs/tools/browser-login.md +73 -0
  1469. package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +211 -0
  1470. package/docs/tools/browser.md +731 -0
  1471. package/docs/tools/btw.md +142 -0
  1472. package/docs/tools/capability-cookbook.md +119 -0
  1473. package/docs/tools/clawhub.md +257 -0
  1474. package/docs/tools/creating-skills.md +117 -0
  1475. package/docs/tools/diffs.md +386 -0
  1476. package/docs/tools/elevated.md +114 -0
  1477. package/docs/tools/exec-approvals.md +400 -0
  1478. package/docs/tools/exec.md +204 -0
  1479. package/docs/tools/firecrawl.md +140 -0
  1480. package/docs/tools/index.md +137 -0
  1481. package/docs/tools/llm-task.md +119 -0
  1482. package/docs/tools/lobster.md +340 -0
  1483. package/docs/tools/loop-detection.md +100 -0
  1484. package/docs/tools/multi-agent-sandbox-tools.md +364 -0
  1485. package/docs/tools/pdf.md +156 -0
  1486. package/docs/tools/perplexity-search.md +174 -0
  1487. package/docs/tools/plugin.md +251 -0
  1488. package/docs/tools/reactions.md +64 -0
  1489. package/docs/tools/skills-config.md +86 -0
  1490. package/docs/tools/skills.md +306 -0
  1491. package/docs/tools/slash-commands.md +294 -0
  1492. package/docs/tools/subagents.md +295 -0
  1493. package/docs/tools/tavily.md +125 -0
  1494. package/docs/tools/thinking.md +96 -0
  1495. package/docs/tools/tts.md +406 -0
  1496. package/docs/tools/web.md +516 -0
  1497. package/docs/tts.md +406 -0
  1498. package/docs/vps.md +112 -0
  1499. package/docs/web/control-ui.md +275 -0
  1500. package/docs/web/dashboard.md +54 -0
  1501. package/docs/web/index.md +120 -0
  1502. package/docs/web/tui.md +170 -0
  1503. package/docs/web/webchat.md +61 -0
  1504. package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
  1505. package/docs/whatsapp-openclaw.jpg +0 -0
  1506. package/docs/zh-CN/AGENTS.md +61 -0
  1507. package/docs/zh-CN/automation/auth-monitoring.md +47 -0
  1508. package/docs/zh-CN/automation/cron-jobs.md +435 -0
  1509. package/docs/zh-CN/automation/cron-vs-heartbeat.md +286 -0
  1510. package/docs/zh-CN/automation/gmail-pubsub.md +249 -0
  1511. package/docs/zh-CN/automation/hooks.md +1051 -0
  1512. package/docs/zh-CN/automation/poll.md +76 -0
  1513. package/docs/zh-CN/automation/troubleshooting.md +8 -0
  1514. package/docs/zh-CN/automation/webhook.md +163 -0
  1515. package/docs/zh-CN/brave-search.md +60 -0
  1516. package/docs/zh-CN/channels/bluebubbles.md +354 -0
  1517. package/docs/zh-CN/channels/broadcast-groups.md +449 -0
  1518. package/docs/zh-CN/channels/channel-routing.md +117 -0
  1519. package/docs/zh-CN/channels/discord.md +468 -0
  1520. package/docs/zh-CN/channels/feishu.md +728 -0
  1521. package/docs/zh-CN/channels/googlechat.md +257 -0
  1522. package/docs/zh-CN/channels/grammy.md +38 -0
  1523. package/docs/zh-CN/channels/group-messages.md +91 -0
  1524. package/docs/zh-CN/channels/groups.md +379 -0
  1525. package/docs/zh-CN/channels/imessage.md +302 -0
  1526. package/docs/zh-CN/channels/index.md +53 -0
  1527. package/docs/zh-CN/channels/line.md +180 -0
  1528. package/docs/zh-CN/channels/location.md +63 -0
  1529. package/docs/zh-CN/channels/matrix.md +221 -0
  1530. package/docs/zh-CN/channels/mattermost.md +144 -0
  1531. package/docs/zh-CN/channels/msteams.md +775 -0
  1532. package/docs/zh-CN/channels/nextcloud-talk.md +142 -0
  1533. package/docs/zh-CN/channels/nostr.md +249 -0
  1534. package/docs/zh-CN/channels/pairing.md +89 -0
  1535. package/docs/zh-CN/channels/signal.md +209 -0
  1536. package/docs/zh-CN/channels/slack.md +531 -0
  1537. package/docs/zh-CN/channels/synology-chat.md +138 -0
  1538. package/docs/zh-CN/channels/telegram.md +751 -0
  1539. package/docs/zh-CN/channels/tlon.md +136 -0
  1540. package/docs/zh-CN/channels/troubleshooting.md +36 -0
  1541. package/docs/zh-CN/channels/twitch.md +385 -0
  1542. package/docs/zh-CN/channels/whatsapp.md +411 -0
  1543. package/docs/zh-CN/channels/zalo.md +196 -0
  1544. package/docs/zh-CN/channels/zalouser.md +147 -0
  1545. package/docs/zh-CN/cli/acp.md +173 -0
  1546. package/docs/zh-CN/cli/agent.md +30 -0
  1547. package/docs/zh-CN/cli/agents.md +82 -0
  1548. package/docs/zh-CN/cli/approvals.md +57 -0
  1549. package/docs/zh-CN/cli/browser.md +114 -0
  1550. package/docs/zh-CN/cli/channels.md +86 -0
  1551. package/docs/zh-CN/cli/config.md +57 -0
  1552. package/docs/zh-CN/cli/configure.md +38 -0
  1553. package/docs/zh-CN/cli/cron.md +43 -0
  1554. package/docs/zh-CN/cli/dashboard.md +23 -0
  1555. package/docs/zh-CN/cli/devices.md +74 -0
  1556. package/docs/zh-CN/cli/directory.md +70 -0
  1557. package/docs/zh-CN/cli/dns.md +30 -0
  1558. package/docs/zh-CN/cli/docs.md +22 -0
  1559. package/docs/zh-CN/cli/doctor.md +48 -0
  1560. package/docs/zh-CN/cli/gateway.md +206 -0
  1561. package/docs/zh-CN/cli/health.md +28 -0
  1562. package/docs/zh-CN/cli/hooks.md +298 -0
  1563. package/docs/zh-CN/cli/index.md +1143 -0
  1564. package/docs/zh-CN/cli/logs.md +31 -0
  1565. package/docs/zh-CN/cli/memory.md +52 -0
  1566. package/docs/zh-CN/cli/message.md +246 -0
  1567. package/docs/zh-CN/cli/models.md +85 -0
  1568. package/docs/zh-CN/cli/node.md +115 -0
  1569. package/docs/zh-CN/cli/nodes.md +80 -0
  1570. package/docs/zh-CN/cli/onboard.md +164 -0
  1571. package/docs/zh-CN/cli/pairing.md +28 -0
  1572. package/docs/zh-CN/cli/plugins.md +66 -0
  1573. package/docs/zh-CN/cli/reset.md +24 -0
  1574. package/docs/zh-CN/cli/sandbox.md +158 -0
  1575. package/docs/zh-CN/cli/security.md +33 -0
  1576. package/docs/zh-CN/cli/sessions.md +23 -0
  1577. package/docs/zh-CN/cli/setup.md +36 -0
  1578. package/docs/zh-CN/cli/skills.md +33 -0
  1579. package/docs/zh-CN/cli/status.md +33 -0
  1580. package/docs/zh-CN/cli/system.md +63 -0
  1581. package/docs/zh-CN/cli/tui.md +30 -0
  1582. package/docs/zh-CN/cli/uninstall.md +24 -0
  1583. package/docs/zh-CN/cli/update.md +101 -0
  1584. package/docs/zh-CN/cli/voicecall.md +41 -0
  1585. package/docs/zh-CN/cli/webhooks.md +32 -0
  1586. package/docs/zh-CN/concepts/agent-loop.md +146 -0
  1587. package/docs/zh-CN/concepts/agent-workspace.md +219 -0
  1588. package/docs/zh-CN/concepts/agent.md +115 -0
  1589. package/docs/zh-CN/concepts/architecture.md +123 -0
  1590. package/docs/zh-CN/concepts/compaction.md +67 -0
  1591. package/docs/zh-CN/concepts/context.md +168 -0
  1592. package/docs/zh-CN/concepts/features.md +59 -0
  1593. package/docs/zh-CN/concepts/markdown-formatting.md +117 -0
  1594. package/docs/zh-CN/concepts/memory.md +412 -0
  1595. package/docs/zh-CN/concepts/messages.md +141 -0
  1596. package/docs/zh-CN/concepts/model-failover.md +145 -0
  1597. package/docs/zh-CN/concepts/model-providers.md +606 -0
  1598. package/docs/zh-CN/concepts/models.md +225 -0
  1599. package/docs/zh-CN/concepts/multi-agent.md +372 -0
  1600. package/docs/zh-CN/concepts/oauth.md +164 -0
  1601. package/docs/zh-CN/concepts/presence.md +99 -0
  1602. package/docs/zh-CN/concepts/queue.md +94 -0
  1603. package/docs/zh-CN/concepts/retry.md +76 -0
  1604. package/docs/zh-CN/concepts/session-pruning.md +129 -0
  1605. package/docs/zh-CN/concepts/session-tool.md +200 -0
  1606. package/docs/zh-CN/concepts/session.md +166 -0
  1607. package/docs/zh-CN/concepts/streaming.md +133 -0
  1608. package/docs/zh-CN/concepts/system-prompt.md +101 -0
  1609. package/docs/zh-CN/concepts/timezone.md +96 -0
  1610. package/docs/zh-CN/concepts/typebox.md +284 -0
  1611. package/docs/zh-CN/concepts/typing-indicators.md +74 -0
  1612. package/docs/zh-CN/concepts/usage-tracking.md +42 -0
  1613. package/docs/zh-CN/date-time.md +129 -0
  1614. package/docs/zh-CN/debug/node-issue.md +90 -0
  1615. package/docs/zh-CN/diagnostics/flags.md +98 -0
  1616. package/docs/zh-CN/gateway/authentication.md +184 -0
  1617. package/docs/zh-CN/gateway/background-process.md +100 -0
  1618. package/docs/zh-CN/gateway/bonjour.md +174 -0
  1619. package/docs/zh-CN/gateway/bridge-protocol.md +86 -0
  1620. package/docs/zh-CN/gateway/cli-backends.md +213 -0
  1621. package/docs/zh-CN/gateway/configuration-examples.md +587 -0
  1622. package/docs/zh-CN/gateway/configuration-reference.md +3103 -0
  1623. package/docs/zh-CN/gateway/configuration.md +640 -0
  1624. package/docs/zh-CN/gateway/discovery.md +123 -0
  1625. package/docs/zh-CN/gateway/doctor.md +238 -0
  1626. package/docs/zh-CN/gateway/gateway-lock.md +41 -0
  1627. package/docs/zh-CN/gateway/health.md +42 -0
  1628. package/docs/zh-CN/gateway/heartbeat.md +274 -0
  1629. package/docs/zh-CN/gateway/index.md +335 -0
  1630. package/docs/zh-CN/gateway/local-models.md +159 -0
  1631. package/docs/zh-CN/gateway/logging.md +114 -0
  1632. package/docs/zh-CN/gateway/multiple-gateways.md +119 -0
  1633. package/docs/zh-CN/gateway/network-model.md +23 -0
  1634. package/docs/zh-CN/gateway/openai-http-api.md +125 -0
  1635. package/docs/zh-CN/gateway/openresponses-http-api.md +317 -0
  1636. package/docs/zh-CN/gateway/pairing.md +99 -0
  1637. package/docs/zh-CN/gateway/protocol.md +220 -0
  1638. package/docs/zh-CN/gateway/remote-gateway-readme.md +164 -0
  1639. package/docs/zh-CN/gateway/remote.md +133 -0
  1640. package/docs/zh-CN/gateway/sandbox-vs-tool-policy-vs-elevated.md +135 -0
  1641. package/docs/zh-CN/gateway/sandboxing.md +188 -0
  1642. package/docs/zh-CN/gateway/security/index.md +777 -0
  1643. package/docs/zh-CN/gateway/tailscale.md +124 -0
  1644. package/docs/zh-CN/gateway/tools-invoke-http-api.md +92 -0
  1645. package/docs/zh-CN/gateway/troubleshooting.md +771 -0
  1646. package/docs/zh-CN/help/debugging.md +160 -0
  1647. package/docs/zh-CN/help/environment.md +88 -0
  1648. package/docs/zh-CN/help/faq.md +2640 -0
  1649. package/docs/zh-CN/help/index.md +28 -0
  1650. package/docs/zh-CN/help/scripts.md +35 -0
  1651. package/docs/zh-CN/help/testing.md +375 -0
  1652. package/docs/zh-CN/help/troubleshooting.md +104 -0
  1653. package/docs/zh-CN/index.md +186 -0
  1654. package/docs/zh-CN/install/ansible.md +215 -0
  1655. package/docs/zh-CN/install/bun.md +65 -0
  1656. package/docs/zh-CN/install/development-channels.md +81 -0
  1657. package/docs/zh-CN/install/docker.md +532 -0
  1658. package/docs/zh-CN/install/exe-dev.md +133 -0
  1659. package/docs/zh-CN/install/fly.md +490 -0
  1660. package/docs/zh-CN/install/gcp.md +510 -0
  1661. package/docs/zh-CN/install/hetzner.md +337 -0
  1662. package/docs/zh-CN/install/index.md +235 -0
  1663. package/docs/zh-CN/install/installer.md +422 -0
  1664. package/docs/zh-CN/install/macos-vm.md +288 -0
  1665. package/docs/zh-CN/install/migrating.md +199 -0
  1666. package/docs/zh-CN/install/nix.md +99 -0
  1667. package/docs/zh-CN/install/node.md +8 -0
  1668. package/docs/zh-CN/install/northflank.mdx +60 -0
  1669. package/docs/zh-CN/install/railway.mdx +106 -0
  1670. package/docs/zh-CN/install/render.mdx +169 -0
  1671. package/docs/zh-CN/install/uninstall.md +135 -0
  1672. package/docs/zh-CN/install/updating.md +233 -0
  1673. package/docs/zh-CN/logging.md +329 -0
  1674. package/docs/zh-CN/network.md +59 -0
  1675. package/docs/zh-CN/nodes/audio.md +120 -0
  1676. package/docs/zh-CN/nodes/camera.md +162 -0
  1677. package/docs/zh-CN/nodes/images.md +79 -0
  1678. package/docs/zh-CN/nodes/index.md +348 -0
  1679. package/docs/zh-CN/nodes/location-command.md +120 -0
  1680. package/docs/zh-CN/nodes/media-understanding.md +380 -0
  1681. package/docs/zh-CN/nodes/talk.md +97 -0
  1682. package/docs/zh-CN/nodes/troubleshooting.md +8 -0
  1683. package/docs/zh-CN/nodes/voicewake.md +72 -0
  1684. package/docs/zh-CN/perplexity.md +102 -0
  1685. package/docs/zh-CN/pi-dev.md +77 -0
  1686. package/docs/zh-CN/pi.md +619 -0
  1687. package/docs/zh-CN/platforms/android.md +155 -0
  1688. package/docs/zh-CN/platforms/digitalocean.md +273 -0
  1689. package/docs/zh-CN/platforms/index.md +60 -0
  1690. package/docs/zh-CN/platforms/ios.md +114 -0
  1691. package/docs/zh-CN/platforms/linux.md +100 -0
  1692. package/docs/zh-CN/platforms/mac/bundled-gateway.md +75 -0
  1693. package/docs/zh-CN/platforms/mac/canvas.md +128 -0
  1694. package/docs/zh-CN/platforms/mac/child-process.md +73 -0
  1695. package/docs/zh-CN/platforms/mac/dev-setup.md +109 -0
  1696. package/docs/zh-CN/platforms/mac/health.md +41 -0
  1697. package/docs/zh-CN/platforms/mac/icon.md +38 -0
  1698. package/docs/zh-CN/platforms/mac/logging.md +64 -0
  1699. package/docs/zh-CN/platforms/mac/menu-bar.md +88 -0
  1700. package/docs/zh-CN/platforms/mac/peekaboo.md +62 -0
  1701. package/docs/zh-CN/platforms/mac/permissions.md +46 -0
  1702. package/docs/zh-CN/platforms/mac/remote.md +90 -0
  1703. package/docs/zh-CN/platforms/mac/signing.md +54 -0
  1704. package/docs/zh-CN/platforms/mac/skills.md +40 -0
  1705. package/docs/zh-CN/platforms/mac/voice-overlay.md +67 -0
  1706. package/docs/zh-CN/platforms/mac/voicewake.md +74 -0
  1707. package/docs/zh-CN/platforms/mac/webchat.md +43 -0
  1708. package/docs/zh-CN/platforms/mac/xpc.md +68 -0
  1709. package/docs/zh-CN/platforms/macos.md +193 -0
  1710. package/docs/zh-CN/platforms/oracle.md +310 -0
  1711. package/docs/zh-CN/platforms/raspberry-pi.md +416 -0
  1712. package/docs/zh-CN/platforms/windows.md +247 -0
  1713. package/docs/zh-CN/plugins/agent-tools.md +99 -0
  1714. package/docs/zh-CN/plugins/manifest.md +68 -0
  1715. package/docs/zh-CN/plugins/voice-call.md +250 -0
  1716. package/docs/zh-CN/plugins/zalouser.md +88 -0
  1717. package/docs/zh-CN/prose.md +141 -0
  1718. package/docs/zh-CN/providers/anthropic.md +265 -0
  1719. package/docs/zh-CN/providers/bedrock.md +170 -0
  1720. package/docs/zh-CN/providers/claude-max-api-proxy.md +155 -0
  1721. package/docs/zh-CN/providers/cloudflare-ai-gateway.md +78 -0
  1722. package/docs/zh-CN/providers/deepgram.md +97 -0
  1723. package/docs/zh-CN/providers/github-copilot.md +67 -0
  1724. package/docs/zh-CN/providers/glm.md +50 -0
  1725. package/docs/zh-CN/providers/huggingface.md +216 -0
  1726. package/docs/zh-CN/providers/index.md +69 -0
  1727. package/docs/zh-CN/providers/kilocode.md +80 -0
  1728. package/docs/zh-CN/providers/litellm.md +160 -0
  1729. package/docs/zh-CN/providers/minimax.md +222 -0
  1730. package/docs/zh-CN/providers/mistral.md +61 -0
  1731. package/docs/zh-CN/providers/models.md +51 -0
  1732. package/docs/zh-CN/providers/moonshot.md +182 -0
  1733. package/docs/zh-CN/providers/nvidia.md +62 -0
  1734. package/docs/zh-CN/providers/ollama.md +359 -0
  1735. package/docs/zh-CN/providers/openai.md +308 -0
  1736. package/docs/zh-CN/providers/opencode-go.md +52 -0
  1737. package/docs/zh-CN/providers/opencode.md +71 -0
  1738. package/docs/zh-CN/providers/openrouter.md +44 -0
  1739. package/docs/zh-CN/providers/qianfan.md +45 -0
  1740. package/docs/zh-CN/providers/qwen.md +55 -0
  1741. package/docs/zh-CN/providers/sglang.md +111 -0
  1742. package/docs/zh-CN/providers/synthetic.md +106 -0
  1743. package/docs/zh-CN/providers/together.md +72 -0
  1744. package/docs/zh-CN/providers/venice.md +289 -0
  1745. package/docs/zh-CN/providers/vercel-ai-gateway.md +66 -0
  1746. package/docs/zh-CN/providers/xiaomi.md +93 -0
  1747. package/docs/zh-CN/providers/zai.md +53 -0
  1748. package/docs/zh-CN/reference/AGENTS.default.md +131 -0
  1749. package/docs/zh-CN/reference/RELEASING.md +48 -0
  1750. package/docs/zh-CN/reference/api-usage-costs.md +141 -0
  1751. package/docs/zh-CN/reference/credits.md +34 -0
  1752. package/docs/zh-CN/reference/device-models.md +54 -0
  1753. package/docs/zh-CN/reference/rpc.md +48 -0
  1754. package/docs/zh-CN/reference/session-management-compaction.md +287 -0
  1755. package/docs/zh-CN/reference/templates/AGENTS.dev.md +89 -0
  1756. package/docs/zh-CN/reference/templates/AGENTS.md +225 -0
  1757. package/docs/zh-CN/reference/templates/BOOT.md +17 -0
  1758. package/docs/zh-CN/reference/templates/BOOTSTRAP.md +68 -0
  1759. package/docs/zh-CN/reference/templates/HEARTBEAT.md +18 -0
  1760. package/docs/zh-CN/reference/templates/IDENTITY.dev.md +54 -0
  1761. package/docs/zh-CN/reference/templates/IDENTITY.md +36 -0
  1762. package/docs/zh-CN/reference/templates/SOUL.dev.md +83 -0
  1763. package/docs/zh-CN/reference/templates/SOUL.md +49 -0
  1764. package/docs/zh-CN/reference/templates/TOOLS.dev.md +31 -0
  1765. package/docs/zh-CN/reference/templates/TOOLS.md +53 -0
  1766. package/docs/zh-CN/reference/templates/USER.dev.md +25 -0
  1767. package/docs/zh-CN/reference/templates/USER.md +30 -0
  1768. package/docs/zh-CN/reference/test.md +57 -0
  1769. package/docs/zh-CN/reference/token-use.md +119 -0
  1770. package/docs/zh-CN/reference/transcript-hygiene.md +109 -0
  1771. package/docs/zh-CN/reference/wizard.md +242 -0
  1772. package/docs/zh-CN/security/formal-verification.md +171 -0
  1773. package/docs/zh-CN/start/bootstrapping.md +9 -0
  1774. package/docs/zh-CN/start/docs-directory.md +70 -0
  1775. package/docs/zh-CN/start/getting-started.md +143 -0
  1776. package/docs/zh-CN/start/hubs.md +194 -0
  1777. package/docs/zh-CN/start/lore.md +226 -0
  1778. package/docs/zh-CN/start/onboarding-overview.md +58 -0
  1779. package/docs/zh-CN/start/onboarding.md +105 -0
  1780. package/docs/zh-CN/start/openclaw.md +248 -0
  1781. package/docs/zh-CN/start/quickstart.md +88 -0
  1782. package/docs/zh-CN/start/setup.md +153 -0
  1783. package/docs/zh-CN/start/showcase.md +423 -0
  1784. package/docs/zh-CN/start/wizard-cli-automation.md +222 -0
  1785. package/docs/zh-CN/start/wizard-cli-reference.md +306 -0
  1786. package/docs/zh-CN/start/wizard.md +132 -0
  1787. package/docs/zh-CN/tools/agent-send.md +59 -0
  1788. package/docs/zh-CN/tools/apply-patch.md +57 -0
  1789. package/docs/zh-CN/tools/browser-linux-troubleshooting.md +144 -0
  1790. package/docs/zh-CN/tools/browser-login.md +75 -0
  1791. package/docs/zh-CN/tools/browser.md +553 -0
  1792. package/docs/zh-CN/tools/chrome-extension.md +183 -0
  1793. package/docs/zh-CN/tools/clawhub.md +209 -0
  1794. package/docs/zh-CN/tools/creating-skills.md +61 -0
  1795. package/docs/zh-CN/tools/elevated.md +64 -0
  1796. package/docs/zh-CN/tools/exec-approvals.md +234 -0
  1797. package/docs/zh-CN/tools/exec.md +169 -0
  1798. package/docs/zh-CN/tools/firecrawl.md +68 -0
  1799. package/docs/zh-CN/tools/index.md +515 -0
  1800. package/docs/zh-CN/tools/llm-task.md +117 -0
  1801. package/docs/zh-CN/tools/lobster.md +349 -0
  1802. package/docs/zh-CN/tools/multi-agent-sandbox-tools.md +401 -0
  1803. package/docs/zh-CN/tools/plugin.md +1612 -0
  1804. package/docs/zh-CN/tools/reactions.md +29 -0
  1805. package/docs/zh-CN/tools/skills-config.md +78 -0
  1806. package/docs/zh-CN/tools/skills.md +279 -0
  1807. package/docs/zh-CN/tools/slash-commands.md +205 -0
  1808. package/docs/zh-CN/tools/subagents.md +167 -0
  1809. package/docs/zh-CN/tools/thinking.md +80 -0
  1810. package/docs/zh-CN/tools/web.md +289 -0
  1811. package/docs/zh-CN/tts.md +375 -0
  1812. package/docs/zh-CN/vps.md +47 -0
  1813. package/docs/zh-CN/web/control-ui.md +191 -0
  1814. package/docs/zh-CN/web/dashboard.md +53 -0
  1815. package/docs/zh-CN/web/index.md +118 -0
  1816. package/docs/zh-CN/web/tui.md +166 -0
  1817. package/docs/zh-CN/web/webchat.md +56 -0
  1818. package/openclaw.mjs +135 -0
  1819. package/package.json +835 -0
  1820. package/skills/1password/SKILL.md +70 -0
  1821. package/skills/1password/references/cli-examples.md +29 -0
  1822. package/skills/1password/references/get-started.md +17 -0
  1823. package/skills/apple-notes/SKILL.md +77 -0
  1824. package/skills/apple-reminders/SKILL.md +118 -0
  1825. package/skills/bear-notes/SKILL.md +107 -0
  1826. package/skills/blogwatcher/SKILL.md +69 -0
  1827. package/skills/blucli/SKILL.md +47 -0
  1828. package/skills/bluebubbles/SKILL.md +131 -0
  1829. package/skills/camsnap/SKILL.md +45 -0
  1830. package/skills/canvas/SKILL.md +198 -0
  1831. package/skills/clawhub/SKILL.md +77 -0
  1832. package/skills/coding-agent/SKILL.md +295 -0
  1833. package/skills/discord/SKILL.md +197 -0
  1834. package/skills/doubao-code/SKILL.md +43 -0
  1835. package/skills/eightctl/SKILL.md +50 -0
  1836. package/skills/gemini/SKILL.md +43 -0
  1837. package/skills/gh-issues/SKILL.md +865 -0
  1838. package/skills/gifgrep/SKILL.md +79 -0
  1839. package/skills/github/SKILL.md +163 -0
  1840. package/skills/gog/SKILL.md +116 -0
  1841. package/skills/goplaces/SKILL.md +52 -0
  1842. package/skills/healthcheck/SKILL.md +245 -0
  1843. package/skills/himalaya/SKILL.md +257 -0
  1844. package/skills/himalaya/references/configuration.md +184 -0
  1845. package/skills/himalaya/references/message-composition.md +199 -0
  1846. package/skills/imsg/SKILL.md +122 -0
  1847. package/skills/kimi-code/SKILL.md +42 -0
  1848. package/skills/mcporter/SKILL.md +61 -0
  1849. package/skills/model-usage/SKILL.md +69 -0
  1850. package/skills/model-usage/references/codexbar-cli.md +33 -0
  1851. package/skills/model-usage/scripts/model_usage.py +320 -0
  1852. package/skills/model-usage/scripts/test_model_usage.py +40 -0
  1853. package/skills/nano-pdf/SKILL.md +38 -0
  1854. package/skills/node-connect/SKILL.md +142 -0
  1855. package/skills/notion/SKILL.md +174 -0
  1856. package/skills/obsidian/SKILL.md +81 -0
  1857. package/skills/openai-image-gen/SKILL.md +92 -0
  1858. package/skills/openai-image-gen/scripts/gen.py +328 -0
  1859. package/skills/openai-image-gen/scripts/test_gen.py +140 -0
  1860. package/skills/openai-whisper/SKILL.md +38 -0
  1861. package/skills/openai-whisper-api/SKILL.md +52 -0
  1862. package/skills/openai-whisper-api/scripts/transcribe.sh +85 -0
  1863. package/skills/openhue/SKILL.md +112 -0
  1864. package/skills/oracle/SKILL.md +125 -0
  1865. package/skills/ordercli/SKILL.md +78 -0
  1866. package/skills/peekaboo/SKILL.md +190 -0
  1867. package/skills/sag/SKILL.md +87 -0
  1868. package/skills/session-logs/SKILL.md +115 -0
  1869. package/skills/sherpa-onnx-tts/SKILL.md +103 -0
  1870. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  1871. package/skills/skill-creator/SKILL.md +372 -0
  1872. package/skills/skill-creator/license.txt +202 -0
  1873. package/skills/skill-creator/scripts/init_skill.py +378 -0
  1874. package/skills/skill-creator/scripts/package_skill.py +139 -0
  1875. package/skills/skill-creator/scripts/quick_validate.py +159 -0
  1876. package/skills/skill-creator/scripts/test_package_skill.py +160 -0
  1877. package/skills/skill-creator/scripts/test_quick_validate.py +72 -0
  1878. package/skills/slack/SKILL.md +144 -0
  1879. package/skills/songsee/SKILL.md +49 -0
  1880. package/skills/sonoscli/SKILL.md +65 -0
  1881. package/skills/spotify-player/SKILL.md +64 -0
  1882. package/skills/summarize/SKILL.md +87 -0
  1883. package/skills/things-mac/SKILL.md +86 -0
  1884. package/skills/tmux/SKILL.md +153 -0
  1885. package/skills/tmux/scripts/find-sessions.sh +112 -0
  1886. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  1887. package/skills/trello/SKILL.md +95 -0
  1888. package/skills/video-frames/SKILL.md +46 -0
  1889. package/skills/video-frames/scripts/frame.sh +81 -0
  1890. package/skills/voice-call/SKILL.md +45 -0
  1891. package/skills/wacli/SKILL.md +72 -0
  1892. package/skills/weather/SKILL.md +112 -0
  1893. package/skills/xurl/SKILL.md +461 -0
@@ -0,0 +1,1446 @@
1
+ import { C as resolveRequiredHomeDir } from "./paths-GHJ97ebE.js";
2
+ import { t as createSubsystemLogger } from "./subsystem-CUp-6QQf.js";
3
+ import { r as normalizeOptionalAccountId } from "./account-id-ZCrgXl7Z.js";
4
+ import { n as normalizeHyphenSlug } from "./string-normalization-CvzuCAZv.js";
5
+ import { s as loadConfig, w as parseByteSize } from "./io-jOnQRia2.js";
6
+ import { t as parseDurationMs } from "./parse-duration-BBGYkY0S.js";
7
+ import { c as listDeliverableMessageChannels, l as normalizeMessageChannel } from "./message-channel-Cy-gN4K2.js";
8
+ import { i as parseSessionArchiveTimestamp, n as isPrimarySessionTranscriptFileName, r as isSessionArchiveArtifactName, t as formatSessionArchiveTimestamp } from "./artifacts-C_4LekPC.js";
9
+ import { t as normalizeChatType } from "./chat-type-C-n03mQY.js";
10
+ import { r as normalizeChannelId, t as getChannelPlugin } from "./registry-C3q59Qj0.js";
11
+ import { a as resolveSessionTranscriptPath, o as resolveSessionTranscriptPathInDir, r as resolveSessionFilePath } from "./paths-CTjJI9l0.js";
12
+ import { i as normalizeSessionRuntimeModelFields, n as mergeSessionEntry, r as mergeSessionEntryPreserveActivity } from "./types-BCKGVVld.js";
13
+ import { t as acquireSessionWriteLock } from "./session-write-lock-DNKvpjKf.js";
14
+ import { i as writeTextAtomic } from "./json-files-WW-H_psG.js";
15
+ import { r as parseStrictNonNegativeInteger } from "./parse-finite-number-CP4MQF_w.js";
16
+ import fs from "node:fs";
17
+ import path from "node:path";
18
+ import os from "node:os";
19
+ //#region src/config/sessions/group.ts
20
+ const getGroupSurfaces = () => new Set([...listDeliverableMessageChannels(), "webchat"]);
21
+ function normalizeGroupLabel(raw) {
22
+ return normalizeHyphenSlug(raw);
23
+ }
24
+ function shortenGroupId(value) {
25
+ const trimmed = value?.trim() ?? "";
26
+ if (!trimmed) return "";
27
+ if (trimmed.length <= 14) return trimmed;
28
+ return `${trimmed.slice(0, 6)}...${trimmed.slice(-4)}`;
29
+ }
30
+ function buildGroupDisplayName(params) {
31
+ const providerKey = (params.provider?.trim().toLowerCase() || "group").trim();
32
+ const groupChannel = params.groupChannel?.trim();
33
+ const space = params.space?.trim();
34
+ const subject = params.subject?.trim();
35
+ const detail = (groupChannel && space ? `${space}${groupChannel.startsWith("#") ? "" : "#"}${groupChannel}` : groupChannel || subject || space || "") || "";
36
+ const fallbackId = params.id?.trim() || params.key;
37
+ const rawLabel = detail || fallbackId;
38
+ let token = normalizeGroupLabel(rawLabel);
39
+ if (!token) token = normalizeGroupLabel(shortenGroupId(rawLabel));
40
+ if (!params.groupChannel && token.startsWith("#")) token = token.replace(/^#+/, "");
41
+ if (token && !/^[@#]/.test(token) && !token.startsWith("g-") && !token.includes("#")) token = `g-${token}`;
42
+ return token ? `${providerKey}:${token}` : providerKey;
43
+ }
44
+ function resolveGroupSessionKey(ctx) {
45
+ const from = typeof ctx.From === "string" ? ctx.From.trim() : "";
46
+ const chatType = ctx.ChatType?.trim().toLowerCase();
47
+ const normalizedChatType = chatType === "channel" ? "channel" : chatType === "group" ? "group" : void 0;
48
+ const isWhatsAppGroupId = from.toLowerCase().endsWith("@g.us");
49
+ if (!(normalizedChatType === "group" || normalizedChatType === "channel" || from.includes(":group:") || from.includes(":channel:") || isWhatsAppGroupId)) return null;
50
+ const providerHint = ctx.Provider?.trim().toLowerCase();
51
+ const parts = from.split(":").filter(Boolean);
52
+ const head = parts[0]?.trim().toLowerCase() ?? "";
53
+ const headIsSurface = head ? getGroupSurfaces().has(head) : false;
54
+ const provider = headIsSurface ? head : providerHint ?? (isWhatsAppGroupId ? "whatsapp" : void 0);
55
+ if (!provider) return null;
56
+ const second = parts[1]?.trim().toLowerCase();
57
+ const secondIsKind = second === "group" || second === "channel";
58
+ const kind = secondIsKind ? second : from.includes(":channel:") || normalizedChatType === "channel" ? "channel" : "group";
59
+ const finalId = (headIsSurface ? secondIsKind ? parts.slice(2).join(":") : parts.slice(1).join(":") : from).trim().toLowerCase();
60
+ if (!finalId) return null;
61
+ return {
62
+ key: `${provider}:${kind}:${finalId}`,
63
+ channel: provider,
64
+ id: finalId,
65
+ chatType: kind === "channel" ? "channel" : "group"
66
+ };
67
+ }
68
+ //#endregion
69
+ //#region src/channels/conversation-label.ts
70
+ function extractConversationId(from) {
71
+ const trimmed = from?.trim();
72
+ if (!trimmed) return;
73
+ const parts = trimmed.split(":").filter(Boolean);
74
+ return parts.length > 0 ? parts[parts.length - 1] : trimmed;
75
+ }
76
+ function shouldAppendId(id) {
77
+ if (/^[0-9]+$/.test(id)) return true;
78
+ if (id.includes("@g.us")) return true;
79
+ return false;
80
+ }
81
+ function resolveConversationLabel(ctx) {
82
+ const explicit = ctx.ConversationLabel?.trim();
83
+ if (explicit) return explicit;
84
+ const threadLabel = ctx.ThreadLabel?.trim();
85
+ if (threadLabel) return threadLabel;
86
+ if (normalizeChatType(ctx.ChatType) === "direct") return ctx.SenderName?.trim() || ctx.From?.trim() || void 0;
87
+ const base = ctx.GroupChannel?.trim() || ctx.GroupSubject?.trim() || ctx.GroupSpace?.trim() || ctx.From?.trim() || "";
88
+ if (!base) return;
89
+ const id = extractConversationId(ctx.From);
90
+ if (!id) return base;
91
+ if (!shouldAppendId(id)) return base;
92
+ if (base === id) return base;
93
+ if (base.includes(id)) return base;
94
+ if (base.toLowerCase().includes(" id:")) return base;
95
+ if (base.startsWith("#") || base.startsWith("@")) return base;
96
+ return `${base} id:${id}`;
97
+ }
98
+ //#endregion
99
+ //#region src/config/sessions/metadata.ts
100
+ const mergeOrigin = (existing, next) => {
101
+ if (!existing && !next) return;
102
+ const merged = existing ? { ...existing } : {};
103
+ if (next?.label) merged.label = next.label;
104
+ if (next?.provider) merged.provider = next.provider;
105
+ if (next?.surface) merged.surface = next.surface;
106
+ if (next?.chatType) merged.chatType = next.chatType;
107
+ if (next?.from) merged.from = next.from;
108
+ if (next?.to) merged.to = next.to;
109
+ if (next?.accountId) merged.accountId = next.accountId;
110
+ if (next?.threadId != null && next.threadId !== "") merged.threadId = next.threadId;
111
+ return Object.keys(merged).length > 0 ? merged : void 0;
112
+ };
113
+ function deriveSessionOrigin(ctx) {
114
+ const label = resolveConversationLabel(ctx)?.trim();
115
+ const provider = normalizeMessageChannel(typeof ctx.OriginatingChannel === "string" && ctx.OriginatingChannel || ctx.Surface || ctx.Provider);
116
+ const surface = ctx.Surface?.trim().toLowerCase();
117
+ const chatType = normalizeChatType(ctx.ChatType) ?? void 0;
118
+ const from = ctx.From?.trim();
119
+ const to = (typeof ctx.OriginatingTo === "string" ? ctx.OriginatingTo : ctx.To)?.trim() ?? void 0;
120
+ const accountId = ctx.AccountId?.trim();
121
+ const threadId = ctx.MessageThreadId ?? void 0;
122
+ const origin = {};
123
+ if (label) origin.label = label;
124
+ if (provider) origin.provider = provider;
125
+ if (surface) origin.surface = surface;
126
+ if (chatType) origin.chatType = chatType;
127
+ if (from) origin.from = from;
128
+ if (to) origin.to = to;
129
+ if (accountId) origin.accountId = accountId;
130
+ if (threadId != null && threadId !== "") origin.threadId = threadId;
131
+ return Object.keys(origin).length > 0 ? origin : void 0;
132
+ }
133
+ function snapshotSessionOrigin(entry) {
134
+ if (!entry?.origin) return;
135
+ return { ...entry.origin };
136
+ }
137
+ function deriveGroupSessionPatch(params) {
138
+ const resolution = params.groupResolution ?? resolveGroupSessionKey(params.ctx);
139
+ if (!resolution?.channel) return null;
140
+ const channel = resolution.channel;
141
+ const subject = params.ctx.GroupSubject?.trim();
142
+ const space = params.ctx.GroupSpace?.trim();
143
+ const explicitChannel = params.ctx.GroupChannel?.trim();
144
+ const normalizedChannel = normalizeChannelId(channel);
145
+ const isChannelProvider = Boolean(normalizedChannel && getChannelPlugin(normalizedChannel)?.capabilities.chatTypes.includes("channel"));
146
+ const nextGroupChannel = explicitChannel ?? ((resolution.chatType === "channel" || isChannelProvider) && subject && subject.startsWith("#") ? subject : void 0);
147
+ const nextSubject = nextGroupChannel ? void 0 : subject;
148
+ const patch = {
149
+ chatType: resolution.chatType ?? "group",
150
+ channel,
151
+ groupId: resolution.id
152
+ };
153
+ if (nextSubject) patch.subject = nextSubject;
154
+ if (nextGroupChannel) patch.groupChannel = nextGroupChannel;
155
+ if (space) patch.space = space;
156
+ const displayName = buildGroupDisplayName({
157
+ provider: channel,
158
+ subject: nextSubject ?? params.existing?.subject,
159
+ groupChannel: nextGroupChannel ?? params.existing?.groupChannel,
160
+ space: space ?? params.existing?.space,
161
+ id: resolution.id,
162
+ key: params.sessionKey
163
+ });
164
+ if (displayName) patch.displayName = displayName;
165
+ return patch;
166
+ }
167
+ function deriveSessionMetaPatch(params) {
168
+ const groupPatch = deriveGroupSessionPatch(params);
169
+ const origin = deriveSessionOrigin(params.ctx);
170
+ if (!groupPatch && !origin) return null;
171
+ const patch = groupPatch ? { ...groupPatch } : {};
172
+ const mergedOrigin = mergeOrigin(params.existing?.origin, origin);
173
+ if (mergedOrigin) patch.origin = mergedOrigin;
174
+ return Object.keys(patch).length > 0 ? patch : null;
175
+ }
176
+ //#endregion
177
+ //#region src/gateway/session-archive.fs.ts
178
+ function canonicalizePathForComparison$1(filePath) {
179
+ const resolved = path.resolve(filePath);
180
+ try {
181
+ return fs.realpathSync(resolved);
182
+ } catch {
183
+ return resolved;
184
+ }
185
+ }
186
+ function resolveSessionTranscriptCandidates(sessionId, storePath, sessionFile, agentId) {
187
+ const candidates = [];
188
+ const pushCandidate = (resolve) => {
189
+ try {
190
+ candidates.push(resolve());
191
+ } catch {}
192
+ };
193
+ if (storePath) {
194
+ const sessionsDir = path.dirname(storePath);
195
+ if (sessionFile) pushCandidate(() => resolveSessionFilePath(sessionId, { sessionFile }, {
196
+ sessionsDir,
197
+ agentId
198
+ }));
199
+ pushCandidate(() => resolveSessionTranscriptPathInDir(sessionId, sessionsDir));
200
+ } else if (sessionFile) if (agentId) pushCandidate(() => resolveSessionFilePath(sessionId, { sessionFile }, { agentId }));
201
+ else {
202
+ const trimmed = sessionFile.trim();
203
+ if (trimmed) candidates.push(path.resolve(trimmed));
204
+ }
205
+ if (agentId) pushCandidate(() => resolveSessionTranscriptPath(sessionId, agentId));
206
+ const home = resolveRequiredHomeDir(process.env, os.homedir);
207
+ const legacyDir = path.join(home, ".openclaw", "sessions");
208
+ pushCandidate(() => resolveSessionTranscriptPathInDir(sessionId, legacyDir));
209
+ return Array.from(new Set(candidates));
210
+ }
211
+ function archiveFileOnDisk(filePath, reason) {
212
+ const archived = `${filePath}.${reason}.${formatSessionArchiveTimestamp()}`;
213
+ fs.renameSync(filePath, archived);
214
+ return archived;
215
+ }
216
+ function archiveSessionTranscripts(opts) {
217
+ const archived = [];
218
+ const storeDir = opts.restrictToStoreDir && opts.storePath ? canonicalizePathForComparison$1(path.dirname(opts.storePath)) : null;
219
+ for (const candidate of resolveSessionTranscriptCandidates(opts.sessionId, opts.storePath, opts.sessionFile, opts.agentId)) {
220
+ const candidatePath = canonicalizePathForComparison$1(candidate);
221
+ if (storeDir) {
222
+ const relative = path.relative(storeDir, candidatePath);
223
+ if (!relative || relative.startsWith("..") || path.isAbsolute(relative)) continue;
224
+ }
225
+ if (!fs.existsSync(candidatePath)) continue;
226
+ try {
227
+ archived.push(archiveFileOnDisk(candidatePath, opts.reason));
228
+ } catch {}
229
+ }
230
+ return archived;
231
+ }
232
+ async function cleanupArchivedSessionTranscripts(opts) {
233
+ if (!Number.isFinite(opts.olderThanMs) || opts.olderThanMs < 0) return {
234
+ removed: 0,
235
+ scanned: 0
236
+ };
237
+ const now = opts.nowMs ?? Date.now();
238
+ const reason = opts.reason ?? "deleted";
239
+ const directories = Array.from(new Set(opts.directories.map((dir) => path.resolve(dir))));
240
+ let removed = 0;
241
+ let scanned = 0;
242
+ for (const dir of directories) {
243
+ const entries = await fs.promises.readdir(dir).catch(() => []);
244
+ for (const entry of entries) {
245
+ const timestamp = parseSessionArchiveTimestamp(entry, reason);
246
+ if (timestamp == null) continue;
247
+ scanned += 1;
248
+ if (now - timestamp <= opts.olderThanMs) continue;
249
+ const fullPath = path.join(dir, entry);
250
+ if (!(await fs.promises.stat(fullPath).catch(() => null))?.isFile()) continue;
251
+ await fs.promises.rm(fullPath).catch(() => void 0);
252
+ removed += 1;
253
+ }
254
+ }
255
+ return {
256
+ removed,
257
+ scanned
258
+ };
259
+ }
260
+ //#endregion
261
+ //#region src/utils/account-id.ts
262
+ function normalizeAccountId(value) {
263
+ return normalizeOptionalAccountId(value);
264
+ }
265
+ //#endregion
266
+ //#region src/utils/delivery-context.ts
267
+ function normalizeDeliveryContext(context) {
268
+ if (!context) return;
269
+ const channel = typeof context.channel === "string" ? normalizeMessageChannel(context.channel) ?? context.channel.trim() : void 0;
270
+ const to = typeof context.to === "string" ? context.to.trim() : void 0;
271
+ const accountId = normalizeAccountId(context.accountId);
272
+ const threadId = typeof context.threadId === "number" && Number.isFinite(context.threadId) ? Math.trunc(context.threadId) : typeof context.threadId === "string" ? context.threadId.trim() : void 0;
273
+ const normalizedThreadId = typeof threadId === "string" ? threadId ? threadId : void 0 : threadId;
274
+ if (!channel && !to && !accountId && normalizedThreadId == null) return;
275
+ const normalized = {
276
+ channel: channel || void 0,
277
+ to: to || void 0,
278
+ accountId
279
+ };
280
+ if (normalizedThreadId != null) normalized.threadId = normalizedThreadId;
281
+ return normalized;
282
+ }
283
+ function formatConversationTarget(params) {
284
+ const channel = typeof params.channel === "string" ? normalizeMessageChannel(params.channel) ?? params.channel.trim() : void 0;
285
+ const conversationId = typeof params.conversationId === "number" && Number.isFinite(params.conversationId) ? String(Math.trunc(params.conversationId)) : typeof params.conversationId === "string" ? params.conversationId.trim() : void 0;
286
+ if (!channel || !conversationId) return;
287
+ if (channel === "matrix") {
288
+ const parentConversationId = typeof params.parentConversationId === "number" && Number.isFinite(params.parentConversationId) ? String(Math.trunc(params.parentConversationId)) : typeof params.parentConversationId === "string" ? params.parentConversationId.trim() : void 0;
289
+ return `room:${parentConversationId && parentConversationId !== conversationId ? parentConversationId : conversationId}`;
290
+ }
291
+ return `channel:${conversationId}`;
292
+ }
293
+ function resolveConversationDeliveryTarget(params) {
294
+ const to = formatConversationTarget(params);
295
+ const channel = typeof params.channel === "string" ? normalizeMessageChannel(params.channel) ?? params.channel.trim() : void 0;
296
+ const conversationId = typeof params.conversationId === "number" && Number.isFinite(params.conversationId) ? String(Math.trunc(params.conversationId)) : typeof params.conversationId === "string" ? params.conversationId.trim() : void 0;
297
+ const parentConversationId = typeof params.parentConversationId === "number" && Number.isFinite(params.parentConversationId) ? String(Math.trunc(params.parentConversationId)) : typeof params.parentConversationId === "string" ? params.parentConversationId.trim() : void 0;
298
+ if (channel === "matrix" && to && conversationId && parentConversationId && parentConversationId !== conversationId) return {
299
+ to,
300
+ threadId: conversationId
301
+ };
302
+ return { to };
303
+ }
304
+ function normalizeSessionDeliveryFields(source) {
305
+ if (!source) return {
306
+ deliveryContext: void 0,
307
+ lastChannel: void 0,
308
+ lastTo: void 0,
309
+ lastAccountId: void 0,
310
+ lastThreadId: void 0
311
+ };
312
+ const merged = mergeDeliveryContext(normalizeDeliveryContext({
313
+ channel: source.lastChannel ?? source.channel,
314
+ to: source.lastTo,
315
+ accountId: source.lastAccountId,
316
+ threadId: source.lastThreadId
317
+ }), normalizeDeliveryContext(source.deliveryContext));
318
+ if (!merged) return {
319
+ deliveryContext: void 0,
320
+ lastChannel: void 0,
321
+ lastTo: void 0,
322
+ lastAccountId: void 0,
323
+ lastThreadId: void 0
324
+ };
325
+ return {
326
+ deliveryContext: merged,
327
+ lastChannel: merged.channel,
328
+ lastTo: merged.to,
329
+ lastAccountId: merged.accountId,
330
+ lastThreadId: merged.threadId
331
+ };
332
+ }
333
+ function deliveryContextFromSession(entry) {
334
+ if (!entry) return;
335
+ return normalizeSessionDeliveryFields({
336
+ channel: entry.channel,
337
+ lastChannel: entry.lastChannel,
338
+ lastTo: entry.lastTo,
339
+ lastAccountId: entry.lastAccountId,
340
+ lastThreadId: entry.lastThreadId ?? entry.deliveryContext?.threadId ?? entry.origin?.threadId,
341
+ deliveryContext: entry.deliveryContext
342
+ }).deliveryContext;
343
+ }
344
+ function mergeDeliveryContext(primary, fallback) {
345
+ const normalizedPrimary = normalizeDeliveryContext(primary);
346
+ const normalizedFallback = normalizeDeliveryContext(fallback);
347
+ if (!normalizedPrimary && !normalizedFallback) return;
348
+ const channelsConflict = normalizedPrimary?.channel && normalizedFallback?.channel && normalizedPrimary.channel !== normalizedFallback.channel;
349
+ return normalizeDeliveryContext({
350
+ channel: normalizedPrimary?.channel ?? normalizedFallback?.channel,
351
+ to: channelsConflict ? normalizedPrimary?.to : normalizedPrimary?.to ?? normalizedFallback?.to,
352
+ accountId: channelsConflict ? normalizedPrimary?.accountId : normalizedPrimary?.accountId ?? normalizedFallback?.accountId,
353
+ threadId: channelsConflict ? normalizedPrimary?.threadId : normalizedPrimary?.threadId ?? normalizedFallback?.threadId
354
+ });
355
+ }
356
+ function deliveryContextKey(context) {
357
+ const normalized = normalizeDeliveryContext(context);
358
+ if (!normalized?.channel || !normalized?.to) return;
359
+ const threadId = normalized.threadId != null && normalized.threadId !== "" ? String(normalized.threadId) : "";
360
+ return `${normalized.channel}|${normalized.to}|${normalized.accountId ?? ""}|${threadId}`;
361
+ }
362
+ //#endregion
363
+ //#region src/config/cache-utils.ts
364
+ function resolveCacheTtlMs(params) {
365
+ const { envValue, defaultTtlMs } = params;
366
+ if (envValue) {
367
+ const parsed = parseStrictNonNegativeInteger(envValue);
368
+ if (parsed !== void 0) return parsed;
369
+ }
370
+ return defaultTtlMs;
371
+ }
372
+ function isCacheEnabled(ttlMs) {
373
+ return ttlMs > 0;
374
+ }
375
+ function getFileStatSnapshot(filePath) {
376
+ try {
377
+ const stats = fs.statSync(filePath);
378
+ return {
379
+ mtimeMs: stats.mtimeMs,
380
+ sizeBytes: stats.size
381
+ };
382
+ } catch {
383
+ return;
384
+ }
385
+ }
386
+ //#endregion
387
+ //#region src/config/sessions/disk-budget.ts
388
+ const NOOP_LOGGER = {
389
+ warn: () => {},
390
+ info: () => {}
391
+ };
392
+ function canonicalizePathForComparison(filePath) {
393
+ const resolved = path.resolve(filePath);
394
+ try {
395
+ return fs.realpathSync(resolved);
396
+ } catch {
397
+ return resolved;
398
+ }
399
+ }
400
+ function measureStoreBytes(store) {
401
+ return Buffer.byteLength(JSON.stringify(store, null, 2), "utf-8");
402
+ }
403
+ function measureStoreEntryChunkBytes(key, entry) {
404
+ const singleEntryStore = JSON.stringify({ [key]: entry }, null, 2);
405
+ if (!singleEntryStore.startsWith("{\n") || !singleEntryStore.endsWith("\n}")) return measureStoreBytes({ [key]: entry }) - 4;
406
+ const chunk = singleEntryStore.slice(2, -2);
407
+ return Buffer.byteLength(chunk, "utf-8");
408
+ }
409
+ function buildStoreEntryChunkSizeMap(store) {
410
+ const out = /* @__PURE__ */ new Map();
411
+ for (const [key, entry] of Object.entries(store)) out.set(key, measureStoreEntryChunkBytes(key, entry));
412
+ return out;
413
+ }
414
+ function getEntryUpdatedAt$1(entry) {
415
+ if (!entry) return 0;
416
+ const updatedAt = entry.updatedAt;
417
+ return Number.isFinite(updatedAt) ? updatedAt : 0;
418
+ }
419
+ function buildSessionIdRefCounts(store) {
420
+ const counts = /* @__PURE__ */ new Map();
421
+ for (const entry of Object.values(store)) {
422
+ const sessionId = entry?.sessionId;
423
+ if (!sessionId) continue;
424
+ counts.set(sessionId, (counts.get(sessionId) ?? 0) + 1);
425
+ }
426
+ return counts;
427
+ }
428
+ function resolveSessionTranscriptPathForEntry(params) {
429
+ if (!params.entry.sessionId) return null;
430
+ try {
431
+ const resolved = resolveSessionFilePath(params.entry.sessionId, params.entry, { sessionsDir: params.sessionsDir });
432
+ const resolvedSessionsDir = canonicalizePathForComparison(params.sessionsDir);
433
+ const resolvedPath = canonicalizePathForComparison(resolved);
434
+ const relative = path.relative(resolvedSessionsDir, resolvedPath);
435
+ if (!relative || relative.startsWith("..") || path.isAbsolute(relative)) return null;
436
+ return resolvedPath;
437
+ } catch {
438
+ return null;
439
+ }
440
+ }
441
+ function resolveReferencedSessionTranscriptPaths(params) {
442
+ const referenced = /* @__PURE__ */ new Set();
443
+ for (const entry of Object.values(params.store)) {
444
+ const resolved = resolveSessionTranscriptPathForEntry({
445
+ sessionsDir: params.sessionsDir,
446
+ entry
447
+ });
448
+ if (resolved) referenced.add(canonicalizePathForComparison(resolved));
449
+ }
450
+ return referenced;
451
+ }
452
+ async function readSessionsDirFiles(sessionsDir) {
453
+ const dirEntries = await fs.promises.readdir(sessionsDir, { withFileTypes: true }).catch(() => []);
454
+ const files = [];
455
+ for (const dirent of dirEntries) {
456
+ if (!dirent.isFile()) continue;
457
+ const filePath = path.join(sessionsDir, dirent.name);
458
+ const stat = await fs.promises.stat(filePath).catch(() => null);
459
+ if (!stat?.isFile()) continue;
460
+ files.push({
461
+ path: filePath,
462
+ canonicalPath: canonicalizePathForComparison(filePath),
463
+ name: dirent.name,
464
+ size: stat.size,
465
+ mtimeMs: stat.mtimeMs
466
+ });
467
+ }
468
+ return files;
469
+ }
470
+ async function removeFileIfExists(filePath) {
471
+ const stat = await fs.promises.stat(filePath).catch(() => null);
472
+ if (!stat?.isFile()) return 0;
473
+ await fs.promises.rm(filePath, { force: true }).catch(() => void 0);
474
+ return stat.size;
475
+ }
476
+ async function removeFileForBudget(params) {
477
+ const resolvedPath = path.resolve(params.filePath);
478
+ const canonicalPath = params.canonicalPath ?? canonicalizePathForComparison(resolvedPath);
479
+ if (params.dryRun) {
480
+ if (params.simulatedRemovedPaths.has(canonicalPath)) return 0;
481
+ const size = params.fileSizesByPath.get(canonicalPath) ?? 0;
482
+ if (size <= 0) return 0;
483
+ params.simulatedRemovedPaths.add(canonicalPath);
484
+ return size;
485
+ }
486
+ return removeFileIfExists(resolvedPath);
487
+ }
488
+ async function enforceSessionDiskBudget(params) {
489
+ const maxBytes = params.maintenance.maxDiskBytes;
490
+ const highWaterBytes = params.maintenance.highWaterBytes;
491
+ if (maxBytes == null || highWaterBytes == null) return null;
492
+ const log = params.log ?? NOOP_LOGGER;
493
+ const dryRun = params.dryRun === true;
494
+ const sessionsDir = path.dirname(params.storePath);
495
+ const files = await readSessionsDirFiles(sessionsDir);
496
+ const fileSizesByPath = new Map(files.map((file) => [file.canonicalPath, file.size]));
497
+ const simulatedRemovedPaths = /* @__PURE__ */ new Set();
498
+ const resolvedStorePath = canonicalizePathForComparison(params.storePath);
499
+ const storeFile = files.find((file) => file.canonicalPath === resolvedStorePath);
500
+ let projectedStoreBytes = measureStoreBytes(params.store);
501
+ let total = files.reduce((sum, file) => sum + file.size, 0) - (storeFile?.size ?? 0) + projectedStoreBytes;
502
+ const totalBefore = total;
503
+ if (total <= maxBytes) return {
504
+ totalBytesBefore: totalBefore,
505
+ totalBytesAfter: total,
506
+ removedFiles: 0,
507
+ removedEntries: 0,
508
+ freedBytes: 0,
509
+ maxBytes,
510
+ highWaterBytes,
511
+ overBudget: false
512
+ };
513
+ if (params.warnOnly) {
514
+ log.warn("session disk budget exceeded (warn-only mode)", {
515
+ sessionsDir,
516
+ totalBytes: total,
517
+ maxBytes,
518
+ highWaterBytes
519
+ });
520
+ return {
521
+ totalBytesBefore: totalBefore,
522
+ totalBytesAfter: total,
523
+ removedFiles: 0,
524
+ removedEntries: 0,
525
+ freedBytes: 0,
526
+ maxBytes,
527
+ highWaterBytes,
528
+ overBudget: true
529
+ };
530
+ }
531
+ let removedFiles = 0;
532
+ let removedEntries = 0;
533
+ let freedBytes = 0;
534
+ const referencedPaths = resolveReferencedSessionTranscriptPaths({
535
+ sessionsDir,
536
+ store: params.store
537
+ });
538
+ const removableFileQueue = files.filter((file) => isSessionArchiveArtifactName(file.name) || isPrimarySessionTranscriptFileName(file.name) && !referencedPaths.has(file.canonicalPath)).toSorted((a, b) => a.mtimeMs - b.mtimeMs);
539
+ for (const file of removableFileQueue) {
540
+ if (total <= highWaterBytes) break;
541
+ const deletedBytes = await removeFileForBudget({
542
+ filePath: file.path,
543
+ canonicalPath: file.canonicalPath,
544
+ dryRun,
545
+ fileSizesByPath,
546
+ simulatedRemovedPaths
547
+ });
548
+ if (deletedBytes <= 0) continue;
549
+ total -= deletedBytes;
550
+ freedBytes += deletedBytes;
551
+ removedFiles += 1;
552
+ }
553
+ if (total > highWaterBytes) {
554
+ const activeSessionKey = params.activeSessionKey?.trim().toLowerCase();
555
+ const sessionIdRefCounts = buildSessionIdRefCounts(params.store);
556
+ const entryChunkBytesByKey = buildStoreEntryChunkSizeMap(params.store);
557
+ const keys = Object.keys(params.store).toSorted((a, b) => {
558
+ return getEntryUpdatedAt$1(params.store[a]) - getEntryUpdatedAt$1(params.store[b]);
559
+ });
560
+ for (const key of keys) {
561
+ if (total <= highWaterBytes) break;
562
+ if (activeSessionKey && key.trim().toLowerCase() === activeSessionKey) continue;
563
+ const entry = params.store[key];
564
+ if (!entry) continue;
565
+ const previousProjectedBytes = projectedStoreBytes;
566
+ delete params.store[key];
567
+ const chunkBytes = entryChunkBytesByKey.get(key);
568
+ entryChunkBytesByKey.delete(key);
569
+ if (typeof chunkBytes === "number" && Number.isFinite(chunkBytes) && chunkBytes >= 0) projectedStoreBytes = Math.max(2, projectedStoreBytes - (chunkBytes + 2));
570
+ else projectedStoreBytes = measureStoreBytes(params.store);
571
+ total += projectedStoreBytes - previousProjectedBytes;
572
+ removedEntries += 1;
573
+ const sessionId = entry.sessionId;
574
+ if (!sessionId) continue;
575
+ const nextRefCount = (sessionIdRefCounts.get(sessionId) ?? 1) - 1;
576
+ if (nextRefCount > 0) {
577
+ sessionIdRefCounts.set(sessionId, nextRefCount);
578
+ continue;
579
+ }
580
+ sessionIdRefCounts.delete(sessionId);
581
+ const transcriptPath = resolveSessionTranscriptPathForEntry({
582
+ sessionsDir,
583
+ entry
584
+ });
585
+ if (!transcriptPath) continue;
586
+ const deletedBytes = await removeFileForBudget({
587
+ filePath: transcriptPath,
588
+ dryRun,
589
+ fileSizesByPath,
590
+ simulatedRemovedPaths
591
+ });
592
+ if (deletedBytes <= 0) continue;
593
+ total -= deletedBytes;
594
+ freedBytes += deletedBytes;
595
+ removedFiles += 1;
596
+ }
597
+ }
598
+ if (!dryRun) {
599
+ if (total > highWaterBytes) log.warn("session disk budget still above high-water target after cleanup", {
600
+ sessionsDir,
601
+ totalBytes: total,
602
+ maxBytes,
603
+ highWaterBytes,
604
+ removedFiles,
605
+ removedEntries
606
+ });
607
+ else if (removedFiles > 0 || removedEntries > 0) log.info("applied session disk budget cleanup", {
608
+ sessionsDir,
609
+ totalBytesBefore: totalBefore,
610
+ totalBytesAfter: total,
611
+ maxBytes,
612
+ highWaterBytes,
613
+ removedFiles,
614
+ removedEntries
615
+ });
616
+ }
617
+ return {
618
+ totalBytesBefore: totalBefore,
619
+ totalBytesAfter: total,
620
+ removedFiles,
621
+ removedEntries,
622
+ freedBytes,
623
+ maxBytes,
624
+ highWaterBytes,
625
+ overBudget: true
626
+ };
627
+ }
628
+ //#endregion
629
+ //#region src/config/sessions/store-cache.ts
630
+ const SESSION_STORE_CACHE = /* @__PURE__ */ new Map();
631
+ const SESSION_STORE_SERIALIZED_CACHE = /* @__PURE__ */ new Map();
632
+ function invalidateSessionStoreCache(storePath) {
633
+ SESSION_STORE_CACHE.delete(storePath);
634
+ SESSION_STORE_SERIALIZED_CACHE.delete(storePath);
635
+ }
636
+ function getSerializedSessionStore(storePath) {
637
+ return SESSION_STORE_SERIALIZED_CACHE.get(storePath);
638
+ }
639
+ function setSerializedSessionStore(storePath, serialized) {
640
+ if (serialized === void 0) {
641
+ SESSION_STORE_SERIALIZED_CACHE.delete(storePath);
642
+ return;
643
+ }
644
+ SESSION_STORE_SERIALIZED_CACHE.set(storePath, serialized);
645
+ }
646
+ function dropSessionStoreObjectCache(storePath) {
647
+ SESSION_STORE_CACHE.delete(storePath);
648
+ }
649
+ function readSessionStoreCache(params) {
650
+ const cached = SESSION_STORE_CACHE.get(params.storePath);
651
+ if (!cached) return null;
652
+ if (Date.now() - cached.loadedAt > params.ttlMs) {
653
+ invalidateSessionStoreCache(params.storePath);
654
+ return null;
655
+ }
656
+ if (params.mtimeMs !== cached.mtimeMs || params.sizeBytes !== cached.sizeBytes) {
657
+ invalidateSessionStoreCache(params.storePath);
658
+ return null;
659
+ }
660
+ return structuredClone(cached.store);
661
+ }
662
+ function writeSessionStoreCache(params) {
663
+ SESSION_STORE_CACHE.set(params.storePath, {
664
+ store: structuredClone(params.store),
665
+ loadedAt: Date.now(),
666
+ storePath: params.storePath,
667
+ mtimeMs: params.mtimeMs,
668
+ sizeBytes: params.sizeBytes,
669
+ serialized: params.serialized
670
+ });
671
+ if (params.serialized !== void 0) SESSION_STORE_SERIALIZED_CACHE.set(params.storePath, params.serialized);
672
+ }
673
+ //#endregion
674
+ //#region src/config/sessions/store-maintenance.ts
675
+ const log$1 = createSubsystemLogger("sessions/store");
676
+ const DEFAULT_SESSION_PRUNE_AFTER_MS = 720 * 60 * 60 * 1e3;
677
+ const DEFAULT_SESSION_MAX_ENTRIES = 500;
678
+ const DEFAULT_SESSION_ROTATE_BYTES = 10485760;
679
+ const DEFAULT_SESSION_MAINTENANCE_MODE = "warn";
680
+ const DEFAULT_SESSION_DISK_BUDGET_HIGH_WATER_RATIO = .8;
681
+ function resolvePruneAfterMs(maintenance) {
682
+ const raw = maintenance?.pruneAfter ?? maintenance?.pruneDays;
683
+ if (raw === void 0 || raw === null || raw === "") return DEFAULT_SESSION_PRUNE_AFTER_MS;
684
+ try {
685
+ return parseDurationMs(String(raw).trim(), { defaultUnit: "d" });
686
+ } catch {
687
+ return DEFAULT_SESSION_PRUNE_AFTER_MS;
688
+ }
689
+ }
690
+ function resolveRotateBytes(maintenance) {
691
+ const raw = maintenance?.rotateBytes;
692
+ if (raw === void 0 || raw === null || raw === "") return DEFAULT_SESSION_ROTATE_BYTES;
693
+ try {
694
+ return parseByteSize(String(raw).trim(), { defaultUnit: "b" });
695
+ } catch {
696
+ return DEFAULT_SESSION_ROTATE_BYTES;
697
+ }
698
+ }
699
+ function resolveResetArchiveRetentionMs(maintenance, pruneAfterMs) {
700
+ const raw = maintenance?.resetArchiveRetention;
701
+ if (raw === false) return null;
702
+ if (raw === void 0 || raw === null || raw === "") return pruneAfterMs;
703
+ try {
704
+ return parseDurationMs(String(raw).trim(), { defaultUnit: "d" });
705
+ } catch {
706
+ return pruneAfterMs;
707
+ }
708
+ }
709
+ function resolveMaxDiskBytes(maintenance) {
710
+ const raw = maintenance?.maxDiskBytes;
711
+ if (raw === void 0 || raw === null || raw === "") return null;
712
+ try {
713
+ return parseByteSize(String(raw).trim(), { defaultUnit: "b" });
714
+ } catch {
715
+ return null;
716
+ }
717
+ }
718
+ function resolveHighWaterBytes(maintenance, maxDiskBytes) {
719
+ const computeDefault = () => {
720
+ if (maxDiskBytes == null) return null;
721
+ if (maxDiskBytes <= 0) return 0;
722
+ return Math.max(1, Math.min(maxDiskBytes, Math.floor(maxDiskBytes * DEFAULT_SESSION_DISK_BUDGET_HIGH_WATER_RATIO)));
723
+ };
724
+ if (maxDiskBytes == null) return null;
725
+ const raw = maintenance?.highWaterBytes;
726
+ if (raw === void 0 || raw === null || raw === "") return computeDefault();
727
+ try {
728
+ const parsed = parseByteSize(String(raw).trim(), { defaultUnit: "b" });
729
+ return Math.min(parsed, maxDiskBytes);
730
+ } catch {
731
+ return computeDefault();
732
+ }
733
+ }
734
+ /**
735
+ * Resolve maintenance settings from openclaw.json (`session.maintenance`).
736
+ * Falls back to built-in defaults when config is missing or unset.
737
+ */
738
+ function resolveMaintenanceConfig() {
739
+ let maintenance;
740
+ try {
741
+ maintenance = loadConfig().session?.maintenance;
742
+ } catch {}
743
+ const pruneAfterMs = resolvePruneAfterMs(maintenance);
744
+ const maxDiskBytes = resolveMaxDiskBytes(maintenance);
745
+ return {
746
+ mode: maintenance?.mode ?? DEFAULT_SESSION_MAINTENANCE_MODE,
747
+ pruneAfterMs,
748
+ maxEntries: maintenance?.maxEntries ?? DEFAULT_SESSION_MAX_ENTRIES,
749
+ rotateBytes: resolveRotateBytes(maintenance),
750
+ resetArchiveRetentionMs: resolveResetArchiveRetentionMs(maintenance, pruneAfterMs),
751
+ maxDiskBytes,
752
+ highWaterBytes: resolveHighWaterBytes(maintenance, maxDiskBytes)
753
+ };
754
+ }
755
+ /**
756
+ * Remove entries whose `updatedAt` is older than the configured threshold.
757
+ * Entries without `updatedAt` are kept (cannot determine staleness).
758
+ * Mutates `store` in-place.
759
+ */
760
+ function pruneStaleEntries(store, overrideMaxAgeMs, opts = {}) {
761
+ const maxAgeMs = overrideMaxAgeMs ?? resolveMaintenanceConfig().pruneAfterMs;
762
+ const cutoffMs = Date.now() - maxAgeMs;
763
+ let pruned = 0;
764
+ for (const [key, entry] of Object.entries(store)) if (entry?.updatedAt != null && entry.updatedAt < cutoffMs) {
765
+ opts.onPruned?.({
766
+ key,
767
+ entry
768
+ });
769
+ delete store[key];
770
+ pruned++;
771
+ }
772
+ if (pruned > 0 && opts.log !== false) log$1.info("pruned stale session entries", {
773
+ pruned,
774
+ maxAgeMs
775
+ });
776
+ return pruned;
777
+ }
778
+ function getEntryUpdatedAt(entry) {
779
+ return entry?.updatedAt ?? Number.NEGATIVE_INFINITY;
780
+ }
781
+ function getActiveSessionMaintenanceWarning(params) {
782
+ const activeSessionKey = params.activeSessionKey.trim();
783
+ if (!activeSessionKey) return null;
784
+ const activeEntry = params.store[activeSessionKey];
785
+ if (!activeEntry) return null;
786
+ const cutoffMs = (params.nowMs ?? Date.now()) - params.pruneAfterMs;
787
+ const wouldPrune = activeEntry.updatedAt != null ? activeEntry.updatedAt < cutoffMs : false;
788
+ const keys = Object.keys(params.store);
789
+ const wouldCap = keys.length > params.maxEntries && keys.toSorted((a, b) => getEntryUpdatedAt(params.store[b]) - getEntryUpdatedAt(params.store[a])).slice(params.maxEntries).includes(activeSessionKey);
790
+ if (!wouldPrune && !wouldCap) return null;
791
+ return {
792
+ activeSessionKey,
793
+ activeUpdatedAt: activeEntry.updatedAt,
794
+ totalEntries: keys.length,
795
+ pruneAfterMs: params.pruneAfterMs,
796
+ maxEntries: params.maxEntries,
797
+ wouldPrune,
798
+ wouldCap
799
+ };
800
+ }
801
+ /**
802
+ * Cap the store to the N most recently updated entries.
803
+ * Entries without `updatedAt` are sorted last (removed first when over limit).
804
+ * Mutates `store` in-place.
805
+ */
806
+ function capEntryCount(store, overrideMax, opts = {}) {
807
+ const maxEntries = overrideMax ?? resolveMaintenanceConfig().maxEntries;
808
+ const keys = Object.keys(store);
809
+ if (keys.length <= maxEntries) return 0;
810
+ const toRemove = keys.toSorted((a, b) => {
811
+ const aTime = getEntryUpdatedAt(store[a]);
812
+ return getEntryUpdatedAt(store[b]) - aTime;
813
+ }).slice(maxEntries);
814
+ for (const key of toRemove) {
815
+ const entry = store[key];
816
+ if (entry) opts.onCapped?.({
817
+ key,
818
+ entry
819
+ });
820
+ delete store[key];
821
+ }
822
+ if (opts.log !== false) log$1.info("capped session entry count", {
823
+ removed: toRemove.length,
824
+ maxEntries
825
+ });
826
+ return toRemove.length;
827
+ }
828
+ async function getSessionFileSize(storePath) {
829
+ try {
830
+ return (await fs.promises.stat(storePath)).size;
831
+ } catch {
832
+ return null;
833
+ }
834
+ }
835
+ /**
836
+ * Rotate the sessions file if it exceeds the configured size threshold.
837
+ * Renames the current file to `sessions.json.bak.{timestamp}` and cleans up
838
+ * old rotation backups, keeping only the 3 most recent `.bak.*` files.
839
+ */
840
+ async function rotateSessionFile(storePath, overrideBytes) {
841
+ const maxBytes = overrideBytes ?? resolveMaintenanceConfig().rotateBytes;
842
+ const fileSize = await getSessionFileSize(storePath);
843
+ if (fileSize == null) return false;
844
+ if (fileSize <= maxBytes) return false;
845
+ const backupPath = `${storePath}.bak.${Date.now()}`;
846
+ try {
847
+ await fs.promises.rename(storePath, backupPath);
848
+ log$1.info("rotated session store file", {
849
+ backupPath: path.basename(backupPath),
850
+ sizeBytes: fileSize
851
+ });
852
+ } catch {
853
+ return false;
854
+ }
855
+ try {
856
+ const dir = path.dirname(storePath);
857
+ const baseName = path.basename(storePath);
858
+ const backups = (await fs.promises.readdir(dir)).filter((f) => f.startsWith(`${baseName}.bak.`)).toSorted().toReversed();
859
+ const maxBackups = 3;
860
+ if (backups.length > maxBackups) {
861
+ const toDelete = backups.slice(maxBackups);
862
+ for (const old of toDelete) await fs.promises.unlink(path.join(dir, old)).catch(() => void 0);
863
+ log$1.info("cleaned up old session store backups", { deleted: toDelete.length });
864
+ }
865
+ } catch {}
866
+ return true;
867
+ }
868
+ //#endregion
869
+ //#region src/config/sessions/store-migrations.ts
870
+ function applySessionStoreMigrations(store) {
871
+ for (const entry of Object.values(store)) {
872
+ if (!entry || typeof entry !== "object") continue;
873
+ const rec = entry;
874
+ if (typeof rec.channel !== "string" && typeof rec.provider === "string") {
875
+ rec.channel = rec.provider;
876
+ delete rec.provider;
877
+ }
878
+ if (typeof rec.lastChannel !== "string" && typeof rec.lastProvider === "string") {
879
+ rec.lastChannel = rec.lastProvider;
880
+ delete rec.lastProvider;
881
+ }
882
+ if (typeof rec.groupChannel !== "string" && typeof rec.room === "string") {
883
+ rec.groupChannel = rec.room;
884
+ delete rec.room;
885
+ } else if ("room" in rec) delete rec.room;
886
+ }
887
+ }
888
+ //#endregion
889
+ //#region src/config/sessions/store.ts
890
+ const log = createSubsystemLogger("sessions/store");
891
+ const DEFAULT_SESSION_STORE_TTL_MS = 45e3;
892
+ function isSessionStoreRecord(value) {
893
+ return !!value && typeof value === "object" && !Array.isArray(value);
894
+ }
895
+ function getSessionStoreTtl() {
896
+ return resolveCacheTtlMs({
897
+ envValue: process.env.OPENCLAW_SESSION_CACHE_TTL_MS,
898
+ defaultTtlMs: DEFAULT_SESSION_STORE_TTL_MS
899
+ });
900
+ }
901
+ function isSessionStoreCacheEnabled() {
902
+ return isCacheEnabled(getSessionStoreTtl());
903
+ }
904
+ function normalizeSessionEntryDelivery(entry) {
905
+ const normalized = normalizeSessionDeliveryFields({
906
+ channel: entry.channel,
907
+ lastChannel: entry.lastChannel,
908
+ lastTo: entry.lastTo,
909
+ lastAccountId: entry.lastAccountId,
910
+ lastThreadId: entry.lastThreadId ?? entry.deliveryContext?.threadId ?? entry.origin?.threadId,
911
+ deliveryContext: entry.deliveryContext
912
+ });
913
+ const nextDelivery = normalized.deliveryContext;
914
+ const sameDelivery = (entry.deliveryContext?.channel ?? void 0) === nextDelivery?.channel && (entry.deliveryContext?.to ?? void 0) === nextDelivery?.to && (entry.deliveryContext?.accountId ?? void 0) === nextDelivery?.accountId && (entry.deliveryContext?.threadId ?? void 0) === nextDelivery?.threadId;
915
+ const sameLast = entry.lastChannel === normalized.lastChannel && entry.lastTo === normalized.lastTo && entry.lastAccountId === normalized.lastAccountId && entry.lastThreadId === normalized.lastThreadId;
916
+ if (sameDelivery && sameLast) return entry;
917
+ return {
918
+ ...entry,
919
+ deliveryContext: nextDelivery,
920
+ lastChannel: normalized.lastChannel,
921
+ lastTo: normalized.lastTo,
922
+ lastAccountId: normalized.lastAccountId,
923
+ lastThreadId: normalized.lastThreadId
924
+ };
925
+ }
926
+ function removeThreadFromDeliveryContext(context) {
927
+ if (!context || context.threadId == null) return context;
928
+ const next = { ...context };
929
+ delete next.threadId;
930
+ return next;
931
+ }
932
+ function normalizeStoreSessionKey(sessionKey) {
933
+ return sessionKey.trim().toLowerCase();
934
+ }
935
+ function resolveSessionStoreEntry(params) {
936
+ const trimmedKey = params.sessionKey.trim();
937
+ const normalizedKey = normalizeStoreSessionKey(trimmedKey);
938
+ const legacyKeySet = /* @__PURE__ */ new Set();
939
+ if (trimmedKey !== normalizedKey && Object.prototype.hasOwnProperty.call(params.store, trimmedKey)) legacyKeySet.add(trimmedKey);
940
+ let existing = params.store[normalizedKey] ?? (legacyKeySet.size > 0 ? params.store[trimmedKey] : void 0);
941
+ let existingUpdatedAt = existing?.updatedAt ?? 0;
942
+ for (const [candidateKey, candidateEntry] of Object.entries(params.store)) {
943
+ if (candidateKey === normalizedKey) continue;
944
+ if (candidateKey.toLowerCase() !== normalizedKey) continue;
945
+ legacyKeySet.add(candidateKey);
946
+ const candidateUpdatedAt = candidateEntry?.updatedAt ?? 0;
947
+ if (!existing || candidateUpdatedAt > existingUpdatedAt) {
948
+ existing = candidateEntry;
949
+ existingUpdatedAt = candidateUpdatedAt;
950
+ }
951
+ }
952
+ return {
953
+ normalizedKey,
954
+ existing,
955
+ legacyKeys: [...legacyKeySet]
956
+ };
957
+ }
958
+ function normalizeSessionStore(store) {
959
+ for (const [key, entry] of Object.entries(store)) {
960
+ if (!entry) continue;
961
+ const normalized = normalizeSessionEntryDelivery(normalizeSessionRuntimeModelFields(entry));
962
+ if (normalized !== entry) store[key] = normalized;
963
+ }
964
+ }
965
+ function loadSessionStore(storePath, opts = {}) {
966
+ if (!opts.skipCache && isSessionStoreCacheEnabled()) {
967
+ const currentFileStat = getFileStatSnapshot(storePath);
968
+ const cached = readSessionStoreCache({
969
+ storePath,
970
+ ttlMs: getSessionStoreTtl(),
971
+ mtimeMs: currentFileStat?.mtimeMs,
972
+ sizeBytes: currentFileStat?.sizeBytes
973
+ });
974
+ if (cached) return cached;
975
+ }
976
+ let store = {};
977
+ let fileStat = getFileStatSnapshot(storePath);
978
+ let mtimeMs = fileStat?.mtimeMs;
979
+ let serializedFromDisk;
980
+ const maxReadAttempts = process.platform === "win32" ? 3 : 1;
981
+ const retryBuf = maxReadAttempts > 1 ? new Int32Array(new SharedArrayBuffer(4)) : void 0;
982
+ for (let attempt = 0; attempt < maxReadAttempts; attempt++) try {
983
+ const raw = fs.readFileSync(storePath, "utf-8");
984
+ if (raw.length === 0 && attempt < maxReadAttempts - 1) {
985
+ Atomics.wait(retryBuf, 0, 0, 50);
986
+ continue;
987
+ }
988
+ const parsed = JSON.parse(raw);
989
+ if (isSessionStoreRecord(parsed)) {
990
+ store = parsed;
991
+ serializedFromDisk = raw;
992
+ }
993
+ fileStat = getFileStatSnapshot(storePath) ?? fileStat;
994
+ mtimeMs = fileStat?.mtimeMs;
995
+ break;
996
+ } catch {
997
+ if (attempt < maxReadAttempts - 1) {
998
+ Atomics.wait(retryBuf, 0, 0, 50);
999
+ continue;
1000
+ }
1001
+ }
1002
+ if (serializedFromDisk !== void 0) setSerializedSessionStore(storePath, serializedFromDisk);
1003
+ else setSerializedSessionStore(storePath, void 0);
1004
+ applySessionStoreMigrations(store);
1005
+ if (!opts.skipCache && isSessionStoreCacheEnabled()) writeSessionStoreCache({
1006
+ storePath,
1007
+ store,
1008
+ mtimeMs,
1009
+ sizeBytes: fileStat?.sizeBytes,
1010
+ serialized: serializedFromDisk
1011
+ });
1012
+ return structuredClone(store);
1013
+ }
1014
+ function readSessionUpdatedAt(params) {
1015
+ try {
1016
+ return resolveSessionStoreEntry({
1017
+ store: loadSessionStore(params.storePath),
1018
+ sessionKey: params.sessionKey
1019
+ }).existing?.updatedAt;
1020
+ } catch {
1021
+ return;
1022
+ }
1023
+ }
1024
+ function updateSessionStoreWriteCaches(params) {
1025
+ const fileStat = getFileStatSnapshot(params.storePath);
1026
+ setSerializedSessionStore(params.storePath, params.serialized);
1027
+ if (!isSessionStoreCacheEnabled()) {
1028
+ dropSessionStoreObjectCache(params.storePath);
1029
+ return;
1030
+ }
1031
+ writeSessionStoreCache({
1032
+ storePath: params.storePath,
1033
+ store: params.store,
1034
+ mtimeMs: fileStat?.mtimeMs,
1035
+ sizeBytes: fileStat?.sizeBytes,
1036
+ serialized: params.serialized
1037
+ });
1038
+ }
1039
+ function resolveMutableSessionStoreKey(store, sessionKey) {
1040
+ const trimmed = sessionKey.trim();
1041
+ if (!trimmed) return;
1042
+ if (Object.prototype.hasOwnProperty.call(store, trimmed)) return trimmed;
1043
+ const normalized = normalizeStoreSessionKey(trimmed);
1044
+ if (Object.prototype.hasOwnProperty.call(store, normalized)) return normalized;
1045
+ return Object.keys(store).find((key) => normalizeStoreSessionKey(key) === normalized);
1046
+ }
1047
+ function collectAcpMetadataSnapshot(store) {
1048
+ const snapshot = /* @__PURE__ */ new Map();
1049
+ for (const [sessionKey, entry] of Object.entries(store)) if (entry?.acp) snapshot.set(sessionKey, entry.acp);
1050
+ return snapshot;
1051
+ }
1052
+ function preserveExistingAcpMetadata(params) {
1053
+ const allowDrop = new Set((params.allowDropSessionKeys ?? []).map((key) => normalizeStoreSessionKey(key)));
1054
+ for (const [previousKey, previousAcp] of params.previousAcpByKey.entries()) {
1055
+ const normalizedKey = normalizeStoreSessionKey(previousKey);
1056
+ if (allowDrop.has(normalizedKey)) continue;
1057
+ const nextKey = resolveMutableSessionStoreKey(params.nextStore, previousKey);
1058
+ if (!nextKey) continue;
1059
+ const nextEntry = params.nextStore[nextKey];
1060
+ if (!nextEntry || nextEntry.acp) continue;
1061
+ params.nextStore[nextKey] = {
1062
+ ...nextEntry,
1063
+ acp: previousAcp
1064
+ };
1065
+ }
1066
+ }
1067
+ async function saveSessionStoreUnlocked(storePath, store, opts) {
1068
+ normalizeSessionStore(store);
1069
+ if (!opts?.skipMaintenance) {
1070
+ const maintenance = {
1071
+ ...resolveMaintenanceConfig(),
1072
+ ...opts?.maintenanceOverride
1073
+ };
1074
+ const shouldWarnOnly = maintenance.mode === "warn";
1075
+ const beforeCount = Object.keys(store).length;
1076
+ if (shouldWarnOnly) {
1077
+ const activeSessionKey = opts?.activeSessionKey?.trim();
1078
+ if (activeSessionKey) {
1079
+ const warning = getActiveSessionMaintenanceWarning({
1080
+ store,
1081
+ activeSessionKey,
1082
+ pruneAfterMs: maintenance.pruneAfterMs,
1083
+ maxEntries: maintenance.maxEntries
1084
+ });
1085
+ if (warning) {
1086
+ log.warn("session maintenance would evict active session; skipping enforcement", {
1087
+ activeSessionKey: warning.activeSessionKey,
1088
+ wouldPrune: warning.wouldPrune,
1089
+ wouldCap: warning.wouldCap,
1090
+ pruneAfterMs: warning.pruneAfterMs,
1091
+ maxEntries: warning.maxEntries
1092
+ });
1093
+ await opts?.onWarn?.(warning);
1094
+ }
1095
+ }
1096
+ const diskBudget = await enforceSessionDiskBudget({
1097
+ store,
1098
+ storePath,
1099
+ activeSessionKey: opts?.activeSessionKey,
1100
+ maintenance,
1101
+ warnOnly: true,
1102
+ log
1103
+ });
1104
+ await opts?.onMaintenanceApplied?.({
1105
+ mode: maintenance.mode,
1106
+ beforeCount,
1107
+ afterCount: Object.keys(store).length,
1108
+ pruned: 0,
1109
+ capped: 0,
1110
+ diskBudget
1111
+ });
1112
+ } else {
1113
+ const removedSessionFiles = /* @__PURE__ */ new Map();
1114
+ const pruned = pruneStaleEntries(store, maintenance.pruneAfterMs, { onPruned: ({ entry }) => {
1115
+ rememberRemovedSessionFile(removedSessionFiles, entry);
1116
+ } });
1117
+ const capped = capEntryCount(store, maintenance.maxEntries, { onCapped: ({ entry }) => {
1118
+ rememberRemovedSessionFile(removedSessionFiles, entry);
1119
+ } });
1120
+ const archivedDirs = /* @__PURE__ */ new Set();
1121
+ const archivedForDeletedSessions = archiveRemovedSessionTranscripts({
1122
+ removedSessionFiles,
1123
+ referencedSessionIds: new Set(Object.values(store).map((entry) => entry?.sessionId).filter((id) => Boolean(id))),
1124
+ storePath,
1125
+ reason: "deleted",
1126
+ restrictToStoreDir: true
1127
+ });
1128
+ for (const archivedDir of archivedForDeletedSessions) archivedDirs.add(archivedDir);
1129
+ if (archivedDirs.size > 0 || maintenance.resetArchiveRetentionMs != null) {
1130
+ const targetDirs = archivedDirs.size > 0 ? [...archivedDirs] : [path.dirname(path.resolve(storePath))];
1131
+ await cleanupArchivedSessionTranscripts({
1132
+ directories: targetDirs,
1133
+ olderThanMs: maintenance.pruneAfterMs,
1134
+ reason: "deleted"
1135
+ });
1136
+ if (maintenance.resetArchiveRetentionMs != null) await cleanupArchivedSessionTranscripts({
1137
+ directories: targetDirs,
1138
+ olderThanMs: maintenance.resetArchiveRetentionMs,
1139
+ reason: "reset"
1140
+ });
1141
+ }
1142
+ await rotateSessionFile(storePath, maintenance.rotateBytes);
1143
+ const diskBudget = await enforceSessionDiskBudget({
1144
+ store,
1145
+ storePath,
1146
+ activeSessionKey: opts?.activeSessionKey,
1147
+ maintenance,
1148
+ warnOnly: false,
1149
+ log
1150
+ });
1151
+ await opts?.onMaintenanceApplied?.({
1152
+ mode: maintenance.mode,
1153
+ beforeCount,
1154
+ afterCount: Object.keys(store).length,
1155
+ pruned,
1156
+ capped,
1157
+ diskBudget
1158
+ });
1159
+ }
1160
+ }
1161
+ await fs.promises.mkdir(path.dirname(storePath), { recursive: true });
1162
+ const json = JSON.stringify(store, null, 2);
1163
+ if (getSerializedSessionStore(storePath) === json) {
1164
+ updateSessionStoreWriteCaches({
1165
+ storePath,
1166
+ store,
1167
+ serialized: json
1168
+ });
1169
+ return;
1170
+ }
1171
+ if (process.platform === "win32") {
1172
+ for (let i = 0; i < 5; i++) try {
1173
+ await writeSessionStoreAtomic({
1174
+ storePath,
1175
+ store,
1176
+ serialized: json
1177
+ });
1178
+ return;
1179
+ } catch (err) {
1180
+ if (getErrorCode(err) === "ENOENT") return;
1181
+ if (i < 4) {
1182
+ await new Promise((r) => setTimeout(r, 50 * (i + 1)));
1183
+ continue;
1184
+ }
1185
+ log.warn(`atomic write failed after 5 attempts: ${storePath}`);
1186
+ }
1187
+ return;
1188
+ }
1189
+ try {
1190
+ await writeSessionStoreAtomic({
1191
+ storePath,
1192
+ store,
1193
+ serialized: json
1194
+ });
1195
+ } catch (err) {
1196
+ if (getErrorCode(err) === "ENOENT") {
1197
+ try {
1198
+ await writeSessionStoreAtomic({
1199
+ storePath,
1200
+ store,
1201
+ serialized: json
1202
+ });
1203
+ } catch (err2) {
1204
+ if (getErrorCode(err2) === "ENOENT") return;
1205
+ throw err2;
1206
+ }
1207
+ return;
1208
+ }
1209
+ throw err;
1210
+ }
1211
+ }
1212
+ async function saveSessionStore(storePath, store, opts) {
1213
+ await withSessionStoreLock(storePath, async () => {
1214
+ await saveSessionStoreUnlocked(storePath, store, opts);
1215
+ });
1216
+ }
1217
+ async function updateSessionStore(storePath, mutator, opts) {
1218
+ return await withSessionStoreLock(storePath, async () => {
1219
+ const store = loadSessionStore(storePath, { skipCache: true });
1220
+ const previousAcpByKey = collectAcpMetadataSnapshot(store);
1221
+ const result = await mutator(store);
1222
+ preserveExistingAcpMetadata({
1223
+ previousAcpByKey,
1224
+ nextStore: store,
1225
+ allowDropSessionKeys: opts?.allowDropAcpMetaSessionKeys
1226
+ });
1227
+ await saveSessionStoreUnlocked(storePath, store, opts);
1228
+ return result;
1229
+ });
1230
+ }
1231
+ const LOCK_QUEUES = /* @__PURE__ */ new Map();
1232
+ function getErrorCode(error) {
1233
+ if (!error || typeof error !== "object" || !("code" in error)) return null;
1234
+ return String(error.code);
1235
+ }
1236
+ function rememberRemovedSessionFile(removedSessionFiles, entry) {
1237
+ if (!removedSessionFiles.has(entry.sessionId) || entry.sessionFile) removedSessionFiles.set(entry.sessionId, entry.sessionFile);
1238
+ }
1239
+ function archiveRemovedSessionTranscripts(params) {
1240
+ const archivedDirs = /* @__PURE__ */ new Set();
1241
+ for (const [sessionId, sessionFile] of params.removedSessionFiles) {
1242
+ if (params.referencedSessionIds.has(sessionId)) continue;
1243
+ const archived = archiveSessionTranscripts({
1244
+ sessionId,
1245
+ storePath: params.storePath,
1246
+ sessionFile,
1247
+ reason: params.reason,
1248
+ restrictToStoreDir: params.restrictToStoreDir
1249
+ });
1250
+ for (const archivedPath of archived) archivedDirs.add(path.dirname(archivedPath));
1251
+ }
1252
+ return archivedDirs;
1253
+ }
1254
+ async function writeSessionStoreAtomic(params) {
1255
+ await writeTextAtomic(params.storePath, params.serialized, { mode: 384 });
1256
+ updateSessionStoreWriteCaches({
1257
+ storePath: params.storePath,
1258
+ store: params.store,
1259
+ serialized: params.serialized
1260
+ });
1261
+ }
1262
+ async function persistResolvedSessionEntry(params) {
1263
+ params.store[params.resolved.normalizedKey] = params.next;
1264
+ for (const legacyKey of params.resolved.legacyKeys) delete params.store[legacyKey];
1265
+ await saveSessionStoreUnlocked(params.storePath, params.store, { activeSessionKey: params.resolved.normalizedKey });
1266
+ return params.next;
1267
+ }
1268
+ function lockTimeoutError(storePath) {
1269
+ return /* @__PURE__ */ new Error(`timeout waiting for session store lock: ${storePath}`);
1270
+ }
1271
+ function getOrCreateLockQueue(storePath) {
1272
+ const existing = LOCK_QUEUES.get(storePath);
1273
+ if (existing) return existing;
1274
+ const created = {
1275
+ running: false,
1276
+ pending: []
1277
+ };
1278
+ LOCK_QUEUES.set(storePath, created);
1279
+ return created;
1280
+ }
1281
+ async function drainSessionStoreLockQueue(storePath) {
1282
+ const queue = LOCK_QUEUES.get(storePath);
1283
+ if (!queue || queue.running) return;
1284
+ queue.running = true;
1285
+ try {
1286
+ while (queue.pending.length > 0) {
1287
+ const task = queue.pending.shift();
1288
+ if (!task) continue;
1289
+ const remainingTimeoutMs = task.timeoutMs ?? Number.POSITIVE_INFINITY;
1290
+ if (task.timeoutMs != null && remainingTimeoutMs <= 0) {
1291
+ task.reject(lockTimeoutError(storePath));
1292
+ continue;
1293
+ }
1294
+ let lock;
1295
+ let result;
1296
+ let failed;
1297
+ let hasFailure = false;
1298
+ try {
1299
+ lock = await acquireSessionWriteLock({
1300
+ sessionFile: storePath,
1301
+ timeoutMs: remainingTimeoutMs,
1302
+ staleMs: task.staleMs
1303
+ });
1304
+ result = await task.fn();
1305
+ } catch (err) {
1306
+ hasFailure = true;
1307
+ failed = err;
1308
+ } finally {
1309
+ await lock?.release().catch(() => void 0);
1310
+ }
1311
+ if (hasFailure) {
1312
+ task.reject(failed);
1313
+ continue;
1314
+ }
1315
+ task.resolve(result);
1316
+ }
1317
+ } finally {
1318
+ queue.running = false;
1319
+ if (queue.pending.length === 0) LOCK_QUEUES.delete(storePath);
1320
+ else queueMicrotask(() => {
1321
+ drainSessionStoreLockQueue(storePath);
1322
+ });
1323
+ }
1324
+ }
1325
+ async function withSessionStoreLock(storePath, fn, opts = {}) {
1326
+ if (!storePath || typeof storePath !== "string") throw new Error(`withSessionStoreLock: storePath must be a non-empty string, got ${JSON.stringify(storePath)}`);
1327
+ const timeoutMs = opts.timeoutMs ?? 1e4;
1328
+ const staleMs = opts.staleMs ?? 3e4;
1329
+ opts.pollIntervalMs;
1330
+ const hasTimeout = timeoutMs > 0 && Number.isFinite(timeoutMs);
1331
+ const queue = getOrCreateLockQueue(storePath);
1332
+ return await new Promise((resolve, reject) => {
1333
+ const task = {
1334
+ fn: async () => await fn(),
1335
+ resolve: (value) => resolve(value),
1336
+ reject,
1337
+ timeoutMs: hasTimeout ? timeoutMs : void 0,
1338
+ staleMs
1339
+ };
1340
+ queue.pending.push(task);
1341
+ drainSessionStoreLockQueue(storePath);
1342
+ });
1343
+ }
1344
+ async function updateSessionStoreEntry(params) {
1345
+ const { storePath, sessionKey, update } = params;
1346
+ return await withSessionStoreLock(storePath, async () => {
1347
+ const store = loadSessionStore(storePath, { skipCache: true });
1348
+ const resolved = resolveSessionStoreEntry({
1349
+ store,
1350
+ sessionKey
1351
+ });
1352
+ const existing = resolved.existing;
1353
+ if (!existing) return null;
1354
+ const patch = await update(existing);
1355
+ if (!patch) return existing;
1356
+ return await persistResolvedSessionEntry({
1357
+ storePath,
1358
+ store,
1359
+ resolved,
1360
+ next: mergeSessionEntry(existing, patch)
1361
+ });
1362
+ });
1363
+ }
1364
+ async function recordSessionMetaFromInbound(params) {
1365
+ const { storePath, sessionKey, ctx } = params;
1366
+ const createIfMissing = params.createIfMissing ?? true;
1367
+ return await updateSessionStore(storePath, (store) => {
1368
+ const resolved = resolveSessionStoreEntry({
1369
+ store,
1370
+ sessionKey
1371
+ });
1372
+ const existing = resolved.existing;
1373
+ const patch = deriveSessionMetaPatch({
1374
+ ctx,
1375
+ sessionKey: resolved.normalizedKey,
1376
+ existing,
1377
+ groupResolution: params.groupResolution
1378
+ });
1379
+ if (!patch) {
1380
+ if (existing && resolved.legacyKeys.length > 0) {
1381
+ store[resolved.normalizedKey] = existing;
1382
+ for (const legacyKey of resolved.legacyKeys) delete store[legacyKey];
1383
+ }
1384
+ return existing ?? null;
1385
+ }
1386
+ if (!existing && !createIfMissing) return null;
1387
+ const next = existing ? mergeSessionEntryPreserveActivity(existing, patch) : mergeSessionEntry(existing, patch);
1388
+ store[resolved.normalizedKey] = next;
1389
+ for (const legacyKey of resolved.legacyKeys) delete store[legacyKey];
1390
+ return next;
1391
+ }, { activeSessionKey: normalizeStoreSessionKey(sessionKey) });
1392
+ }
1393
+ async function updateLastRoute(params) {
1394
+ const { storePath, sessionKey, channel, to, accountId, threadId, ctx } = params;
1395
+ return await withSessionStoreLock(storePath, async () => {
1396
+ const store = loadSessionStore(storePath);
1397
+ const resolved = resolveSessionStoreEntry({
1398
+ store,
1399
+ sessionKey
1400
+ });
1401
+ const existing = resolved.existing;
1402
+ const now = Date.now();
1403
+ const explicitContext = normalizeDeliveryContext(params.deliveryContext);
1404
+ const inlineContext = normalizeDeliveryContext({
1405
+ channel,
1406
+ to,
1407
+ accountId,
1408
+ threadId
1409
+ });
1410
+ const mergedInput = mergeDeliveryContext(explicitContext, inlineContext);
1411
+ const explicitDeliveryContext = params.deliveryContext;
1412
+ const explicitThreadValue = (explicitDeliveryContext != null && Object.prototype.hasOwnProperty.call(explicitDeliveryContext, "threadId") ? explicitDeliveryContext.threadId : void 0) ?? (threadId != null && threadId !== "" ? threadId : void 0);
1413
+ const merged = mergeDeliveryContext(mergedInput, Boolean(explicitContext?.channel || explicitContext?.to || inlineContext?.channel || inlineContext?.to) && explicitThreadValue == null ? removeThreadFromDeliveryContext(deliveryContextFromSession(existing)) : deliveryContextFromSession(existing));
1414
+ const normalized = normalizeSessionDeliveryFields({ deliveryContext: {
1415
+ channel: merged?.channel,
1416
+ to: merged?.to,
1417
+ accountId: merged?.accountId,
1418
+ threadId: merged?.threadId
1419
+ } });
1420
+ const metaPatch = ctx ? deriveSessionMetaPatch({
1421
+ ctx,
1422
+ sessionKey: resolved.normalizedKey,
1423
+ existing,
1424
+ groupResolution: params.groupResolution
1425
+ }) : null;
1426
+ const basePatch = {
1427
+ updatedAt: Math.max(existing?.updatedAt ?? 0, now),
1428
+ deliveryContext: normalized.deliveryContext,
1429
+ lastChannel: normalized.lastChannel,
1430
+ lastTo: normalized.lastTo,
1431
+ lastAccountId: normalized.lastAccountId,
1432
+ lastThreadId: normalized.lastThreadId
1433
+ };
1434
+ return await persistResolvedSessionEntry({
1435
+ storePath,
1436
+ store,
1437
+ resolved,
1438
+ next: mergeSessionEntry(existing, metaPatch ? {
1439
+ ...basePatch,
1440
+ ...metaPatch
1441
+ } : basePatch)
1442
+ });
1443
+ });
1444
+ }
1445
+ //#endregion
1446
+ export { resolveConversationLabel as A, resolveConversationDeliveryTarget as C, cleanupArchivedSessionTranscripts as D, archiveSessionTranscripts as E, resolveGroupSessionKey as M, deriveSessionMetaPatch as O, normalizeSessionDeliveryFields as S, archiveFileOnDisk as T, deliveryContextFromSession as _, recordSessionMetaFromInbound as a, mergeDeliveryContext as b, updateLastRoute as c, capEntryCount as d, pruneStaleEntries as f, resolveCacheTtlMs as g, isCacheEnabled as h, readSessionUpdatedAt as i, buildGroupDisplayName as j, snapshotSessionOrigin as k, updateSessionStore as l, enforceSessionDiskBudget as m, loadSessionStore as n, resolveSessionStoreEntry as o, resolveMaintenanceConfig as p, normalizeStoreSessionKey as r, saveSessionStore as s, archiveRemovedSessionTranscripts as t, updateSessionStoreEntry as u, deliveryContextKey as v, normalizeAccountId as w, normalizeDeliveryContext as x, formatConversationTarget as y };