openclaw-multi-auto 1.6.2 → 1.6.6

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 (182) hide show
  1. package/dist/{accounts-L9ByEpnP.js → accounts-C9HcPI9h.js} +2 -2
  2. package/dist/{accounts-BOzyfwW4.js → accounts-C_lW3Ag9.js} +2 -2
  3. package/dist/{accounts-yfBeCZtS.js → accounts-Tgelvk0C.js} +17 -17
  4. package/dist/{active-listener-D1yqT1cw.js → active-listener-BEdprTkn.js} +2 -2
  5. package/dist/{api-key-rotation-DtsNS2Nb.js → api-key-rotation-BJpKWXy0.js} +2 -2
  6. package/dist/{audio-preflight-DoPfNXDz.js → audio-preflight-BMvgEQ5j.js} +32 -32
  7. package/dist/{audio-transcription-runner-CzjuH3uL.js → audio-transcription-runner-gLFfz8fr.js} +12 -12
  8. package/dist/{audit-membership-runtime-DWyHWAHM.js → audit-membership-runtime-Dntemq07.js} +4 -4
  9. package/dist/build-info.json +3 -3
  10. package/dist/bundled/boot-md/handler.js +51 -51
  11. package/dist/bundled/bootstrap-extra-files/handler.js +6 -6
  12. package/dist/bundled/command-logger/handler.js +2 -2
  13. package/dist/bundled/session-memory/handler.js +51 -51
  14. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  15. package/dist/{channel-activity-xHOMiarp.js → channel-activity-BDnjYF7B.js} +3 -3
  16. package/dist/{chrome-DlhJHqj8.js → chrome-DxxEKrY7.js} +26 -26
  17. package/dist/{commands-registry-V1zZ5pPC.js → commands-registry-D5qXbFJn.js} +4 -4
  18. package/dist/{deliver-CApVJA_l.js → deliver-DbdywYJE.js} +21 -21
  19. package/dist/deliver-runtime-BFs7iAZF.js +36 -0
  20. package/dist/deps-send-discord.runtime-DZUccI6Z.js +26 -0
  21. package/dist/deps-send-imessage.runtime-CF3OpoqY.js +25 -0
  22. package/dist/deps-send-signal.runtime-Cw4-ozeO.js +24 -0
  23. package/dist/deps-send-slack.runtime-BDsDhS1P.js +22 -0
  24. package/dist/deps-send-telegram.runtime-D_4xVasO.js +27 -0
  25. package/dist/deps-send-whatsapp.runtime-DK8jqd14.js +60 -0
  26. package/dist/{diagnostic-Bn4PZjMZ.js → diagnostic-Co6Kghr-.js} +2 -2
  27. package/dist/{errors-CCLeFWAg.js → errors-xt401nuk.js} +1 -1
  28. package/dist/{fetch-BlJWzEP6.js → fetch-DuraYswo.js} +5 -5
  29. package/dist/{fetch-guard-ChYBwfiy.js → fetch-guard-DWr0d00H.js} +2 -2
  30. package/dist/{frontmatter-CvaMP376.js → frontmatter-BkTfEZ93.js} +3 -3
  31. package/dist/{fs-safe-0jAo_Whb.js → fs-safe-CTYUrIgQ.js} +4 -4
  32. package/dist/{github-copilot-token-D13V9YBz.js → github-copilot-token-BDioPmd6.js} +7 -7
  33. package/dist/{image-B3Mz7N5I.js → image-eT7Y-nP5.js} +6 -6
  34. package/dist/{image-ops-CehkHxmW.js → image-ops-BuUnEOE0.js} +2 -2
  35. package/dist/image-runtime-BcAK3n8a.js +29 -0
  36. package/dist/{ir-DAP-B-Xw.js → ir-B83looB-.js} +8 -8
  37. package/dist/{legacy-names-TyzbVqa_.js → legacy-names-DOC03BkU.js} +1 -1
  38. package/dist/llm-slug-generator.js +51 -51
  39. package/dist/{logger-DMZQQtxK.js → logger-BfjWMCSD.js} +7 -7
  40. package/dist/{login-DiCctRo1.js → login-CrIwcrVI.js} +5 -5
  41. package/dist/{login-qr-MUbXgjtd.js → login-qr-BpPDZdl_.js} +10 -10
  42. package/dist/{manager-BW_NSIMl.js → manager-1bvuGrNR.js} +13 -13
  43. package/dist/manager-runtime-FO1Sx3W8.js +18 -0
  44. package/dist/{model-selection-idoqPmw0.js → model-selection-Dna0Gz1k.js} +43 -43
  45. package/dist/{outbound-C2kanETZ.js → outbound-ChDjtuD6.js} +6 -6
  46. package/dist/{outbound-attachment-DBrYWX8h.js → outbound-attachment-DqHlD21U.js} +2 -2
  47. package/dist/{path-alias-guards-DqXRZmsL.js → path-alias-guards-BzvdLvTI.js} +1 -1
  48. package/dist/{paths-CCxysrzL.js → paths-Bkr-BCxW.js} +4 -4
  49. package/dist/{paths-C6TxBCvO.js → paths-Cvc9EM8Y.js} +5 -5
  50. package/dist/{pi-embedded-bcjMe3wj.js → pi-embedded-BQQa91aA.js} +167 -167
  51. package/dist/{pi-embedded-helpers-D5yyGEvA.js → pi-embedded-helpers-CLXm10bV.js} +52 -52
  52. package/dist/{plugin-sdk/pi-model-discovery-v-XPUOOf.js → pi-model-discovery-Dymwdjt0.js} +2 -2
  53. package/dist/pi-model-discovery-runtime-BeY4EUPp.js +11 -0
  54. package/dist/{pi-tools.before-tool-call.runtime-BuLxSyx9.js → pi-tools.before-tool-call.runtime-Cwab_5W1.js} +9 -9
  55. package/dist/plugin-sdk/compat.js +50 -50
  56. package/dist/plugin-sdk/discord.js +6 -6
  57. package/dist/plugin-sdk/slack.js +2 -2
  58. package/dist/{plugins-CWkRQYDj.js → plugins-4Rj4OjLY.js} +11 -11
  59. package/dist/{proxy-env-Cq5gdrbj.js → proxy-env-DlmzDx8x.js} +1 -1
  60. package/dist/{proxy-fetch-CCjEYbFm.js → proxy-fetch-B2pEfjbR.js} +1 -1
  61. package/dist/{pw-ai-CDQDCfUa.js → pw-ai-DNMjFMqH.js} +14 -14
  62. package/dist/{qmd-manager-BsYsO9Ii.js → qmd-manager-BtIKUaO9.js} +10 -10
  63. package/dist/{query-expansion-DtLc3wjL.js → query-expansion-CX-1fS52.js} +6 -6
  64. package/dist/{plugin-sdk/redact-DjVX-1N3.js → redact-COik8ET1.js} +1 -1
  65. package/dist/{run-with-concurrency-D_ZpbgEG.js → run-with-concurrency-BgYfgkXT.js} +4 -4
  66. package/dist/runtime-whatsapp-login.runtime-DUb55byQ.js +13 -0
  67. package/dist/runtime-whatsapp-outbound.runtime-Bii_xSfI.js +22 -0
  68. package/dist/{send-Dx2RkUOZ.js → send-6lz6rNVP.js} +6 -6
  69. package/dist/{send-vmONuVgL.js → send-BHTiZcH3.js} +26 -26
  70. package/dist/{send-Bj776ESJ.js → send-L7gRiwyd.js} +7 -7
  71. package/dist/{send-DcxmcFi_.js → send-PE6cwoTe.js} +8 -8
  72. package/dist/{send-BQERFNyo.js → send-dfu6_rgf.js} +5 -5
  73. package/dist/{session-A4QhBRvH.js → session-D8ImowSs.js} +8 -8
  74. package/dist/{skill-commands-CMzBZKG2.js → skill-commands-DNqJ-kwn.js} +9 -9
  75. package/dist/{skills-CE_iqvM5.js → skills-7ODkHQYp.js} +22 -22
  76. package/dist/slash-commands.runtime-CVw6566g.js +16 -0
  77. package/dist/slash-dispatch.runtime-B9Ygtzi4.js +56 -0
  78. package/dist/slash-skill-commands.runtime-DxZ4z5h6.js +20 -0
  79. package/dist/{store--eR1R_UX.js → store-D89wDcz9.js} +2 -2
  80. package/dist/subagent-registry-runtime-DL1Wv7nA.js +56 -0
  81. package/dist/{subsystem-Di1z8l0Z.js → subsystem-B45WV3qB.js} +14 -14
  82. package/dist/{tables-d739Y1xW.js → tables-mE4cJBN2.js} +1 -1
  83. package/dist/{plugin-sdk/target-errors-Blia4S69.js → target-errors-mnlwhAjP.js} +2 -2
  84. package/dist/{thinking-DXYisHiZ.js → thinking-BeGmb5k6.js} +7 -7
  85. package/dist/{tokens-DxnY9ui_.js → tokens-q32vI39c.js} +1 -1
  86. package/dist/{tool-images-2cBx1W8h.js → tool-images-RZdHiZcG.js} +2 -2
  87. package/dist/{web-NWKn8ABz.js → web-Btj-e8kN.js} +55 -55
  88. package/dist/{whatsapp-actions-iEArE_Ez.js → whatsapp-actions-BHbJJyqw.js} +21 -21
  89. package/dist/{workspace-CUVC6GX1.js → workspace-U-DyR64O.js} +20 -20
  90. package/package.json +1 -1
  91. package/scripts/create-instance.sh +93 -96
  92. package/dist/deliver-runtime-D1z-h5eg.js +0 -36
  93. package/dist/deps-send-discord.runtime-DnbhTFX9.js +0 -26
  94. package/dist/deps-send-imessage.runtime-BOiQ6mDx.js +0 -25
  95. package/dist/deps-send-signal.runtime-CTcl388M.js +0 -24
  96. package/dist/deps-send-slack.runtime-CCqBz4Kg.js +0 -22
  97. package/dist/deps-send-telegram.runtime-DGSKTCpH.js +0 -27
  98. package/dist/deps-send-whatsapp.runtime-Dz_4fi2D.js +0 -60
  99. package/dist/image-runtime-DWjhow2W.js +0 -29
  100. package/dist/manager-runtime-BN6VevdC.js +0 -18
  101. package/dist/pi-model-discovery-BGgOlX8N.js +0 -134
  102. package/dist/pi-model-discovery-runtime-Bwmi4Ev8.js +0 -11
  103. package/dist/plugin-sdk/accounts-CJWOBzwB.js +0 -35
  104. package/dist/plugin-sdk/accounts-DP1-L-QS.js +0 -288
  105. package/dist/plugin-sdk/accounts-DZhWlEg3.js +0 -46
  106. package/dist/plugin-sdk/active-listener-B_sLJTXM.js +0 -50
  107. package/dist/plugin-sdk/api-key-rotation-BRE4X2tf.js +0 -181
  108. package/dist/plugin-sdk/audio-preflight-DGEUDxxR.js +0 -69
  109. package/dist/plugin-sdk/audio-transcription-runner-DkoPNPYt.js +0 -2176
  110. package/dist/plugin-sdk/audit-membership-runtime-DSBHHw7o.js +0 -58
  111. package/dist/plugin-sdk/channel-activity-F3d0yUwy.js +0 -94
  112. package/dist/plugin-sdk/channel-web-QF7EpjeP.js +0 -2256
  113. package/dist/plugin-sdk/chrome-BXoCyCkY.js +0 -2415
  114. package/dist/plugin-sdk/commands-registry-t7cXBTfN.js +0 -1125
  115. package/dist/plugin-sdk/config-BkEnz2Po.js +0 -17913
  116. package/dist/plugin-sdk/deliver-B6AG_l67.js +0 -1694
  117. package/dist/plugin-sdk/deliver-runtime-D585kJZc.js +0 -32
  118. package/dist/plugin-sdk/deps-send-discord.runtime-a_OKY2js.js +0 -23
  119. package/dist/plugin-sdk/deps-send-imessage.runtime-Baxy9TD4.js +0 -22
  120. package/dist/plugin-sdk/deps-send-signal.runtime-BwXoCrFl.js +0 -21
  121. package/dist/plugin-sdk/deps-send-slack.runtime-CLmKjgso.js +0 -19
  122. package/dist/plugin-sdk/deps-send-telegram.runtime-BKfdBKnZ.js +0 -24
  123. package/dist/plugin-sdk/deps-send-whatsapp.runtime-BOTwkbx_.js +0 -57
  124. package/dist/plugin-sdk/diagnostic-CsP-lEkI.js +0 -319
  125. package/dist/plugin-sdk/errors-DaiAM-yU.js +0 -54
  126. package/dist/plugin-sdk/fetch-guard-DETCcJzQ.js +0 -156
  127. package/dist/plugin-sdk/fs-safe-B8y811FR.js +0 -352
  128. package/dist/plugin-sdk/image-DjTEkYZE.js +0 -2310
  129. package/dist/plugin-sdk/image-ops-BSiMpAw4.js +0 -584
  130. package/dist/plugin-sdk/image-runtime-6xPp8m5a.js +0 -25
  131. package/dist/plugin-sdk/ir-DQ7_HbvK.js +0 -1296
  132. package/dist/plugin-sdk/local-roots-BUP4YBmR.js +0 -186
  133. package/dist/plugin-sdk/logger-CZY9KIoY.js +0 -1163
  134. package/dist/plugin-sdk/login-BxEKLlCo.js +0 -57
  135. package/dist/plugin-sdk/login-qr-BQIpMPr9.js +0 -320
  136. package/dist/plugin-sdk/manager-I6KbPihW.js +0 -3917
  137. package/dist/plugin-sdk/manager-runtime-CFfYYWIQ.js +0 -15
  138. package/dist/plugin-sdk/outbound-NS6UHnB6.js +0 -212
  139. package/dist/plugin-sdk/outbound-attachment-Dy6fyf6H.js +0 -19
  140. package/dist/plugin-sdk/path-alias-guards-DBjLbIX_.js +0 -43
  141. package/dist/plugin-sdk/paths-vTM3Lh3X.js +0 -166
  142. package/dist/plugin-sdk/pi-embedded-helpers-1R1gu7eX.js +0 -9627
  143. package/dist/plugin-sdk/pi-model-discovery-runtime-Do9o-dUd.js +0 -8
  144. package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-D4sFsIks.js +0 -354
  145. package/dist/plugin-sdk/plugins-DeBZB9l_.js +0 -864
  146. package/dist/plugin-sdk/proxy-fetch-ChxOhWF4.js +0 -38
  147. package/dist/plugin-sdk/pw-ai-DEOmCSSC.js +0 -1938
  148. package/dist/plugin-sdk/qmd-manager-HyYKoEch.js +0 -1448
  149. package/dist/plugin-sdk/query-expansion-CeyKUeDW.js +0 -1011
  150. package/dist/plugin-sdk/reply-DAo_Jt8K.js +0 -97916
  151. package/dist/plugin-sdk/resolve-outbound-target-B42qgQS9.js +0 -40
  152. package/dist/plugin-sdk/run-with-concurrency-Bt_ks0Qa.js +0 -1994
  153. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-B6W989eF.js +0 -10
  154. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-c_GDFy37.js +0 -19
  155. package/dist/plugin-sdk/send-CQpMudwO.js +0 -2587
  156. package/dist/plugin-sdk/send-DQHLzVyO.js +0 -414
  157. package/dist/plugin-sdk/send-DTB24bEF.js +0 -3135
  158. package/dist/plugin-sdk/send-DfHadjZ_.js +0 -503
  159. package/dist/plugin-sdk/send-XXlW2iny.js +0 -540
  160. package/dist/plugin-sdk/session-6TF6MyaC.js +0 -169
  161. package/dist/plugin-sdk/skill-commands-CkGeFUMl.js +0 -342
  162. package/dist/plugin-sdk/skills-CBkHBYPq.js +0 -1428
  163. package/dist/plugin-sdk/slash-commands.runtime-CxliuGaP.js +0 -13
  164. package/dist/plugin-sdk/slash-dispatch.runtime-DFaeYlJQ.js +0 -52
  165. package/dist/plugin-sdk/slash-skill-commands.runtime-0M0OLCxq.js +0 -16
  166. package/dist/plugin-sdk/ssrf-cFtplYtS.js +0 -202
  167. package/dist/plugin-sdk/store-5nyxY3WU.js +0 -81
  168. package/dist/plugin-sdk/subagent-registry-runtime-DCtmDwna.js +0 -52
  169. package/dist/plugin-sdk/tables-C47P4GTN.js +0 -55
  170. package/dist/plugin-sdk/thinking-Bo2eosVa.js +0 -1206
  171. package/dist/plugin-sdk/tokens-DgNRBwIg.js +0 -52
  172. package/dist/plugin-sdk/tool-images-Gk_-0y2N.js +0 -274
  173. package/dist/plugin-sdk/web-CVxZbXyH.js +0 -56
  174. package/dist/plugin-sdk/whatsapp-actions-Bw0H9g-n.js +0 -80
  175. package/dist/redact-ClbcYG1J.js +0 -319
  176. package/dist/runtime-whatsapp-login.runtime-IeylZEl4.js +0 -13
  177. package/dist/runtime-whatsapp-outbound.runtime-ClBRuLsq.js +0 -22
  178. package/dist/slash-commands.runtime-Cpn2tYW4.js +0 -16
  179. package/dist/slash-dispatch.runtime-CWbpp23S.js +0 -56
  180. package/dist/slash-skill-commands.runtime-DKMvvdDW.js +0 -20
  181. package/dist/subagent-registry-runtime-DEVpAaAP.js +0 -56
  182. package/dist/target-errors-CBI2Ga0y.js +0 -195
