@gaodefa/daocore 2026.5.55 → 2026.5.57

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 (1688) hide show
  1. package/dist/abort-DiC4Sznz.js +277 -0
  2. package/dist/abort.runtime-CQoHzKTf.js +2 -0
  3. package/dist/abort.runtime.js +1 -1
  4. package/dist/account-inspect-Dh7EWFPH.js +173 -0
  5. package/dist/accounts-BZStTFvH.js +107 -0
  6. package/dist/accounts-DOSIhc1G.js +107 -0
  7. package/dist/accounts-hM84k1b4.js +2 -0
  8. package/dist/accounts-j_TdtEpS.js +119 -0
  9. package/dist/acp-runtime-BK9aeb-F.js +26 -0
  10. package/dist/acp-spawn-B_TzMnCs.js +2 -0
  11. package/dist/acp-spawn-C-jSM9pB.js +1275 -0
  12. package/dist/acp-stateful-target-driver-Bs7j0_2y.js +89 -0
  13. package/dist/action-kill-BZimChzW.js +33 -0
  14. package/dist/action-runtime-CV2RGgay.js +469 -0
  15. package/dist/action-runtime-api-Di0XuJjs.js +2 -0
  16. package/dist/action-send-CGACS9au.js +39 -0
  17. package/dist/action-spawn-CaZbPxyj.js +47 -0
  18. package/dist/actions-CWN32SuY.js +161 -0
  19. package/dist/actions.runtime-COUjuN0A.js +5 -0
  20. package/dist/agent-7rrYnTDJ.js +3 -0
  21. package/dist/agent-command-DCD5KH4O.js +1367 -0
  22. package/dist/agent-components.runtime-CpszZAIK.js +10 -0
  23. package/dist/agent-components.runtime.js +1 -1
  24. package/dist/agent-harness-CGtBwZh6.d.ts +146 -0
  25. package/dist/agent-harness-runtime-C8bm2G6W.js +180 -0
  26. package/dist/agent-harness-runtime-DMYJ4buZ.d.ts +691 -0
  27. package/dist/agent-harness-task-runtime-BIlxU__c.js +140 -0
  28. package/dist/agent-runner-execution-BwxMzaLo.js +1713 -0
  29. package/dist/agent-runner-utils-rclNBb27.js +266 -0
  30. package/dist/agent-runner.runtime-bHUq_x-t.js +3455 -0
  31. package/dist/agent-runner.runtime.js +1 -1
  32. package/dist/agent-runtime-xKSjW2h-.js +229 -0
  33. package/dist/agent-via-gateway-CmbxFwNI.js +463 -0
  34. package/dist/agent-zvVk5Gj7.js +2 -0
  35. package/dist/agents/pi-embedded-runner/tool-split.d.ts +1 -1
  36. package/dist/api-Bq22hQPa.js +2 -0
  37. package/dist/api-C9Dmd2CA.d.ts +52 -0
  38. package/dist/api-CFnwFx29.js +639 -0
  39. package/dist/api-ChHyXerl.js +6 -0
  40. package/dist/api-CwAgaVbv.js +2 -0
  41. package/dist/api-DuR1iuSt.js +3 -0
  42. package/dist/api-oLwjYZlQ.js +134 -0
  43. package/dist/apply-CYqNieX-.js +54 -0
  44. package/dist/apply-DhAs6lD_.js +41 -0
  45. package/dist/approval-handler.runtime-DKFYzDbX.js +130 -0
  46. package/dist/assistant-VvAy5G1q.js +291 -0
  47. package/dist/attachment-normalize-DXLRb1vV.js +225 -0
  48. package/dist/attempt-execution-ByHukLRQ.js +558 -0
  49. package/dist/attempt-execution.runtime-CB1K0mw-.js +3 -0
  50. package/dist/attempt-execution.runtime.js +1 -1
  51. package/dist/attempt-execution.shared-DUY-qllk.js +38 -0
  52. package/dist/attempt.prompt-helpers-OGgVyJYC.js +475 -0
  53. package/dist/attempt.tool-run-context-lCJOOyoF.js +2094 -0
  54. package/dist/binding-routing-V7qHnpr1.js +113 -0
  55. package/dist/binding-targets-DRZy-L0v.js +121 -0
  56. package/dist/bot-BRiKm0Sj.js +7894 -0
  57. package/dist/bot-deps-C7IwsRPN.js +2 -0
  58. package/dist/bot-deps-PET2I6SF.js +747 -0
  59. package/dist/bot-message-context.runtime-CToAd9y4.js +7 -0
  60. package/dist/bot-message-context.runtime.js +1 -1
  61. package/dist/bot-message-context.session.runtime-BUs3Wbbp.js +12 -0
  62. package/dist/bot-message-context.session.runtime.js +1 -1
  63. package/dist/bot-native-commands.delivery.runtime-BX5zaPEH.js +4 -0
  64. package/dist/bot-native-commands.delivery.runtime.js +1 -1
  65. package/dist/bot-native-commands.runtime-9tQ5_DNB.js +13 -0
  66. package/dist/bot-native-commands.runtime.js +1 -1
  67. package/dist/bridge-server-B5j8kXOX.js +113 -0
  68. package/dist/browser-cli-C2Zh3969.js +2 -0
  69. package/dist/browser-cli-C8xLyTcb.js +230 -0
  70. package/dist/browser-cli-actions-input-pLyGefrN.js +473 -0
  71. package/dist/browser-cli-actions-observe-yIc8XHto.js +81 -0
  72. package/dist/browser-cli-debug-XNnJPUBx.js +137 -0
  73. package/dist/browser-cli-inspect-bdB11tMm.js +104 -0
  74. package/dist/browser-cli-manage-DxyNyyfu.js +443 -0
  75. package/dist/browser-cli-resize-DTTYXJZe.js +26 -0
  76. package/dist/browser-cli-shared-NVP-6AKd.js +50 -0
  77. package/dist/browser-cli-state-CNGbNPwa.js +337 -0
  78. package/dist/browser-control-auth--sLVv1gk.js +2 -0
  79. package/dist/browser-profiles-DbqSFyjp.js +2 -0
  80. package/dist/browser-runtime-awhrDqeW.js +384 -0
  81. package/dist/build-D-2nejZD.js +257 -0
  82. package/dist/build-info.json +2 -2
  83. package/dist/bundled/boot-md/handler.js +2 -2
  84. package/dist/bundled/session-memory/handler.js +1 -1
  85. package/dist/bundled-channel-config-schema-4eXcH-RE.d.ts +3163 -0
  86. package/dist/call-BAWIPJo2.d.ts +43 -0
  87. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  88. package/dist/capability-cli-BolcyA0G.js +1782 -0
  89. package/dist/channel-Aq5t-z3L.js +2126 -0
  90. package/dist/channel-B6YcNFXw.d.ts +104 -0
  91. package/dist/channel-BSgHNRHc.js +867 -0
  92. package/dist/channel-BdhbzWTg.d.ts +427 -0
  93. package/dist/channel-Bkp8v6zY.d.ts +14 -0
  94. package/dist/channel-BoK62YYe.d.ts +49 -0
  95. package/dist/channel-BspahFUv.js +238 -0
  96. package/dist/channel-C10lHKrC.d.ts +47 -0
  97. package/dist/channel-C6iG1bMw.js +740 -0
  98. package/dist/channel-CGqfpV9W.js +481 -0
  99. package/dist/channel-CP4Ay-zH.js +1496 -0
  100. package/dist/channel-CXv96eif.js +362 -0
  101. package/dist/channel-CZrble5P.d.ts +8 -0
  102. package/dist/channel-D8X4fgB9.d.ts +106 -0
  103. package/dist/channel-D9LDQOYt.d.ts +8 -0
  104. package/dist/channel-DKtJJJmk.js +1134 -0
  105. package/dist/channel-DVGMasO6.d.ts +7 -0
  106. package/dist/channel-DYaugblh.js +1777 -0
  107. package/dist/channel-DfP8Sc0t.d.ts +6 -0
  108. package/dist/channel-Djgm5DE9.d.ts +64 -0
  109. package/dist/channel-Dl4eeuJ3.d.ts +114 -0
  110. package/dist/channel-DpQ6_cvo.d.ts +8 -0
  111. package/dist/channel-Drfw8mPm.js +376 -0
  112. package/dist/channel-DsZ5FgWv.js +508 -0
  113. package/dist/channel-K5ieMY2B.js +1249 -0
  114. package/dist/channel-TByHmphS.js +653 -0
  115. package/dist/channel-_qt56abp.js +955 -0
  116. package/dist/channel-actions.runtime-IJXVGMwr.js +265 -0
  117. package/dist/channel-actions.runtime.js +1 -1
  118. package/dist/channel-core-CbkDdNXh.d.ts +6 -0
  119. package/dist/channel-core-DI56iN4a.js +5 -0
  120. package/dist/channel-entry-contract-DUSF3gce.d.ts +112 -0
  121. package/dist/channel-hShoCuAc.d.ts +12 -0
  122. package/dist/channel-inbound-CLiXSx1p.js +80 -0
  123. package/dist/channel-jD9TGFqC.js +562 -0
  124. package/dist/channel-pIMjOo6Y.d.ts +28 -0
  125. package/dist/channel-plugin-runtime-Cg67QAiE.d.ts +7 -0
  126. package/dist/channel-plugin-runtime-DbH-PJHG.js +998 -0
  127. package/dist/channel-runtime-qDFdfs2o.js +408 -0
  128. package/dist/channel-uP-mo8Q6.d.ts +7 -0
  129. package/dist/channel-v10vtt5n.js +808 -0
  130. package/dist/channel-whyHp4eY.d.ts +26 -0
  131. package/dist/channel-zuYcvD-Z.js +1556 -0
  132. package/dist/channel.runtime-CDU2dm0s.js +1008 -0
  133. package/dist/channel.runtime-CHdAXkYH.js +254 -0
  134. package/dist/channel.runtime-CLJRpc-h.js +88 -0
  135. package/dist/channel.runtime-CPcuYCrA.js +109 -0
  136. package/dist/channel.runtime-CyBKohZL.js +652 -0
  137. package/dist/channel.runtime-Cyt2i5vz.js +733 -0
  138. package/dist/channel.runtime-D0-a4fRP.js +21009 -0
  139. package/dist/channel.runtime-DoLjhXDx.js +4 -0
  140. package/dist/channel.runtime-w3cW8r41.js +2528 -0
  141. package/dist/channel.setup-BMXb23G7.d.ts +6 -0
  142. package/dist/channel.setup-BS1OC5oY.js +10 -0
  143. package/dist/channel.setup-BdEXf9Ic.d.ts +8 -0
  144. package/dist/channel.setup-DVAWbxPf.js +1098 -0
  145. package/dist/channel.setup-Dr17Z8Bs.js +343 -0
  146. package/dist/channel.setup-UZjcpncE.d.ts +7 -0
  147. package/dist/chat-CjtxdDLc.js +2666 -0
  148. package/dist/chrome-edHD-MwA.js +1503 -0
  149. package/dist/cli/run-main.js +5 -5
  150. package/dist/cli-D5u1KTqm.js +1341 -0
  151. package/dist/cli-DYinYyHP.d.ts +20 -0
  152. package/dist/cli-backend-CSCGROD2.d.ts +5 -0
  153. package/dist/cli-backend-DmBwqwqy.d.ts +5 -0
  154. package/dist/cli-compaction-C9Gf32ee.js +347 -0
  155. package/dist/cli-metadata-BRwOm0gD.js +22 -0
  156. package/dist/cli-runner-CHOYrtX0.js +2 -0
  157. package/dist/cli-runner-DoVHGCQ_.js +540 -0
  158. package/dist/cli-runner.runtime-CLMCxLS3.js +3 -0
  159. package/dist/cli-runner.runtime-zYfDdco2.js +4 -0
  160. package/dist/cli-runner.runtime.js +1 -1
  161. package/dist/cli-shared-CXpra3BN.d.ts +20 -0
  162. package/dist/cli-startup-metadata.json +8 -8
  163. package/dist/client-Cnjvcmyb.js +650 -0
  164. package/dist/client-adapter-e-8O4cOK.js +897 -0
  165. package/dist/client-factory-Ciknc94j.js +9 -0
  166. package/dist/command-auth-DptBVN5F.js +135 -0
  167. package/dist/command-handlers-I-N79aEc.js +1609 -0
  168. package/dist/command-registry-CEGc-tLO.js +9 -0
  169. package/dist/command-registry-DyH-S8Mq.js +4 -0
  170. package/dist/command-registry-core-Dm6muwXT.js +110 -0
  171. package/dist/command-status.runtime-BxXo4Lh8.js +90 -0
  172. package/dist/command-status.runtime.js +1 -1
  173. package/dist/commands-CqcnXnk-.d.ts +113 -0
  174. package/dist/commands-acp-D8Qo4y4s.js +74 -0
  175. package/dist/commands-compact.runtime-T8fDbiQ3.js +10 -0
  176. package/dist/commands-compact.runtime.js +1 -1
  177. package/dist/commands-handlers.runtime-BXbiNMgg.js +6154 -0
  178. package/dist/commands-handlers.runtime.js +1 -1
  179. package/dist/commands-status-C33sx-wg.js +16 -0
  180. package/dist/commands-status-ontnXxS9.js +3 -0
  181. package/dist/commands-status.runtime-ontnXxS9.js +3 -0
  182. package/dist/commands-status.runtime.js +1 -1
  183. package/dist/commands-subagents-control.runtime-Dj_eYE95.js +2 -0
  184. package/dist/commands-subagents-control.runtime-vdq632cp.js +3 -0
  185. package/dist/commands-subagents-control.runtime.js +1 -1
  186. package/dist/commands-system-prompt-C12SSIRK.js +162 -0
  187. package/dist/commands-system-prompt-CLwISYbJ.js +2 -0
  188. package/dist/commands.runtime-CpTdfFOn.js +176 -0
  189. package/dist/commands.runtime.js +1 -1
  190. package/dist/commitments/runtime.js +1 -1
  191. package/dist/compact-B_oM1_Kj.js +480 -0
  192. package/dist/compact-D1kBFth6.js +1141 -0
  193. package/dist/compact.runtime-DUkHrkr5.js +12 -0
  194. package/dist/compact.runtime.js +1 -1
  195. package/dist/completion-cli-jKzV4sfV.js +315 -0
  196. package/dist/components-u4gL95dv.d.ts +228 -0
  197. package/dist/components.modal-glHG-y8o.d.ts +568 -0
  198. package/dist/computer-use-CSww5tMF.js +367 -0
  199. package/dist/config-B1vAgTvP.js +373 -0
  200. package/dist/config-DbqSFyjp.js +2 -0
  201. package/dist/config-mutations-CTSn5iBU.js +159 -0
  202. package/dist/config-schema-Bqr7vPys.d.ts +20 -0
  203. package/dist/context-engine-host-compat-Uh8zFTKI.js +2 -0
  204. package/dist/context-engine-host-compat-oT1wCKie.js +288 -0
  205. package/dist/context-engine-lifecycle-DuQ3Yn9Y.js +1274 -0
  206. package/dist/contracts-testkit-DQ4aMv6G.d.ts +145 -0
  207. package/dist/control-auth-Bs45HadJ.js +114 -0
  208. package/dist/control-service-xpFmVcOh.js +145 -0
  209. package/dist/control-ui/assets/agents-BDUMERgO.js +1008 -0
  210. package/dist/control-ui/assets/channel-config-extras-Cf2MQ4fw.js +2 -0
  211. package/dist/control-ui/assets/channels-u-ST-7HL.js +367 -0
  212. package/dist/control-ui/assets/cron-B9oQvQUF.js +1013 -0
  213. package/dist/control-ui/assets/debug-DzwXJPob.js +97 -0
  214. package/dist/control-ui/assets/index-BNgzcqbU.js +7388 -0
  215. package/dist/control-ui/assets/instances-CvAVAozy.js +57 -0
  216. package/dist/control-ui/assets/logs-aR0p0kJ3.js +74 -0
  217. package/dist/control-ui/assets/nodes-m4lui4-1.js +436 -0
  218. package/dist/control-ui/assets/sessions-NOIW66qZ.js +399 -0
  219. package/dist/control-ui/assets/skills-Jm7PDV4c.js +314 -0
  220. package/dist/control-ui/assets/skills-shared-DNQYYVFk.js +11 -0
  221. package/dist/control-ui/index.html +1 -1
  222. package/dist/control-ui/sw.js +1 -1
  223. package/dist/conversation-binding-runtime-x4mPNIxH.js +4 -0
  224. package/dist/conversation-runtime-DtEjS-G-.js +31 -0
  225. package/dist/core-DC7Ny2oO.js +282 -0
  226. package/dist/core-DIQ0fbwp.d.ts +224 -0
  227. package/dist/core-api-15EcrNg-.js +2 -0
  228. package/dist/core-api-BYZCq0RV.js +5 -0
  229. package/dist/crestodian/crestodian.js +1 -1
  230. package/dist/crestodian/rescue-message.js +1 -1
  231. package/dist/crestodian-D5kJCfGc.js +55 -0
  232. package/dist/daocore-runtime-JsdCNe3l.d.ts +151 -0
  233. package/dist/daocore-tools-B3_b_UBy.js +11727 -0
  234. package/dist/delivery-DzhYKAIC.js +1002 -0
  235. package/dist/dialogue-CeR00F0b.js +37 -0
  236. package/dist/dir-fetch-tool-BN93HZEX.js +565 -0
  237. package/dist/dir-list-tool-GN9j9rZf.js +100 -0
  238. package/dist/direct-dm-DG_Y9uZa.js +64 -0
  239. package/dist/directive-handling.fast-lane-C6MB3gfj.js +68 -0
  240. package/dist/directive-handling.impl-DMd8DEIx.js +2 -0
  241. package/dist/directive-handling.impl-DiHRiklw.js +818 -0
  242. package/dist/directive-handling.model-selection-bFnPrpT5.js +122 -0
  243. package/dist/directive-handling.persist.runtime-BmUPRBpx.js +263 -0
  244. package/dist/directive-handling.persist.runtime.js +1 -1
  245. package/dist/dispatch-acp-transcript.runtime-BOd5NoBy.js +40 -0
  246. package/dist/dispatch-acp-transcript.runtime.js +1 -1
  247. package/dist/dispatch-acp.runtime-BAHKODIz.js +18 -0
  248. package/dist/dispatch-acp.runtime.js +1 -1
  249. package/dist/dispatch-nvTA16b0.js +1640 -0
  250. package/dist/doctor-BC74dYFO.js +6 -0
  251. package/dist/doctor-BYhXKI0q.js +2 -0
  252. package/dist/doctor-config-flow-DQGS37Mm.js +1741 -0
  253. package/dist/doctor-core-checks-Cbu28kU4.js +573 -0
  254. package/dist/doctor-core-checks-RYxzr9_s.js +2 -0
  255. package/dist/doctor-health-B_mD0NRM.js +65 -0
  256. package/dist/doctor-health-contributions-CXGagKlC.js +696 -0
  257. package/dist/doctor-lint-D3uAOXwJ.js +94 -0
  258. package/dist/doctor-state-integrity-BGTUWx8E.js +1231 -0
  259. package/dist/doctor-update-BEEW5jJq.js +58 -0
  260. package/dist/dynamic-tools-iaDgH2y8.js +486 -0
  261. package/dist/embedded-backend-CrWLS1VO.js +579 -0
  262. package/dist/embedded-gateway-stub.runtime-D1V-x8Xf.js +12 -0
  263. package/dist/embedded-gateway-stub.runtime.js +1 -1
  264. package/dist/embedding-provider-56qUY6a4.d.ts +16 -0
  265. package/dist/embedding-provider-CfSvDhLk.d.ts +65 -0
  266. package/dist/embedding-provider-DV9KtS1H.d.ts +21 -0
  267. package/dist/entry.d.ts +1 -1
  268. package/dist/exec-approvals-CtBpUdfe.js +149 -0
  269. package/dist/extensionAPI.js +1 -1
  270. package/dist/extensions/active-memory/index.d.ts +1 -1
  271. package/dist/extensions/active-memory/index.js +1 -1
  272. package/dist/extensions/admin-http-rpc/index.d.ts +1 -1
  273. package/dist/extensions/admin-http-rpc/index.js +1 -1
  274. package/dist/extensions/alibaba/index.d.ts +1 -1
  275. package/dist/extensions/anthropic/api.d.ts +3 -3
  276. package/dist/extensions/anthropic/cli-backend-api.d.ts +2 -2
  277. package/dist/extensions/anthropic/cli-backend.d.ts +1 -1
  278. package/dist/extensions/anthropic/cli-migration.d.ts +1 -1
  279. package/dist/extensions/anthropic/cli-shared.d.ts +1 -1
  280. package/dist/extensions/anthropic/contract-api.d.ts +1 -1
  281. package/dist/extensions/anthropic/index.d.ts +1 -1
  282. package/dist/extensions/anthropic/provider-contract-api.d.ts +1 -1
  283. package/dist/extensions/anthropic/provider-discovery.d.ts +1 -1
  284. package/dist/extensions/anthropic/provider-policy-api.d.ts +1 -1
  285. package/dist/extensions/anthropic/register.runtime.d.ts +1 -1
  286. package/dist/extensions/anthropic/replay-policy.d.ts +1 -1
  287. package/dist/extensions/anthropic/setup-api.d.ts +1 -1
  288. package/dist/extensions/anthropic/stream-wrappers.d.ts +1 -1
  289. package/dist/extensions/anthropic/test-api.d.ts +2 -2
  290. package/dist/extensions/arcee/index.d.ts +1 -1
  291. package/dist/extensions/azure-speech/index.d.ts +1 -1
  292. package/dist/extensions/azure-speech/speech-provider.d.ts +1 -1
  293. package/dist/extensions/bonjour/index.d.ts +1 -1
  294. package/dist/extensions/browser/browser-bridge.js +1 -1
  295. package/dist/extensions/browser/browser-config.js +4 -4
  296. package/dist/extensions/browser/browser-control-auth.js +2 -2
  297. package/dist/extensions/browser/browser-doctor.js +2 -2
  298. package/dist/extensions/browser/browser-maintenance.js +1 -1
  299. package/dist/extensions/browser/browser-profiles.js +2 -2
  300. package/dist/extensions/browser/browser-runtime-api.js +11 -11
  301. package/dist/extensions/browser/cli-metadata.d.ts +1 -1
  302. package/dist/extensions/browser/cli-metadata.js +1 -1
  303. package/dist/extensions/browser/index.d.ts +1 -1
  304. package/dist/extensions/browser/index.js +1 -1
  305. package/dist/extensions/browser/plugin-registration.d.ts +1 -1
  306. package/dist/extensions/browser/plugin-registration.js +1 -1
  307. package/dist/extensions/browser/register.runtime.d.ts +2 -2
  308. package/dist/extensions/browser/register.runtime.js +4 -4
  309. package/dist/extensions/browser/runtime-api.d.ts +3 -3
  310. package/dist/extensions/browser/runtime-api.js +13 -13
  311. package/dist/extensions/browser/setup-api.d.ts +1 -1
  312. package/dist/extensions/byteplus/index.d.ts +1 -1
  313. package/dist/extensions/byteplus/provider-discovery.d.ts +1 -1
  314. package/dist/extensions/canvas/cli-metadata.d.ts +1 -1
  315. package/dist/extensions/canvas/index.d.ts +1 -1
  316. package/dist/extensions/canvas/index.js +1 -1
  317. package/dist/extensions/canvas/runtime-api.d.ts +2 -2
  318. package/dist/extensions/canvas/setup-api.d.ts +1 -1
  319. package/dist/extensions/cerebras/index.d.ts +1 -1
  320. package/dist/extensions/chutes/index.d.ts +1 -1
  321. package/dist/extensions/clickclack/api.d.ts +2 -2
  322. package/dist/extensions/clickclack/api.js +2 -2
  323. package/dist/extensions/clickclack/channel-plugin-api.d.ts +1 -1
  324. package/dist/extensions/clickclack/channel-plugin-api.js +1 -1
  325. package/dist/extensions/clickclack/index.d.ts +2 -2
  326. package/dist/extensions/clickclack/runtime-api.d.ts +2 -2
  327. package/dist/extensions/clickclack/runtime-api.js +2 -2
  328. package/dist/extensions/cloudflare-ai-gateway/index.d.ts +1 -1
  329. package/dist/extensions/cloudflare-ai-gateway/stream-wrappers.d.ts +1 -1
  330. package/dist/extensions/comfy/index.d.ts +1 -1
  331. package/dist/extensions/copilot-proxy/index.d.ts +1 -1
  332. package/dist/extensions/copilot-proxy/runtime-api.d.ts +2 -2
  333. package/dist/extensions/deepgram/index.d.ts +1 -1
  334. package/dist/extensions/deepgram/realtime-transcription-provider.d.ts +1 -1
  335. package/dist/extensions/deepgram/test-api.d.ts +1 -1
  336. package/dist/extensions/deepinfra/api.d.ts +2 -2
  337. package/dist/extensions/deepinfra/embedding-provider.d.ts +1 -1
  338. package/dist/extensions/deepinfra/index.d.ts +1 -1
  339. package/dist/extensions/deepinfra/memory-embedding-adapter.d.ts +1 -1
  340. package/dist/extensions/deepinfra/speech-provider.d.ts +1 -1
  341. package/dist/extensions/deepseek/api.d.ts +1 -1
  342. package/dist/extensions/deepseek/index.d.ts +1 -1
  343. package/dist/extensions/deepseek/provider-discovery.d.ts +1 -1
  344. package/dist/extensions/deepseek/provider-policy-api.d.ts +1 -1
  345. package/dist/extensions/deepseek/stream.d.ts +1 -1
  346. package/dist/extensions/deepseek/thinking.d.ts +1 -1
  347. package/dist/extensions/device-pair/api.d.ts +3 -3
  348. package/dist/extensions/device-pair/api.js +1 -1
  349. package/dist/extensions/device-pair/index.d.ts +1 -1
  350. package/dist/extensions/device-pair/notify.d.ts +1 -1
  351. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  352. package/dist/extensions/document-extract/index.d.ts +1 -1
  353. package/dist/extensions/duckduckgo/index.d.ts +1 -1
  354. package/dist/extensions/elevenlabs/index.d.ts +1 -1
  355. package/dist/extensions/elevenlabs/realtime-transcription-provider.d.ts +1 -1
  356. package/dist/extensions/elevenlabs/setup-api.d.ts +1 -1
  357. package/dist/extensions/elevenlabs/speech-provider.d.ts +1 -1
  358. package/dist/extensions/elevenlabs/test-api.d.ts +2 -2
  359. package/dist/extensions/exa/index.d.ts +1 -1
  360. package/dist/extensions/fal/index.d.ts +1 -1
  361. package/dist/extensions/fal/provider-contract-api.d.ts +1 -1
  362. package/dist/extensions/fal/provider-registration.d.ts +1 -1
  363. package/dist/extensions/file-transfer/index.d.ts +1 -1
  364. package/dist/extensions/file-transfer/index.js +4 -4
  365. package/dist/extensions/firecrawl/index.d.ts +1 -1
  366. package/dist/extensions/fireworks/index.d.ts +1 -1
  367. package/dist/extensions/fireworks/provider-policy-api.d.ts +1 -1
  368. package/dist/extensions/fireworks/stream.d.ts +1 -1
  369. package/dist/extensions/fireworks/thinking-policy.d.ts +1 -1
  370. package/dist/extensions/github-copilot/embeddings.d.ts +1 -1
  371. package/dist/extensions/github-copilot/index.d.ts +1 -1
  372. package/dist/extensions/github-copilot/models.d.ts +1 -1
  373. package/dist/extensions/github-copilot/register.runtime.d.ts +2 -2
  374. package/dist/extensions/github-copilot/stream.d.ts +1 -1
  375. package/dist/extensions/google/api.d.ts +5 -5
  376. package/dist/extensions/google/cli-backend.d.ts +1 -1
  377. package/dist/extensions/google/embedding-batch.d.ts +1 -1
  378. package/dist/extensions/google/embedding-provider.d.ts +1 -1
  379. package/dist/extensions/google/gemini-cli-provider.d.ts +1 -1
  380. package/dist/extensions/google/index.d.ts +1 -1
  381. package/dist/extensions/google/memory-embedding-adapter.d.ts +1 -1
  382. package/dist/extensions/google/provider-contract-api.d.ts +1 -1
  383. package/dist/extensions/google/provider-hooks.d.ts +2 -2
  384. package/dist/extensions/google/provider-models.d.ts +1 -1
  385. package/dist/extensions/google/provider-policy-api.d.ts +1 -1
  386. package/dist/extensions/google/provider-policy.d.ts +1 -1
  387. package/dist/extensions/google/provider-registration.d.ts +1 -1
  388. package/dist/extensions/google/realtime-voice-provider.d.ts +1 -1
  389. package/dist/extensions/google/runtime-api.d.ts +3 -3
  390. package/dist/extensions/google/setup-api.d.ts +1 -1
  391. package/dist/extensions/google/speech-provider.d.ts +1 -1
  392. package/dist/extensions/google/test-api.d.ts +2 -2
  393. package/dist/extensions/google/thinking-api.d.ts +1 -1
  394. package/dist/extensions/google/thinking.d.ts +1 -1
  395. package/dist/extensions/google/transport-stream.d.ts +1 -1
  396. package/dist/extensions/gradium/index.d.ts +1 -1
  397. package/dist/extensions/gradium/speech-provider.d.ts +1 -1
  398. package/dist/extensions/groq/index.d.ts +1 -1
  399. package/dist/extensions/huggingface/index.d.ts +1 -1
  400. package/dist/extensions/image-generation-core/api.d.ts +3 -3
  401. package/dist/extensions/image-generation-core/runtime-api.d.ts +1 -1
  402. package/dist/extensions/imessage/api.d.ts +2 -2
  403. package/dist/extensions/imessage/api.js +2 -2
  404. package/dist/extensions/imessage/channel-plugin-api.d.ts +1 -1
  405. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  406. package/dist/extensions/imessage/index.d.ts +2 -2
  407. package/dist/extensions/imessage/message-tool-api.d.ts +1 -1
  408. package/dist/extensions/imessage/runtime-api.d.ts +3 -3
  409. package/dist/extensions/imessage/runtime-api.js +3 -3
  410. package/dist/extensions/imessage/setup-entry.d.ts +2 -2
  411. package/dist/extensions/imessage/test-api.d.ts +1 -1
  412. package/dist/extensions/inworld/index.d.ts +1 -1
  413. package/dist/extensions/inworld/speech-provider.d.ts +1 -1
  414. package/dist/extensions/irc/api.d.ts +1 -1
  415. package/dist/extensions/irc/api.js +2 -2
  416. package/dist/extensions/irc/channel-plugin-api.d.ts +1 -1
  417. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  418. package/dist/extensions/irc/index.d.ts +2 -2
  419. package/dist/extensions/irc/setup-entry.d.ts +2 -2
  420. package/dist/extensions/kilocode/index.d.ts +1 -1
  421. package/dist/extensions/kimi-coding/index.d.ts +1 -1
  422. package/dist/extensions/kimi-coding/stream.d.ts +1 -1
  423. package/dist/extensions/litellm/index.d.ts +1 -1
  424. package/dist/extensions/llm-task/api.d.ts +2 -2
  425. package/dist/extensions/llm-task/index.d.ts +1 -1
  426. package/dist/extensions/llm-task/index.js +1 -1
  427. package/dist/extensions/lmstudio/api.d.ts +1 -1
  428. package/dist/extensions/lmstudio/index.d.ts +1 -1
  429. package/dist/extensions/lmstudio/memory-embedding-adapter.d.ts +1 -1
  430. package/dist/extensions/mattermost/api.js +1 -1
  431. package/dist/extensions/mattermost/channel-plugin-api.d.ts +2 -2
  432. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  433. package/dist/extensions/mattermost/channel-plugin-runtime.d.ts +1 -1
  434. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  435. package/dist/extensions/mattermost/index.d.ts +2 -2
  436. package/dist/extensions/mattermost/policy-api.js +1 -1
  437. package/dist/extensions/mattermost/runtime-api.d.ts +3 -3
  438. package/dist/extensions/mattermost/runtime-api.js +2 -2
  439. package/dist/extensions/mattermost/setup-entry.d.ts +2 -2
  440. package/dist/extensions/mattermost/slash-route-api.d.ts +1 -1
  441. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  442. package/dist/extensions/memory-core/api.d.ts +1 -1
  443. package/dist/extensions/memory-core/cli-metadata.d.ts +1 -1
  444. package/dist/extensions/memory-core/cli-metadata.js +1 -1
  445. package/dist/extensions/memory-core/index.d.ts +1 -1
  446. package/dist/extensions/memory-core/manager-runtime.d.ts +1 -1
  447. package/dist/extensions/memory-core/runtime-api.d.ts +2 -2
  448. package/dist/extensions/memory-wiki/api.d.ts +3 -3
  449. package/dist/extensions/memory-wiki/cli-metadata.d.ts +1 -1
  450. package/dist/extensions/memory-wiki/index.d.ts +1 -1
  451. package/dist/extensions/memory-wiki/setup-api.d.ts +1 -1
  452. package/dist/extensions/microsoft/index.d.ts +1 -1
  453. package/dist/extensions/microsoft/speech-provider.d.ts +1 -1
  454. package/dist/extensions/microsoft/test-api.d.ts +1 -1
  455. package/dist/extensions/microsoft-foundry/auth.d.ts +1 -1
  456. package/dist/extensions/microsoft-foundry/cli.d.ts +1 -1
  457. package/dist/extensions/microsoft-foundry/index.d.ts +1 -1
  458. package/dist/extensions/microsoft-foundry/onboard.d.ts +3 -3
  459. package/dist/extensions/microsoft-foundry/provider.d.ts +1 -1
  460. package/dist/extensions/microsoft-foundry/runtime.d.ts +1 -1
  461. package/dist/extensions/microsoft-foundry/shared-runtime.d.ts +1 -1
  462. package/dist/extensions/microsoft-foundry/shared.d.ts +1 -1
  463. package/dist/extensions/migrate-claude/apply.d.ts +1 -1
  464. package/dist/extensions/migrate-claude/apply.js +1 -1
  465. package/dist/extensions/migrate-claude/config.d.ts +1 -1
  466. package/dist/extensions/migrate-claude/helpers.d.ts +1 -1
  467. package/dist/extensions/migrate-claude/index.d.ts +1 -1
  468. package/dist/extensions/migrate-claude/index.js +1 -1
  469. package/dist/extensions/migrate-claude/memory.d.ts +2 -2
  470. package/dist/extensions/migrate-claude/plan.d.ts +1 -1
  471. package/dist/extensions/migrate-claude/plan.js +1 -1
  472. package/dist/extensions/migrate-claude/provider.d.ts +1 -1
  473. package/dist/extensions/migrate-claude/provider.js +1 -1
  474. package/dist/extensions/migrate-claude/skills.d.ts +2 -2
  475. package/dist/extensions/migrate-claude/targets.d.ts +1 -1
  476. package/dist/extensions/migrate-claude/targets.js +1 -1
  477. package/dist/extensions/migrate-hermes/apply.d.ts +1 -1
  478. package/dist/extensions/migrate-hermes/apply.js +1 -1
  479. package/dist/extensions/migrate-hermes/config.d.ts +1 -1
  480. package/dist/extensions/migrate-hermes/helpers.d.ts +1 -1
  481. package/dist/extensions/migrate-hermes/index.d.ts +1 -1
  482. package/dist/extensions/migrate-hermes/index.js +1 -1
  483. package/dist/extensions/migrate-hermes/items.d.ts +1 -1
  484. package/dist/extensions/migrate-hermes/model.d.ts +1 -1
  485. package/dist/extensions/migrate-hermes/model.js +1 -1
  486. package/dist/extensions/migrate-hermes/plan.d.ts +1 -1
  487. package/dist/extensions/migrate-hermes/plan.js +1 -1
  488. package/dist/extensions/migrate-hermes/provider.d.ts +1 -1
  489. package/dist/extensions/migrate-hermes/provider.js +1 -1
  490. package/dist/extensions/migrate-hermes/secrets.d.ts +2 -2
  491. package/dist/extensions/migrate-hermes/secrets.js +1 -1
  492. package/dist/extensions/migrate-hermes/skills.d.ts +2 -2
  493. package/dist/extensions/migrate-hermes/targets.d.ts +1 -1
  494. package/dist/extensions/migrate-hermes/targets.js +1 -1
  495. package/dist/extensions/minimax/index.d.ts +1 -1
  496. package/dist/extensions/minimax/provider-contract-api.d.ts +1 -1
  497. package/dist/extensions/minimax/provider-registration.d.ts +1 -1
  498. package/dist/extensions/minimax/speech-provider.d.ts +1 -1
  499. package/dist/extensions/mistral/embedding-provider.d.ts +1 -1
  500. package/dist/extensions/mistral/index.d.ts +1 -1
  501. package/dist/extensions/mistral/memory-embedding-adapter.d.ts +1 -1
  502. package/dist/extensions/mistral/realtime-transcription-provider.d.ts +1 -1
  503. package/dist/extensions/mistral/test-api.d.ts +1 -1
  504. package/dist/extensions/moonshot/index.d.ts +1 -1
  505. package/dist/extensions/moonshot/provider-contract-api.d.ts +1 -1
  506. package/dist/extensions/moonshot/provider-discovery.d.ts +1 -1
  507. package/dist/extensions/nvidia/index.d.ts +1 -1
  508. package/dist/extensions/oc-path/cli-metadata.d.ts +1 -1
  509. package/dist/extensions/oc-path/cli-registration.d.ts +1 -1
  510. package/dist/extensions/oc-path/index.d.ts +1 -1
  511. package/dist/extensions/ollama/api.d.ts +1 -1
  512. package/dist/extensions/ollama/index.d.ts +1 -1
  513. package/dist/extensions/ollama/provider-discovery.d.ts +1 -1
  514. package/dist/extensions/ollama/provider-policy-api.d.ts +1 -1
  515. package/dist/extensions/ollama/runtime-api.d.ts +1 -1
  516. package/dist/extensions/open-prose/index.d.ts +1 -1
  517. package/dist/extensions/open-prose/runtime-api.d.ts +2 -2
  518. package/dist/extensions/openai/api.d.ts +4 -4
  519. package/dist/extensions/openai/embedding-batch.d.ts +1 -1
  520. package/dist/extensions/openai/embedding-provider.d.ts +1 -1
  521. package/dist/extensions/openai/index.d.ts +1 -1
  522. package/dist/extensions/openai/memory-embedding-adapter.d.ts +1 -1
  523. package/dist/extensions/openai/openai-codex-oauth.runtime.d.ts +1 -1
  524. package/dist/extensions/openai/openai-codex-provider.d.ts +1 -1
  525. package/dist/extensions/openai/openai-provider.d.ts +1 -1
  526. package/dist/extensions/openai/prompt-overlay.d.ts +1 -1
  527. package/dist/extensions/openai/provider-contract-api.d.ts +1 -1
  528. package/dist/extensions/openai/provider-policy-api.d.ts +1 -1
  529. package/dist/extensions/openai/realtime-transcription-provider.d.ts +1 -1
  530. package/dist/extensions/openai/realtime-voice-provider.d.ts +1 -1
  531. package/dist/extensions/openai/register.runtime.d.ts +6 -6
  532. package/dist/extensions/openai/replay-policy.d.ts +1 -1
  533. package/dist/extensions/openai/setup-api.d.ts +1 -1
  534. package/dist/extensions/openai/shared.d.ts +3 -3
  535. package/dist/extensions/openai/speech-provider.d.ts +1 -1
  536. package/dist/extensions/openai/test-api.d.ts +3 -3
  537. package/dist/extensions/openai/thinking-policy.d.ts +1 -1
  538. package/dist/extensions/openai/transport-policy.d.ts +1 -1
  539. package/dist/extensions/opencode/index.d.ts +1 -1
  540. package/dist/extensions/opencode/provider-policy-api.d.ts +1 -1
  541. package/dist/extensions/opencode-go/index.d.ts +1 -1
  542. package/dist/extensions/opencode-go/provider-catalog.d.ts +1 -1
  543. package/dist/extensions/opencode-go/stream.d.ts +1 -1
  544. package/dist/extensions/openrouter/api.d.ts +1 -1
  545. package/dist/extensions/openrouter/index.d.ts +1 -1
  546. package/dist/extensions/openrouter/provider-contract-api.d.ts +1 -1
  547. package/dist/extensions/openrouter/provider-policy-api.d.ts +1 -1
  548. package/dist/extensions/openrouter/speech-provider.d.ts +1 -1
  549. package/dist/extensions/openrouter/stream.d.ts +1 -1
  550. package/dist/extensions/openrouter/test-api.d.ts +1 -1
  551. package/dist/extensions/openrouter/thinking-policy.d.ts +1 -1
  552. package/dist/extensions/openrouter/video-generation-provider.d.ts +1 -1
  553. package/dist/extensions/openrouter/video-model-catalog.d.ts +1 -1
  554. package/dist/extensions/perplexity/index.d.ts +1 -1
  555. package/dist/extensions/phone-control/index.d.ts +1 -1
  556. package/dist/extensions/phone-control/runtime-api.d.ts +2 -2
  557. package/dist/extensions/policy/api.js +1 -1
  558. package/dist/extensions/policy/index.d.ts +1 -1
  559. package/dist/extensions/policy/index.js +2 -2
  560. package/dist/extensions/qianfan/index.d.ts +1 -1
  561. package/dist/extensions/qwen/api.d.ts +1 -1
  562. package/dist/extensions/qwen/index.d.ts +1 -1
  563. package/dist/extensions/qwen/stream.d.ts +1 -1
  564. package/dist/extensions/runway/index.d.ts +1 -1
  565. package/dist/extensions/searxng/index.d.ts +1 -1
  566. package/dist/extensions/senseaudio/index.d.ts +1 -1
  567. package/dist/extensions/sglang/index.d.ts +1 -1
  568. package/dist/extensions/signal/api.d.ts +2 -2
  569. package/dist/extensions/signal/api.js +6 -6
  570. package/dist/extensions/signal/channel-entry.d.ts +2 -2
  571. package/dist/extensions/signal/channel-plugin-api.d.ts +1 -1
  572. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  573. package/dist/extensions/signal/index.d.ts +2 -2
  574. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  575. package/dist/extensions/signal/runtime-api.d.ts +5 -5
  576. package/dist/extensions/signal/runtime-api.js +7 -7
  577. package/dist/extensions/signal/setup-entry.d.ts +2 -2
  578. package/dist/extensions/skill-workshop/api.d.ts +2 -2
  579. package/dist/extensions/skill-workshop/api.js +1 -1
  580. package/dist/extensions/skill-workshop/index.d.ts +1 -1
  581. package/dist/extensions/skill-workshop/index.js +2 -2
  582. package/dist/extensions/speech-core/api.d.ts +3 -3
  583. package/dist/extensions/speech-core/runtime-api.d.ts +2 -2
  584. package/dist/extensions/stepfun/index.d.ts +1 -1
  585. package/dist/extensions/synthetic/index.d.ts +1 -1
  586. package/dist/extensions/talk-voice/api.d.ts +2 -2
  587. package/dist/extensions/talk-voice/index.d.ts +1 -1
  588. package/dist/extensions/tavily/index.d.ts +1 -1
  589. package/dist/extensions/telegram/account-inspect-api.js +1 -1
  590. package/dist/extensions/telegram/api.d.ts +4 -4
  591. package/dist/extensions/telegram/api.js +11 -11
  592. package/dist/extensions/telegram/channel-plugin-api.d.ts +2 -2
  593. package/dist/extensions/telegram/channel-plugin-api.js +2 -2
  594. package/dist/extensions/telegram/contract-api.d.ts +1 -1
  595. package/dist/extensions/telegram/contract-api.js +3 -3
  596. package/dist/extensions/telegram/index.d.ts +2 -2
  597. package/dist/extensions/telegram/runtime-api.d.ts +4 -4
  598. package/dist/extensions/telegram/runtime-api.js +7 -7
  599. package/dist/extensions/telegram/security-audit-contract-api.js +1 -1
  600. package/dist/extensions/telegram/setup-entry.d.ts +2 -2
  601. package/dist/extensions/telegram/setup-plugin-api.d.ts +1 -1
  602. package/dist/extensions/telegram/setup-plugin-api.js +1 -1
  603. package/dist/extensions/telegram/test-api.js +2 -2
  604. package/dist/extensions/tencent/index.d.ts +1 -1
  605. package/dist/extensions/tencent/provider-discovery.d.ts +1 -1
  606. package/dist/extensions/thread-ownership/api.d.ts +2 -2
  607. package/dist/extensions/thread-ownership/index.d.ts +1 -1
  608. package/dist/extensions/together/index.d.ts +1 -1
  609. package/dist/extensions/tokenjuice/index.d.ts +1 -1
  610. package/dist/extensions/tokenjuice/tool-result-middleware.d.ts +1 -1
  611. package/dist/extensions/tts-local-cli/index.d.ts +1 -1
  612. package/dist/extensions/tts-local-cli/speech-provider.d.ts +1 -1
  613. package/dist/extensions/venice/index.d.ts +1 -1
  614. package/dist/extensions/venice/stream.d.ts +1 -1
  615. package/dist/extensions/vercel-ai-gateway/index.d.ts +1 -1
  616. package/dist/extensions/vercel-ai-gateway/thinking.d.ts +1 -1
  617. package/dist/extensions/video-generation-core/api.d.ts +2 -2
  618. package/dist/extensions/video-generation-core/runtime-api.d.ts +1 -1
  619. package/dist/extensions/vllm/api.d.ts +1 -1
  620. package/dist/extensions/vllm/index.d.ts +1 -1
  621. package/dist/extensions/vllm/stream.d.ts +1 -1
  622. package/dist/extensions/volcengine/index.d.ts +1 -1
  623. package/dist/extensions/volcengine/provider-discovery.d.ts +1 -1
  624. package/dist/extensions/volcengine/speech-provider.d.ts +1 -1
  625. package/dist/extensions/voyage/embedding-batch.d.ts +1 -1
  626. package/dist/extensions/voyage/embedding-provider.d.ts +1 -1
  627. package/dist/extensions/voyage/index.d.ts +1 -1
  628. package/dist/extensions/voyage/memory-embedding-adapter.d.ts +1 -1
  629. package/dist/extensions/vydra/index.d.ts +1 -1
  630. package/dist/extensions/vydra/speech-provider.d.ts +1 -1
  631. package/dist/extensions/web-readability/index.d.ts +1 -1
  632. package/dist/extensions/webhooks/api.d.ts +2 -2
  633. package/dist/extensions/webhooks/api.js +1 -1
  634. package/dist/extensions/webhooks/index.d.ts +1 -1
  635. package/dist/extensions/webhooks/index.js +1 -1
  636. package/dist/extensions/webhooks/runtime-api.d.ts +1 -1
  637. package/dist/extensions/xai/api.d.ts +1 -1
  638. package/dist/extensions/xai/index.d.ts +1 -1
  639. package/dist/extensions/xai/index.js +4 -4
  640. package/dist/extensions/xai/provider-contract-api.d.ts +1 -1
  641. package/dist/extensions/xai/provider-discovery.d.ts +1 -1
  642. package/dist/extensions/xai/provider-models.d.ts +1 -1
  643. package/dist/extensions/xai/provider-policy-api.d.ts +1 -1
  644. package/dist/extensions/xai/realtime-transcription-provider.d.ts +1 -1
  645. package/dist/extensions/xai/realtime-transcription-provider.js +1 -1
  646. package/dist/extensions/xai/setup-api.d.ts +1 -1
  647. package/dist/extensions/xai/speech-provider.d.ts +1 -1
  648. package/dist/extensions/xai/speech-provider.js +1 -1
  649. package/dist/extensions/xai/stream.d.ts +1 -1
  650. package/dist/extensions/xai/test-api.js +1 -1
  651. package/dist/extensions/xai/tts.js +1 -1
  652. package/dist/extensions/xai/web-search.js +1 -1
  653. package/dist/extensions/xai/xai-oauth.d.ts +1 -1
  654. package/dist/extensions/xai/xai-oauth.js +1 -1
  655. package/dist/extensions/xiaomi/index.d.ts +1 -1
  656. package/dist/extensions/xiaomi/speech-provider.d.ts +1 -1
  657. package/dist/extensions/xiaomi/stream.d.ts +1 -1
  658. package/dist/extensions/xiaomi/thinking.d.ts +1 -1
  659. package/dist/extensions/zai/index.d.ts +1 -1
  660. package/dist/file-fetch-tool-6M7otZWJ.js +124 -0
  661. package/dist/file-write-tool-C7sxNalS.js +127 -0
  662. package/dist/format-BaYeBN8g.js +1145 -0
  663. package/dist/format-Gd-3cUBL.js +250 -0
  664. package/dist/gateway/protocol/index.d.ts +1 -1
  665. package/dist/gateway-cli-Do3zXVoA.js +435 -0
  666. package/dist/gateway-method-runtime-3Bh2bCrI.js +21 -0
  667. package/dist/gateway-runtime-COtKzRqi.d.ts +163 -0
  668. package/dist/gemini-cli-provider-BQgviROv.d.ts +6 -0
  669. package/dist/get-reply-fC2lq4Bn.js +4689 -0
  670. package/dist/get-reply-from-config.runtime-BPyCiEfV.js +2 -0
  671. package/dist/get-reply-from-config.runtime.js +1 -1
  672. package/dist/graph-users-CJlHYK21.js +1419 -0
  673. package/dist/group-access-DOGbhNxW.js +112 -0
  674. package/dist/handle-action.guild-admin-CdoddJ3u.js +288 -0
  675. package/dist/harness-B-nCy5CA.js +61 -0
  676. package/dist/health-DTO8sQYx.js +4 -0
  677. package/dist/health-state-D8_oJguq.js +106 -0
  678. package/dist/heartbeat-runner-CyGiZsj3.js +5 -0
  679. package/dist/heartbeat-runner.runtime-D1dYoxzx.js +4 -0
  680. package/dist/heartbeat-runner.runtime.js +1 -1
  681. package/dist/hooks-DlPF6dZs.js +534 -0
  682. package/dist/http-registry-Yo_NvKls.d.ts +23 -0
  683. package/dist/image-generation-runtime-BIAvq6jv.d.ts +21 -0
  684. package/dist/inbound-direct-dm-runtime-DAejzdQq.js +2 -0
  685. package/dist/inbound-reply-dispatch-ccCfh5JF.js +148 -0
  686. package/dist/index-7GMgTC5k.d.ts +3971 -0
  687. package/dist/index.js +1 -1
  688. package/dist/init-DzayFaI9.js +59 -0
  689. package/dist/inline-buttons-6SL2p5Vu.js +40 -0
  690. package/dist/interactive-dispatch-ChuCQxzf.d.ts +56 -0
  691. package/dist/interactive-dispatch-DY_jVu-V.d.ts +143 -0
  692. package/dist/internal-events-CAA5utUP.js +90 -0
  693. package/dist/isolated-agent-B95d6tII.js +2 -0
  694. package/dist/isolated-agent-BAkur-kh.js +1118 -0
  695. package/dist/lifecycle-OYEvGSs_.js +571 -0
  696. package/dist/list.probe-D6_5AksK.js +449 -0
  697. package/dist/list.status-command-f0dAuxjW.js +789 -0
  698. package/dist/llm-slug-generator-DzjXXHiO.js +78 -0
  699. package/dist/llm-slug-generator.js +1 -1
  700. package/dist/loader-C-JyPvyF.d.ts +142 -0
  701. package/dist/local-dispatch.runtime-DE2f2WAa.js +9 -0
  702. package/dist/local-dispatch.runtime.js +1 -1
  703. package/dist/manager-CknaUr2b.d.ts +356 -0
  704. package/dist/manager.runtime-DoBAFZ8r.js +2714 -0
  705. package/dist/manager.runtime.js +1 -1
  706. package/dist/markdown-to-line-DTEs6hVv.js +811 -0
  707. package/dist/mcp-http-CgKbc-pc.js +555 -0
  708. package/dist/mcp-http-x6Cwd0Yu.js +2 -0
  709. package/dist/media-understanding-provider-Bt2HA6p3.js +339 -0
  710. package/dist/memory-core-host-engine-storage-izjrNFNA.d.ts +54 -0
  711. package/dist/memory-embedding-adapter-B3WLPdKc.d.ts +5 -0
  712. package/dist/message-actions-B7JwvxAS.js +145 -0
  713. package/dist/message-handler-BmkNxRDD.js +384 -0
  714. package/dist/message-handler-BsTTww09.js +1715 -0
  715. package/dist/message-handler.preflight-UPPmUa3q.js +1125 -0
  716. package/dist/message-handler.process-D0yb6UtD.js +1484 -0
  717. package/dist/migration-DVKbowM8.d.ts +45 -0
  718. package/dist/model-BSBoLWjJ.d.ts +33 -0
  719. package/dist/model-j0YMhzJy.js +74 -0
  720. package/dist/model-selection-26YSj6pz.js +272 -0
  721. package/dist/models-BWABpoiz.js +104 -0
  722. package/dist/models-BvEw11kE.d.ts +24 -0
  723. package/dist/models-K85k5nnr.js +2 -0
  724. package/dist/models-cli-C7bbgiRD.js +256 -0
  725. package/dist/monitor-B6yOuR2r.js +834 -0
  726. package/dist/monitor-CIFjlXVi.js +60 -0
  727. package/dist/monitor-CWaPk_7V.js +1370 -0
  728. package/dist/monitor-Cs9Lo6bb.js +715 -0
  729. package/dist/monitor-DC_WFeow.js +4377 -0
  730. package/dist/monitor-Db2Zsmky.js +2788 -0
  731. package/dist/monitor-ZJLxyo1m.js +1657 -0
  732. package/dist/monitor-auth-9lbTrakT.js +179 -0
  733. package/dist/monitor-gMuNdFNL.js +2 -0
  734. package/dist/monitor-polling.runtime-rd2B_RoJ.js +883 -0
  735. package/dist/monitor-polling.runtime.js +1 -1
  736. package/dist/monitor-webhook.runtime-YytBaFht.js +387 -0
  737. package/dist/monitor-webhook.runtime.js +1 -1
  738. package/dist/monitor.account-CSzuEIqT.js +5233 -0
  739. package/dist/monitor.runtime-BiN5yYq0.js +2 -0
  740. package/dist/monitor.runtime.js +1 -1
  741. package/dist/monitor.webhook-DK1oH0sg.js +180 -0
  742. package/dist/node-cli-sessions-CRp1n9U4.js +1228 -0
  743. package/dist/openai-codex-provider-C48t8ka8.d.ts +5 -0
  744. package/dist/openai-http-qVcPqpQN.js +824 -0
  745. package/dist/openai-provider-Df75q4KM.d.ts +5 -0
  746. package/dist/openresponses-http-BxeU2OF4.js +1173 -0
  747. package/dist/operations-Pr0GlIYC.js +805 -0
  748. package/dist/outbound-adapter-BaBC-WXA.js +543 -0
  749. package/dist/outbound-session-route-51WiyntM.js +45 -0
  750. package/dist/outbound.runtime-Drn1outO.js +2 -0
  751. package/dist/outbound.runtime.js +1 -1
  752. package/dist/pi-embedded-B2Z84wpp.js +3796 -0
  753. package/dist/pi-embedded-WaRss8a7.js +4 -0
  754. package/dist/pi-embedded.runtime-BXtJQU5L.js +4 -0
  755. package/dist/pi-embedded.runtime.js +1 -1
  756. package/dist/pi-tools--L-L_5qV.js +2413 -0
  757. package/dist/plan-C9P_Zx9I.js +81 -0
  758. package/dist/plan-DvGesBjU.js +112 -0
  759. package/dist/plugin-C946oTpr.js +12396 -0
  760. package/dist/plugin-DMYsMKAW.d.ts +17 -0
  761. package/dist/plugin-app-cache-key-CA3Fk_MS.js +46 -0
  762. package/dist/plugin-enabled-Dl21DFci.js +233 -0
  763. package/dist/plugin-entry-DwVZtdM9.d.ts +47 -0
  764. package/dist/plugin-registration-M8OrW2uL.js +88 -0
  765. package/dist/plugin-runtime-Dx9WRWX8.d.ts +117 -0
  766. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  767. package/dist/plugin-sdk/acp-runtime-backend.js +1 -1
  768. package/dist/plugin-sdk/acp-runtime.js +2 -2
  769. package/dist/plugin-sdk/agent-harness-runtime.js +6 -6
  770. package/dist/plugin-sdk/agent-harness-task-runtime.js +1 -1
  771. package/dist/plugin-sdk/agent-harness.js +7 -7
  772. package/dist/plugin-sdk/agent-runtime.js +2 -2
  773. package/dist/plugin-sdk/channel-core.js +2 -2
  774. package/dist/plugin-sdk/channel-inbound.js +2 -2
  775. package/dist/plugin-sdk/channel-test-helpers.js +1 -1
  776. package/dist/plugin-sdk/command-auth.js +1 -1
  777. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  778. package/dist/plugin-sdk/compat.js +1 -1
  779. package/dist/plugin-sdk/conversation-binding-runtime.js +2 -2
  780. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  781. package/dist/plugin-sdk/core.js +2 -2
  782. package/dist/plugin-sdk/direct-dm.js +1 -1
  783. package/dist/plugin-sdk/gateway-method-runtime.js +1 -1
  784. package/dist/plugin-sdk/health.js +2 -2
  785. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  786. package/dist/plugin-sdk/index.js +1 -1
  787. package/dist/plugin-sdk/mattermost.js +1 -1
  788. package/dist/plugin-sdk/plugin-test-contracts.js +2 -2
  789. package/dist/plugin-sdk/provider-test-contracts.js +4 -4
  790. package/dist/plugin-sdk/reply-runtime.js +4 -4
  791. package/dist/plugin-sdk/testing.js +2 -2
  792. package/dist/plugin-sdk/zalouser.js +1 -1
  793. package/dist/plugin-service-Dii4hVsM.js +1229 -0
  794. package/dist/plugin-service-mHunWjlo.d.ts +24 -0
  795. package/dist/plugins/build-smoke-entry.d.ts +2 -2
  796. package/dist/plugins/loader.d.ts +1 -1
  797. package/dist/plugins/provider-discovery.runtime.d.ts +1 -1
  798. package/dist/plugins/provider-runtime.runtime.d.ts +1 -1
  799. package/dist/plugins/runtime/index.js +4 -4
  800. package/dist/policy-BK63POC5.js +138 -0
  801. package/dist/policy-BVF5IwsA.js +680 -0
  802. package/dist/postinstall-inventory.json +600 -600
  803. package/dist/prepare.runtime-C4MmUS7q.js +732 -0
  804. package/dist/prepare.runtime.js +1 -1
  805. package/dist/preview-warnings-BzWg6XZO.js +392 -0
  806. package/dist/probe-BlRrdfJI.js +47 -0
  807. package/dist/probe-BmRhtWLq.js +2204 -0
  808. package/dist/probe-DM8yRYcU.js +2 -0
  809. package/dist/probe-ejeGnKS6.js +682 -0
  810. package/dist/program-BBjSDxOK.js +131 -0
  811. package/dist/prompt-overlay-D0r0EA6z.d.ts +23 -0
  812. package/dist/provider-BQqi3nak.js +8735 -0
  813. package/dist/provider-CAW13htM.js +32 -0
  814. package/dist/provider-DToIle9H.js +152 -0
  815. package/dist/provider-api-key-auth-2Fp25hP8.d.ts +27 -0
  816. package/dist/provider-auth-result-mIg6RY-l.d.ts +21 -0
  817. package/dist/provider-catalog-runtime-B7e02aat.d.ts +23 -0
  818. package/dist/provider-catalog-shared-D0mIMF1C.d.ts +62 -0
  819. package/dist/provider-dispatcher-DqZ7i_rd.js +22 -0
  820. package/dist/provider-dispatcher.runtime.js +1 -1
  821. package/dist/provider-hook-runtime-CrtHxgL6.d.ts +61 -0
  822. package/dist/provider-model-shared-BESf3jvo.d.ts +143 -0
  823. package/dist/provider-models-B6wofKVD.d.ts +12 -0
  824. package/dist/provider-policy-0JjxJfxh.d.ts +30 -0
  825. package/dist/provider-qnh6YFNd.js +32 -0
  826. package/dist/provider-registration-O7mvATZX.d.ts +6 -0
  827. package/dist/provider-registry-CtFVQxwM.d.ts +8 -0
  828. package/dist/provider-registry-DZxCJHb2.d.ts +8 -0
  829. package/dist/provider-registry-DcUASGbX.d.ts +30 -0
  830. package/dist/provider-runtime-CrrstiDP.d.ts +359 -0
  831. package/dist/provider-self-hosted-setup-DKlGE8A7.d.ts +74 -0
  832. package/dist/provider-session.runtime-DMjJXSkF.js +9 -0
  833. package/dist/provider-session.runtime.js +1 -1
  834. package/dist/provider-stream-C2vPdKh5.d.ts +140 -0
  835. package/dist/provider-stream-shared-CslVTt39.d.ts +128 -0
  836. package/dist/provider.runtime-D4ZzNUfo.js +2 -0
  837. package/dist/provider.runtime.js +1 -1
  838. package/dist/providers.runtime-CHPPEG1J.d.ts +25 -0
  839. package/dist/public-surface-loader-COAaBDuY.js +114 -0
  840. package/dist/pw-ai-4Dk5FtCe.js +3029 -0
  841. package/dist/pw-role-snapshot-CuQzm5NK.js +333 -0
  842. package/dist/reaction-level-ZgH5HPmP.js +19 -0
  843. package/dist/reaction-runtime-api-lrZlU8Ab.js +116 -0
  844. package/dist/realtime-transcription-Brox5yj7.d.ts +43 -0
  845. package/dist/realtime-transcription-provider-Ai-XHtXs.js +205 -0
  846. package/dist/realtime-transcription-provider-B9DWwCuO.d.ts +32 -0
  847. package/dist/realtime-transcription-provider-CGhoGie3.d.ts +28 -0
  848. package/dist/realtime-transcription-provider-Dau7Zk9V.d.ts +37 -0
  849. package/dist/realtime-transcription-provider-WgtPbRJc.d.ts +5 -0
  850. package/dist/realtime-voice-C5Xiylos.d.ts +333 -0
  851. package/dist/realtime-voice-provider-DUPM9wyW.d.ts +5 -0
  852. package/dist/register-CDhBb-x0.js +2178 -0
  853. package/dist/register.agent-DBiFgnVA.js +156 -0
  854. package/dist/register.crestodian-BxWP7RD3.js +24 -0
  855. package/dist/register.maintenance-CnCvd-hk.js +83 -0
  856. package/dist/register.runtime-BcgdXzLA.d.ts +6 -0
  857. package/dist/register.runtime-CihNYXEU.js +54 -0
  858. package/dist/register.status-health-sessions-B0aNyEHy.js +282 -0
  859. package/dist/register.subclis-CLGUU8xn.js +31 -0
  860. package/dist/register.subclis-DwHGcc-o.js +3 -0
  861. package/dist/register.subclis-core-BtmmMq6c.js +273 -0
  862. package/dist/registry-DnnBulh_.d.ts +91 -0
  863. package/dist/registry-types-BQ26lhRo.d.ts +392 -0
  864. package/dist/repair-sequencing-BjZ6HdVL.js +640 -0
  865. package/dist/reply-delivery-7xtGUhB9.js +196 -0
  866. package/dist/reply-runtime-Bts14dIE.js +11 -0
  867. package/dist/reply.runtime-BPyCiEfV.js +2 -0
  868. package/dist/reply.runtime.js +1 -1
  869. package/dist/request-CXg-P0JT.js +54 -0
  870. package/dist/resolve-allowlist-DFQmlgMw.js +220 -0
  871. package/dist/result-fallback-classifier-zyED1xtr.js +79 -0
  872. package/dist/route-C_y4jDQj.js +469 -0
  873. package/dist/route-resolution-Ds3w61Lx.js +274 -0
  874. package/dist/routes-CTG90Mv3.js +2 -0
  875. package/dist/routes-CxTVR0cX.js +3602 -0
  876. package/dist/run-DkpOzywN.js +1162 -0
  877. package/dist/run-attempt-C8drUXdL.js +7704 -0
  878. package/dist/run-command-BFRAg7du.js +23 -0
  879. package/dist/run-command-DdJMIAJV.js +2 -0
  880. package/dist/run-embedded.runtime-LQMkpF2y.js +4 -0
  881. package/dist/run-embedded.runtime.js +1 -1
  882. package/dist/run-execution-cli.runtime-0FeH38Px.js +4 -0
  883. package/dist/run-execution-cli.runtime.js +1 -1
  884. package/dist/run-executor.runtime.js +1 -1
  885. package/dist/run-subagent-registry.runtime-DpPQTC66.js +2 -0
  886. package/dist/run-subagent-registry.runtime.js +1 -1
  887. package/dist/runtime-B3ogObAE.js +438 -0
  888. package/dist/runtime-CPmMLEBj.js +1287 -0
  889. package/dist/runtime-CiJ6IGJc.js +6179 -0
  890. package/dist/runtime-api-BIeJjKVB.js +13 -0
  891. package/dist/runtime-api-BWSHkISv.js +3 -0
  892. package/dist/runtime-api-C2HmJspc.js +13 -0
  893. package/dist/runtime-api-C4WThy-0.js +24 -0
  894. package/dist/runtime-api-CTym-WGW.js +21 -0
  895. package/dist/runtime-api-QSTydHlX.js +17 -0
  896. package/dist/runtime-api-XBWYmn8F.js +4 -0
  897. package/dist/runtime-api.actions-bGxji7I2.js +3 -0
  898. package/dist/runtime-api.monitor-5-ucdxYA.d.ts +3757 -0
  899. package/dist/runtime-api.monitor-e7p7IfH1.js +6 -0
  900. package/dist/runtime-api.send-BttKZW-F.d.ts +38 -0
  901. package/dist/runtime-api.send-COhoRdi6.js +4 -0
  902. package/dist/runtime-api.threads-DFYlu1e-.js +2 -0
  903. package/dist/runtime-channel-CUJifY4W.js +2 -0
  904. package/dist/runtime-channel-CZWoqFu0.js +150 -0
  905. package/dist/runtime-embedded-pi.runtime-BIxr-MBr.js +2 -0
  906. package/dist/runtime-embedded-pi.runtime.js +1 -1
  907. package/dist/runtime-taskflow-Co1PrqbP.d.ts +435 -0
  908. package/dist/sanitize-outbound-DS3EW4FZ.js +127 -0
  909. package/dist/sdk-setup-tools-Dbu0ISil.js +8 -0
  910. package/dist/secrets-B2FsNqik.js +113 -0
  911. package/dist/security-audit-7dSJt583.js +118 -0
  912. package/dist/security-audit-C7nv2f1p.js +122 -0
  913. package/dist/security-audit.runtime-BjFxH4oO.js +2 -0
  914. package/dist/security-audit.runtime.js +1 -1
  915. package/dist/selection-CNuMWlGI.js +3 -0
  916. package/dist/selection-DSrTbfdV.js +16157 -0
  917. package/dist/send-Bt7s80wR.js +143 -0
  918. package/dist/send-CinwCGAp.js +1631 -0
  919. package/dist/send-Dhc5pazQ.js +192 -0
  920. package/dist/send-Dz6aPmRx.js +2 -0
  921. package/dist/send.components-C6Vc715w.js +2 -0
  922. package/dist/send.components-CZQvbNpy.js +500 -0
  923. package/dist/send.runtime-DjcCJNHz.js +2 -0
  924. package/dist/send.runtime.js +1 -1
  925. package/dist/server-C7zyrFv9.js +73 -0
  926. package/dist/server-DP_Qxv9p.js +24 -0
  927. package/dist/server-close.runtime.d.ts +1 -1
  928. package/dist/server-close.runtime.js +1 -1
  929. package/dist/server-context-9btqwxTM.js +2 -0
  930. package/dist/server-context-BWN2z4-J.js +955 -0
  931. package/dist/server-cron-ClWdOpAE.js +2989 -0
  932. package/dist/server-cron-DUfOPQkW.js +2 -0
  933. package/dist/server-maintenance-B4tgrBO5.js +167 -0
  934. package/dist/server-methods-BM3XCIWG.js +16494 -0
  935. package/dist/server-node-events-BUL_qMQZ.js +596 -0
  936. package/dist/server-plugin-bootstrap-D8ECRLtf.js +70 -0
  937. package/dist/server-plugins-ClApYARY.js +432 -0
  938. package/dist/server-reload-handlers-BsTBOEdp.js +714 -0
  939. package/dist/server-restart-sentinel-7LRUDz6N.js +2 -0
  940. package/dist/server-restart-sentinel-DTf-yNzJ.js +747 -0
  941. package/dist/server-runtime-services-3hlgWAb8.js +2 -0
  942. package/dist/server-runtime-services-D4epI5_k.js +267 -0
  943. package/dist/server-startup-early-C_ZWIblP.js +87 -0
  944. package/dist/server-startup-plugins-v2iGMqTe.js +113 -0
  945. package/dist/server-startup-post-attach-CNe0QrNc.js +716 -0
  946. package/dist/server-ws-runtime-hH14LVjT.js +349 -0
  947. package/dist/server.impl-VrV1FexC.js +2586 -0
  948. package/dist/service-CLQYUJAj.js +1446 -0
  949. package/dist/session-binding-B8dvxX2y.js +2 -0
  950. package/dist/session-binding-C2GrKek4.js +219 -0
  951. package/dist/session-kill-http-hFb4-8bg.js +121 -0
  952. package/dist/session-reset-service-CnDZw4-5.js +625 -0
  953. package/dist/session-route-D1tSy-VJ.js +93 -0
  954. package/dist/session-status.runtime-BdpmXmcH.js +2 -0
  955. package/dist/session-status.runtime.js +1 -1
  956. package/dist/session-subagent-reactivation.runtime-DUrd5FpN.js +2 -0
  957. package/dist/session-subagent-reactivation.runtime.js +1 -1
  958. package/dist/session-tab-registry-DRhbHQEm.js +521 -0
  959. package/dist/sessions-history-http-D2K0mGDk.js +430 -0
  960. package/dist/sessions.runtime-CfWr4fEQ.js +2 -0
  961. package/dist/sessions.runtime.js +1 -1
  962. package/dist/setup-api-COkXH76p.js +29 -0
  963. package/dist/setup-core-BdWBmyOC.js +174 -0
  964. package/dist/setup-surface-BV6Wc_S1.js +405 -0
  965. package/dist/setup-surface-CXqLNgjz.js +221 -0
  966. package/dist/setup-surface-Dl-mS95G.js +288 -0
  967. package/dist/setup-surface-Dn-hYgTO.js +320 -0
  968. package/dist/shared-2-FiBN51.d.ts +115 -0
  969. package/dist/shared-client-BAvec-HA.js +2 -0
  970. package/dist/shared-client-Bk01En7M.js +629 -0
  971. package/dist/shared-soPxo6JL.js +121 -0
  972. package/dist/side-question-BAXAMJru.js +683 -0
  973. package/dist/simple-completion-runtime-JMnVclQ6.d.ts +73 -0
  974. package/dist/skill-tool-dispatch.runtime-DaMjMQII.js +143 -0
  975. package/dist/skill-tool-dispatch.runtime.js +1 -1
  976. package/dist/slash-state-BZ06y0To.js +2166 -0
  977. package/dist/speech-CmQkc7zi.d.ts +47 -0
  978. package/dist/speech-core-CVkLGUxG.d.ts +36 -0
  979. package/dist/speech-provider-B73iu4fH.d.ts +5 -0
  980. package/dist/speech-provider-BEBH8vyF.d.ts +34 -0
  981. package/dist/speech-provider-BhCRdoMK.d.ts +8 -0
  982. package/dist/speech-provider-Cf1PVMAj.d.ts +8 -0
  983. package/dist/speech-provider-DdEPWhuR.d.ts +5 -0
  984. package/dist/speech-provider-DwB37Ie_.js +184 -0
  985. package/dist/speech-provider-ECom8JiZ.d.ts +5 -0
  986. package/dist/src-BsqijqVt.js +4256 -0
  987. package/dist/startup-context-CFODg9YM.js +313 -0
  988. package/dist/status-D3n01dp5.js +4 -0
  989. package/dist/status-DbZB702Q.js +3 -0
  990. package/dist/status-all-CCV1CGJz.js +573 -0
  991. package/dist/status-json-DZAKQD2Y.js +14 -0
  992. package/dist/status-json-command-BSE_pTG-.js +84 -0
  993. package/dist/status-runtime-shared-CKt3t6sE.js +283 -0
  994. package/dist/status-subagents.runtime-YuzmENDp.js +18 -0
  995. package/dist/status-subagents.runtime.js +1 -1
  996. package/dist/status-text-D9Zi8UnO.js +296 -0
  997. package/dist/status.command-CBTSvOW1.js +420 -0
  998. package/dist/status.command-CBnJpuXq.js +2 -0
  999. package/dist/status.command.text-runtime-VNORbsBS.js +15 -0
  1000. package/dist/status.scan-BMinf8AZ.js +68 -0
  1001. package/dist/status.scan-overview-B6kfuktS.js +444 -0
  1002. package/dist/status.scan.fast-json-CRT_aiEX.js +2 -0
  1003. package/dist/status.scan.fast-json-DmoXxjwC.js +127 -0
  1004. package/dist/status.scan.runtime-mccN052p.js +479 -0
  1005. package/dist/status.scan.runtime.js +1 -1
  1006. package/dist/status.update-DAbNKHAA.js +86 -0
  1007. package/dist/status.update-Dj_UDfud.js +2 -0
  1008. package/dist/sticker-cache-B_K5GK1F.js +206 -0
  1009. package/dist/sticker-vision.runtime-CLXVetAJ.js +17 -0
  1010. package/dist/sticker-vision.runtime.js +1 -1
  1011. package/dist/stream-CYHgCxMh.d.ts +5 -0
  1012. package/dist/stream-D8Ytt_tB.d.ts +120 -0
  1013. package/dist/stream-DX9I-gkW.d.ts +19 -0
  1014. package/dist/stream-DjL6Gw2C.d.ts +16 -0
  1015. package/dist/stream-m7GKt3W2.d.ts +10 -0
  1016. package/dist/stream-wrappers-UyEQes6p.d.ts +21 -0
  1017. package/dist/subagent-announce-CYVKLzpF.js +354 -0
  1018. package/dist/subagent-announce-delivery-DGlpzYtu.js +958 -0
  1019. package/dist/subagent-control-DdpvJydn.js +508 -0
  1020. package/dist/subagent-hooks-CJ38n1yI.js +116 -0
  1021. package/dist/subagent-hooks-CM8d7uom.js +230 -0
  1022. package/dist/subagent-hooks-CWXgYgeR.js +2 -0
  1023. package/dist/subagent-hooks-ChZlZfOE.js +146 -0
  1024. package/dist/subagent-hooks-CsHFqBnn.js +2 -0
  1025. package/dist/subagent-hooks-J6Z1owZi.js +2 -0
  1026. package/dist/subagent-hooks-api-C6FcvHTT.js +23 -0
  1027. package/dist/subagent-hooks-api-Cjv3KxcX.js +23 -0
  1028. package/dist/subagent-hooks-api-DWfQ0N2_.js +22 -0
  1029. package/dist/subagent-orphan-recovery-C2iu65pp.js +352 -0
  1030. package/dist/subagent-registry-C__l22X7.js +2351 -0
  1031. package/dist/subagent-registry-DsGh1uuc.js +3 -0
  1032. package/dist/subagent-registry.runtime.js +1 -1
  1033. package/dist/subagent-session-cleanup-BJK0KFuz.js +525 -0
  1034. package/dist/subagent-spawn-xX_hbBgM.js +1164 -0
  1035. package/dist/target-id-BcuunvtM.js +107 -0
  1036. package/dist/targets-BgRpAISD.js +19 -0
  1037. package/dist/targets-BynqpysF.js +19 -0
  1038. package/dist/targets-D-0Biv4s.d.ts +10 -0
  1039. package/dist/targets-S-Pmze3w.d.ts +10 -0
  1040. package/dist/targets-noUOYK7d.js +44 -0
  1041. package/dist/task-registry-control.runtime.js +1 -1
  1042. package/dist/telegram/token.js +1 -1
  1043. package/dist/testing-B0wf2Ir6.js +267 -0
  1044. package/dist/text-report-DK79dOC4.js +695 -0
  1045. package/dist/thinking-policy-B31-nCQk.d.ts +5 -0
  1046. package/dist/thread-bindings-BQal3jZo.js +8 -0
  1047. package/dist/thread-bindings-BfMLiM2l.js +228 -0
  1048. package/dist/thread-bindings-DJ8RMaTI.js +571 -0
  1049. package/dist/thread-bindings-nJ5yQbn5.js +232 -0
  1050. package/dist/thread-bindings.discord-api-Cy9zlCKJ.js +187 -0
  1051. package/dist/thread-bindings.manager-BN6EeBr_.js +536 -0
  1052. package/dist/thread-bindings.manager-REfgswjE.js +2 -0
  1053. package/dist/thread-lifecycle-Di28EHnZ.js +1614 -0
  1054. package/dist/token-CkH7nFWY.js +134 -0
  1055. package/dist/tool-DqzQ3obs.js +139 -0
  1056. package/dist/tool-actions.runtime--jhK-xmj.js +534 -0
  1057. package/dist/tool-actions.runtime.js +1 -1
  1058. package/dist/tool-plugin-B9aQw4fj.d.ts +77 -0
  1059. package/dist/tool-resolution-D1-4S4j9.js +149 -0
  1060. package/dist/tool-split-zov3PauL.d.ts +19 -0
  1061. package/dist/tools-effective-inventory-JOMz2Ra6.js +204 -0
  1062. package/dist/tools-invoke-http-C9N441MA.js +67 -0
  1063. package/dist/tools-invoke-shared-DfSLo2Tr.js +200 -0
  1064. package/dist/transport-stream-3OMu_lV2.d.ts +42 -0
  1065. package/dist/tts-DAeWj9Bb.js +66 -0
  1066. package/dist/tui-CTCn5piF.js +4709 -0
  1067. package/dist/tui-backend-By5bSm4p.js +256 -0
  1068. package/dist/tui-cli-DTPrRo4_.js +37 -0
  1069. package/dist/tui-t_WAdGfV.js +2 -0
  1070. package/dist/types-D3enA0Vx.d.ts +786 -0
  1071. package/dist/types-DHSQkzyq2.d.ts +3650 -0
  1072. package/dist/types.public-DHQb4Kl9.d.ts +70 -0
  1073. package/dist/update-check-Dvu5Z_Jp.js +407 -0
  1074. package/dist/update-cli-Bd5_MzQC.js +3664 -0
  1075. package/dist/update-runner-B8GJeQ12.js +2390 -0
  1076. package/dist/update-startup-B86---uS.js +2 -0
  1077. package/dist/update-startup-C2tCNZ7v.js +339 -0
  1078. package/dist/video-generation-runtime-Dj060lga.d.ts +21 -0
  1079. package/dist/video-model-catalog-CQ-f89xh.d.ts +16 -0
  1080. package/dist/vision-tools-mjhp5ZJQ.js +1409 -0
  1081. package/dist/web-search-DznJdih_.js +62 -0
  1082. package/dist/web-search-provider.runtime-CbIP4C_P.js +328 -0
  1083. package/dist/web-search-provider.runtime-D74o1ayv.js +2 -0
  1084. package/dist/web-search-provider.runtime.js +1 -1
  1085. package/dist/webhook-targets-Bixk4LO_.d.ts +99 -0
  1086. package/dist/xai-oauth-B2dU9w_h.js +479 -0
  1087. package/dist/xai-user-agent-CD1kt9ys.js +32 -0
  1088. package/package.json +1 -1
  1089. package/dist/abort-DbmSukS6.js +0 -277
  1090. package/dist/abort.runtime-DfTphPUe.js +0 -2
  1091. package/dist/account-inspect-CrOeeGkg.js +0 -173
  1092. package/dist/accounts-CF5wlCaC.js +0 -119
  1093. package/dist/accounts-CfFTGexZ.js +0 -107
  1094. package/dist/accounts-Cr9iBKG5.js +0 -2
  1095. package/dist/accounts-DdAZRSd-.js +0 -107
  1096. package/dist/acp-runtime-B1CfWEsR.js +0 -26
  1097. package/dist/acp-spawn-Bq8RHmXn.js +0 -1275
  1098. package/dist/acp-spawn-BxyX0qDU.js +0 -2
  1099. package/dist/acp-stateful-target-driver-y9Vk9ZkZ.js +0 -89
  1100. package/dist/action-kill-Xr3eQUBu.js +0 -33
  1101. package/dist/action-runtime-CweBFa8U.js +0 -469
  1102. package/dist/action-runtime-api-DZY1J62H.js +0 -2
  1103. package/dist/action-send-HdOQtFcz.js +0 -39
  1104. package/dist/action-spawn-DWrPplrX.js +0 -47
  1105. package/dist/actions-zZzXK7Ic.js +0 -161
  1106. package/dist/actions.runtime-CK0aV6y4.js +0 -5
  1107. package/dist/agent-command-DB0sppso.js +0 -1367
  1108. package/dist/agent-components.runtime-Drdzm2-F.js +0 -10
  1109. package/dist/agent-harness-BAdIuhgp.d.ts +0 -146
  1110. package/dist/agent-harness-runtime-Btzminw9.js +0 -180
  1111. package/dist/agent-harness-runtime-Dsl-hUeN.d.ts +0 -691
  1112. package/dist/agent-harness-task-runtime-DWiDnwnT.js +0 -140
  1113. package/dist/agent-nenZtwAX.js +0 -3
  1114. package/dist/agent-runner-execution-Cun_PNBn.js +0 -1713
  1115. package/dist/agent-runner-utils-BfF--s17.js +0 -266
  1116. package/dist/agent-runner.runtime-vxDguHci.js +0 -3455
  1117. package/dist/agent-runtime-C5xeqCn8.js +0 -229
  1118. package/dist/agent-svdKN_62.js +0 -2
  1119. package/dist/agent-via-gateway-DQa8cmBa.js +0 -463
  1120. package/dist/api-BQxP3H11.js +0 -134
  1121. package/dist/api-CMMiQOJ0.d.ts +0 -52
  1122. package/dist/api-CT5SnVgO.js +0 -2
  1123. package/dist/api-CtX70NwR.js +0 -2
  1124. package/dist/api-CvUdFHq7.js +0 -6
  1125. package/dist/api-DG9oHhm4.js +0 -639
  1126. package/dist/api-DzfMdJ46.js +0 -3
  1127. package/dist/apply-D8UoOoVD.js +0 -41
  1128. package/dist/apply-DrHwBR1D.js +0 -54
  1129. package/dist/approval-handler.runtime-CT8PWJ9W.js +0 -130
  1130. package/dist/assistant-ByynDFnI.js +0 -291
  1131. package/dist/attachment-normalize-DEAS_ziY.js +0 -225
  1132. package/dist/attempt-execution-CQUmv8x2.js +0 -558
  1133. package/dist/attempt-execution.runtime-AZYQQuAv.js +0 -3
  1134. package/dist/attempt-execution.shared-2ZOaCHct.js +0 -38
  1135. package/dist/attempt.prompt-helpers-B7ano4Xa.js +0 -475
  1136. package/dist/attempt.tool-run-context-DBta4Vhq.js +0 -2094
  1137. package/dist/binding-routing-DYUUioo1.js +0 -113
  1138. package/dist/binding-targets-DthC_zAF.js +0 -121
  1139. package/dist/bot-CHP8Hnzo.js +0 -7894
  1140. package/dist/bot-deps-CLDgPV_x.js +0 -747
  1141. package/dist/bot-deps-W9zVbYpY.js +0 -2
  1142. package/dist/bot-message-context.runtime-B1-gGjAv.js +0 -7
  1143. package/dist/bot-message-context.session.runtime-DUtlPLJq.js +0 -12
  1144. package/dist/bot-native-commands.delivery.runtime-B2_Sb8-0.js +0 -4
  1145. package/dist/bot-native-commands.runtime-pplrKHcn.js +0 -13
  1146. package/dist/bridge-server-Du_qnIXr.js +0 -113
  1147. package/dist/browser-cli-B2-Lzvd1.js +0 -230
  1148. package/dist/browser-cli-actions-input-ZF6YYuIY.js +0 -473
  1149. package/dist/browser-cli-actions-observe-DWLHFME1.js +0 -81
  1150. package/dist/browser-cli-bTjCd41u.js +0 -2
  1151. package/dist/browser-cli-debug-lzd4l2hl.js +0 -137
  1152. package/dist/browser-cli-inspect-C5OnFKqx.js +0 -104
  1153. package/dist/browser-cli-manage-BofwSOgU.js +0 -443
  1154. package/dist/browser-cli-resize-CLs1i6Nu.js +0 -26
  1155. package/dist/browser-cli-shared-6Jygx3GN.js +0 -50
  1156. package/dist/browser-cli-state-BdoHl8ny.js +0 -337
  1157. package/dist/browser-control-auth-DuI4vfIv.js +0 -2
  1158. package/dist/browser-profiles-DkblgTjb.js +0 -2
  1159. package/dist/browser-runtime-BiJKNDAE.js +0 -384
  1160. package/dist/build-CrC0bToI.js +0 -257
  1161. package/dist/bundled-channel-config-schema-Dq9GyGkV.d.ts +0 -3163
  1162. package/dist/call-C_O9lFB3.d.ts +0 -43
  1163. package/dist/capability-cli-BHlS8tBg.js +0 -1782
  1164. package/dist/channel-3bHGABHQ.d.ts +0 -104
  1165. package/dist/channel-5iqpbW6B.js +0 -867
  1166. package/dist/channel-B1qFfjbe.d.ts +0 -7
  1167. package/dist/channel-BGGj7Wjy.d.ts +0 -14
  1168. package/dist/channel-BW3tbxJQ.js +0 -1496
  1169. package/dist/channel-BWo67yh1.js +0 -2126
  1170. package/dist/channel-Bppi3FMK.d.ts +0 -12
  1171. package/dist/channel-Bq52osTf.d.ts +0 -8
  1172. package/dist/channel-Bs3DZFPq.d.ts +0 -106
  1173. package/dist/channel-BsDZhXfM.js +0 -362
  1174. package/dist/channel-BstFikSc.d.ts +0 -427
  1175. package/dist/channel-C95y8CWt.js +0 -1556
  1176. package/dist/channel-CMKGn1i6.js +0 -376
  1177. package/dist/channel-CMUiDCTQ.js +0 -740
  1178. package/dist/channel-CNvxy1bb.js +0 -808
  1179. package/dist/channel-COW85E9X.d.ts +0 -8
  1180. package/dist/channel-CQzh6Wn1.js +0 -653
  1181. package/dist/channel-CWr2KVGU.d.ts +0 -26
  1182. package/dist/channel-CchnfGMs.js +0 -481
  1183. package/dist/channel-CjWH9zRX.js +0 -1777
  1184. package/dist/channel-CjZoZfa2.js +0 -238
  1185. package/dist/channel-CjboShyl.d.ts +0 -6
  1186. package/dist/channel-CkKzMzC_.d.ts +0 -114
  1187. package/dist/channel-Cug3Bamu.d.ts +0 -28
  1188. package/dist/channel-D4fHzRMz.d.ts +0 -7
  1189. package/dist/channel-DKHlpUHA.js +0 -1134
  1190. package/dist/channel-DQivVI_l.d.ts +0 -64
  1191. package/dist/channel-DcxcCY8j.d.ts +0 -8
  1192. package/dist/channel-DhZvHOpE.js +0 -562
  1193. package/dist/channel-DkFslMm5.d.ts +0 -47
  1194. package/dist/channel-DtL_IvqV.js +0 -508
  1195. package/dist/channel-GdNHqdaw.js +0 -1249
  1196. package/dist/channel-ZkqVX5SL.js +0 -955
  1197. package/dist/channel-actions.runtime-DYiOBQDx.js +0 -265
  1198. package/dist/channel-core-CiUQ9zxC.js +0 -5
  1199. package/dist/channel-core-iRU5FnZE.d.ts +0 -6
  1200. package/dist/channel-entry-contract-UMXaNqZx.d.ts +0 -112
  1201. package/dist/channel-inbound-Ctv6wSJ3.js +0 -80
  1202. package/dist/channel-jbiJFUAA.d.ts +0 -49
  1203. package/dist/channel-plugin-runtime-CgGpeLjf.js +0 -998
  1204. package/dist/channel-plugin-runtime-D9Gl8DZ6.d.ts +0 -7
  1205. package/dist/channel-runtime-CPbfvG0l.js +0 -408
  1206. package/dist/channel.runtime-5ebeoN8j.js +0 -1008
  1207. package/dist/channel.runtime-B2Olk7LG.js +0 -4
  1208. package/dist/channel.runtime-B4CnXDGx.js +0 -652
  1209. package/dist/channel.runtime-BzLoF_dR.js +0 -21009
  1210. package/dist/channel.runtime-CNCIcAd6.js +0 -109
  1211. package/dist/channel.runtime-C_--rR-H.js +0 -88
  1212. package/dist/channel.runtime-CmK77Uxp.js +0 -254
  1213. package/dist/channel.runtime-DF5K3pkO.js +0 -2528
  1214. package/dist/channel.runtime-iKNOt2eM.js +0 -733
  1215. package/dist/channel.setup-BMuqTkrm.d.ts +0 -7
  1216. package/dist/channel.setup-CxvbmJQ2.js +0 -343
  1217. package/dist/channel.setup-CzdDnMh7.js +0 -1098
  1218. package/dist/channel.setup-DFIibepr.d.ts +0 -8
  1219. package/dist/channel.setup-Sku9g-22.js +0 -10
  1220. package/dist/channel.setup-qFWXWApC.d.ts +0 -6
  1221. package/dist/chat-BV-WLur6.js +0 -2666
  1222. package/dist/chrome-CBr1Nlj5.js +0 -1503
  1223. package/dist/cli-BIp6XQcZ.d.ts +0 -20
  1224. package/dist/cli-backend-7jHQ_xIa.d.ts +0 -5
  1225. package/dist/cli-backend-BGrt9NcX.d.ts +0 -5
  1226. package/dist/cli-compaction-CzfXx99c.js +0 -347
  1227. package/dist/cli-lsMRD5BD.js +0 -1341
  1228. package/dist/cli-metadata-Cpdwx3O7.js +0 -22
  1229. package/dist/cli-runner-DFh20BoX.js +0 -2
  1230. package/dist/cli-runner-DjgUGfBa.js +0 -540
  1231. package/dist/cli-runner.runtime-Cjd2VdQI.js +0 -3
  1232. package/dist/cli-runner.runtime-uAtVtWM7.js +0 -4
  1233. package/dist/cli-shared-BXoHwlQv.d.ts +0 -20
  1234. package/dist/client-D-yT6rne.js +0 -650
  1235. package/dist/client-adapter-PXk4JoQR.js +0 -897
  1236. package/dist/client-factory-C9zVXY0y.js +0 -9
  1237. package/dist/command-auth-PrmmYdot.js +0 -135
  1238. package/dist/command-handlers-DuHt0qVp.js +0 -1609
  1239. package/dist/command-registry-B_v8R74Z.js +0 -4
  1240. package/dist/command-registry-QvQgQxqT.js +0 -9
  1241. package/dist/command-registry-core-dLVpK66o.js +0 -110
  1242. package/dist/command-status.runtime-DM3aUyTe.js +0 -90
  1243. package/dist/commands-BF90P53c.d.ts +0 -113
  1244. package/dist/commands-acp-DzUZwawt.js +0 -74
  1245. package/dist/commands-compact.runtime-B6-Vv1CH.js +0 -10
  1246. package/dist/commands-handlers.runtime-CaTYrYbd.js +0 -6154
  1247. package/dist/commands-status-NuvnoSL-.js +0 -16
  1248. package/dist/commands-status-SMWi-mj9.js +0 -3
  1249. package/dist/commands-status.runtime-SMWi-mj9.js +0 -3
  1250. package/dist/commands-subagents-control.runtime-Cm9cxI8S.js +0 -2
  1251. package/dist/commands-subagents-control.runtime-e7gSoCXL.js +0 -3
  1252. package/dist/commands-system-prompt-C9pVUDbu.js +0 -162
  1253. package/dist/commands-system-prompt-JP4vOPVK.js +0 -2
  1254. package/dist/commands.runtime-Dg6eg0rn.js +0 -176
  1255. package/dist/compact-B2rH1SUd.js +0 -480
  1256. package/dist/compact-D80suJg8.js +0 -1141
  1257. package/dist/compact.runtime-D8nzDxmY.js +0 -12
  1258. package/dist/completion-cli-DWxWi4aD.js +0 -315
  1259. package/dist/components-D9TlXmrM.d.ts +0 -228
  1260. package/dist/components.modal-F1ooc12a.d.ts +0 -568
  1261. package/dist/computer-use-BGvZ1YTf.js +0 -367
  1262. package/dist/config-DV-fdSq3.js +0 -373
  1263. package/dist/config-DkblgTjb.js +0 -2
  1264. package/dist/config-mutations-DsTp_oTJ.js +0 -159
  1265. package/dist/config-schema-1Rq_tK9x.d.ts +0 -20
  1266. package/dist/context-engine-host-compat-BwIxzf7F.js +0 -2
  1267. package/dist/context-engine-host-compat-CXhSw3Ub.js +0 -288
  1268. package/dist/context-engine-lifecycle-CxxoOuT8.js +0 -1274
  1269. package/dist/contracts-testkit-CkDBPri-.d.ts +0 -145
  1270. package/dist/control-auth-Bb_hAwJF.js +0 -114
  1271. package/dist/control-service-Dom28xYt.js +0 -145
  1272. package/dist/control-ui/assets/agents-8-THqDFl.js +0 -1008
  1273. package/dist/control-ui/assets/channel-config-extras-B5hwzwVQ.js +0 -2
  1274. package/dist/control-ui/assets/channels-DTrsR3i5.js +0 -367
  1275. package/dist/control-ui/assets/cron-u6eW1T62.js +0 -1013
  1276. package/dist/control-ui/assets/debug-Bct0MI1V.js +0 -97
  1277. package/dist/control-ui/assets/index-BUfyv2kl.js +0 -7406
  1278. package/dist/control-ui/assets/instances-C9tRY_VR.js +0 -57
  1279. package/dist/control-ui/assets/logs-CdzoG4_t.js +0 -74
  1280. package/dist/control-ui/assets/nodes-p7_ysgvS.js +0 -436
  1281. package/dist/control-ui/assets/sessions-nkfdptx_.js +0 -399
  1282. package/dist/control-ui/assets/skills-CyCRwu_E.js +0 -314
  1283. package/dist/control-ui/assets/skills-shared-DKx7iJVp.js +0 -11
  1284. package/dist/conversation-binding-runtime-BXeidhrY.js +0 -4
  1285. package/dist/conversation-runtime-Das7yftQ.js +0 -31
  1286. package/dist/core-AxrxO8_x.js +0 -282
  1287. package/dist/core-D7u6inkU.d.ts +0 -224
  1288. package/dist/core-api-BL4BNR1C.js +0 -5
  1289. package/dist/core-api-Bnc3J2fe.js +0 -2
  1290. package/dist/crestodian-CnfWHGFm.js +0 -55
  1291. package/dist/daocore-runtime-DhGitUyP.d.ts +0 -151
  1292. package/dist/daocore-tools-C1WpZGCu.js +0 -11727
  1293. package/dist/delivery--FvYHWJO.js +0 -1002
  1294. package/dist/dialogue-B40qxVGM.js +0 -37
  1295. package/dist/dir-fetch-tool-fbOAtLfN.js +0 -565
  1296. package/dist/dir-list-tool-BQ3k3hKf.js +0 -100
  1297. package/dist/direct-dm-CuNsmrdk.js +0 -64
  1298. package/dist/directive-handling.fast-lane-CQYYvYi_.js +0 -68
  1299. package/dist/directive-handling.impl-DoLFcRUI.js +0 -2
  1300. package/dist/directive-handling.impl-RsdNckR4.js +0 -818
  1301. package/dist/directive-handling.model-selection-Ad4n0BBf.js +0 -122
  1302. package/dist/directive-handling.persist.runtime-Dq8SQvB4.js +0 -263
  1303. package/dist/dispatch-Bmw9mO6a.js +0 -1640
  1304. package/dist/dispatch-acp-transcript.runtime-B7DKK79t.js +0 -40
  1305. package/dist/dispatch-acp.runtime-cVH58wGq.js +0 -18
  1306. package/dist/doctor-HffoL5ik.js +0 -6
  1307. package/dist/doctor-Qg1Gj0PC.js +0 -2
  1308. package/dist/doctor-config-flow-Dudp0oO_.js +0 -1741
  1309. package/dist/doctor-core-checks-BTvmehLq.js +0 -573
  1310. package/dist/doctor-core-checks-CcacCMGd.js +0 -2
  1311. package/dist/doctor-health-DIu25ot8.js +0 -65
  1312. package/dist/doctor-health-contributions-ZQUAiwng.js +0 -696
  1313. package/dist/doctor-lint-C8RjoIYq.js +0 -94
  1314. package/dist/doctor-state-integrity-D5NJcM0t.js +0 -1231
  1315. package/dist/doctor-update-07o96Num.js +0 -58
  1316. package/dist/dynamic-tools-BSIfb0RP.js +0 -486
  1317. package/dist/embedded-backend-499B1IIV.js +0 -579
  1318. package/dist/embedded-gateway-stub.runtime-Bqr2Z4Co.js +0 -12
  1319. package/dist/embedding-provider-BZTPwWKb.d.ts +0 -21
  1320. package/dist/embedding-provider-CSexv_6m.d.ts +0 -16
  1321. package/dist/embedding-provider-VAxs8MlT.d.ts +0 -65
  1322. package/dist/exec-approvals-ClTqhSd7.js +0 -149
  1323. package/dist/file-fetch-tool-CJu8umi9.js +0 -124
  1324. package/dist/file-write-tool-Dz49CI0K.js +0 -127
  1325. package/dist/format-DBhooCE7.js +0 -1145
  1326. package/dist/format-DCronAhx.js +0 -250
  1327. package/dist/gateway-cli-D21vxek0.js +0 -435
  1328. package/dist/gateway-method-runtime-qsRZHdfx.js +0 -21
  1329. package/dist/gateway-runtime-DB-OXh4s.d.ts +0 -163
  1330. package/dist/gemini-cli-provider-DbhcYwoe.d.ts +0 -6
  1331. package/dist/get-reply-D140C4TM.js +0 -4689
  1332. package/dist/get-reply-from-config.runtime-CaM7M0Zp.js +0 -2
  1333. package/dist/graph-users-cBY7anTM.js +0 -1419
  1334. package/dist/group-access-CZOQhsjs.js +0 -112
  1335. package/dist/handle-action.guild-admin-DjuZqjM2.js +0 -288
  1336. package/dist/harness-XL58LNpX.js +0 -61
  1337. package/dist/health-CFPXXpFW.js +0 -4
  1338. package/dist/health-state-Bp0DOLCD.js +0 -106
  1339. package/dist/heartbeat-runner-D_o-itnk.js +0 -5
  1340. package/dist/heartbeat-runner.runtime-CPVGa3Gd.js +0 -4
  1341. package/dist/hooks-Bx3n6o-5.js +0 -534
  1342. package/dist/http-registry-CvWunWhG.d.ts +0 -23
  1343. package/dist/image-generation-runtime-Bmuyaswz.d.ts +0 -21
  1344. package/dist/inbound-direct-dm-runtime-6nIJyODo.js +0 -2
  1345. package/dist/inbound-reply-dispatch-CoeXQvL6.js +0 -148
  1346. package/dist/index-UJCqyZjG.d.ts +0 -3971
  1347. package/dist/init-C8Yc8LlO.js +0 -59
  1348. package/dist/inline-buttons-BMPhhfsN.js +0 -40
  1349. package/dist/interactive-dispatch-BAQobp1L.d.ts +0 -56
  1350. package/dist/interactive-dispatch-VY7vCm4F.d.ts +0 -143
  1351. package/dist/internal-events-BS1EMi0C.js +0 -90
  1352. package/dist/isolated-agent-Ct_AYfLb.js +0 -2
  1353. package/dist/isolated-agent-DxVGoLjs.js +0 -1118
  1354. package/dist/lifecycle-CGcqxM3V.js +0 -571
  1355. package/dist/list.probe-R_AqbwD1.js +0 -449
  1356. package/dist/list.status-command-DcaLppGJ.js +0 -789
  1357. package/dist/llm-slug-generator-Bz1MaPt1.js +0 -78
  1358. package/dist/loader-Dkh4Y7sQ.d.ts +0 -142
  1359. package/dist/local-dispatch.runtime-DnXAlwr7.js +0 -9
  1360. package/dist/manager-BOuQY5Cm.d.ts +0 -356
  1361. package/dist/manager.runtime-1A0jFsbF.js +0 -2714
  1362. package/dist/markdown-to-line-Gq4y1nH-.js +0 -811
  1363. package/dist/mcp-http-BMgo3eu6.js +0 -2
  1364. package/dist/mcp-http-BdgsyrHJ.js +0 -555
  1365. package/dist/media-understanding-provider-CYrAwQ2G.js +0 -339
  1366. package/dist/memory-core-host-engine-storage-DE_xj2Bc.d.ts +0 -54
  1367. package/dist/memory-embedding-adapter-CB6OgeAj.d.ts +0 -5
  1368. package/dist/message-actions-DoFxM22K.js +0 -145
  1369. package/dist/message-handler-CEvRtI9d.js +0 -384
  1370. package/dist/message-handler-CJclaiC-.js +0 -1715
  1371. package/dist/message-handler.preflight-DDVS50X3.js +0 -1125
  1372. package/dist/message-handler.process-BuFXf8os.js +0 -1484
  1373. package/dist/migration-DypFGBwg.d.ts +0 -45
  1374. package/dist/model-B--RdZDR.d.ts +0 -33
  1375. package/dist/model-BqQrUk9a.js +0 -74
  1376. package/dist/model-selection-2Lm1qMLE.js +0 -272
  1377. package/dist/models-BNjZuv4X.d.ts +0 -24
  1378. package/dist/models-BjMdWXf2.js +0 -104
  1379. package/dist/models-cli-RRK90p8k.js +0 -256
  1380. package/dist/models-wWhwx_am.js +0 -2
  1381. package/dist/monitor-C7VAs-uK.js +0 -834
  1382. package/dist/monitor-CezSJDeG.js +0 -60
  1383. package/dist/monitor-Cnzchc9n.js +0 -2788
  1384. package/dist/monitor-Dcvw55ky.js +0 -4377
  1385. package/dist/monitor-DuxFMl7d.js +0 -715
  1386. package/dist/monitor-DxrfxRZL.js +0 -2
  1387. package/dist/monitor-auth-UPQgTP9Y.js +0 -179
  1388. package/dist/monitor-fYdQKsGp.js +0 -1370
  1389. package/dist/monitor-polling.runtime-Db4NoLLg.js +0 -883
  1390. package/dist/monitor-wcLtLTfx.js +0 -1657
  1391. package/dist/monitor-webhook.runtime-DAr7kRbV.js +0 -387
  1392. package/dist/monitor.account-C1mUBkKA.js +0 -5233
  1393. package/dist/monitor.runtime-Bqj8vHGY.js +0 -2
  1394. package/dist/monitor.webhook-Ir3T5B1s.js +0 -180
  1395. package/dist/node-cli-sessions-MBQKJyrs.js +0 -1228
  1396. package/dist/openai-codex-provider-DwXcOSqF.d.ts +0 -5
  1397. package/dist/openai-http-9jmQ2o9Z.js +0 -824
  1398. package/dist/openai-provider-CUJ-PaPI.d.ts +0 -5
  1399. package/dist/openresponses-http-C3-s16Dp.js +0 -1173
  1400. package/dist/operations-C1hhf_yC.js +0 -805
  1401. package/dist/outbound-adapter-C5zBbuVO.js +0 -543
  1402. package/dist/outbound-session-route-Bq_utu59.js +0 -45
  1403. package/dist/outbound.runtime-QHoe8EWX.js +0 -2
  1404. package/dist/pi-embedded-6xH25qP-.js +0 -4
  1405. package/dist/pi-embedded-CkcV64LR.js +0 -3796
  1406. package/dist/pi-embedded.runtime-CKpyReN5.js +0 -4
  1407. package/dist/pi-tools-BbGodehg.js +0 -2413
  1408. package/dist/plan-B_EcRdNP.js +0 -112
  1409. package/dist/plan-DmMZJkHt.js +0 -81
  1410. package/dist/plugin-BVI9qQnF.d.ts +0 -17
  1411. package/dist/plugin-CjfnnqXb.js +0 -12396
  1412. package/dist/plugin-app-cache-key-Dak7S3ax.js +0 -46
  1413. package/dist/plugin-enabled-B9wCs568.js +0 -233
  1414. package/dist/plugin-entry-DLQdGGuF.d.ts +0 -47
  1415. package/dist/plugin-registration-B3AVf0Xj.js +0 -88
  1416. package/dist/plugin-runtime-C0-rSvwU.d.ts +0 -117
  1417. package/dist/plugin-service-BeuNN5d5.d.ts +0 -24
  1418. package/dist/plugin-service-C2toP50L.js +0 -1229
  1419. package/dist/policy-B5jHUD04.js +0 -138
  1420. package/dist/policy-C7_EFtGD.js +0 -680
  1421. package/dist/prepare.runtime-C41yGgw-.js +0 -732
  1422. package/dist/preview-warnings-rfGY8dVy.js +0 -392
  1423. package/dist/probe-B0eSVoSm.js +0 -682
  1424. package/dist/probe-CqAGxL6l.js +0 -2
  1425. package/dist/probe-DFyoiqiI.js +0 -2204
  1426. package/dist/probe-hR0HWnET.js +0 -47
  1427. package/dist/program-CD73-5Xj.js +0 -131
  1428. package/dist/prompt-overlay-Byn_R8NU.d.ts +0 -23
  1429. package/dist/provider-B0ujadL5.js +0 -32
  1430. package/dist/provider-BxR_JJXW.js +0 -152
  1431. package/dist/provider-C9mKa8qP.js +0 -32
  1432. package/dist/provider-DbGPdInL.js +0 -8735
  1433. package/dist/provider-api-key-auth-Dx8L-t2_.d.ts +0 -27
  1434. package/dist/provider-auth-result-BNSiQhij.d.ts +0 -21
  1435. package/dist/provider-catalog-runtime-CHO5ynAJ.d.ts +0 -23
  1436. package/dist/provider-catalog-shared-CnjzKwdh.d.ts +0 -62
  1437. package/dist/provider-dispatcher-CGPKPaP5.js +0 -22
  1438. package/dist/provider-hook-runtime-Di9KibUS.d.ts +0 -61
  1439. package/dist/provider-model-shared-BdiLr8i6.d.ts +0 -143
  1440. package/dist/provider-models-Bhg840ah.d.ts +0 -12
  1441. package/dist/provider-policy-BQkPPnao.d.ts +0 -30
  1442. package/dist/provider-registration-Bmmz4ZeC.d.ts +0 -6
  1443. package/dist/provider-registry-CIIVRa6w.d.ts +0 -8
  1444. package/dist/provider-registry-DmGMS3NG.d.ts +0 -30
  1445. package/dist/provider-registry-nhvIqLQS.d.ts +0 -8
  1446. package/dist/provider-runtime-DXbh5hA1.d.ts +0 -359
  1447. package/dist/provider-self-hosted-setup-NeHRz9nM.d.ts +0 -74
  1448. package/dist/provider-session.runtime-DKkydJWv.js +0 -9
  1449. package/dist/provider-stream-C2CgRBk_.d.ts +0 -140
  1450. package/dist/provider-stream-shared-BVIP58k-.d.ts +0 -128
  1451. package/dist/provider.runtime-ChrWUTdG.js +0 -2
  1452. package/dist/providers.runtime-BxZZsCo6.d.ts +0 -25
  1453. package/dist/public-surface-loader-CMOWVmyY.js +0 -114
  1454. package/dist/pw-ai-mygsAPX7.js +0 -3029
  1455. package/dist/pw-role-snapshot-7_IMuYRR.js +0 -333
  1456. package/dist/reaction-level-DFUu127f.js +0 -19
  1457. package/dist/reaction-runtime-api-6LQnr6q_.js +0 -116
  1458. package/dist/realtime-transcription-RzONWH63.d.ts +0 -43
  1459. package/dist/realtime-transcription-provider-BCVZfRXn.d.ts +0 -37
  1460. package/dist/realtime-transcription-provider-BrLEXlzr.d.ts +0 -5
  1461. package/dist/realtime-transcription-provider-CmxyAofL.d.ts +0 -28
  1462. package/dist/realtime-transcription-provider-LrzigbIT.js +0 -205
  1463. package/dist/realtime-transcription-provider-tltowP27.d.ts +0 -32
  1464. package/dist/realtime-voice-XuxaWlNv.d.ts +0 -333
  1465. package/dist/realtime-voice-provider-CgwwfKxl.d.ts +0 -5
  1466. package/dist/register-B9TeJvXU.js +0 -2178
  1467. package/dist/register.agent-o9BDHbH2.js +0 -156
  1468. package/dist/register.crestodian-BOUP_Pon.js +0 -24
  1469. package/dist/register.maintenance-BC83-YdR.js +0 -83
  1470. package/dist/register.runtime-BSpRaqNT.d.ts +0 -6
  1471. package/dist/register.runtime-DSHYrjtd.js +0 -54
  1472. package/dist/register.status-health-sessions-BrkNpe59.js +0 -282
  1473. package/dist/register.subclis-BS5Lj5wU.js +0 -3
  1474. package/dist/register.subclis-QQq9COp0.js +0 -31
  1475. package/dist/register.subclis-core-DnNechJo.js +0 -273
  1476. package/dist/registry-BCQkqtgq.d.ts +0 -91
  1477. package/dist/registry-types-PnLnWFuJ.d.ts +0 -392
  1478. package/dist/repair-sequencing-CqjW4_hd.js +0 -640
  1479. package/dist/reply-delivery-KRwW1tqL.js +0 -196
  1480. package/dist/reply-runtime-SSrAwVeQ.js +0 -11
  1481. package/dist/reply.runtime-CaM7M0Zp.js +0 -2
  1482. package/dist/request-CatWtIoq.js +0 -54
  1483. package/dist/resolve-allowlist-Dxe9wc_Y.js +0 -220
  1484. package/dist/result-fallback-classifier-B3kvqc2o.js +0 -79
  1485. package/dist/route-BPWKlRDB.js +0 -469
  1486. package/dist/route-resolution-BhkvdIUP.js +0 -274
  1487. package/dist/routes-BOmtNSeT.js +0 -2
  1488. package/dist/routes-Cr9bRW8t.js +0 -3602
  1489. package/dist/run-attempt-DWBeHRdc.js +0 -7704
  1490. package/dist/run-command-DNNFNkbv.js +0 -23
  1491. package/dist/run-command-Kp7LWkQv.js +0 -2
  1492. package/dist/run-embedded.runtime-BxV8m38U.js +0 -4
  1493. package/dist/run-execution-cli.runtime-B9I1oAEO.js +0 -4
  1494. package/dist/run-subagent-registry.runtime-BIsbEmUD.js +0 -2
  1495. package/dist/run-vAv9-st8.js +0 -1162
  1496. package/dist/runtime-BXJM8M8F.js +0 -1287
  1497. package/dist/runtime-BodO4UZT.js +0 -438
  1498. package/dist/runtime-C_5j10Cp.js +0 -6179
  1499. package/dist/runtime-api-BbNLHCZ5.js +0 -24
  1500. package/dist/runtime-api-HUquGiJa.js +0 -4
  1501. package/dist/runtime-api-I6ur4A1S.js +0 -17
  1502. package/dist/runtime-api-MQL0v6n2.js +0 -13
  1503. package/dist/runtime-api-a340pYdX.js +0 -13
  1504. package/dist/runtime-api-g_pGO9f3.js +0 -21
  1505. package/dist/runtime-api-hLSYbpGH.js +0 -3
  1506. package/dist/runtime-api.actions-CawQ9WKM.js +0 -3
  1507. package/dist/runtime-api.monitor-DN3P4USq.js +0 -6
  1508. package/dist/runtime-api.monitor-LRfB_JTP.d.ts +0 -3757
  1509. package/dist/runtime-api.send-BIA6QfVI.js +0 -4
  1510. package/dist/runtime-api.send-BygcWA7R.d.ts +0 -38
  1511. package/dist/runtime-api.threads-DYnc3Jvu.js +0 -2
  1512. package/dist/runtime-channel-CYlRNrxR.js +0 -150
  1513. package/dist/runtime-channel-Ci0dC0Tq.js +0 -2
  1514. package/dist/runtime-embedded-pi.runtime-Wc_lZOzO.js +0 -2
  1515. package/dist/runtime-taskflow-Bwo7SO8T.d.ts +0 -435
  1516. package/dist/sanitize-outbound-BFrYI8F4.js +0 -127
  1517. package/dist/sdk-setup-tools-DLjnnh3Y.js +0 -8
  1518. package/dist/secrets-DibHCqDz.js +0 -113
  1519. package/dist/security-audit-CyMhUYN9.js +0 -122
  1520. package/dist/security-audit-DAk0I2g8.js +0 -118
  1521. package/dist/security-audit.runtime-DtdxZcEG.js +0 -2
  1522. package/dist/selection-BJ2yQ0yh.js +0 -16157
  1523. package/dist/selection-CJ3YNIjG.js +0 -3
  1524. package/dist/send-Ar9e_pA3.js +0 -1631
  1525. package/dist/send-BN-3u18j.js +0 -2
  1526. package/dist/send-BYlEXkEO.js +0 -143
  1527. package/dist/send-BusufuyP.js +0 -192
  1528. package/dist/send.components-C3FzEyYz.js +0 -500
  1529. package/dist/send.components-CMi7rcIs.js +0 -2
  1530. package/dist/send.runtime-D-nw3p-S.js +0 -2
  1531. package/dist/server-CJVI2gjZ.js +0 -24
  1532. package/dist/server-DZl7k4VX.js +0 -73
  1533. package/dist/server-context-BAAz3W-8.js +0 -2
  1534. package/dist/server-context-BLrLchWj.js +0 -955
  1535. package/dist/server-cron-CiyrI-WY.js +0 -2
  1536. package/dist/server-cron-CzhteL8F.js +0 -2989
  1537. package/dist/server-maintenance-CDfLZpYN.js +0 -167
  1538. package/dist/server-methods-DQ0gaIXu.js +0 -16494
  1539. package/dist/server-node-events-D1TywtBI.js +0 -596
  1540. package/dist/server-plugin-bootstrap-ByEZkPkc.js +0 -70
  1541. package/dist/server-plugins-CEZ-W7dG.js +0 -432
  1542. package/dist/server-reload-handlers-DDXJwZWE.js +0 -714
  1543. package/dist/server-restart-sentinel-C9l1iG1h.js +0 -747
  1544. package/dist/server-restart-sentinel-CyweyjEa.js +0 -2
  1545. package/dist/server-runtime-services-BQ08Hyco.js +0 -2
  1546. package/dist/server-runtime-services-BjKoAkjM.js +0 -267
  1547. package/dist/server-startup-early-Ctjir66B.js +0 -87
  1548. package/dist/server-startup-plugins-C_Y62xZe.js +0 -113
  1549. package/dist/server-startup-post-attach-DCAmn6Ct.js +0 -716
  1550. package/dist/server-ws-runtime-CvN63X_w.js +0 -349
  1551. package/dist/server.impl-yHI7jtXF.js +0 -2586
  1552. package/dist/service-mHxeSPC2.js +0 -1446
  1553. package/dist/session-binding-DtmTypDj.js +0 -2
  1554. package/dist/session-binding-xtRKSQOW.js +0 -219
  1555. package/dist/session-kill-http-GnTgzcvZ.js +0 -121
  1556. package/dist/session-reset-service-Bw6li9Te.js +0 -625
  1557. package/dist/session-route-D-PISLLo.js +0 -93
  1558. package/dist/session-status.runtime-jiGvxIDK.js +0 -2
  1559. package/dist/session-subagent-reactivation.runtime-B9QimjvS.js +0 -2
  1560. package/dist/session-tab-registry-BoqXuTYc.js +0 -521
  1561. package/dist/sessions-history-http-CG934aaV.js +0 -430
  1562. package/dist/sessions.runtime-Cl91aZ2M.js +0 -2
  1563. package/dist/setup-api-DAqXqbGP.js +0 -29
  1564. package/dist/setup-core-Czt7XqlN.js +0 -174
  1565. package/dist/setup-surface-CHETBocT.js +0 -405
  1566. package/dist/setup-surface-CVtEDUic.js +0 -320
  1567. package/dist/setup-surface-YW9INYKN.js +0 -288
  1568. package/dist/setup-surface-utUyMdYz.js +0 -221
  1569. package/dist/shared-CSQmYbeX.d.ts +0 -115
  1570. package/dist/shared-DwZ1ZQM4.js +0 -121
  1571. package/dist/shared-client-B2kMpTHH.js +0 -2
  1572. package/dist/shared-client-DHJbz0yn.js +0 -629
  1573. package/dist/side-question-Dlr5pcZK.js +0 -683
  1574. package/dist/simple-completion-runtime-C8xGogR1.d.ts +0 -73
  1575. package/dist/skill-tool-dispatch.runtime-CbDumhVh.js +0 -143
  1576. package/dist/slash-state-BxzZ0Rmv.js +0 -2166
  1577. package/dist/speech-CZ5gvq-1.d.ts +0 -47
  1578. package/dist/speech-core-UlM7sC1c.d.ts +0 -36
  1579. package/dist/speech-provider-BjqPFFWl.d.ts +0 -34
  1580. package/dist/speech-provider-Bl5mpTPW.d.ts +0 -5
  1581. package/dist/speech-provider-C0NTQ--Q.d.ts +0 -5
  1582. package/dist/speech-provider-CDasrxDt.d.ts +0 -8
  1583. package/dist/speech-provider-INk_7d-9.js +0 -184
  1584. package/dist/speech-provider-Z6RxW9fC.d.ts +0 -8
  1585. package/dist/speech-provider-sPM0Xu9T.d.ts +0 -5
  1586. package/dist/src-DAMtNlRl.js +0 -4256
  1587. package/dist/startup-context-DhSjA04E.js +0 -313
  1588. package/dist/status-CHChLqRH.js +0 -3
  1589. package/dist/status-OYJF7NHg.js +0 -4
  1590. package/dist/status-all-CSz2mOkm.js +0 -573
  1591. package/dist/status-json-B5iKxsPt.js +0 -14
  1592. package/dist/status-json-command-B7mD_HM0.js +0 -84
  1593. package/dist/status-runtime-shared-tJ5_gXDE.js +0 -283
  1594. package/dist/status-subagents.runtime-UViaj6fy.js +0 -18
  1595. package/dist/status-text-D4yQvJnW.js +0 -296
  1596. package/dist/status.command-29iMh5b8.js +0 -420
  1597. package/dist/status.command-cDrXztZ4.js +0 -2
  1598. package/dist/status.command.text-runtime-CJLiLlec.js +0 -15
  1599. package/dist/status.scan-BnCyO_-1.js +0 -68
  1600. package/dist/status.scan-overview-8jfuH7wl.js +0 -444
  1601. package/dist/status.scan.fast-json-CyqrMrI6.js +0 -2
  1602. package/dist/status.scan.fast-json-D0y03alo.js +0 -127
  1603. package/dist/status.scan.runtime-DGbNNELT.js +0 -479
  1604. package/dist/status.update-C6moG8hY.js +0 -2
  1605. package/dist/status.update-Ch-d2YqJ.js +0 -86
  1606. package/dist/sticker-cache-CpE2UF0o.js +0 -206
  1607. package/dist/sticker-vision.runtime-C5lk740o.js +0 -17
  1608. package/dist/stream-BQsCB10Z.d.ts +0 -16
  1609. package/dist/stream-Ba6Savi8.d.ts +0 -19
  1610. package/dist/stream-CSzQ2k0Z.d.ts +0 -5
  1611. package/dist/stream-nEf-UhFE.d.ts +0 -120
  1612. package/dist/stream-wrappers-DlkjdNOC.d.ts +0 -21
  1613. package/dist/stream-zWJcNi1V.d.ts +0 -10
  1614. package/dist/subagent-announce-DDensDxS.js +0 -354
  1615. package/dist/subagent-announce-delivery-16skgjOt.js +0 -958
  1616. package/dist/subagent-control-C2SGCamc.js +0 -508
  1617. package/dist/subagent-hooks-BqabvLsv.js +0 -2
  1618. package/dist/subagent-hooks-CGeDwTHC.js +0 -2
  1619. package/dist/subagent-hooks-CR0M3L4o.js +0 -146
  1620. package/dist/subagent-hooks-Dw9C-nUM.js +0 -2
  1621. package/dist/subagent-hooks-api-B03j55PK.js +0 -22
  1622. package/dist/subagent-hooks-api-B2i15coF.js +0 -23
  1623. package/dist/subagent-hooks-api-BcopR7NZ.js +0 -23
  1624. package/dist/subagent-hooks-eOUaLnxx.js +0 -116
  1625. package/dist/subagent-hooks-l4-8TBr2.js +0 -230
  1626. package/dist/subagent-orphan-recovery-CytpmJnf.js +0 -352
  1627. package/dist/subagent-registry-DTDYUst1.js +0 -2351
  1628. package/dist/subagent-registry-kGjRY7OP.js +0 -3
  1629. package/dist/subagent-session-cleanup-C7MqSx3u.js +0 -525
  1630. package/dist/subagent-spawn-DuLVHzht.js +0 -1164
  1631. package/dist/target-id-BqKER5JR.js +0 -107
  1632. package/dist/targets-BkPxUid9.d.ts +0 -10
  1633. package/dist/targets-CYrewJgy.d.ts +0 -10
  1634. package/dist/targets-DYNDWy1s.js +0 -44
  1635. package/dist/targets-DuRWAuVM.js +0 -19
  1636. package/dist/targets-aaR2Mlk_.js +0 -19
  1637. package/dist/testing-7ayMtB6I.js +0 -267
  1638. package/dist/text-report-E0TZg1LV.js +0 -695
  1639. package/dist/thinking-policy-59Wogr8a.d.ts +0 -5
  1640. package/dist/thread-bindings-BzpAXUwZ.js +0 -232
  1641. package/dist/thread-bindings-Cu4J90KY.js +0 -8
  1642. package/dist/thread-bindings-D5o9c3aE.js +0 -228
  1643. package/dist/thread-bindings-DMy2kJ74.js +0 -571
  1644. package/dist/thread-bindings.discord-api-BDj-jkBV.js +0 -187
  1645. package/dist/thread-bindings.manager-C5jC_3Mo.js +0 -2
  1646. package/dist/thread-bindings.manager-CLK7FYoE.js +0 -536
  1647. package/dist/thread-lifecycle-DYeO0OTi.js +0 -1614
  1648. package/dist/token-Ccki3ia9.js +0 -134
  1649. package/dist/tool-BqIYC7Fz.js +0 -139
  1650. package/dist/tool-actions.runtime-Cjbhroli.js +0 -534
  1651. package/dist/tool-plugin-APfyB2vB.d.ts +0 -77
  1652. package/dist/tool-resolution-D4klFB4B.js +0 -149
  1653. package/dist/tool-split-Bwpcndoo.d.ts +0 -19
  1654. package/dist/tools-effective-inventory-YuOuPKR8.js +0 -204
  1655. package/dist/tools-invoke-http-BmQFkxSN.js +0 -67
  1656. package/dist/tools-invoke-shared-DD4l34hg.js +0 -200
  1657. package/dist/transport-stream-CjC5n25n.d.ts +0 -42
  1658. package/dist/tts-BAQZtO6A.js +0 -66
  1659. package/dist/tui-B-CC1PjA.js +0 -2
  1660. package/dist/tui-backend-DLm_nQL8.js +0 -256
  1661. package/dist/tui-cli-BfCs3qwc.js +0 -37
  1662. package/dist/tui-qi8Vakes.js +0 -4709
  1663. package/dist/types-BKHLKutw.d.ts +0 -786
  1664. package/dist/types-Bv_n7Yed2.d.ts +0 -3650
  1665. package/dist/types.public-BCv7Iieb.d.ts +0 -70
  1666. package/dist/update-check-Dvp_oog_.js +0 -387
  1667. package/dist/update-cli-BP32xvfl.js +0 -3664
  1668. package/dist/update-runner-DnbwY3OV.js +0 -2390
  1669. package/dist/update-startup-3l7wPrqM.js +0 -339
  1670. package/dist/update-startup-C_peqiGI.js +0 -2
  1671. package/dist/video-generation-runtime-Cvo9t7Bj.d.ts +0 -21
  1672. package/dist/video-model-catalog-Clo7aLfS.d.ts +0 -16
  1673. package/dist/vision-tools-De-gGPAw.js +0 -1409
  1674. package/dist/web-search-DJMus2yt.js +0 -62
  1675. package/dist/web-search-provider.runtime-6Md25pj8.js +0 -2
  1676. package/dist/web-search-provider.runtime-CBUbt7xF.js +0 -328
  1677. package/dist/webhook-targets-nfKrQnF1.d.ts +0 -99
  1678. package/dist/xai-oauth-Cud_8Og7.js +0 -479
  1679. package/dist/xai-user-agent-dCQuZI6k.js +0 -32
  1680. /package/dist/{acp-runtime-backend-BQNm-KYC.js → acp-runtime-backend-C7YOcgPq.js} +0 -0
  1681. /package/dist/{channel-actions-CMUt5769.js → channel-actions-Blfq9sNz.js} +0 -0
  1682. /package/dist/{command-status-runtime-DXZZv5h_.js → command-status-runtime-D9nZ4WZF.js} +0 -0
  1683. /package/dist/{delegate-BTCHfZIj.js → delegate-BadknD7_.js} +0 -0
  1684. /package/dist/{dispatch-acp-DtdYZo4i.js → dispatch-acp-iub5P5an.js} +0 -0
  1685. /package/dist/{heartbeat-runner-BqUKIwmn.js → heartbeat-runner-l-pU94CG.js} +0 -0
  1686. /package/dist/{library-DavrGMix.js → library-DoNPigeh.js} +0 -0
  1687. /package/dist/{run-executor.runtime-DMU7greB.js → run-executor.runtime-BAkprH5Z.js} +0 -0
  1688. /package/dist/{shared-Kl_LS_vA.js → shared-BtQHfSwf.js} +0 -0
