@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
|
@@ -1,1232 +0,0 @@
|
|
|
1
|
-
import { $ as resolveStateDir, R as CONFIG_PATH, X as resolveNewStateDir, Y as resolveLegacyStateDirs, Z as resolveOAuthDir } from "./entry.js";
|
|
2
|
-
import { t as formatCliCommand } from "./command-format-Clp46jkj.js";
|
|
3
|
-
import { i as buildAgentMainSessionKey, l as normalizeAgentId, r as DEFAULT_MAIN_KEY, t as DEFAULT_ACCOUNT_ID } from "./session-key-BGiG_JcT.js";
|
|
4
|
-
import { _ as resolveHomeDir, d as isRecord } from "./utils-C9sj30YY.js";
|
|
5
|
-
import { c as resolveDefaultAgentId } from "./agent-scope-OZi7lb8S.js";
|
|
6
|
-
import { d as AnimaSchema, n as migrateLegacyConfig, o as readConfigFileSnapshot } from "./config-C8rUDJXY.js";
|
|
7
|
-
import { s as saveSessionStore, y as canonicalizeMainSessionAlias } from "./sessions-DcXpzig0.js";
|
|
8
|
-
import { a as resolveTelegramAccount, i as listTelegramAccountIds } from "./normalize-GDK8JTNW.js";
|
|
9
|
-
import { t as note } from "./note-uiuPxhyX.js";
|
|
10
|
-
import { t as applyPluginAutoEnable } from "./plugin-auto-enable-CxF4bpDN.js";
|
|
11
|
-
import os from "node:os";
|
|
12
|
-
import path from "node:path";
|
|
13
|
-
import fs from "node:fs";
|
|
14
|
-
import JSON5 from "json5";
|
|
15
|
-
import fs$1 from "node:fs/promises";
|
|
16
|
-
|
|
17
|
-
//#region src/commands/doctor-legacy-config.ts
|
|
18
|
-
function normalizeLegacyConfigValues(cfg) {
|
|
19
|
-
const changes = [];
|
|
20
|
-
let next = cfg;
|
|
21
|
-
const isRecord = (value) => Boolean(value) && typeof value === "object" && !Array.isArray(value);
|
|
22
|
-
const normalizeDmAliases = (params) => {
|
|
23
|
-
let changed = false;
|
|
24
|
-
let updated = params.entry;
|
|
25
|
-
const rawDm = updated.dm;
|
|
26
|
-
const dm = isRecord(rawDm) ? structuredClone(rawDm) : null;
|
|
27
|
-
let dmChanged = false;
|
|
28
|
-
const allowFromEqual = (a, b) => {
|
|
29
|
-
if (!Array.isArray(a) || !Array.isArray(b)) return false;
|
|
30
|
-
const na = a.map((v) => String(v).trim()).filter(Boolean);
|
|
31
|
-
const nb = b.map((v) => String(v).trim()).filter(Boolean);
|
|
32
|
-
if (na.length !== nb.length) return false;
|
|
33
|
-
return na.every((v, i) => v === nb[i]);
|
|
34
|
-
};
|
|
35
|
-
const topDmPolicy = updated.dmPolicy;
|
|
36
|
-
const legacyDmPolicy = dm?.policy;
|
|
37
|
-
if (topDmPolicy === void 0 && legacyDmPolicy !== void 0) {
|
|
38
|
-
updated = {
|
|
39
|
-
...updated,
|
|
40
|
-
dmPolicy: legacyDmPolicy
|
|
41
|
-
};
|
|
42
|
-
changed = true;
|
|
43
|
-
if (dm) {
|
|
44
|
-
delete dm.policy;
|
|
45
|
-
dmChanged = true;
|
|
46
|
-
}
|
|
47
|
-
changes.push(`Moved ${params.pathPrefix}.dm.policy → ${params.pathPrefix}.dmPolicy.`);
|
|
48
|
-
} else if (topDmPolicy !== void 0 && legacyDmPolicy !== void 0) {
|
|
49
|
-
if (topDmPolicy === legacyDmPolicy) {
|
|
50
|
-
if (dm) {
|
|
51
|
-
delete dm.policy;
|
|
52
|
-
dmChanged = true;
|
|
53
|
-
changes.push(`Removed ${params.pathPrefix}.dm.policy (dmPolicy already set).`);
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
const topAllowFrom = updated.allowFrom;
|
|
58
|
-
const legacyAllowFrom = dm?.allowFrom;
|
|
59
|
-
if (topAllowFrom === void 0 && legacyAllowFrom !== void 0) {
|
|
60
|
-
updated = {
|
|
61
|
-
...updated,
|
|
62
|
-
allowFrom: legacyAllowFrom
|
|
63
|
-
};
|
|
64
|
-
changed = true;
|
|
65
|
-
if (dm) {
|
|
66
|
-
delete dm.allowFrom;
|
|
67
|
-
dmChanged = true;
|
|
68
|
-
}
|
|
69
|
-
changes.push(`Moved ${params.pathPrefix}.dm.allowFrom → ${params.pathPrefix}.allowFrom.`);
|
|
70
|
-
} else if (topAllowFrom !== void 0 && legacyAllowFrom !== void 0) {
|
|
71
|
-
if (allowFromEqual(topAllowFrom, legacyAllowFrom)) {
|
|
72
|
-
if (dm) {
|
|
73
|
-
delete dm.allowFrom;
|
|
74
|
-
dmChanged = true;
|
|
75
|
-
changes.push(`Removed ${params.pathPrefix}.dm.allowFrom (allowFrom already set).`);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
if (dm && isRecord(rawDm) && dmChanged) if (Object.keys(dm).length === 0) {
|
|
80
|
-
if (updated.dm !== void 0) {
|
|
81
|
-
const { dm: _ignored, ...rest } = updated;
|
|
82
|
-
updated = rest;
|
|
83
|
-
changed = true;
|
|
84
|
-
changes.push(`Removed empty ${params.pathPrefix}.dm after migration.`);
|
|
85
|
-
}
|
|
86
|
-
} else {
|
|
87
|
-
updated = {
|
|
88
|
-
...updated,
|
|
89
|
-
dm
|
|
90
|
-
};
|
|
91
|
-
changed = true;
|
|
92
|
-
}
|
|
93
|
-
return {
|
|
94
|
-
entry: updated,
|
|
95
|
-
changed
|
|
96
|
-
};
|
|
97
|
-
};
|
|
98
|
-
const normalizeProvider = (provider) => {
|
|
99
|
-
const rawEntry = next.channels?.[provider];
|
|
100
|
-
if (!isRecord(rawEntry)) return;
|
|
101
|
-
const base = normalizeDmAliases({
|
|
102
|
-
provider,
|
|
103
|
-
entry: rawEntry,
|
|
104
|
-
pathPrefix: `channels.${provider}`
|
|
105
|
-
});
|
|
106
|
-
let updated = base.entry;
|
|
107
|
-
let changed = base.changed;
|
|
108
|
-
const rawAccounts = updated.accounts;
|
|
109
|
-
if (isRecord(rawAccounts)) {
|
|
110
|
-
let accountsChanged = false;
|
|
111
|
-
const accounts = { ...rawAccounts };
|
|
112
|
-
for (const [accountId, rawAccount] of Object.entries(rawAccounts)) {
|
|
113
|
-
if (!isRecord(rawAccount)) continue;
|
|
114
|
-
const res = normalizeDmAliases({
|
|
115
|
-
provider,
|
|
116
|
-
entry: rawAccount,
|
|
117
|
-
pathPrefix: `channels.${provider}.accounts.${accountId}`
|
|
118
|
-
});
|
|
119
|
-
if (res.changed) {
|
|
120
|
-
accounts[accountId] = res.entry;
|
|
121
|
-
accountsChanged = true;
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
if (accountsChanged) {
|
|
125
|
-
updated = {
|
|
126
|
-
...updated,
|
|
127
|
-
accounts
|
|
128
|
-
};
|
|
129
|
-
changed = true;
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
if (changed) next = {
|
|
133
|
-
...next,
|
|
134
|
-
channels: {
|
|
135
|
-
...next.channels,
|
|
136
|
-
[provider]: updated
|
|
137
|
-
}
|
|
138
|
-
};
|
|
139
|
-
};
|
|
140
|
-
normalizeProvider("slack");
|
|
141
|
-
normalizeProvider("discord");
|
|
142
|
-
const legacyAckReaction = cfg.messages?.ackReaction?.trim();
|
|
143
|
-
const hasWhatsAppConfig = cfg.channels?.whatsapp !== void 0;
|
|
144
|
-
if (legacyAckReaction && hasWhatsAppConfig) {
|
|
145
|
-
if (!(cfg.channels?.whatsapp?.ackReaction !== void 0)) {
|
|
146
|
-
const legacyScope = cfg.messages?.ackReactionScope ?? "group-mentions";
|
|
147
|
-
let direct = true;
|
|
148
|
-
let group = "mentions";
|
|
149
|
-
if (legacyScope === "all") {
|
|
150
|
-
direct = true;
|
|
151
|
-
group = "always";
|
|
152
|
-
} else if (legacyScope === "direct") {
|
|
153
|
-
direct = true;
|
|
154
|
-
group = "never";
|
|
155
|
-
} else if (legacyScope === "group-all") {
|
|
156
|
-
direct = false;
|
|
157
|
-
group = "always";
|
|
158
|
-
} else if (legacyScope === "group-mentions") {
|
|
159
|
-
direct = false;
|
|
160
|
-
group = "mentions";
|
|
161
|
-
}
|
|
162
|
-
next = {
|
|
163
|
-
...next,
|
|
164
|
-
channels: {
|
|
165
|
-
...next.channels,
|
|
166
|
-
whatsapp: {
|
|
167
|
-
...next.channels?.whatsapp,
|
|
168
|
-
ackReaction: {
|
|
169
|
-
emoji: legacyAckReaction,
|
|
170
|
-
direct,
|
|
171
|
-
group
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
};
|
|
176
|
-
changes.push(`Copied messages.ackReaction → channels.whatsapp.ackReaction (scope: ${legacyScope}).`);
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
return {
|
|
180
|
-
config: next,
|
|
181
|
-
changes
|
|
182
|
-
};
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
//#endregion
|
|
186
|
-
//#region src/infra/state-migrations.fs.ts
|
|
187
|
-
function safeReadDir(dir) {
|
|
188
|
-
try {
|
|
189
|
-
return fs.readdirSync(dir, { withFileTypes: true });
|
|
190
|
-
} catch {
|
|
191
|
-
return [];
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
function existsDir(dir) {
|
|
195
|
-
try {
|
|
196
|
-
return fs.existsSync(dir) && fs.statSync(dir).isDirectory();
|
|
197
|
-
} catch {
|
|
198
|
-
return false;
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
function ensureDir(dir) {
|
|
202
|
-
fs.mkdirSync(dir, { recursive: true });
|
|
203
|
-
}
|
|
204
|
-
function fileExists(p) {
|
|
205
|
-
try {
|
|
206
|
-
return fs.existsSync(p) && fs.statSync(p).isFile();
|
|
207
|
-
} catch {
|
|
208
|
-
return false;
|
|
209
|
-
}
|
|
210
|
-
}
|
|
211
|
-
function isLegacyWhatsAppAuthFile(name) {
|
|
212
|
-
if (name === "creds.json" || name === "creds.json.bak") return true;
|
|
213
|
-
if (!name.endsWith(".json")) return false;
|
|
214
|
-
return /^(app-state-sync|session|sender-key|pre-key)-/.test(name);
|
|
215
|
-
}
|
|
216
|
-
function readSessionStoreJson5(storePath) {
|
|
217
|
-
try {
|
|
218
|
-
const raw = fs.readFileSync(storePath, "utf-8");
|
|
219
|
-
const parsed = JSON5.parse(raw);
|
|
220
|
-
if (parsed && typeof parsed === "object" && !Array.isArray(parsed)) return {
|
|
221
|
-
store: parsed,
|
|
222
|
-
ok: true
|
|
223
|
-
};
|
|
224
|
-
} catch {}
|
|
225
|
-
return {
|
|
226
|
-
store: {},
|
|
227
|
-
ok: false
|
|
228
|
-
};
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
//#endregion
|
|
232
|
-
//#region src/infra/state-migrations.ts
|
|
233
|
-
let autoMigrateStateDirChecked = false;
|
|
234
|
-
function isSurfaceGroupKey(key) {
|
|
235
|
-
return key.includes(":group:") || key.includes(":channel:");
|
|
236
|
-
}
|
|
237
|
-
function isLegacyGroupKey(key) {
|
|
238
|
-
const trimmed = key.trim();
|
|
239
|
-
if (!trimmed) return false;
|
|
240
|
-
if (trimmed.startsWith("group:")) return true;
|
|
241
|
-
const lower = trimmed.toLowerCase();
|
|
242
|
-
if (!lower.includes("@g.us")) return false;
|
|
243
|
-
if (!trimmed.includes(":")) return true;
|
|
244
|
-
if (lower.startsWith("whatsapp:") && !trimmed.includes(":group:")) return true;
|
|
245
|
-
return false;
|
|
246
|
-
}
|
|
247
|
-
function canonicalizeSessionKeyForAgent(params) {
|
|
248
|
-
const agentId = normalizeAgentId(params.agentId);
|
|
249
|
-
const raw = params.key.trim();
|
|
250
|
-
if (!raw) return raw;
|
|
251
|
-
if (raw.toLowerCase() === "global" || raw.toLowerCase() === "unknown") return raw.toLowerCase();
|
|
252
|
-
const canonicalMain = canonicalizeMainSessionAlias({
|
|
253
|
-
cfg: { session: {
|
|
254
|
-
scope: params.scope,
|
|
255
|
-
mainKey: params.mainKey
|
|
256
|
-
} },
|
|
257
|
-
agentId,
|
|
258
|
-
sessionKey: raw
|
|
259
|
-
});
|
|
260
|
-
if (canonicalMain !== raw) return canonicalMain.toLowerCase();
|
|
261
|
-
if (raw.toLowerCase().startsWith("agent:")) return raw.toLowerCase();
|
|
262
|
-
if (raw.toLowerCase().startsWith("subagent:")) return `agent:${agentId}:subagent:${raw.slice(9)}`.toLowerCase();
|
|
263
|
-
if (raw.startsWith("group:")) {
|
|
264
|
-
const id = raw.slice(6).trim();
|
|
265
|
-
if (!id) return raw;
|
|
266
|
-
return `agent:${agentId}:${id.toLowerCase().includes("@g.us") ? "whatsapp" : "unknown"}:group:${id}`.toLowerCase();
|
|
267
|
-
}
|
|
268
|
-
if (!raw.includes(":") && raw.toLowerCase().includes("@g.us")) return `agent:${agentId}:whatsapp:group:${raw}`.toLowerCase();
|
|
269
|
-
if (raw.toLowerCase().startsWith("whatsapp:") && raw.toLowerCase().includes("@g.us")) {
|
|
270
|
-
const cleaned = raw.slice(9).trim().replace(/^group:/i, "").trim();
|
|
271
|
-
if (cleaned && !isSurfaceGroupKey(raw)) return `agent:${agentId}:whatsapp:group:${cleaned}`.toLowerCase();
|
|
272
|
-
}
|
|
273
|
-
if (isSurfaceGroupKey(raw)) return `agent:${agentId}:${raw}`.toLowerCase();
|
|
274
|
-
return `agent:${agentId}:${raw}`.toLowerCase();
|
|
275
|
-
}
|
|
276
|
-
function pickLatestLegacyDirectEntry(store) {
|
|
277
|
-
let best = null;
|
|
278
|
-
let bestUpdated = -1;
|
|
279
|
-
for (const [key, entry] of Object.entries(store)) {
|
|
280
|
-
if (!entry || typeof entry !== "object") continue;
|
|
281
|
-
const normalized = key.trim();
|
|
282
|
-
if (!normalized) continue;
|
|
283
|
-
if (normalized === "global") continue;
|
|
284
|
-
if (normalized.startsWith("agent:")) continue;
|
|
285
|
-
if (normalized.toLowerCase().startsWith("subagent:")) continue;
|
|
286
|
-
if (isLegacyGroupKey(normalized) || isSurfaceGroupKey(normalized)) continue;
|
|
287
|
-
const updatedAt = typeof entry.updatedAt === "number" ? entry.updatedAt : 0;
|
|
288
|
-
if (updatedAt > bestUpdated) {
|
|
289
|
-
bestUpdated = updatedAt;
|
|
290
|
-
best = entry;
|
|
291
|
-
}
|
|
292
|
-
}
|
|
293
|
-
return best;
|
|
294
|
-
}
|
|
295
|
-
function normalizeSessionEntry(entry) {
|
|
296
|
-
const sessionId = typeof entry.sessionId === "string" ? entry.sessionId : null;
|
|
297
|
-
if (!sessionId) return null;
|
|
298
|
-
const updatedAt = typeof entry.updatedAt === "number" && Number.isFinite(entry.updatedAt) ? entry.updatedAt : Date.now();
|
|
299
|
-
const normalized = {
|
|
300
|
-
...entry,
|
|
301
|
-
sessionId,
|
|
302
|
-
updatedAt
|
|
303
|
-
};
|
|
304
|
-
const rec = normalized;
|
|
305
|
-
if (typeof rec.groupChannel !== "string" && typeof rec.room === "string") rec.groupChannel = rec.room;
|
|
306
|
-
delete rec.room;
|
|
307
|
-
return normalized;
|
|
308
|
-
}
|
|
309
|
-
function resolveUpdatedAt(entry) {
|
|
310
|
-
return typeof entry.updatedAt === "number" && Number.isFinite(entry.updatedAt) ? entry.updatedAt : 0;
|
|
311
|
-
}
|
|
312
|
-
function mergeSessionEntry(params) {
|
|
313
|
-
if (!params.existing) return params.incoming;
|
|
314
|
-
const existingUpdated = resolveUpdatedAt(params.existing);
|
|
315
|
-
const incomingUpdated = resolveUpdatedAt(params.incoming);
|
|
316
|
-
if (incomingUpdated > existingUpdated) return params.incoming;
|
|
317
|
-
if (incomingUpdated < existingUpdated) return params.existing;
|
|
318
|
-
return params.preferIncomingOnTie ? params.incoming : params.existing;
|
|
319
|
-
}
|
|
320
|
-
function canonicalizeSessionStore(params) {
|
|
321
|
-
const canonical = {};
|
|
322
|
-
const meta = /* @__PURE__ */ new Map();
|
|
323
|
-
const legacyKeys = [];
|
|
324
|
-
for (const [key, entry] of Object.entries(params.store)) {
|
|
325
|
-
if (!entry || typeof entry !== "object") continue;
|
|
326
|
-
const canonicalKey = canonicalizeSessionKeyForAgent({
|
|
327
|
-
key,
|
|
328
|
-
agentId: params.agentId,
|
|
329
|
-
mainKey: params.mainKey,
|
|
330
|
-
scope: params.scope
|
|
331
|
-
});
|
|
332
|
-
const isCanonical = canonicalKey === key;
|
|
333
|
-
if (!isCanonical) legacyKeys.push(key);
|
|
334
|
-
const existing = canonical[canonicalKey];
|
|
335
|
-
if (!existing) {
|
|
336
|
-
canonical[canonicalKey] = entry;
|
|
337
|
-
meta.set(canonicalKey, {
|
|
338
|
-
isCanonical,
|
|
339
|
-
updatedAt: resolveUpdatedAt(entry)
|
|
340
|
-
});
|
|
341
|
-
continue;
|
|
342
|
-
}
|
|
343
|
-
const existingMeta = meta.get(canonicalKey);
|
|
344
|
-
const incomingUpdated = resolveUpdatedAt(entry);
|
|
345
|
-
const existingUpdated = existingMeta?.updatedAt ?? resolveUpdatedAt(existing);
|
|
346
|
-
if (incomingUpdated > existingUpdated) {
|
|
347
|
-
canonical[canonicalKey] = entry;
|
|
348
|
-
meta.set(canonicalKey, {
|
|
349
|
-
isCanonical,
|
|
350
|
-
updatedAt: incomingUpdated
|
|
351
|
-
});
|
|
352
|
-
continue;
|
|
353
|
-
}
|
|
354
|
-
if (incomingUpdated < existingUpdated) continue;
|
|
355
|
-
if (existingMeta?.isCanonical && !isCanonical) continue;
|
|
356
|
-
if (!existingMeta?.isCanonical && isCanonical) {
|
|
357
|
-
canonical[canonicalKey] = entry;
|
|
358
|
-
meta.set(canonicalKey, {
|
|
359
|
-
isCanonical,
|
|
360
|
-
updatedAt: incomingUpdated
|
|
361
|
-
});
|
|
362
|
-
continue;
|
|
363
|
-
}
|
|
364
|
-
}
|
|
365
|
-
return {
|
|
366
|
-
store: canonical,
|
|
367
|
-
legacyKeys
|
|
368
|
-
};
|
|
369
|
-
}
|
|
370
|
-
function listLegacySessionKeys(params) {
|
|
371
|
-
const legacy = [];
|
|
372
|
-
for (const key of Object.keys(params.store)) if (canonicalizeSessionKeyForAgent({
|
|
373
|
-
key,
|
|
374
|
-
agentId: params.agentId,
|
|
375
|
-
mainKey: params.mainKey,
|
|
376
|
-
scope: params.scope
|
|
377
|
-
}) !== key) legacy.push(key);
|
|
378
|
-
return legacy;
|
|
379
|
-
}
|
|
380
|
-
function emptyDirOrMissing(dir) {
|
|
381
|
-
if (!existsDir(dir)) return true;
|
|
382
|
-
return safeReadDir(dir).length === 0;
|
|
383
|
-
}
|
|
384
|
-
function removeDirIfEmpty(dir) {
|
|
385
|
-
if (!existsDir(dir)) return;
|
|
386
|
-
if (!emptyDirOrMissing(dir)) return;
|
|
387
|
-
try {
|
|
388
|
-
fs.rmdirSync(dir);
|
|
389
|
-
} catch {}
|
|
390
|
-
}
|
|
391
|
-
function resolveSymlinkTarget(linkPath) {
|
|
392
|
-
try {
|
|
393
|
-
const target = fs.readlinkSync(linkPath);
|
|
394
|
-
return path.resolve(path.dirname(linkPath), target);
|
|
395
|
-
} catch {
|
|
396
|
-
return null;
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
function formatStateDirMigration(legacyDir, targetDir) {
|
|
400
|
-
return `State dir: ${legacyDir} → ${targetDir} (legacy path now symlinked)`;
|
|
401
|
-
}
|
|
402
|
-
function isDirPath(filePath) {
|
|
403
|
-
try {
|
|
404
|
-
return fs.statSync(filePath).isDirectory();
|
|
405
|
-
} catch {
|
|
406
|
-
return false;
|
|
407
|
-
}
|
|
408
|
-
}
|
|
409
|
-
function isWithinDir(targetPath, rootDir) {
|
|
410
|
-
const relative = path.relative(path.resolve(rootDir), path.resolve(targetPath));
|
|
411
|
-
return relative === "" || !relative.startsWith("..") && !path.isAbsolute(relative);
|
|
412
|
-
}
|
|
413
|
-
function isLegacyTreeSymlinkMirror(currentDir, realTargetDir) {
|
|
414
|
-
let entries;
|
|
415
|
-
try {
|
|
416
|
-
entries = fs.readdirSync(currentDir, { withFileTypes: true });
|
|
417
|
-
} catch {
|
|
418
|
-
return false;
|
|
419
|
-
}
|
|
420
|
-
if (entries.length === 0) return false;
|
|
421
|
-
for (const entry of entries) {
|
|
422
|
-
const entryPath = path.join(currentDir, entry.name);
|
|
423
|
-
let stat;
|
|
424
|
-
try {
|
|
425
|
-
stat = fs.lstatSync(entryPath);
|
|
426
|
-
} catch {
|
|
427
|
-
return false;
|
|
428
|
-
}
|
|
429
|
-
if (stat.isSymbolicLink()) {
|
|
430
|
-
const resolvedTarget = resolveSymlinkTarget(entryPath);
|
|
431
|
-
if (!resolvedTarget) return false;
|
|
432
|
-
let resolvedRealTarget;
|
|
433
|
-
try {
|
|
434
|
-
resolvedRealTarget = fs.realpathSync(resolvedTarget);
|
|
435
|
-
} catch {
|
|
436
|
-
return false;
|
|
437
|
-
}
|
|
438
|
-
if (!isWithinDir(resolvedRealTarget, realTargetDir)) return false;
|
|
439
|
-
continue;
|
|
440
|
-
}
|
|
441
|
-
if (stat.isDirectory()) {
|
|
442
|
-
if (!isLegacyTreeSymlinkMirror(entryPath, realTargetDir)) return false;
|
|
443
|
-
continue;
|
|
444
|
-
}
|
|
445
|
-
return false;
|
|
446
|
-
}
|
|
447
|
-
return true;
|
|
448
|
-
}
|
|
449
|
-
function isLegacyDirSymlinkMirror(legacyDir, targetDir) {
|
|
450
|
-
let realTargetDir;
|
|
451
|
-
try {
|
|
452
|
-
realTargetDir = fs.realpathSync(targetDir);
|
|
453
|
-
} catch {
|
|
454
|
-
return false;
|
|
455
|
-
}
|
|
456
|
-
return isLegacyTreeSymlinkMirror(legacyDir, realTargetDir);
|
|
457
|
-
}
|
|
458
|
-
async function autoMigrateLegacyStateDir(params) {
|
|
459
|
-
if (autoMigrateStateDirChecked) return {
|
|
460
|
-
migrated: false,
|
|
461
|
-
skipped: true,
|
|
462
|
-
changes: [],
|
|
463
|
-
warnings: []
|
|
464
|
-
};
|
|
465
|
-
autoMigrateStateDirChecked = true;
|
|
466
|
-
if ((params.env ?? process.env).ANIMA_STATE_DIR?.trim()) return {
|
|
467
|
-
migrated: false,
|
|
468
|
-
skipped: true,
|
|
469
|
-
changes: [],
|
|
470
|
-
warnings: []
|
|
471
|
-
};
|
|
472
|
-
const homedir = params.homedir ?? os.homedir;
|
|
473
|
-
const targetDir = resolveNewStateDir(homedir);
|
|
474
|
-
const legacyDirs = resolveLegacyStateDirs(homedir);
|
|
475
|
-
let legacyDir = legacyDirs.find((dir) => {
|
|
476
|
-
try {
|
|
477
|
-
return fs.existsSync(dir);
|
|
478
|
-
} catch {
|
|
479
|
-
return false;
|
|
480
|
-
}
|
|
481
|
-
});
|
|
482
|
-
const warnings = [];
|
|
483
|
-
const changes = [];
|
|
484
|
-
let legacyStat = null;
|
|
485
|
-
try {
|
|
486
|
-
legacyStat = legacyDir ? fs.lstatSync(legacyDir) : null;
|
|
487
|
-
} catch {
|
|
488
|
-
legacyStat = null;
|
|
489
|
-
}
|
|
490
|
-
if (!legacyStat) return {
|
|
491
|
-
migrated: false,
|
|
492
|
-
skipped: false,
|
|
493
|
-
changes,
|
|
494
|
-
warnings
|
|
495
|
-
};
|
|
496
|
-
if (!legacyStat.isDirectory() && !legacyStat.isSymbolicLink()) {
|
|
497
|
-
warnings.push(`Legacy state path is not a directory: ${legacyDir}`);
|
|
498
|
-
return {
|
|
499
|
-
migrated: false,
|
|
500
|
-
skipped: false,
|
|
501
|
-
changes,
|
|
502
|
-
warnings
|
|
503
|
-
};
|
|
504
|
-
}
|
|
505
|
-
let symlinkDepth = 0;
|
|
506
|
-
while (legacyStat.isSymbolicLink()) {
|
|
507
|
-
const legacyTarget = legacyDir ? resolveSymlinkTarget(legacyDir) : null;
|
|
508
|
-
if (!legacyTarget) {
|
|
509
|
-
warnings.push(`Legacy state dir is a symlink (${legacyDir ?? "unknown"}); could not resolve target.`);
|
|
510
|
-
return {
|
|
511
|
-
migrated: false,
|
|
512
|
-
skipped: false,
|
|
513
|
-
changes,
|
|
514
|
-
warnings
|
|
515
|
-
};
|
|
516
|
-
}
|
|
517
|
-
if (path.resolve(legacyTarget) === path.resolve(targetDir)) return {
|
|
518
|
-
migrated: false,
|
|
519
|
-
skipped: false,
|
|
520
|
-
changes,
|
|
521
|
-
warnings
|
|
522
|
-
};
|
|
523
|
-
if (legacyDirs.some((dir) => path.resolve(dir) === path.resolve(legacyTarget))) {
|
|
524
|
-
legacyDir = legacyTarget;
|
|
525
|
-
try {
|
|
526
|
-
legacyStat = fs.lstatSync(legacyDir);
|
|
527
|
-
} catch {
|
|
528
|
-
legacyStat = null;
|
|
529
|
-
}
|
|
530
|
-
if (!legacyStat) {
|
|
531
|
-
warnings.push(`Legacy state dir missing after symlink resolution: ${legacyDir}`);
|
|
532
|
-
return {
|
|
533
|
-
migrated: false,
|
|
534
|
-
skipped: false,
|
|
535
|
-
changes,
|
|
536
|
-
warnings
|
|
537
|
-
};
|
|
538
|
-
}
|
|
539
|
-
if (!legacyStat.isDirectory() && !legacyStat.isSymbolicLink()) {
|
|
540
|
-
warnings.push(`Legacy state path is not a directory: ${legacyDir}`);
|
|
541
|
-
return {
|
|
542
|
-
migrated: false,
|
|
543
|
-
skipped: false,
|
|
544
|
-
changes,
|
|
545
|
-
warnings
|
|
546
|
-
};
|
|
547
|
-
}
|
|
548
|
-
symlinkDepth += 1;
|
|
549
|
-
if (symlinkDepth > 2) {
|
|
550
|
-
warnings.push(`Legacy state dir symlink chain too deep: ${legacyDir}`);
|
|
551
|
-
return {
|
|
552
|
-
migrated: false,
|
|
553
|
-
skipped: false,
|
|
554
|
-
changes,
|
|
555
|
-
warnings
|
|
556
|
-
};
|
|
557
|
-
}
|
|
558
|
-
continue;
|
|
559
|
-
}
|
|
560
|
-
warnings.push(`Legacy state dir is a symlink (${legacyDir ?? "unknown"} → ${legacyTarget}); skipping auto-migration.`);
|
|
561
|
-
return {
|
|
562
|
-
migrated: false,
|
|
563
|
-
skipped: false,
|
|
564
|
-
changes,
|
|
565
|
-
warnings
|
|
566
|
-
};
|
|
567
|
-
}
|
|
568
|
-
if (isDirPath(targetDir)) {
|
|
569
|
-
if (legacyDir && isLegacyDirSymlinkMirror(legacyDir, targetDir)) return {
|
|
570
|
-
migrated: false,
|
|
571
|
-
skipped: false,
|
|
572
|
-
changes,
|
|
573
|
-
warnings
|
|
574
|
-
};
|
|
575
|
-
warnings.push(`State dir migration skipped: target already exists (${targetDir}). Remove or merge manually.`);
|
|
576
|
-
return {
|
|
577
|
-
migrated: false,
|
|
578
|
-
skipped: false,
|
|
579
|
-
changes,
|
|
580
|
-
warnings
|
|
581
|
-
};
|
|
582
|
-
}
|
|
583
|
-
try {
|
|
584
|
-
if (!legacyDir) throw new Error("Legacy state dir not found");
|
|
585
|
-
fs.renameSync(legacyDir, targetDir);
|
|
586
|
-
} catch (err) {
|
|
587
|
-
warnings.push(`Failed to move legacy state dir (${legacyDir ?? "unknown"} → ${targetDir}): ${String(err)}`);
|
|
588
|
-
return {
|
|
589
|
-
migrated: false,
|
|
590
|
-
skipped: false,
|
|
591
|
-
changes,
|
|
592
|
-
warnings
|
|
593
|
-
};
|
|
594
|
-
}
|
|
595
|
-
try {
|
|
596
|
-
if (!legacyDir) throw new Error("Legacy state dir not found");
|
|
597
|
-
fs.symlinkSync(targetDir, legacyDir, "dir");
|
|
598
|
-
changes.push(formatStateDirMigration(legacyDir, targetDir));
|
|
599
|
-
} catch (err) {
|
|
600
|
-
try {
|
|
601
|
-
if (process.platform === "win32") {
|
|
602
|
-
if (!legacyDir) throw new Error("Legacy state dir not found", { cause: err });
|
|
603
|
-
fs.symlinkSync(targetDir, legacyDir, "junction");
|
|
604
|
-
changes.push(formatStateDirMigration(legacyDir, targetDir));
|
|
605
|
-
} else throw err;
|
|
606
|
-
} catch (fallbackErr) {
|
|
607
|
-
try {
|
|
608
|
-
if (!legacyDir) throw new Error("Legacy state dir not found", { cause: fallbackErr });
|
|
609
|
-
fs.renameSync(targetDir, legacyDir);
|
|
610
|
-
warnings.push(`State dir migration rolled back (failed to link legacy path): ${String(fallbackErr)}`);
|
|
611
|
-
return {
|
|
612
|
-
migrated: false,
|
|
613
|
-
skipped: false,
|
|
614
|
-
changes: [],
|
|
615
|
-
warnings
|
|
616
|
-
};
|
|
617
|
-
} catch (rollbackErr) {
|
|
618
|
-
warnings.push(`State dir moved but failed to link legacy path (${legacyDir ?? "unknown"} → ${targetDir}): ${String(fallbackErr)}`);
|
|
619
|
-
warnings.push(`Rollback failed; set ANIMA_STATE_DIR=${targetDir} to avoid split state: ${String(rollbackErr)}`);
|
|
620
|
-
changes.push(`State dir: ${legacyDir ?? "unknown"} → ${targetDir}`);
|
|
621
|
-
}
|
|
622
|
-
}
|
|
623
|
-
}
|
|
624
|
-
return {
|
|
625
|
-
migrated: changes.length > 0,
|
|
626
|
-
skipped: false,
|
|
627
|
-
changes,
|
|
628
|
-
warnings
|
|
629
|
-
};
|
|
630
|
-
}
|
|
631
|
-
async function detectLegacyStateMigrations(params) {
|
|
632
|
-
const env = params.env ?? process.env;
|
|
633
|
-
const stateDir = resolveStateDir(env, params.homedir ?? os.homedir);
|
|
634
|
-
const oauthDir = resolveOAuthDir(env, stateDir);
|
|
635
|
-
const targetAgentId = normalizeAgentId(resolveDefaultAgentId(params.cfg));
|
|
636
|
-
const rawMainKey = params.cfg.session?.mainKey;
|
|
637
|
-
const targetMainKey = typeof rawMainKey === "string" && rawMainKey.trim().length > 0 ? rawMainKey.trim() : DEFAULT_MAIN_KEY;
|
|
638
|
-
const targetScope = params.cfg.session?.scope;
|
|
639
|
-
const sessionsLegacyDir = path.join(stateDir, "sessions");
|
|
640
|
-
const sessionsLegacyStorePath = path.join(sessionsLegacyDir, "sessions.json");
|
|
641
|
-
const sessionsTargetDir = path.join(stateDir, "agents", targetAgentId, "sessions");
|
|
642
|
-
const sessionsTargetStorePath = path.join(sessionsTargetDir, "sessions.json");
|
|
643
|
-
const legacySessionEntries = safeReadDir(sessionsLegacyDir);
|
|
644
|
-
const hasLegacySessions = fileExists(sessionsLegacyStorePath) || legacySessionEntries.some((e) => e.isFile() && e.name.endsWith(".jsonl"));
|
|
645
|
-
const targetSessionParsed = fileExists(sessionsTargetStorePath) ? readSessionStoreJson5(sessionsTargetStorePath) : {
|
|
646
|
-
store: {},
|
|
647
|
-
ok: true
|
|
648
|
-
};
|
|
649
|
-
const legacyKeys = targetSessionParsed.ok ? listLegacySessionKeys({
|
|
650
|
-
store: targetSessionParsed.store,
|
|
651
|
-
agentId: targetAgentId,
|
|
652
|
-
mainKey: targetMainKey,
|
|
653
|
-
scope: targetScope
|
|
654
|
-
}) : [];
|
|
655
|
-
const legacyAgentDir = path.join(stateDir, "agent");
|
|
656
|
-
const targetAgentDir = path.join(stateDir, "agents", targetAgentId, "agent");
|
|
657
|
-
const hasLegacyAgentDir = existsDir(legacyAgentDir);
|
|
658
|
-
const targetWhatsAppAuthDir = path.join(oauthDir, "whatsapp", DEFAULT_ACCOUNT_ID);
|
|
659
|
-
const hasLegacyWhatsAppAuth = fileExists(path.join(oauthDir, "creds.json")) && !fileExists(path.join(targetWhatsAppAuthDir, "creds.json"));
|
|
660
|
-
const preview = [];
|
|
661
|
-
if (hasLegacySessions) preview.push(`- Sessions: ${sessionsLegacyDir} → ${sessionsTargetDir}`);
|
|
662
|
-
if (legacyKeys.length > 0) preview.push(`- Sessions: canonicalize legacy keys in ${sessionsTargetStorePath}`);
|
|
663
|
-
if (hasLegacyAgentDir) preview.push(`- Agent dir: ${legacyAgentDir} → ${targetAgentDir}`);
|
|
664
|
-
if (hasLegacyWhatsAppAuth) preview.push(`- WhatsApp auth: ${oauthDir} → ${targetWhatsAppAuthDir} (keep oauth.json)`);
|
|
665
|
-
return {
|
|
666
|
-
targetAgentId,
|
|
667
|
-
targetMainKey,
|
|
668
|
-
targetScope,
|
|
669
|
-
stateDir,
|
|
670
|
-
oauthDir,
|
|
671
|
-
sessions: {
|
|
672
|
-
legacyDir: sessionsLegacyDir,
|
|
673
|
-
legacyStorePath: sessionsLegacyStorePath,
|
|
674
|
-
targetDir: sessionsTargetDir,
|
|
675
|
-
targetStorePath: sessionsTargetStorePath,
|
|
676
|
-
hasLegacy: hasLegacySessions || legacyKeys.length > 0,
|
|
677
|
-
legacyKeys
|
|
678
|
-
},
|
|
679
|
-
agentDir: {
|
|
680
|
-
legacyDir: legacyAgentDir,
|
|
681
|
-
targetDir: targetAgentDir,
|
|
682
|
-
hasLegacy: hasLegacyAgentDir
|
|
683
|
-
},
|
|
684
|
-
whatsappAuth: {
|
|
685
|
-
legacyDir: oauthDir,
|
|
686
|
-
targetDir: targetWhatsAppAuthDir,
|
|
687
|
-
hasLegacy: hasLegacyWhatsAppAuth
|
|
688
|
-
},
|
|
689
|
-
preview
|
|
690
|
-
};
|
|
691
|
-
}
|
|
692
|
-
async function migrateLegacySessions(detected, now) {
|
|
693
|
-
const changes = [];
|
|
694
|
-
const warnings = [];
|
|
695
|
-
if (!detected.sessions.hasLegacy) return {
|
|
696
|
-
changes,
|
|
697
|
-
warnings
|
|
698
|
-
};
|
|
699
|
-
ensureDir(detected.sessions.targetDir);
|
|
700
|
-
const legacyParsed = fileExists(detected.sessions.legacyStorePath) ? readSessionStoreJson5(detected.sessions.legacyStorePath) : {
|
|
701
|
-
store: {},
|
|
702
|
-
ok: true
|
|
703
|
-
};
|
|
704
|
-
const targetParsed = fileExists(detected.sessions.targetStorePath) ? readSessionStoreJson5(detected.sessions.targetStorePath) : {
|
|
705
|
-
store: {},
|
|
706
|
-
ok: true
|
|
707
|
-
};
|
|
708
|
-
const legacyStore = legacyParsed.store;
|
|
709
|
-
const targetStore = targetParsed.store;
|
|
710
|
-
const canonicalizedTarget = canonicalizeSessionStore({
|
|
711
|
-
store: targetStore,
|
|
712
|
-
agentId: detected.targetAgentId,
|
|
713
|
-
mainKey: detected.targetMainKey,
|
|
714
|
-
scope: detected.targetScope
|
|
715
|
-
});
|
|
716
|
-
const canonicalizedLegacy = canonicalizeSessionStore({
|
|
717
|
-
store: legacyStore,
|
|
718
|
-
agentId: detected.targetAgentId,
|
|
719
|
-
mainKey: detected.targetMainKey,
|
|
720
|
-
scope: detected.targetScope
|
|
721
|
-
});
|
|
722
|
-
const merged = { ...canonicalizedTarget.store };
|
|
723
|
-
for (const [key, entry] of Object.entries(canonicalizedLegacy.store)) merged[key] = mergeSessionEntry({
|
|
724
|
-
existing: merged[key],
|
|
725
|
-
incoming: entry,
|
|
726
|
-
preferIncomingOnTie: false
|
|
727
|
-
});
|
|
728
|
-
const mainKey = buildAgentMainSessionKey({
|
|
729
|
-
agentId: detected.targetAgentId,
|
|
730
|
-
mainKey: detected.targetMainKey
|
|
731
|
-
});
|
|
732
|
-
if (!merged[mainKey]) {
|
|
733
|
-
const latest = pickLatestLegacyDirectEntry(legacyStore);
|
|
734
|
-
if (latest?.sessionId) {
|
|
735
|
-
merged[mainKey] = latest;
|
|
736
|
-
changes.push(`Migrated latest direct-chat session → ${mainKey}`);
|
|
737
|
-
}
|
|
738
|
-
}
|
|
739
|
-
if (!legacyParsed.ok) warnings.push(`Legacy sessions store unreadable; left in place at ${detected.sessions.legacyStorePath}`);
|
|
740
|
-
if ((legacyParsed.ok || targetParsed.ok) && (Object.keys(legacyStore).length > 0 || Object.keys(targetStore).length > 0)) {
|
|
741
|
-
const normalized = {};
|
|
742
|
-
for (const [key, entry] of Object.entries(merged)) {
|
|
743
|
-
const normalizedEntry = normalizeSessionEntry(entry);
|
|
744
|
-
if (!normalizedEntry) continue;
|
|
745
|
-
normalized[key] = normalizedEntry;
|
|
746
|
-
}
|
|
747
|
-
await saveSessionStore(detected.sessions.targetStorePath, normalized, { skipMaintenance: true });
|
|
748
|
-
changes.push(`Merged sessions store → ${detected.sessions.targetStorePath}`);
|
|
749
|
-
if (canonicalizedTarget.legacyKeys.length > 0) changes.push(`Canonicalized ${canonicalizedTarget.legacyKeys.length} legacy session key(s)`);
|
|
750
|
-
}
|
|
751
|
-
const entries = safeReadDir(detected.sessions.legacyDir);
|
|
752
|
-
for (const entry of entries) {
|
|
753
|
-
if (!entry.isFile()) continue;
|
|
754
|
-
if (entry.name === "sessions.json") continue;
|
|
755
|
-
const from = path.join(detected.sessions.legacyDir, entry.name);
|
|
756
|
-
const to = path.join(detected.sessions.targetDir, entry.name);
|
|
757
|
-
if (fileExists(to)) continue;
|
|
758
|
-
try {
|
|
759
|
-
fs.renameSync(from, to);
|
|
760
|
-
changes.push(`Moved ${entry.name} → agents/${detected.targetAgentId}/sessions`);
|
|
761
|
-
} catch (err) {
|
|
762
|
-
warnings.push(`Failed moving ${from}: ${String(err)}`);
|
|
763
|
-
}
|
|
764
|
-
}
|
|
765
|
-
if (legacyParsed.ok) try {
|
|
766
|
-
if (fileExists(detected.sessions.legacyStorePath)) fs.rmSync(detected.sessions.legacyStorePath, { force: true });
|
|
767
|
-
} catch {}
|
|
768
|
-
removeDirIfEmpty(detected.sessions.legacyDir);
|
|
769
|
-
if (safeReadDir(detected.sessions.legacyDir).filter((e) => e.isFile()).length > 0) {
|
|
770
|
-
const backupDir = `${detected.sessions.legacyDir}.legacy-${now()}`;
|
|
771
|
-
try {
|
|
772
|
-
fs.renameSync(detected.sessions.legacyDir, backupDir);
|
|
773
|
-
warnings.push(`Left legacy sessions at ${backupDir}`);
|
|
774
|
-
} catch {}
|
|
775
|
-
}
|
|
776
|
-
return {
|
|
777
|
-
changes,
|
|
778
|
-
warnings
|
|
779
|
-
};
|
|
780
|
-
}
|
|
781
|
-
async function migrateLegacyAgentDir(detected, now) {
|
|
782
|
-
const changes = [];
|
|
783
|
-
const warnings = [];
|
|
784
|
-
if (!detected.agentDir.hasLegacy) return {
|
|
785
|
-
changes,
|
|
786
|
-
warnings
|
|
787
|
-
};
|
|
788
|
-
ensureDir(detected.agentDir.targetDir);
|
|
789
|
-
const entries = safeReadDir(detected.agentDir.legacyDir);
|
|
790
|
-
for (const entry of entries) {
|
|
791
|
-
const from = path.join(detected.agentDir.legacyDir, entry.name);
|
|
792
|
-
const to = path.join(detected.agentDir.targetDir, entry.name);
|
|
793
|
-
if (fs.existsSync(to)) continue;
|
|
794
|
-
try {
|
|
795
|
-
fs.renameSync(from, to);
|
|
796
|
-
changes.push(`Moved agent file ${entry.name} → agents/${detected.targetAgentId}/agent`);
|
|
797
|
-
} catch (err) {
|
|
798
|
-
warnings.push(`Failed moving ${from}: ${String(err)}`);
|
|
799
|
-
}
|
|
800
|
-
}
|
|
801
|
-
removeDirIfEmpty(detected.agentDir.legacyDir);
|
|
802
|
-
if (!emptyDirOrMissing(detected.agentDir.legacyDir)) {
|
|
803
|
-
const backupDir = path.join(detected.stateDir, "agents", detected.targetAgentId, `agent.legacy-${now()}`);
|
|
804
|
-
try {
|
|
805
|
-
fs.renameSync(detected.agentDir.legacyDir, backupDir);
|
|
806
|
-
warnings.push(`Left legacy agent dir at ${backupDir}`);
|
|
807
|
-
} catch (err) {
|
|
808
|
-
warnings.push(`Failed relocating legacy agent dir: ${String(err)}`);
|
|
809
|
-
}
|
|
810
|
-
}
|
|
811
|
-
return {
|
|
812
|
-
changes,
|
|
813
|
-
warnings
|
|
814
|
-
};
|
|
815
|
-
}
|
|
816
|
-
async function migrateLegacyWhatsAppAuth(detected) {
|
|
817
|
-
const changes = [];
|
|
818
|
-
const warnings = [];
|
|
819
|
-
if (!detected.whatsappAuth.hasLegacy) return {
|
|
820
|
-
changes,
|
|
821
|
-
warnings
|
|
822
|
-
};
|
|
823
|
-
ensureDir(detected.whatsappAuth.targetDir);
|
|
824
|
-
const entries = safeReadDir(detected.whatsappAuth.legacyDir);
|
|
825
|
-
for (const entry of entries) {
|
|
826
|
-
if (!entry.isFile()) continue;
|
|
827
|
-
if (entry.name === "oauth.json") continue;
|
|
828
|
-
if (!isLegacyWhatsAppAuthFile(entry.name)) continue;
|
|
829
|
-
const from = path.join(detected.whatsappAuth.legacyDir, entry.name);
|
|
830
|
-
const to = path.join(detected.whatsappAuth.targetDir, entry.name);
|
|
831
|
-
if (fileExists(to)) continue;
|
|
832
|
-
try {
|
|
833
|
-
fs.renameSync(from, to);
|
|
834
|
-
changes.push(`Moved WhatsApp auth ${entry.name} → whatsapp/default`);
|
|
835
|
-
} catch (err) {
|
|
836
|
-
warnings.push(`Failed moving ${from}: ${String(err)}`);
|
|
837
|
-
}
|
|
838
|
-
}
|
|
839
|
-
return {
|
|
840
|
-
changes,
|
|
841
|
-
warnings
|
|
842
|
-
};
|
|
843
|
-
}
|
|
844
|
-
async function runLegacyStateMigrations(params) {
|
|
845
|
-
const now = params.now ?? (() => Date.now());
|
|
846
|
-
const detected = params.detected;
|
|
847
|
-
const sessions = await migrateLegacySessions(detected, now);
|
|
848
|
-
const agentDir = await migrateLegacyAgentDir(detected, now);
|
|
849
|
-
const whatsappAuth = await migrateLegacyWhatsAppAuth(detected);
|
|
850
|
-
return {
|
|
851
|
-
changes: [
|
|
852
|
-
...sessions.changes,
|
|
853
|
-
...agentDir.changes,
|
|
854
|
-
...whatsappAuth.changes
|
|
855
|
-
],
|
|
856
|
-
warnings: [
|
|
857
|
-
...sessions.warnings,
|
|
858
|
-
...agentDir.warnings,
|
|
859
|
-
...whatsappAuth.warnings
|
|
860
|
-
]
|
|
861
|
-
};
|
|
862
|
-
}
|
|
863
|
-
|
|
864
|
-
//#endregion
|
|
865
|
-
//#region src/commands/doctor-config-flow.ts
|
|
866
|
-
function normalizeIssuePath(path) {
|
|
867
|
-
return path.filter((part) => typeof part !== "symbol");
|
|
868
|
-
}
|
|
869
|
-
function isUnrecognizedKeysIssue(issue) {
|
|
870
|
-
return issue.code === "unrecognized_keys";
|
|
871
|
-
}
|
|
872
|
-
function formatPath(parts) {
|
|
873
|
-
if (parts.length === 0) return "<root>";
|
|
874
|
-
let out = "";
|
|
875
|
-
for (const part of parts) {
|
|
876
|
-
if (typeof part === "number") {
|
|
877
|
-
out += `[${part}]`;
|
|
878
|
-
continue;
|
|
879
|
-
}
|
|
880
|
-
out = out ? `${out}.${part}` : part;
|
|
881
|
-
}
|
|
882
|
-
return out || "<root>";
|
|
883
|
-
}
|
|
884
|
-
function resolvePathTarget(root, path) {
|
|
885
|
-
let current = root;
|
|
886
|
-
for (const part of path) {
|
|
887
|
-
if (typeof part === "number") {
|
|
888
|
-
if (!Array.isArray(current)) return null;
|
|
889
|
-
if (part < 0 || part >= current.length) return null;
|
|
890
|
-
current = current[part];
|
|
891
|
-
continue;
|
|
892
|
-
}
|
|
893
|
-
if (!current || typeof current !== "object" || Array.isArray(current)) return null;
|
|
894
|
-
const record = current;
|
|
895
|
-
if (!(part in record)) return null;
|
|
896
|
-
current = record[part];
|
|
897
|
-
}
|
|
898
|
-
return current;
|
|
899
|
-
}
|
|
900
|
-
function stripUnknownConfigKeys(config) {
|
|
901
|
-
const parsed = AnimaSchema.safeParse(config);
|
|
902
|
-
if (parsed.success) return {
|
|
903
|
-
config,
|
|
904
|
-
removed: []
|
|
905
|
-
};
|
|
906
|
-
const next = structuredClone(config);
|
|
907
|
-
const removed = [];
|
|
908
|
-
for (const issue of parsed.error.issues) {
|
|
909
|
-
if (!isUnrecognizedKeysIssue(issue)) continue;
|
|
910
|
-
const path = normalizeIssuePath(issue.path);
|
|
911
|
-
const target = resolvePathTarget(next, path);
|
|
912
|
-
if (!target || typeof target !== "object" || Array.isArray(target)) continue;
|
|
913
|
-
const record = target;
|
|
914
|
-
for (const key of issue.keys) {
|
|
915
|
-
if (typeof key !== "string") continue;
|
|
916
|
-
if (!(key in record)) continue;
|
|
917
|
-
delete record[key];
|
|
918
|
-
removed.push(formatPath([...path, key]));
|
|
919
|
-
}
|
|
920
|
-
}
|
|
921
|
-
return {
|
|
922
|
-
config: next,
|
|
923
|
-
removed
|
|
924
|
-
};
|
|
925
|
-
}
|
|
926
|
-
function noteOpencodeProviderOverrides(cfg) {
|
|
927
|
-
const providers = cfg.models?.providers;
|
|
928
|
-
if (!providers) return;
|
|
929
|
-
const overrides = [];
|
|
930
|
-
if (providers.opencode) overrides.push("opencode");
|
|
931
|
-
if (providers["opencode-zen"]) overrides.push("opencode-zen");
|
|
932
|
-
if (overrides.length === 0) return;
|
|
933
|
-
const lines = overrides.flatMap((id) => {
|
|
934
|
-
const providerEntry = providers[id];
|
|
935
|
-
const api = isRecord(providerEntry) && typeof providerEntry.api === "string" ? providerEntry.api : void 0;
|
|
936
|
-
return [`- models.providers.${id} is set; this overrides the built-in OpenCode Zen catalog.`, api ? `- models.providers.${id}.api=${api}` : null].filter((line) => Boolean(line));
|
|
937
|
-
});
|
|
938
|
-
lines.push("- Remove these entries to restore per-model API routing + costs (then re-run onboarding if needed).");
|
|
939
|
-
note(lines.join("\n"), "OpenCode Zen");
|
|
940
|
-
}
|
|
941
|
-
function normalizeTelegramAllowFromEntry(raw) {
|
|
942
|
-
return (typeof raw === "string" ? raw : typeof raw === "number" ? String(raw) : "").trim().replace(/^(telegram|tg):/i, "").trim();
|
|
943
|
-
}
|
|
944
|
-
function isNumericTelegramUserId(raw) {
|
|
945
|
-
return /^\d+$/.test(raw);
|
|
946
|
-
}
|
|
947
|
-
function scanTelegramAllowFromUsernameEntries(cfg) {
|
|
948
|
-
const hits = [];
|
|
949
|
-
const telegram = cfg.channels?.telegram;
|
|
950
|
-
if (!telegram) return hits;
|
|
951
|
-
const scanList = (pathLabel, list) => {
|
|
952
|
-
if (!Array.isArray(list)) return;
|
|
953
|
-
for (const entry of list) {
|
|
954
|
-
const normalized = normalizeTelegramAllowFromEntry(entry);
|
|
955
|
-
if (!normalized || normalized === "*") continue;
|
|
956
|
-
if (isNumericTelegramUserId(normalized)) continue;
|
|
957
|
-
hits.push({
|
|
958
|
-
path: pathLabel,
|
|
959
|
-
entry: String(entry).trim()
|
|
960
|
-
});
|
|
961
|
-
}
|
|
962
|
-
};
|
|
963
|
-
const scanAccount = (prefix, account) => {
|
|
964
|
-
scanList(`${prefix}.allowFrom`, account.allowFrom);
|
|
965
|
-
scanList(`${prefix}.groupAllowFrom`, account.groupAllowFrom);
|
|
966
|
-
const groups = account.groups;
|
|
967
|
-
if (!groups || typeof groups !== "object" || Array.isArray(groups)) return;
|
|
968
|
-
const groupsRecord = groups;
|
|
969
|
-
for (const groupId of Object.keys(groupsRecord)) {
|
|
970
|
-
const group = groupsRecord[groupId];
|
|
971
|
-
if (!group || typeof group !== "object" || Array.isArray(group)) continue;
|
|
972
|
-
const groupRec = group;
|
|
973
|
-
scanList(`${prefix}.groups.${groupId}.allowFrom`, groupRec.allowFrom);
|
|
974
|
-
const topics = groupRec.topics;
|
|
975
|
-
if (!topics || typeof topics !== "object" || Array.isArray(topics)) continue;
|
|
976
|
-
const topicsRecord = topics;
|
|
977
|
-
for (const topicId of Object.keys(topicsRecord)) {
|
|
978
|
-
const topic = topicsRecord[topicId];
|
|
979
|
-
if (!topic || typeof topic !== "object" || Array.isArray(topic)) continue;
|
|
980
|
-
scanList(`${prefix}.groups.${groupId}.topics.${topicId}.allowFrom`, topic.allowFrom);
|
|
981
|
-
}
|
|
982
|
-
}
|
|
983
|
-
};
|
|
984
|
-
scanAccount("channels.telegram", telegram);
|
|
985
|
-
const accounts = telegram.accounts;
|
|
986
|
-
if (!accounts || typeof accounts !== "object" || Array.isArray(accounts)) return hits;
|
|
987
|
-
for (const key of Object.keys(accounts)) {
|
|
988
|
-
const account = accounts[key];
|
|
989
|
-
if (!account || typeof account !== "object" || Array.isArray(account)) continue;
|
|
990
|
-
scanAccount(`channels.telegram.accounts.${key}`, account);
|
|
991
|
-
}
|
|
992
|
-
return hits;
|
|
993
|
-
}
|
|
994
|
-
async function maybeRepairTelegramAllowFromUsernames(cfg) {
|
|
995
|
-
if (scanTelegramAllowFromUsernameEntries(cfg).length === 0) return {
|
|
996
|
-
config: cfg,
|
|
997
|
-
changes: []
|
|
998
|
-
};
|
|
999
|
-
const tokens = Array.from(new Set(listTelegramAccountIds(cfg).map((accountId) => resolveTelegramAccount({
|
|
1000
|
-
cfg,
|
|
1001
|
-
accountId
|
|
1002
|
-
})).map((account) => account.tokenSource === "none" ? "" : account.token).map((token) => token.trim()).filter(Boolean)));
|
|
1003
|
-
if (tokens.length === 0) return {
|
|
1004
|
-
config: cfg,
|
|
1005
|
-
changes: [`- Telegram allowFrom contains @username entries, but no Telegram bot token is configured; cannot auto-resolve (run onboarding or replace with numeric sender IDs).`]
|
|
1006
|
-
};
|
|
1007
|
-
const resolveUserId = async (raw) => {
|
|
1008
|
-
const trimmed = raw.trim();
|
|
1009
|
-
if (!trimmed) return null;
|
|
1010
|
-
const stripped = normalizeTelegramAllowFromEntry(trimmed);
|
|
1011
|
-
if (!stripped || stripped === "*") return null;
|
|
1012
|
-
if (isNumericTelegramUserId(stripped)) return stripped;
|
|
1013
|
-
if (/\s/.test(stripped)) return null;
|
|
1014
|
-
const username = stripped.startsWith("@") ? stripped : `@${stripped}`;
|
|
1015
|
-
for (const token of tokens) {
|
|
1016
|
-
const controller = new AbortController();
|
|
1017
|
-
const timeout = setTimeout(() => controller.abort(), 4e3);
|
|
1018
|
-
try {
|
|
1019
|
-
const url = `https://api.telegram.org/bot${token}/getChat?chat_id=${encodeURIComponent(username)}`;
|
|
1020
|
-
const res = await fetch(url, { signal: controller.signal }).catch(() => null);
|
|
1021
|
-
if (!res || !res.ok) continue;
|
|
1022
|
-
const data = await res.json().catch(() => null);
|
|
1023
|
-
const id = data?.ok ? data?.result?.id : void 0;
|
|
1024
|
-
if (typeof id === "number" || typeof id === "string") return String(id);
|
|
1025
|
-
} catch {} finally {
|
|
1026
|
-
clearTimeout(timeout);
|
|
1027
|
-
}
|
|
1028
|
-
}
|
|
1029
|
-
return null;
|
|
1030
|
-
};
|
|
1031
|
-
const changes = [];
|
|
1032
|
-
const next = structuredClone(cfg);
|
|
1033
|
-
const repairList = async (pathLabel, holder, key) => {
|
|
1034
|
-
const raw = holder[key];
|
|
1035
|
-
if (!Array.isArray(raw)) return;
|
|
1036
|
-
const out = [];
|
|
1037
|
-
const replaced = [];
|
|
1038
|
-
for (const entry of raw) {
|
|
1039
|
-
const normalized = normalizeTelegramAllowFromEntry(entry);
|
|
1040
|
-
if (!normalized) continue;
|
|
1041
|
-
if (normalized === "*") {
|
|
1042
|
-
out.push("*");
|
|
1043
|
-
continue;
|
|
1044
|
-
}
|
|
1045
|
-
if (isNumericTelegramUserId(normalized)) {
|
|
1046
|
-
out.push(normalized);
|
|
1047
|
-
continue;
|
|
1048
|
-
}
|
|
1049
|
-
const resolved = await resolveUserId(String(entry));
|
|
1050
|
-
if (resolved) {
|
|
1051
|
-
out.push(resolved);
|
|
1052
|
-
replaced.push({
|
|
1053
|
-
from: String(entry).trim(),
|
|
1054
|
-
to: resolved
|
|
1055
|
-
});
|
|
1056
|
-
} else out.push(String(entry).trim());
|
|
1057
|
-
}
|
|
1058
|
-
const deduped = [];
|
|
1059
|
-
const seen = /* @__PURE__ */ new Set();
|
|
1060
|
-
for (const entry of out) {
|
|
1061
|
-
const k = String(entry).trim();
|
|
1062
|
-
if (!k || seen.has(k)) continue;
|
|
1063
|
-
seen.add(k);
|
|
1064
|
-
deduped.push(entry);
|
|
1065
|
-
}
|
|
1066
|
-
holder[key] = deduped;
|
|
1067
|
-
if (replaced.length > 0) {
|
|
1068
|
-
for (const rep of replaced.slice(0, 5)) changes.push(`- ${pathLabel}: resolved ${rep.from} -> ${rep.to}`);
|
|
1069
|
-
if (replaced.length > 5) changes.push(`- ${pathLabel}: resolved ${replaced.length - 5} more @username entries`);
|
|
1070
|
-
}
|
|
1071
|
-
};
|
|
1072
|
-
const repairAccount = async (prefix, account) => {
|
|
1073
|
-
await repairList(`${prefix}.allowFrom`, account, "allowFrom");
|
|
1074
|
-
await repairList(`${prefix}.groupAllowFrom`, account, "groupAllowFrom");
|
|
1075
|
-
const groups = account.groups;
|
|
1076
|
-
if (!groups || typeof groups !== "object" || Array.isArray(groups)) return;
|
|
1077
|
-
const groupsRecord = groups;
|
|
1078
|
-
for (const groupId of Object.keys(groupsRecord)) {
|
|
1079
|
-
const group = groupsRecord[groupId];
|
|
1080
|
-
if (!group || typeof group !== "object" || Array.isArray(group)) continue;
|
|
1081
|
-
const groupRec = group;
|
|
1082
|
-
await repairList(`${prefix}.groups.${groupId}.allowFrom`, groupRec, "allowFrom");
|
|
1083
|
-
const topics = groupRec.topics;
|
|
1084
|
-
if (!topics || typeof topics !== "object" || Array.isArray(topics)) continue;
|
|
1085
|
-
const topicsRecord = topics;
|
|
1086
|
-
for (const topicId of Object.keys(topicsRecord)) {
|
|
1087
|
-
const topic = topicsRecord[topicId];
|
|
1088
|
-
if (!topic || typeof topic !== "object" || Array.isArray(topic)) continue;
|
|
1089
|
-
await repairList(`${prefix}.groups.${groupId}.topics.${topicId}.allowFrom`, topic, "allowFrom");
|
|
1090
|
-
}
|
|
1091
|
-
}
|
|
1092
|
-
};
|
|
1093
|
-
const telegram = next.channels?.telegram;
|
|
1094
|
-
if (telegram && typeof telegram === "object" && !Array.isArray(telegram)) {
|
|
1095
|
-
await repairAccount("channels.telegram", telegram);
|
|
1096
|
-
const accounts = telegram.accounts;
|
|
1097
|
-
if (accounts && typeof accounts === "object" && !Array.isArray(accounts)) for (const key of Object.keys(accounts)) {
|
|
1098
|
-
const account = accounts[key];
|
|
1099
|
-
if (!account || typeof account !== "object" || Array.isArray(account)) continue;
|
|
1100
|
-
await repairAccount(`channels.telegram.accounts.${key}`, account);
|
|
1101
|
-
}
|
|
1102
|
-
}
|
|
1103
|
-
if (changes.length === 0) return {
|
|
1104
|
-
config: cfg,
|
|
1105
|
-
changes: []
|
|
1106
|
-
};
|
|
1107
|
-
return {
|
|
1108
|
-
config: next,
|
|
1109
|
-
changes
|
|
1110
|
-
};
|
|
1111
|
-
}
|
|
1112
|
-
async function maybeMigrateLegacyConfig() {
|
|
1113
|
-
const changes = [];
|
|
1114
|
-
const home = resolveHomeDir();
|
|
1115
|
-
if (!home) return changes;
|
|
1116
|
-
const targetDir = path.join(home, ".anima");
|
|
1117
|
-
const targetPath = path.join(targetDir, "anima.json");
|
|
1118
|
-
try {
|
|
1119
|
-
await fs$1.access(targetPath);
|
|
1120
|
-
return changes;
|
|
1121
|
-
} catch {}
|
|
1122
|
-
const legacyCandidates = [
|
|
1123
|
-
path.join(home, ".anima", "anima.json"),
|
|
1124
|
-
path.join(home, ".anima", "anima.json"),
|
|
1125
|
-
path.join(home, ".anima", "anima.json")
|
|
1126
|
-
];
|
|
1127
|
-
let legacyPath = null;
|
|
1128
|
-
for (const candidate of legacyCandidates) try {
|
|
1129
|
-
await fs$1.access(candidate);
|
|
1130
|
-
legacyPath = candidate;
|
|
1131
|
-
break;
|
|
1132
|
-
} catch {}
|
|
1133
|
-
if (!legacyPath) return changes;
|
|
1134
|
-
await fs$1.mkdir(targetDir, { recursive: true });
|
|
1135
|
-
try {
|
|
1136
|
-
await fs$1.copyFile(legacyPath, targetPath, fs$1.constants.COPYFILE_EXCL);
|
|
1137
|
-
changes.push(`Migrated legacy config: ${legacyPath} -> ${targetPath}`);
|
|
1138
|
-
} catch {}
|
|
1139
|
-
return changes;
|
|
1140
|
-
}
|
|
1141
|
-
async function loadAndMaybeMigrateDoctorConfig(params) {
|
|
1142
|
-
const shouldRepair = params.options.repair === true || params.options.yes === true;
|
|
1143
|
-
const stateDirResult = await autoMigrateLegacyStateDir({ env: process.env });
|
|
1144
|
-
if (stateDirResult.changes.length > 0) note(stateDirResult.changes.map((entry) => `- ${entry}`).join("\n"), "Doctor changes");
|
|
1145
|
-
if (stateDirResult.warnings.length > 0) note(stateDirResult.warnings.map((entry) => `- ${entry}`).join("\n"), "Doctor warnings");
|
|
1146
|
-
const legacyConfigChanges = await maybeMigrateLegacyConfig();
|
|
1147
|
-
if (legacyConfigChanges.length > 0) note(legacyConfigChanges.map((entry) => `- ${entry}`).join("\n"), "Doctor changes");
|
|
1148
|
-
let snapshot = await readConfigFileSnapshot();
|
|
1149
|
-
const baseCfg = snapshot.config ?? {};
|
|
1150
|
-
let cfg = baseCfg;
|
|
1151
|
-
let candidate = structuredClone(baseCfg);
|
|
1152
|
-
let pendingChanges = false;
|
|
1153
|
-
let shouldWriteConfig = false;
|
|
1154
|
-
const fixHints = [];
|
|
1155
|
-
if (snapshot.exists && !snapshot.valid && snapshot.legacyIssues.length === 0) note("Config invalid; doctor will run with best-effort config.", "Config");
|
|
1156
|
-
const warnings = snapshot.warnings ?? [];
|
|
1157
|
-
if (warnings.length > 0) note(warnings.map((issue) => `- ${issue.path}: ${issue.message}`).join("\n"), "Config warnings");
|
|
1158
|
-
if (snapshot.legacyIssues.length > 0) {
|
|
1159
|
-
note(snapshot.legacyIssues.map((issue) => `- ${issue.path}: ${issue.message}`).join("\n"), "Legacy config keys detected");
|
|
1160
|
-
const { config: migrated, changes } = migrateLegacyConfig(snapshot.parsed);
|
|
1161
|
-
if (changes.length > 0) note(changes.join("\n"), "Doctor changes");
|
|
1162
|
-
if (migrated) {
|
|
1163
|
-
candidate = migrated;
|
|
1164
|
-
pendingChanges = pendingChanges || changes.length > 0;
|
|
1165
|
-
}
|
|
1166
|
-
if (shouldRepair) {
|
|
1167
|
-
if (migrated) cfg = migrated;
|
|
1168
|
-
} else fixHints.push(`Run "${formatCliCommand("anima doctor --fix")}" to apply legacy migrations.`);
|
|
1169
|
-
}
|
|
1170
|
-
const normalized = normalizeLegacyConfigValues(candidate);
|
|
1171
|
-
if (normalized.changes.length > 0) {
|
|
1172
|
-
note(normalized.changes.join("\n"), "Doctor changes");
|
|
1173
|
-
candidate = normalized.config;
|
|
1174
|
-
pendingChanges = true;
|
|
1175
|
-
if (shouldRepair) cfg = normalized.config;
|
|
1176
|
-
else fixHints.push(`Run "${formatCliCommand("anima doctor --fix")}" to apply these changes.`);
|
|
1177
|
-
}
|
|
1178
|
-
const autoEnable = applyPluginAutoEnable({
|
|
1179
|
-
config: candidate,
|
|
1180
|
-
env: process.env
|
|
1181
|
-
});
|
|
1182
|
-
if (autoEnable.changes.length > 0) {
|
|
1183
|
-
note(autoEnable.changes.join("\n"), "Doctor changes");
|
|
1184
|
-
candidate = autoEnable.config;
|
|
1185
|
-
pendingChanges = true;
|
|
1186
|
-
if (shouldRepair) cfg = autoEnable.config;
|
|
1187
|
-
else fixHints.push(`Run "${formatCliCommand("anima doctor --fix")}" to apply these changes.`);
|
|
1188
|
-
}
|
|
1189
|
-
if (shouldRepair) {
|
|
1190
|
-
const repair = await maybeRepairTelegramAllowFromUsernames(candidate);
|
|
1191
|
-
if (repair.changes.length > 0) {
|
|
1192
|
-
note(repair.changes.join("\n"), "Doctor changes");
|
|
1193
|
-
candidate = repair.config;
|
|
1194
|
-
pendingChanges = true;
|
|
1195
|
-
cfg = repair.config;
|
|
1196
|
-
}
|
|
1197
|
-
} else {
|
|
1198
|
-
const hits = scanTelegramAllowFromUsernameEntries(candidate);
|
|
1199
|
-
if (hits.length > 0) note([`- Telegram allowFrom contains ${hits.length} non-numeric entries (e.g. ${hits[0]?.entry ?? "@"}); Telegram authorization requires numeric sender IDs.`, `- Run "${formatCliCommand("anima doctor --fix")}" to auto-resolve @username entries to numeric IDs (requires a Telegram bot token).`].join("\n"), "Doctor warnings");
|
|
1200
|
-
}
|
|
1201
|
-
const unknown = stripUnknownConfigKeys(candidate);
|
|
1202
|
-
if (unknown.removed.length > 0) {
|
|
1203
|
-
const lines = unknown.removed.map((path) => `- ${path}`).join("\n");
|
|
1204
|
-
candidate = unknown.config;
|
|
1205
|
-
pendingChanges = true;
|
|
1206
|
-
if (shouldRepair) {
|
|
1207
|
-
cfg = unknown.config;
|
|
1208
|
-
note(lines, "Doctor changes");
|
|
1209
|
-
} else {
|
|
1210
|
-
note(lines, "Unknown config keys");
|
|
1211
|
-
fixHints.push("Run \"anima doctor --fix\" to remove these keys.");
|
|
1212
|
-
}
|
|
1213
|
-
}
|
|
1214
|
-
if (!shouldRepair && pendingChanges) {
|
|
1215
|
-
if (await params.confirm({
|
|
1216
|
-
message: "Apply recommended config repairs now?",
|
|
1217
|
-
initialValue: true
|
|
1218
|
-
})) {
|
|
1219
|
-
cfg = candidate;
|
|
1220
|
-
shouldWriteConfig = true;
|
|
1221
|
-
} else if (fixHints.length > 0) note(fixHints.join("\n"), "Doctor");
|
|
1222
|
-
}
|
|
1223
|
-
noteOpencodeProviderOverrides(cfg);
|
|
1224
|
-
return {
|
|
1225
|
-
cfg,
|
|
1226
|
-
path: snapshot.path ?? CONFIG_PATH,
|
|
1227
|
-
shouldWriteConfig
|
|
1228
|
-
};
|
|
1229
|
-
}
|
|
1230
|
-
|
|
1231
|
-
//#endregion
|
|
1232
|
-
export { detectLegacyStateMigrations as n, runLegacyStateMigrations as r, loadAndMaybeMigrateDoctorConfig as t };
|