@visorcraft/idlehands 4.2.5 → 4.2.7

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 (128) hide show
  1. package/README.md +1 -0
  2. package/dist/{agent-via-gateway-Bhon8XVm.js → agent-via-gateway-BMsMjnWe.js} +2 -2
  3. package/dist/{agent-via-gateway-DVTkXwmI.js → agent-via-gateway-CW7FhqaW.js} +7 -7
  4. package/dist/{agent-via-gateway-CS-8ChjV.js → agent-via-gateway-CZLe7Ijx.js} +1 -1
  5. package/dist/{agent-via-gateway-Drygi4ty.js → agent-via-gateway-D8QBXTZL.js} +1 -1
  6. package/dist/{agents-dNuQ9qUa.js → agents-C1x5jDIo.js} +4 -4
  7. package/dist/{agents.config-B_6rOTVW.js → agents.config-4ilUlWts.js} +1 -1
  8. package/dist/{agents.config-DCNsF8yj.js → agents.config-B_McnvK1.js} +1 -1
  9. package/dist/{anton-D375-ufL.js → anton-0pF0zqOs.js} +88 -22
  10. package/dist/{anton-BmSsFmSP.js → anton-BDDjbZ5H.js} +88 -22
  11. package/dist/{anton-Cw4-BgtA.js → anton-C33_8bVg.js} +88 -22
  12. package/dist/{anton-Di5VPZiI.js → anton-D4a5lMjo.js} +88 -22
  13. package/dist/{audio-preflight-CW8IH1lU.js → audio-preflight-BSlR2jEq.js} +4 -4
  14. package/dist/{auth-choice-C8Tj46gd.js → auth-choice-BhfFkY6h.js} +1 -1
  15. package/dist/{auth-choice-CYV4KLt7.js → auth-choice-JcCIJBlD.js} +1 -1
  16. package/dist/{banner-B7_rwm3P.js → banner-DfFhVf3q.js} +1 -1
  17. package/dist/build-info.json +3 -3
  18. package/dist/bundled/boot-md/handler.js +7 -7
  19. package/dist/bundled/session-memory/handler.js +7 -7
  20. package/dist/{channel-options-Dxc1A5iC.js → channel-options-9SPtt4MW.js} +1 -1
  21. package/dist/{channel-options-DTqGMcYU.js → channel-options-CUviKu-7.js} +1 -1
  22. package/dist/{channel-web-CgvDCMru.js → channel-web-C6dFy-1o.js} +2 -2
  23. package/dist/{channel-web-BPlapQS3.js → channel-web-CFn6Nsja.js} +2 -2
  24. package/dist/{channels-cli-BfUIc52d.js → channels-cli-B2da56zV.js} +7 -7
  25. package/dist/{channels-cli-k45uGu5k.js → channels-cli-DGfqgSUL.js} +7 -7
  26. package/dist/{chrome-BcJB6PcM.js → chrome-_2tzVjVl.js} +9 -9
  27. package/dist/{cli-C6GCCnET.js → cli-DmnwiKz9.js} +2 -2
  28. package/dist/{cli-BapK2rdH.js → cli-FOBK-XcZ.js} +2 -2
  29. package/dist/{command-registry-DJb9jSNL.js → command-registry-DacWRRgz.js} +10 -10
  30. package/dist/{completion-cli-BXA0UZAn.js → completion-cli-DydUIkNr.js} +2 -2
  31. package/dist/{completion-cli-DqJEZMJt.js → completion-cli-NMyMglwl.js} +1 -1
  32. package/dist/{config-cli-BfaVUsj-.js → config-cli-B4fFlFK0.js} +1 -1
  33. package/dist/{config-cli-97SkUuuT.js → config-cli-C_DUmmo_.js} +1 -1
  34. package/dist/{configure-DpswIHZC.js → configure-BRK8DqNR.js} +3 -3
  35. package/dist/{configure-CmTKkn3M.js → configure-k0XQkt_5.js} +3 -3
  36. package/dist/{deliver-BUiQ-9fE.js → deliver-CVTXl0Cv.js} +1 -1
  37. package/dist/{deps-CDLYb9a7.js → deps-Bp-zobQ9.js} +1 -1
  38. package/dist/{deps-BV_-fxNb.js → deps-C8gMsatU.js} +1 -1
  39. package/dist/{deps-IpeS3x5O.js → deps-CC9rj6VE.js} +1 -1
  40. package/dist/{deps-Bc5yBM-U.js → deps-k7zLO-No.js} +1 -1
  41. package/dist/{doctor-completion-WFEPRjgs.js → doctor-completion-CtkKGYq1.js} +1 -1
  42. package/dist/{doctor-completion-BkS6Phs6.js → doctor-completion-T65otQPW.js} +1 -1
  43. package/dist/{emergency-stop-DMTHxdvC.js → emergency-stop-B1WGLPIl.js} +2 -2
  44. package/dist/{emergency-stop-Dxp2e3a9.js → emergency-stop-Bqex5qoB.js} +7 -7
  45. package/dist/{emergency-stop-zy54uJoE.js → emergency-stop-C0olMHR9.js} +2 -2
  46. package/dist/{emergency-stop-DKLc7AmD.js → emergency-stop-CHHSptxF.js} +2 -2
  47. package/dist/entry.js +1 -1
  48. package/dist/extensionAPI.js +2 -2
  49. package/dist/{gateway-cli-FNbwxOiN.js → gateway-cli-B4fOuxUC.js} +9 -9
  50. package/dist/{gateway-cli-E6DUzxEX.js → gateway-cli-LuvH-d8m.js} +9 -9
  51. package/dist/{health-CGW71CVV.js → health-BFXk0LFk.js} +1 -1
  52. package/dist/{health-D60h_a2w.js → health-CpPRbWHn.js} +1 -1
  53. package/dist/{hooks-cli-BnVSeWIo.js → hooks-cli-RL3GbGUT.js} +3 -3
  54. package/dist/{hooks-cli-DaWPRdgZ.js → hooks-cli-q_ukCmeC.js} +3 -3
  55. package/dist/{image-D8b_rlQC.js → image-COw__ACq.js} +1 -1
  56. package/dist/index.js +7 -7
  57. package/dist/llm-slug-generator.js +7 -7
  58. package/dist/{models-C1ouQF8k.js → models-DToiZ2jp.js} +2 -2
  59. package/dist/{models-cli-CxEFLoMt.js → models-cli-8wuQnOxc.js} +3 -3
  60. package/dist/{models-cli-BhFUh61j.js → models-cli-C8tnFvU6.js} +4 -4
  61. package/dist/{npm-resolution-Ds0qg1EX.js → npm-resolution-CPEoaDTw.js} +1 -1
  62. package/dist/{npm-resolution-D30nzRfu.js → npm-resolution-Dz95V6fj.js} +1 -1
  63. package/dist/{onboard-NcA_odSQ.js → onboard-DnGowokw.js} +2 -2
  64. package/dist/{onboard-Cv6q6Usf.js → onboard-Dx-J8Bes.js} +2 -2
  65. package/dist/{onboard-channels-C1E5DpTR.js → onboard-channels-CU5VwTMC.js} +1 -1
  66. package/dist/{onboard-channels-bfoS7x6P.js → onboard-channels-rnRb5koA.js} +1 -1
  67. package/dist/{onboarding-CX8a934a.js → onboarding-5FnIgrWy.js} +3 -3
  68. package/dist/{onboarding-CpGBbVTj.js → onboarding-ztl5snrV.js} +3 -3
  69. package/dist/{onboarding.finalize-CRgpFQIz.js → onboarding.finalize-CvJCdPZc.js} +6 -6
  70. package/dist/{onboarding.finalize-BnKQeFN8.js → onboarding.finalize-DpwZIBVH.js} +7 -7
  71. package/dist/{pi-embedded-0YMQWOc5.js → pi-embedded-BYtUxbhJ.js} +11 -11
  72. package/dist/{pi-embedded-BO8wzB4O.js → pi-embedded-CIJj8Clt.js} +26 -26
  73. package/dist/{pi-embedded-helpers-CghCLoPo.js → pi-embedded-helpers-CyTpDKo5.js} +4 -4
  74. package/dist/{plugin-registry-Cp2q0pVP.js → plugin-registry-BCBZDFZm.js} +1 -1
  75. package/dist/{plugin-registry-DceNUcJc.js → plugin-registry-CY9YBaxv.js} +1 -1
  76. package/dist/plugin-sdk/{agent-via-gateway-MuDsrNW6.js → agent-via-gateway-RUSmiQPF.js} +2 -2
  77. package/dist/plugin-sdk/{anton-CkJKOeKT.js → anton-BluQsLu2.js} +88 -22
  78. package/dist/plugin-sdk/{channel-web-B6pGyJpM.js → channel-web-Dn0OzSFP.js} +2 -2
  79. package/dist/plugin-sdk/{deps-FuyQakmK.js → deps-C8qACokW.js} +1 -1
  80. package/dist/plugin-sdk/{emergency-stop-Ci4JC4dU.js → emergency-stop-DylRK_E8.js} +2 -2
  81. package/dist/plugin-sdk/index.js +3 -3
  82. package/dist/plugin-sdk/{reply-BTVimsoK.js → reply-DhycbFxW.js} +11 -11
  83. package/dist/plugin-sdk/{web-HiiN5NkP.js → web-yryYzFPs.js} +3 -3
  84. package/dist/{plugins-cli-2wK7R85Y.js → plugins-cli-BLcXY9sR.js} +3 -3
  85. package/dist/{plugins-cli-BaQt7jqk.js → plugins-cli-c-YfMlpn.js} +3 -3
  86. package/dist/{program-CbwFv75G.js → program-IXAxx4y-.js} +8 -8
  87. package/dist/{program-context-Ck-chzM_.js → program-context-lbXboD45.js} +18 -18
  88. package/dist/{prompt-select-styled-DJ5ONfKl.js → prompt-select-styled-C9ZBkTHU.js} +4 -4
  89. package/dist/{prompt-select-styled-DigZiJWM.js → prompt-select-styled-D1foahBO.js} +4 -4
  90. package/dist/{provider-auth-helpers-DGTDTeE5.js → provider-auth-helpers-CKJG35W4.js} +1 -1
  91. package/dist/{provider-auth-helpers-Ci_EGvif.js → provider-auth-helpers-Q2ZCYpBX.js} +1 -1
  92. package/dist/{push-apns-Dz4hOY07.js → push-apns-DM5pSWEU.js} +1 -1
  93. package/dist/{push-apns-BSYjGCn9.js → push-apns-DbZAasNF.js} +1 -1
  94. package/dist/{pw-ai-CfYaR1K2.js → pw-ai-CowTfhOG.js} +1 -1
  95. package/dist/{register.agent-CTPc2Q9m.js → register.agent-BObt1WS1.js} +8 -8
  96. package/dist/{register.agent-BZh3UWw3.js → register.agent-CMgUOruT.js} +9 -9
  97. package/dist/{register.configure-vVDARCph.js → register.configure-B3lElmGa.js} +8 -8
  98. package/dist/{register.configure-BzTxX7SG.js → register.configure-BSoAZhfz.js} +8 -8
  99. package/dist/{register.maintenance-DTXn32on.js → register.maintenance-0PNfXeOc.js} +8 -8
  100. package/dist/{register.maintenance-BNHEV-po.js → register.maintenance-mxkecZ9A.js} +9 -9
  101. package/dist/{register.message-BYWAEsKP.js → register.message-D7VHunA0.js} +3 -3
  102. package/dist/{register.message-CHf51taw.js → register.message-Dr4UBjNt.js} +3 -3
  103. package/dist/{register.onboard-CxwDhXRS.js → register.onboard-BvDwJMC5.js} +2 -2
  104. package/dist/{register.onboard-vruDRZdG.js → register.onboard-Xh9xW0hH.js} +2 -2
  105. package/dist/{register.orchestrator-anton-qBr2ZYrk.js → register.orchestrator-anton-CObXxmuY.js} +2 -2
  106. package/dist/{register.orchestrator-anton-GSAFxzGa.js → register.orchestrator-anton-DShH4ce_.js} +2 -2
  107. package/dist/{register.setup-DlFQIXoR.js → register.setup-BxsKZdfB.js} +2 -2
  108. package/dist/{register.setup-B0zmlTXV.js → register.setup-d2XyhTY9.js} +2 -2
  109. package/dist/{register.status-health-sessions-16paRP9f.js → register.status-health-sessions-CADZZQMe.js} +4 -4
  110. package/dist/{register.status-health-sessions-CtXhn9Dq.js → register.status-health-sessions-wyNUhSbK.js} +4 -4
  111. package/dist/{register.subclis-lskGgus9.js → register.subclis-Bh3Lakik.js} +9 -9
  112. package/dist/{reply-DfRr_KdS.js → reply-AI4n5V-o.js} +11 -11
  113. package/dist/{run-main-Bj-8MZGb.js → run-main-DNLZvSB0.js} +15 -15
  114. package/dist/{runner-PgRFPYUj.js → runner-BzNdfqDz.js} +1 -1
  115. package/dist/{server-node-events-Benu2lR2.js → server-node-events-B9rufyZR.js} +3 -3
  116. package/dist/{server-node-events-B_LUFrA_.js → server-node-events-DPeIs1oo.js} +3 -3
  117. package/dist/{status-DxcdgCyX.js → status-CvtDDIW9.js} +2 -2
  118. package/dist/{status-DzCllHYZ.js → status-rvywYmZR.js} +2 -2
  119. package/dist/{subagent-registry-BcpHnckA.js → subagent-registry-D7Dwl-dH.js} +11 -11
  120. package/dist/{update-cli-B53rJqAV.js → update-cli-Bofvelva.js} +8 -8
  121. package/dist/{update-cli-CTETjvrF.js → update-cli-DaGTiqso.js} +9 -9
  122. package/dist/{update-runner-BGAdvd0c.js → update-runner-4txNUERu.js} +1 -1
  123. package/dist/{update-runner-BOGIWX18.js → update-runner-B9mGXrK4.js} +1 -1
  124. package/dist/{web-C7HXffph.js → web-BsIp9miY.js} +3 -3
  125. package/dist/{web-CqOVupWI.js → web-D3gEaA39.js} +3 -3
  126. package/dist/{web-3nv8mK11.js → web-DhiwmDh8.js} +3 -3
  127. package/dist/{web-Dwj9igbL.js → web-JPsGpVZ5.js} +8 -8
  128. package/package.json +1 -1
