remoteclaw 0.0.0 → 0.1.0-next.2abd2fa
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/CHANGELOG.md +7 -0
- package/LICENSE +661 -0
- package/README.md +490 -0
- package/assets/chrome-extension/README.md +23 -0
- package/assets/chrome-extension/background-utils.js +48 -0
- package/assets/chrome-extension/background.js +899 -0
- package/assets/chrome-extension/icons/icon128.png +0 -0
- package/assets/chrome-extension/icons/icon16.png +0 -0
- package/assets/chrome-extension/icons/icon32.png +0 -0
- package/assets/chrome-extension/icons/icon48.png +0 -0
- package/assets/chrome-extension/manifest.json +25 -0
- package/assets/chrome-extension/options-validation.js +57 -0
- package/assets/chrome-extension/options.html +200 -0
- package/assets/chrome-extension/options.js +74 -0
- package/assets/clawtributor-avatar-placeholder.png +0 -0
- package/assets/dmg-background-small.png +0 -0
- package/assets/dmg-background.png +0 -0
- package/dist/account-lookup-0KDSp5Mj.js +11 -0
- package/dist/account-lookup-zvANGr2x.js +11 -0
- package/dist/accounts-BFy_Z3od.js +272 -0
- package/dist/accounts-BTXSfPWi.js +270 -0
- package/dist/accounts-BxGS70Do.js +36 -0
- package/dist/accounts-CNY1TGj1.js +47 -0
- package/dist/accounts-DBohBlww.js +32 -0
- package/dist/accounts-DqRQ75w3.js +36 -0
- package/dist/accounts-iODF3SK2.js +47 -0
- package/dist/ack-reactions-B11TAC2D.js +446 -0
- package/dist/ack-reactions-BWVjL4H6.js +446 -0
- package/dist/acp-cli-CA1xMmVo.js +1320 -0
- package/dist/acp-cli-CGo6fJVZ.js +1326 -0
- package/dist/active-listener-VzhWW8W6.js +37 -0
- package/dist/active-listener-z0qVEcom.js +37 -0
- package/dist/agent-CTizRPIJ.js +732 -0
- package/dist/agent-D2RVoS5g.js +731 -0
- package/dist/agent-helpers-B6VfZ9_u.js +606 -0
- package/dist/agent-helpers-CTx5KKJu.js +606 -0
- package/dist/agent-scope-BGYzhtWQ.js +121 -0
- package/dist/agent-scope-C50VuLKh.js +119 -0
- package/dist/agents-BuYn-obw.js +788 -0
- package/dist/agents.config-BSTxuTVd.js +116 -0
- package/dist/agents.config-p3V3b9u6.js +116 -0
- package/dist/ansi-D04X81yq.js +14 -0
- package/dist/api-BeQMq2iS.js +17 -0
- package/dist/api-CxX8-gGz.js +17 -0
- package/dist/argv-Co-b9Zsc.js +101 -0
- package/dist/audio-DPOuhNq7.js +43 -0
- package/dist/audio-VBcVDa08.js +43 -0
- package/dist/audio-preflight-BwmCYeuM.js +64 -0
- package/dist/audio-preflight-co8gjlPX.js +69 -0
- package/dist/audit-oH4urD3G.js +3138 -0
- package/dist/audit-qgtCT3ik.js +3138 -0
- package/dist/auth-CAczFgAO.js +448 -0
- package/dist/auth-Deh9i9Eg.js +448 -0
- package/dist/auth-profiles-BquJGKLC.js +279 -0
- package/dist/auth-profiles-D8vKiBPq.js +281 -0
- package/dist/banner-Cf978khN.js +294 -0
- package/dist/binaries-DXW6oATV.js +13 -0
- package/dist/bindings-CRU_udk8.js +69 -0
- package/dist/bindings-DQZAu8Wv.js +69 -0
- package/dist/bonjour-discovery-DdAk1VyO.js +378 -0
- package/dist/bonjour-discovery-DuhiIZZx.js +378 -0
- package/dist/boot/handler.js +1498 -0
- package/dist/brew-C4zKZsHX.js +46 -0
- package/dist/brew-DbSbN8sD.js +46 -0
- package/dist/browser-cli-CZC4h5V4.js +1687 -0
- package/dist/browser-cli-DAgi_aQk.js +1692 -0
- package/dist/build-info.json +5 -0
- package/dist/bundled/boot/HOOK.md +24 -0
- package/dist/bundled/command-logger/HOOK.md +122 -0
- package/dist/call-BbwtB9Y-.js +2828 -0
- package/dist/call-PivL7Uex.js +2829 -0
- package/dist/canvas-host/a2ui/.bundle.hash +1 -0
- package/dist/canvas-host/a2ui/a2ui.bundle.js +13193 -0
- package/dist/canvas-host/a2ui/index.html +307 -0
- package/dist/catalog-BqO6yem_.js +185 -0
- package/dist/catalog-DFmaYwfk.js +185 -0
- package/dist/channel-account-context-CvIDAtHS.js +550 -0
- package/dist/channel-account-context-q-o0pG1A.js +550 -0
- package/dist/channel-activity-BaCNOZpP.js +94 -0
- package/dist/channel-activity-C-G4n9BK.js +292 -0
- package/dist/channel-activity-DTKGf3j5.js +94 -0
- package/dist/channel-options-Cyappik_.js +32 -0
- package/dist/channel-options-DFnypY5S.js +33 -0
- package/dist/channel-selection-BGl53D5K.js +51 -0
- package/dist/channel-selection-NNPbxnyZ.js +51 -0
- package/dist/channel-web-DmhVkWbP.js +2134 -0
- package/dist/channel-web-kRC3UYBJ.js +2136 -0
- package/dist/channels-cli-C5XRkPJl.js +1421 -0
- package/dist/channels-cli-D6TqCI0m.js +1426 -0
- package/dist/channels-status-issues-CUc9mpeW.js +18 -0
- package/dist/channels-status-issues-DwRDzwrV.js +18 -0
- package/dist/chat-envelope-DEZ-5RY8.js +248 -0
- package/dist/chat-envelope-el7Uo-Fe.js +248 -0
- package/dist/chat-type-CYPyHAj-.js +11 -0
- package/dist/chat-type-DKb2TlGZ.js +11 -0
- package/dist/chrome-0QaGKb3L.js +1732 -0
- package/dist/chrome-CFeWdP0Y.js +1733 -0
- package/dist/chunk-CSQfUhgF.js +341 -0
- package/dist/chunk-D0Y_w4oX.js +341 -0
- package/dist/clack-prompter-B7tOxhJd.js +122 -0
- package/dist/clack-prompter-CCFnKP_1.js +121 -0
- package/dist/cleanup-utils-CqAVZz2b.js +94 -0
- package/dist/cleanup-utils-CwQvD73q.js +94 -0
- package/dist/cli/daemon-cli.js +9 -0
- package/dist/cli-BR2J3c4l.js +125 -0
- package/dist/cli-C1q1vSmN.js +130 -0
- package/dist/cli-name-BicfmwQX.js +23 -0
- package/dist/cli-name-C6rJGl18.js +23 -0
- package/dist/cli-utils-BhXbz2UF.js +16 -0
- package/dist/cli-utils-DZe_rVkZ.js +16 -0
- package/dist/client-C61M8zI3.js +22 -0
- package/dist/client-DdpmATKq.js +22 -0
- package/dist/clipboard-D7_SKHPK.js +31 -0
- package/dist/clipboard-Dzkx6Q2K.js +31 -0
- package/dist/command-format-CVfo8I5f.js +18 -0
- package/dist/command-format-DgXcqxBt.js +32 -0
- package/dist/command-logger/handler.js +57 -0
- package/dist/command-options-C4paWSGf.js +26 -0
- package/dist/command-options-CA30lfLK.js +26 -0
- package/dist/command-registry-CYjvOp8W.js +215 -0
- package/dist/commands-CDonBOrw.js +41 -0
- package/dist/commands-D_-bgTlO.js +41 -0
- package/dist/commands-registry-CWJv6xe2.js +892 -0
- package/dist/commands-registry-Ci8_cFk9.js +893 -0
- package/dist/common-CMI-qsF8.js +156 -0
- package/dist/common-DSVmydhm.js +156 -0
- package/dist/completion-cli-8iZJqfmX.js +452 -0
- package/dist/completion-cli-CYDjEZSt.js +452 -0
- package/dist/config-D5XU45KD.js +6953 -0
- package/dist/config-FHu9Bn4R.js +6951 -0
- package/dist/config-cli-Gehy4sav.js +241 -0
- package/dist/config-cli-RC9qMgJq.js +246 -0
- package/dist/config-eval-CjGZtLwx.js +102 -0
- package/dist/config-eval-H_wlEYIG.js +102 -0
- package/dist/config-guard-J-Q_DFWk.js +97 -0
- package/dist/config-guard-cB5a_ANg.js +75 -0
- package/dist/config-validation-BPNyd9_3.js +18 -0
- package/dist/config-validation-BPWuvhVe.js +18 -0
- package/dist/configure-CC2XdRRm.js +891 -0
- package/dist/configure-DxFBJuhZ.js +889 -0
- package/dist/constants-BmRFoHl0.js +67 -0
- package/dist/constants-C9WPAluB.js +67 -0
- package/dist/constants-ChptG3d7.js +12 -0
- package/dist/constants-DY6b-_Wl.js +12 -0
- package/dist/control-auth-D0tpV3ts.js +397 -0
- package/dist/control-auth-_-0PGRUs.js +397 -0
- package/dist/control-ui/apple-touch-icon.png +0 -0
- package/dist/control-ui/assets/index-B4ZM1lW1.js +7738 -0
- package/dist/control-ui/assets/index-B4ZM1lW1.js.map +1 -0
- package/dist/control-ui/assets/index-PED72sKF.css +1 -0
- package/dist/control-ui/assets/pt-BR-eq0TfCI7.js +2 -0
- package/dist/control-ui/assets/pt-BR-eq0TfCI7.js.map +1 -0
- package/dist/control-ui/assets/zh-CN-DmLG2MF9.js +2 -0
- package/dist/control-ui/assets/zh-CN-DmLG2MF9.js.map +1 -0
- package/dist/control-ui/assets/zh-TW-BLErH0EM.js +2 -0
- package/dist/control-ui/assets/zh-TW-BLErH0EM.js.map +1 -0
- package/dist/control-ui/favicon-32.png +0 -0
- package/dist/control-ui/favicon.ico +0 -0
- package/dist/control-ui/favicon.svg +67 -0
- package/dist/control-ui/index.html +17 -0
- package/dist/control-ui-assets-Cx_mw4D0.js +186 -0
- package/dist/control-ui-assets-W1AUuGrO.js +186 -0
- package/dist/conversation-label-C4SDz4sT.js +36 -0
- package/dist/conversation-label-D1frnvYe.js +36 -0
- package/dist/credentials-BHWUBHMd.js +91 -0
- package/dist/credentials-DFsi1_e8.js +91 -0
- package/dist/cron-cli-BzERxhr5.js +495 -0
- package/dist/cron-cli-C8j_uslU.js +490 -0
- package/dist/daemon-cli-C95XNbX0.js +1199 -0
- package/dist/daemon-cli-e6sURMqd.js +1197 -0
- package/dist/daemon-cli.js +15243 -0
- package/dist/daemon-install-CcohRvKV.js +55 -0
- package/dist/daemon-install-DDshfT0J.js +60 -0
- package/dist/daemon-install-helpers-CFGAfRlj.js +462 -0
- package/dist/daemon-install-helpers-DIUzSFG1.js +462 -0
- package/dist/daemon-runtime-CMnbwryP.js +13 -0
- package/dist/daemon-runtime-CvqE4ysg.js +13 -0
- package/dist/dangerous-name-matching-BzmiLXmA.js +45 -0
- package/dist/dangerous-name-matching-DaVRgwer.js +45 -0
- package/dist/dangerous-tools-BOLoCRv4.js +253 -0
- package/dist/dangerous-tools-Baq7Q-i6.js +253 -0
- package/dist/defaults-B5KStIBg.js +7 -0
- package/dist/defaults-xUAL2Z-F.js +7 -0
- package/dist/deliver-912khjLK.js +481 -0
- package/dist/deliver-D56J4-1F.js +481 -0
- package/dist/delivery-queue-Cfa9Wmxp.js +244 -0
- package/dist/delivery-queue-CxVRi4tw.js +244 -0
- package/dist/devices-cli-0qDhTgZR.js +316 -0
- package/dist/devices-cli-6SKMR2bV.js +321 -0
- package/dist/diagnostics-99iCgBUh.js +46 -0
- package/dist/diagnostics-VC0cz7kX.js +46 -0
- package/dist/directory-cli-5YXdoVdn.js +217 -0
- package/dist/directory-cli-D3IKCHmn.js +222 -0
- package/dist/dm-policy-shared-4rkjhcrM.js +22 -0
- package/dist/dm-policy-shared-D8lgnmrC.js +22 -0
- package/dist/dns-cli-11CtErVU.js +197 -0
- package/dist/dns-cli-SiEd_1Lq.js +202 -0
- package/dist/dock-BqNINg7k.js +928 -0
- package/dist/dock-CQuu41bw.js +929 -0
- package/dist/doctor-completion-BR1SlAT3.js +92 -0
- package/dist/doctor-completion-CZwpEhIK.js +92 -0
- package/dist/doctor-config-flow-BVkHcvoj.js +1933 -0
- package/dist/doctor-config-flow-DVYRn0An.js +1934 -0
- package/dist/enable-DcJnkzfz.js +59 -0
- package/dist/enable-ibNq4UWy.js +59 -0
- package/dist/entry.js +2620 -0
- package/dist/env-DeF64iu0.js +60 -0
- package/dist/env-vars-7aZqKPhk.js +93 -0
- package/dist/env-vars-CLGbxdpL.js +93 -0
- package/dist/errors-8F-77i6m.js +35 -0
- package/dist/errors-DZ199hOo.js +35 -0
- package/dist/exec-DbKuYyM1.js +164 -0
- package/dist/exec-DkFE7lqU.js +164 -0
- package/dist/export-html/template.css +1060 -0
- package/dist/export-html/template.html +88 -0
- package/dist/export-html/template.js +1797 -0
- package/dist/export-html/vendor/highlight.min.js +1213 -0
- package/dist/export-html/vendor/marked.min.js +6 -0
- package/dist/extensionAPI.js +11520 -0
- package/dist/fetch-BFSBLBkA.js +67 -0
- package/dist/fetch-C6XKGA11.js +67 -0
- package/dist/fetch-CEDsOiql.js +67 -0
- package/dist/fetch-timeout-DTIN7CGM.js +43 -0
- package/dist/fetch-timeout-DoySHqfO.js +43 -0
- package/dist/file-identity-BxlKD8Ys.js +12 -0
- package/dist/file-lock-CIvloidc.js +107 -0
- package/dist/file-lock-CzBL_VIx.js +107 -0
- package/dist/format-duration-CqUERz51.js +35 -0
- package/dist/format-duration-Ct-yiwkS.js +35 -0
- package/dist/format-relative-79_Y1n2Y.js +55 -0
- package/dist/format-relative-CxLpEQOX.js +55 -0
- package/dist/fs-safe-DSwT85uK.js +88 -0
- package/dist/fs-safe-DkBhNAc3.js +98 -0
- package/dist/gateway-cli-BEEZhCHv.js +23747 -0
- package/dist/gateway-cli-Nob0g_4y.js +23742 -0
- package/dist/gateway-rpc-CksB-N83.js +28 -0
- package/dist/gateway-rpc-Dq44SkOv.js +28 -0
- package/dist/gmail-setup-utils-Cnx8A5pW.js +422 -0
- package/dist/gmail-setup-utils-nkabbKOE.js +423 -0
- package/dist/health-RT-F3hzT.js +1423 -0
- package/dist/health-SOuaKNRa.js +1420 -0
- package/dist/health-format-BG95OE6N.js +28 -0
- package/dist/health-format-B_QRD8Si.js +28 -0
- package/dist/heartbeat-visibility-BxkZjE5m.js +125 -0
- package/dist/heartbeat-visibility-CGG-G7px.js +125 -0
- package/dist/heartbeat-wake-LGEgcXjs.js +182 -0
- package/dist/heartbeat-wake-Y97geucO.js +182 -0
- package/dist/help-format-DAxf0l_h.js +17 -0
- package/dist/help-format-NNm_Ov4H.js +17 -0
- package/dist/helpers-BAsMXprO.js +25 -0
- package/dist/helpers-DLgbkcEn.js +25 -0
- package/dist/helpers-R7bU5IBz.js +10 -0
- package/dist/helpers-kkeXif0Q.js +10 -0
- package/dist/hook-runner-global-DJ14gXFP.js +527 -0
- package/dist/hooks-cli-DyEKryW8.js +1217 -0
- package/dist/hooks-cli-RuEn0-oy.js +1222 -0
- package/dist/host-env-security-Bms2_EMV.js +92 -0
- package/dist/host-env-security-szwfmhC4.js +92 -0
- package/dist/image-ops-Bi6JPSkD.js +354 -0
- package/dist/image-ops-DWytvdh_.js +354 -0
- package/dist/import-D8BBZQgl.js +170 -0
- package/dist/import-DQ6NI4Fz.js +168 -0
- package/dist/inbound-context-CPkkQW0i.js +68 -0
- package/dist/inbound-context-DS_kpIYI.js +68 -0
- package/dist/inbound-path-policy-Bg4gZBx-.js +250 -0
- package/dist/inbound-path-policy-sdr5Ji0k.js +250 -0
- package/dist/index.js +569 -0
- package/dist/input-provenance-Bn6thJNm.js +35 -0
- package/dist/input-provenance-xUsSMOsz.js +35 -0
- package/dist/inspect-Dt8hogS3.js +559 -0
- package/dist/inspect-vYIL1oA0.js +559 -0
- package/dist/installs-aM5dWAyn.js +325 -0
- package/dist/installs-pWdqG8HL.js +325 -0
- package/dist/ip-C9q3Oq20.js +200 -0
- package/dist/ip-D0zgNmBV.js +200 -0
- package/dist/ipv4--2WXMVtE.js +46 -0
- package/dist/ipv4-CDQpx1A7.js +46 -0
- package/dist/ir-BpaAMTfW.js +940 -0
- package/dist/is-main-DN8-sNR5.js +30 -0
- package/dist/json-file-B7l5-Xhr.js +25 -0
- package/dist/json-file-ChO_R9yh.js +25 -0
- package/dist/json-files-CmpYSF4G.js +46 -0
- package/dist/json-files-DzpTak5i.js +46 -0
- package/dist/lanes-ByWMUgrz.js +58 -0
- package/dist/lanes-cHJ5arWg.js +58 -0
- package/dist/links-Bz4V7R_p.js +15 -0
- package/dist/links-C3soDNDH.js +15 -0
- package/dist/loader-Ccwsh8Sh.js +22624 -0
- package/dist/loader-y9MhJewT.js +22621 -0
- package/dist/local-roots-BrH0Q63K.js +313 -0
- package/dist/local-roots-nImrw2WR.js +314 -0
- package/dist/location-DBWCGNLq.js +43 -0
- package/dist/location-GbZ0bBRU.js +43 -0
- package/dist/logger-BWMPnILd.js +47 -0
- package/dist/logger-Bw3cFE5t.js +49 -0
- package/dist/logger-DyL5G2DO.js +12 -0
- package/dist/logger-GvipVDfh.js +12 -0
- package/dist/logging-C-nxX2fn.js +20 -0
- package/dist/logging-D8-Kozjc.js +19 -0
- package/dist/login-C_Kt57nO.js +62 -0
- package/dist/login-DOmWDMeP.js +61 -0
- package/dist/login-qr-CXU0wC5K.js +322 -0
- package/dist/login-qr-D0u6fdeO.js +327 -0
- package/dist/logs-cli-CschwP4d.js +238 -0
- package/dist/logs-cli-D7ayUvz_.js +233 -0
- package/dist/markdown-tables-CrmghPAr.js +29 -0
- package/dist/markdown-tables-jrnSPvZ6.js +29 -0
- package/dist/media-CojxZ45J.js +10492 -0
- package/dist/media-DN7yRfrH.js +940 -0
- package/dist/message-action-names-CtEZcmlU.js +2521 -0
- package/dist/message-action-names-WglOO_DT.js +2521 -0
- package/dist/message-channel-DzJqHVZD.js +91 -0
- package/dist/message-channel-uWMAiywE.js +91 -0
- package/dist/mime-BS3jhcZE.js +149 -0
- package/dist/mime-Cxh_64P6.js +149 -0
- package/dist/mutable-allowlist-detectors-DiZDtmlZ.js +64 -0
- package/dist/mutable-allowlist-detectors-U5ThQr9V.js +64 -0
- package/dist/net-Cg8AQeke.js +225 -0
- package/dist/net-D6D0wgcF.js +225 -0
- package/dist/node-cli-Q2-n3Fgv.js +24 -0
- package/dist/node-cli-Uf6lAntf.js +24 -0
- package/dist/nodes-cli-C2SoKfCv.js +1343 -0
- package/dist/nodes-cli-CQmlfx0K.js +1348 -0
- package/dist/nodes-screen-BR9sYoPa.js +250 -0
- package/dist/nodes-screen-Cw7Hv7M2.js +250 -0
- package/dist/note-Dlv4NmlQ.js +92 -0
- package/dist/note-kvWV4xtw.js +92 -0
- package/dist/npm-registry-spec-0qiKawvv.js +786 -0
- package/dist/npm-registry-spec-COvUzy5J.js +786 -0
- package/dist/npm-resolution-6v_Zm-9G.js +86 -0
- package/dist/npm-resolution-BFz7LeoN.js +86 -0
- package/dist/onboard-CgyU-mDL.js +407 -0
- package/dist/onboard-RI4vNTZd.js +405 -0
- package/dist/onboard-channels-DN5JoKPd.js +2548 -0
- package/dist/onboard-channels-DyAd1OZr.js +2547 -0
- package/dist/onboard-config-BCTthQ7J.js +24 -0
- package/dist/onboard-config-y-2cgT0V.js +24 -0
- package/dist/onboard-helpers-BCzZUD0z.js +363 -0
- package/dist/onboard-helpers-sDc2Ky6H.js +362 -0
- package/dist/onboard-remote-CJrMtttl.js +127 -0
- package/dist/onboard-remote-hyQIBguz.js +127 -0
- package/dist/onboarding-DCu1iBTV.js +541 -0
- package/dist/onboarding-zKMitzpb.js +543 -0
- package/dist/onboarding.finalize-ClHhYE2E.js +401 -0
- package/dist/onboarding.finalize-D5JkVJgg.js +398 -0
- package/dist/onboarding.gateway-config-DFh71Ndn.js +198 -0
- package/dist/onboarding.gateway-config-VBk6AP9U.js +191 -0
- package/dist/outbound-BYlZshIw.js +221 -0
- package/dist/outbound-CFfJC1j5.js +220 -0
- package/dist/outbound-attachment-BCNs1u1F.js +18 -0
- package/dist/outbound-attachment-B_0D60Yr.js +18 -0
- package/dist/outbound-attachment-o0seS0CP.js +18 -0
- package/dist/pairing-cli-BeydfoF9.js +122 -0
- package/dist/pairing-cli-DWzX866x.js +127 -0
- package/dist/pairing-labels-B-N8S5Fc.js +9 -0
- package/dist/pairing-labels-B_53dY5L.js +9 -0
- package/dist/pairing-store-BxdqFZGK.js +460 -0
- package/dist/pairing-store-CTkD51uW.js +459 -0
- package/dist/parse-log-line-enq8pduH.js +44 -0
- package/dist/parse-log-line-mz9TG6ig.js +44 -0
- package/dist/parse-timeout-BMP8a0_a.js +16 -0
- package/dist/parse-timeout-CDkco8kd.js +16 -0
- package/dist/path-env-DR5vn3QL.js +89 -0
- package/dist/path-env-qRJbjJzj.js +89 -0
- package/dist/path-guards-CIx4hURU.js +31 -0
- package/dist/path-guards-CrQOUlsq.js +31 -0
- package/dist/path-safety-DkT9RmTG.js +14 -0
- package/dist/path-safety-juI2XbO1.js +14 -0
- package/dist/paths-BTaH3rLn.js +232 -0
- package/dist/plugin-auto-enable-D23gv7Aw.js +302 -0
- package/dist/plugin-auto-enable-DuPS9XiJ.js +301 -0
- package/dist/plugin-registry-CNu_1KZz.js +33 -0
- package/dist/plugin-registry-DeHwd2jk.js +33 -0
- package/dist/plugin-sdk/account-id.d.ts +1 -0
- package/dist/plugin-sdk/account-id.js +34 -0
- package/dist/plugin-sdk/agents/agent-helpers/errors.d.ts +55 -0
- package/dist/plugin-sdk/agents/agent-helpers/google.d.ts +3 -0
- package/dist/plugin-sdk/agents/agent-helpers/images.d.ts +21 -0
- package/dist/plugin-sdk/agents/agent-helpers/message-sanitization.d.ts +14 -0
- package/dist/plugin-sdk/agents/agent-helpers/messaging-dedupe.d.ts +10 -0
- package/dist/plugin-sdk/agents/agent-helpers/openai.d.ts +9 -0
- package/dist/plugin-sdk/agents/agent-helpers/thinking.d.ts +5 -0
- package/dist/plugin-sdk/agents/agent-helpers/turns.d.ts +20 -0
- package/dist/plugin-sdk/agents/agent-helpers/types.d.ts +1 -0
- package/dist/plugin-sdk/agents/agent-helpers.d.ts +11 -0
- package/dist/plugin-sdk/agents/agent-messaging.d.ts +8 -0
- package/dist/plugin-sdk/agents/agent-paths.d.ts +1 -0
- package/dist/plugin-sdk/agents/agent-scope.d.ts +61 -0
- package/dist/plugin-sdk/agents/agent-types.d.ts +78 -0
- package/dist/plugin-sdk/agents/agent-utils.d.ts +39 -0
- package/dist/plugin-sdk/agents/announce-idempotency.d.ts +11 -0
- package/dist/plugin-sdk/agents/api-key-rotation.d.ts +22 -0
- package/dist/plugin-sdk/agents/auth-profiles/constants.d.ts +16 -0
- package/dist/plugin-sdk/agents/auth-profiles/display.d.ts +7 -0
- package/dist/plugin-sdk/agents/auth-profiles/doctor.d.ts +8 -0
- package/dist/plugin-sdk/agents/auth-profiles/oauth.d.ts +14 -0
- package/dist/plugin-sdk/agents/auth-profiles/paths.d.ts +4 -0
- package/dist/plugin-sdk/agents/auth-profiles/profiles.d.ts +12 -0
- package/dist/plugin-sdk/agents/auth-profiles/session-override.d.ts +18 -0
- package/dist/plugin-sdk/agents/auth-profiles/store.d.ts +10 -0
- package/dist/plugin-sdk/agents/auth-profiles/types.d.ts +13 -0
- package/dist/plugin-sdk/agents/auth-profiles.d.ts +8 -0
- package/dist/plugin-sdk/agents/block-chunker.d.ts +19 -0
- package/dist/plugin-sdk/agents/channel-tools.d.ts +27 -0
- package/dist/plugin-sdk/agents/cli-session.d.ts +3 -0
- package/dist/plugin-sdk/agents/current-time.d.ts +17 -0
- package/dist/plugin-sdk/agents/date-time.d.ts +13 -0
- package/dist/plugin-sdk/agents/defaults.d.ts +3 -0
- package/dist/plugin-sdk/agents/identity-avatar.d.ts +15 -0
- package/dist/plugin-sdk/agents/identity.d.ts +28 -0
- package/dist/plugin-sdk/agents/image-sanitization.d.ts +8 -0
- package/dist/plugin-sdk/agents/lanes.d.ts +3 -0
- package/dist/plugin-sdk/agents/live-auth-keys.d.ts +6 -0
- package/dist/plugin-sdk/agents/owner-display.d.ts +19 -0
- package/dist/plugin-sdk/agents/provider-auth.d.ts +40 -0
- package/dist/plugin-sdk/agents/provider-utils.d.ts +21 -0
- package/dist/plugin-sdk/agents/schema/typebox.d.ts +14 -0
- package/dist/plugin-sdk/agents/session-write-lock.d.ts +53 -0
- package/dist/plugin-sdk/agents/stable-stringify.d.ts +1 -0
- package/dist/plugin-sdk/agents/subagent-announce-queue.d.ts +24 -0
- package/dist/plugin-sdk/agents/subagent-announce.d.ts +39 -0
- package/dist/plugin-sdk/agents/subagent-depth.d.ts +11 -0
- package/dist/plugin-sdk/agents/subagent-lifecycle-events.d.ts +18 -0
- package/dist/plugin-sdk/agents/subagent-registry-cleanup.d.ts +24 -0
- package/dist/plugin-sdk/agents/subagent-registry-completion.d.ts +15 -0
- package/dist/plugin-sdk/agents/subagent-registry-queries.d.ts +11 -0
- package/dist/plugin-sdk/agents/subagent-registry-state.d.ts +7 -0
- package/dist/plugin-sdk/agents/subagent-registry.d.ts +45 -0
- package/dist/plugin-sdk/agents/subagent-registry.store.d.ts +5 -0
- package/dist/plugin-sdk/agents/subagent-registry.types.d.ts +34 -0
- package/dist/plugin-sdk/agents/subagent-spawn.d.ts +47 -0
- package/dist/plugin-sdk/agents/timeout.d.ts +8 -0
- package/dist/plugin-sdk/agents/tool-call-id.d.ts +27 -0
- package/dist/plugin-sdk/agents/tool-display-common.d.ts +32 -0
- package/dist/plugin-sdk/agents/tool-display.d.ts +15 -0
- package/dist/plugin-sdk/agents/tool-images.d.ts +10 -0
- package/dist/plugin-sdk/agents/tools/agent-step.d.ts +15 -0
- package/dist/plugin-sdk/agents/tools/common.d.ts +80 -0
- package/dist/plugin-sdk/agents/tools/discord-actions-guild.d.ts +4 -0
- package/dist/plugin-sdk/agents/tools/discord-actions-messaging.d.ts +6 -0
- package/dist/plugin-sdk/agents/tools/discord-actions-moderation-shared.d.ts +13 -0
- package/dist/plugin-sdk/agents/tools/discord-actions-moderation.d.ts +4 -0
- package/dist/plugin-sdk/agents/tools/discord-actions-presence.d.ts +4 -0
- package/dist/plugin-sdk/agents/tools/discord-actions.d.ts +5 -0
- package/dist/plugin-sdk/agents/tools/sessions-access.d.ts +42 -0
- package/dist/plugin-sdk/agents/tools/sessions-helpers.d.ts +52 -0
- package/dist/plugin-sdk/agents/tools/sessions-resolution.d.ts +59 -0
- package/dist/plugin-sdk/agents/tools/sessions-send-helpers.d.ts +34 -0
- package/dist/plugin-sdk/agents/tools/slack-actions.d.ts +15 -0
- package/dist/plugin-sdk/agents/tools/telegram-actions.d.ts +7 -0
- package/dist/plugin-sdk/agents/tools/whatsapp-actions.d.ts +3 -0
- package/dist/plugin-sdk/agents/tools/whatsapp-target-auth.d.ts +10 -0
- package/dist/plugin-sdk/agents/usage.d.ts +49 -0
- package/dist/plugin-sdk/agents/workspace.d.ts +1 -0
- package/dist/plugin-sdk/auto-reply/chunk.d.ts +45 -0
- package/dist/plugin-sdk/auto-reply/command-auth.d.ts +17 -0
- package/dist/plugin-sdk/auto-reply/command-detection.d.ts +13 -0
- package/dist/plugin-sdk/auto-reply/commands-args.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/commands-registry.d.ts +47 -0
- package/dist/plugin-sdk/auto-reply/commands-registry.data.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/commands-registry.types.d.ts +66 -0
- package/dist/plugin-sdk/auto-reply/dispatch.d.ts +32 -0
- package/dist/plugin-sdk/auto-reply/envelope.d.ts +58 -0
- package/dist/plugin-sdk/auto-reply/fallback-state.d.ts +55 -0
- package/dist/plugin-sdk/auto-reply/group-activation.d.ts +6 -0
- package/dist/plugin-sdk/auto-reply/heartbeat-reply-payload.d.ts +2 -0
- package/dist/plugin-sdk/auto-reply/heartbeat.d.ts +16 -0
- package/dist/plugin-sdk/auto-reply/inbound-debounce.d.ts +17 -0
- package/dist/plugin-sdk/auto-reply/media-note.d.ts +2 -0
- package/dist/plugin-sdk/auto-reply/model-runtime.d.ts +17 -0
- package/dist/plugin-sdk/auto-reply/model.d.ts +8 -0
- package/dist/plugin-sdk/auto-reply/reply/abort.d.ts +32 -0
- package/dist/plugin-sdk/auto-reply/reply/agent-runner-execution.d.ts +59 -0
- package/dist/plugin-sdk/auto-reply/reply/agent-runner-helpers.d.ts +15 -0
- package/dist/plugin-sdk/auto-reply/reply/agent-runner-payloads.d.ts +27 -0
- package/dist/plugin-sdk/auto-reply/reply/agent-runner-utils.d.ts +152 -0
- package/dist/plugin-sdk/auto-reply/reply/agent-runner.d.ts +36 -0
- package/dist/plugin-sdk/auto-reply/reply/block-reply-coalescer.d.ts +15 -0
- package/dist/plugin-sdk/auto-reply/reply/block-reply-pipeline.d.ts +31 -0
- package/dist/plugin-sdk/auto-reply/reply/block-streaming.d.ts +22 -0
- package/dist/plugin-sdk/auto-reply/reply/body.d.ts +10 -0
- package/dist/plugin-sdk/auto-reply/reply/command-gates.d.ts +18 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-allowlist.d.ts +2 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-config.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-context.d.ts +12 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-core.d.ts +13 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-export-session.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-info.d.ts +11 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-plugin.d.ts +13 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-session.d.ts +8 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-setunset-standard.d.ts +10 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-setunset.d.ts +34 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-slash-parse.d.ts +24 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-status.d.ts +26 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/action-agents.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/action-focus.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/action-help.d.ts +2 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/action-info.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/action-kill.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/action-list.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/action-log.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/action-send.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/action-spawn.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/action-unfocus.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents/shared.d.ts +81 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-subagents.d.ts +4 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-tts.d.ts +2 -0
- package/dist/plugin-sdk/auto-reply/reply/commands-types.d.ts +61 -0
- package/dist/plugin-sdk/auto-reply/reply/commands.d.ts +4 -0
- package/dist/plugin-sdk/auto-reply/reply/config-commands.d.ts +15 -0
- package/dist/plugin-sdk/auto-reply/reply/config-value.d.ts +4 -0
- package/dist/plugin-sdk/auto-reply/reply/debug-commands.d.ts +16 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-handling.auth.d.ts +19 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-handling.d.ts +6 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-handling.fast-lane.d.ts +7 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-handling.impl.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-handling.levels.d.ts +20 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-handling.params.d.ts +59 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-handling.parse.d.ts +65 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-handling.persist.d.ts +42 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-handling.queue-validation.d.ts +10 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-handling.shared.d.ts +29 -0
- package/dist/plugin-sdk/auto-reply/reply/directive-parsing.d.ts +5 -0
- package/dist/plugin-sdk/auto-reply/reply/directives.d.ts +58 -0
- package/dist/plugin-sdk/auto-reply/reply/dispatch-from-config.d.ts +16 -0
- package/dist/plugin-sdk/auto-reply/reply/dispatcher-registry.d.ts +24 -0
- package/dist/plugin-sdk/auto-reply/reply/elevated-allowlist-matcher.d.ts +20 -0
- package/dist/plugin-sdk/auto-reply/reply/elevated-unavailable.d.ts +8 -0
- package/dist/plugin-sdk/auto-reply/reply/followup-runner.d.ts +16 -0
- package/dist/plugin-sdk/auto-reply/reply/get-reply-directives-apply.d.ts +64 -0
- package/dist/plugin-sdk/auto-reply/reply/get-reply-directives-utils.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/get-reply-directives.d.ts +121 -0
- package/dist/plugin-sdk/auto-reply/reply/get-reply-inline-actions.d.ts +56 -0
- package/dist/plugin-sdk/auto-reply/reply/get-reply-run.d.ts +73 -0
- package/dist/plugin-sdk/auto-reply/reply/get-reply.d.ts +4 -0
- package/dist/plugin-sdk/auto-reply/reply/groups.d.ts +26 -0
- package/dist/plugin-sdk/auto-reply/reply/history.d.ts +72 -0
- package/dist/plugin-sdk/auto-reply/reply/inbound-context.d.ts +8 -0
- package/dist/plugin-sdk/auto-reply/reply/inbound-dedupe.d.ts +8 -0
- package/dist/plugin-sdk/auto-reply/reply/inbound-meta.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/inbound-text.d.ts +1 -0
- package/dist/plugin-sdk/auto-reply/reply/line-directives.d.ts +22 -0
- package/dist/plugin-sdk/auto-reply/reply/mentions.d.ts +19 -0
- package/dist/plugin-sdk/auto-reply/reply/normalize-reply.d.ts +11 -0
- package/dist/plugin-sdk/auto-reply/reply/origin-routing.d.ts +13 -0
- package/dist/plugin-sdk/auto-reply/reply/provider-dispatcher.d.ts +19 -0
- package/dist/plugin-sdk/auto-reply/reply/queue/cleanup.d.ts +6 -0
- package/dist/plugin-sdk/auto-reply/reply/queue/directive.d.ts +15 -0
- package/dist/plugin-sdk/auto-reply/reply/queue/drain.d.ts +2 -0
- package/dist/plugin-sdk/auto-reply/reply/queue/enqueue.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/queue/normalize.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/reply/queue/settings.d.ts +2 -0
- package/dist/plugin-sdk/auto-reply/reply/queue/state.d.ts +20 -0
- package/dist/plugin-sdk/auto-reply/reply/queue/types.d.ts +87 -0
- package/dist/plugin-sdk/auto-reply/reply/queue-policy.d.ts +8 -0
- package/dist/plugin-sdk/auto-reply/reply/queue.d.ts +8 -0
- package/dist/plugin-sdk/auto-reply/reply/reply-delivery.d.ts +27 -0
- package/dist/plugin-sdk/auto-reply/reply/reply-directives.d.ts +14 -0
- package/dist/plugin-sdk/auto-reply/reply/reply-dispatcher.d.ts +53 -0
- package/dist/plugin-sdk/auto-reply/reply/reply-elevated.d.ts +16 -0
- package/dist/plugin-sdk/auto-reply/reply/reply-inline.d.ts +8 -0
- package/dist/plugin-sdk/auto-reply/reply/reply-payloads.d.ts +27 -0
- package/dist/plugin-sdk/auto-reply/reply/reply-reference.d.ts +20 -0
- package/dist/plugin-sdk/auto-reply/reply/reply-tags.d.ts +6 -0
- package/dist/plugin-sdk/auto-reply/reply/reply-threading.d.ts +9 -0
- package/dist/plugin-sdk/auto-reply/reply/response-prefix-template.d.ts +51 -0
- package/dist/plugin-sdk/auto-reply/reply/route-reply.d.ts +56 -0
- package/dist/plugin-sdk/auto-reply/reply/session-reset-prompt.d.ts +1 -0
- package/dist/plugin-sdk/auto-reply/reply/session-run-accounting.d.ts +11 -0
- package/dist/plugin-sdk/auto-reply/reply/session-updates.d.ts +18 -0
- package/dist/plugin-sdk/auto-reply/reply/session-usage.d.ts +21 -0
- package/dist/plugin-sdk/auto-reply/reply/session.d.ts +26 -0
- package/dist/plugin-sdk/auto-reply/reply/strip-inbound-meta.d.ts +27 -0
- package/dist/plugin-sdk/auto-reply/reply/subagents-utils.d.ts +26 -0
- package/dist/plugin-sdk/auto-reply/reply/typing-mode.d.ts +27 -0
- package/dist/plugin-sdk/auto-reply/reply/typing.d.ts +18 -0
- package/dist/plugin-sdk/auto-reply/reply/untrusted-context.d.ts +1 -0
- package/dist/plugin-sdk/auto-reply/reply.d.ts +5 -0
- package/dist/plugin-sdk/auto-reply/send-policy.d.ts +6 -0
- package/dist/plugin-sdk/auto-reply/status.d.ts +59 -0
- package/dist/plugin-sdk/auto-reply/templating.d.ts +159 -0
- package/dist/plugin-sdk/auto-reply/thinking.d.ts +22 -0
- package/dist/plugin-sdk/auto-reply/tokens.d.ts +3 -0
- package/dist/plugin-sdk/auto-reply/types.d.ts +82 -0
- package/dist/plugin-sdk/channel-web.d.ts +6 -0
- package/dist/plugin-sdk/channels/account-summary.d.ts +17 -0
- package/dist/plugin-sdk/channels/ack-reactions.d.ts +29 -0
- package/dist/plugin-sdk/channels/allow-from.d.ts +11 -0
- package/dist/plugin-sdk/channels/allowlist-match.d.ts +16 -0
- package/dist/plugin-sdk/channels/allowlists/resolve-utils.d.ts +33 -0
- package/dist/plugin-sdk/channels/channel-config.d.ts +39 -0
- package/dist/plugin-sdk/channels/chat-type.d.ts +2 -0
- package/dist/plugin-sdk/channels/command-gating.d.ts +20 -0
- package/dist/plugin-sdk/channels/conversation-label.d.ts +2 -0
- package/dist/plugin-sdk/channels/dock.d.ts +25 -0
- package/dist/plugin-sdk/channels/draft-stream-controls.d.ts +54 -0
- package/dist/plugin-sdk/channels/draft-stream-loop.d.ts +13 -0
- package/dist/plugin-sdk/channels/location.d.ts +21 -0
- package/dist/plugin-sdk/channels/logging.d.ts +20 -0
- package/dist/plugin-sdk/channels/mention-gating.d.ts +27 -0
- package/dist/plugin-sdk/channels/model-overrides.d.ts +18 -0
- package/dist/plugin-sdk/channels/plugins/account-action-gate.d.ts +5 -0
- package/dist/plugin-sdk/channels/plugins/account-helpers.d.ts +6 -0
- package/dist/plugin-sdk/channels/plugins/actions/discord/handle-action.d.ts +3 -0
- package/dist/plugin-sdk/channels/plugins/actions/discord/handle-action.guild-admin.d.ts +9 -0
- package/dist/plugin-sdk/channels/plugins/actions/discord.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/actions/shared.d.ts +7 -0
- package/dist/plugin-sdk/channels/plugins/actions/signal.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/actions/telegram.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/agent-tools/whatsapp-login.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/allowlist-match.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/bluebubbles-actions.d.ts +48 -0
- package/dist/plugin-sdk/channels/plugins/channel-config.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/config-helpers.d.ts +14 -0
- package/dist/plugin-sdk/channels/plugins/config-schema.d.ts +3 -0
- package/dist/plugin-sdk/channels/plugins/config-writes.d.ts +7 -0
- package/dist/plugin-sdk/channels/plugins/directory-config.d.ts +16 -0
- package/dist/plugin-sdk/channels/plugins/group-mentions.d.ts +18 -0
- package/dist/plugin-sdk/channels/plugins/helpers.d.ts +8 -0
- package/dist/plugin-sdk/channels/plugins/index.d.ts +8 -0
- package/dist/plugin-sdk/channels/plugins/media-limits.d.ts +9 -0
- package/dist/plugin-sdk/channels/plugins/media-payload.d.ts +15 -0
- package/dist/plugin-sdk/channels/plugins/message-action-names.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/normalize/discord.d.ts +14 -0
- package/dist/plugin-sdk/channels/plugins/normalize/imessage.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/normalize/shared.d.ts +6 -0
- package/dist/plugin-sdk/channels/plugins/normalize/signal.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/normalize/slack.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/normalize/telegram.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/normalize/whatsapp.d.ts +3 -0
- package/dist/plugin-sdk/channels/plugins/onboarding/channel-access-configure.d.ts +21 -0
- package/dist/plugin-sdk/channels/plugins/onboarding/channel-access.d.ts +31 -0
- package/dist/plugin-sdk/channels/plugins/onboarding/discord.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/onboarding/helpers.d.ts +177 -0
- package/dist/plugin-sdk/channels/plugins/onboarding/imessage.d.ts +6 -0
- package/dist/plugin-sdk/channels/plugins/onboarding/signal.d.ts +7 -0
- package/dist/plugin-sdk/channels/plugins/onboarding/slack.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/onboarding/telegram.d.ts +4 -0
- package/dist/plugin-sdk/channels/plugins/onboarding/whatsapp.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/onboarding-types.d.ts +77 -0
- package/dist/plugin-sdk/channels/plugins/outbound/load.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/pairing-message.d.ts +1 -0
- package/dist/plugin-sdk/channels/plugins/pairing.d.ts +16 -0
- package/dist/plugin-sdk/channels/plugins/registry-loader.d.ts +5 -0
- package/dist/plugin-sdk/channels/plugins/setup-helpers.d.ts +13 -0
- package/dist/plugin-sdk/channels/plugins/status-issues/bluebubbles.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/status-issues/discord.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/status-issues/shared.d.ts +29 -0
- package/dist/plugin-sdk/channels/plugins/status-issues/telegram.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/status-issues/whatsapp.d.ts +2 -0
- package/dist/plugin-sdk/channels/plugins/types.adapters.d.ts +288 -0
- package/dist/plugin-sdk/channels/plugins/types.core.d.ts +349 -0
- package/dist/plugin-sdk/channels/plugins/types.d.ts +6 -0
- package/dist/plugin-sdk/channels/plugins/types.plugin.d.ts +54 -0
- package/dist/plugin-sdk/channels/plugins/whatsapp-heartbeat.d.ts +11 -0
- package/dist/plugin-sdk/channels/plugins/whatsapp-shared.d.ts +5 -0
- package/dist/plugin-sdk/channels/registry.d.ts +15 -0
- package/dist/plugin-sdk/channels/reply-prefix.d.ts +24 -0
- package/dist/plugin-sdk/channels/sender-label.d.ts +9 -0
- package/dist/plugin-sdk/channels/session.d.ts +18 -0
- package/dist/plugin-sdk/channels/status-reactions.d.ts +62 -0
- package/dist/plugin-sdk/channels/targets.d.ts +42 -0
- package/dist/plugin-sdk/channels/telegram/api.d.ts +5 -0
- package/dist/plugin-sdk/channels/typing-lifecycle.d.ts +12 -0
- package/dist/plugin-sdk/channels/typing.d.ts +13 -0
- package/dist/plugin-sdk/channels/web/index.d.ts +1 -0
- package/dist/plugin-sdk/cli/cli-name.d.ts +3 -0
- package/dist/plugin-sdk/cli/command-format.d.ts +1 -0
- package/dist/plugin-sdk/cli/deps.d.ts +18 -0
- package/dist/plugin-sdk/cli/outbound-send-deps.d.ts +4 -0
- package/dist/plugin-sdk/cli/outbound-send-mapping.d.ts +10 -0
- package/dist/plugin-sdk/cli/parse-bytes.d.ts +4 -0
- package/dist/plugin-sdk/cli/parse-duration.d.ts +4 -0
- package/dist/plugin-sdk/cli/profile-utils.d.ts +2 -0
- package/dist/plugin-sdk/cli/progress.d.ts +24 -0
- package/dist/plugin-sdk/cli/wait.d.ts +1 -0
- package/dist/plugin-sdk/commands/agent/delivery.d.ts +25 -0
- package/dist/plugin-sdk/commands/agent/run-context.d.ts +2 -0
- package/dist/plugin-sdk/commands/agent/session-store.d.ts +16 -0
- package/dist/plugin-sdk/commands/agent/session.d.ts +33 -0
- package/dist/plugin-sdk/commands/agent/types.d.ts +89 -0
- package/dist/plugin-sdk/commands/agent.d.ts +14 -0
- package/dist/plugin-sdk/commands/daemon-runtime.d.ts +8 -0
- package/dist/plugin-sdk/commands/health.d.ts +63 -0
- package/dist/plugin-sdk/commands/oauth-flow.d.ts +21 -0
- package/dist/plugin-sdk/commands/onboard-helpers.d.ts +81 -0
- package/dist/plugin-sdk/commands/onboard-types.d.ts +69 -0
- package/dist/plugin-sdk/commands/signal-install.d.ts +30 -0
- package/dist/plugin-sdk/compat/legacy-names.d.ts +8 -0
- package/dist/plugin-sdk/config/agent-dirs.d.ts +14 -0
- package/dist/plugin-sdk/config/agent-limits.d.ts +6 -0
- package/dist/plugin-sdk/config/backup-rotation.d.ts +5 -0
- package/dist/plugin-sdk/config/cache-utils.d.ts +6 -0
- package/dist/plugin-sdk/config/commands.d.ts +20 -0
- package/dist/plugin-sdk/config/config-paths.d.ts +10 -0
- package/dist/plugin-sdk/config/config.d.ts +7 -0
- package/dist/plugin-sdk/config/dangerous-name-matching.d.ts +12 -0
- package/dist/plugin-sdk/config/defaults.d.ts +19 -0
- package/dist/plugin-sdk/config/discord-preview-streaming.d.ts +25 -0
- package/dist/plugin-sdk/config/env-preserve.d.ts +10 -0
- package/dist/plugin-sdk/config/env-substitution.d.ts +36 -0
- package/dist/plugin-sdk/config/env-vars.d.ts +6 -0
- package/dist/plugin-sdk/config/group-policy.d.ts +49 -0
- package/dist/plugin-sdk/config/includes.d.ts +32 -0
- package/dist/plugin-sdk/config/io.d.ts +60 -0
- package/dist/plugin-sdk/config/legacy-migrate.d.ts +5 -0
- package/dist/plugin-sdk/config/legacy.d.ts +6 -0
- package/dist/plugin-sdk/config/legacy.migrations.d.ts +1 -0
- package/dist/plugin-sdk/config/legacy.migrations.part-1.d.ts +2 -0
- package/dist/plugin-sdk/config/legacy.migrations.part-2.d.ts +2 -0
- package/dist/plugin-sdk/config/legacy.migrations.part-3.d.ts +2 -0
- package/dist/plugin-sdk/config/legacy.rules.d.ts +2 -0
- package/dist/plugin-sdk/config/legacy.shared.d.ts +19 -0
- package/dist/plugin-sdk/config/markdown-tables.d.ts +7 -0
- package/dist/plugin-sdk/config/merge-config.d.ts +7 -0
- package/dist/plugin-sdk/config/merge-patch.d.ts +5 -0
- package/dist/plugin-sdk/config/model-input.d.ts +9 -0
- package/dist/plugin-sdk/config/normalize-paths.d.ts +8 -0
- package/dist/plugin-sdk/config/paths.d.ts +57 -0
- package/dist/plugin-sdk/config/prototype-keys.d.ts +1 -0
- package/dist/plugin-sdk/config/runtime-group-policy.d.ts +56 -0
- package/dist/plugin-sdk/config/runtime-overrides.d.ts +15 -0
- package/dist/plugin-sdk/config/sessions/artifacts.d.ts +5 -0
- package/dist/plugin-sdk/config/sessions/constants.d.ts +2 -0
- package/dist/plugin-sdk/config/sessions/delivery-info.d.ts +16 -0
- package/dist/plugin-sdk/config/sessions/disk-budget.d.ts +28 -0
- package/dist/plugin-sdk/config/sessions/group.d.ts +11 -0
- package/dist/plugin-sdk/config/sessions/main-session.d.ts +43 -0
- package/dist/plugin-sdk/config/sessions/metadata.d.ts +16 -0
- package/dist/plugin-sdk/config/sessions/paths.d.ts +21 -0
- package/dist/plugin-sdk/config/sessions/reset.d.ts +43 -0
- package/dist/plugin-sdk/config/sessions/session-file.d.ts +15 -0
- package/dist/plugin-sdk/config/sessions/session-key.d.ts +8 -0
- package/dist/plugin-sdk/config/sessions/store.d.ts +123 -0
- package/dist/plugin-sdk/config/sessions/transcript.d.ts +18 -0
- package/dist/plugin-sdk/config/sessions/types.d.ts +160 -0
- package/dist/plugin-sdk/config/sessions.d.ts +13 -0
- package/dist/plugin-sdk/config/talk.d.ts +21 -0
- package/dist/plugin-sdk/config/telegram-custom-commands.d.ts +24 -0
- package/dist/plugin-sdk/config/types.agent-defaults.d.ts +268 -0
- package/dist/plugin-sdk/config/types.agents-shared.d.ts +49 -0
- package/dist/plugin-sdk/config/types.agents.d.ts +57 -0
- package/dist/plugin-sdk/config/types.approvals.d.ts +26 -0
- package/dist/plugin-sdk/config/types.auth.d.ts +28 -0
- package/dist/plugin-sdk/config/types.base.d.ts +203 -0
- package/dist/plugin-sdk/config/types.browser.d.ts +65 -0
- package/dist/plugin-sdk/config/types.channel-messaging-common.d.ts +44 -0
- package/dist/plugin-sdk/config/types.channels.d.ts +53 -0
- package/dist/plugin-sdk/config/types.cron.d.ts +26 -0
- package/dist/plugin-sdk/config/types.d.ts +27 -0
- package/dist/plugin-sdk/config/types.discord.d.ts +273 -0
- package/dist/plugin-sdk/config/types.gateway.d.ts +335 -0
- package/dist/plugin-sdk/config/types.googlechat.d.ts +107 -0
- package/dist/plugin-sdk/config/types.hooks.d.ts +123 -0
- package/dist/plugin-sdk/config/types.imessage.d.ts +77 -0
- package/dist/plugin-sdk/config/types.installs.d.ts +14 -0
- package/dist/plugin-sdk/config/types.irc.d.ts +54 -0
- package/dist/plugin-sdk/config/types.messages.d.ts +154 -0
- package/dist/plugin-sdk/config/types.models.d.ts +41 -0
- package/dist/plugin-sdk/config/types.msteams.d.ts +108 -0
- package/dist/plugin-sdk/config/types.node-host.d.ts +10 -0
- package/dist/plugin-sdk/config/types.plugins.d.ts +23 -0
- package/dist/plugin-sdk/config/types.queue.d.ts +14 -0
- package/dist/plugin-sdk/config/types.remoteclaw.d.ts +119 -0
- package/dist/plugin-sdk/config/types.signal.d.ts +46 -0
- package/dist/plugin-sdk/config/types.slack.d.ts +181 -0
- package/dist/plugin-sdk/config/types.telegram.d.ts +191 -0
- package/dist/plugin-sdk/config/types.tools.d.ts +322 -0
- package/dist/plugin-sdk/config/types.tts.d.ts +78 -0
- package/dist/plugin-sdk/config/types.whatsapp.d.ts +101 -0
- package/dist/plugin-sdk/config/validation.d.ts +37 -0
- package/dist/plugin-sdk/config/version.d.ts +8 -0
- package/dist/plugin-sdk/config/zod-schema.agent-defaults.d.ts +156 -0
- package/dist/plugin-sdk/config/zod-schema.agent-model.d.ts +5 -0
- package/dist/plugin-sdk/config/zod-schema.agent-runtime.d.ts +500 -0
- package/dist/plugin-sdk/config/zod-schema.agents.d.ts +298 -0
- package/dist/plugin-sdk/config/zod-schema.allowdeny.d.ts +13 -0
- package/dist/plugin-sdk/config/zod-schema.approvals.d.ts +15 -0
- package/dist/plugin-sdk/config/zod-schema.channels.d.ts +6 -0
- package/dist/plugin-sdk/config/zod-schema.core.d.ts +583 -0
- package/dist/plugin-sdk/config/zod-schema.d.ts +3434 -0
- package/dist/plugin-sdk/config/zod-schema.hooks.d.ts +85 -0
- package/dist/plugin-sdk/config/zod-schema.installs.d.ts +16 -0
- package/dist/plugin-sdk/config/zod-schema.providers-core.d.ts +3693 -0
- package/dist/plugin-sdk/config/zod-schema.providers-whatsapp.d.ts +235 -0
- package/dist/plugin-sdk/config/zod-schema.providers.d.ts +2200 -0
- package/dist/plugin-sdk/config/zod-schema.sensitive.d.ts +2 -0
- package/dist/plugin-sdk/config/zod-schema.session.d.ts +234 -0
- package/dist/plugin-sdk/cron/delivery.d.ts +9 -0
- package/dist/plugin-sdk/cron/legacy-delivery.d.ts +3 -0
- package/dist/plugin-sdk/cron/parse.d.ts +1 -0
- package/dist/plugin-sdk/cron/payload-migration.d.ts +3 -0
- package/dist/plugin-sdk/cron/schedule.d.ts +2 -0
- package/dist/plugin-sdk/cron/service/jobs.d.ts +21 -0
- package/dist/plugin-sdk/cron/service/locked.d.ts +2 -0
- package/dist/plugin-sdk/cron/service/normalize.d.ts +18 -0
- package/dist/plugin-sdk/cron/service/ops.d.ts +81 -0
- package/dist/plugin-sdk/cron/service/state.d.ts +125 -0
- package/dist/plugin-sdk/cron/service/store.d.ts +9 -0
- package/dist/plugin-sdk/cron/service/timer.d.ts +47 -0
- package/dist/plugin-sdk/cron/service.d.ts +66 -0
- package/dist/plugin-sdk/cron/session-reaper.d.ts +35 -0
- package/dist/plugin-sdk/cron/stagger.d.ts +8 -0
- package/dist/plugin-sdk/cron/store.d.ts +6 -0
- package/dist/plugin-sdk/cron/types.d.ts +131 -0
- package/dist/plugin-sdk/cron/webhook-url.d.ts +1 -0
- package/dist/plugin-sdk/daemon/constants.d.ts +35 -0
- package/dist/plugin-sdk/discord/accounts.d.ts +21 -0
- package/dist/plugin-sdk/discord/api.d.ts +11 -0
- package/dist/plugin-sdk/discord/audit.d.ts +29 -0
- package/dist/plugin-sdk/discord/chunk.d.ts +20 -0
- package/dist/plugin-sdk/discord/client.d.ts +21 -0
- package/dist/plugin-sdk/discord/components-registry.d.ts +16 -0
- package/dist/plugin-sdk/discord/components.d.ts +196 -0
- package/dist/plugin-sdk/discord/directory-live.d.ts +4 -0
- package/dist/plugin-sdk/discord/draft-chunking.d.ts +6 -0
- package/dist/plugin-sdk/discord/draft-stream.d.ts +21 -0
- package/dist/plugin-sdk/discord/gateway-logging.d.ts +8 -0
- package/dist/plugin-sdk/discord/guilds.d.ts +6 -0
- package/dist/plugin-sdk/discord/monitor/agent-components.d.ts +55 -0
- package/dist/plugin-sdk/discord/monitor/allow-list.d.ts +176 -0
- package/dist/plugin-sdk/discord/monitor/commands.d.ts +2 -0
- package/dist/plugin-sdk/discord/monitor/format.d.ts +13 -0
- package/dist/plugin-sdk/discord/monitor/gateway-plugin.d.ts +8 -0
- package/dist/plugin-sdk/discord/monitor/gateway-registry.d.ts +9 -0
- package/dist/plugin-sdk/discord/monitor/listeners.d.ts +44 -0
- package/dist/plugin-sdk/discord/monitor/message-handler.d.ts +5 -0
- package/dist/plugin-sdk/discord/monitor/message-handler.preflight.d.ts +14 -0
- package/dist/plugin-sdk/discord/monitor/message-handler.preflight.types.d.ts +95 -0
- package/dist/plugin-sdk/discord/monitor/message-handler.process.d.ts +2 -0
- package/dist/plugin-sdk/discord/monitor/message-utils.d.ts +40 -0
- package/dist/plugin-sdk/discord/monitor/native-command.d.ts +23 -0
- package/dist/plugin-sdk/discord/monitor/presence-cache.d.ts +9 -0
- package/dist/plugin-sdk/discord/monitor/presence.d.ts +5 -0
- package/dist/plugin-sdk/discord/monitor/provider.allowlist.d.ts +14 -0
- package/dist/plugin-sdk/discord/monitor/provider.d.ts +28 -0
- package/dist/plugin-sdk/discord/monitor/provider.lifecycle.d.ts +23 -0
- package/dist/plugin-sdk/discord/monitor/reply-context.d.ts +17 -0
- package/dist/plugin-sdk/discord/monitor/reply-delivery.d.ts +22 -0
- package/dist/plugin-sdk/discord/monitor/rest-fetch.d.ts +2 -0
- package/dist/plugin-sdk/discord/monitor/sender-identity.d.ts +31 -0
- package/dist/plugin-sdk/discord/monitor/system-events.d.ts +2 -0
- package/dist/plugin-sdk/discord/monitor/thread-bindings.d.ts +5 -0
- package/dist/plugin-sdk/discord/monitor/thread-bindings.discord-api.d.ts +36 -0
- package/dist/plugin-sdk/discord/monitor/thread-bindings.lifecycle.d.ts +30 -0
- package/dist/plugin-sdk/discord/monitor/thread-bindings.manager.d.ts +17 -0
- package/dist/plugin-sdk/discord/monitor/thread-bindings.messages.d.ts +17 -0
- package/dist/plugin-sdk/discord/monitor/thread-bindings.state.d.ts +61 -0
- package/dist/plugin-sdk/discord/monitor/thread-bindings.types.d.ts +64 -0
- package/dist/plugin-sdk/discord/monitor/threading.d.ts +106 -0
- package/dist/plugin-sdk/discord/monitor/typing.d.ts +5 -0
- package/dist/plugin-sdk/discord/monitor.d.ts +10 -0
- package/dist/plugin-sdk/discord/monitor.gateway.d.ts +12 -0
- package/dist/plugin-sdk/discord/pluralkit.d.ts +26 -0
- package/dist/plugin-sdk/discord/probe.d.ts +28 -0
- package/dist/plugin-sdk/discord/resolve-channels.d.ts +15 -0
- package/dist/plugin-sdk/discord/resolve-users.d.ts +14 -0
- package/dist/plugin-sdk/discord/send.channels.d.ts +17 -0
- package/dist/plugin-sdk/discord/send.components.d.ts +17 -0
- package/dist/plugin-sdk/discord/send.d.ts +10 -0
- package/dist/plugin-sdk/discord/send.emojis-stickers.d.ts +4 -0
- package/dist/plugin-sdk/discord/send.guild.d.ts +24 -0
- package/dist/plugin-sdk/discord/send.messages.d.ts +20 -0
- package/dist/plugin-sdk/discord/send.outbound.d.ts +57 -0
- package/dist/plugin-sdk/discord/send.permissions.d.ts +20 -0
- package/dist/plugin-sdk/discord/send.reactions.d.ts +15 -0
- package/dist/plugin-sdk/discord/send.shared.d.ts +85 -0
- package/dist/plugin-sdk/discord/send.types.d.ts +144 -0
- package/dist/plugin-sdk/discord/targets.d.ts +18 -0
- package/dist/plugin-sdk/discord/token.d.ts +11 -0
- package/dist/plugin-sdk/discord/voice/command.d.ts +15 -0
- package/dist/plugin-sdk/discord/voice/manager.d.ts +52 -0
- package/dist/plugin-sdk/discord/voice-message.d.ts +50 -0
- package/dist/plugin-sdk/gateway/call.d.ts +65 -0
- package/dist/plugin-sdk/gateway/chat-abort.d.ts +44 -0
- package/dist/plugin-sdk/gateway/chat-sanitize.d.ts +4 -0
- package/dist/plugin-sdk/gateway/client.d.ts +64 -0
- package/dist/plugin-sdk/gateway/control-ui-shared.d.ts +9 -0
- package/dist/plugin-sdk/gateway/credentials.d.ts +36 -0
- package/dist/plugin-sdk/gateway/device-auth.d.ts +11 -0
- package/dist/plugin-sdk/gateway/method-scopes.d.ts +22 -0
- package/dist/plugin-sdk/gateway/net.d.ts +77 -0
- package/dist/plugin-sdk/gateway/node-registry.d.ts +60 -0
- package/dist/plugin-sdk/gateway/protocol/client-info.d.ts +58 -0
- package/dist/plugin-sdk/gateway/protocol/index.d.ts +497 -0
- package/dist/plugin-sdk/gateway/protocol/schema/agent.d.ts +89 -0
- package/dist/plugin-sdk/gateway/protocol/schema/agents-models-skills.d.ts +188 -0
- package/dist/plugin-sdk/gateway/protocol/schema/channels.d.ts +134 -0
- package/dist/plugin-sdk/gateway/protocol/schema/config.d.ts +53 -0
- package/dist/plugin-sdk/gateway/protocol/schema/cron.d.ts +324 -0
- package/dist/plugin-sdk/gateway/protocol/schema/devices.d.ts +41 -0
- package/dist/plugin-sdk/gateway/protocol/schema/error-codes.d.ts +14 -0
- package/dist/plugin-sdk/gateway/protocol/schema/frames.d.ts +168 -0
- package/dist/plugin-sdk/gateway/protocol/schema/logs-chat.d.ts +45 -0
- package/dist/plugin-sdk/gateway/protocol/schema/nodes.d.ts +64 -0
- package/dist/plugin-sdk/gateway/protocol/schema/primitives.d.ts +4 -0
- package/dist/plugin-sdk/gateway/protocol/schema/protocol-schemas.d.ts +3 -0
- package/dist/plugin-sdk/gateway/protocol/schema/push.d.ts +15 -0
- package/dist/plugin-sdk/gateway/protocol/schema/sessions.d.ts +81 -0
- package/dist/plugin-sdk/gateway/protocol/schema/snapshot.d.ts +69 -0
- package/dist/plugin-sdk/gateway/protocol/schema/types.d.ts +120 -0
- package/dist/plugin-sdk/gateway/protocol/schema/wizard.d.ts +86 -0
- package/dist/plugin-sdk/gateway/protocol/schema.d.ts +16 -0
- package/dist/plugin-sdk/gateway/server/ws-types.d.ts +9 -0
- package/dist/plugin-sdk/gateway/server-broadcast.d.ts +17 -0
- package/dist/plugin-sdk/gateway/server-channels.d.ts +26 -0
- package/dist/plugin-sdk/gateway/server-constants.d.ts +10 -0
- package/dist/plugin-sdk/gateway/server-methods/types.d.ts +84 -0
- package/dist/plugin-sdk/gateway/server-shared.d.ts +7 -0
- package/dist/plugin-sdk/gateway/session-utils.fs.d.ts +48 -0
- package/dist/plugin-sdk/gateway/session-utils.types.d.ts +84 -0
- package/dist/plugin-sdk/gateway/ws-log.d.ts +5 -0
- package/dist/plugin-sdk/gateway/ws-logging.d.ts +4 -0
- package/dist/plugin-sdk/globals.d.ts +11 -0
- package/dist/plugin-sdk/hooks/internal-hooks.d.ts +140 -0
- package/dist/plugin-sdk/hooks/types.d.ts +62 -0
- package/dist/plugin-sdk/imessage/accounts.d.ts +16 -0
- package/dist/plugin-sdk/imessage/client.d.ts +46 -0
- package/dist/plugin-sdk/imessage/constants.d.ts +2 -0
- package/dist/plugin-sdk/imessage/monitor/abort-handler.d.ts +9 -0
- package/dist/plugin-sdk/imessage/monitor/deliver.d.ts +14 -0
- package/dist/plugin-sdk/imessage/monitor/echo-cache.d.ts +9 -0
- package/dist/plugin-sdk/imessage/monitor/inbound-processing.d.ts +96 -0
- package/dist/plugin-sdk/imessage/monitor/monitor-provider.d.ts +7 -0
- package/dist/plugin-sdk/imessage/monitor/parse-notification.d.ts +2 -0
- package/dist/plugin-sdk/imessage/monitor/runtime.d.ts +4 -0
- package/dist/plugin-sdk/imessage/monitor/types.d.ts +37 -0
- package/dist/plugin-sdk/imessage/monitor.d.ts +2 -0
- package/dist/plugin-sdk/imessage/probe.d.ts +17 -0
- package/dist/plugin-sdk/imessage/send.d.ts +34 -0
- package/dist/plugin-sdk/imessage/target-parsing-helpers.d.ts +45 -0
- package/dist/plugin-sdk/imessage/targets.d.ts +39 -0
- package/dist/plugin-sdk/index.d.ts +1 -0
- package/dist/plugin-sdk/index.js +24645 -0
- package/dist/plugin-sdk/infra/agent-events.d.ts +21 -0
- package/dist/plugin-sdk/infra/archive-path.d.ts +12 -0
- package/dist/plugin-sdk/infra/archive.d.ts +46 -0
- package/dist/plugin-sdk/infra/backoff.d.ts +8 -0
- package/dist/plugin-sdk/infra/brew.d.ts +8 -0
- package/dist/plugin-sdk/infra/channel-activity.d.ts +18 -0
- package/dist/plugin-sdk/infra/channel-summary.d.ts +6 -0
- package/dist/plugin-sdk/infra/dedupe.d.ts +12 -0
- package/dist/plugin-sdk/infra/device-auth-store.d.ts +18 -0
- package/dist/plugin-sdk/infra/device-identity.d.ts +11 -0
- package/dist/plugin-sdk/infra/device-pairing.d.ts +101 -0
- package/dist/plugin-sdk/infra/diagnostic-events.d.ts +140 -0
- package/dist/plugin-sdk/infra/diagnostic-flags.d.ts +4 -0
- package/dist/plugin-sdk/infra/dotenv.d.ts +3 -0
- package/dist/plugin-sdk/infra/env.d.ts +11 -0
- package/dist/plugin-sdk/infra/errors.d.ts +11 -0
- package/dist/plugin-sdk/infra/fetch.d.ts +2 -0
- package/dist/plugin-sdk/infra/file-identity.d.ts +5 -0
- package/dist/plugin-sdk/infra/file-lock.d.ts +2 -0
- package/dist/plugin-sdk/infra/format-time/format-datetime.d.ts +35 -0
- package/dist/plugin-sdk/infra/format-time/format-duration.d.ts +23 -0
- package/dist/plugin-sdk/infra/format-time/format-relative.d.ts +39 -0
- package/dist/plugin-sdk/infra/fs-safe.d.ts +25 -0
- package/dist/plugin-sdk/infra/gemini-auth.d.ts +16 -0
- package/dist/plugin-sdk/infra/git-commit.d.ts +4 -0
- package/dist/plugin-sdk/infra/git-root.d.ts +7 -0
- package/dist/plugin-sdk/infra/heartbeat-active-hours.d.ts +5 -0
- package/dist/plugin-sdk/infra/heartbeat-events-filter.d.ts +8 -0
- package/dist/plugin-sdk/infra/heartbeat-events.d.ts +21 -0
- package/dist/plugin-sdk/infra/heartbeat-reason.d.ts +5 -0
- package/dist/plugin-sdk/infra/heartbeat-runner.d.ts +45 -0
- package/dist/plugin-sdk/infra/heartbeat-visibility.d.ts +17 -0
- package/dist/plugin-sdk/infra/heartbeat-wake.d.ts +31 -0
- package/dist/plugin-sdk/infra/home-dir.d.ts +7 -0
- package/dist/plugin-sdk/infra/host-env-security.d.ts +21 -0
- package/dist/plugin-sdk/infra/http-body.d.ts +46 -0
- package/dist/plugin-sdk/infra/json-file.d.ts +2 -0
- package/dist/plugin-sdk/infra/json-files.d.ts +5 -0
- package/dist/plugin-sdk/infra/map-size.d.ts +1 -0
- package/dist/plugin-sdk/infra/net/fetch-guard.d.ts +21 -0
- package/dist/plugin-sdk/infra/net/hostname.d.ts +1 -0
- package/dist/plugin-sdk/infra/net/ssrf.d.ts +35 -0
- package/dist/plugin-sdk/infra/outbound/abort.d.ts +8 -0
- package/dist/plugin-sdk/infra/outbound/agent-delivery.d.ts +46 -0
- package/dist/plugin-sdk/infra/outbound/bound-delivery-router.d.ts +16 -0
- package/dist/plugin-sdk/infra/outbound/channel-selection.d.ts +11 -0
- package/dist/plugin-sdk/infra/outbound/channel-target.d.ts +6 -0
- package/dist/plugin-sdk/infra/outbound/deliver.d.ts +81 -0
- package/dist/plugin-sdk/infra/outbound/delivery-queue.d.ts +78 -0
- package/dist/plugin-sdk/infra/outbound/directory-cache.d.ts +24 -0
- package/dist/plugin-sdk/infra/outbound/envelope.d.ts +16 -0
- package/dist/plugin-sdk/infra/outbound/format.d.ts +39 -0
- package/dist/plugin-sdk/infra/outbound/identity.d.ts +8 -0
- package/dist/plugin-sdk/infra/outbound/message-action-spec.d.ts +5 -0
- package/dist/plugin-sdk/infra/outbound/payloads.d.ts +18 -0
- package/dist/plugin-sdk/infra/outbound/session-binding-service.d.ts +57 -0
- package/dist/plugin-sdk/infra/outbound/target-errors.d.ts +6 -0
- package/dist/plugin-sdk/infra/outbound/target-normalization.d.ts +4 -0
- package/dist/plugin-sdk/infra/outbound/target-resolver.d.ts +53 -0
- package/dist/plugin-sdk/infra/outbound/targets.d.ts +87 -0
- package/dist/plugin-sdk/infra/pairing-files.d.ts +23 -0
- package/dist/plugin-sdk/infra/pairing-pending.d.ts +13 -0
- package/dist/plugin-sdk/infra/pairing-token.d.ts +3 -0
- package/dist/plugin-sdk/infra/path-guards.d.ts +5 -0
- package/dist/plugin-sdk/infra/path-safety.d.ts +2 -0
- package/dist/plugin-sdk/infra/plain-object.d.ts +4 -0
- package/dist/plugin-sdk/infra/prototype-keys.d.ts +1 -0
- package/dist/plugin-sdk/infra/provider-usage.auth.d.ts +11 -0
- package/dist/plugin-sdk/infra/provider-usage.d.ts +4 -0
- package/dist/plugin-sdk/infra/provider-usage.fetch.claude.d.ts +2 -0
- package/dist/plugin-sdk/infra/provider-usage.fetch.codex.d.ts +2 -0
- package/dist/plugin-sdk/infra/provider-usage.fetch.copilot.d.ts +2 -0
- package/dist/plugin-sdk/infra/provider-usage.fetch.d.ts +6 -0
- package/dist/plugin-sdk/infra/provider-usage.fetch.gemini.d.ts +2 -0
- package/dist/plugin-sdk/infra/provider-usage.fetch.minimax.d.ts +2 -0
- package/dist/plugin-sdk/infra/provider-usage.fetch.shared.d.ts +12 -0
- package/dist/plugin-sdk/infra/provider-usage.fetch.zai.d.ts +2 -0
- package/dist/plugin-sdk/infra/provider-usage.format.d.ts +13 -0
- package/dist/plugin-sdk/infra/provider-usage.load.d.ts +12 -0
- package/dist/plugin-sdk/infra/provider-usage.shared.d.ts +8 -0
- package/dist/plugin-sdk/infra/provider-usage.types.d.ts +17 -0
- package/dist/plugin-sdk/infra/restart.d.ts +70 -0
- package/dist/plugin-sdk/infra/retry-policy.d.ts +25 -0
- package/dist/plugin-sdk/infra/retry.d.ts +21 -0
- package/dist/plugin-sdk/infra/safe-executable-value.d.ts +1 -0
- package/dist/plugin-sdk/infra/scp-host.d.ts +2 -0
- package/dist/plugin-sdk/infra/secure-random.d.ts +2 -0
- package/dist/plugin-sdk/infra/session-cost-usage.d.ts +45 -0
- package/dist/plugin-sdk/infra/session-cost-usage.types.d.ts +153 -0
- package/dist/plugin-sdk/infra/session-maintenance-warning.d.ts +10 -0
- package/dist/plugin-sdk/infra/shell-env.d.ts +34 -0
- package/dist/plugin-sdk/infra/system-events.d.ts +18 -0
- package/dist/plugin-sdk/infra/tailnet.d.ts +8 -0
- package/dist/plugin-sdk/infra/tls/fingerprint.d.ts +1 -0
- package/dist/plugin-sdk/infra/tls/gateway.d.ts +16 -0
- package/dist/plugin-sdk/infra/tmp-remoteclaw-dir.d.ts +18 -0
- package/dist/plugin-sdk/infra/transport-ready.d.ts +16 -0
- package/dist/plugin-sdk/infra/unhandled-rejections.d.ts +15 -0
- package/dist/plugin-sdk/infra/ws.d.ts +2 -0
- package/dist/plugin-sdk/infra/wsl.d.ts +11 -0
- package/dist/plugin-sdk/line/accounts.d.ts +10 -0
- package/dist/plugin-sdk/line/actions.d.ts +22 -0
- package/dist/plugin-sdk/line/auto-reply-delivery.d.ts +38 -0
- package/dist/plugin-sdk/line/bot-access.d.ts +17 -0
- package/dist/plugin-sdk/line/bot-handlers.d.ts +13 -0
- package/dist/plugin-sdk/line/bot-message-context.d.ts +118 -0
- package/dist/plugin-sdk/line/bot.d.ts +24 -0
- package/dist/plugin-sdk/line/channel-access-token.d.ts +4 -0
- package/dist/plugin-sdk/line/config-schema.d.ts +64 -0
- package/dist/plugin-sdk/line/download.d.ts +7 -0
- package/dist/plugin-sdk/line/flex-templates/basic-cards.d.ts +46 -0
- package/dist/plugin-sdk/line/flex-templates/common.d.ts +2 -0
- package/dist/plugin-sdk/line/flex-templates/media-control-cards.d.ts +73 -0
- package/dist/plugin-sdk/line/flex-templates/message.d.ts +6 -0
- package/dist/plugin-sdk/line/flex-templates/schedule-cards.d.ts +55 -0
- package/dist/plugin-sdk/line/flex-templates/types.d.ts +19 -0
- package/dist/plugin-sdk/line/flex-templates.d.ts +5 -0
- package/dist/plugin-sdk/line/markdown-to-line.d.ts +72 -0
- package/dist/plugin-sdk/line/monitor.d.ts +28 -0
- package/dist/plugin-sdk/line/probe.d.ts +2 -0
- package/dist/plugin-sdk/line/reply-chunks.d.ts +24 -0
- package/dist/plugin-sdk/line/send.d.ts +91 -0
- package/dist/plugin-sdk/line/signature.d.ts +1 -0
- package/dist/plugin-sdk/line/template-messages.d.ts +100 -0
- package/dist/plugin-sdk/line/types.d.ts +113 -0
- package/dist/plugin-sdk/line/webhook-node.d.ts +15 -0
- package/dist/plugin-sdk/line/webhook-utils.d.ts +3 -0
- package/dist/plugin-sdk/line/webhook.d.ts +19 -0
- package/dist/plugin-sdk/link-understanding/apply.d.ts +10 -0
- package/dist/plugin-sdk/link-understanding/defaults.d.ts +2 -0
- package/dist/plugin-sdk/link-understanding/detect.d.ts +3 -0
- package/dist/plugin-sdk/link-understanding/format.d.ts +4 -0
- package/dist/plugin-sdk/link-understanding/runner.d.ts +11 -0
- package/dist/plugin-sdk/logger.d.ts +6 -0
- package/dist/plugin-sdk/logging/config.d.ts +4 -0
- package/dist/plugin-sdk/logging/console.d.ts +23 -0
- package/dist/plugin-sdk/logging/diagnostic-session-state.d.ts +30 -0
- package/dist/plugin-sdk/logging/diagnostic.d.ts +65 -0
- package/dist/plugin-sdk/logging/env-log-level.d.ts +2 -0
- package/dist/plugin-sdk/logging/levels.d.ts +5 -0
- package/dist/plugin-sdk/logging/logger.d.ts +44 -0
- package/dist/plugin-sdk/logging/node-require.d.ts +1 -0
- package/dist/plugin-sdk/logging/redact-identifier.d.ts +4 -0
- package/dist/plugin-sdk/logging/redact.d.ts +9 -0
- package/dist/plugin-sdk/logging/state.d.ts +19 -0
- package/dist/plugin-sdk/logging/subsystem.d.ts +18 -0
- package/dist/plugin-sdk/logging/timestamps.d.ts +1 -0
- package/dist/plugin-sdk/logging.d.ts +10 -0
- package/dist/plugin-sdk/markdown/fences.d.ts +10 -0
- package/dist/plugin-sdk/markdown/ir.d.ts +32 -0
- package/dist/plugin-sdk/markdown/render.d.ts +18 -0
- package/dist/plugin-sdk/markdown/tables.d.ts +2 -0
- package/dist/plugin-sdk/markdown/whatsapp.d.ts +14 -0
- package/dist/plugin-sdk/media/audio-tags.d.ts +10 -0
- package/dist/plugin-sdk/media/audio.d.ts +19 -0
- package/dist/plugin-sdk/media/base64.d.ts +6 -0
- package/dist/plugin-sdk/media/constants.d.ts +7 -0
- package/dist/plugin-sdk/media/fetch.d.ts +23 -0
- package/dist/plugin-sdk/media/image-ops.d.ts +41 -0
- package/dist/plugin-sdk/media/inbound-path-policy.d.ts +18 -0
- package/dist/plugin-sdk/media/input-files.d.ts +95 -0
- package/dist/plugin-sdk/media/local-roots.d.ts +3 -0
- package/dist/plugin-sdk/media/mime.d.ts +16 -0
- package/dist/plugin-sdk/media/outbound-attachment.d.ts +6 -0
- package/dist/plugin-sdk/media/parse.d.ts +8 -0
- package/dist/plugin-sdk/media/png-encode.d.ts +8 -0
- package/dist/plugin-sdk/media/read-response-with-limit.d.ts +7 -0
- package/dist/plugin-sdk/media/store.d.ts +33 -0
- package/dist/plugin-sdk/media-understanding/apply.d.ts +19 -0
- package/dist/plugin-sdk/media-understanding/attachments.d.ts +49 -0
- package/dist/plugin-sdk/media-understanding/audio-preflight.d.ts +16 -0
- package/dist/plugin-sdk/media-understanding/concurrency.d.ts +1 -0
- package/dist/plugin-sdk/media-understanding/defaults.d.ts +12 -0
- package/dist/plugin-sdk/media-understanding/errors.d.ts +6 -0
- package/dist/plugin-sdk/media-understanding/format.d.ts +7 -0
- package/dist/plugin-sdk/media-understanding/fs.d.ts +1 -0
- package/dist/plugin-sdk/media-understanding/output-extract.d.ts +2 -0
- package/dist/plugin-sdk/media-understanding/providers/anthropic/index.d.ts +2 -0
- package/dist/plugin-sdk/media-understanding/providers/deepgram/audio.d.ts +4 -0
- package/dist/plugin-sdk/media-understanding/providers/deepgram/index.d.ts +2 -0
- package/dist/plugin-sdk/media-understanding/providers/google/audio.d.ts +3 -0
- package/dist/plugin-sdk/media-understanding/providers/google/index.d.ts +2 -0
- package/dist/plugin-sdk/media-understanding/providers/google/inline-data.d.ts +20 -0
- package/dist/plugin-sdk/media-understanding/providers/google/video.d.ts +3 -0
- package/dist/plugin-sdk/media-understanding/providers/groq/index.d.ts +2 -0
- package/dist/plugin-sdk/media-understanding/providers/index.d.ts +4 -0
- package/dist/plugin-sdk/media-understanding/providers/minimax/index.d.ts +2 -0
- package/dist/plugin-sdk/media-understanding/providers/mistral/index.d.ts +2 -0
- package/dist/plugin-sdk/media-understanding/providers/moonshot/index.d.ts +2 -0
- package/dist/plugin-sdk/media-understanding/providers/moonshot/video.d.ts +3 -0
- package/dist/plugin-sdk/media-understanding/providers/openai/audio.d.ts +3 -0
- package/dist/plugin-sdk/media-understanding/providers/openai/index.d.ts +2 -0
- package/dist/plugin-sdk/media-understanding/providers/shared.d.ts +20 -0
- package/dist/plugin-sdk/media-understanding/providers/zai/index.d.ts +2 -0
- package/dist/plugin-sdk/media-understanding/resolve.d.ts +44 -0
- package/dist/plugin-sdk/media-understanding/runner.d.ts +34 -0
- package/dist/plugin-sdk/media-understanding/runner.entries.d.ts +33 -0
- package/dist/plugin-sdk/media-understanding/scope.d.ts +9 -0
- package/dist/plugin-sdk/media-understanding/types.d.ts +74 -0
- package/dist/plugin-sdk/media-understanding/video.d.ts +2 -0
- package/dist/plugin-sdk/middleware/channel-bridge.d.ts +39 -0
- package/dist/plugin-sdk/middleware/cli-runtime-base.d.ts +35 -0
- package/dist/plugin-sdk/middleware/delivery-adapter.d.ts +36 -0
- package/dist/plugin-sdk/middleware/error-classifier.d.ts +14 -0
- package/dist/plugin-sdk/middleware/mcp-side-effects.d.ts +20 -0
- package/dist/plugin-sdk/middleware/runtime-factory.d.ts +4 -0
- package/dist/plugin-sdk/middleware/runtimes/claude.d.ts +27 -0
- package/dist/plugin-sdk/middleware/runtimes/codex.d.ts +74 -0
- package/dist/plugin-sdk/middleware/runtimes/gemini.d.ts +52 -0
- package/dist/plugin-sdk/middleware/runtimes/opencode.d.ts +54 -0
- package/dist/plugin-sdk/middleware/session-map.d.ts +36 -0
- package/dist/plugin-sdk/middleware/system-prompt.d.ts +30 -0
- package/dist/plugin-sdk/middleware/types.d.ts +188 -0
- package/dist/plugin-sdk/pairing/pairing-labels.d.ts +2 -0
- package/dist/plugin-sdk/pairing/pairing-messages.d.ts +6 -0
- package/dist/plugin-sdk/pairing/pairing-store.d.ts +48 -0
- package/dist/plugin-sdk/plugin-sdk/account-id.d.ts +1 -0
- package/dist/plugin-sdk/plugin-sdk/agent-media-payload.d.ts +12 -0
- package/dist/plugin-sdk/plugin-sdk/allow-from.d.ts +32 -0
- package/dist/plugin-sdk/plugin-sdk/command-auth.d.ts +25 -0
- package/dist/plugin-sdk/plugin-sdk/config-paths.d.ts +6 -0
- package/dist/plugin-sdk/plugin-sdk/file-lock.d.ts +16 -0
- package/dist/plugin-sdk/plugin-sdk/group-access.d.ts +16 -0
- package/dist/plugin-sdk/plugin-sdk/index.d.ts +162 -0
- package/dist/plugin-sdk/plugin-sdk/json-store.d.ts +5 -0
- package/dist/plugin-sdk/plugin-sdk/onboarding.d.ts +11 -0
- package/dist/plugin-sdk/plugin-sdk/persistent-dedupe.d.ts +20 -0
- package/dist/plugin-sdk/plugin-sdk/reply-payload.d.ts +22 -0
- package/dist/plugin-sdk/plugin-sdk/run-command.d.ts +12 -0
- package/dist/plugin-sdk/plugin-sdk/runtime.d.ts +10 -0
- package/dist/plugin-sdk/plugin-sdk/slack-message-actions.d.ts +11 -0
- package/dist/plugin-sdk/plugin-sdk/status-helpers.d.ts +88 -0
- package/dist/plugin-sdk/plugin-sdk/temp-path.d.ts +12 -0
- package/dist/plugin-sdk/plugin-sdk/text-chunking.d.ts +1 -0
- package/dist/plugin-sdk/plugin-sdk/tool-send.d.ts +4 -0
- package/dist/plugin-sdk/plugin-sdk/webhook-path.d.ts +6 -0
- package/dist/plugin-sdk/plugin-sdk/webhook-targets.d.ts +23 -0
- package/dist/plugin-sdk/plugins/bundled-dir.d.ts +1 -0
- package/dist/plugin-sdk/plugins/commands.d.ts +83 -0
- package/dist/plugin-sdk/plugins/config-schema.d.ts +2 -0
- package/dist/plugin-sdk/plugins/config-state.d.ts +30 -0
- package/dist/plugin-sdk/plugins/discovery.d.ts +24 -0
- package/dist/plugin-sdk/plugins/hook-runner-global.d.ts +37 -0
- package/dist/plugin-sdk/plugins/hooks.d.ts +49 -0
- package/dist/plugin-sdk/plugins/http-path.d.ts +1 -0
- package/dist/plugin-sdk/plugins/http-registry.d.ts +13 -0
- package/dist/plugin-sdk/plugins/manifest-registry.d.ts +34 -0
- package/dist/plugin-sdk/plugins/manifest.d.ts +66 -0
- package/dist/plugin-sdk/plugins/path-safety.d.ts +5 -0
- package/dist/plugin-sdk/plugins/registry.d.ts +130 -0
- package/dist/plugin-sdk/plugins/runtime/native-deps.d.ts +8 -0
- package/dist/plugin-sdk/plugins/runtime/types.d.ts +310 -0
- package/dist/plugin-sdk/plugins/runtime.d.ts +5 -0
- package/dist/plugin-sdk/plugins/schema-validator.d.ts +10 -0
- package/dist/plugin-sdk/plugins/types.d.ts +487 -0
- package/dist/plugin-sdk/polls.d.ts +31 -0
- package/dist/plugin-sdk/process/command-queue.d.ts +51 -0
- package/dist/plugin-sdk/process/exec.d.ts +30 -0
- package/dist/plugin-sdk/process/lanes.d.ts +6 -0
- package/dist/plugin-sdk/process/spawn-utils.d.ts +26 -0
- package/dist/plugin-sdk/routing/account-id.d.ts +3 -0
- package/dist/plugin-sdk/routing/account-lookup.d.ts +1 -0
- package/dist/plugin-sdk/routing/bindings.d.ts +11 -0
- package/dist/plugin-sdk/routing/resolve-route.d.ts +42 -0
- package/dist/plugin-sdk/routing/session-key.d.ts +48 -0
- package/dist/plugin-sdk/runtime.d.ts +7 -0
- package/dist/plugin-sdk/security/channel-metadata.d.ts +6 -0
- package/dist/plugin-sdk/security/dm-policy-shared.d.ts +33 -0
- package/dist/plugin-sdk/security/external-content.d.ts +53 -0
- package/dist/plugin-sdk/security/safe-regex.d.ts +2 -0
- package/dist/plugin-sdk/security/scan-paths.d.ts +5 -0
- package/dist/plugin-sdk/security/secret-equal.d.ts +1 -0
- package/dist/plugin-sdk/sessions/input-provenance.d.ts +16 -0
- package/dist/plugin-sdk/sessions/level-overrides.d.ts +10 -0
- package/dist/plugin-sdk/sessions/model-overrides.d.ts +14 -0
- package/dist/plugin-sdk/sessions/send-policy.d.ts +11 -0
- package/dist/plugin-sdk/sessions/session-key-utils.d.ts +16 -0
- package/dist/plugin-sdk/sessions/session-label.d.ts +9 -0
- package/dist/plugin-sdk/sessions/transcript-events.d.ts +7 -0
- package/dist/plugin-sdk/shared/avatar-policy.d.ts +16 -0
- package/dist/plugin-sdk/shared/chat-content.d.ts +5 -0
- package/dist/plugin-sdk/shared/chat-envelope.d.ts +2 -0
- package/dist/plugin-sdk/shared/device-auth.d.ts +13 -0
- package/dist/plugin-sdk/shared/gateway-bind-url.d.ts +14 -0
- package/dist/plugin-sdk/shared/net/ip.d.ts +19 -0
- package/dist/plugin-sdk/shared/operator-scope-compat.d.ts +5 -0
- package/dist/plugin-sdk/shared/pid-alive.d.ts +1 -0
- package/dist/plugin-sdk/shared/process-scoped-map.d.ts +1 -0
- package/dist/plugin-sdk/shared/string-normalization.d.ts +4 -0
- package/dist/plugin-sdk/shared/subagents-format.d.ts +15 -0
- package/dist/plugin-sdk/shared/tailscale-status.d.ts +8 -0
- package/dist/plugin-sdk/shared/text/code-regions.d.ts +6 -0
- package/dist/plugin-sdk/shared/text/reasoning-tags.d.ts +6 -0
- package/dist/plugin-sdk/shared/text-chunking.d.ts +1 -0
- package/dist/plugin-sdk/signal/accounts.d.ts +17 -0
- package/dist/plugin-sdk/signal/client.d.ts +32 -0
- package/dist/plugin-sdk/signal/daemon.d.ts +26 -0
- package/dist/plugin-sdk/signal/format.d.ts +17 -0
- package/dist/plugin-sdk/signal/identity.d.ts +24 -0
- package/dist/plugin-sdk/signal/index.d.ts +5 -0
- package/dist/plugin-sdk/signal/monitor/event-handler.d.ts +5 -0
- package/dist/plugin-sdk/signal/monitor/event-handler.types.d.ts +125 -0
- package/dist/plugin-sdk/signal/monitor/mentions.d.ts +2 -0
- package/dist/plugin-sdk/signal/monitor.d.ts +25 -0
- package/dist/plugin-sdk/signal/probe.d.ts +7 -0
- package/dist/plugin-sdk/signal/reaction-level.d.ts +17 -0
- package/dist/plugin-sdk/signal/rpc-context.d.ts +9 -0
- package/dist/plugin-sdk/signal/send-reactions.d.ts +32 -0
- package/dist/plugin-sdk/signal/send.d.ts +25 -0
- package/dist/plugin-sdk/signal/sse-reconnect.d.ts +13 -0
- package/dist/plugin-sdk/slack/accounts.d.ts +32 -0
- package/dist/plugin-sdk/slack/actions.d.ts +56 -0
- package/dist/plugin-sdk/slack/blocks-fallback.d.ts +2 -0
- package/dist/plugin-sdk/slack/blocks-input.d.ts +3 -0
- package/dist/plugin-sdk/slack/channel-migration.d.ts +20 -0
- package/dist/plugin-sdk/slack/client.d.ts +4 -0
- package/dist/plugin-sdk/slack/directory-live.d.ts +4 -0
- package/dist/plugin-sdk/slack/draft-stream.d.ts +25 -0
- package/dist/plugin-sdk/slack/format.d.ts +7 -0
- package/dist/plugin-sdk/slack/http/index.d.ts +1 -0
- package/dist/plugin-sdk/slack/http/registry.d.ts +12 -0
- package/dist/plugin-sdk/slack/index.d.ts +6 -0
- package/dist/plugin-sdk/slack/message-actions.d.ts +4 -0
- package/dist/plugin-sdk/slack/modal-metadata.d.ts +7 -0
- package/dist/plugin-sdk/slack/monitor/allow-list.d.ts +23 -0
- package/dist/plugin-sdk/slack/monitor/auth.d.ts +11 -0
- package/dist/plugin-sdk/slack/monitor/channel-config.d.ts +43 -0
- package/dist/plugin-sdk/slack/monitor/commands.d.ts +9 -0
- package/dist/plugin-sdk/slack/monitor/context.d.ts +104 -0
- package/dist/plugin-sdk/slack/monitor/events/channels.d.ts +4 -0
- package/dist/plugin-sdk/slack/monitor/events/interactions.d.ts +4 -0
- package/dist/plugin-sdk/slack/monitor/events/members.d.ts +4 -0
- package/dist/plugin-sdk/slack/monitor/events/messages.d.ts +6 -0
- package/dist/plugin-sdk/slack/monitor/events/pins.d.ts +4 -0
- package/dist/plugin-sdk/slack/monitor/events/reactions.d.ts +4 -0
- package/dist/plugin-sdk/slack/monitor/events.d.ts +8 -0
- package/dist/plugin-sdk/slack/monitor/external-arg-menu-store.d.ts +18 -0
- package/dist/plugin-sdk/slack/monitor/media.d.ts +66 -0
- package/dist/plugin-sdk/slack/monitor/message-handler/dispatch.d.ts +12 -0
- package/dist/plugin-sdk/slack/monitor/message-handler/prepare.d.ts +13 -0
- package/dist/plugin-sdk/slack/monitor/message-handler/types.d.ts +22 -0
- package/dist/plugin-sdk/slack/monitor/message-handler.d.ts +11 -0
- package/dist/plugin-sdk/slack/monitor/mrkdwn.d.ts +1 -0
- package/dist/plugin-sdk/slack/monitor/policy.d.ts +5 -0
- package/dist/plugin-sdk/slack/monitor/provider.d.ts +7 -0
- package/dist/plugin-sdk/slack/monitor/replies.d.ts +53 -0
- package/dist/plugin-sdk/slack/monitor/room-context.d.ts +14 -0
- package/dist/plugin-sdk/slack/monitor/slash.d.ts +6 -0
- package/dist/plugin-sdk/slack/monitor/thread-resolution.d.ts +12 -0
- package/dist/plugin-sdk/slack/monitor/types.d.ts +97 -0
- package/dist/plugin-sdk/slack/monitor.d.ts +5 -0
- package/dist/plugin-sdk/slack/probe.d.ts +14 -0
- package/dist/plugin-sdk/slack/resolve-channels.d.ts +19 -0
- package/dist/plugin-sdk/slack/resolve-users.d.ts +26 -0
- package/dist/plugin-sdk/slack/send.d.ts +22 -0
- package/dist/plugin-sdk/slack/stream-mode.d.ts +23 -0
- package/dist/plugin-sdk/slack/streaming.d.ts +72 -0
- package/dist/plugin-sdk/slack/targets.d.ts +7 -0
- package/dist/plugin-sdk/slack/threading-tool-context.d.ts +10 -0
- package/dist/plugin-sdk/slack/threading.d.ts +29 -0
- package/dist/plugin-sdk/slack/token.d.ts +3 -0
- package/dist/plugin-sdk/slack/types.d.ts +58 -0
- package/dist/plugin-sdk/telegram/accounts.d.ts +21 -0
- package/dist/plugin-sdk/telegram/allowed-updates.d.ts +4 -0
- package/dist/plugin-sdk/telegram/api-logging.d.ts +11 -0
- package/dist/plugin-sdk/telegram/audit.d.ts +29 -0
- package/dist/plugin-sdk/telegram/bot/delivery.d.ts +35 -0
- package/dist/plugin-sdk/telegram/bot/helpers.d.ts +128 -0
- package/dist/plugin-sdk/telegram/bot/types.d.ts +28 -0
- package/dist/plugin-sdk/telegram/bot-access.d.ts +26 -0
- package/dist/plugin-sdk/telegram/bot-handlers.d.ts +2 -0
- package/dist/plugin-sdk/telegram/bot-message-context.d.ts +145 -0
- package/dist/plugin-sdk/telegram/bot-message-dispatch.d.ts +19 -0
- package/dist/plugin-sdk/telegram/bot-message.d.ts +20 -0
- package/dist/plugin-sdk/telegram/bot-native-command-menu.d.ts +33 -0
- package/dist/plugin-sdk/telegram/bot-native-commands.d.ts +59 -0
- package/dist/plugin-sdk/telegram/bot-updates.d.ts +31 -0
- package/dist/plugin-sdk/telegram/bot.d.ts +62 -0
- package/dist/plugin-sdk/telegram/button-types.d.ts +7 -0
- package/dist/plugin-sdk/telegram/caption.d.ts +5 -0
- package/dist/plugin-sdk/telegram/dm-access.d.ts +18 -0
- package/dist/plugin-sdk/telegram/draft-stream.d.ts +37 -0
- package/dist/plugin-sdk/telegram/fetch.d.ts +5 -0
- package/dist/plugin-sdk/telegram/format.d.ts +18 -0
- package/dist/plugin-sdk/telegram/group-access.d.ts +54 -0
- package/dist/plugin-sdk/telegram/group-config-helpers.d.ts +8 -0
- package/dist/plugin-sdk/telegram/group-migration.d.ts +20 -0
- package/dist/plugin-sdk/telegram/inline-buttons.d.ts +11 -0
- package/dist/plugin-sdk/telegram/lane-delivery.d.ts +56 -0
- package/dist/plugin-sdk/telegram/monitor.d.ts +19 -0
- package/dist/plugin-sdk/telegram/network-config.d.ts +33 -0
- package/dist/plugin-sdk/telegram/network-errors.d.ts +5 -0
- package/dist/plugin-sdk/telegram/outbound-params.d.ts +2 -0
- package/dist/plugin-sdk/telegram/probe.d.ts +17 -0
- package/dist/plugin-sdk/telegram/proxy.d.ts +1 -0
- package/dist/plugin-sdk/telegram/reaction-level.d.ts +11 -0
- package/dist/plugin-sdk/telegram/reasoning-lane-coordinator.d.ts +18 -0
- package/dist/plugin-sdk/telegram/send.d.ts +153 -0
- package/dist/plugin-sdk/telegram/sent-message-cache.d.ts +16 -0
- package/dist/plugin-sdk/telegram/status-reaction-variants.d.ts +21 -0
- package/dist/plugin-sdk/telegram/sticker-cache.d.ts +47 -0
- package/dist/plugin-sdk/telegram/target-writeback.d.ts +7 -0
- package/dist/plugin-sdk/telegram/targets.d.ts +11 -0
- package/dist/plugin-sdk/telegram/token.d.ts +13 -0
- package/dist/plugin-sdk/telegram/update-offset-store.d.ts +15 -0
- package/dist/plugin-sdk/telegram/voice.d.ts +16 -0
- package/dist/plugin-sdk/telegram/webhook.d.ts +20 -0
- package/dist/plugin-sdk/terminal/ansi.d.ts +2 -0
- package/dist/plugin-sdk/terminal/health-style.d.ts +1 -0
- package/dist/plugin-sdk/terminal/links.d.ts +6 -0
- package/dist/plugin-sdk/terminal/palette.d.ts +10 -0
- package/dist/plugin-sdk/terminal/progress-line.d.ts +3 -0
- package/dist/plugin-sdk/terminal/prompt-style.d.ts +3 -0
- package/dist/plugin-sdk/terminal/restore.d.ts +17 -0
- package/dist/plugin-sdk/terminal/theme.d.ts +15 -0
- package/dist/plugin-sdk/tts/tts-core.d.ts +38 -0
- package/dist/plugin-sdk/tts/tts.d.ts +177 -0
- package/dist/plugin-sdk/types/agent-types.d.ts +1 -0
- package/dist/plugin-sdk/utils/account-id.d.ts +1 -0
- package/dist/plugin-sdk/utils/boolean.d.ts +5 -0
- package/dist/plugin-sdk/utils/chunk-items.d.ts +1 -0
- package/dist/plugin-sdk/utils/delivery-context.d.ts +29 -0
- package/dist/plugin-sdk/utils/directive-tags.d.ts +29 -0
- package/dist/plugin-sdk/utils/fetch-timeout.d.ts +13 -0
- package/dist/plugin-sdk/utils/mask-api-key.d.ts +1 -0
- package/dist/plugin-sdk/utils/message-channel.d.ts +27 -0
- package/dist/plugin-sdk/utils/normalize-secret-input.d.ts +11 -0
- package/dist/plugin-sdk/utils/provider-utils.d.ts +9 -0
- package/dist/plugin-sdk/utils/queue-helpers.d.ts +80 -0
- package/dist/plugin-sdk/utils/reaction-level.d.ts +15 -0
- package/dist/plugin-sdk/utils/run-with-concurrency.d.ts +11 -0
- package/dist/plugin-sdk/utils/transcript-tools.d.ts +8 -0
- package/dist/plugin-sdk/utils/usage-format.d.ts +26 -0
- package/dist/plugin-sdk/utils/with-timeout.d.ts +1 -0
- package/dist/plugin-sdk/utils.d.ts +63 -0
- package/dist/plugin-sdk/version.d.ts +8 -0
- package/dist/plugin-sdk/web/accounts.d.ts +39 -0
- package/dist/plugin-sdk/web/active-listener.d.ts +25 -0
- package/dist/plugin-sdk/web/auth-store.d.ts +26 -0
- package/dist/plugin-sdk/web/auto-reply/constants.d.ts +1 -0
- package/dist/plugin-sdk/web/auto-reply/deliver-reply.d.ts +19 -0
- package/dist/plugin-sdk/web/auto-reply/heartbeat-runner.d.ts +20 -0
- package/dist/plugin-sdk/web/auto-reply/loggers.d.ts +4 -0
- package/dist/plugin-sdk/web/auto-reply/mentions.d.ts +19 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/ack-reaction.d.ts +13 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/broadcast.d.ts +16 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/commands.d.ts +2 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/echo.d.ts +17 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/group-activation.d.ts +9 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/group-gating.d.ts +33 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/group-members.d.ts +6 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/last-route.d.ts +15 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/message-line.d.ts +11 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/on-message.d.ts +24 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/peer.d.ts +2 -0
- package/dist/plugin-sdk/web/auto-reply/monitor/process-message.d.ts +40 -0
- package/dist/plugin-sdk/web/auto-reply/monitor.d.ts +5 -0
- package/dist/plugin-sdk/web/auto-reply/session-snapshot.d.ts +17 -0
- package/dist/plugin-sdk/web/auto-reply/types.d.ts +30 -0
- package/dist/plugin-sdk/web/auto-reply/util.d.ts +2 -0
- package/dist/plugin-sdk/web/auto-reply.d.ts +1 -0
- package/dist/plugin-sdk/web/auto-reply.impl.d.ts +5 -0
- package/dist/plugin-sdk/web/inbound/access-control.d.ts +36 -0
- package/dist/plugin-sdk/web/inbound/dedupe.d.ts +2 -0
- package/dist/plugin-sdk/web/inbound/extract.d.ts +13 -0
- package/dist/plugin-sdk/web/inbound/media.d.ts +7 -0
- package/dist/plugin-sdk/web/inbound/monitor.d.ts +30 -0
- package/dist/plugin-sdk/web/inbound/send-api.d.ts +22 -0
- package/dist/plugin-sdk/web/inbound/types.d.ts +41 -0
- package/dist/plugin-sdk/web/inbound.d.ts +4 -0
- package/dist/plugin-sdk/web/login-qr.d.ts +19 -0
- package/dist/plugin-sdk/web/login.d.ts +3 -0
- package/dist/plugin-sdk/web/media.d.ts +43 -0
- package/dist/plugin-sdk/web/outbound.d.ts +24 -0
- package/dist/plugin-sdk/web/qr-image.d.ts +4 -0
- package/dist/plugin-sdk/web/reconnect.d.ts +12 -0
- package/dist/plugin-sdk/web/session.d.ts +14 -0
- package/dist/plugin-sdk/web/vcard.d.ts +6 -0
- package/dist/plugin-sdk/whatsapp/normalize.d.ts +6 -0
- package/dist/plugin-sdk/whatsapp/resolve-outbound-target.d.ts +12 -0
- package/dist/plugin-sdk/wizard/prompts.d.ts +43 -0
- package/dist/plugin-sdk/wizard/session.d.ts +42 -0
- package/dist/plugins-BflZz0sp.js +453 -0
- package/dist/plugins-allowlist-BbTQ5Z2k.js +15 -0
- package/dist/plugins-allowlist-C20oaESO.js +15 -0
- package/dist/plugins-cli-DV82scUw.js +798 -0
- package/dist/plugins-cli-Qj1UyIZO.js +793 -0
- package/dist/plugins-woGRXMzU.js +455 -0
- package/dist/polls-B0CCBDeR.js +33 -0
- package/dist/polls-CwwHzYBM.js +33 -0
- package/dist/ports-DrruB2fK.js +370 -0
- package/dist/ports-GT1yV-Tg.js +96 -0
- package/dist/ports-NPqtlfp0.js +316 -0
- package/dist/ports-QMI4-F9m.js +96 -0
- package/dist/ports-lsof-Wteul3ju.js +27 -0
- package/dist/process-scoped-map-CV9kDvfG.js +39 -0
- package/dist/process-scoped-map-PEvnG75N.js +39 -0
- package/dist/program-CQmIaRUI.js +244 -0
- package/dist/program-context-DEU6ACnL.js +474 -0
- package/dist/program-context-jqeI5alP.js +17 -0
- package/dist/progress-C1kUfYL-.js +123 -0
- package/dist/progress-CBkSaM6z.js +124 -0
- package/dist/prompt-Bllj1dhc.js +21 -0
- package/dist/prompt-Yn2yClg1.js +21 -0
- package/dist/prompt-select-styled-BhTN6zE2.js +1650 -0
- package/dist/prompt-select-styled-WopXnjIy.js +1647 -0
- package/dist/prompt-style-DVEm3BZW.js +9 -0
- package/dist/prompt-style-DjEYC_s-.js +9 -0
- package/dist/provider-dispatcher-B4QMe-I6.js +659 -0
- package/dist/provider-dispatcher-Bfauw6zz.js +660 -0
- package/dist/provider-utils-3JTMJroG.js +79 -0
- package/dist/provider-utils-FaBmofiq.js +79 -0
- package/dist/proxy-DL3MD6-P.js +16 -0
- package/dist/proxy-DpNv2cSV.js +16 -0
- package/dist/push-apns-C0LyG-WB.js +713 -0
- package/dist/push-apns-DuG95AKC.js +711 -0
- package/dist/pw-ai-D9n6-Wa6.js +1906 -0
- package/dist/pw-ai-T280E6Mn.js +1910 -0
- package/dist/pw-ai-state-CGfLv6nV.js +11 -0
- package/dist/pw-ai-state-Dynx20hr.js +11 -0
- package/dist/qr-cli-DVECWTHN.js +352 -0
- package/dist/qr-cli-hSLixZCe.js +347 -0
- package/dist/redact-Dx1Fue21.js +191 -0
- package/dist/redact-eZq1uwNK.js +191 -0
- package/dist/redact-identifier-BTIWtaa-.js +15 -0
- package/dist/redact-identifier-CAagcfWA.js +15 -0
- package/dist/redact-snapshot-BZYLIqe-.js +2028 -0
- package/dist/redact-snapshot-C6hVx_9I.js +2028 -0
- package/dist/register.agent-Dmj-sgEl.js +1043 -0
- package/dist/register.agent-IspcBFeD.js +286 -0
- package/dist/register.configure-BqJEqyGL.js +130 -0
- package/dist/register.configure-PPkU_4Ea.js +124 -0
- package/dist/register.import-Bs-UkOs-.js +27 -0
- package/dist/register.import-DLng8g-e.js +30 -0
- package/dist/register.maintenance-BbpkJil3.js +497 -0
- package/dist/register.maintenance-C5nkOQxa.js +494 -0
- package/dist/register.message-C83Hi1b3.js +681 -0
- package/dist/register.message-D16isu4u.js +686 -0
- package/dist/register.onboard-B8EzX3wY.js +257 -0
- package/dist/register.onboard-CyRbr_0V.js +262 -0
- package/dist/register.setup-DWyoowAz.js +109 -0
- package/dist/register.setup-Dz6GwMnu.js +114 -0
- package/dist/register.status-health-sessions-CbQOfycz.js +423 -0
- package/dist/register.status-health-sessions-DXIWG47y.js +669 -0
- package/dist/register.subclis-DeGP5UPU.js +267 -0
- package/dist/remoteclaw-root-C2HV2VeC.js +88 -0
- package/dist/remoteclaw-root-DybYl8PL.js +88 -0
- package/dist/render-6ahYfPwj.js +104 -0
- package/dist/render-CCLsW6Lz.js +104 -0
- package/dist/render-uf6PvGMV.js +104 -0
- package/dist/replies-BKrzM0QI.js +136 -0
- package/dist/replies-Cl2gYBVt.js +136 -0
- package/dist/reply-CCu_DY64.js +13900 -0
- package/dist/reply-DSKC8kyS.js +13897 -0
- package/dist/reply-directives-BHJKp1Du.js +182 -0
- package/dist/reply-directives-CD2WycBM.js +182 -0
- package/dist/reply-payloads-D_BM1Anb.js +527 -0
- package/dist/reply-prefix-DBLCYiup.js +38 -0
- package/dist/reply-prefix-Q4DOJSn_.js +38 -0
- package/dist/resolve-route-CBVbY0xS.js +249 -0
- package/dist/resolve-route-DGEgTEif.js +249 -0
- package/dist/response-prefix-template-rVZQOViK.js +136 -0
- package/dist/response-prefix-template-up4REfuR.js +136 -0
- package/dist/retry-BhuXOEVR.js +77 -0
- package/dist/retry-DUjAzOBy.js +77 -0
- package/dist/retry-DnqPAqWp.js +77 -0
- package/dist/rolldown-runtime-Cbj13DAv.js +20 -0
- package/dist/run-main-Um5xhxla.js +320 -0
- package/dist/runner-yVJ4HB2K.js +2294 -0
- package/dist/runner-z92MWZ3m.js +2294 -0
- package/dist/runtime-DJNp29jv.js +94 -0
- package/dist/runtime-guard-DZ_xuCc4.js +60 -0
- package/dist/runtime-guard-U-ewY_QH.js +60 -0
- package/dist/secret-equal-BbHdTtqY.js +11 -0
- package/dist/secret-equal-CXJEZiWb.js +11 -0
- package/dist/secure-random-CS2mSdTn.js +12 -0
- package/dist/secure-random-Pl9rPl0l.js +44 -0
- package/dist/secure-random-_dzDDlFo.js +12 -0
- package/dist/security-cli-CdwbWZUj.js +484 -0
- package/dist/security-cli-DP5QJpa5.js +478 -0
- package/dist/send-B1_Ymjb9.js +1778 -0
- package/dist/send-B84axiIa.js +29 -0
- package/dist/send-BN_zYVlx.js +547 -0
- package/dist/send-BqVOxAmK.js +1174 -0
- package/dist/send-Bx9bUGav.js +492 -0
- package/dist/send-C3pdJ6p-.js +2245 -0
- package/dist/send-CBGSXjfD.js +2245 -0
- package/dist/send-CGXyTF22.js +426 -0
- package/dist/send-CKavrhXj.js +11 -0
- package/dist/send-D08Je6DL.js +374 -0
- package/dist/send-D1aYEG-k.js +332 -0
- package/dist/send-DHldI3gf.js +492 -0
- package/dist/send-D_DUQJ6H.js +349 -0
- package/dist/send-Ds63eF4a.js +349 -0
- package/dist/send-YRVDWfSs.js +547 -0
- package/dist/send-xnwty9cY.js +1775 -0
- package/dist/server-BQFoyCRR.js +200 -0
- package/dist/server-DhXw25Jq.js +205 -0
- package/dist/server-lifecycle-BjCCyD3w.js +2437 -0
- package/dist/server-lifecycle-Coyr6Lda.js +2437 -0
- package/dist/server-node-events-De4WZQQD.js +393 -0
- package/dist/server-node-events-dXXayuqY.js +398 -0
- package/dist/service-Bjqii5nW.js +670 -0
- package/dist/service-fp29z5Ww.js +670 -0
- package/dist/session-DBL5nHDy.js +170 -0
- package/dist/session-cost-usage-DX09eTPU.js +627 -0
- package/dist/session-cost-usage-yYi525j3.js +627 -0
- package/dist/session-dirs-Cj5xi7zX.js +947 -0
- package/dist/session-dirs-DdF6TDsE.js +947 -0
- package/dist/session-key-5YLnn_qf.js +235 -0
- package/dist/session-key-C2n-VILA.js +235 -0
- package/dist/session-utils-CEtEq6bi.js +625 -0
- package/dist/session-utils-WmlWAs1r.js +625 -0
- package/dist/session-xKIW6gL2.js +170 -0
- package/dist/sessions--PykPynp.js +2593 -0
- package/dist/sessions-Bw4LRnSr.js +252 -0
- package/dist/ssrf-Ck9HDZpv.js +183 -0
- package/dist/ssrf-m7kFIobZ.js +183 -0
- package/dist/stagger-BXv_apuy.js +56 -0
- package/dist/stagger-MI9gd2rQ.js +56 -0
- package/dist/status-BmtCS3T1.js +21 -0
- package/dist/status-BrwHRn2B.js +21 -0
- package/dist/status-CtzYFLLF.js +2072 -0
- package/dist/status-DiN1cq2p.js +2068 -0
- package/dist/status.update-C55QM2xs.js +79 -0
- package/dist/status.update-CBmPXwYN.js +79 -0
- package/dist/store-C3tOpizT.js +64 -0
- package/dist/store-CPJXuhvQ.js +53 -0
- package/dist/store-SusmIfz7.js +2595 -0
- package/dist/store-v3P-OWhi.js +64 -0
- package/dist/strip-inbound-meta-DjKcSFaW.js +110 -0
- package/dist/strip-inbound-meta-jy3bkUab.js +110 -0
- package/dist/subagent-registry-Db4Ho_2Y.js +4858 -0
- package/dist/subagent-registry-Du_j0Fnt.js +4860 -0
- package/dist/subsystem-BUXAJwPD.js +1079 -0
- package/dist/subsystem-COd61u0P.js +1139 -0
- package/dist/system-cli-DYCpLO3T.js +75 -0
- package/dist/system-cli-eAk5wVbP.js +70 -0
- package/dist/systemd-DSnlM3jX.js +547 -0
- package/dist/systemd-TfK8GuTx.js +547 -0
- package/dist/systemd-linger-Axnc1xCb.js +75 -0
- package/dist/systemd-linger-_0_-RY4v.js +75 -0
- package/dist/table-C1rdyYl9.js +278 -0
- package/dist/table-DPTzZyhu.js +279 -0
- package/dist/tables-DI5LGEr1.js +55 -0
- package/dist/tables-PxcSPSO0.js +55 -0
- package/dist/tables-TWiml6b1.js +55 -0
- package/dist/tailnet-CEudzG0i.js +40 -0
- package/dist/tailnet-PnMrjwGT.js +40 -0
- package/dist/tailscale-DTATQxAG.js +230 -0
- package/dist/tailscale-Dbyahx0J.js +230 -0
- package/dist/target-errors-BDpPcwh5.js +26 -0
- package/dist/target-errors-DdIAPcMM.js +26 -0
- package/dist/targets-BMenhVHg.js +39 -0
- package/dist/targets-C-2xwh9f.js +45 -0
- package/dist/targets-C1NeMn2J.js +220 -0
- package/dist/targets-CcTME3bp.js +46 -0
- package/dist/targets-CmC5m7Ey.js +53 -0
- package/dist/targets-D-qLBpTA.js +79 -0
- package/dist/targets-D-u6Kyio.js +650 -0
- package/dist/targets-D7OKVXMI.js +650 -0
- package/dist/targets-D7PT_rdO.js +45 -0
- package/dist/targets-DB4vBpIQ.js +2172 -0
- package/dist/targets-DfqPGOmM.js +2173 -0
- package/dist/targets-DyybKefq.js +53 -0
- package/dist/targets-JCISV-hS.js +120 -0
- package/dist/targets-UncQvCVs.js +79 -0
- package/dist/text-format-BQ3z_OXA.js +9 -0
- package/dist/text-format-oWqzVmah.js +9 -0
- package/dist/tokens-B-jmvNR9.js +21 -0
- package/dist/tokens-DzFOtLlW.js +21 -0
- package/dist/tool-display-Br6mwaJc.js +785 -0
- package/dist/tool-display-sgNwLOBj.js +785 -0
- package/dist/tool-images-BNfIJ_Kj.js +263 -0
- package/dist/tool-images-kloBqxqK.js +263 -0
- package/dist/trash-DPi0aCCQ.js +125 -0
- package/dist/trash-D_Jd_yQZ.js +125 -0
- package/dist/tui-CHc0EfJO.js +3392 -0
- package/dist/tui-CyHwc2uX.js +3392 -0
- package/dist/tui-cli-BvwbrIYO.js +63 -0
- package/dist/tui-cli-C9I18SfW.js +58 -0
- package/dist/update-DxyjwCL2.js +349 -0
- package/dist/update-IX7vdqA8.js +349 -0
- package/dist/update-cli-CBeXUSzq.js +1373 -0
- package/dist/update-cli-DkAWmUrp.js +1370 -0
- package/dist/usage-BdhBT0Vz.js +57 -0
- package/dist/usage-BtQcAnf6.js +57 -0
- package/dist/usage-CYlQW4M2.js +5279 -0
- package/dist/usage-format-C3mNLfhI.js +31 -0
- package/dist/usage-format-DAaPzr_z.js +31 -0
- package/dist/utils-LBKvDoPx.js +631 -0
- package/dist/warning-filter.js +48 -0
- package/dist/web-BUYUdnRH.js +3065 -0
- package/dist/web-Dquzwqf4.js +70 -0
- package/dist/web-tS8diboh.js +76 -0
- package/dist/webhooks-cli-B7Vw3CMz.js +333 -0
- package/dist/webhooks-cli-BpZHQlVd.js +328 -0
- package/dist/whatsapp-actions-D5HXezjp.js +128 -0
- package/dist/whatsapp-actions-DaA291Ya.js +122 -0
- package/dist/widearea-dns-CsmBVbez.js +127 -0
- package/dist/widearea-dns-DSoaA-eH.js +127 -0
- package/dist/workspace-B4ZvVYT9.js +447 -0
- package/dist/workspace-B8PA8oxJ.js +449 -0
- package/dist/workspace-BzPeZDew.js +10 -0
- package/dist/workspace-DkGLVfOl.js +10 -0
- package/dist/wsl-BCnYV9O0.js +52 -0
- package/dist/wsl-B_sPlzWw.js +52 -0
- package/extensions/bluebubbles/README.md +45 -0
- package/extensions/bluebubbles/index.ts +19 -0
- package/extensions/bluebubbles/package.json +33 -0
- package/extensions/bluebubbles/remoteclaw.plugin.json +9 -0
- package/extensions/bluebubbles/src/account-resolve.ts +35 -0
- package/extensions/bluebubbles/src/accounts.ts +90 -0
- package/extensions/bluebubbles/src/actions.ts +460 -0
- package/extensions/bluebubbles/src/attachments.ts +268 -0
- package/extensions/bluebubbles/src/channel.ts +418 -0
- package/extensions/bluebubbles/src/chat.ts +329 -0
- package/extensions/bluebubbles/src/config-schema.ts +65 -0
- package/extensions/bluebubbles/src/history.ts +177 -0
- package/extensions/bluebubbles/src/media-send.ts +317 -0
- package/extensions/bluebubbles/src/monitor-normalize.ts +825 -0
- package/extensions/bluebubbles/src/monitor-processing.ts +1448 -0
- package/extensions/bluebubbles/src/monitor-reply-cache.ts +185 -0
- package/extensions/bluebubbles/src/monitor-shared.ts +41 -0
- package/extensions/bluebubbles/src/monitor.ts +534 -0
- package/extensions/bluebubbles/src/multipart.ts +32 -0
- package/extensions/bluebubbles/src/onboarding.ts +340 -0
- package/extensions/bluebubbles/src/probe.ts +163 -0
- package/extensions/bluebubbles/src/reactions.ts +182 -0
- package/extensions/bluebubbles/src/request-url.ts +12 -0
- package/extensions/bluebubbles/src/runtime.ts +34 -0
- package/extensions/bluebubbles/src/send-helpers.ts +53 -0
- package/extensions/bluebubbles/src/send.ts +472 -0
- package/extensions/bluebubbles/src/targets.ts +370 -0
- package/extensions/bluebubbles/src/test-harness.ts +79 -0
- package/extensions/bluebubbles/src/test-mocks.ts +11 -0
- package/extensions/bluebubbles/src/types.ts +135 -0
- package/extensions/device-pair/index.ts +529 -0
- package/extensions/device-pair/remoteclaw.plugin.json +20 -0
- package/extensions/diagnostics-otel/index.ts +15 -0
- package/extensions/diagnostics-otel/package.json +24 -0
- package/extensions/diagnostics-otel/remoteclaw.plugin.json +8 -0
- package/extensions/diagnostics-otel/src/service.ts +682 -0
- package/extensions/discord/index.ts +19 -0
- package/extensions/discord/package.json +11 -0
- package/extensions/discord/remoteclaw.plugin.json +9 -0
- package/extensions/discord/src/channel.ts +451 -0
- package/extensions/discord/src/runtime.ts +14 -0
- package/extensions/discord/src/subagent-hooks.ts +152 -0
- package/extensions/feishu/index.ts +63 -0
- package/extensions/feishu/package.json +34 -0
- package/extensions/feishu/remoteclaw.plugin.json +10 -0
- package/extensions/feishu/skills/feishu-doc/SKILL.md +105 -0
- package/extensions/feishu/skills/feishu-doc/references/block-types.md +103 -0
- package/extensions/feishu/skills/feishu-drive/SKILL.md +97 -0
- package/extensions/feishu/skills/feishu-perm/SKILL.md +119 -0
- package/extensions/feishu/skills/feishu-wiki/SKILL.md +111 -0
- package/extensions/feishu/src/accounts.ts +144 -0
- package/extensions/feishu/src/bitable.ts +739 -0
- package/extensions/feishu/src/bot.ts +1006 -0
- package/extensions/feishu/src/channel.ts +359 -0
- package/extensions/feishu/src/client.ts +118 -0
- package/extensions/feishu/src/config-schema.ts +226 -0
- package/extensions/feishu/src/dedup.ts +54 -0
- package/extensions/feishu/src/directory.ts +177 -0
- package/extensions/feishu/src/doc-schema.ts +47 -0
- package/extensions/feishu/src/docx.ts +536 -0
- package/extensions/feishu/src/drive-schema.ts +46 -0
- package/extensions/feishu/src/drive.ts +227 -0
- package/extensions/feishu/src/dynamic-agent.ts +131 -0
- package/extensions/feishu/src/external-keys.ts +19 -0
- package/extensions/feishu/src/media.ts +441 -0
- package/extensions/feishu/src/mention.ts +133 -0
- package/extensions/feishu/src/monitor.ts +397 -0
- package/extensions/feishu/src/onboarding.ts +351 -0
- package/extensions/feishu/src/outbound.ts +55 -0
- package/extensions/feishu/src/perm-schema.ts +52 -0
- package/extensions/feishu/src/perm.ts +173 -0
- package/extensions/feishu/src/policy.ts +120 -0
- package/extensions/feishu/src/probe.ts +44 -0
- package/extensions/feishu/src/reactions.ts +160 -0
- package/extensions/feishu/src/reply-dispatcher.ts +239 -0
- package/extensions/feishu/src/runtime.ts +14 -0
- package/extensions/feishu/src/send-result.ts +29 -0
- package/extensions/feishu/src/send-target.ts +25 -0
- package/extensions/feishu/src/send.ts +313 -0
- package/extensions/feishu/src/streaming-card.ts +218 -0
- package/extensions/feishu/src/targets.ts +78 -0
- package/extensions/feishu/src/tools-config.ts +21 -0
- package/extensions/feishu/src/types.ts +81 -0
- package/extensions/feishu/src/typing.ts +80 -0
- package/extensions/feishu/src/wiki-schema.ts +55 -0
- package/extensions/feishu/src/wiki.ts +232 -0
- package/extensions/googlechat/index.ts +19 -0
- package/extensions/googlechat/node_modules/.bin/remoteclaw +21 -0
- package/extensions/googlechat/package.json +37 -0
- package/extensions/googlechat/remoteclaw.plugin.json +9 -0
- package/extensions/googlechat/src/accounts.ts +147 -0
- package/extensions/googlechat/src/actions.ts +176 -0
- package/extensions/googlechat/src/api.ts +282 -0
- package/extensions/googlechat/src/auth.ts +137 -0
- package/extensions/googlechat/src/channel.ts +576 -0
- package/extensions/googlechat/src/monitor.ts +965 -0
- package/extensions/googlechat/src/onboarding.ts +270 -0
- package/extensions/googlechat/src/runtime.ts +14 -0
- package/extensions/googlechat/src/targets.ts +65 -0
- package/extensions/googlechat/src/types.config.ts +3 -0
- package/extensions/googlechat/src/types.ts +73 -0
- package/extensions/imessage/index.ts +17 -0
- package/extensions/imessage/package.json +12 -0
- package/extensions/imessage/remoteclaw.plugin.json +9 -0
- package/extensions/imessage/src/channel.ts +304 -0
- package/extensions/imessage/src/runtime.ts +14 -0
- package/extensions/irc/index.ts +17 -0
- package/extensions/irc/package.json +11 -0
- package/extensions/irc/remoteclaw.plugin.json +9 -0
- package/extensions/irc/src/accounts.ts +268 -0
- package/extensions/irc/src/channel.ts +364 -0
- package/extensions/irc/src/client.ts +439 -0
- package/extensions/irc/src/config-schema.ts +91 -0
- package/extensions/irc/src/connect-options.ts +30 -0
- package/extensions/irc/src/control-chars.ts +22 -0
- package/extensions/irc/src/inbound.ts +372 -0
- package/extensions/irc/src/monitor.ts +146 -0
- package/extensions/irc/src/normalize.ts +123 -0
- package/extensions/irc/src/onboarding.ts +479 -0
- package/extensions/irc/src/policy.ts +166 -0
- package/extensions/irc/src/probe.ts +53 -0
- package/extensions/irc/src/protocol.ts +169 -0
- package/extensions/irc/src/runtime.ts +14 -0
- package/extensions/irc/src/send.ts +88 -0
- package/extensions/irc/src/types.ts +99 -0
- package/extensions/line/index.ts +19 -0
- package/extensions/line/package.json +27 -0
- package/extensions/line/remoteclaw.plugin.json +9 -0
- package/extensions/line/src/card-command.ts +344 -0
- package/extensions/line/src/channel.ts +797 -0
- package/extensions/line/src/runtime.ts +14 -0
- package/extensions/matrix/CHANGELOG.md +32 -0
- package/extensions/matrix/index.ts +17 -0
- package/extensions/matrix/node_modules/.bin/markdown-it +21 -0
- package/extensions/matrix/package.json +33 -0
- package/extensions/matrix/remoteclaw.plugin.json +9 -0
- package/extensions/matrix/src/actions.ts +195 -0
- package/extensions/matrix/src/channel.ts +486 -0
- package/extensions/matrix/src/config-schema.ts +63 -0
- package/extensions/matrix/src/directory-live.ts +208 -0
- package/extensions/matrix/src/group-mentions.ts +52 -0
- package/extensions/matrix/src/matrix/accounts.ts +137 -0
- package/extensions/matrix/src/matrix/actions/client.ts +47 -0
- package/extensions/matrix/src/matrix/actions/limits.ts +6 -0
- package/extensions/matrix/src/matrix/actions/messages.ts +126 -0
- package/extensions/matrix/src/matrix/actions/pins.ts +84 -0
- package/extensions/matrix/src/matrix/actions/reactions.ts +102 -0
- package/extensions/matrix/src/matrix/actions/room.ts +85 -0
- package/extensions/matrix/src/matrix/actions/summary.ts +75 -0
- package/extensions/matrix/src/matrix/actions/types.ts +85 -0
- package/extensions/matrix/src/matrix/actions.ts +15 -0
- package/extensions/matrix/src/matrix/active-client.ts +32 -0
- package/extensions/matrix/src/matrix/client/config.ts +219 -0
- package/extensions/matrix/src/matrix/client/create-client.ts +123 -0
- package/extensions/matrix/src/matrix/client/logging.ts +36 -0
- package/extensions/matrix/src/matrix/client/runtime.ts +4 -0
- package/extensions/matrix/src/matrix/client/shared.ts +201 -0
- package/extensions/matrix/src/matrix/client/storage.ts +131 -0
- package/extensions/matrix/src/matrix/client/types.ts +34 -0
- package/extensions/matrix/src/matrix/client-bootstrap.ts +39 -0
- package/extensions/matrix/src/matrix/client.ts +14 -0
- package/extensions/matrix/src/matrix/credentials.ts +125 -0
- package/extensions/matrix/src/matrix/deps.ts +60 -0
- package/extensions/matrix/src/matrix/format.ts +22 -0
- package/extensions/matrix/src/matrix/index.ts +11 -0
- package/extensions/matrix/src/matrix/monitor/allowlist.ts +103 -0
- package/extensions/matrix/src/matrix/monitor/auto-join.ts +71 -0
- package/extensions/matrix/src/matrix/monitor/direct.ts +104 -0
- package/extensions/matrix/src/matrix/monitor/events.ts +148 -0
- package/extensions/matrix/src/matrix/monitor/handler.ts +688 -0
- package/extensions/matrix/src/matrix/monitor/index.ts +358 -0
- package/extensions/matrix/src/matrix/monitor/location.ts +100 -0
- package/extensions/matrix/src/matrix/monitor/media.ts +118 -0
- package/extensions/matrix/src/matrix/monitor/mentions.ts +62 -0
- package/extensions/matrix/src/matrix/monitor/replies.ts +124 -0
- package/extensions/matrix/src/matrix/monitor/room-info.ts +55 -0
- package/extensions/matrix/src/matrix/monitor/rooms.ts +47 -0
- package/extensions/matrix/src/matrix/monitor/threads.ts +68 -0
- package/extensions/matrix/src/matrix/monitor/types.ts +39 -0
- package/extensions/matrix/src/matrix/poll-types.ts +167 -0
- package/extensions/matrix/src/matrix/probe.ts +69 -0
- package/extensions/matrix/src/matrix/send/client.ts +97 -0
- package/extensions/matrix/src/matrix/send/formatting.ts +93 -0
- package/extensions/matrix/src/matrix/send/media.ts +230 -0
- package/extensions/matrix/src/matrix/send/targets.ts +150 -0
- package/extensions/matrix/src/matrix/send/types.ts +109 -0
- package/extensions/matrix/src/matrix/send-queue.ts +44 -0
- package/extensions/matrix/src/matrix/send.ts +265 -0
- package/extensions/matrix/src/onboarding.ts +446 -0
- package/extensions/matrix/src/outbound.ts +55 -0
- package/extensions/matrix/src/resolve-targets.ts +126 -0
- package/extensions/matrix/src/runtime.ts +14 -0
- package/extensions/matrix/src/tool-actions.ts +164 -0
- package/extensions/matrix/src/types.ts +116 -0
- package/extensions/mattermost/index.ts +17 -0
- package/extensions/mattermost/package.json +25 -0
- package/extensions/mattermost/remoteclaw.plugin.json +9 -0
- package/extensions/mattermost/src/channel.ts +439 -0
- package/extensions/mattermost/src/config-schema.ts +62 -0
- package/extensions/mattermost/src/group-mentions.ts +15 -0
- package/extensions/mattermost/src/mattermost/accounts.ts +128 -0
- package/extensions/mattermost/src/mattermost/client.ts +230 -0
- package/extensions/mattermost/src/mattermost/index.ts +9 -0
- package/extensions/mattermost/src/mattermost/monitor-helpers.ts +72 -0
- package/extensions/mattermost/src/mattermost/monitor-onchar.ts +25 -0
- package/extensions/mattermost/src/mattermost/monitor-websocket.ts +221 -0
- package/extensions/mattermost/src/mattermost/monitor.ts +1061 -0
- package/extensions/mattermost/src/mattermost/probe.ts +61 -0
- package/extensions/mattermost/src/mattermost/reactions.test-helpers.ts +83 -0
- package/extensions/mattermost/src/mattermost/reactions.ts +124 -0
- package/extensions/mattermost/src/mattermost/reconnect.ts +103 -0
- package/extensions/mattermost/src/mattermost/send.ts +231 -0
- package/extensions/mattermost/src/normalize.ts +46 -0
- package/extensions/mattermost/src/onboarding-helpers.ts +1 -0
- package/extensions/mattermost/src/onboarding.ts +182 -0
- package/extensions/mattermost/src/runtime.ts +14 -0
- package/extensions/mattermost/src/types.ts +62 -0
- package/extensions/msteams/CHANGELOG.md +35 -0
- package/extensions/msteams/index.ts +17 -0
- package/extensions/msteams/package.json +32 -0
- package/extensions/msteams/remoteclaw.plugin.json +9 -0
- package/extensions/msteams/src/attachments/download.ts +282 -0
- package/extensions/msteams/src/attachments/graph.ts +354 -0
- package/extensions/msteams/src/attachments/html.ts +90 -0
- package/extensions/msteams/src/attachments/payload.ts +14 -0
- package/extensions/msteams/src/attachments/remote-media.ts +42 -0
- package/extensions/msteams/src/attachments/shared.ts +404 -0
- package/extensions/msteams/src/attachments/types.ts +37 -0
- package/extensions/msteams/src/attachments.ts +18 -0
- package/extensions/msteams/src/channel.ts +464 -0
- package/extensions/msteams/src/conversation-store-fs.ts +165 -0
- package/extensions/msteams/src/conversation-store-memory.ts +47 -0
- package/extensions/msteams/src/conversation-store.ts +41 -0
- package/extensions/msteams/src/directory-live.ts +108 -0
- package/extensions/msteams/src/errors.ts +190 -0
- package/extensions/msteams/src/file-consent-helpers.ts +73 -0
- package/extensions/msteams/src/file-consent.ts +126 -0
- package/extensions/msteams/src/file-lock.ts +1 -0
- package/extensions/msteams/src/graph-chat.ts +53 -0
- package/extensions/msteams/src/graph-upload.ts +452 -0
- package/extensions/msteams/src/graph-users.ts +29 -0
- package/extensions/msteams/src/graph.ts +81 -0
- package/extensions/msteams/src/inbound.ts +48 -0
- package/extensions/msteams/src/index.ts +4 -0
- package/extensions/msteams/src/media-helpers.ts +105 -0
- package/extensions/msteams/src/mentions.ts +114 -0
- package/extensions/msteams/src/messenger.ts +484 -0
- package/extensions/msteams/src/monitor-handler/inbound-media.ts +128 -0
- package/extensions/msteams/src/monitor-handler/message-handler.ts +661 -0
- package/extensions/msteams/src/monitor-handler.ts +162 -0
- package/extensions/msteams/src/monitor-types.ts +5 -0
- package/extensions/msteams/src/monitor.ts +305 -0
- package/extensions/msteams/src/onboarding.ts +406 -0
- package/extensions/msteams/src/outbound.ts +46 -0
- package/extensions/msteams/src/pending-uploads.ts +89 -0
- package/extensions/msteams/src/policy.ts +259 -0
- package/extensions/msteams/src/polls-store-memory.ts +32 -0
- package/extensions/msteams/src/polls.ts +315 -0
- package/extensions/msteams/src/probe.ts +94 -0
- package/extensions/msteams/src/reply-dispatcher.ts +132 -0
- package/extensions/msteams/src/resolve-allowlist.ts +198 -0
- package/extensions/msteams/src/runtime.ts +14 -0
- package/extensions/msteams/src/sdk-types.ts +19 -0
- package/extensions/msteams/src/sdk.ts +33 -0
- package/extensions/msteams/src/send-context.ts +164 -0
- package/extensions/msteams/src/send.ts +530 -0
- package/extensions/msteams/src/sent-message-cache.ts +44 -0
- package/extensions/msteams/src/storage.ts +25 -0
- package/extensions/msteams/src/store-fs.ts +44 -0
- package/extensions/msteams/src/test-runtime.ts +16 -0
- package/extensions/msteams/src/token-response.ts +11 -0
- package/extensions/msteams/src/token.ts +19 -0
- package/extensions/nextcloud-talk/index.ts +17 -0
- package/extensions/nextcloud-talk/package.json +30 -0
- package/extensions/nextcloud-talk/remoteclaw.plugin.json +9 -0
- package/extensions/nextcloud-talk/src/accounts.ts +170 -0
- package/extensions/nextcloud-talk/src/channel.ts +416 -0
- package/extensions/nextcloud-talk/src/config-schema.ts +72 -0
- package/extensions/nextcloud-talk/src/format.ts +79 -0
- package/extensions/nextcloud-talk/src/inbound.ts +343 -0
- package/extensions/nextcloud-talk/src/monitor.ts +275 -0
- package/extensions/nextcloud-talk/src/normalize.ts +39 -0
- package/extensions/nextcloud-talk/src/onboarding.ts +349 -0
- package/extensions/nextcloud-talk/src/policy.ts +180 -0
- package/extensions/nextcloud-talk/src/room-info.ts +125 -0
- package/extensions/nextcloud-talk/src/runtime.ts +14 -0
- package/extensions/nextcloud-talk/src/send.ts +215 -0
- package/extensions/nextcloud-talk/src/signature.ts +72 -0
- package/extensions/nextcloud-talk/src/types.ts +185 -0
- package/extensions/nostr/CHANGELOG.md +44 -0
- package/extensions/nostr/README.md +136 -0
- package/extensions/nostr/index.ts +68 -0
- package/extensions/nostr/package.json +30 -0
- package/extensions/nostr/remoteclaw.plugin.json +9 -0
- package/extensions/nostr/src/channel.ts +345 -0
- package/extensions/nostr/src/config-schema.ts +90 -0
- package/extensions/nostr/src/metrics.ts +458 -0
- package/extensions/nostr/src/nostr-bus.ts +719 -0
- package/extensions/nostr/src/nostr-profile-http.ts +519 -0
- package/extensions/nostr/src/nostr-profile-import.ts +262 -0
- package/extensions/nostr/src/nostr-profile.ts +277 -0
- package/extensions/nostr/src/nostr-state-store.ts +226 -0
- package/extensions/nostr/src/runtime.ts +14 -0
- package/extensions/nostr/src/seen-tracker.ts +289 -0
- package/extensions/nostr/src/types.ts +101 -0
- package/extensions/phone-control/index.ts +421 -0
- package/extensions/phone-control/remoteclaw.plugin.json +10 -0
- package/extensions/shared/resolve-target-test-helpers.ts +66 -0
- package/extensions/signal/index.ts +17 -0
- package/extensions/signal/package.json +12 -0
- package/extensions/signal/remoteclaw.plugin.json +9 -0
- package/extensions/signal/src/channel.ts +299 -0
- package/extensions/signal/src/runtime.ts +14 -0
- package/extensions/slack/index.ts +17 -0
- package/extensions/slack/package.json +12 -0
- package/extensions/slack/remoteclaw.plugin.json +9 -0
- package/extensions/slack/src/channel.ts +421 -0
- package/extensions/slack/src/runtime.ts +14 -0
- package/extensions/synology-chat/index.ts +17 -0
- package/extensions/synology-chat/package.json +28 -0
- package/extensions/synology-chat/remoteclaw.plugin.json +9 -0
- package/extensions/synology-chat/src/accounts.ts +87 -0
- package/extensions/synology-chat/src/channel.ts +347 -0
- package/extensions/synology-chat/src/client.ts +142 -0
- package/extensions/synology-chat/src/runtime.ts +20 -0
- package/extensions/synology-chat/src/security.ts +140 -0
- package/extensions/synology-chat/src/types.ts +60 -0
- package/extensions/synology-chat/src/webhook-handler.ts +221 -0
- package/extensions/talk-voice/index.ts +150 -0
- package/extensions/talk-voice/remoteclaw.plugin.json +10 -0
- package/extensions/telegram/index.ts +17 -0
- package/extensions/telegram/package.json +12 -0
- package/extensions/telegram/remoteclaw.plugin.json +9 -0
- package/extensions/telegram/src/channel.ts +569 -0
- package/extensions/telegram/src/runtime.ts +14 -0
- package/extensions/test-utils/runtime-env.ts +12 -0
- package/extensions/thread-ownership/index.ts +133 -0
- package/extensions/thread-ownership/remoteclaw.plugin.json +28 -0
- package/extensions/tlon/README.md +5 -0
- package/extensions/tlon/index.ts +17 -0
- package/extensions/tlon/package.json +29 -0
- package/extensions/tlon/remoteclaw.plugin.json +9 -0
- package/extensions/tlon/src/account-fields.ts +25 -0
- package/extensions/tlon/src/channel.ts +384 -0
- package/extensions/tlon/src/config-schema.ts +41 -0
- package/extensions/tlon/src/monitor/discovery.ts +78 -0
- package/extensions/tlon/src/monitor/history.ts +92 -0
- package/extensions/tlon/src/monitor/index.ts +596 -0
- package/extensions/tlon/src/monitor/processed-messages.ts +33 -0
- package/extensions/tlon/src/monitor/utils.ts +106 -0
- package/extensions/tlon/src/onboarding.ts +229 -0
- package/extensions/tlon/src/runtime.ts +14 -0
- package/extensions/tlon/src/targets.ts +89 -0
- package/extensions/tlon/src/types.ts +99 -0
- package/extensions/tlon/src/urbit/auth.ts +48 -0
- package/extensions/tlon/src/urbit/base-url.ts +57 -0
- package/extensions/tlon/src/urbit/channel-client.ts +158 -0
- package/extensions/tlon/src/urbit/channel-ops.ts +164 -0
- package/extensions/tlon/src/urbit/context.ts +47 -0
- package/extensions/tlon/src/urbit/errors.ts +51 -0
- package/extensions/tlon/src/urbit/fetch.ts +39 -0
- package/extensions/tlon/src/urbit/send.ts +131 -0
- package/extensions/tlon/src/urbit/sse-client.ts +431 -0
- package/extensions/twitch/CHANGELOG.md +39 -0
- package/extensions/twitch/README.md +89 -0
- package/extensions/twitch/index.ts +20 -0
- package/extensions/twitch/package.json +17 -0
- package/extensions/twitch/remoteclaw.plugin.json +9 -0
- package/extensions/twitch/src/access-control.ts +166 -0
- package/extensions/twitch/src/actions.ts +174 -0
- package/extensions/twitch/src/client-manager-registry.ts +115 -0
- package/extensions/twitch/src/config-schema.ts +84 -0
- package/extensions/twitch/src/config.ts +116 -0
- package/extensions/twitch/src/monitor.ts +273 -0
- package/extensions/twitch/src/onboarding.ts +417 -0
- package/extensions/twitch/src/outbound.ts +187 -0
- package/extensions/twitch/src/plugin.ts +274 -0
- package/extensions/twitch/src/probe.ts +119 -0
- package/extensions/twitch/src/resolver.ts +137 -0
- package/extensions/twitch/src/runtime.ts +14 -0
- package/extensions/twitch/src/send.ts +136 -0
- package/extensions/twitch/src/status.ts +179 -0
- package/extensions/twitch/src/test-fixtures.ts +30 -0
- package/extensions/twitch/src/token.ts +94 -0
- package/extensions/twitch/src/twitch-client.ts +277 -0
- package/extensions/twitch/src/types.ts +141 -0
- package/extensions/twitch/src/utils/markdown.ts +98 -0
- package/extensions/twitch/src/utils/twitch.ts +80 -0
- package/extensions/voice-call/CHANGELOG.md +49 -0
- package/extensions/voice-call/README.md +181 -0
- package/extensions/voice-call/index.ts +512 -0
- package/extensions/voice-call/package.json +16 -0
- package/extensions/voice-call/remoteclaw.plugin.json +559 -0
- package/extensions/voice-call/src/allowlist.ts +19 -0
- package/extensions/voice-call/src/cli.ts +380 -0
- package/extensions/voice-call/src/config.ts +477 -0
- package/extensions/voice-call/src/core-bridge.ts +170 -0
- package/extensions/voice-call/src/manager/context.ts +41 -0
- package/extensions/voice-call/src/manager/events.ts +242 -0
- package/extensions/voice-call/src/manager/lookup.ts +35 -0
- package/extensions/voice-call/src/manager/outbound.ts +380 -0
- package/extensions/voice-call/src/manager/state.ts +48 -0
- package/extensions/voice-call/src/manager/store.ts +94 -0
- package/extensions/voice-call/src/manager/timers.ts +112 -0
- package/extensions/voice-call/src/manager/twiml.ts +9 -0
- package/extensions/voice-call/src/manager.ts +209 -0
- package/extensions/voice-call/src/media-stream.ts +527 -0
- package/extensions/voice-call/src/providers/base.ts +67 -0
- package/extensions/voice-call/src/providers/index.ts +10 -0
- package/extensions/voice-call/src/providers/mock.ts +165 -0
- package/extensions/voice-call/src/providers/plivo.ts +560 -0
- package/extensions/voice-call/src/providers/stt-openai-realtime.ts +311 -0
- package/extensions/voice-call/src/providers/telnyx.ts +318 -0
- package/extensions/voice-call/src/providers/tts-openai.ts +259 -0
- package/extensions/voice-call/src/providers/twilio/api.ts +42 -0
- package/extensions/voice-call/src/providers/twilio/webhook.ts +33 -0
- package/extensions/voice-call/src/providers/twilio.ts +688 -0
- package/extensions/voice-call/src/response-generator.ts +174 -0
- package/extensions/voice-call/src/runtime.ts +217 -0
- package/extensions/voice-call/src/telephony-audio.ts +90 -0
- package/extensions/voice-call/src/telephony-tts.ts +106 -0
- package/extensions/voice-call/src/tunnel.ts +314 -0
- package/extensions/voice-call/src/types.ts +280 -0
- package/extensions/voice-call/src/utils.ts +14 -0
- package/extensions/voice-call/src/voice-mapping.ts +67 -0
- package/extensions/voice-call/src/webhook-security.ts +880 -0
- package/extensions/voice-call/src/webhook.ts +556 -0
- package/extensions/whatsapp/index.ts +17 -0
- package/extensions/whatsapp/package.json +12 -0
- package/extensions/whatsapp/remoteclaw.plugin.json +9 -0
- package/extensions/whatsapp/src/channel.ts +459 -0
- package/extensions/whatsapp/src/runtime.ts +14 -0
- package/extensions/zalo/CHANGELOG.md +29 -0
- package/extensions/zalo/README.md +50 -0
- package/extensions/zalo/index.ts +19 -0
- package/extensions/zalo/package.json +32 -0
- package/extensions/zalo/remoteclaw.plugin.json +9 -0
- package/extensions/zalo/src/accounts.ts +82 -0
- package/extensions/zalo/src/actions.ts +56 -0
- package/extensions/zalo/src/api.ts +208 -0
- package/extensions/zalo/src/channel.ts +398 -0
- package/extensions/zalo/src/config-schema.ts +27 -0
- package/extensions/zalo/src/group-access.ts +48 -0
- package/extensions/zalo/src/monitor.ts +675 -0
- package/extensions/zalo/src/monitor.webhook.ts +219 -0
- package/extensions/zalo/src/onboarding.ts +398 -0
- package/extensions/zalo/src/probe.ts +45 -0
- package/extensions/zalo/src/proxy.ts +24 -0
- package/extensions/zalo/src/runtime.ts +14 -0
- package/extensions/zalo/src/send.ts +124 -0
- package/extensions/zalo/src/status-issues.ts +53 -0
- package/extensions/zalo/src/token.ts +62 -0
- package/extensions/zalo/src/types.ts +48 -0
- package/extensions/zalouser/CHANGELOG.md +31 -0
- package/extensions/zalouser/README.md +225 -0
- package/extensions/zalouser/index.ts +31 -0
- package/extensions/zalouser/package.json +32 -0
- package/extensions/zalouser/remoteclaw.plugin.json +9 -0
- package/extensions/zalouser/src/accounts.ts +138 -0
- package/extensions/zalouser/src/channel.ts +652 -0
- package/extensions/zalouser/src/config-schema.ts +28 -0
- package/extensions/zalouser/src/monitor.ts +619 -0
- package/extensions/zalouser/src/onboarding.ts +428 -0
- package/extensions/zalouser/src/probe.ts +27 -0
- package/extensions/zalouser/src/runtime.ts +14 -0
- package/extensions/zalouser/src/send.ts +141 -0
- package/extensions/zalouser/src/status-issues.ts +89 -0
- package/extensions/zalouser/src/tool.ts +166 -0
- package/extensions/zalouser/src/types.ts +105 -0
- package/extensions/zalouser/src/zca.ts +198 -0
- package/package.json +251 -15
- package/remoteclaw.mjs +56 -0
- package/index.js +0 -4
package/dist/entry.js
ADDED
|
@@ -0,0 +1,2620 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { spawn } from "node:child_process";
|
|
3
|
+
import process$1 from "node:process";
|
|
4
|
+
import { fileURLToPath } from "node:url";
|
|
5
|
+
import os from "node:os";
|
|
6
|
+
import path from "node:path";
|
|
7
|
+
import fs from "node:fs";
|
|
8
|
+
import chalk, { Chalk } from "chalk";
|
|
9
|
+
import { Logger } from "tslog";
|
|
10
|
+
import JSON5 from "json5";
|
|
11
|
+
import util from "node:util";
|
|
12
|
+
|
|
13
|
+
//#region src/infra/home-dir.ts
|
|
14
|
+
function normalize(value) {
|
|
15
|
+
const trimmed = value?.trim();
|
|
16
|
+
return trimmed ? trimmed : void 0;
|
|
17
|
+
}
|
|
18
|
+
function resolveEffectiveHomeDir(env = process.env, homedir = os.homedir) {
|
|
19
|
+
const raw = resolveRawHomeDir(env, homedir);
|
|
20
|
+
return raw ? path.resolve(raw) : void 0;
|
|
21
|
+
}
|
|
22
|
+
function resolveRawHomeDir(env, homedir) {
|
|
23
|
+
const explicitHome = normalize(env.REMOTECLAW_HOME);
|
|
24
|
+
if (explicitHome) {
|
|
25
|
+
if (explicitHome === "~" || explicitHome.startsWith("~/") || explicitHome.startsWith("~\\")) {
|
|
26
|
+
const fallbackHome = normalize(env.HOME) ?? normalize(env.USERPROFILE) ?? normalizeSafe(homedir);
|
|
27
|
+
if (fallbackHome) return explicitHome.replace(/^~(?=$|[\\/])/, fallbackHome);
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
return explicitHome;
|
|
31
|
+
}
|
|
32
|
+
const envHome = normalize(env.HOME);
|
|
33
|
+
if (envHome) return envHome;
|
|
34
|
+
const userProfile = normalize(env.USERPROFILE);
|
|
35
|
+
if (userProfile) return userProfile;
|
|
36
|
+
return normalizeSafe(homedir);
|
|
37
|
+
}
|
|
38
|
+
function normalizeSafe(homedir) {
|
|
39
|
+
try {
|
|
40
|
+
return normalize(homedir());
|
|
41
|
+
} catch {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
function resolveRequiredHomeDir(env = process.env, homedir = os.homedir) {
|
|
46
|
+
return resolveEffectiveHomeDir(env, homedir) ?? path.resolve(process.cwd());
|
|
47
|
+
}
|
|
48
|
+
function expandHomePrefix(input, opts) {
|
|
49
|
+
if (!input.startsWith("~")) return input;
|
|
50
|
+
const home = normalize(opts?.home) ?? resolveEffectiveHomeDir(opts?.env ?? process.env, opts?.homedir ?? os.homedir);
|
|
51
|
+
if (!home) return input;
|
|
52
|
+
return input.replace(/^~(?=$|[\\/])/, home);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
//#endregion
|
|
56
|
+
//#region src/cli/profile-utils.ts
|
|
57
|
+
const PROFILE_NAME_RE = /^[a-z0-9][a-z0-9_-]{0,63}$/i;
|
|
58
|
+
function isValidProfileName(value) {
|
|
59
|
+
if (!value) return false;
|
|
60
|
+
return PROFILE_NAME_RE.test(value);
|
|
61
|
+
}
|
|
62
|
+
function normalizeProfileName(raw) {
|
|
63
|
+
const profile = raw?.trim();
|
|
64
|
+
if (!profile) return null;
|
|
65
|
+
if (profile.toLowerCase() === "default") return null;
|
|
66
|
+
if (!isValidProfileName(profile)) return null;
|
|
67
|
+
return profile;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
//#endregion
|
|
71
|
+
//#region src/cli/profile.ts
|
|
72
|
+
function takeValue(raw, next) {
|
|
73
|
+
if (raw.includes("=")) {
|
|
74
|
+
const [, value] = raw.split("=", 2);
|
|
75
|
+
return {
|
|
76
|
+
value: (value ?? "").trim() || null,
|
|
77
|
+
consumedNext: false
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
return {
|
|
81
|
+
value: (next ?? "").trim() || null,
|
|
82
|
+
consumedNext: Boolean(next)
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
function parseCliProfileArgs(argv) {
|
|
86
|
+
if (argv.length < 2) return {
|
|
87
|
+
ok: true,
|
|
88
|
+
profile: null,
|
|
89
|
+
argv
|
|
90
|
+
};
|
|
91
|
+
const out = argv.slice(0, 2);
|
|
92
|
+
let profile = null;
|
|
93
|
+
let sawDev = false;
|
|
94
|
+
let sawCommand = false;
|
|
95
|
+
const args = argv.slice(2);
|
|
96
|
+
for (let i = 0; i < args.length; i += 1) {
|
|
97
|
+
const arg = args[i];
|
|
98
|
+
if (arg === void 0) continue;
|
|
99
|
+
if (sawCommand) {
|
|
100
|
+
out.push(arg);
|
|
101
|
+
continue;
|
|
102
|
+
}
|
|
103
|
+
if (arg === "--dev") {
|
|
104
|
+
if (profile && profile !== "dev") return {
|
|
105
|
+
ok: false,
|
|
106
|
+
error: "Cannot combine --dev with --profile"
|
|
107
|
+
};
|
|
108
|
+
sawDev = true;
|
|
109
|
+
profile = "dev";
|
|
110
|
+
continue;
|
|
111
|
+
}
|
|
112
|
+
if (arg === "--profile" || arg.startsWith("--profile=")) {
|
|
113
|
+
if (sawDev) return {
|
|
114
|
+
ok: false,
|
|
115
|
+
error: "Cannot combine --dev with --profile"
|
|
116
|
+
};
|
|
117
|
+
const next = args[i + 1];
|
|
118
|
+
const { value, consumedNext } = takeValue(arg, next);
|
|
119
|
+
if (consumedNext) i += 1;
|
|
120
|
+
if (!value) return {
|
|
121
|
+
ok: false,
|
|
122
|
+
error: "--profile requires a value"
|
|
123
|
+
};
|
|
124
|
+
if (!isValidProfileName(value)) return {
|
|
125
|
+
ok: false,
|
|
126
|
+
error: "Invalid --profile (use letters, numbers, \"_\", \"-\" only)"
|
|
127
|
+
};
|
|
128
|
+
profile = value;
|
|
129
|
+
continue;
|
|
130
|
+
}
|
|
131
|
+
if (!arg.startsWith("-")) {
|
|
132
|
+
sawCommand = true;
|
|
133
|
+
out.push(arg);
|
|
134
|
+
continue;
|
|
135
|
+
}
|
|
136
|
+
out.push(arg);
|
|
137
|
+
}
|
|
138
|
+
return {
|
|
139
|
+
ok: true,
|
|
140
|
+
profile,
|
|
141
|
+
argv: out
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
function resolveProfileStateDir(profile, env, homedir) {
|
|
145
|
+
const suffix = profile.toLowerCase() === "default" ? "" : `-${profile}`;
|
|
146
|
+
return path.join(resolveRequiredHomeDir(env, homedir), `.remoteclaw${suffix}`);
|
|
147
|
+
}
|
|
148
|
+
function applyCliProfileEnv(params) {
|
|
149
|
+
const env = params.env ?? process.env;
|
|
150
|
+
const homedir = params.homedir ?? os.homedir;
|
|
151
|
+
const profile = params.profile.trim();
|
|
152
|
+
if (!profile) return;
|
|
153
|
+
env.REMOTECLAW_PROFILE = profile;
|
|
154
|
+
const stateDir = env.REMOTECLAW_STATE_DIR?.trim() || resolveProfileStateDir(profile, env, homedir);
|
|
155
|
+
if (!env.REMOTECLAW_STATE_DIR?.trim()) env.REMOTECLAW_STATE_DIR = stateDir;
|
|
156
|
+
if (!env.REMOTECLAW_CONFIG_PATH?.trim()) env.REMOTECLAW_CONFIG_PATH = path.join(stateDir, "remoteclaw.json");
|
|
157
|
+
if (profile === "dev" && !env.REMOTECLAW_GATEWAY_PORT?.trim()) env.REMOTECLAW_GATEWAY_PORT = "19001";
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
//#endregion
|
|
161
|
+
//#region src/cli/argv.ts
|
|
162
|
+
const HELP_FLAGS = new Set(["-h", "--help"]);
|
|
163
|
+
const VERSION_FLAGS = new Set(["-V", "--version"]);
|
|
164
|
+
const ROOT_VERSION_ALIAS_FLAG = "-v";
|
|
165
|
+
const ROOT_BOOLEAN_FLAGS = new Set(["--dev", "--no-color"]);
|
|
166
|
+
const ROOT_VALUE_FLAGS = new Set(["--profile", "--log-level"]);
|
|
167
|
+
const FLAG_TERMINATOR = "--";
|
|
168
|
+
function hasHelpOrVersion(argv) {
|
|
169
|
+
return argv.some((arg) => HELP_FLAGS.has(arg) || VERSION_FLAGS.has(arg)) || hasRootVersionAlias(argv);
|
|
170
|
+
}
|
|
171
|
+
function isValueToken(arg) {
|
|
172
|
+
if (!arg) return false;
|
|
173
|
+
if (arg === FLAG_TERMINATOR) return false;
|
|
174
|
+
if (!arg.startsWith("-")) return true;
|
|
175
|
+
return /^-\d+(?:\.\d+)?$/.test(arg);
|
|
176
|
+
}
|
|
177
|
+
function parsePositiveInt(value) {
|
|
178
|
+
const parsed = Number.parseInt(value, 10);
|
|
179
|
+
if (Number.isNaN(parsed) || parsed <= 0) return;
|
|
180
|
+
return parsed;
|
|
181
|
+
}
|
|
182
|
+
function hasFlag(argv, name) {
|
|
183
|
+
const args = argv.slice(2);
|
|
184
|
+
for (const arg of args) {
|
|
185
|
+
if (arg === FLAG_TERMINATOR) break;
|
|
186
|
+
if (arg === name) return true;
|
|
187
|
+
}
|
|
188
|
+
return false;
|
|
189
|
+
}
|
|
190
|
+
function hasRootVersionAlias(argv) {
|
|
191
|
+
const args = argv.slice(2);
|
|
192
|
+
let hasAlias = false;
|
|
193
|
+
for (let i = 0; i < args.length; i += 1) {
|
|
194
|
+
const arg = args[i];
|
|
195
|
+
if (!arg) continue;
|
|
196
|
+
if (arg === FLAG_TERMINATOR) break;
|
|
197
|
+
if (arg === ROOT_VERSION_ALIAS_FLAG) {
|
|
198
|
+
hasAlias = true;
|
|
199
|
+
continue;
|
|
200
|
+
}
|
|
201
|
+
if (ROOT_BOOLEAN_FLAGS.has(arg)) continue;
|
|
202
|
+
if (arg.startsWith("--profile=")) continue;
|
|
203
|
+
if (ROOT_VALUE_FLAGS.has(arg)) {
|
|
204
|
+
const next = args[i + 1];
|
|
205
|
+
if (isValueToken(next)) i += 1;
|
|
206
|
+
continue;
|
|
207
|
+
}
|
|
208
|
+
if (arg.startsWith("-")) continue;
|
|
209
|
+
return false;
|
|
210
|
+
}
|
|
211
|
+
return hasAlias;
|
|
212
|
+
}
|
|
213
|
+
function getFlagValue(argv, name) {
|
|
214
|
+
const args = argv.slice(2);
|
|
215
|
+
for (let i = 0; i < args.length; i += 1) {
|
|
216
|
+
const arg = args[i];
|
|
217
|
+
if (arg === FLAG_TERMINATOR) break;
|
|
218
|
+
if (arg === name) {
|
|
219
|
+
const next = args[i + 1];
|
|
220
|
+
return isValueToken(next) ? next : null;
|
|
221
|
+
}
|
|
222
|
+
if (arg.startsWith(`${name}=`)) {
|
|
223
|
+
const value = arg.slice(name.length + 1);
|
|
224
|
+
return value ? value : null;
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
function getVerboseFlag(argv, options) {
|
|
229
|
+
if (hasFlag(argv, "--verbose")) return true;
|
|
230
|
+
if (options?.includeDebug && hasFlag(argv, "--debug")) return true;
|
|
231
|
+
return false;
|
|
232
|
+
}
|
|
233
|
+
function getPositiveIntFlagValue(argv, name) {
|
|
234
|
+
const raw = getFlagValue(argv, name);
|
|
235
|
+
if (raw === null || raw === void 0) return raw;
|
|
236
|
+
return parsePositiveInt(raw);
|
|
237
|
+
}
|
|
238
|
+
function getCommandPath(argv, depth = 2) {
|
|
239
|
+
const args = argv.slice(2);
|
|
240
|
+
const path = [];
|
|
241
|
+
for (let i = 0; i < args.length; i += 1) {
|
|
242
|
+
const arg = args[i];
|
|
243
|
+
if (!arg) continue;
|
|
244
|
+
if (arg === "--") break;
|
|
245
|
+
if (arg.startsWith("-")) continue;
|
|
246
|
+
path.push(arg);
|
|
247
|
+
if (path.length >= depth) break;
|
|
248
|
+
}
|
|
249
|
+
return path;
|
|
250
|
+
}
|
|
251
|
+
function getPrimaryCommand(argv) {
|
|
252
|
+
const [primary] = getCommandPath(argv, 1);
|
|
253
|
+
return primary ?? null;
|
|
254
|
+
}
|
|
255
|
+
function buildParseArgv(params) {
|
|
256
|
+
const baseArgv = params.rawArgs && params.rawArgs.length > 0 ? params.rawArgs : params.fallbackArgv && params.fallbackArgv.length > 0 ? params.fallbackArgv : process.argv;
|
|
257
|
+
const programName = params.programName ?? "";
|
|
258
|
+
const normalizedArgv = programName && baseArgv[0] === programName ? baseArgv.slice(1) : baseArgv[0]?.endsWith("remoteclaw") ? baseArgv.slice(1) : baseArgv;
|
|
259
|
+
const executable = (normalizedArgv[0]?.split(/[/\\]/).pop() ?? "").toLowerCase();
|
|
260
|
+
if (normalizedArgv.length >= 2 && (isNodeExecutable(executable) || isBunExecutable(executable))) return normalizedArgv;
|
|
261
|
+
return [
|
|
262
|
+
"node",
|
|
263
|
+
programName || "remoteclaw",
|
|
264
|
+
...normalizedArgv
|
|
265
|
+
];
|
|
266
|
+
}
|
|
267
|
+
const nodeExecutablePattern = /^node-\d+(?:\.\d+)*(?:\.exe)?$/;
|
|
268
|
+
function isNodeExecutable(executable) {
|
|
269
|
+
return executable === "node" || executable === "node.exe" || executable === "nodejs" || executable === "nodejs.exe" || nodeExecutablePattern.test(executable);
|
|
270
|
+
}
|
|
271
|
+
function isBunExecutable(executable) {
|
|
272
|
+
return executable === "bun" || executable === "bun.exe";
|
|
273
|
+
}
|
|
274
|
+
function shouldMigrateStateFromPath(path) {
|
|
275
|
+
if (path.length === 0) return true;
|
|
276
|
+
const [primary, secondary] = path;
|
|
277
|
+
if (primary === "health" || primary === "status" || primary === "sessions") return false;
|
|
278
|
+
if (primary === "config" && (secondary === "get" || secondary === "unset")) return false;
|
|
279
|
+
if (primary === "models" && (secondary === "list" || secondary === "status")) return false;
|
|
280
|
+
if (primary === "memory" && secondary === "status") return false;
|
|
281
|
+
if (primary === "agent") return false;
|
|
282
|
+
return true;
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
//#endregion
|
|
286
|
+
//#region src/cli/respawn-policy.ts
|
|
287
|
+
function shouldSkipRespawnForArgv(argv) {
|
|
288
|
+
return hasHelpOrVersion(argv);
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
//#endregion
|
|
292
|
+
//#region src/cli/windows-argv.ts
|
|
293
|
+
function normalizeWindowsArgv(argv) {
|
|
294
|
+
if (process.platform !== "win32") return argv;
|
|
295
|
+
if (argv.length < 2) return argv;
|
|
296
|
+
const stripControlChars = (value) => {
|
|
297
|
+
let out = "";
|
|
298
|
+
for (let i = 0; i < value.length; i += 1) {
|
|
299
|
+
const code = value.charCodeAt(i);
|
|
300
|
+
if (code >= 32 && code !== 127) out += value[i];
|
|
301
|
+
}
|
|
302
|
+
return out;
|
|
303
|
+
};
|
|
304
|
+
const normalizeArg = (value) => stripControlChars(value).replace(/^['"]+|['"]+$/g, "").trim();
|
|
305
|
+
const normalizeCandidate = (value) => normalizeArg(value).replace(/^\\\\\\?\\/, "");
|
|
306
|
+
const execPath = normalizeCandidate(process.execPath);
|
|
307
|
+
const execPathLower = execPath.toLowerCase();
|
|
308
|
+
const execBase = path.basename(execPath).toLowerCase();
|
|
309
|
+
const isExecPath = (value) => {
|
|
310
|
+
if (!value) return false;
|
|
311
|
+
const normalized = normalizeCandidate(value);
|
|
312
|
+
if (!normalized) return false;
|
|
313
|
+
const lower = normalized.toLowerCase();
|
|
314
|
+
return lower === execPathLower || path.basename(lower) === execBase || lower.endsWith("\\node.exe") || lower.endsWith("/node.exe") || lower.includes("node.exe") || path.basename(lower) === "node.exe" && fs.existsSync(normalized);
|
|
315
|
+
};
|
|
316
|
+
const next = [...argv];
|
|
317
|
+
for (let i = 1; i <= 3 && i < next.length;) {
|
|
318
|
+
if (isExecPath(next[i])) {
|
|
319
|
+
next.splice(i, 1);
|
|
320
|
+
continue;
|
|
321
|
+
}
|
|
322
|
+
i += 1;
|
|
323
|
+
}
|
|
324
|
+
const filtered = next.filter((arg, index) => index === 0 || !isExecPath(arg));
|
|
325
|
+
if (filtered.length < 3) return filtered;
|
|
326
|
+
const cleaned = [...filtered];
|
|
327
|
+
for (let i = 2; i < cleaned.length;) {
|
|
328
|
+
const arg = cleaned[i];
|
|
329
|
+
if (!arg || arg.startsWith("-")) {
|
|
330
|
+
i += 1;
|
|
331
|
+
continue;
|
|
332
|
+
}
|
|
333
|
+
if (isExecPath(arg)) {
|
|
334
|
+
cleaned.splice(i, 1);
|
|
335
|
+
continue;
|
|
336
|
+
}
|
|
337
|
+
break;
|
|
338
|
+
}
|
|
339
|
+
return cleaned;
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
//#endregion
|
|
343
|
+
//#region src/hooks/internal-hooks.ts
|
|
344
|
+
/** Registry of hook handlers by event key */
|
|
345
|
+
const handlers = /* @__PURE__ */ new Map();
|
|
346
|
+
const log$1 = createSubsystemLogger("internal-hooks");
|
|
347
|
+
/**
|
|
348
|
+
* Register a hook handler for a specific event type or event:action combination
|
|
349
|
+
*
|
|
350
|
+
* @param eventKey - Event type (e.g., 'command') or specific action (e.g., 'command:new')
|
|
351
|
+
* @param handler - Function to call when the event is triggered
|
|
352
|
+
*
|
|
353
|
+
* @example
|
|
354
|
+
* ```ts
|
|
355
|
+
* // Listen to all command events
|
|
356
|
+
* registerInternalHook('command', async (event) => {
|
|
357
|
+
* console.log('Command:', event.action);
|
|
358
|
+
* });
|
|
359
|
+
*
|
|
360
|
+
* // Listen only to /new commands
|
|
361
|
+
* registerInternalHook('command:new', async (event) => {
|
|
362
|
+
* await saveSessionToMemory(event);
|
|
363
|
+
* });
|
|
364
|
+
* ```
|
|
365
|
+
*/
|
|
366
|
+
function registerInternalHook(eventKey, handler) {
|
|
367
|
+
if (!handlers.has(eventKey)) handlers.set(eventKey, []);
|
|
368
|
+
handlers.get(eventKey).push(handler);
|
|
369
|
+
}
|
|
370
|
+
/**
|
|
371
|
+
* Clear all registered hooks (useful for testing)
|
|
372
|
+
*/
|
|
373
|
+
function clearInternalHooks() {
|
|
374
|
+
handlers.clear();
|
|
375
|
+
}
|
|
376
|
+
/**
|
|
377
|
+
* Trigger a hook event
|
|
378
|
+
*
|
|
379
|
+
* Calls all handlers registered for:
|
|
380
|
+
* 1. The general event type (e.g., 'command')
|
|
381
|
+
* 2. The specific event:action combination (e.g., 'command:new')
|
|
382
|
+
*
|
|
383
|
+
* Handlers are called in registration order. Errors are caught and logged
|
|
384
|
+
* but don't prevent other handlers from running.
|
|
385
|
+
*
|
|
386
|
+
* @param event - The event to trigger
|
|
387
|
+
*/
|
|
388
|
+
async function triggerInternalHook(event) {
|
|
389
|
+
const typeHandlers = handlers.get(event.type) ?? [];
|
|
390
|
+
const specificHandlers = handlers.get(`${event.type}:${event.action}`) ?? [];
|
|
391
|
+
const allHandlers = [...typeHandlers, ...specificHandlers];
|
|
392
|
+
if (allHandlers.length === 0) return;
|
|
393
|
+
for (const handler of allHandlers) try {
|
|
394
|
+
await handler(event);
|
|
395
|
+
} catch (err) {
|
|
396
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
397
|
+
log$1.error(`Hook error [${event.type}:${event.action}]: ${message}`);
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
/**
|
|
401
|
+
* Create a hook event with common fields filled in
|
|
402
|
+
*
|
|
403
|
+
* @param type - The event type
|
|
404
|
+
* @param action - The action within that type
|
|
405
|
+
* @param sessionKey - The session key
|
|
406
|
+
* @param context - Additional context
|
|
407
|
+
*/
|
|
408
|
+
function createInternalHookEvent(type, action, sessionKey, context = {}) {
|
|
409
|
+
return {
|
|
410
|
+
type,
|
|
411
|
+
action,
|
|
412
|
+
sessionKey,
|
|
413
|
+
context,
|
|
414
|
+
timestamp: /* @__PURE__ */ new Date(),
|
|
415
|
+
messages: []
|
|
416
|
+
};
|
|
417
|
+
}
|
|
418
|
+
|
|
419
|
+
//#endregion
|
|
420
|
+
//#region src/config/paths.ts
|
|
421
|
+
/**
|
|
422
|
+
* Nix mode detection: When REMOTECLAW_NIX_MODE=1, the gateway is running under Nix.
|
|
423
|
+
* In this mode:
|
|
424
|
+
* - No auto-install flows should be attempted
|
|
425
|
+
* - Missing dependencies should produce actionable Nix-specific error messages
|
|
426
|
+
* - Config is managed externally (read-only from Nix perspective)
|
|
427
|
+
*/
|
|
428
|
+
function resolveIsNixMode(env = process.env) {
|
|
429
|
+
return env.REMOTECLAW_NIX_MODE === "1";
|
|
430
|
+
}
|
|
431
|
+
const isNixMode = resolveIsNixMode();
|
|
432
|
+
const LEGACY_STATE_DIRNAMES = [
|
|
433
|
+
".clawdbot",
|
|
434
|
+
".moldbot",
|
|
435
|
+
".moltbot"
|
|
436
|
+
];
|
|
437
|
+
const NEW_STATE_DIRNAME = ".remoteclaw";
|
|
438
|
+
const CONFIG_FILENAME = "remoteclaw.json";
|
|
439
|
+
const LEGACY_CONFIG_FILENAMES = [
|
|
440
|
+
"clawdbot.json",
|
|
441
|
+
"moldbot.json",
|
|
442
|
+
"moltbot.json"
|
|
443
|
+
];
|
|
444
|
+
function resolveDefaultHomeDir() {
|
|
445
|
+
return resolveRequiredHomeDir(process.env, os.homedir);
|
|
446
|
+
}
|
|
447
|
+
/** Build a homedir thunk that respects REMOTECLAW_HOME for the given env. */
|
|
448
|
+
function envHomedir(env) {
|
|
449
|
+
return () => resolveRequiredHomeDir(env, os.homedir);
|
|
450
|
+
}
|
|
451
|
+
function legacyStateDirs(homedir = resolveDefaultHomeDir) {
|
|
452
|
+
return LEGACY_STATE_DIRNAMES.map((dir) => path.join(homedir(), dir));
|
|
453
|
+
}
|
|
454
|
+
function newStateDir(homedir = resolveDefaultHomeDir) {
|
|
455
|
+
return path.join(homedir(), NEW_STATE_DIRNAME);
|
|
456
|
+
}
|
|
457
|
+
function resolveLegacyStateDirs(homedir = resolveDefaultHomeDir) {
|
|
458
|
+
return legacyStateDirs(homedir);
|
|
459
|
+
}
|
|
460
|
+
function resolveNewStateDir(homedir = resolveDefaultHomeDir) {
|
|
461
|
+
return newStateDir(homedir);
|
|
462
|
+
}
|
|
463
|
+
/**
|
|
464
|
+
* State directory for mutable data (sessions, logs, caches).
|
|
465
|
+
* Can be overridden via REMOTECLAW_STATE_DIR.
|
|
466
|
+
* Default: ~/.remoteclaw
|
|
467
|
+
*/
|
|
468
|
+
function resolveStateDir(env = process.env, homedir = envHomedir(env)) {
|
|
469
|
+
const effectiveHomedir = () => resolveRequiredHomeDir(env, homedir);
|
|
470
|
+
const override = env.REMOTECLAW_STATE_DIR?.trim() || env.CLAWDBOT_STATE_DIR?.trim();
|
|
471
|
+
if (override) return resolveUserPath$1(override, env, effectiveHomedir);
|
|
472
|
+
const newDir = newStateDir(effectiveHomedir);
|
|
473
|
+
const legacyDirs = legacyStateDirs(effectiveHomedir);
|
|
474
|
+
if (fs.existsSync(newDir)) return newDir;
|
|
475
|
+
const existingLegacy = legacyDirs.find((dir) => {
|
|
476
|
+
try {
|
|
477
|
+
return fs.existsSync(dir);
|
|
478
|
+
} catch {
|
|
479
|
+
return false;
|
|
480
|
+
}
|
|
481
|
+
});
|
|
482
|
+
if (existingLegacy) return existingLegacy;
|
|
483
|
+
return newDir;
|
|
484
|
+
}
|
|
485
|
+
function resolveUserPath$1(input, env = process.env, homedir = envHomedir(env)) {
|
|
486
|
+
const trimmed = input.trim();
|
|
487
|
+
if (!trimmed) return trimmed;
|
|
488
|
+
if (trimmed.startsWith("~")) {
|
|
489
|
+
const expanded = expandHomePrefix(trimmed, {
|
|
490
|
+
home: resolveRequiredHomeDir(env, homedir),
|
|
491
|
+
env,
|
|
492
|
+
homedir
|
|
493
|
+
});
|
|
494
|
+
return path.resolve(expanded);
|
|
495
|
+
}
|
|
496
|
+
return path.resolve(trimmed);
|
|
497
|
+
}
|
|
498
|
+
const STATE_DIR = resolveStateDir();
|
|
499
|
+
/**
|
|
500
|
+
* Config file path (JSON5).
|
|
501
|
+
* Can be overridden via REMOTECLAW_CONFIG_PATH.
|
|
502
|
+
* Default: ~/.remoteclaw/remoteclaw.json (or $REMOTECLAW_STATE_DIR/remoteclaw.json)
|
|
503
|
+
*/
|
|
504
|
+
function resolveCanonicalConfigPath(env = process.env, stateDir = resolveStateDir(env, envHomedir(env))) {
|
|
505
|
+
const override = env.REMOTECLAW_CONFIG_PATH?.trim() || env.CLAWDBOT_CONFIG_PATH?.trim();
|
|
506
|
+
if (override) return resolveUserPath$1(override, env, envHomedir(env));
|
|
507
|
+
return path.join(stateDir, CONFIG_FILENAME);
|
|
508
|
+
}
|
|
509
|
+
/**
|
|
510
|
+
* Resolve the active config path by preferring existing config candidates
|
|
511
|
+
* before falling back to the canonical path.
|
|
512
|
+
*/
|
|
513
|
+
function resolveConfigPathCandidate(env = process.env, homedir = envHomedir(env)) {
|
|
514
|
+
const existing = resolveDefaultConfigCandidates(env, homedir).find((candidate) => {
|
|
515
|
+
try {
|
|
516
|
+
return fs.existsSync(candidate);
|
|
517
|
+
} catch {
|
|
518
|
+
return false;
|
|
519
|
+
}
|
|
520
|
+
});
|
|
521
|
+
if (existing) return existing;
|
|
522
|
+
return resolveCanonicalConfigPath(env, resolveStateDir(env, homedir));
|
|
523
|
+
}
|
|
524
|
+
/**
|
|
525
|
+
* Active config path (prefers existing config files).
|
|
526
|
+
*/
|
|
527
|
+
function resolveConfigPath(env = process.env, stateDir = resolveStateDir(env, envHomedir(env)), homedir = envHomedir(env)) {
|
|
528
|
+
const override = env.REMOTECLAW_CONFIG_PATH?.trim();
|
|
529
|
+
if (override) return resolveUserPath$1(override, env, homedir);
|
|
530
|
+
const stateOverride = env.REMOTECLAW_STATE_DIR?.trim();
|
|
531
|
+
const existing = [path.join(stateDir, CONFIG_FILENAME), ...LEGACY_CONFIG_FILENAMES.map((name) => path.join(stateDir, name))].find((candidate) => {
|
|
532
|
+
try {
|
|
533
|
+
return fs.existsSync(candidate);
|
|
534
|
+
} catch {
|
|
535
|
+
return false;
|
|
536
|
+
}
|
|
537
|
+
});
|
|
538
|
+
if (existing) return existing;
|
|
539
|
+
if (stateOverride) return path.join(stateDir, CONFIG_FILENAME);
|
|
540
|
+
const defaultStateDir = resolveStateDir(env, homedir);
|
|
541
|
+
if (path.resolve(stateDir) === path.resolve(defaultStateDir)) return resolveConfigPathCandidate(env, homedir);
|
|
542
|
+
return path.join(stateDir, CONFIG_FILENAME);
|
|
543
|
+
}
|
|
544
|
+
const CONFIG_PATH = resolveConfigPathCandidate();
|
|
545
|
+
/**
|
|
546
|
+
* Resolve default config path candidates across default locations.
|
|
547
|
+
* Order: explicit config path → state-dir-derived paths → new default.
|
|
548
|
+
*/
|
|
549
|
+
function resolveDefaultConfigCandidates(env = process.env, homedir = envHomedir(env)) {
|
|
550
|
+
const effectiveHomedir = () => resolveRequiredHomeDir(env, homedir);
|
|
551
|
+
const explicit = env.REMOTECLAW_CONFIG_PATH?.trim() || env.CLAWDBOT_CONFIG_PATH?.trim();
|
|
552
|
+
if (explicit) return [resolveUserPath$1(explicit, env, effectiveHomedir)];
|
|
553
|
+
const candidates = [];
|
|
554
|
+
const remoteclawStateDir = env.REMOTECLAW_STATE_DIR?.trim() || env.CLAWDBOT_STATE_DIR?.trim();
|
|
555
|
+
if (remoteclawStateDir) {
|
|
556
|
+
const resolved = resolveUserPath$1(remoteclawStateDir, env, effectiveHomedir);
|
|
557
|
+
candidates.push(path.join(resolved, CONFIG_FILENAME));
|
|
558
|
+
candidates.push(...LEGACY_CONFIG_FILENAMES.map((name) => path.join(resolved, name)));
|
|
559
|
+
}
|
|
560
|
+
const defaultDirs = [newStateDir(effectiveHomedir), ...legacyStateDirs(effectiveHomedir)];
|
|
561
|
+
for (const dir of defaultDirs) {
|
|
562
|
+
candidates.push(path.join(dir, CONFIG_FILENAME));
|
|
563
|
+
candidates.push(...LEGACY_CONFIG_FILENAMES.map((name) => path.join(dir, name)));
|
|
564
|
+
}
|
|
565
|
+
return candidates;
|
|
566
|
+
}
|
|
567
|
+
const DEFAULT_GATEWAY_PORT = 18789;
|
|
568
|
+
/**
|
|
569
|
+
* Gateway lock directory (ephemeral).
|
|
570
|
+
* Default: os.tmpdir()/remoteclaw-<uid> (uid suffix when available).
|
|
571
|
+
*/
|
|
572
|
+
function resolveGatewayLockDir(tmpdir = os.tmpdir) {
|
|
573
|
+
const base = tmpdir();
|
|
574
|
+
const uid = typeof process.getuid === "function" ? process.getuid() : void 0;
|
|
575
|
+
const suffix = uid != null ? `remoteclaw-${uid}` : "remoteclaw";
|
|
576
|
+
return path.join(base, suffix);
|
|
577
|
+
}
|
|
578
|
+
/**
|
|
579
|
+
* OAuth credentials storage directory.
|
|
580
|
+
*
|
|
581
|
+
* Precedence:
|
|
582
|
+
* - `REMOTECLAW_OAUTH_DIR` (explicit override)
|
|
583
|
+
* - `$*_STATE_DIR/credentials` (canonical server/default)
|
|
584
|
+
*/
|
|
585
|
+
function resolveOAuthDir(env = process.env, stateDir = resolveStateDir(env, envHomedir(env))) {
|
|
586
|
+
const override = env.REMOTECLAW_OAUTH_DIR?.trim();
|
|
587
|
+
if (override) return resolveUserPath$1(override, env, envHomedir(env));
|
|
588
|
+
return path.join(stateDir, "credentials");
|
|
589
|
+
}
|
|
590
|
+
function resolveGatewayPort(cfg, env = process.env) {
|
|
591
|
+
const envRaw = env.REMOTECLAW_GATEWAY_PORT?.trim() || env.CLAWDBOT_GATEWAY_PORT?.trim();
|
|
592
|
+
if (envRaw) {
|
|
593
|
+
const parsed = Number.parseInt(envRaw, 10);
|
|
594
|
+
if (Number.isFinite(parsed) && parsed > 0) return parsed;
|
|
595
|
+
}
|
|
596
|
+
const configPort = cfg?.gateway?.port;
|
|
597
|
+
if (typeof configPort === "number" && Number.isFinite(configPort)) {
|
|
598
|
+
if (configPort > 0) return configPort;
|
|
599
|
+
}
|
|
600
|
+
return DEFAULT_GATEWAY_PORT;
|
|
601
|
+
}
|
|
602
|
+
|
|
603
|
+
//#endregion
|
|
604
|
+
//#region src/infra/tmp-remoteclaw-dir.ts
|
|
605
|
+
const POSIX_REMOTECLAW_TMP_DIR = "/tmp/remoteclaw";
|
|
606
|
+
function isNodeErrorWithCode(err, code) {
|
|
607
|
+
return typeof err === "object" && err !== null && "code" in err && err.code === code;
|
|
608
|
+
}
|
|
609
|
+
function resolvePreferredRemoteClawTmpDir(options = {}) {
|
|
610
|
+
const accessSync = options.accessSync ?? fs.accessSync;
|
|
611
|
+
const lstatSync = options.lstatSync ?? fs.lstatSync;
|
|
612
|
+
const mkdirSync = options.mkdirSync ?? fs.mkdirSync;
|
|
613
|
+
const getuid = options.getuid ?? (() => {
|
|
614
|
+
try {
|
|
615
|
+
return typeof process.getuid === "function" ? process.getuid() : void 0;
|
|
616
|
+
} catch {
|
|
617
|
+
return;
|
|
618
|
+
}
|
|
619
|
+
});
|
|
620
|
+
const tmpdir = options.tmpdir ?? os.tmpdir;
|
|
621
|
+
const uid = getuid();
|
|
622
|
+
const isSecureDirForUser = (st) => {
|
|
623
|
+
if (uid === void 0) return true;
|
|
624
|
+
if (typeof st.uid === "number" && st.uid !== uid) return false;
|
|
625
|
+
if (typeof st.mode === "number" && (st.mode & 18) !== 0) return false;
|
|
626
|
+
return true;
|
|
627
|
+
};
|
|
628
|
+
const fallback = () => {
|
|
629
|
+
const base = tmpdir();
|
|
630
|
+
const suffix = uid === void 0 ? "remoteclaw" : `remoteclaw-${uid}`;
|
|
631
|
+
return path.join(base, suffix);
|
|
632
|
+
};
|
|
633
|
+
const isTrustedPreferredDir = (st) => {
|
|
634
|
+
return st.isDirectory() && !st.isSymbolicLink() && isSecureDirForUser(st);
|
|
635
|
+
};
|
|
636
|
+
const resolvePreferredState = (requireWritableAccess) => {
|
|
637
|
+
try {
|
|
638
|
+
if (!isTrustedPreferredDir(lstatSync(POSIX_REMOTECLAW_TMP_DIR))) return "invalid";
|
|
639
|
+
if (requireWritableAccess) accessSync(POSIX_REMOTECLAW_TMP_DIR, fs.constants.W_OK | fs.constants.X_OK);
|
|
640
|
+
return "available";
|
|
641
|
+
} catch (err) {
|
|
642
|
+
if (isNodeErrorWithCode(err, "ENOENT")) return "missing";
|
|
643
|
+
return "invalid";
|
|
644
|
+
}
|
|
645
|
+
};
|
|
646
|
+
const existingPreferredState = resolvePreferredState(true);
|
|
647
|
+
if (existingPreferredState === "available") return POSIX_REMOTECLAW_TMP_DIR;
|
|
648
|
+
if (existingPreferredState === "invalid") return fallback();
|
|
649
|
+
try {
|
|
650
|
+
accessSync("/tmp", fs.constants.W_OK | fs.constants.X_OK);
|
|
651
|
+
mkdirSync(POSIX_REMOTECLAW_TMP_DIR, {
|
|
652
|
+
recursive: true,
|
|
653
|
+
mode: 448
|
|
654
|
+
});
|
|
655
|
+
if (resolvePreferredState(true) !== "available") return fallback();
|
|
656
|
+
return POSIX_REMOTECLAW_TMP_DIR;
|
|
657
|
+
} catch {
|
|
658
|
+
return fallback();
|
|
659
|
+
}
|
|
660
|
+
}
|
|
661
|
+
|
|
662
|
+
//#endregion
|
|
663
|
+
//#region src/logging/config.ts
|
|
664
|
+
function readLoggingConfig() {
|
|
665
|
+
const configPath = resolveConfigPath();
|
|
666
|
+
try {
|
|
667
|
+
if (!fs.existsSync(configPath)) return;
|
|
668
|
+
const raw = fs.readFileSync(configPath, "utf-8");
|
|
669
|
+
const logging = JSON5.parse(raw)?.logging;
|
|
670
|
+
if (!logging || typeof logging !== "object" || Array.isArray(logging)) return;
|
|
671
|
+
return logging;
|
|
672
|
+
} catch {
|
|
673
|
+
return;
|
|
674
|
+
}
|
|
675
|
+
}
|
|
676
|
+
|
|
677
|
+
//#endregion
|
|
678
|
+
//#region src/logging/levels.ts
|
|
679
|
+
const ALLOWED_LOG_LEVELS = [
|
|
680
|
+
"silent",
|
|
681
|
+
"fatal",
|
|
682
|
+
"error",
|
|
683
|
+
"warn",
|
|
684
|
+
"info",
|
|
685
|
+
"debug",
|
|
686
|
+
"trace"
|
|
687
|
+
];
|
|
688
|
+
function tryParseLogLevel(level) {
|
|
689
|
+
if (typeof level !== "string") return;
|
|
690
|
+
const candidate = level.trim();
|
|
691
|
+
return ALLOWED_LOG_LEVELS.includes(candidate) ? candidate : void 0;
|
|
692
|
+
}
|
|
693
|
+
function normalizeLogLevel(level, fallback = "info") {
|
|
694
|
+
return tryParseLogLevel(level) ?? fallback;
|
|
695
|
+
}
|
|
696
|
+
function levelToMinLevel(level) {
|
|
697
|
+
return {
|
|
698
|
+
fatal: 0,
|
|
699
|
+
error: 1,
|
|
700
|
+
warn: 2,
|
|
701
|
+
info: 3,
|
|
702
|
+
debug: 4,
|
|
703
|
+
trace: 5,
|
|
704
|
+
silent: Number.POSITIVE_INFINITY
|
|
705
|
+
}[level];
|
|
706
|
+
}
|
|
707
|
+
|
|
708
|
+
//#endregion
|
|
709
|
+
//#region src/logging/state.ts
|
|
710
|
+
const loggingState = {
|
|
711
|
+
cachedLogger: null,
|
|
712
|
+
cachedSettings: null,
|
|
713
|
+
cachedConsoleSettings: null,
|
|
714
|
+
overrideSettings: null,
|
|
715
|
+
invalidEnvLogLevelValue: null,
|
|
716
|
+
consolePatched: false,
|
|
717
|
+
forceConsoleToStderr: false,
|
|
718
|
+
consoleTimestampPrefix: false,
|
|
719
|
+
consoleSubsystemFilter: null,
|
|
720
|
+
resolvingConsoleSettings: false,
|
|
721
|
+
streamErrorHandlersInstalled: false,
|
|
722
|
+
rawConsole: null
|
|
723
|
+
};
|
|
724
|
+
|
|
725
|
+
//#endregion
|
|
726
|
+
//#region src/logging/env-log-level.ts
|
|
727
|
+
function resolveEnvLogLevelOverride() {
|
|
728
|
+
const raw = process.env.REMOTECLAW_LOG_LEVEL;
|
|
729
|
+
const trimmed = typeof raw === "string" ? raw.trim() : "";
|
|
730
|
+
if (!trimmed) {
|
|
731
|
+
loggingState.invalidEnvLogLevelValue = null;
|
|
732
|
+
return;
|
|
733
|
+
}
|
|
734
|
+
const parsed = tryParseLogLevel(trimmed);
|
|
735
|
+
if (parsed) {
|
|
736
|
+
loggingState.invalidEnvLogLevelValue = null;
|
|
737
|
+
return parsed;
|
|
738
|
+
}
|
|
739
|
+
if (loggingState.invalidEnvLogLevelValue !== trimmed) {
|
|
740
|
+
loggingState.invalidEnvLogLevelValue = trimmed;
|
|
741
|
+
process.stderr.write(`[remoteclaw] Ignoring invalid REMOTECLAW_LOG_LEVEL="${trimmed}" (allowed: ${ALLOWED_LOG_LEVELS.join("|")}).\n`);
|
|
742
|
+
}
|
|
743
|
+
}
|
|
744
|
+
|
|
745
|
+
//#endregion
|
|
746
|
+
//#region src/logging/node-require.ts
|
|
747
|
+
function resolveNodeRequireFromMeta(metaUrl) {
|
|
748
|
+
const getBuiltinModule = process.getBuiltinModule;
|
|
749
|
+
if (typeof getBuiltinModule !== "function") return null;
|
|
750
|
+
try {
|
|
751
|
+
const moduleNamespace = getBuiltinModule("module");
|
|
752
|
+
const createRequire = typeof moduleNamespace.createRequire === "function" ? moduleNamespace.createRequire : null;
|
|
753
|
+
return createRequire ? createRequire(metaUrl) : null;
|
|
754
|
+
} catch {
|
|
755
|
+
return null;
|
|
756
|
+
}
|
|
757
|
+
}
|
|
758
|
+
|
|
759
|
+
//#endregion
|
|
760
|
+
//#region src/logging/logger.ts
|
|
761
|
+
const DEFAULT_LOG_DIR = resolvePreferredRemoteClawTmpDir();
|
|
762
|
+
const DEFAULT_LOG_FILE = path.join(DEFAULT_LOG_DIR, "remoteclaw.log");
|
|
763
|
+
const LOG_PREFIX = "remoteclaw";
|
|
764
|
+
const LOG_SUFFIX = ".log";
|
|
765
|
+
const MAX_LOG_AGE_MS = 1440 * 60 * 1e3;
|
|
766
|
+
const DEFAULT_MAX_LOG_FILE_BYTES = 500 * 1024 * 1024;
|
|
767
|
+
const requireConfig$1 = resolveNodeRequireFromMeta(import.meta.url);
|
|
768
|
+
const externalTransports = /* @__PURE__ */ new Set();
|
|
769
|
+
function attachExternalTransport(logger, transport) {
|
|
770
|
+
logger.attachTransport((logObj) => {
|
|
771
|
+
if (!externalTransports.has(transport)) return;
|
|
772
|
+
try {
|
|
773
|
+
transport(logObj);
|
|
774
|
+
} catch {}
|
|
775
|
+
});
|
|
776
|
+
}
|
|
777
|
+
function resolveSettings() {
|
|
778
|
+
let cfg = loggingState.overrideSettings ?? readLoggingConfig();
|
|
779
|
+
if (!cfg) try {
|
|
780
|
+
cfg = (requireConfig$1?.("../config/config.js"))?.loadConfig?.().logging;
|
|
781
|
+
} catch {
|
|
782
|
+
cfg = void 0;
|
|
783
|
+
}
|
|
784
|
+
const defaultLevel = process.env.VITEST === "true" && process.env.REMOTECLAW_TEST_FILE_LOG !== "1" ? "silent" : "info";
|
|
785
|
+
const fromConfig = normalizeLogLevel(cfg?.level, defaultLevel);
|
|
786
|
+
return {
|
|
787
|
+
level: resolveEnvLogLevelOverride() ?? fromConfig,
|
|
788
|
+
file: cfg?.file ?? defaultRollingPathForToday(),
|
|
789
|
+
maxFileBytes: resolveMaxLogFileBytes(cfg?.maxFileBytes)
|
|
790
|
+
};
|
|
791
|
+
}
|
|
792
|
+
function settingsChanged(a, b) {
|
|
793
|
+
if (!a) return true;
|
|
794
|
+
return a.level !== b.level || a.file !== b.file || a.maxFileBytes !== b.maxFileBytes;
|
|
795
|
+
}
|
|
796
|
+
function isFileLogLevelEnabled(level) {
|
|
797
|
+
const settings = loggingState.cachedSettings ?? resolveSettings();
|
|
798
|
+
if (!loggingState.cachedSettings) loggingState.cachedSettings = settings;
|
|
799
|
+
if (settings.level === "silent") return false;
|
|
800
|
+
return levelToMinLevel(level) <= levelToMinLevel(settings.level);
|
|
801
|
+
}
|
|
802
|
+
function buildLogger(settings) {
|
|
803
|
+
fs.mkdirSync(path.dirname(settings.file), { recursive: true });
|
|
804
|
+
if (isRollingPath(settings.file)) pruneOldRollingLogs(path.dirname(settings.file));
|
|
805
|
+
let currentFileBytes = getCurrentLogFileBytes(settings.file);
|
|
806
|
+
let warnedAboutSizeCap = false;
|
|
807
|
+
const logger = new Logger({
|
|
808
|
+
name: "remoteclaw",
|
|
809
|
+
minLevel: levelToMinLevel(settings.level),
|
|
810
|
+
type: "hidden"
|
|
811
|
+
});
|
|
812
|
+
logger.attachTransport((logObj) => {
|
|
813
|
+
try {
|
|
814
|
+
const time = logObj.date?.toISOString?.() ?? (/* @__PURE__ */ new Date()).toISOString();
|
|
815
|
+
const payload = `${JSON.stringify({
|
|
816
|
+
...logObj,
|
|
817
|
+
time
|
|
818
|
+
})}\n`;
|
|
819
|
+
const payloadBytes = Buffer.byteLength(payload, "utf8");
|
|
820
|
+
const nextBytes = currentFileBytes + payloadBytes;
|
|
821
|
+
if (nextBytes > settings.maxFileBytes) {
|
|
822
|
+
if (!warnedAboutSizeCap) {
|
|
823
|
+
warnedAboutSizeCap = true;
|
|
824
|
+
const warningLine = JSON.stringify({
|
|
825
|
+
time: (/* @__PURE__ */ new Date()).toISOString(),
|
|
826
|
+
level: "warn",
|
|
827
|
+
subsystem: "logging",
|
|
828
|
+
message: `log file size cap reached; suppressing writes file=${settings.file} maxFileBytes=${settings.maxFileBytes}`
|
|
829
|
+
});
|
|
830
|
+
appendLogLine(settings.file, `${warningLine}\n`);
|
|
831
|
+
process.stderr.write(`[remoteclaw] log file size cap reached; suppressing writes file=${settings.file} maxFileBytes=${settings.maxFileBytes}\n`);
|
|
832
|
+
}
|
|
833
|
+
return;
|
|
834
|
+
}
|
|
835
|
+
if (appendLogLine(settings.file, payload)) currentFileBytes = nextBytes;
|
|
836
|
+
} catch {}
|
|
837
|
+
});
|
|
838
|
+
for (const transport of externalTransports) attachExternalTransport(logger, transport);
|
|
839
|
+
return logger;
|
|
840
|
+
}
|
|
841
|
+
function resolveMaxLogFileBytes(raw) {
|
|
842
|
+
if (typeof raw === "number" && Number.isFinite(raw) && raw > 0) return Math.floor(raw);
|
|
843
|
+
return DEFAULT_MAX_LOG_FILE_BYTES;
|
|
844
|
+
}
|
|
845
|
+
function getCurrentLogFileBytes(file) {
|
|
846
|
+
try {
|
|
847
|
+
return fs.statSync(file).size;
|
|
848
|
+
} catch {
|
|
849
|
+
return 0;
|
|
850
|
+
}
|
|
851
|
+
}
|
|
852
|
+
function appendLogLine(file, line) {
|
|
853
|
+
try {
|
|
854
|
+
fs.appendFileSync(file, line, { encoding: "utf8" });
|
|
855
|
+
return true;
|
|
856
|
+
} catch {
|
|
857
|
+
return false;
|
|
858
|
+
}
|
|
859
|
+
}
|
|
860
|
+
function getLogger() {
|
|
861
|
+
const settings = resolveSettings();
|
|
862
|
+
const cachedLogger = loggingState.cachedLogger;
|
|
863
|
+
const cachedSettings = loggingState.cachedSettings;
|
|
864
|
+
if (!cachedLogger || settingsChanged(cachedSettings, settings)) {
|
|
865
|
+
loggingState.cachedLogger = buildLogger(settings);
|
|
866
|
+
loggingState.cachedSettings = settings;
|
|
867
|
+
}
|
|
868
|
+
return loggingState.cachedLogger;
|
|
869
|
+
}
|
|
870
|
+
function getChildLogger(bindings, opts) {
|
|
871
|
+
const base = getLogger();
|
|
872
|
+
const minLevel = opts?.level ? levelToMinLevel(opts.level) : void 0;
|
|
873
|
+
const name = bindings ? JSON.stringify(bindings) : void 0;
|
|
874
|
+
return base.getSubLogger({
|
|
875
|
+
name,
|
|
876
|
+
minLevel,
|
|
877
|
+
prefix: bindings ? [name ?? ""] : []
|
|
878
|
+
});
|
|
879
|
+
}
|
|
880
|
+
function toPinoLikeLogger(logger, level) {
|
|
881
|
+
const buildChild = (bindings) => toPinoLikeLogger(logger.getSubLogger({ name: bindings ? JSON.stringify(bindings) : void 0 }), level);
|
|
882
|
+
return {
|
|
883
|
+
level,
|
|
884
|
+
child: buildChild,
|
|
885
|
+
trace: (...args) => logger.trace(...args),
|
|
886
|
+
debug: (...args) => logger.debug(...args),
|
|
887
|
+
info: (...args) => logger.info(...args),
|
|
888
|
+
warn: (...args) => logger.warn(...args),
|
|
889
|
+
error: (...args) => logger.error(...args),
|
|
890
|
+
fatal: (...args) => logger.fatal(...args)
|
|
891
|
+
};
|
|
892
|
+
}
|
|
893
|
+
function getResolvedLoggerSettings() {
|
|
894
|
+
return resolveSettings();
|
|
895
|
+
}
|
|
896
|
+
function formatLocalDate(date) {
|
|
897
|
+
return `${date.getFullYear()}-${String(date.getMonth() + 1).padStart(2, "0")}-${String(date.getDate()).padStart(2, "0")}`;
|
|
898
|
+
}
|
|
899
|
+
function defaultRollingPathForToday() {
|
|
900
|
+
const today = formatLocalDate(/* @__PURE__ */ new Date());
|
|
901
|
+
return path.join(DEFAULT_LOG_DIR, `${LOG_PREFIX}-${today}${LOG_SUFFIX}`);
|
|
902
|
+
}
|
|
903
|
+
function isRollingPath(file) {
|
|
904
|
+
const base = path.basename(file);
|
|
905
|
+
return base.startsWith(`${LOG_PREFIX}-`) && base.endsWith(LOG_SUFFIX) && base.length === `${LOG_PREFIX}-YYYY-MM-DD${LOG_SUFFIX}`.length;
|
|
906
|
+
}
|
|
907
|
+
function pruneOldRollingLogs(dir) {
|
|
908
|
+
try {
|
|
909
|
+
const entries = fs.readdirSync(dir, { withFileTypes: true });
|
|
910
|
+
const cutoff = Date.now() - MAX_LOG_AGE_MS;
|
|
911
|
+
for (const entry of entries) {
|
|
912
|
+
if (!entry.isFile()) continue;
|
|
913
|
+
if (!entry.name.startsWith(`${LOG_PREFIX}-`) || !entry.name.endsWith(LOG_SUFFIX)) continue;
|
|
914
|
+
const fullPath = path.join(dir, entry.name);
|
|
915
|
+
try {
|
|
916
|
+
if (fs.statSync(fullPath).mtimeMs < cutoff) fs.rmSync(fullPath, { force: true });
|
|
917
|
+
} catch {}
|
|
918
|
+
}
|
|
919
|
+
} catch {}
|
|
920
|
+
}
|
|
921
|
+
|
|
922
|
+
//#endregion
|
|
923
|
+
//#region src/terminal/palette.ts
|
|
924
|
+
const LOBSTER_PALETTE = {
|
|
925
|
+
accent: "#FF5A2D",
|
|
926
|
+
accentBright: "#FF7A3D",
|
|
927
|
+
accentDim: "#D14A22",
|
|
928
|
+
info: "#FF8A5B",
|
|
929
|
+
success: "#2FBF71",
|
|
930
|
+
warn: "#FFB020",
|
|
931
|
+
error: "#E23D2D",
|
|
932
|
+
muted: "#8B7F77"
|
|
933
|
+
};
|
|
934
|
+
|
|
935
|
+
//#endregion
|
|
936
|
+
//#region src/terminal/theme.ts
|
|
937
|
+
const hasForceColor = typeof process.env.FORCE_COLOR === "string" && process.env.FORCE_COLOR.trim().length > 0 && process.env.FORCE_COLOR.trim() !== "0";
|
|
938
|
+
const baseChalk = process.env.NO_COLOR && !hasForceColor ? new Chalk({ level: 0 }) : chalk;
|
|
939
|
+
const hex = (value) => baseChalk.hex(value);
|
|
940
|
+
const theme = {
|
|
941
|
+
accent: hex(LOBSTER_PALETTE.accent),
|
|
942
|
+
accentBright: hex(LOBSTER_PALETTE.accentBright),
|
|
943
|
+
accentDim: hex(LOBSTER_PALETTE.accentDim),
|
|
944
|
+
info: hex(LOBSTER_PALETTE.info),
|
|
945
|
+
success: hex(LOBSTER_PALETTE.success),
|
|
946
|
+
warn: hex(LOBSTER_PALETTE.warn),
|
|
947
|
+
error: hex(LOBSTER_PALETTE.error),
|
|
948
|
+
muted: hex(LOBSTER_PALETTE.muted),
|
|
949
|
+
heading: baseChalk.bold.hex(LOBSTER_PALETTE.accent),
|
|
950
|
+
command: hex(LOBSTER_PALETTE.accentBright),
|
|
951
|
+
option: hex(LOBSTER_PALETTE.warn)
|
|
952
|
+
};
|
|
953
|
+
const isRich = () => Boolean(baseChalk.level > 0);
|
|
954
|
+
const colorize = (rich, color, value) => rich ? color(value) : value;
|
|
955
|
+
|
|
956
|
+
//#endregion
|
|
957
|
+
//#region src/globals.ts
|
|
958
|
+
let globalVerbose = false;
|
|
959
|
+
let globalYes = false;
|
|
960
|
+
function setVerbose(v) {
|
|
961
|
+
globalVerbose = v;
|
|
962
|
+
}
|
|
963
|
+
function isVerbose() {
|
|
964
|
+
return globalVerbose;
|
|
965
|
+
}
|
|
966
|
+
function shouldLogVerbose() {
|
|
967
|
+
return globalVerbose || isFileLogLevelEnabled("debug");
|
|
968
|
+
}
|
|
969
|
+
function logVerbose(message) {
|
|
970
|
+
if (!shouldLogVerbose()) return;
|
|
971
|
+
try {
|
|
972
|
+
getLogger().debug({ message }, "verbose");
|
|
973
|
+
} catch {}
|
|
974
|
+
if (!globalVerbose) return;
|
|
975
|
+
console.log(theme.muted(message));
|
|
976
|
+
}
|
|
977
|
+
function logVerboseConsole(message) {
|
|
978
|
+
if (!globalVerbose) return;
|
|
979
|
+
console.log(theme.muted(message));
|
|
980
|
+
}
|
|
981
|
+
function isYes() {
|
|
982
|
+
return globalYes;
|
|
983
|
+
}
|
|
984
|
+
const success = theme.success;
|
|
985
|
+
const warn = theme.warn;
|
|
986
|
+
const info = theme.info;
|
|
987
|
+
const danger = theme.error;
|
|
988
|
+
|
|
989
|
+
//#endregion
|
|
990
|
+
//#region src/infra/plain-object.ts
|
|
991
|
+
/**
|
|
992
|
+
* Strict plain-object guard (excludes arrays and host objects).
|
|
993
|
+
*/
|
|
994
|
+
function isPlainObject(value) {
|
|
995
|
+
return typeof value === "object" && value !== null && !Array.isArray(value) && Object.prototype.toString.call(value) === "[object Object]";
|
|
996
|
+
}
|
|
997
|
+
|
|
998
|
+
//#endregion
|
|
999
|
+
//#region src/utils.ts
|
|
1000
|
+
async function ensureDir(dir) {
|
|
1001
|
+
await fs.promises.mkdir(dir, { recursive: true });
|
|
1002
|
+
}
|
|
1003
|
+
/**
|
|
1004
|
+
* Check if a file or directory exists at the given path.
|
|
1005
|
+
*/
|
|
1006
|
+
async function pathExists(targetPath) {
|
|
1007
|
+
try {
|
|
1008
|
+
await fs.promises.access(targetPath);
|
|
1009
|
+
return true;
|
|
1010
|
+
} catch {
|
|
1011
|
+
return false;
|
|
1012
|
+
}
|
|
1013
|
+
}
|
|
1014
|
+
function clampNumber(value, min, max) {
|
|
1015
|
+
return Math.max(min, Math.min(max, value));
|
|
1016
|
+
}
|
|
1017
|
+
/** Alias for clampNumber (shorter, more common name) */
|
|
1018
|
+
const clamp = clampNumber;
|
|
1019
|
+
/**
|
|
1020
|
+
* Escapes special regex characters in a string so it can be used in a RegExp constructor.
|
|
1021
|
+
*/
|
|
1022
|
+
function escapeRegExp(value) {
|
|
1023
|
+
return value.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
1024
|
+
}
|
|
1025
|
+
/**
|
|
1026
|
+
* Safely parse JSON, returning null on error instead of throwing.
|
|
1027
|
+
*/
|
|
1028
|
+
function safeParseJson(raw) {
|
|
1029
|
+
try {
|
|
1030
|
+
return JSON.parse(raw);
|
|
1031
|
+
} catch {
|
|
1032
|
+
return null;
|
|
1033
|
+
}
|
|
1034
|
+
}
|
|
1035
|
+
/**
|
|
1036
|
+
* Type guard for Record<string, unknown> (less strict than isPlainObject).
|
|
1037
|
+
* Accepts any non-null object that isn't an array.
|
|
1038
|
+
*/
|
|
1039
|
+
function isRecord(value) {
|
|
1040
|
+
return typeof value === "object" && value !== null && !Array.isArray(value);
|
|
1041
|
+
}
|
|
1042
|
+
function normalizeE164(number) {
|
|
1043
|
+
const digits = number.replace(/^whatsapp:/, "").trim().replace(/[^\d+]/g, "");
|
|
1044
|
+
if (digits.startsWith("+")) return `+${digits.slice(1)}`;
|
|
1045
|
+
return `+${digits}`;
|
|
1046
|
+
}
|
|
1047
|
+
/**
|
|
1048
|
+
* "Self-chat mode" heuristic (single phone): the gateway is logged in as the owner's own WhatsApp account,
|
|
1049
|
+
* and `channels.whatsapp.allowFrom` includes that same number. Used to avoid side-effects that make no sense when the
|
|
1050
|
+
* "bot" and the human are the same WhatsApp identity (e.g. auto read receipts, @mention JID triggers).
|
|
1051
|
+
*/
|
|
1052
|
+
function isSelfChatMode(selfE164, allowFrom) {
|
|
1053
|
+
if (!selfE164) return false;
|
|
1054
|
+
if (!Array.isArray(allowFrom) || allowFrom.length === 0) return false;
|
|
1055
|
+
const normalizedSelf = normalizeE164(selfE164);
|
|
1056
|
+
return allowFrom.some((n) => {
|
|
1057
|
+
if (n === "*") return false;
|
|
1058
|
+
try {
|
|
1059
|
+
return normalizeE164(String(n)) === normalizedSelf;
|
|
1060
|
+
} catch {
|
|
1061
|
+
return false;
|
|
1062
|
+
}
|
|
1063
|
+
});
|
|
1064
|
+
}
|
|
1065
|
+
function toWhatsappJid(number) {
|
|
1066
|
+
const withoutPrefix = number.replace(/^whatsapp:/, "").trim();
|
|
1067
|
+
if (withoutPrefix.includes("@")) return withoutPrefix;
|
|
1068
|
+
return `${normalizeE164(withoutPrefix).replace(/\D/g, "")}@s.whatsapp.net`;
|
|
1069
|
+
}
|
|
1070
|
+
function resolveLidMappingDirs(opts) {
|
|
1071
|
+
const dirs = /* @__PURE__ */ new Set();
|
|
1072
|
+
const addDir = (dir) => {
|
|
1073
|
+
if (!dir) return;
|
|
1074
|
+
dirs.add(resolveUserPath(dir));
|
|
1075
|
+
};
|
|
1076
|
+
addDir(opts?.authDir);
|
|
1077
|
+
for (const dir of opts?.lidMappingDirs ?? []) addDir(dir);
|
|
1078
|
+
addDir(resolveOAuthDir());
|
|
1079
|
+
addDir(path.join(CONFIG_DIR, "credentials"));
|
|
1080
|
+
return [...dirs];
|
|
1081
|
+
}
|
|
1082
|
+
function readLidReverseMapping(lid, opts) {
|
|
1083
|
+
const mappingFilename = `lid-mapping-${lid}_reverse.json`;
|
|
1084
|
+
const mappingDirs = resolveLidMappingDirs(opts);
|
|
1085
|
+
for (const dir of mappingDirs) {
|
|
1086
|
+
const mappingPath = path.join(dir, mappingFilename);
|
|
1087
|
+
try {
|
|
1088
|
+
const data = fs.readFileSync(mappingPath, "utf8");
|
|
1089
|
+
const phone = JSON.parse(data);
|
|
1090
|
+
if (phone === null || phone === void 0) continue;
|
|
1091
|
+
return normalizeE164(String(phone));
|
|
1092
|
+
} catch {}
|
|
1093
|
+
}
|
|
1094
|
+
return null;
|
|
1095
|
+
}
|
|
1096
|
+
function jidToE164(jid, opts) {
|
|
1097
|
+
const match = jid.match(/^(\d+)(?::\d+)?@(s\.whatsapp\.net|hosted)$/);
|
|
1098
|
+
if (match) return `+${match[1]}`;
|
|
1099
|
+
const lidMatch = jid.match(/^(\d+)(?::\d+)?@(lid|hosted\.lid)$/);
|
|
1100
|
+
if (lidMatch) {
|
|
1101
|
+
const lid = lidMatch[1];
|
|
1102
|
+
const phone = readLidReverseMapping(lid, opts);
|
|
1103
|
+
if (phone) return phone;
|
|
1104
|
+
if (opts?.logMissing ?? shouldLogVerbose()) logVerbose(`LID mapping not found for ${lid}; skipping inbound message`);
|
|
1105
|
+
}
|
|
1106
|
+
return null;
|
|
1107
|
+
}
|
|
1108
|
+
async function resolveJidToE164(jid, opts) {
|
|
1109
|
+
if (!jid) return null;
|
|
1110
|
+
const direct = jidToE164(jid, opts);
|
|
1111
|
+
if (direct) return direct;
|
|
1112
|
+
if (!/(@lid|@hosted\.lid)$/.test(jid)) return null;
|
|
1113
|
+
if (!opts?.lidLookup?.getPNForLID) return null;
|
|
1114
|
+
try {
|
|
1115
|
+
const pnJid = await opts.lidLookup.getPNForLID(jid);
|
|
1116
|
+
if (!pnJid) return null;
|
|
1117
|
+
return jidToE164(pnJid, opts);
|
|
1118
|
+
} catch (err) {
|
|
1119
|
+
if (shouldLogVerbose()) logVerbose(`LID mapping lookup failed for ${jid}: ${String(err)}`);
|
|
1120
|
+
return null;
|
|
1121
|
+
}
|
|
1122
|
+
}
|
|
1123
|
+
function sleep(ms) {
|
|
1124
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
1125
|
+
}
|
|
1126
|
+
function isHighSurrogate(codeUnit) {
|
|
1127
|
+
return codeUnit >= 55296 && codeUnit <= 56319;
|
|
1128
|
+
}
|
|
1129
|
+
function isLowSurrogate(codeUnit) {
|
|
1130
|
+
return codeUnit >= 56320 && codeUnit <= 57343;
|
|
1131
|
+
}
|
|
1132
|
+
function sliceUtf16Safe(input, start, end) {
|
|
1133
|
+
const len = input.length;
|
|
1134
|
+
let from = start < 0 ? Math.max(len + start, 0) : Math.min(start, len);
|
|
1135
|
+
let to = end === void 0 ? len : end < 0 ? Math.max(len + end, 0) : Math.min(end, len);
|
|
1136
|
+
if (to < from) {
|
|
1137
|
+
const tmp = from;
|
|
1138
|
+
from = to;
|
|
1139
|
+
to = tmp;
|
|
1140
|
+
}
|
|
1141
|
+
if (from > 0 && from < len) {
|
|
1142
|
+
if (isLowSurrogate(input.charCodeAt(from)) && isHighSurrogate(input.charCodeAt(from - 1))) from += 1;
|
|
1143
|
+
}
|
|
1144
|
+
if (to > 0 && to < len) {
|
|
1145
|
+
if (isHighSurrogate(input.charCodeAt(to - 1)) && isLowSurrogate(input.charCodeAt(to))) to -= 1;
|
|
1146
|
+
}
|
|
1147
|
+
return input.slice(from, to);
|
|
1148
|
+
}
|
|
1149
|
+
function truncateUtf16Safe(input, maxLen) {
|
|
1150
|
+
const limit = Math.max(0, Math.floor(maxLen));
|
|
1151
|
+
if (input.length <= limit) return input;
|
|
1152
|
+
return sliceUtf16Safe(input, 0, limit);
|
|
1153
|
+
}
|
|
1154
|
+
function resolveUserPath(input) {
|
|
1155
|
+
if (!input) return "";
|
|
1156
|
+
const trimmed = input.trim();
|
|
1157
|
+
if (!trimmed) return trimmed;
|
|
1158
|
+
if (trimmed.startsWith("~")) {
|
|
1159
|
+
const expanded = expandHomePrefix(trimmed, {
|
|
1160
|
+
home: resolveRequiredHomeDir(process.env, os.homedir),
|
|
1161
|
+
env: process.env,
|
|
1162
|
+
homedir: os.homedir
|
|
1163
|
+
});
|
|
1164
|
+
return path.resolve(expanded);
|
|
1165
|
+
}
|
|
1166
|
+
return path.resolve(trimmed);
|
|
1167
|
+
}
|
|
1168
|
+
function resolveConfigDir(env = process.env, homedir = os.homedir) {
|
|
1169
|
+
const override = env.REMOTECLAW_STATE_DIR?.trim() || env.CLAWDBOT_STATE_DIR?.trim();
|
|
1170
|
+
if (override) return resolveUserPath(override);
|
|
1171
|
+
const newDir = path.join(resolveRequiredHomeDir(env, homedir), ".remoteclaw");
|
|
1172
|
+
try {
|
|
1173
|
+
if (fs.existsSync(newDir)) return newDir;
|
|
1174
|
+
} catch {}
|
|
1175
|
+
return newDir;
|
|
1176
|
+
}
|
|
1177
|
+
function resolveHomeDir() {
|
|
1178
|
+
return resolveEffectiveHomeDir(process.env, os.homedir);
|
|
1179
|
+
}
|
|
1180
|
+
function resolveHomeDisplayPrefix() {
|
|
1181
|
+
const home = resolveHomeDir();
|
|
1182
|
+
if (!home) return;
|
|
1183
|
+
if (process.env.REMOTECLAW_HOME?.trim()) return {
|
|
1184
|
+
home,
|
|
1185
|
+
prefix: "$REMOTECLAW_HOME"
|
|
1186
|
+
};
|
|
1187
|
+
return {
|
|
1188
|
+
home,
|
|
1189
|
+
prefix: "~"
|
|
1190
|
+
};
|
|
1191
|
+
}
|
|
1192
|
+
function shortenHomePath(input) {
|
|
1193
|
+
if (!input) return input;
|
|
1194
|
+
const display = resolveHomeDisplayPrefix();
|
|
1195
|
+
if (!display) return input;
|
|
1196
|
+
const { home, prefix } = display;
|
|
1197
|
+
if (input === home) return prefix;
|
|
1198
|
+
if (input.startsWith(`${home}/`) || input.startsWith(`${home}\\`)) return `${prefix}${input.slice(home.length)}`;
|
|
1199
|
+
return input;
|
|
1200
|
+
}
|
|
1201
|
+
function shortenHomeInString(input) {
|
|
1202
|
+
if (!input) return input;
|
|
1203
|
+
const display = resolveHomeDisplayPrefix();
|
|
1204
|
+
if (!display) return input;
|
|
1205
|
+
return input.split(display.home).join(display.prefix);
|
|
1206
|
+
}
|
|
1207
|
+
function displayPath(input) {
|
|
1208
|
+
return shortenHomePath(input);
|
|
1209
|
+
}
|
|
1210
|
+
function displayString(input) {
|
|
1211
|
+
return shortenHomeInString(input);
|
|
1212
|
+
}
|
|
1213
|
+
function formatTerminalLink(label, url, opts) {
|
|
1214
|
+
const esc = "\x1B";
|
|
1215
|
+
const safeLabel = label.replaceAll(esc, "");
|
|
1216
|
+
const safeUrl = url.replaceAll(esc, "");
|
|
1217
|
+
if (!(opts?.force === true ? true : opts?.force === false ? false : Boolean(process.stdout.isTTY))) return opts?.fallback ?? `${safeLabel} (${safeUrl})`;
|
|
1218
|
+
return `\u001b]8;;${safeUrl}\u0007${safeLabel}\u001b]8;;\u0007`;
|
|
1219
|
+
}
|
|
1220
|
+
const CONFIG_DIR = resolveConfigDir();
|
|
1221
|
+
|
|
1222
|
+
//#endregion
|
|
1223
|
+
//#region src/plugins/commands.ts
|
|
1224
|
+
const pluginCommands = /* @__PURE__ */ new Map();
|
|
1225
|
+
let registryLocked = false;
|
|
1226
|
+
const MAX_ARGS_LENGTH = 4096;
|
|
1227
|
+
/**
|
|
1228
|
+
* Reserved command names that plugins cannot override.
|
|
1229
|
+
* These are built-in commands from commands-registry.data.ts.
|
|
1230
|
+
*/
|
|
1231
|
+
const RESERVED_COMMANDS = new Set([
|
|
1232
|
+
"help",
|
|
1233
|
+
"commands",
|
|
1234
|
+
"status",
|
|
1235
|
+
"whoami",
|
|
1236
|
+
"context",
|
|
1237
|
+
"stop",
|
|
1238
|
+
"restart",
|
|
1239
|
+
"reset",
|
|
1240
|
+
"new",
|
|
1241
|
+
"compact",
|
|
1242
|
+
"config",
|
|
1243
|
+
"debug",
|
|
1244
|
+
"allowlist",
|
|
1245
|
+
"activation",
|
|
1246
|
+
"skill",
|
|
1247
|
+
"subagents",
|
|
1248
|
+
"kill",
|
|
1249
|
+
"steer",
|
|
1250
|
+
"tell",
|
|
1251
|
+
"model",
|
|
1252
|
+
"models",
|
|
1253
|
+
"queue",
|
|
1254
|
+
"send",
|
|
1255
|
+
"bash",
|
|
1256
|
+
"think",
|
|
1257
|
+
"verbose",
|
|
1258
|
+
"reasoning",
|
|
1259
|
+
"elevated",
|
|
1260
|
+
"usage"
|
|
1261
|
+
]);
|
|
1262
|
+
/**
|
|
1263
|
+
* Validate a command name.
|
|
1264
|
+
* Returns an error message if invalid, or null if valid.
|
|
1265
|
+
*/
|
|
1266
|
+
function validateCommandName(name) {
|
|
1267
|
+
const trimmed = name.trim().toLowerCase();
|
|
1268
|
+
if (!trimmed) return "Command name cannot be empty";
|
|
1269
|
+
if (!/^[a-z][a-z0-9_-]*$/.test(trimmed)) return "Command name must start with a letter and contain only letters, numbers, hyphens, and underscores";
|
|
1270
|
+
if (RESERVED_COMMANDS.has(trimmed)) return `Command name "${trimmed}" is reserved by a built-in command`;
|
|
1271
|
+
return null;
|
|
1272
|
+
}
|
|
1273
|
+
/**
|
|
1274
|
+
* Register a plugin command.
|
|
1275
|
+
* Returns an error if the command name is invalid or reserved.
|
|
1276
|
+
*/
|
|
1277
|
+
function registerPluginCommand(pluginId, command) {
|
|
1278
|
+
if (registryLocked) return {
|
|
1279
|
+
ok: false,
|
|
1280
|
+
error: "Cannot register commands while processing is in progress"
|
|
1281
|
+
};
|
|
1282
|
+
if (typeof command.handler !== "function") return {
|
|
1283
|
+
ok: false,
|
|
1284
|
+
error: "Command handler must be a function"
|
|
1285
|
+
};
|
|
1286
|
+
const validationError = validateCommandName(command.name);
|
|
1287
|
+
if (validationError) return {
|
|
1288
|
+
ok: false,
|
|
1289
|
+
error: validationError
|
|
1290
|
+
};
|
|
1291
|
+
const key = `/${command.name.toLowerCase()}`;
|
|
1292
|
+
if (pluginCommands.has(key)) {
|
|
1293
|
+
const existing = pluginCommands.get(key);
|
|
1294
|
+
return {
|
|
1295
|
+
ok: false,
|
|
1296
|
+
error: `Command "${command.name}" already registered by plugin "${existing.pluginId}"`
|
|
1297
|
+
};
|
|
1298
|
+
}
|
|
1299
|
+
pluginCommands.set(key, {
|
|
1300
|
+
...command,
|
|
1301
|
+
pluginId
|
|
1302
|
+
});
|
|
1303
|
+
logVerbose(`Registered plugin command: ${key} (plugin: ${pluginId})`);
|
|
1304
|
+
return { ok: true };
|
|
1305
|
+
}
|
|
1306
|
+
/**
|
|
1307
|
+
* Clear all registered plugin commands.
|
|
1308
|
+
* Called during plugin reload.
|
|
1309
|
+
*/
|
|
1310
|
+
function clearPluginCommands() {
|
|
1311
|
+
pluginCommands.clear();
|
|
1312
|
+
}
|
|
1313
|
+
/**
|
|
1314
|
+
* Check if a command body matches a registered plugin command.
|
|
1315
|
+
* Returns the command definition and parsed args if matched.
|
|
1316
|
+
*
|
|
1317
|
+
* Note: If a command has `acceptsArgs: false` and the user provides arguments,
|
|
1318
|
+
* the command will not match. This allows the message to fall through to
|
|
1319
|
+
* built-in handlers or the agent. Document this behavior to plugin authors.
|
|
1320
|
+
*/
|
|
1321
|
+
function matchPluginCommand(commandBody) {
|
|
1322
|
+
const trimmed = commandBody.trim();
|
|
1323
|
+
if (!trimmed.startsWith("/")) return null;
|
|
1324
|
+
const spaceIndex = trimmed.indexOf(" ");
|
|
1325
|
+
const commandName = spaceIndex === -1 ? trimmed : trimmed.slice(0, spaceIndex);
|
|
1326
|
+
const args = spaceIndex === -1 ? void 0 : trimmed.slice(spaceIndex + 1).trim();
|
|
1327
|
+
const key = commandName.toLowerCase();
|
|
1328
|
+
const command = pluginCommands.get(key);
|
|
1329
|
+
if (!command) return null;
|
|
1330
|
+
if (args && !command.acceptsArgs) return null;
|
|
1331
|
+
return {
|
|
1332
|
+
command,
|
|
1333
|
+
args: args || void 0
|
|
1334
|
+
};
|
|
1335
|
+
}
|
|
1336
|
+
/**
|
|
1337
|
+
* Sanitize command arguments to prevent injection attacks.
|
|
1338
|
+
* Removes control characters and enforces length limits.
|
|
1339
|
+
*/
|
|
1340
|
+
function sanitizeArgs(args) {
|
|
1341
|
+
if (!args) return;
|
|
1342
|
+
if (args.length > MAX_ARGS_LENGTH) return args.slice(0, MAX_ARGS_LENGTH);
|
|
1343
|
+
let sanitized = "";
|
|
1344
|
+
for (const char of args) {
|
|
1345
|
+
const code = char.charCodeAt(0);
|
|
1346
|
+
if (!(code <= 31 && code !== 9 && code !== 10 || code === 127)) sanitized += char;
|
|
1347
|
+
}
|
|
1348
|
+
return sanitized;
|
|
1349
|
+
}
|
|
1350
|
+
/**
|
|
1351
|
+
* Execute a plugin command handler.
|
|
1352
|
+
*
|
|
1353
|
+
* Note: Plugin authors should still validate and sanitize ctx.args for their
|
|
1354
|
+
* specific use case. This function provides basic defense-in-depth sanitization.
|
|
1355
|
+
*/
|
|
1356
|
+
async function executePluginCommand(params) {
|
|
1357
|
+
const { command, args, senderId, channel, isAuthorizedSender, commandBody, config } = params;
|
|
1358
|
+
if (command.requireAuth !== false && !isAuthorizedSender) {
|
|
1359
|
+
logVerbose(`Plugin command /${command.name} blocked: unauthorized sender ${senderId || "<unknown>"}`);
|
|
1360
|
+
return { text: "⚠️ This command requires authorization." };
|
|
1361
|
+
}
|
|
1362
|
+
const sanitizedArgs = sanitizeArgs(args);
|
|
1363
|
+
const ctx = {
|
|
1364
|
+
senderId,
|
|
1365
|
+
channel,
|
|
1366
|
+
channelId: params.channelId,
|
|
1367
|
+
isAuthorizedSender,
|
|
1368
|
+
args: sanitizedArgs,
|
|
1369
|
+
commandBody,
|
|
1370
|
+
config,
|
|
1371
|
+
from: params.from,
|
|
1372
|
+
to: params.to,
|
|
1373
|
+
accountId: params.accountId,
|
|
1374
|
+
messageThreadId: params.messageThreadId
|
|
1375
|
+
};
|
|
1376
|
+
registryLocked = true;
|
|
1377
|
+
try {
|
|
1378
|
+
const result = await command.handler(ctx);
|
|
1379
|
+
logVerbose(`Plugin command /${command.name} executed successfully for ${senderId || "unknown"}`);
|
|
1380
|
+
return result;
|
|
1381
|
+
} catch (err) {
|
|
1382
|
+
const error = err;
|
|
1383
|
+
logVerbose(`Plugin command /${command.name} error: ${error.message}`);
|
|
1384
|
+
return { text: "⚠️ Command failed. Please try again later." };
|
|
1385
|
+
} finally {
|
|
1386
|
+
registryLocked = false;
|
|
1387
|
+
}
|
|
1388
|
+
}
|
|
1389
|
+
/**
|
|
1390
|
+
* List all registered plugin commands.
|
|
1391
|
+
* Used for /help and /commands output.
|
|
1392
|
+
*/
|
|
1393
|
+
function listPluginCommands() {
|
|
1394
|
+
return Array.from(pluginCommands.values()).map((cmd) => ({
|
|
1395
|
+
name: cmd.name,
|
|
1396
|
+
description: cmd.description,
|
|
1397
|
+
pluginId: cmd.pluginId
|
|
1398
|
+
}));
|
|
1399
|
+
}
|
|
1400
|
+
/**
|
|
1401
|
+
* Get plugin command specs for native command registration (e.g., Telegram).
|
|
1402
|
+
*/
|
|
1403
|
+
function getPluginCommandSpecs() {
|
|
1404
|
+
return Array.from(pluginCommands.values()).map((cmd) => ({
|
|
1405
|
+
name: cmd.name,
|
|
1406
|
+
description: cmd.description
|
|
1407
|
+
}));
|
|
1408
|
+
}
|
|
1409
|
+
|
|
1410
|
+
//#endregion
|
|
1411
|
+
//#region src/plugins/http-path.ts
|
|
1412
|
+
function normalizePluginHttpPath(path, fallback) {
|
|
1413
|
+
const trimmed = path?.trim();
|
|
1414
|
+
if (!trimmed) {
|
|
1415
|
+
const fallbackTrimmed = fallback?.trim();
|
|
1416
|
+
if (!fallbackTrimmed) return null;
|
|
1417
|
+
return fallbackTrimmed.startsWith("/") ? fallbackTrimmed : `/${fallbackTrimmed}`;
|
|
1418
|
+
}
|
|
1419
|
+
return trimmed.startsWith("/") ? trimmed : `/${trimmed}`;
|
|
1420
|
+
}
|
|
1421
|
+
|
|
1422
|
+
//#endregion
|
|
1423
|
+
//#region src/plugins/registry.ts
|
|
1424
|
+
function createEmptyPluginRegistry() {
|
|
1425
|
+
return {
|
|
1426
|
+
plugins: [],
|
|
1427
|
+
tools: [],
|
|
1428
|
+
hooks: [],
|
|
1429
|
+
typedHooks: [],
|
|
1430
|
+
channels: [],
|
|
1431
|
+
providers: [],
|
|
1432
|
+
gatewayHandlers: {},
|
|
1433
|
+
httpHandlers: [],
|
|
1434
|
+
httpRoutes: [],
|
|
1435
|
+
cliRegistrars: [],
|
|
1436
|
+
services: [],
|
|
1437
|
+
commands: [],
|
|
1438
|
+
diagnostics: []
|
|
1439
|
+
};
|
|
1440
|
+
}
|
|
1441
|
+
/**
|
|
1442
|
+
* Hooks that belonged to the in-process LLM execution pipeline.
|
|
1443
|
+
* Their trigger points no longer exist in CLI-only mode — registrations
|
|
1444
|
+
* are silently dropped with a diagnostic warning.
|
|
1445
|
+
*/
|
|
1446
|
+
const DEAD_HOOKS = new Set([
|
|
1447
|
+
"before_model_resolve",
|
|
1448
|
+
"before_prompt_build",
|
|
1449
|
+
"before_agent_start",
|
|
1450
|
+
"llm_input",
|
|
1451
|
+
"llm_output",
|
|
1452
|
+
"before_compaction",
|
|
1453
|
+
"after_compaction",
|
|
1454
|
+
"tool_result_persist"
|
|
1455
|
+
]);
|
|
1456
|
+
function createPluginRegistry(registryParams) {
|
|
1457
|
+
const registry = createEmptyPluginRegistry();
|
|
1458
|
+
const coreGatewayMethods = new Set(Object.keys(registryParams.coreGatewayHandlers ?? {}));
|
|
1459
|
+
const pushDiagnostic = (diag) => {
|
|
1460
|
+
registry.diagnostics.push(diag);
|
|
1461
|
+
};
|
|
1462
|
+
const registerTool = (record, tool, opts) => {
|
|
1463
|
+
const names = opts?.names ?? (opts?.name ? [opts.name] : []);
|
|
1464
|
+
const optional = opts?.optional === true;
|
|
1465
|
+
const factory = typeof tool === "function" ? tool : (_ctx) => tool;
|
|
1466
|
+
if (typeof tool !== "function") names.push(tool.name);
|
|
1467
|
+
const normalized = names.map((name) => name.trim()).filter(Boolean);
|
|
1468
|
+
if (normalized.length > 0) record.toolNames.push(...normalized);
|
|
1469
|
+
registry.tools.push({
|
|
1470
|
+
pluginId: record.id,
|
|
1471
|
+
factory,
|
|
1472
|
+
names: normalized,
|
|
1473
|
+
optional,
|
|
1474
|
+
source: record.source
|
|
1475
|
+
});
|
|
1476
|
+
};
|
|
1477
|
+
const registerHook = (record, events, handler, opts, config) => {
|
|
1478
|
+
const trimmedEvents = (Array.isArray(events) ? events : [events]).map((event) => event.trim()).filter(Boolean);
|
|
1479
|
+
const normalizedEvents = [];
|
|
1480
|
+
for (const event of trimmedEvents) {
|
|
1481
|
+
if (DEAD_HOOKS.has(event)) {
|
|
1482
|
+
pushDiagnostic({
|
|
1483
|
+
level: "warn",
|
|
1484
|
+
pluginId: record.id,
|
|
1485
|
+
source: record.source,
|
|
1486
|
+
message: `Hook "${event}" is not available in CLI-only mode. LLM pipeline hooks are managed by the CLI agent runtime. This hook will not fire.`
|
|
1487
|
+
});
|
|
1488
|
+
continue;
|
|
1489
|
+
}
|
|
1490
|
+
normalizedEvents.push(event);
|
|
1491
|
+
}
|
|
1492
|
+
if (normalizedEvents.length === 0) return;
|
|
1493
|
+
const entry = opts?.entry ?? null;
|
|
1494
|
+
const name = entry?.hook.name ?? opts?.name?.trim();
|
|
1495
|
+
if (!name) {
|
|
1496
|
+
pushDiagnostic({
|
|
1497
|
+
level: "warn",
|
|
1498
|
+
pluginId: record.id,
|
|
1499
|
+
source: record.source,
|
|
1500
|
+
message: "hook registration missing name"
|
|
1501
|
+
});
|
|
1502
|
+
return;
|
|
1503
|
+
}
|
|
1504
|
+
const description = entry?.hook.description ?? opts?.description ?? "";
|
|
1505
|
+
const hookEntry = entry ? {
|
|
1506
|
+
...entry,
|
|
1507
|
+
hook: {
|
|
1508
|
+
...entry.hook,
|
|
1509
|
+
name,
|
|
1510
|
+
description,
|
|
1511
|
+
source: "remoteclaw-plugin",
|
|
1512
|
+
pluginId: record.id
|
|
1513
|
+
},
|
|
1514
|
+
metadata: {
|
|
1515
|
+
...entry.metadata,
|
|
1516
|
+
events: normalizedEvents
|
|
1517
|
+
}
|
|
1518
|
+
} : {
|
|
1519
|
+
hook: {
|
|
1520
|
+
name,
|
|
1521
|
+
description,
|
|
1522
|
+
source: "remoteclaw-plugin",
|
|
1523
|
+
pluginId: record.id,
|
|
1524
|
+
filePath: record.source,
|
|
1525
|
+
baseDir: path.dirname(record.source),
|
|
1526
|
+
handlerPath: record.source
|
|
1527
|
+
},
|
|
1528
|
+
frontmatter: {},
|
|
1529
|
+
metadata: { events: normalizedEvents },
|
|
1530
|
+
invocation: { enabled: true }
|
|
1531
|
+
};
|
|
1532
|
+
record.hookNames.push(name);
|
|
1533
|
+
registry.hooks.push({
|
|
1534
|
+
pluginId: record.id,
|
|
1535
|
+
entry: hookEntry,
|
|
1536
|
+
events: normalizedEvents,
|
|
1537
|
+
source: record.source
|
|
1538
|
+
});
|
|
1539
|
+
if (!(config?.hooks?.internal?.enabled === true) || opts?.register === false) return;
|
|
1540
|
+
for (const event of normalizedEvents) registerInternalHook(event, handler);
|
|
1541
|
+
};
|
|
1542
|
+
const registerGatewayMethod = (record, method, handler) => {
|
|
1543
|
+
const trimmed = method.trim();
|
|
1544
|
+
if (!trimmed) return;
|
|
1545
|
+
if (coreGatewayMethods.has(trimmed) || registry.gatewayHandlers[trimmed]) {
|
|
1546
|
+
pushDiagnostic({
|
|
1547
|
+
level: "error",
|
|
1548
|
+
pluginId: record.id,
|
|
1549
|
+
source: record.source,
|
|
1550
|
+
message: `gateway method already registered: ${trimmed}`
|
|
1551
|
+
});
|
|
1552
|
+
return;
|
|
1553
|
+
}
|
|
1554
|
+
registry.gatewayHandlers[trimmed] = handler;
|
|
1555
|
+
record.gatewayMethods.push(trimmed);
|
|
1556
|
+
};
|
|
1557
|
+
const registerHttpHandler = (record, handler) => {
|
|
1558
|
+
record.httpHandlers += 1;
|
|
1559
|
+
registry.httpHandlers.push({
|
|
1560
|
+
pluginId: record.id,
|
|
1561
|
+
handler,
|
|
1562
|
+
source: record.source
|
|
1563
|
+
});
|
|
1564
|
+
};
|
|
1565
|
+
const registerHttpRoute = (record, params) => {
|
|
1566
|
+
const normalizedPath = normalizePluginHttpPath(params.path);
|
|
1567
|
+
if (!normalizedPath) {
|
|
1568
|
+
pushDiagnostic({
|
|
1569
|
+
level: "warn",
|
|
1570
|
+
pluginId: record.id,
|
|
1571
|
+
source: record.source,
|
|
1572
|
+
message: "http route registration missing path"
|
|
1573
|
+
});
|
|
1574
|
+
return;
|
|
1575
|
+
}
|
|
1576
|
+
if (registry.httpRoutes.some((entry) => entry.path === normalizedPath)) {
|
|
1577
|
+
pushDiagnostic({
|
|
1578
|
+
level: "error",
|
|
1579
|
+
pluginId: record.id,
|
|
1580
|
+
source: record.source,
|
|
1581
|
+
message: `http route already registered: ${normalizedPath}`
|
|
1582
|
+
});
|
|
1583
|
+
return;
|
|
1584
|
+
}
|
|
1585
|
+
record.httpHandlers += 1;
|
|
1586
|
+
registry.httpRoutes.push({
|
|
1587
|
+
pluginId: record.id,
|
|
1588
|
+
path: normalizedPath,
|
|
1589
|
+
handler: params.handler,
|
|
1590
|
+
source: record.source
|
|
1591
|
+
});
|
|
1592
|
+
};
|
|
1593
|
+
const registerChannel = (record, registration) => {
|
|
1594
|
+
const normalized = typeof registration.plugin === "object" ? registration : { plugin: registration };
|
|
1595
|
+
const plugin = normalized.plugin;
|
|
1596
|
+
const id = typeof plugin?.id === "string" ? plugin.id.trim() : String(plugin?.id ?? "").trim();
|
|
1597
|
+
if (!id) {
|
|
1598
|
+
pushDiagnostic({
|
|
1599
|
+
level: "error",
|
|
1600
|
+
pluginId: record.id,
|
|
1601
|
+
source: record.source,
|
|
1602
|
+
message: "channel registration missing id"
|
|
1603
|
+
});
|
|
1604
|
+
return;
|
|
1605
|
+
}
|
|
1606
|
+
record.channelIds.push(id);
|
|
1607
|
+
registry.channels.push({
|
|
1608
|
+
pluginId: record.id,
|
|
1609
|
+
plugin,
|
|
1610
|
+
dock: normalized.dock,
|
|
1611
|
+
source: record.source
|
|
1612
|
+
});
|
|
1613
|
+
};
|
|
1614
|
+
const registerCli = (record, registrar, opts) => {
|
|
1615
|
+
const commands = (opts?.commands ?? []).map((cmd) => cmd.trim()).filter(Boolean);
|
|
1616
|
+
record.cliCommands.push(...commands);
|
|
1617
|
+
registry.cliRegistrars.push({
|
|
1618
|
+
pluginId: record.id,
|
|
1619
|
+
register: registrar,
|
|
1620
|
+
commands,
|
|
1621
|
+
source: record.source
|
|
1622
|
+
});
|
|
1623
|
+
};
|
|
1624
|
+
const registerService = (record, service) => {
|
|
1625
|
+
const id = service.id.trim();
|
|
1626
|
+
if (!id) return;
|
|
1627
|
+
record.services.push(id);
|
|
1628
|
+
registry.services.push({
|
|
1629
|
+
pluginId: record.id,
|
|
1630
|
+
service,
|
|
1631
|
+
source: record.source
|
|
1632
|
+
});
|
|
1633
|
+
};
|
|
1634
|
+
const registerCommand = (record, command) => {
|
|
1635
|
+
const name = command.name.trim();
|
|
1636
|
+
if (!name) {
|
|
1637
|
+
pushDiagnostic({
|
|
1638
|
+
level: "error",
|
|
1639
|
+
pluginId: record.id,
|
|
1640
|
+
source: record.source,
|
|
1641
|
+
message: "command registration missing name"
|
|
1642
|
+
});
|
|
1643
|
+
return;
|
|
1644
|
+
}
|
|
1645
|
+
const result = registerPluginCommand(record.id, command);
|
|
1646
|
+
if (!result.ok) {
|
|
1647
|
+
pushDiagnostic({
|
|
1648
|
+
level: "error",
|
|
1649
|
+
pluginId: record.id,
|
|
1650
|
+
source: record.source,
|
|
1651
|
+
message: `command registration failed: ${result.error}`
|
|
1652
|
+
});
|
|
1653
|
+
return;
|
|
1654
|
+
}
|
|
1655
|
+
record.commands.push(name);
|
|
1656
|
+
registry.commands.push({
|
|
1657
|
+
pluginId: record.id,
|
|
1658
|
+
command,
|
|
1659
|
+
source: record.source
|
|
1660
|
+
});
|
|
1661
|
+
};
|
|
1662
|
+
const registerTypedHook = (record, hookName, handler, opts) => {
|
|
1663
|
+
record.hookCount += 1;
|
|
1664
|
+
registry.typedHooks.push({
|
|
1665
|
+
pluginId: record.id,
|
|
1666
|
+
hookName,
|
|
1667
|
+
handler,
|
|
1668
|
+
priority: opts?.priority,
|
|
1669
|
+
source: record.source
|
|
1670
|
+
});
|
|
1671
|
+
};
|
|
1672
|
+
const normalizeLogger = (logger) => ({
|
|
1673
|
+
info: logger.info,
|
|
1674
|
+
warn: logger.warn,
|
|
1675
|
+
error: logger.error,
|
|
1676
|
+
debug: logger.debug
|
|
1677
|
+
});
|
|
1678
|
+
const createApi = (record, params) => {
|
|
1679
|
+
return {
|
|
1680
|
+
id: record.id,
|
|
1681
|
+
name: record.name,
|
|
1682
|
+
version: record.version,
|
|
1683
|
+
description: record.description,
|
|
1684
|
+
source: record.source,
|
|
1685
|
+
config: params.config,
|
|
1686
|
+
pluginConfig: params.pluginConfig,
|
|
1687
|
+
runtime: registryParams.runtime,
|
|
1688
|
+
logger: normalizeLogger(registryParams.logger),
|
|
1689
|
+
registerTool: (tool, opts) => registerTool(record, tool, opts),
|
|
1690
|
+
registerHook: (events, handler, opts) => registerHook(record, events, handler, opts, params.config),
|
|
1691
|
+
registerHttpHandler: (handler) => registerHttpHandler(record, handler),
|
|
1692
|
+
registerHttpRoute: (params) => registerHttpRoute(record, params),
|
|
1693
|
+
registerChannel: (registration) => registerChannel(record, registration),
|
|
1694
|
+
registerGatewayMethod: (method, handler) => registerGatewayMethod(record, method, handler),
|
|
1695
|
+
registerCli: (registrar, opts) => registerCli(record, registrar, opts),
|
|
1696
|
+
registerService: (service) => registerService(record, service),
|
|
1697
|
+
registerCommand: (command) => registerCommand(record, command),
|
|
1698
|
+
resolvePath: (input) => resolveUserPath(input),
|
|
1699
|
+
on: (hookName, handler, opts) => {
|
|
1700
|
+
if (DEAD_HOOKS.has(hookName)) {
|
|
1701
|
+
pushDiagnostic({
|
|
1702
|
+
level: "warn",
|
|
1703
|
+
pluginId: record.id,
|
|
1704
|
+
source: record.source,
|
|
1705
|
+
message: `Hook "${hookName}" is not available in CLI-only mode. LLM pipeline hooks are managed by the CLI agent runtime. This hook will not fire.`
|
|
1706
|
+
});
|
|
1707
|
+
return;
|
|
1708
|
+
}
|
|
1709
|
+
registerTypedHook(record, hookName, handler, opts);
|
|
1710
|
+
}
|
|
1711
|
+
};
|
|
1712
|
+
};
|
|
1713
|
+
return {
|
|
1714
|
+
registry,
|
|
1715
|
+
createApi,
|
|
1716
|
+
pushDiagnostic,
|
|
1717
|
+
registerTool,
|
|
1718
|
+
registerChannel,
|
|
1719
|
+
registerGatewayMethod,
|
|
1720
|
+
registerCli,
|
|
1721
|
+
registerService,
|
|
1722
|
+
registerCommand,
|
|
1723
|
+
registerHook,
|
|
1724
|
+
registerTypedHook
|
|
1725
|
+
};
|
|
1726
|
+
}
|
|
1727
|
+
|
|
1728
|
+
//#endregion
|
|
1729
|
+
//#region src/plugins/runtime.ts
|
|
1730
|
+
const REGISTRY_STATE = Symbol.for("remoteclaw.pluginRegistryState");
|
|
1731
|
+
const state = (() => {
|
|
1732
|
+
const globalState = globalThis;
|
|
1733
|
+
if (!globalState[REGISTRY_STATE]) globalState[REGISTRY_STATE] = {
|
|
1734
|
+
registry: createEmptyPluginRegistry(),
|
|
1735
|
+
key: null
|
|
1736
|
+
};
|
|
1737
|
+
return globalState[REGISTRY_STATE];
|
|
1738
|
+
})();
|
|
1739
|
+
function setActivePluginRegistry(registry, cacheKey) {
|
|
1740
|
+
state.registry = registry;
|
|
1741
|
+
state.key = cacheKey ?? null;
|
|
1742
|
+
}
|
|
1743
|
+
function getActivePluginRegistry() {
|
|
1744
|
+
return state.registry;
|
|
1745
|
+
}
|
|
1746
|
+
function requireActivePluginRegistry() {
|
|
1747
|
+
if (!state.registry) state.registry = createEmptyPluginRegistry();
|
|
1748
|
+
return state.registry;
|
|
1749
|
+
}
|
|
1750
|
+
|
|
1751
|
+
//#endregion
|
|
1752
|
+
//#region src/channels/registry.ts
|
|
1753
|
+
const CHAT_CHANNEL_ORDER = [
|
|
1754
|
+
"telegram",
|
|
1755
|
+
"whatsapp",
|
|
1756
|
+
"discord",
|
|
1757
|
+
"irc",
|
|
1758
|
+
"googlechat",
|
|
1759
|
+
"slack",
|
|
1760
|
+
"signal",
|
|
1761
|
+
"imessage"
|
|
1762
|
+
];
|
|
1763
|
+
const CHANNEL_IDS = [...CHAT_CHANNEL_ORDER];
|
|
1764
|
+
const CHAT_CHANNEL_META = {
|
|
1765
|
+
telegram: {
|
|
1766
|
+
id: "telegram",
|
|
1767
|
+
label: "Telegram",
|
|
1768
|
+
selectionLabel: "Telegram (Bot API)",
|
|
1769
|
+
detailLabel: "Telegram Bot",
|
|
1770
|
+
docsPath: "/channels/telegram",
|
|
1771
|
+
docsLabel: "telegram",
|
|
1772
|
+
blurb: "simplest way to get started — register a bot with @BotFather and get going.",
|
|
1773
|
+
systemImage: "paperplane",
|
|
1774
|
+
selectionDocsPrefix: "",
|
|
1775
|
+
selectionDocsOmitLabel: true,
|
|
1776
|
+
selectionExtras: ["https://remoteclaw.org"]
|
|
1777
|
+
},
|
|
1778
|
+
whatsapp: {
|
|
1779
|
+
id: "whatsapp",
|
|
1780
|
+
label: "WhatsApp",
|
|
1781
|
+
selectionLabel: "WhatsApp (QR link)",
|
|
1782
|
+
detailLabel: "WhatsApp Web",
|
|
1783
|
+
docsPath: "/channels/whatsapp",
|
|
1784
|
+
docsLabel: "whatsapp",
|
|
1785
|
+
blurb: "works with your own number; recommend a separate phone + eSIM.",
|
|
1786
|
+
systemImage: "message"
|
|
1787
|
+
},
|
|
1788
|
+
discord: {
|
|
1789
|
+
id: "discord",
|
|
1790
|
+
label: "Discord",
|
|
1791
|
+
selectionLabel: "Discord (Bot API)",
|
|
1792
|
+
detailLabel: "Discord Bot",
|
|
1793
|
+
docsPath: "/channels/discord",
|
|
1794
|
+
docsLabel: "discord",
|
|
1795
|
+
blurb: "very well supported right now.",
|
|
1796
|
+
systemImage: "bubble.left.and.bubble.right"
|
|
1797
|
+
},
|
|
1798
|
+
irc: {
|
|
1799
|
+
id: "irc",
|
|
1800
|
+
label: "IRC",
|
|
1801
|
+
selectionLabel: "IRC (Server + Nick)",
|
|
1802
|
+
detailLabel: "IRC",
|
|
1803
|
+
docsPath: "/channels/irc",
|
|
1804
|
+
docsLabel: "irc",
|
|
1805
|
+
blurb: "classic IRC networks with DM/channel routing and pairing controls.",
|
|
1806
|
+
systemImage: "network"
|
|
1807
|
+
},
|
|
1808
|
+
googlechat: {
|
|
1809
|
+
id: "googlechat",
|
|
1810
|
+
label: "Google Chat",
|
|
1811
|
+
selectionLabel: "Google Chat (Chat API)",
|
|
1812
|
+
detailLabel: "Google Chat",
|
|
1813
|
+
docsPath: "/channels/googlechat",
|
|
1814
|
+
docsLabel: "googlechat",
|
|
1815
|
+
blurb: "Google Workspace Chat app with HTTP webhook.",
|
|
1816
|
+
systemImage: "message.badge"
|
|
1817
|
+
},
|
|
1818
|
+
slack: {
|
|
1819
|
+
id: "slack",
|
|
1820
|
+
label: "Slack",
|
|
1821
|
+
selectionLabel: "Slack (Socket Mode)",
|
|
1822
|
+
detailLabel: "Slack Bot",
|
|
1823
|
+
docsPath: "/channels/slack",
|
|
1824
|
+
docsLabel: "slack",
|
|
1825
|
+
blurb: "supported (Socket Mode).",
|
|
1826
|
+
systemImage: "number"
|
|
1827
|
+
},
|
|
1828
|
+
signal: {
|
|
1829
|
+
id: "signal",
|
|
1830
|
+
label: "Signal",
|
|
1831
|
+
selectionLabel: "Signal (signal-cli)",
|
|
1832
|
+
detailLabel: "Signal REST",
|
|
1833
|
+
docsPath: "/channels/signal",
|
|
1834
|
+
docsLabel: "signal",
|
|
1835
|
+
blurb: "signal-cli linked device; more setup (David Reagans: \"Hop on Discord.\").",
|
|
1836
|
+
systemImage: "antenna.radiowaves.left.and.right"
|
|
1837
|
+
},
|
|
1838
|
+
imessage: {
|
|
1839
|
+
id: "imessage",
|
|
1840
|
+
label: "iMessage",
|
|
1841
|
+
selectionLabel: "iMessage (imsg)",
|
|
1842
|
+
detailLabel: "iMessage",
|
|
1843
|
+
docsPath: "/channels/imessage",
|
|
1844
|
+
docsLabel: "imessage",
|
|
1845
|
+
blurb: "this is still a work in progress.",
|
|
1846
|
+
systemImage: "message.fill"
|
|
1847
|
+
}
|
|
1848
|
+
};
|
|
1849
|
+
const CHAT_CHANNEL_ALIASES = {
|
|
1850
|
+
imsg: "imessage",
|
|
1851
|
+
"internet-relay-chat": "irc",
|
|
1852
|
+
"google-chat": "googlechat",
|
|
1853
|
+
gchat: "googlechat"
|
|
1854
|
+
};
|
|
1855
|
+
const normalizeChannelKey = (raw) => {
|
|
1856
|
+
return raw?.trim().toLowerCase() || void 0;
|
|
1857
|
+
};
|
|
1858
|
+
function listChatChannels() {
|
|
1859
|
+
return CHAT_CHANNEL_ORDER.map((id) => CHAT_CHANNEL_META[id]);
|
|
1860
|
+
}
|
|
1861
|
+
function getChatChannelMeta(id) {
|
|
1862
|
+
return CHAT_CHANNEL_META[id];
|
|
1863
|
+
}
|
|
1864
|
+
function normalizeChatChannelId(raw) {
|
|
1865
|
+
const normalized = normalizeChannelKey(raw);
|
|
1866
|
+
if (!normalized) return null;
|
|
1867
|
+
const resolved = CHAT_CHANNEL_ALIASES[normalized] ?? normalized;
|
|
1868
|
+
return CHAT_CHANNEL_ORDER.includes(resolved) ? resolved : null;
|
|
1869
|
+
}
|
|
1870
|
+
function normalizeChannelId(raw) {
|
|
1871
|
+
return normalizeChatChannelId(raw);
|
|
1872
|
+
}
|
|
1873
|
+
function normalizeAnyChannelId(raw) {
|
|
1874
|
+
const key = normalizeChannelKey(raw);
|
|
1875
|
+
if (!key) return null;
|
|
1876
|
+
return requireActivePluginRegistry().channels.find((entry) => {
|
|
1877
|
+
const id = String(entry.plugin.id ?? "").trim().toLowerCase();
|
|
1878
|
+
if (id && id === key) return true;
|
|
1879
|
+
return (entry.plugin.meta.aliases ?? []).some((alias) => alias.trim().toLowerCase() === key);
|
|
1880
|
+
})?.plugin.id ?? null;
|
|
1881
|
+
}
|
|
1882
|
+
function formatChannelPrimerLine(meta) {
|
|
1883
|
+
return `${meta.label}: ${meta.blurb}`;
|
|
1884
|
+
}
|
|
1885
|
+
function formatChannelSelectionLine(meta, docsLink) {
|
|
1886
|
+
const docsPrefix = meta.selectionDocsPrefix ?? "Docs:";
|
|
1887
|
+
const docsLabel = meta.docsLabel ?? meta.id;
|
|
1888
|
+
const docs = meta.selectionDocsOmitLabel ? docsLink(meta.docsPath) : docsLink(meta.docsPath, docsLabel);
|
|
1889
|
+
const extras = (meta.selectionExtras ?? []).filter(Boolean).join(" ");
|
|
1890
|
+
return `${meta.label} — ${meta.blurb} ${docsPrefix ? `${docsPrefix} ` : ""}${docs}${extras ? ` ${extras}` : ""}`;
|
|
1891
|
+
}
|
|
1892
|
+
|
|
1893
|
+
//#endregion
|
|
1894
|
+
//#region src/terminal/progress-line.ts
|
|
1895
|
+
let activeStream = null;
|
|
1896
|
+
function registerActiveProgressLine(stream) {
|
|
1897
|
+
if (!stream.isTTY) return;
|
|
1898
|
+
activeStream = stream;
|
|
1899
|
+
}
|
|
1900
|
+
function clearActiveProgressLine() {
|
|
1901
|
+
if (!activeStream?.isTTY) return;
|
|
1902
|
+
activeStream.write("\r\x1B[2K");
|
|
1903
|
+
}
|
|
1904
|
+
function unregisterActiveProgressLine(stream) {
|
|
1905
|
+
if (!activeStream) return;
|
|
1906
|
+
if (stream && activeStream !== stream) return;
|
|
1907
|
+
activeStream = null;
|
|
1908
|
+
}
|
|
1909
|
+
|
|
1910
|
+
//#endregion
|
|
1911
|
+
//#region src/terminal/restore.ts
|
|
1912
|
+
const RESET_SEQUENCE = "\x1B[0m\x1B[?25h\x1B[?1000l\x1B[?1002l\x1B[?1003l\x1B[?1006l\x1B[?2004l";
|
|
1913
|
+
function reportRestoreFailure(scope, err, reason) {
|
|
1914
|
+
const suffix = reason ? ` (${reason})` : "";
|
|
1915
|
+
const message = `[terminal] restore ${scope} failed${suffix}: ${String(err)}`;
|
|
1916
|
+
try {
|
|
1917
|
+
process.stderr.write(`${message}\n`);
|
|
1918
|
+
} catch (writeErr) {
|
|
1919
|
+
console.error(`[terminal] restore reporting failed${suffix}: ${String(writeErr)}`);
|
|
1920
|
+
}
|
|
1921
|
+
}
|
|
1922
|
+
function restoreTerminalState(reason, options = {}) {
|
|
1923
|
+
const resumeStdin = options.resumeStdinIfPaused ?? options.resumeStdin ?? false;
|
|
1924
|
+
try {
|
|
1925
|
+
clearActiveProgressLine();
|
|
1926
|
+
} catch (err) {
|
|
1927
|
+
reportRestoreFailure("progress line", err, reason);
|
|
1928
|
+
}
|
|
1929
|
+
const stdin = process.stdin;
|
|
1930
|
+
if (stdin.isTTY && typeof stdin.setRawMode === "function") {
|
|
1931
|
+
try {
|
|
1932
|
+
stdin.setRawMode(false);
|
|
1933
|
+
} catch (err) {
|
|
1934
|
+
reportRestoreFailure("raw mode", err, reason);
|
|
1935
|
+
}
|
|
1936
|
+
if (resumeStdin && typeof stdin.isPaused === "function" && stdin.isPaused()) try {
|
|
1937
|
+
stdin.resume();
|
|
1938
|
+
} catch (err) {
|
|
1939
|
+
reportRestoreFailure("stdin resume", err, reason);
|
|
1940
|
+
}
|
|
1941
|
+
}
|
|
1942
|
+
if (process.stdout.isTTY) try {
|
|
1943
|
+
process.stdout.write(RESET_SEQUENCE);
|
|
1944
|
+
} catch (err) {
|
|
1945
|
+
reportRestoreFailure("stdout reset", err, reason);
|
|
1946
|
+
}
|
|
1947
|
+
}
|
|
1948
|
+
|
|
1949
|
+
//#endregion
|
|
1950
|
+
//#region src/runtime.ts
|
|
1951
|
+
function shouldEmitRuntimeLog(env = process.env) {
|
|
1952
|
+
if (env.VITEST !== "true") return true;
|
|
1953
|
+
if (env.REMOTECLAW_TEST_RUNTIME_LOG === "1") return true;
|
|
1954
|
+
return typeof console.log.mock === "object";
|
|
1955
|
+
}
|
|
1956
|
+
function createRuntimeIo() {
|
|
1957
|
+
return {
|
|
1958
|
+
log: (...args) => {
|
|
1959
|
+
if (!shouldEmitRuntimeLog()) return;
|
|
1960
|
+
clearActiveProgressLine();
|
|
1961
|
+
console.log(...args);
|
|
1962
|
+
},
|
|
1963
|
+
error: (...args) => {
|
|
1964
|
+
clearActiveProgressLine();
|
|
1965
|
+
console.error(...args);
|
|
1966
|
+
}
|
|
1967
|
+
};
|
|
1968
|
+
}
|
|
1969
|
+
const defaultRuntime = {
|
|
1970
|
+
...createRuntimeIo(),
|
|
1971
|
+
exit: (code) => {
|
|
1972
|
+
restoreTerminalState("runtime exit", { resumeStdinIfPaused: false });
|
|
1973
|
+
process.exit(code);
|
|
1974
|
+
throw new Error("unreachable");
|
|
1975
|
+
}
|
|
1976
|
+
};
|
|
1977
|
+
function createNonExitingRuntime() {
|
|
1978
|
+
return {
|
|
1979
|
+
...createRuntimeIo(),
|
|
1980
|
+
exit: (code) => {
|
|
1981
|
+
throw new Error(`exit ${code}`);
|
|
1982
|
+
}
|
|
1983
|
+
};
|
|
1984
|
+
}
|
|
1985
|
+
|
|
1986
|
+
//#endregion
|
|
1987
|
+
//#region src/terminal/ansi.ts
|
|
1988
|
+
const ANSI_SGR_PATTERN = "\\x1b\\[[0-9;]*m";
|
|
1989
|
+
const OSC8_PATTERN = "\\x1b\\]8;;.*?\\x1b\\\\|\\x1b\\]8;;\\x1b\\\\";
|
|
1990
|
+
const ANSI_REGEX = new RegExp(ANSI_SGR_PATTERN, "g");
|
|
1991
|
+
const OSC8_REGEX = new RegExp(OSC8_PATTERN, "g");
|
|
1992
|
+
function stripAnsi(input) {
|
|
1993
|
+
return input.replace(OSC8_REGEX, "").replace(ANSI_REGEX, "");
|
|
1994
|
+
}
|
|
1995
|
+
function visibleWidth(input) {
|
|
1996
|
+
return Array.from(stripAnsi(input)).length;
|
|
1997
|
+
}
|
|
1998
|
+
|
|
1999
|
+
//#endregion
|
|
2000
|
+
//#region src/logging/timestamps.ts
|
|
2001
|
+
function formatLocalIsoWithOffset(now) {
|
|
2002
|
+
const year = now.getFullYear();
|
|
2003
|
+
const month = String(now.getMonth() + 1).padStart(2, "0");
|
|
2004
|
+
const day = String(now.getDate()).padStart(2, "0");
|
|
2005
|
+
const h = String(now.getHours()).padStart(2, "0");
|
|
2006
|
+
const m = String(now.getMinutes()).padStart(2, "0");
|
|
2007
|
+
const s = String(now.getSeconds()).padStart(2, "0");
|
|
2008
|
+
const ms = String(now.getMilliseconds()).padStart(3, "0");
|
|
2009
|
+
const tzOffset = now.getTimezoneOffset();
|
|
2010
|
+
return `${year}-${month}-${day}T${h}:${m}:${s}.${ms}${tzOffset <= 0 ? "+" : "-"}${String(Math.floor(Math.abs(tzOffset) / 60)).padStart(2, "0")}:${String(Math.abs(tzOffset) % 60).padStart(2, "0")}`;
|
|
2011
|
+
}
|
|
2012
|
+
|
|
2013
|
+
//#endregion
|
|
2014
|
+
//#region src/logging/console.ts
|
|
2015
|
+
const requireConfig = resolveNodeRequireFromMeta(import.meta.url);
|
|
2016
|
+
const loadConfigFallbackDefault = () => {
|
|
2017
|
+
try {
|
|
2018
|
+
return (requireConfig?.("../config/config.js"))?.loadConfig?.().logging;
|
|
2019
|
+
} catch {
|
|
2020
|
+
return;
|
|
2021
|
+
}
|
|
2022
|
+
};
|
|
2023
|
+
let loadConfigFallback = loadConfigFallbackDefault;
|
|
2024
|
+
function normalizeConsoleLevel(level) {
|
|
2025
|
+
if (isVerbose()) return "debug";
|
|
2026
|
+
if (!level && process.env.VITEST === "true" && process.env.REMOTECLAW_TEST_CONSOLE !== "1") return "silent";
|
|
2027
|
+
return normalizeLogLevel(level, "info");
|
|
2028
|
+
}
|
|
2029
|
+
function normalizeConsoleStyle(style) {
|
|
2030
|
+
if (style === "compact" || style === "json" || style === "pretty") return style;
|
|
2031
|
+
if (!process.stdout.isTTY) return "compact";
|
|
2032
|
+
return "pretty";
|
|
2033
|
+
}
|
|
2034
|
+
function resolveConsoleSettings() {
|
|
2035
|
+
let cfg = loggingState.overrideSettings ?? readLoggingConfig();
|
|
2036
|
+
if (!cfg) if (loggingState.resolvingConsoleSettings) cfg = void 0;
|
|
2037
|
+
else {
|
|
2038
|
+
loggingState.resolvingConsoleSettings = true;
|
|
2039
|
+
try {
|
|
2040
|
+
cfg = loadConfigFallback();
|
|
2041
|
+
} finally {
|
|
2042
|
+
loggingState.resolvingConsoleSettings = false;
|
|
2043
|
+
}
|
|
2044
|
+
}
|
|
2045
|
+
return {
|
|
2046
|
+
level: resolveEnvLogLevelOverride() ?? normalizeConsoleLevel(cfg?.consoleLevel),
|
|
2047
|
+
style: normalizeConsoleStyle(cfg?.consoleStyle)
|
|
2048
|
+
};
|
|
2049
|
+
}
|
|
2050
|
+
function consoleSettingsChanged(a, b) {
|
|
2051
|
+
if (!a) return true;
|
|
2052
|
+
return a.level !== b.level || a.style !== b.style;
|
|
2053
|
+
}
|
|
2054
|
+
function getConsoleSettings() {
|
|
2055
|
+
const settings = resolveConsoleSettings();
|
|
2056
|
+
const cached = loggingState.cachedConsoleSettings;
|
|
2057
|
+
if (!cached || consoleSettingsChanged(cached, settings)) loggingState.cachedConsoleSettings = settings;
|
|
2058
|
+
return loggingState.cachedConsoleSettings;
|
|
2059
|
+
}
|
|
2060
|
+
function routeLogsToStderr() {
|
|
2061
|
+
loggingState.forceConsoleToStderr = true;
|
|
2062
|
+
}
|
|
2063
|
+
function setConsoleSubsystemFilter(filters) {
|
|
2064
|
+
if (!filters || filters.length === 0) {
|
|
2065
|
+
loggingState.consoleSubsystemFilter = null;
|
|
2066
|
+
return;
|
|
2067
|
+
}
|
|
2068
|
+
const normalized = filters.map((value) => value.trim()).filter((value) => value.length > 0);
|
|
2069
|
+
loggingState.consoleSubsystemFilter = normalized.length > 0 ? normalized : null;
|
|
2070
|
+
}
|
|
2071
|
+
function setConsoleTimestampPrefix(enabled) {
|
|
2072
|
+
loggingState.consoleTimestampPrefix = enabled;
|
|
2073
|
+
}
|
|
2074
|
+
function shouldLogSubsystemToConsole(subsystem) {
|
|
2075
|
+
const filter = loggingState.consoleSubsystemFilter;
|
|
2076
|
+
if (!filter || filter.length === 0) return true;
|
|
2077
|
+
return filter.some((prefix) => subsystem === prefix || subsystem.startsWith(`${prefix}/`));
|
|
2078
|
+
}
|
|
2079
|
+
const SUPPRESSED_CONSOLE_PREFIXES = [
|
|
2080
|
+
"Closing session:",
|
|
2081
|
+
"Opening session:",
|
|
2082
|
+
"Removing old closed session:",
|
|
2083
|
+
"Session already closed",
|
|
2084
|
+
"Session already open"
|
|
2085
|
+
];
|
|
2086
|
+
function shouldSuppressConsoleMessage(message) {
|
|
2087
|
+
if (isVerbose()) return false;
|
|
2088
|
+
if (SUPPRESSED_CONSOLE_PREFIXES.some((prefix) => message.startsWith(prefix))) return true;
|
|
2089
|
+
if (message.startsWith("[EventQueue] Slow listener detected") && message.includes("DiscordMessageListener")) return true;
|
|
2090
|
+
return false;
|
|
2091
|
+
}
|
|
2092
|
+
function isEpipeError(err) {
|
|
2093
|
+
const code = err?.code;
|
|
2094
|
+
return code === "EPIPE" || code === "EIO";
|
|
2095
|
+
}
|
|
2096
|
+
function formatConsoleTimestamp(style) {
|
|
2097
|
+
const now = /* @__PURE__ */ new Date();
|
|
2098
|
+
if (style === "pretty") return `${String(now.getHours()).padStart(2, "0")}:${String(now.getMinutes()).padStart(2, "0")}:${String(now.getSeconds()).padStart(2, "0")}`;
|
|
2099
|
+
return formatLocalIsoWithOffset(now);
|
|
2100
|
+
}
|
|
2101
|
+
function hasTimestampPrefix(value) {
|
|
2102
|
+
return /^(?:\d{2}:\d{2}:\d{2}|\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:\.\d+)?(?:Z|[+-]\d{2}:\d{2})?)/.test(value);
|
|
2103
|
+
}
|
|
2104
|
+
function isJsonPayload(value) {
|
|
2105
|
+
const trimmed = value.trim();
|
|
2106
|
+
if (!trimmed.startsWith("{") && !trimmed.startsWith("[")) return false;
|
|
2107
|
+
try {
|
|
2108
|
+
JSON.parse(trimmed);
|
|
2109
|
+
return true;
|
|
2110
|
+
} catch {
|
|
2111
|
+
return false;
|
|
2112
|
+
}
|
|
2113
|
+
}
|
|
2114
|
+
/**
|
|
2115
|
+
* Route console.* calls through file logging while still emitting to stdout/stderr.
|
|
2116
|
+
* This keeps user-facing output unchanged but guarantees every console call is captured in log files.
|
|
2117
|
+
*/
|
|
2118
|
+
function enableConsoleCapture() {
|
|
2119
|
+
if (loggingState.consolePatched) return;
|
|
2120
|
+
loggingState.consolePatched = true;
|
|
2121
|
+
if (!loggingState.streamErrorHandlersInstalled) {
|
|
2122
|
+
loggingState.streamErrorHandlersInstalled = true;
|
|
2123
|
+
for (const stream of [process.stdout, process.stderr]) stream.on("error", (err) => {
|
|
2124
|
+
if (isEpipeError(err)) return;
|
|
2125
|
+
throw err;
|
|
2126
|
+
});
|
|
2127
|
+
}
|
|
2128
|
+
let logger = null;
|
|
2129
|
+
const getLoggerLazy = () => {
|
|
2130
|
+
if (!logger) logger = getLogger();
|
|
2131
|
+
return logger;
|
|
2132
|
+
};
|
|
2133
|
+
const original = {
|
|
2134
|
+
log: console.log,
|
|
2135
|
+
info: console.info,
|
|
2136
|
+
warn: console.warn,
|
|
2137
|
+
error: console.error,
|
|
2138
|
+
debug: console.debug,
|
|
2139
|
+
trace: console.trace
|
|
2140
|
+
};
|
|
2141
|
+
loggingState.rawConsole = {
|
|
2142
|
+
log: original.log,
|
|
2143
|
+
info: original.info,
|
|
2144
|
+
warn: original.warn,
|
|
2145
|
+
error: original.error
|
|
2146
|
+
};
|
|
2147
|
+
const forward = (level, orig) => (...args) => {
|
|
2148
|
+
const formatted = util.format(...args);
|
|
2149
|
+
if (shouldSuppressConsoleMessage(formatted)) return;
|
|
2150
|
+
const trimmed = stripAnsi(formatted).trimStart();
|
|
2151
|
+
const timestamp = loggingState.consoleTimestampPrefix && trimmed.length > 0 && !hasTimestampPrefix(trimmed) && !isJsonPayload(trimmed) ? formatConsoleTimestamp(getConsoleSettings().style) : "";
|
|
2152
|
+
try {
|
|
2153
|
+
const resolvedLogger = getLoggerLazy();
|
|
2154
|
+
if (level === "trace") resolvedLogger.trace(formatted);
|
|
2155
|
+
else if (level === "debug") resolvedLogger.debug(formatted);
|
|
2156
|
+
else if (level === "info") resolvedLogger.info(formatted);
|
|
2157
|
+
else if (level === "warn") resolvedLogger.warn(formatted);
|
|
2158
|
+
else if (level === "error" || level === "fatal") resolvedLogger.error(formatted);
|
|
2159
|
+
else resolvedLogger.info(formatted);
|
|
2160
|
+
} catch {}
|
|
2161
|
+
if (loggingState.forceConsoleToStderr) try {
|
|
2162
|
+
const line = timestamp ? `${timestamp} ${formatted}` : formatted;
|
|
2163
|
+
process.stderr.write(`${line}\n`);
|
|
2164
|
+
} catch (err) {
|
|
2165
|
+
if (isEpipeError(err)) return;
|
|
2166
|
+
throw err;
|
|
2167
|
+
}
|
|
2168
|
+
else try {
|
|
2169
|
+
if (!timestamp) {
|
|
2170
|
+
orig.apply(console, args);
|
|
2171
|
+
return;
|
|
2172
|
+
}
|
|
2173
|
+
if (args.length === 0) {
|
|
2174
|
+
orig.call(console, timestamp);
|
|
2175
|
+
return;
|
|
2176
|
+
}
|
|
2177
|
+
if (typeof args[0] === "string") {
|
|
2178
|
+
orig.call(console, `${timestamp} ${args[0]}`, ...args.slice(1));
|
|
2179
|
+
return;
|
|
2180
|
+
}
|
|
2181
|
+
orig.call(console, timestamp, ...args);
|
|
2182
|
+
} catch (err) {
|
|
2183
|
+
if (isEpipeError(err)) return;
|
|
2184
|
+
throw err;
|
|
2185
|
+
}
|
|
2186
|
+
};
|
|
2187
|
+
console.log = forward("info", original.log);
|
|
2188
|
+
console.info = forward("info", original.info);
|
|
2189
|
+
console.warn = forward("warn", original.warn);
|
|
2190
|
+
console.error = forward("error", original.error);
|
|
2191
|
+
console.debug = forward("debug", original.debug);
|
|
2192
|
+
console.trace = forward("trace", original.trace);
|
|
2193
|
+
}
|
|
2194
|
+
|
|
2195
|
+
//#endregion
|
|
2196
|
+
//#region src/logging/subsystem.ts
|
|
2197
|
+
function shouldLogToConsole(level, settings) {
|
|
2198
|
+
if (settings.level === "silent") return false;
|
|
2199
|
+
return levelToMinLevel(level) <= levelToMinLevel(settings.level);
|
|
2200
|
+
}
|
|
2201
|
+
const inspectValue = (() => {
|
|
2202
|
+
const getBuiltinModule = process.getBuiltinModule;
|
|
2203
|
+
if (typeof getBuiltinModule !== "function") return null;
|
|
2204
|
+
try {
|
|
2205
|
+
const utilNamespace = getBuiltinModule("util");
|
|
2206
|
+
return typeof utilNamespace.inspect === "function" ? utilNamespace.inspect : null;
|
|
2207
|
+
} catch {
|
|
2208
|
+
return null;
|
|
2209
|
+
}
|
|
2210
|
+
})();
|
|
2211
|
+
function formatRuntimeArg(arg) {
|
|
2212
|
+
if (typeof arg === "string") return arg;
|
|
2213
|
+
if (inspectValue) return inspectValue(arg);
|
|
2214
|
+
try {
|
|
2215
|
+
return JSON.stringify(arg);
|
|
2216
|
+
} catch {
|
|
2217
|
+
return String(arg);
|
|
2218
|
+
}
|
|
2219
|
+
}
|
|
2220
|
+
function isRichConsoleEnv() {
|
|
2221
|
+
const term = (process.env.TERM ?? "").toLowerCase();
|
|
2222
|
+
if (process.env.COLORTERM || process.env.TERM_PROGRAM) return true;
|
|
2223
|
+
return term.length > 0 && term !== "dumb";
|
|
2224
|
+
}
|
|
2225
|
+
function getColorForConsole() {
|
|
2226
|
+
const hasForceColor = typeof process.env.FORCE_COLOR === "string" && process.env.FORCE_COLOR.trim().length > 0 && process.env.FORCE_COLOR.trim() !== "0";
|
|
2227
|
+
if (process.env.NO_COLOR && !hasForceColor) return new Chalk({ level: 0 });
|
|
2228
|
+
return Boolean(process.stdout.isTTY || process.stderr.isTTY) || isRichConsoleEnv() ? new Chalk({ level: 1 }) : new Chalk({ level: 0 });
|
|
2229
|
+
}
|
|
2230
|
+
const SUBSYSTEM_COLORS = [
|
|
2231
|
+
"cyan",
|
|
2232
|
+
"green",
|
|
2233
|
+
"yellow",
|
|
2234
|
+
"blue",
|
|
2235
|
+
"magenta",
|
|
2236
|
+
"red"
|
|
2237
|
+
];
|
|
2238
|
+
const SUBSYSTEM_COLOR_OVERRIDES = { "gmail-watcher": "blue" };
|
|
2239
|
+
const SUBSYSTEM_PREFIXES_TO_DROP = [
|
|
2240
|
+
"gateway",
|
|
2241
|
+
"channels",
|
|
2242
|
+
"providers"
|
|
2243
|
+
];
|
|
2244
|
+
const SUBSYSTEM_MAX_SEGMENTS = 2;
|
|
2245
|
+
const CHANNEL_SUBSYSTEM_PREFIXES = new Set(CHAT_CHANNEL_ORDER);
|
|
2246
|
+
function pickSubsystemColor(color, subsystem) {
|
|
2247
|
+
const override = SUBSYSTEM_COLOR_OVERRIDES[subsystem];
|
|
2248
|
+
if (override) return color[override];
|
|
2249
|
+
let hash = 0;
|
|
2250
|
+
for (let i = 0; i < subsystem.length; i += 1) hash = hash * 31 + subsystem.charCodeAt(i) | 0;
|
|
2251
|
+
return color[SUBSYSTEM_COLORS[Math.abs(hash) % SUBSYSTEM_COLORS.length]];
|
|
2252
|
+
}
|
|
2253
|
+
function formatSubsystemForConsole(subsystem) {
|
|
2254
|
+
const parts = subsystem.split("/").filter(Boolean);
|
|
2255
|
+
const original = parts.join("/") || subsystem;
|
|
2256
|
+
while (parts.length > 0 && SUBSYSTEM_PREFIXES_TO_DROP.includes(parts[0])) parts.shift();
|
|
2257
|
+
if (parts.length === 0) return original;
|
|
2258
|
+
if (CHANNEL_SUBSYSTEM_PREFIXES.has(parts[0])) return parts[0];
|
|
2259
|
+
if (parts.length > SUBSYSTEM_MAX_SEGMENTS) return parts.slice(-SUBSYSTEM_MAX_SEGMENTS).join("/");
|
|
2260
|
+
return parts.join("/");
|
|
2261
|
+
}
|
|
2262
|
+
function stripRedundantSubsystemPrefixForConsole(message, displaySubsystem) {
|
|
2263
|
+
if (!displaySubsystem) return message;
|
|
2264
|
+
if (message.startsWith("[")) {
|
|
2265
|
+
const closeIdx = message.indexOf("]");
|
|
2266
|
+
if (closeIdx > 1) {
|
|
2267
|
+
if (message.slice(1, closeIdx).toLowerCase() === displaySubsystem.toLowerCase()) {
|
|
2268
|
+
let i = closeIdx + 1;
|
|
2269
|
+
while (message[i] === " ") i += 1;
|
|
2270
|
+
return message.slice(i);
|
|
2271
|
+
}
|
|
2272
|
+
}
|
|
2273
|
+
}
|
|
2274
|
+
if (message.slice(0, displaySubsystem.length).toLowerCase() !== displaySubsystem.toLowerCase()) return message;
|
|
2275
|
+
const next = message.slice(displaySubsystem.length, displaySubsystem.length + 1);
|
|
2276
|
+
if (next !== ":" && next !== " ") return message;
|
|
2277
|
+
let i = displaySubsystem.length;
|
|
2278
|
+
while (message[i] === " ") i += 1;
|
|
2279
|
+
if (message[i] === ":") i += 1;
|
|
2280
|
+
while (message[i] === " ") i += 1;
|
|
2281
|
+
return message.slice(i);
|
|
2282
|
+
}
|
|
2283
|
+
function formatConsoleLine(opts) {
|
|
2284
|
+
const displaySubsystem = opts.style === "json" ? opts.subsystem : formatSubsystemForConsole(opts.subsystem);
|
|
2285
|
+
if (opts.style === "json") return JSON.stringify({
|
|
2286
|
+
time: (/* @__PURE__ */ new Date()).toISOString(),
|
|
2287
|
+
level: opts.level,
|
|
2288
|
+
subsystem: displaySubsystem,
|
|
2289
|
+
message: opts.message,
|
|
2290
|
+
...opts.meta
|
|
2291
|
+
});
|
|
2292
|
+
const color = getColorForConsole();
|
|
2293
|
+
const prefix = `[${displaySubsystem}]`;
|
|
2294
|
+
const prefixColor = pickSubsystemColor(color, displaySubsystem);
|
|
2295
|
+
const levelColor = opts.level === "error" || opts.level === "fatal" ? color.red : opts.level === "warn" ? color.yellow : opts.level === "debug" || opts.level === "trace" ? color.gray : color.cyan;
|
|
2296
|
+
const displayMessage = stripRedundantSubsystemPrefixForConsole(opts.message, displaySubsystem);
|
|
2297
|
+
return `${[(() => {
|
|
2298
|
+
if (opts.style === "pretty") return color.gray((/* @__PURE__ */ new Date()).toISOString().slice(11, 19));
|
|
2299
|
+
if (loggingState.consoleTimestampPrefix) return color.gray((/* @__PURE__ */ new Date()).toISOString());
|
|
2300
|
+
return "";
|
|
2301
|
+
})(), prefixColor(prefix)].filter(Boolean).join(" ")} ${levelColor(displayMessage)}`;
|
|
2302
|
+
}
|
|
2303
|
+
function writeConsoleLine(level, line) {
|
|
2304
|
+
clearActiveProgressLine();
|
|
2305
|
+
const sanitized = process.platform === "win32" && process.env.GITHUB_ACTIONS === "true" ? line.replace(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g, "?").replace(/[\uD800-\uDFFF]/g, "?") : line;
|
|
2306
|
+
const sink = loggingState.rawConsole ?? console;
|
|
2307
|
+
if (loggingState.forceConsoleToStderr || level === "error" || level === "fatal") (sink.error ?? console.error)(sanitized);
|
|
2308
|
+
else if (level === "warn") (sink.warn ?? console.warn)(sanitized);
|
|
2309
|
+
else (sink.log ?? console.log)(sanitized);
|
|
2310
|
+
}
|
|
2311
|
+
function logToFile(fileLogger, level, message, meta) {
|
|
2312
|
+
if (level === "silent") return;
|
|
2313
|
+
const method = fileLogger[level];
|
|
2314
|
+
if (typeof method !== "function") return;
|
|
2315
|
+
if (meta && Object.keys(meta).length > 0) method.call(fileLogger, meta, message);
|
|
2316
|
+
else method.call(fileLogger, message);
|
|
2317
|
+
}
|
|
2318
|
+
function createSubsystemLogger(subsystem) {
|
|
2319
|
+
let fileLogger = null;
|
|
2320
|
+
const getFileLogger = () => {
|
|
2321
|
+
if (!fileLogger) fileLogger = getChildLogger({ subsystem });
|
|
2322
|
+
return fileLogger;
|
|
2323
|
+
};
|
|
2324
|
+
const emit = (level, message, meta) => {
|
|
2325
|
+
const consoleSettings = getConsoleSettings();
|
|
2326
|
+
let consoleMessageOverride;
|
|
2327
|
+
let fileMeta = meta;
|
|
2328
|
+
if (meta && Object.keys(meta).length > 0) {
|
|
2329
|
+
const { consoleMessage, ...rest } = meta;
|
|
2330
|
+
if (typeof consoleMessage === "string") consoleMessageOverride = consoleMessage;
|
|
2331
|
+
fileMeta = Object.keys(rest).length > 0 ? rest : void 0;
|
|
2332
|
+
}
|
|
2333
|
+
logToFile(getFileLogger(), level, message, fileMeta);
|
|
2334
|
+
if (!shouldLogToConsole(level, { level: consoleSettings.level })) return;
|
|
2335
|
+
if (!shouldLogSubsystemToConsole(subsystem)) return;
|
|
2336
|
+
const consoleMessage = consoleMessageOverride ?? message;
|
|
2337
|
+
if (!isVerbose() && subsystem === "agent/embedded" && /(sessionId|runId)=probe-/.test(consoleMessage)) return;
|
|
2338
|
+
writeConsoleLine(level, formatConsoleLine({
|
|
2339
|
+
level,
|
|
2340
|
+
subsystem,
|
|
2341
|
+
message: consoleSettings.style === "json" ? message : consoleMessage,
|
|
2342
|
+
style: consoleSettings.style,
|
|
2343
|
+
meta: fileMeta
|
|
2344
|
+
}));
|
|
2345
|
+
};
|
|
2346
|
+
const isConsoleEnabled = (level) => {
|
|
2347
|
+
return shouldLogToConsole(level, { level: getConsoleSettings().level }) && shouldLogSubsystemToConsole(subsystem);
|
|
2348
|
+
};
|
|
2349
|
+
const isFileEnabled = (level) => isFileLogLevelEnabled(level);
|
|
2350
|
+
return {
|
|
2351
|
+
subsystem,
|
|
2352
|
+
isEnabled: (level, target = "any") => {
|
|
2353
|
+
if (target === "console") return isConsoleEnabled(level);
|
|
2354
|
+
if (target === "file") return isFileEnabled(level);
|
|
2355
|
+
return isConsoleEnabled(level) || isFileEnabled(level);
|
|
2356
|
+
},
|
|
2357
|
+
trace: (message, meta) => emit("trace", message, meta),
|
|
2358
|
+
debug: (message, meta) => emit("debug", message, meta),
|
|
2359
|
+
info: (message, meta) => emit("info", message, meta),
|
|
2360
|
+
warn: (message, meta) => emit("warn", message, meta),
|
|
2361
|
+
error: (message, meta) => emit("error", message, meta),
|
|
2362
|
+
fatal: (message, meta) => emit("fatal", message, meta),
|
|
2363
|
+
raw: (message) => {
|
|
2364
|
+
logToFile(getFileLogger(), "info", message, { raw: true });
|
|
2365
|
+
if (shouldLogSubsystemToConsole(subsystem)) {
|
|
2366
|
+
if (!isVerbose() && subsystem === "agent/embedded" && /(sessionId|runId)=probe-/.test(message)) return;
|
|
2367
|
+
writeConsoleLine("info", message);
|
|
2368
|
+
}
|
|
2369
|
+
},
|
|
2370
|
+
child: (name) => createSubsystemLogger(`${subsystem}/${name}`)
|
|
2371
|
+
};
|
|
2372
|
+
}
|
|
2373
|
+
function runtimeForLogger(logger, exit = defaultRuntime.exit) {
|
|
2374
|
+
const formatArgs = (...args) => args.map((arg) => formatRuntimeArg(arg)).join(" ").trim();
|
|
2375
|
+
return {
|
|
2376
|
+
log: (...args) => logger.info(formatArgs(...args)),
|
|
2377
|
+
error: (...args) => logger.error(formatArgs(...args)),
|
|
2378
|
+
exit
|
|
2379
|
+
};
|
|
2380
|
+
}
|
|
2381
|
+
|
|
2382
|
+
//#endregion
|
|
2383
|
+
//#region src/utils/boolean.ts
|
|
2384
|
+
const DEFAULT_TRUTHY = [
|
|
2385
|
+
"true",
|
|
2386
|
+
"1",
|
|
2387
|
+
"yes",
|
|
2388
|
+
"on"
|
|
2389
|
+
];
|
|
2390
|
+
const DEFAULT_FALSY = [
|
|
2391
|
+
"false",
|
|
2392
|
+
"0",
|
|
2393
|
+
"no",
|
|
2394
|
+
"off"
|
|
2395
|
+
];
|
|
2396
|
+
const DEFAULT_TRUTHY_SET = new Set(DEFAULT_TRUTHY);
|
|
2397
|
+
const DEFAULT_FALSY_SET = new Set(DEFAULT_FALSY);
|
|
2398
|
+
function parseBooleanValue(value, options = {}) {
|
|
2399
|
+
if (typeof value === "boolean") return value;
|
|
2400
|
+
if (typeof value !== "string") return;
|
|
2401
|
+
const normalized = value.trim().toLowerCase();
|
|
2402
|
+
if (!normalized) return;
|
|
2403
|
+
const truthy = options.truthy ?? DEFAULT_TRUTHY;
|
|
2404
|
+
const falsy = options.falsy ?? DEFAULT_FALSY;
|
|
2405
|
+
const truthySet = truthy === DEFAULT_TRUTHY ? DEFAULT_TRUTHY_SET : new Set(truthy);
|
|
2406
|
+
const falsySet = falsy === DEFAULT_FALSY ? DEFAULT_FALSY_SET : new Set(falsy);
|
|
2407
|
+
if (truthySet.has(normalized)) return true;
|
|
2408
|
+
if (falsySet.has(normalized)) return false;
|
|
2409
|
+
}
|
|
2410
|
+
|
|
2411
|
+
//#endregion
|
|
2412
|
+
//#region src/infra/env.ts
|
|
2413
|
+
const log = createSubsystemLogger("env");
|
|
2414
|
+
const loggedEnv = /* @__PURE__ */ new Set();
|
|
2415
|
+
function formatEnvValue(value, redact) {
|
|
2416
|
+
if (redact) return "<redacted>";
|
|
2417
|
+
const singleLine = value.replace(/\s+/g, " ").trim();
|
|
2418
|
+
if (singleLine.length <= 160) return singleLine;
|
|
2419
|
+
return `${singleLine.slice(0, 160)}…`;
|
|
2420
|
+
}
|
|
2421
|
+
function logAcceptedEnvOption(option) {
|
|
2422
|
+
if (process.env.VITEST || false) return;
|
|
2423
|
+
if (loggedEnv.has(option.key)) return;
|
|
2424
|
+
const rawValue = option.value ?? process.env[option.key];
|
|
2425
|
+
if (!rawValue || !rawValue.trim()) return;
|
|
2426
|
+
loggedEnv.add(option.key);
|
|
2427
|
+
log.info(`env: ${option.key}=${formatEnvValue(rawValue, option.redact)} (${option.description})`);
|
|
2428
|
+
}
|
|
2429
|
+
function normalizeZaiEnv() {
|
|
2430
|
+
if (!process.env.ZAI_API_KEY?.trim() && process.env.Z_AI_API_KEY?.trim()) process.env.ZAI_API_KEY = process.env.Z_AI_API_KEY;
|
|
2431
|
+
}
|
|
2432
|
+
function isTruthyEnvValue(value) {
|
|
2433
|
+
return parseBooleanValue(value) === true;
|
|
2434
|
+
}
|
|
2435
|
+
function normalizeEnv() {
|
|
2436
|
+
normalizeZaiEnv();
|
|
2437
|
+
}
|
|
2438
|
+
|
|
2439
|
+
//#endregion
|
|
2440
|
+
//#region src/infra/is-main.ts
|
|
2441
|
+
function normalizePathCandidate(candidate, cwd) {
|
|
2442
|
+
if (!candidate) return;
|
|
2443
|
+
const resolved = path.resolve(cwd, candidate);
|
|
2444
|
+
try {
|
|
2445
|
+
return fs.realpathSync.native(resolved);
|
|
2446
|
+
} catch {
|
|
2447
|
+
return resolved;
|
|
2448
|
+
}
|
|
2449
|
+
}
|
|
2450
|
+
function isMainModule({ currentFile, argv = process.argv, env = process.env, cwd = process.cwd(), wrapperEntryPairs = [] }) {
|
|
2451
|
+
const normalizedCurrent = normalizePathCandidate(currentFile, cwd);
|
|
2452
|
+
const normalizedArgv1 = normalizePathCandidate(argv[1], cwd);
|
|
2453
|
+
if (normalizedCurrent && normalizedArgv1 && normalizedCurrent === normalizedArgv1) return true;
|
|
2454
|
+
const normalizedPmExecPath = normalizePathCandidate(env.pm_exec_path, cwd);
|
|
2455
|
+
if (normalizedCurrent && normalizedPmExecPath && normalizedCurrent === normalizedPmExecPath) return true;
|
|
2456
|
+
if (normalizedCurrent && normalizedArgv1 && wrapperEntryPairs.length > 0) {
|
|
2457
|
+
const currentBase = path.basename(normalizedCurrent);
|
|
2458
|
+
const argvBase = path.basename(normalizedArgv1);
|
|
2459
|
+
if (wrapperEntryPairs.some(({ wrapperBasename, entryBasename }) => currentBase === entryBasename && argvBase === wrapperBasename)) return true;
|
|
2460
|
+
}
|
|
2461
|
+
if (normalizedCurrent && normalizedArgv1 && path.basename(normalizedCurrent) === path.basename(normalizedArgv1)) return true;
|
|
2462
|
+
return false;
|
|
2463
|
+
}
|
|
2464
|
+
|
|
2465
|
+
//#endregion
|
|
2466
|
+
//#region src/infra/warning-filter.ts
|
|
2467
|
+
const warningFilterKey = Symbol.for("remoteclaw.warning-filter");
|
|
2468
|
+
function shouldIgnoreWarning(warning) {
|
|
2469
|
+
if (warning.code === "DEP0040" && warning.message?.includes("punycode")) return true;
|
|
2470
|
+
if (warning.code === "DEP0060" && warning.message?.includes("util._extend")) return true;
|
|
2471
|
+
if (warning.name === "ExperimentalWarning" && warning.message?.includes("SQLite is an experimental feature")) return true;
|
|
2472
|
+
return false;
|
|
2473
|
+
}
|
|
2474
|
+
function normalizeWarningArgs(args) {
|
|
2475
|
+
const warningArg = args[0];
|
|
2476
|
+
const secondArg = args[1];
|
|
2477
|
+
const thirdArg = args[2];
|
|
2478
|
+
let name;
|
|
2479
|
+
let code;
|
|
2480
|
+
let message;
|
|
2481
|
+
if (warningArg instanceof Error) {
|
|
2482
|
+
name = warningArg.name;
|
|
2483
|
+
message = warningArg.message;
|
|
2484
|
+
code = warningArg.code;
|
|
2485
|
+
} else if (typeof warningArg === "string") message = warningArg;
|
|
2486
|
+
if (secondArg && typeof secondArg === "object" && !Array.isArray(secondArg)) {
|
|
2487
|
+
const options = secondArg;
|
|
2488
|
+
if (typeof options.type === "string") name = options.type;
|
|
2489
|
+
if (typeof options.code === "string") code = options.code;
|
|
2490
|
+
} else {
|
|
2491
|
+
if (typeof secondArg === "string") name = secondArg;
|
|
2492
|
+
if (typeof thirdArg === "string") code = thirdArg;
|
|
2493
|
+
}
|
|
2494
|
+
return {
|
|
2495
|
+
name,
|
|
2496
|
+
code,
|
|
2497
|
+
message
|
|
2498
|
+
};
|
|
2499
|
+
}
|
|
2500
|
+
function installProcessWarningFilter() {
|
|
2501
|
+
const globalState = globalThis;
|
|
2502
|
+
if (globalState[warningFilterKey]?.installed) return;
|
|
2503
|
+
const originalEmitWarning = process.emitWarning.bind(process);
|
|
2504
|
+
const wrappedEmitWarning = ((...args) => {
|
|
2505
|
+
if (shouldIgnoreWarning(normalizeWarningArgs(args))) return;
|
|
2506
|
+
return Reflect.apply(originalEmitWarning, process, args);
|
|
2507
|
+
});
|
|
2508
|
+
process.emitWarning = wrappedEmitWarning;
|
|
2509
|
+
globalState[warningFilterKey] = { installed: true };
|
|
2510
|
+
}
|
|
2511
|
+
|
|
2512
|
+
//#endregion
|
|
2513
|
+
//#region src/process/child-process-bridge.ts
|
|
2514
|
+
const defaultSignals = process$1.platform === "win32" ? [
|
|
2515
|
+
"SIGTERM",
|
|
2516
|
+
"SIGINT",
|
|
2517
|
+
"SIGBREAK"
|
|
2518
|
+
] : [
|
|
2519
|
+
"SIGTERM",
|
|
2520
|
+
"SIGINT",
|
|
2521
|
+
"SIGHUP",
|
|
2522
|
+
"SIGQUIT"
|
|
2523
|
+
];
|
|
2524
|
+
function attachChildProcessBridge(child, { signals = defaultSignals, onSignal } = {}) {
|
|
2525
|
+
const listeners = /* @__PURE__ */ new Map();
|
|
2526
|
+
for (const signal of signals) {
|
|
2527
|
+
const listener = () => {
|
|
2528
|
+
onSignal?.(signal);
|
|
2529
|
+
try {
|
|
2530
|
+
child.kill(signal);
|
|
2531
|
+
} catch {}
|
|
2532
|
+
};
|
|
2533
|
+
try {
|
|
2534
|
+
process$1.on(signal, listener);
|
|
2535
|
+
listeners.set(signal, listener);
|
|
2536
|
+
} catch {}
|
|
2537
|
+
}
|
|
2538
|
+
const detach = () => {
|
|
2539
|
+
for (const [signal, listener] of listeners) process$1.off(signal, listener);
|
|
2540
|
+
listeners.clear();
|
|
2541
|
+
};
|
|
2542
|
+
child.once("exit", detach);
|
|
2543
|
+
child.once("error", detach);
|
|
2544
|
+
return { detach };
|
|
2545
|
+
}
|
|
2546
|
+
|
|
2547
|
+
//#endregion
|
|
2548
|
+
//#region src/entry.ts
|
|
2549
|
+
if (!isMainModule({
|
|
2550
|
+
currentFile: fileURLToPath(import.meta.url),
|
|
2551
|
+
wrapperEntryPairs: [...[{
|
|
2552
|
+
wrapperBasename: "remoteclaw.mjs",
|
|
2553
|
+
entryBasename: "entry.js"
|
|
2554
|
+
}, {
|
|
2555
|
+
wrapperBasename: "remoteclaw.js",
|
|
2556
|
+
entryBasename: "entry.js"
|
|
2557
|
+
}]]
|
|
2558
|
+
})) {} else {
|
|
2559
|
+
process$1.title = "remoteclaw";
|
|
2560
|
+
installProcessWarningFilter();
|
|
2561
|
+
normalizeEnv();
|
|
2562
|
+
if (process$1.argv.includes("--no-color")) {
|
|
2563
|
+
process$1.env.NO_COLOR = "1";
|
|
2564
|
+
process$1.env.FORCE_COLOR = "0";
|
|
2565
|
+
}
|
|
2566
|
+
const EXPERIMENTAL_WARNING_FLAG = "--disable-warning=ExperimentalWarning";
|
|
2567
|
+
function hasExperimentalWarningSuppressed() {
|
|
2568
|
+
const nodeOptions = process$1.env.NODE_OPTIONS ?? "";
|
|
2569
|
+
if (nodeOptions.includes(EXPERIMENTAL_WARNING_FLAG) || nodeOptions.includes("--no-warnings")) return true;
|
|
2570
|
+
for (const arg of process$1.execArgv) if (arg === EXPERIMENTAL_WARNING_FLAG || arg === "--no-warnings") return true;
|
|
2571
|
+
return false;
|
|
2572
|
+
}
|
|
2573
|
+
function ensureExperimentalWarningSuppressed() {
|
|
2574
|
+
if (shouldSkipRespawnForArgv(process$1.argv)) return false;
|
|
2575
|
+
if (isTruthyEnvValue(process$1.env.REMOTECLAW_NO_RESPAWN)) return false;
|
|
2576
|
+
if (isTruthyEnvValue(process$1.env.REMOTECLAW_NODE_OPTIONS_READY)) return false;
|
|
2577
|
+
if (hasExperimentalWarningSuppressed()) return false;
|
|
2578
|
+
process$1.env.REMOTECLAW_NODE_OPTIONS_READY = "1";
|
|
2579
|
+
const child = spawn(process$1.execPath, [
|
|
2580
|
+
EXPERIMENTAL_WARNING_FLAG,
|
|
2581
|
+
...process$1.execArgv,
|
|
2582
|
+
...process$1.argv.slice(1)
|
|
2583
|
+
], {
|
|
2584
|
+
stdio: "inherit",
|
|
2585
|
+
env: process$1.env
|
|
2586
|
+
});
|
|
2587
|
+
attachChildProcessBridge(child);
|
|
2588
|
+
child.once("exit", (code, signal) => {
|
|
2589
|
+
if (signal) {
|
|
2590
|
+
process$1.exitCode = 1;
|
|
2591
|
+
return;
|
|
2592
|
+
}
|
|
2593
|
+
process$1.exit(code ?? 1);
|
|
2594
|
+
});
|
|
2595
|
+
child.once("error", (error) => {
|
|
2596
|
+
console.error("[remoteclaw] Failed to respawn CLI:", error instanceof Error ? error.stack ?? error.message : error);
|
|
2597
|
+
process$1.exit(1);
|
|
2598
|
+
});
|
|
2599
|
+
return true;
|
|
2600
|
+
}
|
|
2601
|
+
process$1.argv = normalizeWindowsArgv(process$1.argv);
|
|
2602
|
+
if (!ensureExperimentalWarningSuppressed()) {
|
|
2603
|
+
const parsed = parseCliProfileArgs(process$1.argv);
|
|
2604
|
+
if (!parsed.ok) {
|
|
2605
|
+
console.error(`[remoteclaw] ${parsed.error}`);
|
|
2606
|
+
process$1.exit(2);
|
|
2607
|
+
}
|
|
2608
|
+
if (parsed.profile) {
|
|
2609
|
+
applyCliProfileEnv({ profile: parsed.profile });
|
|
2610
|
+
process$1.argv = parsed.argv;
|
|
2611
|
+
}
|
|
2612
|
+
import("./run-main-Um5xhxla.js").then(({ runCli }) => runCli(process$1.argv)).catch((error) => {
|
|
2613
|
+
console.error("[remoteclaw] Failed to start CLI:", error instanceof Error ? error.stack ?? error.message : error);
|
|
2614
|
+
process$1.exitCode = 1;
|
|
2615
|
+
});
|
|
2616
|
+
}
|
|
2617
|
+
}
|
|
2618
|
+
|
|
2619
|
+
//#endregion
|
|
2620
|
+
export { pathExists as $, buildParseArgv as $t, normalizeChatChannelId as A, normalizeLogLevel as At, listPluginCommands as B, resolveDefaultConfigCandidates as Bt, CHAT_CHANNEL_ORDER as C, theme as Ct, listChatChannels as D, toPinoLikeLogger as Dt, getChatChannelMeta as E, getResolvedLoggerSettings as Et, createPluginRegistry as F, STATE_DIR as Ft, displayString as G, resolveNewStateDir as Gt, CONFIG_DIR as H, resolveGatewayPort as Ht, normalizePluginHttpPath as I, isNixMode as It, formatTerminalLink as J, clearInternalHooks as Jt, ensureDir as K, resolveOAuthDir as Kt, clearPluginCommands as L, resolveCanonicalConfigPath as Lt, requireActivePluginRegistry as M, resolvePreferredRemoteClawTmpDir as Mt, setActivePluginRegistry as N, CONFIG_PATH as Nt, normalizeAnyChannelId as O, resolveNodeRequireFromMeta as Ot, createEmptyPluginRegistry as P, DEFAULT_GATEWAY_PORT as Pt, normalizeE164 as Q, normalizeWindowsArgv as Qt, executePluginCommand as R, resolveConfigPath as Rt, CHANNEL_IDS as S, isRich as St, formatChannelSelectionLine as T, getLogger as Tt, clamp as U, resolveIsNixMode as Ut, matchPluginCommand as V, resolveGatewayLockDir as Vt, displayPath as W, resolveLegacyStateDirs as Wt, isSelfChatMode as X, registerInternalHook as Xt, isRecord as Y, createInternalHookEvent as Yt, jidToE164 as Z, triggerInternalHook as Zt, defaultRuntime as _, setVerbose as _t, parseBooleanValue as a, hasFlag as an, shortenHomeInString as at, registerActiveProgressLine as b, warn as bt, enableConsoleCapture as c, shouldMigrateStateFromPath as cn, toWhatsappJid as ct, setConsoleTimestampPrefix as d, resolveRequiredHomeDir as dn, danger as dt, getCommandPath as en, resolveConfigDir as et, shouldLogSubsystemToConsole as f, info as ft, createNonExitingRuntime as g, logVerboseConsole as gt, visibleWidth as h, logVerbose as ht, normalizeEnv as i, getVerboseFlag as in, safeParseJson as it, getActivePluginRegistry as j, tryParseLogLevel as jt, normalizeChannelId as k, ALLOWED_LOG_LEVELS as kt, routeLogsToStderr as l, normalizeProfileName as ln, truncateUtf16Safe as lt, stripAnsi as m, isYes as mt, isTruthyEnvValue as n, getPositiveIntFlagValue as nn, resolveJidToE164 as nt, createSubsystemLogger as o, hasHelpOrVersion as on, shortenHomePath as ot, formatLocalIsoWithOffset as p, isVerbose as pt, escapeRegExp as q, resolveStateDir as qt, logAcceptedEnvOption as r, getPrimaryCommand as rn, resolveUserPath as rt, runtimeForLogger as s, hasRootVersionAlias as sn, sleep as st, isMainModule as t, getFlagValue as tn, resolveHomeDir as tt, setConsoleSubsystemFilter as u, expandHomePrefix as un, isPlainObject as ut, restoreTerminalState as v, shouldLogVerbose as vt, formatChannelPrimerLine as w, getChildLogger as wt, unregisterActiveProgressLine as x, colorize as xt, clearActiveProgressLine as y, success as yt, getPluginCommandSpecs as z, resolveConfigPathCandidate as zt };
|