@visorcraft/idlehands 4.0.9 → 4.0.11

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 (140) hide show
  1. package/dist/{agent-via-gateway-C29-E0K6.js → agent-via-gateway-8kOQMpw0.js} +1 -1
  2. package/dist/{agent-via-gateway-D2lUw5_a.js → agent-via-gateway-BmUiVvOs.js} +7 -7
  3. package/dist/{agent-via-gateway-C9MXMxE9.js → agent-via-gateway-CwNsKA2p.js} +1 -1
  4. package/dist/{agent-via-gateway-DD6djeRE.js → agent-via-gateway-DFfeM1f8.js} +7 -7
  5. package/dist/{agents-BTQoPRp2.js → agents-FBXsuMx0.js} +4 -4
  6. package/dist/{agents.config-Hj50zEpg.js → agents.config-BeC7mTJ2.js} +1 -1
  7. package/dist/{agents.config-CmrYf0R9.js → agents.config-J5LaHyjZ.js} +1 -1
  8. package/dist/{anton-Ak5zdzLn.js → anton-BMJsNqqL.js} +1 -1
  9. package/dist/{anton-CHMhMbfn.js → anton-CSPEUgVi.js} +1 -1
  10. package/dist/{anton-C7A24R8k.js → anton-_S2TvK6c.js} +1 -1
  11. package/dist/{anton-Cso65xsA.js → anton-y_9cmetd.js} +1 -1
  12. package/dist/{audio-preflight-CW8IH1lU.js → audio-preflight-BSlR2jEq.js} +4 -4
  13. package/dist/{audio-preflight-CSSlgO89.js → audio-preflight-vD3mDc6w.js} +4 -4
  14. package/dist/{auth-choice-BQUQWOPB.js → auth-choice-Cxc76L50.js} +1 -1
  15. package/dist/{auth-choice-CNa4gxNm.js → auth-choice-DycYsq6V.js} +1 -1
  16. package/dist/{banner-C7YGM3JT.js → banner--eQQx-18.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-DvaeKHAx.js → channel-options-DYzhL-Ra.js} +1 -1
  21. package/dist/{channel-options-BKWtYjoK.js → channel-options-E5FeI2sT.js} +1 -1
  22. package/dist/{channel-web-VN0ZgePd.js → channel-web-D1-7qqL3.js} +2 -2
  23. package/dist/{channel-web-CAxuafZC.js → channel-web-d0g0MCG8.js} +2 -2
  24. package/dist/{channels-cli-wID9mrKy.js → channels-cli-DYqCLYO8.js} +7 -7
  25. package/dist/{channels-cli-BXaEFZn4.js → channels-cli-SHHAxfV7.js} +7 -7
  26. package/dist/{chrome-Do5potHV.js → chrome-DEnkfZ9p.js} +9 -9
  27. package/dist/{chrome-BcJB6PcM.js → chrome-_2tzVjVl.js} +9 -9
  28. package/dist/{cli-Bn2CZFDi.js → cli-CIJ_pp-W.js} +2 -2
  29. package/dist/{cli-BxRgr1BR.js → cli-Cg2smqR5.js} +2 -2
  30. package/dist/{command-registry-Dm6V5xBk.js → command-registry-D_coG163.js} +10 -10
  31. package/dist/{completion-cli-DnvwEZHv.js → completion-cli-CAERO_KP.js} +1 -1
  32. package/dist/{completion-cli-BaJBGfP6.js → completion-cli-CTGLJrsU.js} +2 -2
  33. package/dist/{config-cli-DglEI40O.js → config-cli-Ft-MoBA0.js} +1 -1
  34. package/dist/{config-cli-DTMfFEvU.js → config-cli-QKNRUury.js} +1 -1
  35. package/dist/{configure-CFDo6pK5.js → configure-CSFuzRuG.js} +3 -3
  36. package/dist/{configure-DYSAOrvA.js → configure-Dp2SC2bd.js} +3 -3
  37. package/dist/daemon-cli.js +6 -6
  38. package/dist/{deliver-whAbSPLk.js → deliver-5FLCa6tB.js} +1 -1
  39. package/dist/{deliver-BUiQ-9fE.js → deliver-CVTXl0Cv.js} +1 -1
  40. package/dist/{deps-DHhqEEEB.js → deps-CAYnlnre.js} +1 -1
  41. package/dist/{deps-Crf9tOgB.js → deps-DMIwjElF.js} +1 -1
  42. package/dist/{deps-dk-mZVY7.js → deps-DyhYyFzN.js} +1 -1
  43. package/dist/{deps-BuPPEKKU.js → deps-ruCIL6tu.js} +1 -1
  44. package/dist/{doctor-completion-DA87R6kk.js → doctor-completion-BTK69nw4.js} +1 -1
  45. package/dist/{doctor-completion-DHYMwPxZ.js → doctor-completion-C4IaYTpf.js} +1 -1
  46. package/dist/{emergency-stop-dQB5TH61.js → emergency-stop-7aCLPd3c.js} +2 -2
  47. package/dist/{emergency-stop-DqK6Iaxy.js → emergency-stop-BFA2JE99.js} +7 -7
  48. package/dist/{emergency-stop-DSazHQ3v.js → emergency-stop-C4Nj0B8-.js} +7 -7
  49. package/dist/{emergency-stop-D32_vcC_.js → emergency-stop-NRDPtN2X.js} +2 -2
  50. package/dist/entry.js +1 -1
  51. package/dist/extensionAPI.js +7 -7
  52. package/dist/{gateway-cli-NFBeo83U.js → gateway-cli-DOdmF6H_.js} +9 -9
  53. package/dist/{gateway-cli-C4c-ntiL.js → gateway-cli-vdmjtTaI.js} +9 -9
  54. package/dist/{health--cNlCqAN.js → health-Ck3J3S9G.js} +1 -1
  55. package/dist/{health-eSKHWC16.js → health-D0w6dKOf.js} +1 -1
  56. package/dist/{hooks-cli-d-CncxOS.js → hooks-cli-6IjNVfwU.js} +3 -3
  57. package/dist/{hooks-cli-1vbVFYX6.js → hooks-cli-qfbN4qHo.js} +3 -3
  58. package/dist/{image-D8b_rlQC.js → image-COw__ACq.js} +1 -1
  59. package/dist/{image-BAsQlUqT.js → image-C_aN5P6-.js} +1 -1
  60. package/dist/index.js +7 -7
  61. package/dist/llm-slug-generator.js +7 -7
  62. package/dist/{models-DRQazay2.js → models-BN3btFZs.js} +2 -2
  63. package/dist/{models-cli-BMU7V_Gq.js → models-cli-BXIQUriJ.js} +3 -3
  64. package/dist/{models-cli-byvFsScd.js → models-cli-D0f0UhCd.js} +4 -4
  65. package/dist/{npm-resolution-CkV9WMS7.js → npm-resolution-CRr1BFy6.js} +1 -1
  66. package/dist/{npm-resolution-ahyNQr7N.js → npm-resolution-DsNHuATZ.js} +1 -1
  67. package/dist/{onboard-3KtofxpB.js → onboard-BGttnPtz.js} +2 -2
  68. package/dist/{onboard-5gLY4vI6.js → onboard-DmJrRFm6.js} +2 -2
  69. package/dist/{onboard-channels-CO3tBBUm.js → onboard-channels-CDDDee0U.js} +1 -1
  70. package/dist/{onboard-channels-BaQef_ik.js → onboard-channels-CPzMyGUw.js} +1 -1
  71. package/dist/{onboarding-oYr_Z-MX.js → onboarding-BH14vh8u.js} +3 -3
  72. package/dist/{onboarding-DT_a9WqK.js → onboarding-CatctZfr.js} +3 -3
  73. package/dist/{onboarding.finalize-DI8RNUCe.js → onboarding.finalize-B1xAj3zP.js} +7 -7
  74. package/dist/{onboarding.finalize-DQlMXUpt.js → onboarding.finalize-y4p-rW_B.js} +6 -6
  75. package/dist/{pi-embedded-dlIKBCVy.js → pi-embedded-BuvTuh5b.js} +46 -27
  76. package/dist/{pi-embedded-B6_XaeGr.js → pi-embedded-LzC2NbjE.js} +46 -27
  77. package/dist/{pi-embedded-helpers-Ct2rwp-P.js → pi-embedded-helpers-C2j0LfJC.js} +4 -4
  78. package/dist/{pi-embedded-helpers-CghCLoPo.js → pi-embedded-helpers-CyTpDKo5.js} +4 -4
  79. package/dist/{plugin-registry-aAygraDx.js → plugin-registry-ChPpKka-.js} +1 -1
  80. package/dist/{plugin-registry-yw2FGDQo.js → plugin-registry-DJWce7ki.js} +1 -1
  81. package/dist/plugin-sdk/{agent-via-gateway-CYQbsoKO.js → agent-via-gateway-CKHwp3jE.js} +2 -2
  82. package/dist/plugin-sdk/{anton-BhaZ-_lE.js → anton-BbSJqBoq.js} +1 -1
  83. package/dist/plugin-sdk/{channel-web-C9WxJKNF.js → channel-web-BpsnbGKO.js} +2 -2
  84. package/dist/plugin-sdk/{deps-DNCcuQw6.js → deps-UrtR_PKP.js} +1 -1
  85. package/dist/plugin-sdk/{emergency-stop-DVA2XPoO.js → emergency-stop-CfIXvAZq.js} +2 -2
  86. package/dist/plugin-sdk/index.js +3 -3
  87. package/dist/plugin-sdk/{reply-DBeDzICx.js → reply-BTeuxXqB.js} +31 -12
  88. package/dist/plugin-sdk/{upgrade-command-C2uWxfO3.js → upgrade-command-DKUGbn8D.js} +3 -3
  89. package/dist/plugin-sdk/{web-BDqEqvD6.js → web-BkoZvzGE.js} +3 -3
  90. package/dist/{plugins-cli-D5iXgZV0.js → plugins-cli-CjrvJnpu.js} +3 -3
  91. package/dist/{plugins-cli-_X7ygx92.js → plugins-cli-D2fnJF9k.js} +3 -3
  92. package/dist/{program-DdvaYjeO.js → program-CA0hdsv9.js} +8 -8
  93. package/dist/{program-context-GHUcW_u0.js → program-context-C4ufrdyk.js} +22 -22
  94. package/dist/{prompt-select-styled-DsfDWex-.js → prompt-select-styled-CoVuIbC6.js} +4 -4
  95. package/dist/{prompt-select-styled-IsBentVx.js → prompt-select-styled-HOmODGGE.js} +4 -4
  96. package/dist/{provider-auth-helpers-DrbsliXm.js → provider-auth-helpers-BcXvA132.js} +1 -1
  97. package/dist/{provider-auth-helpers-DrJAeoq0.js → provider-auth-helpers-CjC0J8wK.js} +1 -1
  98. package/dist/{push-apns-BbrJYz07.js → push-apns-3RpPSOWj.js} +1 -1
  99. package/dist/{push-apns-JodkXySf.js → push-apns-Bqdhr5u5.js} +1 -1
  100. package/dist/{pw-ai-CfYaR1K2.js → pw-ai-CowTfhOG.js} +1 -1
  101. package/dist/{pw-ai-yrIWfcWX.js → pw-ai-DjmrIQle.js} +1 -1
  102. package/dist/{register.agent-CYk5RGin.js → register.agent-C-ynT_r7.js} +8 -8
  103. package/dist/{register.agent-Bv2Q4a7v.js → register.agent-snJhCvJ4.js} +9 -9
  104. package/dist/{register.configure-CKtMVkJ5.js → register.configure-oHPQgac2.js} +8 -8
  105. package/dist/{register.configure-Cnmmqe9t.js → register.configure-sCW4AYHX.js} +8 -8
  106. package/dist/{register.maintenance-BJ18f5vw.js → register.maintenance-BNuu5G8a.js} +9 -9
  107. package/dist/{register.maintenance-irYQ4RHx.js → register.maintenance-DBOmtQ_7.js} +8 -8
  108. package/dist/{register.message-LaE57X6H.js → register.message-CviOQrxd.js} +3 -3
  109. package/dist/{register.message-RUihJQu2.js → register.message-aGnFopBN.js} +3 -3
  110. package/dist/{register.onboard-BbcuO62e.js → register.onboard-5CNO_6MJ.js} +2 -2
  111. package/dist/{register.onboard-5RSmUDC7.js → register.onboard-DldXC3xb.js} +2 -2
  112. package/dist/{register.orchestrator-anton-DJPJSUZJ.js → register.orchestrator-anton-BdD-lYjq.js} +2 -2
  113. package/dist/{register.orchestrator-anton-BtAMVZTG.js → register.orchestrator-anton-Bh-a7hTU.js} +2 -2
  114. package/dist/{register.setup-BAjbcllf.js → register.setup-B5GQC9NR.js} +2 -2
  115. package/dist/{register.setup-B_DYnuvj.js → register.setup-Dtbm5ocC.js} +2 -2
  116. package/dist/{register.status-health-sessions-DoeE4mrI.js → register.status-health-sessions-7LgfFm3K.js} +4 -4
  117. package/dist/{register.status-health-sessions-CyapPo53.js → register.status-health-sessions-DO5z-I1G.js} +4 -4
  118. package/dist/{register.subclis-BHO_F5il.js → register.subclis-WjFoTOYx.js} +13 -13
  119. package/dist/{reply-UTSsx9A5.js → reply-xob39FTF.js} +31 -12
  120. package/dist/{run-main-BcSggHco.js → run-main-BtJbp5Nx.js} +15 -15
  121. package/dist/{runner-PgRFPYUj.js → runner-BzNdfqDz.js} +1 -1
  122. package/dist/{runner-Bv_BA3vd.js → runner-CZW_eyf2.js} +1 -1
  123. package/dist/{server-node-events-Dy9G22Jd.js → server-node-events-BNL7ha1f.js} +3 -3
  124. package/dist/{server-node-events-djWxYbcV.js → server-node-events-lrUnxVTz.js} +3 -3
  125. package/dist/{status-CRW4RVm9.js → status-DLKGKWq_.js} +2 -2
  126. package/dist/{status-DCTlIRAH.js → status-DvdVIssC.js} +2 -2
  127. package/dist/{subagent-registry-BOLFoCi4.js → subagent-registry-C1Xg6P75.js} +31 -12
  128. package/dist/{update-cli-CmbNPprw.js → update-cli-DBsT1H2C.js} +8 -8
  129. package/dist/{update-cli-Cj0Vr_B2.js → update-cli-Dv_xfkAV.js} +9 -9
  130. package/dist/{update-runner-BVl7tNUy.js → update-runner-CYdqDxJL.js} +1 -1
  131. package/dist/{update-runner-DaUhZyT6.js → update-runner-k3nRoLXk.js} +1 -1
  132. package/dist/{upgrade-command-5UDVpXfB.js → upgrade-command-Bh61DpzA.js} +5 -5
  133. package/dist/{upgrade-command-B_OSevDd.js → upgrade-command-Bvrv4iDU.js} +5 -5
  134. package/dist/{upgrade-command-B2yxOLOn.js → upgrade-command-CvbcPPIF.js} +5 -5
  135. package/dist/{upgrade-command-DP6F1cjV.js → upgrade-command-L9y3xbza.js} +5 -5
  136. package/dist/{web-HiM9F0MQ.js → web-B8L46t9i.js} +8 -8
  137. package/dist/{web-3qIgCpGr.js → web-BOZhcGzD.js} +3 -3
  138. package/dist/{web-DSdRgqhB.js → web-C1TtGYq7.js} +8 -8
  139. package/dist/{web-BWvhgqLS.js → web-DqzOqUcK.js} +3 -3
  140. package/package.json +1 -1