@@ -1,3029 +0,0 @@
1
- import { a as normalizeLowercaseStringOrEmpty, c as normalizeOptionalString$1, f as readStringValue } from "./string-coerce-DyL154ka.js";
2
- import { i as formatErrorMessage } from "./errors-D_oyTIw2.js";
3
- import { O as sanitizeUntrustedFileName, g as resolveStrictExistingPathsWithinRoot, r as writeExternalFileWithinRoot } from "./fs-safe-BFN3ftAo.js";
4
- import { n as resolvePreferredDaoCoreTmpDir } from "./tmp-daocore-dir-kDRsiZXM.js";
5
- import { t as SsrFBlockedError } from "./ssrf-BNF8aODC.js";
6
- import "./string-coerce-runtime-DcopKqDR.js";
7
- import "./sdk-security-runtime-D1Z-V8Bd.js";
8
- import { C as BrowserTabNotFoundError, J as withNoProxyForCdpUrl, c as isWebSocketUrl, i as fetchJson, l as normalizeCdpHttpBaseForJsonEndpoints, n as assertCdpEndpointAllowed, o as getHeadersWithAuth, p as withCdpSocket, t as appendCdpPath } from "./cdp.helpers-Dc4Aa7R9.js";
9
- import { a as DEFAULT_DOWNLOAD_DIR, o as DEFAULT_TRACE_DIR, s as DEFAULT_UPLOAD_DIR } from "./config-DV-fdSq3.js";
10
- import "./tmp-daocore-dir-0uyqO_dp.js";
11
- import "./errors-CdV5A9eu.js";
12
- import { C as assertBrowserNavigationRedirectChainAllowed, E as withBrowserNavigationPolicy, S as assertBrowserNavigationAllowed, f as formatAriaSnapshot, l as AX_REF_PATTERN, p as normalizeCdpWsUrl, t as getChromeWebSocketUrl, w as assertBrowserNavigationResultAllowed, x as InvalidBrowserNavigationUrlError, y as ensureOutputDirectory } from "./chrome-CBr1Nlj5.js";
13
- import { c as ACT_MAX_CLICK_DELAY_MS, d as resolveActInteractionTimeoutMs, f as resolveActWaitTimeoutMs, i as parseRoleRef, l as ACT_MAX_WAIT_TIME_MS, n as buildRoleSnapshotFromAriaSnapshot, p as matchBrowserUrlPattern, r as getRoleSnapshotStats, t as buildRoleSnapshotFromAiSnapshot } from "./pw-role-snapshot-7_IMuYRR.js";
14
- import { n as markPwAiLoaded } from "./pw-ai-state-DL7FXLI8.js";
15
- import { t as isSelectableCdpBrowserTarget } from "./cdp-target-filter-CaIsrb0G.js";
16
- import { createRequire } from "node:module";
17
- import path from "node:path";
18
- import crypto from "node:crypto";
19
- //#region extensions/browser/src/browser/output-atomic.ts
20
- async function writeViaSiblingTempPath(params) {
21
- await ensureOutputDirectory(params.rootDir);
22
- await writeExternalFileWithinRoot({
23
- rootDir: params.rootDir,
24
- path: params.targetPath,
25
- write: params.writeTemp
26
- });
27
- }
28
- const playwrightCore = createRequire(import.meta.url)("playwright-core");
29
- //#endregion
30
- //#region extensions/browser/src/browser/pw-session.page-cdp.ts
31
- const BROWSER_REF_MARKER_ATTRIBUTE = "data-daocore-browser-ref";
32
- async function withPlaywrightPageCdpSession(page, fn) {
33
- const session = await page.context().newCDPSession(page);
34
- try {
35
- return await fn(session);
36
- } finally {
37
- await session.detach().catch(() => {});
38
- }
39
- }
40
- async function withPageScopedCdpClient(opts) {
41
- return await withPlaywrightPageCdpSession(opts.page, async (session) => {
42
- return await opts.fn((method, params) => session.send(method, params));
43
- });
44
- }
45
- async function markBackendDomRefsOnPage(opts) {
46
- await opts.page.locator(`[${BROWSER_REF_MARKER_ATTRIBUTE}]`).evaluateAll((elements, attr) => {
47
- for (const element of elements) if (element instanceof Element) element.removeAttribute(attr);
48
- }, BROWSER_REF_MARKER_ATTRIBUTE).catch(() => {});
49
- const refs = opts.refs.filter((entry) => /^ax\d+$/.test(entry.ref) && Number.isFinite(entry.backendDOMNodeId) && Math.floor(entry.backendDOMNodeId) > 0);
50
- const marked = /* @__PURE__ */ new Set();
51
- if (!refs.length) return marked;
52
- return await withPlaywrightPageCdpSession(opts.page, async (session) => {
53
- const send = async (method, params) => await session.send(method, params);
54
- await send("DOM.enable").catch(() => {});
55
- const backendNodeIds = [...new Set(refs.map((entry) => Math.floor(entry.backendDOMNodeId)))];
56
- const pushed = await send("DOM.pushNodesByBackendIdsToFrontend", { backendNodeIds }).catch(() => ({}));
57
- const nodeIds = Array.isArray(pushed.nodeIds) ? pushed.nodeIds : [];
58
- const nodeIdByBackendId = /* @__PURE__ */ new Map();
59
- for (let index = 0; index < backendNodeIds.length; index += 1) {
60
- const backendNodeId = backendNodeIds[index];
61
- const nodeId = nodeIds[index];
62
- if (backendNodeId && typeof nodeId === "number" && nodeId > 0) nodeIdByBackendId.set(backendNodeId, nodeId);
63
- }
64
- for (const entry of refs) {
65
- const nodeId = nodeIdByBackendId.get(Math.floor(entry.backendDOMNodeId));
66
- if (!nodeId) continue;
67
- try {
68
- await send("DOM.setAttributeValue", {
69
- nodeId,
70
- name: BROWSER_REF_MARKER_ATTRIBUTE,
71
- value: entry.ref
72
- });
73
- marked.add(entry.ref);
74
- } catch {}
75
- }
76
- return marked;
77
- });
78
- }
79
- //#endregion
80
- //#region extensions/browser/src/browser/pw-session.ts
81
- const { chromium } = playwrightCore;
82
- var BrowserObservedDialogBlockedError = class extends Error {
83
- constructor(browserState) {
84
- super("Browser action blocked by a modal dialog.");
85
- this.name = "BrowserObservedDialogBlockedError";
86
- this.browserState = browserState;
87
- }
88
- };
89
- function isBrowserObservedDialogBlockedError(err) {
90
- return err instanceof BrowserObservedDialogBlockedError;
91
- }
92
- const pageStates = /* @__PURE__ */ new WeakMap();
93
- const contextStates = /* @__PURE__ */ new WeakMap();
94
- const observedContexts = /* @__PURE__ */ new WeakSet();
95
- const observedPages = /* @__PURE__ */ new WeakSet();
96
- const roleRefsByTarget = /* @__PURE__ */ new Map();
97
- const MAX_ROLE_REFS_CACHE = 50;
98
- const MAX_CONSOLE_MESSAGES = 500;
99
- const MAX_PAGE_ERRORS = 200;
100
- const MAX_NETWORK_REQUESTS = 500;
101
- const MAX_RECENT_DIALOGS = 20;
102
- const OBSERVED_DIALOG_TIMEOUT_MS = 12e4;
103
- const cachedByCdpUrl = /* @__PURE__ */ new Map();
104
- const connectingByCdpUrl = /* @__PURE__ */ new Map();
105
- const blockedTargetsByCdpUrl = /* @__PURE__ */ new Set();
106
- const blockedPageRefsByCdpUrl = /* @__PURE__ */ new Map();
107
- function normalizeCdpUrl(raw) {
108
- return raw.replace(/\/$/, "");
109
- }
110
- function buildManagedDownloadPath(fileName) {
111
- const id = crypto.randomUUID();
112
- const safeName = sanitizeUntrustedFileName(fileName, "download.bin");
113
- return path.join(DEFAULT_DOWNLOAD_DIR, `${id}-${safeName}`);
114
- }
115
- function hasCachedPlaywrightBrowserConnection(cdpUrl) {
116
- return cachedByCdpUrl.has(normalizeCdpUrl(cdpUrl));
117
- }
118
- function isRecoverablePlaywrightDisconnectError(err) {
119
- const message = formatErrorMessage(err).toLowerCase();
120
- return message.includes("target page, context or browser has been closed") || message.includes("browser has been closed") || message.includes("browser disconnected") || message.includes("target closed") || message.includes("connection closed") || message.includes("websocket closed") || message.includes("cdp socket closed");
121
- }
122
- function isRecoverableStalePageSelectionError(err, reusedCachedBrowser) {
123
- if (!reusedCachedBrowser) return false;
124
- if (err instanceof Error && err.message.includes("No pages available in the connected browser.")) return true;
125
- if (err instanceof BrowserTabNotFoundError) return true;
126
- return (err instanceof Error ? err.message : formatErrorMessage(err)).toLowerCase().includes("tab not found");
127
- }
128
- function findNetworkRequestById(state, id) {
129
- for (let i = state.requests.length - 1; i >= 0; i -= 1) {
130
- const candidate = state.requests[i];
131
- if (candidate && candidate.id === id) return candidate;
132
- }
133
- }
134
- function appendRecentDialog(state, record) {
135
- state.recentDialogs.push(record);
136
- while (state.recentDialogs.length > MAX_RECENT_DIALOGS) state.recentDialogs.shift();
137
- }
138
- function serializeDialogRecord(dialog) {
139
- return {
140
- id: dialog.id,
141
- type: dialog.type,
142
- message: dialog.message,
143
- ...dialog.defaultValue !== void 0 ? { defaultValue: dialog.defaultValue } : {},
144
- openedAt: dialog.openedAt,
145
- ...dialog.closedAt !== void 0 ? { closedAt: dialog.closedAt } : {},
146
- ...dialog.closedBy !== void 0 ? { closedBy: dialog.closedBy } : {}
147
- };
148
- }
149
- function serializePendingDialog(dialog) {
150
- return serializeDialogRecord(dialog);
151
- }
152
- function serializeObservedBrowserState(state) {
153
- return { dialogs: {
154
- pending: state.pendingDialogs.map(serializePendingDialog),
155
- recent: state.recentDialogs.map(serializeDialogRecord)
156
- } };
157
- }
158
- function clearArmedDialogResponse(state) {
159
- if (state.armedDialogResponse?.timer) clearTimeout(state.armedDialogResponse.timer);
160
- state.armedDialogResponse = void 0;
161
- }
162
- function abortActionsBlockedByDialog(state) {
163
- if (state.dialogAbortControllers.size === 0) return;
164
- const err = new BrowserObservedDialogBlockedError(serializeObservedBrowserState(state));
165
- for (const controller of state.dialogAbortControllers) if (!controller.signal.aborted) controller.abort(err);
166
- state.dialogAbortControllers.clear();
167
- }
168
- function isNoDialogShowingError(err) {
169
- return (err instanceof Error ? err.message : String(err)).toLowerCase().includes("no dialog is showing");
170
- }
171
- async function settleObservedDialog(params) {
172
- const { state, pending } = params;
173
- state.pendingDialogs = state.pendingDialogs.filter((dialog) => dialog.id !== pending.id);
174
- let closedBy = params.closedBy;
175
- try {
176
- if (params.accept) await pending.dialog.accept(params.promptText);
177
- else await pending.dialog.dismiss();
178
- } catch (err) {
179
- if (!isNoDialogShowingError(err)) {
180
- if (params.closedBy === "agent") state.pendingDialogs.push(pending);
181
- throw err;
182
- }
183
- closedBy = "remote";
184
- }
185
- const record = {
186
- id: pending.id,
187
- type: pending.type,
188
- message: pending.message,
189
- ...pending.defaultValue !== void 0 ? { defaultValue: pending.defaultValue } : {},
190
- openedAt: pending.openedAt,
191
- closedAt: (/* @__PURE__ */ new Date()).toISOString(),
192
- closedBy
193
- };
194
- appendRecentDialog(state, record);
195
- return record;
196
- }
197
- function observeDialog(pageState, dialog) {
198
- pageState.nextObservedDialogId += 1;
199
- const type = dialog.type();
200
- const defaultValue = dialog.defaultValue();
201
- const pending = {
202
- id: `d${pageState.nextObservedDialogId}`,
203
- type,
204
- message: dialog.message(),
205
- openedAt: (/* @__PURE__ */ new Date()).toISOString(),
206
- dialog,
207
- ...type === "prompt" ? { defaultValue } : {}
208
- };
209
- pageState.pendingDialogs.push(pending);
210
- const armed = pageState.armedDialogResponse;
211
- if (armed && armed.expiresAt >= Date.now()) {
212
- clearArmedDialogResponse(pageState);
213
- settleObservedDialog({
214
- state: pageState,
215
- pending,
216
- accept: armed.accept,
217
- ...armed.promptText !== void 0 ? { promptText: armed.promptText } : {},
218
- closedBy: "armed"
219
- }).catch(() => {});
220
- return;
221
- }
222
- if (armed) clearArmedDialogResponse(pageState);
223
- abortActionsBlockedByDialog(pageState);
224
- }
225
- function targetKey(cdpUrl, targetId) {
226
- return `${normalizeCdpUrl(cdpUrl)}::${targetId}`;
227
- }
228
- function roleRefsKey(cdpUrl, targetId) {
229
- return targetKey(cdpUrl, targetId);
230
- }
231
- function isBlockedTarget(cdpUrl, targetId) {
232
- const normalizedTargetId = normalizeOptionalString$1(targetId) ?? "";
233
- if (!normalizedTargetId) return false;
234
- return blockedTargetsByCdpUrl.has(targetKey(cdpUrl, normalizedTargetId));
235
- }
236
- function markTargetBlocked(cdpUrl, targetId) {
237
- const normalizedTargetId = normalizeOptionalString$1(targetId) ?? "";
238
- if (!normalizedTargetId) return;
239
- blockedTargetsByCdpUrl.add(targetKey(cdpUrl, normalizedTargetId));
240
- }
241
- function clearBlockedTarget(cdpUrl, targetId) {
242
- const normalizedTargetId = normalizeOptionalString$1(targetId) ?? "";
243
- if (!normalizedTargetId) return;
244
- blockedTargetsByCdpUrl.delete(targetKey(cdpUrl, normalizedTargetId));
245
- }
246
- function clearBlockedTargetsForCdpUrl(cdpUrl) {
247
- if (!cdpUrl) {
248
- blockedTargetsByCdpUrl.clear();
249
- return;
250
- }
251
- const prefix = `${normalizeCdpUrl(cdpUrl)}::`;
252
- for (const key of blockedTargetsByCdpUrl) if (key.startsWith(prefix)) blockedTargetsByCdpUrl.delete(key);
253
- }
254
- function blockedPageRefsForCdpUrl(cdpUrl) {
255
- const normalized = normalizeCdpUrl(cdpUrl);
256
- const existing = blockedPageRefsByCdpUrl.get(normalized);
257
- if (existing) return existing;
258
- const created = /* @__PURE__ */ new WeakSet();
259
- blockedPageRefsByCdpUrl.set(normalized, created);
260
- return created;
261
- }
262
- function isBlockedPageRef(cdpUrl, page) {
263
- return blockedPageRefsByCdpUrl.get(normalizeCdpUrl(cdpUrl))?.has(page) ?? false;
264
- }
265
- function markPageRefBlocked(cdpUrl, page) {
266
- blockedPageRefsForCdpUrl(cdpUrl).add(page);
267
- }
268
- function clearBlockedPageRefsForCdpUrl(cdpUrl) {
269
- if (!cdpUrl) {
270
- blockedPageRefsByCdpUrl.clear();
271
- return;
272
- }
273
- blockedPageRefsByCdpUrl.delete(normalizeCdpUrl(cdpUrl));
274
- }
275
- function clearBlockedPageRef(cdpUrl, page) {
276
- blockedPageRefsByCdpUrl.get(normalizeCdpUrl(cdpUrl))?.delete(page);
277
- }
278
- function takeCachedPlaywrightBrowserConnection(cdpUrl) {
279
- const normalized = normalizeCdpUrl(cdpUrl);
280
- const cur = cachedByCdpUrl.get(normalized);
281
- cachedByCdpUrl.delete(normalized);
282
- connectingByCdpUrl.delete(normalized);
283
- if (!cur) return null;
284
- if (cur.onDisconnected && typeof cur.browser.off === "function") cur.browser.off("disconnected", cur.onDisconnected);
285
- return cur;
286
- }
287
- function evictStalePlaywrightBrowserConnection(cdpUrl) {
288
- takeCachedPlaywrightBrowserConnection(cdpUrl)?.browser.close().catch(() => {});
289
- }
290
- function hasBlockedTargetsForCdpUrl(cdpUrl) {
291
- const prefix = `${normalizeCdpUrl(cdpUrl)}::`;
292
- for (const key of blockedTargetsByCdpUrl) if (key.startsWith(prefix)) return true;
293
- return false;
294
- }
295
- var BlockedBrowserTargetError = class extends Error {
296
- constructor() {
297
- super("Browser target is unavailable after SSRF policy blocked its navigation.");
298
- this.name = "BlockedBrowserTargetError";
299
- }
300
- };
301
- function rememberRoleRefsForTarget(opts) {
302
- const targetId = normalizeOptionalString$1(opts.targetId) ?? "";
303
- if (!targetId) return;
304
- roleRefsByTarget.set(roleRefsKey(opts.cdpUrl, targetId), {
305
- refs: opts.refs,
306
- ...opts.frameSelector ? { frameSelector: opts.frameSelector } : {},
307
- ...opts.mode ? { mode: opts.mode } : {}
308
- });
309
- while (roleRefsByTarget.size > MAX_ROLE_REFS_CACHE) {
310
- const first = roleRefsByTarget.keys().next();
311
- if (first.done) break;
312
- roleRefsByTarget.delete(first.value);
313
- }
314
- }
315
- function storeRoleRefsForTarget(opts) {
316
- const state = ensurePageState(opts.page);
317
- state.roleRefs = opts.refs;
318
- state.roleRefsFrameSelector = opts.frameSelector;
319
- state.roleRefsMode = opts.mode;
320
- const targetId = normalizeOptionalString$1(opts.targetId);
321
- if (!targetId) return;
322
- rememberRoleRefsForTarget({
323
- cdpUrl: opts.cdpUrl,
324
- targetId,
325
- refs: opts.refs,
326
- frameSelector: opts.frameSelector,
327
- mode: opts.mode
328
- });
329
- }
330
- function restoreRoleRefsForTarget(opts) {
331
- const targetId = normalizeOptionalString$1(opts.targetId) ?? "";
332
- if (!targetId) return;
333
- const cached = roleRefsByTarget.get(roleRefsKey(opts.cdpUrl, targetId));
334
- if (!cached) return;
335
- const state = ensurePageState(opts.page);
336
- if (state.roleRefs) return;
337
- state.roleRefs = cached.refs;
338
- state.roleRefsFrameSelector = cached.frameSelector;
339
- state.roleRefsMode = cached.mode;
340
- }
341
- function ensurePageState(page) {
342
- const existing = pageStates.get(page);
343
- if (existing) return existing;
344
- const state = {
345
- console: [],
346
- errors: [],
347
- requests: [],
348
- requestIds: /* @__PURE__ */ new WeakMap(),
349
- nextRequestId: 0,
350
- armIdUpload: 0,
351
- armIdDownload: 0,
352
- downloadWaiterDepth: 0,
353
- nextObservedDialogId: 0,
354
- pendingDialogs: [],
355
- recentDialogs: [],
356
- dialogAbortControllers: /* @__PURE__ */ new Set()
357
- };
358
- pageStates.set(page, state);
359
- if (!observedPages.has(page)) {
360
- observedPages.add(page);
361
- page.on("console", (msg) => {
362
- const entry = {
363
- type: msg.type(),
364
- text: msg.text(),
365
- timestamp: (/* @__PURE__ */ new Date()).toISOString(),
366
- location: msg.location()
367
- };
368
- state.console.push(entry);
369
- if (state.console.length > MAX_CONSOLE_MESSAGES) state.console.shift();
370
- });
371
- page.on("pageerror", (err) => {
372
- state.errors.push({
373
- message: err.message || String(err),
374
- name: err.name || void 0,
375
- stack: err.stack || void 0,
376
- timestamp: (/* @__PURE__ */ new Date()).toISOString()
377
- });
378
- if (state.errors.length > MAX_PAGE_ERRORS) state.errors.shift();
379
- });
380
- page.on("request", (req) => {
381
- state.nextRequestId += 1;
382
- const id = `r${state.nextRequestId}`;
383
- state.requestIds.set(req, id);
384
- state.requests.push({
385
- id,
386
- timestamp: (/* @__PURE__ */ new Date()).toISOString(),
387
- method: req.method(),
388
- url: req.url(),
389
- resourceType: req.resourceType()
390
- });
391
- if (state.requests.length > MAX_NETWORK_REQUESTS) state.requests.shift();
392
- });
393
- page.on("response", (resp) => {
394
- const req = resp.request();
395
- const id = state.requestIds.get(req);
396
- if (!id) return;
397
- const rec = findNetworkRequestById(state, id);
398
- if (!rec) return;
399
- rec.status = resp.status();
400
- rec.ok = resp.ok();
401
- });
402
- page.on("requestfailed", (req) => {
403
- const id = state.requestIds.get(req);
404
- if (!id) return;
405
- const rec = findNetworkRequestById(state, id);
406
- if (!rec) return;
407
- rec.failureText = req.failure()?.errorText;
408
- rec.ok = false;
409
- });
410
- page.on("dialog", (dialog) => {
411
- observeDialog(state, dialog);
412
- });
413
- page.on("download", (download) => {
414
- if (state.downloadWaiterDepth > 0) return;
415
- const managedPath = buildManagedDownloadPath(sanitizeUntrustedFileName(download.suggestedFilename?.() || "download.bin", "download.bin"));
416
- const managedSave = (async () => {
417
- await writeViaSiblingTempPath({
418
- rootDir: DEFAULT_DOWNLOAD_DIR,
419
- targetPath: managedPath,
420
- writeTemp: async (tempPath) => {
421
- await download.saveAs?.(tempPath);
422
- }
423
- });
424
- return managedPath;
425
- })();
426
- managedSave.catch(() => {});
427
- download.path = async () => await managedSave;
428
- });
429
- page.on("close", () => {
430
- clearArmedDialogResponse(state);
431
- for (const controller of state.dialogAbortControllers) if (!controller.signal.aborted) controller.abort(/* @__PURE__ */ new Error("Page closed before browser action completed."));
432
- state.dialogAbortControllers.clear();
433
- state.pendingDialogs = [];
434
- pageStates.delete(page);
435
- observedPages.delete(page);
436
- });
437
- }
438
- return state;
439
- }
440
- function getObservedBrowserStateForPage(page) {
441
- return serializeObservedBrowserState(ensurePageState(page));
442
- }
443
- async function getObservedBrowserStateViaPlaywright(opts) {
444
- return getObservedBrowserStateForPage(await getPageForTargetId(opts));
445
- }
446
- function resolvePendingDialogForResponse(params) {
447
- const dialogId = normalizeOptionalString$1(params.dialogId);
448
- if (dialogId) {
449
- const found = params.state.pendingDialogs.find((dialog) => dialog.id === dialogId);
450
- if (found) return found;
451
- throw new Error(`Dialog "${dialogId}" is not pending.`);
452
- }
453
- if (params.state.pendingDialogs.length === 1) return params.state.pendingDialogs[0];
454
- if (params.state.pendingDialogs.length > 1) throw new Error("Multiple dialogs are pending; pass dialogId.");
455
- throw new Error("No dialog is pending.");
456
- }
457
- async function respondToObservedDialogOnPage(opts) {
458
- const state = ensurePageState(opts.page);
459
- return await settleObservedDialog({
460
- state,
461
- pending: resolvePendingDialogForResponse({
462
- state,
463
- ...opts.dialogId !== void 0 ? { dialogId: opts.dialogId } : {}
464
- }),
465
- accept: opts.accept,
466
- ...opts.promptText !== void 0 ? { promptText: opts.promptText } : {},
467
- closedBy: opts.closedBy ?? "agent"
468
- });
469
- }
470
- async function respondToObservedDialogViaPlaywright(opts) {
471
- return await respondToObservedDialogOnPage({
472
- page: await getPageForTargetId(opts),
473
- accept: opts.accept,
474
- ...opts.dialogId !== void 0 ? { dialogId: opts.dialogId } : {},
475
- ...opts.promptText !== void 0 ? { promptText: opts.promptText } : {}
476
- });
477
- }
478
- function markObservedDialogsHandledRemotelyForPage(page) {
479
- const state = ensurePageState(page);
480
- const pending = state.pendingDialogs.splice(0);
481
- const closedAt = (/* @__PURE__ */ new Date()).toISOString();
482
- for (const dialog of pending) appendRecentDialog(state, {
483
- id: dialog.id,
484
- type: dialog.type,
485
- message: dialog.message,
486
- ...dialog.defaultValue !== void 0 ? { defaultValue: dialog.defaultValue } : {},
487
- openedAt: dialog.openedAt,
488
- closedAt,
489
- closedBy: "remote"
490
- });
491
- return serializeObservedBrowserState(state);
492
- }
493
- function armObservedDialogResponseOnPage(opts) {
494
- const state = ensurePageState(opts.page);
495
- clearArmedDialogResponse(state);
496
- const timeoutMs = Math.max(1, Math.floor(opts.timeoutMs ?? OBSERVED_DIALOG_TIMEOUT_MS));
497
- const response = {
498
- accept: opts.accept,
499
- expiresAt: Date.now() + timeoutMs,
500
- ...opts.promptText !== void 0 ? { promptText: opts.promptText } : {}
501
- };
502
- response.timer = setTimeout(() => {
503
- if (state.armedDialogResponse === response) state.armedDialogResponse = void 0;
504
- }, timeoutMs);
505
- state.armedDialogResponse = response;
506
- }
507
- function createObservedDialogAbortSignalForPage(opts) {
508
- const state = ensurePageState(opts.page);
509
- const controller = new AbortController();
510
- const abortForCurrentDialog = () => {
511
- if (!controller.signal.aborted) controller.abort(new BrowserObservedDialogBlockedError(serializeObservedBrowserState(state)));
512
- };
513
- const abortForParent = () => {
514
- if (!controller.signal.aborted) controller.abort(opts.parentSignal?.reason ?? /* @__PURE__ */ new Error("aborted"));
515
- };
516
- if (state.pendingDialogs.length > 0) abortForCurrentDialog();
517
- else state.dialogAbortControllers.add(controller);
518
- if (opts.parentSignal) if (opts.parentSignal.aborted) abortForParent();
519
- else opts.parentSignal.addEventListener("abort", abortForParent, { once: true });
520
- return {
521
- signal: controller.signal,
522
- cleanup: () => {
523
- state.dialogAbortControllers.delete(controller);
524
- opts.parentSignal?.removeEventListener("abort", abortForParent);
525
- }
526
- };
527
- }
528
- function observeContext(context) {
529
- if (observedContexts.has(context)) return;
530
- observedContexts.add(context);
531
- ensureContextState(context);
532
- for (const page of context.pages()) ensurePageState(page);
533
- context.on("page", (page) => ensurePageState(page));
534
- }
535
- function ensureContextState(context) {
536
- const existing = contextStates.get(context);
537
- if (existing) return existing;
538
- const state = { traceActive: false };
539
- contextStates.set(context, state);
540
- return state;
541
- }
542
- function observeBrowser(browser) {
543
- for (const context of browser.contexts()) observeContext(context);
544
- }
545
- async function connectBrowser(cdpUrl, ssrfPolicy) {
546
- const normalized = normalizeCdpUrl(cdpUrl);
547
- const cached = cachedByCdpUrl.get(normalized);
548
- if (cached) return cached;
549
- await assertCdpEndpointAllowed(normalized, ssrfPolicy);
550
- const connecting = connectingByCdpUrl.get(normalized);
551
- if (connecting) return await connecting;
552
- const connectWithRetry = async () => {
553
- let lastErr;
554
- for (let attempt = 0; attempt < 3; attempt += 1) try {
555
- const timeout = 5e3 + attempt * 2e3;
556
- const endpoint = await getChromeWebSocketUrl(normalized, timeout, ssrfPolicy).catch(() => null) ?? normalized;
557
- const connectEndpoint = async (target) => {
558
- const headers = getHeadersWithAuth(target);
559
- return await withNoProxyForCdpUrl(target, () => chromium.connectOverCDP(target, {
560
- timeout,
561
- headers
562
- }));
563
- };
564
- let browser;
565
- try {
566
- browser = await connectEndpoint(endpoint);
567
- } catch (err) {
568
- if (!isWebSocketUrl(normalized) || endpoint === normalized) throw err;
569
- browser = await connectEndpoint(normalized);
570
- }
571
- const onDisconnected = () => {
572
- if (cachedByCdpUrl.get(normalized)?.browser === browser) cachedByCdpUrl.delete(normalized);
573
- };
574
- const connected = {
575
- browser,
576
- cdpUrl: normalized,
577
- onDisconnected
578
- };
579
- cachedByCdpUrl.set(normalized, connected);
580
- browser.on("disconnected", onDisconnected);
581
- observeBrowser(browser);
582
- return connected;
583
- } catch (err) {
584
- lastErr = err;
585
- if (formatErrorMessage(err).includes("rate limit")) break;
586
- const delay = 250 + attempt * 250;
587
- await new Promise((r) => setTimeout(r, delay));
588
- }
589
- if (lastErr instanceof Error) throw lastErr;
590
- const message = lastErr ? formatErrorMessage(lastErr) : "CDP connect failed";
591
- throw new Error(message);
592
- };
593
- const pending = connectWithRetry().finally(() => {
594
- connectingByCdpUrl.delete(normalized);
595
- });
596
- connectingByCdpUrl.set(normalized, pending);
597
- return await pending;
598
- }
599
- async function getAllPages(browser) {
600
- return browser.contexts().flatMap((c) => c.pages());
601
- }
602
- async function partitionAccessiblePages(opts) {
603
- const accessible = [];
604
- let blockedCount = 0;
605
- for (const page of opts.pages) {
606
- if (isBlockedPageRef(opts.cdpUrl, page)) {
607
- blockedCount += 1;
608
- continue;
609
- }
610
- const targetId = await pageTargetId(page).catch(() => null);
611
- if (!targetId) {
612
- if (hasBlockedTargetsForCdpUrl(opts.cdpUrl)) {
613
- blockedCount += 1;
614
- continue;
615
- }
616
- accessible.push(page);
617
- continue;
618
- }
619
- if (isBlockedTarget(opts.cdpUrl, targetId)) {
620
- blockedCount += 1;
621
- continue;
622
- }
623
- accessible.push(page);
624
- }
625
- return {
626
- accessible,
627
- blockedCount
628
- };
629
- }
630
- async function pageTargetId(page) {
631
- const session = await page.context().newCDPSession(page);
632
- try {
633
- return (normalizeOptionalString$1((await session.send("Target.getTargetInfo"))?.targetInfo?.targetId) ?? "") || null;
634
- } finally {
635
- await session.detach().catch(() => {});
636
- }
637
- }
638
- function matchPageByTargetList(pages, targets, targetId) {
639
- const target = targets.find((entry) => entry.id === targetId);
640
- if (!target) return null;
641
- const urlMatch = pages.filter((page) => page.url() === target.url);
642
- if (urlMatch.length === 1) return urlMatch[0] ?? null;
643
- if (urlMatch.length > 1) {
644
- const sameUrlTargets = targets.filter((entry) => entry.url === target.url);
645
- if (sameUrlTargets.length === urlMatch.length) {
646
- const idx = sameUrlTargets.findIndex((entry) => entry.id === targetId);
647
- if (idx >= 0 && idx < urlMatch.length) return urlMatch[idx] ?? null;
648
- }
649
- }
650
- return null;
651
- }
652
- async function findPageByTargetIdViaTargetList(pages, targetId, cdpUrl, ssrfPolicy) {
653
- const cdpHttpBase = normalizeCdpHttpBaseForJsonEndpoints(cdpUrl);
654
- await assertCdpEndpointAllowed(cdpUrl, ssrfPolicy);
655
- return matchPageByTargetList(pages, await fetchJson(appendCdpPath(cdpHttpBase, "/json/list"), 2e3), targetId);
656
- }
657
- async function findPageByTargetId(browser, targetId, cdpUrl, ssrfPolicy) {
658
- const pages = await getAllPages(browser);
659
- let resolvedViaCdp = false;
660
- for (const page of pages) {
661
- let tid = null;
662
- try {
663
- tid = await pageTargetId(page);
664
- resolvedViaCdp = true;
665
- } catch {
666
- tid = null;
667
- }
668
- if (tid && tid === targetId) return page;
669
- }
670
- if (cdpUrl) try {
671
- return await findPageByTargetIdViaTargetList(pages, targetId, cdpUrl, ssrfPolicy);
672
- } catch {}
673
- if (!resolvedViaCdp && pages.length === 1) return pages[0] ?? null;
674
- return null;
675
- }
676
- async function resolvePageByTargetIdOrThrow(opts) {
677
- if (isBlockedTarget(opts.cdpUrl, opts.targetId)) throw new BlockedBrowserTargetError();
678
- const { browser } = await connectBrowser(opts.cdpUrl, opts.ssrfPolicy);
679
- const page = await findPageByTargetId(browser, opts.targetId, opts.cdpUrl, opts.ssrfPolicy);
680
- if (!page) throw new BrowserTabNotFoundError();
681
- return page;
682
- }
683
- async function getPageForTargetIdOnce(opts) {
684
- if (opts.targetId && isBlockedTarget(opts.cdpUrl, opts.targetId)) throw new BlockedBrowserTargetError();
685
- const { browser } = await connectBrowser(opts.cdpUrl, opts.ssrfPolicy);
686
- const pages = await getAllPages(browser);
687
- if (!pages.length) throw new Error("No pages available in the connected browser.");
688
- const { accessible, blockedCount } = await partitionAccessiblePages({
689
- cdpUrl: opts.cdpUrl,
690
- pages
691
- });
692
- if (!accessible.length) {
693
- if (blockedCount > 0) throw new BlockedBrowserTargetError();
694
- throw new Error("No pages available in the connected browser.");
695
- }
696
- const first = accessible[0];
697
- if (!opts.targetId) return first;
698
- const found = await findPageByTargetId(browser, opts.targetId, opts.cdpUrl, opts.ssrfPolicy);
699
- if (found) {
700
- if (isBlockedPageRef(opts.cdpUrl, found)) throw new BlockedBrowserTargetError();
701
- const foundTargetId = await pageTargetId(found).catch(() => null);
702
- if (foundTargetId && isBlockedTarget(opts.cdpUrl, foundTargetId)) throw new BlockedBrowserTargetError();
703
- return found;
704
- }
705
- if (pages.length === 1) return first;
706
- throw new BrowserTabNotFoundError();
707
- }
708
- async function getPageForTargetId(opts) {
709
- const reusedCachedBrowser = hasCachedPlaywrightBrowserConnection(opts.cdpUrl);
710
- try {
711
- return await getPageForTargetIdOnce(opts);
712
- } catch (err) {
713
- if (!isRecoverableStalePageSelectionError(err, reusedCachedBrowser)) throw err;
714
- await closePlaywrightBrowserConnection({ cdpUrl: opts.cdpUrl });
715
- return await getPageForTargetIdOnce(opts);
716
- }
717
- }
718
- function isTopLevelNavigationRequest(page, request) {
719
- let sameMainFrame = false;
720
- try {
721
- sameMainFrame = request.frame() === page.mainFrame();
722
- } catch {
723
- sameMainFrame = true;
724
- }
725
- if (!sameMainFrame) return false;
726
- try {
727
- if (request.isNavigationRequest()) return true;
728
- } catch {}
729
- try {
730
- return request.resourceType() === "document";
731
- } catch {
732
- return false;
733
- }
734
- }
735
- function isSubframeDocumentNavigationRequest(page, request) {
736
- let sameMainFrame = false;
737
- try {
738
- sameMainFrame = request.frame() === page.mainFrame();
739
- } catch {
740
- return true;
741
- }
742
- if (sameMainFrame) return false;
743
- try {
744
- if (request.isNavigationRequest()) return true;
745
- } catch {}
746
- try {
747
- return request.resourceType() === "document";
748
- } catch {
749
- return false;
750
- }
751
- }
752
- function isPolicyDenyNavigationError(err) {
753
- return err instanceof SsrFBlockedError || err instanceof InvalidBrowserNavigationUrlError;
754
- }
755
- async function quarantineBlockedTarget(opts) {
756
- markPageRefBlocked(opts.cdpUrl, opts.page);
757
- const resolvedTargetId = await pageTargetId(opts.page).catch(() => null);
758
- const fallbackTargetId = normalizeOptionalString$1(opts.targetId) ?? "";
759
- const targetIdToBlock = resolvedTargetId || fallbackTargetId;
760
- if (targetIdToBlock) markTargetBlocked(opts.cdpUrl, targetIdToBlock);
761
- }
762
- async function closeBlockedNavigationTarget(opts) {
763
- await quarantineBlockedTarget(opts);
764
- await opts.page.close().catch(() => {});
765
- }
766
- async function assertPageNavigationCompletedSafely(opts) {
767
- const navigationPolicy = withBrowserNavigationPolicy(opts.ssrfPolicy, { browserProxyMode: opts.browserProxyMode });
768
- try {
769
- await assertBrowserNavigationRedirectChainAllowed({
770
- request: opts.response?.request(),
771
- ...navigationPolicy
772
- });
773
- await assertBrowserNavigationResultAllowed({
774
- url: opts.page.url(),
775
- ...navigationPolicy
776
- });
777
- } catch (err) {
778
- if (isPolicyDenyNavigationError(err)) await quarantineBlockedTarget({
779
- cdpUrl: opts.cdpUrl,
780
- page: opts.page,
781
- targetId: opts.targetId
782
- });
783
- throw err;
784
- }
785
- }
786
- async function continueRouteSafely(route) {
787
- try {
788
- await route.continue();
789
- } catch (err) {
790
- if ((err instanceof Error ? err.message : "").includes("Route is already handled")) return;
791
- throw err;
792
- }
793
- }
794
- async function gotoPageWithNavigationGuard(opts) {
795
- const navigationPolicy = withBrowserNavigationPolicy(opts.ssrfPolicy, { browserProxyMode: opts.browserProxyMode });
796
- let blockedError = null;
797
- const handler = async (route, request) => {
798
- if (blockedError) {
799
- await route.abort().catch(() => {});
800
- return;
801
- }
802
- const isTopLevel = isTopLevelNavigationRequest(opts.page, request);
803
- const isSubframeDocument = !isTopLevel && isSubframeDocumentNavigationRequest(opts.page, request);
804
- if (!isTopLevel && !isSubframeDocument) {
805
- await continueRouteSafely(route);
806
- return;
807
- }
808
- try {
809
- await assertBrowserNavigationAllowed({
810
- url: request.url(),
811
- ...navigationPolicy
812
- });
813
- } catch (err) {
814
- if (isPolicyDenyNavigationError(err)) {
815
- if (isTopLevel) blockedError = err;
816
- await route.abort().catch(() => {});
817
- return;
818
- }
819
- throw err;
820
- }
821
- await continueRouteSafely(route);
822
- };
823
- await opts.page.route("**", handler);
824
- try {
825
- const response = await opts.page.goto(opts.url, { timeout: opts.timeoutMs });
826
- if (blockedError) throw blockedError;
827
- return response;
828
- } catch (err) {
829
- if (blockedError) throw blockedError;
830
- throw err;
831
- } finally {
832
- await opts.page.unroute("**", handler).catch(() => {});
833
- if (blockedError) await closeBlockedNavigationTarget({
834
- cdpUrl: opts.cdpUrl,
835
- page: opts.page,
836
- targetId: opts.targetId
837
- });
838
- }
839
- }
840
- function refLocator(page, ref) {
841
- const normalized = ref.startsWith("@") ? ref.slice(1) : ref.startsWith("ref=") ? ref.slice(4) : ref;
842
- if (/^e\d+$/.test(normalized)) {
843
- const state = pageStates.get(page);
844
- if (state?.roleRefsMode === "aria") return (state.roleRefsFrameSelector ? page.frameLocator(state.roleRefsFrameSelector) : page).locator(`aria-ref=${normalized}`);
845
- const info = state?.roleRefs?.[normalized];
846
- if (!info) throw new Error(`Unknown ref "${normalized}". Run a new snapshot and use a ref from that snapshot.`);
847
- const locAny = state?.roleRefsFrameSelector ? page.frameLocator(state.roleRefsFrameSelector) : page;
848
- const locator = info.name ? locAny.getByRole(info.role, {
849
- name: info.name,
850
- exact: true
851
- }) : locAny.getByRole(info.role);
852
- return info.nth !== void 0 ? locator.nth(info.nth) : locator;
853
- }
854
- if (AX_REF_PATTERN.test(normalized)) {
855
- const state = pageStates.get(page);
856
- const info = state?.roleRefs?.[normalized];
857
- if (!info) throw new Error(`Unknown ref "${normalized}". Run a new snapshot and use a ref from that snapshot.`);
858
- const scope = state.roleRefsFrameSelector ? page.frameLocator(state.roleRefsFrameSelector) : page;
859
- if (info.domMarker) return scope.locator(`[${BROWSER_REF_MARKER_ATTRIBUTE}="${normalized}"]`);
860
- const locAny = scope;
861
- const locator = info.name ? locAny.getByRole(info.role, {
862
- name: info.name,
863
- exact: true
864
- }) : locAny.getByRole(info.role);
865
- return info.nth !== void 0 ? locator.nth(info.nth) : locator;
866
- }
867
- return page.locator(`aria-ref=${normalized}`);
868
- }
869
- async function closePlaywrightBrowserConnection(opts) {
870
- const normalized = opts?.cdpUrl ? normalizeCdpUrl(opts.cdpUrl) : null;
871
- if (normalized) {
872
- clearBlockedTargetsForCdpUrl(normalized);
873
- clearBlockedPageRefsForCdpUrl(normalized);
874
- const cur = takeCachedPlaywrightBrowserConnection(normalized);
875
- if (!cur) return;
876
- await cur.browser.close().catch(() => {});
877
- return;
878
- }
879
- const connections = Array.from(cachedByCdpUrl.values());
880
- clearBlockedTargetsForCdpUrl();
881
- clearBlockedPageRefsForCdpUrl();
882
- cachedByCdpUrl.clear();
883
- connectingByCdpUrl.clear();
884
- for (const cur of connections) {
885
- if (cur.onDisconnected && typeof cur.browser.off === "function") cur.browser.off("disconnected", cur.onDisconnected);
886
- await cur.browser.close().catch(() => {});
887
- }
888
- }
889
- function cdpSocketNeedsAttach(wsUrl) {
890
- try {
891
- const pathname = new URL(wsUrl).pathname;
892
- return pathname === "/cdp" || pathname.endsWith("/cdp") || pathname.includes("/devtools/browser/");
893
- } catch {
894
- return false;
895
- }
896
- }
897
- async function tryTerminateExecutionViaCdp(opts) {
898
- await assertCdpEndpointAllowed(opts.cdpUrl, opts.ssrfPolicy);
899
- const cdpHttpBase = normalizeCdpHttpBaseForJsonEndpoints(opts.cdpUrl);
900
- const pages = await fetchJson(appendCdpPath(cdpHttpBase, "/json/list"), 2e3).catch(() => null);
901
- if (!pages || pages.length === 0) return;
902
- const targetId = normalizeOptionalString$1(opts.targetId) ?? "";
903
- const wsUrlRaw = normalizeOptionalString$1(pages.find((p) => normalizeOptionalString$1(p.id) === targetId)?.webSocketDebuggerUrl) ?? "";
904
- if (!wsUrlRaw) return;
905
- const wsUrl = normalizeCdpWsUrl(wsUrlRaw, cdpHttpBase);
906
- const needsAttach = cdpSocketNeedsAttach(wsUrl);
907
- const runWithTimeout = async (work, ms) => {
908
- let timer;
909
- const timeoutPromise = new Promise((_, reject) => {
910
- timer = setTimeout(() => reject(/* @__PURE__ */ new Error("CDP command timed out")), ms);
911
- });
912
- try {
913
- return await Promise.race([work, timeoutPromise]);
914
- } finally {
915
- if (timer) clearTimeout(timer);
916
- }
917
- };
918
- await withCdpSocket(wsUrl, async (send) => {
919
- let sessionId;
920
- try {
921
- if (needsAttach) {
922
- const attachedSessionId = normalizeOptionalString$1((await runWithTimeout(send("Target.attachToTarget", {
923
- targetId: opts.targetId,
924
- flatten: true
925
- }), 1500))?.sessionId);
926
- if (attachedSessionId) sessionId = attachedSessionId;
927
- }
928
- await runWithTimeout(send("Runtime.terminateExecution", void 0, sessionId), 1500);
929
- if (sessionId) send("Target.detachFromTarget", { sessionId }).catch(() => {});
930
- } catch {}
931
- }, { handshakeTimeoutMs: 2e3 }).catch(() => {});
932
- }
933
- /**
934
- * Best-effort cancellation for stuck page operations.
935
- *
936
- * Playwright serializes CDP commands per page; a long-running or stuck operation (notably evaluate)
937
- * can block all subsequent commands. We cannot safely "cancel" an individual command, and we do
938
- * not want to close the actual Chromium tab. Instead, we disconnect Playwright's CDP connection
939
- * so in-flight commands fail fast and the next request reconnects transparently.
940
- *
941
- * IMPORTANT: We CANNOT call Connection.close() because Playwright shares a single Connection
942
- * across all objects (BrowserType, Browser, etc.). Closing it corrupts the entire Playwright
943
- * instance, preventing reconnection.
944
- *
945
- * Instead we:
946
- * 1. Null out `cached` so the next call triggers a fresh connectOverCDP
947
- * 2. Fire-and-forget browser.close() — it may hang but won't block us
948
- * 3. The next connectBrowser() creates a completely new CDP WebSocket connection
949
- *
950
- * The old browser.close() eventually resolves when the in-browser evaluate timeout fires,
951
- * or the old connection gets GC'd. Either way, it doesn't affect the fresh connection.
952
- */
953
- async function forceDisconnectPlaywrightForTarget(opts) {
954
- const normalized = normalizeCdpUrl(opts.cdpUrl);
955
- const cur = takeCachedPlaywrightBrowserConnection(normalized);
956
- if (!cur) return;
957
- const targetId = normalizeOptionalString$1(opts.targetId) ?? "";
958
- if (targetId) await tryTerminateExecutionViaCdp({
959
- cdpUrl: normalized,
960
- targetId,
961
- ssrfPolicy: opts.ssrfPolicy
962
- }).catch(() => {});
963
- cur.browser.close().catch(() => {});
964
- }
965
- async function withPlaywrightSafeReadReconnect(cdpUrl, run) {
966
- try {
967
- return await run();
968
- } catch (err) {
969
- if (!isRecoverablePlaywrightDisconnectError(err)) throw err;
970
- evictStalePlaywrightBrowserConnection(cdpUrl);
971
- return await run();
972
- }
973
- }
974
- /**
975
- * List all pages/tabs from the persistent Playwright connection.
976
- * Used for remote profiles where HTTP-based /json/list is ephemeral.
977
- */
978
- async function listPagesViaPlaywright(opts) {
979
- return await withPlaywrightSafeReadReconnect(opts.cdpUrl, async () => {
980
- const { browser } = await connectBrowser(opts.cdpUrl, opts.ssrfPolicy);
981
- const pages = await getAllPages(browser);
982
- const results = [];
983
- for (const page of pages) {
984
- if (isBlockedPageRef(opts.cdpUrl, page)) continue;
985
- let tid;
986
- try {
987
- tid = await pageTargetId(page);
988
- } catch (err) {
989
- if (isRecoverablePlaywrightDisconnectError(err)) throw err;
990
- tid = null;
991
- }
992
- if (tid && !isBlockedTarget(opts.cdpUrl, tid)) {
993
- let title = "";
994
- try {
995
- title = await page.title();
996
- } catch (err) {
997
- if (isRecoverablePlaywrightDisconnectError(err)) throw err;
998
- }
999
- let url = "";
1000
- try {
1001
- url = page.url();
1002
- } catch (err) {
1003
- if (isRecoverablePlaywrightDisconnectError(err)) throw err;
1004
- }
1005
- if (!isSelectableCdpBrowserTarget({ url })) continue;
1006
- results.push({
1007
- targetId: tid,
1008
- title,
1009
- url,
1010
- type: "page"
1011
- });
1012
- }
1013
- }
1014
- return results;
1015
- });
1016
- }
1017
- /**
1018
- * Create a new page/tab using the persistent Playwright connection.
1019
- * Used for remote profiles where HTTP-based /json/new is ephemeral.
1020
- * Returns the new page's targetId and metadata.
1021
- */
1022
- async function createPageViaPlaywright(opts) {
1023
- const { browser } = await connectBrowser(opts.cdpUrl, opts.ssrfPolicy);
1024
- const context = browser.contexts()[0] ?? await browser.newContext();
1025
- ensureContextState(context);
1026
- const page = await context.newPage();
1027
- ensurePageState(page);
1028
- clearBlockedPageRef(opts.cdpUrl, page);
1029
- const createdTargetId = await pageTargetId(page).catch(() => null);
1030
- clearBlockedTarget(opts.cdpUrl, createdTargetId ?? void 0);
1031
- const targetUrl = opts.url.trim() || "about:blank";
1032
- if (targetUrl !== "about:blank") {
1033
- await assertBrowserNavigationAllowed({
1034
- url: targetUrl,
1035
- ...withBrowserNavigationPolicy(opts.ssrfPolicy, { browserProxyMode: opts.browserProxyMode })
1036
- });
1037
- let response = null;
1038
- try {
1039
- response = await gotoPageWithNavigationGuard({
1040
- cdpUrl: opts.cdpUrl,
1041
- page,
1042
- url: targetUrl,
1043
- timeoutMs: 3e4,
1044
- ssrfPolicy: opts.ssrfPolicy,
1045
- browserProxyMode: opts.browserProxyMode,
1046
- targetId: createdTargetId ?? void 0
1047
- });
1048
- } catch (err) {
1049
- if (isPolicyDenyNavigationError(err) || err instanceof BlockedBrowserTargetError) throw err;
1050
- }
1051
- try {
1052
- await assertPageNavigationCompletedSafely({
1053
- cdpUrl: opts.cdpUrl,
1054
- page,
1055
- response,
1056
- ssrfPolicy: opts.ssrfPolicy,
1057
- browserProxyMode: opts.browserProxyMode,
1058
- targetId: createdTargetId ?? void 0
1059
- });
1060
- } catch (err) {
1061
- if (isPolicyDenyNavigationError(err)) await closeBlockedNavigationTarget({
1062
- cdpUrl: opts.cdpUrl,
1063
- page,
1064
- targetId: createdTargetId ?? void 0
1065
- });
1066
- throw err;
1067
- }
1068
- }
1069
- const tid = createdTargetId || await pageTargetId(page).catch(() => null);
1070
- if (!tid) throw new Error("Failed to get targetId for new page");
1071
- return {
1072
- targetId: tid,
1073
- title: await page.title().catch(() => ""),
1074
- url: page.url(),
1075
- type: "page"
1076
- };
1077
- }
1078
- /**
1079
- * Close a page/tab by targetId using the persistent Playwright connection.
1080
- * Used for remote profiles where HTTP-based /json/close is ephemeral.
1081
- */
1082
- async function closePageByTargetIdViaPlaywright(opts) {
1083
- await (await resolvePageByTargetIdOrThrow(opts)).close();
1084
- }
1085
- /**
1086
- * Focus a page/tab by targetId using the persistent Playwright connection.
1087
- * Used for remote profiles where HTTP-based /json/activate can be ephemeral.
1088
- */
1089
- async function focusPageByTargetIdViaPlaywright(opts) {
1090
- const page = await resolvePageByTargetIdOrThrow(opts);
1091
- try {
1092
- await page.bringToFront();
1093
- } catch (err) {
1094
- try {
1095
- await withPageScopedCdpClient({
1096
- cdpUrl: opts.cdpUrl,
1097
- page,
1098
- targetId: opts.targetId,
1099
- fn: async (send) => {
1100
- await send("Page.bringToFront");
1101
- }
1102
- });
1103
- return;
1104
- } catch {
1105
- throw err;
1106
- }
1107
- }
1108
- }
1109
- //#endregion
1110
- //#region extensions/browser/src/browser/pw-tools-core.activity.ts
1111
- async function getPageErrorsViaPlaywright(opts) {
1112
- const state = ensurePageState(await getPageForTargetId(opts));
1113
- const errors = [...state.errors];
1114
- if (opts.clear) state.errors = [];
1115
- return { errors };
1116
- }
1117
- async function getNetworkRequestsViaPlaywright(opts) {
1118
- const state = ensurePageState(await getPageForTargetId(opts));
1119
- const raw = [...state.requests];
1120
- const filter = typeof opts.filter === "string" ? opts.filter.trim() : "";
1121
- const requests = filter ? raw.filter((r) => r.url.includes(filter)) : raw;
1122
- if (opts.clear) {
1123
- state.requests = [];
1124
- state.requestIds = /* @__PURE__ */ new WeakMap();
1125
- }
1126
- return { requests };
1127
- }
1128
- function consolePriority(level) {
1129
- switch (level) {
1130
- case "error": return 3;
1131
- case "warning": return 2;
1132
- case "info":
1133
- case "log": return 1;
1134
- case "debug": return 0;
1135
- default: return 1;
1136
- }
1137
- }
1138
- async function getConsoleMessagesViaPlaywright(opts) {
1139
- const state = ensurePageState(await getPageForTargetId(opts));
1140
- if (!opts.level) return [...state.console];
1141
- const min = consolePriority(opts.level);
1142
- return state.console.filter((msg) => consolePriority(msg.type) >= min);
1143
- }
1144
- //#endregion
1145
- //#region extensions/browser/src/browser/output-files.ts
1146
- async function writeExternalFileWithinOutputRoot(params) {
1147
- const outputPath = params.path.trim();
1148
- if (!outputPath) throw new Error("output path is required");
1149
- const rootDir = params.rootDir ? path.resolve(params.rootDir) : path.dirname(path.resolve(outputPath));
1150
- await ensureOutputDirectory(rootDir);
1151
- return (await writeExternalFileWithinRoot({
1152
- rootDir,
1153
- path: outputPath,
1154
- write: params.write
1155
- }).catch((err) => {
1156
- if (err instanceof Error && /file not found/i.test(err.message)) throw new Error("output directory changed while writing file");
1157
- throw err;
1158
- })).path;
1159
- }
1160
- //#endregion
1161
- //#region extensions/browser/src/browser/pw-tools-core.shared.ts
1162
- let nextUploadArmId = 0;
1163
- let nextDownloadArmId = 0;
1164
- function bumpUploadArmId() {
1165
- nextUploadArmId += 1;
1166
- return nextUploadArmId;
1167
- }
1168
- function bumpDownloadArmId() {
1169
- nextDownloadArmId += 1;
1170
- return nextDownloadArmId;
1171
- }
1172
- function requireRef(value) {
1173
- const raw = normalizeOptionalString$1(value) ?? "";
1174
- const ref = (raw ? parseRoleRef(raw) : null) ?? (raw.startsWith("@") ? raw.slice(1) : raw);
1175
- if (!ref) throw new Error("ref is required");
1176
- return ref;
1177
- }
1178
- function requireRefOrSelector(ref, selector) {
1179
- const trimmedRef = normalizeOptionalString$1(ref) ?? "";
1180
- const trimmedSelector = normalizeOptionalString$1(selector) ?? "";
1181
- if (!trimmedRef && !trimmedSelector) throw new Error("ref or selector is required");
1182
- return {
1183
- ref: trimmedRef || void 0,
1184
- selector: trimmedSelector || void 0
1185
- };
1186
- }
1187
- function normalizeTimeoutMs(timeoutMs, fallback) {
1188
- return Math.max(500, Math.min(12e4, timeoutMs ?? fallback));
1189
- }
1190
- function toAIFriendlyError(error, selector) {
1191
- const message = formatErrorMessage(error);
1192
- if (message.includes("strict mode violation")) {
1193
- const countMatch = message.match(/resolved to (\d+) elements/);
1194
- const count = countMatch ? countMatch[1] : "multiple";
1195
- return /* @__PURE__ */ new Error(`Selector "${selector}" matched ${count} elements. Run a new snapshot to get updated refs, or use a different ref.`);
1196
- }
1197
- if ((message.includes("Timeout") || message.includes("waiting for")) && (message.includes("to be visible") || message.includes("not visible") || message.includes("waiting for locator("))) return /* @__PURE__ */ new Error(`Element "${selector}" not found or not visible. Run a new snapshot to see current page elements.`);
1198
- if (message.includes("intercepts pointer events") || message.includes("not visible") || message.includes("not receive pointer events")) return /* @__PURE__ */ new Error(`Element "${selector}" is not interactable (hidden or covered). Try scrolling it into view, closing overlays, or re-snapshotting.`);
1199
- return error instanceof Error ? error : new Error(message);
1200
- }
1201
- //#endregion
1202
- //#region extensions/browser/src/browser/pw-tools-core.downloads.ts
1203
- function buildTempDownloadPath(fileName) {
1204
- const id = crypto.randomUUID();
1205
- const safeName = sanitizeUntrustedFileName(fileName, "download.bin");
1206
- return path.join(resolvePreferredDaoCoreTmpDir(), "downloads", `${id}-${safeName}`);
1207
- }
1208
- function createPageDownloadWaiter(page, timeoutMs) {
1209
- const state = ensurePageState(page);
1210
- state.downloadWaiterDepth += 1;
1211
- let done = false;
1212
- let timer;
1213
- let handler;
1214
- let depthReleased = false;
1215
- const cleanup = () => {
1216
- if (!depthReleased) {
1217
- depthReleased = true;
1218
- state.downloadWaiterDepth = Math.max(0, state.downloadWaiterDepth - 1);
1219
- }
1220
- if (timer) clearTimeout(timer);
1221
- timer = void 0;
1222
- if (handler) {
1223
- page.off("download", handler);
1224
- handler = void 0;
1225
- }
1226
- };
1227
- return {
1228
- promise: new Promise((resolve, reject) => {
1229
- handler = (download) => {
1230
- if (done) return;
1231
- done = true;
1232
- cleanup();
1233
- resolve(download);
1234
- };
1235
- page.on("download", handler);
1236
- timer = setTimeout(() => {
1237
- if (done) return;
1238
- done = true;
1239
- cleanup();
1240
- reject(/* @__PURE__ */ new Error("Timeout waiting for download"));
1241
- }, timeoutMs);
1242
- }),
1243
- cancel: () => {
1244
- if (done) return;
1245
- done = true;
1246
- cleanup();
1247
- }
1248
- };
1249
- }
1250
- async function saveDownloadPayload(download, outPath, rootDir) {
1251
- const suggested = download.suggestedFilename?.() || "download.bin";
1252
- const requestedPath = outPath?.trim();
1253
- const finalPath = await writeExternalFileWithinOutputRoot({
1254
- rootDir,
1255
- path: path.resolve(requestedPath || buildTempDownloadPath(suggested)),
1256
- write: async (tempPath) => {
1257
- await download.saveAs?.(tempPath);
1258
- }
1259
- });
1260
- return {
1261
- url: download.url?.() || "",
1262
- suggestedFilename: suggested,
1263
- path: finalPath
1264
- };
1265
- }
1266
- async function awaitDownloadPayload(params) {
1267
- try {
1268
- const download = await params.waiter.promise;
1269
- if (params.state.armIdDownload !== params.armId) throw new Error("Download was superseded by another waiter");
1270
- return await saveDownloadPayload(download, params.outPath ?? "", params.rootDir);
1271
- } catch (err) {
1272
- params.waiter.cancel();
1273
- throw err;
1274
- }
1275
- }
1276
- async function armFileUploadViaPlaywright(opts) {
1277
- const page = await getPageForTargetId(opts);
1278
- const state = ensurePageState(page);
1279
- const timeout = Math.max(500, Math.min(12e4, opts.timeoutMs ?? 12e4));
1280
- state.armIdUpload = bumpUploadArmId();
1281
- const armId = state.armIdUpload;
1282
- page.waitForEvent("filechooser", { timeout }).then(async (fileChooser) => {
1283
- if (state.armIdUpload !== armId) return;
1284
- if (!opts.paths?.length) {
1285
- try {
1286
- await page.keyboard.press("Escape");
1287
- } catch {}
1288
- return;
1289
- }
1290
- const uploadPathsResult = await resolveStrictExistingPathsWithinRoot({
1291
- rootDir: DEFAULT_UPLOAD_DIR,
1292
- requestedPaths: opts.paths,
1293
- scopeLabel: `uploads directory (${DEFAULT_UPLOAD_DIR})`
1294
- });
1295
- if (!uploadPathsResult.ok) {
1296
- try {
1297
- await page.keyboard.press("Escape");
1298
- } catch {}
1299
- return;
1300
- }
1301
- await fileChooser.setFiles(uploadPathsResult.paths);
1302
- try {
1303
- const input = typeof fileChooser.element === "function" ? await Promise.resolve(fileChooser.element()) : null;
1304
- if (input) await input.evaluate((el) => {
1305
- el.dispatchEvent(new Event("input", { bubbles: true }));
1306
- el.dispatchEvent(new Event("change", { bubbles: true }));
1307
- });
1308
- } catch {}
1309
- }).catch(() => {});
1310
- }
1311
- async function armDialogViaPlaywright(opts) {
1312
- const page = await getPageForTargetId(opts);
1313
- const timeout = normalizeTimeoutMs(opts.timeoutMs, 12e4);
1314
- try {
1315
- await respondToObservedDialogOnPage({
1316
- page,
1317
- accept: opts.accept,
1318
- closedBy: "agent",
1319
- ...opts.dialogId !== void 0 ? { dialogId: opts.dialogId } : {},
1320
- ...opts.promptText !== void 0 ? { promptText: opts.promptText } : {}
1321
- });
1322
- return;
1323
- } catch (err) {
1324
- if (opts.dialogId || err instanceof Error && !err.message.includes("No dialog is pending")) throw err;
1325
- }
1326
- armObservedDialogResponseOnPage({
1327
- page,
1328
- accept: opts.accept,
1329
- timeoutMs: timeout,
1330
- ...opts.promptText !== void 0 ? { promptText: opts.promptText } : {}
1331
- });
1332
- }
1333
- async function waitForDownloadViaPlaywright(opts) {
1334
- const page = await getPageForTargetId(opts);
1335
- const state = ensurePageState(page);
1336
- const timeout = normalizeTimeoutMs(opts.timeoutMs, 12e4);
1337
- state.armIdDownload = bumpDownloadArmId();
1338
- const armId = state.armIdDownload;
1339
- return await awaitDownloadPayload({
1340
- waiter: createPageDownloadWaiter(page, timeout),
1341
- state,
1342
- armId,
1343
- outPath: opts.path,
1344
- rootDir: opts.rootDir
1345
- });
1346
- }
1347
- async function downloadViaPlaywright(opts) {
1348
- const page = await getPageForTargetId(opts);
1349
- const state = ensurePageState(page);
1350
- restoreRoleRefsForTarget({
1351
- cdpUrl: opts.cdpUrl,
1352
- targetId: opts.targetId,
1353
- page
1354
- });
1355
- const timeout = normalizeTimeoutMs(opts.timeoutMs, 12e4);
1356
- const ref = requireRef(opts.ref);
1357
- const outPath = opts.path?.trim() ?? "";
1358
- if (!outPath) throw new Error("path is required");
1359
- state.armIdDownload = bumpDownloadArmId();
1360
- const armId = state.armIdDownload;
1361
- const waiter = createPageDownloadWaiter(page, timeout);
1362
- try {
1363
- const locator = refLocator(page, ref);
1364
- try {
1365
- await locator.click({ timeout });
1366
- } catch (err) {
1367
- throw toAIFriendlyError(err, ref);
1368
- }
1369
- return await awaitDownloadPayload({
1370
- waiter,
1371
- state,
1372
- armId,
1373
- outPath,
1374
- rootDir: opts.rootDir
1375
- });
1376
- } catch (err) {
1377
- waiter.cancel();
1378
- throw err;
1379
- }
1380
- }
1381
- //#endregion
1382
- //#region extensions/browser/src/browser/pw-tools-core.snapshot.ts
1383
- async function collectSnapshotUrls(page) {
1384
- const urls = await page.evaluate(() => {
1385
- const seen = /* @__PURE__ */ new Set();
1386
- const out = [];
1387
- for (const anchor of Array.from(document.querySelectorAll("a[href]"))) {
1388
- const href = anchor instanceof HTMLAnchorElement ? anchor.href : "";
1389
- if (!href || seen.has(href)) continue;
1390
- const text = (anchor.textContent || anchor.getAttribute("aria-label") || "").replace(/\s+/g, " ").trim().slice(0, 120) || href;
1391
- seen.add(href);
1392
- out.push({
1393
- text,
1394
- url: href
1395
- });
1396
- if (out.length >= 100) break;
1397
- }
1398
- return out;
1399
- }).catch(() => []);
1400
- return Array.isArray(urls) ? urls : [];
1401
- }
1402
- function appendSnapshotUrls(snapshot, urls) {
1403
- if (urls.length === 0) return snapshot;
1404
- return `${snapshot}\n\nLinks:\n${urls.map((entry, index) => `${index + 1}. ${entry.text} -> ${entry.url}`).join("\n")}`;
1405
- }
1406
- function buildStoredAriaRefs(nodes, markedRefs) {
1407
- const refs = {};
1408
- const counts = /* @__PURE__ */ new Map();
1409
- const refsByKey = /* @__PURE__ */ new Map();
1410
- for (const node of nodes) {
1411
- const role = normalizeLowercaseStringOrEmpty(node.role) || "unknown";
1412
- const name = node.name.trim() || void 0;
1413
- const key = `${role}:${name ?? ""}`;
1414
- const nth = counts.get(key) ?? 0;
1415
- counts.set(key, nth + 1);
1416
- refsByKey.set(key, [...refsByKey.get(key) ?? [], node.ref]);
1417
- refs[node.ref] = {
1418
- role,
1419
- ...name ? { name } : {},
1420
- ...nth > 0 ? { nth } : {},
1421
- ...markedRefs.has(node.ref) ? { domMarker: true } : {}
1422
- };
1423
- }
1424
- for (const refsForKey of refsByKey.values()) {
1425
- if (refsForKey.length > 1) continue;
1426
- const ref = refsForKey[0];
1427
- if (ref) delete refs[ref]?.nth;
1428
- }
1429
- return refs;
1430
- }
1431
- async function storeAriaSnapshotRefsViaPlaywright(opts) {
1432
- const page = opts.page ?? await getPageForTargetId({
1433
- cdpUrl: opts.cdpUrl,
1434
- targetId: opts.targetId
1435
- });
1436
- ensurePageState(page);
1437
- const markedRefs = await markBackendDomRefsOnPage({
1438
- page,
1439
- refs: opts.nodes.flatMap((node) => typeof node.backendDOMNodeId === "number" ? [{
1440
- ref: node.ref,
1441
- backendDOMNodeId: node.backendDOMNodeId
1442
- }] : [])
1443
- });
1444
- storeRoleRefsForTarget({
1445
- page,
1446
- cdpUrl: opts.cdpUrl,
1447
- targetId: opts.targetId,
1448
- refs: buildStoredAriaRefs(opts.nodes, markedRefs),
1449
- mode: "role"
1450
- });
1451
- }
1452
- async function snapshotAriaViaPlaywright(opts) {
1453
- const limit = Math.max(1, Math.min(2e3, Math.floor(opts.limit ?? 500)));
1454
- const page = await getPageForTargetId({
1455
- cdpUrl: opts.cdpUrl,
1456
- targetId: opts.targetId
1457
- });
1458
- ensurePageState(page);
1459
- if (opts.ssrfPolicy) await assertPageNavigationCompletedSafely({
1460
- cdpUrl: opts.cdpUrl,
1461
- page,
1462
- response: null,
1463
- ssrfPolicy: opts.ssrfPolicy,
1464
- targetId: opts.targetId
1465
- });
1466
- const res = await withPageScopedCdpClient({
1467
- cdpUrl: opts.cdpUrl,
1468
- page,
1469
- targetId: opts.targetId,
1470
- fn: async (send) => {
1471
- await send("Accessibility.enable").catch(() => {});
1472
- return await send("Accessibility.getFullAXTree");
1473
- }
1474
- });
1475
- const formatted = formatAriaSnapshot(Array.isArray(res?.nodes) ? res.nodes : [], limit);
1476
- await storeAriaSnapshotRefsViaPlaywright({
1477
- cdpUrl: opts.cdpUrl,
1478
- targetId: opts.targetId,
1479
- nodes: formatted,
1480
- page
1481
- });
1482
- return { nodes: formatted };
1483
- }
1484
- async function snapshotAiViaPlaywright(opts) {
1485
- const page = await getPageForTargetId({
1486
- cdpUrl: opts.cdpUrl,
1487
- targetId: opts.targetId
1488
- });
1489
- ensurePageState(page);
1490
- if (opts.ssrfPolicy) await assertPageNavigationCompletedSafely({
1491
- cdpUrl: opts.cdpUrl,
1492
- page,
1493
- response: null,
1494
- ssrfPolicy: opts.ssrfPolicy,
1495
- targetId: opts.targetId
1496
- });
1497
- let snapshot = await page.ariaSnapshot({
1498
- mode: "ai",
1499
- timeout: Math.max(500, Math.min(6e4, Math.floor(opts.timeoutMs ?? 5e3)))
1500
- });
1501
- if (opts.urls) snapshot = appendSnapshotUrls(snapshot, await collectSnapshotUrls(page));
1502
- const maxChars = opts.maxChars;
1503
- const limit = typeof maxChars === "number" && Number.isFinite(maxChars) && maxChars > 0 ? Math.floor(maxChars) : void 0;
1504
- let truncated = false;
1505
- if (limit && snapshot.length > limit) {
1506
- snapshot = `${snapshot.slice(0, limit)}\n\n[...TRUNCATED - page too large]`;
1507
- truncated = true;
1508
- }
1509
- const built = buildRoleSnapshotFromAiSnapshot(snapshot);
1510
- storeRoleRefsForTarget({
1511
- page,
1512
- cdpUrl: opts.cdpUrl,
1513
- targetId: opts.targetId,
1514
- refs: built.refs,
1515
- mode: "aria"
1516
- });
1517
- return truncated ? {
1518
- snapshot,
1519
- truncated,
1520
- refs: built.refs
1521
- } : {
1522
- snapshot,
1523
- refs: built.refs
1524
- };
1525
- }
1526
- async function snapshotRoleViaPlaywright(opts) {
1527
- const page = await getPageForTargetId({
1528
- cdpUrl: opts.cdpUrl,
1529
- targetId: opts.targetId
1530
- });
1531
- ensurePageState(page);
1532
- if (opts.ssrfPolicy) await assertPageNavigationCompletedSafely({
1533
- cdpUrl: opts.cdpUrl,
1534
- page,
1535
- response: null,
1536
- ssrfPolicy: opts.ssrfPolicy,
1537
- targetId: opts.targetId
1538
- });
1539
- if (opts.refsMode === "aria") {
1540
- if (normalizeOptionalString$1(opts.selector) || normalizeOptionalString$1(opts.frameSelector)) throw new Error("refs=aria does not support selector/frame snapshots yet.");
1541
- const built = buildRoleSnapshotFromAiSnapshot(await page.ariaSnapshot({
1542
- mode: "ai",
1543
- timeout: 5e3
1544
- }), opts.options);
1545
- const snapshotWithUrls = opts.urls ? appendSnapshotUrls(built.snapshot, await collectSnapshotUrls(page)) : built.snapshot;
1546
- storeRoleRefsForTarget({
1547
- page,
1548
- cdpUrl: opts.cdpUrl,
1549
- targetId: opts.targetId,
1550
- refs: built.refs,
1551
- mode: "aria"
1552
- });
1553
- return {
1554
- snapshot: snapshotWithUrls,
1555
- refs: built.refs,
1556
- stats: getRoleSnapshotStats(snapshotWithUrls, built.refs)
1557
- };
1558
- }
1559
- const frameSelector = normalizeOptionalString$1(opts.frameSelector) ?? "";
1560
- const selector = normalizeOptionalString$1(opts.selector) ?? "";
1561
- const built = buildRoleSnapshotFromAriaSnapshot(await (frameSelector ? selector ? page.frameLocator(frameSelector).locator(selector) : page.frameLocator(frameSelector).locator(":root") : selector ? page.locator(selector) : page.locator(":root")).ariaSnapshot() ?? "", opts.options);
1562
- const snapshotWithUrls = opts.urls ? appendSnapshotUrls(built.snapshot, await collectSnapshotUrls(page)) : built.snapshot;
1563
- storeRoleRefsForTarget({
1564
- page,
1565
- cdpUrl: opts.cdpUrl,
1566
- targetId: opts.targetId,
1567
- refs: built.refs,
1568
- frameSelector: frameSelector || void 0,
1569
- mode: "role"
1570
- });
1571
- return {
1572
- snapshot: snapshotWithUrls,
1573
- refs: built.refs,
1574
- stats: getRoleSnapshotStats(snapshotWithUrls, built.refs)
1575
- };
1576
- }
1577
- async function navigateViaPlaywright(opts) {
1578
- const isRetryableNavigateError = (err) => {
1579
- const msg = typeof err === "string" ? err.toLowerCase() : err instanceof Error ? err.message.toLowerCase() : "";
1580
- return msg.includes("frame has been detached") || msg.includes("target page, context or browser has been closed");
1581
- };
1582
- const url = normalizeOptionalString$1(opts.url) ?? "";
1583
- if (!url) throw new Error("url is required");
1584
- await assertBrowserNavigationAllowed({
1585
- url,
1586
- ...withBrowserNavigationPolicy(opts.ssrfPolicy, { browserProxyMode: opts.browserProxyMode })
1587
- });
1588
- const timeout = Math.max(1e3, Math.min(12e4, opts.timeoutMs ?? 2e4));
1589
- let page = await getPageForTargetId(opts);
1590
- ensurePageState(page);
1591
- const navigate = async () => await gotoPageWithNavigationGuard({
1592
- cdpUrl: opts.cdpUrl,
1593
- page,
1594
- url,
1595
- timeoutMs: timeout,
1596
- ssrfPolicy: opts.ssrfPolicy,
1597
- browserProxyMode: opts.browserProxyMode,
1598
- targetId: opts.targetId
1599
- });
1600
- let response;
1601
- try {
1602
- response = await navigate();
1603
- } catch (err) {
1604
- if (!isRetryableNavigateError(err)) throw err;
1605
- await forceDisconnectPlaywrightForTarget({
1606
- cdpUrl: opts.cdpUrl,
1607
- targetId: opts.targetId,
1608
- reason: "retry navigate after detached frame"
1609
- }).catch(() => {});
1610
- page = await getPageForTargetId(opts);
1611
- ensurePageState(page);
1612
- response = await navigate();
1613
- }
1614
- try {
1615
- await assertPageNavigationCompletedSafely({
1616
- cdpUrl: opts.cdpUrl,
1617
- page,
1618
- response,
1619
- ssrfPolicy: opts.ssrfPolicy,
1620
- browserProxyMode: opts.browserProxyMode,
1621
- targetId: opts.targetId
1622
- });
1623
- } catch (err) {
1624
- if (isPolicyDenyNavigationError(err)) await closeBlockedNavigationTarget({
1625
- cdpUrl: opts.cdpUrl,
1626
- page,
1627
- targetId: opts.targetId
1628
- });
1629
- throw err;
1630
- }
1631
- return { url: page.url() };
1632
- }
1633
- async function resizeViewportViaPlaywright(opts) {
1634
- const page = await getPageForTargetId(opts);
1635
- ensurePageState(page);
1636
- await page.setViewportSize({
1637
- width: Math.max(1, Math.floor(opts.width)),
1638
- height: Math.max(1, Math.floor(opts.height))
1639
- });
1640
- }
1641
- async function closePageViaPlaywright(opts) {
1642
- const page = await getPageForTargetId(opts);
1643
- ensurePageState(page);
1644
- await page.close();
1645
- }
1646
- async function pdfViaPlaywright(opts) {
1647
- const page = await getPageForTargetId(opts);
1648
- ensurePageState(page);
1649
- return { buffer: await page.pdf({ printBackground: true }) };
1650
- }
1651
- //#endregion
1652
- //#region extensions/browser/src/browser/pw-tools-core.interactions.ts
1653
- const INTERACTION_NAVIGATION_GRACE_MS = 250;
1654
- const pendingInteractionNavigationGuardCleanup = /* @__PURE__ */ new WeakMap();
1655
- function resolveBoundedDelayMs(value, label, maxMs) {
1656
- const normalized = Math.floor(value ?? 0);
1657
- if (!Number.isFinite(normalized) || normalized < 0) throw new Error(`${label} must be >= 0`);
1658
- if (normalized > maxMs) throw new Error(`${label} exceeds maximum of ${maxMs}ms`);
1659
- return normalized;
1660
- }
1661
- async function getRestoredPageForTarget(opts) {
1662
- const page = await getPageForTargetId(opts);
1663
- ensurePageState(page);
1664
- restoreRoleRefsForTarget({
1665
- cdpUrl: opts.cdpUrl,
1666
- targetId: opts.targetId,
1667
- page
1668
- });
1669
- return page;
1670
- }
1671
- function toFriendlyInteractionError(err, label) {
1672
- return isBrowserObservedDialogBlockedError(err) ? err : toAIFriendlyError(err, label);
1673
- }
1674
- function reconcileRemoteDialogAfterActionSettled(page, signal) {
1675
- if (isBrowserObservedDialogBlockedError(signal?.reason)) markObservedDialogsHandledRemotelyForPage(page);
1676
- }
1677
- const resolveInteractionTimeoutMs = resolveActInteractionTimeoutMs;
1678
- function didCrossDocumentUrlChange(page, previousUrl) {
1679
- const currentUrl = page.url();
1680
- if (currentUrl === previousUrl) return false;
1681
- try {
1682
- const prev = new URL(previousUrl);
1683
- const curr = new URL(currentUrl);
1684
- if (prev.origin === curr.origin && prev.pathname === curr.pathname && prev.search === curr.search) return false;
1685
- } catch {}
1686
- return true;
1687
- }
1688
- function isHashOnlyNavigation(currentUrl, previousUrl) {
1689
- if (currentUrl === previousUrl) return false;
1690
- try {
1691
- const prev = new URL(previousUrl);
1692
- const curr = new URL(currentUrl);
1693
- return prev.origin === curr.origin && prev.pathname === curr.pathname && prev.search === curr.search;
1694
- } catch {
1695
- return false;
1696
- }
1697
- }
1698
- function isMainFrameNavigation(page, frame) {
1699
- if (typeof page.mainFrame !== "function") return true;
1700
- return frame === page.mainFrame();
1701
- }
1702
- async function assertSubframeNavigationAllowed(frameUrl, ssrfPolicy) {
1703
- if (!ssrfPolicy || !frameUrl.startsWith("http://") && !frameUrl.startsWith("https://")) return;
1704
- await assertBrowserNavigationResultAllowed({
1705
- url: frameUrl,
1706
- ...withBrowserNavigationPolicy(ssrfPolicy)
1707
- });
1708
- }
1709
- function snapshotNetworkFrameUrl(frame) {
1710
- try {
1711
- const frameUrl = frame.url();
1712
- return frameUrl.startsWith("http://") || frameUrl.startsWith("https://") ? frameUrl : null;
1713
- } catch {
1714
- return null;
1715
- }
1716
- }
1717
- async function assertObservedDelayedNavigations(opts) {
1718
- let subframeError;
1719
- try {
1720
- for (const frameUrl of opts.observed.subframes) await assertSubframeNavigationAllowed(frameUrl, opts.ssrfPolicy);
1721
- } catch (err) {
1722
- subframeError = err;
1723
- }
1724
- if (opts.observed.mainFrameNavigated) await assertPageNavigationCompletedSafely({
1725
- cdpUrl: opts.cdpUrl,
1726
- page: opts.page,
1727
- response: null,
1728
- ssrfPolicy: opts.ssrfPolicy,
1729
- targetId: opts.targetId
1730
- });
1731
- if (subframeError) throw subframeError;
1732
- }
1733
- function observeDelayedInteractionNavigation(page, previousUrl) {
1734
- if (didCrossDocumentUrlChange(page, previousUrl)) return Promise.resolve({
1735
- mainFrameNavigated: true,
1736
- subframes: []
1737
- });
1738
- if (typeof page.on !== "function" || typeof page.off !== "function") return Promise.resolve({
1739
- mainFrameNavigated: false,
1740
- subframes: []
1741
- });
1742
- return new Promise((resolve) => {
1743
- const subframes = [];
1744
- const onFrameNavigated = (frame) => {
1745
- if (!isMainFrameNavigation(page, frame)) {
1746
- const frameUrl = snapshotNetworkFrameUrl(frame);
1747
- if (frameUrl) subframes.push(frameUrl);
1748
- return;
1749
- }
1750
- if (isHashOnlyNavigation(page.url(), previousUrl)) return;
1751
- cleanup();
1752
- resolve({
1753
- mainFrameNavigated: true,
1754
- subframes
1755
- });
1756
- };
1757
- const timeout = setTimeout(() => {
1758
- cleanup();
1759
- resolve({
1760
- mainFrameNavigated: didCrossDocumentUrlChange(page, previousUrl),
1761
- subframes
1762
- });
1763
- }, INTERACTION_NAVIGATION_GRACE_MS);
1764
- const cleanup = () => {
1765
- clearTimeout(timeout);
1766
- page.off("framenavigated", onFrameNavigated);
1767
- };
1768
- page.on("framenavigated", onFrameNavigated);
1769
- });
1770
- }
1771
- function scheduleDelayedInteractionNavigationGuard(opts) {
1772
- if (!opts.ssrfPolicy) return Promise.resolve();
1773
- const page = opts.page;
1774
- if (didCrossDocumentUrlChange(page, opts.previousUrl)) return assertPageNavigationCompletedSafely({
1775
- cdpUrl: opts.cdpUrl,
1776
- page: opts.page,
1777
- response: null,
1778
- ssrfPolicy: opts.ssrfPolicy,
1779
- targetId: opts.targetId
1780
- });
1781
- if (typeof page.on !== "function" || typeof page.off !== "function") return Promise.resolve();
1782
- pendingInteractionNavigationGuardCleanup.get(opts.page)?.();
1783
- return new Promise((resolve, reject) => {
1784
- const settle = (err) => {
1785
- cleanup();
1786
- if (err) {
1787
- reject(err);
1788
- return;
1789
- }
1790
- resolve();
1791
- };
1792
- const subframes = [];
1793
- const onFrameNavigated = (frame) => {
1794
- if (!isMainFrameNavigation(page, frame)) {
1795
- const frameUrl = snapshotNetworkFrameUrl(frame);
1796
- if (frameUrl) subframes.push(frameUrl);
1797
- return;
1798
- }
1799
- if (isHashOnlyNavigation(page.url(), opts.previousUrl)) return;
1800
- cleanup();
1801
- assertObservedDelayedNavigations({
1802
- cdpUrl: opts.cdpUrl,
1803
- page: opts.page,
1804
- ssrfPolicy: opts.ssrfPolicy,
1805
- targetId: opts.targetId,
1806
- observed: {
1807
- mainFrameNavigated: true,
1808
- subframes
1809
- }
1810
- }).then(() => settle(), settle);
1811
- };
1812
- const timeout = setTimeout(() => {
1813
- cleanup();
1814
- assertObservedDelayedNavigations({
1815
- cdpUrl: opts.cdpUrl,
1816
- page: opts.page,
1817
- ssrfPolicy: opts.ssrfPolicy,
1818
- targetId: opts.targetId,
1819
- observed: {
1820
- mainFrameNavigated: didCrossDocumentUrlChange(page, opts.previousUrl),
1821
- subframes
1822
- }
1823
- }).then(() => settle(), settle);
1824
- }, INTERACTION_NAVIGATION_GRACE_MS);
1825
- const cleanup = () => {
1826
- clearTimeout(timeout);
1827
- page.off("framenavigated", onFrameNavigated);
1828
- if (pendingInteractionNavigationGuardCleanup.get(opts.page) === settle) pendingInteractionNavigationGuardCleanup.delete(opts.page);
1829
- };
1830
- pendingInteractionNavigationGuardCleanup.set(opts.page, settle);
1831
- page.on("framenavigated", onFrameNavigated);
1832
- });
1833
- }
1834
- async function assertInteractionNavigationCompletedSafely(opts) {
1835
- if (!opts.ssrfPolicy) return await opts.action();
1836
- const navPage = opts.page;
1837
- let navigatedDuringAction = false;
1838
- const subframeNavigationsDuringAction = [];
1839
- const onFrameNavigated = (frame) => {
1840
- if (!isMainFrameNavigation(navPage, frame)) {
1841
- const frameUrl = snapshotNetworkFrameUrl(frame);
1842
- if (frameUrl) subframeNavigationsDuringAction.push(frameUrl);
1843
- return;
1844
- }
1845
- if (!isHashOnlyNavigation(opts.page.url(), opts.previousUrl)) navigatedDuringAction = true;
1846
- };
1847
- if (typeof navPage.on === "function") navPage.on("framenavigated", onFrameNavigated);
1848
- let result;
1849
- let actionError = null;
1850
- try {
1851
- result = await opts.action();
1852
- } catch (err) {
1853
- actionError = err;
1854
- } finally {
1855
- if (typeof navPage.off === "function") navPage.off("framenavigated", onFrameNavigated);
1856
- }
1857
- const navigationObserved = navigatedDuringAction || didCrossDocumentUrlChange(opts.page, opts.previousUrl);
1858
- let subframeError;
1859
- try {
1860
- for (const frameUrl of subframeNavigationsDuringAction) await assertSubframeNavigationAllowed(frameUrl, opts.ssrfPolicy);
1861
- } catch (err) {
1862
- subframeError = err;
1863
- }
1864
- if (navigationObserved) await assertPageNavigationCompletedSafely({
1865
- cdpUrl: opts.cdpUrl,
1866
- page: opts.page,
1867
- response: null,
1868
- ssrfPolicy: opts.ssrfPolicy,
1869
- targetId: opts.targetId
1870
- });
1871
- else if (actionError) {
1872
- const observed = await observeDelayedInteractionNavigation(opts.page, opts.previousUrl);
1873
- if (observed.mainFrameNavigated || observed.subframes.length > 0) await assertObservedDelayedNavigations({
1874
- cdpUrl: opts.cdpUrl,
1875
- page: opts.page,
1876
- ssrfPolicy: opts.ssrfPolicy,
1877
- targetId: opts.targetId,
1878
- observed
1879
- });
1880
- } else await scheduleDelayedInteractionNavigationGuard({
1881
- cdpUrl: opts.cdpUrl,
1882
- page: opts.page,
1883
- previousUrl: opts.previousUrl,
1884
- ssrfPolicy: opts.ssrfPolicy,
1885
- targetId: opts.targetId
1886
- });
1887
- if (subframeError) throw subframeError;
1888
- if (actionError) throw actionError;
1889
- return result;
1890
- }
1891
- async function awaitActionWithAbort(actionPromise, abortPromise, onActionResolvedAfterAbort) {
1892
- if (!abortPromise) return await actionPromise;
1893
- try {
1894
- return await Promise.race([actionPromise, abortPromise]);
1895
- } catch (err) {
1896
- actionPromise.then(() => onActionResolvedAfterAbort?.(), () => {});
1897
- throw err;
1898
- }
1899
- }
1900
- function createAbortPromise(signal) {
1901
- return createAbortPromiseWithListener(signal);
1902
- }
1903
- function createAbortPromiseWithListener(signal, onAbort) {
1904
- if (!signal) return { cleanup: () => {} };
1905
- let abortListener;
1906
- const abortPromise = signal.aborted ? (() => {
1907
- onAbort?.(signal.reason);
1908
- return Promise.reject(signal.reason ?? /* @__PURE__ */ new Error("aborted"));
1909
- })() : new Promise((_, reject) => {
1910
- abortListener = () => {
1911
- onAbort?.(signal.reason);
1912
- reject(signal.reason ?? /* @__PURE__ */ new Error("aborted"));
1913
- };
1914
- signal.addEventListener("abort", abortListener, { once: true });
1915
- });
1916
- abortPromise.catch(() => {});
1917
- return {
1918
- abortPromise,
1919
- cleanup: () => {
1920
- if (abortListener) signal.removeEventListener("abort", abortListener);
1921
- }
1922
- };
1923
- }
1924
- async function highlightViaPlaywright(opts) {
1925
- const page = await getRestoredPageForTarget(opts);
1926
- const ref = requireRef(opts.ref);
1927
- try {
1928
- await refLocator(page, ref).highlight();
1929
- } catch (err) {
1930
- throw toFriendlyInteractionError(err, ref);
1931
- }
1932
- }
1933
- async function clickViaPlaywright(opts) {
1934
- const resolved = requireRefOrSelector(opts.ref, opts.selector);
1935
- const page = await getRestoredPageForTarget(opts);
1936
- const label = resolved.ref ?? resolved.selector;
1937
- const locator = resolved.ref ? refLocator(page, requireRef(resolved.ref)) : page.locator(resolved.selector);
1938
- const timeout = resolveInteractionTimeoutMs(opts.timeoutMs);
1939
- const previousUrl = page.url();
1940
- const signal = opts.signal;
1941
- let abortListener;
1942
- let abortReject;
1943
- let abortPromise;
1944
- if (signal) {
1945
- abortPromise = new Promise((_, reject) => {
1946
- abortReject = reject;
1947
- });
1948
- abortPromise.catch(() => {});
1949
- const disconnect = () => {
1950
- if (isBrowserObservedDialogBlockedError(signal.reason)) return;
1951
- forceDisconnectPlaywrightForTarget({
1952
- cdpUrl: opts.cdpUrl,
1953
- targetId: opts.targetId,
1954
- reason: "click aborted"
1955
- }).catch(() => {});
1956
- };
1957
- if (signal.aborted) {
1958
- disconnect();
1959
- throw signal.reason ?? /* @__PURE__ */ new Error("aborted");
1960
- }
1961
- abortListener = () => {
1962
- disconnect();
1963
- abortReject?.(signal.reason ?? /* @__PURE__ */ new Error("aborted"));
1964
- };
1965
- signal.addEventListener("abort", abortListener, { once: true });
1966
- if (signal.aborted) {
1967
- abortListener();
1968
- throw signal.reason ?? /* @__PURE__ */ new Error("aborted");
1969
- }
1970
- }
1971
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, signal);
1972
- try {
1973
- await assertInteractionNavigationCompletedSafely({
1974
- action: async () => {
1975
- const delayMs = resolveBoundedDelayMs(opts.delayMs, "click delayMs", ACT_MAX_CLICK_DELAY_MS);
1976
- if (delayMs > 0) {
1977
- await awaitActionWithAbort(locator.hover({ timeout }), abortPromise, reconcileRemoteDialog);
1978
- await new Promise((resolve) => setTimeout(resolve, delayMs));
1979
- }
1980
- if (opts.doubleClick) {
1981
- await awaitActionWithAbort(locator.dblclick({
1982
- timeout,
1983
- button: opts.button,
1984
- modifiers: opts.modifiers
1985
- }), abortPromise, reconcileRemoteDialog);
1986
- return;
1987
- }
1988
- await awaitActionWithAbort(locator.click({
1989
- timeout,
1990
- button: opts.button,
1991
- modifiers: opts.modifiers
1992
- }), abortPromise, reconcileRemoteDialog);
1993
- },
1994
- cdpUrl: opts.cdpUrl,
1995
- page,
1996
- previousUrl,
1997
- ssrfPolicy: opts.ssrfPolicy,
1998
- targetId: opts.targetId
1999
- });
2000
- } catch (err) {
2001
- throw toFriendlyInteractionError(err, label);
2002
- } finally {
2003
- if (signal && abortListener) signal.removeEventListener("abort", abortListener);
2004
- }
2005
- }
2006
- async function clickCoordsViaPlaywright(opts) {
2007
- const page = await getRestoredPageForTarget(opts);
2008
- const previousUrl = page.url();
2009
- const { abortPromise, cleanup } = createAbortPromise(opts.signal);
2010
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, opts.signal);
2011
- await assertInteractionNavigationCompletedSafely({
2012
- action: async () => {
2013
- await awaitActionWithAbort(page.mouse.click(opts.x, opts.y, {
2014
- button: opts.button,
2015
- clickCount: opts.doubleClick ? 2 : 1,
2016
- delay: resolveBoundedDelayMs(opts.delayMs, "clickCoords delayMs", ACT_MAX_CLICK_DELAY_MS)
2017
- }), abortPromise, reconcileRemoteDialog);
2018
- },
2019
- cdpUrl: opts.cdpUrl,
2020
- page,
2021
- previousUrl,
2022
- ssrfPolicy: opts.ssrfPolicy,
2023
- targetId: opts.targetId
2024
- }).finally(cleanup);
2025
- }
2026
- async function hoverViaPlaywright(opts) {
2027
- const resolved = requireRefOrSelector(opts.ref, opts.selector);
2028
- const page = await getRestoredPageForTarget(opts);
2029
- const label = resolved.ref ?? resolved.selector;
2030
- const locator = resolved.ref ? refLocator(page, requireRef(resolved.ref)) : page.locator(resolved.selector);
2031
- const { abortPromise, cleanup } = createAbortPromise(opts.signal);
2032
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, opts.signal);
2033
- try {
2034
- await awaitActionWithAbort(locator.hover({ timeout: resolveInteractionTimeoutMs(opts.timeoutMs) }), abortPromise, reconcileRemoteDialog);
2035
- } catch (err) {
2036
- throw toFriendlyInteractionError(err, label);
2037
- } finally {
2038
- cleanup();
2039
- }
2040
- }
2041
- async function dragViaPlaywright(opts) {
2042
- const resolvedStart = requireRefOrSelector(opts.startRef, opts.startSelector);
2043
- const resolvedEnd = requireRefOrSelector(opts.endRef, opts.endSelector);
2044
- const page = await getRestoredPageForTarget(opts);
2045
- const startLocator = resolvedStart.ref ? refLocator(page, requireRef(resolvedStart.ref)) : page.locator(resolvedStart.selector);
2046
- const endLocator = resolvedEnd.ref ? refLocator(page, requireRef(resolvedEnd.ref)) : page.locator(resolvedEnd.selector);
2047
- const startLabel = resolvedStart.ref ?? resolvedStart.selector;
2048
- const endLabel = resolvedEnd.ref ?? resolvedEnd.selector;
2049
- const { abortPromise, cleanup } = createAbortPromise(opts.signal);
2050
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, opts.signal);
2051
- try {
2052
- await awaitActionWithAbort(startLocator.dragTo(endLocator, { timeout: resolveInteractionTimeoutMs(opts.timeoutMs) }), abortPromise, reconcileRemoteDialog);
2053
- } catch (err) {
2054
- throw toFriendlyInteractionError(err, `${startLabel} -> ${endLabel}`);
2055
- } finally {
2056
- cleanup();
2057
- }
2058
- }
2059
- async function selectOptionViaPlaywright(opts) {
2060
- const resolved = requireRefOrSelector(opts.ref, opts.selector);
2061
- if (!opts.values?.length) throw new Error("values are required");
2062
- const page = await getRestoredPageForTarget(opts);
2063
- const label = resolved.ref ?? resolved.selector;
2064
- const locator = resolved.ref ? refLocator(page, requireRef(resolved.ref)) : page.locator(resolved.selector);
2065
- const previousUrl = page.url();
2066
- const { abortPromise, cleanup } = createAbortPromise(opts.signal);
2067
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, opts.signal);
2068
- try {
2069
- await assertInteractionNavigationCompletedSafely({
2070
- action: async () => {
2071
- await awaitActionWithAbort(locator.selectOption(opts.values, { timeout: resolveInteractionTimeoutMs(opts.timeoutMs) }), abortPromise, reconcileRemoteDialog);
2072
- },
2073
- cdpUrl: opts.cdpUrl,
2074
- page,
2075
- previousUrl,
2076
- ssrfPolicy: opts.ssrfPolicy,
2077
- targetId: opts.targetId
2078
- });
2079
- } catch (err) {
2080
- throw toFriendlyInteractionError(err, label);
2081
- } finally {
2082
- cleanup();
2083
- }
2084
- }
2085
- async function pressKeyViaPlaywright(opts) {
2086
- const key = normalizeOptionalString$1(opts.key) ?? "";
2087
- if (!key) throw new Error("key is required");
2088
- const page = await getPageForTargetId(opts);
2089
- ensurePageState(page);
2090
- const previousUrl = page.url();
2091
- const { abortPromise, cleanup } = createAbortPromise(opts.signal);
2092
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, opts.signal);
2093
- try {
2094
- await assertInteractionNavigationCompletedSafely({
2095
- action: async () => {
2096
- await awaitActionWithAbort(page.keyboard.press(key, { delay: Math.max(0, Math.floor(opts.delayMs ?? 0)) }), abortPromise, reconcileRemoteDialog);
2097
- },
2098
- cdpUrl: opts.cdpUrl,
2099
- page,
2100
- previousUrl,
2101
- ssrfPolicy: opts.ssrfPolicy,
2102
- targetId: opts.targetId
2103
- });
2104
- } finally {
2105
- cleanup();
2106
- }
2107
- }
2108
- async function typeViaPlaywright(opts) {
2109
- const resolved = requireRefOrSelector(opts.ref, opts.selector);
2110
- const text = opts.text ?? "";
2111
- const page = await getRestoredPageForTarget(opts);
2112
- const label = resolved.ref ?? resolved.selector;
2113
- const locator = resolved.ref ? refLocator(page, requireRef(resolved.ref)) : page.locator(resolved.selector);
2114
- const timeout = resolveInteractionTimeoutMs(opts.timeoutMs);
2115
- const { abortPromise, cleanup } = createAbortPromise(opts.signal);
2116
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, opts.signal);
2117
- try {
2118
- const previousUrl = page.url();
2119
- if (opts.slowly) await assertInteractionNavigationCompletedSafely({
2120
- action: async () => {
2121
- await awaitActionWithAbort(locator.click({ timeout }), abortPromise, reconcileRemoteDialog);
2122
- await awaitActionWithAbort(locator.type(text, {
2123
- timeout,
2124
- delay: 75
2125
- }), abortPromise, reconcileRemoteDialog);
2126
- if (opts.submit) await awaitActionWithAbort(locator.press("Enter", { timeout }), abortPromise, reconcileRemoteDialog);
2127
- },
2128
- cdpUrl: opts.cdpUrl,
2129
- page,
2130
- previousUrl,
2131
- ssrfPolicy: opts.ssrfPolicy,
2132
- targetId: opts.targetId
2133
- });
2134
- else await assertInteractionNavigationCompletedSafely({
2135
- action: async () => {
2136
- await awaitActionWithAbort(locator.fill(text, { timeout }), abortPromise, reconcileRemoteDialog);
2137
- if (opts.submit) await awaitActionWithAbort(locator.press("Enter", { timeout }), abortPromise, reconcileRemoteDialog);
2138
- },
2139
- cdpUrl: opts.cdpUrl,
2140
- page,
2141
- previousUrl,
2142
- ssrfPolicy: opts.ssrfPolicy,
2143
- targetId: opts.targetId
2144
- });
2145
- } catch (err) {
2146
- throw toFriendlyInteractionError(err, label);
2147
- } finally {
2148
- cleanup();
2149
- }
2150
- }
2151
- async function fillFormViaPlaywright(opts) {
2152
- const page = await getRestoredPageForTarget(opts);
2153
- const timeout = resolveInteractionTimeoutMs(opts.timeoutMs);
2154
- const { abortPromise, cleanup } = createAbortPromise(opts.signal);
2155
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, opts.signal);
2156
- try {
2157
- for (const field of opts.fields) {
2158
- const ref = field.ref.trim();
2159
- const type = (field.type || "text").trim() || "text";
2160
- const rawValue = field.value;
2161
- const value = typeof rawValue === "string" ? rawValue : typeof rawValue === "number" || typeof rawValue === "boolean" ? String(rawValue) : "";
2162
- if (!ref) continue;
2163
- const locator = refLocator(page, ref);
2164
- if (type === "checkbox" || type === "radio") {
2165
- const checked = rawValue === true || rawValue === 1 || rawValue === "1" || rawValue === "true";
2166
- try {
2167
- const previousUrl = page.url();
2168
- await assertInteractionNavigationCompletedSafely({
2169
- action: async () => {
2170
- await awaitActionWithAbort(locator.setChecked(checked, { timeout }), abortPromise, reconcileRemoteDialog);
2171
- },
2172
- cdpUrl: opts.cdpUrl,
2173
- page,
2174
- previousUrl,
2175
- ssrfPolicy: opts.ssrfPolicy,
2176
- targetId: opts.targetId
2177
- });
2178
- } catch (err) {
2179
- throw toFriendlyInteractionError(err, ref);
2180
- }
2181
- continue;
2182
- }
2183
- try {
2184
- const previousUrl = page.url();
2185
- await assertInteractionNavigationCompletedSafely({
2186
- action: async () => {
2187
- await awaitActionWithAbort(locator.fill(value, { timeout }), abortPromise, reconcileRemoteDialog);
2188
- },
2189
- cdpUrl: opts.cdpUrl,
2190
- page,
2191
- previousUrl,
2192
- ssrfPolicy: opts.ssrfPolicy,
2193
- targetId: opts.targetId
2194
- });
2195
- } catch (err) {
2196
- throw toFriendlyInteractionError(err, ref);
2197
- }
2198
- }
2199
- } finally {
2200
- cleanup();
2201
- }
2202
- }
2203
- async function evaluateViaPlaywright(opts) {
2204
- const fnText = normalizeOptionalString$1(opts.fn) ?? "";
2205
- if (!fnText) throw new Error("function is required");
2206
- const page = await getRestoredPageForTarget(opts);
2207
- const outerTimeout = normalizeTimeoutMs(opts.timeoutMs, 2e4);
2208
- let evaluateTimeout = Math.max(1e3, Math.min(12e4, outerTimeout - 500));
2209
- evaluateTimeout = Math.min(evaluateTimeout, outerTimeout);
2210
- const signal = opts.signal;
2211
- const { abortPromise, cleanup } = createAbortPromiseWithListener(signal, (reason) => {
2212
- if (isBrowserObservedDialogBlockedError(reason)) return;
2213
- forceDisconnectPlaywrightForTarget({
2214
- cdpUrl: opts.cdpUrl,
2215
- targetId: opts.targetId,
2216
- reason: "evaluate aborted"
2217
- }).catch(() => {});
2218
- });
2219
- if (signal?.aborted) throw signal.reason ?? /* @__PURE__ */ new Error("aborted");
2220
- try {
2221
- const previousUrl = page.url();
2222
- if (opts.ssrfPolicy) await assertPageNavigationCompletedSafely({
2223
- cdpUrl: opts.cdpUrl,
2224
- page,
2225
- response: null,
2226
- ssrfPolicy: opts.ssrfPolicy,
2227
- targetId: opts.targetId
2228
- });
2229
- if (opts.ref) {
2230
- const locator = refLocator(page, opts.ref);
2231
- const elementEvaluator = new Function("el", "args", `
2232
- "use strict";
2233
- var fnBody = args.fnBody, timeoutMs = args.timeoutMs;
2234
- try {
2235
- var candidate = eval("(" + fnBody + ")");
2236
- var result = typeof candidate === "function" ? candidate(el) : candidate;
2237
- if (result && typeof result.then === "function") {
2238
- return Promise.race([
2239
- result,
2240
- new Promise(function(_, reject) {
2241
- setTimeout(function() { reject(new Error("evaluate timed out after " + timeoutMs + "ms")); }, timeoutMs);
2242
- })
2243
- ]);
2244
- }
2245
- return result;
2246
- } catch (err) {
2247
- throw new Error("Invalid evaluate function: " + (err && err.message ? err.message : String(err)));
2248
- }
2249
- `);
2250
- const evalPromise = locator.evaluate(elementEvaluator, {
2251
- fnBody: fnText,
2252
- timeoutMs: evaluateTimeout
2253
- });
2254
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, signal);
2255
- return await assertInteractionNavigationCompletedSafely({
2256
- action: () => awaitActionWithAbort(evalPromise, abortPromise, reconcileRemoteDialog),
2257
- cdpUrl: opts.cdpUrl,
2258
- page,
2259
- previousUrl,
2260
- ssrfPolicy: opts.ssrfPolicy,
2261
- targetId: opts.targetId
2262
- });
2263
- }
2264
- const browserEvaluator = new Function("args", `
2265
- "use strict";
2266
- var fnBody = args.fnBody, timeoutMs = args.timeoutMs;
2267
- try {
2268
- var candidate = eval("(" + fnBody + ")");
2269
- var result = typeof candidate === "function" ? candidate() : candidate;
2270
- if (result && typeof result.then === "function") {
2271
- return Promise.race([
2272
- result,
2273
- new Promise(function(_, reject) {
2274
- setTimeout(function() { reject(new Error("evaluate timed out after " + timeoutMs + "ms")); }, timeoutMs);
2275
- })
2276
- ]);
2277
- }
2278
- return result;
2279
- } catch (err) {
2280
- throw new Error("Invalid evaluate function: " + (err && err.message ? err.message : String(err)));
2281
- }
2282
- `);
2283
- const evalPromise = page.evaluate(browserEvaluator, {
2284
- fnBody: fnText,
2285
- timeoutMs: evaluateTimeout
2286
- });
2287
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, signal);
2288
- return await assertInteractionNavigationCompletedSafely({
2289
- action: () => awaitActionWithAbort(evalPromise, abortPromise, reconcileRemoteDialog),
2290
- cdpUrl: opts.cdpUrl,
2291
- page,
2292
- previousUrl,
2293
- ssrfPolicy: opts.ssrfPolicy,
2294
- targetId: opts.targetId
2295
- });
2296
- } finally {
2297
- cleanup();
2298
- }
2299
- }
2300
- async function scrollIntoViewViaPlaywright(opts) {
2301
- const resolved = requireRefOrSelector(opts.ref, opts.selector);
2302
- const page = await getRestoredPageForTarget(opts);
2303
- const timeout = normalizeTimeoutMs(opts.timeoutMs, 2e4);
2304
- const label = resolved.ref ?? resolved.selector;
2305
- const locator = resolved.ref ? refLocator(page, requireRef(resolved.ref)) : page.locator(resolved.selector);
2306
- const { abortPromise, cleanup } = createAbortPromise(opts.signal);
2307
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, opts.signal);
2308
- try {
2309
- await awaitActionWithAbort(locator.scrollIntoViewIfNeeded({ timeout }), abortPromise, reconcileRemoteDialog);
2310
- } catch (err) {
2311
- throw toFriendlyInteractionError(err, label);
2312
- } finally {
2313
- cleanup();
2314
- }
2315
- }
2316
- async function waitForViaPlaywright(opts) {
2317
- const page = await getPageForTargetId(opts);
2318
- ensurePageState(page);
2319
- const timeout = resolveActWaitTimeoutMs(opts.timeoutMs);
2320
- const { abortPromise, cleanup } = createAbortPromise(opts.signal);
2321
- const reconcileRemoteDialog = () => reconcileRemoteDialogAfterActionSettled(page, opts.signal);
2322
- const waitForStep = async (stepPromise) => {
2323
- await awaitActionWithAbort(stepPromise, abortPromise, reconcileRemoteDialog);
2324
- };
2325
- try {
2326
- if (typeof opts.timeMs === "number" && Number.isFinite(opts.timeMs)) await waitForStep(page.waitForTimeout(resolveBoundedDelayMs(opts.timeMs, "wait timeMs", ACT_MAX_WAIT_TIME_MS)));
2327
- if (opts.text) await waitForStep(page.getByText(opts.text).first().waitFor({
2328
- state: "visible",
2329
- timeout
2330
- }));
2331
- if (opts.textGone) await waitForStep(page.getByText(opts.textGone).first().waitFor({
2332
- state: "hidden",
2333
- timeout
2334
- }));
2335
- if (opts.selector) {
2336
- const selector = normalizeOptionalString$1(opts.selector) ?? "";
2337
- if (selector) await waitForStep(page.locator(selector).first().waitFor({
2338
- state: "visible",
2339
- timeout
2340
- }));
2341
- }
2342
- if (opts.url) {
2343
- const url = normalizeOptionalString$1(opts.url) ?? "";
2344
- if (url) await waitForStep(page.waitForURL(url, { timeout }));
2345
- }
2346
- if (opts.loadState) await waitForStep(page.waitForLoadState(opts.loadState, { timeout }));
2347
- if (opts.fn) {
2348
- const fn = normalizeOptionalString$1(opts.fn) ?? "";
2349
- if (fn) await waitForStep(page.waitForFunction(fn, { timeout }));
2350
- }
2351
- } finally {
2352
- cleanup();
2353
- }
2354
- }
2355
- async function takeScreenshotViaPlaywright(opts) {
2356
- const page = await getPageForTargetId(opts);
2357
- ensurePageState(page);
2358
- restoreRoleRefsForTarget({
2359
- cdpUrl: opts.cdpUrl,
2360
- targetId: opts.targetId,
2361
- page
2362
- });
2363
- const type = opts.type ?? "png";
2364
- if (opts.ref) {
2365
- if (opts.fullPage) throw new Error("fullPage is not supported for element screenshots");
2366
- return { buffer: await refLocator(page, opts.ref).screenshot({
2367
- type,
2368
- timeout: opts.timeoutMs
2369
- }) };
2370
- }
2371
- if (opts.element) {
2372
- if (opts.fullPage) throw new Error("fullPage is not supported for element screenshots");
2373
- return { buffer: await page.locator(opts.element).first().screenshot({
2374
- type,
2375
- timeout: opts.timeoutMs
2376
- }) };
2377
- }
2378
- return { buffer: await page.screenshot({
2379
- type,
2380
- fullPage: Boolean(opts.fullPage),
2381
- timeout: opts.timeoutMs
2382
- }) };
2383
- }
2384
- async function screenshotWithLabelsViaPlaywright(opts) {
2385
- const page = await getPageForTargetId(opts);
2386
- ensurePageState(page);
2387
- restoreRoleRefsForTarget({
2388
- cdpUrl: opts.cdpUrl,
2389
- targetId: opts.targetId,
2390
- page
2391
- });
2392
- const type = opts.type ?? "png";
2393
- const maxLabels = typeof opts.maxLabels === "number" && Number.isFinite(opts.maxLabels) ? Math.max(1, Math.floor(opts.maxLabels)) : 150;
2394
- const viewport = await page.evaluate(() => ({
2395
- scrollX: window.scrollX || 0,
2396
- scrollY: window.scrollY || 0,
2397
- width: window.innerWidth || 0,
2398
- height: window.innerHeight || 0
2399
- }));
2400
- const refs = Object.keys(opts.refs ?? {});
2401
- const boxes = [];
2402
- let skipped = 0;
2403
- for (const ref of refs) {
2404
- if (boxes.length >= maxLabels) {
2405
- skipped += 1;
2406
- continue;
2407
- }
2408
- try {
2409
- const box = await refLocator(page, ref).boundingBox();
2410
- if (!box) {
2411
- skipped += 1;
2412
- continue;
2413
- }
2414
- const x0 = box.x;
2415
- const y0 = box.y;
2416
- const x1 = box.x + box.width;
2417
- const y1 = box.y + box.height;
2418
- const vx0 = viewport.scrollX;
2419
- const vy0 = viewport.scrollY;
2420
- const vx1 = viewport.scrollX + viewport.width;
2421
- const vy1 = viewport.scrollY + viewport.height;
2422
- if (x1 < vx0 || x0 > vx1 || y1 < vy0 || y0 > vy1) {
2423
- skipped += 1;
2424
- continue;
2425
- }
2426
- boxes.push({
2427
- ref,
2428
- x: x0 - viewport.scrollX,
2429
- y: y0 - viewport.scrollY,
2430
- w: Math.max(1, box.width),
2431
- h: Math.max(1, box.height)
2432
- });
2433
- } catch {
2434
- skipped += 1;
2435
- }
2436
- }
2437
- try {
2438
- if (boxes.length > 0) await page.evaluate((labels) => {
2439
- document.querySelectorAll("[data-daocore-labels]").forEach((el) => el.remove());
2440
- const root = document.createElement("div");
2441
- root.setAttribute("data-daocore-labels", "1");
2442
- root.style.position = "fixed";
2443
- root.style.left = "0";
2444
- root.style.top = "0";
2445
- root.style.zIndex = "2147483647";
2446
- root.style.pointerEvents = "none";
2447
- root.style.fontFamily = "\"SF Mono\",\"SFMono-Regular\",Menlo,Monaco,Consolas,\"Liberation Mono\",\"Courier New\",monospace";
2448
- const clamp = (value, min, max) => Math.min(max, Math.max(min, value));
2449
- for (const label of labels) {
2450
- const box = document.createElement("div");
2451
- box.setAttribute("data-daocore-labels", "1");
2452
- box.style.position = "absolute";
2453
- box.style.left = `${label.x}px`;
2454
- box.style.top = `${label.y}px`;
2455
- box.style.width = `${label.w}px`;
2456
- box.style.height = `${label.h}px`;
2457
- box.style.border = "2px solid #ffb020";
2458
- box.style.boxSizing = "border-box";
2459
- const tag = document.createElement("div");
2460
- tag.setAttribute("data-daocore-labels", "1");
2461
- tag.textContent = label.ref;
2462
- tag.style.position = "absolute";
2463
- tag.style.left = `${label.x}px`;
2464
- tag.style.top = `${clamp(label.y - 18, 0, 2e4)}px`;
2465
- tag.style.background = "#ffb020";
2466
- tag.style.color = "#1a1a1a";
2467
- tag.style.fontSize = "12px";
2468
- tag.style.lineHeight = "14px";
2469
- tag.style.padding = "1px 4px";
2470
- tag.style.borderRadius = "3px";
2471
- tag.style.boxShadow = "0 1px 2px rgba(0,0,0,0.35)";
2472
- tag.style.whiteSpace = "nowrap";
2473
- root.appendChild(box);
2474
- root.appendChild(tag);
2475
- }
2476
- document.documentElement.appendChild(root);
2477
- }, boxes);
2478
- return {
2479
- buffer: await page.screenshot({
2480
- type,
2481
- timeout: opts.timeoutMs
2482
- }),
2483
- labels: boxes.length,
2484
- skipped
2485
- };
2486
- } finally {
2487
- await page.evaluate(() => {
2488
- document.querySelectorAll("[data-daocore-labels]").forEach((el) => el.remove());
2489
- }).catch(() => {});
2490
- }
2491
- }
2492
- async function setInputFilesViaPlaywright(opts) {
2493
- const page = await getPageForTargetId(opts);
2494
- ensurePageState(page);
2495
- restoreRoleRefsForTarget({
2496
- cdpUrl: opts.cdpUrl,
2497
- targetId: opts.targetId,
2498
- page
2499
- });
2500
- if (!opts.paths.length) throw new Error("paths are required");
2501
- const inputRef = normalizeOptionalString$1(opts.inputRef) ?? "";
2502
- const element = normalizeOptionalString$1(opts.element) ?? "";
2503
- if (inputRef && element) throw new Error("inputRef and element are mutually exclusive");
2504
- if (!inputRef && !element) throw new Error("inputRef or element is required");
2505
- const locator = inputRef ? refLocator(page, inputRef) : page.locator(element).first();
2506
- const uploadPathsResult = await resolveStrictExistingPathsWithinRoot({
2507
- rootDir: DEFAULT_UPLOAD_DIR,
2508
- requestedPaths: opts.paths,
2509
- scopeLabel: `uploads directory (${DEFAULT_UPLOAD_DIR})`
2510
- });
2511
- if (!uploadPathsResult.ok) throw new Error(uploadPathsResult.error);
2512
- const resolvedPaths = uploadPathsResult.paths;
2513
- try {
2514
- await locator.setInputFiles(resolvedPaths);
2515
- } catch (err) {
2516
- throw toFriendlyInteractionError(err, inputRef || element);
2517
- }
2518
- try {
2519
- const handle = await locator.elementHandle();
2520
- if (handle) await handle.evaluate((el) => {
2521
- el.dispatchEvent(new Event("input", { bubbles: true }));
2522
- el.dispatchEvent(new Event("change", { bubbles: true }));
2523
- });
2524
- } catch {}
2525
- }
2526
- async function executeSingleAction(action, cdpUrl, targetId, evaluateEnabled, ssrfPolicy, depth = 0, signal) {
2527
- if (depth > 5) throw new Error(`Batch nesting depth exceeds maximum of 5`);
2528
- const effectiveTargetId = action.targetId ?? targetId;
2529
- switch (action.kind) {
2530
- case "click":
2531
- await clickViaPlaywright({
2532
- cdpUrl,
2533
- targetId: effectiveTargetId,
2534
- ref: action.ref,
2535
- selector: action.selector,
2536
- doubleClick: action.doubleClick,
2537
- button: action.button,
2538
- modifiers: action.modifiers,
2539
- delayMs: action.delayMs,
2540
- timeoutMs: action.timeoutMs,
2541
- ssrfPolicy,
2542
- signal
2543
- });
2544
- break;
2545
- case "clickCoords":
2546
- await clickCoordsViaPlaywright({
2547
- cdpUrl,
2548
- targetId: effectiveTargetId,
2549
- x: action.x,
2550
- y: action.y,
2551
- doubleClick: action.doubleClick,
2552
- button: action.button,
2553
- delayMs: action.delayMs,
2554
- timeoutMs: action.timeoutMs,
2555
- ssrfPolicy,
2556
- signal
2557
- });
2558
- break;
2559
- case "type":
2560
- await typeViaPlaywright({
2561
- cdpUrl,
2562
- targetId: effectiveTargetId,
2563
- ref: action.ref,
2564
- selector: action.selector,
2565
- text: action.text,
2566
- submit: action.submit,
2567
- slowly: action.slowly,
2568
- timeoutMs: action.timeoutMs,
2569
- ssrfPolicy,
2570
- signal
2571
- });
2572
- break;
2573
- case "press":
2574
- await pressKeyViaPlaywright({
2575
- cdpUrl,
2576
- targetId: effectiveTargetId,
2577
- key: action.key,
2578
- delayMs: action.delayMs,
2579
- ssrfPolicy,
2580
- signal
2581
- });
2582
- break;
2583
- case "hover":
2584
- await hoverViaPlaywright({
2585
- cdpUrl,
2586
- targetId: effectiveTargetId,
2587
- ref: action.ref,
2588
- selector: action.selector,
2589
- timeoutMs: action.timeoutMs,
2590
- signal
2591
- });
2592
- break;
2593
- case "scrollIntoView":
2594
- await scrollIntoViewViaPlaywright({
2595
- cdpUrl,
2596
- targetId: effectiveTargetId,
2597
- ref: action.ref,
2598
- selector: action.selector,
2599
- timeoutMs: action.timeoutMs,
2600
- signal
2601
- });
2602
- break;
2603
- case "drag":
2604
- await dragViaPlaywright({
2605
- cdpUrl,
2606
- targetId: effectiveTargetId,
2607
- startRef: action.startRef,
2608
- startSelector: action.startSelector,
2609
- endRef: action.endRef,
2610
- endSelector: action.endSelector,
2611
- timeoutMs: action.timeoutMs,
2612
- signal
2613
- });
2614
- break;
2615
- case "select":
2616
- await selectOptionViaPlaywright({
2617
- cdpUrl,
2618
- targetId: effectiveTargetId,
2619
- ref: action.ref,
2620
- selector: action.selector,
2621
- values: action.values,
2622
- timeoutMs: action.timeoutMs,
2623
- ssrfPolicy,
2624
- signal
2625
- });
2626
- break;
2627
- case "fill":
2628
- await fillFormViaPlaywright({
2629
- cdpUrl,
2630
- targetId: effectiveTargetId,
2631
- fields: action.fields,
2632
- timeoutMs: action.timeoutMs,
2633
- ssrfPolicy,
2634
- signal
2635
- });
2636
- break;
2637
- case "resize":
2638
- await resizeViewportViaPlaywright({
2639
- cdpUrl,
2640
- targetId: effectiveTargetId,
2641
- width: action.width,
2642
- height: action.height
2643
- });
2644
- break;
2645
- case "wait":
2646
- if (action.fn && !evaluateEnabled) throw new Error("wait --fn is disabled by config (browser.evaluateEnabled=false)");
2647
- await waitForViaPlaywright({
2648
- cdpUrl,
2649
- targetId: effectiveTargetId,
2650
- timeMs: action.timeMs,
2651
- text: action.text,
2652
- textGone: action.textGone,
2653
- selector: action.selector,
2654
- url: action.url,
2655
- loadState: action.loadState,
2656
- fn: action.fn,
2657
- timeoutMs: action.timeoutMs,
2658
- signal
2659
- });
2660
- break;
2661
- case "evaluate":
2662
- if (!evaluateEnabled) throw new Error("act:evaluate is disabled by config (browser.evaluateEnabled=false)");
2663
- return await evaluateViaPlaywright({
2664
- cdpUrl,
2665
- targetId: effectiveTargetId,
2666
- ssrfPolicy,
2667
- fn: action.fn,
2668
- ref: action.ref,
2669
- timeoutMs: action.timeoutMs,
2670
- signal
2671
- });
2672
- case "close":
2673
- await closePageViaPlaywright({
2674
- cdpUrl,
2675
- targetId: effectiveTargetId
2676
- });
2677
- break;
2678
- case "batch":
2679
- await batchViaPlaywright({
2680
- cdpUrl,
2681
- targetId: effectiveTargetId,
2682
- ssrfPolicy,
2683
- actions: action.actions,
2684
- stopOnError: action.stopOnError,
2685
- evaluateEnabled,
2686
- depth: depth + 1,
2687
- signal
2688
- });
2689
- break;
2690
- default: throw new Error(`Unsupported batch action kind: ${action.kind}`);
2691
- }
2692
- }
2693
- async function executeActViaPlaywright(opts) {
2694
- const dialogAbort = createObservedDialogAbortSignalForPage({
2695
- page: await getPageForTargetId({
2696
- cdpUrl: opts.cdpUrl,
2697
- targetId: opts.targetId,
2698
- ssrfPolicy: opts.ssrfPolicy
2699
- }),
2700
- parentSignal: opts.signal
2701
- });
2702
- try {
2703
- if (opts.action.kind === "batch") return { results: (await batchViaPlaywright({
2704
- cdpUrl: opts.cdpUrl,
2705
- targetId: opts.targetId,
2706
- ssrfPolicy: opts.ssrfPolicy,
2707
- actions: opts.action.actions,
2708
- stopOnError: opts.action.stopOnError,
2709
- evaluateEnabled: opts.evaluateEnabled,
2710
- signal: dialogAbort.signal
2711
- })).results };
2712
- const result = await executeSingleAction(opts.action, opts.cdpUrl, opts.targetId, opts.evaluateEnabled, opts.ssrfPolicy, 0, dialogAbort.signal);
2713
- if (opts.action.kind === "evaluate") return { result };
2714
- return {};
2715
- } catch (err) {
2716
- if (isBrowserObservedDialogBlockedError(err)) return {
2717
- blockedByDialog: true,
2718
- browserState: err.browserState
2719
- };
2720
- throw err;
2721
- } finally {
2722
- dialogAbort.cleanup();
2723
- }
2724
- }
2725
- async function batchViaPlaywright(opts) {
2726
- const depth = opts.depth ?? 0;
2727
- if (depth > 5) throw new Error(`Batch nesting depth exceeds maximum of 5`);
2728
- if (opts.actions.length > 100) throw new Error(`Batch exceeds maximum of 100 actions`);
2729
- const results = [];
2730
- for (const action of opts.actions) {
2731
- if (opts.signal?.aborted) throw opts.signal.reason ?? /* @__PURE__ */ new Error("aborted");
2732
- try {
2733
- await executeSingleAction(action, opts.cdpUrl, opts.targetId, opts.evaluateEnabled, opts.ssrfPolicy, depth, opts.signal);
2734
- results.push({ ok: true });
2735
- } catch (err) {
2736
- if (isBrowserObservedDialogBlockedError(err)) throw err;
2737
- const message = formatErrorMessage(err);
2738
- results.push({
2739
- ok: false,
2740
- error: message
2741
- });
2742
- if (opts.stopOnError !== false) break;
2743
- }
2744
- }
2745
- return { results };
2746
- }
2747
- //#endregion
2748
- //#region extensions/browser/src/browser/pw-tools-core.responses.ts
2749
- function normalizeOptionalString(value) {
2750
- return typeof value === "string" ? value.trim() || void 0 : void 0;
2751
- }
2752
- async function responseBodyViaPlaywright(opts) {
2753
- const pattern = normalizeOptionalString(opts.url) ?? "";
2754
- if (!pattern) throw new Error("url is required");
2755
- const maxChars = typeof opts.maxChars === "number" && Number.isFinite(opts.maxChars) ? Math.max(1, Math.min(5e6, Math.floor(opts.maxChars))) : 2e5;
2756
- const timeout = normalizeTimeoutMs(opts.timeoutMs, 2e4);
2757
- const page = await getPageForTargetId(opts);
2758
- ensurePageState(page);
2759
- const resp = await new Promise((resolve, reject) => {
2760
- let done = false;
2761
- let timer;
2762
- let handler;
2763
- const cleanup = () => {
2764
- if (timer) clearTimeout(timer);
2765
- timer = void 0;
2766
- if (handler) page.off("response", handler);
2767
- };
2768
- handler = (resp) => {
2769
- if (done) return;
2770
- if (!matchBrowserUrlPattern(pattern, resp.url?.() || "")) return;
2771
- done = true;
2772
- cleanup();
2773
- resolve(resp);
2774
- };
2775
- page.on("response", handler);
2776
- timer = setTimeout(() => {
2777
- if (done) return;
2778
- done = true;
2779
- cleanup();
2780
- reject(/* @__PURE__ */ new Error(`Response not found for url pattern "${pattern}". Run 'daocore browser requests' to inspect recent network activity.`));
2781
- }, timeout);
2782
- });
2783
- const url = resp.url?.() || "";
2784
- const status = resp.status?.();
2785
- const headers = resp.headers?.();
2786
- let bodyText = "";
2787
- try {
2788
- if (typeof resp.text === "function") bodyText = await resp.text();
2789
- else if (typeof resp.body === "function") {
2790
- const buf = await resp.body();
2791
- bodyText = new TextDecoder("utf-8").decode(buf);
2792
- }
2793
- } catch (err) {
2794
- throw new Error(`Failed to read response body for "${url}": ${String(err)}`, { cause: err });
2795
- }
2796
- return {
2797
- url,
2798
- status,
2799
- headers,
2800
- body: bodyText.length > maxChars ? bodyText.slice(0, maxChars) : bodyText,
2801
- truncated: bodyText.length > maxChars ? true : void 0
2802
- };
2803
- }
2804
- //#endregion
2805
- //#region extensions/browser/src/browser/pw-tools-core.state.ts
2806
- const { devices: playwrightDevices } = playwrightCore;
2807
- async function setOfflineViaPlaywright(opts) {
2808
- const page = await getPageForTargetId(opts);
2809
- ensurePageState(page);
2810
- await page.context().setOffline(opts.offline);
2811
- }
2812
- async function setExtraHTTPHeadersViaPlaywright(opts) {
2813
- const page = await getPageForTargetId(opts);
2814
- ensurePageState(page);
2815
- await page.context().setExtraHTTPHeaders(opts.headers);
2816
- }
2817
- async function setHttpCredentialsViaPlaywright(opts) {
2818
- const page = await getPageForTargetId(opts);
2819
- ensurePageState(page);
2820
- if (opts.clear) {
2821
- await page.context().setHTTPCredentials(null);
2822
- return;
2823
- }
2824
- const username = opts.username ?? "";
2825
- const password = opts.password ?? "";
2826
- if (!username) throw new Error("username is required (or set clear=true)");
2827
- await page.context().setHTTPCredentials({
2828
- username,
2829
- password
2830
- });
2831
- }
2832
- async function setGeolocationViaPlaywright(opts) {
2833
- const page = await getPageForTargetId(opts);
2834
- ensurePageState(page);
2835
- const context = page.context();
2836
- if (opts.clear) {
2837
- await context.setGeolocation(null);
2838
- await context.clearPermissions().catch(() => {});
2839
- return;
2840
- }
2841
- if (typeof opts.latitude !== "number" || typeof opts.longitude !== "number") throw new Error("latitude and longitude are required (or set clear=true)");
2842
- await context.setGeolocation({
2843
- latitude: opts.latitude,
2844
- longitude: opts.longitude,
2845
- accuracy: typeof opts.accuracy === "number" ? opts.accuracy : void 0
2846
- });
2847
- const origin = normalizeOptionalString$1(opts.origin) || (() => {
2848
- try {
2849
- return new URL(page.url()).origin;
2850
- } catch {
2851
- return "";
2852
- }
2853
- })();
2854
- if (origin) await context.grantPermissions(["geolocation"], { origin }).catch(() => {});
2855
- }
2856
- async function emulateMediaViaPlaywright(opts) {
2857
- const page = await getPageForTargetId(opts);
2858
- ensurePageState(page);
2859
- await page.emulateMedia({ colorScheme: opts.colorScheme });
2860
- }
2861
- async function setLocaleViaPlaywright(opts) {
2862
- const page = await getPageForTargetId(opts);
2863
- ensurePageState(page);
2864
- const locale = normalizeOptionalString$1(opts.locale) ?? "";
2865
- if (!locale) throw new Error("locale is required");
2866
- await withPageScopedCdpClient({
2867
- cdpUrl: opts.cdpUrl,
2868
- page,
2869
- targetId: opts.targetId,
2870
- fn: async (send) => {
2871
- try {
2872
- await send("Emulation.setLocaleOverride", { locale });
2873
- } catch (err) {
2874
- if (String(err).includes("Another locale override is already in effect")) return;
2875
- throw err;
2876
- }
2877
- }
2878
- });
2879
- }
2880
- async function setTimezoneViaPlaywright(opts) {
2881
- const page = await getPageForTargetId(opts);
2882
- ensurePageState(page);
2883
- const timezoneId = normalizeOptionalString$1(opts.timezoneId) ?? "";
2884
- if (!timezoneId) throw new Error("timezoneId is required");
2885
- await withPageScopedCdpClient({
2886
- cdpUrl: opts.cdpUrl,
2887
- page,
2888
- targetId: opts.targetId,
2889
- fn: async (send) => {
2890
- try {
2891
- await send("Emulation.setTimezoneOverride", { timezoneId });
2892
- } catch (err) {
2893
- const msg = String(err);
2894
- if (msg.includes("Timezone override is already in effect")) return;
2895
- if (msg.includes("Invalid timezone")) throw new Error(`Invalid timezone ID: ${timezoneId}`, { cause: err });
2896
- throw err;
2897
- }
2898
- }
2899
- });
2900
- }
2901
- async function setDeviceViaPlaywright(opts) {
2902
- const page = await getPageForTargetId(opts);
2903
- ensurePageState(page);
2904
- const name = normalizeOptionalString$1(opts.name) ?? "";
2905
- if (!name) throw new Error("device name is required");
2906
- const descriptor = playwrightDevices[name];
2907
- if (!descriptor) throw new Error(`Unknown device "${name}".`);
2908
- if (descriptor.viewport) await page.setViewportSize({
2909
- width: descriptor.viewport.width,
2910
- height: descriptor.viewport.height
2911
- });
2912
- await withPageScopedCdpClient({
2913
- cdpUrl: opts.cdpUrl,
2914
- page,
2915
- targetId: opts.targetId,
2916
- fn: async (send) => {
2917
- if (descriptor.userAgent || descriptor.locale) await send("Emulation.setUserAgentOverride", {
2918
- userAgent: descriptor.userAgent ?? "",
2919
- acceptLanguage: descriptor.locale ?? void 0
2920
- });
2921
- if (descriptor.viewport) await send("Emulation.setDeviceMetricsOverride", {
2922
- mobile: Boolean(descriptor.isMobile),
2923
- width: descriptor.viewport.width,
2924
- height: descriptor.viewport.height,
2925
- deviceScaleFactor: descriptor.deviceScaleFactor ?? 1,
2926
- screenWidth: descriptor.viewport.width,
2927
- screenHeight: descriptor.viewport.height
2928
- });
2929
- if (descriptor.hasTouch) await send("Emulation.setTouchEmulationEnabled", { enabled: true });
2930
- }
2931
- });
2932
- }
2933
- //#endregion
2934
- //#region extensions/browser/src/browser/pw-tools-core.storage.ts
2935
- async function cookiesGetViaPlaywright(opts) {
2936
- const page = await getPageForTargetId(opts);
2937
- ensurePageState(page);
2938
- return { cookies: await page.context().cookies() };
2939
- }
2940
- async function cookiesSetViaPlaywright(opts) {
2941
- const page = await getPageForTargetId(opts);
2942
- ensurePageState(page);
2943
- const cookie = opts.cookie;
2944
- if (!cookie.name || cookie.value === void 0) throw new Error("cookie name and value are required");
2945
- const hasUrl = typeof cookie.url === "string" && cookie.url.trim();
2946
- const hasDomainPath = typeof cookie.domain === "string" && cookie.domain.trim() && typeof cookie.path === "string" && cookie.path.trim();
2947
- if (!hasUrl && !hasDomainPath) throw new Error("cookie requires url, or domain+path");
2948
- await page.context().addCookies([cookie]);
2949
- }
2950
- async function cookiesClearViaPlaywright(opts) {
2951
- const page = await getPageForTargetId(opts);
2952
- ensurePageState(page);
2953
- await page.context().clearCookies();
2954
- }
2955
- async function storageGetViaPlaywright(opts) {
2956
- const page = await getPageForTargetId(opts);
2957
- ensurePageState(page);
2958
- const kind = opts.kind;
2959
- const key = readStringValue(opts.key);
2960
- return { values: await page.evaluate(({ kind: kind2, key: key2 }) => {
2961
- const store = kind2 === "session" ? window.sessionStorage : window.localStorage;
2962
- if (key2) {
2963
- const value = store.getItem(key2);
2964
- return value === null ? {} : { [key2]: value };
2965
- }
2966
- const out = {};
2967
- for (let i = 0; i < store.length; i += 1) {
2968
- const k = store.key(i);
2969
- if (!k) continue;
2970
- const v = store.getItem(k);
2971
- if (v !== null) out[k] = v;
2972
- }
2973
- return out;
2974
- }, {
2975
- kind,
2976
- key
2977
- }) ?? {} };
2978
- }
2979
- async function storageSetViaPlaywright(opts) {
2980
- const page = await getPageForTargetId(opts);
2981
- ensurePageState(page);
2982
- const key = opts.key;
2983
- if (!key) throw new Error("key is required");
2984
- await page.evaluate(({ kind, key: k, value }) => {
2985
- (kind === "session" ? window.sessionStorage : window.localStorage).setItem(k, value);
2986
- }, {
2987
- kind: opts.kind,
2988
- key,
2989
- value: opts.value
2990
- });
2991
- }
2992
- async function storageClearViaPlaywright(opts) {
2993
- const page = await getPageForTargetId(opts);
2994
- ensurePageState(page);
2995
- await page.evaluate(({ kind }) => {
2996
- (kind === "session" ? window.sessionStorage : window.localStorage).clear();
2997
- }, { kind: opts.kind });
2998
- }
2999
- //#endregion
3000
- //#region extensions/browser/src/browser/pw-tools-core.trace.ts
3001
- async function traceStartViaPlaywright(opts) {
3002
- const context = (await getPageForTargetId(opts)).context();
3003
- const ctxState = ensureContextState(context);
3004
- if (ctxState.traceActive) throw new Error("Trace already running. Stop the current trace before starting a new one.");
3005
- await context.tracing.start({
3006
- screenshots: opts.screenshots ?? true,
3007
- snapshots: opts.snapshots ?? true,
3008
- sources: opts.sources ?? false
3009
- });
3010
- ctxState.traceActive = true;
3011
- }
3012
- async function traceStopViaPlaywright(opts) {
3013
- const context = (await getPageForTargetId(opts)).context();
3014
- const ctxState = ensureContextState(context);
3015
- if (!ctxState.traceActive) throw new Error("No active trace. Start a trace before stopping it.");
3016
- await writeViaSiblingTempPath({
3017
- rootDir: DEFAULT_TRACE_DIR,
3018
- targetPath: opts.path,
3019
- writeTemp: async (tempPath) => {
3020
- await context.tracing.stop({ path: tempPath });
3021
- }
3022
- });
3023
- ctxState.traceActive = false;
3024
- }
3025
- //#endregion
3026
- //#region extensions/browser/src/browser/pw-ai.ts
3027
- markPwAiLoaded();
3028
- //#endregion
3029
- export { armDialogViaPlaywright, armFileUploadViaPlaywright, batchViaPlaywright, clickViaPlaywright, closePageByTargetIdViaPlaywright, closePageViaPlaywright, closePlaywrightBrowserConnection, cookiesClearViaPlaywright, cookiesGetViaPlaywright, cookiesSetViaPlaywright, createObservedDialogAbortSignalForPage, createPageViaPlaywright, downloadViaPlaywright, dragViaPlaywright, emulateMediaViaPlaywright, ensurePageState, evaluateViaPlaywright, executeActViaPlaywright, fillFormViaPlaywright, focusPageByTargetIdViaPlaywright, forceDisconnectPlaywrightForTarget, getConsoleMessagesViaPlaywright, getNetworkRequestsViaPlaywright, getObservedBrowserStateForPage, getObservedBrowserStateViaPlaywright, getPageErrorsViaPlaywright, getPageForTargetId, highlightViaPlaywright, hoverViaPlaywright, isBrowserObservedDialogBlockedError, listPagesViaPlaywright, markObservedDialogsHandledRemotelyForPage, navigateViaPlaywright, pdfViaPlaywright, pressKeyViaPlaywright, refLocator, resizeViewportViaPlaywright, respondToObservedDialogOnPage, respondToObservedDialogViaPlaywright, responseBodyViaPlaywright, screenshotWithLabelsViaPlaywright, scrollIntoViewViaPlaywright, selectOptionViaPlaywright, setDeviceViaPlaywright, setExtraHTTPHeadersViaPlaywright, setGeolocationViaPlaywright, setHttpCredentialsViaPlaywright, setInputFilesViaPlaywright, setLocaleViaPlaywright, setOfflineViaPlaywright, setTimezoneViaPlaywright, snapshotAiViaPlaywright, snapshotAriaViaPlaywright, snapshotRoleViaPlaywright, storageClearViaPlaywright, storageGetViaPlaywright, storageSetViaPlaywright, storeAriaSnapshotRefsViaPlaywright, takeScreenshotViaPlaywright, traceStartViaPlaywright, traceStopViaPlaywright, typeViaPlaywright, waitForDownloadViaPlaywright, waitForViaPlaywright };