squidclaw 3.0.19 → 3.0.21
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/dist/{accounts-s5e9zidf.js → accounts-C7pGQPcS.js} +2 -2
- package/dist/{accounts-Bkb-J8V6.js → accounts-DjhBQg_8.js} +2 -2
- package/dist/{accounts-B6F_XCgS.js → accounts-DwGoZKGm.js} +17 -17
- package/dist/{active-listener-6-Svu8Dx.js → active-listener-DPc_PGsA.js} +2 -2
- package/dist/{agents-DL8uYsUq.js → agents-DXKtU4Il.js} +4 -4
- package/dist/{agents.config-B4KAAVvR.js → agents.config-BM-2SLCh.js} +1 -1
- package/dist/{agents.config-D93fF1eJ.js → agents.config-eMSUW-iw.js} +1 -1
- package/dist/{plugin-sdk/api-key-rotation-DyjMI2n3.js → api-key-rotation-DVyYtQxC.js} +2 -2
- package/dist/{audio-preflight-DZ1LNMJp.js → audio-preflight-BUCBED7N.js} +32 -32
- package/dist/{audio-preflight-Bzo_zN4j.js → audio-preflight-lT9iRnYi.js} +4 -4
- package/dist/{audio-transcription-runner-B3u2x_ja.js → audio-transcription-runner-Cv0Q47cM.js} +12 -12
- package/dist/{audio-transcription-runner-Cp_lkLCv.js → audio-transcription-runner-YiR1ym3a.js} +1 -1
- package/dist/{audit-membership-runtime-w23FnNAN.js → audit-membership-runtime-DyLj-uhz.js} +4 -4
- package/dist/{auth-choice-Ba4AEm_k.js → auth-choice-CXepQc7c.js} +1 -1
- package/dist/{auth-choice-ziFj5bXd.js → auth-choice-D2JrMJn-.js} +1 -1
- package/dist/{banner-DDih2slD.js → banner-DMfuBV69.js} +1 -1
- package/dist/build-info.json +3 -3
- package/dist/bundled/boot-md/handler.js +51 -51
- package/dist/bundled/bootstrap-extra-files/handler.js +6 -6
- package/dist/bundled/command-logger/handler.js +2 -2
- package/dist/bundled/session-memory/handler.js +687 -51
- package/dist/canvas-host/a2ui/a2ui.bundle.js +1 -17815
- package/dist/{channel-activity-CxJbx4sD.js → channel-activity-CPpt4XaL.js} +3 -3
- package/dist/{channel-options-DTDfU0R6.js → channel-options-CQ-gER0J.js} +1 -1
- package/dist/{channel-options-BBSsevyl.js → channel-options-SijIkAlT.js} +1 -1
- package/dist/{channel-web-BXl9jCKV.js → channel-web-7t1a2N13.js} +1 -1
- package/dist/{channel-web-SF18oYqo.js → channel-web-LLzBxZrT.js} +1 -1
- package/dist/{channels-cli-BiuWJpJu.js → channels-cli-D4xUEYYC.js} +6 -6
- package/dist/{channels-cli-BDLabpWH.js → channels-cli-DYaFNMme.js} +6 -6
- package/dist/{chrome-CZQnp4VH.js → chrome-CuBHInKC.js} +8 -8
- package/dist/{chrome-Dxm25ptH.js → chrome-OgCChbC_.js} +26 -26
- package/dist/{cli-CfgDCCuC.js → cli-CAID9zkL.js} +1 -1
- package/dist/{cli-DAZ1MKrJ.js → cli-Dlc9IFWZ.js} +1 -1
- package/dist/{command-registry-DkjNuW8w.js → command-registry-AHS8_9da.js} +9 -9
- package/dist/{commands-registry-B44COZFz.js → commands-registry-BJjv8_oR.js} +4 -4
- package/dist/{completion-cli-DbNma3J9.js → completion-cli-B8xjpHDs.js} +1 -1
- package/dist/{completion-cli-Du8H92bM.js → completion-cli-BR1r9_h4.js} +2 -2
- package/dist/{config-cli-CQhQ8Bcc.js → config-cli-D0A8Awoo.js} +1 -1
- package/dist/{config-cli-D16tlTWa.js → config-cli-D4Rxoozg.js} +1 -1
- package/dist/{configure-B9b3cQTC.js → configure-DOiI8_8c.js} +3 -3
- package/dist/{configure-B4TiK50K.js → configure-XmOqwwy9.js} +3 -3
- package/dist/control-ui/assets/{index-cM5P_3w7.js → index-BqxuPQOl.js} +2 -2
- package/dist/control-ui/assets/{index-cM5P_3w7.js.map → index-BqxuPQOl.js.map} +1 -1
- package/dist/control-ui/index.html +1 -1
- package/dist/{deliver-B4WWPQvt.js → deliver-6zfT7daI.js} +1 -1
- package/dist/{deliver-BcnsjbAB.js → deliver-DMTUTpTM.js} +21 -21
- package/dist/deliver-runtime-B80olQwJ.js +36 -0
- package/dist/{deliver-runtime-CeE1X9si.js → deliver-runtime-MBexxUuG.js} +3 -3
- package/dist/deps-send-discord.runtime-GIuvX7Xw.js +26 -0
- package/dist/deps-send-imessage.runtime-B3TC7G80.js +25 -0
- package/dist/deps-send-signal.runtime-CuVJyw7n.js +24 -0
- package/dist/deps-send-slack.runtime-cbfFoLZ4.js +22 -0
- package/dist/deps-send-telegram.runtime-CRyP-xDQ.js +27 -0
- package/dist/deps-send-whatsapp.runtime-4aOUBP2J.js +60 -0
- package/dist/{deps-send-whatsapp.runtime-B9uivfkM.js → deps-send-whatsapp.runtime-CETLGt-t.js} +3 -3
- package/dist/{deps-send-whatsapp.runtime-miTfQkK9.js → deps-send-whatsapp.runtime-CrxkfP31.js} +7 -7
- package/dist/{deps-send-whatsapp.runtime-CFnZsKW0.js → deps-send-whatsapp.runtime-__ogpmJj.js} +3 -3
- package/dist/{diagnostic-C2lklhkn.js → diagnostic-CnVwZNbm.js} +2 -2
- package/dist/{doctor-completion-ujZ_JdIz.js → doctor-completion-CZoEdMS-.js} +1 -1
- package/dist/{doctor-completion-CEiVFPte.js → doctor-completion-DhLEFUhN.js} +1 -1
- package/dist/entry.js +2 -2
- package/dist/{plugin-sdk/errors-B8oJXuCF.js → errors-kkRuS2Cs.js} +1 -1
- package/dist/extensionAPI.js +6 -6
- package/dist/{fetch-b8tSR7_e.js → fetch-DP-JjB6Z.js} +5 -5
- package/dist/{fetch-guard-D16tjNsZ.js → fetch-guard-BDy975wP.js} +2 -2
- package/dist/{frontmatter-CjKtFduT.js → frontmatter-Cq1TcIQ2.js} +3 -3
- package/dist/{fs-safe-CwHbZdFH.js → fs-safe-BoB4X3GD.js} +4 -4
- package/dist/{gateway-cli-NXeo-J8r.js → gateway-cli-BJHBChfI.js} +8 -8
- package/dist/{gateway-cli-2jaWM_Ci.js → gateway-cli-BpHskeDd.js} +8 -8
- package/dist/{github-copilot-token-Cw3tAXM9.js → github-copilot-token-B5cPlwaz.js} +7 -7
- package/dist/{health-BPZALM__.js → health-TmpUGSqu.js} +1 -1
- package/dist/{health-DFZKMrW2.js → health-XFKFZ7ZJ.js} +1 -1
- package/dist/{hooks-cli-B3rkhWcT.js → hooks-cli-CXsZK8H9.js} +2 -2
- package/dist/{hooks-cli-BO_gZJVD.js → hooks-cli-DsDV-Pxz.js} +2 -2
- package/dist/{image-DKkuLtZ4.js → image-VgwN31FZ.js} +1 -1
- package/dist/{image-C-8Kd2Mh.js → image-kKMG59st.js} +6 -6
- package/dist/{image-ops-BoN1E_WZ.js → image-ops-Dg8iraUV.js} +2 -2
- package/dist/image-runtime-BqIv7p_K.js +29 -0
- package/dist/{image-runtime-BMavqm9n.js → image-runtime-CwMuTYvd.js} +3 -3
- package/dist/index.js +6 -6
- package/dist/{ir-Dut0zXyS.js → ir-CKK03mBV.js} +8 -8
- package/dist/{legacy-names-B0wgIP0Q.js → legacy-names-aGJJuzM_.js} +1 -1
- package/dist/llm-slug-generator.js +51 -51
- package/dist/{logger-oGKcCLZ5.js → logger-CnTSBL7T.js} +7 -7
- package/dist/{login-DJ357UQV.js → login-CeKDrz6_.js} +5 -5
- package/dist/{login-qr-C0fDBnpM.js → login-qr-KbOpR0GQ.js} +10 -10
- package/dist/{manager-BPGhs30n.js → manager-DINhLnMi.js} +13 -13
- package/dist/manager-runtime-D6ckUNSs.js +18 -0
- package/dist/{model-selection-CHnojCCK.js → model-selection-DuNLFQPR.js} +43 -43
- package/dist/{models-Bb-GYqHr.js → models-5VXwJBU2.js} +2 -2
- package/dist/{models-cli-DffAz0ji.js → models-cli-Br56IHfy.js} +3 -3
- package/dist/{models-cli-CAIJM1Wh.js → models-cli-CrR1RN3j.js} +2 -2
- package/dist/{npm-resolution-D2_zGJM-.js → npm-resolution-CKtyq4FH.js} +1 -1
- package/dist/{npm-resolution-D5pBCkUw.js → npm-resolution-CPk7dS7F.js} +1 -1
- package/dist/{onboard-DcVsL9Jx.js → onboard-DUnBamC0.js} +2 -2
- package/dist/{onboard-channels-mNXKTvFs.js → onboard-channels-D45grihx.js} +1 -1
- package/dist/{onboard-channels-C-cQFUBH.js → onboard-channels-_kVo3Apf.js} +1 -1
- package/dist/{onboard-dhG2YBez.js → onboard-lFwpCpC3.js} +2 -2
- package/dist/{onboarding-B3-IwkNi.js → onboarding-CyCSQ__q.js} +3 -3
- package/dist/{onboarding-Cl6kW_iq.js → onboarding-EEd_g8Zg.js} +3 -3
- package/dist/{onboarding.finalize-CCU-ykTR.js → onboarding.finalize-CbMq7C4K.js} +5 -5
- package/dist/{onboarding.finalize-BZqsNG2H.js → onboarding.finalize-Cs1ukjFN.js} +6 -6
- package/dist/{outbound-qTioiTJg.js → outbound-C9svt6RH.js} +6 -6
- package/dist/{outbound-attachment-rlW7G5df.js → outbound-attachment-DwupUxYF.js} +2 -2
- package/dist/{path-alias-guards-Cpsiv2KL.js → path-alias-guards-DORgbZ1w.js} +1 -1
- package/dist/{paths-CSdAWKDO.js → paths-DA5srn0U.js} +5 -5
- package/dist/{paths-CXClY8zC.js → paths-DSd911Oe.js} +4 -4
- package/dist/{pi-embedded-B79nZERv.js → pi-embedded-BN8fghaF.js} +123 -26
- package/dist/{pi-embedded-C5U8Qxn6.js → pi-embedded-BiC4tIJ8.js} +266 -169
- package/dist/{pi-embedded-helpers-CEHpGDRs.js → pi-embedded-helpers-A9VYPVCH.js} +3 -3
- package/dist/{pi-embedded-helpers-DQ7IaeOi.js → pi-embedded-helpers-Di58J7Eh.js} +52 -52
- package/dist/{pi-model-discovery-o-WX5w2t.js → pi-model-discovery-V-InbjOM.js} +7 -7
- package/dist/pi-model-discovery-runtime--t6tAlar.js +11 -0
- package/dist/{pi-tools.before-tool-call.runtime-B_LUttg1.js → pi-tools.before-tool-call.runtime-Bpk4qTgV.js} +9 -9
- package/dist/{plugin-registry-CB47SSz1.js → plugin-registry-CXm125Uz.js} +1 -1
- package/dist/{plugin-registry-Gy_VByyf.js → plugin-registry-D3PnPE1D.js} +1 -1
- package/dist/plugin-sdk/{accounts-0kF5cxkn.js → accounts-C5PAuCTj.js} +2 -2
- package/dist/plugin-sdk/{accounts-u0-JAHzj.js → accounts-DC5cbH9r.js} +2 -2
- package/dist/plugin-sdk/{accounts-xZOA23tQ.js → accounts-DncG0Hx9.js} +3 -3
- package/dist/plugin-sdk/{active-listener-BO7eBEG_.js → active-listener-Bd3HH2km.js} +2 -2
- package/dist/plugin-sdk/agents/agent-tier.d.ts +22 -2
- package/dist/plugin-sdk/{api-key-rotation-C4C_mDsg.js → api-key-rotation-BAZ0GD26.js} +2 -2
- package/dist/plugin-sdk/{audio-preflight-C0q7lu6y.js → audio-preflight-tpVm-t9O.js} +26 -26
- package/dist/plugin-sdk/{audio-transcription-runner-Ced47O1H.js → audio-transcription-runner-DSScb434.js} +11 -11
- package/dist/plugin-sdk/{audit-membership-runtime-Xl20kCBe.js → audit-membership-runtime-DHQDvH4u.js} +2 -2
- package/dist/plugin-sdk/{channel-activity-CNffKOEQ.js → channel-activity-cYEaofTH.js} +3 -3
- package/dist/plugin-sdk/{channel-web-vB3Dcd8-.js → channel-web-CbeCrQ4C.js} +18 -18
- package/dist/plugin-sdk/{channel-web-BrhP6FQO.js → channel-web-CqiSEc52.js} +1 -1
- package/dist/plugin-sdk/{chrome-DJQWo149.js → chrome-DB2h0uN0.js} +6 -6
- package/dist/plugin-sdk/{commands-registry-_kBPE22q.js → commands-registry-DGZ1oFXJ.js} +4 -4
- package/dist/plugin-sdk/{common-J8vIST9Q.js → common-D5lLWoCW.js} +2 -2
- package/dist/plugin-sdk/compat.js +50 -50
- package/dist/plugin-sdk/{config-CnZ1TlEw.js → config-Bt-c7PWF.js} +7 -7
- package/dist/plugin-sdk/{deliver-Xh6voz9H.js → deliver-MvrkIeKJ.js} +10 -10
- package/dist/plugin-sdk/deliver-runtime-i50kjcNM.js +32 -0
- package/dist/plugin-sdk/deps-send-discord.runtime-hOYq9ov0.js +23 -0
- package/dist/plugin-sdk/deps-send-imessage.runtime-D5n9DXyL.js +22 -0
- package/dist/plugin-sdk/deps-send-signal.runtime-CwEaRyJU.js +21 -0
- package/dist/plugin-sdk/deps-send-slack.runtime-DOZeLIaC.js +19 -0
- package/dist/plugin-sdk/deps-send-telegram.runtime-BW1hSPKh.js +24 -0
- package/dist/plugin-sdk/{deps-send-whatsapp.runtime-Ce4Gzz-J.js → deps-send-whatsapp.runtime-DvxhnHR_.js} +3 -3
- package/dist/plugin-sdk/deps-send-whatsapp.runtime-JKmTtCFM.js +57 -0
- package/dist/plugin-sdk/{diagnostic-DKsyROPi.js → diagnostic-B6F3BtCX.js} +2 -2
- package/dist/plugin-sdk/{errors-CgRPdp3o.js → errors-9oVz7reJ.js} +1 -1
- package/dist/plugin-sdk/{fetch-guard-BBAT8G-1.js → fetch-guard-cfPCfkrw.js} +2 -2
- package/dist/plugin-sdk/{fs-safe-DqCO1D4C.js → fs-safe-DFbwq9CS.js} +3 -3
- package/dist/plugin-sdk/{image-4ay2cw7G.js → image-FK5xhY5u.js} +6 -6
- package/dist/plugin-sdk/{image-ops-G8KoEfY8.js → image-ops-BSYgrL7E.js} +2 -2
- package/dist/plugin-sdk/image-runtime-B95EPFpg.js +25 -0
- package/dist/plugin-sdk/index.js +2 -2
- package/dist/plugin-sdk/{ir-DXj1KGnL.js → ir-CWmryq5f.js} +7 -7
- package/dist/plugin-sdk/{local-roots-ovKHgVSP.js → local-roots-U25IdeDH.js} +4 -4
- package/dist/plugin-sdk/{logger-DIb2cGHp.js → logger-Bg4vIUJn.js} +2 -2
- package/dist/plugin-sdk/{login-Cgtm70by.js → login-8qzl2H7G.js} +4 -4
- package/dist/plugin-sdk/{login-qr-BrixqhMx.js → login-qr-kalCTJEw.js} +5 -5
- package/dist/plugin-sdk/{manager-PEQ_cPYF.js → manager-ijYHktIt.js} +8 -8
- package/dist/plugin-sdk/manager-runtime--JrLQE03.js +15 -0
- package/dist/plugin-sdk/{outbound-BK75h9CQ.js → outbound-BIVf0aPq.js} +5 -5
- package/dist/plugin-sdk/{outbound-attachment-BI1QngTS.js → outbound-attachment-F5tzeNUD.js} +2 -2
- package/dist/plugin-sdk/{path-alias-guards-TnxupPQC.js → path-alias-guards-DA0MhfkG.js} +1 -1
- package/dist/plugin-sdk/{paths-B7_75Pdr.js → paths-CP67O8eN.js} +1 -1
- package/dist/plugin-sdk/{pi-embedded-helpers-BioULNev.js → pi-embedded-helpers-CxMnPQ37.js} +16 -16
- package/dist/plugin-sdk/{pi-model-discovery-BMmAbnil.js → pi-model-discovery-8OL77kCh.js} +1 -1
- package/dist/plugin-sdk/pi-model-discovery-runtime-DGRFpUfd.js +8 -0
- package/dist/plugin-sdk/{pi-tools.before-tool-call.runtime-rdRqZ9lk.js → pi-tools.before-tool-call.runtime-B7FW36KX.js} +4 -4
- package/dist/plugin-sdk/{plugins-BqKpJkqt.js → plugins-D3mrhffi.js} +4 -4
- package/dist/plugin-sdk/{proxy-env-C4s12rr8.js → proxy-env-CUUXO6rv.js} +1 -1
- package/dist/plugin-sdk/{proxy-fetch-ZPEvp58f.js → proxy-fetch-Cf3IUSDw.js} +1 -1
- package/dist/plugin-sdk/{pw-ai-Cb0ZDSq4.js → pw-ai-dPmKdw_w.js} +9 -9
- package/dist/plugin-sdk/{qmd-manager-Bei6TaFq.js → qmd-manager-Ov9ElEfG.js} +7 -7
- package/dist/plugin-sdk/{query-expansion-POz2za8a.js → query-expansion-CzjwW461.js} +4 -4
- package/dist/plugin-sdk/{redact-9WsNyb7S.js → redact-DfACyt0X.js} +1 -1
- package/dist/plugin-sdk/{reply-DxvpiQBp.js → reply-BczXGzC_.js} +137 -40
- package/dist/plugin-sdk/{reply-sFKB3ofA.js → reply-Dfjh1YtV.js} +206 -109
- package/dist/plugin-sdk/{resolve-outbound-target-DL1adXpk.js → resolve-outbound-target-BeIB_jm0.js} +2 -2
- package/dist/plugin-sdk/{run-with-concurrency-DmTrN5JG.js → run-with-concurrency-kVooFCVo.js} +1 -1
- package/dist/plugin-sdk/runtime-whatsapp-login.runtime-B6EcC22F.js +10 -0
- package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-DH8J0Ie7.js +19 -0
- package/dist/plugin-sdk/{send-BCVXt-3e.js → send-CgkNzAhS.js} +8 -8
- package/dist/plugin-sdk/{send-CAG0Or0G.js → send-CuENGOhq.js} +7 -7
- package/dist/plugin-sdk/{send-X6QuS7x0.js → send-D6Uh2D1D.js} +5 -5
- package/dist/plugin-sdk/{send-BNePC8CO.js → send-DV5kR0Hg.js} +6 -6
- package/dist/plugin-sdk/{send-DhGDAZnT.js → send-DtA6ngBJ.js} +13 -13
- package/dist/plugin-sdk/{session-CAqYQVhe.js → session-CnlZn-bR.js} +3 -3
- package/dist/plugin-sdk/{skill-commands-Bk-IFyNw.js → skill-commands-Ckfii7h8.js} +4 -4
- package/dist/plugin-sdk/{skills-C5bT9-q4.js → skills-v0WQqKTa.js} +6 -6
- package/dist/plugin-sdk/slash-commands.runtime-BYoxsxkX.js +13 -0
- package/dist/plugin-sdk/{slash-dispatch.runtime-Dyb_EkUt.js → slash-dispatch.runtime-DOo1IzuY.js} +1 -1
- package/dist/plugin-sdk/slash-dispatch.runtime-JfFr7bNy.js +52 -0
- package/dist/plugin-sdk/slash-skill-commands.runtime-D0399tia.js +16 -0
- package/dist/plugin-sdk/{store-D3lgWnS2.js → store-C_UrNuM3.js} +2 -2
- package/dist/plugin-sdk/{subagent-registry-runtime-hdnabonI.js → subagent-registry-runtime-DLvup9ph.js} +1 -1
- package/dist/plugin-sdk/subagent-registry-runtime-DVl5xKOW.js +52 -0
- package/dist/plugin-sdk/{tables-Dmlu4_q_.js → tables-CJP05iMa.js} +1 -1
- package/dist/plugin-sdk/{thinking-DRNOh5Xx.js → thinking-BhP3vn1l.js} +7 -7
- package/dist/plugin-sdk/{tokens-CTIYTLWu.js → tokens-DAL_5WHL.js} +1 -1
- package/dist/plugin-sdk/{tool-images-GSlvf6RP.js → tool-images-ZE5G5UM0.js} +2 -2
- package/dist/plugin-sdk/{web-D9LAdsuU.js → web-C2Sj2WW0.js} +2 -2
- package/dist/plugin-sdk/web-CNY_ky8h.js +56 -0
- package/dist/plugin-sdk/{whatsapp-actions-BCJYmWCB.js → whatsapp-actions-DJmx6ihj.js} +17 -17
- package/dist/plugin-sdk/whatsapp.js +50 -50
- package/dist/{plugins-AqsVZZk3.js → plugins-DvejjZnJ.js} +11 -11
- package/dist/{plugins-cli-BYnoJwF1.js → plugins-cli-BA_2daJe.js} +2 -2
- package/dist/{plugins-cli-gtgkmDcv.js → plugins-cli-C0WKWrZo.js} +2 -2
- package/dist/{program-BGlgDpHI.js → program-D_xdLzmM.js} +7 -7
- package/dist/{program-context-M4FTWqqg.js → program-context-DfmCIQ91.js} +17 -17
- package/dist/{prompt-select-styled-AL5Tm3yO.js → prompt-select-styled-ApPSadr5.js} +4 -4
- package/dist/{prompt-select-styled-BVC2byQV.js → prompt-select-styled-BsheNEnh.js} +4 -4
- package/dist/{provider-auth-helpers-DDgrFku5.js → provider-auth-helpers-B5kD4Lt6.js} +1 -1
- package/dist/{provider-auth-helpers-Q7aIhDgv.js → provider-auth-helpers-DpOFkV28.js} +1 -1
- package/dist/{proxy-env-DXXfs2WL.js → proxy-env-D-fike7s.js} +1 -1
- package/dist/{plugin-sdk/proxy-fetch-Dt5BedH8.js → proxy-fetch-lH6RsRTE.js} +1 -1
- package/dist/{push-apns-Ga8xvhkh.js → push-apns-BbenjEX4.js} +1 -1
- package/dist/{push-apns-FyGbUyh2.js → push-apns-Ci2sdIKf.js} +1 -1
- package/dist/{pw-ai-GOBxzChI.js → pw-ai-B8ymIYub.js} +14 -14
- package/dist/{pw-ai-Du22SYoO.js → pw-ai-CM87tQwG.js} +1 -1
- package/dist/{qmd-manager-CO-shcLU.js → qmd-manager-BN0siR2Z.js} +10 -10
- package/dist/{query-expansion-DlQOkf-g.js → query-expansion-Dzxt6kXo.js} +6 -6
- package/dist/{redact-NmPEVjIo.js → redact-DvzicBMu.js} +1 -1
- package/dist/{register.agent-koAXw1ay.js → register.agent-CY6R-7fn.js} +6 -6
- package/dist/{register.agent-zP8a-sNB.js → register.agent-Dk_5V5oA.js} +7 -7
- package/dist/{register.configure-CUuP5J8W.js → register.configure-C8OFfGln.js} +7 -7
- package/dist/{register.configure-CYrmyjlf.js → register.configure-DT1RLeTR.js} +7 -7
- package/dist/{register.maintenance-BZuEljPU.js → register.maintenance-CluQOq8b.js} +8 -8
- package/dist/{register.maintenance-ByEQ2CVH.js → register.maintenance-YHXmOQzf.js} +7 -7
- package/dist/{register.message-BkSXhv9I.js → register.message-BCTXT5yK.js} +2 -2
- package/dist/{register.message-CgHfmDHm.js → register.message-BuoFjRqA.js} +2 -2
- package/dist/{register.onboard-HcQwPAEK.js → register.onboard-BJaRMtxU.js} +2 -2
- package/dist/{register.onboard-4ke40MNP.js → register.onboard-C64oXnvq.js} +2 -2
- package/dist/{register.setup-B41xZb1r.js → register.setup-Dl3nk2Ui.js} +2 -2
- package/dist/{register.setup-xAb7Cvzy.js → register.setup-Drc55K_w.js} +2 -2
- package/dist/{register.status-health-sessions-CcOVL0x8.js → register.status-health-sessions-BHtbPeCO.js} +3 -3
- package/dist/{register.status-health-sessions-BbHAAKwv.js → register.status-health-sessions-xgC_gtEM.js} +3 -3
- package/dist/{register.subclis-_uSASnfC.js → register.subclis-CDMFyaKR.js} +9 -9
- package/dist/{reply-BFTOdZcK.js → reply-DwjHsBuj.js} +137 -40
- package/dist/{run-main-C1eZrW-5.js → run-main-BcA22Ipv.js} +14 -14
- package/dist/{run-with-concurrency-FczpX8ng.js → run-with-concurrency-BFR3ReeF.js} +4 -4
- package/dist/runtime-whatsapp-login.runtime-DxV9iv6l.js +13 -0
- package/dist/runtime-whatsapp-outbound.runtime-DQqIlwhS.js +22 -0
- package/dist/{send-Bx9CqcZr.js → send-4nRsZJXH.js} +7 -7
- package/dist/{send-D5D0ZGht.js → send-BGlcHjUD.js} +26 -26
- package/dist/{send-DtHQ7_6Z.js → send-BTUU1jWM.js} +8 -8
- package/dist/{send-B9H0BkfO.js → send-DdBbRpTP.js} +6 -6
- package/dist/{send-B5QEmMJ4.js → send-dTQd-IyJ.js} +5 -5
- package/dist/{server-node-events-pYrJmi9w.js → server-node-events-Q0cT2ifj.js} +2 -2
- package/dist/{server-node-events-DbS1jJ5j.js → server-node-events-YN5eJeHa.js} +2 -2
- package/dist/{session-DLTCuoUD.js → session-CnCwDJke.js} +8 -8
- package/dist/{skill-commands-BwTLQRR8.js → skill-commands-Cz45_nme.js} +9 -9
- package/dist/{skills-B9N2bqKU.js → skills-CdCS1HeL.js} +22 -22
- package/dist/slash-commands.runtime-CZz6v6b3.js +16 -0
- package/dist/{slash-dispatch.runtime-PX9_08Hm.js → slash-dispatch.runtime-BOMEVFk0.js} +1 -1
- package/dist/{slash-dispatch.runtime-DmFVOi3w.js → slash-dispatch.runtime-DB1QsBRc.js} +1 -1
- package/dist/slash-dispatch.runtime-SO7HOe8q.js +56 -0
- package/dist/{slash-dispatch.runtime-BGXbtMX6.js → slash-dispatch.runtime-sXaUYn4v.js} +6 -6
- package/dist/slash-skill-commands.runtime-Bawt7j0r.js +20 -0
- package/dist/{status-DtiapFqq.js → status-Bh5x6DsW.js} +2 -2
- package/dist/{status-B4eVRJcO.js → status-cU9cJReo.js} +2 -2
- package/dist/{store-CvQ41zCV.js → store-D9z0dn7D.js} +2 -2
- package/dist/{subagent-registry-Ctrhw4X-.js → subagent-registry-CIgFD2oi.js} +103 -6
- package/dist/{subagent-registry-runtime-CezPaX9P.js → subagent-registry-runtime-232sNNT6.js} +6 -6
- package/dist/subagent-registry-runtime-D2rUxU5J.js +56 -0
- package/dist/{subagent-registry-runtime-Cy7dsGqF.js → subagent-registry-runtime-D7ubAnDZ.js} +1 -1
- package/dist/{subagent-registry-runtime-CTjx4TK5.js → subagent-registry-runtime-DGTjU9Lb.js} +1 -1
- package/dist/{subsystem-BaLYRf7D.js → subsystem-6v7sWnAD.js} +14 -14
- package/dist/{tables-BRYYxYs7.js → tables-BTFiZyRU.js} +1 -1
- package/dist/{target-errors-D0ZJUbbf.js → target-errors-DgNRx3Nr.js} +2 -2
- package/dist/{thinking-B-A99X3F.js → thinking-B75CXkTT.js} +7 -7
- package/dist/{tokens-D2XhLqIz.js → tokens-DfbMVF9y.js} +1 -1
- package/dist/{tool-images-Zn6jVmkX.js → tool-images-Dp5OiXeA.js} +2 -2
- package/dist/{update-cli-_FsTRdQZ.js → update-cli-CktBOXZF.js} +7 -7
- package/dist/{update-cli-DLOWRdjv.js → update-cli-DM_dUip_.js} +8 -8
- package/dist/{update-runner-BY3l7ytB.js → update-runner-BBJZmfZ4.js} +1 -1
- package/dist/{update-runner-BKWHnVYI.js → update-runner-BYGPkHXG.js} +1 -1
- package/dist/{web-BdZ3mX3p.js → web-CZhZC1EA.js} +2 -2
- package/dist/{web-B46aOGK0.js → web-Chw1dtKA.js} +6 -6
- package/dist/{web-BNfDYvlW.js → web-DWRZAXj9.js} +2 -2
- package/dist/{web-1D0d1RHD.js → web-QsxgXbNK.js} +55 -55
- package/dist/{whatsapp-actions-Cuy0qeQK.js → whatsapp-actions-CzqsuSGx.js} +21 -21
- package/dist/{workspace-TqfVSQuO.js → workspace-kVMIaBrV.js} +20 -20
- package/extensions/acpx/node_modules/.bin/acpx +2 -2
- package/extensions/diagnostics-otel/node_modules/.bin/acorn +2 -2
- package/extensions/diffs/node_modules/.bin/playwright-core +2 -2
- package/extensions/googlechat/node_modules/.bin/squidclaw +2 -2
- package/extensions/matrix/node_modules/.bin/markdown-it +2 -2
- package/extensions/memory-core/node_modules/.bin/squidclaw +2 -2
- package/extensions/memory-lancedb/node_modules/.bin/arrow2csv +2 -2
- package/extensions/memory-lancedb/node_modules/.bin/openai +2 -2
- package/extensions/nostr/node_modules/.bin/tsc +2 -2
- package/extensions/nostr/node_modules/.bin/tsserver +2 -2
- package/extensions/tlon/node_modules/.bin/tlon +2 -2
- package/package.json +1 -1
- package/dist/api-key-rotation-TRwuCWbu.js +0 -181
- package/dist/canvas-host/a2ui/.bundle.hash +0 -1
- package/dist/deliver-runtime-_mBfV_4S.js +0 -36
- package/dist/deps-send-discord.runtime-CUTAK2hy.js +0 -26
- package/dist/deps-send-imessage.runtime-CQOiEIuA.js +0 -25
- package/dist/deps-send-signal.runtime-wN7MkzLw.js +0 -24
- package/dist/deps-send-slack.runtime-HEEwW4uU.js +0 -22
- package/dist/deps-send-telegram.runtime-DHlcnjQO.js +0 -27
- package/dist/deps-send-whatsapp.runtime-Cw7U9orE.js +0 -60
- package/dist/errors-DfgAh2Ml.js +0 -54
- package/dist/export-html/vendor/highlight.min.js +0 -1213
- package/dist/export-html/vendor/marked.min.js +0 -6
- package/dist/image-runtime-D11wBIC8.js +0 -29
- package/dist/manager-runtime-BB9lcoFR.js +0 -18
- package/dist/pi-model-discovery-runtime-DBkQoIJw.js +0 -11
- package/dist/plugin-sdk/accounts-CUEuUR3C.js +0 -46
- package/dist/plugin-sdk/accounts-D0W2pELU.js +0 -288
- package/dist/plugin-sdk/accounts-ucj0odJq.js +0 -35
- package/dist/plugin-sdk/active-listener-C5xPUSTb.js +0 -50
- package/dist/plugin-sdk/audio-preflight-Cqdo0JKm.js +0 -69
- package/dist/plugin-sdk/audio-transcription-runner-DnEooIyE.js +0 -2176
- package/dist/plugin-sdk/audit-membership-runtime-B9b-zRwg.js +0 -58
- package/dist/plugin-sdk/channel-activity-BMWLw4o2.js +0 -94
- package/dist/plugin-sdk/channel-web-D9WdAFlv.js +0 -2256
- package/dist/plugin-sdk/chrome-CV-q0Lmc.js +0 -2415
- package/dist/plugin-sdk/commands-registry-e7YoqrbP.js +0 -1125
- package/dist/plugin-sdk/config-B2B64aX0.js +0 -17911
- package/dist/plugin-sdk/deliver-BkyBtcLR.js +0 -1694
- package/dist/plugin-sdk/deliver-runtime-5UVcSskg.js +0 -32
- package/dist/plugin-sdk/deliver-runtime-O4lwAWMw.js +0 -32
- package/dist/plugin-sdk/deps-send-discord.runtime-BAeeBldY.js +0 -23
- package/dist/plugin-sdk/deps-send-discord.runtime-DTspXSCt.js +0 -23
- package/dist/plugin-sdk/deps-send-imessage.runtime-EL-CfikZ.js +0 -22
- package/dist/plugin-sdk/deps-send-imessage.runtime-qThAwDEe.js +0 -22
- package/dist/plugin-sdk/deps-send-signal.runtime-BeemHeUu.js +0 -21
- package/dist/plugin-sdk/deps-send-signal.runtime-DnjnVzZF.js +0 -21
- package/dist/plugin-sdk/deps-send-slack.runtime-CbKevLnv.js +0 -19
- package/dist/plugin-sdk/deps-send-slack.runtime-DTttkC0N.js +0 -19
- package/dist/plugin-sdk/deps-send-telegram.runtime-C6y29O9E.js +0 -24
- package/dist/plugin-sdk/deps-send-telegram.runtime-Dsf9Cnka.js +0 -24
- package/dist/plugin-sdk/deps-send-whatsapp.runtime-CCS71r77.js +0 -57
- package/dist/plugin-sdk/deps-send-whatsapp.runtime-CuxKhIE0.js +0 -57
- package/dist/plugin-sdk/diagnostic-DPRVoKTk.js +0 -319
- package/dist/plugin-sdk/fetch-guard-F0Fnqisy.js +0 -156
- package/dist/plugin-sdk/fs-safe-Dqmpk-Fr.js +0 -352
- package/dist/plugin-sdk/image-cBW8L8pp.js +0 -2310
- package/dist/plugin-sdk/image-ops-BP8ix1GC.js +0 -584
- package/dist/plugin-sdk/image-runtime-9xkgSlNz.js +0 -25
- package/dist/plugin-sdk/image-runtime-CpfepTDc.js +0 -25
- package/dist/plugin-sdk/ir-DWEc6zOp.js +0 -1296
- package/dist/plugin-sdk/local-roots-BIPT8uAO.js +0 -186
- package/dist/plugin-sdk/logger-DDdrdbDu.js +0 -1163
- package/dist/plugin-sdk/login-BMTiGutN.js +0 -57
- package/dist/plugin-sdk/login-qr-BFxqYUkc.js +0 -320
- package/dist/plugin-sdk/manager-BD-aYaZ8.js +0 -3917
- package/dist/plugin-sdk/manager-runtime-BmgTeb5G.js +0 -15
- package/dist/plugin-sdk/manager-runtime-C5bRwUlz.js +0 -15
- package/dist/plugin-sdk/outbound-Bm07xvO6.js +0 -212
- package/dist/plugin-sdk/outbound-attachment-DLsaxDsc.js +0 -19
- package/dist/plugin-sdk/path-alias-guards-gBhrAn14.js +0 -43
- package/dist/plugin-sdk/paths-C6W4VHoa.js +0 -166
- package/dist/plugin-sdk/pi-embedded-helpers-BExwPvTh.js +0 -9627
- package/dist/plugin-sdk/pi-model-discovery-DdctvBeX.js +0 -134
- package/dist/plugin-sdk/pi-model-discovery-runtime-COnuGwZt.js +0 -8
- package/dist/plugin-sdk/pi-model-discovery-runtime-DrtpLJjk.js +0 -8
- package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-rgTz3FBl.js +0 -354
- package/dist/plugin-sdk/plugins-BN64HHZA.js +0 -864
- package/dist/plugin-sdk/pw-ai-DBm3RdBK.js +0 -1938
- package/dist/plugin-sdk/qmd-manager-6bozlfFg.js +0 -1448
- package/dist/plugin-sdk/query-expansion-eeVz_aEm.js +0 -1011
- package/dist/plugin-sdk/redact-BoNEjbpF.js +0 -319
- package/dist/plugin-sdk/reply-CqXMy3Yd.js +0 -98731
- package/dist/plugin-sdk/resolve-outbound-target-DXfjGlZQ.js +0 -40
- package/dist/plugin-sdk/run-with-concurrency-5DMu9szx.js +0 -1994
- package/dist/plugin-sdk/runtime-whatsapp-login.runtime-99sCh8RG.js +0 -10
- package/dist/plugin-sdk/runtime-whatsapp-login.runtime-D2hkJBa-.js +0 -10
- package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-C06I4adi.js +0 -19
- package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-dTkDaXHl.js +0 -19
- package/dist/plugin-sdk/send-B9xnwtQ-.js +0 -540
- package/dist/plugin-sdk/send-BxySs-Cu.js +0 -2587
- package/dist/plugin-sdk/send-D9THKp_J.js +0 -414
- package/dist/plugin-sdk/send-DCuaaP2w.js +0 -503
- package/dist/plugin-sdk/send-Dm_-_xje.js +0 -3135
- package/dist/plugin-sdk/session-DDzIZHxt.js +0 -169
- package/dist/plugin-sdk/skill-commands-DRvqtuFC.js +0 -342
- package/dist/plugin-sdk/skills-BWwlfbVj.js +0 -1428
- package/dist/plugin-sdk/slash-commands.runtime-BzYsaTST.js +0 -13
- package/dist/plugin-sdk/slash-commands.runtime-EAZKpRKq.js +0 -13
- package/dist/plugin-sdk/slash-dispatch.runtime-BC3IAF-I.js +0 -52
- package/dist/plugin-sdk/slash-dispatch.runtime-C7u7mlny.js +0 -52
- package/dist/plugin-sdk/slash-skill-commands.runtime-DGd_JSWX.js +0 -16
- package/dist/plugin-sdk/slash-skill-commands.runtime-sg98L8BK.js +0 -16
- package/dist/plugin-sdk/ssrf-DOBwjFow.js +0 -202
- package/dist/plugin-sdk/store-BKDR_-Qk.js +0 -81
- package/dist/plugin-sdk/subagent-registry-runtime-B6l6PxqP.js +0 -52
- package/dist/plugin-sdk/subagent-registry-runtime-Ceu7AzWi.js +0 -52
- package/dist/plugin-sdk/tables-GIj79us5.js +0 -55
- package/dist/plugin-sdk/target-errors-jlLHihbX.js +0 -195
- package/dist/plugin-sdk/thinking-BgdUnMZ2.js +0 -1206
- package/dist/plugin-sdk/tokens-CLE20fRI.js +0 -52
- package/dist/plugin-sdk/tool-images-BY1gsRyE.js +0 -274
- package/dist/plugin-sdk/web-BK2-uaOo.js +0 -56
- package/dist/plugin-sdk/web-Bnn82S4u.js +0 -56
- package/dist/plugin-sdk/whatsapp-actions-DQpK_5Ds.js +0 -80
- package/dist/proxy-fetch-C2v-Utgg.js +0 -38
- package/dist/runtime-whatsapp-login.runtime-DumUjKRz.js +0 -13
- package/dist/runtime-whatsapp-outbound.runtime-Cgu2MfqR.js +0 -22
- package/dist/slash-commands.runtime-CjBXruwG.js +0 -16
- package/dist/slash-dispatch.runtime-DqZVfX4H.js +0 -56
- package/dist/slash-skill-commands.runtime-DYK20Lxf.js +0 -20
- package/dist/subagent-registry-runtime-BIKGAzgI.js +0 -56
- package/docs/reference/templates/IDENTITY.md +0 -29
- package/docs/reference/templates/USER.md +0 -23
- package/docs/zh-CN/reference/templates/IDENTITY.md +0 -36
- package/docs/zh-CN/reference/templates/USER.md +0 -30
- package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +0 -178
|
@@ -1,1125 +0,0 @@
|
|
|
1
|
-
import { Jr as DEFAULT_MODEL, Mn as resolveConfiguredModelRef, Yr as DEFAULT_PROVIDER, wt as getActivePluginRegistry } from "./config-B2B64aX0.js";
|
|
2
|
-
import { P as isPlainObject, _ as escapeRegExp } from "./logger-DDdrdbDu.js";
|
|
3
|
-
import { f as listChannelDocks, r as listThinkingLevels } from "./thinking-BgdUnMZ2.js";
|
|
4
|
-
import { r as normalizeChannelId } from "./plugins-BN64HHZA.js";
|
|
5
|
-
|
|
6
|
-
//#region src/config/commands.ts
|
|
7
|
-
function resolveAutoDefault(providerId) {
|
|
8
|
-
const id = normalizeChannelId(providerId);
|
|
9
|
-
if (!id) return false;
|
|
10
|
-
if (id === "discord" || id === "telegram") return true;
|
|
11
|
-
if (id === "slack") return false;
|
|
12
|
-
return false;
|
|
13
|
-
}
|
|
14
|
-
function resolveNativeSkillsEnabled(params) {
|
|
15
|
-
return resolveNativeCommandSetting(params);
|
|
16
|
-
}
|
|
17
|
-
function resolveNativeCommandsEnabled(params) {
|
|
18
|
-
return resolveNativeCommandSetting(params);
|
|
19
|
-
}
|
|
20
|
-
function resolveNativeCommandSetting(params) {
|
|
21
|
-
const { providerId, providerSetting, globalSetting } = params;
|
|
22
|
-
const setting = providerSetting === void 0 ? globalSetting : providerSetting;
|
|
23
|
-
if (setting === true) return true;
|
|
24
|
-
if (setting === false) return false;
|
|
25
|
-
return resolveAutoDefault(providerId);
|
|
26
|
-
}
|
|
27
|
-
function isNativeCommandsExplicitlyDisabled(params) {
|
|
28
|
-
const { providerSetting, globalSetting } = params;
|
|
29
|
-
if (providerSetting === false) return true;
|
|
30
|
-
if (providerSetting === void 0) return globalSetting === false;
|
|
31
|
-
return false;
|
|
32
|
-
}
|
|
33
|
-
function getOwnCommandFlagValue(config, key) {
|
|
34
|
-
const { commands } = config ?? {};
|
|
35
|
-
if (!isPlainObject(commands) || !Object.hasOwn(commands, key)) return;
|
|
36
|
-
return commands[key];
|
|
37
|
-
}
|
|
38
|
-
function isCommandFlagEnabled(config, key) {
|
|
39
|
-
return getOwnCommandFlagValue(config, key) === true;
|
|
40
|
-
}
|
|
41
|
-
function isRestartEnabled(config) {
|
|
42
|
-
return getOwnCommandFlagValue(config, "restart") !== false;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
//#endregion
|
|
46
|
-
//#region src/auto-reply/commands-args.ts
|
|
47
|
-
function normalizeArgValue(value) {
|
|
48
|
-
if (value == null) return;
|
|
49
|
-
let text;
|
|
50
|
-
if (typeof value === "string") text = value.trim();
|
|
51
|
-
else if (typeof value === "number" || typeof value === "boolean" || typeof value === "bigint") text = String(value).trim();
|
|
52
|
-
else if (typeof value === "symbol") text = value.toString().trim();
|
|
53
|
-
else if (typeof value === "function") text = value.toString().trim();
|
|
54
|
-
else text = JSON.stringify(value);
|
|
55
|
-
return text ? text : void 0;
|
|
56
|
-
}
|
|
57
|
-
function formatActionArgs(values, params) {
|
|
58
|
-
const action = normalizeArgValue(values.action)?.toLowerCase();
|
|
59
|
-
const path = normalizeArgValue(values.path);
|
|
60
|
-
const value = normalizeArgValue(values.value);
|
|
61
|
-
if (!action) return;
|
|
62
|
-
const knownAction = params.formatKnownAction(action, path);
|
|
63
|
-
if (knownAction) return knownAction;
|
|
64
|
-
return formatSetUnsetArgAction(action, {
|
|
65
|
-
path,
|
|
66
|
-
value
|
|
67
|
-
});
|
|
68
|
-
}
|
|
69
|
-
const formatConfigArgs = (values) => formatActionArgs(values, { formatKnownAction: (action, path) => {
|
|
70
|
-
if (action === "show" || action === "get") return path ? `${action} ${path}` : action;
|
|
71
|
-
} });
|
|
72
|
-
const formatDebugArgs = (values) => formatActionArgs(values, { formatKnownAction: (action) => {
|
|
73
|
-
if (action === "show" || action === "reset") return action;
|
|
74
|
-
} });
|
|
75
|
-
function formatSetUnsetArgAction(action, params) {
|
|
76
|
-
if (action === "unset") return params.path ? `${action} ${params.path}` : action;
|
|
77
|
-
if (action === "set") {
|
|
78
|
-
if (!params.path) return action;
|
|
79
|
-
if (!params.value) return `${action} ${params.path}`;
|
|
80
|
-
return `${action} ${params.path}=${params.value}`;
|
|
81
|
-
}
|
|
82
|
-
return action;
|
|
83
|
-
}
|
|
84
|
-
const formatQueueArgs = (values) => {
|
|
85
|
-
const mode = normalizeArgValue(values.mode);
|
|
86
|
-
const debounce = normalizeArgValue(values.debounce);
|
|
87
|
-
const cap = normalizeArgValue(values.cap);
|
|
88
|
-
const drop = normalizeArgValue(values.drop);
|
|
89
|
-
const parts = [];
|
|
90
|
-
if (mode) parts.push(mode);
|
|
91
|
-
if (debounce) parts.push(`debounce:${debounce}`);
|
|
92
|
-
if (cap) parts.push(`cap:${cap}`);
|
|
93
|
-
if (drop) parts.push(`drop:${drop}`);
|
|
94
|
-
return parts.length > 0 ? parts.join(" ") : void 0;
|
|
95
|
-
};
|
|
96
|
-
const formatExecArgs = (values) => {
|
|
97
|
-
const host = normalizeArgValue(values.host);
|
|
98
|
-
const security = normalizeArgValue(values.security);
|
|
99
|
-
const ask = normalizeArgValue(values.ask);
|
|
100
|
-
const node = normalizeArgValue(values.node);
|
|
101
|
-
const parts = [];
|
|
102
|
-
if (host) parts.push(`host=${host}`);
|
|
103
|
-
if (security) parts.push(`security=${security}`);
|
|
104
|
-
if (ask) parts.push(`ask=${ask}`);
|
|
105
|
-
if (node) parts.push(`node=${node}`);
|
|
106
|
-
return parts.length > 0 ? parts.join(" ") : void 0;
|
|
107
|
-
};
|
|
108
|
-
const COMMAND_ARG_FORMATTERS = {
|
|
109
|
-
config: formatConfigArgs,
|
|
110
|
-
debug: formatDebugArgs,
|
|
111
|
-
queue: formatQueueArgs,
|
|
112
|
-
exec: formatExecArgs
|
|
113
|
-
};
|
|
114
|
-
|
|
115
|
-
//#endregion
|
|
116
|
-
//#region src/auto-reply/commands-registry.data.ts
|
|
117
|
-
function defineChatCommand(command) {
|
|
118
|
-
const aliases = (command.textAliases ?? (command.textAlias ? [command.textAlias] : [])).map((alias) => alias.trim()).filter(Boolean);
|
|
119
|
-
const scope = command.scope ?? (command.nativeName ? aliases.length ? "both" : "native" : "text");
|
|
120
|
-
const acceptsArgs = command.acceptsArgs ?? Boolean(command.args?.length);
|
|
121
|
-
const argsParsing = command.argsParsing ?? (command.args?.length ? "positional" : "none");
|
|
122
|
-
return {
|
|
123
|
-
key: command.key,
|
|
124
|
-
nativeName: command.nativeName,
|
|
125
|
-
description: command.description,
|
|
126
|
-
acceptsArgs,
|
|
127
|
-
args: command.args,
|
|
128
|
-
argsParsing,
|
|
129
|
-
formatArgs: command.formatArgs,
|
|
130
|
-
argsMenu: command.argsMenu,
|
|
131
|
-
textAliases: aliases,
|
|
132
|
-
scope,
|
|
133
|
-
category: command.category
|
|
134
|
-
};
|
|
135
|
-
}
|
|
136
|
-
function defineDockCommand(dock) {
|
|
137
|
-
return defineChatCommand({
|
|
138
|
-
key: `dock:${dock.id}`,
|
|
139
|
-
nativeName: `dock_${dock.id}`,
|
|
140
|
-
description: `Switch to ${dock.id} for replies.`,
|
|
141
|
-
textAliases: [`/dock-${dock.id}`, `/dock_${dock.id}`],
|
|
142
|
-
category: "docks"
|
|
143
|
-
});
|
|
144
|
-
}
|
|
145
|
-
function registerAlias(commands, key, ...aliases) {
|
|
146
|
-
const command = commands.find((entry) => entry.key === key);
|
|
147
|
-
if (!command) throw new Error(`registerAlias: unknown command key: ${key}`);
|
|
148
|
-
const existing = new Set(command.textAliases.map((alias) => alias.trim().toLowerCase()));
|
|
149
|
-
for (const alias of aliases) {
|
|
150
|
-
const trimmed = alias.trim();
|
|
151
|
-
if (!trimmed) continue;
|
|
152
|
-
const lowered = trimmed.toLowerCase();
|
|
153
|
-
if (existing.has(lowered)) continue;
|
|
154
|
-
existing.add(lowered);
|
|
155
|
-
command.textAliases.push(trimmed);
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
function assertCommandRegistry(commands) {
|
|
159
|
-
const keys = /* @__PURE__ */ new Set();
|
|
160
|
-
const nativeNames = /* @__PURE__ */ new Set();
|
|
161
|
-
const textAliases = /* @__PURE__ */ new Set();
|
|
162
|
-
for (const command of commands) {
|
|
163
|
-
if (keys.has(command.key)) throw new Error(`Duplicate command key: ${command.key}`);
|
|
164
|
-
keys.add(command.key);
|
|
165
|
-
const nativeName = command.nativeName?.trim();
|
|
166
|
-
if (command.scope === "text") {
|
|
167
|
-
if (nativeName) throw new Error(`Text-only command has native name: ${command.key}`);
|
|
168
|
-
if (command.textAliases.length === 0) throw new Error(`Text-only command missing text alias: ${command.key}`);
|
|
169
|
-
} else if (!nativeName) throw new Error(`Native command missing native name: ${command.key}`);
|
|
170
|
-
else {
|
|
171
|
-
const nativeKey = nativeName.toLowerCase();
|
|
172
|
-
if (nativeNames.has(nativeKey)) throw new Error(`Duplicate native command: ${nativeName}`);
|
|
173
|
-
nativeNames.add(nativeKey);
|
|
174
|
-
}
|
|
175
|
-
if (command.scope === "native" && command.textAliases.length > 0) throw new Error(`Native-only command has text aliases: ${command.key}`);
|
|
176
|
-
for (const alias of command.textAliases) {
|
|
177
|
-
if (!alias.startsWith("/")) throw new Error(`Command alias missing leading '/': ${alias}`);
|
|
178
|
-
const aliasKey = alias.toLowerCase();
|
|
179
|
-
if (textAliases.has(aliasKey)) throw new Error(`Duplicate command alias: ${alias}`);
|
|
180
|
-
textAliases.add(aliasKey);
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
let cachedCommands = null;
|
|
185
|
-
let cachedRegistry = null;
|
|
186
|
-
let cachedNativeCommandSurfaces = null;
|
|
187
|
-
let cachedNativeRegistry = null;
|
|
188
|
-
function buildChatCommands() {
|
|
189
|
-
const commands = [
|
|
190
|
-
defineChatCommand({
|
|
191
|
-
key: "help",
|
|
192
|
-
nativeName: "help",
|
|
193
|
-
description: "Show available commands.",
|
|
194
|
-
textAlias: "/help",
|
|
195
|
-
category: "status"
|
|
196
|
-
}),
|
|
197
|
-
defineChatCommand({
|
|
198
|
-
key: "commands",
|
|
199
|
-
nativeName: "commands",
|
|
200
|
-
description: "List all slash commands.",
|
|
201
|
-
textAlias: "/commands",
|
|
202
|
-
category: "status"
|
|
203
|
-
}),
|
|
204
|
-
defineChatCommand({
|
|
205
|
-
key: "skill",
|
|
206
|
-
nativeName: "skill",
|
|
207
|
-
description: "Run a skill by name.",
|
|
208
|
-
textAlias: "/skill",
|
|
209
|
-
category: "tools",
|
|
210
|
-
args: [{
|
|
211
|
-
name: "name",
|
|
212
|
-
description: "Skill name",
|
|
213
|
-
type: "string",
|
|
214
|
-
required: true
|
|
215
|
-
}, {
|
|
216
|
-
name: "input",
|
|
217
|
-
description: "Skill input",
|
|
218
|
-
type: "string",
|
|
219
|
-
captureRemaining: true
|
|
220
|
-
}]
|
|
221
|
-
}),
|
|
222
|
-
defineChatCommand({
|
|
223
|
-
key: "status",
|
|
224
|
-
nativeName: "status",
|
|
225
|
-
description: "Show current status.",
|
|
226
|
-
textAlias: "/status",
|
|
227
|
-
category: "status"
|
|
228
|
-
}),
|
|
229
|
-
defineChatCommand({
|
|
230
|
-
key: "allowlist",
|
|
231
|
-
description: "List/add/remove allowlist entries.",
|
|
232
|
-
textAlias: "/allowlist",
|
|
233
|
-
acceptsArgs: true,
|
|
234
|
-
scope: "text",
|
|
235
|
-
category: "management"
|
|
236
|
-
}),
|
|
237
|
-
defineChatCommand({
|
|
238
|
-
key: "approve",
|
|
239
|
-
nativeName: "approve",
|
|
240
|
-
description: "Approve or deny exec requests.",
|
|
241
|
-
textAlias: "/approve",
|
|
242
|
-
acceptsArgs: true,
|
|
243
|
-
category: "management"
|
|
244
|
-
}),
|
|
245
|
-
defineChatCommand({
|
|
246
|
-
key: "context",
|
|
247
|
-
nativeName: "context",
|
|
248
|
-
description: "Explain how context is built and used.",
|
|
249
|
-
textAlias: "/context",
|
|
250
|
-
acceptsArgs: true,
|
|
251
|
-
category: "status"
|
|
252
|
-
}),
|
|
253
|
-
defineChatCommand({
|
|
254
|
-
key: "export-session",
|
|
255
|
-
nativeName: "export-session",
|
|
256
|
-
description: "Export current session to HTML file with full system prompt.",
|
|
257
|
-
textAliases: ["/export-session", "/export"],
|
|
258
|
-
acceptsArgs: true,
|
|
259
|
-
category: "status",
|
|
260
|
-
args: [{
|
|
261
|
-
name: "path",
|
|
262
|
-
description: "Output path (default: workspace)",
|
|
263
|
-
type: "string",
|
|
264
|
-
required: false
|
|
265
|
-
}]
|
|
266
|
-
}),
|
|
267
|
-
defineChatCommand({
|
|
268
|
-
key: "tts",
|
|
269
|
-
nativeName: "tts",
|
|
270
|
-
description: "Control text-to-speech (TTS).",
|
|
271
|
-
textAlias: "/tts",
|
|
272
|
-
category: "media",
|
|
273
|
-
args: [{
|
|
274
|
-
name: "action",
|
|
275
|
-
description: "TTS action",
|
|
276
|
-
type: "string",
|
|
277
|
-
choices: [
|
|
278
|
-
{
|
|
279
|
-
value: "on",
|
|
280
|
-
label: "On"
|
|
281
|
-
},
|
|
282
|
-
{
|
|
283
|
-
value: "off",
|
|
284
|
-
label: "Off"
|
|
285
|
-
},
|
|
286
|
-
{
|
|
287
|
-
value: "status",
|
|
288
|
-
label: "Status"
|
|
289
|
-
},
|
|
290
|
-
{
|
|
291
|
-
value: "provider",
|
|
292
|
-
label: "Provider"
|
|
293
|
-
},
|
|
294
|
-
{
|
|
295
|
-
value: "limit",
|
|
296
|
-
label: "Limit"
|
|
297
|
-
},
|
|
298
|
-
{
|
|
299
|
-
value: "summary",
|
|
300
|
-
label: "Summary"
|
|
301
|
-
},
|
|
302
|
-
{
|
|
303
|
-
value: "audio",
|
|
304
|
-
label: "Audio"
|
|
305
|
-
},
|
|
306
|
-
{
|
|
307
|
-
value: "help",
|
|
308
|
-
label: "Help"
|
|
309
|
-
}
|
|
310
|
-
]
|
|
311
|
-
}, {
|
|
312
|
-
name: "value",
|
|
313
|
-
description: "Provider, limit, or text",
|
|
314
|
-
type: "string",
|
|
315
|
-
captureRemaining: true
|
|
316
|
-
}],
|
|
317
|
-
argsMenu: {
|
|
318
|
-
arg: "action",
|
|
319
|
-
title: "TTS Actions:\n• On – Enable TTS for responses\n• Off – Disable TTS\n• Status – Show current settings\n• Provider – Set voice provider (edge, elevenlabs, openai)\n• Limit – Set max characters for TTS\n• Summary – Toggle AI summary for long texts\n• Audio – Generate TTS from custom text\n• Help – Show usage guide"
|
|
320
|
-
}
|
|
321
|
-
}),
|
|
322
|
-
defineChatCommand({
|
|
323
|
-
key: "whoami",
|
|
324
|
-
nativeName: "whoami",
|
|
325
|
-
description: "Show your sender id.",
|
|
326
|
-
textAlias: "/whoami",
|
|
327
|
-
category: "status"
|
|
328
|
-
}),
|
|
329
|
-
defineChatCommand({
|
|
330
|
-
key: "session",
|
|
331
|
-
nativeName: "session",
|
|
332
|
-
description: "Manage session-level settings (for example /session idle).",
|
|
333
|
-
textAlias: "/session",
|
|
334
|
-
category: "session",
|
|
335
|
-
args: [{
|
|
336
|
-
name: "action",
|
|
337
|
-
description: "idle | max-age",
|
|
338
|
-
type: "string",
|
|
339
|
-
choices: ["idle", "max-age"]
|
|
340
|
-
}, {
|
|
341
|
-
name: "value",
|
|
342
|
-
description: "Duration (24h, 90m) or off",
|
|
343
|
-
type: "string",
|
|
344
|
-
captureRemaining: true
|
|
345
|
-
}],
|
|
346
|
-
argsMenu: "auto"
|
|
347
|
-
}),
|
|
348
|
-
defineChatCommand({
|
|
349
|
-
key: "subagents",
|
|
350
|
-
nativeName: "subagents",
|
|
351
|
-
description: "List, kill, log, spawn, or steer subagent runs for this session.",
|
|
352
|
-
textAlias: "/subagents",
|
|
353
|
-
category: "management",
|
|
354
|
-
args: [
|
|
355
|
-
{
|
|
356
|
-
name: "action",
|
|
357
|
-
description: "list | kill | log | info | send | steer | spawn",
|
|
358
|
-
type: "string",
|
|
359
|
-
choices: [
|
|
360
|
-
"list",
|
|
361
|
-
"kill",
|
|
362
|
-
"log",
|
|
363
|
-
"info",
|
|
364
|
-
"send",
|
|
365
|
-
"steer",
|
|
366
|
-
"spawn"
|
|
367
|
-
]
|
|
368
|
-
},
|
|
369
|
-
{
|
|
370
|
-
name: "target",
|
|
371
|
-
description: "Run id, index, or session key",
|
|
372
|
-
type: "string"
|
|
373
|
-
},
|
|
374
|
-
{
|
|
375
|
-
name: "value",
|
|
376
|
-
description: "Additional input (limit/message)",
|
|
377
|
-
type: "string",
|
|
378
|
-
captureRemaining: true
|
|
379
|
-
}
|
|
380
|
-
],
|
|
381
|
-
argsMenu: "auto"
|
|
382
|
-
}),
|
|
383
|
-
defineChatCommand({
|
|
384
|
-
key: "acp",
|
|
385
|
-
nativeName: "acp",
|
|
386
|
-
description: "Manage ACP sessions and runtime options.",
|
|
387
|
-
textAlias: "/acp",
|
|
388
|
-
category: "management",
|
|
389
|
-
args: [{
|
|
390
|
-
name: "action",
|
|
391
|
-
description: "Action to run",
|
|
392
|
-
type: "string",
|
|
393
|
-
preferAutocomplete: true,
|
|
394
|
-
choices: [
|
|
395
|
-
"spawn",
|
|
396
|
-
"cancel",
|
|
397
|
-
"steer",
|
|
398
|
-
"close",
|
|
399
|
-
"sessions",
|
|
400
|
-
"status",
|
|
401
|
-
"set-mode",
|
|
402
|
-
"set",
|
|
403
|
-
"cwd",
|
|
404
|
-
"permissions",
|
|
405
|
-
"timeout",
|
|
406
|
-
"model",
|
|
407
|
-
"reset-options",
|
|
408
|
-
"doctor",
|
|
409
|
-
"install",
|
|
410
|
-
"help"
|
|
411
|
-
]
|
|
412
|
-
}, {
|
|
413
|
-
name: "value",
|
|
414
|
-
description: "Action arguments",
|
|
415
|
-
type: "string",
|
|
416
|
-
captureRemaining: true
|
|
417
|
-
}],
|
|
418
|
-
argsMenu: "auto"
|
|
419
|
-
}),
|
|
420
|
-
defineChatCommand({
|
|
421
|
-
key: "focus",
|
|
422
|
-
nativeName: "focus",
|
|
423
|
-
description: "Bind this Discord thread (or a new one) to a session target.",
|
|
424
|
-
textAlias: "/focus",
|
|
425
|
-
category: "management",
|
|
426
|
-
args: [{
|
|
427
|
-
name: "target",
|
|
428
|
-
description: "Subagent label/index or session key/id/label",
|
|
429
|
-
type: "string",
|
|
430
|
-
captureRemaining: true
|
|
431
|
-
}]
|
|
432
|
-
}),
|
|
433
|
-
defineChatCommand({
|
|
434
|
-
key: "unfocus",
|
|
435
|
-
nativeName: "unfocus",
|
|
436
|
-
description: "Remove the current Discord thread binding.",
|
|
437
|
-
textAlias: "/unfocus",
|
|
438
|
-
category: "management"
|
|
439
|
-
}),
|
|
440
|
-
defineChatCommand({
|
|
441
|
-
key: "agents",
|
|
442
|
-
nativeName: "agents",
|
|
443
|
-
description: "List thread-bound agents for this session.",
|
|
444
|
-
textAlias: "/agents",
|
|
445
|
-
category: "management"
|
|
446
|
-
}),
|
|
447
|
-
defineChatCommand({
|
|
448
|
-
key: "kill",
|
|
449
|
-
nativeName: "kill",
|
|
450
|
-
description: "Kill a running subagent (or all).",
|
|
451
|
-
textAlias: "/kill",
|
|
452
|
-
category: "management",
|
|
453
|
-
args: [{
|
|
454
|
-
name: "target",
|
|
455
|
-
description: "Label, run id, index, or all",
|
|
456
|
-
type: "string"
|
|
457
|
-
}],
|
|
458
|
-
argsMenu: "auto"
|
|
459
|
-
}),
|
|
460
|
-
defineChatCommand({
|
|
461
|
-
key: "steer",
|
|
462
|
-
nativeName: "steer",
|
|
463
|
-
description: "Send guidance to a running subagent.",
|
|
464
|
-
textAlias: "/steer",
|
|
465
|
-
category: "management",
|
|
466
|
-
args: [{
|
|
467
|
-
name: "target",
|
|
468
|
-
description: "Label, run id, or index",
|
|
469
|
-
type: "string"
|
|
470
|
-
}, {
|
|
471
|
-
name: "message",
|
|
472
|
-
description: "Steering message",
|
|
473
|
-
type: "string",
|
|
474
|
-
captureRemaining: true
|
|
475
|
-
}]
|
|
476
|
-
}),
|
|
477
|
-
defineChatCommand({
|
|
478
|
-
key: "config",
|
|
479
|
-
nativeName: "config",
|
|
480
|
-
description: "Show or set config values.",
|
|
481
|
-
textAlias: "/config",
|
|
482
|
-
category: "management",
|
|
483
|
-
args: [
|
|
484
|
-
{
|
|
485
|
-
name: "action",
|
|
486
|
-
description: "show | get | set | unset",
|
|
487
|
-
type: "string",
|
|
488
|
-
choices: [
|
|
489
|
-
"show",
|
|
490
|
-
"get",
|
|
491
|
-
"set",
|
|
492
|
-
"unset"
|
|
493
|
-
]
|
|
494
|
-
},
|
|
495
|
-
{
|
|
496
|
-
name: "path",
|
|
497
|
-
description: "Config path",
|
|
498
|
-
type: "string"
|
|
499
|
-
},
|
|
500
|
-
{
|
|
501
|
-
name: "value",
|
|
502
|
-
description: "Value for set",
|
|
503
|
-
type: "string",
|
|
504
|
-
captureRemaining: true
|
|
505
|
-
}
|
|
506
|
-
],
|
|
507
|
-
argsParsing: "none",
|
|
508
|
-
formatArgs: COMMAND_ARG_FORMATTERS.config
|
|
509
|
-
}),
|
|
510
|
-
defineChatCommand({
|
|
511
|
-
key: "debug",
|
|
512
|
-
nativeName: "debug",
|
|
513
|
-
description: "Set runtime debug overrides.",
|
|
514
|
-
textAlias: "/debug",
|
|
515
|
-
category: "management",
|
|
516
|
-
args: [
|
|
517
|
-
{
|
|
518
|
-
name: "action",
|
|
519
|
-
description: "show | reset | set | unset",
|
|
520
|
-
type: "string",
|
|
521
|
-
choices: [
|
|
522
|
-
"show",
|
|
523
|
-
"reset",
|
|
524
|
-
"set",
|
|
525
|
-
"unset"
|
|
526
|
-
]
|
|
527
|
-
},
|
|
528
|
-
{
|
|
529
|
-
name: "path",
|
|
530
|
-
description: "Debug path",
|
|
531
|
-
type: "string"
|
|
532
|
-
},
|
|
533
|
-
{
|
|
534
|
-
name: "value",
|
|
535
|
-
description: "Value for set",
|
|
536
|
-
type: "string",
|
|
537
|
-
captureRemaining: true
|
|
538
|
-
}
|
|
539
|
-
],
|
|
540
|
-
argsParsing: "none",
|
|
541
|
-
formatArgs: COMMAND_ARG_FORMATTERS.debug
|
|
542
|
-
}),
|
|
543
|
-
defineChatCommand({
|
|
544
|
-
key: "usage",
|
|
545
|
-
nativeName: "usage",
|
|
546
|
-
description: "Usage footer or cost summary.",
|
|
547
|
-
textAlias: "/usage",
|
|
548
|
-
category: "options",
|
|
549
|
-
args: [{
|
|
550
|
-
name: "mode",
|
|
551
|
-
description: "off, tokens, full, or cost",
|
|
552
|
-
type: "string",
|
|
553
|
-
choices: [
|
|
554
|
-
"off",
|
|
555
|
-
"tokens",
|
|
556
|
-
"full",
|
|
557
|
-
"cost"
|
|
558
|
-
]
|
|
559
|
-
}],
|
|
560
|
-
argsMenu: "auto"
|
|
561
|
-
}),
|
|
562
|
-
defineChatCommand({
|
|
563
|
-
key: "stop",
|
|
564
|
-
nativeName: "stop",
|
|
565
|
-
description: "Stop the current run.",
|
|
566
|
-
textAlias: "/stop",
|
|
567
|
-
category: "session"
|
|
568
|
-
}),
|
|
569
|
-
defineChatCommand({
|
|
570
|
-
key: "restart",
|
|
571
|
-
nativeName: "restart",
|
|
572
|
-
description: "Restart SquidClaw.",
|
|
573
|
-
textAlias: "/restart",
|
|
574
|
-
category: "tools"
|
|
575
|
-
}),
|
|
576
|
-
defineChatCommand({
|
|
577
|
-
key: "activation",
|
|
578
|
-
nativeName: "activation",
|
|
579
|
-
description: "Set group activation mode.",
|
|
580
|
-
textAlias: "/activation",
|
|
581
|
-
category: "management",
|
|
582
|
-
args: [{
|
|
583
|
-
name: "mode",
|
|
584
|
-
description: "mention or always",
|
|
585
|
-
type: "string",
|
|
586
|
-
choices: ["mention", "always"]
|
|
587
|
-
}],
|
|
588
|
-
argsMenu: "auto"
|
|
589
|
-
}),
|
|
590
|
-
defineChatCommand({
|
|
591
|
-
key: "send",
|
|
592
|
-
nativeName: "send",
|
|
593
|
-
description: "Set send policy.",
|
|
594
|
-
textAlias: "/send",
|
|
595
|
-
category: "management",
|
|
596
|
-
args: [{
|
|
597
|
-
name: "mode",
|
|
598
|
-
description: "on, off, or inherit",
|
|
599
|
-
type: "string",
|
|
600
|
-
choices: [
|
|
601
|
-
"on",
|
|
602
|
-
"off",
|
|
603
|
-
"inherit"
|
|
604
|
-
]
|
|
605
|
-
}],
|
|
606
|
-
argsMenu: "auto"
|
|
607
|
-
}),
|
|
608
|
-
defineChatCommand({
|
|
609
|
-
key: "reset",
|
|
610
|
-
nativeName: "reset",
|
|
611
|
-
description: "Reset the current session.",
|
|
612
|
-
textAlias: "/reset",
|
|
613
|
-
acceptsArgs: true,
|
|
614
|
-
category: "session"
|
|
615
|
-
}),
|
|
616
|
-
defineChatCommand({
|
|
617
|
-
key: "new",
|
|
618
|
-
nativeName: "new",
|
|
619
|
-
description: "Start a new session.",
|
|
620
|
-
textAlias: "/new",
|
|
621
|
-
acceptsArgs: true,
|
|
622
|
-
category: "session"
|
|
623
|
-
}),
|
|
624
|
-
defineChatCommand({
|
|
625
|
-
key: "compact",
|
|
626
|
-
nativeName: "compact",
|
|
627
|
-
description: "Compact the session context.",
|
|
628
|
-
textAlias: "/compact",
|
|
629
|
-
category: "session",
|
|
630
|
-
args: [{
|
|
631
|
-
name: "instructions",
|
|
632
|
-
description: "Extra compaction instructions",
|
|
633
|
-
type: "string",
|
|
634
|
-
captureRemaining: true
|
|
635
|
-
}]
|
|
636
|
-
}),
|
|
637
|
-
defineChatCommand({
|
|
638
|
-
key: "think",
|
|
639
|
-
nativeName: "think",
|
|
640
|
-
description: "Set thinking level.",
|
|
641
|
-
textAlias: "/think",
|
|
642
|
-
category: "options",
|
|
643
|
-
args: [{
|
|
644
|
-
name: "level",
|
|
645
|
-
description: "off, minimal, low, medium, high, xhigh",
|
|
646
|
-
type: "string",
|
|
647
|
-
choices: ({ provider, model }) => listThinkingLevels(provider, model)
|
|
648
|
-
}],
|
|
649
|
-
argsMenu: "auto"
|
|
650
|
-
}),
|
|
651
|
-
defineChatCommand({
|
|
652
|
-
key: "verbose",
|
|
653
|
-
nativeName: "verbose",
|
|
654
|
-
description: "Toggle verbose mode.",
|
|
655
|
-
textAlias: "/verbose",
|
|
656
|
-
category: "options",
|
|
657
|
-
args: [{
|
|
658
|
-
name: "mode",
|
|
659
|
-
description: "on or off",
|
|
660
|
-
type: "string",
|
|
661
|
-
choices: ["on", "off"]
|
|
662
|
-
}],
|
|
663
|
-
argsMenu: "auto"
|
|
664
|
-
}),
|
|
665
|
-
defineChatCommand({
|
|
666
|
-
key: "reasoning",
|
|
667
|
-
nativeName: "reasoning",
|
|
668
|
-
description: "Toggle reasoning visibility.",
|
|
669
|
-
textAlias: "/reasoning",
|
|
670
|
-
category: "options",
|
|
671
|
-
args: [{
|
|
672
|
-
name: "mode",
|
|
673
|
-
description: "on, off, or stream",
|
|
674
|
-
type: "string",
|
|
675
|
-
choices: [
|
|
676
|
-
"on",
|
|
677
|
-
"off",
|
|
678
|
-
"stream"
|
|
679
|
-
]
|
|
680
|
-
}],
|
|
681
|
-
argsMenu: "auto"
|
|
682
|
-
}),
|
|
683
|
-
defineChatCommand({
|
|
684
|
-
key: "elevated",
|
|
685
|
-
nativeName: "elevated",
|
|
686
|
-
description: "Toggle elevated mode.",
|
|
687
|
-
textAlias: "/elevated",
|
|
688
|
-
category: "options",
|
|
689
|
-
args: [{
|
|
690
|
-
name: "mode",
|
|
691
|
-
description: "on, off, ask, or full",
|
|
692
|
-
type: "string",
|
|
693
|
-
choices: [
|
|
694
|
-
"on",
|
|
695
|
-
"off",
|
|
696
|
-
"ask",
|
|
697
|
-
"full"
|
|
698
|
-
]
|
|
699
|
-
}],
|
|
700
|
-
argsMenu: "auto"
|
|
701
|
-
}),
|
|
702
|
-
defineChatCommand({
|
|
703
|
-
key: "exec",
|
|
704
|
-
nativeName: "exec",
|
|
705
|
-
description: "Set exec defaults for this session.",
|
|
706
|
-
textAlias: "/exec",
|
|
707
|
-
category: "options",
|
|
708
|
-
args: [
|
|
709
|
-
{
|
|
710
|
-
name: "host",
|
|
711
|
-
description: "sandbox, gateway, or node",
|
|
712
|
-
type: "string",
|
|
713
|
-
choices: [
|
|
714
|
-
"sandbox",
|
|
715
|
-
"gateway",
|
|
716
|
-
"node"
|
|
717
|
-
]
|
|
718
|
-
},
|
|
719
|
-
{
|
|
720
|
-
name: "security",
|
|
721
|
-
description: "deny, allowlist, or full",
|
|
722
|
-
type: "string",
|
|
723
|
-
choices: [
|
|
724
|
-
"deny",
|
|
725
|
-
"allowlist",
|
|
726
|
-
"full"
|
|
727
|
-
]
|
|
728
|
-
},
|
|
729
|
-
{
|
|
730
|
-
name: "ask",
|
|
731
|
-
description: "off, on-miss, or always",
|
|
732
|
-
type: "string",
|
|
733
|
-
choices: [
|
|
734
|
-
"off",
|
|
735
|
-
"on-miss",
|
|
736
|
-
"always"
|
|
737
|
-
]
|
|
738
|
-
},
|
|
739
|
-
{
|
|
740
|
-
name: "node",
|
|
741
|
-
description: "Node id or name",
|
|
742
|
-
type: "string"
|
|
743
|
-
}
|
|
744
|
-
],
|
|
745
|
-
argsParsing: "none",
|
|
746
|
-
formatArgs: COMMAND_ARG_FORMATTERS.exec
|
|
747
|
-
}),
|
|
748
|
-
defineChatCommand({
|
|
749
|
-
key: "model",
|
|
750
|
-
nativeName: "model",
|
|
751
|
-
description: "Show or set the model.",
|
|
752
|
-
textAlias: "/model",
|
|
753
|
-
category: "options",
|
|
754
|
-
args: [{
|
|
755
|
-
name: "model",
|
|
756
|
-
description: "Model id (provider/model or id)",
|
|
757
|
-
type: "string"
|
|
758
|
-
}]
|
|
759
|
-
}),
|
|
760
|
-
defineChatCommand({
|
|
761
|
-
key: "models",
|
|
762
|
-
nativeName: "models",
|
|
763
|
-
description: "List model providers or provider models.",
|
|
764
|
-
textAlias: "/models",
|
|
765
|
-
argsParsing: "none",
|
|
766
|
-
acceptsArgs: true,
|
|
767
|
-
category: "options"
|
|
768
|
-
}),
|
|
769
|
-
defineChatCommand({
|
|
770
|
-
key: "queue",
|
|
771
|
-
nativeName: "queue",
|
|
772
|
-
description: "Adjust queue settings.",
|
|
773
|
-
textAlias: "/queue",
|
|
774
|
-
category: "options",
|
|
775
|
-
args: [
|
|
776
|
-
{
|
|
777
|
-
name: "mode",
|
|
778
|
-
description: "queue mode",
|
|
779
|
-
type: "string",
|
|
780
|
-
choices: [
|
|
781
|
-
"steer",
|
|
782
|
-
"interrupt",
|
|
783
|
-
"followup",
|
|
784
|
-
"collect",
|
|
785
|
-
"steer-backlog"
|
|
786
|
-
]
|
|
787
|
-
},
|
|
788
|
-
{
|
|
789
|
-
name: "debounce",
|
|
790
|
-
description: "debounce duration (e.g. 500ms, 2s)",
|
|
791
|
-
type: "string"
|
|
792
|
-
},
|
|
793
|
-
{
|
|
794
|
-
name: "cap",
|
|
795
|
-
description: "queue cap",
|
|
796
|
-
type: "number"
|
|
797
|
-
},
|
|
798
|
-
{
|
|
799
|
-
name: "drop",
|
|
800
|
-
description: "drop policy",
|
|
801
|
-
type: "string",
|
|
802
|
-
choices: [
|
|
803
|
-
"old",
|
|
804
|
-
"new",
|
|
805
|
-
"summarize"
|
|
806
|
-
]
|
|
807
|
-
}
|
|
808
|
-
],
|
|
809
|
-
argsParsing: "none",
|
|
810
|
-
formatArgs: COMMAND_ARG_FORMATTERS.queue
|
|
811
|
-
}),
|
|
812
|
-
defineChatCommand({
|
|
813
|
-
key: "bash",
|
|
814
|
-
description: "Run host shell commands (host-only).",
|
|
815
|
-
textAlias: "/bash",
|
|
816
|
-
scope: "text",
|
|
817
|
-
category: "tools",
|
|
818
|
-
args: [{
|
|
819
|
-
name: "command",
|
|
820
|
-
description: "Shell command",
|
|
821
|
-
type: "string",
|
|
822
|
-
captureRemaining: true
|
|
823
|
-
}]
|
|
824
|
-
}),
|
|
825
|
-
...listChannelDocks().filter((dock) => dock.capabilities.nativeCommands).map((dock) => defineDockCommand(dock))
|
|
826
|
-
];
|
|
827
|
-
registerAlias(commands, "whoami", "/id");
|
|
828
|
-
registerAlias(commands, "think", "/thinking", "/t");
|
|
829
|
-
registerAlias(commands, "verbose", "/v");
|
|
830
|
-
registerAlias(commands, "reasoning", "/reason");
|
|
831
|
-
registerAlias(commands, "elevated", "/elev");
|
|
832
|
-
registerAlias(commands, "steer", "/tell");
|
|
833
|
-
assertCommandRegistry(commands);
|
|
834
|
-
return commands;
|
|
835
|
-
}
|
|
836
|
-
function getChatCommands() {
|
|
837
|
-
const registry = getActivePluginRegistry();
|
|
838
|
-
if (cachedCommands && registry === cachedRegistry) return cachedCommands;
|
|
839
|
-
const commands = buildChatCommands();
|
|
840
|
-
cachedCommands = commands;
|
|
841
|
-
cachedRegistry = registry;
|
|
842
|
-
cachedNativeCommandSurfaces = null;
|
|
843
|
-
return commands;
|
|
844
|
-
}
|
|
845
|
-
function getNativeCommandSurfaces() {
|
|
846
|
-
const registry = getActivePluginRegistry();
|
|
847
|
-
if (cachedNativeCommandSurfaces && registry === cachedNativeRegistry) return cachedNativeCommandSurfaces;
|
|
848
|
-
cachedNativeCommandSurfaces = new Set(listChannelDocks().filter((dock) => dock.capabilities.nativeCommands).map((dock) => dock.id));
|
|
849
|
-
cachedNativeRegistry = registry;
|
|
850
|
-
return cachedNativeCommandSurfaces;
|
|
851
|
-
}
|
|
852
|
-
|
|
853
|
-
//#endregion
|
|
854
|
-
//#region src/auto-reply/commands-registry.ts
|
|
855
|
-
let cachedTextAliasMap = null;
|
|
856
|
-
let cachedTextAliasCommands = null;
|
|
857
|
-
let cachedDetection;
|
|
858
|
-
let cachedDetectionCommands = null;
|
|
859
|
-
function getTextAliasMap() {
|
|
860
|
-
const commands = getChatCommands();
|
|
861
|
-
if (cachedTextAliasMap && cachedTextAliasCommands === commands) return cachedTextAliasMap;
|
|
862
|
-
const map = /* @__PURE__ */ new Map();
|
|
863
|
-
for (const command of commands) {
|
|
864
|
-
const canonical = command.textAliases[0]?.trim() || `/${command.key}`;
|
|
865
|
-
const acceptsArgs = Boolean(command.acceptsArgs);
|
|
866
|
-
for (const alias of command.textAliases) {
|
|
867
|
-
const normalized = alias.trim().toLowerCase();
|
|
868
|
-
if (!normalized) continue;
|
|
869
|
-
if (!map.has(normalized)) map.set(normalized, {
|
|
870
|
-
key: command.key,
|
|
871
|
-
canonical,
|
|
872
|
-
acceptsArgs
|
|
873
|
-
});
|
|
874
|
-
}
|
|
875
|
-
}
|
|
876
|
-
cachedTextAliasMap = map;
|
|
877
|
-
cachedTextAliasCommands = commands;
|
|
878
|
-
return map;
|
|
879
|
-
}
|
|
880
|
-
function buildSkillCommandDefinitions(skillCommands) {
|
|
881
|
-
if (!skillCommands || skillCommands.length === 0) return [];
|
|
882
|
-
return skillCommands.map((spec) => ({
|
|
883
|
-
key: `skill:${spec.skillName}`,
|
|
884
|
-
nativeName: spec.name,
|
|
885
|
-
description: spec.description,
|
|
886
|
-
textAliases: [`/${spec.name}`],
|
|
887
|
-
acceptsArgs: true,
|
|
888
|
-
argsParsing: "none",
|
|
889
|
-
scope: "both"
|
|
890
|
-
}));
|
|
891
|
-
}
|
|
892
|
-
function listChatCommands(params) {
|
|
893
|
-
const commands = getChatCommands();
|
|
894
|
-
if (!params?.skillCommands?.length) return [...commands];
|
|
895
|
-
return [...commands, ...buildSkillCommandDefinitions(params.skillCommands)];
|
|
896
|
-
}
|
|
897
|
-
function isCommandEnabled(cfg, commandKey) {
|
|
898
|
-
if (commandKey === "config") return isCommandFlagEnabled(cfg, "config");
|
|
899
|
-
if (commandKey === "debug") return isCommandFlagEnabled(cfg, "debug");
|
|
900
|
-
if (commandKey === "bash") return isCommandFlagEnabled(cfg, "bash");
|
|
901
|
-
return true;
|
|
902
|
-
}
|
|
903
|
-
function listChatCommandsForConfig(cfg, params) {
|
|
904
|
-
const base = getChatCommands().filter((command) => isCommandEnabled(cfg, command.key));
|
|
905
|
-
if (!params?.skillCommands?.length) return base;
|
|
906
|
-
return [...base, ...buildSkillCommandDefinitions(params.skillCommands)];
|
|
907
|
-
}
|
|
908
|
-
const NATIVE_NAME_OVERRIDES = {
|
|
909
|
-
discord: { tts: "voice" },
|
|
910
|
-
slack: { status: "agentstatus" }
|
|
911
|
-
};
|
|
912
|
-
function resolveNativeName(command, provider) {
|
|
913
|
-
if (!command.nativeName) return;
|
|
914
|
-
if (provider) {
|
|
915
|
-
const override = NATIVE_NAME_OVERRIDES[provider]?.[command.key];
|
|
916
|
-
if (override) return override;
|
|
917
|
-
}
|
|
918
|
-
return command.nativeName;
|
|
919
|
-
}
|
|
920
|
-
function toNativeCommandSpec(command, provider) {
|
|
921
|
-
return {
|
|
922
|
-
name: resolveNativeName(command, provider) ?? command.key,
|
|
923
|
-
description: command.description,
|
|
924
|
-
acceptsArgs: Boolean(command.acceptsArgs),
|
|
925
|
-
args: command.args
|
|
926
|
-
};
|
|
927
|
-
}
|
|
928
|
-
function listNativeSpecsFromCommands(commands, provider) {
|
|
929
|
-
return commands.filter((command) => command.scope !== "text" && command.nativeName).map((command) => toNativeCommandSpec(command, provider));
|
|
930
|
-
}
|
|
931
|
-
function listNativeCommandSpecs(params) {
|
|
932
|
-
return listNativeSpecsFromCommands(listChatCommands({ skillCommands: params?.skillCommands }), params?.provider);
|
|
933
|
-
}
|
|
934
|
-
function listNativeCommandSpecsForConfig(cfg, params) {
|
|
935
|
-
return listNativeSpecsFromCommands(listChatCommandsForConfig(cfg, params), params?.provider);
|
|
936
|
-
}
|
|
937
|
-
function findCommandByNativeName(name, provider) {
|
|
938
|
-
const normalized = name.trim().toLowerCase();
|
|
939
|
-
return getChatCommands().find((command) => command.scope !== "text" && resolveNativeName(command, provider)?.toLowerCase() === normalized);
|
|
940
|
-
}
|
|
941
|
-
function buildCommandText(commandName, args) {
|
|
942
|
-
const trimmedArgs = args?.trim();
|
|
943
|
-
return trimmedArgs ? `/${commandName} ${trimmedArgs}` : `/${commandName}`;
|
|
944
|
-
}
|
|
945
|
-
function parsePositionalArgs(definitions, raw) {
|
|
946
|
-
const values = {};
|
|
947
|
-
const trimmed = raw.trim();
|
|
948
|
-
if (!trimmed) return values;
|
|
949
|
-
const tokens = trimmed.split(/\s+/).filter(Boolean);
|
|
950
|
-
let index = 0;
|
|
951
|
-
for (const definition of definitions) {
|
|
952
|
-
if (index >= tokens.length) break;
|
|
953
|
-
if (definition.captureRemaining) {
|
|
954
|
-
values[definition.name] = tokens.slice(index).join(" ");
|
|
955
|
-
index = tokens.length;
|
|
956
|
-
break;
|
|
957
|
-
}
|
|
958
|
-
values[definition.name] = tokens[index];
|
|
959
|
-
index += 1;
|
|
960
|
-
}
|
|
961
|
-
return values;
|
|
962
|
-
}
|
|
963
|
-
function formatPositionalArgs(definitions, values) {
|
|
964
|
-
const parts = [];
|
|
965
|
-
for (const definition of definitions) {
|
|
966
|
-
const value = values[definition.name];
|
|
967
|
-
if (value == null) continue;
|
|
968
|
-
let rendered;
|
|
969
|
-
if (typeof value === "string") rendered = value.trim();
|
|
970
|
-
else rendered = String(value);
|
|
971
|
-
if (!rendered) continue;
|
|
972
|
-
parts.push(rendered);
|
|
973
|
-
if (definition.captureRemaining) break;
|
|
974
|
-
}
|
|
975
|
-
return parts.length > 0 ? parts.join(" ") : void 0;
|
|
976
|
-
}
|
|
977
|
-
function parseCommandArgs(command, raw) {
|
|
978
|
-
const trimmed = raw?.trim();
|
|
979
|
-
if (!trimmed) return;
|
|
980
|
-
if (!command.args || command.argsParsing === "none") return { raw: trimmed };
|
|
981
|
-
return {
|
|
982
|
-
raw: trimmed,
|
|
983
|
-
values: parsePositionalArgs(command.args, trimmed)
|
|
984
|
-
};
|
|
985
|
-
}
|
|
986
|
-
function serializeCommandArgs(command, args) {
|
|
987
|
-
if (!args) return;
|
|
988
|
-
const raw = args.raw?.trim();
|
|
989
|
-
if (raw) return raw;
|
|
990
|
-
if (!args.values || !command.args) return;
|
|
991
|
-
if (command.formatArgs) return command.formatArgs(args.values);
|
|
992
|
-
return formatPositionalArgs(command.args, args.values);
|
|
993
|
-
}
|
|
994
|
-
function buildCommandTextFromArgs(command, args) {
|
|
995
|
-
return buildCommandText(command.nativeName ?? command.key, serializeCommandArgs(command, args));
|
|
996
|
-
}
|
|
997
|
-
function resolveDefaultCommandContext(cfg) {
|
|
998
|
-
const resolved = resolveConfiguredModelRef({
|
|
999
|
-
cfg: cfg ?? {},
|
|
1000
|
-
defaultProvider: DEFAULT_PROVIDER,
|
|
1001
|
-
defaultModel: DEFAULT_MODEL
|
|
1002
|
-
});
|
|
1003
|
-
return {
|
|
1004
|
-
provider: resolved.provider ?? DEFAULT_PROVIDER,
|
|
1005
|
-
model: resolved.model ?? DEFAULT_MODEL
|
|
1006
|
-
};
|
|
1007
|
-
}
|
|
1008
|
-
function resolveCommandArgChoices(params) {
|
|
1009
|
-
const { command, arg, cfg } = params;
|
|
1010
|
-
if (!arg.choices) return [];
|
|
1011
|
-
const provided = arg.choices;
|
|
1012
|
-
return (Array.isArray(provided) ? provided : (() => {
|
|
1013
|
-
const defaults = resolveDefaultCommandContext(cfg);
|
|
1014
|
-
return provided({
|
|
1015
|
-
cfg,
|
|
1016
|
-
provider: params.provider ?? defaults.provider,
|
|
1017
|
-
model: params.model ?? defaults.model,
|
|
1018
|
-
command,
|
|
1019
|
-
arg
|
|
1020
|
-
});
|
|
1021
|
-
})()).map((choice) => typeof choice === "string" ? {
|
|
1022
|
-
value: choice,
|
|
1023
|
-
label: choice
|
|
1024
|
-
} : choice);
|
|
1025
|
-
}
|
|
1026
|
-
function resolveCommandArgMenu(params) {
|
|
1027
|
-
const { command, args, cfg } = params;
|
|
1028
|
-
if (!command.args || !command.argsMenu) return null;
|
|
1029
|
-
if (command.argsParsing === "none") return null;
|
|
1030
|
-
const argSpec = command.argsMenu;
|
|
1031
|
-
const argName = argSpec === "auto" ? command.args.find((arg) => resolveCommandArgChoices({
|
|
1032
|
-
command,
|
|
1033
|
-
arg,
|
|
1034
|
-
cfg
|
|
1035
|
-
}).length > 0)?.name : argSpec.arg;
|
|
1036
|
-
if (!argName) return null;
|
|
1037
|
-
if (args?.values && args.values[argName] != null) return null;
|
|
1038
|
-
if (args?.raw && !args.values) return null;
|
|
1039
|
-
const arg = command.args.find((entry) => entry.name === argName);
|
|
1040
|
-
if (!arg) return null;
|
|
1041
|
-
const choices = resolveCommandArgChoices({
|
|
1042
|
-
command,
|
|
1043
|
-
arg,
|
|
1044
|
-
cfg
|
|
1045
|
-
});
|
|
1046
|
-
if (choices.length === 0) return null;
|
|
1047
|
-
return {
|
|
1048
|
-
arg,
|
|
1049
|
-
choices,
|
|
1050
|
-
title: argSpec !== "auto" ? argSpec.title : void 0
|
|
1051
|
-
};
|
|
1052
|
-
}
|
|
1053
|
-
function normalizeCommandBody(raw, options) {
|
|
1054
|
-
const trimmed = raw.trim();
|
|
1055
|
-
if (!trimmed.startsWith("/")) return trimmed;
|
|
1056
|
-
const newline = trimmed.indexOf("\n");
|
|
1057
|
-
const singleLine = newline === -1 ? trimmed : trimmed.slice(0, newline).trim();
|
|
1058
|
-
const colonMatch = singleLine.match(/^\/([^\s:]+)\s*:(.*)$/);
|
|
1059
|
-
const normalized = colonMatch ? (() => {
|
|
1060
|
-
const [, command, rest] = colonMatch;
|
|
1061
|
-
const normalizedRest = rest.trimStart();
|
|
1062
|
-
return normalizedRest ? `/${command} ${normalizedRest}` : `/${command}`;
|
|
1063
|
-
})() : singleLine;
|
|
1064
|
-
const normalizedBotUsername = options?.botUsername?.trim().toLowerCase();
|
|
1065
|
-
const mentionMatch = normalizedBotUsername ? normalized.match(/^\/([^\s@]+)@([^\s]+)(.*)$/) : null;
|
|
1066
|
-
const commandBody = mentionMatch && mentionMatch[2].toLowerCase() === normalizedBotUsername ? `/${mentionMatch[1]}${mentionMatch[3] ?? ""}` : normalized;
|
|
1067
|
-
const lowered = commandBody.toLowerCase();
|
|
1068
|
-
const textAliasMap = getTextAliasMap();
|
|
1069
|
-
const exact = textAliasMap.get(lowered);
|
|
1070
|
-
if (exact) return exact.canonical;
|
|
1071
|
-
const tokenMatch = commandBody.match(/^\/([^\s]+)(?:\s+([\s\S]+))?$/);
|
|
1072
|
-
if (!tokenMatch) return commandBody;
|
|
1073
|
-
const [, token, rest] = tokenMatch;
|
|
1074
|
-
const tokenKey = `/${token.toLowerCase()}`;
|
|
1075
|
-
const tokenSpec = textAliasMap.get(tokenKey);
|
|
1076
|
-
if (!tokenSpec) return commandBody;
|
|
1077
|
-
if (rest && !tokenSpec.acceptsArgs) return commandBody;
|
|
1078
|
-
const normalizedRest = rest?.trimStart();
|
|
1079
|
-
return normalizedRest ? `${tokenSpec.canonical} ${normalizedRest}` : tokenSpec.canonical;
|
|
1080
|
-
}
|
|
1081
|
-
function getCommandDetection(_cfg) {
|
|
1082
|
-
const commands = getChatCommands();
|
|
1083
|
-
if (cachedDetection && cachedDetectionCommands === commands) return cachedDetection;
|
|
1084
|
-
const exact = /* @__PURE__ */ new Set();
|
|
1085
|
-
const patterns = [];
|
|
1086
|
-
for (const cmd of commands) for (const alias of cmd.textAliases) {
|
|
1087
|
-
const normalized = alias.trim().toLowerCase();
|
|
1088
|
-
if (!normalized) continue;
|
|
1089
|
-
exact.add(normalized);
|
|
1090
|
-
const escaped = escapeRegExp(normalized);
|
|
1091
|
-
if (!escaped) continue;
|
|
1092
|
-
if (cmd.acceptsArgs) patterns.push(`${escaped}(?:\\s+.+|\\s*:\\s*.*)?`);
|
|
1093
|
-
else patterns.push(`${escaped}(?:\\s*:\\s*)?`);
|
|
1094
|
-
}
|
|
1095
|
-
cachedDetection = {
|
|
1096
|
-
exact,
|
|
1097
|
-
regex: patterns.length ? new RegExp(`^(?:${patterns.join("|")})$`, "i") : /$^/
|
|
1098
|
-
};
|
|
1099
|
-
cachedDetectionCommands = commands;
|
|
1100
|
-
return cachedDetection;
|
|
1101
|
-
}
|
|
1102
|
-
function maybeResolveTextAlias(raw, cfg) {
|
|
1103
|
-
const trimmed = normalizeCommandBody(raw).trim();
|
|
1104
|
-
if (!trimmed.startsWith("/")) return null;
|
|
1105
|
-
const detection = getCommandDetection(cfg);
|
|
1106
|
-
const normalized = trimmed.toLowerCase();
|
|
1107
|
-
if (detection.exact.has(normalized)) return normalized;
|
|
1108
|
-
if (!detection.regex.test(normalized)) return null;
|
|
1109
|
-
const tokenMatch = normalized.match(/^\/([^\s:]+)(?:\s|$)/);
|
|
1110
|
-
if (!tokenMatch) return null;
|
|
1111
|
-
const tokenKey = `/${tokenMatch[1]}`;
|
|
1112
|
-
return getTextAliasMap().has(tokenKey) ? tokenKey : null;
|
|
1113
|
-
}
|
|
1114
|
-
function isNativeCommandSurface(surface) {
|
|
1115
|
-
if (!surface) return false;
|
|
1116
|
-
return getNativeCommandSurfaces().has(surface.toLowerCase());
|
|
1117
|
-
}
|
|
1118
|
-
function shouldHandleTextCommands(params) {
|
|
1119
|
-
if (params.commandSource === "native") return true;
|
|
1120
|
-
if (params.cfg.commands?.text !== false) return true;
|
|
1121
|
-
return !isNativeCommandSurface(params.surface);
|
|
1122
|
-
}
|
|
1123
|
-
|
|
1124
|
-
//#endregion
|
|
1125
|
-
export { isRestartEnabled as _, listChatCommandsForConfig as a, maybeResolveTextAlias as c, resolveCommandArgChoices as d, resolveCommandArgMenu as f, isNativeCommandsExplicitlyDisabled as g, isCommandFlagEnabled as h, listChatCommands as i, normalizeCommandBody as l, shouldHandleTextCommands as m, findCommandByNativeName as n, listNativeCommandSpecs as o, serializeCommandArgs as p, isCommandEnabled as r, listNativeCommandSpecsForConfig as s, buildCommandTextFromArgs as t, parseCommandArgs as u, resolveNativeCommandsEnabled as v, resolveNativeSkillsEnabled as y };
|