@@ -9,7 +9,7 @@ import { a as resolveWhatsAppAuthDir, n as listWhatsAppAccountIds, r as resolveD
9
9
  import { n as resolveDefaultIMessageAccountId, r as resolveIMessageAccount, t as listIMessageAccountIds } from "./accounts-frp6YB8O.js";
10
10
  import { i as resolveSignalAccount, n as listSignalAccountIds, r as resolveDefaultSignalAccountId } from "./accounts-COaz4Gk1.js";
11
11
  import { dt as normalizeDiscordSlug } from "./send-CCiDIuX4.js";
12
- import { Nn as resolveSlackUserAllowlist, Pn as resolveDiscordUserAllowlist, T as resolveDiscordChannelAllowlist, _ as loadIdleHandsPlugins, g as createPluginLoaderLogger, y as resolveSlackChannelAllowlist } from "./subagent-registry-BOLFoCi4.js";
12
+ import { Nn as resolveSlackUserAllowlist, Pn as resolveDiscordUserAllowlist, T as resolveDiscordChannelAllowlist, _ as loadIdleHandsPlugins, g as createPluginLoaderLogger, y as resolveSlackChannelAllowlist } from "./subagent-registry-C1Xg6P75.js";
13
13
  import { a as listChannelPluginCatalogEntries, n as isChannelConfigured } from "./plugin-auto-enable-dpNitoNd.js";
14
14
  import { s as normalizeIMessageHandle } from "./send-YcXS-UZJ.js";
15
15
  import { t as formatDocsLink } from "./links-fKzK3pnZ.js";
@@ -230,7 +230,7 @@ async function runOnboardingWizard(opts, runtime = defaultRuntime, prompter) {
230
230
  const { ensureAuthProfileStore } = await import("./auth-profiles-Baj5ImDJ.js").then((n) => n.t);
231
231
  const { promptAuthChoiceGrouped } = await import("./auth-choice-prompt-kycZqH8q.js").then((n) => n.t);
232
232
  const { promptCustomApiConfig } = await import("./onboard-custom-BjUK6yP5.js").then((n) => n.r);
233
- const { applyAuthChoice, resolvePreferredProviderForAuthChoice, warnIfModelConfigLooksOff } = await import("./auth-choice-BQUQWOPB.js").then((n) => n.t);
233
+ const { applyAuthChoice, resolvePreferredProviderForAuthChoice, warnIfModelConfigLooksOff } = await import("./auth-choice-Cxc76L50.js").then((n) => n.t);
234
234
  const { applyPrimaryModel, promptDefaultModel } = await import("./model-picker-D_yngXMe.js").then((n) => n.i);
235
235
  const authStore = ensureAuthProfileStore(void 0, { allowKeychainPrompt: false });
236
236
  const authChoiceFromPrompt = opts.authChoice === void 0;
@@ -284,7 +284,7 @@ async function runOnboardingWizard(opts, runtime = defaultRuntime, prompter) {
284
284
  if (opts.skipChannels ?? opts.skipProviders) await prompter.note("Skipping channel setup.", "Channels");
285
285
  else {
286
286
  const { listChannelPlugins } = await import("./plugins-CCrfZ49T.js").then((n) => n.i);
287
- const { setupChannels } = await import("./onboard-channels-BaQef_ik.js").then((n) => n.n);
287
+ const { setupChannels } = await import("./onboard-channels-CPzMyGUw.js").then((n) => n.n);
288
288
  const quickstartAllowFromChannels = flow === "quickstart" ? listChannelPlugins().filter((plugin) => plugin.meta.quickstartAllowFrom).map((plugin) => plugin.id) : [];
289
289
  nextConfig = await setupChannels(nextConfig, runtime, prompter, {
290
290
  allowSignalInstall: true,
@@ -310,7 +310,7 @@ async function runOnboardingWizard(opts, runtime = defaultRuntime, prompter) {
310
310
  mode
311
311
  });
312
312
  await writeConfigFile(nextConfig);
313
- const { finalizeOnboardingWizard } = await import("./onboarding.finalize-DI8RNUCe.js");
313
+ const { finalizeOnboardingWizard } = await import("./onboarding.finalize-B1xAj3zP.js");
314
314
  const { launchedTui } = await finalizeOnboardingWizard({
315
315
  flow,
316
316
  opts,
@@ -231,7 +231,7 @@ async function runOnboardingWizard(opts, runtime = defaultRuntime, prompter) {
231
231
  const { ensureAuthProfileStore } = await import("./model-selection-0dGxYGp8.js").then((n) => n.ot);
232
232
  const { promptAuthChoiceGrouped } = await import("./auth-choice-prompt-CiRp6avH.js").then((n) => n.t);
233
233
  const { promptCustomApiConfig } = await import("./onboard-custom-DUbzMMu7.js").then((n) => n.r);
234
- const { applyAuthChoice, resolvePreferredProviderForAuthChoice, warnIfModelConfigLooksOff } = await import("./auth-choice-CNa4gxNm.js").then((n) => n.t);
234
+ const { applyAuthChoice, resolvePreferredProviderForAuthChoice, warnIfModelConfigLooksOff } = await import("./auth-choice-DycYsq6V.js").then((n) => n.t);
235
235
  const { applyPrimaryModel, promptDefaultModel } = await import("./model-picker-BkXoTOiA.js").then((n) => n.i);
236
236
  const authStore = ensureAuthProfileStore(void 0, { allowKeychainPrompt: false });
237
237
  const authChoiceFromPrompt = opts.authChoice === void 0;
@@ -285,7 +285,7 @@ async function runOnboardingWizard(opts, runtime = defaultRuntime, prompter) {
285
285
  if (opts.skipChannels ?? opts.skipProviders) await prompter.note("Skipping channel setup.", "Channels");
286
286
  else {
287
287
  const { listChannelPlugins } = await import("./plugins-D46VZh7u.js").then((n) => n.i);
288
- const { setupChannels } = await import("./onboard-channels-CO3tBBUm.js").then((n) => n.n);
288
+ const { setupChannels } = await import("./onboard-channels-CDDDee0U.js").then((n) => n.n);
289
289
  const quickstartAllowFromChannels = flow === "quickstart" ? listChannelPlugins().filter((plugin) => plugin.meta.quickstartAllowFrom).map((plugin) => plugin.id) : [];
290
290
  nextConfig = await setupChannels(nextConfig, runtime, prompter, {
291
291
  allowSignalInstall: true,
@@ -311,7 +311,7 @@ async function runOnboardingWizard(opts, runtime = defaultRuntime, prompter) {
311
311
  mode
312
312
  });
313
313
  await writeConfigFile(nextConfig);
314
- const { finalizeOnboardingWizard } = await import("./onboarding.finalize-DQlMXUpt.js");
314
+ const { finalizeOnboardingWizard } = await import("./onboarding.finalize-y4p-rW_B.js");
315
315
  const { launchedTui } = await finalizeOnboardingWizard({
316
316
  flow,
317
317
  opts,
@@ -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-BOLFoCi4.js";
29
+ import "./subagent-registry-C1Xg6P75.js";
30
30
  import "./paths-CC17i2eK.js";
31
31
  import "./chat-envelope-Dedaetiq.js";
32
32
  import "./client-Brv1GCwX.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-BuPPEKKU.js";
112
+ import "./deps-ruCIL6tu.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-Dp6wXNs7.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-BaJBGfP6.js";
118
- import "./register.subclis-BHO_F5il.js";
119
- import "./command-registry-Dm6V5xBk.js";
117
+ import { r as installCompletion } from "./completion-cli-CTGLJrsU.js";
118
+ import "./register.subclis-WjFoTOYx.js";
119
+ import "./command-registry-D_coG163.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-eSKHWC16.js";
126
+ import { r as healthCommand } from "./health-D0w6dKOf.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-DA87R6kk.js";
129
+ import { r as ensureCompletionCacheExists, t as checkShellCompletionStatus } from "./doctor-completion-BTK69nw4.js";
130
130
  import { t as runTui } from "./tui-BPgLehyv.js";
131
131
  import os from "node:os";
132
132
  import path from "node:path";
@@ -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-UTSsx9A5.js";
4
+ import "./reply-xob39FTF.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-dk-mZVY7.js";
106
+ import "./deps-DyhYyFzN.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-GHUcW_u0.js";
120
+ import "./program-context-C4ufrdyk.js";
121
121
  import "./note-69EfBEU-.js";
122
- import { r as installCompletion } from "./completion-cli-DnvwEZHv.js";
122
+ import { r as installCompletion } from "./completion-cli-CAERO_KP.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--cNlCqAN.js";
127
+ import { r as healthCommand } from "./health-Ck3J3S9G.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-DHYMwPxZ.js";
130
+ import { r as ensureCompletionCacheExists, t as checkShellCompletionStatus } from "./doctor-completion-C4IaYTpf.js";
131
131
  import { t as runTui } from "./tui-lalhRHve.js";
132
132
  import os from "node:os";
133
133
  import path from "node:path";
@@ -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-Crf9tOgB.js";
78
+ import { r as createOutboundSendDepsFromCliSource, t as createDefaultDeps } from "./deps-DMIwjElF.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";
@@ -6374,7 +6374,7 @@ var GatewayClient = class {
6374
6374
  if (fingerprint !== expected) return /* @__PURE__ */ new Error("gateway tls fingerprint mismatch");
6375
6375
  });
6376
6376
  }
6377
- this.ws = new WebSocket(url, wsOptions);
6377
+ this.ws = new WebSocket$1(url, wsOptions);
6378
6378
  this.ws.on("open", () => {
6379
6379
  if (url.startsWith("wss://") && this.opts.tlsFingerprint) {
6380
6380
  const tlsError = this.validateTlsFingerprint();
@@ -6570,7 +6570,7 @@ var GatewayClient = class {
6570
6570
  const connectChallengeTimeoutMs = typeof rawConnectDelayMs === "number" && Number.isFinite(rawConnectDelayMs) ? Math.max(250, Math.min(1e4, rawConnectDelayMs)) : 2e3;
6571
6571
  if (this.connectTimer) clearTimeout(this.connectTimer);
6572
6572
  this.connectTimer = setTimeout(() => {
6573
- if (this.connectSent || this.ws?.readyState !== WebSocket.OPEN) return;
6573
+ if (this.connectSent || this.ws?.readyState !== WebSocket$1.OPEN) return;
6574
6574
  this.opts.onConnectError?.(/* @__PURE__ */ new Error("gateway connect challenge timeout"));
6575
6575
  this.ws?.close(1008, "connect challenge timeout");
6576
6576
  }, connectChallengeTimeoutMs);
@@ -6612,7 +6612,7 @@ var GatewayClient = class {
6612
6612
  return null;
6613
6613
  }
6614
6614
  async request(method, params, opts) {
6615
- if (!this.ws || this.ws.readyState !== WebSocket.OPEN) throw new Error("gateway not connected");
6615
+ if (!this.ws || this.ws.readyState !== WebSocket$1.OPEN) throw new Error("gateway not connected");
6616
6616
  const id = randomUUID();
6617
6617
  const frame = {
6618
6618
  type: "req",
@@ -7936,7 +7936,7 @@ async function routeReply(params) {
7936
7936
  const resolvedReplyToId = replyToId ?? (channelId === "slack" && threadId != null && threadId !== "" ? String(threadId) : void 0);
7937
7937
  const resolvedThreadId = channelId === "slack" ? null : threadId ?? null;
7938
7938
  try {
7939
- const { deliverOutboundPayloads } = await import("./deliver-BUiQ-9fE.js").then((n) => n.n);
7939
+ const { deliverOutboundPayloads } = await import("./deliver-CVTXl0Cv.js").then((n) => n.n);
7940
7940
  const outboundSession = buildOutboundSessionContext({
7941
7941
  cfg,
7942
7942
  agentId: resolvedAgentId,
@@ -23061,7 +23061,7 @@ const handleAntonCommand = async (params, _allowTextCommands) => {
23061
23061
  };
23062
23062
  const arg = body.slice(6).trim();
23063
23063
  if (arg === "status" || arg === "") {
23064
- const { antonStatus } = await import("./anton-Cso65xsA.js");
23064
+ const { antonStatus } = await import("./anton-y_9cmetd.js");
23065
23065
  const lines = [];
23066
23066
  await antonStatus({
23067
23067
  log: (msg) => lines.push(msg),
@@ -23077,7 +23077,7 @@ const handleAntonCommand = async (params, _allowTextCommands) => {
23077
23077
  return { shouldContinue: false };
23078
23078
  }
23079
23079
  if (arg === "stop") {
23080
- const { antonStop } = await import("./anton-Cso65xsA.js");
23080
+ const { antonStop } = await import("./anton-y_9cmetd.js");
23081
23081
  const lines = [];
23082
23082
  await antonStop({
23083
23083
  log: (msg) => lines.push(msg),
@@ -23115,8 +23115,8 @@ const handleAntonCommand = async (params, _allowTextCommands) => {
23115
23115
  await sendProgress(replyCtx, text);
23116
23116
  return { shouldContinue: false };
23117
23117
  }
23118
- const { runAnton, formatProgressMessage } = await import("./anton-Cso65xsA.js");
23119
- const { createDefaultDeps } = await import("./deps-Crf9tOgB.js").then((n) => n.n);
23118
+ const { runAnton, formatProgressMessage } = await import("./anton-y_9cmetd.js");
23119
+ const { createDefaultDeps } = await import("./deps-DMIwjElF.js").then((n) => n.n);
23120
23120
  const { createNonExitingRuntime } = await import("./runtime-8mi3mpYB.js").then((n) => n.r);
23121
23121
  const runtime = createNonExitingRuntime();
23122
23122
  const deps = createDefaultDeps();
@@ -29223,7 +29223,7 @@ const handleTtsCommands = async (params, allowTextCommands) => {
29223
29223
  const handleUpgradeCommand = async (params, _allowTextCommands) => {
29224
29224
  if (!params.command.commandBodyNormalized.startsWith("/upgrade")) return null;
29225
29225
  if (!params.command.isAuthorizedSender) return { shouldContinue: false };
29226
- const { performBotUpgrade } = await import("./upgrade-command-B2yxOLOn.js");
29226
+ const { performBotUpgrade } = await import("./upgrade-command-Bvrv4iDU.js");
29227
29227
  const channel = params.ctx.OriginatingChannel ?? params.command.channel;
29228
29228
  const to = params.ctx.OriginatingTo ?? params.command.from ?? params.command.to ?? "";
29229
29229
  await routeReply({
@@ -43684,6 +43684,21 @@ async function handleInlineActions(params) {
43684
43684
  reply: commandResult.reply
43685
43685
  };
43686
43686
  }
43687
+ const simpleBody = cleanedBody.trim().toLowerCase();
43688
+ if ([
43689
+ "hi",
43690
+ "hello",
43691
+ "hey",
43692
+ "yo",
43693
+ "sup",
43694
+ "hola"
43695
+ ].includes(simpleBody)) {
43696
+ typing.cleanup();
43697
+ return {
43698
+ kind: "reply",
43699
+ reply: { text: "Hey 👋 I’m here. What do you want to work on?" }
43700
+ };
43701
+ }
43687
43702
  return {
43688
43703
  kind: "continue",
43689
43704
  directives,
@@ -47121,6 +47136,10 @@ async function runPreparedReply(params) {
47121
47136
  defaultProvider,
47122
47137
  defaultModel
47123
47138
  });
47139
+ if (isBareSessionReset) {
47140
+ typing.cleanup();
47141
+ return;
47142
+ }
47124
47143
  const sessionIdFinal = sessionId ?? crypto.randomUUID();
47125
47144
  const sessionFile = resolveSessionFilePath(sessionIdFinal, sessionEntry, resolveSessionFilePathOptions({
47126
47145
  agentId,
@@ -47409,7 +47428,7 @@ async function deliverSessionMaintenanceWarning(params) {
47409
47428
  return;
47410
47429
  }
47411
47430
  try {
47412
- const { deliverOutboundPayloads } = await import("./deliver-BUiQ-9fE.js").then((n) => n.n);
47431
+ const { deliverOutboundPayloads } = await import("./deliver-CVTXl0Cv.js").then((n) => n.n);
47413
47432
  const outboundSession = buildOutboundSessionContext({
47414
47433
  cfg: params.cfg,
47415
47434
  sessionKey: params.sessionKey
@@ -51845,7 +51864,7 @@ async function describeStickerImage(params) {
51845
51864
  logVerbose(`telegram: describing sticker with ${provider}/${model}`);
51846
51865
  try {
51847
51866
  const buffer = await fs.readFile(imagePath);
51848
- const { describeImageWithModel } = await import("./image-D8b_rlQC.js").then((n) => n.n);
51867
+ const { describeImageWithModel } = await import("./image-COw__ACq.js").then((n) => n.n);
51849
51868
  return (await describeImageWithModel({
51850
51869
  buffer,
51851
51870
  fileName: "sticker.webp",
@@ -54773,7 +54792,7 @@ async function preflightDiscordMessage(params) {
54773
54792
  let preflightTranscript;
54774
54793
  const hasAudioAttachment = message.attachments?.some((att) => att.contentType?.startsWith("audio/"));
54775
54794
  if (!isDirectMessage && shouldRequireMention && hasAudioAttachment && !baseText && mentionRegexes.length > 0) try {
54776
- const { transcribeFirstAudio } = await import("./audio-preflight-CW8IH1lU.js");
54795
+ const { transcribeFirstAudio } = await import("./audio-preflight-BSlR2jEq.js");
54777
54796
  const audioPaths = message.attachments?.filter((att) => att.contentType?.startsWith("audio/")).map((att) => att.url) ?? [];
54778
54797
  if (audioPaths.length > 0) preflightTranscript = await transcribeFirstAudio({
54779
54798
  ctx: {
@@ -57250,7 +57269,7 @@ function createDiscordMessageHandler(params) {
57250
57269
  try {
57251
57270
  const messageText = resolveDiscordMessageText(data.message)?.trim();
57252
57271
  if (messageText) {
57253
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-DqK6Iaxy.js");
57272
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-BFA2JE99.js");
57254
57273
  if (isAbortRequestText(messageText)) {
57255
57274
  const { resolveAgentRoute } = await import("./resolve-route-DuttYY7A.js").then((n) => n.r);
57256
57275
  const channelId = resolveDiscordMessageChannelId({
@@ -62696,7 +62715,7 @@ function createDiscordGatewayPlugin(params) {
62696
62715
  return super.registerClient(client);
62697
62716
  }
62698
62717
  createWebSocket(url) {
62699
- return new WebSocket$1(url, { agent: wsAgent });
62718
+ return new WebSocket(url, { agent: wsAgent });
62700
62719
  }
62701
62720
  }
62702
62721
  return new ProxyGatewayPlugin();
@@ -64748,7 +64767,7 @@ async function monitorIMessageProvider(opts = {}) {
64748
64767
  }
64749
64768
  const msgText = (message.text ?? "").trim();
64750
64769
  if (msgText) {
64751
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-DqK6Iaxy.js");
64770
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-BFA2JE99.js");
64752
64771
  if (isAbortRequestText(msgText)) {
64753
64772
  const { resolveAgentRoute } = await import("./resolve-route-DuttYY7A.js").then((n) => n.r);
64754
64773
  const route = resolveAgentRoute({
@@ -67359,7 +67378,7 @@ function createSignalEventHandler(deps) {
67359
67378
  const senderName = envelope.sourceName ?? senderDisplay;
67360
67379
  const messageId = typeof envelope.timestamp === "number" ? String(envelope.timestamp) : void 0;
67361
67380
  if (bodyText) {
67362
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-DqK6Iaxy.js");
67381
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-BFA2JE99.js");
67363
67382
  if (isAbortRequestText(bodyText)) {
67364
67383
  const { resolveAgentRoute } = await import("./resolve-route-DuttYY7A.js").then((n) => n.r);
67365
67384
  const route = resolveAgentRoute({
@@ -70741,7 +70760,7 @@ function createSlackMessageHandler(params) {
70741
70760
  if (ctx.markMessageSeen(message.channel, message.ts)) return;
70742
70761
  const rawText = (message.text ?? "").trim();
70743
70762
  if (rawText) {
70744
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-DqK6Iaxy.js");
70763
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-BFA2JE99.js");
70745
70764
  if (isAbortRequestText(rawText)) {
70746
70765
  const { resolveAgentRoute } = await import("./resolve-route-DuttYY7A.js").then((n) => n.r);
70747
70766
  const route = resolveAgentRoute({
@@ -72935,7 +72954,7 @@ const registerTelegramHandlers = ({ cfg, accountId, bot, opts, runtime, mediaMax
72935
72954
  const { ctx, msg, chatId, resolvedThreadId, storeAllowFrom, sendOversizeWarning, oversizeLogMessage } = params;
72936
72955
  const text = typeof msg.text === "string" ? msg.text : void 0;
72937
72956
  if (text) {
72938
- const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-DqK6Iaxy.js");
72957
+ const { isAbortRequestText, emergencyStop, resolveSessionForEmergencyStop } = await import("./emergency-stop-BFA2JE99.js");
72939
72958
  if (isAbortRequestText(text)) {
72940
72959
  const senderId = msg.from?.id ? String(msg.from.id) : "";
72941
72960
  if (!senderId || !allowFrom?.length || allowFrom.includes(senderId)) {
@@ -73822,7 +73841,7 @@ const buildTelegramMessageContext = async ({ primaryCtx, allMedia, replyMedia =
73822
73841
  const hasAudio = allMedia.some((media) => media.contentType?.startsWith("audio/"));
73823
73842
  let preflightTranscript;
73824
73843
  if (isGroup && requireMention && hasAudio && !hasUserText && mentionRegexes.length > 0) try {
73825
- const { transcribeFirstAudio } = await import("./audio-preflight-CW8IH1lU.js");
73844
+ const { transcribeFirstAudio } = await import("./audio-preflight-BSlR2jEq.js");
73826
73845
  preflightTranscript = await transcribeFirstAudio({
73827
73846
  ctx: {
73828
73847
  MediaPaths: allMedia.length > 0 ? allMedia.map((m) => m.path) : void 0,
@@ -76420,7 +76439,7 @@ function loadWebLoginQr() {
76420
76439
  return webLoginQrPromise;
76421
76440
  }
76422
76441
  function loadWebChannel() {
76423
- webChannelPromise ??= import("./web-DSdRgqhB.js");
76442
+ webChannelPromise ??= import("./web-C1TtGYq7.js");
76424
76443
  return webChannelPromise;
76425
76444
  }
76426
76445
  function loadWhatsAppActions() {