@@ -1,7 +1,7 @@
1
1
  import "./paths-Cn44w-EB.js";
2
2
  import { h as pathExists, y as resolveUserPath } from "./utils-CXzXXV2o.js";
3
3
  import "./thinking-EAliFiVK.js";
4
- import "./reply-DfRr_KdS.js";
4
+ import "./reply-AI4n5V-o.js";
5
5
  import { v as DEFAULT_BOOTSTRAP_FILENAME } from "./agent-scope-RA0zXRpu.js";
6
6
  import "./subsystem-CGZX2PBV.js";
7
7
  import { i as restoreTerminalState } from "./runtime-44j_X4Y6.js";
@@ -103,7 +103,7 @@ import "./resolve-route-D_AbcmD6.js";
103
103
  import "./replies-hSFVxL4h.js";
104
104
  import "./skill-commands-BFzmZAfo.js";
105
105
  import "./workspace-dirs-SsExQ3Bz.js";
106
- import "./deps-IpeS3x5O.js";
106
+ import "./deps-CC9rj6VE.js";
107
107
  import "./plugin-auto-enable-7DUxMy6A.js";
108
108
  import "./channel-selection-ZxRkxpuF.js";
109
109
  import "./outbound-attachment-Bot3bRnK.js";
@@ -117,17 +117,17 @@ import "./server-lifecycle-B5PlrlbG.js";
117
117
  import "./stagger-rQoQSWkz.js";
118
118
  import "./system-run-command-qJdgzxLp.js";
119
119
  import "./runtime-guard-X6f4YmTM.js";
120
- import "./program-context-Ck-chzM_.js";
120
+ import "./program-context-lbXboD45.js";
121
121
  import "./note-69EfBEU-.js";
122
- import { r as installCompletion } from "./completion-cli-DqJEZMJt.js";
122
+ import { r as installCompletion } from "./completion-cli-NMyMglwl.js";
123
123
  import { n as gatewayInstallErrorHint, t as buildGatewayInstallPlan } from "./daemon-install-helpers-BZY9-jNW.js";
124
124
  import { n as GATEWAY_DAEMON_RUNTIME_OPTIONS, t as DEFAULT_GATEWAY_DAEMON_RUNTIME } from "./daemon-runtime-BGXzfrm4.js";
125
125
  import { r as isSystemdUserServiceAvailable } from "./systemd-CaCR5CyM.js";
126
126
  import { t as resolveGatewayService } from "./service-C8NMS3m_.js";
127
- import { r as healthCommand } from "./health-CGW71CVV.js";
127
+ import { r as healthCommand } from "./health-BFXk0LFk.js";
128
128
  import { t as ensureControlUiAssetsBuilt } from "./control-ui-assets-C7ZpN9hN.js";
