@gguf/pigbot 0.0.1 → 0.0.2

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 (1301) hide show
  1. package/CHANGELOG.md +300 -166
  2. package/README-header.png +0 -0
  3. package/assets/chrome-extension/README.md +5 -5
  4. package/assets/chrome-extension/background.js +5 -5
  5. package/assets/chrome-extension/manifest.json +3 -3
  6. package/assets/chrome-extension/options.html +5 -6
  7. package/assets/chrome-extension/options.js +1 -1
  8. package/dist/acp/client.js +5 -5
  9. package/dist/acp/server.js +3 -3
  10. package/dist/acp/types.js +2 -2
  11. package/dist/agents/agent-paths.js +6 -6
  12. package/dist/agents/anthropic-payload-log.js +2 -2
  13. package/dist/agents/auth-health.js +2 -6
  14. package/dist/agents/auth-profiles/doctor.js +1 -1
  15. package/dist/agents/auth-profiles/external-cli-sync.js +5 -150
  16. package/dist/agents/auth-profiles/oauth.js +26 -7
  17. package/dist/agents/auth-profiles/paths.js +3 -3
  18. package/dist/agents/auth-profiles/store.js +5 -13
  19. package/dist/agents/bash-tools.exec.js +77 -26
  20. package/dist/agents/bash-tools.shared.js +8 -1
  21. package/dist/agents/cache-trace.js +5 -5
  22. package/dist/agents/cli-backends.js +8 -0
  23. package/dist/agents/cli-runner/helpers.js +3 -3
  24. package/dist/agents/cli-runner.js +3 -3
  25. package/dist/agents/compaction.js +3 -0
  26. package/dist/agents/context.js +4 -4
  27. package/dist/agents/docs-path.js +3 -3
  28. package/dist/agents/identity.js +1 -1
  29. package/dist/agents/live-auth-keys.js +2 -2
  30. package/dist/agents/memory-search.js +7 -2
  31. package/dist/agents/minimax-vlm.js +1 -1
  32. package/dist/agents/model-auth.js +1 -1
  33. package/dist/agents/model-catalog.js +23 -5
  34. package/dist/agents/model-fallback.js +22 -0
  35. package/dist/agents/model-selection.js +9 -2
  36. package/dist/agents/models-config.js +3 -3
  37. package/dist/agents/models-config.providers.js +4 -4
  38. package/dist/agents/{pigbot-tools.js → moltbot-tools.js} +7 -6
  39. package/dist/agents/pi-embedded-helpers/errors.js +23 -1
  40. package/dist/agents/pi-embedded-helpers/openai.js +1 -1
  41. package/dist/agents/pi-embedded-runner/cache-ttl.js +1 -1
  42. package/dist/agents/pi-embedded-runner/compact.js +8 -8
  43. package/dist/agents/pi-embedded-runner/extensions.js +5 -0
  44. package/dist/agents/pi-embedded-runner/model.js +9 -3
  45. package/dist/agents/pi-embedded-runner/run/attempt.js +10 -6
  46. package/dist/agents/pi-embedded-runner/run.js +5 -5
  47. package/dist/agents/pi-embedded-runner/sandbox-info.js +1 -4
  48. package/dist/agents/pi-embedded-runner/session-manager-cache.js +1 -1
  49. package/dist/agents/pi-embedded-runner/utils.js +1 -1
  50. package/dist/agents/pi-embedded-subscribe.raw-stream.js +2 -2
  51. package/dist/agents/pi-embedded-utils.js +7 -1
  52. package/dist/agents/pi-extensions/compaction-safeguard-runtime.js +20 -0
  53. package/dist/agents/pi-extensions/compaction-safeguard.js +32 -3
  54. package/dist/agents/pi-tools.js +26 -15
  55. package/dist/agents/pi-tools.policy.js +34 -1
  56. package/dist/agents/pi-tools.read.js +2 -2
  57. package/dist/agents/sandbox/browser.js +10 -12
  58. package/dist/agents/sandbox/config.js +0 -12
  59. package/dist/agents/sandbox/constants.js +8 -8
  60. package/dist/agents/sandbox/context.js +3 -3
  61. package/dist/agents/sandbox/docker.js +8 -8
  62. package/dist/agents/sandbox/runtime-status.js +1 -1
  63. package/dist/agents/session-transcript-repair.js +1 -1
  64. package/dist/agents/session-write-lock.js +68 -0
  65. package/dist/agents/skills/bundled-dir.js +1 -1
  66. package/dist/agents/skills/config.js +9 -8
  67. package/dist/agents/skills/env-overrides.js +1 -1
  68. package/dist/agents/skills/frontmatter.js +15 -14
  69. package/dist/agents/skills/workspace.js +7 -7
  70. package/dist/agents/skills-install.js +1 -1
  71. package/dist/agents/skills-status.js +12 -12
  72. package/dist/agents/subagent-registry.store.js +2 -2
  73. package/dist/agents/system-prompt.js +21 -32
  74. package/dist/agents/tool-images.js +1 -1
  75. package/dist/agents/tool-policy.js +8 -2
  76. package/dist/agents/tools/agents-list-tool.js +3 -1
  77. package/dist/agents/tools/browser-tool.js +19 -79
  78. package/dist/agents/tools/browser-tool.schema.js +1 -2
  79. package/dist/agents/tools/cron-tool.js +44 -1
  80. package/dist/agents/tools/discord-actions-guild.js +5 -1
  81. package/dist/agents/tools/image-tool.js +2 -2
  82. package/dist/agents/tools/message-tool.js +13 -1
  83. package/dist/agents/tools/sessions-send-helpers.js +17 -2
  84. package/dist/agents/tools/sessions-spawn-tool.js +1 -1
  85. package/dist/agents/tools/telegram-actions.js +95 -1
  86. package/dist/agents/tools/web-fetch.js +123 -103
  87. package/dist/agents/tools/web-search.js +7 -7
  88. package/dist/agents/workspace.js +37 -1
  89. package/dist/auto-reply/chunk.js +71 -26
  90. package/dist/auto-reply/commands-registry.data.js +73 -22
  91. package/dist/auto-reply/commands-registry.js +14 -11
  92. package/dist/auto-reply/heartbeat.js +3 -0
  93. package/dist/auto-reply/model.js +1 -1
  94. package/dist/auto-reply/reply/agent-runner-execution.js +21 -3
  95. package/dist/auto-reply/reply/agent-runner-memory.js +5 -0
  96. package/dist/auto-reply/reply/bash-command.js +2 -2
  97. package/dist/auto-reply/reply/block-streaming.js +8 -15
  98. package/dist/auto-reply/reply/commands-context-report.js +2 -2
  99. package/dist/auto-reply/reply/commands-info.js +50 -5
  100. package/dist/auto-reply/reply/commands-plugin.js +4 -2
  101. package/dist/auto-reply/reply/commands-session.js +4 -4
  102. package/dist/auto-reply/reply/commands-tts.js +61 -63
  103. package/dist/auto-reply/reply/directive-handling.shared.js +1 -1
  104. package/dist/auto-reply/reply/directives.js +12 -1
  105. package/dist/auto-reply/reply/dispatch-from-config.js +68 -22
  106. package/dist/auto-reply/reply/followup-runner.js +5 -0
  107. package/dist/auto-reply/reply/get-reply-inline-actions.js +2 -2
  108. package/dist/auto-reply/reply/get-reply-run.js +4 -0
  109. package/dist/auto-reply/reply/get-reply.js +1 -1
  110. package/dist/auto-reply/reply/groups.js +1 -1
  111. package/dist/auto-reply/reply/history.js +23 -0
  112. package/dist/auto-reply/reply/line-directives.js +294 -0
  113. package/dist/auto-reply/reply/normalize-reply.js +13 -5
  114. package/dist/auto-reply/reply/reply-elevated.js +1 -1
  115. package/dist/auto-reply/reply/reply-payloads.js +2 -1
  116. package/dist/auto-reply/reply/route-reply.js +1 -1
  117. package/dist/auto-reply/reply/session-updates.js +6 -1
  118. package/dist/auto-reply/reply/stage-sandbox-media.js +1 -1
  119. package/dist/auto-reply/status.js +144 -42
  120. package/dist/auto-reply/thinking.js +13 -0
  121. package/dist/browser/bridge-server.js +1 -3
  122. package/dist/browser/client-actions-core.js +13 -7
  123. package/dist/browser/client-actions-observe.js +14 -8
  124. package/dist/browser/client-actions-state.js +21 -15
  125. package/dist/browser/client-fetch.js +74 -61
  126. package/dist/browser/client.js +19 -21
  127. package/dist/browser/config.js +13 -26
  128. package/dist/browser/constants.js +1 -1
  129. package/dist/browser/control-service.js +72 -0
  130. package/dist/browser/extension-relay.js +3 -3
  131. package/dist/browser/pw-session.js +41 -4
  132. package/dist/browser/pw-tools-core.downloads.js +1 -1
  133. package/dist/browser/pw-tools-core.interactions.js +5 -5
  134. package/dist/browser/pw-tools-core.responses.js +1 -1
  135. package/dist/browser/routes/agent.act.js +13 -0
  136. package/dist/browser/routes/agent.debug.js +1 -1
  137. package/dist/browser/routes/basic.js +0 -1
  138. package/dist/browser/routes/dispatcher.js +86 -0
  139. package/dist/browser/server-context.js +3 -3
  140. package/dist/browser/server.js +7 -9
  141. package/dist/build-info.json +2 -2
  142. package/dist/canvas-host/a2ui/.bundle.hash +1 -0
  143. package/dist/canvas-host/a2ui/a2ui.bundle.js +1620 -1618
  144. package/dist/canvas-host/a2ui/index.html +28 -28
  145. package/dist/canvas-host/a2ui.js +27 -21
  146. package/dist/canvas-host/server.js +67 -33
  147. package/dist/channels/plugins/actions/discord/handle-action.guild-admin.js +5 -1
  148. package/dist/channels/plugins/actions/telegram.js +62 -7
  149. package/dist/channels/plugins/catalog.js +7 -5
  150. package/dist/channels/plugins/group-mentions.js +48 -1
  151. package/dist/channels/plugins/helpers.js +2 -2
  152. package/dist/channels/plugins/message-action-names.js +1 -0
  153. package/dist/channels/plugins/normalize/imessage.js +36 -0
  154. package/dist/channels/plugins/onboarding/imessage.js +1 -1
  155. package/dist/channels/plugins/onboarding/signal.js +2 -2
  156. package/dist/channels/plugins/onboarding/slack.js +4 -4
  157. package/dist/channels/plugins/onboarding/telegram.js +17 -9
  158. package/dist/channels/plugins/onboarding/whatsapp.js +4 -4
  159. package/dist/channels/plugins/outbound/telegram.js +40 -0
  160. package/dist/channels/plugins/pairing-message.js +1 -1
  161. package/dist/channels/plugins/status-issues/bluebubbles.js +1 -1
  162. package/dist/channels/plugins/status-issues/whatsapp.js +2 -2
  163. package/dist/channels/registry.js +1 -1
  164. package/dist/cli/acp-cli.js +2 -2
  165. package/dist/cli/argv.js +14 -7
  166. package/dist/cli/banner.js +3 -1
  167. package/dist/cli/browser-cli-actions-input/register.element.js +72 -44
  168. package/dist/cli/browser-cli-actions-input/register.files-downloads.js +55 -35
  169. package/dist/cli/browser-cli-actions-input/register.form-wait-eval.js +41 -28
  170. package/dist/cli/browser-cli-actions-input/register.navigation.js +23 -14
  171. package/dist/cli/browser-cli-actions-input/shared.js +10 -3
  172. package/dist/cli/browser-cli-actions-observe.js +29 -21
  173. package/dist/cli/browser-cli-debug.js +49 -35
  174. package/dist/cli/browser-cli-examples.js +29 -29
  175. package/dist/cli/browser-cli-extension.js +8 -8
  176. package/dist/cli/browser-cli-inspect.js +23 -17
  177. package/dist/cli/browser-cli-manage.js +106 -56
  178. package/dist/cli/browser-cli-shared.js +34 -1
  179. package/dist/cli/browser-cli-state.cookies-storage.js +53 -39
  180. package/dist/cli/browser-cli-state.js +90 -64
  181. package/dist/cli/browser-cli.js +4 -5
  182. package/dist/cli/channel-options.js +1 -1
  183. package/dist/cli/channels-cli.js +1 -1
  184. package/dist/cli/cli-name.js +26 -0
  185. package/dist/cli/command-format.js +12 -8
  186. package/dist/cli/config-cli.js +2 -2
  187. package/dist/cli/cron-cli/register.js +1 -1
  188. package/dist/cli/daemon-cli/install.js +3 -2
  189. package/dist/cli/daemon-cli/register.js +1 -1
  190. package/dist/cli/daemon-cli/shared.js +13 -11
  191. package/dist/cli/daemon-cli/status.gather.js +2 -2
  192. package/dist/cli/daemon-cli/status.print.js +8 -8
  193. package/dist/cli/directory-cli.js +1 -1
  194. package/dist/cli/dns-cli.js +7 -7
  195. package/dist/cli/docs-cli.js +2 -2
  196. package/dist/cli/exec-approvals-cli.js +2 -2
  197. package/dist/cli/gateway-cli/dev.js +5 -5
  198. package/dist/cli/gateway-cli/register.js +1 -1
  199. package/dist/cli/gateway-cli/run.js +19 -16
  200. package/dist/cli/gateway-cli/shared.js +5 -5
  201. package/dist/cli/hooks-cli.js +3 -3
  202. package/dist/cli/logs-cli.js +3 -3
  203. package/dist/cli/memory-cli.js +1 -1
  204. package/dist/cli/models-cli.js +2 -2
  205. package/dist/cli/node-cli/daemon.js +3 -3
  206. package/dist/cli/node-cli/register.js +1 -1
  207. package/dist/cli/nodes-camera.js +3 -1
  208. package/dist/cli/nodes-canvas.js +3 -1
  209. package/dist/cli/nodes-cli/register.canvas.js +1 -1
  210. package/dist/cli/nodes-cli/register.js +1 -1
  211. package/dist/cli/nodes-screen.js +1 -1
  212. package/dist/cli/pairing-cli.js +3 -3
  213. package/dist/cli/plugin-registry.js +2 -2
  214. package/dist/cli/plugins-cli.js +3 -3
  215. package/dist/cli/profile.js +9 -9
  216. package/dist/cli/program/config-guard.js +1 -1
  217. package/dist/cli/program/help.js +15 -16
  218. package/dist/cli/program/message/register.send.js +2 -1
  219. package/dist/cli/program/preaction.js +5 -3
  220. package/dist/cli/program/register.agent.js +12 -12
  221. package/dist/cli/program/register.configure.js +1 -1
  222. package/dist/cli/program/register.maintenance.js +4 -4
  223. package/dist/cli/program/register.message.js +5 -5
  224. package/dist/cli/program/register.onboard.js +5 -3
  225. package/dist/cli/program/register.setup.js +2 -2
  226. package/dist/cli/program/register.status-health-sessions.js +13 -13
  227. package/dist/cli/program/register.subclis.js +2 -2
  228. package/dist/cli/route.js +1 -1
  229. package/dist/cli/run-main.js +11 -4
  230. package/dist/cli/sandbox-cli.js +19 -19
  231. package/dist/cli/security-cli.js +18 -8
  232. package/dist/cli/skills-cli.js +3 -3
  233. package/dist/cli/system-cli.js +1 -1
  234. package/dist/cli/tagline.js +2 -2
  235. package/dist/cli/tui-cli.js +1 -1
  236. package/dist/cli/update-cli.js +64 -48
  237. package/dist/cli/webhooks-cli.js +6 -6
  238. package/dist/commands/agent-via-gateway.js +1 -1
  239. package/dist/commands/agent.js +2 -1
  240. package/dist/commands/agents.command-shared.js +1 -1
  241. package/dist/commands/agents.commands.add.js +2 -3
  242. package/dist/commands/agents.commands.list.js +1 -1
  243. package/dist/commands/auth-choice-options.js +4 -54
  244. package/dist/commands/auth-choice.apply.anthropic.js +6 -109
  245. package/dist/commands/auth-choice.apply.openai.js +1 -33
  246. package/dist/commands/auth-choice.apply.plugin-provider.js +2 -2
  247. package/dist/commands/channels/list.js +2 -2
  248. package/dist/commands/channels/shared.js +1 -1
  249. package/dist/commands/channels/status.js +1 -1
  250. package/dist/commands/chutes-oauth.js +1 -1
  251. package/dist/commands/configure.channels.js +4 -4
  252. package/dist/commands/configure.daemon.js +10 -2
  253. package/dist/commands/configure.gateway-auth.js +1 -8
  254. package/dist/commands/configure.gateway.js +1 -10
  255. package/dist/commands/configure.wizard.js +21 -21
  256. package/dist/commands/daemon-install-helpers.js +10 -3
  257. package/dist/commands/dashboard.js +2 -2
  258. package/dist/commands/docs.js +5 -5
  259. package/dist/commands/doctor-auth.js +122 -3
  260. package/dist/commands/doctor-config-flow.js +7 -7
  261. package/dist/commands/doctor-format.js +5 -5
  262. package/dist/commands/doctor-gateway-daemon-flow.js +5 -4
  263. package/dist/commands/doctor-gateway-services.js +7 -5
  264. package/dist/commands/doctor-platform-notes.js +7 -7
  265. package/dist/commands/doctor-security.js +48 -1
  266. package/dist/commands/doctor-state-integrity.js +3 -3
  267. package/dist/commands/doctor-ui.js +2 -2
  268. package/dist/commands/doctor-update.js +5 -5
  269. package/dist/commands/doctor-workspace-status.js +2 -2
  270. package/dist/commands/doctor-workspace.js +4 -4
  271. package/dist/commands/doctor.js +13 -12
  272. package/dist/commands/gateway-status/helpers.js +2 -2
  273. package/dist/commands/gateway-status.js +2 -2
  274. package/dist/commands/health.js +2 -2
  275. package/dist/commands/models/auth.js +23 -22
  276. package/dist/commands/models/list.probe.js +2 -2
  277. package/dist/commands/models/list.registry.js +4 -4
  278. package/dist/commands/models/list.status-command.js +8 -9
  279. package/dist/commands/node-daemon-install-helpers.js +1 -1
  280. package/dist/commands/onboard-auth.credentials.js +2 -2
  281. package/dist/commands/onboard-channels.js +3 -3
  282. package/dist/commands/onboard-helpers.js +4 -4
  283. package/dist/commands/onboard-hooks.js +4 -4
  284. package/dist/commands/onboard-non-interactive/local/auth-choice.js +38 -34
  285. package/dist/commands/onboard-non-interactive/local/daemon-install.js +1 -0
  286. package/dist/commands/onboard-non-interactive/local/gateway-config.js +7 -4
  287. package/dist/commands/onboard-non-interactive/local.js +1 -1
  288. package/dist/commands/onboard-non-interactive/remote.js +1 -1
  289. package/dist/commands/onboard-non-interactive.js +1 -1
  290. package/dist/commands/onboard-remote.js +2 -2
  291. package/dist/commands/onboard-skills.js +2 -2
  292. package/dist/commands/onboard.js +25 -4
  293. package/dist/commands/onboarding/plugin-install.js +2 -2
  294. package/dist/commands/reset.js +3 -3
  295. package/dist/commands/sandbox-display.js +1 -1
  296. package/dist/commands/sandbox-explain.js +2 -2
  297. package/dist/commands/setup.js +2 -2
  298. package/dist/commands/signal-install.js +2 -2
  299. package/dist/commands/status-all/diagnosis.js +1 -1
  300. package/dist/commands/status-all/report-lines.js +1 -1
  301. package/dist/commands/status-all.js +5 -5
  302. package/dist/commands/status.command.js +9 -9
  303. package/dist/commands/status.gateway-probe.js +2 -2
  304. package/dist/commands/status.scan.js +2 -2
  305. package/dist/commands/status.update.js +3 -3
  306. package/dist/commands/uninstall.js +4 -4
  307. package/dist/compat/legacy-names.js +6 -0
  308. package/dist/config/config.js +1 -1
  309. package/dist/config/env-vars.js +21 -0
  310. package/dist/config/group-policy.js +69 -0
  311. package/dist/config/io.js +24 -28
  312. package/dist/config/legacy.migrations.part-3.js +3 -0
  313. package/dist/config/logging.js +3 -3
  314. package/dist/config/paths.js +57 -17
  315. package/dist/config/schema.js +26 -12
  316. package/dist/config/sessions/store.js +1 -1
  317. package/dist/config/sessions/transcript.js +1 -1
  318. package/dist/config/types.clawdbot.js +1 -0
  319. package/dist/config/types.js +1 -1
  320. package/dist/config/validation.js +2 -2
  321. package/dist/config/version.js +4 -4
  322. package/dist/config/zod-schema.agent-defaults.js +1 -0
  323. package/dist/config/zod-schema.agent-runtime.js +39 -7
  324. package/dist/config/zod-schema.hooks.js +2 -0
  325. package/dist/config/zod-schema.js +10 -3
  326. package/dist/config/zod-schema.providers-core.js +24 -0
  327. package/dist/config/zod-schema.providers-whatsapp.js +3 -0
  328. package/dist/control-ui/assets/index-BAFzd9IE.css +1 -0
  329. package/dist/control-ui/assets/index-CxUFDXFX.js +3162 -0
  330. package/dist/control-ui/assets/index-CxUFDXFX.js.map +1 -0
  331. package/dist/control-ui/index.html +4 -4
  332. package/dist/cron/isolated-agent/run.js +38 -3
  333. package/dist/daemon/constants.js +26 -16
  334. package/dist/daemon/inspect.js +16 -15
  335. package/dist/daemon/launchd.js +8 -8
  336. package/dist/daemon/node-service.js +14 -14
  337. package/dist/daemon/paths.js +3 -3
  338. package/dist/daemon/program-args.js +1 -1
  339. package/dist/daemon/schtasks.js +6 -6
  340. package/dist/daemon/service-env.js +21 -21
  341. package/dist/daemon/systemd-hints.js +1 -1
  342. package/dist/daemon/systemd-unit.js +1 -1
  343. package/dist/daemon/systemd.js +6 -6
  344. package/dist/discord/monitor/listeners.js +25 -1
  345. package/dist/discord/monitor/native-command.js +7 -5
  346. package/dist/discord/monitor/presence-cache.js +38 -0
  347. package/dist/discord/monitor/provider.js +21 -7
  348. package/dist/entry.js +7 -7
  349. package/dist/gateway/auth.js +55 -22
  350. package/dist/gateway/call.js +2 -2
  351. package/dist/gateway/control-ui.js +4 -4
  352. package/dist/gateway/hooks-mapping.js +18 -4
  353. package/dist/gateway/hooks.js +5 -7
  354. package/dist/gateway/http-utils.js +3 -5
  355. package/dist/gateway/net.js +1 -1
  356. package/dist/gateway/openai-http.js +3 -3
  357. package/dist/gateway/openresponses-http.js +4 -4
  358. package/dist/gateway/protocol/client-info.js +5 -5
  359. package/dist/gateway/protocol/schema/logs-chat.js +1 -1
  360. package/dist/gateway/server/__tests__/test-utils.js +2 -0
  361. package/dist/gateway/server/health-state.js +3 -3
  362. package/dist/gateway/server/hooks.js +1 -0
  363. package/dist/gateway/server/plugins-http.js +23 -2
  364. package/dist/gateway/server/ws-connection/message-handler.js +66 -19
  365. package/dist/gateway/server-browser.js +16 -5
  366. package/dist/gateway/server-chat.js +28 -2
  367. package/dist/gateway/server-constants.js +2 -2
  368. package/dist/gateway/server-cron.js +1 -1
  369. package/dist/gateway/server-discovery-runtime.js +25 -17
  370. package/dist/gateway/server-discovery.js +7 -7
  371. package/dist/gateway/server-http.js +13 -7
  372. package/dist/gateway/server-methods/agent.js +2 -0
  373. package/dist/gateway/server-methods/browser.js +204 -0
  374. package/dist/gateway/server-methods/chat.js +5 -0
  375. package/dist/gateway/server-methods/config.js +8 -8
  376. package/dist/gateway/server-methods/logs.js +1 -1
  377. package/dist/gateway/server-methods/skills.js +3 -3
  378. package/dist/gateway/server-methods/update.js +2 -2
  379. package/dist/gateway/server-methods-list.js +1 -0
  380. package/dist/gateway/server-methods.js +3 -0
  381. package/dist/gateway/server-plugins.js +2 -2
  382. package/dist/gateway/server-reload-handlers.js +5 -5
  383. package/dist/gateway/server-restart-sentinel.js +10 -5
  384. package/dist/gateway/server-runtime-config.js +7 -4
  385. package/dist/gateway/server-startup.js +5 -5
  386. package/dist/gateway/server.impl.js +17 -7
  387. package/dist/gateway/session-utils.fs.js +1 -1
  388. package/dist/gateway/session-utils.js +31 -11
  389. package/dist/gateway/test-helpers.mocks.js +8 -7
  390. package/dist/gateway/test-helpers.server.js +51 -32
  391. package/dist/gateway/tools-invoke-http.js +15 -8
  392. package/dist/hooks/bundled/boot-md/HOOK.md +3 -3
  393. package/dist/hooks/bundled/command-logger/HOOK.md +12 -12
  394. package/dist/hooks/bundled/command-logger/handler.js +1 -1
  395. package/dist/hooks/bundled/session-memory/HOOK.md +4 -4
  396. package/dist/hooks/bundled/session-memory/handler.js +2 -2
  397. package/dist/hooks/bundled/soul-evil/HOOK.md +5 -5
  398. package/dist/hooks/bundled-dir.js +2 -2
  399. package/dist/hooks/config.js +8 -7
  400. package/dist/hooks/frontmatter.js +16 -15
  401. package/dist/hooks/gmail-ops.js +4 -4
  402. package/dist/hooks/gmail-watcher.js +1 -1
  403. package/dist/hooks/hooks-status.js +13 -13
  404. package/dist/hooks/install.js +8 -7
  405. package/dist/hooks/internal-hooks.js +1 -1
  406. package/dist/hooks/llm-slug-generator.js +1 -1
  407. package/dist/hooks/loader.js +3 -3
  408. package/dist/hooks/plugin-hooks.js +8 -8
  409. package/dist/hooks/workspace.js +10 -9
  410. package/dist/imessage/monitor/monitor-provider.js +2 -2
  411. package/dist/imessage/targets.js +19 -0
  412. package/dist/index.js +4 -4
  413. package/dist/infra/agent-events.js +3 -0
  414. package/dist/infra/bonjour-discovery.js +9 -9
  415. package/dist/infra/bonjour.js +20 -13
  416. package/dist/infra/device-identity.js +1 -1
  417. package/dist/infra/diagnostic-flags.js +66 -0
  418. package/dist/infra/dotenv.js +1 -1
  419. package/dist/infra/env.js +22 -0
  420. package/dist/infra/exec-approvals.js +2 -2
  421. package/dist/infra/fs-safe.js +76 -0
  422. package/dist/infra/gateway-lock.js +5 -4
  423. package/dist/infra/heartbeat-visibility.js +14 -0
  424. package/dist/infra/heartbeat-wake.js +2 -2
  425. package/dist/infra/machine-name.js +1 -1
  426. package/dist/infra/{pigbot-root.js → moltbot-root.js} +3 -2
  427. package/dist/infra/net/ssrf.js +77 -1
  428. package/dist/infra/node-shell.js +1 -1
  429. package/dist/infra/outbound/deliver.js +41 -18
  430. package/dist/infra/outbound/message-action-runner.js +24 -3
  431. package/dist/infra/outbound/message-action-spec.js +1 -0
  432. package/dist/infra/outbound/message.js +1 -0
  433. package/dist/infra/outbound/outbound-policy.js +4 -1
  434. package/dist/infra/outbound/outbound-send-service.js +10 -0
  435. package/dist/infra/outbound/payloads.js +15 -5
  436. package/dist/infra/outbound/target-resolver.js +53 -14
  437. package/dist/infra/outbound/targets.js +1 -1
  438. package/dist/infra/path-env.js +9 -9
  439. package/dist/infra/ports-format.js +2 -2
  440. package/dist/infra/ports.js +2 -2
  441. package/dist/infra/provider-usage.auth.js +2 -4
  442. package/dist/infra/provider-usage.fetch.claude.js +1 -1
  443. package/dist/infra/provider-usage.fetch.minimax.js +1 -1
  444. package/dist/infra/restart-sentinel.js +1 -1
  445. package/dist/infra/restart.js +4 -4
  446. package/dist/infra/retry-policy.js +4 -1
  447. package/dist/infra/runtime-guard.js +2 -2
  448. package/dist/infra/shell-env.js +4 -4
  449. package/dist/infra/skills-remote.js +3 -3
  450. package/dist/infra/state-migrations.js +1 -1
  451. package/dist/infra/system-presence.js +1 -1
  452. package/dist/infra/tailscale.js +63 -1
  453. package/dist/infra/tls/gateway.js +1 -1
  454. package/dist/infra/unhandled-rejections.js +89 -2
  455. package/dist/infra/update-check.js +2 -4
  456. package/dist/infra/update-global.js +5 -5
  457. package/dist/infra/update-runner.js +32 -8
  458. package/dist/infra/update-startup.js +3 -3
  459. package/dist/infra/warnings.js +1 -1
  460. package/dist/infra/widearea-dns.js +10 -10
  461. package/dist/line/accounts.js +130 -0
  462. package/dist/line/auto-reply-delivery.js +102 -0
  463. package/dist/line/bot-access.js +38 -0
  464. package/dist/line/bot-handlers.js +258 -0
  465. package/dist/line/bot-message-context.js +374 -0
  466. package/dist/line/bot.js +48 -0
  467. package/dist/line/config-schema.js +47 -0
  468. package/dist/line/download.js +95 -0
  469. package/dist/line/flex-templates.js +1264 -0
  470. package/dist/line/http-registry.js +27 -0
  471. package/dist/line/index.js +19 -0
  472. package/dist/line/markdown-to-line.js +346 -0
  473. package/dist/line/monitor.js +266 -0
  474. package/dist/line/probe.js +37 -0
  475. package/dist/line/reply-chunks.js +53 -0
  476. package/dist/line/rich-menu.js +320 -0
  477. package/dist/line/send.js +451 -0
  478. package/dist/line/signature.js +11 -0
  479. package/dist/line/template-messages.js +258 -0
  480. package/dist/line/types.js +1 -0
  481. package/dist/line/webhook.js +71 -0
  482. package/dist/link-understanding/apply.js +22 -0
  483. package/dist/link-understanding/defaults.js +2 -0
  484. package/dist/link-understanding/detect.js +49 -0
  485. package/dist/link-understanding/format.js +10 -0
  486. package/dist/link-understanding/index.js +4 -0
  487. package/dist/link-understanding/runner.js +99 -0
  488. package/dist/logging/logger.js +4 -4
  489. package/dist/macos/gateway-daemon.js +7 -7
  490. package/dist/macos/relay-smoke.js +1 -1
  491. package/dist/macos/relay.js +6 -6
  492. package/dist/media/host.js +1 -1
  493. package/dist/media/image-ops.js +3 -3
  494. package/dist/media/input-files.js +40 -32
  495. package/dist/media/server.js +39 -15
  496. package/dist/media/store.js +72 -52
  497. package/dist/media-understanding/attachments.js +1 -1
  498. package/dist/media-understanding/providers/image.js +2 -2
  499. package/dist/media-understanding/runner.js +69 -1
  500. package/dist/memory/batch-gemini.js +2 -2
  501. package/dist/memory/batch-openai.js +1 -1
  502. package/dist/memory/embeddings-gemini.js +1 -1
  503. package/dist/memory/embeddings.js +1 -1
  504. package/dist/node-host/runner.js +64 -60
  505. package/dist/pairing/pairing-messages.js +2 -2
  506. package/dist/plugin-sdk/index.js +12 -2
  507. package/dist/plugins/bundled-dir.js +1 -1
  508. package/dist/plugins/cli.js +2 -2
  509. package/dist/plugins/commands.js +1 -1
  510. package/dist/plugins/discovery.js +6 -5
  511. package/dist/plugins/http-path.js +10 -0
  512. package/dist/plugins/http-registry.js +31 -0
  513. package/dist/plugins/install.js +8 -7
  514. package/dist/plugins/loader.js +11 -4
  515. package/dist/plugins/manifest-registry.js +4 -4
  516. package/dist/plugins/manifest.js +16 -1
  517. package/dist/plugins/providers.js +2 -2
  518. package/dist/plugins/registry.js +36 -5
  519. package/dist/plugins/runtime/index.js +26 -0
  520. package/dist/plugins/runtime.js +2 -1
  521. package/dist/plugins/services.js +3 -3
  522. package/dist/plugins/status.js +2 -2
  523. package/dist/plugins/tools.js +2 -2
  524. package/dist/plugins/update.js +3 -3
  525. package/dist/process/exec.js +11 -7
  526. package/dist/process/spawn-utils.js +95 -0
  527. package/dist/providers/qwen-portal-oauth.js +1 -1
  528. package/dist/routing/session-key.js +17 -12
  529. package/dist/security/audit-extra.js +120 -70
  530. package/dist/security/audit-fs.js +78 -0
  531. package/dist/security/audit.js +145 -87
  532. package/dist/security/external-content.js +143 -0
  533. package/dist/security/fix.js +93 -8
  534. package/dist/security/windows-acl.js +162 -0
  535. package/dist/shared/text/reasoning-tags.js +48 -0
  536. package/dist/slack/monitor/media.js +32 -4
  537. package/dist/slack/monitor/message-handler/dispatch.js +2 -1
  538. package/dist/slack/monitor/slash.js +3 -3
  539. package/dist/slack/monitor.test-helpers.js +1 -1
  540. package/dist/telegram/accounts.js +1 -1
  541. package/dist/telegram/api-logging.js +24 -0
  542. package/dist/telegram/bot/delivery.js +218 -28
  543. package/dist/telegram/bot/helpers.js +29 -19
  544. package/dist/telegram/bot-handlers.js +70 -8
  545. package/dist/telegram/bot-message-context.js +83 -22
  546. package/dist/telegram/bot-message-dispatch.js +69 -0
  547. package/dist/telegram/bot-native-commands.js +245 -94
  548. package/dist/telegram/bot.js +18 -2
  549. package/dist/telegram/fetch.js +25 -1
  550. package/dist/telegram/monitor.js +11 -3
  551. package/dist/telegram/network-config.js +23 -0
  552. package/dist/telegram/network-errors.js +103 -0
  553. package/dist/telegram/send.js +229 -41
  554. package/dist/telegram/sticker-cache.js +202 -0
  555. package/dist/telegram/webhook-set.js +13 -6
  556. package/dist/telegram/webhook.js +8 -3
  557. package/dist/terminal/links.js +1 -1
  558. package/dist/tts/tts.js +128 -25
  559. package/dist/tui/components/filterable-select-list.js +1 -1
  560. package/dist/tui/components/searchable-select-list.js +2 -1
  561. package/dist/tui/gateway-chat.js +3 -3
  562. package/dist/tui/tui.js +1 -1
  563. package/dist/utils.js +3 -3
  564. package/dist/version.js +3 -3
  565. package/dist/web/active-listener.js +1 -1
  566. package/dist/web/auth-store.js +1 -1
  567. package/dist/web/auto-reply/monitor/process-message.js +1 -1
  568. package/dist/web/auto-reply/monitor.js +1 -1
  569. package/dist/web/login.js +1 -1
  570. package/dist/web/session.js +2 -2
  571. package/dist/wizard/onboarding.finalize.js +22 -21
  572. package/dist/wizard/onboarding.gateway-config.js +1 -11
  573. package/dist/wizard/onboarding.js +24 -13
  574. package/docs/CNAME +1 -1
  575. package/docs/_config.yml +2 -2
  576. package/docs/_layouts/default.html +9 -9
  577. package/docs/assets/terminal.css +3 -0
  578. package/docs/assets/theme.js +1 -1
  579. package/docs/automation/auth-monitoring.md +7 -7
  580. package/docs/automation/cron-jobs.md +19 -19
  581. package/docs/automation/cron-vs-heartbeat.md +8 -8
  582. package/docs/automation/gmail-pubsub.md +27 -25
  583. package/docs/automation/poll.md +7 -7
  584. package/docs/automation/webhook.md +13 -8
  585. package/docs/bedrock.md +10 -10
  586. package/docs/brave-search.md +1 -1
  587. package/docs/broadcast-groups.md +4 -4
  588. package/docs/channels/bluebubbles.md +14 -12
  589. package/docs/channels/discord.md +23 -18
  590. package/docs/channels/googlechat.md +16 -16
  591. package/docs/channels/grammy.md +1 -1
  592. package/docs/channels/imessage.md +14 -14
  593. package/docs/channels/index.md +6 -4
  594. package/docs/channels/line.md +183 -0
  595. package/docs/channels/location.md +1 -1
  596. package/docs/channels/matrix.md +16 -16
  597. package/docs/channels/mattermost.md +8 -8
  598. package/docs/channels/msteams.md +31 -27
  599. package/docs/channels/nextcloud-talk.md +8 -8
  600. package/docs/channels/nostr.md +9 -9
  601. package/docs/channels/signal.md +11 -11
  602. package/docs/channels/slack.md +31 -29
  603. package/docs/channels/telegram.md +152 -22
  604. package/docs/channels/tlon.md +5 -5
  605. package/docs/channels/troubleshooting.md +2 -2
  606. package/docs/channels/twitch.md +366 -0
  607. package/docs/channels/whatsapp.md +26 -26
  608. package/docs/channels/zalo.md +8 -8
  609. package/docs/channels/zalouser.md +12 -12
  610. package/docs/cli/acp.md +24 -24
  611. package/docs/cli/agent.md +6 -6
  612. package/docs/cli/agents.md +9 -9
  613. package/docs/cli/approvals.md +14 -14
  614. package/docs/cli/browser.md +33 -35
  615. package/docs/cli/channels.md +21 -21
  616. package/docs/cli/config.md +15 -15
  617. package/docs/cli/configure.md +6 -6
  618. package/docs/cli/cron.md +5 -5
  619. package/docs/cli/dashboard.md +4 -4
  620. package/docs/cli/devices.md +13 -13
  621. package/docs/cli/directory.md +12 -12
  622. package/docs/cli/dns.md +5 -5
  623. package/docs/cli/docs.md +5 -5
  624. package/docs/cli/doctor.md +11 -11
  625. package/docs/cli/gateway.md +26 -26
  626. package/docs/cli/health.md +5 -5
  627. package/docs/cli/hooks.md +34 -34
  628. package/docs/cli/index.md +46 -52
  629. package/docs/cli/logs.md +6 -6
  630. package/docs/cli/memory.md +11 -11
  631. package/docs/cli/message.md +11 -11
  632. package/docs/cli/models.md +17 -17
  633. package/docs/cli/node.md +14 -14
  634. package/docs/cli/nodes.md +14 -14
  635. package/docs/cli/onboard.md +7 -6
  636. package/docs/cli/pairing.md +4 -4
  637. package/docs/cli/plugins.md +16 -16
  638. package/docs/cli/reset.md +5 -5
  639. package/docs/cli/sandbox.md +28 -28
  640. package/docs/cli/security.md +5 -5
  641. package/docs/cli/sessions.md +5 -5
  642. package/docs/cli/setup.md +6 -6
  643. package/docs/cli/skills.md +6 -6
  644. package/docs/cli/status.md +7 -7
  645. package/docs/cli/system.md +6 -6
  646. package/docs/cli/tui.md +5 -5
  647. package/docs/cli/uninstall.md +5 -5
  648. package/docs/cli/update.md +20 -20
  649. package/docs/cli/voicecall.md +9 -9
  650. package/docs/cli/webhooks.md +5 -5
  651. package/docs/concepts/agent-loop.md +5 -5
  652. package/docs/concepts/agent-workspace.md +21 -21
  653. package/docs/concepts/agent.md +12 -12
  654. package/docs/concepts/architecture.md +2 -2
  655. package/docs/concepts/channel-routing.md +4 -4
  656. package/docs/concepts/compaction.md +5 -5
  657. package/docs/concepts/context.md +6 -6
  658. package/docs/concepts/group-messages.md +6 -6
  659. package/docs/concepts/groups.md +41 -5
  660. package/docs/concepts/markdown-formatting.md +3 -3
  661. package/docs/concepts/memory.md +14 -14
  662. package/docs/concepts/messages.md +4 -4
  663. package/docs/concepts/model-failover.md +14 -14
  664. package/docs/concepts/model-providers.md +22 -22
  665. package/docs/concepts/models.md +27 -27
  666. package/docs/concepts/multi-agent.md +19 -19
  667. package/docs/concepts/oauth.md +32 -59
  668. package/docs/concepts/presence.md +2 -2
  669. package/docs/concepts/retry.md +1 -1
  670. package/docs/concepts/session-pruning.md +1 -1
  671. package/docs/concepts/session-tool.md +4 -4
  672. package/docs/concepts/session.md +14 -14
  673. package/docs/concepts/streaming.md +4 -4
  674. package/docs/concepts/system-prompt.md +11 -11
  675. package/docs/concepts/timezone.md +2 -2
  676. package/docs/concepts/typebox.md +3 -3
  677. package/docs/concepts/typing-indicators.md +2 -2
  678. package/docs/concepts/usage-tracking.md +3 -3
  679. package/docs/date-time.md +2 -2
  680. package/docs/debug/node-issue.md +4 -4
  681. package/docs/debugging.md +18 -18
  682. package/docs/diagnostics/flags.md +89 -0
  683. package/docs/docs.json +37 -7
  684. package/docs/environment.md +7 -7
  685. package/docs/experiments/plans/cron-add-hardening.md +1 -1
  686. package/docs/experiments/plans/openresponses-gateway.md +2 -2
  687. package/docs/experiments/research/memory.md +6 -6
  688. package/docs/gateway/authentication.md +33 -57
  689. package/docs/gateway/background-process.md +2 -2
  690. package/docs/gateway/bonjour.md +25 -25
  691. package/docs/gateway/bridge-protocol.md +2 -2
  692. package/docs/gateway/cli-backends.md +13 -12
  693. package/docs/gateway/configuration-examples.md +14 -14
  694. package/docs/gateway/configuration.md +160 -145
  695. package/docs/gateway/discovery.md +10 -10
  696. package/docs/gateway/doctor.md +27 -27
  697. package/docs/gateway/gateway-lock.md +1 -1
  698. package/docs/gateway/health.md +11 -11
  699. package/docs/gateway/heartbeat.md +5 -5
  700. package/docs/gateway/index.md +65 -65
  701. package/docs/gateway/local-models.md +2 -2
  702. package/docs/gateway/logging.md +8 -8
  703. package/docs/gateway/multiple-gateways.md +27 -27
  704. package/docs/gateway/openai-http-api.md +12 -12
  705. package/docs/gateway/openresponses-http-api.md +12 -12
  706. package/docs/gateway/pairing.md +9 -9
  707. package/docs/gateway/protocol.md +6 -5
  708. package/docs/gateway/remote-gateway-readme.md +16 -14
  709. package/docs/gateway/remote.md +5 -5
  710. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +10 -7
  711. package/docs/gateway/sandboxing.md +8 -6
  712. package/docs/gateway/security/formal-verification.md +107 -0
  713. package/docs/gateway/{security.md → security/index.md} +172 -75
  714. package/docs/gateway/tailscale.md +19 -38
  715. package/docs/gateway/tools-invoke-http-api.md +5 -5
  716. package/docs/gateway/troubleshooting.md +114 -119
  717. package/docs/help/faq.md +369 -355
  718. package/docs/help/troubleshooting.md +16 -16
  719. package/docs/hooks/soul-evil.md +2 -2
  720. package/docs/hooks.md +60 -60
  721. package/docs/index.md +35 -35
  722. package/docs/install/ansible.md +35 -35
  723. package/docs/install/development-channels.md +10 -10
  724. package/docs/install/docker.md +44 -44
  725. package/docs/install/index.md +34 -33
  726. package/docs/install/installer.md +24 -24
  727. package/docs/install/migrating.md +190 -0
  728. package/docs/install/nix.md +18 -18
  729. package/docs/install/node.md +7 -6
  730. package/docs/install/uninstall.md +30 -30
  731. package/docs/install/updating.md +50 -49
  732. package/docs/logging.md +82 -58
  733. package/docs/multi-agent-sandbox-tools.md +7 -7
  734. package/docs/network.md +1 -1
  735. package/docs/nodes/audio.md +2 -2
  736. package/docs/nodes/camera.md +18 -18
  737. package/docs/nodes/images.md +4 -4
  738. package/docs/nodes/index.md +57 -57
  739. package/docs/nodes/location-command.md +2 -2
  740. package/docs/nodes/media-understanding.md +5 -5
  741. package/docs/nodes/talk.md +1 -1
  742. package/docs/nodes/voicewake.md +2 -2
  743. package/docs/northflank.mdx +53 -0
  744. package/docs/perplexity.md +2 -2
  745. package/docs/platforms/android.md +13 -13
  746. package/docs/platforms/digitalocean.md +243 -0
  747. package/docs/platforms/exe-dev.md +25 -25
  748. package/docs/platforms/fly.md +149 -24
  749. package/docs/platforms/gcp.md +498 -0
  750. package/docs/platforms/hetzner.md +42 -42
  751. package/docs/platforms/index.md +9 -9
  752. package/docs/platforms/ios.md +13 -13
  753. package/docs/platforms/linux.md +11 -11
  754. package/docs/platforms/mac/bundled-gateway.md +16 -16
  755. package/docs/platforms/mac/canvas.md +14 -14
  756. package/docs/platforms/mac/child-process.md +9 -9
  757. package/docs/platforms/mac/dev-setup.md +11 -11
  758. package/docs/platforms/mac/health.md +2 -2
  759. package/docs/platforms/mac/icon.md +1 -1
  760. package/docs/platforms/mac/logging.md +7 -7
  761. package/docs/platforms/mac/menu-bar.md +1 -1
  762. package/docs/platforms/mac/peekaboo.md +9 -9
  763. package/docs/platforms/mac/permissions.md +3 -3
  764. package/docs/platforms/mac/release.md +20 -20
  765. package/docs/platforms/mac/remote.md +14 -14
  766. package/docs/platforms/mac/signing.md +7 -7
  767. package/docs/platforms/mac/skills.md +4 -4
  768. package/docs/platforms/mac/voice-overlay.md +2 -2
  769. package/docs/platforms/mac/webchat.md +2 -2
  770. package/docs/platforms/mac/xpc.md +4 -4
  771. package/docs/platforms/macos-vm.md +27 -27
  772. package/docs/platforms/macos.md +20 -20
  773. package/docs/platforms/oracle.md +291 -0
  774. package/docs/platforms/raspberry-pi.md +354 -0
  775. package/docs/platforms/windows.md +11 -11
  776. package/docs/plugin.md +80 -64
  777. package/docs/plugins/agent-tools.md +1 -1
  778. package/docs/plugins/manifest.md +4 -4
  779. package/docs/plugins/voice-call.md +96 -12
  780. package/docs/plugins/zalouser.md +9 -9
  781. package/docs/prose.md +9 -9
  782. package/docs/providers/anthropic.md +23 -27
  783. package/docs/providers/claude-max-api-proxy.md +145 -0
  784. package/docs/providers/deepgram.md +2 -2
  785. package/docs/providers/github-copilot.md +11 -11
  786. package/docs/providers/glm.md +4 -4
  787. package/docs/providers/index.md +7 -3
  788. package/docs/providers/minimax.md +9 -9
  789. package/docs/providers/models.md +3 -3
  790. package/docs/providers/moonshot.md +2 -2
  791. package/docs/providers/ollama.md +11 -11
  792. package/docs/providers/openai.md +9 -13
  793. package/docs/providers/opencode.md +3 -3
  794. package/docs/providers/openrouter.md +3 -3
  795. package/docs/providers/qwen.md +6 -6
  796. package/docs/providers/synthetic.md +4 -4
  797. package/docs/providers/venice.md +21 -21
  798. package/docs/providers/vercel-ai-gateway.md +5 -4
  799. package/docs/providers/zai.md +5 -5
  800. package/docs/railway.mdx +9 -7
  801. package/docs/refactor/exec-host.md +5 -5
  802. package/docs/refactor/plugin-sdk.md +12 -12
  803. package/docs/refactor/strict-config.md +11 -11
  804. package/docs/reference/AGENTS.default.md +10 -10
  805. package/docs/reference/RELEASING.md +29 -29
  806. package/docs/reference/api-usage-costs.md +6 -6
  807. package/docs/reference/device-models.md +7 -7
  808. package/docs/reference/rpc.md +3 -3
  809. package/docs/reference/session-management-compaction.md +19 -19
  810. package/docs/reference/templates/AGENTS.dev.md +1 -1
  811. package/docs/reference/templates/BOOT.md +1 -1
  812. package/docs/reference/templates/IDENTITY.md +27 -0
  813. package/docs/reference/templates/TOOLS.dev.md +1 -1
  814. package/docs/reference/templates/USER.dev.md +2 -2
  815. package/docs/reference/templates/USER.md +22 -0
  816. package/docs/reference/test.md +2 -2
  817. package/docs/reference/transcript-hygiene.md +1 -1
  818. package/docs/render.mdx +158 -0
  819. package/docs/scripts.md +1 -1
  820. package/docs/security/formal-verification.md +107 -0
  821. package/docs/start/clawd.md +29 -29
  822. package/docs/start/getting-started.md +31 -25
  823. package/docs/start/hubs.md +2 -2
  824. package/docs/start/lore.md +74 -38
  825. package/docs/start/onboarding.md +7 -7
  826. package/docs/start/pairing.md +10 -10
  827. package/docs/start/setup.md +30 -17
  828. package/docs/start/showcase.md +32 -32
  829. package/docs/start/wizard.md +29 -26
  830. package/docs/testing.md +56 -56
  831. package/docs/token-use.md +7 -7
  832. package/docs/tools/agent-send.md +10 -10
  833. package/docs/tools/browser-linux-troubleshooting.md +10 -10
  834. package/docs/tools/browser-login.md +4 -4
  835. package/docs/tools/browser.md +136 -242
  836. package/docs/tools/chrome-extension.md +31 -48
  837. package/docs/tools/clawdhub.md +7 -7
  838. package/docs/tools/creating-skills.md +41 -0
  839. package/docs/tools/elevated.md +1 -0
  840. package/docs/tools/exec-approvals.md +8 -5
  841. package/docs/tools/exec.md +15 -4
  842. package/docs/tools/firecrawl.md +2 -2
  843. package/docs/tools/index.md +18 -15
  844. package/docs/tools/llm-task.md +1 -1
  845. package/docs/tools/lobster.md +23 -11
  846. package/docs/tools/skills-config.md +2 -2
  847. package/docs/tools/skills.md +39 -31
  848. package/docs/tools/slash-commands.md +10 -8
  849. package/docs/tools/web.md +8 -8
  850. package/docs/tts.md +11 -11
  851. package/docs/tui.md +7 -7
  852. package/docs/vps.md +6 -1
  853. package/docs/web/control-ui.md +15 -14
  854. package/docs/web/dashboard.md +10 -6
  855. package/docs/web/index.md +7 -6
  856. package/docs/web/webchat.md +1 -1
  857. package/extensions/bluebubbles/index.ts +3 -3
  858. package/extensions/bluebubbles/package.json +5 -5
  859. package/extensions/bluebubbles/src/accounts.ts +9 -9
  860. package/extensions/bluebubbles/src/actions.test.ts +22 -22
  861. package/extensions/bluebubbles/src/actions.ts +6 -6
  862. package/extensions/bluebubbles/src/attachments.ts +2 -2
  863. package/extensions/bluebubbles/src/channel.ts +71 -17
  864. package/extensions/bluebubbles/src/chat.ts +2 -2
  865. package/extensions/bluebubbles/src/config-schema.ts +1 -1
  866. package/extensions/bluebubbles/src/media-send.ts +2 -2
  867. package/extensions/bluebubbles/src/monitor.test.ts +56 -50
  868. package/extensions/bluebubbles/src/monitor.ts +181 -6
  869. package/extensions/bluebubbles/src/onboarding.ts +9 -9
  870. package/extensions/bluebubbles/src/reactions.ts +2 -2
  871. package/extensions/bluebubbles/src/runtime.ts +1 -1
  872. package/extensions/bluebubbles/src/send.test.ts +94 -2
  873. package/extensions/bluebubbles/src/send.ts +73 -7
  874. package/extensions/copilot-proxy/README.md +3 -3
  875. package/extensions/copilot-proxy/index.ts +1 -1
  876. package/extensions/copilot-proxy/package.json +4 -4
  877. package/extensions/diagnostics-otel/index.ts +3 -3
  878. package/extensions/diagnostics-otel/package.json +4 -4
  879. package/extensions/diagnostics-otel/src/service.test.ts +15 -15
  880. package/extensions/diagnostics-otel/src/service.ts +85 -85
  881. package/extensions/discord/index.ts +3 -3
  882. package/extensions/discord/package.json +4 -4
  883. package/extensions/discord/src/channel.ts +1 -1
  884. package/extensions/discord/src/runtime.ts +1 -1
  885. package/extensions/google-antigravity-auth/README.md +3 -3
  886. package/extensions/google-antigravity-auth/index.ts +9 -2
  887. package/extensions/google-antigravity-auth/package.json +4 -4
  888. package/extensions/google-gemini-cli-auth/README.md +17 -6
  889. package/extensions/google-gemini-cli-auth/index.ts +3 -3
  890. package/extensions/google-gemini-cli-auth/oauth.test.ts +228 -0
  891. package/extensions/google-gemini-cli-auth/oauth.ts +96 -12
  892. package/extensions/google-gemini-cli-auth/package.json +4 -4
  893. package/extensions/googlechat/index.ts +4 -4
  894. package/extensions/googlechat/package.json +7 -7
  895. package/extensions/googlechat/src/accounts.ts +9 -9
  896. package/extensions/googlechat/src/actions.ts +8 -8
  897. package/extensions/googlechat/src/api.ts +1 -1
  898. package/extensions/googlechat/src/channel.ts +23 -23
  899. package/extensions/googlechat/src/monitor.ts +9 -9
  900. package/extensions/googlechat/src/onboarding.ts +11 -11
  901. package/extensions/googlechat/src/runtime.ts +1 -1
  902. package/extensions/googlechat/src/types.config.ts +1 -1
  903. package/extensions/imessage/index.ts +3 -3
  904. package/extensions/imessage/package.json +4 -4
  905. package/extensions/imessage/src/channel.ts +5 -8
  906. package/extensions/imessage/src/runtime.ts +1 -1
  907. package/extensions/line/clawdbot.plugin.json +11 -0
  908. package/extensions/line/index.ts +20 -0
  909. package/extensions/line/package.json +29 -0
  910. package/extensions/line/src/card-command.ts +338 -0
  911. package/extensions/line/src/channel.logout.test.ts +96 -0
  912. package/extensions/line/src/channel.sendPayload.test.ts +308 -0
  913. package/extensions/line/src/channel.ts +773 -0
  914. package/extensions/line/src/runtime.ts +14 -0
  915. package/extensions/llm-task/README.md +4 -4
  916. package/extensions/llm-task/index.ts +2 -2
  917. package/extensions/llm-task/package.json +4 -4
  918. package/extensions/llm-task/src/llm-task-tool.ts +5 -5
  919. package/extensions/lobster/README.md +6 -6
  920. package/extensions/lobster/index.ts +2 -2
  921. package/extensions/lobster/package.json +3 -3
  922. package/extensions/lobster/src/lobster-tool.test.ts +26 -6
  923. package/extensions/lobster/src/lobster-tool.ts +24 -6
  924. package/extensions/matrix/CHANGELOG.md +9 -9
  925. package/extensions/matrix/index.ts +3 -3
  926. package/extensions/matrix/node_modules/.bin/markdown-it +2 -2
  927. package/extensions/matrix/node_modules/.bin/markdown-it.CMD +2 -2
  928. package/extensions/matrix/node_modules/.bin/markdown-it.ps1 +2 -2
  929. package/extensions/matrix/package.json +7 -7
  930. package/extensions/matrix/src/actions.ts +1 -1
  931. package/extensions/matrix/src/channel.directory.test.ts +1 -1
  932. package/extensions/matrix/src/channel.ts +1 -1
  933. package/extensions/matrix/src/config-schema.ts +1 -1
  934. package/extensions/matrix/src/directory-live.ts +1 -1
  935. package/extensions/matrix/src/group-mentions.ts +1 -1
  936. package/extensions/matrix/src/matrix/accounts.ts +1 -1
  937. package/extensions/matrix/src/matrix/actions/client.ts +1 -1
  938. package/extensions/matrix/src/matrix/actions/messages.ts +1 -1
  939. package/extensions/matrix/src/matrix/actions/reactions.ts +1 -1
  940. package/extensions/matrix/src/matrix/actions/room.ts +3 -3
  941. package/extensions/matrix/src/matrix/actions/summary.ts +1 -1
  942. package/extensions/matrix/src/matrix/actions/types.ts +1 -1
  943. package/extensions/matrix/src/matrix/active-client.ts +1 -1
  944. package/extensions/matrix/src/matrix/client/config.ts +2 -2
  945. package/extensions/matrix/src/matrix/client/create-client.ts +2 -2
  946. package/extensions/matrix/src/matrix/client/logging.ts +1 -1
  947. package/extensions/matrix/src/matrix/client/shared.ts +3 -3
  948. package/extensions/matrix/src/matrix/deps.ts +5 -5
  949. package/extensions/matrix/src/matrix/monitor/allowlist.ts +1 -1
  950. package/extensions/matrix/src/matrix/monitor/auto-join.ts +4 -4
  951. package/extensions/matrix/src/matrix/monitor/direct.ts +1 -1
  952. package/extensions/matrix/src/matrix/monitor/events.ts +2 -2
  953. package/extensions/matrix/src/matrix/monitor/handler.ts +15 -11
  954. package/extensions/matrix/src/matrix/monitor/index.ts +2 -2
  955. package/extensions/matrix/src/matrix/monitor/location.ts +2 -2
  956. package/extensions/matrix/src/matrix/monitor/media.test.ts +41 -5
  957. package/extensions/matrix/src/matrix/monitor/media.ts +17 -14
  958. package/extensions/matrix/src/matrix/monitor/replies.ts +2 -2
  959. package/extensions/matrix/src/matrix/monitor/room-info.ts +1 -1
  960. package/extensions/matrix/src/matrix/monitor/rooms.ts +1 -1
  961. package/extensions/matrix/src/matrix/monitor/threads.ts +1 -1
  962. package/extensions/matrix/src/matrix/monitor/types.ts +2 -1
  963. package/extensions/matrix/src/matrix/poll-types.ts +1 -1
  964. package/extensions/matrix/src/matrix/probe.ts +1 -1
  965. package/extensions/matrix/src/matrix/send/client.ts +3 -3
  966. package/extensions/matrix/src/matrix/send/media.ts +1 -1
  967. package/extensions/matrix/src/matrix/send/targets.test.ts +1 -1
  968. package/extensions/matrix/src/matrix/send/targets.ts +1 -1
  969. package/extensions/matrix/src/matrix/send/types.ts +2 -2
  970. package/extensions/matrix/src/matrix/send.test.ts +3 -3
  971. package/extensions/matrix/src/matrix/send.ts +4 -4
  972. package/extensions/matrix/src/onboarding.ts +3 -3
  973. package/extensions/matrix/src/outbound.ts +1 -1
  974. package/extensions/matrix/src/resolve-targets.ts +1 -1
  975. package/extensions/matrix/src/runtime.ts +1 -1
  976. package/extensions/matrix/src/tool-actions.ts +1 -1
  977. package/extensions/matrix/src/types.ts +1 -1
  978. package/extensions/mattermost/index.ts +3 -3
  979. package/extensions/mattermost/package.json +5 -5
  980. package/extensions/mattermost/src/channel.ts +1 -1
  981. package/extensions/mattermost/src/config-schema.ts +1 -1
  982. package/extensions/mattermost/src/group-mentions.ts +2 -2
  983. package/extensions/mattermost/src/mattermost/accounts.ts +10 -10
  984. package/extensions/mattermost/src/mattermost/client.ts +1 -1
  985. package/extensions/mattermost/src/mattermost/monitor-helpers.ts +6 -6
  986. package/extensions/mattermost/src/mattermost/monitor.ts +4 -4
  987. package/extensions/mattermost/src/mattermost/probe.ts +1 -1
  988. package/extensions/mattermost/src/onboarding-helpers.ts +5 -5
  989. package/extensions/mattermost/src/onboarding.ts +5 -5
  990. package/extensions/mattermost/src/runtime.ts +1 -1
  991. package/extensions/mattermost/src/types.ts +1 -1
  992. package/extensions/memory-core/index.ts +3 -3
  993. package/extensions/memory-core/package.json +9 -6
  994. package/extensions/memory-lancedb/{pigbot.plugin.json → clawdbot.plugin.json} +1 -1
  995. package/extensions/memory-lancedb/config.ts +2 -2
  996. package/extensions/memory-lancedb/index.test.ts +3 -3
  997. package/extensions/memory-lancedb/index.ts +4 -4
  998. package/extensions/memory-lancedb/node_modules/.bin/openai +2 -2
  999. package/extensions/memory-lancedb/node_modules/.bin/openai.CMD +2 -2
  1000. package/extensions/memory-lancedb/node_modules/.bin/openai.ps1 +2 -2
  1001. package/extensions/memory-lancedb/package.json +4 -4
  1002. package/extensions/msteams/CHANGELOG.md +7 -7
  1003. package/extensions/msteams/index.ts +3 -3
  1004. package/extensions/msteams/package.json +6 -6
  1005. package/extensions/msteams/src/attachments.test.ts +1 -1
  1006. package/extensions/msteams/src/channel.directory.test.ts +2 -2
  1007. package/extensions/msteams/src/channel.ts +3 -3
  1008. package/extensions/msteams/src/conversation-store-fs.test.ts +5 -5
  1009. package/extensions/msteams/src/directory-live.ts +1 -1
  1010. package/extensions/msteams/src/graph-upload.ts +4 -4
  1011. package/extensions/msteams/src/media-helpers.ts +1 -1
  1012. package/extensions/msteams/src/messenger.test.ts +1 -1
  1013. package/extensions/msteams/src/messenger.ts +1 -1
  1014. package/extensions/msteams/src/monitor-handler/message-handler.ts +1 -1
  1015. package/extensions/msteams/src/monitor-handler.ts +2 -2
  1016. package/extensions/msteams/src/monitor.ts +3 -3
  1017. package/extensions/msteams/src/onboarding.ts +11 -11
  1018. package/extensions/msteams/src/outbound.ts +1 -1
  1019. package/extensions/msteams/src/policy.test.ts +1 -1
  1020. package/extensions/msteams/src/policy.ts +50 -5
  1021. package/extensions/msteams/src/polls-store.test.ts +1 -1
  1022. package/extensions/msteams/src/polls.test.ts +5 -5
  1023. package/extensions/msteams/src/polls.ts +8 -8
  1024. package/extensions/msteams/src/probe.test.ts +1 -1
  1025. package/extensions/msteams/src/probe.ts +1 -1
  1026. package/extensions/msteams/src/reply-dispatcher.ts +36 -36
  1027. package/extensions/msteams/src/runtime.ts +1 -1
  1028. package/extensions/msteams/src/send-context.ts +2 -2
  1029. package/extensions/msteams/src/send.ts +5 -5
  1030. package/extensions/msteams/src/token.ts +1 -1
  1031. package/extensions/nextcloud-talk/index.ts +3 -3
  1032. package/extensions/nextcloud-talk/package.json +5 -5
  1033. package/extensions/nextcloud-talk/src/accounts.ts +2 -2
  1034. package/extensions/nextcloud-talk/src/channel.ts +8 -8
  1035. package/extensions/nextcloud-talk/src/config-schema.ts +1 -1
  1036. package/extensions/nextcloud-talk/src/inbound.ts +8 -8
  1037. package/extensions/nextcloud-talk/src/monitor.ts +1 -1
  1038. package/extensions/nextcloud-talk/src/onboarding.ts +2 -2
  1039. package/extensions/nextcloud-talk/src/policy.ts +2 -2
  1040. package/extensions/nextcloud-talk/src/room-info.ts +1 -1
  1041. package/extensions/nextcloud-talk/src/runtime.ts +1 -1
  1042. package/extensions/nextcloud-talk/src/types.ts +1 -1
  1043. package/extensions/nostr/CHANGELOG.md +4 -4
  1044. package/extensions/nostr/README.md +5 -5
  1045. package/extensions/nostr/index.ts +6 -6
  1046. package/extensions/nostr/package.json +6 -6
  1047. package/extensions/nostr/src/channel.ts +2 -2
  1048. package/extensions/nostr/src/config-schema.ts +1 -1
  1049. package/extensions/nostr/src/nostr-state-store.test.ts +8 -8
  1050. package/extensions/nostr/src/runtime.ts +1 -1
  1051. package/extensions/nostr/src/types.ts +4 -4
  1052. package/extensions/open-prose/index.ts +2 -2
  1053. package/extensions/open-prose/package.json +3 -3
  1054. package/extensions/open-prose/skills/prose/SKILL.md +5 -5
  1055. package/extensions/open-prose/skills/prose/examples/28-automated-pr-review.prose +2 -2
  1056. package/extensions/open-prose/skills/prose/prose.md +4 -4
  1057. package/extensions/qwen-portal-auth/README.md +3 -3
  1058. package/extensions/qwen-portal-auth/index.ts +1 -1
  1059. package/extensions/signal/index.ts +3 -3
  1060. package/extensions/signal/package.json +4 -4
  1061. package/extensions/signal/src/channel.ts +1 -1
  1062. package/extensions/signal/src/runtime.ts +1 -1
  1063. package/extensions/slack/index.ts +3 -3
  1064. package/extensions/slack/package.json +4 -4
  1065. package/extensions/slack/src/channel.ts +1 -1
  1066. package/extensions/slack/src/runtime.ts +1 -1
  1067. package/extensions/telegram/index.ts +3 -3
  1068. package/extensions/telegram/package.json +4 -4
  1069. package/extensions/telegram/src/channel.ts +3 -3
  1070. package/extensions/telegram/src/runtime.ts +1 -1
  1071. package/extensions/tlon/README.md +3 -3
  1072. package/extensions/tlon/index.ts +3 -3
  1073. package/extensions/tlon/package.json +5 -5
  1074. package/extensions/tlon/src/channel.ts +15 -15
  1075. package/extensions/tlon/src/config-schema.ts +1 -1
  1076. package/extensions/tlon/src/monitor/discovery.ts +1 -1
  1077. package/extensions/tlon/src/monitor/history.ts +1 -1
  1078. package/extensions/tlon/src/monitor/index.ts +3 -3
  1079. package/extensions/tlon/src/onboarding.ts +4 -4
  1080. package/extensions/tlon/src/runtime.ts +1 -1
  1081. package/extensions/tlon/src/types.ts +3 -3
  1082. package/extensions/tlon/src/urbit/send.ts +19 -6
  1083. package/extensions/twitch/CHANGELOG.md +21 -0
  1084. package/extensions/twitch/README.md +89 -0
  1085. package/extensions/twitch/clawdbot.plugin.json +9 -0
  1086. package/extensions/twitch/index.ts +20 -0
  1087. package/extensions/twitch/package.json +20 -0
  1088. package/extensions/twitch/src/access-control.test.ts +489 -0
  1089. package/extensions/twitch/src/access-control.ts +154 -0
  1090. package/extensions/twitch/src/actions.ts +173 -0
  1091. package/extensions/twitch/src/client-manager-registry.ts +115 -0
  1092. package/extensions/twitch/src/config-schema.ts +82 -0
  1093. package/extensions/twitch/src/config.test.ts +88 -0
  1094. package/extensions/twitch/src/config.ts +116 -0
  1095. package/extensions/twitch/src/monitor.ts +257 -0
  1096. package/extensions/twitch/src/onboarding.test.ts +311 -0
  1097. package/extensions/twitch/src/onboarding.ts +411 -0
  1098. package/extensions/twitch/src/outbound.test.ts +373 -0
  1099. package/extensions/twitch/src/outbound.ts +186 -0
  1100. package/extensions/twitch/src/plugin.test.ts +39 -0
  1101. package/extensions/twitch/src/plugin.ts +274 -0
  1102. package/extensions/twitch/src/probe.test.ts +198 -0
  1103. package/extensions/twitch/src/probe.ts +118 -0
  1104. package/extensions/twitch/src/resolver.ts +137 -0
  1105. package/extensions/twitch/src/runtime.ts +14 -0
  1106. package/extensions/twitch/src/send.test.ts +289 -0
  1107. package/extensions/twitch/src/send.ts +136 -0
  1108. package/extensions/twitch/src/status.test.ts +270 -0
  1109. package/extensions/twitch/src/status.ts +176 -0
  1110. package/extensions/twitch/src/token.test.ts +171 -0
  1111. package/extensions/twitch/src/token.ts +87 -0
  1112. package/extensions/twitch/src/twitch-client.test.ts +574 -0
  1113. package/extensions/twitch/src/twitch-client.ts +277 -0
  1114. package/extensions/twitch/src/types.ts +141 -0
  1115. package/extensions/twitch/src/utils/markdown.ts +92 -0
  1116. package/extensions/twitch/src/utils/twitch.ts +78 -0
  1117. package/extensions/twitch/test/setup.ts +7 -0
  1118. package/extensions/voice-call/CHANGELOG.md +19 -11
  1119. package/extensions/voice-call/README.md +38 -16
  1120. package/extensions/voice-call/{pigbot.plugin.json → clawdbot.plugin.json} +210 -14
  1121. package/extensions/voice-call/index.ts +32 -12
  1122. package/extensions/voice-call/package.json +4 -4
  1123. package/extensions/voice-call/src/cli.ts +1 -1
  1124. package/extensions/voice-call/src/config.test.ts +204 -0
  1125. package/extensions/voice-call/src/config.ts +134 -26
  1126. package/extensions/voice-call/src/core-bridge.ts +16 -8
  1127. package/extensions/voice-call/src/manager/context.ts +0 -1
  1128. package/extensions/voice-call/src/manager/events.ts +0 -1
  1129. package/extensions/voice-call/src/manager/lookup.ts +0 -1
  1130. package/extensions/voice-call/src/manager/outbound.ts +4 -3
  1131. package/extensions/voice-call/src/manager/state.ts +0 -1
  1132. package/extensions/voice-call/src/manager/store.ts +0 -1
  1133. package/extensions/voice-call/src/manager/timers.ts +0 -1
  1134. package/extensions/voice-call/src/manager/twiml.ts +0 -1
  1135. package/extensions/voice-call/src/manager.test.ts +2 -2
  1136. package/extensions/voice-call/src/manager.ts +4 -2
  1137. package/extensions/voice-call/src/media-stream.test.ts +97 -0
  1138. package/extensions/voice-call/src/media-stream.ts +114 -0
  1139. package/extensions/voice-call/src/providers/plivo.test.ts +0 -1
  1140. package/extensions/voice-call/src/providers/stt-openai-realtime.ts +8 -0
  1141. package/extensions/voice-call/src/providers/twilio/webhook.ts +2 -2
  1142. package/extensions/voice-call/src/providers/twilio.ts +44 -26
  1143. package/extensions/voice-call/src/response-generator.ts +1 -1
  1144. package/extensions/voice-call/src/runtime.ts +37 -27
  1145. package/extensions/voice-call/src/telephony-audio.ts +88 -0
  1146. package/extensions/voice-call/src/telephony-tts.ts +95 -0
  1147. package/extensions/voice-call/src/types.ts +1 -0
  1148. package/extensions/voice-call/src/webhook-security.test.ts +52 -0
  1149. package/extensions/voice-call/src/webhook-security.ts +16 -5
  1150. package/extensions/voice-call/src/webhook.ts +11 -0
  1151. package/extensions/whatsapp/index.ts +3 -3
  1152. package/extensions/whatsapp/package.json +4 -4
  1153. package/extensions/whatsapp/src/channel.ts +1 -1
  1154. package/extensions/whatsapp/src/runtime.ts +1 -1
  1155. package/extensions/zalo/CHANGELOG.md +9 -9
  1156. package/extensions/zalo/README.md +4 -4
  1157. package/extensions/zalo/index.ts +3 -3
  1158. package/extensions/zalo/package.json +6 -6
  1159. package/extensions/zalo/src/accounts.ts +9 -9
  1160. package/extensions/zalo/src/actions.ts +6 -6
  1161. package/extensions/zalo/src/channel.directory.test.ts +2 -2
  1162. package/extensions/zalo/src/channel.ts +20 -20
  1163. package/extensions/zalo/src/config-schema.ts +1 -1
  1164. package/extensions/zalo/src/monitor.ts +9 -9
  1165. package/extensions/zalo/src/monitor.webhook.test.ts +2 -2
  1166. package/extensions/zalo/src/onboarding.ts +27 -27
  1167. package/extensions/zalo/src/runtime.ts +1 -1
  1168. package/extensions/zalo/src/send.ts +2 -2
  1169. package/extensions/zalo/src/status-issues.ts +1 -1
  1170. package/extensions/zalo/src/token.ts +1 -1
  1171. package/extensions/zalouser/CHANGELOG.md +4 -4
  1172. package/extensions/zalouser/README.md +18 -18
  1173. package/extensions/zalouser/index.ts +3 -3
  1174. package/extensions/zalouser/package.json +6 -6
  1175. package/extensions/zalouser/src/accounts.ts +10 -10
  1176. package/extensions/zalouser/src/channel.test.ts +0 -1
  1177. package/extensions/zalouser/src/channel.ts +27 -27
  1178. package/extensions/zalouser/src/config-schema.ts +1 -1
  1179. package/extensions/zalouser/src/monitor.ts +5 -5
  1180. package/extensions/zalouser/src/onboarding.ts +32 -32
  1181. package/extensions/zalouser/src/runtime.ts +1 -1
  1182. package/extensions/zalouser/src/status-issues.ts +2 -2
  1183. package/package.json +34 -22
  1184. package/scripts/postinstall.js +1 -1
  1185. package/skills/1password/SKILL.md +3 -3
  1186. package/skills/apple-notes/SKILL.md +2 -2
  1187. package/skills/apple-reminders/SKILL.md +1 -1
  1188. package/skills/bear-notes/SKILL.md +1 -1
  1189. package/skills/bird/SKILL.md +1 -1
  1190. package/skills/blogwatcher/SKILL.md +1 -1
  1191. package/skills/blucli/SKILL.md +1 -1
  1192. package/skills/bluebubbles/SKILL.md +2 -2
  1193. package/skills/camsnap/SKILL.md +1 -1
  1194. package/skills/canvas/SKILL.md +15 -15
  1195. package/skills/clawdhub/SKILL.md +2 -2
  1196. package/skills/coding-agent/SKILL.md +6 -6
  1197. package/skills/discord/SKILL.md +6 -5
  1198. package/skills/eightctl/SKILL.md +1 -1
  1199. package/skills/food-order/SKILL.md +1 -1
  1200. package/skills/gemini/SKILL.md +1 -1
  1201. package/skills/gifgrep/SKILL.md +1 -1
  1202. package/skills/github/SKILL.md +1 -0
  1203. package/skills/gog/SKILL.md +1 -1
  1204. package/skills/goplaces/SKILL.md +1 -1
  1205. package/skills/himalaya/SKILL.md +1 -1
  1206. package/skills/imsg/SKILL.md +1 -1
  1207. package/skills/local-places/SKILL.md +2 -2
  1208. package/skills/mcporter/SKILL.md +1 -1
  1209. package/skills/model-usage/SKILL.md +1 -1
  1210. package/skills/nano-banana-pro/SKILL.md +10 -5
  1211. package/skills/nano-banana-pro/scripts/generate_image.py +42 -27
  1212. package/skills/nano-pdf/SKILL.md +1 -1
  1213. package/skills/notion/SKILL.md +1 -1
  1214. package/skills/obsidian/SKILL.md +1 -1
  1215. package/skills/openai-image-gen/SKILL.md +1 -1
  1216. package/skills/openai-whisper/SKILL.md +1 -1
  1217. package/skills/openai-whisper-api/SKILL.md +2 -2
  1218. package/skills/openhue/SKILL.md +1 -1
  1219. package/skills/oracle/SKILL.md +1 -1
  1220. package/skills/ordercli/SKILL.md +1 -1
  1221. package/skills/peekaboo/SKILL.md +1 -1
  1222. package/skills/sag/SKILL.md +1 -1
  1223. package/skills/session-logs/SKILL.md +7 -7
  1224. package/skills/sherpa-onnx-tts/SKILL.md +6 -6
  1225. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  1226. package/skills/slack/SKILL.md +4 -3
  1227. package/skills/songsee/SKILL.md +1 -1
  1228. package/skills/sonoscli/SKILL.md +1 -1
  1229. package/skills/spotify-player/SKILL.md +1 -1
  1230. package/skills/summarize/SKILL.md +1 -1
  1231. package/skills/things-mac/SKILL.md +3 -3
  1232. package/skills/tmux/SKILL.md +8 -8
  1233. package/skills/tmux/scripts/find-sessions.sh +2 -2
  1234. package/skills/trello/SKILL.md +2 -2
  1235. package/skills/video-frames/SKILL.md +1 -1
  1236. package/skills/voice-call/SKILL.md +4 -4
  1237. package/skills/wacli/SKILL.md +2 -2
  1238. package/skills/weather/SKILL.md +1 -1
  1239. package/dist/cli/browser-cli-serve.js +0 -91
  1240. package/dist/control-ui/assets/index--6ilUi7V.css +0 -1
  1241. package/dist/control-ui/assets/index-DrGg77je.js +0 -3111
  1242. package/dist/control-ui/assets/index-DrGg77je.js.map +0 -1
  1243. package/extensions/diagnostics-otel/node_modules/.bin/acorn +0 -21
  1244. package/extensions/diagnostics-otel/node_modules/.bin/acorn.CMD +0 -12
  1245. package/extensions/diagnostics-otel/node_modules/.bin/acorn.ps1 +0 -41
  1246. package/extensions/googlechat/node_modules/.bin/pigbot +0 -21
  1247. package/extensions/googlechat/node_modules/.bin/pigbot.CMD +0 -12
  1248. package/extensions/googlechat/node_modules/.bin/pigbot.ps1 +0 -41
  1249. package/extensions/matrix/node_modules/.bin/pigbot +0 -21
  1250. package/extensions/matrix/node_modules/.bin/pigbot.CMD +0 -12
  1251. package/extensions/matrix/node_modules/.bin/pigbot.ps1 +0 -41
  1252. package/extensions/memory-core/node_modules/.bin/pigbot +0 -21
  1253. package/extensions/memory-core/node_modules/.bin/pigbot.CMD +0 -12
  1254. package/extensions/memory-core/node_modules/.bin/pigbot.ps1 +0 -41
  1255. package/extensions/memory-lancedb/node_modules/.bin/arrow2csv +0 -21
  1256. package/extensions/memory-lancedb/node_modules/.bin/arrow2csv.CMD +0 -12
  1257. package/extensions/memory-lancedb/node_modules/.bin/arrow2csv.ps1 +0 -41
  1258. package/extensions/msteams/node_modules/.bin/pigbot +0 -21
  1259. package/extensions/msteams/node_modules/.bin/pigbot.CMD +0 -12
  1260. package/extensions/msteams/node_modules/.bin/pigbot.ps1 +0 -41
  1261. package/extensions/nostr/node_modules/.bin/pigbot +0 -21
  1262. package/extensions/nostr/node_modules/.bin/pigbot.CMD +0 -12
  1263. package/extensions/nostr/node_modules/.bin/pigbot.ps1 +0 -41
  1264. package/extensions/nostr/node_modules/.bin/tsc +0 -21
  1265. package/extensions/nostr/node_modules/.bin/tsc.CMD +0 -12
  1266. package/extensions/nostr/node_modules/.bin/tsc.ps1 +0 -41
  1267. package/extensions/nostr/node_modules/.bin/tsserver +0 -21
  1268. package/extensions/nostr/node_modules/.bin/tsserver.CMD +0 -12
  1269. package/extensions/nostr/node_modules/.bin/tsserver.ps1 +0 -41
  1270. package/extensions/zalo/node_modules/.bin/pigbot +0 -21
  1271. package/extensions/zalo/node_modules/.bin/pigbot.CMD +0 -12
  1272. package/extensions/zalo/node_modules/.bin/pigbot.ps1 +0 -41
  1273. package/extensions/zalouser/node_modules/.bin/pigbot +0 -21
  1274. package/extensions/zalouser/node_modules/.bin/pigbot.CMD +0 -12
  1275. package/extensions/zalouser/node_modules/.bin/pigbot.ps1 +0 -41
  1276. /package/dist/{config/types.pigbot.js → browser/routes/types.js} +0 -0
  1277. /package/extensions/bluebubbles/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1278. /package/extensions/copilot-proxy/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1279. /package/extensions/diagnostics-otel/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1280. /package/extensions/discord/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1281. /package/extensions/google-antigravity-auth/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1282. /package/extensions/google-gemini-cli-auth/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1283. /package/extensions/googlechat/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1284. /package/extensions/imessage/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1285. /package/extensions/llm-task/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1286. /package/extensions/lobster/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1287. /package/extensions/matrix/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1288. /package/extensions/mattermost/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1289. /package/extensions/memory-core/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1290. /package/extensions/msteams/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1291. /package/extensions/nextcloud-talk/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1292. /package/extensions/nostr/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1293. /package/extensions/open-prose/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1294. /package/extensions/qwen-portal-auth/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1295. /package/extensions/signal/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1296. /package/extensions/slack/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1297. /package/extensions/telegram/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1298. /package/extensions/tlon/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1299. /package/extensions/whatsapp/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1300. /package/extensions/zalo/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
  1301. /package/extensions/zalouser/{pigbot.plugin.json → clawdbot.plugin.json} +0 -0
