@poolzin/pool-bot 2026.2.11 → 2026.2.18

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 (535) hide show
  1. package/CHANGELOG.md +34 -0
  2. package/dist/agents/agent-scope.js +4 -0
  3. package/dist/agents/announce-idempotency.js +14 -0
  4. package/dist/agents/auth-profiles/usage.js +22 -0
  5. package/dist/agents/auth-profiles.js +1 -1
  6. package/dist/agents/auth-profiles.resolve-auth-profile-order.fixtures.js +23 -0
  7. package/dist/agents/bash-tools.exec-runtime.js +438 -0
  8. package/dist/agents/bash-tools.shared.js +6 -0
  9. package/dist/agents/cli-runner/reliability.js +61 -0
  10. package/dist/agents/cli-watchdog-defaults.js +11 -0
  11. package/dist/agents/command-poll-backoff.js +63 -0
  12. package/dist/agents/current-time.js +16 -0
  13. package/dist/agents/glob-pattern.js +42 -0
  14. package/dist/agents/memory-search.js +33 -0
  15. package/dist/agents/model-alias-lines.js +18 -0
  16. package/dist/agents/model-auth-label.js +61 -0
  17. package/dist/agents/model-fallback.js +59 -8
  18. package/dist/agents/models-config.e2e-harness.js +115 -0
  19. package/dist/agents/ollama-stream.js +11 -3
  20. package/dist/agents/openclaw-tools.js +135 -0
  21. package/dist/agents/pi-auth-json.js +118 -0
  22. package/dist/agents/pi-embedded-runner/run.overflow-compaction.mocks.shared.js +147 -0
  23. package/dist/agents/pi-embedded-subscribe.e2e-harness.js +90 -0
  24. package/dist/agents/pi-embedded-subscribe.handlers.compaction.js +63 -0
  25. package/dist/agents/pi-embedded-subscribe.handlers.tools.media.test-helpers.js +30 -0
  26. package/dist/agents/pi-extensions/session-manager-runtime-registry.js +23 -0
  27. package/dist/agents/pi-tools.before-tool-call.js +145 -4
  28. package/dist/agents/pi-tools.js +29 -9
  29. package/dist/agents/pi-tools.policy.js +85 -92
  30. package/dist/agents/pi-tools.schema.js +54 -27
  31. package/dist/agents/queued-file-writer.js +22 -0
  32. package/dist/agents/sandbox/docker.js +133 -40
  33. package/dist/agents/sandbox/fs-bridge.js +146 -0
  34. package/dist/agents/sandbox/fs-paths.js +205 -0
  35. package/dist/agents/sandbox/hash.js +4 -0
  36. package/dist/agents/sandbox/validate-sandbox-security.js +157 -0
  37. package/dist/agents/sandbox-paths.js +3 -0
  38. package/dist/agents/sandbox-tool-policy.js +26 -0
  39. package/dist/agents/sanitize-for-prompt.js +18 -0
  40. package/dist/agents/session-dirs.js +20 -0
  41. package/dist/agents/session-write-lock.js +203 -39
  42. package/dist/agents/skills/filter.js +24 -0
  43. package/dist/agents/skills/tools-dir.js +9 -0
  44. package/dist/agents/skills-install-download.js +290 -0
  45. package/dist/agents/skills-install-output.js +30 -0
  46. package/dist/agents/skills-install.download-test-utils.js +36 -0
  47. package/dist/agents/skills.e2e-test-helpers.js +13 -0
  48. package/dist/agents/subagent-announce-queue.js +59 -15
  49. package/dist/agents/subagent-depth.js +137 -0
  50. package/dist/agents/subagent-registry.js +448 -96
  51. package/dist/agents/subagent-spawn.js +262 -0
  52. package/dist/agents/system-prompt.js +52 -10
  53. package/dist/agents/test-helpers/fast-tool-stubs.js +18 -0
  54. package/dist/agents/test-helpers/host-sandbox-fs-bridge.js +74 -0
  55. package/dist/agents/tool-display-common.js +782 -0
  56. package/dist/agents/tool-loop-detection.js +466 -0
  57. package/dist/agents/tool-policy.js +6 -0
  58. package/dist/agents/tools/image-tool.js +1 -1
  59. package/dist/agents/tools/sessions-access.js +178 -0
  60. package/dist/agents/tools/sessions-resolution.js +206 -0
  61. package/dist/agents/tools/subagents-tool.js +616 -0
  62. package/dist/agents/workspace-dir.js +18 -0
  63. package/dist/agents/workspace-dirs.js +14 -0
  64. package/dist/agents/workspace.js +70 -0
  65. package/dist/auto-reply/heartbeat-reply-payload.js +18 -0
  66. package/dist/auto-reply/reply/commands-export-session.js +163 -0
  67. package/dist/auto-reply/reply/commands-mesh.js +245 -0
  68. package/dist/auto-reply/reply/commands-setunset.js +28 -0
  69. package/dist/auto-reply/reply/commands-slash-parse.js +31 -0
  70. package/dist/auto-reply/reply/commands-system-prompt.js +117 -0
  71. package/dist/auto-reply/reply/directive-handling.levels.js +17 -0
  72. package/dist/auto-reply/reply/directive-handling.params.js +1 -0
  73. package/dist/auto-reply/reply/directive-parsing.js +36 -0
  74. package/dist/auto-reply/reply/dispatcher-registry.js +43 -0
  75. package/dist/auto-reply/reply/elevated-unavailable.js +20 -0
  76. package/dist/auto-reply/reply/post-compaction-audit.js +96 -0
  77. package/dist/auto-reply/reply/post-compaction-context.js +98 -0
  78. package/dist/auto-reply/reply/reply-delivery.js +92 -0
  79. package/dist/auto-reply/reply/session-reset-prompt.js +1 -0
  80. package/dist/auto-reply/reply/session-run-accounting.js +33 -0
  81. package/dist/auto-reply/reply.directive.directive-behavior.e2e-harness.js +115 -0
  82. package/dist/auto-reply/reply.directive.directive-behavior.e2e-mocks.js +12 -0
  83. package/dist/browser/bridge-auth-registry.js +26 -0
  84. package/dist/browser/client-actions-url.js +10 -0
  85. package/dist/browser/control-auth.js +73 -0
  86. package/dist/browser/csrf.js +64 -0
  87. package/dist/browser/http-auth.js +52 -0
  88. package/dist/browser/paths.js +37 -0
  89. package/dist/browser/proxy-files.js +32 -0
  90. package/dist/browser/pw-ai-state.js +7 -0
  91. package/dist/browser/resolved-config-refresh.js +42 -0
  92. package/dist/browser/routes/path-output.js +1 -0
  93. package/dist/browser/server-context.chrome-test-harness.js +20 -0
  94. package/dist/browser/server-middleware.js +31 -0
  95. package/dist/browser/test-port.js +16 -0
  96. package/dist/build-info.json +3 -3
  97. package/dist/canvas-host/file-resolver.js +43 -0
  98. package/dist/channels/account-summary.js +19 -0
  99. package/dist/channels/draft-stream-loop.js +77 -0
  100. package/dist/channels/plugins/account-helpers.js +26 -0
  101. package/dist/channels/telegram/allow-from.js +10 -0
  102. package/dist/cli/browser-cli-resize.js +22 -0
  103. package/dist/cli/browser-cli-shared.js +8 -0
  104. package/dist/cli/clawbot-cli.js +5 -0
  105. package/dist/cli/completion-cli.js +566 -0
  106. package/dist/cli/config-cli.js +63 -5
  107. package/dist/cli/daemon-cli/lifecycle-core.js +256 -0
  108. package/dist/cli/daemon-cli/register-service-commands.js +60 -0
  109. package/dist/cli/daemon-cli-compat.js +80 -0
  110. package/dist/cli/nodes-cli/pairing-render.js +26 -0
  111. package/dist/cli/program/action-reparse.js +17 -0
  112. package/dist/cli/program/command-registry.js +17 -0
  113. package/dist/cli/program/program-context.js +8 -0
  114. package/dist/cli/program/register.subclis.js +7 -0
  115. package/dist/cli/program/routes.js +233 -0
  116. package/dist/cli/qr-cli.js +132 -0
  117. package/dist/cli/requirements-test-fixtures.js +17 -0
  118. package/dist/cli/respawn-policy.js +4 -0
  119. package/dist/cli/shared/parse-port.js +18 -0
  120. package/dist/cli/skills-cli.format.js +241 -0
  121. package/dist/cli/update-cli/progress.js +121 -0
  122. package/dist/cli/update-cli/restart-helper.js +108 -0
  123. package/dist/cli/update-cli/shared.js +196 -0
  124. package/dist/cli/update-cli/status.js +97 -0
  125. package/dist/cli/update-cli/suppress-deprecations.js +17 -0
  126. package/dist/cli/update-cli/update-command.js +506 -0
  127. package/dist/cli/update-cli/wizard.js +130 -0
  128. package/dist/cli/update-cli.js +3 -9
  129. package/dist/cli/windows-argv.js +69 -0
  130. package/dist/commands/auth-choice-legacy.js +20 -0
  131. package/dist/commands/auth-choice.apply-helpers.js +8 -0
  132. package/dist/commands/channel-test-helpers.js +19 -0
  133. package/dist/commands/cleanup-plan.js +10 -0
  134. package/dist/commands/cleanup-utils.js +7 -0
  135. package/dist/commands/config-validation.js +15 -0
  136. package/dist/commands/doctor-completion.js +112 -0
  137. package/dist/commands/doctor-memory-search.js +119 -0
  138. package/dist/commands/doctor-session-locks.js +73 -0
  139. package/dist/commands/doctor.e2e-harness.js +364 -0
  140. package/dist/commands/gateway-presence.js +19 -0
  141. package/dist/commands/model-default.js +35 -0
  142. package/dist/commands/models/fallbacks-shared.js +102 -0
  143. package/dist/commands/models/shared.js +24 -0
  144. package/dist/commands/onboard-auth.config-gateways.js +64 -0
  145. package/dist/commands/onboard-auth.config-litellm.js +45 -0
  146. package/dist/commands/onboard-auth.config-shared.js +116 -0
  147. package/dist/commands/onboard-config.js +16 -0
  148. package/dist/commands/onboard-non-interactive.test-helpers.js +31 -0
  149. package/dist/commands/onboard-provider-auth-flags.js +136 -0
  150. package/dist/commands/openai-codex-oauth.js +40 -0
  151. package/dist/commands/test-runtime-config-helpers.js +21 -0
  152. package/dist/commands/test-wizard-helpers.js +68 -0
  153. package/dist/commands/vllm-setup.js +66 -0
  154. package/dist/compat/legacy-names.js +2 -0
  155. package/dist/config/backup-rotation.js +19 -0
  156. package/dist/config/env-preserve.js +122 -0
  157. package/dist/config/includes-scan.js +78 -0
  158. package/dist/config/plugins-allowlist.js +13 -0
  159. package/dist/config/schema.help.js +256 -0
  160. package/dist/config/schema.hints.js +189 -0
  161. package/dist/config/schema.irc.js +20 -0
  162. package/dist/config/schema.labels.js +317 -0
  163. package/dist/config/sessions/delivery-info.js +40 -0
  164. package/dist/config/types.irc.js +1 -0
  165. package/dist/config/zod-schema.agent-defaults.js +14 -0
  166. package/dist/config/zod-schema.agent-model.js +10 -0
  167. package/dist/config/zod-schema.agent-runtime.js +14 -0
  168. package/dist/config/zod-schema.allowdeny.js +35 -0
  169. package/dist/config/zod-schema.sensitive.js +4 -0
  170. package/dist/control-ui/assets/index-HRr1grwl.js.map +1 -1
  171. package/dist/cron/isolated-agent/skills-snapshot.js +26 -0
  172. package/dist/cron/isolated-agent/subagent-followup.js +127 -0
  173. package/dist/cron/isolated-agent.mocks.js +12 -0
  174. package/dist/cron/isolated-agent.test-setup.js +22 -0
  175. package/dist/cron/legacy-delivery.js +43 -0
  176. package/dist/cron/webhook-url.js +22 -0
  177. package/dist/daemon/arg-split.js +40 -0
  178. package/dist/daemon/exec-file.js +23 -0
  179. package/dist/daemon/output.js +6 -0
  180. package/dist/daemon/runtime-format.js +31 -0
  181. package/dist/daemon/schtasks-exec.js +4 -0
  182. package/dist/daemon/service-audit.js +22 -0
  183. package/dist/discord/client.js +41 -0
  184. package/dist/discord/components-registry.js +57 -0
  185. package/dist/discord/components.js +816 -0
  186. package/dist/discord/guilds.js +12 -0
  187. package/dist/discord/monitor/gateway-plugin.js +48 -0
  188. package/dist/discord/monitor/presence.js +30 -0
  189. package/dist/discord/send.components.js +115 -0
  190. package/dist/discord/send.shared.js +4 -0
  191. package/dist/discord/ui.js +26 -0
  192. package/dist/discord/voice-message.js +254 -0
  193. package/dist/gateway/agent-event-assistant-text.js +5 -0
  194. package/dist/gateway/agent-prompt.js +33 -0
  195. package/dist/gateway/auth-rate-limit.js +136 -0
  196. package/dist/gateway/channel-health-monitor.js +114 -0
  197. package/dist/gateway/control-ui-contract.js +1 -0
  198. package/dist/gateway/control-ui-csp.js +15 -0
  199. package/dist/gateway/gateway-config-prompts.shared.js +25 -0
  200. package/dist/gateway/http-auth-helpers.js +18 -0
  201. package/dist/gateway/http-common.js +18 -0
  202. package/dist/gateway/http-endpoint-helpers.js +27 -0
  203. package/dist/gateway/node-invoke-sanitize.js +11 -0
  204. package/dist/gateway/node-invoke-system-run-approval.js +205 -0
  205. package/dist/gateway/probe-auth.js +21 -0
  206. package/dist/gateway/protocol/index.js +7 -2
  207. package/dist/gateway/protocol/schema/mesh.js +54 -0
  208. package/dist/gateway/protocol/schema/protocol-schemas.js +7 -0
  209. package/dist/gateway/protocol/schema.js +1 -0
  210. package/dist/gateway/server/ws-connection/auth-messages.js +54 -0
  211. package/dist/gateway/server-channels.js +11 -0
  212. package/dist/gateway/server-methods/attachment-normalize.js +16 -0
  213. package/dist/gateway/server-methods/base-hash.js +8 -0
  214. package/dist/gateway/server-methods/mesh.js +700 -0
  215. package/dist/gateway/server-methods/nodes.handlers.invoke-result.js +55 -0
  216. package/dist/gateway/server-methods/restart-request.js +13 -0
  217. package/dist/gateway/server-methods/validation.js +8 -0
  218. package/dist/gateway/server.agent.gateway-server-agent.mocks.js +35 -0
  219. package/dist/gateway/server.e2e-registry-helpers.js +1 -0
  220. package/dist/gateway/server.e2e-ws-harness.js +20 -0
  221. package/dist/gateway/test-helpers.js +2 -0
  222. package/dist/gateway/test-helpers.server.js +3 -1
  223. package/dist/gateway/test-http-response.js +12 -0
  224. package/dist/gateway/test-openai-responses-model.js +20 -0
  225. package/dist/gateway/test-temp-config.js +30 -0
  226. package/dist/gateway/test-with-server.js +32 -0
  227. package/dist/hooks/bundled/bootstrap-extra-files/handler.js +46 -0
  228. package/dist/imessage/monitor/abort-handler.js +23 -0
  229. package/dist/imessage/monitor/inbound-processing.js +346 -0
  230. package/dist/imessage/monitor/parse-notification.js +64 -0
  231. package/dist/imessage/target-parsing-helpers.js +92 -0
  232. package/dist/infra/archive.js +244 -20
  233. package/dist/infra/detect-package-manager.js +26 -0
  234. package/dist/infra/exec-approvals-allowlist.js +257 -0
  235. package/dist/infra/exec-approvals-analysis.js +770 -0
  236. package/dist/infra/exec-approvals.js +13 -0
  237. package/dist/infra/file-lock.js +1 -0
  238. package/dist/infra/gemini-auth.js +39 -0
  239. package/dist/infra/heartbeat-active-hours.js +85 -0
  240. package/dist/infra/heartbeat-events-filter.js +50 -0
  241. package/dist/infra/heartbeat-runner.test-utils.js +39 -0
  242. package/dist/infra/http-body.js +265 -0
  243. package/dist/infra/install-package-dir.js +50 -0
  244. package/dist/infra/install-safe-path.js +49 -0
  245. package/dist/infra/json-files.js +49 -0
  246. package/dist/infra/jsonl-socket.js +52 -0
  247. package/dist/infra/map-size.js +14 -0
  248. package/dist/infra/net/hostname.js +7 -0
  249. package/dist/infra/npm-registry-spec.js +39 -0
  250. package/dist/infra/openclaw-root.js +109 -0
  251. package/dist/infra/outbound/delivery-queue.js +214 -0
  252. package/dist/infra/outbound/identity.js +23 -0
  253. package/dist/infra/outbound/message-action-params.js +307 -0
  254. package/dist/infra/outbound/tool-payload.js +21 -0
  255. package/dist/infra/package-json.js +23 -0
  256. package/dist/infra/pairing-files.js +19 -0
  257. package/dist/infra/pairing-token.js +9 -0
  258. package/dist/infra/path-prepend.js +51 -0
  259. package/dist/infra/path-safety.js +16 -0
  260. package/dist/infra/process-respawn.js +49 -0
  261. package/dist/infra/runtime-status.js +16 -0
  262. package/dist/infra/session-cost-usage.types.js +1 -0
  263. package/dist/infra/session-maintenance-warning.js +89 -0
  264. package/dist/infra/system-run-command.js +78 -0
  265. package/dist/infra/tmp-openclaw-dir.js +81 -0
  266. package/dist/infra/tmp-poolbot-dir.js +2 -0
  267. package/dist/infra/update-channels.js +19 -0
  268. package/dist/line/actions.js +45 -0
  269. package/dist/line/channel-access-token.js +9 -0
  270. package/dist/line/flex-templates/basic-cards.js +332 -0
  271. package/dist/line/flex-templates/common.js +18 -0
  272. package/dist/line/flex-templates/media-control-cards.js +453 -0
  273. package/dist/line/flex-templates/message.js +10 -0
  274. package/dist/line/flex-templates/schedule-cards.js +399 -0
  275. package/dist/line/flex-templates/types.js +1 -0
  276. package/dist/line/webhook-node.js +100 -0
  277. package/dist/line/webhook-utils.js +11 -0
  278. package/dist/logging/diagnostic-session-state.js +73 -0
  279. package/dist/logging/diagnostic.js +22 -0
  280. package/dist/logging/timestamps.js +14 -0
  281. package/dist/markdown/whatsapp.js +62 -0
  282. package/dist/media/base64.js +34 -0
  283. package/dist/media/local-roots.js +32 -0
  284. package/dist/media/outbound-attachment.js +10 -0
  285. package/dist/media/read-response-with-limit.js +41 -0
  286. package/dist/media/sniff-mime-from-base64.js +19 -0
  287. package/dist/media-understanding/audio-preflight.js +67 -0
  288. package/dist/media-understanding/fs.js +13 -0
  289. package/dist/media-understanding/output-extract.js +26 -0
  290. package/dist/media-understanding/providers/audio.test-helpers.js +34 -0
  291. package/dist/media-understanding/providers/google/inline-data.js +64 -0
  292. package/dist/media-understanding/providers/shared.js +7 -0
  293. package/dist/media-understanding/runner.entries.js +459 -0
  294. package/dist/memory/batch-error-utils.js +11 -0
  295. package/dist/memory/batch-http.js +27 -0
  296. package/dist/memory/batch-output.js +29 -0
  297. package/dist/memory/batch-runner.js +22 -0
  298. package/dist/memory/batch-upload.js +23 -0
  299. package/dist/memory/batch-utils.js +26 -0
  300. package/dist/memory/embeddings-debug.js +11 -0
  301. package/dist/memory/embeddings-remote-client.js +22 -0
  302. package/dist/memory/embeddings-remote-fetch.js +14 -0
  303. package/dist/memory/embeddings.js +36 -9
  304. package/dist/memory/hybrid.js +24 -5
  305. package/dist/memory/manager-embedding-ops.js +616 -0
  306. package/dist/memory/manager-sync-ops.js +953 -0
  307. package/dist/memory/manager.js +76 -28
  308. package/dist/memory/mmr.js +164 -0
  309. package/dist/memory/qmd-manager.js +1061 -0
  310. package/dist/memory/qmd-query-parser.js +107 -0
  311. package/dist/memory/qmd-scope.js +93 -0
  312. package/dist/memory/query-expansion.js +331 -0
  313. package/dist/memory/search-manager.js +0 -1
  314. package/dist/memory/sync-index.js +21 -0
  315. package/dist/memory/sync-progress.js +22 -0
  316. package/dist/memory/sync-stale.js +30 -0
  317. package/dist/memory/temporal-decay.js +119 -0
  318. package/dist/memory/test-embeddings-mock.js +16 -0
  319. package/dist/memory/test-manager-helpers.js +14 -0
  320. package/dist/memory/test-runtime-mocks.js +11 -0
  321. package/dist/node-host/invoke-browser.js +177 -0
  322. package/dist/node-host/invoke.js +685 -0
  323. package/dist/pairing/setup-code.js +285 -0
  324. package/dist/plugin-sdk/account-id.js +1 -0
  325. package/dist/plugin-sdk/agent-media-payload.js +13 -0
  326. package/dist/plugin-sdk/allow-from.js +47 -0
  327. package/dist/plugin-sdk/command-auth.js +23 -0
  328. package/dist/plugin-sdk/config-paths.js +9 -0
  329. package/dist/plugin-sdk/file-lock.js +116 -0
  330. package/dist/plugin-sdk/json-store.js +31 -0
  331. package/dist/plugin-sdk/onboarding.js +28 -0
  332. package/dist/plugin-sdk/provider-auth-result.js +29 -0
  333. package/dist/plugin-sdk/slack-message-actions.js +133 -0
  334. package/dist/plugin-sdk/status-helpers.js +35 -0
  335. package/dist/plugin-sdk/text-chunking.js +31 -0
  336. package/dist/plugin-sdk/tool-send.js +12 -0
  337. package/dist/plugin-sdk/webhook-path.js +27 -0
  338. package/dist/plugin-sdk/webhook-targets.js +34 -0
  339. package/dist/plugins/hooks.test-helpers.js +21 -0
  340. package/dist/plugins/uninstall.js +171 -0
  341. package/dist/process/kill-tree.js +98 -0
  342. package/dist/process/supervisor/adapters/child.js +143 -0
  343. package/dist/process/supervisor/adapters/env.js +13 -0
  344. package/dist/process/supervisor/adapters/pty.js +148 -0
  345. package/dist/process/supervisor/index.js +10 -0
  346. package/dist/process/supervisor/registry.js +117 -0
  347. package/dist/process/supervisor/supervisor.js +244 -0
  348. package/dist/process/supervisor/types.js +1 -0
  349. package/dist/providers/google-shared.test-helpers.js +75 -0
  350. package/dist/security/audit-channel.js +419 -0
  351. package/dist/security/audit-tool-policy.js +1 -0
  352. package/dist/security/scan-paths.js +12 -0
  353. package/dist/sessions/input-provenance.js +55 -0
  354. package/dist/sessions/session-key-utils.js +7 -0
  355. package/dist/shared/chat-content.js +31 -0
  356. package/dist/shared/chat-envelope.js +45 -0
  357. package/dist/shared/config-eval.js +117 -0
  358. package/dist/shared/device-auth.js +16 -0
  359. package/dist/shared/entry-metadata.js +9 -0
  360. package/dist/shared/entry-status.js +25 -0
  361. package/dist/shared/frontmatter.js +98 -0
  362. package/dist/shared/model-param-b.js +19 -0
  363. package/dist/shared/net/ipv4.js +17 -0
  364. package/dist/shared/node-match.js +53 -0
  365. package/dist/shared/pid-alive.js +12 -0
  366. package/dist/shared/process-scoped-map.js +10 -0
  367. package/dist/shared/requirements.js +128 -0
  368. package/dist/shared/subagents-format.js +84 -0
  369. package/dist/shared/usage-aggregates.js +28 -0
  370. package/dist/signal/monitor/mentions.js +45 -0
  371. package/dist/signal/rpc-context.js +19 -0
  372. package/dist/slack/blocks-fallback.js +76 -0
  373. package/dist/slack/blocks-input.js +40 -0
  374. package/dist/slack/draft-stream.js +106 -0
  375. package/dist/slack/message-actions.js +51 -0
  376. package/dist/slack/modal-metadata.js +32 -0
  377. package/dist/slack/monitor/events/interactions.js +462 -0
  378. package/dist/slack/monitor/room-context.js +17 -0
  379. package/dist/slack/stream-mode.js +41 -0
  380. package/dist/telegram/bot-native-command-menu.js +64 -0
  381. package/dist/telegram/bot.media.e2e-harness.js +81 -0
  382. package/dist/telegram/button-types.js +1 -0
  383. package/dist/telegram/group-access.js +65 -0
  384. package/dist/telegram/outbound-params.js +21 -0
  385. package/dist/telegram/poll-vote-cache.js +21 -0
  386. package/dist/terminal/health-style.js +36 -0
  387. package/dist/test-utils/chunk-test-helpers.js +21 -0
  388. package/dist/test-utils/env.js +72 -0
  389. package/dist/test-utils/exec-assertions.js +12 -0
  390. package/dist/test-utils/imessage-test-plugin.js +54 -0
  391. package/dist/test-utils/mock-http-response.js +17 -0
  392. package/dist/test-utils/vitest-mock-fn.js +1 -0
  393. package/dist/tts/tts-core.js +550 -0
  394. package/dist/utils/chunk-items.js +10 -0
  395. package/dist/utils/reaction-level.js +52 -0
  396. package/dist/utils/safe-json.js +22 -0
  397. package/dist/utils/with-timeout.js +14 -0
  398. package/dist/web/media.js +17 -5
  399. package/dist/whatsapp/resolve-outbound-target.js +42 -0
  400. package/dist/wizard/onboarding.completion.js +74 -0
  401. package/extensions/bluebubbles/package.json +1 -1
  402. package/extensions/bluebubbles/src/account-resolve.ts +29 -0
  403. package/extensions/bluebubbles/src/monitor-normalize.ts +796 -0
  404. package/extensions/bluebubbles/src/monitor-processing.ts +1007 -0
  405. package/extensions/bluebubbles/src/monitor-reply-cache.ts +185 -0
  406. package/extensions/bluebubbles/src/monitor-shared.ts +51 -0
  407. package/extensions/bluebubbles/src/multipart.ts +32 -0
  408. package/extensions/bluebubbles/src/send-helpers.ts +53 -0
  409. package/extensions/bluebubbles/src/test-harness.ts +50 -0
  410. package/extensions/bluebubbles/src/test-mocks.ts +11 -0
  411. package/extensions/copilot-proxy/package.json +1 -1
  412. package/extensions/device-pair/index.ts +554 -0
  413. package/extensions/diagnostics-otel/package.json +1 -1
  414. package/extensions/discord/package.json +1 -1
  415. package/extensions/discord/src/channel.js +366 -0
  416. package/extensions/discord/src/runtime.js +10 -0
  417. package/extensions/feishu/index.ts +63 -0
  418. package/extensions/feishu/src/accounts.ts +114 -0
  419. package/extensions/feishu/src/bitable.ts +739 -0
  420. package/extensions/feishu/src/bot.ts +965 -0
  421. package/extensions/feishu/src/channel.ts +351 -0
  422. package/extensions/feishu/src/client.ts +118 -0
  423. package/extensions/feishu/src/config-schema.ts +206 -0
  424. package/extensions/feishu/src/dedup.ts +33 -0
  425. package/extensions/feishu/src/directory.ts +177 -0
  426. package/extensions/feishu/src/doc-schema.ts +47 -0
  427. package/extensions/feishu/src/docx.ts +536 -0
  428. package/extensions/feishu/src/drive-schema.ts +46 -0
  429. package/extensions/feishu/src/drive.ts +227 -0
  430. package/extensions/feishu/src/dynamic-agent.ts +131 -0
  431. package/extensions/feishu/src/media.ts +449 -0
  432. package/extensions/feishu/src/mention.ts +126 -0
  433. package/extensions/feishu/src/monitor.ts +330 -0
  434. package/extensions/feishu/src/onboarding.ts +359 -0
  435. package/extensions/feishu/src/outbound.ts +55 -0
  436. package/extensions/feishu/src/perm-schema.ts +52 -0
  437. package/extensions/feishu/src/perm.ts +173 -0
  438. package/extensions/feishu/src/policy.ts +84 -0
  439. package/extensions/feishu/src/probe.ts +44 -0
  440. package/extensions/feishu/src/reactions.ts +160 -0
  441. package/extensions/feishu/src/reply-dispatcher.ts +239 -0
  442. package/extensions/feishu/src/runtime.ts +14 -0
  443. package/extensions/feishu/src/send-result.ts +29 -0
  444. package/extensions/feishu/src/send.ts +335 -0
  445. package/extensions/feishu/src/streaming-card.ts +223 -0
  446. package/extensions/feishu/src/targets.ts +78 -0
  447. package/extensions/feishu/src/tools-config.ts +21 -0
  448. package/extensions/feishu/src/types.ts +81 -0
  449. package/extensions/feishu/src/typing.ts +80 -0
  450. package/extensions/feishu/src/wiki-schema.ts +55 -0
  451. package/extensions/feishu/src/wiki.ts +232 -0
  452. package/extensions/google-antigravity-auth/package.json +1 -1
  453. package/extensions/google-gemini-cli-auth/package.json +1 -1
  454. package/extensions/googlechat/package.json +1 -1
  455. package/extensions/imessage/package.json +1 -1
  456. package/extensions/imessage/src/channel.js +253 -0
  457. package/extensions/imessage/src/runtime.js +10 -0
  458. package/extensions/irc/index.ts +17 -0
  459. package/extensions/irc/src/accounts.ts +268 -0
  460. package/extensions/irc/src/channel.ts +367 -0
  461. package/extensions/irc/src/client.ts +439 -0
  462. package/extensions/irc/src/config-schema.ts +97 -0
  463. package/extensions/irc/src/connect-options.ts +30 -0
  464. package/extensions/irc/src/control-chars.ts +22 -0
  465. package/extensions/irc/src/inbound.ts +334 -0
  466. package/extensions/irc/src/monitor.ts +147 -0
  467. package/extensions/irc/src/normalize.ts +117 -0
  468. package/extensions/irc/src/onboarding.ts +479 -0
  469. package/extensions/irc/src/policy.ts +157 -0
  470. package/extensions/irc/src/probe.ts +53 -0
  471. package/extensions/irc/src/protocol.ts +169 -0
  472. package/extensions/irc/src/runtime.ts +14 -0
  473. package/extensions/irc/src/send.ts +88 -0
  474. package/extensions/irc/src/types.ts +93 -0
  475. package/extensions/line/package.json +1 -1
  476. package/extensions/llm-task/package.json +1 -1
  477. package/extensions/lobster/package.json +1 -1
  478. package/extensions/matrix/CHANGELOG.md +5 -0
  479. package/extensions/matrix/package.json +1 -1
  480. package/extensions/matrix/src/matrix/client-bootstrap.ts +39 -0
  481. package/extensions/mattermost/package.json +1 -1
  482. package/extensions/mattermost/src/mattermost/monitor-onchar.ts +25 -0
  483. package/extensions/mattermost/src/mattermost/monitor-websocket.ts +221 -0
  484. package/extensions/mattermost/src/mattermost/reactions.ts +130 -0
  485. package/extensions/mattermost/src/mattermost/reconnect.ts +103 -0
  486. package/extensions/memory-core/package.json +1 -1
  487. package/extensions/memory-lancedb/package.json +1 -1
  488. package/extensions/minimax-portal-auth/index.ts +161 -0
  489. package/extensions/minimax-portal-auth/oauth.ts +247 -0
  490. package/extensions/msteams/CHANGELOG.md +5 -0
  491. package/extensions/msteams/package.json +1 -1
  492. package/extensions/msteams/src/file-lock.ts +1 -0
  493. package/extensions/msteams/src/graph.ts +92 -0
  494. package/extensions/msteams/src/mentions.ts +114 -0
  495. package/extensions/msteams/src/test-runtime.ts +16 -0
  496. package/extensions/nextcloud-talk/package.json +1 -1
  497. package/extensions/nostr/CHANGELOG.md +5 -0
  498. package/extensions/nostr/package.json +1 -1
  499. package/extensions/open-prose/package.json +1 -1
  500. package/extensions/openai-codex-auth/index.ts +177 -0
  501. package/extensions/phone-control/index.ts +421 -0
  502. package/extensions/shared/resolve-target-test-helpers.ts +66 -0
  503. package/extensions/signal/package.json +1 -1
  504. package/extensions/signal/src/channel.js +273 -0
  505. package/extensions/signal/src/runtime.js +10 -0
  506. package/extensions/slack/package.json +1 -1
  507. package/extensions/slack/src/channel.js +489 -0
  508. package/extensions/slack/src/runtime.js +10 -0
  509. package/extensions/talk-voice/index.ts +150 -0
  510. package/extensions/telegram/package.json +1 -1
  511. package/extensions/telegram/src/channel.js +424 -0
  512. package/extensions/telegram/src/runtime.js +10 -0
  513. package/extensions/thread-ownership/index.ts +133 -0
  514. package/extensions/tlon/package.json +1 -1
  515. package/extensions/tlon/src/account-fields.ts +25 -0
  516. package/extensions/tlon/src/urbit/base-url.ts +57 -0
  517. package/extensions/tlon/src/urbit/channel-client.ts +157 -0
  518. package/extensions/tlon/src/urbit/channel-ops.ts +164 -0
  519. package/extensions/tlon/src/urbit/context.ts +47 -0
  520. package/extensions/tlon/src/urbit/errors.ts +51 -0
  521. package/extensions/tlon/src/urbit/fetch.ts +39 -0
  522. package/extensions/twitch/CHANGELOG.md +5 -0
  523. package/extensions/twitch/package.json +1 -1
  524. package/extensions/twitch/src/test-fixtures.ts +30 -0
  525. package/extensions/voice-call/CHANGELOG.md +5 -0
  526. package/extensions/voice-call/package.json +1 -1
  527. package/extensions/voice-call/src/allowlist.ts +19 -0
  528. package/extensions/whatsapp/package.json +1 -1
  529. package/extensions/whatsapp/src/channel.js +429 -0
  530. package/extensions/whatsapp/src/runtime.js +10 -0
  531. package/extensions/zalo/CHANGELOG.md +5 -0
  532. package/extensions/zalo/package.json +1 -1
  533. package/extensions/zalouser/CHANGELOG.md +5 -0
  534. package/extensions/zalouser/package.json +1 -1
  535. package/package.json +1 -1
