@pixelzx/genesis 2026.5.3-5 → 2026.5.5
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 +8 -0
- package/dist/.buildstamp +1 -1
- package/dist/abort-t5XiT6Yl.js +201 -0
- package/dist/abort.runtime-C_xk0DkL.js +2 -0
- package/dist/abort.runtime.js +1 -1
- package/dist/accounts-B7yDKwxi.js +104 -0
- package/dist/accounts-CS7VL356.js +107 -0
- package/dist/accounts-XvHcAtMf.js +2 -0
- package/dist/acp-cli-B5H0nvID.js +2193 -0
- package/dist/acp-spawn-BRTMqPlq.js +2 -0
- package/dist/acp-spawn-Dsw3dzWY.js +1093 -0
- package/dist/acp-stateful-target-driver-BYhkJnyh.js +89 -0
- package/dist/action-agents-Ca9kTFvv.js +67 -0
- package/dist/action-focus-D4pT0hra.js +132 -0
- package/dist/action-help-DMzMxFEQ.js +7 -0
- package/dist/action-info-Dzn_fn6G.js +101 -0
- package/dist/action-kill-2AQuhnLy.js +33 -0
- package/dist/action-list-DI1M2pKU.js +21 -0
- package/dist/action-log-BVKGgOki.js +30 -0
- package/dist/action-send-CZ2wciMW.js +39 -0
- package/dist/action-spawn-BdclQLrK.js +47 -0
- package/dist/action-unfocus-DfQuRf8d.js +29 -0
- package/dist/actions.runtime-B2-oz_B6.js +5 -0
- package/dist/actions.runtime-BoUxrcw3.js +18 -0
- package/dist/actions.runtime.js +1 -1
- package/dist/agent-CnQ3yCIw.js +2 -0
- package/dist/agent-command-C4H_9c2N.js +874 -0
- package/dist/agent-harness-runtime-D2oXzgyL.js +144 -0
- package/dist/agent-runner-utils-CWgPcOYn.js +239 -0
- package/dist/agent-runner.runtime-DvK-HQhq.js +3455 -0
- package/dist/agent-runner.runtime.js +1 -1
- package/dist/agent-runtime-BDslXtCf.js +18 -0
- package/dist/agents-4T7YaeKy.js +953 -0
- package/dist/agents-C_Gty_RK.js +5 -0
- package/dist/aliases-BkVpehd-.js +96 -0
- package/dist/aliases-DWkJWJ5A.js +2 -0
- package/dist/api-CgW6fcU2.js +3 -0
- package/dist/api-DYPaGKUj.js +5 -0
- package/dist/api-DdoV90Cn.js +139 -0
- package/dist/approval-gateway-resolver-Ba_2kb3B.js +29 -0
- package/dist/approval-gateway-runtime-7VMivk0A.js +2 -0
- package/dist/approval-handler-runtime-DUDpOwG7.js +439 -0
- package/dist/approval-native-runtime-KkmX9gwQ.js +729 -0
- package/dist/attempt-execution.runtime-CQkeVpDx.js +509 -0
- package/dist/attempt-execution.runtime.js +1 -1
- package/dist/attempt.prompt-helpers-MoT6VaD0.js +221 -0
- package/dist/attempt.tool-run-context-B53GhX-d.js +933 -0
- package/dist/audit-CvHcVVb-.js +939 -0
- package/dist/audit.runtime-C7n442Rc.js +7 -0
- package/dist/audit.runtime.js +1 -1
- package/dist/auth-CAnSldtM.js +2 -0
- package/dist/auth-Czf_o5iE.js +383 -0
- package/dist/auth-order-Cu9Vj7lA.js +96 -0
- package/dist/auth-order-q1IFw7L3.js +2 -0
- package/dist/bash-tools-BS4TrA4X.js +2824 -0
- package/dist/bash-tools-DbHYuk8O.js +3 -0
- package/dist/binding-routing-CnNQE65Q.js +85 -0
- package/dist/binding-targets-DW0ScIRI.js +121 -0
- package/dist/bridge-server-BGS08n2f.js +113 -0
- package/dist/browser-control-auth-DMlQOsyN.js +2 -0
- package/dist/browser-node-runtime-CF32scUO.js +12 -0
- package/dist/browser-profiles-CmER65eh.js +2 -0
- package/dist/browser-runtime-D73M9fg3.js +387 -0
- package/dist/browser-setup-tools-Cr0UI1rf.js +13 -0
- package/dist/build-BL7WirDF.js +550 -0
- package/dist/build-info.json +3 -3
- package/dist/bundled/boot-md/handler.js +2 -2
- package/dist/bundled/session-memory/handler.js +1 -1
- package/dist/call-Ckws4Nlw.js +3 -0
- package/dist/call-DkGNVvLy.js +331 -0
- package/dist/call.runtime-DfLBtAIr.js +2 -0
- package/dist/call.runtime.js +1 -1
- package/dist/capability-cli-tSqSJf2o.js +1401 -0
- package/dist/catchup-Dp2L1RcY.js +300 -0
- package/dist/channel-BIFp1GJd.js +1320 -0
- package/dist/channel-BZMzoXhw.js +840 -0
- package/dist/channel-BtPZ0i4g.js +297 -0
- package/dist/channel-DDd7xwLG.js +226 -0
- package/dist/channel-DLezQPqR.js +350 -0
- package/dist/channel-DcYHXn_7.js +1100 -0
- package/dist/channel-DzKtLfJj.js +1802 -0
- package/dist/channel-LlY18tI5.js +595 -0
- package/dist/channel-NjZviHcJ.js +1174 -0
- package/dist/channel-core-Cg1mFpva.js +5 -0
- package/dist/channel-inbound-CZpi-vp5.js +31 -0
- package/dist/channel-pDXIWFS4.js +453 -0
- package/dist/channel-plugin-runtime-DHl81Ror.js +771 -0
- package/dist/channel-runtime-CtYrrwow.js +425 -0
- package/dist/channel-wMkGGyIY.js +491 -0
- package/dist/channel.runtime-B1n0hvUI.js +430 -0
- package/dist/channel.runtime-B9iR26l_.js +576 -0
- package/dist/channel.runtime-C8eBQk67.js +4 -0
- package/dist/channel.runtime-Db8g8JCg.js +89 -0
- package/dist/channel.runtime-DfRfisV2.js +34702 -0
- package/dist/channel.runtime-gPdBMu3V.js +109 -0
- package/dist/channel.runtime-rG9pJ5NO.js +2364 -0
- package/dist/channel.runtime.js +1 -1
- package/dist/channel.setup-CWblUOhD.js +10 -0
- package/dist/channels-B4dYRKsI.js +733 -0
- package/dist/channels-cli-GMAOUYU3.js +268 -0
- package/dist/chat-D2XaZNiP.js +2758 -0
- package/dist/clawbot-cli-CSmdcIMT.js +9 -0
- package/dist/cli/daemon-cli.js +3 -3
- package/dist/cli-2u5IZTMS.js +219 -0
- package/dist/cli-Bk8uXnyc.js +72 -0
- package/dist/cli-DBfw9jCz.js +2 -0
- package/dist/cli-runner-BEqvX1ky.js +286 -0
- package/dist/cli-runner.runtime-BIUcUGDa.js +4 -0
- package/dist/cli-runner.runtime-D2u3Yw0W.js +3 -0
- package/dist/cli-runner.runtime.js +1 -1
- package/dist/cli-startup-metadata.json +2 -2
- package/dist/cli-waH8839u.js +2 -0
- package/dist/cli.runtime-mKvJpLwI.js +1261 -0
- package/dist/cli.runtime.js +1 -1
- package/dist/client-CKizOsGp.js +138 -0
- package/dist/client-CrPccv7a.js +713 -0
- package/dist/command-auth-DPkjKHdv.js +76 -0
- package/dist/command-config-resolution-BTjtnAp2.js +2 -0
- package/dist/command-config-resolution-Be3KZA_l.js +23 -0
- package/dist/command-config-resolution.runtime-DXgL8cm7.js +2 -0
- package/dist/command-config-resolution.runtime.js +1 -1
- package/dist/command-registry-BL1Z4Cen.js +4 -0
- package/dist/command-registry-BMePAw9w.js +9 -0
- package/dist/command-registry-core-CAay55-n.js +104 -0
- package/dist/command-secret-gateway-jj1Qmk9L.js +528 -0
- package/dist/command-status.runtime-BVcCm9_0.js +87 -0
- package/dist/command-status.runtime.js +1 -1
- package/dist/commands-acp-COdUW69f.js +77 -0
- package/dist/commands-compact.runtime-C0Fedews.js +10 -0
- package/dist/commands-compact.runtime.js +1 -1
- package/dist/commands-handlers.runtime-BXVM3PWG.js +4597 -0
- package/dist/commands-handlers.runtime.js +1 -1
- package/dist/commands-status-DaApOLoQ.js +16 -0
- package/dist/commands-status.runtime-CxSjrKne.js +3 -0
- package/dist/commands-status.runtime.js +1 -1
- package/dist/commands-subagents-control.runtime-BEfW44br.js +2 -0
- package/dist/commands-subagents-control.runtime-DB3AROHI.js +3 -0
- package/dist/commands-subagents-control.runtime.js +1 -1
- package/dist/commands-system-prompt-CCrUy7xq.js +158 -0
- package/dist/commands-system-prompt-CN56TtaC.js +2 -0
- package/dist/commands.runtime-Bee6dM3V.js +166 -0
- package/dist/commands.runtime.js +1 -1
- package/dist/compact-7YtEe1kG.js +1118 -0
- package/dist/compact.runtime-4gW_cs7D.js +12 -0
- package/dist/compact.runtime.js +1 -1
- package/dist/completion-cli-COv-r8_h.js +313 -0
- package/dist/config-DSsLlg8J.js +251 -0
- package/dist/config-cli-C9oGe9gl.js +1078 -0
- package/dist/configure-Bfy9tVmS.js +2 -0
- package/dist/configure-DpIFRaAD.js +1245 -0
- package/dist/connect-options-CPixzqP_.js +699 -0
- package/dist/control-auth-L7U2ivRJ.js +125 -0
- package/dist/control-service-CbUz8qU5.js +156 -0
- package/dist/conversation-id-BroDIGeT.js +38 -0
- package/dist/conversation-id-CuVi0tWe.js +235 -0
- package/dist/conversation-runtime-weaahZQN.js +31 -0
- package/dist/core-PXv1nsc-.js +275 -0
- package/dist/cron-cli-DZNSQBuA.js +713 -0
- package/dist/daemon-cli-C_9CNoZA.js +12 -0
- package/dist/delegate-B8wh-jjf.js +64 -0
- package/dist/detached-task-runtime-BTq-jIGw.js +73 -0
- package/dist/devices-cli-C_amY-AS.js +496 -0
- package/dist/diagnostics-Bw-fd0ug.js +154 -0
- package/dist/direct-dm-Dvqjch3O.js +64 -0
- package/dist/dispatch-DHPQS49Q.js +1131 -0
- package/dist/dispatch-acp-manager.runtime-y-oykPUz.js +3 -0
- package/dist/dispatch-acp-manager.runtime.js +1 -1
- package/dist/dispatch-acp-taSuJD5W.js +981 -0
- package/dist/dispatch-acp.runtime-DgyaFFNX.js +19 -0
- package/dist/dispatch-acp.runtime.js +1 -1
- package/dist/doctor-device-pairing-rxwogzYF.js +307 -0
- package/dist/doctor-gateway-daemon-flow-Dm4wxnTt.js +250 -0
- package/dist/doctor-gateway-health-wJVW5xUW.js +60 -0
- package/dist/doctor-health-DaodspKU.js +59 -0
- package/dist/doctor-health-contributions-CBVyN6ju.js +486 -0
- package/dist/doctor-prompter-vO6LPeXZ.js +56 -0
- package/dist/doctor-workspace-status-BnXA04-6.js +75 -0
- package/dist/dreaming-1RLie1iF.js +1574 -0
- package/dist/dreaming-narrative-BRtTdpbt.js +595 -0
- package/dist/embedded-gateway-stub.runtime-GMix51Tf.js +9 -0
- package/dist/embedded-gateway-stub.runtime.js +1 -1
- package/dist/entry.js +2 -2
- package/dist/exec-approvals-cli-R6jgupQH.js +498 -0
- package/dist/extensionAPI.js +1 -1
- package/dist/extensions/active-memory/index.js +1 -1
- package/dist/extensions/bluebubbles/api.js +3 -3
- package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
- package/dist/extensions/browser/browser-bridge.js +1 -1
- package/dist/extensions/browser/browser-config.js +4 -4
- package/dist/extensions/browser/browser-control-auth.js +2 -2
- package/dist/extensions/browser/browser-doctor.js +2 -2
- package/dist/extensions/browser/browser-maintenance.js +2 -2
- package/dist/extensions/browser/browser-profiles.js +2 -2
- package/dist/extensions/browser/browser-runtime-api.js +10 -10
- package/dist/extensions/browser/index.js +1 -1
- package/dist/extensions/browser/plugin-registration.js +1 -1
- package/dist/extensions/browser/register.runtime.js +3 -3
- package/dist/extensions/browser/runtime-api.js +11 -11
- package/dist/extensions/browser/test-support.js +1 -1
- package/dist/extensions/device-pair/api.js +1 -1
- package/dist/extensions/device-pair/index.js +3 -3
- package/dist/extensions/device-pair/notify.js +1 -1
- package/dist/extensions/device-pair/pair-command-approve.js +1 -1
- package/dist/extensions/google-meet/index.js +2 -2
- package/dist/extensions/imessage/api.js +3 -3
- package/dist/extensions/imessage/channel-plugin-api.js +1 -1
- package/dist/extensions/imessage/runtime-api.js +3 -3
- package/dist/extensions/irc/api.js +2 -2
- package/dist/extensions/irc/channel-plugin-api.js +1 -1
- package/dist/extensions/line/api.js +2 -2
- package/dist/extensions/line/channel-plugin-api.js +1 -1
- package/dist/extensions/line/contract-api.js +1 -1
- package/dist/extensions/line/runtime-api.js +4 -4
- package/dist/extensions/line/setup-api.js +1 -1
- package/dist/extensions/llm-task/index.js +2 -2
- package/dist/extensions/lobster/index.js +3 -3
- package/dist/extensions/lobster/runtime-api.js +1 -1
- package/dist/extensions/mattermost/api.js +1 -1
- package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
- package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
- package/dist/extensions/mattermost/policy-api.js +1 -1
- package/dist/extensions/mattermost/runtime-api.js +4 -4
- package/dist/extensions/mattermost/slash-route-api.js +1 -1
- package/dist/extensions/memory-core/api.js +1 -1
- package/dist/extensions/memory-core/cli-metadata.js +2 -2
- package/dist/extensions/memory-core/index.js +3 -3
- package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
- package/dist/extensions/msteams/api.js +1 -1
- package/dist/extensions/msteams/channel-plugin-api.js +1 -1
- package/dist/extensions/msteams/runtime-api.js +3 -3
- package/dist/extensions/msteams/test-api.js +1 -1
- package/dist/extensions/nextcloud-talk/api.js +1 -1
- package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
- package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
- package/dist/extensions/openshell/index.js +2 -2
- package/dist/extensions/signal/api.js +6 -6
- package/dist/extensions/signal/channel-plugin-api.js +1 -1
- package/dist/extensions/signal/reaction-runtime-api.js +1 -1
- package/dist/extensions/signal/runtime-api.js +7 -7
- package/dist/extensions/skill-workshop/api.js +1 -1
- package/dist/extensions/skill-workshop/index.js +1 -1
- package/dist/extensions/synology-chat/api.js +1 -1
- package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
- package/dist/extensions/tlon/api.js +2 -2
- package/dist/extensions/tlon/channel-plugin-api.js +1 -1
- package/dist/extensions/tlon/runtime-api.js +1 -1
- package/dist/extensions/tlon/test-api.js +1 -1
- package/dist/extensions/twitch/api.js +1 -1
- package/dist/extensions/twitch/channel-plugin-api.js +1 -1
- package/dist/extensions/twitch/setup-plugin-api.js +1 -1
- package/dist/extensions/zalo/api.js +3 -3
- package/dist/extensions/zalo/channel-plugin-api.js +1 -1
- package/dist/extensions/zalo/runtime-api.js +2 -2
- package/dist/extensions/zalo/setup-api.js +2 -2
- package/dist/extensions/zalouser/api.js +3 -3
- package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
- package/dist/extensions/zalouser/runtime-api.js +6 -6
- package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
- package/dist/extensions/zalouser/test-api.js +1 -1
- package/dist/fallbacks-Cckv3nng.js +2 -0
- package/dist/fallbacks-Y_nNY8_a.js +31 -0
- package/dist/fallbacks-shared-DZiG1Gr_.js +111 -0
- package/dist/gateway-CDfn0J87.js +115 -0
- package/dist/gateway-cli-D197U6l0.js +1325 -0
- package/dist/gateway-rpc-Bomz8HKq.js +14 -0
- package/dist/gateway-rpc.runtime-597tksmo.js +23 -0
- package/dist/gateway-rpc.runtime.js +1 -1
- package/dist/gateway-runtime-Bm2_MhFn.js +15 -0
- package/dist/gateway-status-Cr4UJKUx.js +584 -0
- package/dist/genesis-tools-DCRaVVjY.js +8999 -0
- package/dist/genesis-tools.runtime-idgd5fjy.js +2 -0
- package/dist/genesis-tools.runtime.js +1 -1
- package/dist/get-reply-BF_7bR5f.js +3879 -0
- package/dist/get-reply-from-config.runtime-DEq5XM_s.js +2 -0
- package/dist/get-reply-from-config.runtime.js +1 -1
- package/dist/graph-users-Bhlw-_4i.js +1337 -0
- package/dist/health-9ifMvGZN.js +3 -0
- package/dist/health-CzOJa6SX.js +469 -0
- package/dist/heartbeat-runner-B2Tkbj5e.js +5 -0
- package/dist/heartbeat-runner-B63G8dbO.js +1292 -0
- package/dist/heartbeat-runner.runtime-QJ_2AMjN.js +4 -0
- package/dist/heartbeat-runner.runtime.js +1 -1
- package/dist/hooks-cli-ZWI1iJnh.js +433 -0
- package/dist/image-fallbacks-BpTfBvbi.js +2 -0
- package/dist/image-fallbacks-DpVwnB41.js +31 -0
- package/dist/inbound-reply-dispatch-mKybIcNA.js +73 -0
- package/dist/index.js +2 -2
- package/dist/infra-runtime-CvwvzUfM.js +39 -0
- package/dist/init-CWeM0DfJ.js +59 -0
- package/dist/library-ClQalZ3x.js +45 -0
- package/dist/lifecycle-CgV7Cgt-.js +571 -0
- package/dist/lifecycle-DVWaxj-A.js +229 -0
- package/dist/lifecycle.runtime-DErLwVJ_.js +2 -0
- package/dist/lifecycle.runtime.js +1 -1
- package/dist/list-5RIS3LMG.js +2 -0
- package/dist/list-BNesYDN2.js +2 -0
- package/dist/list-Dk1hCKis.js +1201 -0
- package/dist/list-eUjt_6__.js +131 -0
- package/dist/list.probe-C51ceJSY.js +419 -0
- package/dist/llm-slug-generator-D64IMUoy.js +79 -0
- package/dist/llm-slug-generator.js +1 -1
- package/dist/load-config-Ccss2uTi.js +35 -0
- package/dist/local-dispatch.runtime-u7Ir1N07.js +8 -0
- package/dist/local-dispatch.runtime.js +1 -1
- package/dist/logs-cli-BYHTboPa.js +265 -0
- package/dist/logs-cli.runtime-CQwNptr-.js +2 -0
- package/dist/logs-cli.runtime.js +1 -1
- package/dist/main-session-restart-recovery-CA9bvC1W.js +206 -0
- package/dist/managed-image-attachments-B_gpkI1u.js +635 -0
- package/dist/managed-image-attachments-C0Y6nAP2.js +2 -0
- package/dist/manager-DZGFArgz.js +2 -0
- package/dist/manager-Df8TC4rX.js +2057 -0
- package/dist/markdown-to-line-xXLdnzcE.js +790 -0
- package/dist/mcp/plugin-tools-serve.js +1 -1
- package/dist/mcp-cli-B50W9Pkc.js +725 -0
- package/dist/mcp-http-BiUGVpJ4.js +529 -0
- package/dist/memory-core-host-runtime-cli-UgLo6ezC.js +9 -0
- package/dist/message-C95gttLd.js +232 -0
- package/dist/message-action-runner-0KAp6ccG.js +1407 -0
- package/dist/message-action-runner-BSUDvECO.js +2 -0
- package/dist/message-actions-Be4Ob151.js +143 -0
- package/dist/message.gateway.runtime-DMMRMIln.js +2 -0
- package/dist/message.gateway.runtime.js +1 -1
- package/dist/models-auth-status-DhYxBz7G.js +201 -0
- package/dist/models-cli-C2prinXb.js +219 -0
- package/dist/monitor-BEI21vNQ.js +1661 -0
- package/dist/monitor-BUgTAJvZ.js +1237 -0
- package/dist/monitor-BdJRIhi1.js +2 -0
- package/dist/monitor-C7wuttQJ.js +1459 -0
- package/dist/monitor-DMumiWnt.js +788 -0
- package/dist/monitor-IQo2ExmV.js +671 -0
- package/dist/monitor-auth-DW0lvfm3.js +207 -0
- package/dist/monitor-processing-DTrsRdyz.js +1974 -0
- package/dist/monitor.runtime-DwqyCQcb.js +2 -0
- package/dist/monitor.runtime.js +1 -1
- package/dist/monitor.webhook-D11nrUh9.js +180 -0
- package/dist/msteams-DO-PW98M.js +35 -0
- package/dist/native-hook-relay-CNZrcPIw.js +519 -0
- package/dist/nextcloud-talk-BeYFnATY.js +17 -0
- package/dist/node-cli-BFrdTPdH.js +2506 -0
- package/dist/nodes-cli-B3Wj_MvP.js +1046 -0
- package/dist/nodes-utils-AsgrCa7K.js +84 -0
- package/dist/nodes.helpers-CMXxavTs.js +34 -0
- package/dist/notify-CNS0kRWM.js +315 -0
- package/dist/onboard-D4ehf66t.js +632 -0
- package/dist/onboard-helpers-DWxdMyCs.js +6 -0
- package/dist/onboard-helpers-o78s0lR1.js +204 -0
- package/dist/onboard-remote-Cc1XlRzr.js +193 -0
- package/dist/onboard-remote-D8THwo3P.js +2 -0
- package/dist/onboard-skills-B2VoCq7v.js +134 -0
- package/dist/onboard-skills-DtOgSJZo.js +2 -0
- package/dist/openai-http-DKQZWsqY.js +500 -0
- package/dist/openresponses-http-C4kol41X.js +1128 -0
- package/dist/operator-approvals-client-BoN_VmkB.js +68 -0
- package/dist/outbound.runtime-D-L8FN8E.js +2 -0
- package/dist/outbound.runtime.js +1 -1
- package/dist/pair-command-approve-DMeQ6uD4.js +44 -0
- package/dist/persistent-bindings.lifecycle-O-RnoTW4.js +2 -0
- package/dist/persistent-bindings.lifecycle-bptWQEFT.js +85 -0
- package/dist/pi-embedded-BM79sXqb.js +2905 -0
- package/dist/pi-embedded-BUDWcDt8.js +4 -0
- package/dist/pi-embedded.runtime-D53bCPOr.js +4 -0
- package/dist/pi-embedded.runtime.js +1 -1
- package/dist/pi-tool-definition-adapter-DdYQtumi.js +217 -0
- package/dist/pi-tools-ihbjTP0K.js +1057 -0
- package/dist/pi-tools.before-tool-call-DrEqr96j.js +433 -0
- package/dist/pi-tools.before-tool-call-VB9YEPOv.js +2 -0
- package/dist/plugin-DwNULpmw.js +12195 -0
- package/dist/plugin-enabled-DbO9GyRJ.js +140 -0
- package/dist/plugin-registration-Du6hgUkp.js +23 -0
- package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
- package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
- package/dist/plugin-sdk/acp-runtime.js +2 -2
- package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
- package/dist/plugin-sdk/agent-harness.js +6 -6
- package/dist/plugin-sdk/agent-runtime.js +2 -2
- package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
- package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
- package/dist/plugin-sdk/approval-runtime.js +1 -1
- package/dist/plugin-sdk/browser-node-runtime.js +4 -4
- package/dist/plugin-sdk/browser-setup-tools.js +3 -3
- package/dist/plugin-sdk/browser-support.js +7 -7
- package/dist/plugin-sdk/channel-core.js +2 -2
- package/dist/plugin-sdk/channel-inbound.js +2 -2
- package/dist/plugin-sdk/command-auth.js +1 -1
- package/dist/plugin-sdk/command-status-runtime.js +1 -1
- package/dist/plugin-sdk/compat.js +1 -1
- package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
- package/dist/plugin-sdk/conversation-runtime.js +3 -3
- package/dist/plugin-sdk/core.js +2 -2
- package/dist/plugin-sdk/direct-dm.js +1 -1
- package/dist/plugin-sdk/gateway-runtime.js +3 -3
- package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
- package/dist/plugin-sdk/index.js +1 -1
- package/dist/plugin-sdk/infra-runtime.js +2 -2
- package/dist/plugin-sdk/irc.js +2 -2
- package/dist/plugin-sdk/matrix.js +1 -1
- package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
- package/dist/plugin-sdk/memory-core.js +2 -2
- package/dist/plugin-sdk/msteams.js +2 -2
- package/dist/plugin-sdk/nextcloud-talk.js +2 -2
- package/dist/plugin-sdk/nostr.js +1 -1
- package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
- package/dist/plugin-sdk/reply-runtime.js +4 -4
- package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
- package/dist/plugin-sdk/runtime.js +2 -2
- package/dist/plugin-sdk/session-visibility.js +1 -1
- package/dist/plugin-sdk/testing.js +4 -4
- package/dist/plugin-sdk/tlon.js +1 -1
- package/dist/plugin-sdk/zalo.js +1 -1
- package/dist/plugin-sdk/zalouser.js +1 -1
- package/dist/plugin-service-DcSnRF5x.js +2890 -0
- package/dist/plugins/runtime/index.js +1 -1
- package/dist/policy-uc224usV.js +328 -0
- package/dist/postinstall-inventory.json +407 -407
- package/dist/prepare.runtime-BPA6jMiM.js +815 -0
- package/dist/prepare.runtime.js +1 -1
- package/dist/probe-5ToseFjd.js +1443 -0
- package/dist/probe-BdCXAH_u.js +2 -0
- package/dist/probe-ByVoZEdq.js +45 -0
- package/dist/probe-D-D_1oc4.js +241 -0
- package/dist/probe-D6s_1Z5k.js +2 -0
- package/dist/probe-DIMAmSsO.js +74 -0
- package/dist/probe-DYuL-s4A.js +2205 -0
- package/dist/program-DDTWTh6g.js +111 -0
- package/dist/prompt-select-styled-kf1dPqNa.js +20 -0
- package/dist/protocol-Batc2DmY.js +2234 -0
- package/dist/provider-dispatcher-DdUqCa6H.js +2 -0
- package/dist/provider-dispatcher-uioW38XW.js +22 -0
- package/dist/qr-cli-B1WUe8Eb.js +2 -0
- package/dist/qr-cli-DmPti3xe.js +349 -0
- package/dist/reaction-runtime-api-5G3e9J0C.js +116 -0
- package/dist/reactions-x7VH-B95.js +998 -0
- package/dist/register-service-commands-DcW5qPTu.js +71 -0
- package/dist/register.agent-Dtj4HC7R.js +248 -0
- package/dist/register.configure-CJHb84Ce.js +15 -0
- package/dist/register.maintenance-BUkPfMcX.js +438 -0
- package/dist/register.message-DGFpyYBl.js +329 -0
- package/dist/register.onboard-D3v3xIfF.js +81 -0
- package/dist/register.runtime-DI4QxYdj.js +81 -0
- package/dist/register.runtime.js +1 -1
- package/dist/register.setup-CXTyuIFM.js +150 -0
- package/dist/register.status-health-sessions-CYUnRi97.js +1215 -0
- package/dist/register.subclis-DKMVrwRc.js +3 -0
- package/dist/register.subclis-NWRi2XKp.js +29 -0
- package/dist/register.subclis-core-De6qmQkr.js +243 -0
- package/dist/reply-dispatch-runtime-B8_j6pJi.js +13 -0
- package/dist/reply-runtime-DGHQDC9d.js +11 -0
- package/dist/reply.runtime-BCfqw2Co.js +2 -0
- package/dist/reply.runtime.js +1 -1
- package/dist/restart-health-6cjrRBpF.js +202 -0
- package/dist/restart-health-b6Qw43Tj.js +2 -0
- package/dist/root-help-BTIH_eUe.js +44 -0
- package/dist/routes-C3J2GfHR.js +3341 -0
- package/dist/routes-SMmfW6k8.js +2 -0
- package/dist/rpc-DQbAcIKu.js +61 -0
- package/dist/rpc.runtime-Q3qyofLf.js +21 -0
- package/dist/rpc.runtime.js +1 -1
- package/dist/run-delivery.runtime-BsLouK3f.js +530 -0
- package/dist/run-delivery.runtime.js +1 -1
- package/dist/run-embedded.runtime-CXd0oZQP.js +4 -0
- package/dist/run-embedded.runtime.js +1 -1
- package/dist/run-execution-cli.runtime-D-MKbq8r.js +4 -0
- package/dist/run-execution-cli.runtime.js +1 -1
- package/dist/run-executor.runtime-Cz0I8mDt.js +277 -0
- package/dist/run-executor.runtime.js +1 -1
- package/dist/run-main-CkXBTQut.js +516 -0
- package/dist/run-subagent-registry.runtime-Cyb8amrH.js +2 -0
- package/dist/run-subagent-registry.runtime.js +1 -1
- package/dist/run-wait-KlS0pdIK.js +135 -0
- package/dist/runtime-3niXLiFY.js +9 -0
- package/dist/runtime-api-B79e2jL2.js +4 -0
- package/dist/runtime-api-CM2c2bSC.js +9 -0
- package/dist/runtime-api-CnOFFN5q.js +14 -0
- package/dist/runtime-api-TnwM-EZH.js +9 -0
- package/dist/runtime-embedded-pi.runtime-9csGjukF.js +2 -0
- package/dist/runtime-embedded-pi.runtime.js +1 -1
- package/dist/runtime-internal-CQX4Zehn.js +2 -0
- package/dist/runtime-options-C0qP2VlT.js +275 -0
- package/dist/runtime-schema-DanWbDoL.js +27780 -0
- package/dist/runtime-vycfMfew.js +973 -0
- package/dist/scan-Bs5zROOQ.js +2 -0
- package/dist/scan-CP2zJb_w.js +523 -0
- package/dist/secrets-cli-YFTlIMmq.js +2101 -0
- package/dist/security-cli-B2WBRU9C.js +486 -0
- package/dist/selection-DSZGsU6m.js +2 -0
- package/dist/selection-hUGDnCgX.js +7736 -0
- package/dist/send-B3Ygb3r3.js +156 -0
- package/dist/send-DMwqnu6K.js +102 -0
- package/dist/send.runtime-D86atcfW.js +2 -0
- package/dist/send.runtime.js +1 -1
- package/dist/server-4gQCBM3M.js +77 -0
- package/dist/server-CK9eCPCG.js +13 -0
- package/dist/server-context-ih3GaGaI.js +847 -0
- package/dist/server-context-kZ_QADic.js +2 -0
- package/dist/server-node-events-CMlHOIKa.js +481 -0
- package/dist/server-plugin-bootstrap-B0XitldT.js +11333 -0
- package/dist/server-plugin-bootstrap-CHlVF8XB.js +2 -0
- package/dist/server-restart-sentinel-TpXCoiYX.js +697 -0
- package/dist/server.impl-B6at3Orl.js +12734 -0
- package/dist/session-kill-http-DvYp5h-j.js +110 -0
- package/dist/session-reset-service-C9rIVqF7.js +471 -0
- package/dist/session-route-FaMcEc7I.js +93 -0
- package/dist/session-status.runtime-BfPn8qA8.js +2 -0
- package/dist/session-status.runtime.js +1 -1
- package/dist/session-subagent-reactivation.runtime-C1fGNaiM.js +2 -0
- package/dist/session-subagent-reactivation.runtime.js +1 -1
- package/dist/session-tab-registry-BDK2AlxL.js +491 -0
- package/dist/session-visibility-BkrL2kFF.js +147 -0
- package/dist/sessions-helpers-YOu_5tl0.js +304 -0
- package/dist/sessions-history-http-DxNaoDfb.js +383 -0
- package/dist/sessions-patch-BPtlF0Lu.js +309 -0
- package/dist/sessions-resolve-B2rpvSka.js +174 -0
- package/dist/sessions.runtime-DEk_x65_.js +2 -0
- package/dist/sessions.runtime.js +1 -1
- package/dist/setup-DZJZF2R6.js +495 -0
- package/dist/setup-api-BkYWhB-B.js +29 -0
- package/dist/setup-core-BXBabSEx.js +171 -0
- package/dist/setup-core-eahC1DXh.js +176 -0
- package/dist/setup-surface-BEf8reey.js +286 -0
- package/dist/setup-surface-DAOKJ-ai.js +219 -0
- package/dist/setup-surface-b6gu0S8l.js +403 -0
- package/dist/setup.finalize-DXUCLT5O.js +539 -0
- package/dist/setup.gateway-config-BH4xbjcX.js +250 -0
- package/dist/shared-BhHdyXun.js +198 -0
- package/dist/shared-CKv38qsN.js +121 -0
- package/dist/shared-DUw9Q4Lf.js +76 -0
- package/dist/slash-state-BQgmhum1.js +1911 -0
- package/dist/src-C1B3uJMu.js +3974 -0
- package/dist/startup-context-DTpThe3H.js +312 -0
- package/dist/status-63GZxfe4.js +2 -0
- package/dist/status-C6qTe-QQ.js +397 -0
- package/dist/status-CSIGAUly.js +190 -0
- package/dist/status-DOW91Kcx.js +2 -0
- package/dist/status-all-7hqTcvxr.js +498 -0
- package/dist/status-json-CUzzv8An.js +14 -0
- package/dist/status-json-command-DwWlqvoV.js +84 -0
- package/dist/status-p4yx6E3C.js +209 -0
- package/dist/status-runtime-shared-yrzbsOR8.js +257 -0
- package/dist/status-subagents.runtime-CuRGoNNn.js +18 -0
- package/dist/status-subagents.runtime.js +1 -1
- package/dist/status-text-BrcRsCFE.js +237 -0
- package/dist/status-zV1BflCE.js +3 -0
- package/dist/status.gateway-connection.runtime-BKd4Zivg.js +2 -0
- package/dist/status.gateway-connection.runtime.js +1 -1
- package/dist/status.gather-B7WlHpIR.js +292 -0
- package/dist/status.gather-Ccewg4ce.js +2 -0
- package/dist/status.runtime-BFru2C4v.js +2 -0
- package/dist/status.runtime.js +1 -1
- package/dist/status.scan-mEKnAmP3.js +65 -0
- package/dist/status.scan-overview-B0qQVJd0.js +379 -0
- package/dist/status.scan.fast-json-CsU-fWhj.js +132 -0
- package/dist/status.scan.fast-json-tEc36TAC.js +2 -0
- package/dist/status.summary-Bvgry977.js +214 -0
- package/dist/status.summary-DRolowE_.js +2 -0
- package/dist/subagent-announce-Bhe55Ktf.js +351 -0
- package/dist/subagent-announce-delivery-NDBIRwuZ.js +726 -0
- package/dist/subagent-announce-output-DsmGO7Oi.js +364 -0
- package/dist/subagent-control-Bn8n-535.js +506 -0
- package/dist/subagent-followup.runtime-C7s-lOGN.js +68 -0
- package/dist/subagent-followup.runtime.js +1 -1
- package/dist/subagent-orphan-recovery-CJEhSvFZ.js +305 -0
- package/dist/subagent-registry-BgQA8eP1.js +1753 -0
- package/dist/subagent-registry-DAm-N9-O.js +3 -0
- package/dist/subagent-registry.runtime.js +1 -1
- package/dist/subagent-spawn-EXtecXVT.js +1005 -0
- package/dist/system-cli-CFS_PN8R.js +59 -0
- package/dist/targets-BXWH2MfM.js +67 -0
- package/dist/task-executor-DfugjJEq.js +360 -0
- package/dist/task-owner-access-CSwIy-v-.js +74 -0
- package/dist/task-registry-B-kQGKt_.js +2366 -0
- package/dist/task-registry-delivery-runtime-DD1_7xUF.js +3 -0
- package/dist/task-registry-delivery-runtime-DIsasFa1.js +2 -0
- package/dist/task-registry.maintenance-CxAx195T.js +2 -0
- package/dist/task-registry.maintenance-DIFuNnzy.js +416 -0
- package/dist/telegram/token.js +1 -1
- package/dist/testing-C7oUBiZL.js +575 -0
- package/dist/text-report-hYiQ_Kcv.js +587 -0
- package/dist/tool-resolution-CnnOHyxg.js +90 -0
- package/dist/tools-effective-inventory-DqYXIS6R.js +152 -0
- package/dist/tools-invoke-http-zop5qWa_.js +206 -0
- package/dist/trash-DZRlsk_R.js +24 -0
- package/dist/tui-cli-2cKXF0J8.js +4575 -0
- package/dist/update-cli-DP1KXasM.js +1759 -0
- package/dist/upgrade-DPFxH2YB.js +1226 -0
- package/dist/video-generation-task-status-BEgeadFu.js +163 -0
- package/dist/wait-for-idle-before-flush-CmSNfAco.js +5986 -0
- package/dist/wizard-models-BJGn0RnU.js +161 -0
- package/package.json +1 -1
- package/dist/abort-ca8hDmJr.js +0 -201
- package/dist/abort.runtime-BrChEuUS.js +0 -2
- package/dist/accounts-C1ECKXaw.js +0 -107
- package/dist/accounts-DH8HU_Fu.js +0 -104
- package/dist/accounts-DWQpG06j.js +0 -2
- package/dist/acp-cli-BLpWVnc7.js +0 -2193
- package/dist/acp-spawn-D1p6b1gk.js +0 -2
- package/dist/acp-spawn-qoyl9NiU.js +0 -1093
- package/dist/acp-stateful-target-driver-NL9txhIM.js +0 -89
- package/dist/action-agents-C729fJ_P.js +0 -67
- package/dist/action-focus-53k9XP4K.js +0 -132
- package/dist/action-help-bIJZBYLz.js +0 -7
- package/dist/action-info-BBzvYFX_.js +0 -101
- package/dist/action-kill-C4fa3E9I.js +0 -33
- package/dist/action-list-BEiIbwP1.js +0 -21
- package/dist/action-log-Cq7RLW2T.js +0 -30
- package/dist/action-send-DyiHgRwh.js +0 -39
- package/dist/action-spawn-CEZfDvXU.js +0 -47
- package/dist/action-unfocus-CpAw3JOi.js +0 -29
- package/dist/actions.runtime-BKEwPyo7.js +0 -18
- package/dist/actions.runtime-Bp0UusIf.js +0 -5
- package/dist/agent-C2hwJefQ.js +0 -2
- package/dist/agent-command-BAAeGRql.js +0 -874
- package/dist/agent-harness-runtime-Czrx53YL.js +0 -144
- package/dist/agent-runner-utils-DzShckNa.js +0 -239
- package/dist/agent-runner.runtime-d_EtNxBK.js +0 -3455
- package/dist/agent-runtime-DNgz7AOP.js +0 -18
- package/dist/agents-CZmpon7q.js +0 -5
- package/dist/agents-Cs9je_gQ.js +0 -953
- package/dist/aliases-CZemdpTj.js +0 -2
- package/dist/aliases-KefnmoaT.js +0 -96
- package/dist/api-CO05iXNH.js +0 -139
- package/dist/api-CyjlApHT.js +0 -3
- package/dist/api-DArm1ECd.js +0 -5
- package/dist/approval-gateway-resolver-URpDQMld.js +0 -29
- package/dist/approval-gateway-runtime-B087BMms.js +0 -2
- package/dist/approval-handler-runtime-BgRQnG4g.js +0 -439
- package/dist/approval-native-runtime-DAsraihr.js +0 -729
- package/dist/attempt-execution.runtime-D_FGkDQz.js +0 -509
- package/dist/attempt.prompt-helpers-CDzDUi1C.js +0 -221
- package/dist/attempt.tool-run-context-DitxaTPJ.js +0 -933
- package/dist/audit-Bq8vlxok.js +0 -939
- package/dist/audit.runtime-CU42yh1v.js +0 -7
- package/dist/auth-CQfwC-AH.js +0 -383
- package/dist/auth-DyWcaG4X.js +0 -2
- package/dist/auth-order-C3zGI0s9.js +0 -96
- package/dist/auth-order-XQ9ZGPd9.js +0 -2
- package/dist/bash-tools-BBRtIa6j.js +0 -2824
- package/dist/bash-tools-BI0d1TdC.js +0 -3
- package/dist/binding-routing-Cvm5c1IV.js +0 -85
- package/dist/binding-targets-DSs4NXbd.js +0 -121
- package/dist/bridge-server-CwWzSgv8.js +0 -113
- package/dist/browser-control-auth-y1f-9HRI.js +0 -2
- package/dist/browser-node-runtime-3UAeP8a6.js +0 -12
- package/dist/browser-profiles-BzzxphNW.js +0 -2
- package/dist/browser-runtime-jj11LR-E.js +0 -387
- package/dist/browser-setup-tools-CFB52yQc.js +0 -13
- package/dist/build-TlobwpQW.js +0 -550
- package/dist/call-Bx8lENb2.js +0 -3
- package/dist/call-jYRpeAWm.js +0 -331
- package/dist/call.runtime-BRluUZbD.js +0 -2
- package/dist/capability-cli-Iyj9Zi3g.js +0 -1401
- package/dist/catchup-CtxTwzY8.js +0 -300
- package/dist/channel-BJKHBfnq.js +0 -491
- package/dist/channel-BNNnYzwK.js +0 -1100
- package/dist/channel-BXS-Hd8p.js +0 -226
- package/dist/channel-C4XWpowe.js +0 -1174
- package/dist/channel-CJQdQgPr.js +0 -840
- package/dist/channel-C_zWAu4D.js +0 -595
- package/dist/channel-CtGzrF-K.js +0 -1802
- package/dist/channel-O9DE4IIq.js +0 -350
- package/dist/channel-WHUOtJme.js +0 -297
- package/dist/channel-WoDWDxqx.js +0 -1320
- package/dist/channel-core-BJjq9SOq.js +0 -5
- package/dist/channel-inbound-DLs-YfUs.js +0 -31
- package/dist/channel-plugin-runtime-CMG8ac2K.js +0 -771
- package/dist/channel-runtime-4UjeDmDI.js +0 -425
- package/dist/channel-ys2FFqi1.js +0 -453
- package/dist/channel.runtime-B38Ky3R9.js +0 -109
- package/dist/channel.runtime-Bl8WYZvF.js +0 -576
- package/dist/channel.runtime-D3kAsCsR.js +0 -89
- package/dist/channel.runtime-DEQ-anMf.js +0 -2364
- package/dist/channel.runtime-DG-EUnSC.js +0 -4
- package/dist/channel.runtime-IfV1Md6p.js +0 -430
- package/dist/channel.runtime-w1tHjTOa.js +0 -34702
- package/dist/channel.setup-dXwiMlyi.js +0 -10
- package/dist/channels-B2G1Y-iD.js +0 -733
- package/dist/channels-cli-YintLKAt.js +0 -268
- package/dist/chat-DdKbu8CA.js +0 -2758
- package/dist/clawbot-cli-CnHERFYk.js +0 -9
- package/dist/cli-CSNAd6Sz.js +0 -72
- package/dist/cli-CdRioBfN.js +0 -2
- package/dist/cli-DMPwqYqc.js +0 -219
- package/dist/cli-ctyAqh0j.js +0 -2
- package/dist/cli-runner-CNlk7xmx.js +0 -286
- package/dist/cli-runner.runtime-BK4sQk1m.js +0 -3
- package/dist/cli-runner.runtime-BT8ZZn-R.js +0 -4
- package/dist/cli.runtime-DU7swpBI.js +0 -1261
- package/dist/client-CQdcTPUf.js +0 -138
- package/dist/client-Vx7pseEY.js +0 -713
- package/dist/command-auth-DkJWb2HE.js +0 -76
- package/dist/command-config-resolution-CIRWRfR8.js +0 -23
- package/dist/command-config-resolution-DYZWj6Zm.js +0 -2
- package/dist/command-config-resolution.runtime-CUtVJOf0.js +0 -2
- package/dist/command-registry-CHy5EH0v.js +0 -4
- package/dist/command-registry-CyKgELQP.js +0 -9
- package/dist/command-registry-core-DQeRIuot.js +0 -104
- package/dist/command-secret-gateway-BNnWdAlq.js +0 -528
- package/dist/command-status.runtime-CKgimR6Y.js +0 -87
- package/dist/commands-acp-DSm97O5v.js +0 -77
- package/dist/commands-compact.runtime-BXhP6WJ6.js +0 -10
- package/dist/commands-handlers.runtime-FzK-n0L8.js +0 -4597
- package/dist/commands-status-BQnB5OSX.js +0 -16
- package/dist/commands-status.runtime-B6GcfEDm.js +0 -3
- package/dist/commands-subagents-control.runtime-CByd528A.js +0 -2
- package/dist/commands-subagents-control.runtime-CqI4LMYa.js +0 -3
- package/dist/commands-system-prompt-BD_LeeZk.js +0 -2
- package/dist/commands-system-prompt-C2Md_Ia1.js +0 -158
- package/dist/commands.runtime-CwiPf7Cc.js +0 -166
- package/dist/compact-B_4bMVpw.js +0 -1118
- package/dist/compact.runtime-BhRqiBXG.js +0 -12
- package/dist/completion-cli-D07hGGMI.js +0 -313
- package/dist/config-B1lvYOd7.js +0 -251
- package/dist/config-cli-BgepNwob.js +0 -1078
- package/dist/configure-CEfl0ORM.js +0 -2
- package/dist/configure-TsykzQqM.js +0 -1245
- package/dist/connect-options-zqTIEl6K.js +0 -699
- package/dist/control-auth-CNa_KHpo.js +0 -125
- package/dist/control-service-CZl5wFdZ.js +0 -156
- package/dist/conversation-id-BLY9ffjm.js +0 -38
- package/dist/conversation-id-DVeOM5Jh.js +0 -235
- package/dist/conversation-runtime-gJt7AAg2.js +0 -31
- package/dist/core-BtmNtOpS.js +0 -275
- package/dist/cron-cli-s9SF4__G.js +0 -713
- package/dist/daemon-cli-TCubZfI_.js +0 -12
- package/dist/delegate-DyITI93V.js +0 -64
- package/dist/detached-task-runtime-CTUQj84i.js +0 -73
- package/dist/devices-cli-SXcLjGmh.js +0 -496
- package/dist/diagnostics-waSemGnZ.js +0 -154
- package/dist/direct-dm-CiSjkmkL.js +0 -64
- package/dist/dispatch-BnQSIx2G.js +0 -1131
- package/dist/dispatch-acp-CaNQyl2L.js +0 -981
- package/dist/dispatch-acp-manager.runtime-DJK1eHYX.js +0 -3
- package/dist/dispatch-acp.runtime-Bl5cvtX4.js +0 -19
- package/dist/doctor-device-pairing-DBhEA-8G.js +0 -307
- package/dist/doctor-gateway-daemon-flow-Ds47Er3Y.js +0 -250
- package/dist/doctor-gateway-health-EWwTw5JR.js +0 -60
- package/dist/doctor-health-C6muRn7t.js +0 -59
- package/dist/doctor-health-contributions-B984415a.js +0 -486
- package/dist/doctor-prompter-BpOi4ndi.js +0 -56
- package/dist/doctor-workspace-status-CiEWZXrx.js +0 -75
- package/dist/dreaming-DFPenC85.js +0 -1574
- package/dist/dreaming-narrative-6A27_Gft.js +0 -595
- package/dist/embedded-gateway-stub.runtime-UVgfXZzk.js +0 -9
- package/dist/exec-approvals-cli-Cc_GG9ZT.js +0 -498
- package/dist/fallbacks-DX4YcmAx.js +0 -2
- package/dist/fallbacks-inTaaG-m.js +0 -31
- package/dist/fallbacks-shared-ow1la-U2.js +0 -111
- package/dist/gateway-D4iWwu3_.js +0 -115
- package/dist/gateway-cli-D6j0Aj3R.js +0 -1325
- package/dist/gateway-rpc-Dd_x2GX5.js +0 -14
- package/dist/gateway-rpc.runtime-Btnvsv-7.js +0 -23
- package/dist/gateway-runtime-DctMRv_p.js +0 -15
- package/dist/gateway-status-DJCtvUVn.js +0 -584
- package/dist/genesis-tools-CvMcpUvH.js +0 -8999
- package/dist/genesis-tools.runtime-Ch3NDEDq.js +0 -2
- package/dist/get-reply-Cm39MCyU.js +0 -3879
- package/dist/get-reply-from-config.runtime-CSqCYatb.js +0 -2
- package/dist/graph-users-BJxYqA3A.js +0 -1337
- package/dist/health-C14jIilQ.js +0 -469
- package/dist/health-C6yJSCMc.js +0 -3
- package/dist/heartbeat-runner-C6-gFnyC.js +0 -5
- package/dist/heartbeat-runner-yUYjgzIM.js +0 -1292
- package/dist/heartbeat-runner.runtime-DZzyrUNB.js +0 -4
- package/dist/hooks-cli-CCRaHheu.js +0 -433
- package/dist/image-fallbacks-BH9qLbBG.js +0 -31
- package/dist/image-fallbacks-DUOPO1ic.js +0 -2
- package/dist/inbound-reply-dispatch-DPf_IrbV.js +0 -73
- package/dist/infra-runtime-CLND6LJ0.js +0 -39
- package/dist/init-CzWob-9v.js +0 -59
- package/dist/library-C0a9Bz2M.js +0 -45
- package/dist/lifecycle-B_B_jt3r.js +0 -571
- package/dist/lifecycle-DuqKKZop.js +0 -229
- package/dist/lifecycle.runtime-DoosWTnK.js +0 -2
- package/dist/list-Bly8XeOF.js +0 -2
- package/dist/list-C5HvtbwZ.js +0 -2
- package/dist/list-CHIiamt1.js +0 -131
- package/dist/list-CMmJiacX.js +0 -1201
- package/dist/list.probe-kmHRFlrP.js +0 -419
- package/dist/llm-slug-generator-C3u6Ptgq.js +0 -79
- package/dist/load-config-CXvIGI7N.js +0 -35
- package/dist/local-dispatch.runtime-BNQF4rqW.js +0 -8
- package/dist/logs-cli-DEy1GPk2.js +0 -265
- package/dist/logs-cli.runtime-jWShKzQC.js +0 -2
- package/dist/main-session-restart-recovery-CzfY6Cd8.js +0 -206
- package/dist/managed-image-attachments-BGPKA7Mn.js +0 -2
- package/dist/managed-image-attachments-CTrq9ym-.js +0 -635
- package/dist/manager-C_ZGa9x8.js +0 -2057
- package/dist/manager-DIHLRzYF.js +0 -2
- package/dist/markdown-to-line-CRbbXtJK.js +0 -790
- package/dist/mcp-cli-FMJb3T4k.js +0 -725
- package/dist/mcp-http-b6UMoE_J.js +0 -529
- package/dist/memory-core-host-runtime-cli-CquxELNj.js +0 -9
- package/dist/message-CmjuvIFf.js +0 -232
- package/dist/message-action-runner-CiY3rhqt.js +0 -1407
- package/dist/message-action-runner-Do4P0h5i.js +0 -2
- package/dist/message-actions-BYREqFJA.js +0 -143
- package/dist/message.gateway.runtime-gkoWzaYV.js +0 -2
- package/dist/models-auth-status-B_Pcr0tl.js +0 -201
- package/dist/models-cli-BZSuW2gw.js +0 -219
- package/dist/monitor-22LY8y6z.js +0 -788
- package/dist/monitor-BZdf_CEm.js +0 -1237
- package/dist/monitor-CTVDlTs2.js +0 -671
- package/dist/monitor-Cfv-KGAl.js +0 -1661
- package/dist/monitor-DuA69-8E.js +0 -2
- package/dist/monitor-auth-BNDlfcw7.js +0 -207
- package/dist/monitor-cmWeDVxf.js +0 -1459
- package/dist/monitor-processing-D9Xcsagt.js +0 -1974
- package/dist/monitor.runtime-zWvcbNim.js +0 -2
- package/dist/monitor.webhook-BYWQa5lY.js +0 -180
- package/dist/msteams-n9HDT4O-.js +0 -35
- package/dist/native-hook-relay-CKyIfLOm.js +0 -519
- package/dist/nextcloud-talk-BuJVVP0J.js +0 -17
- package/dist/node-cli-DBK2TIEH.js +0 -2506
- package/dist/nodes-cli-D5Y1_ZVD.js +0 -1046
- package/dist/nodes-utils-C6IKaTjm.js +0 -84
- package/dist/nodes.helpers-CkJO5i0d.js +0 -34
- package/dist/notify-v0zoiI-O.js +0 -315
- package/dist/onboard-BCaLBJor.js +0 -632
- package/dist/onboard-helpers-Ba7ES7kB.js +0 -204
- package/dist/onboard-helpers-D5qdyBIj.js +0 -6
- package/dist/onboard-remote-BaHm_VrY.js +0 -2
- package/dist/onboard-remote-DbGAo_Ad.js +0 -193
- package/dist/onboard-skills-BA7c4li1.js +0 -2
- package/dist/onboard-skills-upyHp6T9.js +0 -134
- package/dist/openai-http-DwCqhEcX.js +0 -500
- package/dist/openresponses-http-tJr67vC1.js +0 -1128
- package/dist/operator-approvals-client-C0t_-2xC.js +0 -68
- package/dist/outbound.runtime-nXA4k1xA.js +0 -2
- package/dist/pair-command-approve-G5y-rKn9.js +0 -44
- package/dist/persistent-bindings.lifecycle-C56aKBVc.js +0 -2
- package/dist/persistent-bindings.lifecycle-CfBqvz9L.js +0 -85
- package/dist/pi-embedded-B1wvxHXL.js +0 -2905
- package/dist/pi-embedded-DmDb-oUB.js +0 -4
- package/dist/pi-embedded.runtime-D5xqw9Ko.js +0 -4
- package/dist/pi-tool-definition-adapter-CAxlo-Va.js +0 -217
- package/dist/pi-tools-C69yvznf.js +0 -1057
- package/dist/pi-tools.before-tool-call-BDeCmoAy.js +0 -2
- package/dist/pi-tools.before-tool-call-DG7VVNBn.js +0 -433
- package/dist/plugin-B9Ld0CUs.js +0 -12195
- package/dist/plugin-enabled-BguUplCN.js +0 -140
- package/dist/plugin-registration-DPBnSoak.js +0 -23
- package/dist/plugin-service-CdNFnRyN.js +0 -2890
- package/dist/policy-DgfegT_Y.js +0 -328
- package/dist/prepare.runtime-C_sRmuFC.js +0 -815
- package/dist/probe-8vb_Ssot.js +0 -45
- package/dist/probe-BjmKFiz1.js +0 -2205
- package/dist/probe-CVlOo8Hr.js +0 -74
- package/dist/probe-CakOsrSu.js +0 -241
- package/dist/probe-CbOoVumf.js +0 -2
- package/dist/probe-D6yFcZpK.js +0 -1443
- package/dist/probe-OcOYm1bj.js +0 -2
- package/dist/program-BJnTb7UE.js +0 -111
- package/dist/prompt-select-styled-C8kGHNpY.js +0 -20
- package/dist/protocol-C40iRm9c.js +0 -2234
- package/dist/provider-dispatcher-BIOPYzb9.js +0 -2
- package/dist/provider-dispatcher-CpwviX0O.js +0 -22
- package/dist/qr-cli-CJXKCj0L.js +0 -2
- package/dist/qr-cli-kSU9X-N0.js +0 -349
- package/dist/reaction-runtime-api-3XFmruJA.js +0 -116
- package/dist/reactions-By-nqZC6.js +0 -998
- package/dist/register-service-commands-fwB-T6mW.js +0 -71
- package/dist/register.agent-CpScU3CV.js +0 -248
- package/dist/register.configure-DpD3_BCK.js +0 -15
- package/dist/register.maintenance-ByoQXpk9.js +0 -438
- package/dist/register.message-BTXNOZMD.js +0 -329
- package/dist/register.onboard-B83CAOYy.js +0 -81
- package/dist/register.runtime-Doz01zcH.js +0 -81
- package/dist/register.setup-BKI5rwWy.js +0 -150
- package/dist/register.status-health-sessions-DRPszDQ-.js +0 -1215
- package/dist/register.subclis-DeXklyQL.js +0 -3
- package/dist/register.subclis-YkmoZoxl.js +0 -29
- package/dist/register.subclis-core-BPo4hV1Q.js +0 -243
- package/dist/reply-dispatch-runtime-DjIuN_dr.js +0 -13
- package/dist/reply-runtime-5TFidLR3.js +0 -11
- package/dist/reply.runtime-6d1e0INl.js +0 -2
- package/dist/restart-health-BWUPc4R-.js +0 -202
- package/dist/restart-health-CWvsjHVN.js +0 -2
- package/dist/root-help-D2YiFpS6.js +0 -44
- package/dist/routes-BdYdVpe7.js +0 -3341
- package/dist/routes-jYoN_qOU.js +0 -2
- package/dist/rpc-5tMjebZH.js +0 -61
- package/dist/rpc.runtime-BzAHjcm4.js +0 -21
- package/dist/run-delivery.runtime-qZIB76oE.js +0 -530
- package/dist/run-embedded.runtime-nHunVmCv.js +0 -4
- package/dist/run-execution-cli.runtime-CMT7La6D.js +0 -4
- package/dist/run-executor.runtime-BG6SDi3f.js +0 -277
- package/dist/run-main-CNf_LLX7.js +0 -516
- package/dist/run-subagent-registry.runtime-D0RcqcJr.js +0 -2
- package/dist/run-wait--kou3jZ7.js +0 -135
- package/dist/runtime-BvxkGJm2.js +0 -9
- package/dist/runtime-DgQ5oUKq.js +0 -973
- package/dist/runtime-api-6SzMK-FZ.js +0 -4
- package/dist/runtime-api-BAMrcB-5.js +0 -9
- package/dist/runtime-api-DLSrxS5O.js +0 -9
- package/dist/runtime-api-DsPleWQg.js +0 -14
- package/dist/runtime-embedded-pi.runtime-eyjaJfAz.js +0 -2
- package/dist/runtime-internal-BTfGDlHi.js +0 -2
- package/dist/runtime-options-B5_eZxMV.js +0 -275
- package/dist/runtime-schema-BB3QzGXJ.js +0 -27780
- package/dist/scan-D0fsxqed.js +0 -2
- package/dist/scan-DrjjN66Z.js +0 -523
- package/dist/secrets-cli-B7-qbfn-.js +0 -2101
- package/dist/security-cli-CYTPgL67.js +0 -486
- package/dist/selection-DEAdLh1Q.js +0 -2
- package/dist/selection-zPPyzfBX.js +0 -7736
- package/dist/send-CYKfZTCJ.js +0 -156
- package/dist/send-Di1tRwJD.js +0 -102
- package/dist/send.runtime-Bw22DBkL.js +0 -2
- package/dist/server-BIF5dPI_.js +0 -13
- package/dist/server-BJK0Q4xw.js +0 -77
- package/dist/server-context-CiVVCQNp.js +0 -847
- package/dist/server-context-DXvk5Tdy.js +0 -2
- package/dist/server-node-events-CdZP3Kok.js +0 -481
- package/dist/server-plugin-bootstrap-Di15EOt4.js +0 -11333
- package/dist/server-plugin-bootstrap-dboO44LL.js +0 -2
- package/dist/server-restart-sentinel-BWiOzljY.js +0 -697
- package/dist/server.impl-Ph8YCQpT.js +0 -12734
- package/dist/session-kill-http-B_J1fJ4-.js +0 -110
- package/dist/session-reset-service-DPgw70iw.js +0 -471
- package/dist/session-route-B0h6MEyB.js +0 -93
- package/dist/session-status.runtime-DCvgI1pG.js +0 -2
- package/dist/session-subagent-reactivation.runtime-BgsCnI-h.js +0 -2
- package/dist/session-tab-registry-FyN6CWh5.js +0 -491
- package/dist/session-visibility-CZjMA1SL.js +0 -147
- package/dist/sessions-helpers-B3W7MdIb.js +0 -304
- package/dist/sessions-history-http-Bw5J6HQ-.js +0 -383
- package/dist/sessions-patch-2sBcHc9a.js +0 -309
- package/dist/sessions-resolve-C-VZh_56.js +0 -174
- package/dist/sessions.runtime-cLuc67tJ.js +0 -2
- package/dist/setup-FW8xH-S-.js +0 -495
- package/dist/setup-api-Culp0Usf.js +0 -29
- package/dist/setup-core-CaTBS6Tz.js +0 -171
- package/dist/setup-core-youmXvW_.js +0 -176
- package/dist/setup-surface-BeMn-9hU.js +0 -403
- package/dist/setup-surface-CUd-s0wh.js +0 -286
- package/dist/setup-surface-DtscjAY3.js +0 -219
- package/dist/setup.finalize-BWyA4f4q.js +0 -539
- package/dist/setup.gateway-config-CvzMdftA.js +0 -250
- package/dist/shared-B3Pz1Xcr.js +0 -121
- package/dist/shared-Bc3x3THS.js +0 -76
- package/dist/shared-CxbLx0Ww.js +0 -198
- package/dist/slash-state-XfeMEeuI.js +0 -1911
- package/dist/src-BiDxQvtV.js +0 -3974
- package/dist/startup-context-CXQi-7YB.js +0 -312
- package/dist/status-Ch3bm70K.js +0 -2
- package/dist/status-CiQSxvY-.js +0 -3
- package/dist/status-DY0DlWlw.js +0 -190
- package/dist/status-DjdByQv-.js +0 -209
- package/dist/status-MT62_Jgw.js +0 -2
- package/dist/status-all-BD2viQD9.js +0 -498
- package/dist/status-json-CWS2oYON.js +0 -14
- package/dist/status-json-command-B6lZefoe.js +0 -84
- package/dist/status-pujDHwRb.js +0 -397
- package/dist/status-runtime-shared-Bu9Zhd7x.js +0 -257
- package/dist/status-subagents.runtime-B4UXD0lL.js +0 -18
- package/dist/status-text-myqmk4OL.js +0 -237
- package/dist/status.gateway-connection.runtime-B0Iwl2iZ.js +0 -2
- package/dist/status.gather-C51Ja0wP.js +0 -292
- package/dist/status.gather-DQ7WZp3H.js +0 -2
- package/dist/status.runtime-Cxyb3wHZ.js +0 -2
- package/dist/status.scan-C1aqDsy2.js +0 -65
- package/dist/status.scan-overview-BerlJz2l.js +0 -379
- package/dist/status.scan.fast-json-BXY82vu2.js +0 -2
- package/dist/status.scan.fast-json-DJqgEbzZ.js +0 -132
- package/dist/status.summary-CCdLUph8.js +0 -214
- package/dist/status.summary-CHAn0_FS.js +0 -2
- package/dist/subagent-announce-D4jG75Ub.js +0 -351
- package/dist/subagent-announce-delivery-BkQYzDcy.js +0 -726
- package/dist/subagent-announce-output-C3pkuu-t.js +0 -364
- package/dist/subagent-control-DVVK8du2.js +0 -506
- package/dist/subagent-followup.runtime-CdeweG-S.js +0 -68
- package/dist/subagent-orphan-recovery-ZQanOHb4.js +0 -305
- package/dist/subagent-registry-BcPa3ho0.js +0 -3
- package/dist/subagent-registry-hJUso5eL.js +0 -1753
- package/dist/subagent-spawn-DTaeQc9q.js +0 -1005
- package/dist/system-cli-CT8VaSDY.js +0 -59
- package/dist/targets-BPdSjnQH.js +0 -67
- package/dist/task-executor-B62Qzfi-.js +0 -360
- package/dist/task-owner-access-BBMrMOlN.js +0 -74
- package/dist/task-registry-BD-ew2bT.js +0 -2366
- package/dist/task-registry-delivery-runtime-B2WyGY0d.js +0 -3
- package/dist/task-registry-delivery-runtime-MFJszOHI.js +0 -2
- package/dist/task-registry.maintenance-0D2Yxl49.js +0 -416
- package/dist/task-registry.maintenance-OPlfB5W9.js +0 -2
- package/dist/testing-DmxZ16UC.js +0 -575
- package/dist/text-report-BwIpU54R.js +0 -587
- package/dist/tool-resolution-vn72hwMo.js +0 -90
- package/dist/tools-effective-inventory-DII_pOSr.js +0 -152
- package/dist/tools-invoke-http-DdthGR52.js +0 -206
- package/dist/trash-BVZu6rU7.js +0 -24
- package/dist/tui-cli-Bz51WCAi.js +0 -4575
- package/dist/update-cli-DkH8vHQP.js +0 -1759
- package/dist/upgrade-Dvj8K4WB.js +0 -1226
- package/dist/video-generation-task-status-CHYB_IeZ.js +0 -163
- package/dist/wait-for-idle-before-flush-DJMxeE2X.js +0 -5986
- package/dist/wizard-models-BNQQ7fvr.js +0 -161
package/dist/monitor-Cfv-KGAl.js
DELETED
|
@@ -1,1661 +0,0 @@
|
|
|
1
|
-
import { c as normalizeOptionalString, r as lowercasePreservingWhitespace } from "./string-coerce-C1IzJjqi.js";
|
|
2
|
-
import { t as createNonExitingRuntime } from "./runtime-CQ7eH0le.js";
|
|
3
|
-
import { a as shouldLogVerbose, r as logVerbose, t as danger } from "./globals-C5IxqXPj.js";
|
|
4
|
-
import { a as loadConfig } from "./io-h8M_Z0Lj.js";
|
|
5
|
-
import { a as normalizePluginHttpPath } from "./http-route-overlap-C_DiJ-_J.js";
|
|
6
|
-
import { m as resolveSendableOutboundReplyParts } from "./reply-payload-ChFsXpe2.js";
|
|
7
|
-
import { t as buildRandomTempFilePath } from "./temp-download-6i8PZNjx.js";
|
|
8
|
-
import { r as chunkMarkdownText } from "./chunk-CMvONy3a.js";
|
|
9
|
-
import { i as resolveAgentRoute } from "./resolve-route-BA6bCR3F.js";
|
|
10
|
-
import "./text-runtime-7KpTTpVi.js";
|
|
11
|
-
import "./routing-lEBa2-AE.js";
|
|
12
|
-
import { t as hasControlCommand } from "./command-detection--wYDcLgI.js";
|
|
13
|
-
import { t as finalizeInboundContext } from "./inbound-context-DcpIc6mh.js";
|
|
14
|
-
import { r as formatInboundEnvelope } from "./envelope-C1lEhRFw.js";
|
|
15
|
-
import { n as buildMentionRegexes, r as matchesMentionPatterns } from "./mentions-Dm5IQz51.js";
|
|
16
|
-
import { t as dispatchReplyWithBufferedBlockDispatcher } from "./provider-dispatcher-CpwviX0O.js";
|
|
17
|
-
import { n as resolveControlCommandGate } from "./command-gating-BnQtRLCi.js";
|
|
18
|
-
import { n as resolveInboundMentionDecision } from "./mention-gating-C2K3rSdY.js";
|
|
19
|
-
import { t as recordInboundSession } from "./session-DgdrHsUH.js";
|
|
20
|
-
import { n as recordChannelActivity } from "./channel-activity-DqxQNED1.js";
|
|
21
|
-
import { a as readChannelAllowFromStore, d as upsertChannelPairingRequest } from "./pairing-store-DI7znxyK.js";
|
|
22
|
-
import { n as isSenderIdAllowed, r as mergeDmAllowFromSources, t as firstDefined } from "./allow-from-B05EJfJr.js";
|
|
23
|
-
import { a as warnMissingProviderGroupPolicyFallbackOnce, n as resolveAllowlistProviderRuntimeGroupPolicy, r as resolveDefaultGroupPolicy } from "./runtime-group-policy-CX-BIMex.js";
|
|
24
|
-
import { n as evaluateMatchedGroupAccessForPolicy } from "./group-access-DnyCrhTl.js";
|
|
25
|
-
import { c as resolvePinnedMainDmOwnerFromAllowlist } from "./dm-policy-shared-CWi7ZZgc.js";
|
|
26
|
-
import { s as clearHistoryEntriesIfEnabled, u as recordPendingHistoryEntryIfEnabled } from "./history-XG_CXCAa.js";
|
|
27
|
-
import "./reply-history-BBCEOSzW.js";
|
|
28
|
-
import { t as createChannelReplyPipeline } from "./channel-reply-pipeline-BgPhKdUO.js";
|
|
29
|
-
import { t as createChannelPairingChallengeIssuer } from "./channel-pairing-B3r45ANt.js";
|
|
30
|
-
import { a as isRequestBodyLimitError, c as requestBodyErrorToText, s as readRequestBodyWithLimit } from "./http-body-DDG39e3E.js";
|
|
31
|
-
import { a as createWebhookInFlightLimiter, i as beginWebhookRequestPipelineOrReject } from "./webhook-request-guards-D4zAmS4Z.js";
|
|
32
|
-
import { t as registerPluginHttpRoute } from "./http-registry-H4nrRWJL.js";
|
|
33
|
-
import "./webhook-ingress-BET_Iso7.js";
|
|
34
|
-
import { t as waitForAbortSignal } from "./abort-signal-BF5LQl9w.js";
|
|
35
|
-
import "./runtime-env-6Wx5-zP8.js";
|
|
36
|
-
import "./config-runtime-Dr1JoMKQ.js";
|
|
37
|
-
import "./reply-runtime-5TFidLR3.js";
|
|
38
|
-
import "./reply-dispatch-runtime-DjIuN_dr.js";
|
|
39
|
-
import "./infra-runtime-CLND6LJ0.js";
|
|
40
|
-
import { n as resolveConfiguredBindingRoute, r as resolveRuntimeConversationBindingRoute, t as ensureConfiguredBindingRouteReady } from "./binding-routing-Cvm5c1IV.js";
|
|
41
|
-
import "./conversation-runtime-gJt7AAg2.js";
|
|
42
|
-
import { t as resolvePairingIdLabel } from "./pairing-labels-BpsUT7f4.js";
|
|
43
|
-
import "./command-auth-DkJWb2HE.js";
|
|
44
|
-
import "./channel-inbound-DLs-YfUs.js";
|
|
45
|
-
import { n as toLocationContext, t as formatLocationText } from "./location-U0wbh3pT.js";
|
|
46
|
-
import { t as resolveInboundSessionEnvelopeContext } from "./session-envelope-DdJGLsph.js";
|
|
47
|
-
import { t as createClaimableDedupe } from "./persistent-dedupe-BTyTh8iP.js";
|
|
48
|
-
import { i as resolveLineAccount, r as resolveDefaultLineAccountId } from "./accounts-C1ECKXaw.js";
|
|
49
|
-
import { n as resolveLineGroupConfigEntry } from "./group-keys-BIByIJoY.js";
|
|
50
|
-
import { D as showLoadingAnimation, S as pushMessagesLine, T as replyMessageLine, c as processLineMessage, d as createImageMessage, f as createLocationMessage, g as getUserDisplayName, k as buildTemplateMessageFromPayload, m as createTextMessageWithQuickReplies, p as createQuickReplyItems, u as createFlexMessage, w as pushTextMessageWithQuickReplies, x as pushMessageLine } from "./markdown-to-line-CRbbXtJK.js";
|
|
51
|
-
import { i as mergeHeaders, n as HTTPFetchClient, r as convertResponseToReadable } from "./messagingApiClient-D5t5u7Gk.js";
|
|
52
|
-
import fs from "node:fs";
|
|
53
|
-
import crypto from "node:crypto";
|
|
54
|
-
//#region extensions/line/src/bot-access.ts
|
|
55
|
-
function normalizeAllowEntry(value) {
|
|
56
|
-
const trimmed = String(value).trim();
|
|
57
|
-
if (!trimmed) return "";
|
|
58
|
-
if (trimmed === "*") return "*";
|
|
59
|
-
return trimmed.replace(/^line:(?:user:)?/i, "");
|
|
60
|
-
}
|
|
61
|
-
const normalizeAllowFrom = (list) => {
|
|
62
|
-
const entries = (list ?? []).map((value) => normalizeAllowEntry(value)).filter(Boolean);
|
|
63
|
-
return {
|
|
64
|
-
entries,
|
|
65
|
-
hasWildcard: entries.includes("*"),
|
|
66
|
-
hasEntries: entries.length > 0
|
|
67
|
-
};
|
|
68
|
-
};
|
|
69
|
-
const normalizeDmAllowFromWithStore = (params) => normalizeAllowFrom(mergeDmAllowFromSources(params));
|
|
70
|
-
const isSenderAllowed = (params) => {
|
|
71
|
-
const { allow, senderId } = params;
|
|
72
|
-
return isSenderIdAllowed(allow, senderId, false);
|
|
73
|
-
};
|
|
74
|
-
//#endregion
|
|
75
|
-
//#region node_modules/@line/bot-sdk/dist/messaging-api/api/messagingApiBlobClient.js
|
|
76
|
-
/**
|
|
77
|
-
* LINE Messaging API
|
|
78
|
-
* This document describes LINE Messaging API.
|
|
79
|
-
*
|
|
80
|
-
* The version of the OpenAPI document: 0.0.1
|
|
81
|
-
*
|
|
82
|
-
*
|
|
83
|
-
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
|
|
84
|
-
* https://openapi-generator.tech
|
|
85
|
-
* Do not edit the class manually.
|
|
86
|
-
*/
|
|
87
|
-
/**
|
|
88
|
-
* @see {@link LineBotClient} for a unified interface that wraps this client.
|
|
89
|
-
*/
|
|
90
|
-
var MessagingApiBlobClient = class {
|
|
91
|
-
httpClient;
|
|
92
|
-
constructor(config) {
|
|
93
|
-
const baseURL = config.baseURL || "https://api-data.line.me";
|
|
94
|
-
const defaultHeaders = mergeHeaders(config.defaultHeaders, { Authorization: "Bearer " + config.channelAccessToken });
|
|
95
|
-
this.httpClient = new HTTPFetchClient({
|
|
96
|
-
defaultHeaders,
|
|
97
|
-
baseURL
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
/**
|
|
101
|
-
* Download image, video, and audio data sent from users.
|
|
102
|
-
* @param messageId Message ID of video or audio
|
|
103
|
-
*
|
|
104
|
-
* @see <a href="https://developers.line.biz/en/reference/messaging-api/#get-content"> Documentation</a>
|
|
105
|
-
*/
|
|
106
|
-
async getMessageContent(messageId) {
|
|
107
|
-
return (await this.getMessageContentWithHttpInfo(messageId)).body;
|
|
108
|
-
}
|
|
109
|
-
/**
|
|
110
|
-
* Download image, video, and audio data sent from users..
|
|
111
|
-
* This method includes HttpInfo object to return additional information.
|
|
112
|
-
* @param messageId Message ID of video or audio
|
|
113
|
-
*
|
|
114
|
-
* @see <a href="https://developers.line.biz/en/reference/messaging-api/#get-content"> Documentation</a>
|
|
115
|
-
*/
|
|
116
|
-
async getMessageContentWithHttpInfo(messageId) {
|
|
117
|
-
const response = await this.httpClient.get("/v2/bot/message/{messageId}/content".replace("{messageId}", String(messageId)));
|
|
118
|
-
return {
|
|
119
|
-
httpResponse: response,
|
|
120
|
-
body: convertResponseToReadable(response)
|
|
121
|
-
};
|
|
122
|
-
}
|
|
123
|
-
/**
|
|
124
|
-
* Get a preview image of the image or video
|
|
125
|
-
* @param messageId Message ID of image or video
|
|
126
|
-
*
|
|
127
|
-
* @see <a href="https://developers.line.biz/en/reference/messaging-api/#get-image-or-video-preview"> Documentation</a>
|
|
128
|
-
*/
|
|
129
|
-
async getMessageContentPreview(messageId) {
|
|
130
|
-
return (await this.getMessageContentPreviewWithHttpInfo(messageId)).body;
|
|
131
|
-
}
|
|
132
|
-
/**
|
|
133
|
-
* Get a preview image of the image or video.
|
|
134
|
-
* This method includes HttpInfo object to return additional information.
|
|
135
|
-
* @param messageId Message ID of image or video
|
|
136
|
-
*
|
|
137
|
-
* @see <a href="https://developers.line.biz/en/reference/messaging-api/#get-image-or-video-preview"> Documentation</a>
|
|
138
|
-
*/
|
|
139
|
-
async getMessageContentPreviewWithHttpInfo(messageId) {
|
|
140
|
-
const response = await this.httpClient.get("/v2/bot/message/{messageId}/content/preview".replace("{messageId}", String(messageId)));
|
|
141
|
-
return {
|
|
142
|
-
httpResponse: response,
|
|
143
|
-
body: convertResponseToReadable(response)
|
|
144
|
-
};
|
|
145
|
-
}
|
|
146
|
-
/**
|
|
147
|
-
* Verify the preparation status of a video or audio for getting
|
|
148
|
-
* @param messageId Message ID of video or audio
|
|
149
|
-
*
|
|
150
|
-
* @see <a href="https://developers.line.biz/en/reference/messaging-api/#verify-video-or-audio-preparation-status"> Documentation</a>
|
|
151
|
-
*/
|
|
152
|
-
async getMessageContentTranscodingByMessageId(messageId) {
|
|
153
|
-
return (await this.getMessageContentTranscodingByMessageIdWithHttpInfo(messageId)).body;
|
|
154
|
-
}
|
|
155
|
-
/**
|
|
156
|
-
* Verify the preparation status of a video or audio for getting.
|
|
157
|
-
* This method includes HttpInfo object to return additional information.
|
|
158
|
-
* @param messageId Message ID of video or audio
|
|
159
|
-
*
|
|
160
|
-
* @see <a href="https://developers.line.biz/en/reference/messaging-api/#verify-video-or-audio-preparation-status"> Documentation</a>
|
|
161
|
-
*/
|
|
162
|
-
async getMessageContentTranscodingByMessageIdWithHttpInfo(messageId) {
|
|
163
|
-
const res = await this.httpClient.get("/v2/bot/message/{messageId}/content/transcoding".replace("{messageId}", String(messageId)));
|
|
164
|
-
const text = await res.text();
|
|
165
|
-
return {
|
|
166
|
-
httpResponse: res,
|
|
167
|
-
body: text ? JSON.parse(text) : null
|
|
168
|
-
};
|
|
169
|
-
}
|
|
170
|
-
/**
|
|
171
|
-
* Download rich menu image.
|
|
172
|
-
* @param richMenuId ID of the rich menu with the image to be downloaded
|
|
173
|
-
*
|
|
174
|
-
* @see <a href="https://developers.line.biz/en/reference/messaging-api/#download-rich-menu-image"> Documentation</a>
|
|
175
|
-
*/
|
|
176
|
-
async getRichMenuImage(richMenuId) {
|
|
177
|
-
return (await this.getRichMenuImageWithHttpInfo(richMenuId)).body;
|
|
178
|
-
}
|
|
179
|
-
/**
|
|
180
|
-
* Download rich menu image..
|
|
181
|
-
* This method includes HttpInfo object to return additional information.
|
|
182
|
-
* @param richMenuId ID of the rich menu with the image to be downloaded
|
|
183
|
-
*
|
|
184
|
-
* @see <a href="https://developers.line.biz/en/reference/messaging-api/#download-rich-menu-image"> Documentation</a>
|
|
185
|
-
*/
|
|
186
|
-
async getRichMenuImageWithHttpInfo(richMenuId) {
|
|
187
|
-
const response = await this.httpClient.get("/v2/bot/richmenu/{richMenuId}/content".replace("{richMenuId}", String(richMenuId)));
|
|
188
|
-
return {
|
|
189
|
-
httpResponse: response,
|
|
190
|
-
body: convertResponseToReadable(response)
|
|
191
|
-
};
|
|
192
|
-
}
|
|
193
|
-
/**
|
|
194
|
-
* Upload rich menu image
|
|
195
|
-
* @param richMenuId The ID of the rich menu to attach the image to
|
|
196
|
-
* @param body
|
|
197
|
-
*
|
|
198
|
-
* @see <a href="https://developers.line.biz/en/reference/messaging-api/#upload-rich-menu-image"> Documentation</a>
|
|
199
|
-
*/
|
|
200
|
-
async setRichMenuImage(richMenuId, body) {
|
|
201
|
-
return (await this.setRichMenuImageWithHttpInfo(richMenuId, body)).body;
|
|
202
|
-
}
|
|
203
|
-
/**
|
|
204
|
-
* Upload rich menu image.
|
|
205
|
-
* This method includes HttpInfo object to return additional information.
|
|
206
|
-
* @param richMenuId The ID of the rich menu to attach the image to
|
|
207
|
-
* @param body
|
|
208
|
-
*
|
|
209
|
-
* @see <a href="https://developers.line.biz/en/reference/messaging-api/#upload-rich-menu-image"> Documentation</a>
|
|
210
|
-
*/
|
|
211
|
-
async setRichMenuImageWithHttpInfo(richMenuId, body) {
|
|
212
|
-
const params = body;
|
|
213
|
-
const res = await this.httpClient.postBinaryContent("/v2/bot/richmenu/{richMenuId}/content".replace("{richMenuId}", String(richMenuId)), params);
|
|
214
|
-
const text = await res.text();
|
|
215
|
-
return {
|
|
216
|
-
httpResponse: res,
|
|
217
|
-
body: text ? JSON.parse(text) : null
|
|
218
|
-
};
|
|
219
|
-
}
|
|
220
|
-
};
|
|
221
|
-
//#endregion
|
|
222
|
-
//#region extensions/line/src/download.ts
|
|
223
|
-
const AUDIO_BRANDS = new Set([
|
|
224
|
-
"m4a ",
|
|
225
|
-
"m4b ",
|
|
226
|
-
"m4p ",
|
|
227
|
-
"m4r ",
|
|
228
|
-
"f4a ",
|
|
229
|
-
"f4b "
|
|
230
|
-
]);
|
|
231
|
-
async function downloadLineMedia(messageId, channelAccessToken, maxBytes = 10 * 1024 * 1024) {
|
|
232
|
-
const response = await new MessagingApiBlobClient({ channelAccessToken }).getMessageContent(messageId);
|
|
233
|
-
const chunks = [];
|
|
234
|
-
let totalSize = 0;
|
|
235
|
-
for await (const chunk of response) {
|
|
236
|
-
totalSize += chunk.length;
|
|
237
|
-
if (totalSize > maxBytes) throw new Error(`Media exceeds ${Math.round(maxBytes / (1024 * 1024))}MB limit`);
|
|
238
|
-
chunks.push(chunk);
|
|
239
|
-
}
|
|
240
|
-
const buffer = Buffer.concat(chunks);
|
|
241
|
-
const contentType = detectContentType(buffer);
|
|
242
|
-
const filePath = buildRandomTempFilePath({
|
|
243
|
-
prefix: "line-media",
|
|
244
|
-
extension: getExtensionForContentType(contentType)
|
|
245
|
-
});
|
|
246
|
-
await fs.promises.writeFile(filePath, buffer);
|
|
247
|
-
logVerbose(`line: downloaded media ${messageId} to ${filePath} (${buffer.length} bytes)`);
|
|
248
|
-
return {
|
|
249
|
-
path: filePath,
|
|
250
|
-
contentType,
|
|
251
|
-
size: buffer.length
|
|
252
|
-
};
|
|
253
|
-
}
|
|
254
|
-
function detectContentType(buffer) {
|
|
255
|
-
const hasFtypBox = buffer.length >= 12 && buffer[4] === 102 && buffer[5] === 116 && buffer[6] === 121 && buffer[7] === 112;
|
|
256
|
-
if (buffer.length >= 2) {
|
|
257
|
-
if (buffer[0] === 255 && buffer[1] === 216) return "image/jpeg";
|
|
258
|
-
if (buffer[0] === 137 && buffer[1] === 80 && buffer[2] === 78 && buffer[3] === 71) return "image/png";
|
|
259
|
-
if (buffer[0] === 71 && buffer[1] === 73 && buffer[2] === 70) return "image/gif";
|
|
260
|
-
if (buffer[0] === 82 && buffer[1] === 73 && buffer[2] === 70 && buffer[3] === 70 && buffer[8] === 87 && buffer[9] === 69 && buffer[10] === 66 && buffer[11] === 80) return "image/webp";
|
|
261
|
-
if (hasFtypBox) {
|
|
262
|
-
const majorBrand = lowercasePreservingWhitespace(buffer.toString("ascii", 8, 12));
|
|
263
|
-
if (AUDIO_BRANDS.has(majorBrand)) return "audio/mp4";
|
|
264
|
-
return "video/mp4";
|
|
265
|
-
}
|
|
266
|
-
}
|
|
267
|
-
return "application/octet-stream";
|
|
268
|
-
}
|
|
269
|
-
function getExtensionForContentType(contentType) {
|
|
270
|
-
switch (contentType) {
|
|
271
|
-
case "image/jpeg": return ".jpg";
|
|
272
|
-
case "image/png": return ".png";
|
|
273
|
-
case "image/gif": return ".gif";
|
|
274
|
-
case "image/webp": return ".webp";
|
|
275
|
-
case "video/mp4": return ".mp4";
|
|
276
|
-
case "audio/mp4": return ".m4a";
|
|
277
|
-
case "audio/mpeg": return ".mp3";
|
|
278
|
-
default: return ".bin";
|
|
279
|
-
}
|
|
280
|
-
}
|
|
281
|
-
//#endregion
|
|
282
|
-
//#region extensions/line/src/auto-reply-delivery.ts
|
|
283
|
-
async function deliverLineAutoReply(params) {
|
|
284
|
-
const { payload, lineData, replyToken, accountId, to, textLimit, deps } = params;
|
|
285
|
-
let replyTokenUsed = params.replyTokenUsed;
|
|
286
|
-
const pushLineMessages = async (messages) => {
|
|
287
|
-
if (messages.length === 0) return;
|
|
288
|
-
for (let i = 0; i < messages.length; i += 5) await deps.pushMessagesLine(to, messages.slice(i, i + 5), {
|
|
289
|
-
cfg: params.cfg,
|
|
290
|
-
accountId
|
|
291
|
-
});
|
|
292
|
-
};
|
|
293
|
-
const sendLineMessages = async (messages, allowReplyToken) => {
|
|
294
|
-
if (messages.length === 0) return;
|
|
295
|
-
let remaining = messages;
|
|
296
|
-
if (allowReplyToken && replyToken && !replyTokenUsed) {
|
|
297
|
-
const replyBatch = remaining.slice(0, 5);
|
|
298
|
-
try {
|
|
299
|
-
await deps.replyMessageLine(replyToken, replyBatch, {
|
|
300
|
-
cfg: params.cfg,
|
|
301
|
-
accountId
|
|
302
|
-
});
|
|
303
|
-
} catch (err) {
|
|
304
|
-
deps.onReplyError?.(err);
|
|
305
|
-
await pushLineMessages(replyBatch);
|
|
306
|
-
}
|
|
307
|
-
replyTokenUsed = true;
|
|
308
|
-
remaining = remaining.slice(replyBatch.length);
|
|
309
|
-
}
|
|
310
|
-
if (remaining.length > 0) await pushLineMessages(remaining);
|
|
311
|
-
};
|
|
312
|
-
const richMessages = [];
|
|
313
|
-
const hasQuickReplies = Boolean(lineData.quickReplies?.length);
|
|
314
|
-
if (lineData.flexMessage) richMessages.push(deps.createFlexMessage(lineData.flexMessage.altText.slice(0, 400), lineData.flexMessage.contents));
|
|
315
|
-
if (lineData.templateMessage) {
|
|
316
|
-
const templateMsg = deps.buildTemplateMessageFromPayload(lineData.templateMessage);
|
|
317
|
-
if (templateMsg) richMessages.push(templateMsg);
|
|
318
|
-
}
|
|
319
|
-
if (lineData.location) richMessages.push(deps.createLocationMessage(lineData.location));
|
|
320
|
-
const processed = payload.text ? deps.processLineMessage(payload.text) : {
|
|
321
|
-
text: "",
|
|
322
|
-
flexMessages: []
|
|
323
|
-
};
|
|
324
|
-
for (const flexMsg of processed.flexMessages) richMessages.push(deps.createFlexMessage(flexMsg.altText.slice(0, 400), flexMsg.contents));
|
|
325
|
-
const chunks = processed.text ? deps.chunkMarkdownText(processed.text, textLimit) : [];
|
|
326
|
-
const mediaMessages = resolveSendableOutboundReplyParts(payload).mediaUrls.map((url) => url?.trim()).filter((url) => Boolean(url)).map((url) => deps.createImageMessage(url));
|
|
327
|
-
if (chunks.length > 0) {
|
|
328
|
-
const hasRichOrMedia = richMessages.length > 0 || mediaMessages.length > 0;
|
|
329
|
-
if (hasQuickReplies && hasRichOrMedia) try {
|
|
330
|
-
await sendLineMessages([...richMessages, ...mediaMessages], false);
|
|
331
|
-
} catch (err) {
|
|
332
|
-
deps.onReplyError?.(err);
|
|
333
|
-
}
|
|
334
|
-
const { replyTokenUsed: nextReplyTokenUsed } = await deps.sendLineReplyChunks({
|
|
335
|
-
to,
|
|
336
|
-
chunks,
|
|
337
|
-
quickReplies: lineData.quickReplies,
|
|
338
|
-
replyToken,
|
|
339
|
-
replyTokenUsed,
|
|
340
|
-
cfg: params.cfg,
|
|
341
|
-
accountId,
|
|
342
|
-
replyMessageLine: deps.replyMessageLine,
|
|
343
|
-
pushMessageLine: deps.pushMessageLine,
|
|
344
|
-
pushTextMessageWithQuickReplies: deps.pushTextMessageWithQuickReplies,
|
|
345
|
-
createTextMessageWithQuickReplies: deps.createTextMessageWithQuickReplies
|
|
346
|
-
});
|
|
347
|
-
replyTokenUsed = nextReplyTokenUsed;
|
|
348
|
-
if (!hasQuickReplies || !hasRichOrMedia) {
|
|
349
|
-
await sendLineMessages(richMessages, false);
|
|
350
|
-
if (mediaMessages.length > 0) await sendLineMessages(mediaMessages, false);
|
|
351
|
-
}
|
|
352
|
-
} else {
|
|
353
|
-
const combined = [...richMessages, ...mediaMessages];
|
|
354
|
-
if (hasQuickReplies && combined.length > 0) {
|
|
355
|
-
const quickReply = deps.createQuickReplyItems(lineData.quickReplies);
|
|
356
|
-
const targetIndex = replyToken && !replyTokenUsed ? Math.min(4, combined.length - 1) : combined.length - 1;
|
|
357
|
-
combined[targetIndex] = {
|
|
358
|
-
...combined[targetIndex],
|
|
359
|
-
quickReply
|
|
360
|
-
};
|
|
361
|
-
}
|
|
362
|
-
await sendLineMessages(combined, true);
|
|
363
|
-
}
|
|
364
|
-
return { replyTokenUsed };
|
|
365
|
-
}
|
|
366
|
-
//#endregion
|
|
367
|
-
//#region extensions/line/src/bot-message-context.ts
|
|
368
|
-
function getLineSourceInfo(source) {
|
|
369
|
-
if (!source) return {
|
|
370
|
-
userId: void 0,
|
|
371
|
-
groupId: void 0,
|
|
372
|
-
roomId: void 0,
|
|
373
|
-
isGroup: false
|
|
374
|
-
};
|
|
375
|
-
return {
|
|
376
|
-
userId: source.type === "user" ? source.userId : source.type === "group" ? source.userId : source.type === "room" ? source.userId : void 0,
|
|
377
|
-
groupId: source.type === "group" ? source.groupId : void 0,
|
|
378
|
-
roomId: source.type === "room" ? source.roomId : void 0,
|
|
379
|
-
isGroup: source.type === "group" || source.type === "room"
|
|
380
|
-
};
|
|
381
|
-
}
|
|
382
|
-
function buildPeerId(source) {
|
|
383
|
-
if (!source) return "unknown";
|
|
384
|
-
const groupKey = normalizeOptionalString(source.type === "group" ? source.groupId : void 0) ?? normalizeOptionalString(source.type === "room" ? source.roomId : void 0);
|
|
385
|
-
if (groupKey) return groupKey;
|
|
386
|
-
if (source.type === "user" && source.userId) return source.userId;
|
|
387
|
-
return "unknown";
|
|
388
|
-
}
|
|
389
|
-
async function resolveLineInboundRoute(params) {
|
|
390
|
-
recordChannelActivity({
|
|
391
|
-
channel: "line",
|
|
392
|
-
accountId: params.account.accountId,
|
|
393
|
-
direction: "inbound"
|
|
394
|
-
});
|
|
395
|
-
const { userId, groupId, roomId, isGroup } = getLineSourceInfo(params.source);
|
|
396
|
-
const peerId = buildPeerId(params.source);
|
|
397
|
-
let route = resolveAgentRoute({
|
|
398
|
-
cfg: params.cfg,
|
|
399
|
-
channel: "line",
|
|
400
|
-
accountId: params.account.accountId,
|
|
401
|
-
peer: {
|
|
402
|
-
kind: isGroup ? "group" : "direct",
|
|
403
|
-
id: peerId
|
|
404
|
-
}
|
|
405
|
-
});
|
|
406
|
-
const configuredRoute = resolveConfiguredBindingRoute({
|
|
407
|
-
cfg: params.cfg,
|
|
408
|
-
route,
|
|
409
|
-
conversation: {
|
|
410
|
-
channel: "line",
|
|
411
|
-
accountId: params.account.accountId,
|
|
412
|
-
conversationId: peerId
|
|
413
|
-
}
|
|
414
|
-
});
|
|
415
|
-
let configuredBinding = configuredRoute.bindingResolution;
|
|
416
|
-
const configuredBindingSessionKey = configuredRoute.boundSessionKey ?? "";
|
|
417
|
-
route = configuredRoute.route;
|
|
418
|
-
const runtimeRoute = resolveRuntimeConversationBindingRoute({
|
|
419
|
-
route,
|
|
420
|
-
conversation: {
|
|
421
|
-
channel: "line",
|
|
422
|
-
accountId: params.account.accountId,
|
|
423
|
-
conversationId: peerId
|
|
424
|
-
}
|
|
425
|
-
});
|
|
426
|
-
route = runtimeRoute.route;
|
|
427
|
-
if (runtimeRoute.bindingRecord) {
|
|
428
|
-
configuredBinding = null;
|
|
429
|
-
logVerbose(runtimeRoute.boundSessionKey ? `line: routed via bound conversation ${peerId} -> ${runtimeRoute.boundSessionKey}` : `line: plugin-bound conversation ${peerId}`);
|
|
430
|
-
}
|
|
431
|
-
if (configuredBinding) {
|
|
432
|
-
const ensured = await ensureConfiguredBindingRouteReady({
|
|
433
|
-
cfg: params.cfg,
|
|
434
|
-
bindingResolution: configuredBinding
|
|
435
|
-
});
|
|
436
|
-
if (!ensured.ok) {
|
|
437
|
-
logVerbose(`line: configured ACP binding unavailable for ${peerId} -> ${configuredBindingSessionKey}: ${ensured.error}`);
|
|
438
|
-
throw new Error(`Configured ACP binding unavailable: ${ensured.error}`);
|
|
439
|
-
}
|
|
440
|
-
logVerbose(`line: using configured ACP binding for ${peerId} -> ${configuredBindingSessionKey}`);
|
|
441
|
-
}
|
|
442
|
-
return {
|
|
443
|
-
userId,
|
|
444
|
-
groupId,
|
|
445
|
-
roomId,
|
|
446
|
-
isGroup,
|
|
447
|
-
peerId,
|
|
448
|
-
route
|
|
449
|
-
};
|
|
450
|
-
}
|
|
451
|
-
const STICKER_PACKAGES = {
|
|
452
|
-
"1": "Moon & James",
|
|
453
|
-
"2": "Cony & Brown",
|
|
454
|
-
"3": "Brown & Friends",
|
|
455
|
-
"4": "Moon Special",
|
|
456
|
-
"789": "LINE Characters",
|
|
457
|
-
"6136": "Cony's Happy Life",
|
|
458
|
-
"6325": "Brown's Life",
|
|
459
|
-
"6359": "Choco",
|
|
460
|
-
"6362": "Sally",
|
|
461
|
-
"6370": "Edward",
|
|
462
|
-
"11537": "Cony",
|
|
463
|
-
"11538": "Brown",
|
|
464
|
-
"11539": "Moon"
|
|
465
|
-
};
|
|
466
|
-
function describeStickerKeywords(sticker) {
|
|
467
|
-
const keywords = sticker.keywords;
|
|
468
|
-
if (keywords && keywords.length > 0) return keywords.slice(0, 3).join(", ");
|
|
469
|
-
const stickerText = sticker.text;
|
|
470
|
-
if (stickerText) return stickerText;
|
|
471
|
-
return "";
|
|
472
|
-
}
|
|
473
|
-
function extractMessageText(message) {
|
|
474
|
-
if (message.type === "text") return message.text;
|
|
475
|
-
if (message.type === "location") {
|
|
476
|
-
const loc = message;
|
|
477
|
-
return formatLocationText({
|
|
478
|
-
latitude: loc.latitude,
|
|
479
|
-
longitude: loc.longitude,
|
|
480
|
-
name: loc.title,
|
|
481
|
-
address: loc.address
|
|
482
|
-
}) ?? "";
|
|
483
|
-
}
|
|
484
|
-
if (message.type === "sticker") {
|
|
485
|
-
const sticker = message;
|
|
486
|
-
const packageName = STICKER_PACKAGES[sticker.packageId] ?? "sticker";
|
|
487
|
-
const keywords = describeStickerKeywords(sticker);
|
|
488
|
-
if (keywords) return `[Sent a ${packageName} sticker: ${keywords}]`;
|
|
489
|
-
return `[Sent a ${packageName} sticker]`;
|
|
490
|
-
}
|
|
491
|
-
return "";
|
|
492
|
-
}
|
|
493
|
-
function extractMediaPlaceholder(message) {
|
|
494
|
-
switch (message.type) {
|
|
495
|
-
case "image": return "<media:image>";
|
|
496
|
-
case "video": return "<media:video>";
|
|
497
|
-
case "audio": return "<media:audio>";
|
|
498
|
-
case "file": return "<media:document>";
|
|
499
|
-
default: return "";
|
|
500
|
-
}
|
|
501
|
-
}
|
|
502
|
-
function resolveLineConversationLabel(params) {
|
|
503
|
-
return params.isGroup ? params.groupId ? `group:${params.groupId}` : params.roomId ? `room:${params.roomId}` : "unknown-group" : params.senderLabel;
|
|
504
|
-
}
|
|
505
|
-
function resolveLineAddresses(params) {
|
|
506
|
-
const fromAddress = params.isGroup ? params.groupId ? `line:group:${params.groupId}` : params.roomId ? `line:room:${params.roomId}` : `line:${params.peerId}` : `line:${params.userId ?? params.peerId}`;
|
|
507
|
-
return {
|
|
508
|
-
fromAddress,
|
|
509
|
-
toAddress: params.isGroup ? fromAddress : `line:${params.userId ?? params.peerId}`,
|
|
510
|
-
originatingTo: params.isGroup ? fromAddress : `line:${params.userId ?? params.peerId}`
|
|
511
|
-
};
|
|
512
|
-
}
|
|
513
|
-
async function finalizeLineInboundContext(params) {
|
|
514
|
-
const { fromAddress, toAddress, originatingTo } = resolveLineAddresses({
|
|
515
|
-
isGroup: params.source.isGroup,
|
|
516
|
-
groupId: params.source.groupId,
|
|
517
|
-
roomId: params.source.roomId,
|
|
518
|
-
userId: params.source.userId,
|
|
519
|
-
peerId: params.source.peerId
|
|
520
|
-
});
|
|
521
|
-
const senderId = params.source.userId ?? "unknown";
|
|
522
|
-
const senderLabel = params.source.userId ? `user:${params.source.userId}` : "unknown";
|
|
523
|
-
const conversationLabel = resolveLineConversationLabel({
|
|
524
|
-
isGroup: params.source.isGroup,
|
|
525
|
-
groupId: params.source.groupId,
|
|
526
|
-
roomId: params.source.roomId,
|
|
527
|
-
senderLabel
|
|
528
|
-
});
|
|
529
|
-
const { storePath, envelopeOptions, previousTimestamp } = resolveInboundSessionEnvelopeContext({
|
|
530
|
-
cfg: params.cfg,
|
|
531
|
-
agentId: params.route.agentId,
|
|
532
|
-
sessionKey: params.route.sessionKey
|
|
533
|
-
});
|
|
534
|
-
const body = formatInboundEnvelope({
|
|
535
|
-
channel: "LINE",
|
|
536
|
-
from: conversationLabel,
|
|
537
|
-
timestamp: params.timestamp,
|
|
538
|
-
body: params.rawBody,
|
|
539
|
-
chatType: params.source.isGroup ? "group" : "direct",
|
|
540
|
-
sender: { id: senderId },
|
|
541
|
-
previousTimestamp,
|
|
542
|
-
envelope: envelopeOptions
|
|
543
|
-
});
|
|
544
|
-
const ctxPayload = finalizeInboundContext({
|
|
545
|
-
Body: body,
|
|
546
|
-
BodyForAgent: params.rawBody,
|
|
547
|
-
RawBody: params.rawBody,
|
|
548
|
-
CommandBody: params.rawBody,
|
|
549
|
-
From: fromAddress,
|
|
550
|
-
To: toAddress,
|
|
551
|
-
SessionKey: params.route.sessionKey,
|
|
552
|
-
AccountId: params.route.accountId,
|
|
553
|
-
ChatType: params.source.isGroup ? "group" : "direct",
|
|
554
|
-
ConversationLabel: conversationLabel,
|
|
555
|
-
GroupSubject: params.source.isGroup ? params.source.groupId ?? params.source.roomId : void 0,
|
|
556
|
-
SenderId: senderId,
|
|
557
|
-
Provider: "line",
|
|
558
|
-
Surface: "line",
|
|
559
|
-
MessageSid: params.messageSid,
|
|
560
|
-
Timestamp: params.timestamp,
|
|
561
|
-
MediaPath: params.media.firstPath,
|
|
562
|
-
MediaType: params.media.firstContentType,
|
|
563
|
-
MediaUrl: params.media.firstPath,
|
|
564
|
-
MediaPaths: params.media.paths,
|
|
565
|
-
MediaUrls: params.media.paths,
|
|
566
|
-
MediaTypes: params.media.types,
|
|
567
|
-
...params.locationContext,
|
|
568
|
-
CommandAuthorized: params.commandAuthorized,
|
|
569
|
-
OriginatingChannel: "line",
|
|
570
|
-
OriginatingTo: originatingTo,
|
|
571
|
-
GroupSystemPrompt: params.source.isGroup ? normalizeOptionalString(resolveLineGroupConfigEntry(params.account.config.groups, {
|
|
572
|
-
groupId: params.source.groupId,
|
|
573
|
-
roomId: params.source.roomId
|
|
574
|
-
})?.systemPrompt) : void 0,
|
|
575
|
-
InboundHistory: params.inboundHistory
|
|
576
|
-
});
|
|
577
|
-
const pinnedMainDmOwner = !params.source.isGroup ? resolvePinnedMainDmOwnerFromAllowlist({
|
|
578
|
-
dmScope: params.cfg.session?.dmScope,
|
|
579
|
-
allowFrom: params.account.config.allowFrom,
|
|
580
|
-
normalizeEntry: (entry) => normalizeAllowFrom([entry]).entries[0]
|
|
581
|
-
}) : null;
|
|
582
|
-
await recordInboundSession({
|
|
583
|
-
storePath,
|
|
584
|
-
sessionKey: ctxPayload.SessionKey ?? params.route.sessionKey,
|
|
585
|
-
ctx: ctxPayload,
|
|
586
|
-
updateLastRoute: !params.source.isGroup ? {
|
|
587
|
-
sessionKey: params.route.mainSessionKey,
|
|
588
|
-
channel: "line",
|
|
589
|
-
to: params.source.userId ?? params.source.peerId,
|
|
590
|
-
accountId: params.route.accountId,
|
|
591
|
-
mainDmOwnerPin: pinnedMainDmOwner && params.source.userId ? {
|
|
592
|
-
ownerRecipient: pinnedMainDmOwner,
|
|
593
|
-
senderRecipient: params.source.userId,
|
|
594
|
-
onSkip: ({ ownerRecipient, senderRecipient }) => {
|
|
595
|
-
logVerbose(`line: skip main-session last route for ${senderRecipient} (pinned owner ${ownerRecipient})`);
|
|
596
|
-
}
|
|
597
|
-
} : void 0
|
|
598
|
-
} : void 0,
|
|
599
|
-
onRecordError: (err) => {
|
|
600
|
-
logVerbose(`line: failed updating session meta: ${String(err)}`);
|
|
601
|
-
}
|
|
602
|
-
});
|
|
603
|
-
if (shouldLogVerbose()) {
|
|
604
|
-
const preview = body.slice(0, 200).replace(/\n/g, "\\n");
|
|
605
|
-
const mediaInfo = params.verboseLog.kind === "inbound" && (params.verboseLog.mediaCount ?? 0) > 1 ? ` mediaCount=${params.verboseLog.mediaCount}` : "";
|
|
606
|
-
logVerbose(`${params.verboseLog.kind === "inbound" ? "line inbound" : "line postback"}: from=${ctxPayload.From} len=${body.length}${mediaInfo} preview="${preview}"`);
|
|
607
|
-
}
|
|
608
|
-
return {
|
|
609
|
-
ctxPayload,
|
|
610
|
-
replyToken: params.event.replyToken
|
|
611
|
-
};
|
|
612
|
-
}
|
|
613
|
-
async function buildLineMessageContext(params) {
|
|
614
|
-
const { event, allMedia, cfg, account, commandAuthorized, groupHistories, historyLimit } = params;
|
|
615
|
-
const source = event.source;
|
|
616
|
-
const { userId, groupId, roomId, isGroup, peerId, route } = await resolveLineInboundRoute({
|
|
617
|
-
source,
|
|
618
|
-
cfg,
|
|
619
|
-
account
|
|
620
|
-
});
|
|
621
|
-
const message = event.message;
|
|
622
|
-
const messageId = message.id;
|
|
623
|
-
const timestamp = event.timestamp;
|
|
624
|
-
const textContent = extractMessageText(message);
|
|
625
|
-
const placeholder = extractMediaPlaceholder(message);
|
|
626
|
-
let rawBody = textContent || placeholder;
|
|
627
|
-
if (!rawBody && allMedia.length > 0) rawBody = `<media:image>${allMedia.length > 1 ? ` (${allMedia.length} images)` : ""}`;
|
|
628
|
-
if (!rawBody && allMedia.length === 0) return null;
|
|
629
|
-
let locationContext;
|
|
630
|
-
if (message.type === "location") {
|
|
631
|
-
const loc = message;
|
|
632
|
-
locationContext = toLocationContext({
|
|
633
|
-
latitude: loc.latitude,
|
|
634
|
-
longitude: loc.longitude,
|
|
635
|
-
name: loc.title,
|
|
636
|
-
address: loc.address
|
|
637
|
-
});
|
|
638
|
-
}
|
|
639
|
-
const historyKey = isGroup ? peerId : void 0;
|
|
640
|
-
const inboundHistory = historyKey && groupHistories && (historyLimit ?? 0) > 0 ? (groupHistories.get(historyKey) ?? []).map((entry) => ({
|
|
641
|
-
sender: entry.sender,
|
|
642
|
-
body: entry.body,
|
|
643
|
-
timestamp: entry.timestamp
|
|
644
|
-
})) : void 0;
|
|
645
|
-
const { ctxPayload } = await finalizeLineInboundContext({
|
|
646
|
-
cfg,
|
|
647
|
-
account,
|
|
648
|
-
event,
|
|
649
|
-
route,
|
|
650
|
-
source: {
|
|
651
|
-
userId,
|
|
652
|
-
groupId,
|
|
653
|
-
roomId,
|
|
654
|
-
isGroup,
|
|
655
|
-
peerId
|
|
656
|
-
},
|
|
657
|
-
rawBody,
|
|
658
|
-
timestamp,
|
|
659
|
-
messageSid: messageId,
|
|
660
|
-
commandAuthorized,
|
|
661
|
-
media: {
|
|
662
|
-
firstPath: allMedia[0]?.path,
|
|
663
|
-
firstContentType: allMedia[0]?.contentType,
|
|
664
|
-
paths: allMedia.length > 0 ? allMedia.map((m) => m.path) : void 0,
|
|
665
|
-
types: allMedia.length > 0 ? allMedia.map((m) => m.contentType).filter(Boolean) : void 0
|
|
666
|
-
},
|
|
667
|
-
locationContext,
|
|
668
|
-
verboseLog: {
|
|
669
|
-
kind: "inbound",
|
|
670
|
-
mediaCount: allMedia.length
|
|
671
|
-
},
|
|
672
|
-
inboundHistory
|
|
673
|
-
});
|
|
674
|
-
return {
|
|
675
|
-
ctxPayload,
|
|
676
|
-
event,
|
|
677
|
-
userId,
|
|
678
|
-
groupId,
|
|
679
|
-
roomId,
|
|
680
|
-
isGroup,
|
|
681
|
-
route,
|
|
682
|
-
replyToken: event.replyToken,
|
|
683
|
-
accountId: account.accountId
|
|
684
|
-
};
|
|
685
|
-
}
|
|
686
|
-
async function buildLinePostbackContext(params) {
|
|
687
|
-
const { event, cfg, account, commandAuthorized } = params;
|
|
688
|
-
const source = event.source;
|
|
689
|
-
const { userId, groupId, roomId, isGroup, peerId, route } = await resolveLineInboundRoute({
|
|
690
|
-
source,
|
|
691
|
-
cfg,
|
|
692
|
-
account
|
|
693
|
-
});
|
|
694
|
-
const timestamp = event.timestamp;
|
|
695
|
-
const rawData = event.postback?.data?.trim() ?? "";
|
|
696
|
-
if (!rawData) return null;
|
|
697
|
-
let rawBody = rawData;
|
|
698
|
-
if (rawData.includes("line.action=")) {
|
|
699
|
-
const searchParams = new URLSearchParams(rawData);
|
|
700
|
-
const action = searchParams.get("line.action") ?? "";
|
|
701
|
-
const device = searchParams.get("line.device");
|
|
702
|
-
rawBody = device ? `line action ${action} device ${device}` : `line action ${action}`;
|
|
703
|
-
}
|
|
704
|
-
const messageSid = event.replyToken ? `postback:${event.replyToken}` : `postback:${timestamp}`;
|
|
705
|
-
const { ctxPayload } = await finalizeLineInboundContext({
|
|
706
|
-
cfg,
|
|
707
|
-
account,
|
|
708
|
-
event,
|
|
709
|
-
route,
|
|
710
|
-
source: {
|
|
711
|
-
userId,
|
|
712
|
-
groupId,
|
|
713
|
-
roomId,
|
|
714
|
-
isGroup,
|
|
715
|
-
peerId
|
|
716
|
-
},
|
|
717
|
-
rawBody,
|
|
718
|
-
timestamp,
|
|
719
|
-
messageSid,
|
|
720
|
-
commandAuthorized,
|
|
721
|
-
media: {
|
|
722
|
-
firstPath: "",
|
|
723
|
-
firstContentType: void 0,
|
|
724
|
-
paths: void 0,
|
|
725
|
-
types: void 0
|
|
726
|
-
},
|
|
727
|
-
verboseLog: { kind: "postback" }
|
|
728
|
-
});
|
|
729
|
-
return {
|
|
730
|
-
ctxPayload,
|
|
731
|
-
event,
|
|
732
|
-
userId,
|
|
733
|
-
groupId,
|
|
734
|
-
roomId,
|
|
735
|
-
isGroup,
|
|
736
|
-
route,
|
|
737
|
-
replyToken: event.replyToken,
|
|
738
|
-
accountId: account.accountId
|
|
739
|
-
};
|
|
740
|
-
}
|
|
741
|
-
//#endregion
|
|
742
|
-
//#region extensions/line/src/bot-handlers.ts
|
|
743
|
-
const LINE_DOWNLOADABLE_MESSAGE_TYPES = new Set([
|
|
744
|
-
"image",
|
|
745
|
-
"video",
|
|
746
|
-
"audio",
|
|
747
|
-
"file"
|
|
748
|
-
]);
|
|
749
|
-
function isDownloadableLineMessageType(messageType) {
|
|
750
|
-
return LINE_DOWNLOADABLE_MESSAGE_TYPES.has(messageType);
|
|
751
|
-
}
|
|
752
|
-
const LINE_WEBHOOK_REPLAY_WINDOW_MS = 600 * 1e3;
|
|
753
|
-
const LINE_WEBHOOK_REPLAY_MAX_ENTRIES = 4096;
|
|
754
|
-
var LineRetryableWebhookError = class extends Error {
|
|
755
|
-
constructor(message, options) {
|
|
756
|
-
super(message, options);
|
|
757
|
-
this.name = "LineRetryableWebhookError";
|
|
758
|
-
}
|
|
759
|
-
};
|
|
760
|
-
function createLineWebhookReplayCache() {
|
|
761
|
-
return createClaimableDedupe({
|
|
762
|
-
ttlMs: LINE_WEBHOOK_REPLAY_WINDOW_MS,
|
|
763
|
-
memoryMaxSize: LINE_WEBHOOK_REPLAY_MAX_ENTRIES
|
|
764
|
-
});
|
|
765
|
-
}
|
|
766
|
-
function buildLineWebhookReplayKey(event, accountId) {
|
|
767
|
-
if (event.type === "message") {
|
|
768
|
-
const messageId = event.message?.id?.trim();
|
|
769
|
-
if (messageId) return {
|
|
770
|
-
key: `${accountId}|message:${messageId}`,
|
|
771
|
-
eventId: `message:${messageId}`
|
|
772
|
-
};
|
|
773
|
-
}
|
|
774
|
-
const eventId = event.webhookEventId?.trim();
|
|
775
|
-
if (!eventId) return null;
|
|
776
|
-
const source = event.source;
|
|
777
|
-
const sourceId = source?.type === "group" ? `group:${source.groupId ?? ""}` : source?.type === "room" ? `room:${source.roomId ?? ""}` : `user:${source?.userId ?? ""}`;
|
|
778
|
-
return {
|
|
779
|
-
key: `${accountId}|${event.type}|${sourceId}|${eventId}`,
|
|
780
|
-
eventId: `event:${eventId}`
|
|
781
|
-
};
|
|
782
|
-
}
|
|
783
|
-
function getLineReplayCandidate(event, context) {
|
|
784
|
-
const replay = buildLineWebhookReplayKey(event, context.account.accountId);
|
|
785
|
-
const cache = context.replayCache;
|
|
786
|
-
if (!replay || !cache) return null;
|
|
787
|
-
return {
|
|
788
|
-
key: replay.key,
|
|
789
|
-
eventId: replay.eventId,
|
|
790
|
-
cache
|
|
791
|
-
};
|
|
792
|
-
}
|
|
793
|
-
async function claimLineReplayEvent(candidate) {
|
|
794
|
-
const claim = await candidate.cache.claim(candidate.key);
|
|
795
|
-
if (claim.kind === "claimed") return { skip: false };
|
|
796
|
-
if (claim.kind === "inflight") {
|
|
797
|
-
logVerbose(`line: skipped in-flight replayed webhook event ${candidate.eventId}`);
|
|
798
|
-
return {
|
|
799
|
-
skip: true,
|
|
800
|
-
inFlightResult: claim.pending.then(() => void 0)
|
|
801
|
-
};
|
|
802
|
-
}
|
|
803
|
-
logVerbose(`line: skipped replayed webhook event ${candidate.eventId}`);
|
|
804
|
-
return { skip: true };
|
|
805
|
-
}
|
|
806
|
-
function resolveLineGroupConfig(params) {
|
|
807
|
-
return resolveLineGroupConfigEntry(params.config.groups, {
|
|
808
|
-
groupId: params.groupId,
|
|
809
|
-
roomId: params.roomId
|
|
810
|
-
});
|
|
811
|
-
}
|
|
812
|
-
async function sendLinePairingReply(params) {
|
|
813
|
-
const { senderId, replyToken, context } = params;
|
|
814
|
-
const idLabel = (() => {
|
|
815
|
-
try {
|
|
816
|
-
return resolvePairingIdLabel("line");
|
|
817
|
-
} catch {
|
|
818
|
-
return "lineUserId";
|
|
819
|
-
}
|
|
820
|
-
})();
|
|
821
|
-
await createChannelPairingChallengeIssuer({
|
|
822
|
-
channel: "line",
|
|
823
|
-
upsertPairingRequest: async ({ id, meta }) => await upsertChannelPairingRequest({
|
|
824
|
-
channel: "line",
|
|
825
|
-
id,
|
|
826
|
-
accountId: context.account.accountId,
|
|
827
|
-
meta
|
|
828
|
-
})
|
|
829
|
-
})({
|
|
830
|
-
senderId,
|
|
831
|
-
senderIdLine: `Your ${idLabel}: ${senderId}`,
|
|
832
|
-
onCreated: () => {
|
|
833
|
-
logVerbose(`line pairing request sender=${senderId}`);
|
|
834
|
-
},
|
|
835
|
-
sendPairingReply: async (text) => {
|
|
836
|
-
if (replyToken) try {
|
|
837
|
-
await replyMessageLine(replyToken, [{
|
|
838
|
-
type: "text",
|
|
839
|
-
text
|
|
840
|
-
}], {
|
|
841
|
-
cfg: context.cfg,
|
|
842
|
-
accountId: context.account.accountId,
|
|
843
|
-
channelAccessToken: context.account.channelAccessToken
|
|
844
|
-
});
|
|
845
|
-
return;
|
|
846
|
-
} catch (err) {
|
|
847
|
-
logVerbose(`line pairing reply failed for ${senderId}: ${String(err)}`);
|
|
848
|
-
}
|
|
849
|
-
try {
|
|
850
|
-
await pushMessageLine(`line:${senderId}`, text, {
|
|
851
|
-
cfg: context.cfg,
|
|
852
|
-
accountId: context.account.accountId,
|
|
853
|
-
channelAccessToken: context.account.channelAccessToken
|
|
854
|
-
});
|
|
855
|
-
} catch (err) {
|
|
856
|
-
logVerbose(`line pairing reply failed for ${senderId}: ${String(err)}`);
|
|
857
|
-
}
|
|
858
|
-
}
|
|
859
|
-
});
|
|
860
|
-
}
|
|
861
|
-
async function shouldProcessLineEvent(event, context) {
|
|
862
|
-
const denied = {
|
|
863
|
-
allowed: false,
|
|
864
|
-
commandAuthorized: false
|
|
865
|
-
};
|
|
866
|
-
const { cfg, account } = context;
|
|
867
|
-
const { userId, groupId, roomId, isGroup } = getLineSourceInfo(event.source);
|
|
868
|
-
const senderId = userId ?? "";
|
|
869
|
-
const dmPolicy = account.config.dmPolicy ?? "pairing";
|
|
870
|
-
const storeAllowFrom = await readChannelAllowFromStore("line", void 0, account.accountId).catch(() => []);
|
|
871
|
-
const effectiveDmAllow = normalizeDmAllowFromWithStore({
|
|
872
|
-
allowFrom: account.config.allowFrom,
|
|
873
|
-
storeAllowFrom,
|
|
874
|
-
dmPolicy
|
|
875
|
-
});
|
|
876
|
-
const groupConfig = resolveLineGroupConfig({
|
|
877
|
-
config: account.config,
|
|
878
|
-
groupId,
|
|
879
|
-
roomId
|
|
880
|
-
});
|
|
881
|
-
const groupAllowOverride = groupConfig?.allowFrom;
|
|
882
|
-
const fallbackGroupAllowFrom = account.config.allowFrom?.length ? account.config.allowFrom : void 0;
|
|
883
|
-
const effectiveGroupAllow = normalizeAllowFrom(firstDefined(groupAllowOverride, account.config.groupAllowFrom, fallbackGroupAllowFrom));
|
|
884
|
-
const defaultGroupPolicy = resolveDefaultGroupPolicy(cfg);
|
|
885
|
-
const { groupPolicy, providerMissingFallbackApplied } = resolveAllowlistProviderRuntimeGroupPolicy({
|
|
886
|
-
providerConfigPresent: cfg.channels?.line !== void 0,
|
|
887
|
-
groupPolicy: account.config.groupPolicy,
|
|
888
|
-
defaultGroupPolicy
|
|
889
|
-
});
|
|
890
|
-
warnMissingProviderGroupPolicyFallbackOnce({
|
|
891
|
-
providerMissingFallbackApplied,
|
|
892
|
-
providerKey: "line",
|
|
893
|
-
accountId: account.accountId,
|
|
894
|
-
log: (message) => logVerbose(message)
|
|
895
|
-
});
|
|
896
|
-
if (isGroup) {
|
|
897
|
-
if (groupConfig?.enabled === false) {
|
|
898
|
-
logVerbose(`Blocked line group ${groupId ?? roomId ?? "unknown"} (group disabled)`);
|
|
899
|
-
return denied;
|
|
900
|
-
}
|
|
901
|
-
if (groupAllowOverride !== void 0) {
|
|
902
|
-
if (!senderId) {
|
|
903
|
-
logVerbose("Blocked line group message (group allowFrom override, no sender ID)");
|
|
904
|
-
return denied;
|
|
905
|
-
}
|
|
906
|
-
if (!isSenderAllowed({
|
|
907
|
-
allow: effectiveGroupAllow,
|
|
908
|
-
senderId
|
|
909
|
-
})) {
|
|
910
|
-
logVerbose(`Blocked line group sender ${senderId} (group allowFrom override)`);
|
|
911
|
-
return denied;
|
|
912
|
-
}
|
|
913
|
-
}
|
|
914
|
-
const senderGroupAccess = evaluateMatchedGroupAccessForPolicy({
|
|
915
|
-
groupPolicy,
|
|
916
|
-
requireMatchInput: true,
|
|
917
|
-
hasMatchInput: Boolean(senderId),
|
|
918
|
-
allowlistConfigured: effectiveGroupAllow.entries.length > 0,
|
|
919
|
-
allowlistMatched: Boolean(senderId) && isSenderAllowed({
|
|
920
|
-
allow: effectiveGroupAllow,
|
|
921
|
-
senderId
|
|
922
|
-
})
|
|
923
|
-
});
|
|
924
|
-
if (!senderGroupAccess.allowed && senderGroupAccess.reason === "disabled") {
|
|
925
|
-
logVerbose("Blocked line group message (groupPolicy: disabled)");
|
|
926
|
-
return denied;
|
|
927
|
-
}
|
|
928
|
-
if (!senderGroupAccess.allowed && senderGroupAccess.reason === "missing_match_input") {
|
|
929
|
-
logVerbose("Blocked line group message (no sender ID, groupPolicy: allowlist)");
|
|
930
|
-
return denied;
|
|
931
|
-
}
|
|
932
|
-
if (!senderGroupAccess.allowed && senderGroupAccess.reason === "empty_allowlist") {
|
|
933
|
-
logVerbose("Blocked line group message (groupPolicy: allowlist, no groupAllowFrom)");
|
|
934
|
-
return denied;
|
|
935
|
-
}
|
|
936
|
-
if (!senderGroupAccess.allowed && senderGroupAccess.reason === "not_allowlisted") {
|
|
937
|
-
logVerbose(`Blocked line group message from ${senderId} (groupPolicy: allowlist)`);
|
|
938
|
-
return denied;
|
|
939
|
-
}
|
|
940
|
-
return {
|
|
941
|
-
allowed: true,
|
|
942
|
-
commandAuthorized: resolveLineCommandAuthorized({
|
|
943
|
-
cfg,
|
|
944
|
-
event,
|
|
945
|
-
senderId,
|
|
946
|
-
allow: effectiveGroupAllow
|
|
947
|
-
})
|
|
948
|
-
};
|
|
949
|
-
}
|
|
950
|
-
if (dmPolicy === "disabled") {
|
|
951
|
-
logVerbose("Blocked line sender (dmPolicy: disabled)");
|
|
952
|
-
return denied;
|
|
953
|
-
}
|
|
954
|
-
if (!(dmPolicy === "open" || isSenderAllowed({
|
|
955
|
-
allow: effectiveDmAllow,
|
|
956
|
-
senderId
|
|
957
|
-
}))) {
|
|
958
|
-
if (dmPolicy === "pairing") {
|
|
959
|
-
if (!senderId) {
|
|
960
|
-
logVerbose("Blocked line sender (dmPolicy: pairing, no sender ID)");
|
|
961
|
-
return denied;
|
|
962
|
-
}
|
|
963
|
-
await sendLinePairingReply({
|
|
964
|
-
senderId,
|
|
965
|
-
replyToken: "replyToken" in event ? event.replyToken : void 0,
|
|
966
|
-
context
|
|
967
|
-
});
|
|
968
|
-
} else logVerbose(`Blocked line sender ${senderId || "unknown"} (dmPolicy: ${dmPolicy})`);
|
|
969
|
-
return denied;
|
|
970
|
-
}
|
|
971
|
-
return {
|
|
972
|
-
allowed: true,
|
|
973
|
-
commandAuthorized: resolveLineCommandAuthorized({
|
|
974
|
-
cfg,
|
|
975
|
-
event,
|
|
976
|
-
senderId,
|
|
977
|
-
allow: effectiveDmAllow
|
|
978
|
-
})
|
|
979
|
-
};
|
|
980
|
-
}
|
|
981
|
-
function getLineMentionees(message) {
|
|
982
|
-
if (message.type !== "text") return [];
|
|
983
|
-
const mentionees = message.mention?.mentionees;
|
|
984
|
-
return Array.isArray(mentionees) ? mentionees : [];
|
|
985
|
-
}
|
|
986
|
-
function isLineBotMentioned(message) {
|
|
987
|
-
return getLineMentionees(message).some((m) => m.isSelf === true || m.type === "all");
|
|
988
|
-
}
|
|
989
|
-
function hasAnyLineMention(message) {
|
|
990
|
-
return getLineMentionees(message).length > 0;
|
|
991
|
-
}
|
|
992
|
-
function resolveEventRawText(event) {
|
|
993
|
-
if (event.type === "message") {
|
|
994
|
-
const msg = event.message;
|
|
995
|
-
if (msg.type === "text") return msg.text;
|
|
996
|
-
return "";
|
|
997
|
-
}
|
|
998
|
-
if (event.type === "postback") return event.postback?.data?.trim() ?? "";
|
|
999
|
-
return "";
|
|
1000
|
-
}
|
|
1001
|
-
function resolveLineCommandAuthorized(params) {
|
|
1002
|
-
const senderAllowedForCommands = isSenderAllowed({
|
|
1003
|
-
allow: params.allow,
|
|
1004
|
-
senderId: params.senderId
|
|
1005
|
-
});
|
|
1006
|
-
const useAccessGroups = params.cfg.commands?.useAccessGroups !== false;
|
|
1007
|
-
const rawText = resolveEventRawText(params.event);
|
|
1008
|
-
return resolveControlCommandGate({
|
|
1009
|
-
useAccessGroups,
|
|
1010
|
-
authorizers: [{
|
|
1011
|
-
configured: params.allow.hasEntries,
|
|
1012
|
-
allowed: senderAllowedForCommands
|
|
1013
|
-
}],
|
|
1014
|
-
allowTextCommands: true,
|
|
1015
|
-
hasControlCommand: hasControlCommand(rawText, params.cfg)
|
|
1016
|
-
}).commandAuthorized;
|
|
1017
|
-
}
|
|
1018
|
-
async function handleMessageEvent(event, context) {
|
|
1019
|
-
const { cfg, account, runtime, mediaMaxBytes, processMessage } = context;
|
|
1020
|
-
const message = event.message;
|
|
1021
|
-
const decision = await shouldProcessLineEvent(event, context);
|
|
1022
|
-
if (!decision.allowed) return;
|
|
1023
|
-
const { isGroup, groupId, roomId } = getLineSourceInfo(event.source);
|
|
1024
|
-
if (isGroup) {
|
|
1025
|
-
const requireMention = resolveLineGroupConfig({
|
|
1026
|
-
config: account.config,
|
|
1027
|
-
groupId,
|
|
1028
|
-
roomId
|
|
1029
|
-
})?.requireMention !== false;
|
|
1030
|
-
const rawText = message.type === "text" ? message.text : "";
|
|
1031
|
-
const sourceInfo = getLineSourceInfo(event.source);
|
|
1032
|
-
const peerId = groupId ?? roomId ?? sourceInfo.userId ?? "unknown";
|
|
1033
|
-
const { agentId } = resolveAgentRoute({
|
|
1034
|
-
cfg,
|
|
1035
|
-
channel: "line",
|
|
1036
|
-
accountId: account.accountId,
|
|
1037
|
-
peer: {
|
|
1038
|
-
kind: "group",
|
|
1039
|
-
id: peerId
|
|
1040
|
-
}
|
|
1041
|
-
});
|
|
1042
|
-
const mentionRegexes = buildMentionRegexes(cfg, agentId);
|
|
1043
|
-
const wasMentionedByNative = isLineBotMentioned(message);
|
|
1044
|
-
const wasMentionedByPattern = message.type === "text" ? matchesMentionPatterns(rawText, mentionRegexes) : false;
|
|
1045
|
-
const wasMentioned = wasMentionedByNative || wasMentionedByPattern;
|
|
1046
|
-
if (resolveInboundMentionDecision({
|
|
1047
|
-
facts: {
|
|
1048
|
-
canDetectMention: message.type === "text",
|
|
1049
|
-
wasMentioned,
|
|
1050
|
-
hasAnyMention: hasAnyLineMention(message),
|
|
1051
|
-
implicitMentionKinds: []
|
|
1052
|
-
},
|
|
1053
|
-
policy: {
|
|
1054
|
-
isGroup: true,
|
|
1055
|
-
requireMention,
|
|
1056
|
-
allowTextCommands: true,
|
|
1057
|
-
hasControlCommand: hasControlCommand(rawText, cfg),
|
|
1058
|
-
commandAuthorized: decision.commandAuthorized
|
|
1059
|
-
}
|
|
1060
|
-
}).shouldSkip) {
|
|
1061
|
-
logVerbose(`line: skipping group message (requireMention, not mentioned)`);
|
|
1062
|
-
const historyKey = groupId ?? roomId;
|
|
1063
|
-
const senderId = sourceInfo.userId ?? "unknown";
|
|
1064
|
-
if (historyKey && context.groupHistories) recordPendingHistoryEntryIfEnabled({
|
|
1065
|
-
historyMap: context.groupHistories,
|
|
1066
|
-
historyKey,
|
|
1067
|
-
limit: context.historyLimit ?? 50,
|
|
1068
|
-
entry: {
|
|
1069
|
-
sender: `user:${senderId}`,
|
|
1070
|
-
body: rawText || `<${message.type}>`,
|
|
1071
|
-
timestamp: event.timestamp
|
|
1072
|
-
}
|
|
1073
|
-
});
|
|
1074
|
-
return;
|
|
1075
|
-
}
|
|
1076
|
-
}
|
|
1077
|
-
const allMedia = [];
|
|
1078
|
-
if (isDownloadableLineMessageType(message.type)) try {
|
|
1079
|
-
const media = await downloadLineMedia(message.id, account.channelAccessToken, mediaMaxBytes);
|
|
1080
|
-
allMedia.push({
|
|
1081
|
-
path: media.path,
|
|
1082
|
-
contentType: media.contentType
|
|
1083
|
-
});
|
|
1084
|
-
} catch (err) {
|
|
1085
|
-
const errMsg = String(err);
|
|
1086
|
-
if (errMsg.includes("exceeds") && errMsg.includes("limit")) logVerbose(`line: media exceeds size limit for message ${message.id}`);
|
|
1087
|
-
else runtime.error?.(danger(`line: failed to download media: ${errMsg}`));
|
|
1088
|
-
}
|
|
1089
|
-
const messageContext = await buildLineMessageContext({
|
|
1090
|
-
event,
|
|
1091
|
-
allMedia,
|
|
1092
|
-
cfg,
|
|
1093
|
-
account,
|
|
1094
|
-
commandAuthorized: decision.commandAuthorized,
|
|
1095
|
-
groupHistories: context.groupHistories,
|
|
1096
|
-
historyLimit: context.historyLimit ?? 50
|
|
1097
|
-
});
|
|
1098
|
-
if (!messageContext) {
|
|
1099
|
-
logVerbose("line: skipping empty message");
|
|
1100
|
-
return;
|
|
1101
|
-
}
|
|
1102
|
-
await processMessage(messageContext);
|
|
1103
|
-
if (isGroup && context.groupHistories) {
|
|
1104
|
-
const historyKey = groupId ?? roomId;
|
|
1105
|
-
if (historyKey && context.groupHistories.has(historyKey)) clearHistoryEntriesIfEnabled({
|
|
1106
|
-
historyMap: context.groupHistories,
|
|
1107
|
-
historyKey,
|
|
1108
|
-
limit: context.historyLimit ?? 50
|
|
1109
|
-
});
|
|
1110
|
-
}
|
|
1111
|
-
}
|
|
1112
|
-
async function handleFollowEvent(event, _context) {
|
|
1113
|
-
const { userId } = getLineSourceInfo(event.source);
|
|
1114
|
-
logVerbose(`line: user ${userId ?? "unknown"} followed`);
|
|
1115
|
-
}
|
|
1116
|
-
async function handleUnfollowEvent(event, _context) {
|
|
1117
|
-
const { userId } = getLineSourceInfo(event.source);
|
|
1118
|
-
logVerbose(`line: user ${userId ?? "unknown"} unfollowed`);
|
|
1119
|
-
}
|
|
1120
|
-
async function handleJoinEvent(event, _context) {
|
|
1121
|
-
const { groupId, roomId } = getLineSourceInfo(event.source);
|
|
1122
|
-
logVerbose(`line: bot joined ${groupId ? `group ${groupId}` : `room ${roomId}`}`);
|
|
1123
|
-
}
|
|
1124
|
-
async function handleLeaveEvent(event, _context) {
|
|
1125
|
-
const { groupId, roomId } = getLineSourceInfo(event.source);
|
|
1126
|
-
logVerbose(`line: bot left ${groupId ? `group ${groupId}` : `room ${roomId}`}`);
|
|
1127
|
-
}
|
|
1128
|
-
async function handlePostbackEvent(event, context) {
|
|
1129
|
-
const data = event.postback.data;
|
|
1130
|
-
logVerbose(`line: received postback: ${data}`);
|
|
1131
|
-
const decision = await shouldProcessLineEvent(event, context);
|
|
1132
|
-
if (!decision.allowed) return;
|
|
1133
|
-
const postbackContext = await buildLinePostbackContext({
|
|
1134
|
-
event,
|
|
1135
|
-
cfg: context.cfg,
|
|
1136
|
-
account: context.account,
|
|
1137
|
-
commandAuthorized: decision.commandAuthorized
|
|
1138
|
-
});
|
|
1139
|
-
if (!postbackContext) return;
|
|
1140
|
-
await context.processMessage(postbackContext);
|
|
1141
|
-
}
|
|
1142
|
-
async function handleLineWebhookEvents(events, context) {
|
|
1143
|
-
let firstError;
|
|
1144
|
-
for (const event of events) {
|
|
1145
|
-
const replayCandidate = getLineReplayCandidate(event, context);
|
|
1146
|
-
const replaySkip = replayCandidate ? await claimLineReplayEvent(replayCandidate) : null;
|
|
1147
|
-
if (replaySkip?.skip) {
|
|
1148
|
-
if (replaySkip.inFlightResult) try {
|
|
1149
|
-
await replaySkip.inFlightResult;
|
|
1150
|
-
} catch (err) {
|
|
1151
|
-
context.runtime.error?.(danger(`line: replayed in-flight event failed: ${String(err)}`));
|
|
1152
|
-
firstError ??= err;
|
|
1153
|
-
}
|
|
1154
|
-
continue;
|
|
1155
|
-
}
|
|
1156
|
-
try {
|
|
1157
|
-
switch (event.type) {
|
|
1158
|
-
case "message":
|
|
1159
|
-
await handleMessageEvent(event, context);
|
|
1160
|
-
break;
|
|
1161
|
-
case "follow":
|
|
1162
|
-
await handleFollowEvent(event, context);
|
|
1163
|
-
break;
|
|
1164
|
-
case "unfollow":
|
|
1165
|
-
await handleUnfollowEvent(event, context);
|
|
1166
|
-
break;
|
|
1167
|
-
case "join":
|
|
1168
|
-
await handleJoinEvent(event, context);
|
|
1169
|
-
break;
|
|
1170
|
-
case "leave":
|
|
1171
|
-
await handleLeaveEvent(event, context);
|
|
1172
|
-
break;
|
|
1173
|
-
case "postback":
|
|
1174
|
-
await handlePostbackEvent(event, context);
|
|
1175
|
-
break;
|
|
1176
|
-
default: logVerbose(`line: unhandled event type: ${event.type}`);
|
|
1177
|
-
}
|
|
1178
|
-
if (replayCandidate) await replayCandidate.cache.commit(replayCandidate.key);
|
|
1179
|
-
} catch (err) {
|
|
1180
|
-
if (replayCandidate) if (err instanceof LineRetryableWebhookError) replayCandidate.cache.release(replayCandidate.key, { error: err });
|
|
1181
|
-
else await replayCandidate.cache.commit(replayCandidate.key);
|
|
1182
|
-
context.runtime.error?.(danger(`line: event handler failed: ${String(err)}`));
|
|
1183
|
-
firstError ??= err;
|
|
1184
|
-
}
|
|
1185
|
-
}
|
|
1186
|
-
if (firstError) throw firstError;
|
|
1187
|
-
}
|
|
1188
|
-
//#endregion
|
|
1189
|
-
//#region extensions/line/src/signature.ts
|
|
1190
|
-
function validateLineSignature(body, signature, channelSecret) {
|
|
1191
|
-
const hash = crypto.createHmac("SHA256", channelSecret).update(body).digest("base64");
|
|
1192
|
-
const hashBuffer = Buffer.from(hash);
|
|
1193
|
-
const signatureBuffer = Buffer.from(signature);
|
|
1194
|
-
const maxLen = Math.max(hashBuffer.length, signatureBuffer.length);
|
|
1195
|
-
const paddedHash = Buffer.alloc(maxLen);
|
|
1196
|
-
const paddedSig = Buffer.alloc(maxLen);
|
|
1197
|
-
hashBuffer.copy(paddedHash);
|
|
1198
|
-
signatureBuffer.copy(paddedSig);
|
|
1199
|
-
const timingResult = crypto.timingSafeEqual(paddedHash, paddedSig);
|
|
1200
|
-
return hashBuffer.length === signatureBuffer.length && timingResult;
|
|
1201
|
-
}
|
|
1202
|
-
//#endregion
|
|
1203
|
-
//#region extensions/line/src/webhook-utils.ts
|
|
1204
|
-
function parseLineWebhookBody(rawBody) {
|
|
1205
|
-
try {
|
|
1206
|
-
return JSON.parse(rawBody);
|
|
1207
|
-
} catch {
|
|
1208
|
-
return null;
|
|
1209
|
-
}
|
|
1210
|
-
}
|
|
1211
|
-
//#endregion
|
|
1212
|
-
//#region extensions/line/src/webhook.ts
|
|
1213
|
-
const LINE_WEBHOOK_MAX_RAW_BODY_BYTES = 64 * 1024;
|
|
1214
|
-
function readRawBody(req) {
|
|
1215
|
-
const rawBody = req.rawBody ?? (typeof req.body === "string" || Buffer.isBuffer(req.body) ? req.body : null);
|
|
1216
|
-
if (!rawBody) return null;
|
|
1217
|
-
return Buffer.isBuffer(rawBody) ? rawBody.toString("utf-8") : rawBody;
|
|
1218
|
-
}
|
|
1219
|
-
function parseWebhookBody(rawBody) {
|
|
1220
|
-
if (!rawBody) return null;
|
|
1221
|
-
return parseLineWebhookBody(rawBody);
|
|
1222
|
-
}
|
|
1223
|
-
function createLineWebhookMiddleware(options) {
|
|
1224
|
-
const { channelSecret, onEvents, runtime } = options;
|
|
1225
|
-
return async (req, res, _next) => {
|
|
1226
|
-
try {
|
|
1227
|
-
const signature = req.headers["x-line-signature"];
|
|
1228
|
-
if (!signature || typeof signature !== "string") {
|
|
1229
|
-
res.status(400).json({ error: "Missing X-Line-Signature header" });
|
|
1230
|
-
return;
|
|
1231
|
-
}
|
|
1232
|
-
const rawBody = readRawBody(req);
|
|
1233
|
-
if (!rawBody) {
|
|
1234
|
-
res.status(400).json({ error: "Missing raw request body for signature verification" });
|
|
1235
|
-
return;
|
|
1236
|
-
}
|
|
1237
|
-
if (Buffer.byteLength(rawBody, "utf-8") > LINE_WEBHOOK_MAX_RAW_BODY_BYTES) {
|
|
1238
|
-
res.status(413).json({ error: "Payload too large" });
|
|
1239
|
-
return;
|
|
1240
|
-
}
|
|
1241
|
-
if (!validateLineSignature(rawBody, signature, channelSecret)) {
|
|
1242
|
-
logVerbose("line: webhook signature validation failed");
|
|
1243
|
-
res.status(401).json({ error: "Invalid signature" });
|
|
1244
|
-
return;
|
|
1245
|
-
}
|
|
1246
|
-
const body = parseWebhookBody(rawBody);
|
|
1247
|
-
if (!body) {
|
|
1248
|
-
res.status(400).json({ error: "Invalid webhook payload" });
|
|
1249
|
-
return;
|
|
1250
|
-
}
|
|
1251
|
-
if (body.events && body.events.length > 0) {
|
|
1252
|
-
logVerbose(`line: received ${body.events.length} webhook events`);
|
|
1253
|
-
await onEvents(body);
|
|
1254
|
-
}
|
|
1255
|
-
res.status(200).json({ status: "ok" });
|
|
1256
|
-
} catch (err) {
|
|
1257
|
-
runtime?.error?.(danger(`line webhook error: ${String(err)}`));
|
|
1258
|
-
if (!res.headersSent) res.status(500).json({ error: "Internal server error" });
|
|
1259
|
-
}
|
|
1260
|
-
};
|
|
1261
|
-
}
|
|
1262
|
-
function startLineWebhook(options) {
|
|
1263
|
-
const channelSecret = typeof options.channelSecret === "string" ? options.channelSecret.trim() : "";
|
|
1264
|
-
if (!channelSecret) throw new Error("LINE webhook mode requires a non-empty channel secret. Set channels.line.channelSecret in your config.");
|
|
1265
|
-
return {
|
|
1266
|
-
path: options.path ?? "/line/webhook",
|
|
1267
|
-
handler: createLineWebhookMiddleware({
|
|
1268
|
-
channelSecret,
|
|
1269
|
-
onEvents: options.onEvents,
|
|
1270
|
-
runtime: options.runtime
|
|
1271
|
-
})
|
|
1272
|
-
};
|
|
1273
|
-
}
|
|
1274
|
-
//#endregion
|
|
1275
|
-
//#region extensions/line/src/bot.ts
|
|
1276
|
-
function createLineBot(opts) {
|
|
1277
|
-
const runtime = opts.runtime ?? createNonExitingRuntime();
|
|
1278
|
-
const cfg = opts.config ?? loadConfig();
|
|
1279
|
-
const account = resolveLineAccount({
|
|
1280
|
-
cfg,
|
|
1281
|
-
accountId: opts.accountId
|
|
1282
|
-
});
|
|
1283
|
-
const mediaMaxBytes = (opts.mediaMaxMb ?? account.config.mediaMaxMb ?? 10) * 1024 * 1024;
|
|
1284
|
-
const processMessage = opts.onMessage ?? (async () => {
|
|
1285
|
-
logVerbose("line: no message handler configured");
|
|
1286
|
-
});
|
|
1287
|
-
const replayCache = createLineWebhookReplayCache();
|
|
1288
|
-
const groupHistories = /* @__PURE__ */ new Map();
|
|
1289
|
-
const handleWebhook = async (body) => {
|
|
1290
|
-
if (!body.events || body.events.length === 0) return;
|
|
1291
|
-
await handleLineWebhookEvents(body.events, {
|
|
1292
|
-
cfg,
|
|
1293
|
-
account,
|
|
1294
|
-
runtime,
|
|
1295
|
-
mediaMaxBytes,
|
|
1296
|
-
processMessage,
|
|
1297
|
-
replayCache,
|
|
1298
|
-
groupHistories,
|
|
1299
|
-
historyLimit: cfg.messages?.groupChat?.historyLimit ?? 50
|
|
1300
|
-
});
|
|
1301
|
-
};
|
|
1302
|
-
return {
|
|
1303
|
-
handleWebhook,
|
|
1304
|
-
account
|
|
1305
|
-
};
|
|
1306
|
-
}
|
|
1307
|
-
//#endregion
|
|
1308
|
-
//#region extensions/line/src/reply-chunks.ts
|
|
1309
|
-
async function sendLineReplyChunks(params) {
|
|
1310
|
-
const hasQuickReplies = Boolean(params.quickReplies?.length);
|
|
1311
|
-
let replyTokenUsed = Boolean(params.replyTokenUsed);
|
|
1312
|
-
if (params.chunks.length === 0) return { replyTokenUsed };
|
|
1313
|
-
if (params.replyToken && !replyTokenUsed) try {
|
|
1314
|
-
const replyBatch = params.chunks.slice(0, 5);
|
|
1315
|
-
const remaining = params.chunks.slice(replyBatch.length);
|
|
1316
|
-
const replyMessages = replyBatch.map((chunk) => ({
|
|
1317
|
-
type: "text",
|
|
1318
|
-
text: chunk
|
|
1319
|
-
}));
|
|
1320
|
-
if (hasQuickReplies && remaining.length === 0 && replyMessages.length > 0) {
|
|
1321
|
-
const lastIndex = replyMessages.length - 1;
|
|
1322
|
-
replyMessages[lastIndex] = params.createTextMessageWithQuickReplies(replyBatch[lastIndex], params.quickReplies);
|
|
1323
|
-
}
|
|
1324
|
-
await params.replyMessageLine(params.replyToken, replyMessages, {
|
|
1325
|
-
cfg: params.cfg,
|
|
1326
|
-
accountId: params.accountId
|
|
1327
|
-
});
|
|
1328
|
-
replyTokenUsed = true;
|
|
1329
|
-
for (let i = 0; i < remaining.length; i += 1) if (i === remaining.length - 1 && hasQuickReplies) await params.pushTextMessageWithQuickReplies(params.to, remaining[i], params.quickReplies, {
|
|
1330
|
-
cfg: params.cfg,
|
|
1331
|
-
accountId: params.accountId
|
|
1332
|
-
});
|
|
1333
|
-
else await params.pushMessageLine(params.to, remaining[i], {
|
|
1334
|
-
cfg: params.cfg,
|
|
1335
|
-
accountId: params.accountId
|
|
1336
|
-
});
|
|
1337
|
-
return { replyTokenUsed };
|
|
1338
|
-
} catch (err) {
|
|
1339
|
-
params.onReplyError?.(err);
|
|
1340
|
-
replyTokenUsed = true;
|
|
1341
|
-
}
|
|
1342
|
-
for (let i = 0; i < params.chunks.length; i += 1) if (i === params.chunks.length - 1 && hasQuickReplies) await params.pushTextMessageWithQuickReplies(params.to, params.chunks[i], params.quickReplies, {
|
|
1343
|
-
cfg: params.cfg,
|
|
1344
|
-
accountId: params.accountId
|
|
1345
|
-
});
|
|
1346
|
-
else await params.pushMessageLine(params.to, params.chunks[i], {
|
|
1347
|
-
cfg: params.cfg,
|
|
1348
|
-
accountId: params.accountId
|
|
1349
|
-
});
|
|
1350
|
-
return { replyTokenUsed };
|
|
1351
|
-
}
|
|
1352
|
-
//#endregion
|
|
1353
|
-
//#region extensions/line/src/webhook-node.ts
|
|
1354
|
-
const LINE_WEBHOOK_MAX_BODY_BYTES = 1024 * 1024;
|
|
1355
|
-
const LINE_WEBHOOK_PREAUTH_MAX_BODY_BYTES = 64 * 1024;
|
|
1356
|
-
const LINE_WEBHOOK_PREAUTH_BODY_TIMEOUT_MS = 5e3;
|
|
1357
|
-
async function readLineWebhookRequestBody(req, maxBytes = LINE_WEBHOOK_MAX_BODY_BYTES, timeoutMs = LINE_WEBHOOK_PREAUTH_BODY_TIMEOUT_MS) {
|
|
1358
|
-
return await readRequestBodyWithLimit(req, {
|
|
1359
|
-
maxBytes,
|
|
1360
|
-
timeoutMs
|
|
1361
|
-
});
|
|
1362
|
-
}
|
|
1363
|
-
function createLineNodeWebhookHandler(params) {
|
|
1364
|
-
const maxBodyBytes = params.maxBodyBytes ?? LINE_WEBHOOK_MAX_BODY_BYTES;
|
|
1365
|
-
const readBody = params.readBody ?? readLineWebhookRequestBody;
|
|
1366
|
-
return async (req, res) => {
|
|
1367
|
-
if (req.method === "GET" || req.method === "HEAD") {
|
|
1368
|
-
if (req.method === "HEAD") {
|
|
1369
|
-
res.statusCode = 204;
|
|
1370
|
-
res.end();
|
|
1371
|
-
return;
|
|
1372
|
-
}
|
|
1373
|
-
res.statusCode = 200;
|
|
1374
|
-
res.setHeader("Content-Type", "text/plain");
|
|
1375
|
-
res.end("OK");
|
|
1376
|
-
return;
|
|
1377
|
-
}
|
|
1378
|
-
if (req.method !== "POST") {
|
|
1379
|
-
res.statusCode = 405;
|
|
1380
|
-
res.setHeader("Allow", "GET, HEAD, POST");
|
|
1381
|
-
res.setHeader("Content-Type", "application/json");
|
|
1382
|
-
res.end(JSON.stringify({ error: "Method Not Allowed" }));
|
|
1383
|
-
return;
|
|
1384
|
-
}
|
|
1385
|
-
try {
|
|
1386
|
-
const signatureHeader = req.headers["x-line-signature"];
|
|
1387
|
-
const signature = typeof signatureHeader === "string" ? signatureHeader.trim() : Array.isArray(signatureHeader) ? (signatureHeader[0] ?? "").trim() : "";
|
|
1388
|
-
if (!signature) {
|
|
1389
|
-
logVerbose("line: webhook missing X-Line-Signature header");
|
|
1390
|
-
res.statusCode = 400;
|
|
1391
|
-
res.setHeader("Content-Type", "application/json");
|
|
1392
|
-
res.end(JSON.stringify({ error: "Missing X-Line-Signature header" }));
|
|
1393
|
-
return;
|
|
1394
|
-
}
|
|
1395
|
-
const rawBody = await readBody(req, Math.min(maxBodyBytes, LINE_WEBHOOK_PREAUTH_MAX_BODY_BYTES), LINE_WEBHOOK_PREAUTH_BODY_TIMEOUT_MS);
|
|
1396
|
-
if (!validateLineSignature(rawBody, signature, params.channelSecret)) {
|
|
1397
|
-
logVerbose("line: webhook signature validation failed");
|
|
1398
|
-
res.statusCode = 401;
|
|
1399
|
-
res.setHeader("Content-Type", "application/json");
|
|
1400
|
-
res.end(JSON.stringify({ error: "Invalid signature" }));
|
|
1401
|
-
return;
|
|
1402
|
-
}
|
|
1403
|
-
const body = parseLineWebhookBody(rawBody);
|
|
1404
|
-
if (!body) {
|
|
1405
|
-
res.statusCode = 400;
|
|
1406
|
-
res.setHeader("Content-Type", "application/json");
|
|
1407
|
-
res.end(JSON.stringify({ error: "Invalid webhook payload" }));
|
|
1408
|
-
return;
|
|
1409
|
-
}
|
|
1410
|
-
params.onRequestAuthenticated?.();
|
|
1411
|
-
if (body.events && body.events.length > 0) {
|
|
1412
|
-
logVerbose(`line: received ${body.events.length} webhook events`);
|
|
1413
|
-
await params.bot.handleWebhook(body);
|
|
1414
|
-
}
|
|
1415
|
-
res.statusCode = 200;
|
|
1416
|
-
res.setHeader("Content-Type", "application/json");
|
|
1417
|
-
res.end(JSON.stringify({ status: "ok" }));
|
|
1418
|
-
} catch (err) {
|
|
1419
|
-
if (isRequestBodyLimitError(err, "PAYLOAD_TOO_LARGE")) {
|
|
1420
|
-
res.statusCode = 413;
|
|
1421
|
-
res.setHeader("Content-Type", "application/json");
|
|
1422
|
-
res.end(JSON.stringify({ error: "Payload too large" }));
|
|
1423
|
-
return;
|
|
1424
|
-
}
|
|
1425
|
-
if (isRequestBodyLimitError(err, "REQUEST_BODY_TIMEOUT")) {
|
|
1426
|
-
res.statusCode = 408;
|
|
1427
|
-
res.setHeader("Content-Type", "application/json");
|
|
1428
|
-
res.end(JSON.stringify({ error: requestBodyErrorToText("REQUEST_BODY_TIMEOUT") }));
|
|
1429
|
-
return;
|
|
1430
|
-
}
|
|
1431
|
-
params.runtime.error?.(danger(`line webhook error: ${String(err)}`));
|
|
1432
|
-
if (!res.headersSent) {
|
|
1433
|
-
res.statusCode = 500;
|
|
1434
|
-
res.setHeader("Content-Type", "application/json");
|
|
1435
|
-
res.end(JSON.stringify({ error: "Internal server error" }));
|
|
1436
|
-
}
|
|
1437
|
-
}
|
|
1438
|
-
};
|
|
1439
|
-
}
|
|
1440
|
-
//#endregion
|
|
1441
|
-
//#region extensions/line/src/monitor.ts
|
|
1442
|
-
const runtimeState = /* @__PURE__ */ new Map();
|
|
1443
|
-
const lineWebhookInFlightLimiter = createWebhookInFlightLimiter();
|
|
1444
|
-
function recordChannelRuntimeState(params) {
|
|
1445
|
-
const key = `${params.channel}:${params.accountId}`;
|
|
1446
|
-
const existing = runtimeState.get(key) ?? {
|
|
1447
|
-
running: false,
|
|
1448
|
-
lastStartAt: null,
|
|
1449
|
-
lastStopAt: null,
|
|
1450
|
-
lastError: null
|
|
1451
|
-
};
|
|
1452
|
-
runtimeState.set(key, {
|
|
1453
|
-
...existing,
|
|
1454
|
-
...params.state
|
|
1455
|
-
});
|
|
1456
|
-
}
|
|
1457
|
-
function startLineLoadingKeepalive(params) {
|
|
1458
|
-
const intervalMs = params.intervalMs ?? 18e3;
|
|
1459
|
-
const loadingSeconds = params.loadingSeconds ?? 20;
|
|
1460
|
-
let stopped = false;
|
|
1461
|
-
const trigger = () => {
|
|
1462
|
-
if (stopped) return;
|
|
1463
|
-
showLoadingAnimation(params.userId, {
|
|
1464
|
-
cfg: params.cfg,
|
|
1465
|
-
accountId: params.accountId,
|
|
1466
|
-
loadingSeconds
|
|
1467
|
-
}).catch(() => {});
|
|
1468
|
-
};
|
|
1469
|
-
trigger();
|
|
1470
|
-
const timer = setInterval(trigger, intervalMs);
|
|
1471
|
-
return () => {
|
|
1472
|
-
if (stopped) return;
|
|
1473
|
-
stopped = true;
|
|
1474
|
-
clearInterval(timer);
|
|
1475
|
-
};
|
|
1476
|
-
}
|
|
1477
|
-
async function monitorLineProvider(opts) {
|
|
1478
|
-
const { channelAccessToken, channelSecret, accountId, config, runtime, abortSignal, webhookPath } = opts;
|
|
1479
|
-
const resolvedAccountId = accountId ?? resolveDefaultLineAccountId(config);
|
|
1480
|
-
const token = channelAccessToken.trim();
|
|
1481
|
-
const secret = channelSecret.trim();
|
|
1482
|
-
if (!token) throw new Error("LINE webhook mode requires a non-empty channel access token.");
|
|
1483
|
-
if (!secret) throw new Error("LINE webhook mode requires a non-empty channel secret.");
|
|
1484
|
-
recordChannelRuntimeState({
|
|
1485
|
-
channel: "line",
|
|
1486
|
-
accountId: resolvedAccountId,
|
|
1487
|
-
state: {
|
|
1488
|
-
running: true,
|
|
1489
|
-
lastStartAt: Date.now()
|
|
1490
|
-
}
|
|
1491
|
-
});
|
|
1492
|
-
const bot = createLineBot({
|
|
1493
|
-
channelAccessToken: token,
|
|
1494
|
-
channelSecret: secret,
|
|
1495
|
-
accountId,
|
|
1496
|
-
runtime,
|
|
1497
|
-
config,
|
|
1498
|
-
onMessage: async (ctx) => {
|
|
1499
|
-
if (!ctx) return;
|
|
1500
|
-
const { ctxPayload, replyToken, route } = ctx;
|
|
1501
|
-
recordChannelRuntimeState({
|
|
1502
|
-
channel: "line",
|
|
1503
|
-
accountId: resolvedAccountId,
|
|
1504
|
-
state: { lastInboundAt: Date.now() }
|
|
1505
|
-
});
|
|
1506
|
-
const shouldShowLoading = Boolean(ctx.userId && !ctx.isGroup);
|
|
1507
|
-
const displayNamePromise = ctx.userId ? getUserDisplayName(ctx.userId, {
|
|
1508
|
-
cfg: config,
|
|
1509
|
-
accountId: ctx.accountId
|
|
1510
|
-
}) : Promise.resolve(ctxPayload.From);
|
|
1511
|
-
const stopLoading = shouldShowLoading ? startLineLoadingKeepalive({
|
|
1512
|
-
cfg: config,
|
|
1513
|
-
userId: ctx.userId,
|
|
1514
|
-
accountId: ctx.accountId
|
|
1515
|
-
}) : null;
|
|
1516
|
-
logVerbose(`line: received message from ${await displayNamePromise} (${ctxPayload.From})`);
|
|
1517
|
-
try {
|
|
1518
|
-
const textLimit = 5e3;
|
|
1519
|
-
let replyTokenUsed = false;
|
|
1520
|
-
const { onModelSelected, ...replyPipeline } = createChannelReplyPipeline({
|
|
1521
|
-
cfg: config,
|
|
1522
|
-
agentId: route.agentId,
|
|
1523
|
-
channel: "line",
|
|
1524
|
-
accountId: route.accountId
|
|
1525
|
-
});
|
|
1526
|
-
const { queuedFinal } = await dispatchReplyWithBufferedBlockDispatcher({
|
|
1527
|
-
ctx: ctxPayload,
|
|
1528
|
-
cfg: config,
|
|
1529
|
-
dispatcherOptions: {
|
|
1530
|
-
...replyPipeline,
|
|
1531
|
-
deliver: async (payload, _info) => {
|
|
1532
|
-
const lineData = payload.channelData?.line ?? {};
|
|
1533
|
-
if (ctx.userId && !ctx.isGroup) showLoadingAnimation(ctx.userId, {
|
|
1534
|
-
cfg: config,
|
|
1535
|
-
accountId: ctx.accountId
|
|
1536
|
-
}).catch(() => {});
|
|
1537
|
-
const { replyTokenUsed: nextReplyTokenUsed } = await deliverLineAutoReply({
|
|
1538
|
-
payload,
|
|
1539
|
-
lineData,
|
|
1540
|
-
to: ctxPayload.From,
|
|
1541
|
-
replyToken,
|
|
1542
|
-
replyTokenUsed,
|
|
1543
|
-
accountId: ctx.accountId,
|
|
1544
|
-
cfg: config,
|
|
1545
|
-
textLimit,
|
|
1546
|
-
deps: {
|
|
1547
|
-
buildTemplateMessageFromPayload,
|
|
1548
|
-
processLineMessage,
|
|
1549
|
-
chunkMarkdownText,
|
|
1550
|
-
sendLineReplyChunks,
|
|
1551
|
-
replyMessageLine,
|
|
1552
|
-
pushMessageLine,
|
|
1553
|
-
pushTextMessageWithQuickReplies,
|
|
1554
|
-
createQuickReplyItems,
|
|
1555
|
-
createTextMessageWithQuickReplies,
|
|
1556
|
-
pushMessagesLine,
|
|
1557
|
-
createFlexMessage,
|
|
1558
|
-
createImageMessage,
|
|
1559
|
-
createLocationMessage,
|
|
1560
|
-
onReplyError: (replyErr) => {
|
|
1561
|
-
logVerbose(`line: reply token failed, falling back to push: ${String(replyErr)}`);
|
|
1562
|
-
}
|
|
1563
|
-
}
|
|
1564
|
-
});
|
|
1565
|
-
replyTokenUsed = nextReplyTokenUsed;
|
|
1566
|
-
recordChannelRuntimeState({
|
|
1567
|
-
channel: "line",
|
|
1568
|
-
accountId: resolvedAccountId,
|
|
1569
|
-
state: { lastOutboundAt: Date.now() }
|
|
1570
|
-
});
|
|
1571
|
-
},
|
|
1572
|
-
onError: (err, info) => {
|
|
1573
|
-
runtime.error?.(danger(`line ${info.kind} reply failed: ${String(err)}`));
|
|
1574
|
-
}
|
|
1575
|
-
},
|
|
1576
|
-
replyOptions: { onModelSelected }
|
|
1577
|
-
});
|
|
1578
|
-
if (!queuedFinal) logVerbose(`line: no response generated for message from ${ctxPayload.From}`);
|
|
1579
|
-
} catch (err) {
|
|
1580
|
-
runtime.error?.(danger(`line: auto-reply failed: ${String(err)}`));
|
|
1581
|
-
if (replyToken) try {
|
|
1582
|
-
await replyMessageLine(replyToken, [{
|
|
1583
|
-
type: "text",
|
|
1584
|
-
text: "Sorry, I encountered an error processing your message."
|
|
1585
|
-
}], {
|
|
1586
|
-
cfg: config,
|
|
1587
|
-
accountId: ctx.accountId
|
|
1588
|
-
});
|
|
1589
|
-
} catch (replyErr) {
|
|
1590
|
-
runtime.error?.(danger(`line: error reply failed: ${String(replyErr)}`));
|
|
1591
|
-
}
|
|
1592
|
-
} finally {
|
|
1593
|
-
stopLoading?.();
|
|
1594
|
-
}
|
|
1595
|
-
}
|
|
1596
|
-
});
|
|
1597
|
-
const normalizedPath = normalizePluginHttpPath(webhookPath, "/line/webhook") ?? "/line/webhook";
|
|
1598
|
-
const createScopedLineWebhookHandler = (onRequestAuthenticated) => createLineNodeWebhookHandler({
|
|
1599
|
-
channelSecret: secret,
|
|
1600
|
-
bot,
|
|
1601
|
-
runtime,
|
|
1602
|
-
onRequestAuthenticated
|
|
1603
|
-
});
|
|
1604
|
-
const unregisterHttp = registerPluginHttpRoute({
|
|
1605
|
-
path: normalizedPath,
|
|
1606
|
-
auth: "plugin",
|
|
1607
|
-
replaceExisting: true,
|
|
1608
|
-
pluginId: "line",
|
|
1609
|
-
accountId: resolvedAccountId,
|
|
1610
|
-
log: (msg) => logVerbose(msg),
|
|
1611
|
-
handler: async (req, res) => {
|
|
1612
|
-
if (req.method !== "POST") {
|
|
1613
|
-
await createScopedLineWebhookHandler()(req, res);
|
|
1614
|
-
return;
|
|
1615
|
-
}
|
|
1616
|
-
const requestLifecycle = beginWebhookRequestPipelineOrReject({
|
|
1617
|
-
req,
|
|
1618
|
-
res,
|
|
1619
|
-
inFlightLimiter: lineWebhookInFlightLimiter,
|
|
1620
|
-
inFlightKey: `line:${resolvedAccountId}`
|
|
1621
|
-
});
|
|
1622
|
-
if (!requestLifecycle.ok) return;
|
|
1623
|
-
try {
|
|
1624
|
-
await createScopedLineWebhookHandler(requestLifecycle.release)(req, res);
|
|
1625
|
-
} finally {
|
|
1626
|
-
requestLifecycle.release();
|
|
1627
|
-
}
|
|
1628
|
-
}
|
|
1629
|
-
});
|
|
1630
|
-
logVerbose(`line: registered webhook handler at ${normalizedPath}`);
|
|
1631
|
-
let stopped = false;
|
|
1632
|
-
const stopHandler = () => {
|
|
1633
|
-
if (stopped) return;
|
|
1634
|
-
stopped = true;
|
|
1635
|
-
logVerbose(`line: stopping provider for account ${resolvedAccountId}`);
|
|
1636
|
-
unregisterHttp();
|
|
1637
|
-
recordChannelRuntimeState({
|
|
1638
|
-
channel: "line",
|
|
1639
|
-
accountId: resolvedAccountId,
|
|
1640
|
-
state: {
|
|
1641
|
-
running: false,
|
|
1642
|
-
lastStopAt: Date.now()
|
|
1643
|
-
}
|
|
1644
|
-
});
|
|
1645
|
-
};
|
|
1646
|
-
if (abortSignal?.aborted) stopHandler();
|
|
1647
|
-
else if (abortSignal) {
|
|
1648
|
-
abortSignal.addEventListener("abort", stopHandler, { once: true });
|
|
1649
|
-
await waitForAbortSignal(abortSignal);
|
|
1650
|
-
}
|
|
1651
|
-
return {
|
|
1652
|
-
account: bot.account,
|
|
1653
|
-
handleWebhook: bot.handleWebhook,
|
|
1654
|
-
stop: () => {
|
|
1655
|
-
stopHandler();
|
|
1656
|
-
abortSignal?.removeEventListener("abort", stopHandler);
|
|
1657
|
-
}
|
|
1658
|
-
};
|
|
1659
|
-
}
|
|
1660
|
-
//#endregion
|
|
1661
|
-
export { startLineWebhook as a, downloadLineMedia as c, normalizeAllowFrom as d, normalizeDmAllowFromWithStore as f, createLineWebhookMiddleware as i, MessagingApiBlobClient as l, createLineNodeWebhookHandler as n, parseLineWebhookBody as o, readLineWebhookRequestBody as r, validateLineSignature as s, monitorLineProvider as t, isSenderAllowed as u };
|