@@ -0,0 +1,38 @@
1
+ /**
2
+ * In-memory cache of Discord user presence data.
3
+ * Populated by PRESENCE_UPDATE gateway events when the GuildPresences intent is enabled.
4
+ */
5
+ const presenceCache = new Map();
6
+ function resolveAccountKey(accountId) {
7
+ return accountId ?? "default";
8
+ }
9
+ /** Update cached presence for a user. */
10
+ export function setPresence(accountId, userId, data) {
11
+ const accountKey = resolveAccountKey(accountId);
12
+ let accountCache = presenceCache.get(accountKey);
13
+ if (!accountCache) {
14
+ accountCache = new Map();
15
+ presenceCache.set(accountKey, accountCache);
16
+ }
17
+ accountCache.set(userId, data);
18
+ }
19
+ /** Get cached presence for a user. Returns undefined if not cached. */
20
+ export function getPresence(accountId, userId) {
21
+ return presenceCache.get(resolveAccountKey(accountId))?.get(userId);
22
+ }
23
+ /** Clear cached presence data. */
24
+ export function clearPresences(accountId) {
25
+ if (accountId) {
26
+ presenceCache.delete(resolveAccountKey(accountId));
27
+ return;
28
+ }
29
+ presenceCache.clear();
30
+ }
31
+ /** Get the number of cached presence entries. */
32
+ export function presenceCacheSize() {
33
+ let total = 0;
34
+ for (const accountCache of presenceCache.values()) {
35
+ total += accountCache.size;
36
+ }
37
+ return total;
38
+ }
@@ -19,7 +19,7 @@ import { fetchDiscordApplicationId } from "../probe.js";
19
19
  import { resolveDiscordChannelAllowlist } from "../resolve-channels.js";