@@ -227,6 +227,76 @@ export async function loadWorkspaceBootstrapFiles(dir) {
227
227
  return result;
228
228
  }
229
229
  const SUBAGENT_BOOTSTRAP_ALLOWLIST = new Set([DEFAULT_AGENTS_FILENAME, DEFAULT_TOOLS_FILENAME]);
230
+ const VALID_BOOTSTRAP_NAMES = new Set([
231
+ DEFAULT_AGENTS_FILENAME,
232
+ DEFAULT_SOUL_FILENAME,
233
+ DEFAULT_TOOLS_FILENAME,
234
+ DEFAULT_IDENTITY_FILENAME,
235
+ DEFAULT_USER_FILENAME,
236
+ DEFAULT_HEARTBEAT_FILENAME,
237
+ DEFAULT_BOOTSTRAP_FILENAME,
238
+ DEFAULT_MEMORY_FILENAME,
239
+ DEFAULT_MEMORY_ALT_FILENAME,
240
+ ]);
241
+ export async function loadExtraBootstrapFiles(dir, extraPatterns) {
242
+ if (!extraPatterns.length) {
243
+ return [];
244
+ }
245
+ const resolvedDir = resolveUserPath(dir);
246
+ let realResolvedDir = resolvedDir;
247
+ try {
248
+ realResolvedDir = await fs.realpath(resolvedDir);
249
+ }
250
+ catch {
251
+ // Keep lexical root if realpath fails.
252
+ }
253
+ const resolvedPaths = new Set();
254
+ for (const pattern of extraPatterns) {
255
+ if (pattern.includes("*") || pattern.includes("?") || pattern.includes("{")) {
256
+ try {
257
+ const matches = fs.glob(pattern, { cwd: resolvedDir });
258
+ for await (const m of matches) {
259
+ resolvedPaths.add(m);
260
+ }
261
+ }
262
+ catch {
263
+ resolvedPaths.add(pattern);
264
+ }
265
+ }
266
+ else {
267
+ resolvedPaths.add(pattern);
268
+ }
269
+ }
270
+ const result = [];
271
+ for (const relPath of resolvedPaths) {
272
+ const filePath = path.resolve(resolvedDir, relPath);
273
+ if (!filePath.startsWith(resolvedDir + path.sep) && filePath !== resolvedDir) {
274
+ continue;
275
+ }
276
+ try {
277
+ const realFilePath = await fs.realpath(filePath);
278
+ if (!realFilePath.startsWith(realResolvedDir + path.sep) &&
279
+ realFilePath !== realResolvedDir) {
280
+ continue;
281
+ }
282
+ const baseName = path.basename(relPath);
283
+ if (!VALID_BOOTSTRAP_NAMES.has(baseName)) {
284
+ continue;
285
+ }
286
+ const content = await fs.readFile(realFilePath, "utf-8");
287
+ result.push({
288
+ name: baseName,
289
+ path: filePath,
290
+ content,
291
+ missing: false,
292
+ });
293
+ }
294
+ catch {
295
+ // Silently skip missing extra files
296
+ }
297
+ }
298
+ return result;
299
+ }
230
300
  export function filterBootstrapFilesForSession(files, sessionKey) {
231
301
  if (!sessionKey || !isSubagentSessionKey(sessionKey))
232
302
  return files;
@@ -0,0 +1,18 @@
1
+ export function resolveHeartbeatReplyPayload(replyResult) {
2
+ if (!replyResult) {
3
+ return undefined;
4
+ }
5
+ if (!Array.isArray(replyResult)) {
6
+ return replyResult;
7
+ }
8
+ for (let idx = replyResult.length - 1; idx >= 0; idx -= 1) {
9
+ const payload = replyResult[idx];
10
+ if (!payload) {
11
+ continue;
12
+ }
13
+ if (payload.text || payload.mediaUrl || (payload.mediaUrls && payload.mediaUrls.length > 0)) {
14
+ return payload;
15
+ }
16
+ }
17
+ return undefined;
18
+ }
@@ -0,0 +1,163 @@
1
+ import fs from "node:fs";
2
+ import path from "node:path";
3
+ import { fileURLToPath } from "node:url";
4
+ import { SessionManager } from "@mariozechner/pi-coding-agent";
5
+ import { resolveDefaultSessionStorePath, resolveSessionFilePath, } from "../../config/sessions/paths.js";
6
+ import { loadSessionStore } from "../../config/sessions/store.js";
7
+ import { resolveCommandsSystemPromptBundle } from "./commands-system-prompt.js";
8
+ // Export HTML templates are bundled with this module
9
+ const EXPORT_HTML_DIR = path.join(path.dirname(fileURLToPath(import.meta.url)), "export-html");
10
+ function loadTemplate(fileName) {
11
+ return fs.readFileSync(path.join(EXPORT_HTML_DIR, fileName), "utf-8");
12
+ }
13
+ function generateHtml(sessionData) {
14
+ const template = loadTemplate("template.html");
15
+ const templateCss = loadTemplate("template.css");
16
+ const templateJs = loadTemplate("template.js");
17
+ const markedJs = loadTemplate(path.join("vendor", "marked.min.js"));
18
+ const hljsJs = loadTemplate(path.join("vendor", "highlight.min.js"));
19
+ // Use pi-mono dark theme colors (matching their theme/dark.json)
20
+ const themeVars = `
21
+ --cyan: #00d7ff;
22
+ --blue: #5f87ff;
23
+ --green: #b5bd68;
24
+ --red: #cc6666;
25
+ --yellow: #ffff00;
26
+ --gray: #808080;
27
+ --dimGray: #666666;
28
+ --darkGray: #505050;
29
+ --accent: #8abeb7;
30
+ --selectedBg: #3a3a4a;
31
+ --userMsgBg: #343541;
32
+ --toolPendingBg: #282832;
33
+ --toolSuccessBg: #283228;
34
+ --toolErrorBg: #3c2828;
35
+ --customMsgBg: #2d2838;
36
+ --text: #e0e0e0;
37
+ --dim: #666666;
38
+ --muted: #808080;
39
+ --border: #5f87ff;
40
+ --borderAccent: #00d7ff;
41
+ --borderMuted: #505050;
42
+ --success: #b5bd68;
43
+ --error: #cc6666;
44
+ --warning: #ffff00;
45
+ --thinkingText: #808080;
46
+ --userMessageBg: #343541;
47
+ --userMessageText: #e0e0e0;
48
+ --customMessageBg: #2d2838;
49
+ --customMessageText: #e0e0e0;
50
+ --customMessageLabel: #9575cd;
51
+ --toolTitle: #e0e0e0;
52
+ --toolOutput: #808080;
53
+ --mdHeading: #f0c674;
54
+ --mdLink: #81a2be;
55
+ --mdLinkUrl: #666666;
56
+ --mdCode: #8abeb7;
57
+ --mdCodeBlock: #b5bd68;
58
+ `;
59
+ const bodyBg = "#1e1e28";
60
+ const containerBg = "#282832";
61
+ const infoBg = "#343541";
62
+ // Base64 encode session data
63
+ const sessionDataBase64 = Buffer.from(JSON.stringify(sessionData)).toString("base64");
64
+ // Build CSS with theme variables
65
+ const css = templateCss
66
+ .replace("/* {{THEME_VARS}} */", themeVars.trim())
67
+ .replace("/* {{BODY_BG_DECL}} */", `--body-bg: ${bodyBg};`)
68
+ .replace("/* {{CONTAINER_BG_DECL}} */", `--container-bg: ${containerBg};`)
69
+ .replace("/* {{INFO_BG_DECL}} */", `--info-bg: ${infoBg};`);
70
+ return template
71
+ .replace("{{CSS}}", css)
72
+ .replace("{{JS}}", templateJs)
73
+ .replace("{{SESSION_DATA}}", sessionDataBase64)
74
+ .replace("{{MARKED_JS}}", markedJs)
75
+ .replace("{{HIGHLIGHT_JS}}", hljsJs);
76
+ }
77
+ function parseExportArgs(commandBodyNormalized) {
78
+ const normalized = commandBodyNormalized.trim();
79
+ if (normalized === "/export-session" || normalized === "/export") {
80
+ return {};
81
+ }
82
+ const args = normalized.replace(/^\/(export-session|export)\s*/, "").trim();
83
+ // First non-flag argument is the output path
84
+ const outputPath = args.split(/\s+/).find((part) => !part.startsWith("-"));
85
+ return { outputPath };
86
+ }
87
+ export async function buildExportSessionReply(params) {
88
+ const args = parseExportArgs(params.command.commandBodyNormalized);
89
+ // 1. Resolve session file
90
+ const sessionEntry = params.sessionEntry;
91
+ if (!sessionEntry?.sessionId) {
92
+ return { text: "❌ No active session found." };
93
+ }
94
+ const storePath = resolveDefaultSessionStorePath(params.agentId);
95
+ const store = loadSessionStore(storePath, { skipCache: true });
96
+ const entry = store[params.sessionKey];
97
+ if (!entry?.sessionId) {
98
+ return { text: `❌ Session not found: ${params.sessionKey}` };
99
+ }
100
+ let sessionFile;
101
+ try {
102
+ sessionFile = resolveSessionFilePath(entry.sessionId, entry, {
103
+ agentId: params.agentId,
104
+ sessionsDir: path.dirname(storePath),
105
+ });
106
+ }
107
+ catch (err) {
108
+ return {
109
+ text: `❌ Failed to resolve session file: ${err instanceof Error ? err.message : String(err)}`,
110
+ };
111
+ }
112
+ if (!fs.existsSync(sessionFile)) {
113
+ return { text: `❌ Session file not found: ${sessionFile}` };
114
+ }
115
+ // 2. Load session entries
116
+ const sessionManager = SessionManager.open(sessionFile);
117
+ const entries = sessionManager.getEntries();
118
+ const header = sessionManager.getHeader();
119
+ const leafId = sessionManager.getLeafId();
120
+ // 3. Build full system prompt
121
+ const { systemPrompt, tools } = await resolveCommandsSystemPromptBundle(params);
122
+ // 4. Prepare session data
123
+ const sessionData = {
124
+ header,
125
+ entries,
126
+ leafId,
127
+ systemPrompt,
128
+ tools: tools.map((t) => ({
129
+ name: t.name,
130
+ description: t.description,
131
+ parameters: t.parameters,
132
+ })),
133
+ };
134
+ // 5. Generate HTML
135
+ const html = generateHtml(sessionData);
136
+ // 6. Determine output path
137
+ const timestamp = new Date().toISOString().replace(/[:.]/g, "-").slice(0, 19);
138
+ const defaultFileName = `openclaw-session-${entry.sessionId.slice(0, 8)}-${timestamp}.html`;
139
+ const outputPath = args.outputPath
140
+ ? path.resolve(args.outputPath.startsWith("~")
141
+ ? args.outputPath.replace("~", process.env.HOME ?? "")
142
+ : args.outputPath)
143
+ : path.join(params.workspaceDir, defaultFileName);
144
+ // Ensure directory exists
145
+ const outputDir = path.dirname(outputPath);
146
+ if (!fs.existsSync(outputDir)) {
147
+ fs.mkdirSync(outputDir, { recursive: true });
148
+ }
149
+ // 7. Write file
150
+ fs.writeFileSync(outputPath, html, "utf-8");
151
+ const relativePath = path.relative(params.workspaceDir, outputPath);
152
+ const displayPath = relativePath.startsWith("..") ? outputPath : relativePath;
153
+ return {
154
+ text: [
155
+ "✅ Session exported!",
156
+ "",
157
+ `📄 File: ${displayPath}`,
158
+ `📊 Entries: ${entries.length}`,
159
+ `🧠 System prompt: ${systemPrompt.length.toLocaleString()} chars`,
160
+ `🔧 Tools: ${tools.length}`,
161
+ ].join("\n"),
162
+ };
163
+ }
@@ -0,0 +1,245 @@
1
+ import { callGateway } from "../../gateway/call.js";
2
+ import { logVerbose } from "../../globals.js";
3
+ import { GATEWAY_CLIENT_MODES, GATEWAY_CLIENT_NAMES } from "../../utils/message-channel.js";
4
+ const meshPlanCache = new Map();
5
+ const MAX_CACHED_MESH_PLANS = 200;
6
+ function trimMeshPlanCache() {
7
+ if (meshPlanCache.size <= MAX_CACHED_MESH_PLANS) {
8
+ return;
9
+ }
10
+ const oldest = [...meshPlanCache.entries()]
11
+ .toSorted((a, b) => a[1].createdAt - b[1].createdAt)
12
+ .slice(0, meshPlanCache.size - MAX_CACHED_MESH_PLANS);
13
+ for (const [key] of oldest) {
14
+ meshPlanCache.delete(key);
15
+ }
16
+ }
17
+ function parseMeshCommand(commandBody) {
18
+ const trimmed = commandBody.trim();
19
+ if (!/^\/mesh\b/i.test(trimmed)) {
20
+ return null;
21
+ }
22
+ const rest = trimmed.replace(/^\/mesh\b:?/i, "").trim();
23
+ if (!rest || /^help$/i.test(rest)) {
24
+ return { ok: true, action: "help" };
25
+ }
26
+ const tokens = rest.split(/\s+/).filter(Boolean);
27
+ if (tokens.length === 0) {
28
+ return { ok: true, action: "help" };
29
+ }
30
+ const actionCandidate = tokens[0]?.toLowerCase() ?? "";
31
+ const explicitAction = actionCandidate === "run" ||
32
+ actionCandidate === "plan" ||
33
+ actionCandidate === "status" ||
34
+ actionCandidate === "retry"
35
+ ? actionCandidate
36
+ : null;
37
+ if (!explicitAction) {
38
+ // Shorthand: `/mesh <goal>` => auto plan + run
39
+ return { ok: true, action: "run", target: rest };
40
+ }
41
+ const actionArgs = rest.slice(tokens[0]?.length ?? 0).trim();
42
+ if (explicitAction === "plan" || explicitAction === "run") {
43
+ if (!actionArgs) {
44
+ return { ok: false, message: `Usage: /mesh ${explicitAction} <goal>` };
45
+ }
46
+ return { ok: true, action: explicitAction, target: actionArgs };
47
+ }
48
+ if (explicitAction === "status") {
49
+ if (!actionArgs) {
50
+ return { ok: false, message: "Usage: /mesh status <runId>" };
51
+ }
52
+ return { ok: true, action: "status", runId: actionArgs.split(/\s+/)[0] };
53
+ }
54
+ // retry
55
+ const argsTokens = actionArgs.split(/\s+/).filter(Boolean);
56
+ if (argsTokens.length === 0) {
57
+ return { ok: false, message: "Usage: /mesh retry <runId> [step1,step2,...]" };
58
+ }
59
+ const runId = argsTokens[0];
60
+ const stepArg = argsTokens.slice(1).join(" ").trim();
61
+ const stepIds = stepArg.length > 0
62
+ ? stepArg
63
+ .split(",")
64
+ .map((entry) => entry.trim())
65
+ .filter(Boolean)
66
+ : undefined;
67
+ return { ok: true, action: "retry", runId, stepIds };
68
+ }
69
+ function cacheKeyForPlan(params, planId) {
70
+ const sender = params.command.senderId ?? "unknown";
71
+ const channel = params.command.channel || "unknown";
72
+ return `${channel}:${sender}:${planId}`;
73
+ }
74
+ function putCachedPlan(params, plan) {
75
+ meshPlanCache.set(cacheKeyForPlan(params, plan.planId), { plan, createdAt: Date.now() });
76
+ trimMeshPlanCache();
77
+ }
78
+ function getCachedPlan(params, planId) {
79
+ return meshPlanCache.get(cacheKeyForPlan(params, planId))?.plan ?? null;
80
+ }
81
+ function looksLikeMeshPlanId(value) {
82
+ return /^mesh-plan-[a-z0-9-]+$/i.test(value.trim());
83
+ }
84
+ function resolveMeshCommandBody(params) {
85
+ return (params.ctx.BodyForCommands ??
86
+ params.ctx.CommandBody ??
87
+ params.ctx.RawBody ??
88
+ params.ctx.Body ??
89
+ params.command.commandBodyNormalized);
90
+ }
91
+ function formatPlanSummary(plan) {
92
+ const lines = [`🕸️ Mesh Plan`, `Goal: ${plan.goal}`, "", `Steps (${plan.steps.length}):`];
93
+ for (const step of plan.steps) {
94
+ const dependsOn = Array.isArray(step.dependsOn) && step.dependsOn.length > 0;
95
+ const depLine = dependsOn ? ` (depends on: ${step.dependsOn?.join(", ")})` : "";
96
+ lines.push(`- ${step.id}${step.name ? ` — ${step.name}` : ""}${depLine}`);
97
+ lines.push(` ${step.prompt}`);
98
+ }
99
+ return lines.join("\n");
100
+ }
101
+ function formatRunSummary(payload) {
102
+ const stats = payload.stats ?? {};
103
+ return [
104
+ `🕸️ Mesh Run`,
105
+ `Run: ${payload.runId}`,
106
+ `Status: ${payload.status}`,
107
+ `Steps: total=${stats.total ?? 0}, ok=${stats.succeeded ?? 0}, failed=${stats.failed ?? 0}, skipped=${stats.skipped ?? 0}, running=${stats.running ?? 0}, pending=${stats.pending ?? 0}`,
108
+ ].join("\n");
109
+ }
110
+ function meshUsageText() {
111
+ return [
112
+ "🕸️ Mesh command",
113
+ "Usage:",
114
+ "- /mesh <goal> (auto plan + run)",
115
+ "- /mesh plan <goal>",
116
+ "- /mesh run <goal|mesh-plan-id>",
117
+ "- /mesh status <runId>",
118
+ "- /mesh retry <runId> [step1,step2,...]",
119
+ ].join("\n");
120
+ }
121
+ function resolveMeshClientLabel(params) {
122
+ const channel = params.command.channel;
123
+ const sender = params.command.senderId ?? "unknown";
124
+ return `Chat mesh (${channel}:${sender})`;
125
+ }
126
+ export const handleMeshCommand = async (params, allowTextCommands) => {
127
+ if (!allowTextCommands) {
128
+ return null;
129
+ }
130
+ const parsed = parseMeshCommand(resolveMeshCommandBody(params));
131
+ if (!parsed) {
132
+ return null;
133
+ }
134
+ if (!params.command.isAuthorizedSender) {
135
+ logVerbose(`Ignoring /mesh from unauthorized sender: ${params.command.senderId || "<unknown>"}`);
136
+ return { shouldContinue: false };
137
+ }
138
+ if (!parsed.ok) {
139
+ return { shouldContinue: false, reply: { text: parsed.message } };
140
+ }
141
+ if (parsed.action === "help") {
142
+ return { shouldContinue: false, reply: { text: meshUsageText() } };
143
+ }
144
+ const clientDisplayName = resolveMeshClientLabel(params);
145
+ const commonGateway = {
146
+ clientName: GATEWAY_CLIENT_NAMES.GATEWAY_CLIENT,
147
+ clientDisplayName,
148
+ mode: GATEWAY_CLIENT_MODES.BACKEND,
149
+ };
150
+ try {
151
+ if (parsed.action === "plan") {
152
+ const planResp = await callGateway({
153
+ method: "mesh.plan.auto",
154
+ params: {
155
+ goal: parsed.target,
156
+ agentId: params.agentId ?? "main",
157
+ },
158
+ ...commonGateway,
159
+ });
160
+ putCachedPlan(params, planResp.plan);
161
+ const sourceLine = planResp.source ? `\nPlanner source: ${planResp.source}` : "";
162
+ return {
163
+ shouldContinue: false,
164
+ reply: {
165
+ text: `${formatPlanSummary(planResp.plan)}${sourceLine}\n\nRun exact plan: /mesh run ${planResp.plan.planId}`,
166
+ },
167
+ };
168
+ }
169
+ if (parsed.action === "run") {
170
+ let runPlan;
171
+ if (looksLikeMeshPlanId(parsed.target)) {
172
+ const cached = getCachedPlan(params, parsed.target.trim());
173
+ if (!cached) {
174
+ return {
175
+ shouldContinue: false,
176
+ reply: {
177
+ text: `Plan ${parsed.target.trim()} not found in this chat.\nCreate one first: /mesh plan <goal>`,
178
+ },
179
+ };
180
+ }
181
+ runPlan = cached;
182
+ }
183
+ else {
184
+ const planResp = await callGateway({
185
+ method: "mesh.plan.auto",
186
+ params: {
187
+ goal: parsed.target,
188
+ agentId: params.agentId ?? "main",
189
+ },
190
+ ...commonGateway,
191
+ });
192
+ putCachedPlan(params, planResp.plan);
193
+ runPlan = planResp.plan;
194
+ }
195
+ const runResp = await callGateway({
196
+ method: "mesh.run",
197
+ params: {
198
+ plan: runPlan,
199
+ },
200
+ ...commonGateway,
201
+ });
202
+ return {
203
+ shouldContinue: false,
204
+ reply: {
205
+ text: `${formatPlanSummary(runPlan)}\n\n${formatRunSummary(runResp)}`,
206
+ },
207
+ };
208
+ }
209
+ if (parsed.action === "status") {
210
+ const statusResp = await callGateway({
211
+ method: "mesh.status",
212
+ params: { runId: parsed.runId },
213
+ ...commonGateway,
214
+ });
215
+ return {
216
+ shouldContinue: false,
217
+ reply: { text: formatRunSummary(statusResp) },
218
+ };
219
+ }
220
+ if (parsed.action === "retry") {
221
+ const retryResp = await callGateway({
222
+ method: "mesh.retry",
223
+ params: {
224
+ runId: parsed.runId,
225
+ ...(parsed.stepIds && parsed.stepIds.length > 0 ? { stepIds: parsed.stepIds } : {}),
226
+ },
227
+ ...commonGateway,
228
+ });
229
+ return {
230
+ shouldContinue: false,
231
+ reply: { text: `🔁 Retry submitted\n${formatRunSummary(retryResp)}` },
232
+ };
233
+ }
234
+ return null;
235
+ }
236
+ catch (err) {
237
+ const message = err instanceof Error ? err.message : String(err);
238
+ return {
239
+ shouldContinue: false,
240
+ reply: {
241
+ text: `❌ Mesh command failed: ${message}`,
242
+ },
243
+ };
244
+ }
245
+ };
@@ -0,0 +1,28 @@
1
+ import { parseConfigValue } from "./config-value.js";
2
+ export function parseSetUnsetCommand(params) {
3
+ const action = params.action;
4
+ const args = params.args.trim();
5
+ if (action === "unset") {
6
+ if (!args) {
7
+ return { kind: "error", message: `Usage: ${params.slash} unset path` };
8
+ }
9
+ return { kind: "unset", path: args };
10
+ }
11
+ if (!args) {
12
+ return { kind: "error", message: `Usage: ${params.slash} set path=value` };
13
+ }
14
+ const eqIndex = args.indexOf("=");
15
+ if (eqIndex <= 0) {
16
+ return { kind: "error", message: `Usage: ${params.slash} set path=value` };
17
+ }
18
+ const path = args.slice(0, eqIndex).trim();
19
+ const rawValue = args.slice(eqIndex + 1);
20
+ if (!path) {
21
+ return { kind: "error", message: `Usage: ${params.slash} set path=value` };
22
+ }
23
+ const parsed = parseConfigValue(rawValue);
24
+ if (parsed.error) {
25
+ return { kind: "error", message: parsed.error };
26
+ }
27
+ return { kind: "set", path, value: parsed.value };
28
+ }
@@ -0,0 +1,31 @@
1
+ export function parseSlashCommandActionArgs(raw, slash) {
2
+ const trimmed = raw.trim();
3
+ const slashLower = slash.toLowerCase();
4
+ if (!trimmed.toLowerCase().startsWith(slashLower)) {
5
+ return { kind: "no-match" };
6
+ }
7
+ const rest = trimmed.slice(slash.length).trim();
8
+ if (!rest) {
9
+ return { kind: "empty" };
10
+ }
11
+ const match = rest.match(/^(\S+)(?:\s+([\s\S]+))?$/);
12
+ if (!match) {
13
+ return { kind: "invalid" };
14
+ }
15
+ const action = match[1]?.toLowerCase() ?? "";
16
+ const args = (match[2] ?? "").trim();
17
+ return { kind: "parsed", action, args };
18
+ }
19
+ export function parseSlashCommandOrNull(raw, slash, opts) {
20
+ const parsed = parseSlashCommandActionArgs(raw, slash);
21
+ if (parsed.kind === "no-match") {
22
+ return null;
23
+ }
24
+ if (parsed.kind === "invalid") {
25
+ return { ok: false, message: opts.invalidMessage };
26
+ }
27
+ if (parsed.kind === "empty") {
28
+ return { ok: true, action: opts.defaultAction ?? "show", args: "" };
29
+ }
30
+ return { ok: true, action: parsed.action, args: parsed.args };
31
+ }
@@ -0,0 +1,117 @@
1
+ import { resolveSessionAgentIds } from "../../agents/agent-scope.js";
2
+ import { resolveBootstrapContextForRun } from "../../agents/bootstrap-files.js";
3
+ import { resolveDefaultModelForAgent } from "../../agents/model-selection.js";
4
+ import { createOpenClawCodingTools } from "../../agents/pi-tools.js";
5
+ import { resolveSandboxRuntimeStatus } from "../../agents/sandbox.js";
6
+ import { buildWorkspaceSkillSnapshot } from "../../agents/skills.js";
7
+ import { getSkillsSnapshotVersion } from "../../agents/skills/refresh.js";
8
+ import { buildSystemPromptParams } from "../../agents/system-prompt-params.js";
9
+ import { buildAgentSystemPrompt } from "../../agents/system-prompt.js";
10
+ import { buildToolSummaryMap } from "../../agents/tool-summaries.js";
11
+ import { getRemoteSkillEligibility } from "../../infra/skills-remote.js";
12
+ import { buildTtsSystemPromptHint } from "../../tts/tts.js";
13
+ export async function resolveCommandsSystemPromptBundle(params) {
14
+ const workspaceDir = params.workspaceDir;
15
+ const { bootstrapFiles, contextFiles: injectedFiles } = await resolveBootstrapContextForRun({
16
+ workspaceDir,
17
+ config: params.cfg,
18
+ sessionKey: params.sessionKey,
19
+ sessionId: params.sessionEntry?.sessionId,
20
+ });
21
+ const skillsSnapshot = (() => {
22
+ try {
23
+ return buildWorkspaceSkillSnapshot(workspaceDir, {
24
+ config: params.cfg,
25
+ eligibility: { remote: getRemoteSkillEligibility() },
26
+ snapshotVersion: getSkillsSnapshotVersion(workspaceDir),
27
+ });
28
+ }
29
+ catch {
30
+ return { prompt: "", skills: [], resolvedSkills: [] };
31
+ }
32
+ })();
33
+ const skillsPrompt = skillsSnapshot.prompt ?? "";
34
+ const sandboxRuntime = resolveSandboxRuntimeStatus({
35
+ cfg: params.cfg,
36
+ sessionKey: params.ctx.SessionKey ?? params.sessionKey,
37
+ });
38
+ const tools = (() => {
39
+ try {
40
+ return createOpenClawCodingTools({
41
+ config: params.cfg,
42
+ workspaceDir,
43
+ sessionKey: params.sessionKey,
44
+ messageProvider: params.command.channel,
45
+ groupId: params.sessionEntry?.groupId ?? undefined,
46
+ groupChannel: params.sessionEntry?.groupChannel ?? undefined,
47
+ groupSpace: params.sessionEntry?.space ?? undefined,
48
+ spawnedBy: params.sessionEntry?.spawnedBy ?? undefined,
49
+ senderIsOwner: params.command.senderIsOwner,
50
+ modelProvider: params.provider,
51
+ modelId: params.model,
52
+ });
53
+ }
54
+ catch {
55
+ return [];
56
+ }
57
+ })();
58
+ const toolSummaries = buildToolSummaryMap(tools);
59
+ const toolNames = tools.map((t) => t.name);
60
+ const { sessionAgentId } = resolveSessionAgentIds({
61
+ sessionKey: params.sessionKey,
62
+ config: params.cfg,
63
+ });
64
+ const defaultModelRef = resolveDefaultModelForAgent({
65
+ cfg: params.cfg,
66
+ agentId: sessionAgentId,
67
+ });
68
+ const defaultModelLabel = `${defaultModelRef.provider}/${defaultModelRef.model}`;
69
+ const { runtimeInfo, userTimezone, userTime, userTimeFormat } = buildSystemPromptParams({
70
+ config: params.cfg,
71
+ agentId: sessionAgentId,
72
+ workspaceDir,
73
+ cwd: process.cwd(),
74
+ runtime: {
75
+ host: "unknown",
76
+ os: "unknown",
77
+ arch: "unknown",
78
+ node: process.version,
79
+ model: `${params.provider}/${params.model}`,
80
+ defaultModel: defaultModelLabel,
81
+ },
82
+ });
83
+ const sandboxInfo = sandboxRuntime.sandboxed
84
+ ? {
85
+ enabled: true,
86
+ workspaceDir,
87
+ workspaceAccess: "rw",
88
+ elevated: {
89
+ allowed: params.elevated.allowed,
90
+ defaultLevel: (params.resolvedElevatedLevel ?? "off"),
91
+ },
92
+ }
93
+ : { enabled: false };
94
+ const ttsHint = params.cfg ? buildTtsSystemPromptHint(params.cfg) : undefined;
95
+ const systemPrompt = buildAgentSystemPrompt({
96
+ workspaceDir,
97
+ defaultThinkLevel: params.resolvedThinkLevel,
98
+ reasoningLevel: params.resolvedReasoningLevel,
99
+ extraSystemPrompt: undefined,
100
+ ownerNumbers: undefined,
101
+ reasoningTagHint: false,
102
+ toolNames,
103
+ toolSummaries,
104
+ modelAliasLines: [],
105
+ userTimezone,
106
+ userTime,
107
+ userTimeFormat,
108
+ contextFiles: injectedFiles,
109
+ skillsPrompt,
110
+ heartbeatPrompt: undefined,
111
+ ttsHint,
112
+ runtimeInfo,
113
+ sandboxInfo,
114
+ memoryCitationsMode: params.cfg?.memory?.citations,
115
+ });
116
+ return { systemPrompt, tools, skillsPrompt, bootstrapFiles, injectedFiles, sandboxRuntime };
117
+ }