@pixelzx/genesis 2026.5.5-3 → 2026.5.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.
Files changed (1099) hide show
  1. package/CHANGELOG.md +2 -1
  2. package/dist/.buildstamp +1 -1
  3. package/dist/abort-Eo7XsA03.js +201 -0
  4. package/dist/abort.runtime-B5p-SlXK.js +2 -0
  5. package/dist/abort.runtime.js +1 -1
  6. package/dist/accounts-9Krv4f9C.js +2 -0
  7. package/dist/accounts-B3R0SEUc.js +107 -0
  8. package/dist/accounts-BU0s8Imm.js +104 -0
  9. package/dist/accounts-CbIPkOW8.js +66 -0
  10. package/dist/accounts.runtime-M-6eankg.js +2 -0
  11. package/dist/accounts.runtime.js +1 -1
  12. package/dist/acp-cli-z6OXmifV.js +2193 -0
  13. package/dist/acp-spawn-Dagbjv-c.js +1093 -0
  14. package/dist/acp-spawn-Dzb_-EiJ.js +2 -0
  15. package/dist/acp-stateful-target-driver-JXFh96Nx.js +89 -0
  16. package/dist/action-agents-DevmKFPq.js +67 -0
  17. package/dist/action-focus-slEC2ZvE.js +132 -0
  18. package/dist/action-help-BNI_jV7m.js +7 -0
  19. package/dist/action-info-A0aWRFGn.js +101 -0
  20. package/dist/action-kill-BSoka9Ag.js +33 -0
  21. package/dist/action-list-DnKS7NUS.js +21 -0
  22. package/dist/action-log-pjPufssA.js +30 -0
  23. package/dist/action-send-rCD6KNIM.js +39 -0
  24. package/dist/action-spawn-Z9Cs9AKM.js +47 -0
  25. package/dist/action-unfocus-D2zbhGSQ.js +29 -0
  26. package/dist/actions.runtime-DCIg2FO0.js +18 -0
  27. package/dist/actions.runtime-io4CYWEl.js +5 -0
  28. package/dist/actions.runtime.js +1 -1
  29. package/dist/agent-BIsY2xbQ.js +2 -0
  30. package/dist/agent-command-Bko5m9ND.js +874 -0
  31. package/dist/agent-harness-runtime-y19kcHYa.js +144 -0
  32. package/dist/agent-runner-utils-DZsEMF5x.js +239 -0
  33. package/dist/agent-runner.runtime-Dk4YPE9M.js +3455 -0
  34. package/dist/agent-runner.runtime.js +1 -1
  35. package/dist/agent-runtime-bsFtkcfq.js +18 -0
  36. package/dist/agents-BI1C9XcY.js +953 -0
  37. package/dist/agents-BqFQzPnc.js +5 -0
  38. package/dist/aliases-YaSyoY8V.js +2 -0
  39. package/dist/aliases-dc4pWr4w.js +96 -0
  40. package/dist/api-BwKUC3oZ.js +5 -0
  41. package/dist/api-BzsECesc.js +139 -0
  42. package/dist/api-W3n67ens.js +3 -0
  43. package/dist/approval-gateway-resolver-tbaA47lu.js +29 -0
  44. package/dist/approval-gateway-runtime-DNu7ZYTl.js +2 -0
  45. package/dist/approval-handler-runtime-DaJ2bQ8K.js +439 -0
  46. package/dist/approval-native-runtime-c-AA06Kd.js +729 -0
  47. package/dist/attempt-execution.runtime-Cfd4qrSC.js +509 -0
  48. package/dist/attempt-execution.runtime.js +1 -1
  49. package/dist/attempt.prompt-helpers-Sly6bfCz.js +221 -0
  50. package/dist/attempt.tool-run-context-BN9lQ-hT.js +933 -0
  51. package/dist/audit-Bw9kBXSm.js +939 -0
  52. package/dist/audit.runtime-5Y0uwaKo.js +7 -0
  53. package/dist/audit.runtime.js +1 -1
  54. package/dist/auth-BeJ-lcT0.js +383 -0
  55. package/dist/auth-lYX2L0Ul.js +2 -0
  56. package/dist/auth-order-BRkdy5ZR.js +96 -0
  57. package/dist/auth-order-Cz5FlXVM.js +2 -0
  58. package/dist/bash-tools-CENsF10z.js +2824 -0
  59. package/dist/bash-tools-CTM07nQV.js +3 -0
  60. package/dist/binding-routing-6cr2GU2Z.js +85 -0
  61. package/dist/binding-targets-ElXGtJx6.js +121 -0
  62. package/dist/bridge-server-BFqa--hi.js +113 -0
  63. package/dist/browser-control-auth-CU8n1cKt.js +2 -0
  64. package/dist/browser-node-runtime-D7C9c9PL.js +12 -0
  65. package/dist/browser-profiles-BtXKvgoD.js +2 -0
  66. package/dist/browser-runtime-BTqH6b-o.js +387 -0
  67. package/dist/browser-setup-tools-C0AtDMGC.js +13 -0
  68. package/dist/build-B7Fw754S.js +550 -0
  69. package/dist/build-info.json +3 -3
  70. package/dist/bundled/boot-md/handler.js +2 -2
  71. package/dist/bundled/session-memory/handler.js +1 -1
  72. package/dist/call-Bu6qiSj3.js +331 -0
  73. package/dist/call-DHNRfD2p.js +3 -0
  74. package/dist/call.runtime-93EU1EXn.js +2 -0
  75. package/dist/call.runtime.js +1 -1
  76. package/dist/capability-cli-OTV_9-o3.js +1401 -0
  77. package/dist/catchup-HQymClSi.js +300 -0
  78. package/dist/channel-BUi5IT4y.js +595 -0
  79. package/dist/channel-C8_SXfQR.js +491 -0
  80. package/dist/channel-D0m2o2Vx.js +453 -0
  81. package/dist/channel-D1x8Tidv.js +226 -0
  82. package/dist/channel-D28-KeGu.js +297 -0
  83. package/dist/channel-D4fD_ELv.js +840 -0
  84. package/dist/channel-DDs9mkGR.js +1320 -0
  85. package/dist/channel-DF_iiMCP.js +1100 -0
  86. package/dist/channel-DwwRtWIy.js +350 -0
  87. package/dist/channel-E_FCZxzs.js +1802 -0
  88. package/dist/channel-core-CGLZRv9b.js +5 -0
  89. package/dist/channel-inbound-BvfXTTbL.js +31 -0
  90. package/dist/channel-plugin-runtime-Zt1YkCwm.js +771 -0
  91. package/dist/channel-runtime-CZE8ZwJa.js +425 -0
  92. package/dist/channel-wlrRJszs.js +1174 -0
  93. package/dist/channel.runtime-BRsrFBpW.js +89 -0
  94. package/dist/channel.runtime-Cg_VX6Fe.js +4 -0
  95. package/dist/channel.runtime-DFUE9oMa.js +34702 -0
  96. package/dist/channel.runtime-DLgAiBGS.js +109 -0
  97. package/dist/channel.runtime-DRzzcVJe.js +576 -0
  98. package/dist/channel.runtime-DZKrwSTU.js +2364 -0
  99. package/dist/channel.runtime-JfYZ9yn3.js +26 -0
  100. package/dist/channel.runtime-XLGJZpuw.js +430 -0
  101. package/dist/channel.setup-C61m_WuB.js +10 -0
  102. package/dist/channels-DZ6gQ08q.js +733 -0
  103. package/dist/channels-cli-I85GHTus.js +268 -0
  104. package/dist/chat-Bbmabe4k.js +2758 -0
  105. package/dist/clawbot-cli-BOy_NgZZ.js +9 -0
  106. package/dist/cli/daemon-cli.js +4 -4
  107. package/dist/cli-7go0hekY.js +219 -0
  108. package/dist/cli-Bl9VIAti.js +72 -0
  109. package/dist/cli-CKC1TKDs.js +2 -0
  110. package/dist/cli-ChQYhws1.js +2 -0
  111. package/dist/cli-runner-DETCLlhR.js +286 -0
  112. package/dist/cli-runner.runtime-BSFbP0qC.js +4 -0
  113. package/dist/cli-runner.runtime-C8ZcGdWt.js +3 -0
  114. package/dist/cli-runner.runtime.js +1 -1
  115. package/dist/cli-startup-metadata.json +2 -2
  116. package/dist/cli.runtime-DzHfJgTn.js +1261 -0
  117. package/dist/cli.runtime.js +1 -1
  118. package/dist/client-B0QJbO9O.js +713 -0
  119. package/dist/client-D9Yh0P5l.js +138 -0
  120. package/dist/command-auth-CtA0lbtD.js +76 -0
  121. package/dist/command-config-resolution-Ca1VhPh6.js +23 -0
  122. package/dist/command-config-resolution-CzVRM9ST.js +2 -0
  123. package/dist/command-config-resolution.runtime-DB2PNtn6.js +2 -0
  124. package/dist/command-config-resolution.runtime.js +1 -1
  125. package/dist/command-registry-933Sv1vK.js +9 -0
  126. package/dist/command-registry-core-D8aHghZH.js +101 -0
  127. package/dist/command-registry-fZisu462.js +4 -0
  128. package/dist/command-secret-gateway-BiDNHLok.js +528 -0
  129. package/dist/command-status.runtime-BRf_Jr9L.js +87 -0
  130. package/dist/command-status.runtime.js +1 -1
  131. package/dist/commands-acp-BrL95pJ8.js +77 -0
  132. package/dist/commands-compact.runtime-DYukJ-s7.js +10 -0
  133. package/dist/commands-compact.runtime.js +1 -1
  134. package/dist/commands-handlers.runtime-CYccZqks.js +4597 -0
  135. package/dist/commands-handlers.runtime.js +1 -1
  136. package/dist/commands-status-CvAD8raW.js +16 -0
  137. package/dist/commands-status.runtime-C4jpZ_ly.js +3 -0
  138. package/dist/commands-status.runtime.js +1 -1
  139. package/dist/commands-subagents-control.runtime-2infwrLW.js +2 -0
  140. package/dist/commands-subagents-control.runtime-BItxlxqC.js +3 -0
  141. package/dist/commands-subagents-control.runtime.js +1 -1
  142. package/dist/commands-system-prompt-D4V5ryNf.js +158 -0
  143. package/dist/commands-system-prompt-PJ-MwSQK.js +2 -0
  144. package/dist/commands.runtime-OieWfVCv.js +166 -0
  145. package/dist/commands.runtime.js +1 -1
  146. package/dist/compact-BXSlPyME.js +1118 -0
  147. package/dist/compact.runtime-o89ZdgH2.js +12 -0
  148. package/dist/compact.runtime.js +1 -1
  149. package/dist/completion-cli-CpaOR4Y2.js +328 -0
  150. package/dist/config-D4iBIDV7.js +251 -0
  151. package/dist/config-cli-BQqlP6h4.js +1078 -0
  152. package/dist/configure--yuymC-4.js +2 -0
  153. package/dist/configure-DFIqz4FW.js +1245 -0
  154. package/dist/connect-options-B0Lt-rU2.js +699 -0
  155. package/dist/control-auth-BGRSY5e3.js +125 -0
  156. package/dist/control-service-DT6fleyD.js +156 -0
  157. package/dist/control-ui-CWXb-Fp5.js +688 -0
  158. package/dist/conversation-id-BSuv_BUL.js +235 -0
  159. package/dist/conversation-id-CNXhZOAr.js +38 -0
  160. package/dist/conversation-runtime-BHctDnia.js +31 -0
  161. package/dist/core-BlXGwz2n.js +275 -0
  162. package/dist/cron-cli-5AWYX_JN.js +713 -0
  163. package/dist/daemon-cli-DmvnMTwU.js +12 -0
  164. package/dist/daemon-install-CiudqvC8.js +64 -0
  165. package/dist/delegate-Bd-FPQqY.js +64 -0
  166. package/dist/delivery.runtime-Corwnx7a.js +253 -0
  167. package/dist/delivery.runtime.js +1 -1
  168. package/dist/detached-task-runtime-DfVdnBXS.js +73 -0
  169. package/dist/devices-cli-DZZgB4A7.js +496 -0
  170. package/dist/diagnostics-Ck31VWA6.js +154 -0
  171. package/dist/direct-dm-Dmjok-pB.js +64 -0
  172. package/dist/dispatch-CRDSpd0f.js +1131 -0
  173. package/dist/dispatch-acp-Cu9MKTKz.js +981 -0
  174. package/dist/dispatch-acp-manager.runtime-DcW9RwSI.js +3 -0
  175. package/dist/dispatch-acp-manager.runtime.js +1 -1
  176. package/dist/dispatch-acp.runtime-BsQByEI3.js +19 -0
  177. package/dist/dispatch-acp.runtime.js +1 -1
  178. package/dist/doctor-device-pairing-DXaIZ9a_.js +307 -0
  179. package/dist/doctor-gateway-daemon-flow-bg9a147z.js +250 -0
  180. package/dist/doctor-gateway-health-zdQbGmmj.js +60 -0
  181. package/dist/doctor-gateway-services-ChajuYZL.js +316 -0
  182. package/dist/doctor-health-DQGXbUKZ.js +59 -0
  183. package/dist/doctor-health-contributions-D7MWDAlD.js +486 -0
  184. package/dist/doctor-prompter-2aroILEC.js +56 -0
  185. package/dist/doctor-workspace-status-D4kiEraU.js +75 -0
  186. package/dist/dreaming-Q-aETkru.js +1574 -0
  187. package/dist/dreaming-narrative-663l1FRo.js +595 -0
  188. package/dist/embedded-gateway-stub.runtime-DUc8aWQC.js +9 -0
  189. package/dist/embedded-gateway-stub.runtime.js +1 -1
  190. package/dist/embeddings-http-BQ4pNJtW.js +205 -0
  191. package/dist/entry.js +2 -2
  192. package/dist/exec-approvals-cli-CX0ETYsT.js +498 -0
  193. package/dist/execute.runtime-CBVe-PCC.js +1366 -0
  194. package/dist/execute.runtime.js +1 -1
  195. package/dist/extensionAPI.js +1 -1
  196. package/dist/extensions/active-memory/index.js +1 -1
  197. package/dist/extensions/bluebubbles/api.js +3 -3
  198. package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
  199. package/dist/extensions/browser/browser-bridge.js +1 -1
  200. package/dist/extensions/browser/browser-config.js +4 -4
  201. package/dist/extensions/browser/browser-control-auth.js +2 -2
  202. package/dist/extensions/browser/browser-doctor.js +2 -2
  203. package/dist/extensions/browser/browser-maintenance.js +2 -2
  204. package/dist/extensions/browser/browser-profiles.js +2 -2
  205. package/dist/extensions/browser/browser-runtime-api.js +10 -10
  206. package/dist/extensions/browser/index.js +1 -1
  207. package/dist/extensions/browser/plugin-registration.js +1 -1
  208. package/dist/extensions/browser/register.runtime.js +3 -3
  209. package/dist/extensions/browser/runtime-api.js +11 -11
  210. package/dist/extensions/browser/test-support.js +1 -1
  211. package/dist/extensions/device-pair/api.js +2 -2
  212. package/dist/extensions/device-pair/index.js +4 -4
  213. package/dist/extensions/device-pair/notify.js +1 -1
  214. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  215. package/dist/extensions/device-pair/qr-image.js +2 -2
  216. package/dist/extensions/google-meet/index.js +2 -2
  217. package/dist/extensions/imessage/api.js +3 -3
  218. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  219. package/dist/extensions/imessage/runtime-api.js +4 -4
  220. package/dist/extensions/irc/api.js +2 -2
  221. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  222. package/dist/extensions/line/api.js +2 -2
  223. package/dist/extensions/line/channel-plugin-api.js +1 -1
  224. package/dist/extensions/line/contract-api.js +1 -1
  225. package/dist/extensions/line/runtime-api.js +4 -4
  226. package/dist/extensions/line/setup-api.js +1 -1
  227. package/dist/extensions/llm-task/index.js +2 -2
  228. package/dist/extensions/lobster/index.js +3 -3
  229. package/dist/extensions/lobster/runtime-api.js +1 -1
  230. package/dist/extensions/mattermost/api.js +1 -1
  231. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  232. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  233. package/dist/extensions/mattermost/policy-api.js +1 -1
  234. package/dist/extensions/mattermost/runtime-api.js +6 -6
  235. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  236. package/dist/extensions/memory-core/api.js +1 -1
  237. package/dist/extensions/memory-core/cli-metadata.js +2 -2
  238. package/dist/extensions/memory-core/index.js +3 -3
  239. package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
  240. package/dist/extensions/microsoft/index.js +1 -1
  241. package/dist/extensions/microsoft/speech-provider.js +1 -1
  242. package/dist/extensions/microsoft/test-api.js +1 -1
  243. package/dist/extensions/minimax/index.js +1 -1
  244. package/dist/extensions/minimax/speech-provider.js +1 -1
  245. package/dist/extensions/msteams/api.js +1 -1
  246. package/dist/extensions/msteams/channel-plugin-api.js +1 -1
  247. package/dist/extensions/msteams/runtime-api.js +5 -5
  248. package/dist/extensions/msteams/test-api.js +1 -1
  249. package/dist/extensions/nextcloud-talk/api.js +1 -1
  250. package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
  251. package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
  252. package/dist/extensions/openshell/index.js +2 -2
  253. package/dist/extensions/signal/api.js +6 -6
  254. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  255. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  256. package/dist/extensions/signal/runtime-api.js +8 -8
  257. package/dist/extensions/skill-workshop/api.js +1 -1
  258. package/dist/extensions/skill-workshop/index.js +1 -1
  259. package/dist/extensions/synology-chat/api.js +1 -1
  260. package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
  261. package/dist/extensions/tlon/api.js +2 -2
  262. package/dist/extensions/tlon/channel-plugin-api.js +1 -1
  263. package/dist/extensions/tlon/runtime-api.js +1 -1
  264. package/dist/extensions/tlon/test-api.js +1 -1
  265. package/dist/extensions/twitch/api.js +1 -1
  266. package/dist/extensions/twitch/channel-plugin-api.js +1 -1
  267. package/dist/extensions/twitch/setup-plugin-api.js +1 -1
  268. package/dist/extensions/zalo/api.js +3 -3
  269. package/dist/extensions/zalo/channel-plugin-api.js +1 -1
  270. package/dist/extensions/zalo/runtime-api.js +2 -2
  271. package/dist/extensions/zalo/setup-api.js +2 -2
  272. package/dist/extensions/zalouser/api.js +4 -4
  273. package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
  274. package/dist/extensions/zalouser/runtime-api.js +8 -8
  275. package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
  276. package/dist/extensions/zalouser/test-api.js +4 -4
  277. package/dist/fallbacks-CR6GSZx5.js +31 -0
  278. package/dist/fallbacks-DuO41eqR.js +2 -0
  279. package/dist/fallbacks-shared-cZD0oSnX.js +111 -0
  280. package/dist/gateway-CTi4P0bk.js +115 -0
  281. package/dist/gateway-cli-DiXT82AL.js +1325 -0
  282. package/dist/gateway-rpc-Bq-pVMHn.js +14 -0
  283. package/dist/gateway-rpc.runtime-C23EQzC5.js +23 -0
  284. package/dist/gateway-rpc.runtime.js +1 -1
  285. package/dist/gateway-runtime-BR3N9P3q.js +15 -0
  286. package/dist/gateway-status-CRgYhpJo.js +584 -0
  287. package/dist/genesis-tools-mB3U5mZA.js +9115 -0
  288. package/dist/genesis-tools.runtime-CdTs0e6U.js +2 -0
  289. package/dist/genesis-tools.runtime.js +1 -1
  290. package/dist/get-reply-DZ2b8RH0.js +3879 -0
  291. package/dist/get-reply-from-config.runtime-DtL4cSUe.js +2 -0
  292. package/dist/get-reply-from-config.runtime.js +1 -1
  293. package/dist/graph-users-BkIkWfZy.js +1337 -0
  294. package/dist/health-7viGK1Im.js +469 -0
  295. package/dist/health-Dnp1EweA.js +3 -0
  296. package/dist/heartbeat-runner-BTCCQMuG.js +5 -0
  297. package/dist/heartbeat-runner-DfAaiAe7.js +1292 -0
  298. package/dist/heartbeat-runner.runtime-B4HXgACZ.js +4 -0
  299. package/dist/heartbeat-runner.runtime.js +1 -1
  300. package/dist/helpers-Bts8fTCo.js +320 -0
  301. package/dist/hooks-cli-DcTAWUQx.js +433 -0
  302. package/dist/http-endpoint-helpers-BT1NBMhv.js +41 -0
  303. package/dist/http-utils-B_TTb19C.js +924 -0
  304. package/dist/image-fallbacks-BSxulCpr.js +2 -0
  305. package/dist/image-fallbacks-BdbQMsja.js +31 -0
  306. package/dist/images-9cckfaLv.js +352 -0
  307. package/dist/inbound-reply-dispatch-CYtgAOpZ.js +73 -0
  308. package/dist/index.js +2 -2
  309. package/dist/infra-runtime-DXR8kcRT.js +39 -0
  310. package/dist/init-CjPPA1H0.js +59 -0
  311. package/dist/install-DLJF8qA4.js +190 -0
  312. package/dist/install.runtime-B_wJtoom.js +2 -0
  313. package/dist/launchd-OykeouWG.js +696 -0
  314. package/dist/library-BzChF6u9.js +45 -0
  315. package/dist/lifecycle-BzYiPHdW.js +229 -0
  316. package/dist/lifecycle-C5re4Pps.js +571 -0
  317. package/dist/lifecycle-core-DCeS7I2A.js +422 -0
  318. package/dist/lifecycle.runtime-B-tJ4JkM.js +2 -0
  319. package/dist/lifecycle.runtime.js +1 -1
  320. package/dist/list-C3saN4jV.js +2 -0
  321. package/dist/list-CXSiDlSN.js +2 -0
  322. package/dist/list-DMSdymkl.js +1201 -0
  323. package/dist/list-QiopLrb5.js +131 -0
  324. package/dist/list.probe-DyaF2edJ.js +419 -0
  325. package/dist/llm-slug-generator-BVJgrz13.js +79 -0
  326. package/dist/llm-slug-generator.js +1 -1
  327. package/dist/load-config-C-QpKZNj.js +35 -0
  328. package/dist/local-dispatch.runtime-zLnmF_Wh.js +8 -0
  329. package/dist/local-dispatch.runtime.js +1 -1
  330. package/dist/logs-cli-BosZUQjD.js +265 -0
  331. package/dist/logs-cli.runtime-CVOxtZtj.js +2 -0
  332. package/dist/logs-cli.runtime.js +1 -1
  333. package/dist/main-session-restart-recovery-CRTG8jvU.js +206 -0
  334. package/dist/managed-image-attachments-CGeUdh-A.js +2 -0
  335. package/dist/managed-image-attachments-CvjfVZxS.js +635 -0
  336. package/dist/manager-CznNbeVh.js +2 -0
  337. package/dist/manager-OyRJWBpE.js +2057 -0
  338. package/dist/markdown-to-line-oHIsEREp.js +790 -0
  339. package/dist/mcp/plugin-tools-serve.js +1 -1
  340. package/dist/mcp-cli-BnTIIeyA.js +725 -0
  341. package/dist/mcp-http-DCyyXjC6.js +529 -0
  342. package/dist/media-runtime-Cz9iit6D.js +329 -0
  343. package/dist/memory-core-host-runtime-cli-DZ0I6fFG.js +9 -0
  344. package/dist/message-CKMSghPM.js +232 -0
  345. package/dist/message-action-runner-BhMtHi5R.js +1407 -0
  346. package/dist/message-action-runner-CQRkxPID.js +2 -0
  347. package/dist/message-actions-BoLjX-Cs.js +143 -0
  348. package/dist/message.gateway.runtime-HANIkH2g.js +2 -0
  349. package/dist/message.gateway.runtime.js +1 -1
  350. package/dist/method-scopes-CVKEoi44.js +216 -0
  351. package/dist/models-auth-status-B-Mv4ebj.js +201 -0
  352. package/dist/models-cli-yBKYg40-.js +219 -0
  353. package/dist/models-http-BF6M973E.js +92 -0
  354. package/dist/monitor-B9VfGlmi.js +671 -0
  355. package/dist/monitor-BQ5Umwrc.js +1459 -0
  356. package/dist/monitor-BzzGjxc2.js +2 -0
  357. package/dist/monitor-C51eRypH.js +1237 -0
  358. package/dist/monitor-CtynHYuN.js +1661 -0
  359. package/dist/monitor-auth-CAfnLXi1.js +207 -0
  360. package/dist/monitor-hIFUjaQ5.js +788 -0
  361. package/dist/monitor-processing-BwFvVQV7.js +1974 -0
  362. package/dist/monitor.runtime-C4IsQ8Tg.js +2 -0
  363. package/dist/monitor.runtime.js +1 -1
  364. package/dist/monitor.webhook-Cyk4TYD-.js +180 -0
  365. package/dist/msteams-nwubaeIt.js +35 -0
  366. package/dist/native-hook-relay-pC5BaAsL.js +519 -0
  367. package/dist/nextcloud-talk-CFZriQJA.js +17 -0
  368. package/dist/node-cli-B0h1wrXR.js +2506 -0
  369. package/dist/node-service-BhD56-7r.js +68 -0
  370. package/dist/nodes-cli-C6i6IIFh.js +1046 -0
  371. package/dist/nodes-utils-w8SS4Vmb.js +84 -0
  372. package/dist/nodes.helpers-Dpk8LjQI.js +34 -0
  373. package/dist/notify-D3Psjkle.js +315 -0
  374. package/dist/onboard-helpers-C_caLTeb.js +6 -0
  375. package/dist/onboard-helpers-sLsRr-5l.js +204 -0
  376. package/dist/onboard-remote-BAQ8Ybuy.js +2 -0
  377. package/dist/onboard-remote-BwPX6vba.js +193 -0
  378. package/dist/onboard-skills-B3cMpFqK.js +2 -0
  379. package/dist/onboard-skills-B8gUFCpR.js +134 -0
  380. package/dist/onboard-xyUq8s8R.js +632 -0
  381. package/dist/openai-http-BLWuf_x9.js +500 -0
  382. package/dist/openresponses-http-B21orF7e.js +1128 -0
  383. package/dist/operator-approvals-client-bRfV9Ywa.js +68 -0
  384. package/dist/outbound-attachment-CTpQ1O5C.js +19 -0
  385. package/dist/outbound-media-DBOgVtv-.js +19 -0
  386. package/dist/outbound.runtime-BnCaPvIo.js +2 -0
  387. package/dist/outbound.runtime.js +1 -1
  388. package/dist/pair-command-approve-_kbfrhjq.js +44 -0
  389. package/dist/persistent-bindings.lifecycle-_3A07X4u.js +85 -0
  390. package/dist/persistent-bindings.lifecycle-dP7WfiuG.js +2 -0
  391. package/dist/pi-embedded-Bo7aGINx.js +4 -0
  392. package/dist/pi-embedded-CpvC_TY4.js +2905 -0
  393. package/dist/pi-embedded.runtime-l80MFX5c.js +4 -0
  394. package/dist/pi-embedded.runtime.js +1 -1
  395. package/dist/pi-tool-definition-adapter-COQSRMJW.js +217 -0
  396. package/dist/pi-tools-COW0I6Dx.js +1057 -0
  397. package/dist/pi-tools.before-tool-call-BUxAbnx6.js +2 -0
  398. package/dist/pi-tools.before-tool-call-CHWOH7FS.js +433 -0
  399. package/dist/plugin-CuJOfAQA.js +12195 -0
  400. package/dist/plugin-enabled-K8ODIpea.js +140 -0
  401. package/dist/plugin-registration-BavW8FwB.js +23 -0
  402. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  403. package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
  404. package/dist/plugin-sdk/acp-runtime.js +2 -2
  405. package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
  406. package/dist/plugin-sdk/agent-harness.js +6 -6
  407. package/dist/plugin-sdk/agent-runtime.js +2 -2
  408. package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
  409. package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
  410. package/dist/plugin-sdk/approval-runtime.js +1 -1
  411. package/dist/plugin-sdk/browser-node-runtime.js +4 -4
  412. package/dist/plugin-sdk/browser-setup-tools.js +3 -3
  413. package/dist/plugin-sdk/browser-support.js +7 -7
  414. package/dist/plugin-sdk/channel-core.js +2 -2
  415. package/dist/plugin-sdk/channel-inbound.js +2 -2
  416. package/dist/plugin-sdk/command-auth.js +1 -1
  417. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  418. package/dist/plugin-sdk/compat.js +1 -1
  419. package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
  420. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  421. package/dist/plugin-sdk/core.js +2 -2
  422. package/dist/plugin-sdk/direct-dm.js +1 -1
  423. package/dist/plugin-sdk/gateway-runtime.js +3 -3
  424. package/dist/plugin-sdk/googlechat.js +3 -3
  425. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  426. package/dist/plugin-sdk/index.js +1 -1
  427. package/dist/plugin-sdk/infra-runtime.js +2 -2
  428. package/dist/plugin-sdk/irc.js +2 -2
  429. package/dist/plugin-sdk/matrix.js +2 -2
  430. package/dist/plugin-sdk/mattermost.js +1 -1
  431. package/dist/plugin-sdk/media-runtime.js +2 -2
  432. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
  433. package/dist/plugin-sdk/memory-core.js +2 -2
  434. package/dist/plugin-sdk/msteams.js +4 -4
  435. package/dist/plugin-sdk/nextcloud-talk.js +2 -2
  436. package/dist/plugin-sdk/nostr.js +1 -1
  437. package/dist/plugin-sdk/outbound-media.js +1 -1
  438. package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
  439. package/dist/plugin-sdk/reply-runtime.js +4 -4
  440. package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
  441. package/dist/plugin-sdk/runtime.js +2 -2
  442. package/dist/plugin-sdk/session-visibility.js +1 -1
  443. package/dist/plugin-sdk/src/agents/subagent-control.d.ts +2 -2
  444. package/dist/plugin-sdk/src/gateway/protocol/index.d.ts +34 -3
  445. package/dist/plugin-sdk/src/gateway/protocol/schema/canvas.d.ts +43 -0
  446. package/dist/plugin-sdk/src/gateway/protocol/schema/protocol-schemas.d.ts +31 -0
  447. package/dist/plugin-sdk/src/gateway/protocol/schema/types.d.ts +2 -0
  448. package/dist/plugin-sdk/src/gateway/protocol/schema.d.ts +1 -0
  449. package/dist/plugin-sdk/src/plugin-sdk/approval-auth-helpers.d.ts +1 -1
  450. package/dist/plugin-sdk/testing.js +4 -4
  451. package/dist/plugin-sdk/tlon.js +1 -1
  452. package/dist/plugin-sdk/web-media.js +2 -2
  453. package/dist/plugin-sdk/zalo.js +1 -1
  454. package/dist/plugin-sdk/zalouser.js +2 -2
  455. package/dist/plugin-service-_9pkkiUS.js +2890 -0
  456. package/dist/plugins/runtime/index.js +1 -1
  457. package/dist/policy-BrXeII-A.js +328 -0
  458. package/dist/postinstall-inventory.json +449 -448
  459. package/dist/prepare.runtime-DDAttJh0.js +815 -0
  460. package/dist/prepare.runtime.js +1 -1
  461. package/dist/probe-A3zmoqnI.js +241 -0
  462. package/dist/probe-BI2aKtuv.js +74 -0
  463. package/dist/probe-BIjDXmE0.js +2205 -0
  464. package/dist/probe-Bht75arj.js +45 -0
  465. package/dist/probe-DRTzvcaE.js +1443 -0
  466. package/dist/probe-DaXQclu7.js +2 -0
  467. package/dist/probe-Dtp1ekg0.js +2 -0
  468. package/dist/program-TdCGX0aC.js +111 -0
  469. package/dist/prompt-select-styled-zAQZeJQu.js +20 -0
  470. package/dist/protocol-DWprZycP.js +2283 -0
  471. package/dist/provider-dispatcher-RVQ5ny3p.js +22 -0
  472. package/dist/provider-dispatcher-e7qXzL8Y.js +2 -0
  473. package/dist/qr-cli-BRKmL1xp.js +2 -0
  474. package/dist/qr-cli-Dv3PKtbg.js +349 -0
  475. package/dist/qr-image-BJXt-R5Y.js +2 -0
  476. package/dist/reaction-runtime-api-B_tKpY7u.js +116 -0
  477. package/dist/reactions-DrQks01C.js +998 -0
  478. package/dist/register-service-commands-xV8y3FHS.js +71 -0
  479. package/dist/register.agent-iDeNuiw1.js +248 -0
  480. package/dist/register.configure-2klz9fW8.js +15 -0
  481. package/dist/register.maintenance-FShE6C3p.js +438 -0
  482. package/dist/register.message-CPomBvI5.js +329 -0
  483. package/dist/register.onboard-aaUTaCQq.js +81 -0
  484. package/dist/register.runtime-DJ_p2orX.js +81 -0
  485. package/dist/register.runtime.js +1 -1
  486. package/dist/register.setup-TLLrIiSj.js +150 -0
  487. package/dist/register.status-health-sessions-CRgx0w7q.js +1215 -0
  488. package/dist/register.subclis-Dv1wGW3g.js +29 -0
  489. package/dist/register.subclis-DwIbjIAj.js +3 -0
  490. package/dist/register.subclis-core-Bko3H89P.js +249 -0
  491. package/dist/reply-dispatch-runtime-yjhlGmQa.js +13 -0
  492. package/dist/reply-media-paths.runtime-CuKBYqSs.js +2 -0
  493. package/dist/reply-media-paths.runtime-kh3iabdJ.js +146 -0
  494. package/dist/reply-media-paths.runtime.js +1 -1
  495. package/dist/reply-runtime-POkwAYBF.js +11 -0
  496. package/dist/reply.runtime-BZy3p8kg.js +2 -0
  497. package/dist/reply.runtime.js +1 -1
  498. package/dist/restart-health-BNrBfydi.js +202 -0
  499. package/dist/restart-health-wL13AbJS.js +2 -0
  500. package/dist/root-help-BktYhr6-.js +44 -0
  501. package/dist/routes-BLzTBe3U.js +3341 -0
  502. package/dist/routes-Do7Hp3Ju.js +2 -0
  503. package/dist/rpc-BLwz-9XH.js +61 -0
  504. package/dist/rpc.runtime-CKg08vpf.js +21 -0
  505. package/dist/rpc.runtime.js +1 -1
  506. package/dist/run-delivery.runtime-CJASymic.js +530 -0
  507. package/dist/run-delivery.runtime.js +1 -1
  508. package/dist/run-embedded.runtime-CX9arbKH.js +4 -0
  509. package/dist/run-embedded.runtime.js +1 -1
  510. package/dist/run-execution-cli.runtime-DjAY46Ol.js +4 -0
  511. package/dist/run-execution-cli.runtime.js +1 -1
  512. package/dist/run-executor.runtime-BFtk6iEm.js +277 -0
  513. package/dist/run-executor.runtime.js +1 -1
  514. package/dist/run-main-Bc7hVWlB.js +516 -0
  515. package/dist/run-subagent-registry.runtime-CF8amtGs.js +2 -0
  516. package/dist/run-subagent-registry.runtime.js +1 -1
  517. package/dist/run-wait-CHWyK79k.js +135 -0
  518. package/dist/runtime-CAJhi8f1.js +9 -0
  519. package/dist/runtime-XuiwQ4IM.js +973 -0
  520. package/dist/runtime-api--BeXVwyz.js +14 -0
  521. package/dist/runtime-api-Bjv_K-bW.js +4 -0
  522. package/dist/runtime-api-DfP95G4h.js +9 -0
  523. package/dist/runtime-api-Dju3YRRE.js +9 -0
  524. package/dist/runtime-embedded-pi.runtime-BnJbjva-.js +2 -0
  525. package/dist/runtime-embedded-pi.runtime.js +1 -1
  526. package/dist/runtime-internal-Ca1j_B7K.js +2 -0
  527. package/dist/runtime-options-BvWou_ca.js +275 -0
  528. package/dist/runtime-schema-DG-9mark.js +27780 -0
  529. package/dist/runtime-web-channel-plugin-CBDGLtiI.js +203 -0
  530. package/dist/scan-Cx5B3k3o.js +2 -0
  531. package/dist/scan-DHNMkx03.js +523 -0
  532. package/dist/secrets-cli-ukRqmE6x.js +2101 -0
  533. package/dist/security-cli-BiBQQ-88.js +486 -0
  534. package/dist/selection-Cud6Ozkq.js +2 -0
  535. package/dist/selection-qjyb9DhM.js +7736 -0
  536. package/dist/send-Bjv6gz1i.js +534 -0
  537. package/dist/send-CM9Yk5Kl.js +102 -0
  538. package/dist/send-DS-hlqsq.js +156 -0
  539. package/dist/send.runtime-CF_u1AVo.js +2 -0
  540. package/dist/send.runtime.js +1 -1
  541. package/dist/server-3pSUrSh6.js +77 -0
  542. package/dist/server-D_QJ4EdI.js +13 -0
  543. package/dist/server-context-BXVgdmge.js +2 -0
  544. package/dist/server-context-DdNdrdcV.js +847 -0
  545. package/dist/server-node-events-CAqPVPy4.js +481 -0
  546. package/dist/server-plugin-bootstrap-Bp2QUBjV.js +11398 -0
  547. package/dist/server-plugin-bootstrap-VFs6VC4p.js +2 -0
  548. package/dist/server-restart-sentinel-PI0b2Gyv.js +697 -0
  549. package/dist/server.impl-C4g02o6w.js +12736 -0
  550. package/dist/service-D6nRIQp0.js +120 -0
  551. package/dist/service-audit-CuYUK6l5.js +2 -0
  552. package/dist/service-audit-FsztusUk.js +261 -0
  553. package/dist/service-fyUTnkAE.js +2 -0
  554. package/dist/session-kill-http-DY5gLSmw.js +110 -0
  555. package/dist/session-reset-service-D1taSq3b.js +471 -0
  556. package/dist/session-route-BOJjXlWV.js +93 -0
  557. package/dist/session-status.runtime-B6NrMkU2.js +2 -0
  558. package/dist/session-status.runtime.js +1 -1
  559. package/dist/session-subagent-reactivation.runtime-CpbYOD80.js +2 -0
  560. package/dist/session-subagent-reactivation.runtime.js +1 -1
  561. package/dist/session-tab-registry-DECjIH2N.js +491 -0
  562. package/dist/session-visibility-CUqABJ6F.js +147 -0
  563. package/dist/sessions-helpers-B79P1mgf.js +304 -0
  564. package/dist/sessions-history-http-D3x9I2CD.js +383 -0
  565. package/dist/sessions-patch-idFzynvW.js +309 -0
  566. package/dist/sessions-resolve-DEMCJQTu.js +174 -0
  567. package/dist/sessions.runtime-Tbxzf5BH.js +2 -0
  568. package/dist/sessions.runtime.js +1 -1
  569. package/dist/setup-DvXcV-JY.js +495 -0
  570. package/dist/setup-api-DvrmJaiq.js +29 -0
  571. package/dist/setup-core-D1XPjfQr.js +171 -0
  572. package/dist/setup-core-eJZyYf85.js +176 -0
  573. package/dist/setup-surface-B7_Ps6_r.js +351 -0
  574. package/dist/setup-surface-Bk4lYh22.js +286 -0
  575. package/dist/setup-surface-BvccUnYq.js +219 -0
  576. package/dist/setup-surface-DoYhuKb1.js +403 -0
  577. package/dist/setup-surface-lvsksj3R.js +3 -0
  578. package/dist/setup.finalize-DxKMFMc_.js +539 -0
  579. package/dist/setup.gateway-config-CxYQl6JZ.js +250 -0
  580. package/dist/shared-BcVfaCRV.js +76 -0
  581. package/dist/shared-Cs_JtPmo.js +198 -0
  582. package/dist/shared-Tjzld0G6.js +121 -0
  583. package/dist/slash-state-DKR6rK8s.js +1911 -0
  584. package/dist/speech-provider-CJzbX5qG.js +209 -0
  585. package/dist/speech-provider-DLC_JPdP.js +216 -0
  586. package/dist/src-CTKGdCHv.js +3974 -0
  587. package/dist/startup-context-BlZVogKY.js +312 -0
  588. package/dist/status-B-r34lU4.js +3 -0
  589. package/dist/status-ClkoUp4o.js +2 -0
  590. package/dist/status-Cxc00N9a.js +209 -0
  591. package/dist/status-JFx75t88.js +190 -0
  592. package/dist/status-all-DkliFJYW.js +498 -0
  593. package/dist/status-json-CrGTMZWh.js +14 -0
  594. package/dist/status-json-command-DR9dHV95.js +84 -0
  595. package/dist/status-m9z9_EWg.js +2 -0
  596. package/dist/status-mIdcu6Cd.js +397 -0
  597. package/dist/status-runtime-shared-CkaK7bm4.js +257 -0
  598. package/dist/status-subagents.runtime-CCIoqL6q.js +18 -0
  599. package/dist/status-subagents.runtime.js +1 -1
  600. package/dist/status-text-3K5ON3ww.js +237 -0
  601. package/dist/status.gateway-connection.runtime-DjINyACC.js +2 -0
  602. package/dist/status.gateway-connection.runtime.js +1 -1
  603. package/dist/status.gather-7pCDV98-.js +2 -0
  604. package/dist/status.gather-CUXcp4EU.js +292 -0
  605. package/dist/status.runtime-B8RiZylS.js +2 -0
  606. package/dist/status.runtime.js +1 -1
  607. package/dist/status.scan-DszewobD.js +65 -0
  608. package/dist/status.scan-overview-C0eSlFGV.js +379 -0
  609. package/dist/status.scan.fast-json-3IR5FzGX.js +2 -0
  610. package/dist/status.scan.fast-json-Byy3YGsw.js +132 -0
  611. package/dist/status.summary-7QkrUPXI.js +214 -0
  612. package/dist/status.summary-DAlH2IPt.js +2 -0
  613. package/dist/subagent-announce-Cgq0tXM1.js +351 -0
  614. package/dist/subagent-announce-delivery-CKt_jQYe.js +726 -0
  615. package/dist/subagent-announce-output-DxXic4Q4.js +364 -0
  616. package/dist/subagent-control-DoYC7NGK.js +506 -0
  617. package/dist/subagent-followup.runtime-D9zLQ2zg.js +68 -0
  618. package/dist/subagent-followup.runtime.js +1 -1
  619. package/dist/subagent-orphan-recovery-B-f1P_9V.js +305 -0
  620. package/dist/subagent-registry-BlqNkrxa.js +3 -0
  621. package/dist/subagent-registry-COK0GlWy.js +1753 -0
  622. package/dist/subagent-registry.runtime.js +1 -1
  623. package/dist/subagent-spawn-Bu71yN3K.js +1005 -0
  624. package/dist/system-cli-BDBKF4EX.js +59 -0
  625. package/dist/system-prompt-BvLQVZGu.js +639 -0
  626. package/dist/targets-Bvxbtvp1.js +67 -0
  627. package/dist/task-executor-DYDCeAnK.js +360 -0
  628. package/dist/task-owner-access-DbaTH-83.js +74 -0
  629. package/dist/task-registry-CwGaJROW.js +2366 -0
  630. package/dist/task-registry-delivery-runtime-CSc0go9b.js +2 -0
  631. package/dist/task-registry-delivery-runtime-DzlKrbrk.js +3 -0
  632. package/dist/task-registry.maintenance-B9dYReWo.js +416 -0
  633. package/dist/task-registry.maintenance-BMmNtwe6.js +2 -0
  634. package/dist/telegram/token.js +1 -1
  635. package/dist/testing-Bmks5PrM.js +575 -0
  636. package/dist/text-report-CL-DD3RH.js +587 -0
  637. package/dist/tool-resolution-DWJjQ7CH.js +90 -0
  638. package/dist/tools-effective-inventory-Cm8H7A2A.js +152 -0
  639. package/dist/tools-invoke-http-CCURH0u8.js +206 -0
  640. package/dist/trash-B3lF3eWt.js +24 -0
  641. package/dist/tui-cli-24oh_Prd.js +4575 -0
  642. package/dist/update-cli-YBhNTeZV.js +1759 -0
  643. package/dist/upgrade-C3WPTXeR.js +1226 -0
  644. package/dist/video-generation-task-status-ZOfWEvIE.js +163 -0
  645. package/dist/wait-for-idle-before-flush-Cw9qqEAc.js +5986 -0
  646. package/dist/web-media-BvDXw5y1.js +2 -0
  647. package/dist/web-media-PnHEx5HT.js +715 -0
  648. package/dist/wizard-models-DIT_Mi4K.js +161 -0
  649. package/dist/workspace-run-C72pNbKQ.js +70 -0
  650. package/dist/zalo-js-BH-o_WTn.js +1157 -0
  651. package/package.json +1 -1
  652. package/dist/abort-Yw60gQ-C.js +0 -201
  653. package/dist/abort.runtime-DYQuut_O.js +0 -2
  654. package/dist/accounts-BSCHGPHp.js +0 -107
  655. package/dist/accounts-Bb0FqxV2.js +0 -104
  656. package/dist/accounts-BjGgx8lz.js +0 -2
  657. package/dist/accounts-Co4cbVCU.js +0 -66
  658. package/dist/accounts.runtime-V3yFS1uD.js +0 -2
  659. package/dist/acp-cli-emMnOaiO.js +0 -2193
  660. package/dist/acp-spawn-BmyUZuJX.js +0 -1093
  661. package/dist/acp-spawn-DPF5zmnN.js +0 -2
  662. package/dist/acp-stateful-target-driver-CJ4JyIHf.js +0 -89
  663. package/dist/action-agents-D1tXt8Kj.js +0 -67
  664. package/dist/action-focus-Bk6AJsNH.js +0 -132
  665. package/dist/action-help-4nFSAuVo.js +0 -7
  666. package/dist/action-info-D-byoefn.js +0 -101
  667. package/dist/action-kill-Bo-NwBVR.js +0 -33
  668. package/dist/action-list-lAa4rlzN.js +0 -21
  669. package/dist/action-log-BasoUC3L.js +0 -30
  670. package/dist/action-send-DwLkiz4x.js +0 -39
  671. package/dist/action-spawn-C70_iR8d.js +0 -47
  672. package/dist/action-unfocus-dUVMx5Fh.js +0 -29
  673. package/dist/actions.runtime-BdSo6rN8.js +0 -18
  674. package/dist/actions.runtime-BvY67XKu.js +0 -5
  675. package/dist/agent-DDBv3Vgl.js +0 -2
  676. package/dist/agent-command-DC7I_88W.js +0 -874
  677. package/dist/agent-harness-runtime-TA6YH7Ud.js +0 -144
  678. package/dist/agent-runner-utils-CMe-JIDq.js +0 -239
  679. package/dist/agent-runner.runtime-le6AmJRw.js +0 -3455
  680. package/dist/agent-runtime-CONy4fDD.js +0 -18
  681. package/dist/agents-BlbOM4XW.js +0 -953
  682. package/dist/agents-Byj8CDAP.js +0 -5
  683. package/dist/aliases-C3Ks5x38.js +0 -2
  684. package/dist/aliases-CxBcx9gF.js +0 -96
  685. package/dist/api-CLoj7nYH.js +0 -3
  686. package/dist/api-DZiRkVPk.js +0 -5
  687. package/dist/api-_Y4nIHNo.js +0 -139
  688. package/dist/approval-gateway-resolver-Ba_2kb3B.js +0 -29
  689. package/dist/approval-gateway-runtime-7VMivk0A.js +0 -2
  690. package/dist/approval-handler-runtime-Bh0onoHD.js +0 -439
  691. package/dist/approval-native-runtime-IYFyT8Hf.js +0 -729
  692. package/dist/attempt-execution.runtime-CpL2tsYd.js +0 -509
  693. package/dist/attempt.prompt-helpers-Gx9nGKbW.js +0 -221
  694. package/dist/attempt.tool-run-context-BmuljBMs.js +0 -933
  695. package/dist/audit-CsjqOEVE.js +0 -939
  696. package/dist/audit.runtime-BybEaYH4.js +0 -7
  697. package/dist/auth-BFbLz2gx.js +0 -383
  698. package/dist/auth-DdoNShRm.js +0 -2
  699. package/dist/auth-order-CtO2WQTH.js +0 -2
  700. package/dist/auth-order-zXIiW-Cn.js +0 -96
  701. package/dist/bash-tools-CnDYSbnX.js +0 -2824
  702. package/dist/bash-tools-DiOcKaak.js +0 -3
  703. package/dist/binding-routing-E9Gh_NqO.js +0 -85
  704. package/dist/binding-targets-C5PbBaZ6.js +0 -121
  705. package/dist/bridge-server-DragdaQD.js +0 -113
  706. package/dist/browser-control-auth-D_M31xJ1.js +0 -2
  707. package/dist/browser-node-runtime-Bgu82luB.js +0 -12
  708. package/dist/browser-profiles-C3ffkgOt.js +0 -2
  709. package/dist/browser-runtime-D84IBo4A.js +0 -387
  710. package/dist/browser-setup-tools-VC7rGCyn.js +0 -13
  711. package/dist/build-DeGDX_pJ.js +0 -550
  712. package/dist/call-CbvF41H8.js +0 -3
  713. package/dist/call-DuDGOVT1.js +0 -331
  714. package/dist/call.runtime-DztWXjMr.js +0 -2
  715. package/dist/capability-cli-DoJLi3eS.js +0 -1401
  716. package/dist/catchup-Dk-5hIwm.js +0 -300
  717. package/dist/channel-BJ9iEC4Y.js +0 -595
  718. package/dist/channel-BdvsbgZE.js +0 -453
  719. package/dist/channel-Bu-7KaIx.js +0 -1802
  720. package/dist/channel-C9vQNMK1.js +0 -350
  721. package/dist/channel-CZoVAZyW.js +0 -491
  722. package/dist/channel-Cr2KTwyo.js +0 -840
  723. package/dist/channel-DCeC6AEQ.js +0 -297
  724. package/dist/channel-DOGp2TfT.js +0 -1320
  725. package/dist/channel-Dfq1lxxI.js +0 -226
  726. package/dist/channel-core-DiltAzdr.js +0 -5
  727. package/dist/channel-hZDaTBpm.js +0 -1100
  728. package/dist/channel-inbound-DvOS-Z1s.js +0 -31
  729. package/dist/channel-plugin-runtime-PFRHQ61T.js +0 -771
  730. package/dist/channel-runtime-BAjxIEfQ.js +0 -425
  731. package/dist/channel-szBwbQZB.js +0 -1174
  732. package/dist/channel.runtime-B1Ry35gt.js +0 -89
  733. package/dist/channel.runtime-BNp6GxaQ.js +0 -34702
  734. package/dist/channel.runtime-BfjvNvbj.js +0 -2364
  735. package/dist/channel.runtime-BlGn4QYV.js +0 -4
  736. package/dist/channel.runtime-BozvCkMo.js +0 -26
  737. package/dist/channel.runtime-D7bv5rJl.js +0 -576
  738. package/dist/channel.runtime-DQ5gSgeW.js +0 -109
  739. package/dist/channel.runtime-IxClQMdT.js +0 -430
  740. package/dist/channel.setup-BsfyGPgV.js +0 -10
  741. package/dist/channels-Dn2VHRmZ.js +0 -733
  742. package/dist/channels-cli-l4xjPvDv.js +0 -268
  743. package/dist/chat-zUeX8mQw.js +0 -2758
  744. package/dist/clawbot-cli-C3BFdHJB.js +0 -9
  745. package/dist/cli-BTnpFsj1.js +0 -2
  746. package/dist/cli-CAFQ6Cwy.js +0 -72
  747. package/dist/cli-CiqIbwtg.js +0 -219
  748. package/dist/cli-DL1ppK38.js +0 -2
  749. package/dist/cli-runner-DO6lEPJr.js +0 -286
  750. package/dist/cli-runner.runtime-B-Ic4DyC.js +0 -3
  751. package/dist/cli-runner.runtime-C4cAORcg.js +0 -4
  752. package/dist/cli.runtime-CYHctHVS.js +0 -1261
  753. package/dist/client-Bb_miREU.js +0 -138
  754. package/dist/client-CrPccv7a.js +0 -713
  755. package/dist/command-auth-B7P-1IeA.js +0 -76
  756. package/dist/command-config-resolution-BB-SsCob.js +0 -23
  757. package/dist/command-config-resolution-DMKYb0Kh.js +0 -2
  758. package/dist/command-config-resolution.runtime-Coeaa9lz.js +0 -2
  759. package/dist/command-registry-B2JzWHqy.js +0 -9
  760. package/dist/command-registry-CNUpJUp8.js +0 -4
  761. package/dist/command-registry-core-BLap9aka.js +0 -101
  762. package/dist/command-secret-gateway-ChRXthnT.js +0 -528
  763. package/dist/command-status.runtime-D8VWyC3v.js +0 -87
  764. package/dist/commands-acp-QLk1cU5f.js +0 -77
  765. package/dist/commands-compact.runtime-BIHG2RSY.js +0 -10
  766. package/dist/commands-handlers.runtime-DjimbxSJ.js +0 -4597
  767. package/dist/commands-status-DiIQSYSt.js +0 -16
  768. package/dist/commands-status.runtime-DBRxICN6.js +0 -3
  769. package/dist/commands-subagents-control.runtime-BmqXiKHu.js +0 -3
  770. package/dist/commands-subagents-control.runtime-CVQSOd8H.js +0 -2
  771. package/dist/commands-system-prompt-2qwZc3xL.js +0 -158
  772. package/dist/commands-system-prompt-Clnn_Gct.js +0 -2
  773. package/dist/commands.runtime-DAqpiDPr.js +0 -166
  774. package/dist/compact-DqOkQZYr.js +0 -1118
  775. package/dist/compact.runtime-CC_l29j4.js +0 -12
  776. package/dist/completion-cli-DZFJPSiF.js +0 -328
  777. package/dist/config-D9XEe0Cd.js +0 -251
  778. package/dist/config-cli-DVDwIjKr.js +0 -1078
  779. package/dist/configure-39oQUHuK.js +0 -1245
  780. package/dist/configure-BGD8tViZ.js +0 -2
  781. package/dist/connect-options-Fpky6zuL.js +0 -699
  782. package/dist/control-auth-BlqH4IVx.js +0 -125
  783. package/dist/control-service-CaqDohiY.js +0 -156
  784. package/dist/control-ui-CIhsZ2Nb.js +0 -688
  785. package/dist/conversation-id-BH9GFVB2.js +0 -235
  786. package/dist/conversation-id-UdIegcf4.js +0 -38
  787. package/dist/conversation-runtime-Bao0kIPf.js +0 -31
  788. package/dist/core-DXUh5Xbm.js +0 -275
  789. package/dist/cron-cli-B1mxHnGP.js +0 -713
  790. package/dist/daemon-cli-CaHBNwMy.js +0 -12
  791. package/dist/daemon-install-BBwOxf1q.js +0 -64
  792. package/dist/delegate-7G7R4C-C.js +0 -64
  793. package/dist/delivery.runtime-Ci0ToUzj.js +0 -253
  794. package/dist/detached-task-runtime-BMdSrcuz.js +0 -73
  795. package/dist/devices-cli-DnEQH3R2.js +0 -496
  796. package/dist/diagnostics-C8VwSDtU.js +0 -154
  797. package/dist/direct-dm-BSEkIiOe.js +0 -64
  798. package/dist/dispatch-1gv6It-6.js +0 -1131
  799. package/dist/dispatch-acp-hbhR9aHr.js +0 -981
  800. package/dist/dispatch-acp-manager.runtime-BXQbK1cO.js +0 -3
  801. package/dist/dispatch-acp.runtime-Dhx090J2.js +0 -19
  802. package/dist/doctor-device-pairing-1gf3tk3g.js +0 -307
  803. package/dist/doctor-gateway-daemon-flow-LEnN6pL-.js +0 -250
  804. package/dist/doctor-gateway-health-DwxLkTV4.js +0 -60
  805. package/dist/doctor-gateway-services-BhqUOY_e.js +0 -316
  806. package/dist/doctor-health-CdJkaUYf.js +0 -59
  807. package/dist/doctor-health-contributions-BaTnIzCT.js +0 -486
  808. package/dist/doctor-prompter-BZTb5rOn.js +0 -56
  809. package/dist/doctor-workspace-status-DnBARoPa.js +0 -75
  810. package/dist/dreaming-BAGFdUxh.js +0 -1574
  811. package/dist/dreaming-narrative-XoOfVb0x.js +0 -595
  812. package/dist/embedded-gateway-stub.runtime-xwZ-M7Ei.js +0 -9
  813. package/dist/embeddings-http-BDz5OXZk.js +0 -205
  814. package/dist/exec-approvals-cli-CWVWSMk-.js +0 -498
  815. package/dist/execute.runtime-COmoY37L.js +0 -1366
  816. package/dist/fallbacks-BKA5XrxA.js +0 -31
  817. package/dist/fallbacks-QvezaDAr.js +0 -2
  818. package/dist/fallbacks-shared-DS-qTOLR.js +0 -111
  819. package/dist/gateway-C0YHaLXO.js +0 -115
  820. package/dist/gateway-cli-DJBCD8J5.js +0 -1325
  821. package/dist/gateway-rpc-CmJXd4SU.js +0 -14
  822. package/dist/gateway-rpc.runtime-C9Fs2mSx.js +0 -23
  823. package/dist/gateway-runtime-Bm2_MhFn.js +0 -15
  824. package/dist/gateway-status-DXKMKFtB.js +0 -584
  825. package/dist/genesis-tools-AolFZ-0I.js +0 -8999
  826. package/dist/genesis-tools.runtime-CBWXJqzw.js +0 -2
  827. package/dist/get-reply-BpxjHQBp.js +0 -3879
  828. package/dist/get-reply-from-config.runtime-DJKEqLSi.js +0 -2
  829. package/dist/graph-users-D2Q5UTGQ.js +0 -1337
  830. package/dist/health-BNKpuAPB.js +0 -469
  831. package/dist/health-BkxZfKx8.js +0 -3
  832. package/dist/heartbeat-runner-Bdu2q6k3.js +0 -5
  833. package/dist/heartbeat-runner-C0B-c-fv.js +0 -1292
  834. package/dist/heartbeat-runner.runtime-Cic23eNy.js +0 -4
  835. package/dist/helpers-B-g1rXs3.js +0 -320
  836. package/dist/hooks-cli-BfCr2In5.js +0 -433
  837. package/dist/http-endpoint-helpers-CY0P-_y2.js +0 -41
  838. package/dist/http-utils-Da8hOLty.js +0 -924
  839. package/dist/image-fallbacks-Dgy-LmDo.js +0 -2
  840. package/dist/image-fallbacks-RlfTqOne.js +0 -31
  841. package/dist/images-e55CDILU.js +0 -352
  842. package/dist/inbound-reply-dispatch-D4KJHWLG.js +0 -73
  843. package/dist/infra-runtime-BTJv3KK8.js +0 -39
  844. package/dist/init-q4INH9uv.js +0 -59
  845. package/dist/install-BT4BNeMX.js +0 -190
  846. package/dist/install.runtime-BnqPyIyn.js +0 -2
  847. package/dist/launchd-BM_37PLv.js +0 -698
  848. package/dist/library-DGd4UZKC.js +0 -45
  849. package/dist/lifecycle-B_RLw4uY.js +0 -229
  850. package/dist/lifecycle-Bw01evSl.js +0 -571
  851. package/dist/lifecycle-core-CTjCo-k0.js +0 -422
  852. package/dist/lifecycle.runtime-BxpD2Ol7.js +0 -2
  853. package/dist/list-BXa4zUF-.js +0 -2
  854. package/dist/list-BugTSXmQ.js +0 -131
  855. package/dist/list-CgC_rsta.js +0 -1201
  856. package/dist/list-D2sk1YPs.js +0 -2
  857. package/dist/list.probe-C6zfgLdG.js +0 -419
  858. package/dist/llm-slug-generator-DsWJvqNx.js +0 -79
  859. package/dist/load-config-D6ZKPY7I.js +0 -35
  860. package/dist/local-dispatch.runtime-MWMxyZKj.js +0 -8
  861. package/dist/logs-cli-Dn-8jl3z.js +0 -265
  862. package/dist/logs-cli.runtime-DwsccWUJ.js +0 -2
  863. package/dist/main-session-restart-recovery-6Uh4W8ZJ.js +0 -206
  864. package/dist/managed-image-attachments-DHawPS1-.js +0 -2
  865. package/dist/managed-image-attachments-DjtxwZ9o.js +0 -635
  866. package/dist/manager-D0tkR46e.js +0 -2057
  867. package/dist/manager-g_P1RDky.js +0 -2
  868. package/dist/markdown-to-line-7AxR7QFo.js +0 -790
  869. package/dist/mcp-cli-Cw2XQMOA.js +0 -725
  870. package/dist/mcp-http-DFKqya8U.js +0 -529
  871. package/dist/media-runtime-D2xH8y9Y.js +0 -329
  872. package/dist/memory-core-host-runtime-cli-DaAsOXiU.js +0 -9
  873. package/dist/message-BDCG7eWj.js +0 -232
  874. package/dist/message-action-runner-6C7kXcC9.js +0 -2
  875. package/dist/message-action-runner-C2P3efhU.js +0 -1407
  876. package/dist/message-actions-BWQWt5gT.js +0 -143
  877. package/dist/message.gateway.runtime-BXChuYAf.js +0 -2
  878. package/dist/method-scopes-DPvtAkiy.js +0 -215
  879. package/dist/models-auth-status-B8lnM1PS.js +0 -201
  880. package/dist/models-cli-DbUA18AN.js +0 -219
  881. package/dist/models-http-n4zWGd1p.js +0 -92
  882. package/dist/monitor-BEJe2ceJ.js +0 -1237
  883. package/dist/monitor-BO9i6U5R.js +0 -1459
  884. package/dist/monitor-BZLrxL_x.js +0 -1661
  885. package/dist/monitor-CDDxHGlD.js +0 -788
  886. package/dist/monitor-D779kLc0.js +0 -671
  887. package/dist/monitor-V5ZNCrQL.js +0 -2
  888. package/dist/monitor-auth-D2rCHNgr.js +0 -207
  889. package/dist/monitor-processing-BLbsNFVv.js +0 -1974
  890. package/dist/monitor.runtime-RrusGXVO.js +0 -2
  891. package/dist/monitor.webhook-B0DuBNWa.js +0 -180
  892. package/dist/msteams-hh9nwLlZ.js +0 -35
  893. package/dist/native-hook-relay-BygYZoeR.js +0 -519
  894. package/dist/nextcloud-talk-AadRCqXn.js +0 -17
  895. package/dist/node-cli-FF1zz0JU.js +0 -2506
  896. package/dist/node-service-f8mmgM5L.js +0 -68
  897. package/dist/nodes-cli-tQ5dpecZ.js +0 -1046
  898. package/dist/nodes-utils-BfpGcUca.js +0 -84
  899. package/dist/nodes.helpers-CMXxavTs.js +0 -34
  900. package/dist/notify-DaNP5Zyh.js +0 -315
  901. package/dist/onboard-B9hx80Dm.js +0 -632
  902. package/dist/onboard-helpers-BlPrFJHK.js +0 -204
  903. package/dist/onboard-helpers-kL8mgUkl.js +0 -6
  904. package/dist/onboard-remote-ByHuQd1m.js +0 -193
  905. package/dist/onboard-remote-CRPXcrWy.js +0 -2
  906. package/dist/onboard-skills-ChtyNRCd.js +0 -2
  907. package/dist/onboard-skills-DROlYXya.js +0 -134
  908. package/dist/openai-http-2An5HAJU.js +0 -500
  909. package/dist/openresponses-http-DpbJXZP4.js +0 -1128
  910. package/dist/operator-approvals-client-BoN_VmkB.js +0 -68
  911. package/dist/outbound-attachment-Cgs2OPPc.js +0 -19
  912. package/dist/outbound-media-0d3HzPSa.js +0 -19
  913. package/dist/outbound.runtime-D_aebUn6.js +0 -2
  914. package/dist/pair-command-approve-i-1VECJx.js +0 -44
  915. package/dist/persistent-bindings.lifecycle-eZyKQ1D8.js +0 -85
  916. package/dist/persistent-bindings.lifecycle-mxY73TJR.js +0 -2
  917. package/dist/pi-embedded-0fErjTQ7.js +0 -2905
  918. package/dist/pi-embedded-Bc1jC2x0.js +0 -4
  919. package/dist/pi-embedded.runtime-Bn_RZ5z8.js +0 -4
  920. package/dist/pi-tool-definition-adapter-thh7LO1t.js +0 -217
  921. package/dist/pi-tools-BtlLDovQ.js +0 -1057
  922. package/dist/pi-tools.before-tool-call-BJ_X8Dq3.js +0 -2
  923. package/dist/pi-tools.before-tool-call-DdPCGWCs.js +0 -433
  924. package/dist/plugin-CdHHk4Xn.js +0 -12195
  925. package/dist/plugin-enabled-DybhbjKQ.js +0 -140
  926. package/dist/plugin-registration-Bgwpsokw.js +0 -23
  927. package/dist/plugin-service-ClhrJfT3.js +0 -2890
  928. package/dist/policy-CoqHgREn.js +0 -328
  929. package/dist/prepare.runtime-CawO_32K.js +0 -815
  930. package/dist/probe-BP3QS65i.js +0 -74
  931. package/dist/probe-BdCXAH_u.js +0 -2
  932. package/dist/probe-Cv5tXOMP.js +0 -2205
  933. package/dist/probe-D-D_1oc4.js +0 -241
  934. package/dist/probe-DO-gll0g.js +0 -2
  935. package/dist/probe-T6c0F73q.js +0 -45
  936. package/dist/probe-dxji7IxZ.js +0 -1443
  937. package/dist/program-GMPfHt5E.js +0 -111
  938. package/dist/prompt-select-styled-BvuJNEJG.js +0 -20
  939. package/dist/protocol-Batc2DmY.js +0 -2234
  940. package/dist/provider-dispatcher-CGYoOdKf.js +0 -2
  941. package/dist/provider-dispatcher-iTEDM88F.js +0 -22
  942. package/dist/qr-cli-6IxenO1C.js +0 -349
  943. package/dist/qr-cli-D63piSog.js +0 -2
  944. package/dist/qr-image-BAPDnfbt.js +0 -2
  945. package/dist/reaction-runtime-api-DgwRXTz2.js +0 -116
  946. package/dist/reactions-Dnh7t4Zl.js +0 -998
  947. package/dist/register-service-commands-D7w01SKL.js +0 -71
  948. package/dist/register.agent-j1Eno4xr.js +0 -248
  949. package/dist/register.configure-ubwxTkGt.js +0 -15
  950. package/dist/register.maintenance-B7FuM_ZW.js +0 -438
  951. package/dist/register.message-QR3u9rBl.js +0 -329
  952. package/dist/register.onboard-Bdcf_lH0.js +0 -81
  953. package/dist/register.runtime-QDduc4yj.js +0 -81
  954. package/dist/register.setup-DzVV6tdQ.js +0 -150
  955. package/dist/register.status-health-sessions-Brw3VcxG.js +0 -1215
  956. package/dist/register.subclis-B8qDbqPl.js +0 -29
  957. package/dist/register.subclis-DdoN3nZi.js +0 -3
  958. package/dist/register.subclis-core-CWHmnIoe.js +0 -249
  959. package/dist/reply-dispatch-runtime-BVLvCeJ0.js +0 -13
  960. package/dist/reply-media-paths.runtime-CmS_Bnnf.js +0 -2
  961. package/dist/reply-media-paths.runtime-DCj1JhDR.js +0 -146
  962. package/dist/reply-runtime-BXkvfLv_.js +0 -11
  963. package/dist/reply.runtime-BTkpxI5R.js +0 -2
  964. package/dist/restart-health-6cjrRBpF.js +0 -202
  965. package/dist/restart-health-b6Qw43Tj.js +0 -2
  966. package/dist/root-help-DDa1oEtT.js +0 -44
  967. package/dist/routes-CoCMty69.js +0 -2
  968. package/dist/routes-D9uC_Zdy.js +0 -3341
  969. package/dist/rpc-DpLGM3FH.js +0 -61
  970. package/dist/rpc.runtime-B27EA5A0.js +0 -21
  971. package/dist/run-delivery.runtime-OmILefLX.js +0 -530
  972. package/dist/run-embedded.runtime-Dc43u_Z7.js +0 -4
  973. package/dist/run-execution-cli.runtime-DL5w7Ac8.js +0 -4
  974. package/dist/run-executor.runtime-Bzwt0zP-.js +0 -277
  975. package/dist/run-main-BLD1wTLU.js +0 -516
  976. package/dist/run-subagent-registry.runtime-CddCeg6W.js +0 -2
  977. package/dist/run-wait-D4Gxuyru.js +0 -135
  978. package/dist/runtime-8BuIPrSY.js +0 -973
  979. package/dist/runtime-Co8r21pw.js +0 -9
  980. package/dist/runtime-api-BG0XWkir.js +0 -4
  981. package/dist/runtime-api-BjBzlgns.js +0 -9
  982. package/dist/runtime-api-DlYbbA-n.js +0 -14
  983. package/dist/runtime-api-faT33SE2.js +0 -9
  984. package/dist/runtime-embedded-pi.runtime-QdJ7K4t0.js +0 -2
  985. package/dist/runtime-internal-C0xc_Zhf.js +0 -2
  986. package/dist/runtime-options-DLv7ygkO.js +0 -275
  987. package/dist/runtime-schema-CQK5R5Pl.js +0 -27780
  988. package/dist/runtime-web-channel-plugin-DQoEo6bK.js +0 -203
  989. package/dist/scan-Yz6DoQn5.js +0 -523
  990. package/dist/scan-k38hL_6o.js +0 -2
  991. package/dist/secrets-cli-Bjvr0bOw.js +0 -2101
  992. package/dist/security-cli-C2gkMFcB.js +0 -486
  993. package/dist/selection-DC8EXnRg.js +0 -7736
  994. package/dist/selection-DmSFI5k4.js +0 -2
  995. package/dist/send-CMqcsAS2.js +0 -534
  996. package/dist/send-CT6EfHrc.js +0 -102
  997. package/dist/send-_ANvjE_C.js +0 -156
  998. package/dist/send.runtime-COIjG4BV.js +0 -2
  999. package/dist/server-COkv9Si4.js +0 -13
  1000. package/dist/server-DHLQZJL8.js +0 -77
  1001. package/dist/server-context-6jnr-aAw.js +0 -2
  1002. package/dist/server-context-DK1QsdLh.js +0 -847
  1003. package/dist/server-node-events-q8H0odkq.js +0 -481
  1004. package/dist/server-plugin-bootstrap-Bw4a88yA.js +0 -2
  1005. package/dist/server-plugin-bootstrap-By_w9ngt.js +0 -11333
  1006. package/dist/server-restart-sentinel-CGLYF3mk.js +0 -697
  1007. package/dist/server.impl-8j4SImks.js +0 -12735
  1008. package/dist/service-CNjb_qXC.js +0 -2
  1009. package/dist/service-CyR3mZIU.js +0 -120
  1010. package/dist/service-audit-DIL0OiMa.js +0 -260
  1011. package/dist/service-audit-pwloDggS.js +0 -2
  1012. package/dist/session-kill-http-Dek5w0Ee.js +0 -110
  1013. package/dist/session-reset-service-B_9Ps0kr.js +0 -471
  1014. package/dist/session-route-Cr6vOd9_.js +0 -93
  1015. package/dist/session-status.runtime-C_x1MHH5.js +0 -2
  1016. package/dist/session-subagent-reactivation.runtime-BKWuNild.js +0 -2
  1017. package/dist/session-tab-registry-C08V5jx6.js +0 -491
  1018. package/dist/session-visibility-D4j8hN_B.js +0 -147
  1019. package/dist/sessions-helpers-DmUVRk16.js +0 -304
  1020. package/dist/sessions-history-http-DN3KzEnX.js +0 -383
  1021. package/dist/sessions-patch-BPtlF0Lu.js +0 -309
  1022. package/dist/sessions-resolve-D6KPfG_4.js +0 -174
  1023. package/dist/sessions.runtime-DGL1-G20.js +0 -2
  1024. package/dist/setup-CkYiQoP0.js +0 -495
  1025. package/dist/setup-api-CUGYqGNT.js +0 -29
  1026. package/dist/setup-core-BmplfubJ.js +0 -171
  1027. package/dist/setup-core-C5ddWpfy.js +0 -176
  1028. package/dist/setup-surface-2JmEfowI.js +0 -219
  1029. package/dist/setup-surface-BpSH7F_m.js +0 -351
  1030. package/dist/setup-surface-BzHQx_GD.js +0 -403
  1031. package/dist/setup-surface-DOH6kc6w.js +0 -286
  1032. package/dist/setup-surface-DiYEprKG.js +0 -3
  1033. package/dist/setup.finalize-Ci2HBkDq.js +0 -539
  1034. package/dist/setup.gateway-config-CyG_Fzaa.js +0 -250
  1035. package/dist/shared-BItUH43s.js +0 -121
  1036. package/dist/shared-D7diJkX6.js +0 -198
  1037. package/dist/shared-DJU_HCJ1.js +0 -76
  1038. package/dist/slash-state-C4YD-tLz.js +0 -1911
  1039. package/dist/speech-provider-CNOimJB2.js +0 -209
  1040. package/dist/speech-provider-D9i0DEZ1.js +0 -216
  1041. package/dist/src-8HdytGc7.js +0 -3974
  1042. package/dist/startup-context-CfcCyUU0.js +0 -312
  1043. package/dist/status-B94yciC9.js +0 -397
  1044. package/dist/status-BUkUYtFm.js +0 -190
  1045. package/dist/status-BsHC-0MV.js +0 -2
  1046. package/dist/status-D4jNATg0.js +0 -209
  1047. package/dist/status-U8ut-X2Q.js +0 -2
  1048. package/dist/status-all-CIzsXQnV.js +0 -498
  1049. package/dist/status-json-alPkfWTd.js +0 -14
  1050. package/dist/status-json-command-CAkzWzw7.js +0 -84
  1051. package/dist/status-jxNdVQVZ.js +0 -3
  1052. package/dist/status-runtime-shared-BSsA48i9.js +0 -257
  1053. package/dist/status-subagents.runtime-hIKg6PXV.js +0 -18
  1054. package/dist/status-text-BmLJrLth.js +0 -237
  1055. package/dist/status.gateway-connection.runtime-Dr7HJ1wZ.js +0 -2
  1056. package/dist/status.gather-DFY0T97g.js +0 -2
  1057. package/dist/status.gather-e6sfNh8I.js +0 -292
  1058. package/dist/status.runtime-DBvapXQS.js +0 -2
  1059. package/dist/status.scan-DSpkE-Q-.js +0 -65
  1060. package/dist/status.scan-overview-Dr72bkbi.js +0 -379
  1061. package/dist/status.scan.fast-json-C7k_m46S.js +0 -2
  1062. package/dist/status.scan.fast-json-KHh7R3wX.js +0 -132
  1063. package/dist/status.summary-C4r9lkCH.js +0 -214
  1064. package/dist/status.summary-D0EJwkmX.js +0 -2
  1065. package/dist/subagent-announce-Bu5-8O3P.js +0 -351
  1066. package/dist/subagent-announce-delivery-4hk9P48s.js +0 -726
  1067. package/dist/subagent-announce-output-Csyi1-Kz.js +0 -364
  1068. package/dist/subagent-control-DAeNsV_G.js +0 -506
  1069. package/dist/subagent-followup.runtime-Bch92LIq.js +0 -68
  1070. package/dist/subagent-orphan-recovery-mNzyr1b-.js +0 -305
  1071. package/dist/subagent-registry-BMjQxBxi.js +0 -3
  1072. package/dist/subagent-registry-D4DFKQCL.js +0 -1753
  1073. package/dist/subagent-spawn-C13uUm47.js +0 -1005
  1074. package/dist/system-cli-BU6GhJxG.js +0 -59
  1075. package/dist/system-prompt-BsfYBoK_.js +0 -638
  1076. package/dist/targets-eYkepVzz.js +0 -67
  1077. package/dist/task-executor-DzJLcm4D.js +0 -360
  1078. package/dist/task-owner-access-DW9EbhjP.js +0 -74
  1079. package/dist/task-registry-DBJkAtFF.js +0 -2366
  1080. package/dist/task-registry-delivery-runtime-BdkPeGC1.js +0 -2
  1081. package/dist/task-registry-delivery-runtime-Ov88LGnv.js +0 -3
  1082. package/dist/task-registry.maintenance-BU6Z4V_9.js +0 -416
  1083. package/dist/task-registry.maintenance-sEo6eYdx.js +0 -2
  1084. package/dist/testing-B2jHeQft.js +0 -575
  1085. package/dist/text-report-HYrgZP8-.js +0 -587
  1086. package/dist/tool-resolution-BZxaDOKg.js +0 -90
  1087. package/dist/tools-effective-inventory-BCvCprpD.js +0 -152
  1088. package/dist/tools-invoke-http-Dt1rsx4a.js +0 -206
  1089. package/dist/trash-F4tvjrKS.js +0 -24
  1090. package/dist/tui-cli-DlQ1oejy.js +0 -4575
  1091. package/dist/update-cli-DHMdwQWA.js +0 -1759
  1092. package/dist/upgrade-UR-EI5pO.js +0 -1226
  1093. package/dist/video-generation-task-status-qtHrIZLt.js +0 -163
  1094. package/dist/wait-for-idle-before-flush-CYB_61O0.js +0 -5986
  1095. package/dist/web-media-DtmXd0Ej.js +0 -2
  1096. package/dist/web-media-UhS-eUvv.js +0 -600
  1097. package/dist/wizard-models-BKqMCaCm.js +0 -161
  1098. package/dist/workspace-run-DcHTcwZo.js +0 -70
  1099. package/dist/zalo-js-B0dhviG7.js +0 -1157
