@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,1304 +0,0 @@
|
|
|
1
|
-
import { E as setVerbose, F as getResolvedLoggerSettings, M as theme, b as danger, h as defaultRuntime, rt as DEFAULT_CHAT_CHANNEL } from "./entry.js";
|
|
2
|
-
import { g as loadAuthProfileStore } from "./auth-profiles-DxI8L7bs.js";
|
|
3
|
-
import { t as formatCliCommand } from "./command-format-Clp46jkj.js";
|
|
4
|
-
import { c as normalizeAccountId, t as DEFAULT_ACCOUNT_ID } from "./session-key-BGiG_JcT.js";
|
|
5
|
-
import "./utils-C9sj30YY.js";
|
|
6
|
-
import "./exec-BizYYQgP.js";
|
|
7
|
-
import { c as resolveDefaultAgentId, s as resolveAgentWorkspaceDir } from "./agent-scope-OZi7lb8S.js";
|
|
8
|
-
import "./pi-model-discovery-DsRqYJLy.js";
|
|
9
|
-
import "./skills-B5LQx4lT.js";
|
|
10
|
-
import "./manifest-registry-D4lM2RdV.js";
|
|
11
|
-
import { i as loadConfig, l as writeConfigFile, o as readConfigFileSnapshot } from "./config-C8rUDJXY.js";
|
|
12
|
-
import "./client-C1avc0vD.js";
|
|
13
|
-
import { n as callGateway } from "./call-BAHvlu2G.js";
|
|
14
|
-
import "./message-channel-w4F2b2F6.js";
|
|
15
|
-
import "./timeout-CswI_K-U.js";
|
|
16
|
-
import "./sessions-DcXpzig0.js";
|
|
17
|
-
import "./subagent-registry-Byuex3zp.js";
|
|
18
|
-
import "./logging-BdnOSVPD.js";
|
|
19
|
-
import "./accounts-CcVrwKqv.js";
|
|
20
|
-
import { c as loadProviderUsageSummary, l as formatUsageReportLines, ot as parseDiscordTarget } from "./reply-mlsExaZm.js";
|
|
21
|
-
import { n as listChannelPlugins, r as normalizeChannelId, t as getChannelPlugin } from "./plugins-CDJw924T.js";
|
|
22
|
-
import "./tokens-C-X7wDKj.js";
|
|
23
|
-
import "./dock-DbxBBv30.js";
|
|
24
|
-
import "./paths-CxRf2rBG.js";
|
|
25
|
-
import "./chunk-mxPVo000.js";
|
|
26
|
-
import "./media-THyainiE.js";
|
|
27
|
-
import "./mime-B1ZoR53M.js";
|
|
28
|
-
import "./image-ops-Dlt3T7th.js";
|
|
29
|
-
import "./common-D6bu0zHC.js";
|
|
30
|
-
import "./server-context-49XFFxFg.js";
|
|
31
|
-
import "./chrome-Bi6iZ5sG.js";
|
|
32
|
-
import "./auth-lZ26wsbN.js";
|
|
33
|
-
import "./ports-CqLSlU6Z.js";
|
|
34
|
-
import "./trash-BJLK1vMn.js";
|
|
35
|
-
import "./control-service-DKotCWCg.js";
|
|
36
|
-
import "./cli-session-Dd8DKb5a.js";
|
|
37
|
-
import "./thinking-BXEswx1X.js";
|
|
38
|
-
import "./context-D5iEFzv9.js";
|
|
39
|
-
import "./sandbox-BIGfMYEI.js";
|
|
40
|
-
import "./routes-DO0HqW2e.js";
|
|
41
|
-
import "./paths-DcVEkYX5.js";
|
|
42
|
-
import "./commands-registry-Bd0xbvwG.js";
|
|
43
|
-
import "./deliver-LiY5oL52.js";
|
|
44
|
-
import "./pairing-store-DmOzxcuk.js";
|
|
45
|
-
import "./nodes-screen-DZeD8hE5.js";
|
|
46
|
-
import { n as formatTimeAgo } from "./format-relative-C6kUHuOj.js";
|
|
47
|
-
import "./memory-cli-BKocCWXM.js";
|
|
48
|
-
import "./manager-B4OyvcxT.js";
|
|
49
|
-
import "./sqlite-BukcjdJa.js";
|
|
50
|
-
import "./redact-ClVwO7Nn.js";
|
|
51
|
-
import { n as fetchChannelPermissionsDiscord } from "./send-Dz2BDHll.js";
|
|
52
|
-
import { t as formatDocsLink } from "./links-BfjHVTB_.js";
|
|
53
|
-
import { n as runCommandWithRuntime } from "./cli-utils-DtAxdCte.js";
|
|
54
|
-
import { n as withProgress } from "./progress-CbZ2D53A.js";
|
|
55
|
-
import "./dispatcher-10Shiuz3.js";
|
|
56
|
-
import { n as resolveMessageChannelSelection } from "./channel-selection-DfGpCyh2.js";
|
|
57
|
-
import "./delivery-queue-B6IHz4Ry.js";
|
|
58
|
-
import "./pi-tools.policy-DSHkkb5b.js";
|
|
59
|
-
import "./session-cost-usage-BwiTZuKl.js";
|
|
60
|
-
import { r as listChannelPluginCatalogEntries } from "./catalog-BAayBt1L.js";
|
|
61
|
-
import "./prompt-style-DKy6qQxR.js";
|
|
62
|
-
import "./note-uiuPxhyX.js";
|
|
63
|
-
import { t as createClackPrompter } from "./clack-prompter-B0kl7shw.js";
|
|
64
|
-
import { t as resolveChannelDefaultAccountId } from "./helpers-ZKNRexvX.js";
|
|
65
|
-
import "./plugin-auto-enable-CxF4bpDN.js";
|
|
66
|
-
import { i as reloadOnboardingPluginRegistry, n as setupChannels, r as ensureOnboardingPluginInstalled } from "./onboard-channels-D7NbA55V.js";
|
|
67
|
-
import "./npm-registry-spec-za3itb5Y.js";
|
|
68
|
-
import "./skill-scanner-CkaVLABv.js";
|
|
69
|
-
import "./installs-D-cPGdCw.js";
|
|
70
|
-
import { t as buildChannelAccountSnapshot } from "./status-CMnlcBVc.js";
|
|
71
|
-
import { t as parseLogLine } from "./parse-log-line-Bqh1SSzC.js";
|
|
72
|
-
import { t as collectChannelStatusIssues } from "./channels-status-issues-DBc1pU_R.js";
|
|
73
|
-
import "./plugin-registry-DcUCbGax.js";
|
|
74
|
-
import { t as formatCliChannelOptions } from "./channel-options-ZdvXrTGs.js";
|
|
75
|
-
import { t as hasExplicitOptions } from "./command-options-Cp1tf96a.js";
|
|
76
|
-
import fs from "node:fs/promises";
|
|
77
|
-
|
|
78
|
-
//#region src/commands/channels/add-mutators.ts
|
|
79
|
-
function applyAccountName(params) {
|
|
80
|
-
const accountId = normalizeAccountId(params.accountId);
|
|
81
|
-
const apply = getChannelPlugin(params.channel)?.setup?.applyAccountName;
|
|
82
|
-
return apply ? apply({
|
|
83
|
-
cfg: params.cfg,
|
|
84
|
-
accountId,
|
|
85
|
-
name: params.name
|
|
86
|
-
}) : params.cfg;
|
|
87
|
-
}
|
|
88
|
-
function applyChannelAccountConfig(params) {
|
|
89
|
-
const accountId = normalizeAccountId(params.accountId);
|
|
90
|
-
const apply = getChannelPlugin(params.channel)?.setup?.applyAccountConfig;
|
|
91
|
-
if (!apply) return params.cfg;
|
|
92
|
-
return apply({
|
|
93
|
-
cfg: params.cfg,
|
|
94
|
-
accountId,
|
|
95
|
-
input: params.input
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
//#endregion
|
|
100
|
-
//#region src/commands/channels/shared.ts
|
|
101
|
-
async function requireValidConfig(runtime = defaultRuntime) {
|
|
102
|
-
const snapshot = await readConfigFileSnapshot();
|
|
103
|
-
if (snapshot.exists && !snapshot.valid) {
|
|
104
|
-
const issues = snapshot.issues.length > 0 ? snapshot.issues.map((issue) => `- ${issue.path}: ${issue.message}`).join("\n") : "Unknown validation issue.";
|
|
105
|
-
runtime.error(`Config invalid:\n${issues}`);
|
|
106
|
-
runtime.error(`Fix the config or run ${formatCliCommand("anima doctor")}.`);
|
|
107
|
-
runtime.exit(1);
|
|
108
|
-
return null;
|
|
109
|
-
}
|
|
110
|
-
return snapshot.config;
|
|
111
|
-
}
|
|
112
|
-
function formatAccountLabel(params) {
|
|
113
|
-
const base = params.accountId || DEFAULT_ACCOUNT_ID;
|
|
114
|
-
if (params.name?.trim()) return `${base} (${params.name.trim()})`;
|
|
115
|
-
return base;
|
|
116
|
-
}
|
|
117
|
-
const channelLabel = (channel) => {
|
|
118
|
-
return getChannelPlugin(channel)?.meta.label ?? channel;
|
|
119
|
-
};
|
|
120
|
-
function formatChannelAccountLabel(params) {
|
|
121
|
-
const channelText = channelLabel(params.channel);
|
|
122
|
-
const accountText = formatAccountLabel({
|
|
123
|
-
accountId: params.accountId,
|
|
124
|
-
name: params.name
|
|
125
|
-
});
|
|
126
|
-
return `${params.channelStyle ? params.channelStyle(channelText) : channelText} ${params.accountStyle ? params.accountStyle(accountText) : accountText}`;
|
|
127
|
-
}
|
|
128
|
-
function shouldUseWizard(params) {
|
|
129
|
-
return params?.hasFlags === false;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
//#endregion
|
|
133
|
-
//#region src/commands/channels/add.ts
|
|
134
|
-
function parseList(value) {
|
|
135
|
-
if (!value?.trim()) return;
|
|
136
|
-
const parsed = value.split(/[\n,;]+/g).map((entry) => entry.trim()).filter(Boolean);
|
|
137
|
-
return parsed.length > 0 ? parsed : void 0;
|
|
138
|
-
}
|
|
139
|
-
function resolveCatalogChannelEntry(raw, cfg) {
|
|
140
|
-
const trimmed = raw.trim().toLowerCase();
|
|
141
|
-
if (!trimmed) return;
|
|
142
|
-
return listChannelPluginCatalogEntries({ workspaceDir: cfg ? resolveAgentWorkspaceDir(cfg, resolveDefaultAgentId(cfg)) : void 0 }).find((entry) => {
|
|
143
|
-
if (entry.id.toLowerCase() === trimmed) return true;
|
|
144
|
-
return (entry.meta.aliases ?? []).some((alias) => alias.trim().toLowerCase() === trimmed);
|
|
145
|
-
});
|
|
146
|
-
}
|
|
147
|
-
async function channelsAddCommand(opts, runtime = defaultRuntime, params) {
|
|
148
|
-
const cfg = await requireValidConfig(runtime);
|
|
149
|
-
if (!cfg) return;
|
|
150
|
-
let nextConfig = cfg;
|
|
151
|
-
if (shouldUseWizard(params)) {
|
|
152
|
-
const prompter = createClackPrompter();
|
|
153
|
-
let selection = [];
|
|
154
|
-
const accountIds = {};
|
|
155
|
-
await prompter.intro("Channel setup");
|
|
156
|
-
let nextConfig = await setupChannels(cfg, runtime, prompter, {
|
|
157
|
-
allowDisable: false,
|
|
158
|
-
allowSignalInstall: true,
|
|
159
|
-
promptAccountIds: true,
|
|
160
|
-
onSelection: (value) => {
|
|
161
|
-
selection = value;
|
|
162
|
-
},
|
|
163
|
-
onAccountId: (channel, accountId) => {
|
|
164
|
-
accountIds[channel] = accountId;
|
|
165
|
-
}
|
|
166
|
-
});
|
|
167
|
-
if (selection.length === 0) {
|
|
168
|
-
await prompter.outro("No channels selected.");
|
|
169
|
-
return;
|
|
170
|
-
}
|
|
171
|
-
if (await prompter.confirm({
|
|
172
|
-
message: "Add display names for these accounts? (optional)",
|
|
173
|
-
initialValue: false
|
|
174
|
-
})) for (const channel of selection) {
|
|
175
|
-
const accountId = accountIds[channel] ?? DEFAULT_ACCOUNT_ID;
|
|
176
|
-
const plugin = getChannelPlugin(channel);
|
|
177
|
-
const account = plugin?.config.resolveAccount(nextConfig, accountId);
|
|
178
|
-
const existingName = (plugin?.config.describeAccount?.(account, nextConfig))?.name ?? account?.name;
|
|
179
|
-
const name = await prompter.text({
|
|
180
|
-
message: `${channel} account name (${accountId})`,
|
|
181
|
-
initialValue: existingName
|
|
182
|
-
});
|
|
183
|
-
if (name?.trim()) nextConfig = applyAccountName({
|
|
184
|
-
cfg: nextConfig,
|
|
185
|
-
channel,
|
|
186
|
-
accountId,
|
|
187
|
-
name
|
|
188
|
-
});
|
|
189
|
-
}
|
|
190
|
-
await writeConfigFile(nextConfig);
|
|
191
|
-
await prompter.outro("Channels updated.");
|
|
192
|
-
return;
|
|
193
|
-
}
|
|
194
|
-
const rawChannel = String(opts.channel ?? "");
|
|
195
|
-
let channel = normalizeChannelId(rawChannel);
|
|
196
|
-
let catalogEntry = channel ? void 0 : resolveCatalogChannelEntry(rawChannel, nextConfig);
|
|
197
|
-
if (!channel && catalogEntry) {
|
|
198
|
-
const prompter = createClackPrompter();
|
|
199
|
-
const workspaceDir = resolveAgentWorkspaceDir(nextConfig, resolveDefaultAgentId(nextConfig));
|
|
200
|
-
const result = await ensureOnboardingPluginInstalled({
|
|
201
|
-
cfg: nextConfig,
|
|
202
|
-
entry: catalogEntry,
|
|
203
|
-
prompter,
|
|
204
|
-
runtime,
|
|
205
|
-
workspaceDir
|
|
206
|
-
});
|
|
207
|
-
nextConfig = result.cfg;
|
|
208
|
-
if (!result.installed) return;
|
|
209
|
-
reloadOnboardingPluginRegistry({
|
|
210
|
-
cfg: nextConfig,
|
|
211
|
-
runtime,
|
|
212
|
-
workspaceDir
|
|
213
|
-
});
|
|
214
|
-
channel = normalizeChannelId(catalogEntry.id) ?? catalogEntry.id;
|
|
215
|
-
}
|
|
216
|
-
if (!channel) {
|
|
217
|
-
const hint = catalogEntry ? `Plugin ${catalogEntry.meta.label} could not be loaded after install.` : `Unknown channel: ${String(opts.channel ?? "")}`;
|
|
218
|
-
runtime.error(hint);
|
|
219
|
-
runtime.exit(1);
|
|
220
|
-
return;
|
|
221
|
-
}
|
|
222
|
-
const plugin = getChannelPlugin(channel);
|
|
223
|
-
if (!plugin?.setup?.applyAccountConfig) {
|
|
224
|
-
runtime.error(`Channel ${channel} does not support add.`);
|
|
225
|
-
runtime.exit(1);
|
|
226
|
-
return;
|
|
227
|
-
}
|
|
228
|
-
const accountId = plugin.setup.resolveAccountId?.({
|
|
229
|
-
cfg: nextConfig,
|
|
230
|
-
accountId: opts.account
|
|
231
|
-
}) ?? normalizeAccountId(opts.account);
|
|
232
|
-
const useEnv = opts.useEnv === true;
|
|
233
|
-
const initialSyncLimit = typeof opts.initialSyncLimit === "number" ? opts.initialSyncLimit : typeof opts.initialSyncLimit === "string" && opts.initialSyncLimit.trim() ? Number.parseInt(opts.initialSyncLimit, 10) : void 0;
|
|
234
|
-
const groupChannels = parseList(opts.groupChannels);
|
|
235
|
-
const dmAllowlist = parseList(opts.dmAllowlist);
|
|
236
|
-
const input = {
|
|
237
|
-
name: opts.name,
|
|
238
|
-
token: opts.token,
|
|
239
|
-
tokenFile: opts.tokenFile,
|
|
240
|
-
botToken: opts.botToken,
|
|
241
|
-
appToken: opts.appToken,
|
|
242
|
-
signalNumber: opts.signalNumber,
|
|
243
|
-
cliPath: opts.cliPath,
|
|
244
|
-
dbPath: opts.dbPath,
|
|
245
|
-
service: opts.service,
|
|
246
|
-
region: opts.region,
|
|
247
|
-
authDir: opts.authDir,
|
|
248
|
-
httpUrl: opts.httpUrl,
|
|
249
|
-
httpHost: opts.httpHost,
|
|
250
|
-
httpPort: opts.httpPort,
|
|
251
|
-
webhookPath: opts.webhookPath,
|
|
252
|
-
webhookUrl: opts.webhookUrl,
|
|
253
|
-
audienceType: opts.audienceType,
|
|
254
|
-
audience: opts.audience,
|
|
255
|
-
homeserver: opts.homeserver,
|
|
256
|
-
userId: opts.userId,
|
|
257
|
-
accessToken: opts.accessToken,
|
|
258
|
-
password: opts.password,
|
|
259
|
-
deviceName: opts.deviceName,
|
|
260
|
-
initialSyncLimit,
|
|
261
|
-
useEnv,
|
|
262
|
-
ship: opts.ship,
|
|
263
|
-
url: opts.url,
|
|
264
|
-
code: opts.code,
|
|
265
|
-
groupChannels,
|
|
266
|
-
dmAllowlist,
|
|
267
|
-
autoDiscoverChannels: opts.autoDiscoverChannels
|
|
268
|
-
};
|
|
269
|
-
const validationError = plugin.setup.validateInput?.({
|
|
270
|
-
cfg: nextConfig,
|
|
271
|
-
accountId,
|
|
272
|
-
input
|
|
273
|
-
});
|
|
274
|
-
if (validationError) {
|
|
275
|
-
runtime.error(validationError);
|
|
276
|
-
runtime.exit(1);
|
|
277
|
-
return;
|
|
278
|
-
}
|
|
279
|
-
nextConfig = applyChannelAccountConfig({
|
|
280
|
-
cfg: nextConfig,
|
|
281
|
-
channel,
|
|
282
|
-
accountId,
|
|
283
|
-
input
|
|
284
|
-
});
|
|
285
|
-
await writeConfigFile(nextConfig);
|
|
286
|
-
runtime.log(`Added ${channelLabel(channel)} account "${accountId}".`);
|
|
287
|
-
}
|
|
288
|
-
|
|
289
|
-
//#endregion
|
|
290
|
-
//#region src/slack/scopes.ts
|
|
291
|
-
async function fetchSlackScopes(..._args) {
|
|
292
|
-
return {
|
|
293
|
-
scopes: [],
|
|
294
|
-
missing: []
|
|
295
|
-
};
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
//#endregion
|
|
299
|
-
//#region src/commands/channels/capabilities.ts
|
|
300
|
-
const REQUIRED_DISCORD_PERMISSIONS = ["ViewChannel", "SendMessages"];
|
|
301
|
-
const TEAMS_GRAPH_PERMISSION_HINTS = {
|
|
302
|
-
"ChannelMessage.Read.All": "channel history",
|
|
303
|
-
"Chat.Read.All": "chat history",
|
|
304
|
-
"Channel.ReadBasic.All": "channel list",
|
|
305
|
-
"Team.ReadBasic.All": "team list",
|
|
306
|
-
"TeamsActivity.Read.All": "teams activity",
|
|
307
|
-
"Sites.Read.All": "files (SharePoint)",
|
|
308
|
-
"Files.Read.All": "files (OneDrive)"
|
|
309
|
-
};
|
|
310
|
-
function normalizeTimeout(raw, fallback = 1e4) {
|
|
311
|
-
const value = typeof raw === "string" ? Number(raw) : Number(raw);
|
|
312
|
-
if (!Number.isFinite(value) || value <= 0) return fallback;
|
|
313
|
-
return value;
|
|
314
|
-
}
|
|
315
|
-
function formatSupport(capabilities) {
|
|
316
|
-
if (!capabilities) return "unknown";
|
|
317
|
-
const bits = [];
|
|
318
|
-
if (capabilities.chatTypes?.length) bits.push(`chatTypes=${capabilities.chatTypes.join(",")}`);
|
|
319
|
-
if (capabilities.polls) bits.push("polls");
|
|
320
|
-
if (capabilities.reactions) bits.push("reactions");
|
|
321
|
-
if (capabilities.edit) bits.push("edit");
|
|
322
|
-
if (capabilities.unsend) bits.push("unsend");
|
|
323
|
-
if (capabilities.reply) bits.push("reply");
|
|
324
|
-
if (capabilities.effects) bits.push("effects");
|
|
325
|
-
if (capabilities.groupManagement) bits.push("groupManagement");
|
|
326
|
-
if (capabilities.threads) bits.push("threads");
|
|
327
|
-
if (capabilities.media) bits.push("media");
|
|
328
|
-
if (capabilities.nativeCommands) bits.push("nativeCommands");
|
|
329
|
-
if (capabilities.blockStreaming) bits.push("blockStreaming");
|
|
330
|
-
return bits.length ? bits.join(" ") : "none";
|
|
331
|
-
}
|
|
332
|
-
function summarizeDiscordTarget(raw) {
|
|
333
|
-
if (!raw) return;
|
|
334
|
-
const target = parseDiscordTarget(raw, { defaultKind: "channel" });
|
|
335
|
-
if (!target) return { raw };
|
|
336
|
-
if (target.kind === "channel") return {
|
|
337
|
-
raw,
|
|
338
|
-
normalized: target.normalized,
|
|
339
|
-
kind: "channel",
|
|
340
|
-
channelId: target.id
|
|
341
|
-
};
|
|
342
|
-
if (target.kind === "user") return {
|
|
343
|
-
raw,
|
|
344
|
-
normalized: target.normalized,
|
|
345
|
-
kind: "user"
|
|
346
|
-
};
|
|
347
|
-
return {
|
|
348
|
-
raw,
|
|
349
|
-
normalized: target.normalized
|
|
350
|
-
};
|
|
351
|
-
}
|
|
352
|
-
function formatDiscordIntents(intents) {
|
|
353
|
-
if (!intents) return "unknown";
|
|
354
|
-
return [
|
|
355
|
-
`messageContent=${intents.messageContent ?? "unknown"}`,
|
|
356
|
-
`guildMembers=${intents.guildMembers ?? "unknown"}`,
|
|
357
|
-
`presence=${intents.presence ?? "unknown"}`
|
|
358
|
-
].join(" ");
|
|
359
|
-
}
|
|
360
|
-
function formatProbeLines(channelId, probe) {
|
|
361
|
-
const lines = [];
|
|
362
|
-
if (!probe || typeof probe !== "object") return lines;
|
|
363
|
-
const probeObj = probe;
|
|
364
|
-
if (channelId === "discord") {
|
|
365
|
-
const bot = probeObj.bot;
|
|
366
|
-
if (bot?.username) {
|
|
367
|
-
const botId = bot.id ? ` (${bot.id})` : "";
|
|
368
|
-
lines.push(`Bot: ${theme.accent(`@${bot.username}`)}${botId}`);
|
|
369
|
-
}
|
|
370
|
-
const app = probeObj.application;
|
|
371
|
-
if (app?.intents) lines.push(`Intents: ${formatDiscordIntents(app.intents)}`);
|
|
372
|
-
}
|
|
373
|
-
if (channelId === "telegram") {
|
|
374
|
-
const bot = probeObj.bot;
|
|
375
|
-
if (bot?.username) {
|
|
376
|
-
const botId = bot.id ? ` (${bot.id})` : "";
|
|
377
|
-
lines.push(`Bot: ${theme.accent(`@${bot.username}`)}${botId}`);
|
|
378
|
-
}
|
|
379
|
-
const flags = [];
|
|
380
|
-
const canJoinGroups = bot?.canJoinGroups;
|
|
381
|
-
const canReadAll = bot?.canReadAllGroupMessages;
|
|
382
|
-
const inlineQueries = bot?.supportsInlineQueries;
|
|
383
|
-
if (typeof canJoinGroups === "boolean") flags.push(`joinGroups=${canJoinGroups}`);
|
|
384
|
-
if (typeof canReadAll === "boolean") flags.push(`readAllGroupMessages=${canReadAll}`);
|
|
385
|
-
if (typeof inlineQueries === "boolean") flags.push(`inlineQueries=${inlineQueries}`);
|
|
386
|
-
if (flags.length > 0) lines.push(`Flags: ${flags.join(" ")}`);
|
|
387
|
-
const webhook = probeObj.webhook;
|
|
388
|
-
if (webhook?.url !== void 0) lines.push(`Webhook: ${webhook.url || "none"}`);
|
|
389
|
-
}
|
|
390
|
-
if (channelId === "slack") {
|
|
391
|
-
const bot = probeObj.bot;
|
|
392
|
-
const team = probeObj.team;
|
|
393
|
-
if (bot?.name) lines.push(`Bot: ${theme.accent(`@${bot.name}`)}`);
|
|
394
|
-
if (team?.name || team?.id) {
|
|
395
|
-
const id = team?.id ? ` (${team.id})` : "";
|
|
396
|
-
lines.push(`Team: ${team?.name ?? "unknown"}${id}`);
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
if (channelId === "signal") {
|
|
400
|
-
const version = probeObj.version;
|
|
401
|
-
if (version) lines.push(`Signal daemon: ${version}`);
|
|
402
|
-
}
|
|
403
|
-
if (channelId === "msteams") {
|
|
404
|
-
const appId = typeof probeObj.appId === "string" ? probeObj.appId.trim() : "";
|
|
405
|
-
if (appId) lines.push(`App: ${theme.accent(appId)}`);
|
|
406
|
-
const graph = probeObj.graph;
|
|
407
|
-
if (graph) {
|
|
408
|
-
const roles = Array.isArray(graph.roles) ? graph.roles.map((role) => String(role).trim()).filter(Boolean) : [];
|
|
409
|
-
const scopes = typeof graph.scopes === "string" ? graph.scopes.split(/\s+/).map((scope) => scope.trim()).filter(Boolean) : Array.isArray(graph.scopes) ? graph.scopes.map((scope) => String(scope).trim()).filter(Boolean) : [];
|
|
410
|
-
if (graph.ok === false) lines.push(`Graph: ${theme.error(graph.error ?? "failed")}`);
|
|
411
|
-
else if (roles.length > 0 || scopes.length > 0) {
|
|
412
|
-
const formatPermission = (permission) => {
|
|
413
|
-
const hint = TEAMS_GRAPH_PERMISSION_HINTS[permission];
|
|
414
|
-
return hint ? `${permission} (${hint})` : permission;
|
|
415
|
-
};
|
|
416
|
-
if (roles.length > 0) lines.push(`Graph roles: ${roles.map(formatPermission).join(", ")}`);
|
|
417
|
-
if (scopes.length > 0) lines.push(`Graph scopes: ${scopes.map(formatPermission).join(", ")}`);
|
|
418
|
-
} else if (graph.ok === true) lines.push("Graph: ok");
|
|
419
|
-
}
|
|
420
|
-
}
|
|
421
|
-
const ok = typeof probeObj.ok === "boolean" ? probeObj.ok : void 0;
|
|
422
|
-
if (ok === true && lines.length === 0) lines.push("Probe: ok");
|
|
423
|
-
if (ok === false) {
|
|
424
|
-
const error = typeof probeObj.error === "string" && probeObj.error ? ` (${probeObj.error})` : "";
|
|
425
|
-
lines.push(`Probe: ${theme.error(`failed${error}`)}`);
|
|
426
|
-
}
|
|
427
|
-
return lines;
|
|
428
|
-
}
|
|
429
|
-
async function buildDiscordPermissions(params) {
|
|
430
|
-
const target = summarizeDiscordTarget(params.target?.trim());
|
|
431
|
-
if (!target) return {};
|
|
432
|
-
if (target.kind !== "channel" || !target.channelId) return {
|
|
433
|
-
target,
|
|
434
|
-
report: { error: "Target looks like a DM user; pass channel:<id> to audit channel permissions." }
|
|
435
|
-
};
|
|
436
|
-
const token = params.account.token?.trim();
|
|
437
|
-
if (!token) return {
|
|
438
|
-
target,
|
|
439
|
-
report: {
|
|
440
|
-
channelId: target.channelId,
|
|
441
|
-
error: "Discord bot token missing for permission audit."
|
|
442
|
-
}
|
|
443
|
-
};
|
|
444
|
-
try {
|
|
445
|
-
const perms = await fetchChannelPermissionsDiscord(target.channelId, {
|
|
446
|
-
token,
|
|
447
|
-
accountId: params.account.accountId ?? void 0
|
|
448
|
-
});
|
|
449
|
-
const missing = REQUIRED_DISCORD_PERMISSIONS.filter((permission) => !perms.permissions.includes(permission));
|
|
450
|
-
return {
|
|
451
|
-
target,
|
|
452
|
-
report: {
|
|
453
|
-
channelId: perms.channelId,
|
|
454
|
-
guildId: perms.guildId,
|
|
455
|
-
isDm: perms.isDm,
|
|
456
|
-
channelType: perms.channelType,
|
|
457
|
-
permissions: perms.permissions,
|
|
458
|
-
missingRequired: missing.length ? missing : [],
|
|
459
|
-
raw: perms.raw
|
|
460
|
-
}
|
|
461
|
-
};
|
|
462
|
-
} catch (err) {
|
|
463
|
-
return {
|
|
464
|
-
target,
|
|
465
|
-
report: {
|
|
466
|
-
channelId: target.channelId,
|
|
467
|
-
error: err instanceof Error ? err.message : String(err)
|
|
468
|
-
}
|
|
469
|
-
};
|
|
470
|
-
}
|
|
471
|
-
}
|
|
472
|
-
async function resolveChannelReports(params) {
|
|
473
|
-
const { plugin, cfg, timeoutMs } = params;
|
|
474
|
-
const accountIds = params.accountOverride ? [params.accountOverride] : (() => {
|
|
475
|
-
const ids = plugin.config.listAccountIds(cfg);
|
|
476
|
-
return ids.length > 0 ? ids : [resolveChannelDefaultAccountId({
|
|
477
|
-
plugin,
|
|
478
|
-
cfg,
|
|
479
|
-
accountIds: ids
|
|
480
|
-
})];
|
|
481
|
-
})();
|
|
482
|
-
const reports = [];
|
|
483
|
-
const listedActions = plugin.actions?.listActions?.({ cfg }) ?? [];
|
|
484
|
-
const actions = Array.from(new Set([
|
|
485
|
-
"send",
|
|
486
|
-
"broadcast",
|
|
487
|
-
...listedActions.map((action) => String(action))
|
|
488
|
-
]));
|
|
489
|
-
for (const accountId of accountIds) {
|
|
490
|
-
const resolvedAccount = plugin.config.resolveAccount(cfg, accountId);
|
|
491
|
-
const configured = plugin.config.isConfigured ? await plugin.config.isConfigured(resolvedAccount, cfg) : Boolean(resolvedAccount);
|
|
492
|
-
const enabled = plugin.config.isEnabled ? plugin.config.isEnabled(resolvedAccount, cfg) : resolvedAccount.enabled !== false;
|
|
493
|
-
let probe;
|
|
494
|
-
if (configured && enabled && plugin.status?.probeAccount) try {
|
|
495
|
-
probe = await plugin.status.probeAccount({
|
|
496
|
-
account: resolvedAccount,
|
|
497
|
-
timeoutMs,
|
|
498
|
-
cfg
|
|
499
|
-
});
|
|
500
|
-
} catch (err) {
|
|
501
|
-
probe = {
|
|
502
|
-
ok: false,
|
|
503
|
-
error: err instanceof Error ? err.message : String(err)
|
|
504
|
-
};
|
|
505
|
-
}
|
|
506
|
-
let slackScopes;
|
|
507
|
-
if (plugin.id === "slack" && configured && enabled) {
|
|
508
|
-
const botToken = resolvedAccount.botToken?.trim();
|
|
509
|
-
const userToken = resolvedAccount.config?.userToken?.trim();
|
|
510
|
-
const scopeReports = [];
|
|
511
|
-
if (botToken) scopeReports.push({
|
|
512
|
-
tokenType: "bot",
|
|
513
|
-
result: await fetchSlackScopes(botToken, timeoutMs)
|
|
514
|
-
});
|
|
515
|
-
else scopeReports.push({
|
|
516
|
-
tokenType: "bot",
|
|
517
|
-
result: {
|
|
518
|
-
ok: false,
|
|
519
|
-
error: "Slack bot token missing."
|
|
520
|
-
}
|
|
521
|
-
});
|
|
522
|
-
if (userToken) scopeReports.push({
|
|
523
|
-
tokenType: "user",
|
|
524
|
-
result: await fetchSlackScopes(userToken, timeoutMs)
|
|
525
|
-
});
|
|
526
|
-
slackScopes = scopeReports;
|
|
527
|
-
}
|
|
528
|
-
let discordTarget;
|
|
529
|
-
let discordPermissions;
|
|
530
|
-
if (plugin.id === "discord" && params.target) {
|
|
531
|
-
const perms = await buildDiscordPermissions({
|
|
532
|
-
account: resolvedAccount,
|
|
533
|
-
target: params.target
|
|
534
|
-
});
|
|
535
|
-
discordTarget = perms.target;
|
|
536
|
-
discordPermissions = perms.report;
|
|
537
|
-
}
|
|
538
|
-
reports.push({
|
|
539
|
-
channel: plugin.id,
|
|
540
|
-
accountId,
|
|
541
|
-
accountName: typeof resolvedAccount.name === "string" ? resolvedAccount.name?.trim() || void 0 : void 0,
|
|
542
|
-
configured,
|
|
543
|
-
enabled,
|
|
544
|
-
support: plugin.capabilities,
|
|
545
|
-
probe,
|
|
546
|
-
target: discordTarget,
|
|
547
|
-
channelPermissions: discordPermissions,
|
|
548
|
-
actions,
|
|
549
|
-
slackScopes
|
|
550
|
-
});
|
|
551
|
-
}
|
|
552
|
-
return reports;
|
|
553
|
-
}
|
|
554
|
-
async function channelsCapabilitiesCommand(opts, runtime = defaultRuntime) {
|
|
555
|
-
const cfg = await requireValidConfig(runtime);
|
|
556
|
-
if (!cfg) return;
|
|
557
|
-
const timeoutMs = normalizeTimeout(opts.timeout, 1e4);
|
|
558
|
-
const rawChannel = typeof opts.channel === "string" ? opts.channel.trim().toLowerCase() : "";
|
|
559
|
-
const rawTarget = typeof opts.target === "string" ? opts.target.trim() : "";
|
|
560
|
-
if (opts.account && (!rawChannel || rawChannel === "all")) {
|
|
561
|
-
runtime.error(danger("--account requires a specific --channel."));
|
|
562
|
-
runtime.exit(1);
|
|
563
|
-
return;
|
|
564
|
-
}
|
|
565
|
-
if (rawTarget && rawChannel !== "discord") {
|
|
566
|
-
runtime.error(danger("--target requires --channel discord."));
|
|
567
|
-
runtime.exit(1);
|
|
568
|
-
return;
|
|
569
|
-
}
|
|
570
|
-
const plugins = listChannelPlugins();
|
|
571
|
-
const selected = !rawChannel || rawChannel === "all" ? plugins : (() => {
|
|
572
|
-
const plugin = getChannelPlugin(rawChannel);
|
|
573
|
-
if (!plugin) return null;
|
|
574
|
-
return [plugin];
|
|
575
|
-
})();
|
|
576
|
-
if (!selected || selected.length === 0) {
|
|
577
|
-
runtime.error(danger(`Unknown channel "${rawChannel}".`));
|
|
578
|
-
runtime.exit(1);
|
|
579
|
-
return;
|
|
580
|
-
}
|
|
581
|
-
const reports = [];
|
|
582
|
-
for (const plugin of selected) {
|
|
583
|
-
const accountOverride = opts.account?.trim() || void 0;
|
|
584
|
-
reports.push(...await resolveChannelReports({
|
|
585
|
-
plugin,
|
|
586
|
-
cfg,
|
|
587
|
-
timeoutMs,
|
|
588
|
-
accountOverride,
|
|
589
|
-
target: rawTarget && plugin.id === "discord" ? rawTarget : void 0
|
|
590
|
-
}));
|
|
591
|
-
}
|
|
592
|
-
if (opts.json) {
|
|
593
|
-
runtime.log(JSON.stringify({ channels: reports }, null, 2));
|
|
594
|
-
return;
|
|
595
|
-
}
|
|
596
|
-
const lines = [];
|
|
597
|
-
for (const report of reports) {
|
|
598
|
-
const label = formatChannelAccountLabel({
|
|
599
|
-
channel: report.channel,
|
|
600
|
-
accountId: report.accountId,
|
|
601
|
-
name: report.accountName,
|
|
602
|
-
channelStyle: theme.accent,
|
|
603
|
-
accountStyle: theme.heading
|
|
604
|
-
});
|
|
605
|
-
lines.push(theme.heading(label));
|
|
606
|
-
lines.push(`Support: ${formatSupport(report.support)}`);
|
|
607
|
-
if (report.actions && report.actions.length > 0) lines.push(`Actions: ${report.actions.join(", ")}`);
|
|
608
|
-
if (report.configured === false || report.enabled === false) {
|
|
609
|
-
const configuredLabel = report.configured === false ? "not configured" : "configured";
|
|
610
|
-
const enabledLabel = report.enabled === false ? "disabled" : "enabled";
|
|
611
|
-
lines.push(`Status: ${configuredLabel}, ${enabledLabel}`);
|
|
612
|
-
}
|
|
613
|
-
const probeLines = formatProbeLines(report.channel, report.probe);
|
|
614
|
-
if (probeLines.length > 0) lines.push(...probeLines);
|
|
615
|
-
else if (report.configured && report.enabled) lines.push(theme.muted("Probe: unavailable"));
|
|
616
|
-
if (report.channel === "slack" && report.slackScopes) for (const entry of report.slackScopes) {
|
|
617
|
-
const source = entry.result.source ? ` (${entry.result.source})` : "";
|
|
618
|
-
const label = entry.tokenType === "user" ? "User scopes" : "Bot scopes";
|
|
619
|
-
if (entry.result.ok && entry.result.scopes?.length) lines.push(`${label}${source}: ${entry.result.scopes.join(", ")}`);
|
|
620
|
-
else if (entry.result.error) lines.push(`${label}: ${theme.error(entry.result.error)}`);
|
|
621
|
-
}
|
|
622
|
-
if (report.channel === "discord" && report.channelPermissions) {
|
|
623
|
-
const perms = report.channelPermissions;
|
|
624
|
-
if (perms.error) lines.push(`Permissions: ${theme.error(perms.error)}`);
|
|
625
|
-
else {
|
|
626
|
-
const list = perms.permissions?.length ? perms.permissions.join(", ") : "none";
|
|
627
|
-
const label = perms.channelId ? ` (${perms.channelId})` : "";
|
|
628
|
-
lines.push(`Permissions${label}: ${list}`);
|
|
629
|
-
if (perms.missingRequired && perms.missingRequired.length > 0) lines.push(`${theme.warn("Missing required:")} ${perms.missingRequired.join(", ")}`);
|
|
630
|
-
else lines.push(theme.success("Missing required: none"));
|
|
631
|
-
}
|
|
632
|
-
} else if (report.channel === "discord" && rawTarget && !report.channelPermissions) lines.push(theme.muted("Permissions: skipped (no target)."));
|
|
633
|
-
lines.push("");
|
|
634
|
-
}
|
|
635
|
-
runtime.log(lines.join("\n").trimEnd());
|
|
636
|
-
}
|
|
637
|
-
|
|
638
|
-
//#endregion
|
|
639
|
-
//#region src/commands/channels/list.ts
|
|
640
|
-
const colorValue = (value) => {
|
|
641
|
-
if (value === "none") return theme.error(value);
|
|
642
|
-
if (value === "env") return theme.accent(value);
|
|
643
|
-
return theme.success(value);
|
|
644
|
-
};
|
|
645
|
-
function formatEnabled(value) {
|
|
646
|
-
return value === false ? theme.error("disabled") : theme.success("enabled");
|
|
647
|
-
}
|
|
648
|
-
function formatConfigured(value) {
|
|
649
|
-
return value ? theme.success("configured") : theme.warn("not configured");
|
|
650
|
-
}
|
|
651
|
-
function formatTokenSource(source) {
|
|
652
|
-
return `token=${colorValue(source || "none")}`;
|
|
653
|
-
}
|
|
654
|
-
function formatSource(label, source) {
|
|
655
|
-
return `${label}=${colorValue(source || "none")}`;
|
|
656
|
-
}
|
|
657
|
-
function formatLinked(value) {
|
|
658
|
-
return value ? theme.success("linked") : theme.warn("not linked");
|
|
659
|
-
}
|
|
660
|
-
function shouldShowConfigured(channel) {
|
|
661
|
-
return channel.meta.showConfigured !== false;
|
|
662
|
-
}
|
|
663
|
-
function formatAccountLine(params) {
|
|
664
|
-
const { channel, snapshot } = params;
|
|
665
|
-
const label = formatChannelAccountLabel({
|
|
666
|
-
channel: channel.id,
|
|
667
|
-
accountId: snapshot.accountId,
|
|
668
|
-
name: snapshot.name,
|
|
669
|
-
channelStyle: theme.accent,
|
|
670
|
-
accountStyle: theme.heading
|
|
671
|
-
});
|
|
672
|
-
const bits = [];
|
|
673
|
-
if (snapshot.linked !== void 0) bits.push(formatLinked(snapshot.linked));
|
|
674
|
-
if (shouldShowConfigured(channel) && typeof snapshot.configured === "boolean") bits.push(formatConfigured(snapshot.configured));
|
|
675
|
-
if (snapshot.tokenSource) bits.push(formatTokenSource(snapshot.tokenSource));
|
|
676
|
-
if (snapshot.botTokenSource) bits.push(formatSource("bot", snapshot.botTokenSource));
|
|
677
|
-
if (snapshot.appTokenSource) bits.push(formatSource("app", snapshot.appTokenSource));
|
|
678
|
-
if (snapshot.baseUrl) bits.push(`base=${theme.muted(snapshot.baseUrl)}`);
|
|
679
|
-
if (typeof snapshot.enabled === "boolean") bits.push(formatEnabled(snapshot.enabled));
|
|
680
|
-
return `- ${label}: ${bits.join(", ")}`;
|
|
681
|
-
}
|
|
682
|
-
async function loadUsageWithProgress(runtime) {
|
|
683
|
-
try {
|
|
684
|
-
return await withProgress({
|
|
685
|
-
label: "Fetching usage snapshot…",
|
|
686
|
-
indeterminate: true,
|
|
687
|
-
enabled: true
|
|
688
|
-
}, async () => await loadProviderUsageSummary());
|
|
689
|
-
} catch (err) {
|
|
690
|
-
runtime.error(String(err));
|
|
691
|
-
return null;
|
|
692
|
-
}
|
|
693
|
-
}
|
|
694
|
-
async function channelsListCommand(opts, runtime = defaultRuntime) {
|
|
695
|
-
const cfg = await requireValidConfig(runtime);
|
|
696
|
-
if (!cfg) return;
|
|
697
|
-
const includeUsage = opts.usage !== false;
|
|
698
|
-
const plugins = listChannelPlugins();
|
|
699
|
-
const authStore = loadAuthProfileStore();
|
|
700
|
-
const authProfiles = Object.entries(authStore.profiles).map(([profileId, profile]) => ({
|
|
701
|
-
id: profileId,
|
|
702
|
-
provider: profile.provider,
|
|
703
|
-
type: profile.type,
|
|
704
|
-
isExternal: false
|
|
705
|
-
}));
|
|
706
|
-
if (opts.json) {
|
|
707
|
-
const usage = includeUsage ? await loadProviderUsageSummary() : void 0;
|
|
708
|
-
const chat = {};
|
|
709
|
-
for (const plugin of plugins) chat[plugin.id] = plugin.config.listAccountIds(cfg);
|
|
710
|
-
const payload = {
|
|
711
|
-
chat,
|
|
712
|
-
auth: authProfiles,
|
|
713
|
-
...usage ? { usage } : {}
|
|
714
|
-
};
|
|
715
|
-
runtime.log(JSON.stringify(payload, null, 2));
|
|
716
|
-
return;
|
|
717
|
-
}
|
|
718
|
-
const lines = [];
|
|
719
|
-
lines.push(theme.heading("Chat channels:"));
|
|
720
|
-
for (const plugin of plugins) {
|
|
721
|
-
const accounts = plugin.config.listAccountIds(cfg);
|
|
722
|
-
if (!accounts || accounts.length === 0) continue;
|
|
723
|
-
for (const accountId of accounts) {
|
|
724
|
-
const snapshot = await buildChannelAccountSnapshot({
|
|
725
|
-
plugin,
|
|
726
|
-
cfg,
|
|
727
|
-
accountId
|
|
728
|
-
});
|
|
729
|
-
lines.push(formatAccountLine({
|
|
730
|
-
channel: plugin,
|
|
731
|
-
snapshot
|
|
732
|
-
}));
|
|
733
|
-
}
|
|
734
|
-
}
|
|
735
|
-
lines.push("");
|
|
736
|
-
lines.push(theme.heading("Auth providers (OAuth + API keys):"));
|
|
737
|
-
if (authProfiles.length === 0) lines.push(theme.muted("- none"));
|
|
738
|
-
else for (const profile of authProfiles) {
|
|
739
|
-
const external = profile.isExternal ? theme.muted(" (synced)") : "";
|
|
740
|
-
lines.push(`- ${theme.accent(profile.id)} (${theme.success(profile.type)}${external})`);
|
|
741
|
-
}
|
|
742
|
-
runtime.log(lines.join("\n"));
|
|
743
|
-
if (includeUsage) {
|
|
744
|
-
runtime.log("");
|
|
745
|
-
const usage = await loadUsageWithProgress(runtime);
|
|
746
|
-
if (usage) {
|
|
747
|
-
const usageLines = formatUsageReportLines(usage);
|
|
748
|
-
if (usageLines.length > 0) {
|
|
749
|
-
usageLines[0] = theme.accent(usageLines[0]);
|
|
750
|
-
runtime.log(usageLines.join("\n"));
|
|
751
|
-
}
|
|
752
|
-
}
|
|
753
|
-
}
|
|
754
|
-
runtime.log("");
|
|
755
|
-
runtime.log(`Docs: ${formatDocsLink("/gateway/configuration", "gateway/configuration")}`);
|
|
756
|
-
}
|
|
757
|
-
|
|
758
|
-
//#endregion
|
|
759
|
-
//#region src/commands/channels/logs.ts
|
|
760
|
-
const DEFAULT_LIMIT = 200;
|
|
761
|
-
const MAX_BYTES = 1e6;
|
|
762
|
-
const getChannelSet = () => new Set([...listChannelPlugins().map((plugin) => plugin.id), "all"]);
|
|
763
|
-
function parseChannelFilter(raw) {
|
|
764
|
-
const trimmed = raw?.trim().toLowerCase();
|
|
765
|
-
if (!trimmed) return "all";
|
|
766
|
-
return getChannelSet().has(trimmed) ? trimmed : "all";
|
|
767
|
-
}
|
|
768
|
-
function matchesChannel(line, channel) {
|
|
769
|
-
if (channel === "all") return true;
|
|
770
|
-
const needle = `gateway/channels/${channel}`;
|
|
771
|
-
if (line.subsystem?.includes(needle)) return true;
|
|
772
|
-
if (line.module?.includes(channel)) return true;
|
|
773
|
-
return false;
|
|
774
|
-
}
|
|
775
|
-
async function readTailLines(file, limit) {
|
|
776
|
-
const stat = await fs.stat(file).catch(() => null);
|
|
777
|
-
if (!stat) return [];
|
|
778
|
-
const size = stat.size;
|
|
779
|
-
const start = Math.max(0, size - MAX_BYTES);
|
|
780
|
-
const handle = await fs.open(file, "r");
|
|
781
|
-
try {
|
|
782
|
-
const length = Math.max(0, size - start);
|
|
783
|
-
if (length === 0) return [];
|
|
784
|
-
const buffer = Buffer.alloc(length);
|
|
785
|
-
const readResult = await handle.read(buffer, 0, length, start);
|
|
786
|
-
let lines = buffer.toString("utf8", 0, readResult.bytesRead).split("\n");
|
|
787
|
-
if (start > 0) lines = lines.slice(1);
|
|
788
|
-
if (lines.length && lines[lines.length - 1] === "") lines = lines.slice(0, -1);
|
|
789
|
-
if (lines.length > limit) lines = lines.slice(lines.length - limit);
|
|
790
|
-
return lines;
|
|
791
|
-
} finally {
|
|
792
|
-
await handle.close();
|
|
793
|
-
}
|
|
794
|
-
}
|
|
795
|
-
async function channelsLogsCommand(opts, runtime = defaultRuntime) {
|
|
796
|
-
const channel = parseChannelFilter(opts.channel);
|
|
797
|
-
const limitRaw = typeof opts.lines === "string" ? Number(opts.lines) : opts.lines;
|
|
798
|
-
const limit = typeof limitRaw === "number" && Number.isFinite(limitRaw) && limitRaw > 0 ? Math.floor(limitRaw) : DEFAULT_LIMIT;
|
|
799
|
-
const file = getResolvedLoggerSettings().file;
|
|
800
|
-
const filtered = (await readTailLines(file, limit * 4)).map(parseLogLine).filter((line) => Boolean(line)).filter((line) => matchesChannel(line, channel));
|
|
801
|
-
const lines = filtered.slice(Math.max(0, filtered.length - limit));
|
|
802
|
-
if (opts.json) {
|
|
803
|
-
runtime.log(JSON.stringify({
|
|
804
|
-
file,
|
|
805
|
-
channel,
|
|
806
|
-
lines
|
|
807
|
-
}, null, 2));
|
|
808
|
-
return;
|
|
809
|
-
}
|
|
810
|
-
runtime.log(theme.info(`Log file: ${file}`));
|
|
811
|
-
if (channel !== "all") runtime.log(theme.info(`Channel: ${channel}`));
|
|
812
|
-
if (lines.length === 0) {
|
|
813
|
-
runtime.log(theme.muted("No matching log lines."));
|
|
814
|
-
return;
|
|
815
|
-
}
|
|
816
|
-
for (const line of lines) {
|
|
817
|
-
const ts = line.time ? `${line.time} ` : "";
|
|
818
|
-
const level = line.level ? `${line.level.toLowerCase()} ` : "";
|
|
819
|
-
runtime.log(`${ts}${level}${line.message}`.trim());
|
|
820
|
-
}
|
|
821
|
-
}
|
|
822
|
-
|
|
823
|
-
//#endregion
|
|
824
|
-
//#region src/commands/channels/remove.ts
|
|
825
|
-
function listAccountIds(cfg, channel) {
|
|
826
|
-
const plugin = getChannelPlugin(channel);
|
|
827
|
-
if (!plugin) return [];
|
|
828
|
-
return plugin.config.listAccountIds(cfg);
|
|
829
|
-
}
|
|
830
|
-
async function channelsRemoveCommand(opts, runtime = defaultRuntime, params) {
|
|
831
|
-
const cfg = await requireValidConfig(runtime);
|
|
832
|
-
if (!cfg) return;
|
|
833
|
-
const useWizard = shouldUseWizard(params);
|
|
834
|
-
const prompter = useWizard ? createClackPrompter() : null;
|
|
835
|
-
let channel = normalizeChannelId(opts.channel);
|
|
836
|
-
let accountId = normalizeAccountId(opts.account);
|
|
837
|
-
const deleteConfig = Boolean(opts.delete);
|
|
838
|
-
if (useWizard && prompter) {
|
|
839
|
-
await prompter.intro("Remove channel account");
|
|
840
|
-
const selectedChannel = await prompter.select({
|
|
841
|
-
message: "Channel",
|
|
842
|
-
options: listChannelPlugins().map((plugin) => ({
|
|
843
|
-
value: plugin.id,
|
|
844
|
-
label: plugin.meta.label
|
|
845
|
-
}))
|
|
846
|
-
});
|
|
847
|
-
channel = selectedChannel;
|
|
848
|
-
accountId = await (async () => {
|
|
849
|
-
const ids = listAccountIds(cfg, selectedChannel);
|
|
850
|
-
return normalizeAccountId(await prompter.select({
|
|
851
|
-
message: "Account",
|
|
852
|
-
options: ids.map((id) => ({
|
|
853
|
-
value: id,
|
|
854
|
-
label: id === DEFAULT_ACCOUNT_ID ? "default (primary)" : id
|
|
855
|
-
})),
|
|
856
|
-
initialValue: ids[0] ?? DEFAULT_ACCOUNT_ID
|
|
857
|
-
}));
|
|
858
|
-
})();
|
|
859
|
-
if (!await prompter.confirm({
|
|
860
|
-
message: `Disable ${channelLabel(selectedChannel)} account "${accountId}"? (keeps config)`,
|
|
861
|
-
initialValue: true
|
|
862
|
-
})) {
|
|
863
|
-
await prompter.outro("Cancelled.");
|
|
864
|
-
return;
|
|
865
|
-
}
|
|
866
|
-
} else {
|
|
867
|
-
if (!channel) {
|
|
868
|
-
runtime.error("Channel is required. Use --channel <name>.");
|
|
869
|
-
runtime.exit(1);
|
|
870
|
-
return;
|
|
871
|
-
}
|
|
872
|
-
if (!deleteConfig) {
|
|
873
|
-
if (!await createClackPrompter().confirm({
|
|
874
|
-
message: `Disable ${channelLabel(channel)} account "${accountId}"? (keeps config)`,
|
|
875
|
-
initialValue: true
|
|
876
|
-
})) return;
|
|
877
|
-
}
|
|
878
|
-
}
|
|
879
|
-
const plugin = getChannelPlugin(channel);
|
|
880
|
-
if (!plugin) {
|
|
881
|
-
runtime.error(`Unknown channel: ${channel}`);
|
|
882
|
-
runtime.exit(1);
|
|
883
|
-
return;
|
|
884
|
-
}
|
|
885
|
-
const resolvedAccountId = normalizeAccountId(accountId) ?? resolveChannelDefaultAccountId({
|
|
886
|
-
plugin,
|
|
887
|
-
cfg
|
|
888
|
-
});
|
|
889
|
-
const accountKey = resolvedAccountId || DEFAULT_ACCOUNT_ID;
|
|
890
|
-
let next = { ...cfg };
|
|
891
|
-
if (deleteConfig) {
|
|
892
|
-
if (!plugin.config.deleteAccount) {
|
|
893
|
-
runtime.error(`Channel ${channel} does not support delete.`);
|
|
894
|
-
runtime.exit(1);
|
|
895
|
-
return;
|
|
896
|
-
}
|
|
897
|
-
next = plugin.config.deleteAccount({
|
|
898
|
-
cfg: next,
|
|
899
|
-
accountId: resolvedAccountId
|
|
900
|
-
});
|
|
901
|
-
} else {
|
|
902
|
-
if (!plugin.config.setAccountEnabled) {
|
|
903
|
-
runtime.error(`Channel ${channel} does not support disable.`);
|
|
904
|
-
runtime.exit(1);
|
|
905
|
-
return;
|
|
906
|
-
}
|
|
907
|
-
next = plugin.config.setAccountEnabled({
|
|
908
|
-
cfg: next,
|
|
909
|
-
accountId: resolvedAccountId,
|
|
910
|
-
enabled: false
|
|
911
|
-
});
|
|
912
|
-
}
|
|
913
|
-
await writeConfigFile(next);
|
|
914
|
-
if (useWizard && prompter) await prompter.outro(deleteConfig ? `Deleted ${channelLabel(channel)} account "${accountKey}".` : `Disabled ${channelLabel(channel)} account "${accountKey}".`);
|
|
915
|
-
else runtime.log(deleteConfig ? `Deleted ${channelLabel(channel)} account "${accountKey}".` : `Disabled ${channelLabel(channel)} account "${accountKey}".`);
|
|
916
|
-
}
|
|
917
|
-
|
|
918
|
-
//#endregion
|
|
919
|
-
//#region src/commands/channels/resolve.ts
|
|
920
|
-
function resolvePreferredKind(kind) {
|
|
921
|
-
if (!kind || kind === "auto") return;
|
|
922
|
-
if (kind === "user") return "user";
|
|
923
|
-
return "group";
|
|
924
|
-
}
|
|
925
|
-
function detectAutoKind(input) {
|
|
926
|
-
const trimmed = input.trim();
|
|
927
|
-
if (!trimmed) return "group";
|
|
928
|
-
if (trimmed.startsWith("@")) return "user";
|
|
929
|
-
if (/^<@!?/.test(trimmed)) return "user";
|
|
930
|
-
if (/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(trimmed)) return "user";
|
|
931
|
-
if (/^(user|discord|slack|matrix|msteams|teams|zalo|zalouser|googlechat|google-chat|gchat):/i.test(trimmed)) return "user";
|
|
932
|
-
return "group";
|
|
933
|
-
}
|
|
934
|
-
function formatResolveResult(result) {
|
|
935
|
-
if (!result.resolved || !result.id) return `${result.input} -> unresolved`;
|
|
936
|
-
const name = result.name ? ` (${result.name})` : "";
|
|
937
|
-
const note = result.note ? ` [${result.note}]` : "";
|
|
938
|
-
return `${result.input} -> ${result.id}${name}${note}`;
|
|
939
|
-
}
|
|
940
|
-
async function channelsResolveCommand(opts, runtime) {
|
|
941
|
-
const cfg = loadConfig();
|
|
942
|
-
const entries = (opts.entries ?? []).map((entry) => entry.trim()).filter(Boolean);
|
|
943
|
-
if (entries.length === 0) throw new Error("At least one entry is required.");
|
|
944
|
-
const selection = await resolveMessageChannelSelection({
|
|
945
|
-
cfg,
|
|
946
|
-
channel: opts.channel ?? null
|
|
947
|
-
});
|
|
948
|
-
const plugin = getChannelPlugin(selection.channel);
|
|
949
|
-
if (!plugin?.resolver?.resolveTargets) throw new Error(`Channel ${selection.channel} does not support resolve.`);
|
|
950
|
-
const preferredKind = resolvePreferredKind(opts.kind);
|
|
951
|
-
let results = [];
|
|
952
|
-
if (preferredKind) results = (await plugin.resolver.resolveTargets({
|
|
953
|
-
cfg,
|
|
954
|
-
accountId: opts.account ?? null,
|
|
955
|
-
inputs: entries,
|
|
956
|
-
kind: preferredKind,
|
|
957
|
-
runtime
|
|
958
|
-
})).map((entry) => ({
|
|
959
|
-
input: entry.input,
|
|
960
|
-
resolved: entry.resolved,
|
|
961
|
-
id: entry.id,
|
|
962
|
-
name: entry.name,
|
|
963
|
-
note: entry.note
|
|
964
|
-
}));
|
|
965
|
-
else {
|
|
966
|
-
const byKind = /* @__PURE__ */ new Map();
|
|
967
|
-
for (const entry of entries) {
|
|
968
|
-
const kind = detectAutoKind(entry);
|
|
969
|
-
byKind.set(kind, [...byKind.get(kind) ?? [], entry]);
|
|
970
|
-
}
|
|
971
|
-
const resolved = [];
|
|
972
|
-
for (const [kind, inputs] of byKind.entries()) {
|
|
973
|
-
const batch = await plugin.resolver.resolveTargets({
|
|
974
|
-
cfg,
|
|
975
|
-
accountId: opts.account ?? null,
|
|
976
|
-
inputs,
|
|
977
|
-
kind,
|
|
978
|
-
runtime
|
|
979
|
-
});
|
|
980
|
-
resolved.push(...batch);
|
|
981
|
-
}
|
|
982
|
-
const byInput = new Map(resolved.map((entry) => [entry.input, entry]));
|
|
983
|
-
results = entries.map((input) => {
|
|
984
|
-
const entry = byInput.get(input);
|
|
985
|
-
return {
|
|
986
|
-
input,
|
|
987
|
-
resolved: entry?.resolved ?? false,
|
|
988
|
-
id: entry?.id,
|
|
989
|
-
name: entry?.name,
|
|
990
|
-
note: entry?.note
|
|
991
|
-
};
|
|
992
|
-
});
|
|
993
|
-
}
|
|
994
|
-
if (opts.json) {
|
|
995
|
-
runtime.log(JSON.stringify(results, null, 2));
|
|
996
|
-
return;
|
|
997
|
-
}
|
|
998
|
-
for (const result of results) if (result.resolved && result.id) runtime.log(formatResolveResult(result));
|
|
999
|
-
else runtime.error(danger(`${result.input} -> unresolved${result.error ? ` (${result.error})` : result.note ? ` (${result.note})` : ""}`));
|
|
1000
|
-
}
|
|
1001
|
-
|
|
1002
|
-
//#endregion
|
|
1003
|
-
//#region src/commands/channels/status.ts
|
|
1004
|
-
function formatGatewayChannelsStatusLines(payload) {
|
|
1005
|
-
const lines = [];
|
|
1006
|
-
lines.push(theme.success("Gateway reachable."));
|
|
1007
|
-
const accountLines = (provider, accounts) => accounts.map((account) => {
|
|
1008
|
-
const bits = [];
|
|
1009
|
-
if (typeof account.enabled === "boolean") bits.push(account.enabled ? "enabled" : "disabled");
|
|
1010
|
-
if (typeof account.configured === "boolean") bits.push(account.configured ? "configured" : "not configured");
|
|
1011
|
-
if (typeof account.linked === "boolean") bits.push(account.linked ? "linked" : "not linked");
|
|
1012
|
-
if (typeof account.running === "boolean") bits.push(account.running ? "running" : "stopped");
|
|
1013
|
-
if (typeof account.connected === "boolean") bits.push(account.connected ? "connected" : "disconnected");
|
|
1014
|
-
const inboundAt = typeof account.lastInboundAt === "number" && Number.isFinite(account.lastInboundAt) ? account.lastInboundAt : null;
|
|
1015
|
-
const outboundAt = typeof account.lastOutboundAt === "number" && Number.isFinite(account.lastOutboundAt) ? account.lastOutboundAt : null;
|
|
1016
|
-
if (inboundAt) bits.push(`in:${formatTimeAgo(Date.now() - inboundAt)}`);
|
|
1017
|
-
if (outboundAt) bits.push(`out:${formatTimeAgo(Date.now() - outboundAt)}`);
|
|
1018
|
-
if (typeof account.mode === "string" && account.mode.length > 0) bits.push(`mode:${account.mode}`);
|
|
1019
|
-
const botUsername = (() => {
|
|
1020
|
-
const bot = account.bot;
|
|
1021
|
-
const probeBot = account.probe?.bot;
|
|
1022
|
-
const raw = bot?.username ?? probeBot?.username ?? "";
|
|
1023
|
-
if (typeof raw !== "string") return "";
|
|
1024
|
-
const trimmed = raw.trim();
|
|
1025
|
-
if (!trimmed) return "";
|
|
1026
|
-
return trimmed.startsWith("@") ? trimmed : `@${trimmed}`;
|
|
1027
|
-
})();
|
|
1028
|
-
if (botUsername) bits.push(`bot:${botUsername}`);
|
|
1029
|
-
if (typeof account.dmPolicy === "string" && account.dmPolicy.length > 0) bits.push(`dm:${account.dmPolicy}`);
|
|
1030
|
-
if (Array.isArray(account.allowFrom) && account.allowFrom.length > 0) bits.push(`allow:${account.allowFrom.slice(0, 2).join(",")}`);
|
|
1031
|
-
if (typeof account.tokenSource === "string" && account.tokenSource) bits.push(`token:${account.tokenSource}`);
|
|
1032
|
-
if (typeof account.botTokenSource === "string" && account.botTokenSource) bits.push(`bot:${account.botTokenSource}`);
|
|
1033
|
-
if (typeof account.appTokenSource === "string" && account.appTokenSource) bits.push(`app:${account.appTokenSource}`);
|
|
1034
|
-
const messageContent = account.application?.intents?.messageContent;
|
|
1035
|
-
if (typeof messageContent === "string" && messageContent.length > 0 && messageContent !== "enabled") bits.push(`intents:content=${messageContent}`);
|
|
1036
|
-
if (account.allowUnmentionedGroups === true) bits.push("groups:unmentioned");
|
|
1037
|
-
if (typeof account.baseUrl === "string" && account.baseUrl) bits.push(`url:${account.baseUrl}`);
|
|
1038
|
-
const probe = account.probe;
|
|
1039
|
-
if (probe && typeof probe.ok === "boolean") bits.push(probe.ok ? "works" : "probe failed");
|
|
1040
|
-
const audit = account.audit;
|
|
1041
|
-
if (audit && typeof audit.ok === "boolean") bits.push(audit.ok ? "audit ok" : "audit failed");
|
|
1042
|
-
if (typeof account.lastError === "string" && account.lastError) bits.push(`error:${account.lastError}`);
|
|
1043
|
-
return `- ${formatChannelAccountLabel({
|
|
1044
|
-
channel: provider,
|
|
1045
|
-
accountId: typeof account.accountId === "string" ? account.accountId : "default",
|
|
1046
|
-
name: (typeof account.name === "string" ? account.name.trim() : "") || void 0
|
|
1047
|
-
})}: ${bits.join(", ")}`;
|
|
1048
|
-
});
|
|
1049
|
-
const plugins = listChannelPlugins();
|
|
1050
|
-
const accountsByChannel = payload.channelAccounts;
|
|
1051
|
-
const accountPayloads = {};
|
|
1052
|
-
for (const plugin of plugins) {
|
|
1053
|
-
const raw = accountsByChannel?.[plugin.id];
|
|
1054
|
-
if (Array.isArray(raw)) accountPayloads[plugin.id] = raw;
|
|
1055
|
-
}
|
|
1056
|
-
for (const plugin of plugins) {
|
|
1057
|
-
const accounts = accountPayloads[plugin.id];
|
|
1058
|
-
if (accounts && accounts.length > 0) lines.push(...accountLines(plugin.id, accounts));
|
|
1059
|
-
}
|
|
1060
|
-
lines.push("");
|
|
1061
|
-
const issues = collectChannelStatusIssues(payload);
|
|
1062
|
-
if (issues.length > 0) {
|
|
1063
|
-
lines.push(theme.warn("Warnings:"));
|
|
1064
|
-
for (const issue of issues) lines.push(`- ${issue.channel} ${issue.accountId}: ${issue.message}${issue.fix ? ` (${issue.fix})` : ""}`);
|
|
1065
|
-
lines.push(`- Run: ${formatCliCommand("anima doctor")}`);
|
|
1066
|
-
lines.push("");
|
|
1067
|
-
}
|
|
1068
|
-
lines.push(`Tip: ${formatDocsLink("/cli#status", "status --deep")} adds gateway health probes to status output (requires a reachable gateway).`);
|
|
1069
|
-
return lines;
|
|
1070
|
-
}
|
|
1071
|
-
async function formatConfigChannelsStatusLines(cfg, meta) {
|
|
1072
|
-
const lines = [];
|
|
1073
|
-
lines.push(theme.warn("Gateway not reachable; showing config-only status."));
|
|
1074
|
-
if (meta.path) lines.push(`Config: ${meta.path}`);
|
|
1075
|
-
if (meta.mode) lines.push(`Mode: ${meta.mode}`);
|
|
1076
|
-
if (meta.path || meta.mode) lines.push("");
|
|
1077
|
-
const accountLines = (provider, accounts) => accounts.map((account) => {
|
|
1078
|
-
const bits = [];
|
|
1079
|
-
if (typeof account.enabled === "boolean") bits.push(account.enabled ? "enabled" : "disabled");
|
|
1080
|
-
if (typeof account.configured === "boolean") bits.push(account.configured ? "configured" : "not configured");
|
|
1081
|
-
if (typeof account.linked === "boolean") bits.push(account.linked ? "linked" : "not linked");
|
|
1082
|
-
if (typeof account.mode === "string" && account.mode.length > 0) bits.push(`mode:${account.mode}`);
|
|
1083
|
-
if (typeof account.tokenSource === "string" && account.tokenSource) bits.push(`token:${account.tokenSource}`);
|
|
1084
|
-
if (typeof account.botTokenSource === "string" && account.botTokenSource) bits.push(`bot:${account.botTokenSource}`);
|
|
1085
|
-
if (typeof account.appTokenSource === "string" && account.appTokenSource) bits.push(`app:${account.appTokenSource}`);
|
|
1086
|
-
if (typeof account.baseUrl === "string" && account.baseUrl) bits.push(`url:${account.baseUrl}`);
|
|
1087
|
-
return `- ${formatChannelAccountLabel({
|
|
1088
|
-
channel: provider,
|
|
1089
|
-
accountId: typeof account.accountId === "string" ? account.accountId : "default",
|
|
1090
|
-
name: (typeof account.name === "string" ? account.name.trim() : "") || void 0
|
|
1091
|
-
})}: ${bits.join(", ")}`;
|
|
1092
|
-
});
|
|
1093
|
-
const plugins = listChannelPlugins();
|
|
1094
|
-
for (const plugin of plugins) {
|
|
1095
|
-
const accountIds = plugin.config.listAccountIds(cfg);
|
|
1096
|
-
if (!accountIds.length) continue;
|
|
1097
|
-
const snapshots = [];
|
|
1098
|
-
for (const accountId of accountIds) {
|
|
1099
|
-
const snapshot = await buildChannelAccountSnapshot({
|
|
1100
|
-
plugin,
|
|
1101
|
-
cfg,
|
|
1102
|
-
accountId
|
|
1103
|
-
});
|
|
1104
|
-
snapshots.push(snapshot);
|
|
1105
|
-
}
|
|
1106
|
-
if (snapshots.length > 0) lines.push(...accountLines(plugin.id, snapshots));
|
|
1107
|
-
}
|
|
1108
|
-
lines.push("");
|
|
1109
|
-
lines.push(`Tip: ${formatDocsLink("/cli#status", "status --deep")} adds gateway health probes to status output (requires a reachable gateway).`);
|
|
1110
|
-
return lines;
|
|
1111
|
-
}
|
|
1112
|
-
async function channelsStatusCommand(opts, runtime = defaultRuntime) {
|
|
1113
|
-
const timeoutMs = Number(opts.timeout ?? 1e4);
|
|
1114
|
-
const statusLabel = opts.probe ? "Checking channel status (probe)…" : "Checking channel status…";
|
|
1115
|
-
if (opts.json !== true && !process.stderr.isTTY) runtime.log(statusLabel);
|
|
1116
|
-
try {
|
|
1117
|
-
const payload = await withProgress({
|
|
1118
|
-
label: statusLabel,
|
|
1119
|
-
indeterminate: true,
|
|
1120
|
-
enabled: opts.json !== true
|
|
1121
|
-
}, async () => await callGateway({
|
|
1122
|
-
method: "channels.status",
|
|
1123
|
-
params: {
|
|
1124
|
-
probe: Boolean(opts.probe),
|
|
1125
|
-
timeoutMs
|
|
1126
|
-
},
|
|
1127
|
-
timeoutMs
|
|
1128
|
-
}));
|
|
1129
|
-
if (opts.json) {
|
|
1130
|
-
runtime.log(JSON.stringify(payload, null, 2));
|
|
1131
|
-
return;
|
|
1132
|
-
}
|
|
1133
|
-
runtime.log(formatGatewayChannelsStatusLines(payload).join("\n"));
|
|
1134
|
-
} catch (err) {
|
|
1135
|
-
runtime.error(`Gateway not reachable: ${String(err)}`);
|
|
1136
|
-
const cfg = await requireValidConfig(runtime);
|
|
1137
|
-
if (!cfg) return;
|
|
1138
|
-
const snapshot = await readConfigFileSnapshot();
|
|
1139
|
-
const mode = cfg.gateway?.mode === "remote" ? "remote" : "local";
|
|
1140
|
-
runtime.log((await formatConfigChannelsStatusLines(cfg, {
|
|
1141
|
-
path: snapshot.path,
|
|
1142
|
-
mode
|
|
1143
|
-
})).join("\n"));
|
|
1144
|
-
}
|
|
1145
|
-
}
|
|
1146
|
-
|
|
1147
|
-
//#endregion
|
|
1148
|
-
//#region src/cli/channel-auth.ts
|
|
1149
|
-
async function runChannelLogin(opts, runtime = defaultRuntime) {
|
|
1150
|
-
const channelInput = opts.channel ?? DEFAULT_CHAT_CHANNEL;
|
|
1151
|
-
const channelId = normalizeChannelId(channelInput);
|
|
1152
|
-
if (!channelId) throw new Error(`Unsupported channel: ${channelInput}`);
|
|
1153
|
-
const plugin = getChannelPlugin(channelId);
|
|
1154
|
-
if (!plugin?.auth?.login) throw new Error(`Channel ${channelId} does not support login`);
|
|
1155
|
-
setVerbose(Boolean(opts.verbose));
|
|
1156
|
-
const cfg = loadConfig();
|
|
1157
|
-
const accountId = opts.account?.trim() || resolveChannelDefaultAccountId({
|
|
1158
|
-
plugin,
|
|
1159
|
-
cfg
|
|
1160
|
-
});
|
|
1161
|
-
await plugin.auth.login({
|
|
1162
|
-
cfg,
|
|
1163
|
-
accountId,
|
|
1164
|
-
runtime,
|
|
1165
|
-
verbose: Boolean(opts.verbose),
|
|
1166
|
-
channelInput
|
|
1167
|
-
});
|
|
1168
|
-
}
|
|
1169
|
-
async function runChannelLogout(opts, runtime = defaultRuntime) {
|
|
1170
|
-
const channelInput = opts.channel ?? DEFAULT_CHAT_CHANNEL;
|
|
1171
|
-
const channelId = normalizeChannelId(channelInput);
|
|
1172
|
-
if (!channelId) throw new Error(`Unsupported channel: ${channelInput}`);
|
|
1173
|
-
const plugin = getChannelPlugin(channelId);
|
|
1174
|
-
if (!plugin?.gateway?.logoutAccount) throw new Error(`Channel ${channelId} does not support logout`);
|
|
1175
|
-
const cfg = loadConfig();
|
|
1176
|
-
const accountId = opts.account?.trim() || resolveChannelDefaultAccountId({
|
|
1177
|
-
plugin,
|
|
1178
|
-
cfg
|
|
1179
|
-
});
|
|
1180
|
-
const account = plugin.config.resolveAccount(cfg, accountId);
|
|
1181
|
-
await plugin.gateway.logoutAccount({
|
|
1182
|
-
cfg,
|
|
1183
|
-
accountId,
|
|
1184
|
-
account,
|
|
1185
|
-
runtime
|
|
1186
|
-
});
|
|
1187
|
-
}
|
|
1188
|
-
|
|
1189
|
-
//#endregion
|
|
1190
|
-
//#region src/cli/channels-cli.ts
|
|
1191
|
-
const optionNamesAdd = [
|
|
1192
|
-
"channel",
|
|
1193
|
-
"account",
|
|
1194
|
-
"name",
|
|
1195
|
-
"token",
|
|
1196
|
-
"tokenFile",
|
|
1197
|
-
"botToken",
|
|
1198
|
-
"appToken",
|
|
1199
|
-
"signalNumber",
|
|
1200
|
-
"cliPath",
|
|
1201
|
-
"dbPath",
|
|
1202
|
-
"service",
|
|
1203
|
-
"region",
|
|
1204
|
-
"authDir",
|
|
1205
|
-
"httpUrl",
|
|
1206
|
-
"httpHost",
|
|
1207
|
-
"httpPort",
|
|
1208
|
-
"webhookPath",
|
|
1209
|
-
"webhookUrl",
|
|
1210
|
-
"audienceType",
|
|
1211
|
-
"audience",
|
|
1212
|
-
"useEnv",
|
|
1213
|
-
"homeserver",
|
|
1214
|
-
"userId",
|
|
1215
|
-
"accessToken",
|
|
1216
|
-
"password",
|
|
1217
|
-
"deviceName",
|
|
1218
|
-
"initialSyncLimit",
|
|
1219
|
-
"ship",
|
|
1220
|
-
"url",
|
|
1221
|
-
"code",
|
|
1222
|
-
"groupChannels",
|
|
1223
|
-
"dmAllowlist",
|
|
1224
|
-
"autoDiscoverChannels"
|
|
1225
|
-
];
|
|
1226
|
-
const optionNamesRemove = [
|
|
1227
|
-
"channel",
|
|
1228
|
-
"account",
|
|
1229
|
-
"delete"
|
|
1230
|
-
];
|
|
1231
|
-
function runChannelsCommand(action) {
|
|
1232
|
-
return runCommandWithRuntime(defaultRuntime, action);
|
|
1233
|
-
}
|
|
1234
|
-
function runChannelsCommandWithDanger(action, label) {
|
|
1235
|
-
return runCommandWithRuntime(defaultRuntime, action, (err) => {
|
|
1236
|
-
defaultRuntime.error(danger(`${label}: ${String(err)}`));
|
|
1237
|
-
defaultRuntime.exit(1);
|
|
1238
|
-
});
|
|
1239
|
-
}
|
|
1240
|
-
function registerChannelsCli(program) {
|
|
1241
|
-
const channelNames = formatCliChannelOptions();
|
|
1242
|
-
const channels = program.command("channels").description("Manage chat channel accounts").addHelpText("after", () => `\n${theme.muted("Docs:")} ${formatDocsLink("/cli/channels", "docs.openclaw.ai/cli/channels")}\n`);
|
|
1243
|
-
channels.command("list").description("List configured channels + auth profiles").option("--no-usage", "Skip model provider usage/quota snapshots").option("--json", "Output JSON", false).action(async (opts) => {
|
|
1244
|
-
await runChannelsCommand(async () => {
|
|
1245
|
-
await channelsListCommand(opts, defaultRuntime);
|
|
1246
|
-
});
|
|
1247
|
-
});
|
|
1248
|
-
channels.command("status").description("Show gateway channel status (use status --deep for local)").option("--probe", "Probe channel credentials", false).option("--timeout <ms>", "Timeout in ms", "10000").option("--json", "Output JSON", false).action(async (opts) => {
|
|
1249
|
-
await runChannelsCommand(async () => {
|
|
1250
|
-
await channelsStatusCommand(opts, defaultRuntime);
|
|
1251
|
-
});
|
|
1252
|
-
});
|
|
1253
|
-
channels.command("capabilities").description("Show provider capabilities (intents/scopes + supported features)").option("--channel <name>", `Channel (${formatCliChannelOptions(["all"])})`).option("--account <id>", "Account id (only with --channel)").option("--target <dest>", "Channel target for permission audit (Discord channel:<id>)").option("--timeout <ms>", "Timeout in ms", "10000").option("--json", "Output JSON", false).action(async (opts) => {
|
|
1254
|
-
await runChannelsCommand(async () => {
|
|
1255
|
-
await channelsCapabilitiesCommand(opts, defaultRuntime);
|
|
1256
|
-
});
|
|
1257
|
-
});
|
|
1258
|
-
channels.command("resolve").description("Resolve channel/user names to IDs").argument("<entries...>", "Entries to resolve (names or ids)").option("--channel <name>", `Channel (${channelNames})`).option("--account <id>", "Account id (accountId)").option("--kind <kind>", "Target kind (auto|user|group)", "auto").option("--json", "Output JSON", false).action(async (entries, opts) => {
|
|
1259
|
-
await runChannelsCommand(async () => {
|
|
1260
|
-
await channelsResolveCommand({
|
|
1261
|
-
channel: opts.channel,
|
|
1262
|
-
account: opts.account,
|
|
1263
|
-
kind: opts.kind,
|
|
1264
|
-
json: Boolean(opts.json),
|
|
1265
|
-
entries: Array.isArray(entries) ? entries : [String(entries)]
|
|
1266
|
-
}, defaultRuntime);
|
|
1267
|
-
});
|
|
1268
|
-
});
|
|
1269
|
-
channels.command("logs").description("Show recent channel logs from the gateway log file").option("--channel <name>", `Channel (${formatCliChannelOptions(["all"])})`, "all").option("--lines <n>", "Number of lines (default: 200)", "200").option("--json", "Output JSON", false).action(async (opts) => {
|
|
1270
|
-
await runChannelsCommand(async () => {
|
|
1271
|
-
await channelsLogsCommand(opts, defaultRuntime);
|
|
1272
|
-
});
|
|
1273
|
-
});
|
|
1274
|
-
channels.command("add").description("Add or update a channel account").option("--channel <name>", `Channel (${channelNames})`).option("--account <id>", "Account id (default when omitted)").option("--name <name>", "Display name for this account").option("--token <token>", "Bot token (Telegram/Discord)").option("--token-file <path>", "Bot token file (Telegram)").option("--bot-token <token>", "Slack bot token (xoxb-...)").option("--app-token <token>", "Slack app token (xapp-...)").option("--signal-number <e164>", "Signal account number (E.164)").option("--cli-path <path>", "CLI path (signal-cli or imsg)").option("--db-path <path>", "iMessage database path").option("--service <service>", "iMessage service (imessage|sms|auto)").option("--region <region>", "iMessage region (for SMS)").option("--auth-dir <path>", "WhatsApp auth directory override").option("--http-url <url>", "Signal HTTP daemon base URL").option("--http-host <host>", "Signal HTTP host").option("--http-port <port>", "Signal HTTP port").option("--webhook-path <path>", "Webhook path (Google Chat/BlueBubbles)").option("--webhook-url <url>", "Google Chat webhook URL").option("--audience-type <type>", "Google Chat audience type (app-url|project-number)").option("--audience <value>", "Google Chat audience value (app URL or project number)").option("--homeserver <url>", "Matrix homeserver URL").option("--user-id <id>", "Matrix user ID").option("--access-token <token>", "Matrix access token").option("--password <password>", "Matrix password").option("--device-name <name>", "Matrix device name").option("--initial-sync-limit <n>", "Matrix initial sync limit").option("--ship <ship>", "Tlon ship name (~sampel-palnet)").option("--url <url>", "Tlon ship URL").option("--code <code>", "Tlon login code").option("--group-channels <list>", "Tlon group channels (comma-separated)").option("--dm-allowlist <list>", "Tlon DM allowlist (comma-separated ships)").option("--auto-discover-channels", "Tlon auto-discover group channels").option("--no-auto-discover-channels", "Disable Tlon auto-discovery").option("--use-env", "Use env token (default account only)", false).action(async (opts, command) => {
|
|
1275
|
-
await runChannelsCommand(async () => {
|
|
1276
|
-
await channelsAddCommand(opts, defaultRuntime, { hasFlags: hasExplicitOptions(command, optionNamesAdd) });
|
|
1277
|
-
});
|
|
1278
|
-
});
|
|
1279
|
-
channels.command("remove").description("Disable or delete a channel account").option("--channel <name>", `Channel (${channelNames})`).option("--account <id>", "Account id (default when omitted)").option("--delete", "Delete config entries (no prompt)", false).action(async (opts, command) => {
|
|
1280
|
-
await runChannelsCommand(async () => {
|
|
1281
|
-
await channelsRemoveCommand(opts, defaultRuntime, { hasFlags: hasExplicitOptions(command, optionNamesRemove) });
|
|
1282
|
-
});
|
|
1283
|
-
});
|
|
1284
|
-
channels.command("login").description("Link a channel account (if supported)").option("--channel <channel>", "Channel alias (default: whatsapp)").option("--account <id>", "Account id (accountId)").option("--verbose", "Verbose connection logs", false).action(async (opts) => {
|
|
1285
|
-
await runChannelsCommandWithDanger(async () => {
|
|
1286
|
-
await runChannelLogin({
|
|
1287
|
-
channel: opts.channel,
|
|
1288
|
-
account: opts.account,
|
|
1289
|
-
verbose: Boolean(opts.verbose)
|
|
1290
|
-
}, defaultRuntime);
|
|
1291
|
-
}, "Channel login failed");
|
|
1292
|
-
});
|
|
1293
|
-
channels.command("logout").description("Log out of a channel session (if supported)").option("--channel <channel>", "Channel alias (default: whatsapp)").option("--account <id>", "Account id (accountId)").action(async (opts) => {
|
|
1294
|
-
await runChannelsCommandWithDanger(async () => {
|
|
1295
|
-
await runChannelLogout({
|
|
1296
|
-
channel: opts.channel,
|
|
1297
|
-
account: opts.account
|
|
1298
|
-
}, defaultRuntime);
|
|
1299
|
-
}, "Channel logout failed");
|
|
1300
|
-
});
|
|
1301
|
-
}
|
|
1302
|
-
|
|
1303
|
-
//#endregion
|
|
1304
|
-
export { registerChannelsCli };
|