@@ -1,13 +0,0 @@
1
- import "./run-with-concurrency-Bt_ks0Qa.js";
2
- import "./accounts-DP1-L-QS.js";
3
- import "./paths-MKyEVmEb.js";
4
- import "./github-copilot-token-D5fdS6xD.js";
5
- import "./config-BkEnz2Po.js";
6
- import "./logger-CZY9KIoY.js";
7
- import "./thinking-Bo2eosVa.js";
8
- import "./plugins-DeBZB9l_.js";
9
- import "./accounts-CJWOBzwB.js";
10
- import "./accounts-DZhWlEg3.js";
11
- import { f as resolveCommandArgMenu, n as findCommandByNativeName, s as listNativeCommandSpecsForConfig, t as buildCommandTextFromArgs, u as parseCommandArgs } from "./commands-registry-t7cXBTfN.js";
12
-
13
- export { buildCommandTextFromArgs, findCommandByNativeName, listNativeCommandSpecsForConfig, parseCommandArgs, resolveCommandArgMenu };
@@ -1,52 +0,0 @@
1
- import "./run-with-concurrency-Bt_ks0Qa.js";
2
- import "./accounts-DP1-L-QS.js";
3
- import { N as finalizeInboundContext, X as createReplyPrefixOptions, a as deliverSlackSlashReplies, m as dispatchReplyWithDispatcher, n as recordInboundSessionMetaSafe, v as resolveAgentRoute } from "./reply-DAo_Jt8K.js";
4
- import "./paths-MKyEVmEb.js";
5
- import "./github-copilot-token-D5fdS6xD.js";
6
- import "./config-BkEnz2Po.js";
7
- import "./logger-CZY9KIoY.js";
8
- import "./thinking-Bo2eosVa.js";
9
- import "./image-ops-BSiMpAw4.js";
10
- import { rn as resolveConversationLabel } from "./pi-embedded-helpers-1R1gu7eX.js";
11
- import "./plugins-DeBZB9l_.js";
12
- import "./accounts-CJWOBzwB.js";
13
- import "./accounts-DZhWlEg3.js";
14
- import "./send-DTB24bEF.js";
15
- import "./paths-vTM3Lh3X.js";
16
- import "./fetch-Bv4TQOMH.js";
17
- import "./redact-DjVX-1N3.js";
18
- import "./errors-DaiAM-yU.js";
19
- import "./channel-activity-F3d0yUwy.js";
20
- import "./path-alias-guards-DBjLbIX_.js";
21
- import "./fs-safe-B8y811FR.js";
22
- import "./ssrf-cFtplYtS.js";
23
- import "./fetch-guard-DETCcJzQ.js";
24
- import "./local-roots-BUP4YBmR.js";
25
- import { d as resolveChunkMode, i as resolveMarkdownTableMode } from "./ir-DQ7_HbvK.js";
26
- import "./render-HmipMDlP.js";
27
- import "./tables-C47P4GTN.js";
28
- import "./send-DfHadjZ_.js";
29
- import "./send-CQpMudwO.js";
30
- import "./tool-images-Gk_-0y2N.js";
31
- import "./target-errors-Blia4S69.js";
32
- import "./send-DQHLzVyO.js";
33
- import "./audio-transcription-runner-DkoPNPYt.js";
34
- import "./tokens-DgNRBwIg.js";
35
- import "./skill-commands-CkGeFUMl.js";
36
- import "./skills-CBkHBYPq.js";
37
- import "./chrome-BXoCyCkY.js";
38
- import "./deliver-B6AG_l67.js";
39
- import "./diagnostic-CsP-lEkI.js";
40
- import "./store-5nyxY3WU.js";
41
- import "./commands-registry-t7cXBTfN.js";
42
- import "./image-DjTEkYZE.js";
43
- import "./api-key-rotation-BRE4X2tf.js";
44
- import "./proxy-fetch-ChxOhWF4.js";
45
- import "./pi-model-discovery-v-XPUOOf.js";
46
- import "./send-XXlW2iny.js";
47
- import "./outbound-attachment-Dy6fyf6H.js";
48
- import "./proxy-BKdNrmWL.js";
49
- import "./manager-I6KbPihW.js";
50
- import "./query-expansion-CeyKUeDW.js";
51
-
52
- export { createReplyPrefixOptions, deliverSlackSlashReplies, dispatchReplyWithDispatcher, finalizeInboundContext, recordInboundSessionMetaSafe, resolveAgentRoute, resolveChunkMode, resolveConversationLabel, resolveMarkdownTableMode };
@@ -1,16 +0,0 @@
1
- import "./run-with-concurrency-Bt_ks0Qa.js";
2
- import "./accounts-DP1-L-QS.js";
3
- import "./paths-MKyEVmEb.js";
4
- import "./github-copilot-token-D5fdS6xD.js";
5
- import "./config-BkEnz2Po.js";
6
- import "./logger-CZY9KIoY.js";
7
- import "./thinking-Bo2eosVa.js";
8
- import "./plugins-DeBZB9l_.js";
9
- import "./accounts-CJWOBzwB.js";
10
- import "./accounts-DZhWlEg3.js";
11
- import "./path-alias-guards-DBjLbIX_.js";
12
- import { n as listSkillCommandsForAgents } from "./skill-commands-CkGeFUMl.js";
13
- import "./skills-CBkHBYPq.js";
14
- import "./commands-registry-t7cXBTfN.js";
15
-
16
- export { listSkillCommandsForAgents };
@@ -1,202 +0,0 @@
1
- import { $ as parseCanonicalIpAddress, G as isBlockedSpecialUseIpv4Address, J as isIpv4Address, K as isBlockedSpecialUseIpv6Address, W as extractEmbeddedIpv4FromIpv6, Y as isLegacyIpv4Literal, et as parseLooseIpAddress, q as isCanonicalDottedDecimalIPv4 } from "./config-BkEnz2Po.js";
2
- import { Agent } from "undici";
3
- import { lookup } from "node:dns";
4
- import { lookup as lookup$1 } from "node:dns/promises";
5
-
6
- //#region src/infra/net/proxy-env.ts
7
- const PROXY_ENV_KEYS = [
8
- "HTTP_PROXY",
9
- "HTTPS_PROXY",
10
- "ALL_PROXY",
11
- "http_proxy",
12
- "https_proxy",
13
- "all_proxy"
14
- ];
15
- function hasProxyEnvConfigured(env = process.env) {
16
- for (const key of PROXY_ENV_KEYS) {
17
- const value = env[key];
18
- if (typeof value === "string" && value.trim().length > 0) return true;
19
- }
20
- return false;
21
- }
22
-
23
- //#endregion
24
- //#region src/infra/net/hostname.ts
25
- function normalizeHostname(hostname) {
26
- const normalized = hostname.trim().toLowerCase().replace(/\.$/, "");
27
- if (normalized.startsWith("[") && normalized.endsWith("]")) return normalized.slice(1, -1);
28
- return normalized;
29
- }
30
-
31
- //#endregion
32
- //#region src/infra/net/ssrf.ts
33
- var SsrFBlockedError = class extends Error {
34
- constructor(message) {
35
- super(message);
36
- this.name = "SsrFBlockedError";
37
- }
38
- };
39
- const BLOCKED_HOSTNAMES = new Set([
40
- "localhost",
41
- "localhost.localdomain",
42
- "metadata.google.internal"
43
- ]);
44
- function normalizeHostnameSet(values) {
45
- if (!values || values.length === 0) return /* @__PURE__ */ new Set();
46
- return new Set(values.map((value) => normalizeHostname(value)).filter(Boolean));
47
- }
48
- function normalizeHostnameAllowlist(values) {
49
- if (!values || values.length === 0) return [];
50
- return Array.from(new Set(values.map((value) => normalizeHostname(value)).filter((value) => value !== "*" && value !== "*." && value.length > 0)));
51
- }
52
- function isPrivateNetworkAllowedByPolicy(policy) {
53
- return policy?.dangerouslyAllowPrivateNetwork === true || policy?.allowPrivateNetwork === true;
54
- }
55
- function resolveIpv4SpecialUseBlockOptions(policy) {
56
- return { allowRfc2544BenchmarkRange: policy?.allowRfc2544BenchmarkRange === true };
57
- }
58
- function isHostnameAllowedByPattern(hostname, pattern) {
59
- if (pattern.startsWith("*.")) {
60
- const suffix = pattern.slice(2);
61
- if (!suffix || hostname === suffix) return false;
62
- return hostname.endsWith(`.${suffix}`);
63
- }
64
- return hostname === pattern;
65
- }
66
- function matchesHostnameAllowlist(hostname, allowlist) {
67
- if (allowlist.length === 0) return true;
68
- return allowlist.some((pattern) => isHostnameAllowedByPattern(hostname, pattern));
69
- }
70
- function looksLikeUnsupportedIpv4Literal(address) {
71
- const parts = address.split(".");
72
- if (parts.length === 0 || parts.length > 4) return false;
73
- if (parts.some((part) => part.length === 0)) return true;
74
- return parts.every((part) => /^[0-9]+$/.test(part) || /^0x/i.test(part));
75
- }
76
- function isPrivateIpAddress(address, policy) {
77
- let normalized = address.trim().toLowerCase();
78
- if (normalized.startsWith("[") && normalized.endsWith("]")) normalized = normalized.slice(1, -1);
79
- if (!normalized) return false;
80
- const blockOptions = resolveIpv4SpecialUseBlockOptions(policy);
81
- const strictIp = parseCanonicalIpAddress(normalized);
82
- if (strictIp) {
83
- if (isIpv4Address(strictIp)) return isBlockedSpecialUseIpv4Address(strictIp, blockOptions);
84
- if (isBlockedSpecialUseIpv6Address(strictIp)) return true;
85
- const embeddedIpv4 = extractEmbeddedIpv4FromIpv6(strictIp);
86
- if (embeddedIpv4) return isBlockedSpecialUseIpv4Address(embeddedIpv4, blockOptions);
87
- return false;
88
- }
89
- if (normalized.includes(":") && !parseLooseIpAddress(normalized)) return true;
90
- if (!isCanonicalDottedDecimalIPv4(normalized) && isLegacyIpv4Literal(normalized)) return true;
91
- if (looksLikeUnsupportedIpv4Literal(normalized)) return true;
92
- return false;
93
- }
94
- function isBlockedHostname(hostname) {
95
- const normalized = normalizeHostname(hostname);
96
- if (!normalized) return false;
97
- return isBlockedHostnameNormalized(normalized);
98
- }
99
- function isBlockedHostnameNormalized(normalized) {
100
- if (BLOCKED_HOSTNAMES.has(normalized)) return true;
101
- return normalized.endsWith(".localhost") || normalized.endsWith(".local") || normalized.endsWith(".internal");
102
- }
103
- function isBlockedHostnameOrIp(hostname, policy) {
104
- const normalized = normalizeHostname(hostname);
105
- if (!normalized) return false;
106
- return isBlockedHostnameNormalized(normalized) || isPrivateIpAddress(normalized, policy);
107
- }
108
- const BLOCKED_HOST_OR_IP_MESSAGE = "Blocked hostname or private/internal/special-use IP address";
109
- const BLOCKED_RESOLVED_IP_MESSAGE = "Blocked: resolves to private/internal/special-use IP address";
110
- function assertAllowedHostOrIpOrThrow(hostnameOrIp, policy) {
111
- if (isBlockedHostnameOrIp(hostnameOrIp, policy)) throw new SsrFBlockedError(BLOCKED_HOST_OR_IP_MESSAGE);
112
- }
113
- function assertAllowedResolvedAddressesOrThrow(results, policy) {
114
- for (const entry of results) if (isBlockedHostnameOrIp(entry.address, policy)) throw new SsrFBlockedError(BLOCKED_RESOLVED_IP_MESSAGE);
115
- }
116
- function createPinnedLookup(params) {
117
- const normalizedHost = normalizeHostname(params.hostname);
118
- const fallback = params.fallback ?? lookup;
119
- const fallbackLookup = fallback;
120
- const fallbackWithOptions = fallback;
121
- const records = params.addresses.map((address) => ({
122
- address,
123
- family: address.includes(":") ? 6 : 4
124
- }));
125
- let index = 0;
126
- return ((host, options, callback) => {
127
- const cb = typeof options === "function" ? options : callback;
128
- if (!cb) return;
129
- const normalized = normalizeHostname(host);
130
- if (!normalized || normalized !== normalizedHost) {
131
- if (typeof options === "function" || options === void 0) return fallbackLookup(host, cb);
132
- return fallbackWithOptions(host, options, cb);
133
- }
134
- const opts = typeof options === "object" && options !== null ? options : {};
135
- const requestedFamily = typeof options === "number" ? options : typeof opts.family === "number" ? opts.family : 0;
136
- const candidates = requestedFamily === 4 || requestedFamily === 6 ? records.filter((entry) => entry.family === requestedFamily) : records;
137
- const usable = candidates.length > 0 ? candidates : records;
138
- if (opts.all) {
139
- cb(null, usable);
140
- return;
141
- }
142
- const chosen = usable[index % usable.length];
143
- index += 1;
144
- cb(null, chosen.address, chosen.family);
145
- });
146
- }
147
- function dedupeAndPreferIpv4(results) {
148
- const seen = /* @__PURE__ */ new Set();
149
- const ipv4 = [];
150
- const otherFamilies = [];
151
- for (const entry of results) {
152
- if (seen.has(entry.address)) continue;
153
- seen.add(entry.address);
154
- if (entry.family === 4) {
155
- ipv4.push(entry.address);
156
- continue;
157
- }
158
- otherFamilies.push(entry.address);
159
- }
160
- return [...ipv4, ...otherFamilies];
161
- }
162
- async function resolvePinnedHostnameWithPolicy(hostname, params = {}) {
163
- const normalized = normalizeHostname(hostname);
164
- if (!normalized) throw new Error("Invalid hostname");
165
- const allowPrivateNetwork = isPrivateNetworkAllowedByPolicy(params.policy);
166
- const allowedHostnames = normalizeHostnameSet(params.policy?.allowedHostnames);
167
- const hostnameAllowlist = normalizeHostnameAllowlist(params.policy?.hostnameAllowlist);
168
- const isExplicitAllowed = allowedHostnames.has(normalized);
169
- const skipPrivateNetworkChecks = allowPrivateNetwork || isExplicitAllowed;
170
- if (!matchesHostnameAllowlist(normalized, hostnameAllowlist)) throw new SsrFBlockedError(`Blocked hostname (not in allowlist): ${hostname}`);
171
- if (!skipPrivateNetworkChecks) assertAllowedHostOrIpOrThrow(normalized, params.policy);
172
- const results = await (params.lookupFn ?? lookup$1)(normalized, { all: true });
173
- if (results.length === 0) throw new Error(`Unable to resolve hostname: ${hostname}`);
174
- if (!skipPrivateNetworkChecks) assertAllowedResolvedAddressesOrThrow(results, params.policy);
175
- const addresses = dedupeAndPreferIpv4(results);
176
- if (addresses.length === 0) throw new Error(`Unable to resolve hostname: ${hostname}`);
177
- return {
178
- hostname: normalized,
179
- addresses,
180
- lookup: createPinnedLookup({
181
- hostname: normalized,
182
- addresses
183
- })
184
- };
185
- }
186
- function createPinnedDispatcher(pinned) {
187
- return new Agent({ connect: { lookup: pinned.lookup } });
188
- }
189
- async function closeDispatcher(dispatcher) {
190
- if (!dispatcher) return;
191
- const candidate = dispatcher;
192
- try {
193
- if (typeof candidate.close === "function") {
194
- await candidate.close();
195
- return;
196
- }
197
- if (typeof candidate.destroy === "function") candidate.destroy();
198
- } catch {}
199
- }
200
-
201
- //#endregion
202
- export { isBlockedHostnameOrIp as a, resolvePinnedHostnameWithPolicy as c, isBlockedHostname as i, normalizeHostname as l, closeDispatcher as n, isPrivateIpAddress as o, createPinnedDispatcher as r, isPrivateNetworkAllowedByPolicy as s, SsrFBlockedError as t, hasProxyEnvConfigured as u };
@@ -1,81 +0,0 @@
1
- import { w as resolveConfigDir } from "./logger-CZY9KIoY.js";
2
- import { c as detectMime, l as extensionForMime } from "./image-ops-BSiMpAw4.js";
3
- import { createWriteStream } from "node:fs";
4
- import path from "node:path";
5
- import fs$1 from "node:fs/promises";
6
- import crypto from "node:crypto";
7
- import { pipeline } from "node:stream/promises";
8
- import { request } from "node:https";
9
-
10
- //#region src/media/store.ts
11
- const resolveMediaDir = () => path.join(resolveConfigDir(), "media");
12
- const MEDIA_MAX_BYTES = 5 * 1024 * 1024;
13
- const MAX_BYTES = MEDIA_MAX_BYTES;
14
- const DEFAULT_TTL_MS = 120 * 1e3;
15
- const MEDIA_FILE_MODE = 420;
16
- /**
17
- * Sanitize a filename for cross-platform safety.
18
- * Removes chars unsafe on Windows/SharePoint/all platforms.
19
- * Keeps: alphanumeric, dots, hyphens, underscores, Unicode letters/numbers.
20
- */
21
- function sanitizeFilename(name) {
22
- const trimmed = name.trim();
23
- if (!trimmed) return "";
24
- return trimmed.replace(/[^\p{L}\p{N}._-]+/gu, "_").replace(/_+/g, "_").replace(/^_|_$/g, "").slice(0, 60);
25
- }
26
- /**
27
- * Extract original filename from path if it matches the embedded format.
28
- * Pattern: {original}---{uuid}.{ext} → returns "{original}.{ext}"
29
- * Falls back to basename if no pattern match, or "file.bin" if empty.
30
- */
31
- function extractOriginalFilename(filePath) {
32
- const basename = path.basename(filePath);
33
- if (!basename) return "file.bin";
34
- const ext = path.extname(basename);
35
- const match = path.basename(basename, ext).match(/^(.+)---[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}$/i);
36
- if (match?.[1]) return `${match[1]}${ext}`;
37
- return basename;
38
- }
39
- function getMediaDir() {
40
- return resolveMediaDir();
41
- }
42
- async function ensureMediaDir() {
43
- const mediaDir = resolveMediaDir();
44
- await fs$1.mkdir(mediaDir, {
45
- recursive: true,
46
- mode: 448
47
- });
48
- return mediaDir;
49
- }
50
- async function saveMediaBuffer(buffer, contentType, subdir = "inbound", maxBytes = MAX_BYTES, originalFilename) {
51
- if (buffer.byteLength > maxBytes) throw new Error(`Media exceeds ${(maxBytes / (1024 * 1024)).toFixed(0)}MB limit`);
52
- const dir = path.join(resolveMediaDir(), subdir);
53
- await fs$1.mkdir(dir, {
54
- recursive: true,
55
- mode: 448
56
- });
57
- const uuid = crypto.randomUUID();
58
- const headerExt = extensionForMime(contentType?.split(";")[0]?.trim() ?? void 0);
59
- const mime = await detectMime({
60
- buffer,
61
- headerMime: contentType
62
- });
63
- const ext = headerExt ?? extensionForMime(mime) ?? "";
64
- let id;
65
- if (originalFilename) {
66
- const base = path.parse(originalFilename).name;
67
- const sanitized = sanitizeFilename(base);
68
- id = sanitized ? `${sanitized}---${uuid}${ext}` : `${uuid}${ext}`;
69
- } else id = ext ? `${uuid}${ext}` : uuid;
70
- const dest = path.join(dir, id);
71
- await fs$1.writeFile(dest, buffer, { mode: MEDIA_FILE_MODE });
72
- return {
73
- id,
74
- path: dest,
75
- size: buffer.byteLength,
76
- contentType: mime
77
- };
78
- }
79
-
80
- //#endregion
81
- export { saveMediaBuffer as a, getMediaDir as i, ensureMediaDir as n, extractOriginalFilename as r, MEDIA_MAX_BYTES as t };
@@ -1,52 +0,0 @@
1
- import "./run-with-concurrency-Bt_ks0Qa.js";
2
- import "./accounts-DP1-L-QS.js";
3
- import { C as countPendingDescendantRunsExcludingRun, S as countPendingDescendantRuns, T as resolveRequesterForChildSession, w as isSubagentSessionRunActive, x as countActiveDescendantRuns } from "./reply-DAo_Jt8K.js";
4
- import "./paths-MKyEVmEb.js";
5
- import "./github-copilot-token-D5fdS6xD.js";
6
- import "./config-BkEnz2Po.js";
7
- import "./logger-CZY9KIoY.js";
8
- import "./thinking-Bo2eosVa.js";
9
- import "./image-ops-BSiMpAw4.js";
10
- import "./pi-embedded-helpers-1R1gu7eX.js";
11
- import "./plugins-DeBZB9l_.js";
12
- import "./accounts-CJWOBzwB.js";
13
- import "./accounts-DZhWlEg3.js";
14
- import "./send-DTB24bEF.js";
15
- import "./paths-vTM3Lh3X.js";
16
- import "./fetch-Bv4TQOMH.js";
17
- import "./redact-DjVX-1N3.js";
18
- import "./errors-DaiAM-yU.js";
19
- import "./channel-activity-F3d0yUwy.js";
20
- import "./path-alias-guards-DBjLbIX_.js";
21
- import "./fs-safe-B8y811FR.js";
22
- import "./ssrf-cFtplYtS.js";
23
- import "./fetch-guard-DETCcJzQ.js";
24
- import "./local-roots-BUP4YBmR.js";
25
- import "./ir-DQ7_HbvK.js";
26
- import "./render-HmipMDlP.js";
27
- import "./tables-C47P4GTN.js";
28
- import "./send-DfHadjZ_.js";
29
- import "./send-CQpMudwO.js";
30
- import "./tool-images-Gk_-0y2N.js";
31
- import "./target-errors-Blia4S69.js";
32
- import "./send-DQHLzVyO.js";
33
- import "./audio-transcription-runner-DkoPNPYt.js";
34
- import "./tokens-DgNRBwIg.js";
35
- import "./skill-commands-CkGeFUMl.js";
36
- import "./skills-CBkHBYPq.js";
37
- import "./chrome-BXoCyCkY.js";
38
- import "./deliver-B6AG_l67.js";
39
- import "./diagnostic-CsP-lEkI.js";
40
- import "./store-5nyxY3WU.js";
41
- import "./commands-registry-t7cXBTfN.js";
42
- import "./image-DjTEkYZE.js";
43
- import "./api-key-rotation-BRE4X2tf.js";
44
- import "./proxy-fetch-ChxOhWF4.js";
45
- import "./pi-model-discovery-v-XPUOOf.js";
46
- import "./send-XXlW2iny.js";
47
- import "./outbound-attachment-Dy6fyf6H.js";
48
- import "./proxy-BKdNrmWL.js";
49
- import "./manager-I6KbPihW.js";
50
- import "./query-expansion-CeyKUeDW.js";
51
-
52
- export { countActiveDescendantRuns, countPendingDescendantRuns, countPendingDescendantRunsExcludingRun, isSubagentSessionRunActive, resolveRequesterForChildSession };
@@ -1,55 +0,0 @@
1
- import { r as markdownToIRWithMeta } from "./ir-DQ7_HbvK.js";
2
- import { t as renderMarkdownWithMarkers } from "./render-HmipMDlP.js";
3
-
4
- //#region src/markdown/tables.ts
5
- const MARKDOWN_STYLE_MARKERS = {
6
- bold: {
7
- open: "**",
8
- close: "**"
9
- },
10
- italic: {
11
- open: "_",
12
- close: "_"
13
- },
14
- strikethrough: {
15
- open: "~~",
16
- close: "~~"
17
- },
18
- code: {
19
- open: "`",
20
- close: "`"
21
- },
22
- code_block: {
23
- open: "```\n",
24
- close: "```"
25
- }
26
- };
27
- function convertMarkdownTables(markdown, mode) {
28
- if (!markdown || mode === "off") return markdown;
29
- const { ir, hasTables } = markdownToIRWithMeta(markdown, {
30
- linkify: false,
31
- autolink: false,
32
- headingStyle: "none",
33
- blockquotePrefix: "",
34
- tableMode: mode
35
- });
36
- if (!hasTables) return markdown;
37
- return renderMarkdownWithMarkers(ir, {
38
- styleMarkers: MARKDOWN_STYLE_MARKERS,
39
- escapeText: (text) => text,
40
- buildLink: (link, text) => {
41
- const href = link.href.trim();
42
- if (!href) return null;
43
- if (!text.slice(link.start, link.end)) return null;
44
- return {
45
- start: link.start,
46
- end: link.end,
47
- open: "[",
48
- close: `](${href})`
49
- };
50
- }
51
- });
52
- }
53
-
54
- //#endregion
55
- export { convertMarkdownTables as t };