20
20
  import { resolveDiscordUserAllowlist } from "../resolve-users.js";
21
21
  import { normalizeDiscordToken } from "../token.js";
22
- import { DiscordMessageListener, DiscordReactionListener, DiscordReactionRemoveListener, registerDiscordListener, } from "./listeners.js";
22
+ import { DiscordMessageListener, DiscordPresenceListener, DiscordReactionListener, DiscordReactionRemoveListener, registerDiscordListener, } from "./listeners.js";
23
23
  import { createDiscordMessageHandler } from "./message-handler.js";
24
24
  import { createDiscordCommandArgFallbackButton, createDiscordNativeCommand, } from "./native-command.js";
25
25
  import { createExecApprovalButton, DiscordExecApprovalHandler } from "./exec-approvals.js";
@@ -79,6 +79,21 @@ function formatDiscordDeployErrorDetails(err) {
79
79
  }
80
80
  return details.length > 0 ? ` (${details.join(", ")})` : "";
81
81
  }
82
+ function resolveDiscordGatewayIntents(intentsConfig) {
83
+ let intents = GatewayIntents.Guilds |
84
+ GatewayIntents.GuildMessages |
85
+ GatewayIntents.MessageContent |
86
+ GatewayIntents.DirectMessages |
87
+ GatewayIntents.GuildMessageReactions |
88
+ GatewayIntents.DirectMessageReactions;
89
+ if (intentsConfig?.presence) {
90
+ intents |= GatewayIntents.GuildPresences;
91
+ }
92
+ if (intentsConfig?.guildMembers) {
93
+ intents |= GatewayIntents.GuildMembers;
94
+ }
95
+ return intents;
96
+ }
82
97
  export async function monitorDiscordProvider(opts = {}) {
83
98
  const cfg = opts.config ?? loadConfig();
84
99
  const account = resolveDiscordAccount({
@@ -387,12 +402,7 @@ export async function monitorDiscordProvider(opts = {}) {
387
402
  reconnect: {
388
403
  maxAttempts: Number.POSITIVE_INFINITY,
389
404
  },
390
- intents: GatewayIntents.Guilds |
391
- GatewayIntents.GuildMessages |
392
- GatewayIntents.MessageContent |
393
- GatewayIntents.DirectMessages |
394
- GatewayIntents.GuildMessageReactions |
395
- GatewayIntents.DirectMessageReactions,
405
+ intents: resolveDiscordGatewayIntents(discordCfg.intents),
396
406
  autoInteractions: true,
397
407
  }),
398
408
  ]);
