@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
|
@@ -0,0 +1,1167 @@
|
|
|
1
|
+
import { a as resolveOAuthDir, c as expandHomePrefix, l as resolveEffectiveHomeDir, n as resolveConfigPath, u as resolveRequiredHomeDir } from "./paths-DA9WYabg.js";
|
|
2
|
+
import { createRequire } from "node:module";
|
|
3
|
+
import os from "node:os";
|
|
4
|
+
import path from "node:path";
|
|
5
|
+
import fsSync from "node:fs";
|
|
6
|
+
import { Logger } from "tslog";
|
|
7
|
+
import JSON5 from "json5";
|
|
8
|
+
import chalk, { Chalk } from "chalk";
|
|
9
|
+
import { execFile, spawn } from "node:child_process";
|
|
10
|
+
import { promisify } from "node:util";
|
|
11
|
+
|
|
12
|
+
//#region src/infra/tmp-openclaw-dir.ts
|
|
13
|
+
const POSIX_ANIMA_TMP_DIR = "/tmp/anima";
|
|
14
|
+
function isNodeErrorWithCode(err, code) {
|
|
15
|
+
return typeof err === "object" && err !== null && "code" in err && err.code === code;
|
|
16
|
+
}
|
|
17
|
+
function resolvePreferredAnimaTmpDir(options = {}) {
|
|
18
|
+
const accessSync = options.accessSync ?? fsSync.accessSync;
|
|
19
|
+
const lstatSync = options.lstatSync ?? fsSync.lstatSync;
|
|
20
|
+
const mkdirSync = options.mkdirSync ?? fsSync.mkdirSync;
|
|
21
|
+
const getuid = options.getuid ?? (() => {
|
|
22
|
+
try {
|
|
23
|
+
return typeof process.getuid === "function" ? process.getuid() : void 0;
|
|
24
|
+
} catch {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
const tmpdir = options.tmpdir ?? os.tmpdir;
|
|
29
|
+
const uid = getuid();
|
|
30
|
+
const isSecureDirForUser = (st) => {
|
|
31
|
+
if (uid === void 0) return true;
|
|
32
|
+
if (typeof st.uid === "number" && st.uid !== uid) return false;
|
|
33
|
+
if (typeof st.mode === "number" && (st.mode & 18) !== 0) return false;
|
|
34
|
+
return true;
|
|
35
|
+
};
|
|
36
|
+
const fallback = () => {
|
|
37
|
+
const base = tmpdir();
|
|
38
|
+
const suffix = uid === void 0 ? "anima" : `anima-${uid}`;
|
|
39
|
+
return path.join(base, suffix);
|
|
40
|
+
};
|
|
41
|
+
try {
|
|
42
|
+
const preferred = lstatSync(POSIX_ANIMA_TMP_DIR);
|
|
43
|
+
if (!preferred.isDirectory() || preferred.isSymbolicLink()) return fallback();
|
|
44
|
+
accessSync(POSIX_ANIMA_TMP_DIR, fsSync.constants.W_OK | fsSync.constants.X_OK);
|
|
45
|
+
if (!isSecureDirForUser(preferred)) return fallback();
|
|
46
|
+
return POSIX_ANIMA_TMP_DIR;
|
|
47
|
+
} catch (err) {
|
|
48
|
+
if (!isNodeErrorWithCode(err, "ENOENT")) return fallback();
|
|
49
|
+
}
|
|
50
|
+
try {
|
|
51
|
+
accessSync("/tmp", fsSync.constants.W_OK | fsSync.constants.X_OK);
|
|
52
|
+
mkdirSync(POSIX_ANIMA_TMP_DIR, {
|
|
53
|
+
recursive: true,
|
|
54
|
+
mode: 448
|
|
55
|
+
});
|
|
56
|
+
try {
|
|
57
|
+
const preferred = lstatSync(POSIX_ANIMA_TMP_DIR);
|
|
58
|
+
if (!preferred.isDirectory() || preferred.isSymbolicLink()) return fallback();
|
|
59
|
+
if (!isSecureDirForUser(preferred)) return fallback();
|
|
60
|
+
} catch {
|
|
61
|
+
return fallback();
|
|
62
|
+
}
|
|
63
|
+
return POSIX_ANIMA_TMP_DIR;
|
|
64
|
+
} catch {
|
|
65
|
+
return fallback();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
//#endregion
|
|
70
|
+
//#region src/logging/config.ts
|
|
71
|
+
function readLoggingConfig() {
|
|
72
|
+
const configPath = resolveConfigPath();
|
|
73
|
+
try {
|
|
74
|
+
if (!fsSync.existsSync(configPath)) return;
|
|
75
|
+
const raw = fsSync.readFileSync(configPath, "utf-8");
|
|
76
|
+
const logging = JSON5.parse(raw)?.logging;
|
|
77
|
+
if (!logging || typeof logging !== "object" || Array.isArray(logging)) return;
|
|
78
|
+
return logging;
|
|
79
|
+
} catch {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
//#endregion
|
|
85
|
+
//#region src/logging/levels.ts
|
|
86
|
+
const ALLOWED_LOG_LEVELS = [
|
|
87
|
+
"silent",
|
|
88
|
+
"fatal",
|
|
89
|
+
"error",
|
|
90
|
+
"warn",
|
|
91
|
+
"info",
|
|
92
|
+
"debug",
|
|
93
|
+
"trace"
|
|
94
|
+
];
|
|
95
|
+
function normalizeLogLevel(level, fallback = "info") {
|
|
96
|
+
const candidate = (level ?? fallback).trim();
|
|
97
|
+
return ALLOWED_LOG_LEVELS.includes(candidate) ? candidate : fallback;
|
|
98
|
+
}
|
|
99
|
+
function levelToMinLevel(level) {
|
|
100
|
+
return {
|
|
101
|
+
fatal: 0,
|
|
102
|
+
error: 1,
|
|
103
|
+
warn: 2,
|
|
104
|
+
info: 3,
|
|
105
|
+
debug: 4,
|
|
106
|
+
trace: 5,
|
|
107
|
+
silent: Number.POSITIVE_INFINITY
|
|
108
|
+
}[level];
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
//#endregion
|
|
112
|
+
//#region src/logging/state.ts
|
|
113
|
+
const loggingState = {
|
|
114
|
+
cachedLogger: null,
|
|
115
|
+
cachedSettings: null,
|
|
116
|
+
cachedConsoleSettings: null,
|
|
117
|
+
overrideSettings: null,
|
|
118
|
+
consolePatched: false,
|
|
119
|
+
forceConsoleToStderr: false,
|
|
120
|
+
consoleTimestampPrefix: false,
|
|
121
|
+
consoleSubsystemFilter: null,
|
|
122
|
+
resolvingConsoleSettings: false,
|
|
123
|
+
streamErrorHandlersInstalled: false,
|
|
124
|
+
rawConsole: null
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
//#endregion
|
|
128
|
+
//#region src/logging/logger.ts
|
|
129
|
+
const DEFAULT_LOG_DIR = resolvePreferredAnimaTmpDir();
|
|
130
|
+
const DEFAULT_LOG_FILE = path.join(DEFAULT_LOG_DIR, "anima.log");
|
|
131
|
+
const LOG_PREFIX = "anima";
|
|
132
|
+
const LOG_SUFFIX = ".log";
|
|
133
|
+
const MAX_LOG_AGE_MS = 1440 * 60 * 1e3;
|
|
134
|
+
const requireConfig$1 = createRequire(import.meta.url);
|
|
135
|
+
const externalTransports = /* @__PURE__ */ new Set();
|
|
136
|
+
function attachExternalTransport(logger, transport) {
|
|
137
|
+
logger.attachTransport((logObj) => {
|
|
138
|
+
if (!externalTransports.has(transport)) return;
|
|
139
|
+
try {
|
|
140
|
+
transport(logObj);
|
|
141
|
+
} catch {}
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
function resolveSettings() {
|
|
145
|
+
let cfg = loggingState.overrideSettings ?? readLoggingConfig();
|
|
146
|
+
if (!cfg) try {
|
|
147
|
+
cfg = requireConfig$1("../config/config.js").loadConfig?.().logging;
|
|
148
|
+
} catch {
|
|
149
|
+
cfg = void 0;
|
|
150
|
+
}
|
|
151
|
+
const defaultLevel = process.env.VITEST === "true" && process.env.ANIMA_TEST_FILE_LOG !== "1" ? "silent" : "info";
|
|
152
|
+
return {
|
|
153
|
+
level: normalizeLogLevel(cfg?.level, defaultLevel),
|
|
154
|
+
file: cfg?.file ?? defaultRollingPathForToday()
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
function settingsChanged(a, b) {
|
|
158
|
+
if (!a) return true;
|
|
159
|
+
return a.level !== b.level || a.file !== b.file;
|
|
160
|
+
}
|
|
161
|
+
function isFileLogLevelEnabled(level) {
|
|
162
|
+
const settings = loggingState.cachedSettings ?? resolveSettings();
|
|
163
|
+
if (!loggingState.cachedSettings) loggingState.cachedSettings = settings;
|
|
164
|
+
if (settings.level === "silent") return false;
|
|
165
|
+
return levelToMinLevel(level) <= levelToMinLevel(settings.level);
|
|
166
|
+
}
|
|
167
|
+
function buildLogger(settings) {
|
|
168
|
+
fsSync.mkdirSync(path.dirname(settings.file), { recursive: true });
|
|
169
|
+
if (isRollingPath(settings.file)) pruneOldRollingLogs(path.dirname(settings.file));
|
|
170
|
+
const logger = new Logger({
|
|
171
|
+
name: "anima",
|
|
172
|
+
minLevel: levelToMinLevel(settings.level),
|
|
173
|
+
type: "hidden"
|
|
174
|
+
});
|
|
175
|
+
logger.attachTransport((logObj) => {
|
|
176
|
+
try {
|
|
177
|
+
const time = logObj.date?.toISOString?.() ?? (/* @__PURE__ */ new Date()).toISOString();
|
|
178
|
+
const line = JSON.stringify({
|
|
179
|
+
...logObj,
|
|
180
|
+
time
|
|
181
|
+
});
|
|
182
|
+
fsSync.appendFileSync(settings.file, `${line}\n`, { encoding: "utf8" });
|
|
183
|
+
} catch {}
|
|
184
|
+
});
|
|
185
|
+
for (const transport of externalTransports) attachExternalTransport(logger, transport);
|
|
186
|
+
return logger;
|
|
187
|
+
}
|
|
188
|
+
function getLogger() {
|
|
189
|
+
const settings = resolveSettings();
|
|
190
|
+
const cachedLogger = loggingState.cachedLogger;
|
|
191
|
+
const cachedSettings = loggingState.cachedSettings;
|
|
192
|
+
if (!cachedLogger || settingsChanged(cachedSettings, settings)) {
|
|
193
|
+
loggingState.cachedLogger = buildLogger(settings);
|
|
194
|
+
loggingState.cachedSettings = settings;
|
|
195
|
+
}
|
|
196
|
+
return loggingState.cachedLogger;
|
|
197
|
+
}
|
|
198
|
+
function getChildLogger(bindings, opts) {
|
|
199
|
+
const base = getLogger();
|
|
200
|
+
const minLevel = opts?.level ? levelToMinLevel(opts.level) : void 0;
|
|
201
|
+
const name = bindings ? JSON.stringify(bindings) : void 0;
|
|
202
|
+
return base.getSubLogger({
|
|
203
|
+
name,
|
|
204
|
+
minLevel,
|
|
205
|
+
prefix: bindings ? [name ?? ""] : []
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
function toPinoLikeLogger(logger, level) {
|
|
209
|
+
const buildChild = (bindings) => toPinoLikeLogger(logger.getSubLogger({ name: bindings ? JSON.stringify(bindings) : void 0 }), level);
|
|
210
|
+
return {
|
|
211
|
+
level,
|
|
212
|
+
child: buildChild,
|
|
213
|
+
trace: (...args) => logger.trace(...args),
|
|
214
|
+
debug: (...args) => logger.debug(...args),
|
|
215
|
+
info: (...args) => logger.info(...args),
|
|
216
|
+
warn: (...args) => logger.warn(...args),
|
|
217
|
+
error: (...args) => logger.error(...args),
|
|
218
|
+
fatal: (...args) => logger.fatal(...args)
|
|
219
|
+
};
|
|
220
|
+
}
|
|
221
|
+
function formatLocalDate(date) {
|
|
222
|
+
return `${date.getFullYear()}-${String(date.getMonth() + 1).padStart(2, "0")}-${String(date.getDate()).padStart(2, "0")}`;
|
|
223
|
+
}
|
|
224
|
+
function defaultRollingPathForToday() {
|
|
225
|
+
const today = formatLocalDate(/* @__PURE__ */ new Date());
|
|
226
|
+
return path.join(DEFAULT_LOG_DIR, `${LOG_PREFIX}-${today}${LOG_SUFFIX}`);
|
|
227
|
+
}
|
|
228
|
+
function isRollingPath(file) {
|
|
229
|
+
const base = path.basename(file);
|
|
230
|
+
return base.startsWith(`${LOG_PREFIX}-`) && base.endsWith(LOG_SUFFIX) && base.length === `${LOG_PREFIX}-YYYY-MM-DD${LOG_SUFFIX}`.length;
|
|
231
|
+
}
|
|
232
|
+
function pruneOldRollingLogs(dir) {
|
|
233
|
+
try {
|
|
234
|
+
const entries = fsSync.readdirSync(dir, { withFileTypes: true });
|
|
235
|
+
const cutoff = Date.now() - MAX_LOG_AGE_MS;
|
|
236
|
+
for (const entry of entries) {
|
|
237
|
+
if (!entry.isFile()) continue;
|
|
238
|
+
if (!entry.name.startsWith(`${LOG_PREFIX}-`) || !entry.name.endsWith(LOG_SUFFIX)) continue;
|
|
239
|
+
const fullPath = path.join(dir, entry.name);
|
|
240
|
+
try {
|
|
241
|
+
if (fsSync.statSync(fullPath).mtimeMs < cutoff) fsSync.rmSync(fullPath, { force: true });
|
|
242
|
+
} catch {}
|
|
243
|
+
}
|
|
244
|
+
} catch {}
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
//#endregion
|
|
248
|
+
//#region src/terminal/palette.ts
|
|
249
|
+
const LOBSTER_PALETTE = {
|
|
250
|
+
accent: "#FF5A2D",
|
|
251
|
+
accentBright: "#FF7A3D",
|
|
252
|
+
accentDim: "#D14A22",
|
|
253
|
+
info: "#FF8A5B",
|
|
254
|
+
success: "#2FBF71",
|
|
255
|
+
warn: "#FFB020",
|
|
256
|
+
error: "#E23D2D",
|
|
257
|
+
muted: "#8B7F77"
|
|
258
|
+
};
|
|
259
|
+
|
|
260
|
+
//#endregion
|
|
261
|
+
//#region src/terminal/theme.ts
|
|
262
|
+
const hasForceColor = typeof process.env.FORCE_COLOR === "string" && process.env.FORCE_COLOR.trim().length > 0 && process.env.FORCE_COLOR.trim() !== "0";
|
|
263
|
+
const baseChalk = process.env.NO_COLOR && !hasForceColor ? new Chalk({ level: 0 }) : chalk;
|
|
264
|
+
const hex = (value) => baseChalk.hex(value);
|
|
265
|
+
const theme = {
|
|
266
|
+
accent: hex(LOBSTER_PALETTE.accent),
|
|
267
|
+
accentBright: hex(LOBSTER_PALETTE.accentBright),
|
|
268
|
+
accentDim: hex(LOBSTER_PALETTE.accentDim),
|
|
269
|
+
info: hex(LOBSTER_PALETTE.info),
|
|
270
|
+
success: hex(LOBSTER_PALETTE.success),
|
|
271
|
+
warn: hex(LOBSTER_PALETTE.warn),
|
|
272
|
+
error: hex(LOBSTER_PALETTE.error),
|
|
273
|
+
muted: hex(LOBSTER_PALETTE.muted),
|
|
274
|
+
heading: baseChalk.bold.hex(LOBSTER_PALETTE.accent),
|
|
275
|
+
command: hex(LOBSTER_PALETTE.accentBright),
|
|
276
|
+
option: hex(LOBSTER_PALETTE.warn)
|
|
277
|
+
};
|
|
278
|
+
const isRich = () => Boolean(baseChalk.level > 0);
|
|
279
|
+
const colorize = (rich, color, value) => rich ? color(value) : value;
|
|
280
|
+
|
|
281
|
+
//#endregion
|
|
282
|
+
//#region src/globals.ts
|
|
283
|
+
let globalVerbose = false;
|
|
284
|
+
function setVerbose(v) {
|
|
285
|
+
globalVerbose = v;
|
|
286
|
+
}
|
|
287
|
+
function isVerbose() {
|
|
288
|
+
return globalVerbose;
|
|
289
|
+
}
|
|
290
|
+
function shouldLogVerbose() {
|
|
291
|
+
return globalVerbose || isFileLogLevelEnabled("debug");
|
|
292
|
+
}
|
|
293
|
+
function logVerbose(message) {
|
|
294
|
+
if (!shouldLogVerbose()) return;
|
|
295
|
+
try {
|
|
296
|
+
getLogger().debug({ message }, "verbose");
|
|
297
|
+
} catch {}
|
|
298
|
+
if (!globalVerbose) return;
|
|
299
|
+
console.log(theme.muted(message));
|
|
300
|
+
}
|
|
301
|
+
function logVerboseConsole(message) {
|
|
302
|
+
if (!globalVerbose) return;
|
|
303
|
+
console.log(theme.muted(message));
|
|
304
|
+
}
|
|
305
|
+
const success = theme.success;
|
|
306
|
+
const warn = theme.warn;
|
|
307
|
+
const info = theme.info;
|
|
308
|
+
const danger = theme.error;
|
|
309
|
+
|
|
310
|
+
//#endregion
|
|
311
|
+
//#region src/utils.ts
|
|
312
|
+
async function ensureDir(dir) {
|
|
313
|
+
await fsSync.promises.mkdir(dir, { recursive: true });
|
|
314
|
+
}
|
|
315
|
+
/**
|
|
316
|
+
* Check if a file or directory exists at the given path.
|
|
317
|
+
*/
|
|
318
|
+
async function pathExists(targetPath) {
|
|
319
|
+
try {
|
|
320
|
+
await fsSync.promises.access(targetPath);
|
|
321
|
+
return true;
|
|
322
|
+
} catch {
|
|
323
|
+
return false;
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
function clampNumber(value, min, max) {
|
|
327
|
+
return Math.max(min, Math.min(max, value));
|
|
328
|
+
}
|
|
329
|
+
function clampInt(value, min, max) {
|
|
330
|
+
return clampNumber(Math.floor(value), min, max);
|
|
331
|
+
}
|
|
332
|
+
/** Alias for clampNumber (shorter, more common name) */
|
|
333
|
+
const clamp = clampNumber;
|
|
334
|
+
/**
|
|
335
|
+
* Escapes special regex characters in a string so it can be used in a RegExp constructor.
|
|
336
|
+
*/
|
|
337
|
+
function escapeRegExp(value) {
|
|
338
|
+
return value.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
339
|
+
}
|
|
340
|
+
/**
|
|
341
|
+
* Safely parse JSON, returning null on error instead of throwing.
|
|
342
|
+
*/
|
|
343
|
+
function safeParseJson(raw) {
|
|
344
|
+
try {
|
|
345
|
+
return JSON.parse(raw);
|
|
346
|
+
} catch {
|
|
347
|
+
return null;
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
/**
|
|
351
|
+
* Type guard for plain objects (not arrays, null, Date, RegExp, etc.).
|
|
352
|
+
* Uses Object.prototype.toString for maximum safety.
|
|
353
|
+
*/
|
|
354
|
+
function isPlainObject(value) {
|
|
355
|
+
return typeof value === "object" && value !== null && !Array.isArray(value) && Object.prototype.toString.call(value) === "[object Object]";
|
|
356
|
+
}
|
|
357
|
+
/**
|
|
358
|
+
* Type guard for Record<string, unknown> (less strict than isPlainObject).
|
|
359
|
+
* Accepts any non-null object that isn't an array.
|
|
360
|
+
*/
|
|
361
|
+
function isRecord(value) {
|
|
362
|
+
return typeof value === "object" && value !== null && !Array.isArray(value);
|
|
363
|
+
}
|
|
364
|
+
function normalizeE164(number) {
|
|
365
|
+
const digits = number.replace(/^whatsapp:/, "").trim().replace(/[^\d+]/g, "");
|
|
366
|
+
if (digits.startsWith("+")) return `+${digits.slice(1)}`;
|
|
367
|
+
return `+${digits}`;
|
|
368
|
+
}
|
|
369
|
+
/**
|
|
370
|
+
* "Self-chat mode" heuristic (single phone): the gateway is logged in as the owner's own WhatsApp account,
|
|
371
|
+
* and `channels.whatsapp.allowFrom` includes that same number. Used to avoid side-effects that make no sense when the
|
|
372
|
+
* "bot" and the human are the same WhatsApp identity (e.g. auto read receipts, @mention JID triggers).
|
|
373
|
+
*/
|
|
374
|
+
function isSelfChatMode(selfE164, allowFrom) {
|
|
375
|
+
if (!selfE164) return false;
|
|
376
|
+
if (!Array.isArray(allowFrom) || allowFrom.length === 0) return false;
|
|
377
|
+
const normalizedSelf = normalizeE164(selfE164);
|
|
378
|
+
return allowFrom.some((n) => {
|
|
379
|
+
if (n === "*") return false;
|
|
380
|
+
try {
|
|
381
|
+
return normalizeE164(String(n)) === normalizedSelf;
|
|
382
|
+
} catch {
|
|
383
|
+
return false;
|
|
384
|
+
}
|
|
385
|
+
});
|
|
386
|
+
}
|
|
387
|
+
function toWhatsappJid(number) {
|
|
388
|
+
const withoutPrefix = number.replace(/^whatsapp:/, "").trim();
|
|
389
|
+
if (withoutPrefix.includes("@")) return withoutPrefix;
|
|
390
|
+
return `${normalizeE164(withoutPrefix).replace(/\D/g, "")}@s.whatsapp.net`;
|
|
391
|
+
}
|
|
392
|
+
function resolveLidMappingDirs(opts) {
|
|
393
|
+
const dirs = /* @__PURE__ */ new Set();
|
|
394
|
+
const addDir = (dir) => {
|
|
395
|
+
if (!dir) return;
|
|
396
|
+
dirs.add(resolveUserPath(dir));
|
|
397
|
+
};
|
|
398
|
+
addDir(opts?.authDir);
|
|
399
|
+
for (const dir of opts?.lidMappingDirs ?? []) addDir(dir);
|
|
400
|
+
addDir(resolveOAuthDir());
|
|
401
|
+
addDir(path.join(CONFIG_DIR, "credentials"));
|
|
402
|
+
return [...dirs];
|
|
403
|
+
}
|
|
404
|
+
function readLidReverseMapping(lid, opts) {
|
|
405
|
+
const mappingFilename = `lid-mapping-${lid}_reverse.json`;
|
|
406
|
+
const mappingDirs = resolveLidMappingDirs(opts);
|
|
407
|
+
for (const dir of mappingDirs) {
|
|
408
|
+
const mappingPath = path.join(dir, mappingFilename);
|
|
409
|
+
try {
|
|
410
|
+
const data = fsSync.readFileSync(mappingPath, "utf8");
|
|
411
|
+
const phone = JSON.parse(data);
|
|
412
|
+
if (phone === null || phone === void 0) continue;
|
|
413
|
+
return normalizeE164(String(phone));
|
|
414
|
+
} catch {}
|
|
415
|
+
}
|
|
416
|
+
return null;
|
|
417
|
+
}
|
|
418
|
+
function jidToE164(jid, opts) {
|
|
419
|
+
const match = jid.match(/^(\d+)(?::\d+)?@(s\.whatsapp\.net|hosted)$/);
|
|
420
|
+
if (match) return `+${match[1]}`;
|
|
421
|
+
const lidMatch = jid.match(/^(\d+)(?::\d+)?@(lid|hosted\.lid)$/);
|
|
422
|
+
if (lidMatch) {
|
|
423
|
+
const lid = lidMatch[1];
|
|
424
|
+
const phone = readLidReverseMapping(lid, opts);
|
|
425
|
+
if (phone) return phone;
|
|
426
|
+
if (opts?.logMissing ?? shouldLogVerbose()) logVerbose(`LID mapping not found for ${lid}; skipping inbound message`);
|
|
427
|
+
}
|
|
428
|
+
return null;
|
|
429
|
+
}
|
|
430
|
+
async function resolveJidToE164(jid, opts) {
|
|
431
|
+
if (!jid) return null;
|
|
432
|
+
const direct = jidToE164(jid, opts);
|
|
433
|
+
if (direct) return direct;
|
|
434
|
+
if (!/(@lid|@hosted\.lid)$/.test(jid)) return null;
|
|
435
|
+
if (!opts?.lidLookup?.getPNForLID) return null;
|
|
436
|
+
try {
|
|
437
|
+
const pnJid = await opts.lidLookup.getPNForLID(jid);
|
|
438
|
+
if (!pnJid) return null;
|
|
439
|
+
return jidToE164(pnJid, opts);
|
|
440
|
+
} catch (err) {
|
|
441
|
+
if (shouldLogVerbose()) logVerbose(`LID mapping lookup failed for ${jid}: ${String(err)}`);
|
|
442
|
+
return null;
|
|
443
|
+
}
|
|
444
|
+
}
|
|
445
|
+
function sleep(ms) {
|
|
446
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
447
|
+
}
|
|
448
|
+
function isHighSurrogate(codeUnit) {
|
|
449
|
+
return codeUnit >= 55296 && codeUnit <= 56319;
|
|
450
|
+
}
|
|
451
|
+
function isLowSurrogate(codeUnit) {
|
|
452
|
+
return codeUnit >= 56320 && codeUnit <= 57343;
|
|
453
|
+
}
|
|
454
|
+
function sliceUtf16Safe(input, start, end) {
|
|
455
|
+
const len = input.length;
|
|
456
|
+
let from = start < 0 ? Math.max(len + start, 0) : Math.min(start, len);
|
|
457
|
+
let to = end === void 0 ? len : end < 0 ? Math.max(len + end, 0) : Math.min(end, len);
|
|
458
|
+
if (to < from) {
|
|
459
|
+
const tmp = from;
|
|
460
|
+
from = to;
|
|
461
|
+
to = tmp;
|
|
462
|
+
}
|
|
463
|
+
if (from > 0 && from < len) {
|
|
464
|
+
if (isLowSurrogate(input.charCodeAt(from)) && isHighSurrogate(input.charCodeAt(from - 1))) from += 1;
|
|
465
|
+
}
|
|
466
|
+
if (to > 0 && to < len) {
|
|
467
|
+
if (isHighSurrogate(input.charCodeAt(to - 1)) && isLowSurrogate(input.charCodeAt(to))) to -= 1;
|
|
468
|
+
}
|
|
469
|
+
return input.slice(from, to);
|
|
470
|
+
}
|
|
471
|
+
function truncateUtf16Safe(input, maxLen) {
|
|
472
|
+
const limit = Math.max(0, Math.floor(maxLen));
|
|
473
|
+
if (input.length <= limit) return input;
|
|
474
|
+
return sliceUtf16Safe(input, 0, limit);
|
|
475
|
+
}
|
|
476
|
+
function resolveUserPath(input) {
|
|
477
|
+
const trimmed = input.trim();
|
|
478
|
+
if (!trimmed) return trimmed;
|
|
479
|
+
if (trimmed.startsWith("~")) {
|
|
480
|
+
const expanded = expandHomePrefix(trimmed, {
|
|
481
|
+
home: resolveRequiredHomeDir(process.env, os.homedir),
|
|
482
|
+
env: process.env,
|
|
483
|
+
homedir: os.homedir
|
|
484
|
+
});
|
|
485
|
+
return path.resolve(expanded);
|
|
486
|
+
}
|
|
487
|
+
return path.resolve(trimmed);
|
|
488
|
+
}
|
|
489
|
+
function resolveConfigDir(env = process.env, homedir = os.homedir) {
|
|
490
|
+
const override = env.ANIMA_STATE_DIR?.trim() || env.ANIMA_STATE_DIR?.trim();
|
|
491
|
+
if (override) return resolveUserPath(override);
|
|
492
|
+
const newDir = path.join(resolveRequiredHomeDir(env, homedir), ".anima");
|
|
493
|
+
try {
|
|
494
|
+
if (fsSync.existsSync(newDir)) return newDir;
|
|
495
|
+
} catch {}
|
|
496
|
+
return newDir;
|
|
497
|
+
}
|
|
498
|
+
function resolveHomeDir() {
|
|
499
|
+
return resolveEffectiveHomeDir(process.env, os.homedir);
|
|
500
|
+
}
|
|
501
|
+
function resolveHomeDisplayPrefix() {
|
|
502
|
+
const home = resolveHomeDir();
|
|
503
|
+
if (!home) return;
|
|
504
|
+
if (process.env.ANIMA_HOME?.trim()) return {
|
|
505
|
+
home,
|
|
506
|
+
prefix: "$ANIMA_HOME"
|
|
507
|
+
};
|
|
508
|
+
return {
|
|
509
|
+
home,
|
|
510
|
+
prefix: "~"
|
|
511
|
+
};
|
|
512
|
+
}
|
|
513
|
+
function shortenHomePath(input) {
|
|
514
|
+
if (!input) return input;
|
|
515
|
+
const display = resolveHomeDisplayPrefix();
|
|
516
|
+
if (!display) return input;
|
|
517
|
+
const { home, prefix } = display;
|
|
518
|
+
if (input === home) return prefix;
|
|
519
|
+
if (input.startsWith(`${home}/`) || input.startsWith(`${home}\\`)) return `${prefix}${input.slice(home.length)}`;
|
|
520
|
+
return input;
|
|
521
|
+
}
|
|
522
|
+
function shortenHomeInString(input) {
|
|
523
|
+
if (!input) return input;
|
|
524
|
+
const display = resolveHomeDisplayPrefix();
|
|
525
|
+
if (!display) return input;
|
|
526
|
+
return input.split(display.home).join(display.prefix);
|
|
527
|
+
}
|
|
528
|
+
function formatTerminalLink(label, url, opts) {
|
|
529
|
+
const esc = "\x1B";
|
|
530
|
+
const safeLabel = label.replaceAll(esc, "");
|
|
531
|
+
const safeUrl = url.replaceAll(esc, "");
|
|
532
|
+
if (!(opts?.force === true ? true : opts?.force === false ? false : Boolean(process.stdout.isTTY))) return opts?.fallback ?? `${safeLabel} (${safeUrl})`;
|
|
533
|
+
return `\u001b]8;;${safeUrl}\u0007${safeLabel}\u001b]8;;\u0007`;
|
|
534
|
+
}
|
|
535
|
+
const CONFIG_DIR = resolveConfigDir();
|
|
536
|
+
|
|
537
|
+
//#endregion
|
|
538
|
+
//#region src/plugins/runtime.ts
|
|
539
|
+
const createEmptyRegistry = () => ({
|
|
540
|
+
plugins: [],
|
|
541
|
+
tools: [],
|
|
542
|
+
hooks: [],
|
|
543
|
+
typedHooks: [],
|
|
544
|
+
channels: [],
|
|
545
|
+
providers: [],
|
|
546
|
+
gatewayHandlers: {},
|
|
547
|
+
httpHandlers: [],
|
|
548
|
+
httpRoutes: [],
|
|
549
|
+
cliRegistrars: [],
|
|
550
|
+
services: [],
|
|
551
|
+
commands: [],
|
|
552
|
+
diagnostics: []
|
|
553
|
+
});
|
|
554
|
+
const REGISTRY_STATE = Symbol.for("anima.pluginRegistryState");
|
|
555
|
+
const state = (() => {
|
|
556
|
+
const globalState = globalThis;
|
|
557
|
+
if (!globalState[REGISTRY_STATE]) globalState[REGISTRY_STATE] = {
|
|
558
|
+
registry: createEmptyRegistry(),
|
|
559
|
+
key: null
|
|
560
|
+
};
|
|
561
|
+
return globalState[REGISTRY_STATE];
|
|
562
|
+
})();
|
|
563
|
+
function setActivePluginRegistry(registry, cacheKey) {
|
|
564
|
+
state.registry = registry;
|
|
565
|
+
state.key = cacheKey ?? null;
|
|
566
|
+
}
|
|
567
|
+
function getActivePluginRegistry() {
|
|
568
|
+
return state.registry;
|
|
569
|
+
}
|
|
570
|
+
function requireActivePluginRegistry() {
|
|
571
|
+
if (!state.registry) state.registry = createEmptyRegistry();
|
|
572
|
+
return state.registry;
|
|
573
|
+
}
|
|
574
|
+
|
|
575
|
+
//#endregion
|
|
576
|
+
//#region src/channels/registry.ts
|
|
577
|
+
const CHAT_CHANNEL_ORDER = ["web"];
|
|
578
|
+
const CHANNEL_IDS = [...CHAT_CHANNEL_ORDER];
|
|
579
|
+
const DEFAULT_CHAT_CHANNEL = "web";
|
|
580
|
+
const CHAT_CHANNEL_META = { web: {
|
|
581
|
+
id: "web",
|
|
582
|
+
label: "Web",
|
|
583
|
+
selectionLabel: "Web (Gateway UI)",
|
|
584
|
+
detailLabel: "Web Interface",
|
|
585
|
+
docsPath: "/channels/web",
|
|
586
|
+
docsLabel: "web",
|
|
587
|
+
blurb: "browser-based gateway control interface.",
|
|
588
|
+
systemImage: "globe",
|
|
589
|
+
selectionExtras: ["https://noxsoft.net"]
|
|
590
|
+
} };
|
|
591
|
+
const CHAT_CHANNEL_ALIASES = {};
|
|
592
|
+
const normalizeChannelKey = (raw) => {
|
|
593
|
+
return raw?.trim().toLowerCase() || void 0;
|
|
594
|
+
};
|
|
595
|
+
function getChatChannelMeta(id) {
|
|
596
|
+
return CHAT_CHANNEL_META[id];
|
|
597
|
+
}
|
|
598
|
+
function normalizeChatChannelId(raw) {
|
|
599
|
+
const normalized = normalizeChannelKey(raw);
|
|
600
|
+
if (!normalized) return null;
|
|
601
|
+
const resolved = CHAT_CHANNEL_ALIASES[normalized] ?? normalized;
|
|
602
|
+
return CHAT_CHANNEL_ORDER.includes(resolved) ? resolved : null;
|
|
603
|
+
}
|
|
604
|
+
function normalizeChannelId(raw) {
|
|
605
|
+
return normalizeChatChannelId(raw);
|
|
606
|
+
}
|
|
607
|
+
function normalizeAnyChannelId(raw) {
|
|
608
|
+
const key = normalizeChannelKey(raw);
|
|
609
|
+
if (!key) return null;
|
|
610
|
+
return requireActivePluginRegistry().channels.find((entry) => {
|
|
611
|
+
const id = String(entry.plugin.id ?? "").trim().toLowerCase();
|
|
612
|
+
if (id && id === key) return true;
|
|
613
|
+
return (entry.plugin.meta.aliases ?? []).some((alias) => alias.trim().toLowerCase() === key);
|
|
614
|
+
})?.plugin.id ?? null;
|
|
615
|
+
}
|
|
616
|
+
|
|
617
|
+
//#endregion
|
|
618
|
+
//#region src/terminal/progress-line.ts
|
|
619
|
+
let activeStream = null;
|
|
620
|
+
function registerActiveProgressLine(stream) {
|
|
621
|
+
if (!stream.isTTY) return;
|
|
622
|
+
activeStream = stream;
|
|
623
|
+
}
|
|
624
|
+
function clearActiveProgressLine() {
|
|
625
|
+
if (!activeStream?.isTTY) return;
|
|
626
|
+
activeStream.write("\r\x1B[2K");
|
|
627
|
+
}
|
|
628
|
+
function unregisterActiveProgressLine(stream) {
|
|
629
|
+
if (!activeStream) return;
|
|
630
|
+
if (stream && activeStream !== stream) return;
|
|
631
|
+
activeStream = null;
|
|
632
|
+
}
|
|
633
|
+
|
|
634
|
+
//#endregion
|
|
635
|
+
//#region src/terminal/restore.ts
|
|
636
|
+
const RESET_SEQUENCE = "\x1B[0m\x1B[?25h\x1B[?1000l\x1B[?1002l\x1B[?1003l\x1B[?1006l\x1B[?2004l";
|
|
637
|
+
function reportRestoreFailure(scope, err, reason) {
|
|
638
|
+
const suffix = reason ? ` (${reason})` : "";
|
|
639
|
+
const message = `[terminal] restore ${scope} failed${suffix}: ${String(err)}`;
|
|
640
|
+
try {
|
|
641
|
+
process.stderr.write(`${message}\n`);
|
|
642
|
+
} catch (writeErr) {
|
|
643
|
+
console.error(`[terminal] restore reporting failed${suffix}: ${String(writeErr)}`);
|
|
644
|
+
}
|
|
645
|
+
}
|
|
646
|
+
function restoreTerminalState(reason, options = {}) {
|
|
647
|
+
const resumeStdin = options.resumeStdinIfPaused ?? options.resumeStdin ?? false;
|
|
648
|
+
try {
|
|
649
|
+
clearActiveProgressLine();
|
|
650
|
+
} catch (err) {
|
|
651
|
+
reportRestoreFailure("progress line", err, reason);
|
|
652
|
+
}
|
|
653
|
+
const stdin = process.stdin;
|
|
654
|
+
if (stdin.isTTY && typeof stdin.setRawMode === "function") {
|
|
655
|
+
try {
|
|
656
|
+
stdin.setRawMode(false);
|
|
657
|
+
} catch (err) {
|
|
658
|
+
reportRestoreFailure("raw mode", err, reason);
|
|
659
|
+
}
|
|
660
|
+
if (resumeStdin && typeof stdin.isPaused === "function" && stdin.isPaused()) try {
|
|
661
|
+
stdin.resume();
|
|
662
|
+
} catch (err) {
|
|
663
|
+
reportRestoreFailure("stdin resume", err, reason);
|
|
664
|
+
}
|
|
665
|
+
}
|
|
666
|
+
if (process.stdout.isTTY) try {
|
|
667
|
+
process.stdout.write(RESET_SEQUENCE);
|
|
668
|
+
} catch (err) {
|
|
669
|
+
reportRestoreFailure("stdout reset", err, reason);
|
|
670
|
+
}
|
|
671
|
+
}
|
|
672
|
+
|
|
673
|
+
//#endregion
|
|
674
|
+
//#region src/runtime.ts
|
|
675
|
+
function shouldEmitRuntimeLog(env = process.env) {
|
|
676
|
+
if (env.VITEST !== "true") return true;
|
|
677
|
+
if (env.ANIMA_TEST_RUNTIME_LOG === "1") return true;
|
|
678
|
+
return typeof console.log.mock === "object";
|
|
679
|
+
}
|
|
680
|
+
const defaultRuntime = {
|
|
681
|
+
log: (...args) => {
|
|
682
|
+
if (!shouldEmitRuntimeLog()) return;
|
|
683
|
+
clearActiveProgressLine();
|
|
684
|
+
console.log(...args);
|
|
685
|
+
},
|
|
686
|
+
error: (...args) => {
|
|
687
|
+
clearActiveProgressLine();
|
|
688
|
+
console.error(...args);
|
|
689
|
+
},
|
|
690
|
+
exit: (code) => {
|
|
691
|
+
restoreTerminalState("runtime exit", { resumeStdinIfPaused: false });
|
|
692
|
+
process.exit(code);
|
|
693
|
+
throw new Error("unreachable");
|
|
694
|
+
}
|
|
695
|
+
};
|
|
696
|
+
|
|
697
|
+
//#endregion
|
|
698
|
+
//#region src/terminal/ansi.ts
|
|
699
|
+
const ANSI_SGR_PATTERN = "\\x1b\\[[0-9;]*m";
|
|
700
|
+
const OSC8_PATTERN = "\\x1b\\]8;;.*?\\x1b\\\\|\\x1b\\]8;;\\x1b\\\\";
|
|
701
|
+
const ANSI_REGEX = new RegExp(ANSI_SGR_PATTERN, "g");
|
|
702
|
+
const OSC8_REGEX = new RegExp(OSC8_PATTERN, "g");
|
|
703
|
+
|
|
704
|
+
//#endregion
|
|
705
|
+
//#region src/logging/console.ts
|
|
706
|
+
const requireConfig = createRequire(import.meta.url);
|
|
707
|
+
const loadConfigFallbackDefault = () => {
|
|
708
|
+
try {
|
|
709
|
+
return requireConfig("../config/config.js").loadConfig?.().logging;
|
|
710
|
+
} catch {
|
|
711
|
+
return;
|
|
712
|
+
}
|
|
713
|
+
};
|
|
714
|
+
let loadConfigFallback = loadConfigFallbackDefault;
|
|
715
|
+
function normalizeConsoleLevel(level) {
|
|
716
|
+
if (isVerbose()) return "debug";
|
|
717
|
+
if (!level && process.env.VITEST === "true" && process.env.ANIMA_TEST_CONSOLE !== "1") return "silent";
|
|
718
|
+
return normalizeLogLevel(level, "info");
|
|
719
|
+
}
|
|
720
|
+
function normalizeConsoleStyle(style) {
|
|
721
|
+
if (style === "compact" || style === "json" || style === "pretty") return style;
|
|
722
|
+
if (!process.stdout.isTTY) return "compact";
|
|
723
|
+
return "pretty";
|
|
724
|
+
}
|
|
725
|
+
function resolveConsoleSettings() {
|
|
726
|
+
let cfg = loggingState.overrideSettings ?? readLoggingConfig();
|
|
727
|
+
if (!cfg) if (loggingState.resolvingConsoleSettings) cfg = void 0;
|
|
728
|
+
else {
|
|
729
|
+
loggingState.resolvingConsoleSettings = true;
|
|
730
|
+
try {
|
|
731
|
+
cfg = loadConfigFallback();
|
|
732
|
+
} finally {
|
|
733
|
+
loggingState.resolvingConsoleSettings = false;
|
|
734
|
+
}
|
|
735
|
+
}
|
|
736
|
+
return {
|
|
737
|
+
level: normalizeConsoleLevel(cfg?.consoleLevel),
|
|
738
|
+
style: normalizeConsoleStyle(cfg?.consoleStyle)
|
|
739
|
+
};
|
|
740
|
+
}
|
|
741
|
+
function consoleSettingsChanged(a, b) {
|
|
742
|
+
if (!a) return true;
|
|
743
|
+
return a.level !== b.level || a.style !== b.style;
|
|
744
|
+
}
|
|
745
|
+
function getConsoleSettings() {
|
|
746
|
+
const settings = resolveConsoleSettings();
|
|
747
|
+
const cached = loggingState.cachedConsoleSettings;
|
|
748
|
+
if (!cached || consoleSettingsChanged(cached, settings)) loggingState.cachedConsoleSettings = settings;
|
|
749
|
+
return loggingState.cachedConsoleSettings;
|
|
750
|
+
}
|
|
751
|
+
function shouldLogSubsystemToConsole(subsystem) {
|
|
752
|
+
const filter = loggingState.consoleSubsystemFilter;
|
|
753
|
+
if (!filter || filter.length === 0) return true;
|
|
754
|
+
return filter.some((prefix) => subsystem === prefix || subsystem.startsWith(`${prefix}/`));
|
|
755
|
+
}
|
|
756
|
+
|
|
757
|
+
//#endregion
|
|
758
|
+
//#region src/logging/subsystem.ts
|
|
759
|
+
function shouldLogToConsole(level, settings) {
|
|
760
|
+
if (settings.level === "silent") return false;
|
|
761
|
+
return levelToMinLevel(level) <= levelToMinLevel(settings.level);
|
|
762
|
+
}
|
|
763
|
+
function isRichConsoleEnv() {
|
|
764
|
+
const term = (process.env.TERM ?? "").toLowerCase();
|
|
765
|
+
if (process.env.COLORTERM || process.env.TERM_PROGRAM) return true;
|
|
766
|
+
return term.length > 0 && term !== "dumb";
|
|
767
|
+
}
|
|
768
|
+
function getColorForConsole() {
|
|
769
|
+
const hasForceColor = typeof process.env.FORCE_COLOR === "string" && process.env.FORCE_COLOR.trim().length > 0 && process.env.FORCE_COLOR.trim() !== "0";
|
|
770
|
+
if (process.env.NO_COLOR && !hasForceColor) return new Chalk({ level: 0 });
|
|
771
|
+
return Boolean(process.stdout.isTTY || process.stderr.isTTY) || isRichConsoleEnv() ? new Chalk({ level: 1 }) : new Chalk({ level: 0 });
|
|
772
|
+
}
|
|
773
|
+
const SUBSYSTEM_COLORS = [
|
|
774
|
+
"cyan",
|
|
775
|
+
"green",
|
|
776
|
+
"yellow",
|
|
777
|
+
"blue",
|
|
778
|
+
"magenta",
|
|
779
|
+
"red"
|
|
780
|
+
];
|
|
781
|
+
const SUBSYSTEM_COLOR_OVERRIDES = { "gmail-watcher": "blue" };
|
|
782
|
+
const SUBSYSTEM_PREFIXES_TO_DROP = [
|
|
783
|
+
"gateway",
|
|
784
|
+
"channels",
|
|
785
|
+
"providers"
|
|
786
|
+
];
|
|
787
|
+
const SUBSYSTEM_MAX_SEGMENTS = 2;
|
|
788
|
+
const CHANNEL_SUBSYSTEM_PREFIXES = new Set(CHAT_CHANNEL_ORDER);
|
|
789
|
+
function pickSubsystemColor(color, subsystem) {
|
|
790
|
+
const override = SUBSYSTEM_COLOR_OVERRIDES[subsystem];
|
|
791
|
+
if (override) return color[override];
|
|
792
|
+
let hash = 0;
|
|
793
|
+
for (let i = 0; i < subsystem.length; i += 1) hash = hash * 31 + subsystem.charCodeAt(i) | 0;
|
|
794
|
+
return color[SUBSYSTEM_COLORS[Math.abs(hash) % SUBSYSTEM_COLORS.length]];
|
|
795
|
+
}
|
|
796
|
+
function formatSubsystemForConsole(subsystem) {
|
|
797
|
+
const parts = subsystem.split("/").filter(Boolean);
|
|
798
|
+
const original = parts.join("/") || subsystem;
|
|
799
|
+
while (parts.length > 0 && SUBSYSTEM_PREFIXES_TO_DROP.includes(parts[0])) parts.shift();
|
|
800
|
+
if (parts.length === 0) return original;
|
|
801
|
+
if (CHANNEL_SUBSYSTEM_PREFIXES.has(parts[0])) return parts[0];
|
|
802
|
+
if (parts.length > SUBSYSTEM_MAX_SEGMENTS) return parts.slice(-SUBSYSTEM_MAX_SEGMENTS).join("/");
|
|
803
|
+
return parts.join("/");
|
|
804
|
+
}
|
|
805
|
+
function stripRedundantSubsystemPrefixForConsole(message, displaySubsystem) {
|
|
806
|
+
if (!displaySubsystem) return message;
|
|
807
|
+
if (message.startsWith("[")) {
|
|
808
|
+
const closeIdx = message.indexOf("]");
|
|
809
|
+
if (closeIdx > 1) {
|
|
810
|
+
if (message.slice(1, closeIdx).toLowerCase() === displaySubsystem.toLowerCase()) {
|
|
811
|
+
let i = closeIdx + 1;
|
|
812
|
+
while (message[i] === " ") i += 1;
|
|
813
|
+
return message.slice(i);
|
|
814
|
+
}
|
|
815
|
+
}
|
|
816
|
+
}
|
|
817
|
+
if (message.slice(0, displaySubsystem.length).toLowerCase() !== displaySubsystem.toLowerCase()) return message;
|
|
818
|
+
const next = message.slice(displaySubsystem.length, displaySubsystem.length + 1);
|
|
819
|
+
if (next !== ":" && next !== " ") return message;
|
|
820
|
+
let i = displaySubsystem.length;
|
|
821
|
+
while (message[i] === " ") i += 1;
|
|
822
|
+
if (message[i] === ":") i += 1;
|
|
823
|
+
while (message[i] === " ") i += 1;
|
|
824
|
+
return message.slice(i);
|
|
825
|
+
}
|
|
826
|
+
function formatConsoleLine(opts) {
|
|
827
|
+
const displaySubsystem = opts.style === "json" ? opts.subsystem : formatSubsystemForConsole(opts.subsystem);
|
|
828
|
+
if (opts.style === "json") return JSON.stringify({
|
|
829
|
+
time: (/* @__PURE__ */ new Date()).toISOString(),
|
|
830
|
+
level: opts.level,
|
|
831
|
+
subsystem: displaySubsystem,
|
|
832
|
+
message: opts.message,
|
|
833
|
+
...opts.meta
|
|
834
|
+
});
|
|
835
|
+
const color = getColorForConsole();
|
|
836
|
+
const prefix = `[${displaySubsystem}]`;
|
|
837
|
+
const prefixColor = pickSubsystemColor(color, displaySubsystem);
|
|
838
|
+
const levelColor = opts.level === "error" || opts.level === "fatal" ? color.red : opts.level === "warn" ? color.yellow : opts.level === "debug" || opts.level === "trace" ? color.gray : color.cyan;
|
|
839
|
+
const displayMessage = stripRedundantSubsystemPrefixForConsole(opts.message, displaySubsystem);
|
|
840
|
+
return `${[(() => {
|
|
841
|
+
if (opts.style === "pretty") return color.gray((/* @__PURE__ */ new Date()).toISOString().slice(11, 19));
|
|
842
|
+
if (loggingState.consoleTimestampPrefix) return color.gray((/* @__PURE__ */ new Date()).toISOString());
|
|
843
|
+
return "";
|
|
844
|
+
})(), prefixColor(prefix)].filter(Boolean).join(" ")} ${levelColor(displayMessage)}`;
|
|
845
|
+
}
|
|
846
|
+
function writeConsoleLine(level, line) {
|
|
847
|
+
clearActiveProgressLine();
|
|
848
|
+
const sanitized = process.platform === "win32" && process.env.GITHUB_ACTIONS === "true" ? line.replace(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g, "?").replace(/[\uD800-\uDFFF]/g, "?") : line;
|
|
849
|
+
const sink = loggingState.rawConsole ?? console;
|
|
850
|
+
if (loggingState.forceConsoleToStderr || level === "error" || level === "fatal") (sink.error ?? console.error)(sanitized);
|
|
851
|
+
else if (level === "warn") (sink.warn ?? console.warn)(sanitized);
|
|
852
|
+
else (sink.log ?? console.log)(sanitized);
|
|
853
|
+
}
|
|
854
|
+
function logToFile(fileLogger, level, message, meta) {
|
|
855
|
+
if (level === "silent") return;
|
|
856
|
+
const method = fileLogger[level];
|
|
857
|
+
if (typeof method !== "function") return;
|
|
858
|
+
if (meta && Object.keys(meta).length > 0) method.call(fileLogger, meta, message);
|
|
859
|
+
else method.call(fileLogger, message);
|
|
860
|
+
}
|
|
861
|
+
function createSubsystemLogger(subsystem) {
|
|
862
|
+
let fileLogger = null;
|
|
863
|
+
const getFileLogger = () => {
|
|
864
|
+
if (!fileLogger) fileLogger = getChildLogger({ subsystem });
|
|
865
|
+
return fileLogger;
|
|
866
|
+
};
|
|
867
|
+
const emit = (level, message, meta) => {
|
|
868
|
+
const consoleSettings = getConsoleSettings();
|
|
869
|
+
let consoleMessageOverride;
|
|
870
|
+
let fileMeta = meta;
|
|
871
|
+
if (meta && Object.keys(meta).length > 0) {
|
|
872
|
+
const { consoleMessage, ...rest } = meta;
|
|
873
|
+
if (typeof consoleMessage === "string") consoleMessageOverride = consoleMessage;
|
|
874
|
+
fileMeta = Object.keys(rest).length > 0 ? rest : void 0;
|
|
875
|
+
}
|
|
876
|
+
logToFile(getFileLogger(), level, message, fileMeta);
|
|
877
|
+
if (!shouldLogToConsole(level, { level: consoleSettings.level })) return;
|
|
878
|
+
if (!shouldLogSubsystemToConsole(subsystem)) return;
|
|
879
|
+
const consoleMessage = consoleMessageOverride ?? message;
|
|
880
|
+
if (!isVerbose() && subsystem === "agent/embedded" && /(sessionId|runId)=probe-/.test(consoleMessage)) return;
|
|
881
|
+
writeConsoleLine(level, formatConsoleLine({
|
|
882
|
+
level,
|
|
883
|
+
subsystem,
|
|
884
|
+
message: consoleSettings.style === "json" ? message : consoleMessage,
|
|
885
|
+
style: consoleSettings.style,
|
|
886
|
+
meta: fileMeta
|
|
887
|
+
}));
|
|
888
|
+
};
|
|
889
|
+
const isConsoleEnabled = (level) => {
|
|
890
|
+
return shouldLogToConsole(level, { level: getConsoleSettings().level }) && shouldLogSubsystemToConsole(subsystem);
|
|
891
|
+
};
|
|
892
|
+
const isFileEnabled = (level) => isFileLogLevelEnabled(level);
|
|
893
|
+
return {
|
|
894
|
+
subsystem,
|
|
895
|
+
isEnabled: (level, target = "any") => {
|
|
896
|
+
if (target === "console") return isConsoleEnabled(level);
|
|
897
|
+
if (target === "file") return isFileEnabled(level);
|
|
898
|
+
return isConsoleEnabled(level) || isFileEnabled(level);
|
|
899
|
+
},
|
|
900
|
+
trace: (message, meta) => emit("trace", message, meta),
|
|
901
|
+
debug: (message, meta) => emit("debug", message, meta),
|
|
902
|
+
info: (message, meta) => emit("info", message, meta),
|
|
903
|
+
warn: (message, meta) => emit("warn", message, meta),
|
|
904
|
+
error: (message, meta) => emit("error", message, meta),
|
|
905
|
+
fatal: (message, meta) => emit("fatal", message, meta),
|
|
906
|
+
raw: (message) => {
|
|
907
|
+
logToFile(getFileLogger(), "info", message, { raw: true });
|
|
908
|
+
if (shouldLogSubsystemToConsole(subsystem)) {
|
|
909
|
+
if (!isVerbose() && subsystem === "agent/embedded" && /(sessionId|runId)=probe-/.test(message)) return;
|
|
910
|
+
writeConsoleLine("info", message);
|
|
911
|
+
}
|
|
912
|
+
},
|
|
913
|
+
child: (name) => createSubsystemLogger(`${subsystem}/${name}`)
|
|
914
|
+
};
|
|
915
|
+
}
|
|
916
|
+
|
|
917
|
+
//#endregion
|
|
918
|
+
//#region src/logger.ts
|
|
919
|
+
const subsystemPrefixRe = /^([a-z][a-z0-9-]{1,20}):\s+(.*)$/i;
|
|
920
|
+
function splitSubsystem(message) {
|
|
921
|
+
const match = message.match(subsystemPrefixRe);
|
|
922
|
+
if (!match) return null;
|
|
923
|
+
const [, subsystem, rest] = match;
|
|
924
|
+
return {
|
|
925
|
+
subsystem,
|
|
926
|
+
rest
|
|
927
|
+
};
|
|
928
|
+
}
|
|
929
|
+
function logInfo(message, runtime = defaultRuntime) {
|
|
930
|
+
const parsed = runtime === defaultRuntime ? splitSubsystem(message) : null;
|
|
931
|
+
if (parsed) {
|
|
932
|
+
createSubsystemLogger(parsed.subsystem).info(parsed.rest);
|
|
933
|
+
return;
|
|
934
|
+
}
|
|
935
|
+
runtime.log(info(message));
|
|
936
|
+
getLogger().info(message);
|
|
937
|
+
}
|
|
938
|
+
function logWarn(message, runtime = defaultRuntime) {
|
|
939
|
+
const parsed = runtime === defaultRuntime ? splitSubsystem(message) : null;
|
|
940
|
+
if (parsed) {
|
|
941
|
+
createSubsystemLogger(parsed.subsystem).warn(parsed.rest);
|
|
942
|
+
return;
|
|
943
|
+
}
|
|
944
|
+
runtime.log(warn(message));
|
|
945
|
+
getLogger().warn(message);
|
|
946
|
+
}
|
|
947
|
+
function logError(message, runtime = defaultRuntime) {
|
|
948
|
+
const parsed = runtime === defaultRuntime ? splitSubsystem(message) : null;
|
|
949
|
+
if (parsed) {
|
|
950
|
+
createSubsystemLogger(parsed.subsystem).error(parsed.rest);
|
|
951
|
+
return;
|
|
952
|
+
}
|
|
953
|
+
runtime.error(danger(message));
|
|
954
|
+
getLogger().error(message);
|
|
955
|
+
}
|
|
956
|
+
function logDebug(message) {
|
|
957
|
+
getLogger().debug(message);
|
|
958
|
+
logVerboseConsole(message);
|
|
959
|
+
}
|
|
960
|
+
|
|
961
|
+
//#endregion
|
|
962
|
+
//#region src/process/spawn-utils.ts
|
|
963
|
+
const DEFAULT_RETRY_CODES = ["EBADF"];
|
|
964
|
+
function resolveCommandStdio(params) {
|
|
965
|
+
return [
|
|
966
|
+
params.hasInput ? "pipe" : params.preferInherit ? "inherit" : "pipe",
|
|
967
|
+
"pipe",
|
|
968
|
+
"pipe"
|
|
969
|
+
];
|
|
970
|
+
}
|
|
971
|
+
function formatSpawnError(err) {
|
|
972
|
+
if (!(err instanceof Error)) return String(err);
|
|
973
|
+
const details = err;
|
|
974
|
+
const parts = [];
|
|
975
|
+
const message = err.message?.trim();
|
|
976
|
+
if (message) parts.push(message);
|
|
977
|
+
if (details.code && !message?.includes(details.code)) parts.push(details.code);
|
|
978
|
+
if (details.syscall) parts.push(`syscall=${details.syscall}`);
|
|
979
|
+
if (typeof details.errno === "number") parts.push(`errno=${details.errno}`);
|
|
980
|
+
return parts.join(" ");
|
|
981
|
+
}
|
|
982
|
+
function shouldRetry(err, codes) {
|
|
983
|
+
const code = err && typeof err === "object" && "code" in err ? String(err.code) : "";
|
|
984
|
+
return code.length > 0 && codes.includes(code);
|
|
985
|
+
}
|
|
986
|
+
async function spawnAndWaitForSpawn(spawnImpl, argv, options) {
|
|
987
|
+
const child = spawnImpl(argv[0], argv.slice(1), options);
|
|
988
|
+
return await new Promise((resolve, reject) => {
|
|
989
|
+
let settled = false;
|
|
990
|
+
const cleanup = () => {
|
|
991
|
+
child.removeListener("error", onError);
|
|
992
|
+
child.removeListener("spawn", onSpawn);
|
|
993
|
+
};
|
|
994
|
+
const finishResolve = () => {
|
|
995
|
+
if (settled) return;
|
|
996
|
+
settled = true;
|
|
997
|
+
cleanup();
|
|
998
|
+
resolve(child);
|
|
999
|
+
};
|
|
1000
|
+
const onError = (err) => {
|
|
1001
|
+
if (settled) return;
|
|
1002
|
+
settled = true;
|
|
1003
|
+
cleanup();
|
|
1004
|
+
reject(err);
|
|
1005
|
+
};
|
|
1006
|
+
const onSpawn = () => {
|
|
1007
|
+
finishResolve();
|
|
1008
|
+
};
|
|
1009
|
+
child.once("error", onError);
|
|
1010
|
+
child.once("spawn", onSpawn);
|
|
1011
|
+
process.nextTick(() => {
|
|
1012
|
+
if (typeof child.pid === "number") finishResolve();
|
|
1013
|
+
});
|
|
1014
|
+
});
|
|
1015
|
+
}
|
|
1016
|
+
async function spawnWithFallback(params) {
|
|
1017
|
+
const spawnImpl = params.spawnImpl ?? spawn;
|
|
1018
|
+
const retryCodes = params.retryCodes ?? DEFAULT_RETRY_CODES;
|
|
1019
|
+
const baseOptions = { ...params.options };
|
|
1020
|
+
const fallbacks = params.fallbacks ?? [];
|
|
1021
|
+
const attempts = [{ options: baseOptions }, ...fallbacks.map((fallback) => ({
|
|
1022
|
+
label: fallback.label,
|
|
1023
|
+
options: {
|
|
1024
|
+
...baseOptions,
|
|
1025
|
+
...fallback.options
|
|
1026
|
+
}
|
|
1027
|
+
}))];
|
|
1028
|
+
let lastError;
|
|
1029
|
+
for (let index = 0; index < attempts.length; index += 1) {
|
|
1030
|
+
const attempt = attempts[index];
|
|
1031
|
+
try {
|
|
1032
|
+
return {
|
|
1033
|
+
child: await spawnAndWaitForSpawn(spawnImpl, params.argv, attempt.options),
|
|
1034
|
+
usedFallback: index > 0,
|
|
1035
|
+
fallbackLabel: attempt.label
|
|
1036
|
+
};
|
|
1037
|
+
} catch (err) {
|
|
1038
|
+
lastError = err;
|
|
1039
|
+
const nextFallback = fallbacks[index];
|
|
1040
|
+
if (!nextFallback || !shouldRetry(err, retryCodes)) throw err;
|
|
1041
|
+
params.onFallback?.(err, nextFallback);
|
|
1042
|
+
}
|
|
1043
|
+
}
|
|
1044
|
+
throw lastError;
|
|
1045
|
+
}
|
|
1046
|
+
|
|
1047
|
+
//#endregion
|
|
1048
|
+
//#region src/process/exec.ts
|
|
1049
|
+
const execFileAsync = promisify(execFile);
|
|
1050
|
+
/**
|
|
1051
|
+
* Resolves a command for Windows compatibility.
|
|
1052
|
+
* On Windows, non-.exe commands (like npm, pnpm) require their .cmd extension.
|
|
1053
|
+
*/
|
|
1054
|
+
function resolveCommand(command) {
|
|
1055
|
+
if (process.platform !== "win32") return command;
|
|
1056
|
+
const basename = path.basename(command).toLowerCase();
|
|
1057
|
+
if (path.extname(basename)) return command;
|
|
1058
|
+
if ([
|
|
1059
|
+
"npm",
|
|
1060
|
+
"pnpm",
|
|
1061
|
+
"yarn",
|
|
1062
|
+
"npx"
|
|
1063
|
+
].includes(basename)) return `${command}.cmd`;
|
|
1064
|
+
return command;
|
|
1065
|
+
}
|
|
1066
|
+
function shouldSpawnWithShell(params) {
|
|
1067
|
+
return false;
|
|
1068
|
+
}
|
|
1069
|
+
async function runExec(command, args, opts = 1e4) {
|
|
1070
|
+
const options = typeof opts === "number" ? {
|
|
1071
|
+
timeout: opts,
|
|
1072
|
+
encoding: "utf8"
|
|
1073
|
+
} : {
|
|
1074
|
+
timeout: opts.timeoutMs,
|
|
1075
|
+
maxBuffer: opts.maxBuffer,
|
|
1076
|
+
encoding: "utf8"
|
|
1077
|
+
};
|
|
1078
|
+
try {
|
|
1079
|
+
const { stdout, stderr } = await execFileAsync(resolveCommand(command), args, options);
|
|
1080
|
+
if (shouldLogVerbose()) {
|
|
1081
|
+
if (stdout.trim()) logDebug(stdout.trim());
|
|
1082
|
+
if (stderr.trim()) logError(stderr.trim());
|
|
1083
|
+
}
|
|
1084
|
+
return {
|
|
1085
|
+
stdout,
|
|
1086
|
+
stderr
|
|
1087
|
+
};
|
|
1088
|
+
} catch (err) {
|
|
1089
|
+
if (shouldLogVerbose()) logError(danger(`Command failed: ${command} ${args.join(" ")}`));
|
|
1090
|
+
throw err;
|
|
1091
|
+
}
|
|
1092
|
+
}
|
|
1093
|
+
async function runCommandWithTimeout(argv, optionsOrTimeout) {
|
|
1094
|
+
const options = typeof optionsOrTimeout === "number" ? { timeoutMs: optionsOrTimeout } : optionsOrTimeout;
|
|
1095
|
+
const { timeoutMs, cwd, input, env } = options;
|
|
1096
|
+
const { windowsVerbatimArguments } = options;
|
|
1097
|
+
const hasInput = input !== void 0;
|
|
1098
|
+
const shouldSuppressNpmFund = (() => {
|
|
1099
|
+
const cmd = path.basename(argv[0] ?? "");
|
|
1100
|
+
if (cmd === "npm" || cmd === "npm.cmd" || cmd === "npm.exe") return true;
|
|
1101
|
+
if (cmd === "node" || cmd === "node.exe") return (argv[1] ?? "").includes("npm-cli.js");
|
|
1102
|
+
return false;
|
|
1103
|
+
})();
|
|
1104
|
+
const mergedEnv = env ? {
|
|
1105
|
+
...process.env,
|
|
1106
|
+
...env
|
|
1107
|
+
} : { ...process.env };
|
|
1108
|
+
const resolvedEnv = Object.fromEntries(Object.entries(mergedEnv).filter(([, value]) => value !== void 0).map(([key, value]) => [key, String(value)]));
|
|
1109
|
+
if (shouldSuppressNpmFund) {
|
|
1110
|
+
if (resolvedEnv.NPM_CONFIG_FUND == null) resolvedEnv.NPM_CONFIG_FUND = "false";
|
|
1111
|
+
if (resolvedEnv.npm_config_fund == null) resolvedEnv.npm_config_fund = "false";
|
|
1112
|
+
}
|
|
1113
|
+
const stdio = resolveCommandStdio({
|
|
1114
|
+
hasInput,
|
|
1115
|
+
preferInherit: true
|
|
1116
|
+
});
|
|
1117
|
+
const resolvedCommand = resolveCommand(argv[0] ?? "");
|
|
1118
|
+
const child = spawn(resolvedCommand, argv.slice(1), {
|
|
1119
|
+
stdio,
|
|
1120
|
+
cwd,
|
|
1121
|
+
env: resolvedEnv,
|
|
1122
|
+
windowsVerbatimArguments,
|
|
1123
|
+
...shouldSpawnWithShell({
|
|
1124
|
+
resolvedCommand,
|
|
1125
|
+
platform: process.platform
|
|
1126
|
+
}) ? { shell: true } : {}
|
|
1127
|
+
});
|
|
1128
|
+
return await new Promise((resolve, reject) => {
|
|
1129
|
+
let stdout = "";
|
|
1130
|
+
let stderr = "";
|
|
1131
|
+
let settled = false;
|
|
1132
|
+
const timer = setTimeout(() => {
|
|
1133
|
+
if (typeof child.kill === "function") child.kill("SIGKILL");
|
|
1134
|
+
}, timeoutMs);
|
|
1135
|
+
if (hasInput && child.stdin) {
|
|
1136
|
+
child.stdin.write(input ?? "");
|
|
1137
|
+
child.stdin.end();
|
|
1138
|
+
}
|
|
1139
|
+
child.stdout?.on("data", (d) => {
|
|
1140
|
+
stdout += d.toString();
|
|
1141
|
+
});
|
|
1142
|
+
child.stderr?.on("data", (d) => {
|
|
1143
|
+
stderr += d.toString();
|
|
1144
|
+
});
|
|
1145
|
+
child.on("error", (err) => {
|
|
1146
|
+
if (settled) return;
|
|
1147
|
+
settled = true;
|
|
1148
|
+
clearTimeout(timer);
|
|
1149
|
+
reject(err);
|
|
1150
|
+
});
|
|
1151
|
+
child.on("close", (code, signal) => {
|
|
1152
|
+
if (settled) return;
|
|
1153
|
+
settled = true;
|
|
1154
|
+
clearTimeout(timer);
|
|
1155
|
+
resolve({
|
|
1156
|
+
stdout,
|
|
1157
|
+
stderr,
|
|
1158
|
+
code,
|
|
1159
|
+
signal,
|
|
1160
|
+
killed: child.killed
|
|
1161
|
+
});
|
|
1162
|
+
});
|
|
1163
|
+
});
|
|
1164
|
+
}
|
|
1165
|
+
|
|
1166
|
+
//#endregion
|
|
1167
|
+
export { colorize as $, formatTerminalLink as A, safeParseJson as B, setActivePluginRegistry as C, clampNumber as D, clampInt as E, normalizeE164 as F, toWhatsappJid as G, shortenHomePath as H, pathExists as I, info as J, truncateUtf16Safe as K, resolveConfigDir as L, isRecord as M, isSelfChatMode as N, ensureDir as O, jidToE164 as P, success as Q, resolveJidToE164 as R, requireActivePluginRegistry as S, clamp as T, sleep as U, shortenHomeInString as V, sliceUtf16Safe as W, setVerbose as X, logVerbose as Y, shouldLogVerbose as Z, getChatChannelMeta as _, logDebug as a, resolvePreferredAnimaTmpDir as at, normalizeChatChannelId as b, logWarn as c, clearActiveProgressLine as d, isRich as et, registerActiveProgressLine as f, DEFAULT_CHAT_CHANNEL as g, CHAT_CHANNEL_ORDER as h, spawnWithFallback as i, normalizeLogLevel as it, isPlainObject as j, escapeRegExp as k, createSubsystemLogger as l, CHANNEL_IDS as m, runExec as n, getChildLogger as nt, logError as o, unregisterActiveProgressLine as p, danger as q, formatSpawnError as r, toPinoLikeLogger as rt, logInfo as s, runCommandWithTimeout as t, theme as tt, defaultRuntime as u, normalizeAnyChannelId as v, CONFIG_DIR as w, getActivePluginRegistry as x, normalizeChannelId as y, resolveUserPath as z };
|