@gaodefa/daocore 2026.5.85 → 2026.5.87

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 (1702) hide show
  1. package/dist/abort-DF_NBB7k.js +277 -0
  2. package/dist/abort.runtime-D4MkvEhQ.js +2 -0
  3. package/dist/abort.runtime.js +1 -1
  4. package/dist/account-inspect-BgTcq2xK.js +173 -0
  5. package/dist/accounts-B4A5OwEA.js +119 -0
  6. package/dist/accounts-BkS1Fh-0.js +107 -0
  7. package/dist/accounts-DF7-7Smq.js +107 -0
  8. package/dist/accounts-UL1OgSV7.js +2 -0
  9. package/dist/acp/control-plane/manager.d.ts +2 -1
  10. package/dist/acp-runtime-Cx2ACvcD.js +26 -0
  11. package/dist/acp-spawn-BGd_lmtE.js +2 -0
  12. package/dist/acp-spawn-BV0aSrgH.js +1275 -0
  13. package/dist/acp-stateful-target-driver-BZXAtm9O.js +89 -0
  14. package/dist/action-kill-CrabJ-6-.js +33 -0
  15. package/dist/action-runtime-BWOfmJe3.js +469 -0
  16. package/dist/action-runtime-api-Fr0Pcsql.js +2 -0
  17. package/dist/action-send-Cpl-x8ro.js +39 -0
  18. package/dist/action-spawn-DceGvU1M.js +47 -0
  19. package/dist/actions-Dx4zHx1-.js +161 -0
  20. package/dist/actions.runtime-CXgc7_sE.js +5 -0
  21. package/dist/agent-6f80KcUH.js +2 -0
  22. package/dist/agent-B2kAd5xV.js +3 -0
  23. package/dist/agent-command-DQ1XgXqe.d.ts +105 -0
  24. package/dist/agent-command-DwGwELK0.js +1367 -0
  25. package/dist/agent-components.runtime-DJYuGMFi.js +10 -0
  26. package/dist/agent-components.runtime.js +1 -1
  27. package/dist/agent-harness-Dya8_zFH.d.ts +146 -0
  28. package/dist/agent-harness-runtime-B18Zw6Rz.d.ts +691 -0
  29. package/dist/agent-harness-runtime-D_wIHJVe.js +180 -0
  30. package/dist/agent-harness-task-runtime-ol_ltjHi.js +140 -0
  31. package/dist/agent-runner-execution-D5wMRx5h.js +1713 -0
  32. package/dist/agent-runner-utils-CLCfaT2K.js +266 -0
  33. package/dist/agent-runner.runtime-Igsb-Us4.js +3455 -0
  34. package/dist/agent-runner.runtime.js +1 -1
  35. package/dist/agent-runtime-tAPmASEK.js +229 -0
  36. package/dist/agent-via-gateway-CmOOhHWf.js +463 -0
  37. package/dist/agents/pi-embedded-runner/tool-split.d.ts +1 -1
  38. package/dist/api-BGUYfA7u.js +639 -0
  39. package/dist/api-Bb3jRMVp.js +3 -0
  40. package/dist/api-CDGKNega.js +6 -0
  41. package/dist/api-D-TLdpx5.js +2 -0
  42. package/dist/api-DXDbFZ7W.js +134 -0
  43. package/dist/api-DYuUdqrI.d.ts +52 -0
  44. package/dist/api-o2EhTZRZ.js +2 -0
  45. package/dist/apply-BWXKR0_1.js +41 -0
  46. package/dist/apply-C3i3NucS.js +54 -0
  47. package/dist/approval-handler.runtime-DhzHxhOa.js +130 -0
  48. package/dist/assistant-SXZqrOD4.js +291 -0
  49. package/dist/attachment-normalize-DobdGk6t.js +225 -0
  50. package/dist/attempt-execution-BOV_h0-N.js +558 -0
  51. package/dist/attempt-execution.runtime-CXlw2E2H.js +3 -0
  52. package/dist/attempt-execution.runtime.js +1 -1
  53. package/dist/attempt-execution.shared-BUNB-ofJ.js +38 -0
  54. package/dist/attempt.prompt-helpers-DfgNBTYi.js +475 -0
  55. package/dist/attempt.tool-run-context-DdadqfC-.js +2094 -0
  56. package/dist/binding-routing-BYWsTgH4.js +113 -0
  57. package/dist/binding-targets-CDxkaXRY.js +121 -0
  58. package/dist/bot-BMJcaPAi.js +7894 -0
  59. package/dist/bot-deps-CNg_Zt2P.js +2 -0
  60. package/dist/bot-deps-FZotnMZO.js +747 -0
  61. package/dist/bot-message-context.runtime-C_OEKOE-.js +7 -0
  62. package/dist/bot-message-context.runtime.js +1 -1
  63. package/dist/bot-message-context.session.runtime-VbbwvU7y.js +12 -0
  64. package/dist/bot-message-context.session.runtime.js +1 -1
  65. package/dist/bot-native-commands.delivery.runtime-CuquGLAx.js +4 -0
  66. package/dist/bot-native-commands.delivery.runtime.js +1 -1
  67. package/dist/bot-native-commands.runtime-DtYCPjvW.js +13 -0
  68. package/dist/bot-native-commands.runtime.js +1 -1
  69. package/dist/bridge-server-B4pS54jd.js +113 -0
  70. package/dist/browser-cli-BHUdFJIS.js +230 -0
  71. package/dist/browser-cli-BWWH1Csp.js +2 -0
  72. package/dist/browser-cli-actions-input-1hfL1q3f.js +473 -0
  73. package/dist/browser-cli-actions-observe-Ctdz-Ocl.js +81 -0
  74. package/dist/browser-cli-debug-D4yOgAhy.js +137 -0
  75. package/dist/browser-cli-inspect-D6c28uLw.js +104 -0
  76. package/dist/browser-cli-manage-DoCDoOsO.js +443 -0
  77. package/dist/browser-cli-resize-Dgb5KdMO.js +26 -0
  78. package/dist/browser-cli-shared-C1LIiQyl.js +50 -0
  79. package/dist/browser-cli-state-CwIDB8-B.js +337 -0
  80. package/dist/browser-control-auth-COjZjE3L.js +2 -0
  81. package/dist/browser-profiles-D085C5gN.js +2 -0
  82. package/dist/browser-runtime-CKIOtwI9.js +384 -0
  83. package/dist/build-DHK6vRrC.js +257 -0
  84. package/dist/build-info.json +3 -3
  85. package/dist/bundled/boot-md/handler.js +2 -2
  86. package/dist/bundled/session-memory/handler.js +1 -1
  87. package/dist/bundled-channel-config-schema-BsHcx3wh.d.ts +3163 -0
  88. package/dist/call-D8ev9OI5.d.ts +43 -0
  89. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  90. package/dist/capability-cli-DRrPaB5q.js +1782 -0
  91. package/dist/channel-29833Q7U.d.ts +8 -0
  92. package/dist/channel-B0gFm2e0.d.ts +49 -0
  93. package/dist/channel-B4huj9Kp.js +362 -0
  94. package/dist/channel-B4wQxeHH.d.ts +14 -0
  95. package/dist/channel-BLs4RYYL.js +1777 -0
  96. package/dist/channel-BS3cqj-Z.d.ts +6 -0
  97. package/dist/channel-BU5YCSFs.d.ts +427 -0
  98. package/dist/channel-BXg8HDz6.d.ts +7 -0
  99. package/dist/channel-B_rnZ7-_.d.ts +26 -0
  100. package/dist/channel-BnSrEvQt.js +238 -0
  101. package/dist/channel-BuEQnzVg.js +1556 -0
  102. package/dist/channel-BvlX4grI.d.ts +106 -0
  103. package/dist/channel-C75uc-F0.d.ts +12 -0
  104. package/dist/channel-CMIcwlip.js +955 -0
  105. package/dist/channel-CTTRs_4Q.js +376 -0
  106. package/dist/channel-Ceh4DhGf.js +808 -0
  107. package/dist/channel-Cg78poCb.d.ts +7 -0
  108. package/dist/channel-CtVWvTxM.d.ts +8 -0
  109. package/dist/channel-CxzIiRo0.js +740 -0
  110. package/dist/channel-D3sCmweW.d.ts +64 -0
  111. package/dist/channel-DBe2Xwn9.js +1249 -0
  112. package/dist/channel-DOB2mltt.js +867 -0
  113. package/dist/channel-DU9qt3dX.js +481 -0
  114. package/dist/channel-DWCzQ-Po.js +562 -0
  115. package/dist/channel-Dha12xQd.js +2126 -0
  116. package/dist/channel-EAYFx_aX.d.ts +47 -0
  117. package/dist/channel-VJIcMa-M.js +508 -0
  118. package/dist/channel-WPOWimOu.js +1134 -0
  119. package/dist/channel-actions.runtime-bqHQHH3X.js +265 -0
  120. package/dist/channel-actions.runtime.js +1 -1
  121. package/dist/channel-core-DsmamxDL.d.ts +6 -0
  122. package/dist/channel-core-m0EI5nTB.js +5 -0
  123. package/dist/channel-entry-contract-DwsX3A32.d.ts +112 -0
  124. package/dist/channel-ez59JAzr.d.ts +114 -0
  125. package/dist/channel-inbound-hFEolyVo.js +80 -0
  126. package/dist/channel-l10cAz1Q.js +1496 -0
  127. package/dist/channel-lifecycle-BXdiTu_h.d.ts +126 -0
  128. package/dist/channel-oeyyvfIC.d.ts +104 -0
  129. package/dist/channel-pairing-qPwn6FAN.d.ts +58 -0
  130. package/dist/channel-plugin-runtime-BMtJ1Wgj.js +998 -0
  131. package/dist/channel-plugin-runtime-Cm532MRz.d.ts +7 -0
  132. package/dist/channel-runtime-TLiTFcI9.js +408 -0
  133. package/dist/channel-ryumzsaN.d.ts +28 -0
  134. package/dist/channel-uLv7YV-J.js +653 -0
  135. package/dist/channel-zfDQdZSM.d.ts +8 -0
  136. package/dist/channel.runtime-3Aev2p4z.js +88 -0
  137. package/dist/channel.runtime-BBoj-2rR.js +2528 -0
  138. package/dist/channel.runtime-BHW11124.js +254 -0
  139. package/dist/channel.runtime-BO5IrBIY.js +652 -0
  140. package/dist/channel.runtime-C8L4S2Y3.js +109 -0
  141. package/dist/channel.runtime-D55LFe_S.js +21009 -0
  142. package/dist/channel.runtime-DUVRcCkd.js +1008 -0
  143. package/dist/channel.runtime-eAjrNDCs.js +733 -0
  144. package/dist/channel.runtime-ek9gTQao.js +4 -0
  145. package/dist/channel.setup-BKCOmQ1R.d.ts +6 -0
  146. package/dist/channel.setup-C4kFVZ9n.js +1098 -0
  147. package/dist/channel.setup-CG4h40nr.js +10 -0
  148. package/dist/channel.setup-CIy_GOHl.d.ts +8 -0
  149. package/dist/channel.setup-DLoH7iov.d.ts +7 -0
  150. package/dist/channel.setup-t6GC0j9y.js +343 -0
  151. package/dist/chat-u7qZ4sNv.js +2666 -0
  152. package/dist/chrome-CcpklbxU.js +1503 -0
  153. package/dist/cli/run-main.js +5 -5
  154. package/dist/cli-DfMcB-YB.d.ts +20 -0
  155. package/dist/cli-DuN9_yOX.js +1341 -0
  156. package/dist/cli-backend-C3cY7GNo.d.ts +5 -0
  157. package/dist/cli-backend-Dq6pWbMI.d.ts +5 -0
  158. package/dist/cli-compaction-_t3h1d1Y.js +347 -0
  159. package/dist/cli-metadata-CuQDanWu.js +22 -0
  160. package/dist/cli-runner-BICDg94b.js +2 -0
  161. package/dist/cli-runner-CeaLhAdU.js +540 -0
  162. package/dist/cli-runner.runtime-Ckyx1-nO.js +4 -0
  163. package/dist/cli-runner.runtime-ZsfkXp6T.js +3 -0
  164. package/dist/cli-runner.runtime.js +1 -1
  165. package/dist/cli-shared-CLlJpRmc.d.ts +20 -0
  166. package/dist/cli-startup-metadata.json +8 -8
  167. package/dist/client-UnpX4vLL.js +650 -0
  168. package/dist/client-adapter-DXOFyLda.js +897 -0
  169. package/dist/client-factory-DvI4dWav.js +9 -0
  170. package/dist/command-auth--55vYozU.js +135 -0
  171. package/dist/command-handlers-luOY52Zj.js +1609 -0
  172. package/dist/command-registry-2ZPFOxQD.js +4 -0
  173. package/dist/command-registry-BnlVL4Z5.js +9 -0
  174. package/dist/command-registry-core-CY3_nsXj.js +110 -0
  175. package/dist/command-status.runtime-DlWcbk6f.js +90 -0
  176. package/dist/command-status.runtime.js +1 -1
  177. package/dist/commands-9rlXSaBn.d.ts +113 -0
  178. package/dist/commands-acp-1GcD7q5q.js +74 -0
  179. package/dist/commands-compact.runtime-DO9NBGsY.js +10 -0
  180. package/dist/commands-compact.runtime.js +1 -1
  181. package/dist/commands-handlers.runtime-CS9oLcTy.js +6154 -0
  182. package/dist/commands-handlers.runtime.js +1 -1
  183. package/dist/commands-status-B-VHaYH5.js +3 -0
  184. package/dist/commands-status-CD4lbvZe.js +16 -0
  185. package/dist/commands-status.runtime-B-VHaYH5.js +3 -0
  186. package/dist/commands-status.runtime.js +1 -1
  187. package/dist/commands-subagents-control.runtime-BW2wSGGB.js +2 -0
  188. package/dist/commands-subagents-control.runtime-DayCbQBi.js +3 -0
  189. package/dist/commands-subagents-control.runtime.js +1 -1
  190. package/dist/commands-system-prompt-Bu0-zdQV.js +162 -0
  191. package/dist/commands-system-prompt-DqzUrExG.js +2 -0
  192. package/dist/commands.runtime-Bi618hLG.js +176 -0
  193. package/dist/commands.runtime.js +1 -1
  194. package/dist/commitments/runtime.js +1 -1
  195. package/dist/compact-D6RF2ao-.js +480 -0
  196. package/dist/compact-DOHvJc9C.js +1141 -0
  197. package/dist/compact.runtime-BMV69fdx.js +12 -0
  198. package/dist/compact.runtime.js +1 -1
  199. package/dist/completion-cli-CKorRumh.js +315 -0
  200. package/dist/computer-use-QDwH-PSW.js +367 -0
  201. package/dist/config-D085C5gN.js +2 -0
  202. package/dist/config-kivtFwCd.js +373 -0
  203. package/dist/config-mutations-BEpZ3rYv.js +159 -0
  204. package/dist/config-schema-Bwgooc-v.d.ts +20 -0
  205. package/dist/config-schema-lIvqvlbL.d.ts +34 -0
  206. package/dist/context-engine-host-compat-BXoUGeB_.js +2 -0
  207. package/dist/context-engine-host-compat-CcCmD5o9.js +288 -0
  208. package/dist/context-engine-lifecycle-CwtbthA3.js +1274 -0
  209. package/dist/contracts-testkit-DC7MJzfa.d.ts +145 -0
  210. package/dist/control-auth-wsG-pObJ.js +114 -0
  211. package/dist/control-service-DoSyDuPZ.js +145 -0
  212. package/dist/conversation-binding-runtime-vZQ351Yx.js +4 -0
  213. package/dist/conversation-runtime-DZztdc11.js +31 -0
  214. package/dist/core-CcQCE1PE.js +282 -0
  215. package/dist/core-api-Cn9nxEQY.js +5 -0
  216. package/dist/core-api-DJttT99e.js +2 -0
  217. package/dist/core-loprAG73.d.ts +224 -0
  218. package/dist/crestodian/crestodian.js +1 -1
  219. package/dist/crestodian/rescue-message.js +1 -1
  220. package/dist/crestodian-B77mGOnM.js +55 -0
  221. package/dist/daocore-runtime-B-rzUpKx.d.ts +151 -0
  222. package/dist/daocore-tools-B2AoPxwu.js +11727 -0
  223. package/dist/delivery-DrO-hbmH.js +1002 -0
  224. package/dist/dialogue-xd9pIoHO.js +37 -0
  225. package/dist/dir-fetch-tool-CMJ9Pt6u.js +565 -0
  226. package/dist/dir-list-tool-BrTrO97I.js +100 -0
  227. package/dist/direct-dm-Dbxrg-M8.js +64 -0
  228. package/dist/directive-handling.fast-lane-Cm6q7myY.js +68 -0
  229. package/dist/directive-handling.impl-BW2_4S2v.js +818 -0
  230. package/dist/directive-handling.impl-DkMvyjSy.js +2 -0
  231. package/dist/directive-handling.model-selection-BBc-JgRD.js +122 -0
  232. package/dist/directive-handling.persist.runtime-ByZk594V.js +263 -0
  233. package/dist/directive-handling.persist.runtime.js +1 -1
  234. package/dist/dispatch-acp-transcript.runtime-t6_JeKwA.js +40 -0
  235. package/dist/dispatch-acp-transcript.runtime.js +1 -1
  236. package/dist/dispatch-acp.runtime-yf6pNdiB.js +18 -0
  237. package/dist/dispatch-acp.runtime.js +1 -1
  238. package/dist/dispatch-rpGfQmzk.js +1640 -0
  239. package/dist/doctor-Ce9osVgH.js +6 -0
  240. package/dist/doctor-Dl4rkbw8.js +2 -0
  241. package/dist/doctor-config-flow-IokiMPZL.js +1741 -0
  242. package/dist/doctor-core-checks-DPugZhrT.js +2 -0
  243. package/dist/doctor-core-checks-DTM0dPXV.js +573 -0
  244. package/dist/doctor-health-D9BF5XjZ.js +65 -0
  245. package/dist/doctor-health-contributions-CeAx5c5L.js +696 -0
  246. package/dist/doctor-lint-B3Ya8mmD.js +94 -0
  247. package/dist/doctor-state-integrity-B5aQjl2y.js +1231 -0
  248. package/dist/doctor-update-CGkyLrKv.js +58 -0
  249. package/dist/doctor-update-fix-CQ8qVhBX.js +107 -0
  250. package/dist/dynamic-tools-DZebai0O.js +486 -0
  251. package/dist/embedded-backend-BS79InDg.js +579 -0
  252. package/dist/embedded-gateway-stub.runtime-CsTs2-an.js +12 -0
  253. package/dist/embedded-gateway-stub.runtime.js +1 -1
  254. package/dist/embedding-provider-BKIXHvGl.d.ts +16 -0
  255. package/dist/embedding-provider-ZDZfzTLK.d.ts +65 -0
  256. package/dist/embedding-provider-uqWqn4wW.d.ts +21 -0
  257. package/dist/entry.d.ts +1 -1
  258. package/dist/exec-approvals-DSGilgX_.js +149 -0
  259. package/dist/extensionAPI.js +1 -1
  260. package/dist/extensions/active-memory/index.d.ts +1 -1
  261. package/dist/extensions/active-memory/index.js +1 -1
  262. package/dist/extensions/admin-http-rpc/index.d.ts +1 -1
  263. package/dist/extensions/admin-http-rpc/index.js +1 -1
  264. package/dist/extensions/alibaba/index.d.ts +1 -1
  265. package/dist/extensions/anthropic/api.d.ts +3 -3
  266. package/dist/extensions/anthropic/cli-backend-api.d.ts +2 -2
  267. package/dist/extensions/anthropic/cli-backend.d.ts +1 -1
  268. package/dist/extensions/anthropic/cli-migration.d.ts +1 -1
  269. package/dist/extensions/anthropic/cli-shared.d.ts +1 -1
  270. package/dist/extensions/anthropic/contract-api.d.ts +1 -1
  271. package/dist/extensions/anthropic/doctor-contract-api.d.ts +1 -1
  272. package/dist/extensions/anthropic/index.d.ts +1 -1
  273. package/dist/extensions/anthropic/provider-contract-api.d.ts +1 -1
  274. package/dist/extensions/anthropic/provider-discovery.d.ts +1 -1
  275. package/dist/extensions/anthropic/provider-policy-api.d.ts +1 -1
  276. package/dist/extensions/anthropic/register.runtime.d.ts +1 -1
  277. package/dist/extensions/anthropic/replay-policy.d.ts +1 -1
  278. package/dist/extensions/anthropic/setup-api.d.ts +1 -1
  279. package/dist/extensions/anthropic/stream-wrappers.d.ts +1 -1
  280. package/dist/extensions/anthropic/test-api.d.ts +2 -2
  281. package/dist/extensions/arcee/index.d.ts +1 -1
  282. package/dist/extensions/azure-speech/index.d.ts +1 -1
  283. package/dist/extensions/azure-speech/speech-provider.d.ts +1 -1
  284. package/dist/extensions/bonjour/index.d.ts +1 -1
  285. package/dist/extensions/browser/browser-bridge.js +1 -1
  286. package/dist/extensions/browser/browser-config.js +4 -4
  287. package/dist/extensions/browser/browser-control-auth.js +2 -2
  288. package/dist/extensions/browser/browser-doctor.js +2 -2
  289. package/dist/extensions/browser/browser-maintenance.js +1 -1
  290. package/dist/extensions/browser/browser-profiles.js +2 -2
  291. package/dist/extensions/browser/browser-runtime-api.js +11 -11
  292. package/dist/extensions/browser/cli-metadata.d.ts +1 -1
  293. package/dist/extensions/browser/cli-metadata.js +1 -1
  294. package/dist/extensions/browser/index.d.ts +1 -1
  295. package/dist/extensions/browser/index.js +1 -1
  296. package/dist/extensions/browser/plugin-registration.d.ts +1 -1
  297. package/dist/extensions/browser/plugin-registration.js +1 -1
  298. package/dist/extensions/browser/register.runtime.d.ts +2 -2
  299. package/dist/extensions/browser/register.runtime.js +4 -4
  300. package/dist/extensions/browser/runtime-api.d.ts +3 -3
  301. package/dist/extensions/browser/runtime-api.js +13 -13
  302. package/dist/extensions/browser/setup-api.d.ts +1 -1
  303. package/dist/extensions/browser/test-support.d.ts +1 -1
  304. package/dist/extensions/byteplus/index.d.ts +1 -1
  305. package/dist/extensions/byteplus/provider-discovery.d.ts +1 -1
  306. package/dist/extensions/canvas/cli-metadata.d.ts +1 -1
  307. package/dist/extensions/canvas/index.d.ts +1 -1
  308. package/dist/extensions/canvas/index.js +1 -1
  309. package/dist/extensions/canvas/runtime-api.d.ts +2 -2
  310. package/dist/extensions/canvas/setup-api.d.ts +1 -1
  311. package/dist/extensions/cerebras/index.d.ts +1 -1
  312. package/dist/extensions/chutes/index.d.ts +1 -1
  313. package/dist/extensions/clickclack/api.d.ts +2 -2
  314. package/dist/extensions/clickclack/api.js +2 -2
  315. package/dist/extensions/clickclack/channel-plugin-api.d.ts +1 -1
  316. package/dist/extensions/clickclack/channel-plugin-api.js +1 -1
  317. package/dist/extensions/clickclack/index.d.ts +2 -2
  318. package/dist/extensions/clickclack/runtime-api.d.ts +2 -2
  319. package/dist/extensions/clickclack/runtime-api.js +2 -2
  320. package/dist/extensions/cloudflare-ai-gateway/index.d.ts +1 -1
  321. package/dist/extensions/cloudflare-ai-gateway/stream-wrappers.d.ts +1 -1
  322. package/dist/extensions/comfy/index.d.ts +1 -1
  323. package/dist/extensions/copilot-proxy/index.d.ts +1 -1
  324. package/dist/extensions/copilot-proxy/runtime-api.d.ts +2 -2
  325. package/dist/extensions/deepgram/index.d.ts +1 -1
  326. package/dist/extensions/deepgram/realtime-transcription-provider.d.ts +1 -1
  327. package/dist/extensions/deepgram/test-api.d.ts +1 -1
  328. package/dist/extensions/deepinfra/api.d.ts +2 -2
  329. package/dist/extensions/deepinfra/embedding-provider.d.ts +1 -1
  330. package/dist/extensions/deepinfra/index.d.ts +1 -1
  331. package/dist/extensions/deepinfra/memory-embedding-adapter.d.ts +1 -1
  332. package/dist/extensions/deepinfra/speech-provider.d.ts +1 -1
  333. package/dist/extensions/deepseek/api.d.ts +1 -1
  334. package/dist/extensions/deepseek/index.d.ts +1 -1
  335. package/dist/extensions/deepseek/provider-discovery.d.ts +1 -1
  336. package/dist/extensions/deepseek/provider-policy-api.d.ts +1 -1
  337. package/dist/extensions/deepseek/stream.d.ts +1 -1
  338. package/dist/extensions/deepseek/thinking.d.ts +1 -1
  339. package/dist/extensions/device-pair/api.d.ts +3 -3
  340. package/dist/extensions/device-pair/api.js +1 -1
  341. package/dist/extensions/device-pair/index.d.ts +1 -1
  342. package/dist/extensions/device-pair/notify.d.ts +1 -1
  343. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  344. package/dist/extensions/document-extract/index.d.ts +1 -1
  345. package/dist/extensions/duckduckgo/index.d.ts +1 -1
  346. package/dist/extensions/elevenlabs/index.d.ts +1 -1
  347. package/dist/extensions/elevenlabs/realtime-transcription-provider.d.ts +1 -1
  348. package/dist/extensions/elevenlabs/setup-api.d.ts +1 -1
  349. package/dist/extensions/elevenlabs/speech-provider.d.ts +1 -1
  350. package/dist/extensions/elevenlabs/test-api.d.ts +2 -2
  351. package/dist/extensions/exa/index.d.ts +1 -1
  352. package/dist/extensions/fal/index.d.ts +1 -1
  353. package/dist/extensions/fal/provider-contract-api.d.ts +1 -1
  354. package/dist/extensions/fal/provider-registration.d.ts +1 -1
  355. package/dist/extensions/file-transfer/index.d.ts +1 -1
  356. package/dist/extensions/file-transfer/index.js +4 -4
  357. package/dist/extensions/firecrawl/index.d.ts +1 -1
  358. package/dist/extensions/fireworks/index.d.ts +1 -1
  359. package/dist/extensions/fireworks/provider-policy-api.d.ts +1 -1
  360. package/dist/extensions/fireworks/stream.d.ts +1 -1
  361. package/dist/extensions/fireworks/thinking-policy.d.ts +1 -1
  362. package/dist/extensions/github-copilot/embeddings.d.ts +1 -1
  363. package/dist/extensions/github-copilot/index.d.ts +1 -1
  364. package/dist/extensions/github-copilot/models.d.ts +1 -1
  365. package/dist/extensions/github-copilot/register.runtime.d.ts +2 -2
  366. package/dist/extensions/github-copilot/stream.d.ts +1 -1
  367. package/dist/extensions/google/api.d.ts +5 -5
  368. package/dist/extensions/google/cli-backend.d.ts +1 -1
  369. package/dist/extensions/google/doctor-contract-api.d.ts +1 -1
  370. package/dist/extensions/google/embedding-batch.d.ts +1 -1
  371. package/dist/extensions/google/embedding-provider.d.ts +1 -1
  372. package/dist/extensions/google/gemini-cli-provider.d.ts +1 -1
  373. package/dist/extensions/google/index.d.ts +1 -1
  374. package/dist/extensions/google/memory-embedding-adapter.d.ts +1 -1
  375. package/dist/extensions/google/provider-contract-api.d.ts +1 -1
  376. package/dist/extensions/google/provider-hooks.d.ts +2 -2
  377. package/dist/extensions/google/provider-models.d.ts +1 -1
  378. package/dist/extensions/google/provider-policy-api.d.ts +1 -1
  379. package/dist/extensions/google/provider-policy.d.ts +1 -1
  380. package/dist/extensions/google/provider-registration.d.ts +1 -1
  381. package/dist/extensions/google/realtime-voice-provider.d.ts +1 -1
  382. package/dist/extensions/google/runtime-api.d.ts +3 -3
  383. package/dist/extensions/google/setup-api.d.ts +1 -1
  384. package/dist/extensions/google/speech-provider.d.ts +1 -1
  385. package/dist/extensions/google/test-api.d.ts +2 -2
  386. package/dist/extensions/google/thinking-api.d.ts +1 -1
  387. package/dist/extensions/google/thinking.d.ts +1 -1
  388. package/dist/extensions/google/transport-stream.d.ts +1 -1
  389. package/dist/extensions/gradium/index.d.ts +1 -1
  390. package/dist/extensions/gradium/speech-provider.d.ts +1 -1
  391. package/dist/extensions/groq/index.d.ts +1 -1
  392. package/dist/extensions/huggingface/index.d.ts +1 -1
  393. package/dist/extensions/image-generation-core/api.d.ts +4 -4
  394. package/dist/extensions/image-generation-core/runtime-api.d.ts +1 -1
  395. package/dist/extensions/imessage/api.d.ts +2 -2
  396. package/dist/extensions/imessage/api.js +2 -2
  397. package/dist/extensions/imessage/channel-plugin-api.d.ts +1 -1
  398. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  399. package/dist/extensions/imessage/index.d.ts +2 -2
  400. package/dist/extensions/imessage/message-tool-api.d.ts +1 -1
  401. package/dist/extensions/imessage/runtime-api.d.ts +5 -5
  402. package/dist/extensions/imessage/runtime-api.js +3 -3
  403. package/dist/extensions/imessage/setup-entry.d.ts +2 -2
  404. package/dist/extensions/imessage/test-api.d.ts +1 -1
  405. package/dist/extensions/inworld/index.d.ts +1 -1
  406. package/dist/extensions/inworld/speech-provider.d.ts +1 -1
  407. package/dist/extensions/irc/api.d.ts +1 -1
  408. package/dist/extensions/irc/api.js +2 -2
  409. package/dist/extensions/irc/channel-plugin-api.d.ts +1 -1
  410. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  411. package/dist/extensions/irc/index.d.ts +2 -2
  412. package/dist/extensions/irc/setup-entry.d.ts +2 -2
  413. package/dist/extensions/kilocode/index.d.ts +1 -1
  414. package/dist/extensions/kimi-coding/index.d.ts +1 -1
  415. package/dist/extensions/kimi-coding/stream.d.ts +1 -1
  416. package/dist/extensions/litellm/index.d.ts +1 -1
  417. package/dist/extensions/llm-task/api.d.ts +2 -2
  418. package/dist/extensions/llm-task/index.d.ts +1 -1
  419. package/dist/extensions/llm-task/index.js +1 -1
  420. package/dist/extensions/lmstudio/api.d.ts +1 -1
  421. package/dist/extensions/lmstudio/index.d.ts +1 -1
  422. package/dist/extensions/lmstudio/memory-embedding-adapter.d.ts +1 -1
  423. package/dist/extensions/mattermost/api.js +1 -1
  424. package/dist/extensions/mattermost/channel-plugin-api.d.ts +2 -2
  425. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  426. package/dist/extensions/mattermost/channel-plugin-runtime.d.ts +1 -1
  427. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  428. package/dist/extensions/mattermost/index.d.ts +2 -2
  429. package/dist/extensions/mattermost/policy-api.js +1 -1
  430. package/dist/extensions/mattermost/runtime-api.d.ts +10 -10
  431. package/dist/extensions/mattermost/runtime-api.js +2 -2
  432. package/dist/extensions/mattermost/setup-entry.d.ts +2 -2
  433. package/dist/extensions/mattermost/slash-route-api.d.ts +1 -1
  434. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  435. package/dist/extensions/memory-core/api.d.ts +1 -1
  436. package/dist/extensions/memory-core/cli-metadata.d.ts +1 -1
  437. package/dist/extensions/memory-core/cli-metadata.js +1 -1
  438. package/dist/extensions/memory-core/index.d.ts +1 -1
  439. package/dist/extensions/memory-core/manager-runtime.d.ts +1 -1
  440. package/dist/extensions/memory-core/runtime-api.d.ts +2 -2
  441. package/dist/extensions/memory-wiki/api.d.ts +3 -3
  442. package/dist/extensions/memory-wiki/cli-metadata.d.ts +1 -1
  443. package/dist/extensions/memory-wiki/index.d.ts +1 -1
  444. package/dist/extensions/memory-wiki/setup-api.d.ts +1 -1
  445. package/dist/extensions/microsoft/index.d.ts +1 -1
  446. package/dist/extensions/microsoft/speech-provider.d.ts +1 -1
  447. package/dist/extensions/microsoft/test-api.d.ts +1 -1
  448. package/dist/extensions/microsoft-foundry/auth.d.ts +1 -1
  449. package/dist/extensions/microsoft-foundry/cli.d.ts +1 -1
  450. package/dist/extensions/microsoft-foundry/index.d.ts +1 -1
  451. package/dist/extensions/microsoft-foundry/onboard.d.ts +3 -3
  452. package/dist/extensions/microsoft-foundry/provider.d.ts +1 -1
  453. package/dist/extensions/microsoft-foundry/runtime.d.ts +1 -1
  454. package/dist/extensions/microsoft-foundry/shared-runtime.d.ts +1 -1
  455. package/dist/extensions/microsoft-foundry/shared.d.ts +1 -1
  456. package/dist/extensions/migrate-claude/apply.d.ts +1 -1
  457. package/dist/extensions/migrate-claude/apply.js +1 -1
  458. package/dist/extensions/migrate-claude/config.d.ts +1 -1
  459. package/dist/extensions/migrate-claude/helpers.d.ts +1 -1
  460. package/dist/extensions/migrate-claude/index.d.ts +1 -1
  461. package/dist/extensions/migrate-claude/index.js +1 -1
  462. package/dist/extensions/migrate-claude/memory.d.ts +2 -2
  463. package/dist/extensions/migrate-claude/plan.d.ts +1 -1
  464. package/dist/extensions/migrate-claude/plan.js +1 -1
  465. package/dist/extensions/migrate-claude/provider.d.ts +1 -1
  466. package/dist/extensions/migrate-claude/provider.js +1 -1
  467. package/dist/extensions/migrate-claude/skills.d.ts +2 -2
  468. package/dist/extensions/migrate-claude/targets.d.ts +1 -1
  469. package/dist/extensions/migrate-claude/targets.js +1 -1
  470. package/dist/extensions/migrate-hermes/apply.d.ts +1 -1
  471. package/dist/extensions/migrate-hermes/apply.js +1 -1
  472. package/dist/extensions/migrate-hermes/config.d.ts +1 -1
  473. package/dist/extensions/migrate-hermes/helpers.d.ts +1 -1
  474. package/dist/extensions/migrate-hermes/index.d.ts +1 -1
  475. package/dist/extensions/migrate-hermes/index.js +1 -1
  476. package/dist/extensions/migrate-hermes/items.d.ts +1 -1
  477. package/dist/extensions/migrate-hermes/model.d.ts +1 -1
  478. package/dist/extensions/migrate-hermes/model.js +1 -1
  479. package/dist/extensions/migrate-hermes/plan.d.ts +1 -1
  480. package/dist/extensions/migrate-hermes/plan.js +1 -1
  481. package/dist/extensions/migrate-hermes/provider.d.ts +1 -1
  482. package/dist/extensions/migrate-hermes/provider.js +1 -1
  483. package/dist/extensions/migrate-hermes/secrets.d.ts +2 -2
  484. package/dist/extensions/migrate-hermes/secrets.js +1 -1
  485. package/dist/extensions/migrate-hermes/skills.d.ts +2 -2
  486. package/dist/extensions/migrate-hermes/targets.d.ts +1 -1
  487. package/dist/extensions/migrate-hermes/targets.js +1 -1
  488. package/dist/extensions/minimax/index.d.ts +1 -1
  489. package/dist/extensions/minimax/provider-contract-api.d.ts +1 -1
  490. package/dist/extensions/minimax/provider-registration.d.ts +1 -1
  491. package/dist/extensions/minimax/speech-provider.d.ts +1 -1
  492. package/dist/extensions/mistral/embedding-provider.d.ts +1 -1
  493. package/dist/extensions/mistral/index.d.ts +1 -1
  494. package/dist/extensions/mistral/memory-embedding-adapter.d.ts +1 -1
  495. package/dist/extensions/mistral/realtime-transcription-provider.d.ts +1 -1
  496. package/dist/extensions/mistral/test-api.d.ts +1 -1
  497. package/dist/extensions/moonshot/index.d.ts +1 -1
  498. package/dist/extensions/moonshot/provider-contract-api.d.ts +1 -1
  499. package/dist/extensions/moonshot/provider-discovery.d.ts +1 -1
  500. package/dist/extensions/nvidia/index.d.ts +1 -1
  501. package/dist/extensions/oc-path/cli-metadata.d.ts +1 -1
  502. package/dist/extensions/oc-path/cli-registration.d.ts +1 -1
  503. package/dist/extensions/oc-path/index.d.ts +1 -1
  504. package/dist/extensions/ollama/api.d.ts +1 -1
  505. package/dist/extensions/ollama/index.d.ts +1 -1
  506. package/dist/extensions/ollama/provider-discovery.d.ts +1 -1
  507. package/dist/extensions/ollama/provider-policy-api.d.ts +1 -1
  508. package/dist/extensions/ollama/runtime-api.d.ts +1 -1
  509. package/dist/extensions/open-prose/index.d.ts +1 -1
  510. package/dist/extensions/open-prose/runtime-api.d.ts +2 -2
  511. package/dist/extensions/openai/api.d.ts +4 -4
  512. package/dist/extensions/openai/embedding-batch.d.ts +1 -1
  513. package/dist/extensions/openai/embedding-provider.d.ts +1 -1
  514. package/dist/extensions/openai/index.d.ts +1 -1
  515. package/dist/extensions/openai/memory-embedding-adapter.d.ts +1 -1
  516. package/dist/extensions/openai/openai-codex-oauth.runtime.d.ts +1 -1
  517. package/dist/extensions/openai/openai-codex-provider.d.ts +1 -1
  518. package/dist/extensions/openai/openai-provider.d.ts +1 -1
  519. package/dist/extensions/openai/prompt-overlay.d.ts +1 -1
  520. package/dist/extensions/openai/provider-contract-api.d.ts +1 -1
  521. package/dist/extensions/openai/provider-policy-api.d.ts +1 -1
  522. package/dist/extensions/openai/realtime-transcription-provider.d.ts +1 -1
  523. package/dist/extensions/openai/realtime-voice-provider.d.ts +1 -1
  524. package/dist/extensions/openai/register.runtime.d.ts +6 -6
  525. package/dist/extensions/openai/replay-policy.d.ts +1 -1
  526. package/dist/extensions/openai/setup-api.d.ts +1 -1
  527. package/dist/extensions/openai/shared.d.ts +3 -3
  528. package/dist/extensions/openai/speech-provider.d.ts +1 -1
  529. package/dist/extensions/openai/test-api.d.ts +3 -3
  530. package/dist/extensions/openai/thinking-policy.d.ts +1 -1
  531. package/dist/extensions/openai/transport-policy.d.ts +1 -1
  532. package/dist/extensions/opencode/index.d.ts +1 -1
  533. package/dist/extensions/opencode/provider-policy-api.d.ts +1 -1
  534. package/dist/extensions/opencode-go/index.d.ts +1 -1
  535. package/dist/extensions/opencode-go/provider-catalog.d.ts +1 -1
  536. package/dist/extensions/opencode-go/stream.d.ts +1 -1
  537. package/dist/extensions/openrouter/api.d.ts +1 -1
  538. package/dist/extensions/openrouter/index.d.ts +1 -1
  539. package/dist/extensions/openrouter/provider-contract-api.d.ts +1 -1
  540. package/dist/extensions/openrouter/provider-policy-api.d.ts +1 -1
  541. package/dist/extensions/openrouter/speech-provider.d.ts +1 -1
  542. package/dist/extensions/openrouter/stream.d.ts +1 -1
  543. package/dist/extensions/openrouter/test-api.d.ts +1 -1
  544. package/dist/extensions/openrouter/thinking-policy.d.ts +1 -1
  545. package/dist/extensions/openrouter/video-generation-provider.d.ts +1 -1
  546. package/dist/extensions/openrouter/video-model-catalog.d.ts +1 -1
  547. package/dist/extensions/perplexity/index.d.ts +1 -1
  548. package/dist/extensions/phone-control/index.d.ts +1 -1
  549. package/dist/extensions/phone-control/runtime-api.d.ts +2 -2
  550. package/dist/extensions/policy/api.js +1 -1
  551. package/dist/extensions/policy/index.d.ts +1 -1
  552. package/dist/extensions/policy/index.js +2 -2
  553. package/dist/extensions/qianfan/index.d.ts +1 -1
  554. package/dist/extensions/qwen/api.d.ts +1 -1
  555. package/dist/extensions/qwen/index.d.ts +1 -1
  556. package/dist/extensions/qwen/stream.d.ts +1 -1
  557. package/dist/extensions/qwen-dashscope/index.d.ts +1 -1
  558. package/dist/extensions/runway/index.d.ts +1 -1
  559. package/dist/extensions/searxng/index.d.ts +1 -1
  560. package/dist/extensions/senseaudio/index.d.ts +1 -1
  561. package/dist/extensions/sglang/index.d.ts +1 -1
  562. package/dist/extensions/signal/api.d.ts +3 -3
  563. package/dist/extensions/signal/api.js +6 -6
  564. package/dist/extensions/signal/channel-entry.d.ts +2 -2
  565. package/dist/extensions/signal/channel-plugin-api.d.ts +1 -1
  566. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  567. package/dist/extensions/signal/index.d.ts +2 -2
  568. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  569. package/dist/extensions/signal/runtime-api.d.ts +8 -8
  570. package/dist/extensions/signal/runtime-api.js +7 -7
  571. package/dist/extensions/signal/setup-entry.d.ts +2 -2
  572. package/dist/extensions/skill-workshop/api.d.ts +2 -2
  573. package/dist/extensions/skill-workshop/api.js +1 -1
  574. package/dist/extensions/skill-workshop/index.d.ts +1 -1
  575. package/dist/extensions/skill-workshop/index.js +2 -2
  576. package/dist/extensions/speech-core/api.d.ts +3 -3
  577. package/dist/extensions/speech-core/runtime-api.d.ts +2 -2
  578. package/dist/extensions/stepfun/index.d.ts +1 -1
  579. package/dist/extensions/synthetic/index.d.ts +1 -1
  580. package/dist/extensions/talk-voice/api.d.ts +2 -2
  581. package/dist/extensions/talk-voice/index.d.ts +1 -1
  582. package/dist/extensions/tavily/index.d.ts +1 -1
  583. package/dist/extensions/telegram/account-inspect-api.js +1 -1
  584. package/dist/extensions/telegram/api.d.ts +5 -5
  585. package/dist/extensions/telegram/api.js +11 -11
  586. package/dist/extensions/telegram/channel-plugin-api.d.ts +2 -2
  587. package/dist/extensions/telegram/channel-plugin-api.js +2 -2
  588. package/dist/extensions/telegram/contract-api.d.ts +1 -1
  589. package/dist/extensions/telegram/contract-api.js +3 -3
  590. package/dist/extensions/telegram/index.d.ts +2 -2
  591. package/dist/extensions/telegram/runtime-api.d.ts +5 -5
  592. package/dist/extensions/telegram/runtime-api.js +7 -7
  593. package/dist/extensions/telegram/security-audit-contract-api.js +1 -1
  594. package/dist/extensions/telegram/setup-entry.d.ts +2 -2
  595. package/dist/extensions/telegram/setup-plugin-api.d.ts +1 -1
  596. package/dist/extensions/telegram/setup-plugin-api.js +1 -1
  597. package/dist/extensions/telegram/test-api.js +2 -2
  598. package/dist/extensions/tencent/index.d.ts +1 -1
  599. package/dist/extensions/tencent/provider-discovery.d.ts +1 -1
  600. package/dist/extensions/thread-ownership/api.d.ts +2 -2
  601. package/dist/extensions/thread-ownership/index.d.ts +1 -1
  602. package/dist/extensions/together/index.d.ts +1 -1
  603. package/dist/extensions/tokenjuice/index.d.ts +1 -1
  604. package/dist/extensions/tokenjuice/tool-result-middleware.d.ts +1 -1
  605. package/dist/extensions/tts-local-cli/index.d.ts +1 -1
  606. package/dist/extensions/tts-local-cli/speech-provider.d.ts +1 -1
  607. package/dist/extensions/venice/index.d.ts +1 -1
  608. package/dist/extensions/venice/stream.d.ts +1 -1
  609. package/dist/extensions/vercel-ai-gateway/index.d.ts +1 -1
  610. package/dist/extensions/vercel-ai-gateway/thinking.d.ts +1 -1
  611. package/dist/extensions/video-generation-core/api.d.ts +3 -3
  612. package/dist/extensions/video-generation-core/runtime-api.d.ts +1 -1
  613. package/dist/extensions/vllm/api.d.ts +1 -1
  614. package/dist/extensions/vllm/index.d.ts +1 -1
  615. package/dist/extensions/vllm/stream.d.ts +1 -1
  616. package/dist/extensions/volcengine/index.d.ts +1 -1
  617. package/dist/extensions/volcengine/provider-discovery.d.ts +1 -1
  618. package/dist/extensions/volcengine/speech-provider.d.ts +1 -1
  619. package/dist/extensions/voyage/embedding-batch.d.ts +1 -1
  620. package/dist/extensions/voyage/embedding-provider.d.ts +1 -1
  621. package/dist/extensions/voyage/index.d.ts +1 -1
  622. package/dist/extensions/voyage/memory-embedding-adapter.d.ts +1 -1
  623. package/dist/extensions/vydra/index.d.ts +1 -1
  624. package/dist/extensions/vydra/speech-provider.d.ts +1 -1
  625. package/dist/extensions/web-readability/index.d.ts +1 -1
  626. package/dist/extensions/webhooks/api.d.ts +2 -2
  627. package/dist/extensions/webhooks/api.js +1 -1
  628. package/dist/extensions/webhooks/index.d.ts +1 -1
  629. package/dist/extensions/webhooks/index.js +1 -1
  630. package/dist/extensions/webhooks/runtime-api.d.ts +2 -2
  631. package/dist/extensions/xai/api.d.ts +1 -1
  632. package/dist/extensions/xai/index.d.ts +1 -1
  633. package/dist/extensions/xai/index.js +4 -4
  634. package/dist/extensions/xai/provider-contract-api.d.ts +1 -1
  635. package/dist/extensions/xai/provider-discovery.d.ts +1 -1
  636. package/dist/extensions/xai/provider-models.d.ts +1 -1
  637. package/dist/extensions/xai/provider-policy-api.d.ts +1 -1
  638. package/dist/extensions/xai/realtime-transcription-provider.d.ts +1 -1
  639. package/dist/extensions/xai/realtime-transcription-provider.js +1 -1
  640. package/dist/extensions/xai/setup-api.d.ts +1 -1
  641. package/dist/extensions/xai/speech-provider.d.ts +1 -1
  642. package/dist/extensions/xai/speech-provider.js +1 -1
  643. package/dist/extensions/xai/stream.d.ts +1 -1
  644. package/dist/extensions/xai/test-api.js +1 -1
  645. package/dist/extensions/xai/tts.js +1 -1
  646. package/dist/extensions/xai/web-search.js +1 -1
  647. package/dist/extensions/xai/xai-oauth.d.ts +1 -1
  648. package/dist/extensions/xai/xai-oauth.js +1 -1
  649. package/dist/extensions/xiaomi/index.d.ts +1 -1
  650. package/dist/extensions/xiaomi/speech-provider.d.ts +1 -1
  651. package/dist/extensions/xiaomi/stream.d.ts +1 -1
  652. package/dist/extensions/xiaomi/thinking.d.ts +1 -1
  653. package/dist/extensions/zai/index.d.ts +1 -1
  654. package/dist/file-fetch-tool-QFQ7QZQ9.js +124 -0
  655. package/dist/file-write-tool-znIJ5MOE.js +127 -0
  656. package/dist/format-B3nq4sfa.js +1145 -0
  657. package/dist/gateway/protocol/index.d.ts +1 -1
  658. package/dist/gateway-cli-D5nQafQi.js +435 -0
  659. package/dist/gateway-method-runtime-BXmOAMxN.js +21 -0
  660. package/dist/gateway-runtime-BRfyNjsE.d.ts +163 -0
  661. package/dist/gemini-cli-provider-2RAshvHZ.d.ts +6 -0
  662. package/dist/get-reply-DZK53szF.js +4689 -0
  663. package/dist/get-reply-from-config.runtime-Kx4GwLAA.js +2 -0
  664. package/dist/get-reply-from-config.runtime.js +1 -1
  665. package/dist/graph-users-CNpoBMLI.js +1419 -0
  666. package/dist/group-access-B-lpiIoP.js +112 -0
  667. package/dist/handle-action.guild-admin-D7AInszH.js +288 -0
  668. package/dist/harness-BPTKe2TG.js +61 -0
  669. package/dist/health-BkXVkm2H.js +4 -0
  670. package/dist/heartbeat-runner-Dbddl21A.js +5 -0
  671. package/dist/heartbeat-runner.runtime-CDmb7D-Q.js +4 -0
  672. package/dist/heartbeat-runner.runtime.js +1 -1
  673. package/dist/hook-runtime-BBONf8H3.d.ts +108 -0
  674. package/dist/hooks-90WH7Tva.js +534 -0
  675. package/dist/http-registry-DydRvucX.d.ts +23 -0
  676. package/dist/image-generation-runtime-CYSxJAy2.d.ts +21 -0
  677. package/dist/inbound-direct-dm-runtime-bXneq4t0.js +2 -0
  678. package/dist/inbound-reply-dispatch-BVzOSvZX.js +148 -0
  679. package/dist/index-BFhfE749.d.ts +3971 -0
  680. package/dist/index.d.ts +1 -1
  681. package/dist/index.js +1 -1
  682. package/dist/init-DWgLcXq7.js +59 -0
  683. package/dist/inline-buttons-DtcEDZIV.js +40 -0
  684. package/dist/interactive-dispatch-CNUK2pZt.d.ts +56 -0
  685. package/dist/interactive-dispatch-DuuOPzwD.d.ts +143 -0
  686. package/dist/internal-events-D3SdlwzM.js +90 -0
  687. package/dist/isolated-agent-B9qCvLC4.js +1118 -0
  688. package/dist/isolated-agent-DaBWyrzI.js +2 -0
  689. package/dist/lifecycle-CfcTMzLT.js +571 -0
  690. package/dist/list.probe-aXBUfusA.js +449 -0
  691. package/dist/list.status-command-xrFMny0R.js +789 -0
  692. package/dist/llm-slug-generator-D5FE5osT.js +78 -0
  693. package/dist/llm-slug-generator.js +1 -1
  694. package/dist/loader-BKopCdPY.d.ts +142 -0
  695. package/dist/local-dispatch.runtime-0dOK_rcW.js +9 -0
  696. package/dist/local-dispatch.runtime.js +1 -1
  697. package/dist/manager-BrS--u6G.d.ts +356 -0
  698. package/dist/manager-DWN3qo90.d.ts +10 -0
  699. package/dist/manager.core-BRd2_lqA.d.ts +198 -0
  700. package/dist/manager.runtime-pUdntZ2i.js +2714 -0
  701. package/dist/manager.runtime.js +1 -1
  702. package/dist/markdown-to-line-Cv0Gm132.js +811 -0
  703. package/dist/mcp-http-CaliRokB.js +555 -0
  704. package/dist/mcp-http-Dgcmuypw.js +2 -0
  705. package/dist/media-understanding-provider-Cu7iRaWL.js +339 -0
  706. package/dist/memory-core-host-engine-storage-DsNomsw4.d.ts +54 -0
  707. package/dist/memory-embedding-adapter-Ba-UYpWr.d.ts +5 -0
  708. package/dist/message-actions-BBiWyHuJ.js +145 -0
  709. package/dist/message-handler-VnxCCjy7.js +384 -0
  710. package/dist/message-handler-dNRhdkX3.js +1715 -0
  711. package/dist/message-handler.preflight-CREgYCNj.js +1125 -0
  712. package/dist/message-handler.process-DN93vvas.js +1484 -0
  713. package/dist/migration-DOuQeJ7P.d.ts +45 -0
  714. package/dist/model-Bp-W7fVB.js +74 -0
  715. package/dist/model-eEpAu59T.d.ts +33 -0
  716. package/dist/model-selection-CXTwfi0m.js +272 -0
  717. package/dist/models-BF1vdgHr.js +2 -0
  718. package/dist/models-DepHj1G3.d.ts +24 -0
  719. package/dist/models-DvbokHz4.js +104 -0
  720. package/dist/models-cli-B_zT7frv.js +256 -0
  721. package/dist/monitor-BoW4qfGV.js +834 -0
  722. package/dist/monitor-Bs8KSKu7.js +60 -0
  723. package/dist/monitor-DHgHadUx.js +1370 -0
  724. package/dist/monitor-DX7Ya0rb.js +715 -0
  725. package/dist/monitor-DlzBuqhN.js +2788 -0
  726. package/dist/monitor-DnzcdtYh.js +1657 -0
  727. package/dist/monitor-DwwFCaSy.js +4377 -0
  728. package/dist/monitor-auth-BRF9yj8s.js +179 -0
  729. package/dist/monitor-m5zwJU51.js +2 -0
  730. package/dist/monitor-polling.runtime-DXMM7v9c.js +883 -0
  731. package/dist/monitor-polling.runtime.js +1 -1
  732. package/dist/monitor-webhook.runtime-vNDAo7Yq.js +387 -0
  733. package/dist/monitor-webhook.runtime.js +1 -1
  734. package/dist/monitor.account-DT1JC2fm.js +5233 -0
  735. package/dist/monitor.runtime-BUw4UbJN.js +2 -0
  736. package/dist/monitor.runtime.js +1 -1
  737. package/dist/monitor.webhook-IBx7ZFi4.js +180 -0
  738. package/dist/node-cli-sessions-BJW0oB3s.js +1228 -0
  739. package/dist/openai-codex-provider-LwMbKOK1.d.ts +5 -0
  740. package/dist/openai-http-BX-DFq23.js +824 -0
  741. package/dist/openai-provider-F0nEHs4l.d.ts +5 -0
  742. package/dist/openresponses-http-BN6ztKxO.js +1173 -0
  743. package/dist/operations-DmaD-gxv.js +805 -0
  744. package/dist/outbound-adapter-v9Q4K2Bl.js +543 -0
  745. package/dist/outbound-session-route-BxhErAps.js +45 -0
  746. package/dist/outbound.runtime-ClUOK-Ir.js +2 -0
  747. package/dist/outbound.runtime.js +1 -1
  748. package/dist/pairing-store-Cfy_zHzi.d.ts +87 -0
  749. package/dist/pi-embedded-CG0u988w.js +4 -0
  750. package/dist/pi-embedded-D7UoOQFj.js +3796 -0
  751. package/dist/pi-embedded.runtime-CKNVJdm9.js +4 -0
  752. package/dist/pi-embedded.runtime.js +1 -1
  753. package/dist/pi-tools-DP7eGHq-.js +2413 -0
  754. package/dist/plan-BD5JNOvV.js +81 -0
  755. package/dist/plan-BSDlELnX.js +112 -0
  756. package/dist/plugin-4bygXnMD.js +12396 -0
  757. package/dist/plugin-BW5kVZrl.d.ts +17 -0
  758. package/dist/plugin-app-cache-key-BfaJYLXl.js +46 -0
  759. package/dist/plugin-enabled-44kWBMek.js +233 -0
  760. package/dist/plugin-entry-oVFfOYI7.d.ts +47 -0
  761. package/dist/plugin-registration-DoD5ARyg.js +88 -0
  762. package/dist/plugin-runtime-Bx8TuYU5.d.ts +117 -0
  763. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  764. package/dist/plugin-sdk/acp-runtime-backend.js +1 -1
  765. package/dist/plugin-sdk/acp-runtime.js +2 -2
  766. package/dist/plugin-sdk/agent-harness-runtime.js +6 -6
  767. package/dist/plugin-sdk/agent-harness-task-runtime.js +1 -1
  768. package/dist/plugin-sdk/agent-harness.js +7 -7
  769. package/dist/plugin-sdk/agent-runtime.js +2 -2
  770. package/dist/plugin-sdk/channel-core.js +2 -2
  771. package/dist/plugin-sdk/channel-inbound.js +2 -2
  772. package/dist/plugin-sdk/channel-test-helpers.js +1 -1
  773. package/dist/plugin-sdk/command-auth.js +1 -1
  774. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  775. package/dist/plugin-sdk/compat.js +1 -1
  776. package/dist/plugin-sdk/conversation-binding-runtime.js +2 -2
  777. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  778. package/dist/plugin-sdk/core.js +2 -2
  779. package/dist/plugin-sdk/direct-dm.js +1 -1
  780. package/dist/plugin-sdk/gateway-method-runtime.js +1 -1
  781. package/dist/plugin-sdk/health.js +2 -2
  782. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  783. package/dist/plugin-sdk/index.js +1 -1
  784. package/dist/plugin-sdk/mattermost.js +1 -1
  785. package/dist/plugin-sdk/plugin-test-contracts.js +2 -2
  786. package/dist/plugin-sdk/provider-test-contracts.js +4 -4
  787. package/dist/plugin-sdk/reply-runtime.js +4 -4
  788. package/dist/plugin-sdk/src/commands/doctor.types.d.ts +0 -1
  789. package/dist/plugin-sdk/src/compat/legacy-names.d.ts +1 -1
  790. package/dist/plugin-sdk/src/plugins/manifest.d.ts +1 -1
  791. package/dist/plugin-sdk/testing.js +2 -2
  792. package/dist/plugin-sdk/zalouser.js +1 -1
  793. package/dist/plugin-service-CJqwjPRa.js +1229 -0
  794. package/dist/plugin-service-W6IMgQjk.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-C2YDmnm2.js +138 -0
  801. package/dist/policy-CYBwtJmM.js +680 -0
  802. package/dist/prepare.runtime-B9SQyzSp.js +732 -0
  803. package/dist/prepare.runtime.js +1 -1
  804. package/dist/preview-warnings-DkMoGKdo.js +392 -0
  805. package/dist/probe-BYucGf4s.js +682 -0
  806. package/dist/probe-D8YoJ89r.js +2204 -0
  807. package/dist/probe-DKinNcah.js +47 -0
  808. package/dist/probe-DSYRrw81.js +2 -0
  809. package/dist/program-MtNU1_sG.js +131 -0
  810. package/dist/prompt-overlay-CaXYKmjI.d.ts +23 -0
  811. package/dist/provider-26ZZeAkw.js +32 -0
  812. package/dist/provider-BtNK1WFZ.js +8735 -0
  813. package/dist/provider-CfJzlnOm.js +32 -0
  814. package/dist/provider-Dl-E4_a8.js +152 -0
  815. package/dist/provider-api-key-auth-DOu4GJBt.d.ts +27 -0
  816. package/dist/provider-auth-result-CO9yqIJ_.d.ts +21 -0
  817. package/dist/provider-catalog-runtime-f_87intf.d.ts +23 -0
  818. package/dist/provider-catalog-shared-CXZnqdym.d.ts +62 -0
  819. package/dist/provider-dispatcher-CAaa54DQ.js +22 -0
  820. package/dist/provider-dispatcher.runtime.js +1 -1
  821. package/dist/provider-hook-runtime-o2J0hqhZ.d.ts +61 -0
  822. package/dist/provider-model-shared-CsZtXE0W.d.ts +143 -0
  823. package/dist/provider-models-BbjvK4gF.d.ts +12 -0
  824. package/dist/provider-policy-BwZykYqb.d.ts +30 -0
  825. package/dist/provider-registration-CytP1d9Y.d.ts +6 -0
  826. package/dist/provider-registry-Ct1dA5S3.d.ts +8 -0
  827. package/dist/provider-registry-DgEFqiK2.d.ts +30 -0
  828. package/dist/provider-registry-Dilmwbu_.d.ts +8 -0
  829. package/dist/provider-runtime-ChO01VYW.d.ts +359 -0
  830. package/dist/provider-self-hosted-setup-DCeKR5ZH.d.ts +74 -0
  831. package/dist/provider-session.runtime-DDMGL25I.js +9 -0
  832. package/dist/provider-session.runtime.js +1 -1
  833. package/dist/provider-stream-CrWY0s8C.d.ts +140 -0
  834. package/dist/provider-stream-shared-CgnrFxMf.d.ts +128 -0
  835. package/dist/provider.runtime-CUdlREry.js +2 -0
  836. package/dist/provider.runtime.js +1 -1
  837. package/dist/providers.runtime-CiX4UePR.d.ts +25 -0
  838. package/dist/public-surface-loader-iYUvHxzC.js +114 -0
  839. package/dist/pw-ai-DQjpZTSa.js +3029 -0
  840. package/dist/pw-role-snapshot-DgavoGdC.js +333 -0
  841. package/dist/reaction-level-uiCaLj0m.js +19 -0
  842. package/dist/reaction-runtime-api-ErmZKqXv.js +116 -0
  843. package/dist/realtime-transcription-abdbHd8R.d.ts +43 -0
  844. package/dist/realtime-transcription-provider-CPK7XYp9.d.ts +5 -0
  845. package/dist/realtime-transcription-provider-DC2AscwX.d.ts +32 -0
  846. package/dist/realtime-transcription-provider-Dg5t03mY.d.ts +28 -0
  847. package/dist/realtime-transcription-provider-UesXbEwy.d.ts +37 -0
  848. package/dist/realtime-transcription-provider-tLRMgcYk.js +205 -0
  849. package/dist/realtime-voice-D1aiUBBt.d.ts +333 -0
  850. package/dist/realtime-voice-provider-D5DZsLRA.d.ts +5 -0
  851. package/dist/register-DxldPhbz.js +2178 -0
  852. package/dist/register.agent-B9171wFk.js +156 -0
  853. package/dist/register.crestodian-plvra03q.js +24 -0
  854. package/dist/register.maintenance-BLH-PhXR.js +105 -0
  855. package/dist/register.runtime-CAW8ORTZ.d.ts +6 -0
  856. package/dist/register.runtime-CnuNQn65.js +54 -0
  857. package/dist/register.subclis-C9TqTF1g.js +3 -0
  858. package/dist/register.subclis-core-B4RLAWNE.js +273 -0
  859. package/dist/register.subclis-zvycA0fS.js +31 -0
  860. package/dist/registry-paAkM8At.d.ts +91 -0
  861. package/dist/registry-types-DSJvRhBP.d.ts +392 -0
  862. package/dist/repair-sequencing-3Q95ftKn.js +640 -0
  863. package/dist/reply-delivery-BYtyofYM.js +196 -0
  864. package/dist/reply-runtime-DUv2dRp3.d.ts +34 -0
  865. package/dist/reply-runtime-P6EiRGYz.js +11 -0
  866. package/dist/reply.runtime-Kx4GwLAA.js +2 -0
  867. package/dist/reply.runtime.js +1 -1
  868. package/dist/request-B8_J1Hk5.js +54 -0
  869. package/dist/resolve-allowlist-BHhr7pGG.js +220 -0
  870. package/dist/result-fallback-classifier-v1BgnJLN.js +79 -0
  871. package/dist/route-Dl0ZJvrW.js +469 -0
  872. package/dist/route-resolution-mVRyzqn_.js +274 -0
  873. package/dist/routes-B8uiTXHO.js +3602 -0
  874. package/dist/routes-Bjw1nWyB.js +2 -0
  875. package/dist/run-attempt-DKRsY7Xs.js +7704 -0
  876. package/dist/run-command-Bs2y31Ew.js +2 -0
  877. package/dist/run-command-CBDF_cGB.js +23 -0
  878. package/dist/run-embedded.runtime-2GWQN_Qf.js +4 -0
  879. package/dist/run-embedded.runtime.js +1 -1
  880. package/dist/run-execution-cli.runtime-BEXMdwL2.js +4 -0
  881. package/dist/run-execution-cli.runtime.js +1 -1
  882. package/dist/run-executor.runtime.js +1 -1
  883. package/dist/run-rMTtvEMF.js +1163 -0
  884. package/dist/run-subagent-registry.runtime-CBmgh09W.js +2 -0
  885. package/dist/run-subagent-registry.runtime.js +1 -1
  886. package/dist/runtime-D21vC5Bd.d.ts +17 -0
  887. package/dist/runtime-DFBt4ZZw.js +1287 -0
  888. package/dist/runtime-DQV1yYF5.js +6179 -0
  889. package/dist/runtime-api-B6S-7TVS.js +3 -0
  890. package/dist/runtime-api-BLV9PO47.js +24 -0
  891. package/dist/runtime-api-BX1AvShq.js +17 -0
  892. package/dist/runtime-api-BnN22IWf.js +13 -0
  893. package/dist/runtime-api-BsmZgGnI.js +21 -0
  894. package/dist/runtime-api-CJ6x4Uuu.js +13 -0
  895. package/dist/runtime-api-DTdQMFV-.d.ts +3151 -0
  896. package/dist/runtime-api-DXCKXAYu.js +4 -0
  897. package/dist/runtime-api.actions-C9Jtoruo.js +3 -0
  898. package/dist/runtime-api.actions-CClxRuYx.d.ts +23 -0
  899. package/dist/runtime-api.monitor-slWfxEgT.js +6 -0
  900. package/dist/runtime-api.send-D_auPJG_.js +4 -0
  901. package/dist/runtime-api.send-wXeDllRu.d.ts +38 -0
  902. package/dist/runtime-api.threads-BWzc1vrN.js +2 -0
  903. package/dist/runtime-channel-BOnbxldg.js +2 -0
  904. package/dist/runtime-channel-Dh45Bl_Q.js +150 -0
  905. package/dist/runtime-doctor-DVYwKwIT.d.ts +47 -0
  906. package/dist/runtime-embedded-pi.runtime-BVjCGIqB.js +2 -0
  907. package/dist/runtime-embedded-pi.runtime.js +1 -1
  908. package/dist/runtime-hYOWxRKE.js +438 -0
  909. package/dist/runtime-taskflow-BYZsMg1i.d.ts +435 -0
  910. package/dist/sanitize-outbound-CP-twYgG.js +127 -0
  911. package/dist/sdk-setup-tools-Cfh-ATXD.js +8 -0
  912. package/dist/secrets-DcQ7WBB-.js +113 -0
  913. package/dist/security-audit-CwMh7ULQ.js +118 -0
  914. package/dist/security-audit-yRC5cfp1.js +122 -0
  915. package/dist/security-audit.runtime-COitYvaV.js +2 -0
  916. package/dist/security-audit.runtime.js +1 -1
  917. package/dist/selection-C_swgArS.js +3 -0
  918. package/dist/selection-Cud_xC6-.js +16157 -0
  919. package/dist/send-BXTj6QIe.js +143 -0
  920. package/dist/send-Be-rQ3Py.js +1631 -0
  921. package/dist/send-D95RJNJM.d.ts +104 -0
  922. package/dist/send-DZ4YhPHH.d.ts +231 -0
  923. package/dist/send-DrSo2pTm.js +192 -0
  924. package/dist/send-un_jKNYG.js +2 -0
  925. package/dist/send.components-C0ugXCvj.js +500 -0
  926. package/dist/send.components-CaHcQCve.js +2 -0
  927. package/dist/send.runtime-CcGjdPIe.js +2 -0
  928. package/dist/send.runtime.js +1 -1
  929. package/dist/send.types-_f4omMzG.d.ts +159 -0
  930. package/dist/server-Belw8J0P.js +24 -0
  931. package/dist/server-CbbbWl0g.js +73 -0
  932. package/dist/server-close.runtime.d.ts +1 -1
  933. package/dist/server-close.runtime.js +1 -1
  934. package/dist/server-context-D5PPz4pG.js +955 -0
  935. package/dist/server-context-DfiZrO39.js +2 -0
  936. package/dist/server-cron-B4uqojsc.js +2989 -0
  937. package/dist/server-cron-D5ofhC2R.js +2 -0
  938. package/dist/server-methods-BtrFcSCY.js +16499 -0
  939. package/dist/server-node-events-B7f6W47S.js +596 -0
  940. package/dist/server-plugin-bootstrap-CldF7ied.js +70 -0
  941. package/dist/server-plugins-BVVgDSdq.d.ts +1 -0
  942. package/dist/server-plugins-BkRL48_Y.js +432 -0
  943. package/dist/server-reload-handlers-CmD463eg.js +714 -0
  944. package/dist/server-restart-sentinel-1-GltJOW.js +2 -0
  945. package/dist/server-restart-sentinel-BAc6ad7u.js +747 -0
  946. package/dist/server-runtime-services-DdDWPwwJ.js +2 -0
  947. package/dist/server-runtime-services-q4vtzdgR.js +267 -0
  948. package/dist/server-startup-plugins-RDIvIW1b.js +113 -0
  949. package/dist/server-startup-post-attach-B-Bcz1b8.js +716 -0
  950. package/dist/server-ws-runtime-ClfNa1gj.js +349 -0
  951. package/dist/server.impl-5A5eWz1g.js +2587 -0
  952. package/dist/service-BIi_LAz_.js +1446 -0
  953. package/dist/session-binding-DxgaaGZ8.js +219 -0
  954. package/dist/session-binding-SoSof-ir.js +2 -0
  955. package/dist/session-kill-http-CpA7WXXP.js +121 -0
  956. package/dist/session-reset-service-MBceWYbr.js +625 -0
  957. package/dist/session-route-SMerc1ZF.js +93 -0
  958. package/dist/session-status.runtime-C1MOnm-1.js +2 -0
  959. package/dist/session-status.runtime.js +1 -1
  960. package/dist/session-subagent-reactivation.runtime-Cca41-p8.js +2 -0
  961. package/dist/session-subagent-reactivation.runtime.js +1 -1
  962. package/dist/session-tab-registry-BL8A9tMR.js +521 -0
  963. package/dist/sessions-history-http-Cb21uPHU.js +430 -0
  964. package/dist/sessions.runtime-ClHkmNrd.js +2 -0
  965. package/dist/sessions.runtime.js +1 -1
  966. package/dist/setup-api-CwKuO7ZG.js +29 -0
  967. package/dist/setup-core-C8_XbMIV.js +174 -0
  968. package/dist/setup-surface-B3m7rAoM.js +405 -0
  969. package/dist/setup-surface-BstaBVou.js +320 -0
  970. package/dist/setup-surface-C5L8UmIu.js +221 -0
  971. package/dist/setup-surface-DwijXcOh.js +288 -0
  972. package/dist/shared-DdLk0hA6.d.ts +115 -0
  973. package/dist/shared-DemthgnG.js +121 -0
  974. package/dist/shared-client-CLvetNfK.js +2 -0
  975. package/dist/shared-client-CR88Qth4.js +629 -0
  976. package/dist/side-question-BKRlgFVG.js +683 -0
  977. package/dist/simple-completion-runtime-D3vYpwbZ.d.ts +73 -0
  978. package/dist/skill-tool-dispatch.runtime-Bsz4SNiK.js +143 -0
  979. package/dist/skill-tool-dispatch.runtime.js +1 -1
  980. package/dist/slash-state-Cbb2tkH9.js +2166 -0
  981. package/dist/speech-Cf7RmLix.d.ts +47 -0
  982. package/dist/speech-core-BWd27MY5.d.ts +36 -0
  983. package/dist/speech-provider-Csdu9pW1.d.ts +5 -0
  984. package/dist/speech-provider-D4v4Jv2s.d.ts +34 -0
  985. package/dist/speech-provider-Dj7nG9do.d.ts +5 -0
  986. package/dist/speech-provider-DnyUKHSU.d.ts +5 -0
  987. package/dist/speech-provider-MoJPg1gB.d.ts +8 -0
  988. package/dist/speech-provider-hT52upCX.d.ts +8 -0
  989. package/dist/speech-provider-hqhi426N.js +184 -0
  990. package/dist/src-wxYdKry6.js +4256 -0
  991. package/dist/startup-context-CidK9XK8.js +313 -0
  992. package/dist/status-subagents.runtime-DgYNfrbK.js +18 -0
  993. package/dist/status-subagents.runtime.js +1 -1
  994. package/dist/status-text-w43pGoDJ.js +296 -0
  995. package/dist/sticker-cache-BdIkkDGC.js +206 -0
  996. package/dist/sticker-vision.runtime-bmccn4BW.js +17 -0
  997. package/dist/sticker-vision.runtime.js +1 -1
  998. package/dist/stream-BVr9Y5Fk.d.ts +19 -0
  999. package/dist/stream-C5ugQLbM.d.ts +10 -0
  1000. package/dist/stream-CDDV9-Wq.d.ts +5 -0
  1001. package/dist/stream-D3ZhJVM7.d.ts +16 -0
  1002. package/dist/stream-Dhh55ncO.d.ts +120 -0
  1003. package/dist/stream-wrappers-PZu4IPG2.d.ts +21 -0
  1004. package/dist/subagent-announce-Cig5R7bU.js +354 -0
  1005. package/dist/subagent-announce-delivery-DElem-jW.js +958 -0
  1006. package/dist/subagent-control-Dx1qbt2M.js +508 -0
  1007. package/dist/subagent-hooks-03ne_B1P.js +2 -0
  1008. package/dist/subagent-hooks-BW4tdl1N.js +116 -0
  1009. package/dist/subagent-hooks-BdADgqQH.js +2 -0
  1010. package/dist/subagent-hooks-D5ZUfS0C.js +146 -0
  1011. package/dist/subagent-hooks-DKEWsBSa.js +230 -0
  1012. package/dist/subagent-hooks-api-BNJpIv9Q.js +23 -0
  1013. package/dist/subagent-hooks-api-BXE-a9iQ.js +22 -0
  1014. package/dist/subagent-hooks-api-w7wOpXSR.js +23 -0
  1015. package/dist/subagent-hooks-kf263oYw.js +2 -0
  1016. package/dist/subagent-orphan-recovery-TGLIuI1K.js +352 -0
  1017. package/dist/subagent-registry-BVVgDSdq.d.ts +1 -0
  1018. package/dist/subagent-registry-Bai39rEv.js +3 -0
  1019. package/dist/subagent-registry-read-BVVgDSdq.d.ts +1 -0
  1020. package/dist/subagent-registry-vgjMT_I1.js +2351 -0
  1021. package/dist/subagent-registry.runtime.js +1 -1
  1022. package/dist/subagent-session-cleanup-PEEQtuLS.js +525 -0
  1023. package/dist/subagent-spawn-2TTDQg5Y.js +1164 -0
  1024. package/dist/target-id-BgSzF2Lk.js +107 -0
  1025. package/dist/targets-Bd9-WGJt.js +19 -0
  1026. package/dist/targets-CdiGPFGr.d.ts +10 -0
  1027. package/dist/targets-DxKwMzNB.js +44 -0
  1028. package/dist/targets-DzdYRUSR.js +19 -0
  1029. package/dist/targets-ZJ1ZRt5L.d.ts +10 -0
  1030. package/dist/task-registry-control.runtime.d.ts +1 -1
  1031. package/dist/task-registry-control.runtime.js +1 -1
  1032. package/dist/telegram/token.js +1 -1
  1033. package/dist/test-fixtures-xgg7UsEw.d.ts +27 -0
  1034. package/dist/test-support-BVVgDSdq.d.ts +1 -0
  1035. package/dist/testing-B6jLjq4r.js +267 -0
  1036. package/dist/thinking-policy-CAsew9b-.d.ts +5 -0
  1037. package/dist/thread-bindings-BumrOVO8.js +571 -0
  1038. package/dist/thread-bindings-C4yc8CZT.js +228 -0
  1039. package/dist/thread-bindings-Dkeit03N.js +8 -0
  1040. package/dist/thread-bindings-FVOv7g2T.js +232 -0
  1041. package/dist/thread-bindings.discord-api-D83vw86t.js +187 -0
  1042. package/dist/thread-bindings.manager-DEqfX4rc.js +2 -0
  1043. package/dist/thread-bindings.manager-LOMmQ1pN.js +536 -0
  1044. package/dist/thread-lifecycle-CGFgul5c.js +1614 -0
  1045. package/dist/token-CoB7XxKt.js +134 -0
  1046. package/dist/tool-CIfIAkxV.js +139 -0
  1047. package/dist/tool-actions.runtime-BrVxKuRd.js +534 -0
  1048. package/dist/tool-actions.runtime.js +1 -1
  1049. package/dist/tool-plugin-B18esZUX.d.ts +77 -0
  1050. package/dist/tool-resolution-BWdOXsX0.js +149 -0
  1051. package/dist/tool-split-_O9ZqSIU.d.ts +19 -0
  1052. package/dist/tools-effective-inventory-CW8_FJBN.js +204 -0
  1053. package/dist/tools-invoke-http-CYJCHpxL.js +67 -0
  1054. package/dist/tools-invoke-shared-SnaEXvuz.js +200 -0
  1055. package/dist/transport-stream-Piw1coFu.d.ts +42 -0
  1056. package/dist/tts-5p3qPz-P.js +66 -0
  1057. package/dist/tui-BYTSFA_c.js +4709 -0
  1058. package/dist/tui-LOGspKbe.js +2 -0
  1059. package/dist/tui-backend-C8nbqNLo.js +256 -0
  1060. package/dist/tui-cli-C91LywYY.js +37 -0
  1061. package/dist/typed-cases-v8PtmO3g.d.ts +68 -0
  1062. package/dist/types--mFsqUEV.d.ts +786 -0
  1063. package/dist/types-CcjGrBF52.d.ts +3650 -0
  1064. package/dist/types.public-rJrhXChy.d.ts +70 -0
  1065. package/dist/update-cli-DZuYe1aX.js +3665 -0
  1066. package/dist/update-global-ucSOAIga.js +606 -0
  1067. package/dist/update-runner-2pS-KlSn.js +1798 -0
  1068. package/dist/video-generation-runtime-CA2LiNwu.d.ts +21 -0
  1069. package/dist/video-model-catalog-BJ9GJKrw.d.ts +16 -0
  1070. package/dist/vision-tools-mJMJD3Yw.js +1409 -0
  1071. package/dist/web-search-BZgc3DQT.js +62 -0
  1072. package/dist/web-search-provider.runtime-BgoF9yna.js +328 -0
  1073. package/dist/web-search-provider.runtime-D1lmfAbp.js +2 -0
  1074. package/dist/web-search-provider.runtime.js +1 -1
  1075. package/dist/webhook-targets-B_syT8-q.d.ts +99 -0
  1076. package/dist/xai-oauth-B-LPhpsk.js +479 -0
  1077. package/dist/xai-user-agent-B0F4Hyt5.js +32 -0
  1078. package/dist/zod-schema.core-Bwbyyd_y.d.ts +166 -0
  1079. package/npm-shrinkwrap.json +2 -2
  1080. package/package.json +1 -1
  1081. package/dist/abort-BtS5AfJG.js +0 -277
  1082. package/dist/abort.runtime-D211494J.js +0 -2
  1083. package/dist/account-inspect-BqAxH1Q_.js +0 -173
  1084. package/dist/accounts-2VYKksau.js +0 -107
  1085. package/dist/accounts-B6aVCtty.js +0 -119
  1086. package/dist/accounts-CE6mvWMC.js +0 -2
  1087. package/dist/accounts-eprn8x0M.js +0 -107
  1088. package/dist/acp-runtime-C_0NA0CS.js +0 -26
  1089. package/dist/acp-spawn-CTmucfK5.js +0 -2
  1090. package/dist/acp-spawn-DcTgPZQB.js +0 -1275
  1091. package/dist/acp-stateful-target-driver-DVWNxIEX.js +0 -89
  1092. package/dist/action-kill-C6NRFglx.js +0 -33
  1093. package/dist/action-runtime-BaKOu7uV.js +0 -469
  1094. package/dist/action-runtime-api-QC43ZgvC.js +0 -2
  1095. package/dist/action-send-B790BH2g.js +0 -39
  1096. package/dist/action-spawn-Dgf97JGp.js +0 -47
  1097. package/dist/actions-DhY0Hqxd.js +0 -161
  1098. package/dist/actions.runtime-BfdjoY4f.js +0 -5
  1099. package/dist/agent-C1VC8waN.js +0 -3
  1100. package/dist/agent-DuLat04d.js +0 -2
  1101. package/dist/agent-command-BQ2JuYpP.js +0 -1367
  1102. package/dist/agent-command-COFQwKxZ.d.ts +0 -141
  1103. package/dist/agent-components.runtime-BskyK1iq.js +0 -10
  1104. package/dist/agent-harness-WlBoSv-g.d.ts +0 -146
  1105. package/dist/agent-harness-runtime-CsWVHhWd.d.ts +0 -691
  1106. package/dist/agent-harness-runtime-l4d66klL.js +0 -180
  1107. package/dist/agent-harness-task-runtime-D5vhG7mw.js +0 -140
  1108. package/dist/agent-runner-execution-DKJ7YE9g.js +0 -1713
  1109. package/dist/agent-runner-utils-BOJEvwHI.js +0 -266
  1110. package/dist/agent-runner.runtime-BAC7XlZX.js +0 -3455
  1111. package/dist/agent-runtime-D8J3kngS.js +0 -229
  1112. package/dist/agent-via-gateway-BPZeOgET.js +0 -463
  1113. package/dist/api-2J3KsQlI.js +0 -2
  1114. package/dist/api-BNZFdrOx.js +0 -639
  1115. package/dist/api-CQY8p5l4.js +0 -134
  1116. package/dist/api-CdIYfiOh.js +0 -3
  1117. package/dist/api-D5uGvU4G.d.ts +0 -52
  1118. package/dist/api-DaLfnqrr.js +0 -2
  1119. package/dist/api-DzpDMEqm.js +0 -6
  1120. package/dist/apply-DTkOJDSZ.js +0 -54
  1121. package/dist/apply-DY6Ov6qF.js +0 -41
  1122. package/dist/approval-handler.runtime-9W6kSKLn.js +0 -130
  1123. package/dist/assistant-D338eQWk.js +0 -291
  1124. package/dist/attachment-normalize-BaGndElX.js +0 -225
  1125. package/dist/attempt-execution-aOkjnMht.js +0 -558
  1126. package/dist/attempt-execution.runtime-lKPuGjsg.js +0 -3
  1127. package/dist/attempt-execution.shared-lwEBnvQR.js +0 -38
  1128. package/dist/attempt.prompt-helpers-BVDwNazv.js +0 -475
  1129. package/dist/attempt.tool-run-context-DXgP_TxW.js +0 -2094
  1130. package/dist/binding-routing-CA-u9MaB.js +0 -113
  1131. package/dist/binding-targets-SGf9XyYl.js +0 -121
  1132. package/dist/bot-C0uHsCiq.js +0 -7894
  1133. package/dist/bot-deps-CfqgukPx.js +0 -747
  1134. package/dist/bot-deps-D0dGR0Um.js +0 -2
  1135. package/dist/bot-message-context.runtime-aqONyuCb.js +0 -7
  1136. package/dist/bot-message-context.session.runtime-CYJpmbne.js +0 -12
  1137. package/dist/bot-native-commands.delivery.runtime-DjCvDhXo.js +0 -4
  1138. package/dist/bot-native-commands.runtime-CNDOgqnt.js +0 -13
  1139. package/dist/bridge-server-DX39VTjh.js +0 -113
  1140. package/dist/browser-cli-BM0neIBN.js +0 -2
  1141. package/dist/browser-cli-TjkCzsOd.js +0 -230
  1142. package/dist/browser-cli-actions-input-Crdngwmz.js +0 -473
  1143. package/dist/browser-cli-actions-observe-CR0DTzDP.js +0 -81
  1144. package/dist/browser-cli-debug-CC9OYHxx.js +0 -137
  1145. package/dist/browser-cli-inspect-DVWu-CO3.js +0 -104
  1146. package/dist/browser-cli-manage-BfSgA18U.js +0 -443
  1147. package/dist/browser-cli-resize-ddNFsnFm.js +0 -26
  1148. package/dist/browser-cli-shared-B_5TDXXY.js +0 -50
  1149. package/dist/browser-cli-state-CnLWkvHn.js +0 -337
  1150. package/dist/browser-control-auth-1gcUHgnp.js +0 -2
  1151. package/dist/browser-profiles-BkIb0hYP.js +0 -2
  1152. package/dist/browser-runtime-RQ9H-pQ2.js +0 -384
  1153. package/dist/build-C3ote3YU.js +0 -257
  1154. package/dist/bundled-channel-config-schema-4eXcH-RE.d.ts +0 -3163
  1155. package/dist/call-DY6_VEa_.d.ts +0 -43
  1156. package/dist/capability-cli-D2fTtzuV.js +0 -1782
  1157. package/dist/channel-B0dtLI6U.d.ts +0 -49
  1158. package/dist/channel-B2MLRCOm.d.ts +0 -106
  1159. package/dist/channel-B4XBSqBl.d.ts +0 -7
  1160. package/dist/channel-BC3xWers.js +0 -808
  1161. package/dist/channel-BJFPY0Kt.js +0 -376
  1162. package/dist/channel-BMVs8cLm.js +0 -740
  1163. package/dist/channel-BNmekEHv.js +0 -508
  1164. package/dist/channel-BnPanYUC.js +0 -562
  1165. package/dist/channel-BompXOlb.js +0 -1134
  1166. package/dist/channel-Bq3wyp3c.d.ts +0 -8
  1167. package/dist/channel-BwdtLWWj.js +0 -1556
  1168. package/dist/channel-C1AEDysJ.d.ts +0 -47
  1169. package/dist/channel-CEH1dfVt.d.ts +0 -12
  1170. package/dist/channel-CQJHudhH.d.ts +0 -114
  1171. package/dist/channel-CUu3R9QU.d.ts +0 -14
  1172. package/dist/channel-CaugIi5d.js +0 -481
  1173. package/dist/channel-CsdkcuzU.d.ts +0 -7
  1174. package/dist/channel-D-QJ4LSf.d.ts +0 -28
  1175. package/dist/channel-D07QdL-Z.d.ts +0 -8
  1176. package/dist/channel-D1AKh1-N.d.ts +0 -6
  1177. package/dist/channel-D7LE0yXG.js +0 -653
  1178. package/dist/channel-DBucF-mL.js +0 -1496
  1179. package/dist/channel-DC98b13r.js +0 -238
  1180. package/dist/channel-DECcAIqn.d.ts +0 -104
  1181. package/dist/channel-DGWSLAgs.js +0 -1249
  1182. package/dist/channel-DHk6PKNy.js +0 -362
  1183. package/dist/channel-DZW76PDC.d.ts +0 -8
  1184. package/dist/channel-Dqyy2G9y.js +0 -955
  1185. package/dist/channel-DwSP9REc.d.ts +0 -64
  1186. package/dist/channel-LKyGksmz.d.ts +0 -26
  1187. package/dist/channel-Z-wTsii5.js +0 -1777
  1188. package/dist/channel-_B9ZXRPx.js +0 -867
  1189. package/dist/channel-actions.runtime-C3lWtJBL.js +0 -265
  1190. package/dist/channel-cGJKLfJe.d.ts +0 -427
  1191. package/dist/channel-core-B3Xqnnjw.js +0 -5
  1192. package/dist/channel-core-DshTARNf.d.ts +0 -6
  1193. package/dist/channel-entry-contract-DpdwxgOw.d.ts +0 -112
  1194. package/dist/channel-inbound-BnUDIbdQ.js +0 -80
  1195. package/dist/channel-lifecycle-C4NrMjdz.d.ts +0 -125
  1196. package/dist/channel-pairing-ndZVB-VX.d.ts +0 -58
  1197. package/dist/channel-plugin-runtime-CFKbI6Pu.js +0 -998
  1198. package/dist/channel-plugin-runtime-CS0_tyOZ.d.ts +0 -7
  1199. package/dist/channel-runtime-BLFYOC-l.js +0 -408
  1200. package/dist/channel-yBZ1hu-c.js +0 -2126
  1201. package/dist/channel.runtime-BMBFwVOB.js +0 -1008
  1202. package/dist/channel.runtime-BPaTa_4p.js +0 -4
  1203. package/dist/channel.runtime-BiOmO6NR.js +0 -254
  1204. package/dist/channel.runtime-BmwN1CYk.js +0 -652
  1205. package/dist/channel.runtime-C5JA3DOQ.js +0 -21009
  1206. package/dist/channel.runtime-CWmegcjl.js +0 -109
  1207. package/dist/channel.runtime-DDs1y218.js +0 -733
  1208. package/dist/channel.runtime-DJMJ7DxI.js +0 -88
  1209. package/dist/channel.runtime-Dr7_P-K2.js +0 -2528
  1210. package/dist/channel.setup-B03MiH5Q.d.ts +0 -6
  1211. package/dist/channel.setup-BRhsffda.js +0 -10
  1212. package/dist/channel.setup-ByuZMttY.d.ts +0 -8
  1213. package/dist/channel.setup-C74nA6R0.js +0 -343
  1214. package/dist/channel.setup-CIlbvWjW.d.ts +0 -7
  1215. package/dist/channel.setup-RbyDP1dD.js +0 -1098
  1216. package/dist/chat-CGdonziw.js +0 -2666
  1217. package/dist/chrome-BbE0579R.js +0 -1503
  1218. package/dist/cli-CJkC6ybf.js +0 -1341
  1219. package/dist/cli-backend-Dg9IEgrP.d.ts +0 -5
  1220. package/dist/cli-backend-DwmYGZX7.d.ts +0 -5
  1221. package/dist/cli-compaction-D7zwr6if.js +0 -347
  1222. package/dist/cli-metadata-gL02qQsZ.js +0 -22
  1223. package/dist/cli-pk6gIQfi.d.ts +0 -20
  1224. package/dist/cli-runner-DTqOC0Ap.js +0 -540
  1225. package/dist/cli-runner-DX7wbmT5.js +0 -2
  1226. package/dist/cli-runner.runtime-CMFns61M.js +0 -4
  1227. package/dist/cli-runner.runtime-DH0Kp9FZ.js +0 -3
  1228. package/dist/cli-shared-C_4_xNC-.d.ts +0 -20
  1229. package/dist/client-B763Tol6.js +0 -650
  1230. package/dist/client-adapter-WxKxH6x-.js +0 -897
  1231. package/dist/client-factory-00sxHiJF.js +0 -9
  1232. package/dist/command-auth-CXYQ5Z0j.js +0 -135
  1233. package/dist/command-handlers-D1Ac0Dkj.js +0 -1609
  1234. package/dist/command-registry-D2dsDDz5.js +0 -9
  1235. package/dist/command-registry-Dih3NQG-.js +0 -4
  1236. package/dist/command-registry-core-CjXOyB2J.js +0 -110
  1237. package/dist/command-status.runtime-B0-uERwh.js +0 -90
  1238. package/dist/commands-CLbV1tFt.d.ts +0 -113
  1239. package/dist/commands-acp-pD2JpUSj.js +0 -74
  1240. package/dist/commands-compact.runtime-V-TcIs65.js +0 -10
  1241. package/dist/commands-handlers.runtime-5M-A0jiA.js +0 -6154
  1242. package/dist/commands-status-Bm4dG6pI.js +0 -3
  1243. package/dist/commands-status-qm4EnRyE.js +0 -16
  1244. package/dist/commands-status.runtime-Bm4dG6pI.js +0 -3
  1245. package/dist/commands-subagents-control.runtime-DI46smsH.js +0 -2
  1246. package/dist/commands-subagents-control.runtime-rWDaFqzc.js +0 -3
  1247. package/dist/commands-system-prompt-B4F4MOEY.js +0 -162
  1248. package/dist/commands-system-prompt-jk5Mc_DP.js +0 -2
  1249. package/dist/commands.runtime-Bc23O5Mi.js +0 -176
  1250. package/dist/compact-CtN0DOvK.js +0 -480
  1251. package/dist/compact-D1ChSGOh.js +0 -1141
  1252. package/dist/compact.runtime-C7If8t90.js +0 -12
  1253. package/dist/completion-cli-gXouR92c.js +0 -315
  1254. package/dist/computer-use-CdO4BAyI.js +0 -367
  1255. package/dist/config-BkIb0hYP.js +0 -2
  1256. package/dist/config-dmYhst2s.js +0 -373
  1257. package/dist/config-mutations-D2ETKy_j.js +0 -159
  1258. package/dist/config-schema-BwKcspTI.d.ts +0 -20
  1259. package/dist/config-schema-Dx48Ud8L.d.ts +0 -34
  1260. package/dist/context-engine-host-compat-DgNqJwdY.js +0 -288
  1261. package/dist/context-engine-host-compat-OWTQLkIP.js +0 -2
  1262. package/dist/context-engine-lifecycle-CGVL8HdA.js +0 -1274
  1263. package/dist/contracts-testkit-CzhusazO.d.ts +0 -145
  1264. package/dist/control-auth-BFMiW_62.js +0 -114
  1265. package/dist/control-service-D7r7Quub.js +0 -145
  1266. package/dist/control-ui/apple-touch-icon.png +0 -0
  1267. package/dist/control-ui/assets/agents-DHLE0HFl.js +0 -1008
  1268. package/dist/control-ui/assets/ar-DmY3OKJ7.js +0 -2
  1269. package/dist/control-ui/assets/channel-config-extras-CxFOBh-V.js +0 -2
  1270. package/dist/control-ui/assets/channels-C6FcgeKY.js +0 -367
  1271. package/dist/control-ui/assets/cron-SXiWM7mY.js +0 -1013
  1272. package/dist/control-ui/assets/de-nNWCMyC9.js +0 -2
  1273. package/dist/control-ui/assets/debug-B0jMeZzd.js +0 -97
  1274. package/dist/control-ui/assets/es-BcdhLNdf.js +0 -2
  1275. package/dist/control-ui/assets/fa-DbS2z7VZ.js +0 -2
  1276. package/dist/control-ui/assets/fr-CBqvw0rY.js +0 -2
  1277. package/dist/control-ui/assets/id-DXES9f6X.js +0 -2
  1278. package/dist/control-ui/assets/index-BimYwq-S.css +0 -1
  1279. package/dist/control-ui/assets/index-DL8I3w4m.js +0 -7373
  1280. package/dist/control-ui/assets/instances-CzcXlcf6.js +0 -57
  1281. package/dist/control-ui/assets/it-DpT4ZVOU.js +0 -2
  1282. package/dist/control-ui/assets/ja-JP-D8RXA_04.js +0 -2
  1283. package/dist/control-ui/assets/ko-5en8VO8w.js +0 -2
  1284. package/dist/control-ui/assets/logs-UowLBcx5.js +0 -74
  1285. package/dist/control-ui/assets/nl-Bb10QoRg.js +0 -2
  1286. package/dist/control-ui/assets/nodes-elwKg1C7.js +0 -436
  1287. package/dist/control-ui/assets/pl-Y8UIOEIm.js +0 -2
  1288. package/dist/control-ui/assets/preview-BBw3vauN.js +0 -2
  1289. package/dist/control-ui/assets/pt-BR-DDsy5M68.js +0 -2
  1290. package/dist/control-ui/assets/push-subscription-TTvs1whj.js +0 -2
  1291. package/dist/control-ui/assets/sessions-zRBKS883.js +0 -399
  1292. package/dist/control-ui/assets/skills-Bdaz7HoH.js +0 -314
  1293. package/dist/control-ui/assets/skills-shared-DMTrs8i3.js +0 -11
  1294. package/dist/control-ui/assets/th-D_2DtFn6.js +0 -2
  1295. package/dist/control-ui/assets/tr-DBsYZTmE.js +0 -2
  1296. package/dist/control-ui/assets/uk-BUxHBc05.js +0 -2
  1297. package/dist/control-ui/assets/vi-B67Eos5b.js +0 -2
  1298. package/dist/control-ui/assets/zh-CN-1-UH_6gQ.js +0 -2
  1299. package/dist/control-ui/assets/zh-TW-CA4YEnf2.js +0 -2
  1300. package/dist/control-ui/favicon-32.png +0 -0
  1301. package/dist/control-ui/favicon-512.png +0 -0
  1302. package/dist/control-ui/favicon.ico +0 -0
  1303. package/dist/control-ui/favicon.svg +0 -12
  1304. package/dist/control-ui/index.html +0 -322
  1305. package/dist/control-ui/manifest.webmanifest +0 -40
  1306. package/dist/control-ui/sw.js +0 -133
  1307. package/dist/conversation-binding-runtime-BW_4K8cX.js +0 -4
  1308. package/dist/conversation-runtime-oIeuYAld.js +0 -31
  1309. package/dist/core-B7zb6eoz.d.ts +0 -224
  1310. package/dist/core-Cqwgrdgs.js +0 -282
  1311. package/dist/core-api-DI9CNhVz.js +0 -2
  1312. package/dist/core-api-Dcj6myhZ.js +0 -5
  1313. package/dist/crestodian-DVM5VVBT.js +0 -55
  1314. package/dist/daocore-runtime-DogaiqPT.d.ts +0 -151
  1315. package/dist/daocore-tools-bO6317PZ.js +0 -11727
  1316. package/dist/delivery-BCvDWVt-.js +0 -1002
  1317. package/dist/dialogue-D7jagbT_.js +0 -37
  1318. package/dist/dir-fetch-tool-BT5EPw-5.js +0 -565
  1319. package/dist/dir-list-tool-H_efDjDq.js +0 -100
  1320. package/dist/direct-dm-D0B-QMik.js +0 -64
  1321. package/dist/directive-handling.fast-lane-DsGCtBC-.js +0 -68
  1322. package/dist/directive-handling.impl-C-1mgd9g.js +0 -2
  1323. package/dist/directive-handling.impl-DumICYAp.js +0 -818
  1324. package/dist/directive-handling.model-selection-BJZn2fo_.js +0 -122
  1325. package/dist/directive-handling.persist.runtime-D62V2_9_.js +0 -263
  1326. package/dist/dispatch-CnOOlfPn.js +0 -1640
  1327. package/dist/dispatch-acp-transcript.runtime-DV_7Zl9P.js +0 -40
  1328. package/dist/dispatch-acp.runtime-ATTViG-t.js +0 -18
  1329. package/dist/doctor-8vhWy3Dw.js +0 -2
  1330. package/dist/doctor-CKYTXvU7.js +0 -6
  1331. package/dist/doctor-config-flow-B0Ilj0MM.js +0 -1741
  1332. package/dist/doctor-core-checks-B0DeLp7M.js +0 -2
  1333. package/dist/doctor-core-checks-NFFEe2qP.js +0 -573
  1334. package/dist/doctor-health-BQDkMVRf.js +0 -65
  1335. package/dist/doctor-health-contributions-BTtoe4Zy.js +0 -696
  1336. package/dist/doctor-lint-CtjiT5S1.js +0 -94
  1337. package/dist/doctor-state-integrity-C1p_aTX_.js +0 -1231
  1338. package/dist/doctor-update-Dzr9Vt00.js +0 -58
  1339. package/dist/doctor-update-fix-Dw80wTUs.js +0 -107
  1340. package/dist/dynamic-tools-Cb1BxOUV.js +0 -486
  1341. package/dist/embedded-backend-DIv3GabL.js +0 -579
  1342. package/dist/embedded-gateway-stub.runtime-DqgU4q-g.js +0 -12
  1343. package/dist/embedding-provider-B82QlZsy.d.ts +0 -21
  1344. package/dist/embedding-provider-Cmb3dgUf.d.ts +0 -65
  1345. package/dist/embedding-provider-w7EJz-DO.d.ts +0 -16
  1346. package/dist/exec-approvals-ClOFMgg8.js +0 -149
  1347. package/dist/file-fetch-tool-CIe7NhYV.js +0 -124
  1348. package/dist/file-write-tool-DBpMRVuc.js +0 -127
  1349. package/dist/format-DwlQcHW-.js +0 -1145
  1350. package/dist/gateway-cli-B-RpSgut.js +0 -435
  1351. package/dist/gateway-method-runtime-BblhHt-0.js +0 -21
  1352. package/dist/gateway-runtime-BcWCu-QH.d.ts +0 -163
  1353. package/dist/gemini-cli-provider-DtyOwxHA.d.ts +0 -6
  1354. package/dist/get-reply-HRNSgWtJ.js +0 -4689
  1355. package/dist/get-reply-from-config.runtime-D_IjyVEy.js +0 -2
  1356. package/dist/graph-users-xOkVRyWa.js +0 -1419
  1357. package/dist/group-access-5rOw40mA.js +0 -112
  1358. package/dist/handle-action.guild-admin-3izRlfhG.js +0 -288
  1359. package/dist/harness-DSATBx4q.js +0 -61
  1360. package/dist/health-gXf5LPQE.js +0 -4
  1361. package/dist/heartbeat-runner-BAl6rYJ4.js +0 -5
  1362. package/dist/heartbeat-runner.runtime-BwR4hXGN.js +0 -4
  1363. package/dist/hook-runtime-Cms52qXe.d.ts +0 -107
  1364. package/dist/hooks-Ds30xkRl.js +0 -534
  1365. package/dist/http-registry-D3Cdok5J.d.ts +0 -23
  1366. package/dist/image-generation-runtime-DhYgou3B.d.ts +0 -21
  1367. package/dist/inbound-direct-dm-runtime-VLA3Sl_Y.js +0 -2
  1368. package/dist/inbound-reply-dispatch-B1Yv-_Ol.js +0 -148
  1369. package/dist/index-ChRAMnH9.d.ts +0 -3971
  1370. package/dist/init-C94m6gc5.js +0 -59
  1371. package/dist/inline-buttons-B48KLvRY.js +0 -40
  1372. package/dist/interactive-dispatch-B-NLdr77.d.ts +0 -56
  1373. package/dist/interactive-dispatch-B66zssEF.d.ts +0 -143
  1374. package/dist/internal-events-DH1wKI3W.js +0 -90
  1375. package/dist/isolated-agent-BHtpDjQ3.js +0 -1118
  1376. package/dist/isolated-agent-CQ8xLCdA.js +0 -2
  1377. package/dist/lifecycle-J2_rGItq.js +0 -571
  1378. package/dist/list.probe-CQkRrePt.js +0 -449
  1379. package/dist/list.status-command-Dh4C_nmX.js +0 -789
  1380. package/dist/llm-slug-generator-CuTyqyw9.js +0 -78
  1381. package/dist/loader-Ben-RYnp.d.ts +0 -142
  1382. package/dist/local-dispatch.runtime-DMFlGKN5.js +0 -9
  1383. package/dist/manager-BDWyUfHJ.d.ts +0 -356
  1384. package/dist/manager-CuzV3XAs.d.ts +0 -205
  1385. package/dist/manager.runtime-ChEFeq5B.js +0 -2714
  1386. package/dist/markdown-to-line-BXszL2cy.js +0 -811
  1387. package/dist/mcp-http-BfLRPB10.js +0 -555
  1388. package/dist/mcp-http-C4jMPkoA.js +0 -2
  1389. package/dist/media-understanding-provider-By_IYDJy.js +0 -339
  1390. package/dist/memory-core-host-engine-storage-BAq5Rf51.d.ts +0 -54
  1391. package/dist/memory-embedding-adapter-Cv87QsD0.d.ts +0 -5
  1392. package/dist/message-actions-CnGb9RhR.js +0 -145
  1393. package/dist/message-handler-BczaNv3J.js +0 -384
  1394. package/dist/message-handler-txIHUJJr.js +0 -1715
  1395. package/dist/message-handler.preflight-DQ_XIRJD.js +0 -1125
  1396. package/dist/message-handler.process-DW_BauDK.js +0 -1484
  1397. package/dist/migration-BOkhOT4K.d.ts +0 -45
  1398. package/dist/model-B4s-pIp8.d.ts +0 -33
  1399. package/dist/model-CzeDtlL2.js +0 -74
  1400. package/dist/model-selection-DISTEWT3.js +0 -272
  1401. package/dist/models-6NYWdsJM.d.ts +0 -24
  1402. package/dist/models-Cs632hpM.js +0 -104
  1403. package/dist/models-DFdDefW_.js +0 -2
  1404. package/dist/models-cli-CEJaAepl.js +0 -256
  1405. package/dist/monitor-1sdwxltF.js +0 -2788
  1406. package/dist/monitor-B3satZZM.js +0 -2
  1407. package/dist/monitor-BjTf4-1k.js +0 -715
  1408. package/dist/monitor-Blfd3oxm.js +0 -1370
  1409. package/dist/monitor-CTBBctRZ.js +0 -60
  1410. package/dist/monitor-DMs9Fc-I.js +0 -4377
  1411. package/dist/monitor-Jaf6yIPY.js +0 -1657
  1412. package/dist/monitor-QlSkTI6D.js +0 -834
  1413. package/dist/monitor-auth-C1tksIdC.js +0 -179
  1414. package/dist/monitor-polling.runtime-BfiQ9WKu.js +0 -883
  1415. package/dist/monitor-webhook.runtime-DaN0Z6_6.js +0 -387
  1416. package/dist/monitor.account-DXs-I96r.js +0 -5233
  1417. package/dist/monitor.runtime-CfhDXAnn.js +0 -2
  1418. package/dist/monitor.webhook-Dh2yCA0H.js +0 -180
  1419. package/dist/node-cli-sessions-BRSHPLpR.js +0 -1228
  1420. package/dist/openai-codex-provider-CByFL0Au.d.ts +0 -5
  1421. package/dist/openai-http-CJKcPRWW.js +0 -824
  1422. package/dist/openai-provider-DbEgHbfx.d.ts +0 -5
  1423. package/dist/openresponses-http-BhyRvqJ0.js +0 -1173
  1424. package/dist/operations-CL7dqxSs.js +0 -805
  1425. package/dist/outbound-adapter-BzLFym-i.js +0 -543
  1426. package/dist/outbound-session-route-do6mbRaF.js +0 -45
  1427. package/dist/outbound.runtime-ClwB5soC.js +0 -2
  1428. package/dist/pairing-challenge-EwSQYSud.d.ts +0 -87
  1429. package/dist/pi-embedded-BtyxupRo.js +0 -3796
  1430. package/dist/pi-embedded-DC6txKUX.js +0 -4
  1431. package/dist/pi-embedded.runtime-CLGqbc8E.js +0 -4
  1432. package/dist/pi-tools-BNtGWzuL.js +0 -2413
  1433. package/dist/plan-BKvy4WrJ.js +0 -81
  1434. package/dist/plan-DwVlQpE1.js +0 -112
  1435. package/dist/plugin-BehbkTVr.d.ts +0 -17
  1436. package/dist/plugin-CY0rEF7s.js +0 -12396
  1437. package/dist/plugin-app-cache-key-DNUt0H7R.js +0 -46
  1438. package/dist/plugin-enabled-Cyd8634I.js +0 -233
  1439. package/dist/plugin-entry-feg_rkHL.d.ts +0 -47
  1440. package/dist/plugin-registration-B_-ymgPg.js +0 -88
  1441. package/dist/plugin-runtime-paqzXBLJ.d.ts +0 -117
  1442. package/dist/plugin-sdk/scripts/lib/plugin-sdk-doc-metadata.d.ts +0 -107
  1443. package/dist/plugin-service-C0JwHvDr.d.ts +0 -24
  1444. package/dist/plugin-service-Dxx-FdeS.js +0 -1229
  1445. package/dist/policy-BXjjr3b_.js +0 -138
  1446. package/dist/policy-cKo9Yeux.js +0 -680
  1447. package/dist/prepare.runtime-DKbtJNij.js +0 -732
  1448. package/dist/preview-warnings-B_dB0-nc.js +0 -392
  1449. package/dist/probe-D02PTGyD.js +0 -47
  1450. package/dist/probe-DywFeNCV.js +0 -682
  1451. package/dist/probe-f3qP15_E.js +0 -2204
  1452. package/dist/probe-sSNH7OtW.js +0 -2
  1453. package/dist/program-CI-yGmHj.js +0 -131
  1454. package/dist/prompt-overlay-qLjnjnSK.d.ts +0 -23
  1455. package/dist/provider-0MTK_A59.js +0 -32
  1456. package/dist/provider-Bqz_XGo0.js +0 -8735
  1457. package/dist/provider-DguV0rAM.js +0 -32
  1458. package/dist/provider-Vf0kCR9H.js +0 -152
  1459. package/dist/provider-api-key-auth-CB8Tllmv.d.ts +0 -27
  1460. package/dist/provider-auth-result-Xze96yVn.d.ts +0 -21
  1461. package/dist/provider-catalog-runtime-Bo88wUpB.d.ts +0 -23
  1462. package/dist/provider-catalog-shared-rq7-Hkyg.d.ts +0 -62
  1463. package/dist/provider-dispatcher-DYgMXESe.js +0 -22
  1464. package/dist/provider-hook-runtime-bhgA4zLg.d.ts +0 -61
  1465. package/dist/provider-model-shared-Bv_vhH6i.d.ts +0 -143
  1466. package/dist/provider-models-DzbXgGDD.d.ts +0 -12
  1467. package/dist/provider-policy-Cx2IwhQ-.d.ts +0 -30
  1468. package/dist/provider-registration-D4DJp8vF.d.ts +0 -6
  1469. package/dist/provider-registry-BQ5DzWBt.d.ts +0 -8
  1470. package/dist/provider-registry-BrtezAkH.d.ts +0 -30
  1471. package/dist/provider-registry-DG571X-9.d.ts +0 -8
  1472. package/dist/provider-runtime-BJlV-8wH.d.ts +0 -359
  1473. package/dist/provider-self-hosted-setup-C5mGtzPJ.d.ts +0 -74
  1474. package/dist/provider-session.runtime-DPLsI_az.js +0 -9
  1475. package/dist/provider-stream-D-MYyujL.d.ts +0 -140
  1476. package/dist/provider-stream-shared-B6pQNRl4.d.ts +0 -128
  1477. package/dist/provider.runtime-Dqb234pz.js +0 -2
  1478. package/dist/providers.runtime-B9kfx6q8.d.ts +0 -25
  1479. package/dist/public-surface-loader-BFaumhij.js +0 -114
  1480. package/dist/pw-ai-G5xV3oAx.js +0 -3029
  1481. package/dist/pw-role-snapshot-Dx3HJBHP.js +0 -333
  1482. package/dist/reaction-level-cwg9IPV-.js +0 -19
  1483. package/dist/reaction-runtime-api-BO5tonA_.js +0 -116
  1484. package/dist/realtime-transcription-CAC89bnc.d.ts +0 -43
  1485. package/dist/realtime-transcription-provider-BPUt8lMk.js +0 -205
  1486. package/dist/realtime-transcription-provider-ChYQDNhv.d.ts +0 -5
  1487. package/dist/realtime-transcription-provider-DTYtMlJi.d.ts +0 -28
  1488. package/dist/realtime-transcription-provider-DirKeOjA.d.ts +0 -32
  1489. package/dist/realtime-transcription-provider-QHEXWhCJ.d.ts +0 -37
  1490. package/dist/realtime-voice-Bm0GBqnc.d.ts +0 -333
  1491. package/dist/realtime-voice-provider-NcUDkuN4.d.ts +0 -5
  1492. package/dist/register-hPi-PJ7K.js +0 -2178
  1493. package/dist/register.agent-C17wwmyB.js +0 -156
  1494. package/dist/register.crestodian-BgN2eNeU.js +0 -24
  1495. package/dist/register.maintenance-CZV43uUT.js +0 -105
  1496. package/dist/register.runtime-B6KhmuJw.js +0 -54
  1497. package/dist/register.runtime-CXLFfKiU.d.ts +0 -6
  1498. package/dist/register.subclis-By70wsLN.js +0 -31
  1499. package/dist/register.subclis-D_XDgsMy.js +0 -3
  1500. package/dist/register.subclis-core-CYi-wxpA.js +0 -273
  1501. package/dist/registry-DXBS27qE.d.ts +0 -91
  1502. package/dist/registry-types-DlO771W4.d.ts +0 -392
  1503. package/dist/repair-sequencing-ze6dXKp3.js +0 -640
  1504. package/dist/reply-delivery-BRsL-nIn.js +0 -196
  1505. package/dist/reply-runtime-hB7p7Uov.js +0 -11
  1506. package/dist/reply.runtime-D_IjyVEy.js +0 -2
  1507. package/dist/request-C6QBV_dA.js +0 -54
  1508. package/dist/resolve-allowlist-zmvmVPzW.js +0 -220
  1509. package/dist/result-fallback-classifier-hWTcOYyH.js +0 -79
  1510. package/dist/route-BMCrq1SN.js +0 -469
  1511. package/dist/route-resolution-nWgSniti.js +0 -274
  1512. package/dist/routes-BXyfYxi-.js +0 -2
  1513. package/dist/routes-CpMZFxzv.js +0 -3602
  1514. package/dist/run-Bzp1cq1J.js +0 -1163
  1515. package/dist/run-attempt-DMj1Q3oE.js +0 -7704
  1516. package/dist/run-command-CbDBts53.js +0 -23
  1517. package/dist/run-command-CrJ2mrht.js +0 -2
  1518. package/dist/run-embedded.runtime-sD3O3k2K.js +0 -4
  1519. package/dist/run-execution-cli.runtime-CG1zNse6.js +0 -4
  1520. package/dist/run-subagent-registry.runtime-CGzIerQZ.js +0 -2
  1521. package/dist/runtime-B0ZKPxxL.js +0 -6179
  1522. package/dist/runtime-C3k-ZByi.d.ts +0 -17
  1523. package/dist/runtime-Dh-KFKJv.js +0 -1287
  1524. package/dist/runtime-api-9Xxm9K2E.js +0 -21
  1525. package/dist/runtime-api-C2252PQ4.js +0 -4
  1526. package/dist/runtime-api-C7ToEUFX2.d.ts +0 -3151
  1527. package/dist/runtime-api-Cl3W6JLB.js +0 -13
  1528. package/dist/runtime-api-CwyQGzrm.js +0 -24
  1529. package/dist/runtime-api-DQVZQ82e.js +0 -17
  1530. package/dist/runtime-api-Ksdts3J7.js +0 -13
  1531. package/dist/runtime-api-lHayJI0f.js +0 -3
  1532. package/dist/runtime-api.actions-CHH4JoFd.js +0 -3
  1533. package/dist/runtime-api.actions-CzDO06T7.d.ts +0 -23
  1534. package/dist/runtime-api.monitor-CuAnxOiA.js +0 -6
  1535. package/dist/runtime-api.send-C5Ndv4Sb.js +0 -4
  1536. package/dist/runtime-api.send-C_MjuzGA.d.ts +0 -38
  1537. package/dist/runtime-api.threads-Car1xuWI.js +0 -2
  1538. package/dist/runtime-channel-PhHAbE3P.js +0 -2
  1539. package/dist/runtime-channel-ehNPdqhp.js +0 -150
  1540. package/dist/runtime-doctor-_yVIDUi3.d.ts +0 -48
  1541. package/dist/runtime-embedded-pi.runtime-BExQEON7.js +0 -2
  1542. package/dist/runtime-l-x1mIPp.js +0 -438
  1543. package/dist/runtime-taskflow-PDIujF9q.d.ts +0 -435
  1544. package/dist/sanitize-outbound-CINW3wBb.js +0 -127
  1545. package/dist/sdk-setup-tools-DotzY-Ff.js +0 -8
  1546. package/dist/secrets-BdWCp_pg.js +0 -113
  1547. package/dist/security-audit-BMS02wuX.js +0 -122
  1548. package/dist/security-audit-BXupNbYa.js +0 -118
  1549. package/dist/security-audit.runtime-CONAKFRk.js +0 -2
  1550. package/dist/selection-8iOGMBPh.js +0 -16157
  1551. package/dist/selection-D9-GNcGp.js +0 -3
  1552. package/dist/send-BsqMC7vV.js +0 -143
  1553. package/dist/send-CTDEXMPp.d.ts +0 -231
  1554. package/dist/send-ChUpwNpF.js +0 -2
  1555. package/dist/send-D92kiCYa.js +0 -192
  1556. package/dist/send-DaFuA5cD.d.ts +0 -105
  1557. package/dist/send-LSm52k6p.js +0 -1631
  1558. package/dist/send.components-D_1vDkKM.js +0 -2
  1559. package/dist/send.components-Scs0rrDy.js +0 -500
  1560. package/dist/send.runtime-BJbljin6.js +0 -2
  1561. package/dist/send.types-DU1uiiR9.d.ts +0 -160
  1562. package/dist/server-BQ9wTpKB.js +0 -73
  1563. package/dist/server-CHWh_XGy.js +0 -24
  1564. package/dist/server-context-D42gG6GT.js +0 -2
  1565. package/dist/server-context-oRlMLKPz.js +0 -955
  1566. package/dist/server-cron-BpLzGXmi.js +0 -2
  1567. package/dist/server-cron-DFsVLz6k.js +0 -2989
  1568. package/dist/server-methods-CVgaE49L.js +0 -16499
  1569. package/dist/server-node-events-DmaGt81F.js +0 -596
  1570. package/dist/server-plugin-bootstrap-ypOUJ438.js +0 -70
  1571. package/dist/server-plugins-BZZxcYFZ.js +0 -432
  1572. package/dist/server-reload-handlers-Ccu2KW5E.js +0 -714
  1573. package/dist/server-restart-sentinel-Bud1fPG5.js +0 -2
  1574. package/dist/server-restart-sentinel-C4oYiDTT.js +0 -747
  1575. package/dist/server-runtime-services-BAlijw2O.js +0 -267
  1576. package/dist/server-runtime-services-BY8y-CAk.js +0 -2
  1577. package/dist/server-startup-plugins-utvxpVCl.js +0 -113
  1578. package/dist/server-startup-post-attach-C09QVu1D.js +0 -716
  1579. package/dist/server-ws-runtime-hgZQmILO.js +0 -349
  1580. package/dist/server.impl-btEzW7aF.js +0 -2587
  1581. package/dist/service-DYvUSJDx.js +0 -1446
  1582. package/dist/session-binding-Smi9h573.js +0 -219
  1583. package/dist/session-binding-vAzR408o.js +0 -2
  1584. package/dist/session-kill-http-HXI6hUDG.js +0 -121
  1585. package/dist/session-reset-service-CdqhH7XS.js +0 -625
  1586. package/dist/session-route-DX9HyYoG.js +0 -93
  1587. package/dist/session-status.runtime-B7dGtknj.js +0 -2
  1588. package/dist/session-subagent-reactivation.runtime-Dn-wvdjM.js +0 -2
  1589. package/dist/session-tab-registry-UN4VZE8a.js +0 -521
  1590. package/dist/sessions-history-http--Dgcvhb0.js +0 -430
  1591. package/dist/sessions.runtime-LnYxeKSP.js +0 -2
  1592. package/dist/setup-api-BfO7Ctmd.js +0 -29
  1593. package/dist/setup-core-DlCsv-9q.js +0 -174
  1594. package/dist/setup-surface-BDXmLycW.js +0 -221
  1595. package/dist/setup-surface-Bi-pZtB0.js +0 -405
  1596. package/dist/setup-surface-Bk9MdZ9I.js +0 -288
  1597. package/dist/setup-surface-m649hpou.js +0 -320
  1598. package/dist/shared-DwXuhcIz.js +0 -121
  1599. package/dist/shared-client-Cj3X4R8q.js +0 -2
  1600. package/dist/shared-client-D02xLLJg.js +0 -629
  1601. package/dist/shared-eYKaB8rP.d.ts +0 -115
  1602. package/dist/side-question-DbsrGTKR.js +0 -683
  1603. package/dist/simple-completion-runtime-D3SeEaWT.d.ts +0 -73
  1604. package/dist/skill-tool-dispatch.runtime-CswUeFQB.js +0 -143
  1605. package/dist/slash-state-Br7bOIIy.js +0 -2166
  1606. package/dist/speech-Dbhvhbdq.d.ts +0 -47
  1607. package/dist/speech-core-8X_D3HLF.d.ts +0 -36
  1608. package/dist/speech-provider-BHcOkoLn.js +0 -184
  1609. package/dist/speech-provider-BYm63_co.d.ts +0 -8
  1610. package/dist/speech-provider-BtJxZzKb.d.ts +0 -8
  1611. package/dist/speech-provider-CbneUhtJ.d.ts +0 -5
  1612. package/dist/speech-provider-DOAvAvlS.d.ts +0 -5
  1613. package/dist/speech-provider-DdfnOmrC.d.ts +0 -5
  1614. package/dist/speech-provider-ptNkD7Yf.d.ts +0 -34
  1615. package/dist/src-DcIZ_w7l.js +0 -4256
  1616. package/dist/startup-context-BU3ZwnPZ.js +0 -313
  1617. package/dist/status-subagents.runtime-U9cVRB6A.js +0 -18
  1618. package/dist/status-text-DlZ-OoHI.js +0 -296
  1619. package/dist/sticker-cache-BfgCFMo_.js +0 -206
  1620. package/dist/sticker-vision.runtime-DYSdlJUC.js +0 -17
  1621. package/dist/stream-BHkpDd1i.d.ts +0 -10
  1622. package/dist/stream-C6huJP_D.d.ts +0 -5
  1623. package/dist/stream-D4Pmcj3t.d.ts +0 -16
  1624. package/dist/stream-DpSe6hAE.d.ts +0 -19
  1625. package/dist/stream-DrRUuJ8m.d.ts +0 -120
  1626. package/dist/stream-wrappers-DLxwmPDI.d.ts +0 -21
  1627. package/dist/subagent-announce-BntptirO.js +0 -354
  1628. package/dist/subagent-announce-delivery-6GUsisag.js +0 -958
  1629. package/dist/subagent-control-C7DSvkWz.js +0 -508
  1630. package/dist/subagent-hooks-4aumktTW.js +0 -2
  1631. package/dist/subagent-hooks-COUrrxEC.js +0 -2
  1632. package/dist/subagent-hooks-DUGDXbSM.js +0 -146
  1633. package/dist/subagent-hooks-DjDgoKjj.js +0 -230
  1634. package/dist/subagent-hooks-DjvL3k1b.js +0 -2
  1635. package/dist/subagent-hooks-api-BxfHMA2E.js +0 -22
  1636. package/dist/subagent-hooks-api-Cn7QkuFW.js +0 -23
  1637. package/dist/subagent-hooks-api-_lgvYj20.js +0 -23
  1638. package/dist/subagent-hooks-gWxlJnmo.js +0 -116
  1639. package/dist/subagent-orphan-recovery-CcAPcsDk.js +0 -352
  1640. package/dist/subagent-registry-BsYF1Amv.js +0 -3
  1641. package/dist/subagent-registry-LC_Gic13.js +0 -2351
  1642. package/dist/subagent-session-cleanup-6AY_7hyu.js +0 -525
  1643. package/dist/subagent-spawn-C2IO1E1i.js +0 -1164
  1644. package/dist/target-id-By34AE0b.js +0 -107
  1645. package/dist/targets-B40DzW6Y.js +0 -44
  1646. package/dist/targets-BttGNxRs.js +0 -19
  1647. package/dist/targets-C6bpLZdS.js +0 -19
  1648. package/dist/targets-CZhlhiDN.d.ts +0 -10
  1649. package/dist/targets-HPytm6Z8.d.ts +0 -10
  1650. package/dist/test-fixtures-HY6a4nTW.d.ts +0 -26
  1651. package/dist/testing-BzZIozrH.js +0 -267
  1652. package/dist/thinking-policy-wJH8MNPa.d.ts +0 -5
  1653. package/dist/thread-bindings-CBiuE4G4.js +0 -228
  1654. package/dist/thread-bindings-CTJq5UHl.js +0 -232
  1655. package/dist/thread-bindings-bN9Ad5r9.js +0 -571
  1656. package/dist/thread-bindings-kXHwWthg.js +0 -8
  1657. package/dist/thread-bindings.discord-api-C8jkPA0w.js +0 -187
  1658. package/dist/thread-bindings.manager-BsFmjrbx.js +0 -536
  1659. package/dist/thread-bindings.manager-DfJgNAl6.js +0 -2
  1660. package/dist/thread-lifecycle-gR5OSLzh.js +0 -1614
  1661. package/dist/token-B2FhcBoz.js +0 -134
  1662. package/dist/tool-47nHlaiR.js +0 -139
  1663. package/dist/tool-actions.runtime-DwQ1lVPo.js +0 -534
  1664. package/dist/tool-plugin-CmXn59FQ.d.ts +0 -77
  1665. package/dist/tool-resolution-DQej_E5w.js +0 -149
  1666. package/dist/tool-split-CaXOLBeI.d.ts +0 -19
  1667. package/dist/tools-effective-inventory-CyXaSANM.js +0 -204
  1668. package/dist/tools-invoke-http-yo3HU4V6.js +0 -67
  1669. package/dist/tools-invoke-shared-LpV_xD9g.js +0 -200
  1670. package/dist/transport-stream-lU_hAKuv.d.ts +0 -42
  1671. package/dist/tts-E7ULNzl4.js +0 -66
  1672. package/dist/tui-B-wyN6wJ.js +0 -4709
  1673. package/dist/tui-CdI6yMis.js +0 -2
  1674. package/dist/tui-backend-CXej-4Er.js +0 -256
  1675. package/dist/tui-cli-wboa0AnA.js +0 -37
  1676. package/dist/typed-cases-BYRVKA1F.d.ts +0 -68
  1677. package/dist/types-CD1xwSld.d.ts +0 -786
  1678. package/dist/types-Zj4Bq9h-2.d.ts +0 -3650
  1679. package/dist/types.public-B0VjJLe9.d.ts +0 -70
  1680. package/dist/update-cli-CGUsDh2T.js +0 -3665
  1681. package/dist/update-global-BbP9IhEf.js +0 -601
  1682. package/dist/update-runner-B54rgAmr.js +0 -1798
  1683. package/dist/video-generation-runtime-DsFG7djU.d.ts +0 -21
  1684. package/dist/video-model-catalog-CfhC-Mol.d.ts +0 -16
  1685. package/dist/vision-tools-wacIK5vr.js +0 -1409
  1686. package/dist/web-search-AMwc61Dr.js +0 -62
  1687. package/dist/web-search-provider.runtime-CNG2uQTF.js +0 -2
  1688. package/dist/web-search-provider.runtime-oBaJtm_S.js +0 -328
  1689. package/dist/webhook-targets-DqetRJVn.d.ts +0 -99
  1690. package/dist/xai-oauth-DOqf2jTO.js +0 -479
  1691. package/dist/xai-user-agent-Dk71wEWd.js +0 -32
  1692. package/dist/zod-schema.core-BhLPa6BF.d.ts +0 -166
  1693. /package/dist/{acp-runtime-backend-4DfhM5M9.js → acp-runtime-backend-CxP454w8.js} +0 -0
  1694. /package/dist/{channel-actions-CYB0u2id.js → channel-actions-AudMk4Yk.js} +0 -0
  1695. /package/dist/{command-status-runtime-CPIRzAU6.js → command-status-runtime-BWRWzQv1.js} +0 -0
  1696. /package/dist/{delegate-DpQ2iXjn.js → delegate-CLZeP48P.js} +0 -0
  1697. /package/dist/{dispatch-acp-Bdp6i1Mz.js → dispatch-acp-BK0Zh3_p.js} +0 -0
  1698. /package/dist/{heartbeat-runner-Cx01gr5N.js → heartbeat-runner-BouutzYV.js} +0 -0
  1699. /package/dist/{library-BSsSuIcq.js → library-C-O719bG.js} +0 -0
  1700. /package/dist/{models-D6WT5XG8.d.ts → models-D6WT5XG82.d.ts} +0 -0
  1701. /package/dist/{run-executor.runtime-DwZVL5h6.js → run-executor.runtime-DF1Wol1i.js} +0 -0
  1702. /package/dist/{shared-DJ7fJ5uN.js → shared-BqbJdmuE.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-DBsOrD6X.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-Buw9g4SP.js";
9
- import { a as DEFAULT_DOWNLOAD_DIR, o as DEFAULT_TRACE_DIR, s as DEFAULT_UPLOAD_DIR } from "./config-dmYhst2s.js";
10
- import "./tmp-daocore-dir-BwRKKFcC.js";
11
- import "./errors-Bw64Buth.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-BbE0579R.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-Dx3HJBHP.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 };