129
129
  import { t as formatHealthCheckFailure } from "./health-format-Ba_hOaT2.js";
130
- import { r as ensureCompletionCacheExists, t as checkShellCompletionStatus } from "./doctor-completion-BkS6Phs6.js";
130
+ import { r as ensureCompletionCacheExists, t as checkShellCompletionStatus } from "./doctor-completion-T65otQPW.js";
131
131
  import { t as runTui } from "./tui-Bne3YNiw.js";
132
132
  import os from "node:os";
133
133
  import path from "node:path";
@@ -26,7 +26,7 @@ import "./logging-Bgrm4o7g.js";
26
26
  import "./auth-store-D9BmR4S6.js";
27
27
  import "./send-m4lQkQcY.js";
28
28
  import "./send-CCiDIuX4.js";
29
- import "./subagent-registry-BcpHnckA.js";
29
+ import "./subagent-registry-D7Dwl-dH.js";
30
30
  import "./paths-CC17i2eK.js";
31
31
  import "./chat-envelope-Dedaetiq.js";
32
32
  import "./client-udFMSDes.js";
@@ -109,24 +109,24 @@ import "./cli-utils-BfsDuRZS.js";
109
109
  import "./help-format-CldHB7lS.js";
110
110
  import "./progress-B76RkFx7.js";
111
111
  import "./replies-DSfpze17.js";
112
- import "./deps-BV_-fxNb.js";
112
+ import "./deps-C8gMsatU.js";
113
113
  import { b as waitForGatewayReachable, f as openUrl, g as resolveControlUiLinks, i as detectBrowserOpenSupport, m as probeGatewayReachable, o as formatControlUiSshHint } from "./onboard-helpers-DWivfzcc.js";
114
114
  import "./prompt-style-XmK49QYK.js";
115
115
  import "./pairing-labels-D7xcHkxi.js";
116
116
  import "./note-C2HHth6G.js";
117
- import { r as installCompletion } from "./completion-cli-BXA0UZAn.js";
118
- import "./register.subclis-lskGgus9.js";
119
- import "./command-registry-DJb9jSNL.js";
117
+ import { r as installCompletion } from "./completion-cli-DydUIkNr.js";
118
+ import "./register.subclis-Bh3Lakik.js";
119
+ import "./command-registry-DacWRRgz.js";
120
120
  import "./program-context-BrqeiWcA.js";
121
121
  import { n as gatewayInstallErrorHint, t as buildGatewayInstallPlan } from "./daemon-install-helpers-DUHqeg5Y.js";
122
122
  import "./runtime-guard-DTSD0F6o.js";
123
123
  import { n as GATEWAY_DAEMON_RUNTIME_OPTIONS, t as DEFAULT_GATEWAY_DAEMON_RUNTIME } from "./daemon-runtime-CRT3STlu.js";
124
124
  import { r as isSystemdUserServiceAvailable } from "./systemd-CYLBa7fG.js";
125
125
  import { t as resolveGatewayService } from "./service-BzgRt9im.js";
126
- import { r as healthCommand } from "./health-D60h_a2w.js";
126
+ import { r as healthCommand } from "./health-CpPRbWHn.js";
127
127
  import { t as ensureControlUiAssetsBuilt } from "./control-ui-assets-B5haX6bT.js";
128
128
  import { t as formatHealthCheckFailure } from "./health-format-wax5NzZB.js";
129
- import { r as ensureCompletionCacheExists, t as checkShellCompletionStatus } from "./doctor-completion-WFEPRjgs.js";
129
+ import { r as ensureCompletionCacheExists, t as checkShellCompletionStatus } from "./doctor-completion-CtkKGYq1.js";
130
130
  import { t as runTui } from "./tui-2u2ZDhHV.js";
131
131
  import os from "node:os";
132
132
  import path from "node:path";
@@ -72,7 +72,7 @@ import { n as resolveAgentRoute, t as buildAgentSessionKey } from "./resolve-rou
72
72
  import { i as redactIdentifier, t as getActiveWebListener } from "./active-listener-BnWIC6Jc.js";
73
73
  import { t as makeProxyFetch } from "./proxy-CNZpb4NE.js";
74
74
  import { a as createReplyReferencePlanner, i as resolveSlackThreadTs, n as deliverReplies$3, t as createSlackReplyDeliveryPlan } from "./replies-CqYEEgmA.js";
75
- import { r as createOutboundSendDepsFromCliSource, t as createDefaultDeps } from "./deps-CDLYb9a7.js";
75
+ import { r as createOutboundSendDepsFromCliSource, t as createDefaultDeps } from "./deps-Bp-zobQ9.js";
76
76
  import { createRequire } from "node:module";
77
77
  import * as path$1 from "node:path";
78
78
  import path, { isAbsolute } from "node:path";
@@ -23059,7 +23059,7 @@ const handleAntonCommand = async (params, _allowTextCommands) => {
23059
23059
  };
23060
23060
  const arg = body.slice(6).trim();