@@ -0,0 +1,1661 @@
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-DNd8mbjy.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-B4pK_Jpd.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-RVQ5ny3p.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-DF38Qk5T.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-CiIsBMuo.js";
37
+ import "./reply-runtime-POkwAYBF.js";
38
+ import "./reply-dispatch-runtime-yjhlGmQa.js";
39
+ import "./infra-runtime-DXR8kcRT.js";
40
+ import { n as resolveConfiguredBindingRoute, r as resolveRuntimeConversationBindingRoute, t as ensureConfiguredBindingRouteReady } from "./binding-routing-6cr2GU2Z.js";
41
+ import "./conversation-runtime-BHctDnia.js";
42
+ import { t as resolvePairingIdLabel } from "./pairing-labels-BpsUT7f4.js";
43
+ import "./command-auth-CtA0lbtD.js";
44
+ import "./channel-inbound-BvfXTTbL.js";
45
+ import { n as toLocationContext, t as formatLocationText } from "./location-U0wbh3pT.js";
46
+ import { t as resolveInboundSessionEnvelopeContext } from "./session-envelope-SoEaHn7u.js";
47
+ import { t as createClaimableDedupe } from "./persistent-dedupe-BTyTh8iP.js";
48
+ import { i as resolveLineAccount, r as resolveDefaultLineAccountId } from "./accounts-B3R0SEUc.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-oHIsEREp.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 };