@noxsoft/anima 2.0.2 → 2.0.4
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.
- package/README.md +1260 -28
- package/dist/accounts-Bth3PpPD.js +260 -0
- package/dist/accounts-D8CPKNkN.js +259 -0
- package/dist/acp-cli-ByK6lS6c.js +1081 -0
- package/dist/acp-cli-CaQCjIw4.js +1084 -0
- package/dist/agent-BgIkqd3F.js +725 -0
- package/dist/agent-N5BDcge4.js +725 -0
- package/dist/agent-events-COH7NDW2.js +182 -0
- package/dist/agent-scope-CPphqq-U.js +452 -0
- package/dist/agent-scope-DZgptr9J.js +452 -0
- package/dist/agent-scope-cj2QCT6R.js +112 -0
- package/dist/agents-NEudYMdg.js +774 -0
- package/dist/agents.config-Bujs-NIy.js +182 -0
- package/dist/agents.config-jp7OLssr.js +182 -0
- package/dist/argv-BMZMiW7v.js +73 -0
- package/dist/audit-C-UJhfdv.js +2401 -0
- package/dist/audit-CeCO7SK5.js +2401 -0
- package/dist/auth-BNZsOHGF.js +648 -0
- package/dist/auth-DMPZWzEa.js +639 -0
- package/dist/auth-choice-5VnaGMD-.js +2681 -0
- package/dist/auth-choice-DA2k4vs8.js +2681 -0
- package/dist/auth-health-B7FqA26_.js +149 -0
- package/dist/auth-health-VO_MPqVX.js +149 -0
- package/dist/auth-profiles-BDrNYX_n.js +1564 -0
- package/dist/auth-profiles-CxSHydjn.js +2689 -0
- package/dist/banner-BtDZPRzi.js +294 -0
- package/dist/browser-cli-8yQMpxb8.js +1679 -0
- package/dist/browser-cli-Czg3JtDH.js +1676 -0
- package/dist/build-info.json +3 -3
- package/dist/bundled/boot-md/handler.js +16 -16
- package/dist/bundled/bootstrap-extra-files/handler.js +4 -4
- package/dist/bundled/command-logger/handler.js +1 -1
- package/dist/bundled/session-memory/handler.js +5 -5
- package/dist/call-BIzCaKZb.js +282 -0
- package/dist/call-BYDpTVCZ.js +282 -0
- package/dist/canvas-host/a2ui/.bundle.hash +1 -1
- package/dist/catalog-CqKiUgu6.js +185 -0
- package/dist/catalog-DMfEg-oK.js +185 -0
- package/dist/channel-options-BrtCtyrT.js +32 -0
- package/dist/channel-options-CO21Gl8p.js +33 -0
- package/dist/channel-selection-Bbm1lq3P.js +51 -0
- package/dist/channel-selection-CqcX7Ocw.js +51 -0
- package/dist/channel-web-DrsT6OAE.js +2162 -0
- package/dist/channels-cli-Juyh1S6n.js +1304 -0
- package/dist/channels-cli-zNvi1m5c.js +1306 -0
- package/dist/channels-status-issues-CqzqshW4.js +18 -0
- package/dist/channels-status-issues-DdJdO866.js +18 -0
- package/dist/chrome-C4dOMO8z.js +1601 -0
- package/dist/chrome-DdcDzAtH.js +1629 -0
- package/dist/chrome-U3DRzjJD.js +1601 -0
- package/dist/chunk-D2nLsrEW.js +348 -0
- package/dist/clack-prompter-BI3RDW5w.js +92 -0
- package/dist/clack-prompter-Dwr1m_IZ.js +92 -0
- package/dist/cli/daemon-cli.js +1 -1
- package/dist/cli-C3cpDaz8.js +99 -0
- package/dist/cli-CjWUGdGC.js +101 -0
- package/dist/cli-session-BVjY_XrW.js +5463 -0
- package/dist/cli-session-gtuYN2Iq.js +5408 -0
- package/dist/client-Dswwze5_.js +1692 -0
- package/dist/client-LRKFjo4A.js +1692 -0
- package/dist/clipboard-BZKS9O1u.js +31 -0
- package/dist/clipboard-DES8b1AM.js +31 -0
- package/dist/command-format-CP1YTNCl.js +52 -0
- package/dist/command-format-CVL4K5cj.js +52 -0
- package/dist/command-format-G6N2zghg.js +38 -0
- package/dist/command-registry-BBvNvysr.js +248 -0
- package/dist/commands-AZ3n8Y2c.js +726 -0
- package/dist/commands-BMnD_QRY.js +726 -0
- package/dist/commands-registry-cFqZ6Ib4.js +766 -0
- package/dist/commands-registry-q13H7ng5.js +766 -0
- package/dist/common-CX5458fH.js +287 -0
- package/dist/common-DJbnT8ws.js +287 -0
- package/dist/completion-cli-BADRBcIl.js +432 -0
- package/dist/completion-cli-DMQgiObF.js +431 -0
- package/dist/config-CU-Axg8P.js +5704 -0
- package/dist/config-DaqbUdkI.js +5705 -0
- package/dist/config-cli-BPlbwiuA.js +244 -0
- package/dist/config-cli-DXgZJkPU.js +247 -0
- package/dist/config-guard-Ba49JNds.js +76 -0
- package/dist/config-guard-Cu0qMKZJ.js +93 -0
- package/dist/config-kVVm5EYV.js +6523 -0
- package/dist/config-sync-CzLnLTXt.js +91 -0
- package/dist/config-sync-DuydxPWx.js +91 -0
- package/dist/configure-CHgacLyi.js +960 -0
- package/dist/configure-DfHXDa1L.js +959 -0
- package/dist/context-DzgXOckU.js +60 -0
- package/dist/control-service-8_wKHwBa.js +72 -0
- package/dist/control-service-BtL1Jto_.js +72 -0
- package/dist/cron-cli-BCzSR2c0.js +448 -0
- package/dist/cron-cli-CCWNkykU.js +451 -0
- package/dist/daemon-cli-Bjkbu9Vy.js +565 -0
- package/dist/daemon-cli-CmlHcC1J.js +566 -0
- package/dist/daemon-cli.js +16 -16
- package/dist/daemon-runtime-C0tz7VAC.js +460 -0
- package/dist/daemon-runtime-rUTqCVwJ.js +460 -0
- package/dist/deliver-BBggsviM.js +1097 -0
- package/dist/deliver-CePITOl8.js +1162 -0
- package/dist/deliver-DFnVaetP.js +1097 -0
- package/dist/delivery-queue-BJQK3oh5.js +220 -0
- package/dist/deps-CeEKhrp7.js +42 -0
- package/dist/devices-cli-DQrDMrZH.js +198 -0
- package/dist/devices-cli-Oe-A1Dv0.js +195 -0
- package/dist/diagnostics-DxMFrBLO.js +35 -0
- package/dist/diagnostics-m79ZlMmZ.js +35 -0
- package/dist/directory-cli-BL6h8cGF.js +246 -0
- package/dist/directory-cli-Cjgmi_sj.js +243 -0
- package/dist/dispatcher-DAFbQM-c.js +100 -0
- package/dist/dispatcher-DNd40gUn.js +100 -0
- package/dist/dist-CqDI82ei.js +929 -0
- package/dist/dist-DnHRxR5U.js +929 -0
- package/dist/dns-cli-CFtV3BXK.js +200 -0
- package/dist/dns-cli-NyIHvQ5S.js +197 -0
- package/dist/dock-BdXLb5oY.js +753 -0
- package/dist/dock-jYICmNcI.js +753 -0
- package/dist/docs-cli-CrOaIK_H.js +161 -0
- package/dist/docs-cli-D_cmJDSr.js +159 -0
- package/dist/doctor-BpGxKrBl.js +1815 -0
- package/dist/doctor-D12wNQPU.js +1813 -0
- package/dist/doctor-completion-DeOfofek.js +92 -0
- package/dist/doctor-completion-DwjqdEcK.js +92 -0
- package/dist/doctor-config-flow-BI3mpkbd.js +1232 -0
- package/dist/doctor-config-flow-wMHheFkC.js +1232 -0
- package/dist/engine-BCtL-AMw.js +563 -0
- package/dist/engine-Bk_UT413.js +563 -0
- package/dist/entry.js +5 -5
- package/dist/env-v6411I8h.js +32 -0
- package/dist/exec-B7sUS164.js +1167 -0
- package/dist/exec-approvals-CroGJRUg.js +1221 -0
- package/dist/exec-approvals-cli-BTxF_RsH.js +371 -0
- package/dist/exec-approvals-cli-n1gyGwH2.js +368 -0
- package/dist/exec-mhSykkaa.js +255 -0
- package/dist/extensionAPI.js +3 -3
- package/dist/frontmatter-BmHq0vRD.js +204 -0
- package/dist/gateway-cli-DDBadlrS.js +19971 -0
- package/dist/gateway-cli-IZNkOMBe.js +19972 -0
- package/dist/gateway-rpc-Dtx8HN-n.js +28 -0
- package/dist/gateway-rpc-L2PVSqGj.js +28 -0
- package/dist/github-copilot-auth-DKyqDaGU.js +1418 -0
- package/dist/github-copilot-auth-DXpOMSd3.js +1418 -0
- package/dist/gmail-setup-utils-BKNczIJ9.js +428 -0
- package/dist/gmail-setup-utils-co0ppccC.js +428 -0
- package/dist/health-Bm8ZTvC3.js +1253 -0
- package/dist/health-DUf1gt4E.js +1258 -0
- package/dist/health-format-BksT6F68.js +208 -0
- package/dist/health-format-uzh1xYLD.js +208 -0
- package/dist/heartbeat-visibility-1TJb1Zao.js +98 -0
- package/dist/heartbeat-visibility-CwodtdcX.js +98 -0
- package/dist/help-format-C6cv_aZp.js +17 -0
- package/dist/helpers-N-uSFKOn.js +10 -0
- package/dist/hooks-cli-1POsXqOl.js +993 -0
- package/dist/hooks-cli-BGjILbze.js +991 -0
- package/dist/hooks-status-DE07n5RC.js +356 -0
- package/dist/hooks-status-Du-d1jde.js +356 -0
- package/dist/image-ops-B_AYV3tp.js +541 -0
- package/dist/image-ops-Bp0C6Mvr.js +541 -0
- package/dist/index.js +82 -82
- package/dist/init-9A0s7bWG.js +122 -0
- package/dist/init-DoyCHJDC.js +122 -0
- package/dist/installs-D1C9wHAq.js +383 -0
- package/dist/installs-Dh4dHayM.js +383 -0
- package/dist/ipv4-DCItfaJo.js +1964 -0
- package/dist/ipv4-DSOUVx0i.js +1964 -0
- package/dist/lanes-BvSnHq2h.js +232 -0
- package/dist/lifecycle-core-BY4WIf9g.js +388 -0
- package/dist/lifecycle-core-TQKyXO-6.js +387 -0
- package/dist/links-CNu_8RZl.js +15 -0
- package/dist/links-D2tt2ouh.js +15 -0
- package/dist/llm-slug-generator.js +4 -4
- package/dist/logging-BIeRw0WR.js +15 -0
- package/dist/logging-C7lb3Vjc.js +15 -0
- package/dist/login-DXWKewA2.js +59 -0
- package/dist/login-Fhh4uWmf.js +61 -0
- package/dist/login-pPs3UO38.js +61 -0
- package/dist/login-qr-CevLD8cV.js +326 -0
- package/dist/login-qr-GF2JMIy-.js +323 -0
- package/dist/login-qr-ZYYKD6Yt.js +321 -0
- package/dist/logs-cli-CzXbX8HZ.js +242 -0
- package/dist/logs-cli-D9ngH9PF.js +245 -0
- package/dist/manager-BD5rA3w0.js +3244 -0
- package/dist/manager-BDPgBQSH.js +3246 -0
- package/dist/manager-DRWMWM--.js +3244 -0
- package/dist/manifest-registry-DbvPaBXY.js +748 -0
- package/dist/manifest-registry-kHX_MFa1.js +748 -0
- package/dist/markdown-tables-CqwihY2m.js +347 -0
- package/dist/markdown-tables-DJV7eAJZ.js +348 -0
- package/dist/media-lUqN-0O9.js +1342 -0
- package/dist/memory-cli-BLXSpgnN.js +868 -0
- package/dist/memory-cli-BcGVkkRJ.js +869 -0
- package/dist/message-channel-D_jIO87f.js +110 -0
- package/dist/migrate-BpVOar4L.js +157 -0
- package/dist/migrate-CkgGDkWy.js +157 -0
- package/dist/model-selection-Cqt6aJ0G.js +2691 -0
- package/dist/models-CExsNQPH.js +2510 -0
- package/dist/models-cli-Ba3Jmwev.js +2739 -0
- package/dist/models-cli-iDAlsbL2.js +258 -0
- package/dist/net-0A_zcaQD.js +218 -0
- package/dist/node-cli-ATmwCXIk.js +1319 -0
- package/dist/node-cli-DYFR_V25.js +1322 -0
- package/dist/node-service-CN4LqR1A.js +67 -0
- package/dist/node-service-CWt3MdSC.js +67 -0
- package/dist/nodes-cli-BeVmhTz3.js +1197 -0
- package/dist/nodes-cli-QeJIfa18.js +1200 -0
- package/dist/nodes-screen-DHyWAlla.js +234 -0
- package/dist/nodes-screen-qs3jRBPk.js +234 -0
- package/dist/note-CSlg2BnB.js +73 -0
- package/dist/note-Ctvglhp1.js +73 -0
- package/dist/npm-registry-spec-DQd4M22q.js +351 -0
- package/dist/npm-registry-spec-PxisIMts.js +351 -0
- package/dist/onboard-DeruD10m.js +1166 -0
- package/dist/onboard-SAcu5N6N.js +1165 -0
- package/dist/onboard-channels-C4iSfFXR.js +672 -0
- package/dist/onboard-channels-oVTVgoyg.js +672 -0
- package/dist/onboard-helpers-B8roRwLP.js +365 -0
- package/dist/onboard-helpers-Dgh26hgP.js +365 -0
- package/dist/onboarding-Bi-ac8we.js +911 -0
- package/dist/onboarding-C2gjB2u8.js +910 -0
- package/dist/orchestrator-DlbAYMQP.js +357 -0
- package/dist/orchestrator-DlwVRVDA.js +357 -0
- package/dist/outbound-CkKgc6iR.js +2062 -0
- package/dist/outbound-Vfm5yDh3.js +214 -0
- package/dist/outbound-bs_VK51X.js +214 -0
- package/dist/outbound-send-deps-DDjiMfEL.js +55 -0
- package/dist/pairing-cli-CJYeuEik.js +118 -0
- package/dist/pairing-cli-mqopHI8s.js +121 -0
- package/dist/pairing-store-BsXzUDPv.js +388 -0
- package/dist/pairing-store-DoNj00-X.js +388 -0
- package/dist/path-env-C_xpiG8l.js +89 -0
- package/dist/path-env-DSSMHu5A.js +89 -0
- package/dist/paths-B1vRVCad.js +126 -0
- package/dist/paths-BMuHNFxg.js +238 -0
- package/dist/paths-BXQQzXGQ.js +129 -0
- package/dist/paths-Buw_geoe.js +54 -0
- package/dist/paths-DA9WYabg.js +222 -0
- package/dist/paths-DfQGx0_k.js +129 -0
- package/dist/pi-auth-json-DOPW3e4X.js +78 -0
- package/dist/pi-auth-json-MruLmI_X.js +82 -0
- package/dist/pi-auth-json-lae_wwwo.js +80 -0
- package/dist/pi-model-discovery-7q0GxMrp.js +3 -0
- package/dist/pi-tools.policy-Csmla32P.js +200 -0
- package/dist/pi-tools.policy-xYdDLEv9.js +200 -0
- package/dist/plugin-auto-enable-CViVVWgg.js +282 -0
- package/dist/plugin-auto-enable-CjZ238UI.js +282 -0
- package/dist/plugin-registry-B4Aw2hzq.js +32 -0
- package/dist/plugin-registry-DW81arxW.js +32 -0
- package/dist/plugin-sdk/cli/cli-name.d.ts +1 -1
- package/dist/plugin-sdk/config/paths.d.ts +2 -2
- package/dist/plugin-sdk/index.js +7 -7
- package/dist/plugins-DhcGAPDB.js +38 -0
- package/dist/plugins-DtghNRtM.js +168 -0
- package/dist/plugins-cli-4vWTmOAb.js +736 -0
- package/dist/plugins-cli-CdTMbP0X.js +734 -0
- package/dist/polls-D6eCdatA.js +1343 -0
- package/dist/ports-BtZx-JKD.js +96 -0
- package/dist/ports-C8bKN8s0.js +96 -0
- package/dist/ports-DHiKnPRX.js +344 -0
- package/dist/ports-vd93M_Pt.js +317 -0
- package/dist/program-CX3aUVeb.js +176 -0
- package/dist/program-context-BPos0ivo.js +496 -0
- package/dist/progress-oiAjiiNi.js +133 -0
- package/dist/prompt-style-Cm4wOtKm.js +9 -0
- package/dist/pw-ai-4QbK5YFe.js +1865 -0
- package/dist/pw-ai-BWz3Cxt7.js +1868 -0
- package/dist/pw-ai-C83HBue2.js +1867 -0
- package/dist/qmd-manager-BcMeZiGD.js +938 -0
- package/dist/qmd-manager-CPypGJ0P.js +935 -0
- package/dist/qmd-manager-CRrSkfia.js +937 -0
- package/dist/register.agent-DDY8KJhn.js +265 -0
- package/dist/register.agent-DKawm-9d.js +1003 -0
- package/dist/register.anima-CEWUo29k.js +193 -0
- package/dist/register.anima-DBWz2rk_.js +193 -0
- package/dist/register.configure-BX67qV8k.js +103 -0
- package/dist/register.configure-CWsySuiq.js +101 -0
- package/dist/register.maintenance-0k-ZNhDg.js +543 -0
- package/dist/register.maintenance-BIwx1fzX.js +543 -0
- package/dist/register.message-CXPsoakA.js +657 -0
- package/dist/register.message-DA3jvfgI.js +660 -0
- package/dist/register.onboard-C4HG7Hqv.js +170 -0
- package/dist/register.onboard-GOpdif-j.js +170 -0
- package/dist/register.setup-B17vZT7C.js +175 -0
- package/dist/register.setup-GJyUDCqh.js +175 -0
- package/dist/register.status-health-sessions-D5876dGx.js +313 -0
- package/dist/register.status-health-sessions-lOewVIZR.js +142 -0
- package/dist/register.subclis-Dwnujj5C.js +255 -0
- package/dist/reply-CR5T_oQJ.js +32212 -0
- package/dist/reply-prefix-BcrS4Umd.js +100 -0
- package/dist/reply-prefix-Btb5o2NH.js +100 -0
- package/dist/reply-r089HuRA.js +32212 -0
- package/dist/routes-B4czFzIb.js +1820 -0
- package/dist/routes-ucJWAk5O.js +1820 -0
- package/dist/rpc-BnKxnQ0v.js +70 -0
- package/dist/rpc-DgE-xnyx.js +70 -0
- package/dist/run-main-B74kv84C.js +371 -0
- package/dist/runtime-guard-CKFdts2L.js +60 -0
- package/dist/sandbox-CJTS3er6.js +858 -0
- package/dist/sandbox-DBSiVHt_.js +859 -0
- package/dist/sandbox-cli-CrkjyU5M.js +461 -0
- package/dist/sandbox-cli-D1r5y6Sz.js +458 -0
- package/dist/security-cli-BZUdnkhn.js +462 -0
- package/dist/security-cli-DS09ebvA.js +465 -0
- package/dist/server-context-C0xZbYhg.js +824 -0
- package/dist/server-context-DVh2z7om.js +824 -0
- package/dist/server-node-events-bu9lpkMH.js +233 -0
- package/dist/server-node-events-i1Rrww31.js +231 -0
- package/dist/service-CJJwLEor.js +642 -0
- package/dist/service-DxLxBhaU.js +642 -0
- package/dist/service-audit-DB4Y3Ekp.js +488 -0
- package/dist/service-audit-M8y4TXVb.js +488 -0
- package/dist/session-CGxOLFs2.js +179 -0
- package/dist/session-DTTbdKb0.js +181 -0
- package/dist/session-cost-usage-FcdJl9c3.js +600 -0
- package/dist/session-cost-usage-qdfsGU2a.js +600 -0
- package/dist/session-yOhWcsD2.js +181 -0
- package/dist/sessions-B-Cu7JZq.js +1296 -0
- package/dist/sessions-BgLN4KFr.js +180 -0
- package/dist/sessions-CnRjwdVr.js +1296 -0
- package/dist/sessions-wRKla1Qh.js +2038 -0
- package/dist/shared-DS3UaJSP.js +66 -0
- package/dist/shared-DxNHzky3.js +77 -0
- package/dist/shared-Qpt4hUDi.js +66 -0
- package/dist/shared-kzrojZ1B.js +77 -0
- package/dist/skill-scanner-DLJji5Ye.js +263 -0
- package/dist/skills-BWFIEp4j.js +807 -0
- package/dist/skills-DV4zKdCx.js +808 -0
- package/dist/skills-cli-BY53ILm2.js +289 -0
- package/dist/skills-cli-CO3gxl8A.js +286 -0
- package/dist/skills-status-DX5pcqY3.js +166 -0
- package/dist/skills-status-zhcKzGkp.js +166 -0
- package/dist/sqlite-B6MojU1I.js +321 -0
- package/dist/sqlite-CuprTGR7.js +453 -0
- package/dist/sqlite-dzD-jMjs.js +368 -0
- package/dist/start-Cu3aLoSf.js +297 -0
- package/dist/start-Dz7tMAl8.js +296 -0
- package/dist/status-CaSxhxfV.js +2132 -0
- package/dist/status-D2C0JCX3.js +2137 -0
- package/dist/status-DlFMsQzh.js +27 -0
- package/dist/status-G0CITnKR.js +27 -0
- package/dist/status.update-CHjhVxJY.js +79 -0
- package/dist/status.update-DVFelehi.js +79 -0
- package/dist/subagent-registry-3Xb4el-8.js +14 -0
- package/dist/subagent-registry-CdSjz14I.js +2760 -0
- package/dist/subagent-registry-DNDhbHWi.js +2759 -0
- package/dist/subsystem-DfKstnEK.js +860 -0
- package/dist/system-cli-B5mt0FWa.js +82 -0
- package/dist/system-cli-Dg3UQ3Zz.js +79 -0
- package/dist/systemd-B43AvOGx.js +452 -0
- package/dist/systemd-RpPE0XGg.js +452 -0
- package/dist/systemd-hints-DMJT-Bbc.js +36 -0
- package/dist/systemd-hints-vRInKcz9.js +36 -0
- package/dist/systemd-linger-Dzyxqsod.js +75 -0
- package/dist/systemd-linger-EujbmI5A.js +75 -0
- package/dist/table-DhXHfRX2.js +279 -0
- package/dist/table-bWCLW-3P.js +279 -0
- package/dist/timeout-Ddn-5kAO.js +232 -0
- package/dist/tokens-3psI_Qk2.js +14 -0
- package/dist/tokens-BaM53PEx.js +14 -0
- package/dist/trash-Bmxs1Rnm.js +23 -0
- package/dist/trash-C39a6hKA.js +23 -0
- package/dist/tui-BHgBWhHE.js +3894 -0
- package/dist/tui-cli-B9Sq5-cC.js +50 -0
- package/dist/tui-cli-Dw7v4JoJ.js +47 -0
- package/dist/tui-mUwDwqvd.js +3894 -0
- package/dist/update-DF0GHG0j.js +317 -0
- package/dist/update-DoZLVjva.js +317 -0
- package/dist/update-check-Bt1dVPVN.js +400 -0
- package/dist/update-check-D5qAKes7.js +400 -0
- package/dist/update-cli-BNu2Oi7H.js +1105 -0
- package/dist/update-cli-D36AmALA.js +1105 -0
- package/dist/update-runner-CNQQaTwA.js +894 -0
- package/dist/update-runner-CvxZmbu-.js +894 -0
- package/dist/usage-BGCwNnjk.js +4516 -0
- package/dist/utils-DZ8pnOD5.js +243 -0
- package/dist/web-B5QG839O.js +46842 -0
- package/dist/web-Cmnvk9v0.js +2203 -0
- package/dist/web-Cv2KnTnL.js +63 -0
- package/dist/webhooks-cli-B6y89Pj_.js +319 -0
- package/dist/webhooks-cli-BDzHON4w.js +316 -0
- package/dist/whatsapp-actions-C_5MwVxM.js +45 -0
- package/dist/whatsapp-actions-hgYA12To.js +53 -0
- package/dist/whatsapp-actions-zTiVOoOV.js +49 -0
- package/dist/widearea-dns-BeIdnISJ.js +127 -0
- package/dist/widearea-dns-CF1gxpJ-.js +127 -0
- package/dist/workspace-DLna1IxR.js +649 -0
- package/dist/ws-log-Q4wO1Ztb.js +267 -0
- package/dist/ws-log-xF0kxDzp.js +267 -0
- package/package.json +1 -2
- package/dist/accounts-Cc5E4IDO.js +0 -260
- package/dist/accounts-CcVrwKqv.js +0 -259
- package/dist/acp-cli-DvphOKuh.js +0 -1081
- package/dist/acp-cli-p28pQ65a.js +0 -1084
- package/dist/agent-Cj7uDJaZ.js +0 -725
- package/dist/agent-Cuj9-2sT.js +0 -725
- package/dist/agent-events-BEBQsyE5.js +0 -182
- package/dist/agent-scope-BVf4aSwY.js +0 -112
- package/dist/agent-scope-OZi7lb8S.js +0 -452
- package/dist/agent-scope-V1bi9OYL.js +0 -452
- package/dist/agents-BUWqn_Ui.js +0 -774
- package/dist/agents.config-Dvo2ULxs.js +0 -182
- package/dist/agents.config-d6H0_3oj.js +0 -182
- package/dist/argv-DqUHKf0o.js +0 -73
- package/dist/audit-C6okOOSh.js +0 -2401
- package/dist/audit-VWjIdwC7.js +0 -2401
- package/dist/auth-91o2YM96.js +0 -648
- package/dist/auth-choice-CAmACV13.js +0 -2681
- package/dist/auth-choice-p3SeHPj2.js +0 -2681
- package/dist/auth-health-B_jXrWe6.js +0 -149
- package/dist/auth-health-DCicUKYR.js +0 -149
- package/dist/auth-lZ26wsbN.js +0 -639
- package/dist/auth-profiles-CCDD56dU.js +0 -1564
- package/dist/auth-profiles-DxI8L7bs.js +0 -2689
- package/dist/banner-Cohn04J6.js +0 -294
- package/dist/browser-cli-DANzjztE.js +0 -1676
- package/dist/browser-cli-WjsVH741.js +0 -1679
- package/dist/call-BAHvlu2G.js +0 -282
- package/dist/call-Ct7EGP_L.js +0 -282
- package/dist/catalog-BAayBt1L.js +0 -185
- package/dist/catalog-BNsf97BM.js +0 -185
- package/dist/channel-options-Dx9nPlX8.js +0 -33
- package/dist/channel-options-ZdvXrTGs.js +0 -32
- package/dist/channel-selection-CujyiWGM.js +0 -51
- package/dist/channel-selection-DfGpCyh2.js +0 -51
- package/dist/channel-web-CC0hkgkR.js +0 -2162
- package/dist/channels-cli-D7lNBpIb.js +0 -1304
- package/dist/channels-cli-DUPG8WDv.js +0 -1306
- package/dist/channels-status-issues-DBc1pU_R.js +0 -18
- package/dist/channels-status-issues-DjO9MHIG.js +0 -18
- package/dist/chrome-Bi6iZ5sG.js +0 -1601
- package/dist/chrome-DNSv7Cpy.js +0 -1629
- package/dist/chrome-DScZx4Lk.js +0 -1601
- package/dist/chunk-mxPVo000.js +0 -348
- package/dist/clack-prompter-B0kl7shw.js +0 -92
- package/dist/clack-prompter-B1YxZdRy.js +0 -92
- package/dist/cli-CfHUkOD0.js +0 -101
- package/dist/cli-ClMrIh6l.js +0 -99
- package/dist/cli-session-BkPTd9Pk.js +0 -5463
- package/dist/cli-session-Dd8DKb5a.js +0 -5408
- package/dist/client-C1avc0vD.js +0 -1692
- package/dist/client-CC94YZrT.js +0 -1692
- package/dist/clipboard-B2fBy8tG.js +0 -31
- package/dist/clipboard-BbGnZskJ.js +0 -31
- package/dist/command-format-Clp46jkj.js +0 -38
- package/dist/command-format-DELazozB.js +0 -52
- package/dist/command-format-SkzzRqR1.js +0 -52
- package/dist/command-registry-DZ4hkmA0.js +0 -248
- package/dist/commands-DtYZJSPn.js +0 -568
- package/dist/commands-Dujk1JmY.js +0 -568
- package/dist/commands-registry-Bd0xbvwG.js +0 -766
- package/dist/commands-registry-DYfRSVF3.js +0 -766
- package/dist/common-D6bu0zHC.js +0 -287
- package/dist/common-zW9Y2P1B.js +0 -287
- package/dist/completion-cli-tSe7Pmqm.js +0 -431
- package/dist/completion-cli-vn4IScs5.js +0 -432
- package/dist/config-C8rUDJXY.js +0 -5704
- package/dist/config-CLZ_XGVw.js +0 -6523
- package/dist/config-SY8M0kM_.js +0 -5705
- package/dist/config-cli-1V7D2Wsw.js +0 -247
- package/dist/config-cli-CjWEC81L.js +0 -244
- package/dist/config-guard-BW2gpKj_.js +0 -93
- package/dist/config-guard-BvxuzHpo.js +0 -76
- package/dist/config-sync-CoIIbEOe.js +0 -91
- package/dist/config-sync-DvAttep0.js +0 -91
- package/dist/configure-Bf0oupCE.js +0 -959
- package/dist/configure-DRM-7zFf.js +0 -960
- package/dist/context-D5iEFzv9.js +0 -60
- package/dist/control-service-C8m8F9pr.js +0 -72
- package/dist/control-service-DKotCWCg.js +0 -72
- package/dist/cron-cli-DB_FLYHD.js +0 -448
- package/dist/cron-cli-bxm5lrrO.js +0 -451
- package/dist/daemon-cli-1LsOnICv.js +0 -566
- package/dist/daemon-cli-CC2NrJ7a.js +0 -565
- package/dist/daemon-runtime-BXZhtBL9.js +0 -460
- package/dist/daemon-runtime-DW4USC7r.js +0 -460
- package/dist/deliver-B4HuPwJA.js +0 -1162
- package/dist/deliver-LiY5oL52.js +0 -1097
- package/dist/deliver-xrmk7xjh.js +0 -1097
- package/dist/delivery-queue-TnQykYsg.js +0 -220
- package/dist/deps-CMMOiOsF.js +0 -42
- package/dist/devices-cli-Be5he2SA.js +0 -195
- package/dist/devices-cli-z6ecoFe9.js +0 -198
- package/dist/diagnostics-Dj75aEHN.js +0 -35
- package/dist/diagnostics-DlIw6fqD.js +0 -35
- package/dist/directory-cli-CEy-0nxj.js +0 -243
- package/dist/directory-cli-DpzKcigr.js +0 -246
- package/dist/dispatcher-10Shiuz3.js +0 -100
- package/dist/dispatcher-3Jae6AiW.js +0 -100
- package/dist/dns-cli-Bat1pkc-.js +0 -200
- package/dist/dns-cli-NohNyEo0.js +0 -197
- package/dist/dock-DbxBBv30.js +0 -753
- package/dist/dock-cPBY4qGl.js +0 -753
- package/dist/docs-cli-BWp6p-Tq.js +0 -161
- package/dist/docs-cli-x22FnZfL.js +0 -159
- package/dist/doctor-BrT5m_on.js +0 -1815
- package/dist/doctor-Pp2HVnjM.js +0 -1813
- package/dist/doctor-completion-DNTimX9o.js +0 -92
- package/dist/doctor-completion-ylN9QAJ6.js +0 -92
- package/dist/doctor-config-flow-D1w3700T.js +0 -1232
- package/dist/doctor-config-flow-Dq50iE1R.js +0 -1232
- package/dist/engine-B9avUJL5.js +0 -563
- package/dist/engine-BiUQ25D4.js +0 -563
- package/dist/env-0lJfCPsw.js +0 -32
- package/dist/exec-BenD3A5l.js +0 -1167
- package/dist/exec-Bv3pyjeM.js +0 -255
- package/dist/exec-approvals-CdLmKX2R.js +0 -1221
- package/dist/exec-approvals-cli-DXfV6G8H.js +0 -368
- package/dist/exec-approvals-cli-J2cZs10o.js +0 -371
- package/dist/frontmatter-YijVi0FQ.js +0 -204
- package/dist/gateway-cli-DOAbA0pc.js +0 -19972
- package/dist/gateway-cli-QpWtBhQy.js +0 -19971
- package/dist/gateway-rpc-DJKBil9s.js +0 -28
- package/dist/gateway-rpc-DVterpLP.js +0 -28
- package/dist/github-copilot-auth-4IUFp669.js +0 -1418
- package/dist/github-copilot-auth-C9E0IROs.js +0 -1418
- package/dist/gmail-setup-utils-BPo_LkKI.js +0 -428
- package/dist/gmail-setup-utils-D3Yqgor7.js +0 -428
- package/dist/health-BeZnqp6m.js +0 -1258
- package/dist/health-Cn2OoVWZ.js +0 -1253
- package/dist/health-format-CdP99j3Y.js +0 -208
- package/dist/health-format-JEChH08S.js +0 -208
- package/dist/heartbeat-visibility-BL3WAchI.js +0 -98
- package/dist/heartbeat-visibility-CQ9QimI7.js +0 -98
- package/dist/help-format-Dl4bsrLI.js +0 -17
- package/dist/helpers-ZKNRexvX.js +0 -10
- package/dist/hooks-cli-D99hXt7K.js +0 -991
- package/dist/hooks-cli-DMB8RiEO.js +0 -993
- package/dist/hooks-status-B-e96dZj.js +0 -356
- package/dist/hooks-status-C_9sE0ox.js +0 -356
- package/dist/image-ops-Dlt3T7th.js +0 -541
- package/dist/image-ops-omlvdfah.js +0 -541
- package/dist/init-Bm04RagW.js +0 -122
- package/dist/init-CaJBf4p1.js +0 -122
- package/dist/installs-C2iMRBVz.js +0 -383
- package/dist/installs-D-cPGdCw.js +0 -383
- package/dist/ipv4-Bf7NS3QU.js +0 -1964
- package/dist/ipv4-wWNs8IH_.js +0 -1964
- package/dist/lanes-CNxj3tit.js +0 -232
- package/dist/lifecycle-core-B_7XRcvF.js +0 -388
- package/dist/lifecycle-core-By83PVAK.js +0 -387
- package/dist/links-BfjHVTB_.js +0 -15
- package/dist/links-DPGe0OHw.js +0 -15
- package/dist/logging-DB6BQmhi.js +0 -15
- package/dist/logging-mcb66J0p.js +0 -15
- package/dist/login-BDCg6D0N.js +0 -61
- package/dist/login-BDfnbjnZ.js +0 -59
- package/dist/login-BqH1itcg.js +0 -61
- package/dist/login-qr-CyOw3R4r.js +0 -321
- package/dist/login-qr-D8ECtb72.js +0 -323
- package/dist/login-qr-RnR7e4Bw.js +0 -326
- package/dist/logs-cli--j89L74J.js +0 -245
- package/dist/logs-cli-DpEMg_Gq.js +0 -242
- package/dist/manager-B4OyvcxT.js +0 -3244
- package/dist/manager-Cqc1CeH7.js +0 -3246
- package/dist/manager-DUyQPFvj.js +0 -3244
- package/dist/manifest-registry-CW1zCyRF.js +0 -748
- package/dist/manifest-registry-D4lM2RdV.js +0 -748
- package/dist/markdown-tables-BT1X6jqH.js +0 -347
- package/dist/markdown-tables-DHgOK2vI.js +0 -348
- package/dist/media-THyainiE.js +0 -1342
- package/dist/memory-cli-BKocCWXM.js +0 -868
- package/dist/memory-cli-Jmma-xI_.js +0 -869
- package/dist/message-channel-dSTVVCyX.js +0 -110
- package/dist/migrate-BR6iAIjO.js +0 -157
- package/dist/migrate-D0EcMs0f.js +0 -157
- package/dist/model-selection-YcSr9CgC.js +0 -2691
- package/dist/models-1vUQBVfw.js +0 -2510
- package/dist/models-cli-BK3BwUhL.js +0 -2739
- package/dist/models-cli-DECrM8oA.js +0 -258
- package/dist/net-B5lXhYLV.js +0 -218
- package/dist/node-cli-cLHUNpPD.js +0 -1319
- package/dist/node-cli-fO7Y132S.js +0 -1322
- package/dist/node-service-BFxHJsno.js +0 -67
- package/dist/node-service-DUnan4uK.js +0 -67
- package/dist/nodes-cli-BCq35E6N.js +0 -1200
- package/dist/nodes-cli-vD7MwAKP.js +0 -1197
- package/dist/nodes-screen-1YiLkqr5.js +0 -234
- package/dist/nodes-screen-DZeD8hE5.js +0 -234
- package/dist/note-Bi8Wb8DV.js +0 -73
- package/dist/note-uiuPxhyX.js +0 -73
- package/dist/npm-registry-spec-B-XIShkB.js +0 -351
- package/dist/npm-registry-spec-za3itb5Y.js +0 -351
- package/dist/onboard-Ds6w_sWo.js +0 -1165
- package/dist/onboard-SAVx3bp4.js +0 -1166
- package/dist/onboard-channels-Cg_EkBa4.js +0 -672
- package/dist/onboard-channels-D7NbA55V.js +0 -672
- package/dist/onboard-helpers-DO_hgZb9.js +0 -365
- package/dist/onboard-helpers-_XgJgeqh.js +0 -365
- package/dist/onboarding-3hLmDd0r.js +0 -911
- package/dist/onboarding-B4LKLsbU.js +0 -910
- package/dist/orchestrator-BKzmyBWy.js +0 -357
- package/dist/orchestrator-BN3QCz2s.js +0 -357
- package/dist/outbound-BgA9hNlP.js +0 -2062
- package/dist/outbound-CjdvVhUI.js +0 -214
- package/dist/outbound-DOGe6qb2.js +0 -214
- package/dist/outbound-send-deps-Du5aBpd7.js +0 -55
- package/dist/pairing-cli-2vnyg_Nd.js +0 -118
- package/dist/pairing-cli-BH1KQtNV.js +0 -121
- package/dist/pairing-store-DJz_9Gv0.js +0 -388
- package/dist/pairing-store-DmOzxcuk.js +0 -388
- package/dist/path-env-Bu6k0jDQ.js +0 -89
- package/dist/path-env-C0zQSjw8.js +0 -89
- package/dist/paths-BTc4nk-6.js +0 -126
- package/dist/paths-BgUi2Z2G.js +0 -54
- package/dist/paths-C6VCWKo3.js +0 -238
- package/dist/paths-CCxa0o9c.js +0 -222
- package/dist/paths-CxRf2rBG.js +0 -129
- package/dist/paths-hcX1Gqg5.js +0 -129
- package/dist/pi-auth-json-B68R7q7_.js +0 -82
- package/dist/pi-auth-json-CR0jXAgq.js +0 -78
- package/dist/pi-auth-json-ZYzi3nxs.js +0 -80
- package/dist/pi-model-discovery-Cxs4pvC2.js +0 -3
- package/dist/pi-tools.policy-D81U5xy0.js +0 -200
- package/dist/pi-tools.policy-DSHkkb5b.js +0 -200
- package/dist/plugin-auto-enable-CxF4bpDN.js +0 -282
- package/dist/plugin-auto-enable-jNaAeyEh.js +0 -282
- package/dist/plugin-registry-C7XWotZG.js +0 -32
- package/dist/plugin-registry-DcUCbGax.js +0 -32
- package/dist/plugins-B362e77G.js +0 -168
- package/dist/plugins-CmSUIUNi.js +0 -38
- package/dist/plugins-cli-BsCEnoQ7.js +0 -734
- package/dist/plugins-cli-QSIsMUG7.js +0 -736
- package/dist/polls-CItfB1H8.js +0 -1343
- package/dist/ports-BVLMN1Sr.js +0 -96
- package/dist/ports-CqLSlU6Z.js +0 -317
- package/dist/ports-D94CwCrv.js +0 -344
- package/dist/ports-D_NHthOz.js +0 -96
- package/dist/program-DkJHjI0R.js +0 -176
- package/dist/program-context-DnyGM2SC.js +0 -496
- package/dist/progress-Bek_GyWS.js +0 -133
- package/dist/prompt-style-lu0clOOE.js +0 -9
- package/dist/pw-ai-BLVMuSLv.js +0 -1867
- package/dist/pw-ai-DZJWEF_f.js +0 -1865
- package/dist/pw-ai-dzf-ptcn.js +0 -1868
- package/dist/qmd-manager-Cur_Ekn0.js +0 -937
- package/dist/qmd-manager-DNAUuwjK.js +0 -938
- package/dist/qmd-manager-DepEoASu.js +0 -935
- package/dist/register.agent-CSWvzOkR.js +0 -265
- package/dist/register.agent-UeH2NXmH.js +0 -1003
- package/dist/register.anima-DOdee0dh.js +0 -193
- package/dist/register.anima-HHDWsz6r.js +0 -193
- package/dist/register.configure-CSJFxdz9.js +0 -103
- package/dist/register.configure-D84Fvcz4.js +0 -101
- package/dist/register.maintenance-B3pvNbZb.js +0 -543
- package/dist/register.maintenance-BKVOwkw6.js +0 -543
- package/dist/register.message-BAO6CPl2.js +0 -657
- package/dist/register.message-OXoOKE_6.js +0 -660
- package/dist/register.onboard-BK_ixVmD.js +0 -170
- package/dist/register.onboard-cfCaPx6j.js +0 -170
- package/dist/register.setup-BGfDnzph.js +0 -175
- package/dist/register.setup-Y-Q74M-0.js +0 -175
- package/dist/register.status-health-sessions-CT14eitH.js +0 -142
- package/dist/register.status-health-sessions-TfZMzAUn.js +0 -313
- package/dist/register.subclis-BZwdlNHC.js +0 -255
- package/dist/reply-mlsExaZm.js +0 -32212
- package/dist/reply-prefix-B0CfR4bM.js +0 -100
- package/dist/reply-prefix-w4a39ybC.js +0 -100
- package/dist/reply-qalRISe_.js +0 -32212
- package/dist/routes-CENsHJyg.js +0 -1820
- package/dist/routes-DO0HqW2e.js +0 -1820
- package/dist/rpc-C0pjNhBi.js +0 -70
- package/dist/rpc-DZ44PIXE.js +0 -70
- package/dist/run-main-BMpKw8Mp.js +0 -371
- package/dist/runtime-guard-BSUFiAQV.js +0 -60
- package/dist/sandbox-BIGfMYEI.js +0 -858
- package/dist/sandbox-DxP3IpUP.js +0 -859
- package/dist/sandbox-cli-DtLGH8sL.js +0 -461
- package/dist/sandbox-cli-_Tg7lfJ_.js +0 -458
- package/dist/security-cli-BRwgbedo.js +0 -462
- package/dist/security-cli-D3bSuyZt.js +0 -465
- package/dist/server-context-49XFFxFg.js +0 -824
- package/dist/server-context-LrlgrZzS.js +0 -824
- package/dist/server-node-events-Dm52i7NW.js +0 -231
- package/dist/server-node-events-QX523UyF.js +0 -233
- package/dist/service-BNVpYcQe.js +0 -642
- package/dist/service-D56aMXUB.js +0 -642
- package/dist/service-audit-D0X_XAB2.js +0 -488
- package/dist/service-audit-qmf6XMmP.js +0 -488
- package/dist/session-CrQQLLhx.js +0 -179
- package/dist/session-LocsOOWJ.js +0 -181
- package/dist/session-Vlce2BAT.js +0 -181
- package/dist/session-cost-usage-BwiTZuKl.js +0 -600
- package/dist/session-cost-usage-DT9YNXTJ.js +0 -600
- package/dist/sessions-BfV53TbG.js +0 -1296
- package/dist/sessions-BimpX_km.js +0 -180
- package/dist/sessions-DcXpzig0.js +0 -1296
- package/dist/sessions-Wd18dukK.js +0 -2038
- package/dist/shared-Bsr69u_7.js +0 -77
- package/dist/shared-Cgly1vPb.js +0 -66
- package/dist/shared-JOo05hST.js +0 -66
- package/dist/shared-f7dvQsi7.js +0 -77
- package/dist/skill-scanner-CkaVLABv.js +0 -263
- package/dist/skills-B-G7UHOa.js +0 -808
- package/dist/skills-B5LQx4lT.js +0 -807
- package/dist/skills-cli-DUGe2ZWW.js +0 -286
- package/dist/skills-cli-DtOk0bvK.js +0 -289
- package/dist/skills-status-Clq9ZnYu.js +0 -166
- package/dist/skills-status-JQluhU-P.js +0 -166
- package/dist/sqlite-BukcjdJa.js +0 -321
- package/dist/sqlite-CGcOZZ0C.js +0 -368
- package/dist/sqlite-Ck6f9KWc.js +0 -453
- package/dist/start--xmSFepB.js +0 -372
- package/dist/start-BdlZbqrr.js +0 -371
- package/dist/status-BgoeFm6g.js +0 -2137
- package/dist/status-BjjDrUq7.js +0 -27
- package/dist/status-Ct0DgOZ-.js +0 -2132
- package/dist/status-RA_uNmK0.js +0 -27
- package/dist/status.update-BjOH3GlS.js +0 -79
- package/dist/status.update-DLU1qBf0.js +0 -79
- package/dist/subagent-registry-9RLdKxES.js +0 -2760
- package/dist/subagent-registry-Byuex3zp.js +0 -2759
- package/dist/subagent-registry-DOBunBYS.js +0 -14
- package/dist/subsystem-Dowf8fSU.js +0 -860
- package/dist/system-cli-C5oBpzni.js +0 -79
- package/dist/system-cli-DXNKD_Id.js +0 -82
- package/dist/systemd-BSrHDyeU.js +0 -452
- package/dist/systemd-By5xdSB4.js +0 -452
- package/dist/systemd-hints-BtjL_5Rh.js +0 -36
- package/dist/systemd-hints-sJmr6cjb.js +0 -36
- package/dist/systemd-linger-CTmV2Gci.js +0 -75
- package/dist/systemd-linger-CmyqQkeC.js +0 -75
- package/dist/table-BL0lJzsm.js +0 -279
- package/dist/table-DoiRPsn0.js +0 -279
- package/dist/timeout-CswI_K-U.js +0 -232
- package/dist/tokens-C-X7wDKj.js +0 -14
- package/dist/tokens-DkvqA72p.js +0 -14
- package/dist/trash-BJLK1vMn.js +0 -23
- package/dist/trash-_x5UZ94k.js +0 -23
- package/dist/tui-BHjxDFZC.js +0 -3894
- package/dist/tui-CgOocwN8.js +0 -3894
- package/dist/tui-cli-5ANH8dE5.js +0 -47
- package/dist/tui-cli-BQ4P-JW_.js +0 -50
- package/dist/update-LFgxHHPd.js +0 -317
- package/dist/update-TxptCqk7.js +0 -317
- package/dist/update-check-CWc7YXmc.js +0 -400
- package/dist/update-check-IhlWaui6.js +0 -400
- package/dist/update-cli-PtXU62w7.js +0 -1105
- package/dist/update-cli-Va0EtETG.js +0 -1105
- package/dist/update-runner-BLeKFkiB.js +0 -894
- package/dist/update-runner-Iuzpc-_y.js +0 -894
- package/dist/usage-ApGvBLVg.js +0 -4516
- package/dist/utils-Bsw__U-F.js +0 -243
- package/dist/web-B6_Ky60G.js +0 -63
- package/dist/web-EZLQEWXY.js +0 -46842
- package/dist/web-pec8YJUX.js +0 -2203
- package/dist/webhooks-cli-BYQKTHTp.js +0 -319
- package/dist/webhooks-cli-C2_xtsUQ.js +0 -316
- package/dist/whatsapp-actions-C72VCq8f.js +0 -49
- package/dist/whatsapp-actions-Ck9Uv0Nw.js +0 -45
- package/dist/whatsapp-actions-D0reTj2k.js +0 -53
- package/dist/widearea-dns-B6ocX23x.js +0 -127
- package/dist/widearea-dns-NsEUNYwz.js +0 -127
- package/dist/workspace-Dcfoy5JJ.js +0 -649
- package/dist/ws-log-N8R5MvGE.js +0 -267
- package/dist/ws-log-gwFxPxj5.js +0 -267
- /package/dist/{auto-update-CUeF99gI.js → auto-update-CpF0fycd.js} +0 -0
- /package/dist/{auto-update-cgkp9ZTJ.js → auto-update-DNWdO7uF.js} +0 -0
- /package/dist/{brew-CVZkr0GU.js → brew-nqf_MiE4.js} +0 -0
- /package/dist/{budget-DxYQSekw.js → budget-CPedI-qW.js} +0 -0
- /package/dist/{budget-BWBp8Res.js → budget-CRpvqDRX.js} +0 -0
- /package/dist/{cli-utils-DtAxdCte.js → cli-utils-C1YHVD4o.js} +0 -0
- /package/dist/{command-options-CSbuuqHr.js → command-options-BbponVnw.js} +0 -0
- /package/dist/{command-options-Cp1tf96a.js → command-options-s0gnvXnS.js} +0 -0
- /package/dist/{constants-O8yBqCBv.js → constants-Dhb6zSIV.js} +0 -0
- /package/dist/{dangerous-tools-5ObDWy1N.js → dangerous-tools-DGTtJ_JR.js} +0 -0
- /package/dist/{dangerous-tools-Jwr7jqNw.js → dangerous-tools-DxrfTOfT.js} +0 -0
- /package/dist/{delivery-queue-B6IHz4Ry.js → delivery-queue-Bxm0nzw7.js} +0 -0
- /package/dist/{display-BDOsXu8F.js → display-Jy3UdGzA.js} +0 -0
- /package/dist/{errors-CHow2wtt.js → errors-CKaCqKga.js} +0 -0
- /package/dist/{exec-BizYYQgP.js → exec-DDmuVVNq.js} +0 -0
- /package/dist/{format-Mq6iU0_5.js → format-ByEjgyTF.js} +0 -0
- /package/dist/{format-duration-DhWzz_5b.js → format-duration-Aaj5tjJd.js} +0 -0
- /package/dist/{format-relative-C6kUHuOj.js → format-relative-79_Y1n2Y.js} +0 -0
- /package/dist/{help-format-DUBI91Ti.js → help-format-BMKzarov.js} +0 -0
- /package/dist/{helpers-eJFa4K6r.js → helpers-DpEB9Mh0.js} +0 -0
- /package/dist/{helpers-DLgbkcEn.js → helpers-FMld9sBT.js} +0 -0
- /package/dist/{input-provenance-DJBdpeKk.js → input-provenance-Cy_KnBlP.js} +0 -0
- /package/dist/{is-main-Dt9DTcH1.js → is-main-yjaVwMtJ.js} +0 -0
- /package/dist/{loader-l2OBdJ8x.js → loader-Br7Vr0zn.js} +0 -0
- /package/dist/{loader-BoYxRfcW.js → loader-CkmOrXcC.js} +0 -0
- /package/dist/{logging-BdnOSVPD.js → logging-CY-Q5cwf.js} +0 -0
- /package/dist/{message-channel-w4F2b2F6.js → message-channel-dua8OOGJ.js} +0 -0
- /package/dist/{mime-B1ZoR53M.js → mime-CBg4KybI.js} +0 -0
- /package/dist/{model-param-b-DPwyNGn8.js → model-param-b-DW9f0NN8.js} +0 -0
- /package/dist/{node-match-8XZnaid6.js → node-match-BV8bTBd4.js} +0 -0
- /package/dist/{normalize-GDK8JTNW.js → normalize-_lmlBOW9.js} +0 -0
- /package/dist/{openclaw-root-C85WMnVV.js → openclaw-root-JPvmPTf7.js} +0 -0
- /package/dist/{outbound-send-deps-ANnAhImn.js → outbound-send-deps-BfUvuWGa.js} +0 -0
- /package/dist/{parse-6-2MDhdT.js → parse-CZRwKocn.js} +0 -0
- /package/dist/{parse-log-line-Bqh1SSzC.js → parse-log-line-CvrZEK6A.js} +0 -0
- /package/dist/{parse-log-line-DUZCjXbl.js → parse-log-line-mLdat0AH.js} +0 -0
- /package/dist/{parse-port-BKB9Exlg.js → parse-port-BSOOdo7I.js} +0 -0
- /package/dist/{parse-port-DrfvwwiL.js → parse-port-Y0NK62x1.js} +0 -0
- /package/dist/{parse-timeout-Di_tcEmi.js → parse-timeout-DVPQ3n9j.js} +0 -0
- /package/dist/{paths-DcVEkYX5.js → paths-DHjlJ6cn.js} +0 -0
- /package/dist/{pi-model-discovery-DsRqYJLy.js → pi-model-discovery-DzEIEgHL.js} +0 -0
- /package/dist/{plugins-CDJw924T.js → plugins-D6PBOdkn.js} +0 -0
- /package/dist/{program-context-Bvn8046-.js → program-context-Q1hkT73c.js} +0 -0
- /package/dist/{progress-CbZ2D53A.js → progress-C9Ha1NJh.js} +0 -0
- /package/dist/{prompt-style-DKy6qQxR.js → prompt-style-DQi8j03a.js} +0 -0
- /package/dist/{prompts-BI__va99.js → prompts-BEHxUC3w.js} +0 -0
- /package/dist/{prompts-_dDWkCAz.js → prompts-CSOhuiqe.js} +0 -0
- /package/dist/{queue-D_u34pbL.js → queue-BJGo7kAB.js} +0 -0
- /package/dist/{queue-PG591iID.js → queue-DYgUbdoq.js} +0 -0
- /package/dist/{redact-ClVwO7Nn.js → redact-CyKvdFrg.js} +0 -0
- /package/dist/{registry-Bs_DJK9E.js → registry-C5MAYD4V.js} +0 -0
- /package/dist/{registry-D_zlP1U-.js → registry-CRrXXVs0.js} +0 -0
- /package/dist/{requirements-BzZxj2Wu.js → requirements-CGkxTCu4.js} +0 -0
- /package/dist/{requirements-DIW1svgA.js → requirements-CIDaOcbO.js} +0 -0
- /package/dist/{runtime-guard-DeOXA_86.js → runtime-guard-nL3Lp8T-.js} +0 -0
- /package/dist/{secret-equal-Dghy3xsA.js → secret-equal-DJpmLXlG.js} +0 -0
- /package/dist/{send-BhAfdGII.js → send-CTcxgDDU.js} +0 -0
- /package/dist/{send-ga9udK1_.js → send-DPezUR3-.js} +0 -0
- /package/dist/{send-C2t9xpXI.js → send-DZQTaG7-.js} +0 -0
- /package/dist/{send-DigO-i9j.js → send-VDff2gra.js} +0 -0
- /package/dist/{send-Dz2BDHll.js → send-bgQNV8d1.js} +0 -0
- /package/dist/{session-key-BGiG_JcT.js → session-key-CQT-NR6w.js} +0 -0
- /package/dist/{shell-argv-CAq1mLa2.js → shell-argv-n9IueeJQ.js} +0 -0
- /package/dist/{skill-scanner-Coo4QoCd.js → skill-scanner-o6NgVMD9.js} +0 -0
- /package/dist/{status-CMnlcBVc.js → status-C53kTIXF.js} +0 -0
- /package/dist/{status-tDZPwewW.js → status-CZDDA_Sy.js} +0 -0
- /package/dist/{system-run-command-X9lDJIy0.js → system-run-command-BCjUffN9.js} +0 -0
- /package/dist/{system-run-command-DGk7dwQP.js → system-run-command-CqAqKL9K.js} +0 -0
- /package/dist/{tailnet-CuiNECdL.js → tailnet-Ciwjv243.js} +0 -0
- /package/dist/{templates-CeYJjVzw.js → templates-37RKpACb.js} +0 -0
- /package/dist/{templates-I3Z0xplD.js → templates-DPalk30o.js} +0 -0
- /package/dist/{thinking-BXEswx1X.js → thinking-2hxwmvTl.js} +0 -0
- /package/dist/{transcript-events-C1hdue6u.js → transcript-events-Bp7fGnwv.js} +0 -0
- /package/dist/{transcript-tools-DuyYOkUq.js → transcript-tools-D4Lbxlka.js} +0 -0
- /package/dist/{usage-format-BAirWUSO.js → usage-format-6Uar63S0.js} +0 -0
- /package/dist/{utils-C9sj30YY.js → utils-DT8uXjFS.js} +0 -0
- /package/dist/{wsl-CqyuRvtM.js → wsl-CrPvx2kZ.js} +0 -0
- /package/dist/{wsl-ymJYvc9Q.js → wsl-UvJ5dHah.js} +0 -0
package/dist/chrome-DScZx4Lk.js
DELETED
|
@@ -1,1601 +0,0 @@
|
|
|
1
|
-
import { t as createSubsystemLogger } from "./subsystem-Dowf8fSU.js";
|
|
2
|
-
import { t as CONFIG_DIR } from "./utils-Bsw__U-F.js";
|
|
3
|
-
import { n as isLoopbackAddress, r as isLoopbackHost, t as rawDataToString } from "./ws-COSqlEPx.js";
|
|
4
|
-
import { r as ensurePortAvailable } from "./ports-D94CwCrv.js";
|
|
5
|
-
import fs from "node:fs";
|
|
6
|
-
import os from "node:os";
|
|
7
|
-
import path from "node:path";
|
|
8
|
-
import { execFileSync, spawn } from "node:child_process";
|
|
9
|
-
import { randomBytes } from "node:crypto";
|
|
10
|
-
import { createServer } from "node:http";
|
|
11
|
-
import WebSocket, { WebSocketServer } from "ws";
|
|
12
|
-
|
|
13
|
-
//#region src/browser/constants.ts
|
|
14
|
-
const DEFAULT_ANIMA_BROWSER_ENABLED = true;
|
|
15
|
-
const DEFAULT_BROWSER_EVALUATE_ENABLED = true;
|
|
16
|
-
const DEFAULT_ANIMA_BROWSER_COLOR = "#FF4500";
|
|
17
|
-
const DEFAULT_ANIMA_BROWSER_PROFILE_NAME = "anima";
|
|
18
|
-
const DEFAULT_BROWSER_DEFAULT_PROFILE_NAME = "chrome";
|
|
19
|
-
const DEFAULT_AI_SNAPSHOT_MAX_CHARS = 8e4;
|
|
20
|
-
const DEFAULT_AI_SNAPSHOT_EFFICIENT_MAX_CHARS = 1e4;
|
|
21
|
-
const DEFAULT_AI_SNAPSHOT_EFFICIENT_DEPTH = 6;
|
|
22
|
-
|
|
23
|
-
//#endregion
|
|
24
|
-
//#region src/browser/extension-relay.ts
|
|
25
|
-
const RELAY_AUTH_HEADER = "x-anima-relay-token";
|
|
26
|
-
function headerValue(value) {
|
|
27
|
-
if (!value) return;
|
|
28
|
-
if (Array.isArray(value)) return value[0];
|
|
29
|
-
return value;
|
|
30
|
-
}
|
|
31
|
-
function getHeader(req, name) {
|
|
32
|
-
return headerValue(req.headers[name.toLowerCase()]);
|
|
33
|
-
}
|
|
34
|
-
function parseBaseUrl(raw) {
|
|
35
|
-
const parsed = new URL(raw.trim().replace(/\/$/, ""));
|
|
36
|
-
if (parsed.protocol !== "http:" && parsed.protocol !== "https:") throw new Error(`extension relay cdpUrl must be http(s), got ${parsed.protocol}`);
|
|
37
|
-
const host = parsed.hostname;
|
|
38
|
-
const port = parsed.port?.trim() !== "" ? Number(parsed.port) : parsed.protocol === "https:" ? 443 : 80;
|
|
39
|
-
if (!Number.isFinite(port) || port <= 0 || port > 65535) throw new Error(`extension relay cdpUrl has invalid port: ${parsed.port || "(empty)"}`);
|
|
40
|
-
return {
|
|
41
|
-
host,
|
|
42
|
-
port,
|
|
43
|
-
baseUrl: parsed.toString().replace(/\/$/, "")
|
|
44
|
-
};
|
|
45
|
-
}
|
|
46
|
-
function text(res, status, bodyText) {
|
|
47
|
-
const body = Buffer.from(bodyText);
|
|
48
|
-
res.write(`HTTP/1.1 ${status} ${status === 200 ? "OK" : "ERR"}\r\nContent-Type: text/plain; charset=utf-8\r
|
|
49
|
-
Content-Length: ${body.length}\r\nConnection: close\r
|
|
50
|
-
\r
|
|
51
|
-
`);
|
|
52
|
-
res.write(body);
|
|
53
|
-
res.end();
|
|
54
|
-
}
|
|
55
|
-
function rejectUpgrade(socket, status, bodyText) {
|
|
56
|
-
text(socket, status, bodyText);
|
|
57
|
-
try {
|
|
58
|
-
socket.destroy();
|
|
59
|
-
} catch {}
|
|
60
|
-
}
|
|
61
|
-
const serversByPort = /* @__PURE__ */ new Map();
|
|
62
|
-
const relayAuthByPort = /* @__PURE__ */ new Map();
|
|
63
|
-
function relayAuthTokenForUrl(url) {
|
|
64
|
-
try {
|
|
65
|
-
const parsed = new URL(url);
|
|
66
|
-
if (!isLoopbackHost(parsed.hostname)) return null;
|
|
67
|
-
const port = parsed.port?.trim() !== "" ? Number(parsed.port) : parsed.protocol === "https:" || parsed.protocol === "wss:" ? 443 : 80;
|
|
68
|
-
if (!Number.isFinite(port)) return null;
|
|
69
|
-
return relayAuthByPort.get(port) ?? null;
|
|
70
|
-
} catch {
|
|
71
|
-
return null;
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
function getChromeExtensionRelayAuthHeaders(url) {
|
|
75
|
-
const token = relayAuthTokenForUrl(url);
|
|
76
|
-
if (!token) return {};
|
|
77
|
-
return { [RELAY_AUTH_HEADER]: token };
|
|
78
|
-
}
|
|
79
|
-
async function ensureChromeExtensionRelayServer(opts) {
|
|
80
|
-
const info = parseBaseUrl(opts.cdpUrl);
|
|
81
|
-
if (!isLoopbackHost(info.host)) throw new Error(`extension relay requires loopback cdpUrl host (got ${info.host})`);
|
|
82
|
-
const existing = serversByPort.get(info.port);
|
|
83
|
-
if (existing) return existing;
|
|
84
|
-
let extensionWs = null;
|
|
85
|
-
const cdpClients = /* @__PURE__ */ new Set();
|
|
86
|
-
const connectedTargets = /* @__PURE__ */ new Map();
|
|
87
|
-
const pendingExtension = /* @__PURE__ */ new Map();
|
|
88
|
-
let nextExtensionId = 1;
|
|
89
|
-
const sendToExtension = async (payload) => {
|
|
90
|
-
const ws = extensionWs;
|
|
91
|
-
if (!ws || ws.readyState !== WebSocket.OPEN) throw new Error("Chrome extension not connected");
|
|
92
|
-
ws.send(JSON.stringify(payload));
|
|
93
|
-
return await new Promise((resolve, reject) => {
|
|
94
|
-
const timer = setTimeout(() => {
|
|
95
|
-
pendingExtension.delete(payload.id);
|
|
96
|
-
reject(/* @__PURE__ */ new Error(`extension request timeout: ${payload.params.method}`));
|
|
97
|
-
}, 3e4);
|
|
98
|
-
pendingExtension.set(payload.id, {
|
|
99
|
-
resolve,
|
|
100
|
-
reject,
|
|
101
|
-
timer
|
|
102
|
-
});
|
|
103
|
-
});
|
|
104
|
-
};
|
|
105
|
-
const broadcastToCdpClients = (evt) => {
|
|
106
|
-
const msg = JSON.stringify(evt);
|
|
107
|
-
for (const ws of cdpClients) {
|
|
108
|
-
if (ws.readyState !== WebSocket.OPEN) continue;
|
|
109
|
-
ws.send(msg);
|
|
110
|
-
}
|
|
111
|
-
};
|
|
112
|
-
const sendResponseToCdp = (ws, res) => {
|
|
113
|
-
if (ws.readyState !== WebSocket.OPEN) return;
|
|
114
|
-
ws.send(JSON.stringify(res));
|
|
115
|
-
};
|
|
116
|
-
const ensureTargetEventsForClient = (ws, mode) => {
|
|
117
|
-
for (const target of connectedTargets.values()) if (mode === "autoAttach") ws.send(JSON.stringify({
|
|
118
|
-
method: "Target.attachedToTarget",
|
|
119
|
-
params: {
|
|
120
|
-
sessionId: target.sessionId,
|
|
121
|
-
targetInfo: {
|
|
122
|
-
...target.targetInfo,
|
|
123
|
-
attached: true
|
|
124
|
-
},
|
|
125
|
-
waitingForDebugger: false
|
|
126
|
-
}
|
|
127
|
-
}));
|
|
128
|
-
else ws.send(JSON.stringify({
|
|
129
|
-
method: "Target.targetCreated",
|
|
130
|
-
params: { targetInfo: {
|
|
131
|
-
...target.targetInfo,
|
|
132
|
-
attached: true
|
|
133
|
-
} }
|
|
134
|
-
}));
|
|
135
|
-
};
|
|
136
|
-
const routeCdpCommand = async (cmd) => {
|
|
137
|
-
switch (cmd.method) {
|
|
138
|
-
case "Browser.getVersion": return {
|
|
139
|
-
protocolVersion: "1.3",
|
|
140
|
-
product: "Chrome/Anima-Extension-Relay",
|
|
141
|
-
revision: "0",
|
|
142
|
-
userAgent: "Anima-Extension-Relay",
|
|
143
|
-
jsVersion: "V8"
|
|
144
|
-
};
|
|
145
|
-
case "Browser.setDownloadBehavior": return {};
|
|
146
|
-
case "Target.setAutoAttach":
|
|
147
|
-
case "Target.setDiscoverTargets": return {};
|
|
148
|
-
case "Target.getTargets": return { targetInfos: Array.from(connectedTargets.values()).map((t) => ({
|
|
149
|
-
...t.targetInfo,
|
|
150
|
-
attached: true
|
|
151
|
-
})) };
|
|
152
|
-
case "Target.getTargetInfo": {
|
|
153
|
-
const params = cmd.params ?? {};
|
|
154
|
-
const targetId = typeof params.targetId === "string" ? params.targetId : void 0;
|
|
155
|
-
if (targetId) {
|
|
156
|
-
for (const t of connectedTargets.values()) if (t.targetId === targetId) return { targetInfo: t.targetInfo };
|
|
157
|
-
}
|
|
158
|
-
if (cmd.sessionId && connectedTargets.has(cmd.sessionId)) {
|
|
159
|
-
const t = connectedTargets.get(cmd.sessionId);
|
|
160
|
-
if (t) return { targetInfo: t.targetInfo };
|
|
161
|
-
}
|
|
162
|
-
return { targetInfo: Array.from(connectedTargets.values())[0]?.targetInfo };
|
|
163
|
-
}
|
|
164
|
-
case "Target.attachToTarget": {
|
|
165
|
-
const params = cmd.params ?? {};
|
|
166
|
-
const targetId = typeof params.targetId === "string" ? params.targetId : void 0;
|
|
167
|
-
if (!targetId) throw new Error("targetId required");
|
|
168
|
-
for (const t of connectedTargets.values()) if (t.targetId === targetId) return { sessionId: t.sessionId };
|
|
169
|
-
throw new Error("target not found");
|
|
170
|
-
}
|
|
171
|
-
default: return await sendToExtension({
|
|
172
|
-
id: nextExtensionId++,
|
|
173
|
-
method: "forwardCDPCommand",
|
|
174
|
-
params: {
|
|
175
|
-
method: cmd.method,
|
|
176
|
-
sessionId: cmd.sessionId,
|
|
177
|
-
params: cmd.params
|
|
178
|
-
}
|
|
179
|
-
});
|
|
180
|
-
}
|
|
181
|
-
};
|
|
182
|
-
const relayAuthToken = randomBytes(32).toString("base64url");
|
|
183
|
-
const server = createServer((req, res) => {
|
|
184
|
-
const path = new URL(req.url ?? "/", info.baseUrl).pathname;
|
|
185
|
-
if (path.startsWith("/json")) {
|
|
186
|
-
const token = getHeader(req, RELAY_AUTH_HEADER);
|
|
187
|
-
if (!token || token !== relayAuthToken) {
|
|
188
|
-
res.writeHead(401);
|
|
189
|
-
res.end("Unauthorized");
|
|
190
|
-
return;
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
if (req.method === "HEAD" && path === "/") {
|
|
194
|
-
res.writeHead(200);
|
|
195
|
-
res.end();
|
|
196
|
-
return;
|
|
197
|
-
}
|
|
198
|
-
if (path === "/") {
|
|
199
|
-
res.writeHead(200, { "Content-Type": "text/plain; charset=utf-8" });
|
|
200
|
-
res.end("OK");
|
|
201
|
-
return;
|
|
202
|
-
}
|
|
203
|
-
if (path === "/extension/status") {
|
|
204
|
-
res.writeHead(200, { "Content-Type": "application/json" });
|
|
205
|
-
res.end(JSON.stringify({ connected: Boolean(extensionWs) }));
|
|
206
|
-
return;
|
|
207
|
-
}
|
|
208
|
-
const cdpWsUrl = `${`ws://${req.headers.host?.trim() || `${info.host}:${info.port}`}`}/cdp`;
|
|
209
|
-
if ((path === "/json/version" || path === "/json/version/") && (req.method === "GET" || req.method === "PUT")) {
|
|
210
|
-
const payload = {
|
|
211
|
-
Browser: "Anima/extension-relay",
|
|
212
|
-
"Protocol-Version": "1.3"
|
|
213
|
-
};
|
|
214
|
-
if (extensionWs) payload.webSocketDebuggerUrl = cdpWsUrl;
|
|
215
|
-
res.writeHead(200, { "Content-Type": "application/json" });
|
|
216
|
-
res.end(JSON.stringify(payload));
|
|
217
|
-
return;
|
|
218
|
-
}
|
|
219
|
-
if (new Set([
|
|
220
|
-
"/json",
|
|
221
|
-
"/json/",
|
|
222
|
-
"/json/list",
|
|
223
|
-
"/json/list/"
|
|
224
|
-
]).has(path) && (req.method === "GET" || req.method === "PUT")) {
|
|
225
|
-
const list = Array.from(connectedTargets.values()).map((t) => ({
|
|
226
|
-
id: t.targetId,
|
|
227
|
-
type: t.targetInfo.type ?? "page",
|
|
228
|
-
title: t.targetInfo.title ?? "",
|
|
229
|
-
description: t.targetInfo.title ?? "",
|
|
230
|
-
url: t.targetInfo.url ?? "",
|
|
231
|
-
webSocketDebuggerUrl: cdpWsUrl,
|
|
232
|
-
devtoolsFrontendUrl: `/devtools/inspector.html?ws=${cdpWsUrl.replace("ws://", "")}`
|
|
233
|
-
}));
|
|
234
|
-
res.writeHead(200, { "Content-Type": "application/json" });
|
|
235
|
-
res.end(JSON.stringify(list));
|
|
236
|
-
return;
|
|
237
|
-
}
|
|
238
|
-
const activateMatch = path.match(/^\/json\/activate\/(.+)$/);
|
|
239
|
-
if (activateMatch && (req.method === "GET" || req.method === "PUT")) {
|
|
240
|
-
const targetId = decodeURIComponent(activateMatch[1] ?? "").trim();
|
|
241
|
-
if (!targetId) {
|
|
242
|
-
res.writeHead(400);
|
|
243
|
-
res.end("targetId required");
|
|
244
|
-
return;
|
|
245
|
-
}
|
|
246
|
-
(async () => {
|
|
247
|
-
try {
|
|
248
|
-
await sendToExtension({
|
|
249
|
-
id: nextExtensionId++,
|
|
250
|
-
method: "forwardCDPCommand",
|
|
251
|
-
params: {
|
|
252
|
-
method: "Target.activateTarget",
|
|
253
|
-
params: { targetId }
|
|
254
|
-
}
|
|
255
|
-
});
|
|
256
|
-
} catch {}
|
|
257
|
-
})();
|
|
258
|
-
res.writeHead(200);
|
|
259
|
-
res.end("OK");
|
|
260
|
-
return;
|
|
261
|
-
}
|
|
262
|
-
const closeMatch = path.match(/^\/json\/close\/(.+)$/);
|
|
263
|
-
if (closeMatch && (req.method === "GET" || req.method === "PUT")) {
|
|
264
|
-
const targetId = decodeURIComponent(closeMatch[1] ?? "").trim();
|
|
265
|
-
if (!targetId) {
|
|
266
|
-
res.writeHead(400);
|
|
267
|
-
res.end("targetId required");
|
|
268
|
-
return;
|
|
269
|
-
}
|
|
270
|
-
(async () => {
|
|
271
|
-
try {
|
|
272
|
-
await sendToExtension({
|
|
273
|
-
id: nextExtensionId++,
|
|
274
|
-
method: "forwardCDPCommand",
|
|
275
|
-
params: {
|
|
276
|
-
method: "Target.closeTarget",
|
|
277
|
-
params: { targetId }
|
|
278
|
-
}
|
|
279
|
-
});
|
|
280
|
-
} catch {}
|
|
281
|
-
})();
|
|
282
|
-
res.writeHead(200);
|
|
283
|
-
res.end("OK");
|
|
284
|
-
return;
|
|
285
|
-
}
|
|
286
|
-
res.writeHead(404);
|
|
287
|
-
res.end("not found");
|
|
288
|
-
});
|
|
289
|
-
const wssExtension = new WebSocketServer({ noServer: true });
|
|
290
|
-
const wssCdp = new WebSocketServer({ noServer: true });
|
|
291
|
-
server.on("upgrade", (req, socket, head) => {
|
|
292
|
-
const pathname = new URL(req.url ?? "/", info.baseUrl).pathname;
|
|
293
|
-
const remote = req.socket.remoteAddress;
|
|
294
|
-
if (!isLoopbackAddress(remote)) {
|
|
295
|
-
rejectUpgrade(socket, 403, "Forbidden");
|
|
296
|
-
return;
|
|
297
|
-
}
|
|
298
|
-
const origin = headerValue(req.headers.origin);
|
|
299
|
-
if (origin && !origin.startsWith("chrome-extension://")) {
|
|
300
|
-
rejectUpgrade(socket, 403, "Forbidden: invalid origin");
|
|
301
|
-
return;
|
|
302
|
-
}
|
|
303
|
-
if (pathname === "/extension") {
|
|
304
|
-
if (extensionWs) {
|
|
305
|
-
rejectUpgrade(socket, 409, "Extension already connected");
|
|
306
|
-
return;
|
|
307
|
-
}
|
|
308
|
-
wssExtension.handleUpgrade(req, socket, head, (ws) => {
|
|
309
|
-
wssExtension.emit("connection", ws, req);
|
|
310
|
-
});
|
|
311
|
-
return;
|
|
312
|
-
}
|
|
313
|
-
if (pathname === "/cdp") {
|
|
314
|
-
const token = getHeader(req, RELAY_AUTH_HEADER);
|
|
315
|
-
if (!token || token !== relayAuthToken) {
|
|
316
|
-
rejectUpgrade(socket, 401, "Unauthorized");
|
|
317
|
-
return;
|
|
318
|
-
}
|
|
319
|
-
if (!extensionWs) {
|
|
320
|
-
rejectUpgrade(socket, 503, "Extension not connected");
|
|
321
|
-
return;
|
|
322
|
-
}
|
|
323
|
-
wssCdp.handleUpgrade(req, socket, head, (ws) => {
|
|
324
|
-
wssCdp.emit("connection", ws, req);
|
|
325
|
-
});
|
|
326
|
-
return;
|
|
327
|
-
}
|
|
328
|
-
rejectUpgrade(socket, 404, "Not Found");
|
|
329
|
-
});
|
|
330
|
-
wssExtension.on("connection", (ws) => {
|
|
331
|
-
extensionWs = ws;
|
|
332
|
-
const ping = setInterval(() => {
|
|
333
|
-
if (ws.readyState !== WebSocket.OPEN) return;
|
|
334
|
-
ws.send(JSON.stringify({ method: "ping" }));
|
|
335
|
-
}, 5e3);
|
|
336
|
-
ws.on("message", (data) => {
|
|
337
|
-
let parsed = null;
|
|
338
|
-
try {
|
|
339
|
-
parsed = JSON.parse(rawDataToString(data));
|
|
340
|
-
} catch {
|
|
341
|
-
return;
|
|
342
|
-
}
|
|
343
|
-
if (parsed && typeof parsed === "object" && "id" in parsed && typeof parsed.id === "number") {
|
|
344
|
-
const pending = pendingExtension.get(parsed.id);
|
|
345
|
-
if (!pending) return;
|
|
346
|
-
pendingExtension.delete(parsed.id);
|
|
347
|
-
clearTimeout(pending.timer);
|
|
348
|
-
if ("error" in parsed && typeof parsed.error === "string" && parsed.error.trim()) pending.reject(new Error(parsed.error));
|
|
349
|
-
else pending.resolve(parsed.result);
|
|
350
|
-
return;
|
|
351
|
-
}
|
|
352
|
-
if (parsed && typeof parsed === "object" && "method" in parsed) {
|
|
353
|
-
if (parsed.method === "pong") return;
|
|
354
|
-
if (parsed.method !== "forwardCDPEvent") return;
|
|
355
|
-
const evt = parsed;
|
|
356
|
-
const method = evt.params?.method;
|
|
357
|
-
const params = evt.params?.params;
|
|
358
|
-
const sessionId = evt.params?.sessionId;
|
|
359
|
-
if (!method || typeof method !== "string") return;
|
|
360
|
-
if (method === "Target.attachedToTarget") {
|
|
361
|
-
const attached = params ?? {};
|
|
362
|
-
if ((attached?.targetInfo?.type ?? "page") !== "page") return;
|
|
363
|
-
if (attached?.sessionId && attached?.targetInfo?.targetId) {
|
|
364
|
-
const prev = connectedTargets.get(attached.sessionId);
|
|
365
|
-
const nextTargetId = attached.targetInfo.targetId;
|
|
366
|
-
const prevTargetId = prev?.targetId;
|
|
367
|
-
const changedTarget = Boolean(prev && prevTargetId && prevTargetId !== nextTargetId);
|
|
368
|
-
connectedTargets.set(attached.sessionId, {
|
|
369
|
-
sessionId: attached.sessionId,
|
|
370
|
-
targetId: nextTargetId,
|
|
371
|
-
targetInfo: attached.targetInfo
|
|
372
|
-
});
|
|
373
|
-
if (changedTarget && prevTargetId) broadcastToCdpClients({
|
|
374
|
-
method: "Target.detachedFromTarget",
|
|
375
|
-
params: {
|
|
376
|
-
sessionId: attached.sessionId,
|
|
377
|
-
targetId: prevTargetId
|
|
378
|
-
},
|
|
379
|
-
sessionId: attached.sessionId
|
|
380
|
-
});
|
|
381
|
-
if (!prev || changedTarget) broadcastToCdpClients({
|
|
382
|
-
method,
|
|
383
|
-
params,
|
|
384
|
-
sessionId
|
|
385
|
-
});
|
|
386
|
-
return;
|
|
387
|
-
}
|
|
388
|
-
}
|
|
389
|
-
if (method === "Target.detachedFromTarget") {
|
|
390
|
-
const detached = params ?? {};
|
|
391
|
-
if (detached?.sessionId) connectedTargets.delete(detached.sessionId);
|
|
392
|
-
broadcastToCdpClients({
|
|
393
|
-
method,
|
|
394
|
-
params,
|
|
395
|
-
sessionId
|
|
396
|
-
});
|
|
397
|
-
return;
|
|
398
|
-
}
|
|
399
|
-
if (method === "Target.targetInfoChanged") {
|
|
400
|
-
const targetInfo = (params ?? {})?.targetInfo;
|
|
401
|
-
const targetId = targetInfo?.targetId;
|
|
402
|
-
if (targetId && (targetInfo?.type ?? "page") === "page") for (const [sid, target] of connectedTargets) {
|
|
403
|
-
if (target.targetId !== targetId) continue;
|
|
404
|
-
connectedTargets.set(sid, {
|
|
405
|
-
...target,
|
|
406
|
-
targetInfo: {
|
|
407
|
-
...target.targetInfo,
|
|
408
|
-
...targetInfo
|
|
409
|
-
}
|
|
410
|
-
});
|
|
411
|
-
}
|
|
412
|
-
}
|
|
413
|
-
broadcastToCdpClients({
|
|
414
|
-
method,
|
|
415
|
-
params,
|
|
416
|
-
sessionId
|
|
417
|
-
});
|
|
418
|
-
}
|
|
419
|
-
});
|
|
420
|
-
ws.on("close", () => {
|
|
421
|
-
clearInterval(ping);
|
|
422
|
-
extensionWs = null;
|
|
423
|
-
for (const [, pending] of pendingExtension) {
|
|
424
|
-
clearTimeout(pending.timer);
|
|
425
|
-
pending.reject(/* @__PURE__ */ new Error("extension disconnected"));
|
|
426
|
-
}
|
|
427
|
-
pendingExtension.clear();
|
|
428
|
-
connectedTargets.clear();
|
|
429
|
-
for (const client of cdpClients) try {
|
|
430
|
-
client.close(1011, "extension disconnected");
|
|
431
|
-
} catch {}
|
|
432
|
-
cdpClients.clear();
|
|
433
|
-
});
|
|
434
|
-
});
|
|
435
|
-
wssCdp.on("connection", (ws) => {
|
|
436
|
-
cdpClients.add(ws);
|
|
437
|
-
ws.on("message", async (data) => {
|
|
438
|
-
let cmd = null;
|
|
439
|
-
try {
|
|
440
|
-
cmd = JSON.parse(rawDataToString(data));
|
|
441
|
-
} catch {
|
|
442
|
-
return;
|
|
443
|
-
}
|
|
444
|
-
if (!cmd || typeof cmd !== "object") return;
|
|
445
|
-
if (typeof cmd.id !== "number" || typeof cmd.method !== "string") return;
|
|
446
|
-
if (!extensionWs) {
|
|
447
|
-
sendResponseToCdp(ws, {
|
|
448
|
-
id: cmd.id,
|
|
449
|
-
sessionId: cmd.sessionId,
|
|
450
|
-
error: { message: "Extension not connected" }
|
|
451
|
-
});
|
|
452
|
-
return;
|
|
453
|
-
}
|
|
454
|
-
try {
|
|
455
|
-
const result = await routeCdpCommand(cmd);
|
|
456
|
-
if (cmd.method === "Target.setAutoAttach" && !cmd.sessionId) ensureTargetEventsForClient(ws, "autoAttach");
|
|
457
|
-
if (cmd.method === "Target.setDiscoverTargets") {
|
|
458
|
-
if ((cmd.params ?? {}).discover === true) ensureTargetEventsForClient(ws, "discover");
|
|
459
|
-
}
|
|
460
|
-
if (cmd.method === "Target.attachToTarget") {
|
|
461
|
-
const params = cmd.params ?? {};
|
|
462
|
-
const targetId = typeof params.targetId === "string" ? params.targetId : void 0;
|
|
463
|
-
if (targetId) {
|
|
464
|
-
const target = Array.from(connectedTargets.values()).find((t) => t.targetId === targetId);
|
|
465
|
-
if (target) ws.send(JSON.stringify({
|
|
466
|
-
method: "Target.attachedToTarget",
|
|
467
|
-
params: {
|
|
468
|
-
sessionId: target.sessionId,
|
|
469
|
-
targetInfo: {
|
|
470
|
-
...target.targetInfo,
|
|
471
|
-
attached: true
|
|
472
|
-
},
|
|
473
|
-
waitingForDebugger: false
|
|
474
|
-
}
|
|
475
|
-
}));
|
|
476
|
-
}
|
|
477
|
-
}
|
|
478
|
-
sendResponseToCdp(ws, {
|
|
479
|
-
id: cmd.id,
|
|
480
|
-
sessionId: cmd.sessionId,
|
|
481
|
-
result
|
|
482
|
-
});
|
|
483
|
-
} catch (err) {
|
|
484
|
-
sendResponseToCdp(ws, {
|
|
485
|
-
id: cmd.id,
|
|
486
|
-
sessionId: cmd.sessionId,
|
|
487
|
-
error: { message: err instanceof Error ? err.message : String(err) }
|
|
488
|
-
});
|
|
489
|
-
}
|
|
490
|
-
});
|
|
491
|
-
ws.on("close", () => {
|
|
492
|
-
cdpClients.delete(ws);
|
|
493
|
-
});
|
|
494
|
-
});
|
|
495
|
-
await new Promise((resolve, reject) => {
|
|
496
|
-
server.listen(info.port, info.host, () => resolve());
|
|
497
|
-
server.once("error", reject);
|
|
498
|
-
});
|
|
499
|
-
const port = server.address()?.port ?? info.port;
|
|
500
|
-
const host = info.host;
|
|
501
|
-
const relay = {
|
|
502
|
-
host,
|
|
503
|
-
port,
|
|
504
|
-
baseUrl: `${new URL(info.baseUrl).protocol}//${host}:${port}`,
|
|
505
|
-
cdpWsUrl: `ws://${host}:${port}/cdp`,
|
|
506
|
-
extensionConnected: () => Boolean(extensionWs),
|
|
507
|
-
stop: async () => {
|
|
508
|
-
serversByPort.delete(port);
|
|
509
|
-
relayAuthByPort.delete(port);
|
|
510
|
-
try {
|
|
511
|
-
extensionWs?.close(1001, "server stopping");
|
|
512
|
-
} catch {}
|
|
513
|
-
for (const ws of cdpClients) try {
|
|
514
|
-
ws.close(1001, "server stopping");
|
|
515
|
-
} catch {}
|
|
516
|
-
await new Promise((resolve) => {
|
|
517
|
-
server.close(() => resolve());
|
|
518
|
-
});
|
|
519
|
-
wssExtension.close();
|
|
520
|
-
wssCdp.close();
|
|
521
|
-
}
|
|
522
|
-
};
|
|
523
|
-
relayAuthByPort.set(port, relayAuthToken);
|
|
524
|
-
serversByPort.set(port, relay);
|
|
525
|
-
return relay;
|
|
526
|
-
}
|
|
527
|
-
async function stopChromeExtensionRelayServer(opts) {
|
|
528
|
-
const info = parseBaseUrl(opts.cdpUrl);
|
|
529
|
-
const existing = serversByPort.get(info.port);
|
|
530
|
-
if (!existing) return false;
|
|
531
|
-
await existing.stop();
|
|
532
|
-
relayAuthByPort.delete(info.port);
|
|
533
|
-
return true;
|
|
534
|
-
}
|
|
535
|
-
|
|
536
|
-
//#endregion
|
|
537
|
-
//#region src/browser/cdp.helpers.ts
|
|
538
|
-
function getHeadersWithAuth(url, headers = {}) {
|
|
539
|
-
const mergedHeaders = {
|
|
540
|
-
...getChromeExtensionRelayAuthHeaders(url),
|
|
541
|
-
...headers
|
|
542
|
-
};
|
|
543
|
-
try {
|
|
544
|
-
const parsed = new URL(url);
|
|
545
|
-
if (Object.keys(mergedHeaders).some((key) => key.toLowerCase() === "authorization")) return mergedHeaders;
|
|
546
|
-
if (parsed.username || parsed.password) {
|
|
547
|
-
const auth = Buffer.from(`${parsed.username}:${parsed.password}`).toString("base64");
|
|
548
|
-
return {
|
|
549
|
-
...mergedHeaders,
|
|
550
|
-
Authorization: `Basic ${auth}`
|
|
551
|
-
};
|
|
552
|
-
}
|
|
553
|
-
} catch {}
|
|
554
|
-
return mergedHeaders;
|
|
555
|
-
}
|
|
556
|
-
function appendCdpPath(cdpUrl, path) {
|
|
557
|
-
const url = new URL(cdpUrl);
|
|
558
|
-
url.pathname = `${url.pathname.replace(/\/$/, "")}${path.startsWith("/") ? path : `/${path}`}`;
|
|
559
|
-
return url.toString();
|
|
560
|
-
}
|
|
561
|
-
function createCdpSender(ws) {
|
|
562
|
-
let nextId = 1;
|
|
563
|
-
const pending = /* @__PURE__ */ new Map();
|
|
564
|
-
const send = (method, params, sessionId) => {
|
|
565
|
-
const id = nextId++;
|
|
566
|
-
const msg = {
|
|
567
|
-
id,
|
|
568
|
-
method,
|
|
569
|
-
params,
|
|
570
|
-
sessionId
|
|
571
|
-
};
|
|
572
|
-
ws.send(JSON.stringify(msg));
|
|
573
|
-
return new Promise((resolve, reject) => {
|
|
574
|
-
pending.set(id, {
|
|
575
|
-
resolve,
|
|
576
|
-
reject
|
|
577
|
-
});
|
|
578
|
-
});
|
|
579
|
-
};
|
|
580
|
-
const closeWithError = (err) => {
|
|
581
|
-
for (const [, p] of pending) p.reject(err);
|
|
582
|
-
pending.clear();
|
|
583
|
-
try {
|
|
584
|
-
ws.close();
|
|
585
|
-
} catch {}
|
|
586
|
-
};
|
|
587
|
-
ws.on("error", (err) => {
|
|
588
|
-
closeWithError(err instanceof Error ? err : new Error(String(err)));
|
|
589
|
-
});
|
|
590
|
-
ws.on("message", (data) => {
|
|
591
|
-
try {
|
|
592
|
-
const parsed = JSON.parse(rawDataToString(data));
|
|
593
|
-
if (typeof parsed.id !== "number") return;
|
|
594
|
-
const p = pending.get(parsed.id);
|
|
595
|
-
if (!p) return;
|
|
596
|
-
pending.delete(parsed.id);
|
|
597
|
-
if (parsed.error?.message) {
|
|
598
|
-
p.reject(new Error(parsed.error.message));
|
|
599
|
-
return;
|
|
600
|
-
}
|
|
601
|
-
p.resolve(parsed.result);
|
|
602
|
-
} catch {}
|
|
603
|
-
});
|
|
604
|
-
ws.on("close", () => {
|
|
605
|
-
closeWithError(/* @__PURE__ */ new Error("CDP socket closed"));
|
|
606
|
-
});
|
|
607
|
-
return {
|
|
608
|
-
send,
|
|
609
|
-
closeWithError
|
|
610
|
-
};
|
|
611
|
-
}
|
|
612
|
-
async function fetchJson(url, timeoutMs = 1500, init) {
|
|
613
|
-
const ctrl = new AbortController();
|
|
614
|
-
const t = setTimeout(ctrl.abort.bind(ctrl), timeoutMs);
|
|
615
|
-
try {
|
|
616
|
-
const headers = getHeadersWithAuth(url, init?.headers || {});
|
|
617
|
-
const res = await fetch(url, {
|
|
618
|
-
...init,
|
|
619
|
-
headers,
|
|
620
|
-
signal: ctrl.signal
|
|
621
|
-
});
|
|
622
|
-
if (!res.ok) throw new Error(`HTTP ${res.status}`);
|
|
623
|
-
return await res.json();
|
|
624
|
-
} finally {
|
|
625
|
-
clearTimeout(t);
|
|
626
|
-
}
|
|
627
|
-
}
|
|
628
|
-
async function withCdpSocket(wsUrl, fn, opts) {
|
|
629
|
-
const headers = getHeadersWithAuth(wsUrl, opts?.headers ?? {});
|
|
630
|
-
const ws = new WebSocket(wsUrl, {
|
|
631
|
-
handshakeTimeout: typeof opts?.handshakeTimeoutMs === "number" && Number.isFinite(opts.handshakeTimeoutMs) ? Math.max(1, Math.floor(opts.handshakeTimeoutMs)) : 5e3,
|
|
632
|
-
...Object.keys(headers).length ? { headers } : {}
|
|
633
|
-
});
|
|
634
|
-
const { send, closeWithError } = createCdpSender(ws);
|
|
635
|
-
const openPromise = new Promise((resolve, reject) => {
|
|
636
|
-
ws.once("open", () => resolve());
|
|
637
|
-
ws.once("error", (err) => reject(err));
|
|
638
|
-
ws.once("close", () => reject(/* @__PURE__ */ new Error("CDP socket closed")));
|
|
639
|
-
});
|
|
640
|
-
try {
|
|
641
|
-
await openPromise;
|
|
642
|
-
} catch (err) {
|
|
643
|
-
closeWithError(err instanceof Error ? err : new Error(String(err)));
|
|
644
|
-
throw err;
|
|
645
|
-
}
|
|
646
|
-
try {
|
|
647
|
-
return await fn(send);
|
|
648
|
-
} catch (err) {
|
|
649
|
-
closeWithError(err instanceof Error ? err : new Error(String(err)));
|
|
650
|
-
throw err;
|
|
651
|
-
} finally {
|
|
652
|
-
try {
|
|
653
|
-
ws.close();
|
|
654
|
-
} catch {}
|
|
655
|
-
}
|
|
656
|
-
}
|
|
657
|
-
|
|
658
|
-
//#endregion
|
|
659
|
-
//#region src/browser/cdp.ts
|
|
660
|
-
function normalizeCdpWsUrl(wsUrl, cdpUrl) {
|
|
661
|
-
const ws = new URL(wsUrl);
|
|
662
|
-
const cdp = new URL(cdpUrl);
|
|
663
|
-
if (isLoopbackHost(ws.hostname) && !isLoopbackHost(cdp.hostname)) {
|
|
664
|
-
ws.hostname = cdp.hostname;
|
|
665
|
-
const cdpPort = cdp.port || (cdp.protocol === "https:" ? "443" : "80");
|
|
666
|
-
if (cdpPort) ws.port = cdpPort;
|
|
667
|
-
ws.protocol = cdp.protocol === "https:" ? "wss:" : "ws:";
|
|
668
|
-
}
|
|
669
|
-
if (cdp.protocol === "https:" && ws.protocol === "ws:") ws.protocol = "wss:";
|
|
670
|
-
if (!ws.username && !ws.password && (cdp.username || cdp.password)) {
|
|
671
|
-
ws.username = cdp.username;
|
|
672
|
-
ws.password = cdp.password;
|
|
673
|
-
}
|
|
674
|
-
for (const [key, value] of cdp.searchParams.entries()) if (!ws.searchParams.has(key)) ws.searchParams.append(key, value);
|
|
675
|
-
return ws.toString();
|
|
676
|
-
}
|
|
677
|
-
async function captureScreenshot(opts) {
|
|
678
|
-
return await withCdpSocket(opts.wsUrl, async (send) => {
|
|
679
|
-
await send("Page.enable");
|
|
680
|
-
let clip;
|
|
681
|
-
if (opts.fullPage) {
|
|
682
|
-
const metrics = await send("Page.getLayoutMetrics");
|
|
683
|
-
const size = metrics?.cssContentSize ?? metrics?.contentSize;
|
|
684
|
-
const width = Number(size?.width ?? 0);
|
|
685
|
-
const height = Number(size?.height ?? 0);
|
|
686
|
-
if (width > 0 && height > 0) clip = {
|
|
687
|
-
x: 0,
|
|
688
|
-
y: 0,
|
|
689
|
-
width,
|
|
690
|
-
height,
|
|
691
|
-
scale: 1
|
|
692
|
-
};
|
|
693
|
-
}
|
|
694
|
-
const format = opts.format ?? "png";
|
|
695
|
-
const quality = format === "jpeg" ? Math.max(0, Math.min(100, Math.round(opts.quality ?? 85))) : void 0;
|
|
696
|
-
const base64 = (await send("Page.captureScreenshot", {
|
|
697
|
-
format,
|
|
698
|
-
...quality !== void 0 ? { quality } : {},
|
|
699
|
-
fromSurface: true,
|
|
700
|
-
captureBeyondViewport: true,
|
|
701
|
-
...clip ? { clip } : {}
|
|
702
|
-
}))?.data;
|
|
703
|
-
if (!base64) throw new Error("Screenshot failed: missing data");
|
|
704
|
-
return Buffer.from(base64, "base64");
|
|
705
|
-
});
|
|
706
|
-
}
|
|
707
|
-
async function createTargetViaCdp(opts) {
|
|
708
|
-
const version = await fetchJson(appendCdpPath(opts.cdpUrl, "/json/version"), 1500);
|
|
709
|
-
const wsUrlRaw = String(version?.webSocketDebuggerUrl ?? "").trim();
|
|
710
|
-
const wsUrl = wsUrlRaw ? normalizeCdpWsUrl(wsUrlRaw, opts.cdpUrl) : "";
|
|
711
|
-
if (!wsUrl) throw new Error("CDP /json/version missing webSocketDebuggerUrl");
|
|
712
|
-
return await withCdpSocket(wsUrl, async (send) => {
|
|
713
|
-
const created = await send("Target.createTarget", { url: opts.url });
|
|
714
|
-
const targetId = String(created?.targetId ?? "").trim();
|
|
715
|
-
if (!targetId) throw new Error("CDP Target.createTarget returned no targetId");
|
|
716
|
-
return { targetId };
|
|
717
|
-
});
|
|
718
|
-
}
|
|
719
|
-
function axValue(v) {
|
|
720
|
-
if (!v || typeof v !== "object") return "";
|
|
721
|
-
const value = v.value;
|
|
722
|
-
if (typeof value === "string") return value;
|
|
723
|
-
if (typeof value === "number" || typeof value === "boolean") return String(value);
|
|
724
|
-
return "";
|
|
725
|
-
}
|
|
726
|
-
function formatAriaSnapshot(nodes, limit) {
|
|
727
|
-
const byId = /* @__PURE__ */ new Map();
|
|
728
|
-
for (const n of nodes) if (n.nodeId) byId.set(n.nodeId, n);
|
|
729
|
-
const referenced = /* @__PURE__ */ new Set();
|
|
730
|
-
for (const n of nodes) for (const c of n.childIds ?? []) referenced.add(c);
|
|
731
|
-
const root = nodes.find((n) => n.nodeId && !referenced.has(n.nodeId)) ?? nodes[0];
|
|
732
|
-
if (!root?.nodeId) return [];
|
|
733
|
-
const out = [];
|
|
734
|
-
const stack = [{
|
|
735
|
-
id: root.nodeId,
|
|
736
|
-
depth: 0
|
|
737
|
-
}];
|
|
738
|
-
while (stack.length && out.length < limit) {
|
|
739
|
-
const popped = stack.pop();
|
|
740
|
-
if (!popped) break;
|
|
741
|
-
const { id, depth } = popped;
|
|
742
|
-
const n = byId.get(id);
|
|
743
|
-
if (!n) continue;
|
|
744
|
-
const role = axValue(n.role);
|
|
745
|
-
const name = axValue(n.name);
|
|
746
|
-
const value = axValue(n.value);
|
|
747
|
-
const description = axValue(n.description);
|
|
748
|
-
const ref = `ax${out.length + 1}`;
|
|
749
|
-
out.push({
|
|
750
|
-
ref,
|
|
751
|
-
role: role || "unknown",
|
|
752
|
-
name: name || "",
|
|
753
|
-
...value ? { value } : {},
|
|
754
|
-
...description ? { description } : {},
|
|
755
|
-
...typeof n.backendDOMNodeId === "number" ? { backendDOMNodeId: n.backendDOMNodeId } : {},
|
|
756
|
-
depth
|
|
757
|
-
});
|
|
758
|
-
const children = (n.childIds ?? []).filter((c) => byId.has(c));
|
|
759
|
-
for (let i = children.length - 1; i >= 0; i--) {
|
|
760
|
-
const child = children[i];
|
|
761
|
-
if (child) stack.push({
|
|
762
|
-
id: child,
|
|
763
|
-
depth: depth + 1
|
|
764
|
-
});
|
|
765
|
-
}
|
|
766
|
-
}
|
|
767
|
-
return out;
|
|
768
|
-
}
|
|
769
|
-
async function snapshotAria(opts) {
|
|
770
|
-
const limit = Math.max(1, Math.min(2e3, Math.floor(opts.limit ?? 500)));
|
|
771
|
-
return await withCdpSocket(opts.wsUrl, async (send) => {
|
|
772
|
-
await send("Accessibility.enable").catch(() => {});
|
|
773
|
-
const res = await send("Accessibility.getFullAXTree");
|
|
774
|
-
return { nodes: formatAriaSnapshot(Array.isArray(res?.nodes) ? res.nodes : [], limit) };
|
|
775
|
-
});
|
|
776
|
-
}
|
|
777
|
-
|
|
778
|
-
//#endregion
|
|
779
|
-
//#region src/browser/chrome.executables.ts
|
|
780
|
-
const CHROMIUM_BUNDLE_IDS = new Set([
|
|
781
|
-
"com.google.Chrome",
|
|
782
|
-
"com.google.Chrome.beta",
|
|
783
|
-
"com.google.Chrome.canary",
|
|
784
|
-
"com.google.Chrome.dev",
|
|
785
|
-
"com.brave.Browser",
|
|
786
|
-
"com.brave.Browser.beta",
|
|
787
|
-
"com.brave.Browser.nightly",
|
|
788
|
-
"com.microsoft.Edge",
|
|
789
|
-
"com.microsoft.EdgeBeta",
|
|
790
|
-
"com.microsoft.EdgeDev",
|
|
791
|
-
"com.microsoft.EdgeCanary",
|
|
792
|
-
"org.chromium.Chromium",
|
|
793
|
-
"com.vivaldi.Vivaldi",
|
|
794
|
-
"com.operasoftware.Opera",
|
|
795
|
-
"com.operasoftware.OperaGX",
|
|
796
|
-
"com.yandex.desktop.yandex-browser",
|
|
797
|
-
"company.thebrowser.Browser"
|
|
798
|
-
]);
|
|
799
|
-
const CHROMIUM_DESKTOP_IDS = new Set([
|
|
800
|
-
"google-chrome.desktop",
|
|
801
|
-
"google-chrome-beta.desktop",
|
|
802
|
-
"google-chrome-unstable.desktop",
|
|
803
|
-
"brave-browser.desktop",
|
|
804
|
-
"microsoft-edge.desktop",
|
|
805
|
-
"microsoft-edge-beta.desktop",
|
|
806
|
-
"microsoft-edge-dev.desktop",
|
|
807
|
-
"microsoft-edge-canary.desktop",
|
|
808
|
-
"chromium.desktop",
|
|
809
|
-
"chromium-browser.desktop",
|
|
810
|
-
"vivaldi.desktop",
|
|
811
|
-
"vivaldi-stable.desktop",
|
|
812
|
-
"opera.desktop",
|
|
813
|
-
"opera-gx.desktop",
|
|
814
|
-
"yandex-browser.desktop",
|
|
815
|
-
"org.chromium.Chromium.desktop"
|
|
816
|
-
]);
|
|
817
|
-
const CHROMIUM_EXE_NAMES = new Set([
|
|
818
|
-
"chrome.exe",
|
|
819
|
-
"msedge.exe",
|
|
820
|
-
"brave.exe",
|
|
821
|
-
"brave-browser.exe",
|
|
822
|
-
"chromium.exe",
|
|
823
|
-
"vivaldi.exe",
|
|
824
|
-
"opera.exe",
|
|
825
|
-
"launcher.exe",
|
|
826
|
-
"yandex.exe",
|
|
827
|
-
"yandexbrowser.exe",
|
|
828
|
-
"google chrome",
|
|
829
|
-
"google chrome canary",
|
|
830
|
-
"brave browser",
|
|
831
|
-
"microsoft edge",
|
|
832
|
-
"chromium",
|
|
833
|
-
"chrome",
|
|
834
|
-
"brave",
|
|
835
|
-
"msedge",
|
|
836
|
-
"brave-browser",
|
|
837
|
-
"google-chrome",
|
|
838
|
-
"google-chrome-stable",
|
|
839
|
-
"google-chrome-beta",
|
|
840
|
-
"google-chrome-unstable",
|
|
841
|
-
"microsoft-edge",
|
|
842
|
-
"microsoft-edge-beta",
|
|
843
|
-
"microsoft-edge-dev",
|
|
844
|
-
"microsoft-edge-canary",
|
|
845
|
-
"chromium-browser",
|
|
846
|
-
"vivaldi",
|
|
847
|
-
"vivaldi-stable",
|
|
848
|
-
"opera",
|
|
849
|
-
"opera-stable",
|
|
850
|
-
"opera-gx",
|
|
851
|
-
"yandex-browser"
|
|
852
|
-
]);
|
|
853
|
-
function exists$1(filePath) {
|
|
854
|
-
try {
|
|
855
|
-
return fs.existsSync(filePath);
|
|
856
|
-
} catch {
|
|
857
|
-
return false;
|
|
858
|
-
}
|
|
859
|
-
}
|
|
860
|
-
function execText(command, args, timeoutMs = 1200, maxBuffer = 1024 * 1024) {
|
|
861
|
-
try {
|
|
862
|
-
const output = execFileSync(command, args, {
|
|
863
|
-
timeout: timeoutMs,
|
|
864
|
-
encoding: "utf8",
|
|
865
|
-
maxBuffer
|
|
866
|
-
});
|
|
867
|
-
return String(output ?? "").trim() || null;
|
|
868
|
-
} catch {
|
|
869
|
-
return null;
|
|
870
|
-
}
|
|
871
|
-
}
|
|
872
|
-
function inferKindFromIdentifier(identifier) {
|
|
873
|
-
const id = identifier.toLowerCase();
|
|
874
|
-
if (id.includes("brave")) return "brave";
|
|
875
|
-
if (id.includes("edge")) return "edge";
|
|
876
|
-
if (id.includes("chromium")) return "chromium";
|
|
877
|
-
if (id.includes("canary")) return "canary";
|
|
878
|
-
if (id.includes("opera") || id.includes("vivaldi") || id.includes("yandex") || id.includes("thebrowser")) return "chromium";
|
|
879
|
-
return "chrome";
|
|
880
|
-
}
|
|
881
|
-
function inferKindFromExecutableName(name) {
|
|
882
|
-
const lower = name.toLowerCase();
|
|
883
|
-
if (lower.includes("brave")) return "brave";
|
|
884
|
-
if (lower.includes("edge") || lower.includes("msedge")) return "edge";
|
|
885
|
-
if (lower.includes("chromium")) return "chromium";
|
|
886
|
-
if (lower.includes("canary") || lower.includes("sxs")) return "canary";
|
|
887
|
-
if (lower.includes("opera") || lower.includes("vivaldi") || lower.includes("yandex")) return "chromium";
|
|
888
|
-
return "chrome";
|
|
889
|
-
}
|
|
890
|
-
function detectDefaultChromiumExecutable(platform) {
|
|
891
|
-
if (platform === "darwin") return detectDefaultChromiumExecutableMac();
|
|
892
|
-
if (platform === "linux") return detectDefaultChromiumExecutableLinux();
|
|
893
|
-
if (platform === "win32") return detectDefaultChromiumExecutableWindows();
|
|
894
|
-
return null;
|
|
895
|
-
}
|
|
896
|
-
function detectDefaultChromiumExecutableMac() {
|
|
897
|
-
const bundleId = detectDefaultBrowserBundleIdMac();
|
|
898
|
-
if (!bundleId || !CHROMIUM_BUNDLE_IDS.has(bundleId)) return null;
|
|
899
|
-
const appPathRaw = execText("/usr/bin/osascript", ["-e", `POSIX path of (path to application id "${bundleId}")`]);
|
|
900
|
-
if (!appPathRaw) return null;
|
|
901
|
-
const appPath = appPathRaw.trim().replace(/\/$/, "");
|
|
902
|
-
const exeName = execText("/usr/bin/defaults", [
|
|
903
|
-
"read",
|
|
904
|
-
path.join(appPath, "Contents", "Info"),
|
|
905
|
-
"CFBundleExecutable"
|
|
906
|
-
]);
|
|
907
|
-
if (!exeName) return null;
|
|
908
|
-
const exePath = path.join(appPath, "Contents", "MacOS", exeName.trim());
|
|
909
|
-
if (!exists$1(exePath)) return null;
|
|
910
|
-
return {
|
|
911
|
-
kind: inferKindFromIdentifier(bundleId),
|
|
912
|
-
path: exePath
|
|
913
|
-
};
|
|
914
|
-
}
|
|
915
|
-
function detectDefaultBrowserBundleIdMac() {
|
|
916
|
-
const plistPath = path.join(os.homedir(), "Library/Preferences/com.apple.LaunchServices/com.apple.launchservices.secure.plist");
|
|
917
|
-
if (!exists$1(plistPath)) return null;
|
|
918
|
-
const handlersRaw = execText("/usr/bin/plutil", [
|
|
919
|
-
"-extract",
|
|
920
|
-
"LSHandlers",
|
|
921
|
-
"json",
|
|
922
|
-
"-o",
|
|
923
|
-
"-",
|
|
924
|
-
"--",
|
|
925
|
-
plistPath
|
|
926
|
-
], 2e3, 5 * 1024 * 1024);
|
|
927
|
-
if (!handlersRaw) return null;
|
|
928
|
-
let handlers;
|
|
929
|
-
try {
|
|
930
|
-
handlers = JSON.parse(handlersRaw);
|
|
931
|
-
} catch {
|
|
932
|
-
return null;
|
|
933
|
-
}
|
|
934
|
-
if (!Array.isArray(handlers)) return null;
|
|
935
|
-
const resolveScheme = (scheme) => {
|
|
936
|
-
let candidate = null;
|
|
937
|
-
for (const entry of handlers) {
|
|
938
|
-
if (!entry || typeof entry !== "object") continue;
|
|
939
|
-
const record = entry;
|
|
940
|
-
if (record.LSHandlerURLScheme !== scheme) continue;
|
|
941
|
-
const role = typeof record.LSHandlerRoleAll === "string" && record.LSHandlerRoleAll || typeof record.LSHandlerRoleViewer === "string" && record.LSHandlerRoleViewer || null;
|
|
942
|
-
if (role) candidate = role;
|
|
943
|
-
}
|
|
944
|
-
return candidate;
|
|
945
|
-
};
|
|
946
|
-
return resolveScheme("http") ?? resolveScheme("https");
|
|
947
|
-
}
|
|
948
|
-
function detectDefaultChromiumExecutableLinux() {
|
|
949
|
-
const desktopId = execText("xdg-settings", ["get", "default-web-browser"]) || execText("xdg-mime", [
|
|
950
|
-
"query",
|
|
951
|
-
"default",
|
|
952
|
-
"x-scheme-handler/http"
|
|
953
|
-
]);
|
|
954
|
-
if (!desktopId) return null;
|
|
955
|
-
const trimmed = desktopId.trim();
|
|
956
|
-
if (!CHROMIUM_DESKTOP_IDS.has(trimmed)) return null;
|
|
957
|
-
const desktopPath = findDesktopFilePath(trimmed);
|
|
958
|
-
if (!desktopPath) return null;
|
|
959
|
-
const execLine = readDesktopExecLine(desktopPath);
|
|
960
|
-
if (!execLine) return null;
|
|
961
|
-
const command = extractExecutableFromExecLine(execLine);
|
|
962
|
-
if (!command) return null;
|
|
963
|
-
const resolved = resolveLinuxExecutablePath(command);
|
|
964
|
-
if (!resolved) return null;
|
|
965
|
-
const exeName = path.posix.basename(resolved).toLowerCase();
|
|
966
|
-
if (!CHROMIUM_EXE_NAMES.has(exeName)) return null;
|
|
967
|
-
return {
|
|
968
|
-
kind: inferKindFromExecutableName(exeName),
|
|
969
|
-
path: resolved
|
|
970
|
-
};
|
|
971
|
-
}
|
|
972
|
-
function detectDefaultChromiumExecutableWindows() {
|
|
973
|
-
const progId = readWindowsProgId();
|
|
974
|
-
const command = (progId ? readWindowsCommandForProgId(progId) : null) || readWindowsCommandForProgId("http");
|
|
975
|
-
if (!command) return null;
|
|
976
|
-
const exePath = extractWindowsExecutablePath(expandWindowsEnvVars(command));
|
|
977
|
-
if (!exePath) return null;
|
|
978
|
-
if (!exists$1(exePath)) return null;
|
|
979
|
-
const exeName = path.win32.basename(exePath).toLowerCase();
|
|
980
|
-
if (!CHROMIUM_EXE_NAMES.has(exeName)) return null;
|
|
981
|
-
return {
|
|
982
|
-
kind: inferKindFromExecutableName(exeName),
|
|
983
|
-
path: exePath
|
|
984
|
-
};
|
|
985
|
-
}
|
|
986
|
-
function findDesktopFilePath(desktopId) {
|
|
987
|
-
const candidates = [
|
|
988
|
-
path.join(os.homedir(), ".local", "share", "applications", desktopId),
|
|
989
|
-
path.join("/usr/local/share/applications", desktopId),
|
|
990
|
-
path.join("/usr/share/applications", desktopId),
|
|
991
|
-
path.join("/var/lib/snapd/desktop/applications", desktopId)
|
|
992
|
-
];
|
|
993
|
-
for (const candidate of candidates) if (exists$1(candidate)) return candidate;
|
|
994
|
-
return null;
|
|
995
|
-
}
|
|
996
|
-
function readDesktopExecLine(desktopPath) {
|
|
997
|
-
try {
|
|
998
|
-
const lines = fs.readFileSync(desktopPath, "utf8").split(/\r?\n/);
|
|
999
|
-
for (const line of lines) if (line.startsWith("Exec=")) return line.slice(5).trim();
|
|
1000
|
-
} catch {}
|
|
1001
|
-
return null;
|
|
1002
|
-
}
|
|
1003
|
-
function extractExecutableFromExecLine(execLine) {
|
|
1004
|
-
const tokens = splitExecLine(execLine);
|
|
1005
|
-
for (const token of tokens) {
|
|
1006
|
-
if (!token) continue;
|
|
1007
|
-
if (token === "env") continue;
|
|
1008
|
-
if (token.includes("=") && !token.startsWith("/") && !token.includes("\\")) continue;
|
|
1009
|
-
return token.replace(/^["']|["']$/g, "");
|
|
1010
|
-
}
|
|
1011
|
-
return null;
|
|
1012
|
-
}
|
|
1013
|
-
function splitExecLine(line) {
|
|
1014
|
-
const tokens = [];
|
|
1015
|
-
let current = "";
|
|
1016
|
-
let inQuotes = false;
|
|
1017
|
-
let quoteChar = "";
|
|
1018
|
-
for (let i = 0; i < line.length; i += 1) {
|
|
1019
|
-
const ch = line[i];
|
|
1020
|
-
if ((ch === "\"" || ch === "'") && (!inQuotes || ch === quoteChar)) {
|
|
1021
|
-
if (inQuotes) {
|
|
1022
|
-
inQuotes = false;
|
|
1023
|
-
quoteChar = "";
|
|
1024
|
-
} else {
|
|
1025
|
-
inQuotes = true;
|
|
1026
|
-
quoteChar = ch;
|
|
1027
|
-
}
|
|
1028
|
-
continue;
|
|
1029
|
-
}
|
|
1030
|
-
if (!inQuotes && /\s/.test(ch)) {
|
|
1031
|
-
if (current) {
|
|
1032
|
-
tokens.push(current);
|
|
1033
|
-
current = "";
|
|
1034
|
-
}
|
|
1035
|
-
continue;
|
|
1036
|
-
}
|
|
1037
|
-
current += ch;
|
|
1038
|
-
}
|
|
1039
|
-
if (current) tokens.push(current);
|
|
1040
|
-
return tokens;
|
|
1041
|
-
}
|
|
1042
|
-
function resolveLinuxExecutablePath(command) {
|
|
1043
|
-
const cleaned = command.trim().replace(/%[a-zA-Z]/g, "");
|
|
1044
|
-
if (!cleaned) return null;
|
|
1045
|
-
if (cleaned.startsWith("/")) return cleaned;
|
|
1046
|
-
const resolved = execText("which", [cleaned], 800);
|
|
1047
|
-
return resolved ? resolved.trim() : null;
|
|
1048
|
-
}
|
|
1049
|
-
function readWindowsProgId() {
|
|
1050
|
-
const output = execText("reg", [
|
|
1051
|
-
"query",
|
|
1052
|
-
"HKCU\\Software\\Microsoft\\Windows\\Shell\\Associations\\UrlAssociations\\http\\UserChoice",
|
|
1053
|
-
"/v",
|
|
1054
|
-
"ProgId"
|
|
1055
|
-
]);
|
|
1056
|
-
if (!output) return null;
|
|
1057
|
-
return output.match(/ProgId\s+REG_\w+\s+(.+)$/im)?.[1]?.trim() || null;
|
|
1058
|
-
}
|
|
1059
|
-
function readWindowsCommandForProgId(progId) {
|
|
1060
|
-
const output = execText("reg", [
|
|
1061
|
-
"query",
|
|
1062
|
-
progId === "http" ? "HKCR\\http\\shell\\open\\command" : `HKCR\\${progId}\\shell\\open\\command`,
|
|
1063
|
-
"/ve"
|
|
1064
|
-
]);
|
|
1065
|
-
if (!output) return null;
|
|
1066
|
-
return output.match(/REG_\w+\s+(.+)$/im)?.[1]?.trim() || null;
|
|
1067
|
-
}
|
|
1068
|
-
function expandWindowsEnvVars(value) {
|
|
1069
|
-
return value.replace(/%([^%]+)%/g, (_match, name) => {
|
|
1070
|
-
const key = String(name ?? "").trim();
|
|
1071
|
-
return key ? process.env[key] ?? `%${key}%` : _match;
|
|
1072
|
-
});
|
|
1073
|
-
}
|
|
1074
|
-
function extractWindowsExecutablePath(command) {
|
|
1075
|
-
const quoted = command.match(/"([^"]+\\.exe)"/i);
|
|
1076
|
-
if (quoted?.[1]) return quoted[1];
|
|
1077
|
-
const unquoted = command.match(/([^\\s]+\\.exe)/i);
|
|
1078
|
-
if (unquoted?.[1]) return unquoted[1];
|
|
1079
|
-
return null;
|
|
1080
|
-
}
|
|
1081
|
-
function findFirstExecutable(candidates) {
|
|
1082
|
-
for (const candidate of candidates) if (exists$1(candidate.path)) return candidate;
|
|
1083
|
-
return null;
|
|
1084
|
-
}
|
|
1085
|
-
function findChromeExecutableMac() {
|
|
1086
|
-
return findFirstExecutable([
|
|
1087
|
-
{
|
|
1088
|
-
kind: "chrome",
|
|
1089
|
-
path: "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome"
|
|
1090
|
-
},
|
|
1091
|
-
{
|
|
1092
|
-
kind: "chrome",
|
|
1093
|
-
path: path.join(os.homedir(), "Applications/Google Chrome.app/Contents/MacOS/Google Chrome")
|
|
1094
|
-
},
|
|
1095
|
-
{
|
|
1096
|
-
kind: "brave",
|
|
1097
|
-
path: "/Applications/Brave Browser.app/Contents/MacOS/Brave Browser"
|
|
1098
|
-
},
|
|
1099
|
-
{
|
|
1100
|
-
kind: "brave",
|
|
1101
|
-
path: path.join(os.homedir(), "Applications/Brave Browser.app/Contents/MacOS/Brave Browser")
|
|
1102
|
-
},
|
|
1103
|
-
{
|
|
1104
|
-
kind: "edge",
|
|
1105
|
-
path: "/Applications/Microsoft Edge.app/Contents/MacOS/Microsoft Edge"
|
|
1106
|
-
},
|
|
1107
|
-
{
|
|
1108
|
-
kind: "edge",
|
|
1109
|
-
path: path.join(os.homedir(), "Applications/Microsoft Edge.app/Contents/MacOS/Microsoft Edge")
|
|
1110
|
-
},
|
|
1111
|
-
{
|
|
1112
|
-
kind: "chromium",
|
|
1113
|
-
path: "/Applications/Chromium.app/Contents/MacOS/Chromium"
|
|
1114
|
-
},
|
|
1115
|
-
{
|
|
1116
|
-
kind: "chromium",
|
|
1117
|
-
path: path.join(os.homedir(), "Applications/Chromium.app/Contents/MacOS/Chromium")
|
|
1118
|
-
},
|
|
1119
|
-
{
|
|
1120
|
-
kind: "canary",
|
|
1121
|
-
path: "/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary"
|
|
1122
|
-
},
|
|
1123
|
-
{
|
|
1124
|
-
kind: "canary",
|
|
1125
|
-
path: path.join(os.homedir(), "Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary")
|
|
1126
|
-
}
|
|
1127
|
-
]);
|
|
1128
|
-
}
|
|
1129
|
-
function findChromeExecutableLinux() {
|
|
1130
|
-
return findFirstExecutable([
|
|
1131
|
-
{
|
|
1132
|
-
kind: "chrome",
|
|
1133
|
-
path: "/usr/bin/google-chrome"
|
|
1134
|
-
},
|
|
1135
|
-
{
|
|
1136
|
-
kind: "chrome",
|
|
1137
|
-
path: "/usr/bin/google-chrome-stable"
|
|
1138
|
-
},
|
|
1139
|
-
{
|
|
1140
|
-
kind: "chrome",
|
|
1141
|
-
path: "/usr/bin/chrome"
|
|
1142
|
-
},
|
|
1143
|
-
{
|
|
1144
|
-
kind: "brave",
|
|
1145
|
-
path: "/usr/bin/brave-browser"
|
|
1146
|
-
},
|
|
1147
|
-
{
|
|
1148
|
-
kind: "brave",
|
|
1149
|
-
path: "/usr/bin/brave-browser-stable"
|
|
1150
|
-
},
|
|
1151
|
-
{
|
|
1152
|
-
kind: "brave",
|
|
1153
|
-
path: "/usr/bin/brave"
|
|
1154
|
-
},
|
|
1155
|
-
{
|
|
1156
|
-
kind: "brave",
|
|
1157
|
-
path: "/snap/bin/brave"
|
|
1158
|
-
},
|
|
1159
|
-
{
|
|
1160
|
-
kind: "edge",
|
|
1161
|
-
path: "/usr/bin/microsoft-edge"
|
|
1162
|
-
},
|
|
1163
|
-
{
|
|
1164
|
-
kind: "edge",
|
|
1165
|
-
path: "/usr/bin/microsoft-edge-stable"
|
|
1166
|
-
},
|
|
1167
|
-
{
|
|
1168
|
-
kind: "chromium",
|
|
1169
|
-
path: "/usr/bin/chromium"
|
|
1170
|
-
},
|
|
1171
|
-
{
|
|
1172
|
-
kind: "chromium",
|
|
1173
|
-
path: "/usr/bin/chromium-browser"
|
|
1174
|
-
},
|
|
1175
|
-
{
|
|
1176
|
-
kind: "chromium",
|
|
1177
|
-
path: "/snap/bin/chromium"
|
|
1178
|
-
}
|
|
1179
|
-
]);
|
|
1180
|
-
}
|
|
1181
|
-
function findChromeExecutableWindows() {
|
|
1182
|
-
const localAppData = process.env.LOCALAPPDATA ?? "";
|
|
1183
|
-
const programFiles = process.env.ProgramFiles ?? "C:\\Program Files";
|
|
1184
|
-
const programFilesX86 = process.env["ProgramFiles(x86)"] ?? "C:\\Program Files (x86)";
|
|
1185
|
-
const joinWin = path.win32.join;
|
|
1186
|
-
const candidates = [];
|
|
1187
|
-
if (localAppData) {
|
|
1188
|
-
candidates.push({
|
|
1189
|
-
kind: "chrome",
|
|
1190
|
-
path: joinWin(localAppData, "Google", "Chrome", "Application", "chrome.exe")
|
|
1191
|
-
});
|
|
1192
|
-
candidates.push({
|
|
1193
|
-
kind: "brave",
|
|
1194
|
-
path: joinWin(localAppData, "BraveSoftware", "Brave-Browser", "Application", "brave.exe")
|
|
1195
|
-
});
|
|
1196
|
-
candidates.push({
|
|
1197
|
-
kind: "edge",
|
|
1198
|
-
path: joinWin(localAppData, "Microsoft", "Edge", "Application", "msedge.exe")
|
|
1199
|
-
});
|
|
1200
|
-
candidates.push({
|
|
1201
|
-
kind: "chromium",
|
|
1202
|
-
path: joinWin(localAppData, "Chromium", "Application", "chrome.exe")
|
|
1203
|
-
});
|
|
1204
|
-
candidates.push({
|
|
1205
|
-
kind: "canary",
|
|
1206
|
-
path: joinWin(localAppData, "Google", "Chrome SxS", "Application", "chrome.exe")
|
|
1207
|
-
});
|
|
1208
|
-
}
|
|
1209
|
-
candidates.push({
|
|
1210
|
-
kind: "chrome",
|
|
1211
|
-
path: joinWin(programFiles, "Google", "Chrome", "Application", "chrome.exe")
|
|
1212
|
-
});
|
|
1213
|
-
candidates.push({
|
|
1214
|
-
kind: "chrome",
|
|
1215
|
-
path: joinWin(programFilesX86, "Google", "Chrome", "Application", "chrome.exe")
|
|
1216
|
-
});
|
|
1217
|
-
candidates.push({
|
|
1218
|
-
kind: "brave",
|
|
1219
|
-
path: joinWin(programFiles, "BraveSoftware", "Brave-Browser", "Application", "brave.exe")
|
|
1220
|
-
});
|
|
1221
|
-
candidates.push({
|
|
1222
|
-
kind: "brave",
|
|
1223
|
-
path: joinWin(programFilesX86, "BraveSoftware", "Brave-Browser", "Application", "brave.exe")
|
|
1224
|
-
});
|
|
1225
|
-
candidates.push({
|
|
1226
|
-
kind: "edge",
|
|
1227
|
-
path: joinWin(programFiles, "Microsoft", "Edge", "Application", "msedge.exe")
|
|
1228
|
-
});
|
|
1229
|
-
candidates.push({
|
|
1230
|
-
kind: "edge",
|
|
1231
|
-
path: joinWin(programFilesX86, "Microsoft", "Edge", "Application", "msedge.exe")
|
|
1232
|
-
});
|
|
1233
|
-
return findFirstExecutable(candidates);
|
|
1234
|
-
}
|
|
1235
|
-
function resolveBrowserExecutableForPlatform(resolved, platform) {
|
|
1236
|
-
if (resolved.executablePath) {
|
|
1237
|
-
if (!exists$1(resolved.executablePath)) throw new Error(`browser.executablePath not found: ${resolved.executablePath}`);
|
|
1238
|
-
return {
|
|
1239
|
-
kind: "custom",
|
|
1240
|
-
path: resolved.executablePath
|
|
1241
|
-
};
|
|
1242
|
-
}
|
|
1243
|
-
const detected = detectDefaultChromiumExecutable(platform);
|
|
1244
|
-
if (detected) return detected;
|
|
1245
|
-
if (platform === "darwin") return findChromeExecutableMac();
|
|
1246
|
-
if (platform === "linux") return findChromeExecutableLinux();
|
|
1247
|
-
if (platform === "win32") return findChromeExecutableWindows();
|
|
1248
|
-
return null;
|
|
1249
|
-
}
|
|
1250
|
-
|
|
1251
|
-
//#endregion
|
|
1252
|
-
//#region src/browser/chrome.profile-decoration.ts
|
|
1253
|
-
function decoratedMarkerPath(userDataDir) {
|
|
1254
|
-
return path.join(userDataDir, ".anima-profile-decorated");
|
|
1255
|
-
}
|
|
1256
|
-
function safeReadJson(filePath) {
|
|
1257
|
-
try {
|
|
1258
|
-
if (!fs.existsSync(filePath)) return null;
|
|
1259
|
-
const raw = fs.readFileSync(filePath, "utf-8");
|
|
1260
|
-
const parsed = JSON.parse(raw);
|
|
1261
|
-
if (typeof parsed !== "object" || parsed === null || Array.isArray(parsed)) return null;
|
|
1262
|
-
return parsed;
|
|
1263
|
-
} catch {
|
|
1264
|
-
return null;
|
|
1265
|
-
}
|
|
1266
|
-
}
|
|
1267
|
-
function safeWriteJson(filePath, data) {
|
|
1268
|
-
fs.mkdirSync(path.dirname(filePath), { recursive: true });
|
|
1269
|
-
fs.writeFileSync(filePath, JSON.stringify(data, null, 2));
|
|
1270
|
-
}
|
|
1271
|
-
function setDeep(obj, keys, value) {
|
|
1272
|
-
let node = obj;
|
|
1273
|
-
for (const key of keys.slice(0, -1)) {
|
|
1274
|
-
const next = node[key];
|
|
1275
|
-
if (typeof next !== "object" || next === null || Array.isArray(next)) node[key] = {};
|
|
1276
|
-
node = node[key];
|
|
1277
|
-
}
|
|
1278
|
-
node[keys[keys.length - 1] ?? ""] = value;
|
|
1279
|
-
}
|
|
1280
|
-
function parseHexRgbToSignedArgbInt(hex) {
|
|
1281
|
-
const cleaned = hex.trim().replace(/^#/, "");
|
|
1282
|
-
if (!/^[0-9a-fA-F]{6}$/.test(cleaned)) return null;
|
|
1283
|
-
const argbUnsigned = 255 << 24 | Number.parseInt(cleaned, 16);
|
|
1284
|
-
return argbUnsigned > 2147483647 ? argbUnsigned - 4294967296 : argbUnsigned;
|
|
1285
|
-
}
|
|
1286
|
-
function isProfileDecorated(userDataDir, desiredName, desiredColorHex) {
|
|
1287
|
-
const desiredColorInt = parseHexRgbToSignedArgbInt(desiredColorHex);
|
|
1288
|
-
const localStatePath = path.join(userDataDir, "Local State");
|
|
1289
|
-
const preferencesPath = path.join(userDataDir, "Default", "Preferences");
|
|
1290
|
-
const profile = safeReadJson(localStatePath)?.profile;
|
|
1291
|
-
const infoCache = typeof profile === "object" && profile !== null && !Array.isArray(profile) ? profile.info_cache : null;
|
|
1292
|
-
const info = typeof infoCache === "object" && infoCache !== null && !Array.isArray(infoCache) && typeof infoCache.Default === "object" && infoCache.Default !== null && !Array.isArray(infoCache.Default) ? infoCache.Default : null;
|
|
1293
|
-
const prefs = safeReadJson(preferencesPath);
|
|
1294
|
-
const browserTheme = (() => {
|
|
1295
|
-
const browser = prefs?.browser;
|
|
1296
|
-
const theme = typeof browser === "object" && browser !== null && !Array.isArray(browser) ? browser.theme : null;
|
|
1297
|
-
return typeof theme === "object" && theme !== null && !Array.isArray(theme) ? theme : null;
|
|
1298
|
-
})();
|
|
1299
|
-
const autogeneratedTheme = (() => {
|
|
1300
|
-
const autogenerated = prefs?.autogenerated;
|
|
1301
|
-
const theme = typeof autogenerated === "object" && autogenerated !== null && !Array.isArray(autogenerated) ? autogenerated.theme : null;
|
|
1302
|
-
return typeof theme === "object" && theme !== null && !Array.isArray(theme) ? theme : null;
|
|
1303
|
-
})();
|
|
1304
|
-
const nameOk = typeof info?.name === "string" ? info.name === desiredName : true;
|
|
1305
|
-
if (desiredColorInt == null) return nameOk;
|
|
1306
|
-
const localSeedOk = typeof info?.profile_color_seed === "number" ? info.profile_color_seed === desiredColorInt : false;
|
|
1307
|
-
const prefOk = typeof browserTheme?.user_color2 === "number" && browserTheme.user_color2 === desiredColorInt || typeof autogeneratedTheme?.color === "number" && autogeneratedTheme.color === desiredColorInt;
|
|
1308
|
-
return nameOk && localSeedOk && prefOk;
|
|
1309
|
-
}
|
|
1310
|
-
/**
|
|
1311
|
-
* Best-effort profile decoration (name + lobster-orange). Chrome preference keys
|
|
1312
|
-
* vary by version; we keep this conservative and idempotent.
|
|
1313
|
-
*/
|
|
1314
|
-
function decorateAnimaProfile(userDataDir, opts) {
|
|
1315
|
-
const desiredName = opts?.name ?? DEFAULT_ANIMA_BROWSER_PROFILE_NAME;
|
|
1316
|
-
const desiredColor = (opts?.color ?? DEFAULT_ANIMA_BROWSER_COLOR).toUpperCase();
|
|
1317
|
-
const desiredColorInt = parseHexRgbToSignedArgbInt(desiredColor);
|
|
1318
|
-
const localStatePath = path.join(userDataDir, "Local State");
|
|
1319
|
-
const preferencesPath = path.join(userDataDir, "Default", "Preferences");
|
|
1320
|
-
const localState = safeReadJson(localStatePath) ?? {};
|
|
1321
|
-
setDeep(localState, [
|
|
1322
|
-
"profile",
|
|
1323
|
-
"info_cache",
|
|
1324
|
-
"Default",
|
|
1325
|
-
"name"
|
|
1326
|
-
], desiredName);
|
|
1327
|
-
setDeep(localState, [
|
|
1328
|
-
"profile",
|
|
1329
|
-
"info_cache",
|
|
1330
|
-
"Default",
|
|
1331
|
-
"shortcut_name"
|
|
1332
|
-
], desiredName);
|
|
1333
|
-
setDeep(localState, [
|
|
1334
|
-
"profile",
|
|
1335
|
-
"info_cache",
|
|
1336
|
-
"Default",
|
|
1337
|
-
"user_name"
|
|
1338
|
-
], desiredName);
|
|
1339
|
-
setDeep(localState, [
|
|
1340
|
-
"profile",
|
|
1341
|
-
"info_cache",
|
|
1342
|
-
"Default",
|
|
1343
|
-
"profile_color"
|
|
1344
|
-
], desiredColor);
|
|
1345
|
-
setDeep(localState, [
|
|
1346
|
-
"profile",
|
|
1347
|
-
"info_cache",
|
|
1348
|
-
"Default",
|
|
1349
|
-
"user_color"
|
|
1350
|
-
], desiredColor);
|
|
1351
|
-
if (desiredColorInt != null) {
|
|
1352
|
-
setDeep(localState, [
|
|
1353
|
-
"profile",
|
|
1354
|
-
"info_cache",
|
|
1355
|
-
"Default",
|
|
1356
|
-
"profile_color_seed"
|
|
1357
|
-
], desiredColorInt);
|
|
1358
|
-
setDeep(localState, [
|
|
1359
|
-
"profile",
|
|
1360
|
-
"info_cache",
|
|
1361
|
-
"Default",
|
|
1362
|
-
"profile_highlight_color"
|
|
1363
|
-
], desiredColorInt);
|
|
1364
|
-
setDeep(localState, [
|
|
1365
|
-
"profile",
|
|
1366
|
-
"info_cache",
|
|
1367
|
-
"Default",
|
|
1368
|
-
"default_avatar_fill_color"
|
|
1369
|
-
], desiredColorInt);
|
|
1370
|
-
setDeep(localState, [
|
|
1371
|
-
"profile",
|
|
1372
|
-
"info_cache",
|
|
1373
|
-
"Default",
|
|
1374
|
-
"default_avatar_stroke_color"
|
|
1375
|
-
], desiredColorInt);
|
|
1376
|
-
}
|
|
1377
|
-
safeWriteJson(localStatePath, localState);
|
|
1378
|
-
const prefs = safeReadJson(preferencesPath) ?? {};
|
|
1379
|
-
setDeep(prefs, ["profile", "name"], desiredName);
|
|
1380
|
-
setDeep(prefs, ["profile", "profile_color"], desiredColor);
|
|
1381
|
-
setDeep(prefs, ["profile", "user_color"], desiredColor);
|
|
1382
|
-
if (desiredColorInt != null) {
|
|
1383
|
-
setDeep(prefs, [
|
|
1384
|
-
"autogenerated",
|
|
1385
|
-
"theme",
|
|
1386
|
-
"color"
|
|
1387
|
-
], desiredColorInt);
|
|
1388
|
-
setDeep(prefs, [
|
|
1389
|
-
"browser",
|
|
1390
|
-
"theme",
|
|
1391
|
-
"user_color2"
|
|
1392
|
-
], desiredColorInt);
|
|
1393
|
-
}
|
|
1394
|
-
safeWriteJson(preferencesPath, prefs);
|
|
1395
|
-
try {
|
|
1396
|
-
fs.writeFileSync(decoratedMarkerPath(userDataDir), `${Date.now()}\n`, "utf-8");
|
|
1397
|
-
} catch {}
|
|
1398
|
-
}
|
|
1399
|
-
function ensureProfileCleanExit(userDataDir) {
|
|
1400
|
-
const preferencesPath = path.join(userDataDir, "Default", "Preferences");
|
|
1401
|
-
const prefs = safeReadJson(preferencesPath) ?? {};
|
|
1402
|
-
setDeep(prefs, ["exit_type"], "Normal");
|
|
1403
|
-
setDeep(prefs, ["exited_cleanly"], true);
|
|
1404
|
-
safeWriteJson(preferencesPath, prefs);
|
|
1405
|
-
}
|
|
1406
|
-
|
|
1407
|
-
//#endregion
|
|
1408
|
-
//#region src/browser/chrome.ts
|
|
1409
|
-
const log = createSubsystemLogger("browser").child("chrome");
|
|
1410
|
-
function exists(filePath) {
|
|
1411
|
-
try {
|
|
1412
|
-
return fs.existsSync(filePath);
|
|
1413
|
-
} catch {
|
|
1414
|
-
return false;
|
|
1415
|
-
}
|
|
1416
|
-
}
|
|
1417
|
-
function resolveBrowserExecutable(resolved) {
|
|
1418
|
-
return resolveBrowserExecutableForPlatform(resolved, process.platform);
|
|
1419
|
-
}
|
|
1420
|
-
function resolveAnimaUserDataDir(profileName = DEFAULT_ANIMA_BROWSER_PROFILE_NAME) {
|
|
1421
|
-
return path.join(CONFIG_DIR, "browser", profileName, "user-data");
|
|
1422
|
-
}
|
|
1423
|
-
function cdpUrlForPort(cdpPort) {
|
|
1424
|
-
return `http://127.0.0.1:${cdpPort}`;
|
|
1425
|
-
}
|
|
1426
|
-
async function isChromeReachable(cdpUrl, timeoutMs = 500) {
|
|
1427
|
-
const version = await fetchChromeVersion(cdpUrl, timeoutMs);
|
|
1428
|
-
return Boolean(version);
|
|
1429
|
-
}
|
|
1430
|
-
async function fetchChromeVersion(cdpUrl, timeoutMs = 500) {
|
|
1431
|
-
const ctrl = new AbortController();
|
|
1432
|
-
const t = setTimeout(ctrl.abort.bind(ctrl), timeoutMs);
|
|
1433
|
-
try {
|
|
1434
|
-
const versionUrl = appendCdpPath(cdpUrl, "/json/version");
|
|
1435
|
-
const res = await fetch(versionUrl, {
|
|
1436
|
-
signal: ctrl.signal,
|
|
1437
|
-
headers: getHeadersWithAuth(versionUrl)
|
|
1438
|
-
});
|
|
1439
|
-
if (!res.ok) return null;
|
|
1440
|
-
const data = await res.json();
|
|
1441
|
-
if (!data || typeof data !== "object") return null;
|
|
1442
|
-
return data;
|
|
1443
|
-
} catch {
|
|
1444
|
-
return null;
|
|
1445
|
-
} finally {
|
|
1446
|
-
clearTimeout(t);
|
|
1447
|
-
}
|
|
1448
|
-
}
|
|
1449
|
-
async function getChromeWebSocketUrl(cdpUrl, timeoutMs = 500) {
|
|
1450
|
-
const version = await fetchChromeVersion(cdpUrl, timeoutMs);
|
|
1451
|
-
const wsUrl = String(version?.webSocketDebuggerUrl ?? "").trim();
|
|
1452
|
-
if (!wsUrl) return null;
|
|
1453
|
-
return normalizeCdpWsUrl(wsUrl, cdpUrl);
|
|
1454
|
-
}
|
|
1455
|
-
async function canOpenWebSocket(wsUrl, timeoutMs = 800) {
|
|
1456
|
-
return await new Promise((resolve) => {
|
|
1457
|
-
const headers = getHeadersWithAuth(wsUrl);
|
|
1458
|
-
const ws = new WebSocket(wsUrl, {
|
|
1459
|
-
handshakeTimeout: timeoutMs,
|
|
1460
|
-
...Object.keys(headers).length ? { headers } : {}
|
|
1461
|
-
});
|
|
1462
|
-
const timer = setTimeout(() => {
|
|
1463
|
-
try {
|
|
1464
|
-
ws.terminate();
|
|
1465
|
-
} catch {}
|
|
1466
|
-
resolve(false);
|
|
1467
|
-
}, Math.max(50, timeoutMs + 25));
|
|
1468
|
-
ws.once("open", () => {
|
|
1469
|
-
clearTimeout(timer);
|
|
1470
|
-
try {
|
|
1471
|
-
ws.close();
|
|
1472
|
-
} catch {}
|
|
1473
|
-
resolve(true);
|
|
1474
|
-
});
|
|
1475
|
-
ws.once("error", () => {
|
|
1476
|
-
clearTimeout(timer);
|
|
1477
|
-
resolve(false);
|
|
1478
|
-
});
|
|
1479
|
-
});
|
|
1480
|
-
}
|
|
1481
|
-
async function isChromeCdpReady(cdpUrl, timeoutMs = 500, handshakeTimeoutMs = 800) {
|
|
1482
|
-
const wsUrl = await getChromeWebSocketUrl(cdpUrl, timeoutMs);
|
|
1483
|
-
if (!wsUrl) return false;
|
|
1484
|
-
return await canOpenWebSocket(wsUrl, handshakeTimeoutMs);
|
|
1485
|
-
}
|
|
1486
|
-
async function launchAnimaChrome(resolved, profile) {
|
|
1487
|
-
if (!profile.cdpIsLoopback) throw new Error(`Profile "${profile.name}" is remote; cannot launch local Chrome.`);
|
|
1488
|
-
await ensurePortAvailable(profile.cdpPort);
|
|
1489
|
-
const exe = resolveBrowserExecutable(resolved);
|
|
1490
|
-
if (!exe) throw new Error("No supported browser found (Chrome/Brave/Edge/Chromium on macOS, Linux, or Windows).");
|
|
1491
|
-
const userDataDir = resolveAnimaUserDataDir(profile.name);
|
|
1492
|
-
fs.mkdirSync(userDataDir, { recursive: true });
|
|
1493
|
-
const needsDecorate = !isProfileDecorated(userDataDir, profile.name, (profile.color ?? DEFAULT_ANIMA_BROWSER_COLOR).toUpperCase());
|
|
1494
|
-
const spawnOnce = () => {
|
|
1495
|
-
const args = [
|
|
1496
|
-
`--remote-debugging-port=${profile.cdpPort}`,
|
|
1497
|
-
`--user-data-dir=${userDataDir}`,
|
|
1498
|
-
"--no-first-run",
|
|
1499
|
-
"--no-default-browser-check",
|
|
1500
|
-
"--disable-sync",
|
|
1501
|
-
"--disable-background-networking",
|
|
1502
|
-
"--disable-component-update",
|
|
1503
|
-
"--disable-features=Translate,MediaRouter",
|
|
1504
|
-
"--disable-session-crashed-bubble",
|
|
1505
|
-
"--hide-crash-restore-bubble",
|
|
1506
|
-
"--password-store=basic"
|
|
1507
|
-
];
|
|
1508
|
-
if (resolved.headless) {
|
|
1509
|
-
args.push("--headless=new");
|
|
1510
|
-
args.push("--disable-gpu");
|
|
1511
|
-
}
|
|
1512
|
-
if (resolved.noSandbox) {
|
|
1513
|
-
args.push("--no-sandbox");
|
|
1514
|
-
args.push("--disable-setuid-sandbox");
|
|
1515
|
-
}
|
|
1516
|
-
if (process.platform === "linux") args.push("--disable-dev-shm-usage");
|
|
1517
|
-
args.push("--disable-blink-features=AutomationControlled");
|
|
1518
|
-
args.push("about:blank");
|
|
1519
|
-
return spawn(exe.path, args, {
|
|
1520
|
-
stdio: "pipe",
|
|
1521
|
-
env: {
|
|
1522
|
-
...process.env,
|
|
1523
|
-
HOME: os.homedir()
|
|
1524
|
-
}
|
|
1525
|
-
});
|
|
1526
|
-
};
|
|
1527
|
-
const startedAt = Date.now();
|
|
1528
|
-
const localStatePath = path.join(userDataDir, "Local State");
|
|
1529
|
-
const preferencesPath = path.join(userDataDir, "Default", "Preferences");
|
|
1530
|
-
if (!exists(localStatePath) || !exists(preferencesPath)) {
|
|
1531
|
-
const bootstrap = spawnOnce();
|
|
1532
|
-
const deadline = Date.now() + 1e4;
|
|
1533
|
-
while (Date.now() < deadline) {
|
|
1534
|
-
if (exists(localStatePath) && exists(preferencesPath)) break;
|
|
1535
|
-
await new Promise((r) => setTimeout(r, 100));
|
|
1536
|
-
}
|
|
1537
|
-
try {
|
|
1538
|
-
bootstrap.kill("SIGTERM");
|
|
1539
|
-
} catch {}
|
|
1540
|
-
const exitDeadline = Date.now() + 5e3;
|
|
1541
|
-
while (Date.now() < exitDeadline) {
|
|
1542
|
-
if (bootstrap.exitCode != null) break;
|
|
1543
|
-
await new Promise((r) => setTimeout(r, 50));
|
|
1544
|
-
}
|
|
1545
|
-
}
|
|
1546
|
-
if (needsDecorate) try {
|
|
1547
|
-
decorateAnimaProfile(userDataDir, {
|
|
1548
|
-
name: profile.name,
|
|
1549
|
-
color: profile.color
|
|
1550
|
-
});
|
|
1551
|
-
log.info(`🦞 anima browser profile decorated (${profile.color})`);
|
|
1552
|
-
} catch (err) {
|
|
1553
|
-
log.warn(`anima browser profile decoration failed: ${String(err)}`);
|
|
1554
|
-
}
|
|
1555
|
-
try {
|
|
1556
|
-
ensureProfileCleanExit(userDataDir);
|
|
1557
|
-
} catch (err) {
|
|
1558
|
-
log.warn(`anima browser clean-exit prefs failed: ${String(err)}`);
|
|
1559
|
-
}
|
|
1560
|
-
const proc = spawnOnce();
|
|
1561
|
-
const readyDeadline = Date.now() + 15e3;
|
|
1562
|
-
while (Date.now() < readyDeadline) {
|
|
1563
|
-
if (await isChromeReachable(profile.cdpUrl, 500)) break;
|
|
1564
|
-
await new Promise((r) => setTimeout(r, 200));
|
|
1565
|
-
}
|
|
1566
|
-
if (!await isChromeReachable(profile.cdpUrl, 500)) {
|
|
1567
|
-
try {
|
|
1568
|
-
proc.kill("SIGKILL");
|
|
1569
|
-
} catch {}
|
|
1570
|
-
throw new Error(`Failed to start Chrome CDP on port ${profile.cdpPort} for profile "${profile.name}".`);
|
|
1571
|
-
}
|
|
1572
|
-
const pid = proc.pid ?? -1;
|
|
1573
|
-
log.info(`🦞 anima browser started (${exe.kind}) profile "${profile.name}" on 127.0.0.1:${profile.cdpPort} (pid ${pid})`);
|
|
1574
|
-
return {
|
|
1575
|
-
pid,
|
|
1576
|
-
exe,
|
|
1577
|
-
userDataDir,
|
|
1578
|
-
cdpPort: profile.cdpPort,
|
|
1579
|
-
startedAt,
|
|
1580
|
-
proc
|
|
1581
|
-
};
|
|
1582
|
-
}
|
|
1583
|
-
async function stopAnimaChrome(running, timeoutMs = 2500) {
|
|
1584
|
-
const proc = running.proc;
|
|
1585
|
-
if (proc.killed) return;
|
|
1586
|
-
try {
|
|
1587
|
-
proc.kill("SIGTERM");
|
|
1588
|
-
} catch {}
|
|
1589
|
-
const start = Date.now();
|
|
1590
|
-
while (Date.now() - start < timeoutMs) {
|
|
1591
|
-
if (!proc.exitCode && proc.killed) break;
|
|
1592
|
-
if (!await isChromeReachable(cdpUrlForPort(running.cdpPort), 200)) return;
|
|
1593
|
-
await new Promise((r) => setTimeout(r, 100));
|
|
1594
|
-
}
|
|
1595
|
-
try {
|
|
1596
|
-
proc.kill("SIGKILL");
|
|
1597
|
-
} catch {}
|
|
1598
|
-
}
|
|
1599
|
-
|
|
1600
|
-
//#endregion
|
|
1601
|
-
export { DEFAULT_ANIMA_BROWSER_ENABLED as C, DEFAULT_BROWSER_EVALUATE_ENABLED as E, DEFAULT_ANIMA_BROWSER_COLOR as S, DEFAULT_BROWSER_DEFAULT_PROFILE_NAME as T, ensureChromeExtensionRelayServer as _, resolveAnimaUserDataDir as a, DEFAULT_AI_SNAPSHOT_EFFICIENT_MAX_CHARS as b, captureScreenshot as c, normalizeCdpWsUrl as d, snapshotAria as f, withCdpSocket as g, getHeadersWithAuth as h, launchAnimaChrome as i, createTargetViaCdp as l, fetchJson as m, isChromeCdpReady as n, stopAnimaChrome as o, appendCdpPath as p, isChromeReachable as r, resolveBrowserExecutableForPlatform as s, getChromeWebSocketUrl as t, formatAriaSnapshot as u, stopChromeExtensionRelayServer as v, DEFAULT_ANIMA_BROWSER_PROFILE_NAME as w, DEFAULT_AI_SNAPSHOT_MAX_CHARS as x, DEFAULT_AI_SNAPSHOT_EFFICIENT_DEPTH as y };
|