23061
23061
  if (arg === "status" || arg === "") {
23062
- const { antonStatus } = await import("./anton-BmSsFmSP.js");
23062
+ const { antonStatus } = await import("./anton-BDDjbZ5H.js");
23063
23063
  const lines = [];
23064
23064
  await antonStatus({
23065
23065
  log: (msg) => lines.push(msg),
@@ -23075,7 +23075,7 @@ const handleAntonCommand = async (params, _allowTextCommands) => {
23075
23075
  return { shouldContinue: false };
23076
23076
  }
23077
23077
  if (arg === "stop") {
23078
- const { antonStop } = await import("./anton-BmSsFmSP.js");
23078
+ const { antonStop } = await import("./anton-BDDjbZ5H.js");
23079
23079
  const lines = [];
23080
23080
  await antonStop({
23081
23081
  log: (msg) => lines.push(msg),
@@ -23113,8 +23113,8 @@ const handleAntonCommand = async (params, _allowTextCommands) => {
23113
23113
  await sendProgress(replyCtx, text);
23114
23114
  return { shouldContinue: false };
23115
23115
  }
23116
- const { runAnton, formatProgressMessage } = await import("./anton-BmSsFmSP.js");
23117
- const { createDefaultDeps } = await import("./deps-CDLYb9a7.js").then((n) => n.n);
23116
+ const { runAnton, formatProgressMessage } = await import("./anton-BDDjbZ5H.js");
23117
+ const { createDefaultDeps } = await import("./deps-Bp-zobQ9.js").then((n) => n.n);
23118
23118
  const { createNonExitingRuntime } = await import("./runtime-8mi3mpYB.js").then((n) => n.r);
23119
23119
  const runtime = createNonExitingRuntime();
23120
23120
  const deps = createDefaultDeps();
@@ -57271,7 +57271,7 @@ function createDiscordMessageHandler(params) {
57271
57271
  try {
57272
57272
  const messageText = resolveDiscordMessageText(data.message)?.trim();
57273
57273
  if (messageText) {
57274
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-DKLc7AmD.js");
57274
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-CHHSptxF.js");
57275
57275
  if (isAbortRequestText(messageText)) {
57276
57276
  const { resolveAgentRoute } = await import("./resolve-route-BI3VjtwE.js").then((n) => n.r);
57277
57277
  const channelId = resolveDiscordMessageChannelId({
@@ -64769,7 +64769,7 @@ async function monitorIMessageProvider(opts = {}) {
64769
64769
  }
64770
64770
  const msgText = (message.text ?? "").trim();
64771
64771
  if (msgText) {
64772
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-DKLc7AmD.js");
64772
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-CHHSptxF.js");
64773
64773
  if (isAbortRequestText(msgText)) {
64774
64774
  const { resolveAgentRoute } = await import("./resolve-route-BI3VjtwE.js").then((n) => n.r);
64775
64775
  const route = resolveAgentRoute({
@@ -67380,7 +67380,7 @@ function createSignalEventHandler(deps) {
67380
67380
  const senderName = envelope.sourceName ?? senderDisplay;
67381
67381
  const messageId = typeof envelope.timestamp === "number" ? String(envelope.timestamp) : void 0;
67382
67382
  if (bodyText) {
67383
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-DKLc7AmD.js");
67383
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-CHHSptxF.js");
67384
67384
  if (isAbortRequestText(bodyText)) {
67385
67385
  const { resolveAgentRoute } = await import("./resolve-route-BI3VjtwE.js").then((n) => n.r);
67386
67386
  const route = resolveAgentRoute({
@@ -70762,7 +70762,7 @@ function createSlackMessageHandler(params) {
70762
70762
  if (ctx.markMessageSeen(message.channel, message.ts)) return;
70763
70763
  const rawText = (message.text ?? "").trim();
70764
70764
  if (rawText) {
70765
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-DKLc7AmD.js");
70765
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-CHHSptxF.js");
70766
70766
  if (isAbortRequestText(rawText)) {
70767
70767
  const { resolveAgentRoute } = await import("./resolve-route-BI3VjtwE.js").then((n) => n.r);
70768
70768
  const route = resolveAgentRoute({
@@ -72956,7 +72956,7 @@ const registerTelegramHandlers = ({ cfg, accountId, bot, opts, runtime, mediaMax
72956
72956
  const { ctx, msg, chatId, resolvedThreadId, storeAllowFrom, sendOversizeWarning, oversizeLogMessage } = params;
72957
72957
  const text = typeof msg.text === "string" ? msg.text : void 0;
72958
72958
  if (text) {
72959
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-DKLc7AmD.js");
72959
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-CHHSptxF.js");
72960
72960
  if (isAbortRequestText(text)) {
72961
72961
  const senderId = msg.from?.id ? String(msg.from.id) : "";
72962
72962
  if (!senderId || !allowFrom?.length || allowFrom.includes(senderId)) {
@@ -76441,7 +76441,7 @@ function loadWebLoginQr() {
76441
76441
  return webLoginQrPromise;
76442
76442
  }
76443
76443
  function loadWebChannel() {
76444
- webChannelPromise ??= import("./web-C7HXffph.js");
76444
+ webChannelPromise ??= import("./web-BsIp9miY.js");
76445
76445
  return webChannelPromise;
76446
76446
  }
76447
76447
  function loadWhatsAppActions() {
@@ -24,7 +24,7 @@ import { a as logoutWeb, i as logWebSelfId, l as readWebSelfId, n as getWebAuthA
24
24
  import { a as resolveSlackWebClientOptions, c as buildSlackBlocksFallbackText, i as createSlackWebClient, l as parseSlackTarget, o as parseSlackBlocksInput, s as validateSlackBlocksArray, t as sendMessageSlack, u as resolveSlackChannelId } from "./send-BeIZJuy4.js";
25
25
  import { $ as fetchChannelPermissionsDiscord, A as unpinMessageDiscord, B as listScheduledEventsDiscord, C as editMessageDiscord, Ct as resolveTimestampMs, D as pinMessageDiscord, Dt as normalizeChannelSlug, E as listThreadsDiscord, Et as buildChannelKeyCandidates, F as fetchMemberInfoDiscord, G as uploadStickerDiscord, H as timeoutMemberDiscord, I as fetchRoleInfoDiscord, J as editChannelDiscord, K as createChannelDiscord, L as fetchVoiceStatusDiscord, M as banMemberDiscord, N as createScheduledEventDiscord, O as readMessagesDiscord, Ot as resolveChannelEntryMatchWithFallback, P as fetchChannelInfoDiscord, Q as stripUndefinedFields, R as kickMemberDiscord, S as deleteMessageDiscord, St as resolveDiscordSystemLocation, T as listPinsDiscord, Tt as applyChannelMatchMeta, U as listGuildEmojisDiscord, V as removeRoleDiscord, W as uploadEmojiDiscord, X as removeChannelPermissionDiscord, Y as moveChannelDiscord, Z as setChannelPermissionDiscord, _ as sendPollDiscord, _t as resolveDiscordShouldRequireMention, a as removeReactionDiscord, at as resolveDiscordChannelId, b as sendWebhookMessageDiscord, bt as formatDiscordReactionEmoji, c as formatDiscordComponentEventText, ct as allowListMatches$1, d as parseDiscordModalCustomId, dt as normalizeDiscordSlug, et as hasAnyGuildPermissionDiscord, f as parseDiscordModalCustomIdForCarbon, ft as resolveDiscordAllowListMatch, g as sendMessageDiscord, gt as resolveDiscordOwnerAllowFrom, h as resolveDiscordModalEntry, ht as resolveDiscordMemberAccessState, i as removeOwnReactionsDiscord, it as parseDiscordTarget, j as addRoleDiscord, k as searchMessagesDiscord, l as parseDiscordComponentCustomId, lt as isDiscordGroupAllowedByPolicy, m as resolveDiscordComponentEntry, mt as resolveDiscordGuildEntry, n as fetchReactionsDiscord, nt as createDiscordClient, o as sendDiscordComponentMessage, ot as listDiscordDirectoryGroupsLive, p as readDiscordComponentSpec, pt as resolveDiscordChannelConfigWithFallback, q as deleteChannelDiscord, r as reactMessageDiscord, rt as createDiscordRestClient, s as createDiscordFormModal, st as listDiscordDirectoryPeersLive, tt as chunkDiscordTextWithMode, u as parseDiscordComponentCustomIdForCarbon, ut as normalizeDiscordAllowList, v as sendStickerDiscord, vt as resolveGroupDmAllow, w as fetchMessageDiscord, wt as fetchDiscord, x as createThreadDiscord, xt as formatDiscordUserTag, y as sendVoiceMessageDiscord, yt as shouldEmitDiscordReactionNotification, z as listGuildChannelsDiscord } from "./send-DmLC7aEF.js";
26
26
  import { n as generateSecureUuid, t as generateSecureToken } from "./secure-random-B1N_MXT_.js";
27
- import { C as initializeGlobalHookRunner, S as getGlobalHookRunner, _ as createReplyToModeFilterForChannel, a as normalizeOutboundPayloadsForJson, b as normalizeChannelTargetInput, c as parseReplyDirectives, d as applyReplyThreading, f as filterMessagingToolDuplicates, g as shouldSuppressReasoningPayload, h as shouldSuppressMessagingToolReplies, i as normalizeOutboundPayloads, l as splitMediaFromOutput, m as isRenderablePayload, o as normalizeReplyPayloadsForDelivery, p as filterMessagingToolMediaDuplicates, r as formatOutboundPayloadLog, s as throwIfAborted, t as deliverOutboundPayloads, u as applyReplyTagsToPayload, v as resolveReplyToMode, x as normalizeTargetForProvider, y as buildTargetResolverSignature } from "./deliver-BUiQ-9fE.js";
27
+ import { C as initializeGlobalHookRunner, S as getGlobalHookRunner, _ as createReplyToModeFilterForChannel, a as normalizeOutboundPayloadsForJson, b as normalizeChannelTargetInput, c as parseReplyDirectives, d as applyReplyThreading, f as filterMessagingToolDuplicates, g as shouldSuppressReasoningPayload, h as shouldSuppressMessagingToolReplies, i as normalizeOutboundPayloads, l as splitMediaFromOutput, m as isRenderablePayload, o as normalizeReplyPayloadsForDelivery, p as filterMessagingToolMediaDuplicates, r as formatOutboundPayloadLog, s as throwIfAborted, t as deliverOutboundPayloads, u as applyReplyTagsToPayload, v as resolveReplyToMode, x as normalizeTargetForProvider, y as buildTargetResolverSignature } from "./deliver-CVTXl0Cv.js";
28
28
  import { a as logMessageProcessed, c as logWebhookError, d as startDiagnosticHeartbeat, f as stopDiagnosticHeartbeat, i as logLaneEnqueue, l as logWebhookProcessed, m as isDiagnosticsEnabled, o as logMessageQueued, p as emitDiagnosticEvent, r as logLaneDequeue, s as logSessionStateChange, t as diag, u as logWebhookReceived } from "./diagnostic-4owMk4vH.js";
29
29
  import { r as getDiagnosticSessionState } from "./diagnostic-session-state-BGF2r-kt.js";
30
30
  import { n as resolveSignalAccount, t as listEnabledSignalAccounts } from "./accounts-BDVs8LTu.js";
@@ -32,8 +32,8 @@ import { $ as readJsonFileWithFallback, A as extractTelegramLocation, B as norma
32
32
  import { c as detectMime, d as imageMimeFromFormat, f as isAudioFileName, g as MAX_IMAGE_BYTES, i as getImageMetadata, l as extensionForMime, p as isGifMedia, s as resizeToJpeg, v as mediaKindFromMime } from "./image-ops-D1KtygWz.js";
33
33
  import { n as discoverModels, t as discoverAuthStorage } from "./pi-model-discovery-Bb__OY-j.js";
34
34
  import { a as isMarkdownCapableMessageChannel, c as resolveGatewayMessageChannel, d as GATEWAY_CLIENT_MODES, f as GATEWAY_CLIENT_NAMES, i as isInternalMessageChannel, l as resolveMessageChannel, n as isDeliverableMessageChannel, o as listDeliverableMessageChannels, r as isGatewayMessageChannel, s as normalizeMessageChannel, t as INTERNAL_MESSAGE_CHANNEL, u as GATEWAY_CLIENT_IDS } from "./message-channel-C8QtrwEU.js";
35
- import { $ as stripPluginOnlyAllowlist, A as isTimeoutErrorMessage, B as resolveBrowserConfig, C as isCompactionFailureError, D as isLikelyContextOverflowError, E as isFailoverErrorMessage, F as ensureSandboxWorkspaceForSession, G as resolveGatewayCredentialsFromConfig, H as getBridgeAuthForPort, I as resolveSandboxContext, J as applyOwnerOnlyToolPolicy, K as trimToUndefined$1, L as resolveSandboxRuntimeStatus, M as parseImageDimensionError, N as parseImageSizeError, O as isRateLimitAssistantError, P as sanitizeUserFacingText, Q as mergeAlsoAllowPolicy, R as createBrowserRouteContext, S as isCloudCodeAssistFormatError, T as isFailoverAssistantError, U as ensureBrowserControlAuth, V as resolveProfile, W as resolveBrowserControlAuth, X as collectExplicitAllowlist, Y as buildPluginToolGroups, Z as expandPolicyWithPluginGroups, _ as formatRawAssistantErrorForUi, a as isMessagingToolDuplicateNormalized, at as buildBootstrapContextFiles, b as isAuthPermanentErrorMessage, c as extractToolCallsFromAssistant, ct as resolveBootstrapTotalMaxChars, d as downgradeOpenAIReasoningBlocks, et as expandToolGroups, f as isGoogleModelApi, g as formatBillingErrorMessage, h as formatAssistantErrorText, it as matchesAnyGlobPattern, j as isTransientHttpError, k as isRawApiErrorPayload, l as extractToolResultId, lt as sanitizeGoogleTurnOrdering, m as classifyFailoverReason, n as validateGeminiTurns, nt as resolveToolProfilePolicy, o as normalizeTextForComparison, ot as ensureSessionHeader, p as BILLING_ERROR_USER_MESSAGE, q as resolveSandboxConfigForAgent, r as pickFallbackThinkingLevel, rt as compileGlobPatterns, s as sanitizeSessionMessagesImages, st as resolveBootstrapMaxChars, t as validateAnthropicTurns, tt as normalizeToolName, u as sanitizeToolCallIdsForCloudCodeAssist, v as getApiErrorPayloadFingerprint, w as isContextOverflowError, x as isBillingAssistantError, y as isAuthAssistantError, z as registerBrowserRoutes } from "./pi-embedded-helpers-CghCLoPo.js";
36
- import { C as ensureChromeExtensionRelayServer, F as isSecureWebSocketUrl, O as DEFAULT_UPLOAD_DIR, P as isLoopbackHost, R as DEFAULT_AI_SNAPSHOT_MAX_CHARS, T as rawDataToString, k as resolveExistingPathsWithinRoot, s as resolveLsofCommandSync } from "./chrome-BcJB6PcM.js";
35
+ import { $ as stripPluginOnlyAllowlist, A as isTimeoutErrorMessage, B as resolveBrowserConfig, C as isCompactionFailureError, D as isLikelyContextOverflowError, E as isFailoverErrorMessage, F as ensureSandboxWorkspaceForSession, G as resolveGatewayCredentialsFromConfig, H as getBridgeAuthForPort, I as resolveSandboxContext, J as applyOwnerOnlyToolPolicy, K as trimToUndefined$1, L as resolveSandboxRuntimeStatus, M as parseImageDimensionError, N as parseImageSizeError, O as isRateLimitAssistantError, P as sanitizeUserFacingText, Q as mergeAlsoAllowPolicy, R as createBrowserRouteContext, S as isCloudCodeAssistFormatError, T as isFailoverAssistantError, U as ensureBrowserControlAuth, V as resolveProfile, W as resolveBrowserControlAuth, X as collectExplicitAllowlist, Y as buildPluginToolGroups, Z as expandPolicyWithPluginGroups, _ as formatRawAssistantErrorForUi, a as isMessagingToolDuplicateNormalized, at as buildBootstrapContextFiles, b as isAuthPermanentErrorMessage, c as extractToolCallsFromAssistant, ct as resolveBootstrapTotalMaxChars, d as downgradeOpenAIReasoningBlocks, et as expandToolGroups, f as isGoogleModelApi, g as formatBillingErrorMessage, h as formatAssistantErrorText, it as matchesAnyGlobPattern, j as isTransientHttpError, k as isRawApiErrorPayload, l as extractToolResultId, lt as sanitizeGoogleTurnOrdering, m as classifyFailoverReason, n as validateGeminiTurns, nt as resolveToolProfilePolicy, o as normalizeTextForComparison, ot as ensureSessionHeader, p as BILLING_ERROR_USER_MESSAGE, q as resolveSandboxConfigForAgent, r as pickFallbackThinkingLevel, rt as compileGlobPatterns, s as sanitizeSessionMessagesImages, st as resolveBootstrapMaxChars, t as validateAnthropicTurns, tt as normalizeToolName, u as sanitizeToolCallIdsForCloudCodeAssist, v as getApiErrorPayloadFingerprint, w as isContextOverflowError, x as isBillingAssistantError, y as isAuthAssistantError, z as registerBrowserRoutes } from "./pi-embedded-helpers-CyTpDKo5.js";
36
+ import { C as ensureChromeExtensionRelayServer, F as isSecureWebSocketUrl, O as DEFAULT_UPLOAD_DIR, P as isLoopbackHost, R as DEFAULT_AI_SNAPSHOT_MAX_CHARS, T as rawDataToString, k as resolveExistingPathsWithinRoot, s as resolveLsofCommandSync } from "./chrome-_2tzVjVl.js";
37
37
  import { i as isBlockedHostnameOrIp, o as normalizeHostname, t as SsrFBlockedError } from "./ssrf-CZeHDwVZ.js";
38
38
  import { c as assertSandboxPath, d as resolveSandboxedMediaSource, f as applySkillEnvOverrides, i as resolveSkillsPromptForRun, l as resolveSandboxInputPath, n as buildWorkspaceSkillSnapshot, p as applySkillEnvOverridesFromSnapshot, r as loadWorkspaceSkillEntries, s as assertMediaNotDataUrl } from "./skills-CnAPWfca.js";
39
39
  import { t as PATH_ALIAS_POLICIES } from "./path-alias-guards-Cu1nXNMM.js";
@@ -48,7 +48,7 @@ import { a as resolveSessionFilePathOptions, i as resolveSessionFilePath, l as r
48
48
  import { t as emitSessionTranscriptUpdate } from "./transcript-events-_OimdA_2.js";
49
49
  import { a as canonicalizeBase64, i as resolveImageSanitizationLimits, n as sanitizeImageBlocks, o as estimateBase64DecodedBytes, r as sanitizeToolResultImages } from "./tool-images-CcGZpzmq.js";
50
50
  import { a as normalizeReasoningLevel, c as normalizeVerboseLevel, i as normalizeElevatedLevel, l as resolveResponseUsageMode, n as formatXHighModelHint, o as normalizeThinkLevel, s as normalizeUsageDisplay, t as formatThinkingLevels, u as supportsXHighThinking } from "./thinking-z4_linel.js";
51
- import { C as extractTextFromChatContent, S as isInsideCode, _ as stripMinimaxToolCallXml, a as decodeDataUrl, b as stripReasoningTagsFromText, c as extractAssistantText$1, d as extractThinkingFromTaggedText, f as formatReasoningMessage, g as stripDowngradedToolCallText, h as promoteThinkingTagsToBlocks, i as coerceImageModelConfig, l as extractAssistantThinking, m as isAssistantMessage, o as resolveProviderVisionModelFromConfig, p as inferToolMetaFromArgs, r as coerceImageAssistantText, s as minimaxUnderstandImage, u as extractThinkingFromTaggedStream, v as stripThinkingTagsFromText, w as ensureIdleHandsModelsJson, x as findCodeRegions, y as resolveToolDisplay } from "./image-D8b_rlQC.js";
51
+ import { C as extractTextFromChatContent, S as isInsideCode, _ as stripMinimaxToolCallXml, a as decodeDataUrl, b as stripReasoningTagsFromText, c as extractAssistantText$1, d as extractThinkingFromTaggedText, f as formatReasoningMessage, g as stripDowngradedToolCallText, h as promoteThinkingTagsToBlocks, i as coerceImageModelConfig, l as extractAssistantThinking, m as isAssistantMessage, o as resolveProviderVisionModelFromConfig, p as inferToolMetaFromArgs, r as coerceImageAssistantText, s as minimaxUnderstandImage, u as extractThinkingFromTaggedStream, v as stripThinkingTagsFromText, w as ensureIdleHandsModelsJson, x as findCodeRegions, y as resolveToolDisplay } from "./image-COw__ACq.js";
52
52
  import { a as resolveAgentIdentity, i as resolveAckReaction, o as resolveEffectiveMessagesConfig, r as resolveResponsePrefixTemplate, s as resolveHumanDelayConfig, t as createReplyPrefixOptions } from "./reply-prefix-BUgeSN2R.js";
53
53
  import { n as resolveMemorySearchConfig } from "./manager-BE_76jWB.js";
54
54
  import { n as fetchWithTimeout, t as bindAbortRelay } from "./fetch-timeout-3YYM8QuM.js";
@@ -63,7 +63,7 @@ import { a as loadWebMedia, i as getDefaultLocalRoots } from "./ir-B7IBoKLy.js";
63
63
  import { _ as isNativeCommandsExplicitlyDisabled, a as listChatCommands, b as resolveNativeSkillsEnabled, c as listNativeCommandSpecsForConfig, d as parseCommandArgs, f as resolveCommandArgChoices, g as isCommandFlagEnabled, h as shouldHandleTextCommands, i as isCommandEnabled, l as maybeResolveTextAlias, m as serializeCommandArgs, o as listChatCommandsForConfig, p as resolveCommandArgMenu, r as findCommandByNativeName, s as listNativeCommandSpecs, t as buildCommandTextFromArgs, u as normalizeCommandBody, v as isRestartEnabled, y as resolveNativeCommandsEnabled } from "./commands-registry-j4vAzcF2.js";
64
64
  import { c as getSkillsSnapshotVersion, d as createAsyncLock, f as readJsonFile, i as resolveSkillCommandInvocation, l as pruneExpiredPending, n as listSkillCommandsForAgents, o as getRemoteSkillEligibility, p as writeJsonAtomic, r as listSkillCommandsForWorkspace, s as ensureSkillsWatcher, t as listReservedChatSlashCommandNames, u as resolvePairingPaths } from "./skill-commands-Ck3flWX7.js";
65
65
  import { r as normalizeInboundTextNewlines, t as finalizeInboundContext } from "./inbound-context-BYczzTII.js";
66
- import { _ as resolveMediaUnderstandingScope, a as resolveMediaAttachmentLocalRoots, c as loadModelCatalog, d as resolveAttachmentKind, f as buildRandomTempFilePath, g as normalizeMediaUnderstandingChatType, h as resolveTimeoutMs$2, i as resolveAutoImageModel, l as modelSupportsVision, m as resolveConcurrency, n as createMediaAttachmentCache, o as runCapability, p as registerUnhandledRejectionHandler, r as normalizeMediaAttachments, s as findModelInCatalog, t as buildProviderRegistry, v as CLI_OUTPUT_MAX_BUFFER, y as applyTemplate } from "./runner-PgRFPYUj.js";
66
+ import { _ as resolveMediaUnderstandingScope, a as resolveMediaAttachmentLocalRoots, c as loadModelCatalog, d as resolveAttachmentKind, f as buildRandomTempFilePath, g as normalizeMediaUnderstandingChatType, h as resolveTimeoutMs$2, i as resolveAutoImageModel, l as modelSupportsVision, m as resolveConcurrency, n as createMediaAttachmentCache, o as runCapability, p as registerUnhandledRejectionHandler, r as normalizeMediaAttachments, s as findModelInCatalog, t as buildProviderRegistry, v as CLI_OUTPUT_MAX_BUFFER, y as applyTemplate } from "./runner-BzNdfqDz.js";
67
67
  import { n as wrapFetchWithAbortSignal, t as resolveFetch } from "./fetch-CsfR_943.js";
68
68
  import { n as recordCommandPoll, r as resetCommandPollCount } from "./command-poll-backoff-D9g0X0i7.js";
69
69
  import { n as recordChannelActivity, r as createDiscordRetryRunner, t as getChannelActivity } from "./channel-activity-D_TMOGQ0.js";
@@ -75,7 +75,7 @@ import { n as resolveAgentRoute, t as buildAgentSessionKey } from "./resolve-rou
75
75
  import { i as redactIdentifier, t as getActiveWebListener } from "./active-listener-jilCMH1M.js";
76
76
  import { t as makeProxyFetch } from "./proxy-CRB9oCP5.js";
77
77
  import { a as createReplyReferencePlanner, i as resolveSlackThreadTs, n as deliverReplies$3, t as createSlackReplyDeliveryPlan } from "./replies-6_GxvQYe.js";
78
- import { r as createOutboundSendDepsFromCliSource, t as createDefaultDeps } from "./deps-Bc5yBM-U.js";
78
+ import { r as createOutboundSendDepsFromCliSource, t as createDefaultDeps } from "./deps-k7zLO-No.js";
79
79
  import { createRequire } from "node:module";
80
80
  import * as fs$1 from "node:fs/promises";
81
81
  import fs from "node:fs/promises";
@@ -94,7 +94,7 @@ import { CURRENT_SESSION_VERSION, DefaultResourceLoader, SessionManager, Setting
94
94
  import { EdgeTTS } from "node-edge-tts";
95
95
  import { createServer } from "node:http";
96
96
  import { ProxyAgent, fetch as fetch$1 } from "undici";
97
- import WebSocket$1, { WebSocket } from "ws";
97
+ import WebSocket, { WebSocket as WebSocket$1 } from "ws";
98
98
  import { Buffer as Buffer$1 } from "node:buffer";
99
99
  import { createJiti } from "jiti";
100
100
  import { Type } from "@sinclair/typebox";
@@ -6375,7 +6375,7 @@ var GatewayClient = class {
6375
6375
  if (fingerprint !== expected) return /* @__PURE__ */ new Error("gateway tls fingerprint mismatch");
6376
6376
  });
6377
6377
  }
6378
- this.ws = new WebSocket(url, wsOptions);
6378
+ this.ws = new WebSocket$1(url, wsOptions);
6379
6379
  this.ws.on("open", () => {
6380
6380
  if (url.startsWith("wss://") && this.opts.tlsFingerprint) {
6381
6381
  const tlsError = this.validateTlsFingerprint();
@@ -6571,7 +6571,7 @@ var GatewayClient = class {
6571
6571
  const connectChallengeTimeoutMs = typeof rawConnectDelayMs === "number" && Number.isFinite(rawConnectDelayMs) ? Math.max(250, Math.min(1e4, rawConnectDelayMs)) : 2e3;
6572
6572
  if (this.connectTimer) clearTimeout(this.connectTimer);
6573
6573
  this.connectTimer = setTimeout(() => {
6574
- if (this.connectSent || this.ws?.readyState !== WebSocket.OPEN) return;
6574
+ if (this.connectSent || this.ws?.readyState !== WebSocket$1.OPEN) return;
6575
6575
  this.opts.onConnectError?.(/* @__PURE__ */ new Error("gateway connect challenge timeout"));
6576
6576
  this.ws?.close(1008, "connect challenge timeout");
6577
6577
  }, connectChallengeTimeoutMs);
@@ -6613,7 +6613,7 @@ var GatewayClient = class {
6613
6613
  return null;
6614
6614
  }
6615
6615
  async request(method, params, opts) {
6616
- if (!this.ws || this.ws.readyState !== WebSocket.OPEN) throw new Error("gateway not connected");
6616
+ if (!this.ws || this.ws.readyState !== WebSocket$1.OPEN) throw new Error("gateway not connected");
6617
6617
  const id = randomUUID();
6618
6618
  const frame = {
6619
6619
  type: "req",
@@ -7937,7 +7937,7 @@ async function routeReply(params) {
7937
7937
  const resolvedReplyToId = replyToId ?? (channelId === "slack" && threadId != null && threadId !== "" ? String(threadId) : void 0);
7938
7938
  const resolvedThreadId = channelId === "slack" ? null : threadId ?? null;
7939
7939
  try {
7940
- const { deliverOutboundPayloads } = await import("./deliver-BUiQ-9fE.js").then((n) => n.n);
7940
+ const { deliverOutboundPayloads } = await import("./deliver-CVTXl0Cv.js").then((n) => n.n);
7941
7941
  const outboundSession = buildOutboundSessionContext({
7942
7942
  cfg,
7943
7943
  agentId: resolvedAgentId,
@@ -23062,7 +23062,7 @@ const handleAntonCommand = async (params, _allowTextCommands) => {
23062
23062
  };
23063
23063
  const arg = body.slice(6).trim();
23064
23064
  if (arg === "status" || arg === "") {
23065
- const { antonStatus } = await import("./anton-Cw4-BgtA.js");
23065
+ const { antonStatus } = await import("./anton-C33_8bVg.js");
23066
23066
  const lines = [];
23067
23067
  await antonStatus({
23068
23068
  log: (msg) => lines.push(msg),
@@ -23078,7 +23078,7 @@ const handleAntonCommand = async (params, _allowTextCommands) => {
23078
23078
  return { shouldContinue: false };
23079
23079
  }
23080
23080
  if (arg === "stop") {
23081
- const { antonStop } = await import("./anton-Cw4-BgtA.js");
23081
+ const { antonStop } = await import("./anton-C33_8bVg.js");
23082
23082
  const lines = [];
23083
23083
  await antonStop({
23084
23084
  log: (msg) => lines.push(msg),
@@ -23116,8 +23116,8 @@ const handleAntonCommand = async (params, _allowTextCommands) => {
23116
23116
  await sendProgress(replyCtx, text);
23117
23117
  return { shouldContinue: false };
23118
23118
  }
23119
- const { runAnton, formatProgressMessage } = await import("./anton-Cw4-BgtA.js");
23120
- const { createDefaultDeps } = await import("./deps-Bc5yBM-U.js").then((n) => n.n);
23119
+ const { runAnton, formatProgressMessage } = await import("./anton-C33_8bVg.js");
23120
+ const { createDefaultDeps } = await import("./deps-k7zLO-No.js").then((n) => n.n);
23121
23121
  const { createNonExitingRuntime } = await import("./runtime-8mi3mpYB.js").then((n) => n.r);
23122
23122
  const runtime = createNonExitingRuntime();
23123
23123
  const deps = createDefaultDeps();
@@ -47429,7 +47429,7 @@ async function deliverSessionMaintenanceWarning(params) {
47429
47429
  return;
47430
47430
  }
47431
47431
  try {
47432
- const { deliverOutboundPayloads } = await import("./deliver-BUiQ-9fE.js").then((n) => n.n);
47432
+ const { deliverOutboundPayloads } = await import("./deliver-CVTXl0Cv.js").then((n) => n.n);
47433
47433
  const outboundSession = buildOutboundSessionContext({
47434
47434
  cfg: params.cfg,
47435
47435
  sessionKey: params.sessionKey
@@ -51865,7 +51865,7 @@ async function describeStickerImage(params) {
51865
51865
  logVerbose(`telegram: describing sticker with ${provider}/${model}`);
51866
51866
  try {
51867
51867
  const buffer = await fs.readFile(imagePath);
51868
- const { describeImageWithModel } = await import("./image-D8b_rlQC.js").then((n) => n.n);
51868
+ const { describeImageWithModel } = await import("./image-COw__ACq.js").then((n) => n.n);
51869
51869
  return (await describeImageWithModel({
51870
51870
  buffer,
51871
51871
  fileName: "sticker.webp",
@@ -54793,7 +54793,7 @@ async function preflightDiscordMessage(params) {
54793
54793
  let preflightTranscript;
54794
54794
  const hasAudioAttachment = message.attachments?.some((att) => att.contentType?.startsWith("audio/"));
54795
54795
  if (!isDirectMessage && shouldRequireMention && hasAudioAttachment && !baseText && mentionRegexes.length > 0) try {
54796
- const { transcribeFirstAudio } = await import("./audio-preflight-CW8IH1lU.js");
54796
+ const { transcribeFirstAudio } = await import("./audio-preflight-BSlR2jEq.js");
54797
54797
  const audioPaths = message.attachments?.filter((att) => att.contentType?.startsWith("audio/")).map((att) => att.url) ?? [];
54798
54798
  if (audioPaths.length > 0) preflightTranscript = await transcribeFirstAudio({
54799
54799
  ctx: {
@@ -57274,7 +57274,7 @@ function createDiscordMessageHandler(params) {
57274
57274
  try {
57275
57275
  const messageText = resolveDiscordMessageText(data.message)?.trim();
57276
57276
  if (messageText) {
57277
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-Dxp2e3a9.js");
57277
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-Bqex5qoB.js");
57278
57278
  if (isAbortRequestText(messageText)) {
57279
57279
  const { resolveAgentRoute } = await import("./resolve-route-DuttYY7A.js").then((n) => n.r);
57280
57280
  const channelId = resolveDiscordMessageChannelId({
@@ -62720,7 +62720,7 @@ function createDiscordGatewayPlugin(params) {
62720
62720
  return super.registerClient(client);
62721
62721
  }
62722
62722
  createWebSocket(url) {
62723
- return new WebSocket$1(url, { agent: wsAgent });
62723
+ return new WebSocket(url, { agent: wsAgent });
62724
62724
  }
62725
62725
  }
62726
62726
  return new ProxyGatewayPlugin();
@@ -64772,7 +64772,7 @@ async function monitorIMessageProvider(opts = {}) {
64772
64772
  }
64773
64773
  const msgText = (message.text ?? "").trim();
64774
64774
  if (msgText) {
64775
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-Dxp2e3a9.js");
64775
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-Bqex5qoB.js");
64776
64776
  if (isAbortRequestText(msgText)) {
64777
64777
  const { resolveAgentRoute } = await import("./resolve-route-DuttYY7A.js").then((n) => n.r);
64778
64778
  const route = resolveAgentRoute({
@@ -67383,7 +67383,7 @@ function createSignalEventHandler(deps) {
67383
67383
  const senderName = envelope.sourceName ?? senderDisplay;
67384
67384
  const messageId = typeof envelope.timestamp === "number" ? String(envelope.timestamp) : void 0;
67385
67385
  if (bodyText) {
67386
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-Dxp2e3a9.js");
67386
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-Bqex5qoB.js");
67387
67387
  if (isAbortRequestText(bodyText)) {
67388
67388
  const { resolveAgentRoute } = await import("./resolve-route-DuttYY7A.js").then((n) => n.r);
67389
67389
  const route = resolveAgentRoute({
@@ -70765,7 +70765,7 @@ function createSlackMessageHandler(params) {
70765
70765
  if (ctx.markMessageSeen(message.channel, message.ts)) return;
70766
70766
  const rawText = (message.text ?? "").trim();
70767
70767
  if (rawText) {
70768
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-Dxp2e3a9.js");
70768
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-Bqex5qoB.js");
70769
70769
  if (isAbortRequestText(rawText)) {
70770
70770
  const { resolveAgentRoute } = await import("./resolve-route-DuttYY7A.js").then((n) => n.r);
70771
70771
  const route = resolveAgentRoute({
@@ -72959,7 +72959,7 @@ const registerTelegramHandlers = ({ cfg, accountId, bot, opts, runtime, mediaMax
72959
72959
  const { ctx, msg, chatId, resolvedThreadId, storeAllowFrom, sendOversizeWarning, oversizeLogMessage } = params;
72960
72960
  const text = typeof msg.text === "string" ? msg.text : void 0;
72961
72961
  if (text) {
72962
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-Dxp2e3a9.js");
72962
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-Bqex5qoB.js");
72963
72963
  if (isAbortRequestText(text)) {
72964
72964
  const senderId = msg.from?.id ? String(msg.from.id) : "";
72965
72965
  if (!senderId || !allowFrom?.length || allowFrom.includes(senderId)) {
@@ -73846,7 +73846,7 @@ const buildTelegramMessageContext = async ({ primaryCtx, allMedia, replyMedia =
73846
73846
  const hasAudio = allMedia.some((media) => media.contentType?.startsWith("audio/"));
73847
73847
  let preflightTranscript;
73848
73848
  if (isGroup && requireMention && hasAudio && !hasUserText && mentionRegexes.length > 0) try {
73849
- const { transcribeFirstAudio } = await import("./audio-preflight-CW8IH1lU.js");
73849
+ const { transcribeFirstAudio } = await import("./audio-preflight-BSlR2jEq.js");
73850
73850
  preflightTranscript = await transcribeFirstAudio({
73851
73851
  ctx: {
73852
73852
  MediaPaths: allMedia.length > 0 ? allMedia.map((m) => m.path) : void 0,
@@ -76444,7 +76444,7 @@ function loadWebLoginQr() {
76444
76444
  return webLoginQrPromise;
76445
76445
  }
76446
76446
  function loadWebChannel() {
76447
- webChannelPromise ??= import("./web-Dwj9igbL.js");
76447
+ webChannelPromise ??= import("./web-JPsGpVZ5.js");
76448
76448
  return webChannelPromise;
76449
76449
  }
76450
76450
  function loadWhatsAppActions() {
@@ -10,7 +10,7 @@ import { t as formatCliCommand } from "./command-format-BAxx4PW5.js";
10
10
  import { t as parseBooleanValue } from "./boolean-CE7i9tBR.js";
11
11
  import { t as generateSecureToken } from "./secure-random-B1N_MXT_.js";
12
12
  import { i as getImageMetadata, n as buildImageResizeSideGrid, s as resizeToJpeg, t as IMAGE_REDUCE_QUALITY_STEPS } from "./image-ops-D1KtygWz.js";
13
- import { B as DEFAULT_BROWSER_EVALUATE_ENABLED, C as ensureChromeExtensionRelayServer, D as DEFAULT_TRACE_DIR, E as DEFAULT_DOWNLOAD_DIR, H as DEFAULT_IDLEHANDS_BROWSER_ENABLED, I as DEFAULT_AI_SNAPSHOT_EFFICIENT_DEPTH, L as DEFAULT_AI_SNAPSHOT_EFFICIENT_MAX_CHARS, N as normalizeBrowserFormField, O as DEFAULT_UPLOAD_DIR, P as isLoopbackHost, R as DEFAULT_AI_SNAPSHOT_MAX_CHARS, U as DEFAULT_IDLEHANDS_BROWSER_PROFILE_NAME, V as DEFAULT_IDLEHANDS_BROWSER_COLOR, _ as withBrowserNavigationPolicy, a as resolveIdleHandsUserDataDir, b as fetchOk, c as resolveBrowserExecutableForPlatform, f as normalizeCdpWsUrl, g as assertBrowserNavigationResultAllowed, h as assertBrowserNavigationAllowed, i as launchIdleHandsChrome, j as resolveWritablePathWithinRoot, k as resolveExistingPathsWithinRoot, l as captureScreenshot, m as InvalidBrowserNavigationUrlError, n as isChromeCdpReady, o as stopIdleHandsChrome, p as snapshotAria, r as isChromeReachable, u as createTargetViaCdp, v as appendCdpPath, w as stopChromeExtensionRelayServer, y as fetchJson, z as DEFAULT_BROWSER_DEFAULT_PROFILE_NAME } from "./chrome-BcJB6PcM.js";
13
+ import { B as DEFAULT_BROWSER_EVALUATE_ENABLED, C as ensureChromeExtensionRelayServer, D as DEFAULT_TRACE_DIR, E as DEFAULT_DOWNLOAD_DIR, H as DEFAULT_IDLEHANDS_BROWSER_ENABLED, I as DEFAULT_AI_SNAPSHOT_EFFICIENT_DEPTH, L as DEFAULT_AI_SNAPSHOT_EFFICIENT_MAX_CHARS, N as normalizeBrowserFormField, O as DEFAULT_UPLOAD_DIR, P as isLoopbackHost, R as DEFAULT_AI_SNAPSHOT_MAX_CHARS, U as DEFAULT_IDLEHANDS_BROWSER_PROFILE_NAME, V as DEFAULT_IDLEHANDS_BROWSER_COLOR, _ as withBrowserNavigationPolicy, a as resolveIdleHandsUserDataDir, b as fetchOk, c as resolveBrowserExecutableForPlatform, f as normalizeCdpWsUrl, g as assertBrowserNavigationResultAllowed, h as assertBrowserNavigationAllowed, i as launchIdleHandsChrome, j as resolveWritablePathWithinRoot, k as resolveExistingPathsWithinRoot, l as captureScreenshot, m as InvalidBrowserNavigationUrlError, n as isChromeCdpReady, o as stopIdleHandsChrome, p as snapshotAria, r as isChromeReachable, u as createTargetViaCdp, v as appendCdpPath, w as stopChromeExtensionRelayServer, y as fetchJson, z as DEFAULT_BROWSER_DEFAULT_PROFILE_NAME } from "./chrome-_2tzVjVl.js";
14
14
  import { t as SsrFBlockedError } from "./ssrf-CZeHDwVZ.js";
15
15
  import { a as syncSkillsToWorkspace, l as resolveSandboxInputPath, m as sanitizeEnvVars, u as resolveSandboxPath } from "./skills-CnAPWfca.js";
16
16
  import { t as PATH_ALIAS_POLICIES } from "./path-alias-guards-Cu1nXNMM.js";
@@ -1182,7 +1182,7 @@ function isModuleNotFoundError(err) {
1182
1182
  }
1183
1183
  async function loadPwAiModule(mode) {
1184
1184
  try {
1185
- return await import("./pw-ai-CfYaR1K2.js");
1185
+ return await import("./pw-ai-CowTfhOG.js");
1186
1186
  } catch (err) {
1187
1187
  if (mode === "soft") return null;
1188
1188
  if (isModuleNotFoundError(err)) return null;
@@ -3717,11 +3717,11 @@ function createProfileContext(opts, profile) {
3717
3717
  const userDataDir = resolveIdleHandsUserDataDir(profile.name);
3718
3718
  const profileState = getProfileState();
3719
3719
  if (await isHttpReachable(300) && !profileState.running) try {
3720
- await (await import("./pw-ai-CfYaR1K2.js")).closePlaywrightBrowserConnection();
3720
+ await (await import("./pw-ai-CowTfhOG.js")).closePlaywrightBrowserConnection();
3721
3721
  } catch {}
3722
3722
  if (profileState.running) await stopRunningBrowser();
3723
3723
  try {
3724
- await (await import("./pw-ai-CfYaR1K2.js")).closePlaywrightBrowserConnection();
3724
+ await (await import("./pw-ai-CowTfhOG.js")).closePlaywrightBrowserConnection();
3725
3725
  } catch {}
3726
3726
  if (!syncFs.existsSync(userDataDir)) return {
3727
3727
  moved: false,
@@ -2,7 +2,7 @@ import { t as __exportAll } from "./rolldown-runtime-Cbj13DAv.js";
2
2
  import { E as getActivePluginRegistry, s as createSubsystemLogger } from "./entry.js";
3
3
  import { j as loadConfig } from "./auth-profiles-Baj5ImDJ.js";
4
4
  import { d as resolveDefaultAgentId, u as resolveAgentWorkspaceDir } from "./agent-scope-mLXQGQde.js";
5
- import { _ as loadIdleHandsPlugins } from "./subagent-registry-BcpHnckA.js";
5
+ import { _ as loadIdleHandsPlugins } from "./subagent-registry-D7Dwl-dH.js";
6
6
 
7
7
  //#region src/cli/plugin-registry.ts
8
8
  var plugin_registry_exports = /* @__PURE__ */ __exportAll({ ensurePluginRegistryLoaded: () => ensurePluginRegistryLoaded });
@@ -1,5 +1,5 @@
1
1
  import { t as __exportAll } from "./rolldown-runtime-Cbj13DAv.js";
2
- import { ht as loadIdleHandsPlugins } from "./reply-DfRr_KdS.js";
2
+ import { ht as loadIdleHandsPlugins } from "./reply-AI4n5V-o.js";
3
3
  import { d as resolveDefaultAgentId, u as resolveAgentWorkspaceDir } from "./agent-scope-RA0zXRpu.js";
4
4
  import { b as getActivePluginRegistry, t as createSubsystemLogger } from "./subsystem-CGZX2PBV.js";
5
5
  import { It as loadConfig } from "./model-selection-0dGxYGp8.js";
@@ -1,6 +1,6 @@
1
1
  import { s as normalizeAgentId } from "./session-key-47BV2tLd.js";
2
2
  import "./accounts-BLYMokxV.js";
3
- import { F as callGateway, I as randomIdempotencyKey, d as agentCommand, f as resolveSessionKeyForRequest, p as withProgress } from "./reply-BTVimsoK.js";
3
+ import { F as callGateway, I as randomIdempotencyKey, d as agentCommand, f as resolveSessionKeyForRequest, p as withProgress } from "./reply-DhycbFxW.js";
4
4
  import "./paths-CtGV5i8O.js";
5
5
  import "./github-copilot-token-CY2euW0d.js";
6
6
  import { r as loadConfig } from "./config-CEgzwk0J.js";
@@ -63,7 +63,7 @@ import "./send-B26cNPqY.js";
63
63
  import "./proxy-C4ewPdlN.js";
64
64
  import "./resolve-route-BZABUE4J.js";
65
65
  import "./replies-ZovJp-3F.js";
66
- import "./deps-FuyQakmK.js";
66
+ import "./deps-C8qACokW.js";
67
67
  import "./outbound-attachment-BisU5Vji.js";
68
68
 
69
69
  //#region src/commands/agent-via-gateway.ts