@@ -449,6 +459,10 @@ export async function monitorDiscordProvider(opts = {}) {
449
459
  guildEntries,
450
460
  logger,
451
461
  }));
462
+ if (discordCfg.intents?.presence) {
463
+ registerDiscordListener(client.listeners, new DiscordPresenceListener({ logger, accountId: account.accountId }));
464
+ runtime.log?.("discord: GuildPresences intent enabled — presence listener registered");
465
+ }
452
466
  runtime.log?.(`logged in to discord${botUserId ? ` as ${botUserId}` : ""}`);
453
467
  // Start exec approvals handler after client is ready
454
468
  if (execApprovalsHandler) {
package/dist/entry.js CHANGED
@@ -6,7 +6,7 @@ import { applyCliProfileEnv, parseCliProfileArgs } from "./cli/profile.js";
6
6
  import { isTruthyEnvValue } from "./infra/env.js";
7
7
  import { installProcessWarningFilter } from "./infra/warnings.js";
8
8
  import { attachChildProcessBridge } from "./process/child-process-bridge.js";
9
- process.title = "pigbot";
9
+ process.title = "moltbot";
10
10
  installProcessWarningFilter();
11
11
  if (process.argv.includes("--no-color")) {
12
12
  process.env.NO_COLOR = "1";
@@ -19,14 +19,14 @@ function hasExperimentalWarningSuppressed(nodeOptions) {
19
19
  return nodeOptions.includes(EXPERIMENTAL_WARNING_FLAG) || nodeOptions.includes("--no-warnings");
20
20
  }
21
21
  function ensureExperimentalWarningSuppressed() {
22
- if (isTruthyEnvValue(process.env.PIGBOT_NO_RESPAWN))
22
+ if (isTruthyEnvValue(process.env.CLAWDBOT_NO_RESPAWN))
23
23
  return false;
24
- if (isTruthyEnvValue(process.env.PIGBOT_NODE_OPTIONS_READY))
24
+ if (isTruthyEnvValue(process.env.CLAWDBOT_NODE_OPTIONS_READY))
25
25
  return false;
26
26
  const nodeOptions = process.env.NODE_OPTIONS ?? "";
27
27
  if (hasExperimentalWarningSuppressed(nodeOptions))
28
28
  return false;
29
- process.env.PIGBOT_NODE_OPTIONS_READY = "1";
29
+ process.env.CLAWDBOT_NODE_OPTIONS_READY = "1";
30
30
  process.env.NODE_OPTIONS = `${nodeOptions} ${EXPERIMENTAL_WARNING_FLAG}`.trim();
31
31
  const child = spawn(process.execPath, [...process.execArgv, ...process.argv.slice(1)], {
32
32
  stdio: "inherit",
@@ -41,7 +41,7 @@ function ensureExperimentalWarningSuppressed() {
41
41
  process.exit(code ?? 1);
42
42
  });
43
43
  child.once("error", (error) => {
44
- console.error("[pigbot] Failed to respawn CLI:", error instanceof Error ? (error.stack ?? error.message) : error);
44
+ console.error("[moltbot] Failed to respawn CLI:", error instanceof Error ? (error.stack ?? error.message) : error);
45
45
  process.exit(1);
46
46
  });
47
47
  // Parent must not continue running the CLI.
@@ -110,7 +110,7 @@ if (!ensureExperimentalWarningSuppressed()) {
110
110
  const parsed = parseCliProfileArgs(process.argv);
111
111
  if (!parsed.ok) {
112
112
  // Keep it simple; Commander will handle rich help/errors after we strip flags.
113
- console.error(`[pigbot] ${parsed.error}`);
113
+ console.error(`[moltbot] ${parsed.error}`);
114
114
  process.exit(2);
115
115
  }
116
116
  if (parsed.profile) {
@@ -121,7 +121,7 @@ if (!ensureExperimentalWarningSuppressed()) {
121
121
  import("./cli/run-main.js")
122
122
  .then(({ runCli }) => runCli(process.argv))
123
123
  .catch((error) => {
124
- console.error("[pigbot] Failed to start CLI:", error instanceof Error ? (error.stack ?? error.message) : error);
124
+ console.error("[moltbot] Failed to start CLI:", error instanceof Error ? (error.stack ?? error.message) : error);
125
125
  process.exitCode = 1;
126
126
  });
127
127
  }
@@ -1,10 +1,14 @@
1
1
  import { timingSafeEqual } from "node:crypto";
2
- import { isTrustedProxyAddress, resolveGatewayClientIp } from "./net.js";
2
+ import { readTailscaleWhoisIdentity } from "../infra/tailscale.js";
3
+ import { isTrustedProxyAddress, parseForwardedForClientIp, resolveGatewayClientIp } from "./net.js";
3
4
  function safeEqual(a, b) {
4
5
  if (a.length !== b.length)
5
6
  return false;
6
7
  return timingSafeEqual(Buffer.from(a), Buffer.from(b));
7
8
  }
9
+ function normalizeLogin(login) {
10
+ return login.trim().toLowerCase();
11
+ }
8
12
  function isLoopbackAddress(ip) {
9
13
  if (!ip)
10
14
  return false;
@@ -33,6 +37,12 @@ function getHostName(hostHeader) {
33
37
  function headerValue(value) {
34
38
  return Array.isArray(value) ? value[0] : value;
35
39
  }
40
+ function resolveTailscaleClientIp(req) {
41
+ if (!req)
42
+ return undefined;
43
+ const forwardedFor = headerValue(req.headers?.["x-forwarded-for"]);
44
+ return forwardedFor ? parseForwardedForClientIp(forwardedFor) : undefined;
45
+ }
36
46
  function resolveRequestClientIp(req, trustedProxies) {
37
47
  if (!req)
38
48
  return undefined;
@@ -43,7 +53,7 @@ function resolveRequestClientIp(req, trustedProxies) {
43
53
  trustedProxies,
44
54
  });
45
55
  }
46
- function isLocalDirectRequest(req, trustedProxies) {
56
+ export function isLocalDirectRequest(req, trustedProxies) {
47
57
  if (!req)
48
58
  return false;
49
59
  const clientIp = resolveRequestClientIp(req, trustedProxies) ?? "";
@@ -85,12 +95,41 @@ function isTailscaleProxyRequest(req) {
85
95
  return false;
86
96
  return isLoopbackAddress(req.socket?.remoteAddress) && hasTailscaleProxyHeaders(req);
87
97
  }
98
+ async function resolveVerifiedTailscaleUser(params) {
99
+ const { req, tailscaleWhois } = params;
100
+ const tailscaleUser = getTailscaleUser(req);
101
+ if (!tailscaleUser) {
102
+ return { ok: false, reason: "tailscale_user_missing" };
103
+ }
104
+ if (!isTailscaleProxyRequest(req)) {
105
+ return { ok: false, reason: "tailscale_proxy_missing" };
106
+ }
107
+ const clientIp = resolveTailscaleClientIp(req);
108
+ if (!clientIp) {
109
+ return { ok: false, reason: "tailscale_whois_failed" };
110
+ }
111
+ const whois = await tailscaleWhois(clientIp);
112
+ if (!whois?.login) {
113
+ return { ok: false, reason: "tailscale_whois_failed" };
114
+ }
115
+ if (normalizeLogin(whois.login) !== normalizeLogin(tailscaleUser.login)) {
116
+ return { ok: false, reason: "tailscale_user_mismatch" };
117
+ }
118
+ return {
119
+ ok: true,
120
+ user: {
121
+ login: whois.login,
122
+ name: whois.name ?? tailscaleUser.name,
123
+ profilePic: tailscaleUser.profilePic,
124
+ },
125
+ };
126
+ }
88
127
  export function resolveGatewayAuth(params) {
89
128
  const authConfig = params.authConfig ?? {};
90
129
  const env = params.env ?? process.env;
91
- const token = authConfig.token ?? env.PIGBOT_GATEWAY_TOKEN ?? undefined;
92
- const password = authConfig.password ?? env.PIGBOT_GATEWAY_PASSWORD ?? undefined;
93
- const mode = authConfig.mode ?? (password ? "password" : token ? "token" : "none");
130
+ const token = authConfig.token ?? env.CLAWDBOT_GATEWAY_TOKEN ?? undefined;
131
+ const password = authConfig.password ?? env.CLAWDBOT_GATEWAY_PASSWORD ?? undefined;
132
+ const mode = authConfig.mode ?? (password ? "password" : "token");
94
133
  const allowTailscale = authConfig.allowTailscale ?? (params.tailscaleMode === "serve" && mode !== "password");
95
134
  return {
96
135
  mode,
@@ -101,7 +140,9 @@ export function resolveGatewayAuth(params) {
101
140
  }
102
141
  export function assertGatewayAuthConfigured(auth) {
103
142
  if (auth.mode === "token" && !auth.token) {
104
- throw new Error("gateway auth mode is token, but no token was configured (set gateway.auth.token or PIGBOT_GATEWAY_TOKEN)");
143
+ if (auth.allowTailscale)
144
+ return;
145
+ throw new Error("gateway auth mode is token, but no token was configured (set gateway.auth.token or CLAWDBOT_GATEWAY_TOKEN)");
105
146
  }
106
147
  if (auth.mode === "password" && !auth.password) {
107
148
  throw new Error("gateway auth mode is password, but no password was configured");
@@ -109,28 +150,20 @@ export function assertGatewayAuthConfigured(auth) {
109
150
  }
110
151
  export async function authorizeGatewayConnect(params) {
111
152
  const { auth, connectAuth, req, trustedProxies } = params;
153
+ const tailscaleWhois = params.tailscaleWhois ?? readTailscaleWhoisIdentity;
112
154
  const localDirect = isLocalDirectRequest(req, trustedProxies);
113
155
  if (auth.allowTailscale && !localDirect) {
114
- const tailscaleUser = getTailscaleUser(req);
115
- const tailscaleProxy = isTailscaleProxyRequest(req);
116
- if (tailscaleUser && tailscaleProxy) {
156
+ const tailscaleCheck = await resolveVerifiedTailscaleUser({
157
+ req,
158
+ tailscaleWhois,
159
+ });
160
+ if (tailscaleCheck.ok) {
117
161
  return {
118
162
  ok: true,
119
163
  method: "tailscale",
120
- user: tailscaleUser.login,
164
+ user: tailscaleCheck.user.login,
121
165
  };
122
166
  }
123
- if (auth.mode === "none") {
124
- if (!tailscaleUser) {
125
- return { ok: false, reason: "tailscale_user_missing" };
126
- }
127
- if (!tailscaleProxy) {
128
- return { ok: false, reason: "tailscale_proxy_missing" };
129
- }
130
- }
131
- }
132
- if (auth.mode === "none") {
133
- return { ok: true, method: "none" };
134
167
  }
135
168
  if (auth.mode === "token") {
136
169
  if (!auth.token) {
@@ -139,7 +172,7 @@ export async function authorizeGatewayConnect(params) {
139
172
  if (!connectAuth?.token) {
140
173
  return { ok: false, reason: "token_missing" };
141
174
  }
142
- if (connectAuth.token !== auth.token) {
175
+ if (!safeEqual(connectAuth.token, auth.token)) {
143
176
  return { ok: false, reason: "token_mismatch" };
144
177
  }
145
178
  return { ok: true, method: "token" };
@@ -95,14 +95,14 @@ export async function callGateway(opts) {
95
95
  ? typeof remote?.token === "string" && remote.token.trim().length > 0
96
96
  ? remote.token.trim()
97
97
  : undefined
98
- : process.env.PIGBOT_GATEWAY_TOKEN?.trim() ||
98
+ : process.env.CLAWDBOT_GATEWAY_TOKEN?.trim() ||
99
99
  (typeof authToken === "string" && authToken.trim().length > 0
100
100
  ? authToken.trim()
101
101
  : undefined));
102
102
  const password = (typeof opts.password === "string" && opts.password.trim().length > 0
103
103
  ? opts.password.trim()
104
104
  : undefined) ||
105
- process.env.PIGBOT_GATEWAY_PASSWORD?.trim() ||
105
+ process.env.CLAWDBOT_GATEWAY_PASSWORD?.trim() ||
106
106
  (isRemoteMode
107
107
  ? typeof remote?.password === "string" && remote.password.trim().length > 0
108
108
  ? remote.password.trim()
@@ -130,12 +130,12 @@ function serveFile(res, filePath) {
130
130
  function injectControlUiConfig(html, opts) {
131
131
  const { basePath, assistantName, assistantAvatar } = opts;
132
132
  const script = `<script>` +
133
- `window.__PIGBOT_CONTROL_UI_BASE_PATH__=${JSON.stringify(basePath)};` +
134
- `window.__PIGBOT_ASSISTANT_NAME__=${JSON.stringify(assistantName ?? DEFAULT_ASSISTANT_IDENTITY.name)};` +
135
- `window.__PIGBOT_ASSISTANT_AVATAR__=${JSON.stringify(assistantAvatar ?? DEFAULT_ASSISTANT_IDENTITY.avatar)};` +
133
+ `window.__CLAWDBOT_CONTROL_UI_BASE_PATH__=${JSON.stringify(basePath)};` +
134
+ `window.__CLAWDBOT_ASSISTANT_NAME__=${JSON.stringify(assistantName ?? DEFAULT_ASSISTANT_IDENTITY.name)};` +
135
+ `window.__CLAWDBOT_ASSISTANT_AVATAR__=${JSON.stringify(assistantAvatar ?? DEFAULT_ASSISTANT_IDENTITY.avatar)};` +
136
136
  `</script>`;
137
137
  // Check if already injected
138
- if (html.includes("__PIGBOT_ASSISTANT_NAME__"))
138
+ if (html.includes("__CLAWDBOT_ASSISTANT_NAME__"))
139
139
  return html;
140
140
  const headClose = html.indexOf("</head>");
141
141
  if (headClose !== -1) {
@@ -1,6 +1,6 @@
1
1
  import path from "node:path";
2
2
  import { pathToFileURL } from "node:url";
3
- import { CONFIG_PATH_PIGBOT, } from "../config/config.js";
3
+ import { CONFIG_PATH } from "../config/config.js";
4
4
  const hookPresetMappings = {
5
5
  gmail: [
6
6
  {
@@ -17,17 +17,26 @@ const hookPresetMappings = {
17
17
  const transformCache = new Map();
18
18
  export function resolveHookMappings(hooks) {
19
19
  const presets = hooks?.presets ?? [];
20
+ const gmailAllowUnsafe = hooks?.gmail?.allowUnsafeExternalContent;
20
21
  const mappings = [];
21
22
  if (hooks?.mappings)
22
23
  mappings.push(...hooks.mappings);
23
24
  for (const preset of presets) {
24
25
  const presetMappings = hookPresetMappings[preset];
25
- if (presetMappings)
26
- mappings.push(...presetMappings);
26
+ if (!presetMappings)
27
+ continue;
28
+ if (preset === "gmail" && typeof gmailAllowUnsafe === "boolean") {
29
+ mappings.push(...presetMappings.map((mapping) => ({
30
+ ...mapping,
31
+ allowUnsafeExternalContent: gmailAllowUnsafe,
32
+ })));
33
+ continue;
34
+ }
35
+ mappings.push(...presetMappings);
27
36
  }
28
37
  if (mappings.length === 0)
29
38
  return [];
30
- const configDir = path.dirname(CONFIG_PATH_PIGBOT);
39
+ const configDir = path.dirname(CONFIG_PATH);
31
40
  const transformsDir = hooks?.transformsDir
32
41
  ? resolvePath(configDir, hooks.transformsDir)
33
42
  : configDir;
@@ -82,6 +91,7 @@ function normalizeHookMapping(mapping, index, transformsDir) {
82
91
  messageTemplate: mapping.messageTemplate,
83
92
  textTemplate: mapping.textTemplate,
84
93
  deliver: mapping.deliver,
94
+ allowUnsafeExternalContent: mapping.allowUnsafeExternalContent,
85
95
  channel: mapping.channel,
86
96
  to: mapping.to,
87
97
  model: mapping.model,
@@ -124,6 +134,7 @@ function buildActionFromMapping(mapping, ctx) {
124
134
  wakeMode: mapping.wakeMode ?? "now",
125
135
  sessionKey: renderOptional(mapping.sessionKey, ctx),
126
136
  deliver: mapping.deliver,
137
+ allowUnsafeExternalContent: mapping.allowUnsafeExternalContent,
127
138
  channel: mapping.channel,
128
139
  to: renderOptional(mapping.to, ctx),
129
140
  model: renderOptional(mapping.model, ctx),
@@ -153,6 +164,9 @@ function mergeAction(base, override, defaultAction) {
153
164
  name: override.name ?? baseAgent?.name,
154
165
  sessionKey: override.sessionKey ?? baseAgent?.sessionKey,
155
166
  deliver: typeof override.deliver === "boolean" ? override.deliver : baseAgent?.deliver,
167
+ allowUnsafeExternalContent: typeof override.allowUnsafeExternalContent === "boolean"
168
+ ? override.allowUnsafeExternalContent
169
+ : baseAgent?.allowUnsafeExternalContent,
156
170
  channel: override.channel ?? baseAgent?.channel,
157
171
  to: override.to ?? baseAgent?.to,
158
172
  model: override.model ?? baseAgent?.model,
@@ -33,17 +33,15 @@ export function extractHookToken(req, url) {
33
33
  if (auth.toLowerCase().startsWith("bearer ")) {
34
34
  const token = auth.slice(7).trim();
35
35
  if (token)
36
- return token;
36
+ return { token, fromQuery: false };
37
37
  }
38
- const headerToken = typeof req.headers["x-pigbot-token"] === "string"
39
- ? req.headers["x-pigbot-token"].trim()
40
- : "";
38
+ const headerToken = typeof req.headers["x-moltbot-token"] === "string" ? req.headers["x-moltbot-token"].trim() : "";
41
39
  if (headerToken)
42
- return headerToken;
40
+ return { token: headerToken, fromQuery: false };
43
41
  const queryToken = url.searchParams.get("token");
44
42
  if (queryToken)
45
- return queryToken.trim();
46
- return undefined;
43
+ return { token: queryToken.trim(), fromQuery: true };
44
+ return { token: undefined, fromQuery: false };
47
45
  }
48
46
  export async function readJsonBody(req, maxBytes) {
49
47
  return await new Promise((resolve) => {
@@ -16,9 +16,7 @@ export function getBearerToken(req) {
16
16
  return token || undefined;
17
17
  }
18
18
  export function resolveAgentIdFromHeader(req) {
19
- const raw = getHeader(req, "x-pigbot-agent-id")?.trim() ||
20
- getHeader(req, "x-pigbot-agent")?.trim() ||
21
- "";
19
+ const raw = getHeader(req, "x-moltbot-agent-id")?.trim() || getHeader(req, "x-moltbot-agent")?.trim() || "";
22
20
  if (!raw)
23
21
  return undefined;
24
22
  return normalizeAgentId(raw);
@@ -27,7 +25,7 @@ export function resolveAgentIdFromModel(model) {
27
25
  const raw = model?.trim();
28
26
  if (!raw)
29
27
  return undefined;
30
- const m = raw.match(/^pigbot[:/](?<agentId>[a-z0-9][a-z0-9_-]{0,63})$/i) ??
28
+ const m = raw.match(/^moltbot[:/](?<agentId>[a-z0-9][a-z0-9_-]{0,63})$/i) ??
31
29
  raw.match(/^agent:(?<agentId>[a-z0-9][a-z0-9_-]{0,63})$/i);
32
30
  const agentId = m?.groups?.agentId;
33
31
  if (!agentId)
@@ -42,7 +40,7 @@ export function resolveAgentIdForRequest(params) {
42
40
  return fromModel ?? "main";
43
41
  }
44
42
  export function resolveSessionKey(params) {
45
- const explicit = getHeader(params.req, "x-pigbot-session-key")?.trim();
43
+ const explicit = getHeader(params.req, "x-moltbot-session-key")?.trim();
46
44
  if (explicit)
47
45
  return explicit;
48
46
  const user = params.user?.trim();
@@ -40,7 +40,7 @@ function stripOptionalPort(ip) {
40
40
  }
41
41
  return ip;
42
42
  }
43
- function parseForwardedForClientIp(forwardedFor) {
43
+ export function parseForwardedForClientIp(forwardedFor) {
44
44
  const raw = forwardedFor?.split(",")[0]?.trim();
45
45
  if (!raw)
46
46
  return undefined;
@@ -134,7 +134,7 @@ export async function handleOpenAiHttpRequest(req, res, opts) {
134
134
  return true;
135
135
  const payload = coerceRequest(body);
136
136
  const stream = Boolean(payload.stream);
137
- const model = typeof payload.model === "string" ? payload.model : "pigbot";
137
+ const model = typeof payload.model === "string" ? payload.model : "moltbot";
138
138
  const user = typeof payload.user === "string" ? payload.user : undefined;
139
139
  const agentId = resolveAgentIdForRequest({ req, model });
140
140
  const sessionKey = resolveOpenAiSessionKey({ req, agentId, user });
@@ -167,7 +167,7 @@ export async function handleOpenAiHttpRequest(req, res, opts) {
167
167
  .map((p) => (typeof p.text === "string" ? p.text : ""))
168
168
  .filter(Boolean)
169
169
  .join("\n\n")
170
- : "No response from Pigbot.";
170
+ : "No response from Moltbot.";
171
171
  sendJson(res, 200, {
172
172
  id: runId,
173
173
  object: "chat.completion",
@@ -275,7 +275,7 @@ export async function handleOpenAiHttpRequest(req, res, opts) {
275
275
  .map((p) => (typeof p.text === "string" ? p.text : ""))
276
276
  .filter(Boolean)
277
277
  .join("\n\n")
278
- : "No response from Pigbot.";
278
+ : "No response from Moltbot.";
279
279
  sawAssistantDelta = true;
280
280
  writeSse(res, {
281
281
  id: runId,
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * OpenResponses HTTP Handler
3
3
  *
4
- * Implements the OpenResponses `/v1/responses` endpoint for Pigbot Gateway.
4
+ * Implements the OpenResponses `/v1/responses` endpoint for Moltbot Gateway.
5
5
  *
6
6
  * @see https://www.open-responses.com/
7
7
  */
@@ -405,7 +405,7 @@ export async function handleOpenResponsesHttpRequest(req, res, opts) {
405
405
  .map((p) => (typeof p.text === "string" ? p.text : ""))
406
406
  .filter(Boolean)
407
407
  .join("\n\n")
408
- : "No response from Pigbot.";
408
+ : "No response from Moltbot.";
409
409
  const response = createResponseResource({
410
410
  id: responseId,
411
411
  model,
@@ -543,7 +543,7 @@ export async function handleOpenResponsesHttpRequest(req, res, opts) {
543
543
  if (evt.stream === "lifecycle") {
544
544
  const phase = evt.data?.phase;
545
545
  if (phase === "end" || phase === "error") {
546
- const finalText = accumulatedText || "No response from Pigbot.";
546
+ const finalText = accumulatedText || "No response from Moltbot.";
547
547
  const finalStatus = phase === "error" ? "failed" : "completed";
548
548
  requestFinalize(finalStatus, finalText);
549
549
  }
@@ -647,7 +647,7 @@ export async function handleOpenResponsesHttpRequest(req, res, opts) {
647
647
  .map((p) => (typeof p.text === "string" ? p.text : ""))
648
648
  .filter(Boolean)
649
649
  .join("\n\n")
650
- : "No response from Pigbot.";
650
+ : "No response from Moltbot.";
651
651
  accumulatedText = content;
652
652
  sawAssistantDelta = true;
653
653
  writeSseEvent(res, {
@@ -1,16 +1,16 @@
1
1
  export const GATEWAY_CLIENT_IDS = {
2
2
  WEBCHAT_UI: "webchat-ui",
3
- CONTROL_UI: "pigbot-control-ui",
3
+ CONTROL_UI: "moltbot-control-ui",
4
4
  WEBCHAT: "webchat",
5
5
  CLI: "cli",
6
6
  GATEWAY_CLIENT: "gateway-client",
7
- MACOS_APP: "pigbot-macos",
8
- IOS_APP: "pigbot-ios",
9
- ANDROID_APP: "pigbot-android",
7
+ MACOS_APP: "moltbot-macos",
8
+ IOS_APP: "moltbot-ios",
9
+ ANDROID_APP: "moltbot-android",
10
10
  NODE_HOST: "node-host",
11
11
  TEST: "test",
12
12
  FINGERPRINT: "fingerprint",
13
- PROBE: "pigbot-probe",
13
+ PROBE: "moltbot-probe",
14
14
  };
15
15
  // Back-compat naming (internal): these values are IDs, not display names.
16
16
  export const GATEWAY_CLIENT_NAMES = GATEWAY_CLIENT_IDS;
@@ -20,7 +20,7 @@ export const ChatHistoryParamsSchema = Type.Object({
20
20
  }, { additionalProperties: false });
21
21
  export const ChatSendParamsSchema = Type.Object({
22
22
  sessionKey: NonEmptyString,
23
- message: NonEmptyString,
23
+ message: Type.String(),
24
24
  thinking: Type.Optional(Type.String()),
25
25
  deliver: Type.Optional(Type.Boolean()),
26
26
  attachments: Type.Optional(Type.Array(Type.Unknown())),
@@ -8,6 +8,7 @@ export const createTestRegistry = (overrides = {}) => {
8
8
  providers: [],
9
9
  gatewayHandlers: {},
10
10
  httpHandlers: [],
11
+ httpRoutes: [],
11
12
  cliRegistrars: [],
12
13
  services: [],
13
14
  commands: [],
@@ -18,5 +19,6 @@ export const createTestRegistry = (overrides = {}) => {
18
19
  ...merged,
19
20
  gatewayHandlers: merged.gatewayHandlers ?? {},
20
21
  httpHandlers: merged.httpHandlers ?? [],
22
+ httpRoutes: merged.httpRoutes ?? [],
21
23
  };
22
24
  };
@@ -1,6 +1,6 @@
1
1
  import { resolveDefaultAgentId } from "../../agents/agent-scope.js";
2
2
  import { getHealthSnapshot } from "../../commands/health.js";
3
- import { CONFIG_PATH_PIGBOT, STATE_DIR_PIGBOT, loadConfig } from "../../config/config.js";
3
+ import { CONFIG_PATH, STATE_DIR, loadConfig } from "../../config/config.js";
4
4
  import { resolveMainSessionKey } from "../../config/sessions.js";
5
5
  import { normalizeMainKey } from "../../routing/session-key.js";
6
6
  import { listSystemPresence } from "../../infra/system-presence.js";
@@ -25,8 +25,8 @@ export function buildGatewaySnapshot() {
25
25
  stateVersion: { presence: presenceVersion, health: healthVersion },
26
26
  uptimeMs,
27
27
  // Surface resolved paths so UIs can display the true config location.
28
- configPath: CONFIG_PATH_PIGBOT,
29
- stateDir: STATE_DIR_PIGBOT,
28
+ configPath: CONFIG_PATH,
29
+ stateDir: STATE_DIR,
30
30
  sessionDefaults: {
31
31
  defaultAgentId,
32
32
  mainKey,
@@ -37,6 +37,7 @@ export function createGatewayHooksRequestHandler(params) {
37
37
  deliver: value.deliver,
38
38
  channel: value.channel,
39
39
  to: value.to,
40
+ allowUnsafeExternalContent: value.allowUnsafeExternalContent,
40
41
  },
41
42
  state: { nextRunAtMs: now },
42
43
  };
@@ -1,9 +1,30 @@
1
1
  export function createGatewayPluginRequestHandler(params) {
2
2
  const { registry, log } = params;
3
3
  return async (req, res) => {
4
- if (registry.httpHandlers.length === 0)
4
+ const routes = registry.httpRoutes ?? [];
5
+ const handlers = registry.httpHandlers ?? [];
6
+ if (routes.length === 0 && handlers.length === 0)
5
7
  return false;
6
- for (const entry of registry.httpHandlers) {
8
+ if (routes.length > 0) {
9
+ const url = new URL(req.url ?? "/", "http://localhost");
10
+ const route = routes.find((entry) => entry.path === url.pathname);
11
+ if (route) {
12
+ try {
13
+ await route.handler(req, res);
14
+ return true;
15
+ }
16
+ catch (err) {
17
+ log.warn(`plugin http route failed (${route.pluginId ?? "unknown"}): ${String(err)}`);
18
+ if (!res.headersSent) {
19
+ res.statusCode = 500;
20
+ res.setHeader("Content-Type", "text/plain; charset=utf-8");
21
+ res.end("Internal Server Error");
22
+ }
23
+ return true;
24
+ }
25
+ }
26
+ }
27
+ for (const entry of handlers) {
7
28
  try {
8
29
  const handled = await entry.handler(req, res);
9
30
  if (handled)