@pixelzx/genesis 2026.6.4-1 → 2026.6.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 (1010) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/dist/.buildstamp +1 -1
  3. package/dist/abort-CcNxEsSq.js +201 -0
  4. package/dist/abort.runtime-DZJDSf0d.js +2 -0
  5. package/dist/abort.runtime.js +1 -1
  6. package/dist/accounts-B7M6y8l8.js +107 -0
  7. package/dist/accounts-DddcYo7u.js +2 -0
  8. package/dist/accounts-v0Cqfnse.js +104 -0
  9. package/dist/acp-cli-D_2_Nim8.js +2193 -0
  10. package/dist/acp-spawn-BZPupfsZ.js +2 -0
  11. package/dist/acp-spawn-CWfIrbK7.js +1093 -0
  12. package/dist/acp-stateful-target-driver-DpCTjH5T.js +89 -0
  13. package/dist/action-agents-fjIM4rpc.js +67 -0
  14. package/dist/action-focus-cx1pm1ym.js +132 -0
  15. package/dist/action-help-DtyAnULB.js +7 -0
  16. package/dist/action-info-DF30-xZl.js +101 -0
  17. package/dist/action-kill-rsSdXzvX.js +33 -0
  18. package/dist/action-list-4VN835m2.js +21 -0
  19. package/dist/action-log-L032mq5B.js +30 -0
  20. package/dist/action-send-Dm62UP-n.js +39 -0
  21. package/dist/action-spawn-BuZHKlpL.js +47 -0
  22. package/dist/action-unfocus-CTIWf8WX.js +29 -0
  23. package/dist/actions.runtime-0ezEcm7K.js +18 -0
  24. package/dist/actions.runtime-DKsCTTnH.js +5 -0
  25. package/dist/actions.runtime.js +1 -1
  26. package/dist/agent-BTOBOCIw.js +2 -0
  27. package/dist/agent-command-C-_EFUUu.js +874 -0
  28. package/dist/agent-harness-runtime-Bye6j3EL.js +144 -0
  29. package/dist/agent-runner-utils-CX2vCMkx.js +239 -0
  30. package/dist/agent-runner.runtime-BBqrjZv4.js +3455 -0
  31. package/dist/agent-runner.runtime.js +1 -1
  32. package/dist/agent-runtime-D1LIGcNj.js +18 -0
  33. package/dist/agents-CME2O1l9.js +5 -0
  34. package/dist/agents-DsDQvAPy.js +954 -0
  35. package/dist/aliases-C807OidC.js +2 -0
  36. package/dist/aliases-jq1ap6Dz.js +96 -0
  37. package/dist/api-BbxKoRkD.js +3 -0
  38. package/dist/api-CwJPCW9U.js +139 -0
  39. package/dist/api-N5Kaaq64.js +5 -0
  40. package/dist/approval-gateway-resolver-DIPFgTnx.js +29 -0
  41. package/dist/approval-gateway-runtime-i0yziXk2.js +2 -0
  42. package/dist/approval-handler-runtime-Cdm-10f9.js +439 -0
  43. package/dist/approval-native-runtime-BRjeBoqL.js +729 -0
  44. package/dist/attempt-execution.runtime-NFTF7Cbt.js +509 -0
  45. package/dist/attempt-execution.runtime.js +1 -1
  46. package/dist/attempt.prompt-helpers-DuBXv46v.js +221 -0
  47. package/dist/attempt.tool-run-context-Qf-tbC-C.js +933 -0
  48. package/dist/audit-DsDfRhB8.js +939 -0
  49. package/dist/audit.runtime-ComjcUGJ.js +7 -0
  50. package/dist/audit.runtime.js +1 -1
  51. package/dist/auth-BT_gqC-D.js +2 -0
  52. package/dist/auth-DeUz_8w8.js +383 -0
  53. package/dist/auth-order-DM7UkPDa.js +96 -0
  54. package/dist/auth-order-yS8hXrXh.js +2 -0
  55. package/dist/bash-tools-D0M9gBDu.js +3 -0
  56. package/dist/bash-tools-tnj1gSbO.js +2824 -0
  57. package/dist/binding-routing-C7atXiTD.js +85 -0
  58. package/dist/binding-targets-CCv7agx9.js +121 -0
  59. package/dist/bridge-server-C5O9rTJg.js +113 -0
  60. package/dist/browser-control-auth-GGN_kbqE.js +2 -0
  61. package/dist/browser-node-runtime-B-uTSVqP.js +12 -0
  62. package/dist/browser-profiles-Dex2eaLH.js +2 -0
  63. package/dist/browser-runtime-BPocB6yO.js +387 -0
  64. package/dist/browser-setup-tools-gHfYeDWA.js +13 -0
  65. package/dist/build-BqG7RkBz.js +550 -0
  66. package/dist/build-info.json +3 -3
  67. package/dist/bundled/boot-md/handler.js +2 -2
  68. package/dist/bundled/session-memory/handler.js +1 -1
  69. package/dist/call-BI4JvjcR.js +3 -0
  70. package/dist/call-wY43fzOF.js +331 -0
  71. package/dist/call.runtime-Dh61oVeL.js +2 -0
  72. package/dist/call.runtime.js +1 -1
  73. package/dist/capability-cli-BHz-2Stx.js +1401 -0
  74. package/dist/catchup-Be7tHJwK.js +300 -0
  75. package/dist/channel-B-6VmF4-.js +840 -0
  76. package/dist/channel-BCJccV-O.js +226 -0
  77. package/dist/channel-BDZqLbod.js +1100 -0
  78. package/dist/channel-BQDNgTea.js +1174 -0
  79. package/dist/channel-BwjThGwK.js +453 -0
  80. package/dist/channel-CPoThmda.js +595 -0
  81. package/dist/channel-CUT8NJ-B.js +350 -0
  82. package/dist/channel-C_Y7lv8v.js +491 -0
  83. package/dist/channel-Ck7-C-lB.js +297 -0
  84. package/dist/channel-DOpVjq4i.js +1802 -0
  85. package/dist/channel-core-QV9-eAtb.js +5 -0
  86. package/dist/channel-inbound-D_tebgdx.js +31 -0
  87. package/dist/channel-plugin-runtime-DXcBwNNM.js +771 -0
  88. package/dist/channel-runtime-D4ci0o4V.js +425 -0
  89. package/dist/channel-sAdF_zH-.js +1320 -0
  90. package/dist/channel.runtime-1swLIpNV.js +89 -0
  91. package/dist/channel.runtime-B9hljdNF.js +4 -0
  92. package/dist/channel.runtime-CSbR2pni.js +430 -0
  93. package/dist/channel.runtime-CdpqhnLO.js +2364 -0
  94. package/dist/channel.runtime-DOx6WROg.js +40130 -0
  95. package/dist/channel.runtime-H5Kb2LbC.js +109 -0
  96. package/dist/channel.runtime-V7boBc_e.js +576 -0
  97. package/dist/channel.runtime.js +1 -1
  98. package/dist/channel.setup-BXyeNJ2_.js +10 -0
  99. package/dist/channels-KU7bwUUs.js +733 -0
  100. package/dist/channels-cli-CTX6_5z3.js +268 -0
  101. package/dist/chat-C_i6Wp50.js +2830 -0
  102. package/dist/clawbot-cli-CLGPtbt-.js +9 -0
  103. package/dist/cli/daemon-cli.js +3 -3
  104. package/dist/cli-BhwHu1dK.js +72 -0
  105. package/dist/cli-CFsq8f2H.js +2 -0
  106. package/dist/cli-CNVlwurq.js +219 -0
  107. package/dist/cli-DLP8hKbi.js +2 -0
  108. package/dist/cli-runner-BbNBHV6v.js +286 -0
  109. package/dist/cli-runner.runtime-CfPaauuM.js +4 -0
  110. package/dist/cli-runner.runtime-MxBlCOO2.js +3 -0
  111. package/dist/cli-runner.runtime.js +1 -1
  112. package/dist/cli-startup-metadata.json +2 -2
  113. package/dist/cli.runtime-3cD-pSyn.js +1261 -0
  114. package/dist/cli.runtime.js +1 -1
  115. package/dist/client-Bl0d_7ak.js +138 -0
  116. package/dist/client-ClJyHgmq.js +713 -0
  117. package/dist/command-auth-DO32coey.js +76 -0
  118. package/dist/command-config-resolution-CAsa4fGg.js +2 -0
  119. package/dist/command-config-resolution-D6YcwuRh.js +23 -0
  120. package/dist/command-config-resolution.runtime-CSHDu35A.js +2 -0
  121. package/dist/command-config-resolution.runtime.js +1 -1
  122. package/dist/command-registry-BJEQrMqR.js +4 -0
  123. package/dist/command-registry-DI9i95nj.js +9 -0
  124. package/dist/command-registry-core-BpF1mggD.js +106 -0
  125. package/dist/command-secret-gateway-DDNHxysD.js +528 -0
  126. package/dist/command-status.runtime-DqYUCcEA.js +87 -0
  127. package/dist/command-status.runtime.js +1 -1
  128. package/dist/commands-acp-C_zCJPvL.js +77 -0
  129. package/dist/commands-compact.runtime-B6e3kwMS.js +10 -0
  130. package/dist/commands-compact.runtime.js +1 -1
  131. package/dist/commands-handlers.runtime-B0gTkAC0.js +4599 -0
  132. package/dist/commands-handlers.runtime.js +1 -1
  133. package/dist/commands-status-BgZ64sA8.js +16 -0
  134. package/dist/commands-status.runtime-JI89gIEU.js +3 -0
  135. package/dist/commands-status.runtime.js +1 -1
  136. package/dist/commands-subagents-control.runtime-B0hdcBxr.js +2 -0
  137. package/dist/commands-subagents-control.runtime-DUeSQ5j4.js +3 -0
  138. package/dist/commands-subagents-control.runtime.js +1 -1
  139. package/dist/commands-system-prompt-B7moUaCI.js +158 -0
  140. package/dist/commands-system-prompt-DTUkp9TH.js +2 -0
  141. package/dist/commands.runtime-BjCVVqol.js +167 -0
  142. package/dist/commands.runtime.js +1 -1
  143. package/dist/compact-BNJH56SX.js +1118 -0
  144. package/dist/compact.runtime-CYI8Yi9d.js +12 -0
  145. package/dist/compact.runtime.js +1 -1
  146. package/dist/completion-cli-Bb1Tk-vM.js +328 -0
  147. package/dist/config-DxkleHmo.js +252 -0
  148. package/dist/config-cli-CtaRB_f8.js +1078 -0
  149. package/dist/configure-Bp8WFryM.js +1252 -0
  150. package/dist/configure-DQ_X5zyT.js +2 -0
  151. package/dist/connect-options-BkWD0Wvv.js +699 -0
  152. package/dist/control-auth-Iqyldslx.js +125 -0
  153. package/dist/control-service-xIhkqyZE.js +156 -0
  154. package/dist/conversation-id-BZtOqHIz.js +38 -0
  155. package/dist/conversation-id-D1Q9qPFH.js +235 -0
  156. package/dist/conversation-runtime-B1QZ-DEM.js +31 -0
  157. package/dist/core-BdVAy0Wv.js +275 -0
  158. package/dist/cron-cli-BWM2kRKU.js +713 -0
  159. package/dist/daemon-cli-MRl5nyuF.js +12 -0
  160. package/dist/dashboard-BkdlJrnf.js +2 -0
  161. package/dist/dashboard-C9m86rHv.js +81 -0
  162. package/dist/delegate-BjUvKQlo.js +64 -0
  163. package/dist/detached-task-runtime-BAEzkNB8.js +73 -0
  164. package/dist/devices-cli-B1n6tl9f.js +498 -0
  165. package/dist/diagnostics-DZxWkW3i.js +154 -0
  166. package/dist/direct-dm-qw-uk31C.js +64 -0
  167. package/dist/dispatch-D0xiJ6Up.js +1131 -0
  168. package/dist/dispatch-acp-DVN58m9G.js +981 -0
  169. package/dist/dispatch-acp-manager.runtime-C8t1i5Wt.js +3 -0
  170. package/dist/dispatch-acp-manager.runtime.js +1 -1
  171. package/dist/dispatch-acp.runtime-FR0DUPpn.js +19 -0
  172. package/dist/dispatch-acp.runtime.js +1 -1
  173. package/dist/doctor-device-pairing-DIbiBPlL.js +307 -0
  174. package/dist/doctor-gateway-daemon-flow-BFjRlXvA.js +250 -0
  175. package/dist/doctor-gateway-health-uZrukX3c.js +63 -0
  176. package/dist/doctor-health-DKpg1bxM.js +59 -0
  177. package/dist/doctor-health-contributions-BoXX8ubw.js +493 -0
  178. package/dist/doctor-prompter-CLf5Uf10.js +56 -0
  179. package/dist/doctor-workspace-status-Cw61BbGy.js +75 -0
  180. package/dist/dreaming-Bk8dVfGi.js +1574 -0
  181. package/dist/dreaming-narrative-DGSQa-0N.js +595 -0
  182. package/dist/embedded-gateway-stub.runtime-sokWrs6B.js +9 -0
  183. package/dist/embedded-gateway-stub.runtime.js +1 -1
  184. package/dist/entry.js +2 -2
  185. package/dist/exec-approvals-cli-CnNETs_u.js +498 -0
  186. package/dist/extensionAPI.js +1 -1
  187. package/dist/extensions/active-memory/index.js +1 -1
  188. package/dist/extensions/bluebubbles/api.js +3 -3
  189. package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
  190. package/dist/extensions/browser/browser-bridge.js +1 -1
  191. package/dist/extensions/browser/browser-config.js +4 -4
  192. package/dist/extensions/browser/browser-control-auth.js +2 -2
  193. package/dist/extensions/browser/browser-doctor.js +2 -2
  194. package/dist/extensions/browser/browser-maintenance.js +2 -2
  195. package/dist/extensions/browser/browser-profiles.js +2 -2
  196. package/dist/extensions/browser/browser-runtime-api.js +10 -10
  197. package/dist/extensions/browser/index.js +1 -1
  198. package/dist/extensions/browser/plugin-registration.js +1 -1
  199. package/dist/extensions/browser/register.runtime.js +3 -3
  200. package/dist/extensions/browser/runtime-api.js +11 -11
  201. package/dist/extensions/browser/test-support.js +1 -1
  202. package/dist/extensions/device-pair/api.js +1 -1
  203. package/dist/extensions/device-pair/index.js +3 -3
  204. package/dist/extensions/device-pair/notify.js +1 -1
  205. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  206. package/dist/extensions/google-meet/index.js +2 -2
  207. package/dist/extensions/imessage/api.js +3 -3
  208. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  209. package/dist/extensions/imessage/runtime-api.js +3 -3
  210. package/dist/extensions/irc/api.js +2 -2
  211. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  212. package/dist/extensions/line/api.js +2 -2
  213. package/dist/extensions/line/channel-plugin-api.js +1 -1
  214. package/dist/extensions/line/contract-api.js +1 -1
  215. package/dist/extensions/line/runtime-api.js +4 -4
  216. package/dist/extensions/line/setup-api.js +1 -1
  217. package/dist/extensions/llm-task/index.js +2 -2
  218. package/dist/extensions/lobster/index.js +3 -3
  219. package/dist/extensions/lobster/runtime-api.js +1 -1
  220. package/dist/extensions/mattermost/api.js +1 -1
  221. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  222. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  223. package/dist/extensions/mattermost/policy-api.js +1 -1
  224. package/dist/extensions/mattermost/runtime-api.js +4 -4
  225. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  226. package/dist/extensions/memory-core/api.js +1 -1
  227. package/dist/extensions/memory-core/cli-metadata.js +2 -2
  228. package/dist/extensions/memory-core/index.js +3 -3
  229. package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
  230. package/dist/extensions/msteams/api.js +1 -1
  231. package/dist/extensions/msteams/channel-plugin-api.js +1 -1
  232. package/dist/extensions/msteams/runtime-api.js +3 -3
  233. package/dist/extensions/msteams/test-api.js +1 -1
  234. package/dist/extensions/nextcloud-talk/api.js +1 -1
  235. package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
  236. package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
  237. package/dist/extensions/openshell/index.js +2 -2
  238. package/dist/extensions/signal/api.js +6 -6
  239. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  240. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  241. package/dist/extensions/signal/runtime-api.js +7 -7
  242. package/dist/extensions/skill-workshop/api.js +1 -1
  243. package/dist/extensions/skill-workshop/index.js +1 -1
  244. package/dist/extensions/synology-chat/api.js +1 -1
  245. package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
  246. package/dist/extensions/tlon/api.js +2 -2
  247. package/dist/extensions/tlon/channel-plugin-api.js +1 -1
  248. package/dist/extensions/tlon/runtime-api.js +1 -1
  249. package/dist/extensions/tlon/test-api.js +1 -1
  250. package/dist/extensions/twitch/api.js +1 -1
  251. package/dist/extensions/twitch/channel-plugin-api.js +1 -1
  252. package/dist/extensions/twitch/setup-plugin-api.js +1 -1
  253. package/dist/extensions/zalo/api.js +3 -3
  254. package/dist/extensions/zalo/channel-plugin-api.js +1 -1
  255. package/dist/extensions/zalo/runtime-api.js +2 -2
  256. package/dist/extensions/zalo/setup-api.js +2 -2
  257. package/dist/extensions/zalouser/api.js +3 -3
  258. package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
  259. package/dist/extensions/zalouser/runtime-api.js +6 -6
  260. package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
  261. package/dist/extensions/zalouser/test-api.js +1 -1
  262. package/dist/fallbacks-BwNexEVP.js +31 -0
  263. package/dist/fallbacks-GwVAaFt5.js +2 -0
  264. package/dist/fallbacks-shared-DmepG9Mq.js +111 -0
  265. package/dist/gateway-BB4hdlYm.js +115 -0
  266. package/dist/gateway-cli-Bzz62NC8.js +1283 -0
  267. package/dist/gateway-rpc-dyJV2osv.js +14 -0
  268. package/dist/gateway-rpc.runtime-DYVOEv4W.js +23 -0
  269. package/dist/gateway-rpc.runtime.js +1 -1
  270. package/dist/gateway-runtime-CqSQCYo0.js +15 -0
  271. package/dist/gateway-status-DdCiwrPt.js +584 -0
  272. package/dist/genesis-tools-Bh6dAUhK.js +9166 -0
  273. package/dist/genesis-tools.runtime-CiIUponP.js +2 -0
  274. package/dist/genesis-tools.runtime.js +1 -1
  275. package/dist/get-reply-from-config.runtime-Cu2DcwOW.js +2 -0
  276. package/dist/get-reply-from-config.runtime.js +1 -1
  277. package/dist/get-reply-qVmTjhwr.js +3897 -0
  278. package/dist/graph-users-kkSJYBNX.js +1337 -0
  279. package/dist/health-CFyVDYng.js +469 -0
  280. package/dist/health-Cl371mu8.js +3 -0
  281. package/dist/health-route-D0IspgUK.js +41 -0
  282. package/dist/health-route-D2tFKCLv.js +2 -0
  283. package/dist/heartbeat-runner-Bmi8YsXz.js +5 -0
  284. package/dist/heartbeat-runner-FSCWra2R.js +1292 -0
  285. package/dist/heartbeat-runner.runtime-QF8dg4j-.js +4 -0
  286. package/dist/heartbeat-runner.runtime.js +1 -1
  287. package/dist/hooks-cli-DYoG7Dz1.js +433 -0
  288. package/dist/image-fallbacks-5ckuJ46I.js +31 -0
  289. package/dist/image-fallbacks-DYnqzK01.js +2 -0
  290. package/dist/inbound-reply-dispatch-D5pqDZRa.js +73 -0
  291. package/dist/index.js +2 -2
  292. package/dist/infra-runtime-D08WIqN2.js +39 -0
  293. package/dist/init-BCgwiSZj.js +59 -0
  294. package/dist/library-CP9n_7AP.js +45 -0
  295. package/dist/lifecycle-BYam90xH.js +229 -0
  296. package/dist/lifecycle-DS58sNmu.js +571 -0
  297. package/dist/lifecycle.runtime-DMwss7xM.js +2 -0
  298. package/dist/lifecycle.runtime.js +1 -1
  299. package/dist/list-CASc4IWz.js +131 -0
  300. package/dist/list-CBPrBS2u.js +1212 -0
  301. package/dist/list-Cf7fcqQd.js +2 -0
  302. package/dist/list-Dqd2QyTH.js +2 -0
  303. package/dist/list.probe-BWcMSWDF.js +419 -0
  304. package/dist/llm-slug-generator-4LADFhXT.js +79 -0
  305. package/dist/llm-slug-generator.js +1 -1
  306. package/dist/load-config-DI-LDL6p.js +35 -0
  307. package/dist/local-dispatch.runtime-WDgraH3j.js +8 -0
  308. package/dist/local-dispatch.runtime.js +1 -1
  309. package/dist/logs-cli-zoBIelUH.js +265 -0
  310. package/dist/logs-cli.runtime-DxKNxXAz.js +2 -0
  311. package/dist/logs-cli.runtime.js +1 -1
  312. package/dist/main-session-restart-recovery-DWZfkOzH.js +206 -0
  313. package/dist/managed-image-attachments-DLDa1aE2.js +2 -0
  314. package/dist/managed-image-attachments-a4v60Bk3.js +635 -0
  315. package/dist/manager-CfUcsSI9.js +2057 -0
  316. package/dist/manager-DmBBLCOg.js +2 -0
  317. package/dist/markdown-to-line-B0mPruD_.js +790 -0
  318. package/dist/mcp/plugin-tools-serve.js +1 -1
  319. package/dist/mcp-cli-CLL9nfvE.js +725 -0
  320. package/dist/mcp-http-p7GbtbMx.js +529 -0
  321. package/dist/memory-core-host-runtime-cli-CZNYkDoE.js +9 -0
  322. package/dist/message-CRyNLXch.js +232 -0
  323. package/dist/message-action-runner-5Y4EFpWh.js +1407 -0
  324. package/dist/message-action-runner-Dxv-GXkn.js +2 -0
  325. package/dist/message-actions-DtoR6Mr2.js +143 -0
  326. package/dist/message.gateway.runtime-RI4cvk_E.js +2 -0
  327. package/dist/message.gateway.runtime.js +1 -1
  328. package/dist/models-auth-status-DsheCXaS.js +201 -0
  329. package/dist/models-cli-CQQG1U-p.js +219 -0
  330. package/dist/monitor-BRRSjPQY.js +1459 -0
  331. package/dist/monitor-Ch-cG7Si.js +1661 -0
  332. package/dist/monitor-ChBhfnC-.js +788 -0
  333. package/dist/monitor-CsvCTpjq.js +671 -0
  334. package/dist/monitor-DjemBuVh.js +1237 -0
  335. package/dist/monitor-LyGEO-KI.js +2 -0
  336. package/dist/monitor-auth-DVCdDwlp.js +207 -0
  337. package/dist/monitor-processing-Cib3ZjUe.js +1974 -0
  338. package/dist/monitor.runtime-DLBFALbV.js +2 -0
  339. package/dist/monitor.runtime.js +1 -1
  340. package/dist/monitor.webhook-Dktr8JA-.js +180 -0
  341. package/dist/msteams-G5I2CO13.js +35 -0
  342. package/dist/native-hook-relay-B1ArNeG5.js +519 -0
  343. package/dist/nextcloud-talk-DimOAfaR.js +17 -0
  344. package/dist/node-cli-RIjV0id4.js +2276 -0
  345. package/dist/nodes-cli-Cke-B80I.js +1046 -0
  346. package/dist/nodes-utils-CsTqKwN9.js +84 -0
  347. package/dist/nodes.helpers-DYpGCFer.js +34 -0
  348. package/dist/notify-zBChwf0-.js +315 -0
  349. package/dist/onboard-D6UawRld.js +2 -0
  350. package/dist/onboard-DfoCtk3_.js +70 -0
  351. package/dist/onboard-helpers-BKQMe3RX.js +6 -0
  352. package/dist/onboard-helpers-BLBJlQ50.js +204 -0
  353. package/dist/onboard-interactive-GAbQD437.js +24 -0
  354. package/dist/onboard-non-interactive-Bqi-JXh3.js +635 -0
  355. package/dist/onboard-remote-CNpTyVws.js +193 -0
  356. package/dist/onboard-remote-GFp2lT6Y.js +2 -0
  357. package/dist/onboard-skills-BQneolfo.js +2 -0
  358. package/dist/onboard-skills-BipqJ48b.js +134 -0
  359. package/dist/openai-http-CLDWjSKC.js +500 -0
  360. package/dist/openresponses-http-DNvXNiw_.js +1128 -0
  361. package/dist/operator-approvals-client-gaflvETF.js +68 -0
  362. package/dist/outbound.runtime-ByVsvEri.js +2 -0
  363. package/dist/outbound.runtime.js +1 -1
  364. package/dist/pair-command-approve-Dzkubc-8.js +44 -0
  365. package/dist/persistent-bindings.lifecycle-BhdRK7Lp.js +2 -0
  366. package/dist/persistent-bindings.lifecycle-DQ0AiHuy.js +85 -0
  367. package/dist/pi-embedded-C789hs31.js +4 -0
  368. package/dist/pi-embedded-CXLkrOwv.js +2905 -0
  369. package/dist/pi-embedded.runtime-BaHYLgKa.js +4 -0
  370. package/dist/pi-embedded.runtime.js +1 -1
  371. package/dist/pi-tool-definition-adapter-DFutc0D4.js +229 -0
  372. package/dist/pi-tools-k60jrAVq.js +1057 -0
  373. package/dist/pi-tools.before-tool-call-CFy20GCz.js +2 -0
  374. package/dist/pi-tools.before-tool-call-DJmPOVfQ.js +433 -0
  375. package/dist/plugin-BfFuIgXQ.js +12195 -0
  376. package/dist/plugin-enabled-dXOUnZwX.js +140 -0
  377. package/dist/plugin-registration-CEAozQhV.js +23 -0
  378. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  379. package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
  380. package/dist/plugin-sdk/acp-runtime.js +2 -2
  381. package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
  382. package/dist/plugin-sdk/agent-harness.js +6 -6
  383. package/dist/plugin-sdk/agent-runtime.js +2 -2
  384. package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
  385. package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
  386. package/dist/plugin-sdk/approval-runtime.js +1 -1
  387. package/dist/plugin-sdk/browser-node-runtime.js +4 -4
  388. package/dist/plugin-sdk/browser-setup-tools.js +3 -3
  389. package/dist/plugin-sdk/browser-support.js +7 -7
  390. package/dist/plugin-sdk/channel-core.js +2 -2
  391. package/dist/plugin-sdk/channel-inbound.js +2 -2
  392. package/dist/plugin-sdk/command-auth.js +1 -1
  393. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  394. package/dist/plugin-sdk/compat.js +1 -1
  395. package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
  396. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  397. package/dist/plugin-sdk/core.js +2 -2
  398. package/dist/plugin-sdk/direct-dm.js +1 -1
  399. package/dist/plugin-sdk/gateway-runtime.js +3 -3
  400. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  401. package/dist/plugin-sdk/index.js +1 -1
  402. package/dist/plugin-sdk/infra-runtime.js +2 -2
  403. package/dist/plugin-sdk/irc.js +2 -2
  404. package/dist/plugin-sdk/matrix.js +1 -1
  405. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
  406. package/dist/plugin-sdk/memory-core.js +2 -2
  407. package/dist/plugin-sdk/msteams.js +2 -2
  408. package/dist/plugin-sdk/nextcloud-talk.js +2 -2
  409. package/dist/plugin-sdk/nostr.js +1 -1
  410. package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
  411. package/dist/plugin-sdk/reply-runtime.js +4 -4
  412. package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
  413. package/dist/plugin-sdk/runtime.js +2 -2
  414. package/dist/plugin-sdk/session-visibility.js +1 -1
  415. package/dist/plugin-sdk/testing.js +4 -4
  416. package/dist/plugin-sdk/tlon.js +1 -1
  417. package/dist/plugin-sdk/zalo.js +1 -1
  418. package/dist/plugin-sdk/zalouser.js +1 -1
  419. package/dist/plugin-service-BOpLQ8BU.js +2892 -0
  420. package/dist/plugins/runtime/index.js +1 -1
  421. package/dist/policy-DiIlt2yW.js +328 -0
  422. package/dist/postinstall-inventory.json +414 -414
  423. package/dist/prepare.runtime-Bd8adOy3.js +815 -0
  424. package/dist/prepare.runtime.js +1 -1
  425. package/dist/probe-BOlTfbzG.js +2 -0
  426. package/dist/probe-BSRvsN95.js +2205 -0
  427. package/dist/probe-CDfjQSnz.js +74 -0
  428. package/dist/probe-D7gHyiZV.js +241 -0
  429. package/dist/probe-DTNKTWSs.js +2 -0
  430. package/dist/probe-DcryDdZh.js +45 -0
  431. package/dist/probe-nyesoHxj.js +1443 -0
  432. package/dist/program-BFGavenz.js +111 -0
  433. package/dist/prompt-select-styled-BhY1zahx.js +20 -0
  434. package/dist/protocol-DxLbSF2J.js +2477 -0
  435. package/dist/provider-dispatcher-C-yy1D7r.js +22 -0
  436. package/dist/provider-dispatcher-ErSjESTP.js +2 -0
  437. package/dist/qr-cli-C1-oy_ho.js +349 -0
  438. package/dist/qr-cli-DmEs63Sb.js +2 -0
  439. package/dist/reaction-runtime-api-gua650a7.js +116 -0
  440. package/dist/reactions-R-rA7cXz.js +998 -0
  441. package/dist/register-service-commands-DkbqNKVB.js +71 -0
  442. package/dist/register.agent-C3nW9wDn.js +248 -0
  443. package/dist/register.configure-BzLHCu95.js +15 -0
  444. package/dist/register.maintenance-BHFQo4gr.js +363 -0
  445. package/dist/register.message-CsYRdfKi.js +329 -0
  446. package/dist/register.onboard-DltySQ6C.js +88 -0
  447. package/dist/register.runtime-6Sk1Njnp.js +81 -0
  448. package/dist/register.runtime.js +1 -1
  449. package/dist/register.setup-CDvVQJuj.js +150 -0
  450. package/dist/register.status-health-sessions-B8lorJ2x.js +1215 -0
  451. package/dist/register.subclis-BD4fuAci.js +3 -0
  452. package/dist/register.subclis-CbRd3F_m.js +29 -0
  453. package/dist/register.subclis-core-Dtq9dAjI.js +249 -0
  454. package/dist/reply-dispatch-runtime-DldslKSK.js +13 -0
  455. package/dist/reply-runtime-2EGTfk-1.js +11 -0
  456. package/dist/reply.runtime-OaHntzIS.js +2 -0
  457. package/dist/reply.runtime.js +1 -1
  458. package/dist/restart-health-BjmfJCUM.js +202 -0
  459. package/dist/restart-health-hw909zlD.js +2 -0
  460. package/dist/root-help-_hHiERsR.js +44 -0
  461. package/dist/routes-BxCk7Pue.js +3341 -0
  462. package/dist/routes-C1_6oFmZ.js +2 -0
  463. package/dist/rpc-zRbkEo6W.js +61 -0
  464. package/dist/rpc.runtime-BZSYNDPa.js +21 -0
  465. package/dist/rpc.runtime.js +1 -1
  466. package/dist/run-delivery.runtime-D6YDo67d.js +530 -0
  467. package/dist/run-delivery.runtime.js +1 -1
  468. package/dist/run-embedded.runtime-BsgPrPDa.js +4 -0
  469. package/dist/run-embedded.runtime.js +1 -1
  470. package/dist/run-execution-cli.runtime-CggaHhrJ.js +4 -0
  471. package/dist/run-execution-cli.runtime.js +1 -1
  472. package/dist/run-executor.runtime-CKkLEr_T.js +277 -0
  473. package/dist/run-executor.runtime.js +1 -1
  474. package/dist/run-main-CJYYkV6H.js +567 -0
  475. package/dist/run-subagent-registry.runtime-B0sgf_oy.js +2 -0
  476. package/dist/run-subagent-registry.runtime.js +1 -1
  477. package/dist/run-wait-DHizeptL.js +135 -0
  478. package/dist/runtime-EtV_ChXX.js +9 -0
  479. package/dist/runtime-api-6H864Pmt.js +9 -0
  480. package/dist/runtime-api-CbZqRBZQ.js +14 -0
  481. package/dist/runtime-api-ZxEgu8cW.js +4 -0
  482. package/dist/runtime-api-j9A6jYUr.js +9 -0
  483. package/dist/runtime-embedded-pi.runtime-BHjCPnxo.js +2 -0
  484. package/dist/runtime-embedded-pi.runtime.js +1 -1
  485. package/dist/runtime-hvRzTSAZ.js +973 -0
  486. package/dist/runtime-internal-C_KZYzFK.js +2 -0
  487. package/dist/runtime-options-BZEOCnMg.js +275 -0
  488. package/dist/runtime-schema-R7LWe58K.js +28576 -0
  489. package/dist/scan-BNDE3dSE.js +523 -0
  490. package/dist/scan-TG6lVEQ2.js +2 -0
  491. package/dist/secrets-cli-twD2FWoZ.js +2101 -0
  492. package/dist/security-cli-Cd1A5yhL.js +486 -0
  493. package/dist/selection-CqqmU0Hi.js +7764 -0
  494. package/dist/selection-CsM62vcz.js +2 -0
  495. package/dist/send-D-EgB64m.js +156 -0
  496. package/dist/send-DPk5hW1W.js +102 -0
  497. package/dist/send.runtime-3QDkKN71.js +2 -0
  498. package/dist/send.runtime.js +1 -1
  499. package/dist/server-C94r_Qff.js +77 -0
  500. package/dist/server-Ceiopn_v.js +13 -0
  501. package/dist/server-context-BFJlu5HY.js +2 -0
  502. package/dist/server-context-PNEqhnTM.js +847 -0
  503. package/dist/server-node-events-QOAWLsDC.js +481 -0
  504. package/dist/server-plugin-bootstrap-CgsjzB17.js +2 -0
  505. package/dist/server-plugin-bootstrap-Dfuf75EN.js +12728 -0
  506. package/dist/server-restart-sentinel-BMPqZ7Jw.js +697 -0
  507. package/dist/server.impl-CCoQpvB7.js +12864 -0
  508. package/dist/session-kill-http-oPi3ajEp.js +110 -0
  509. package/dist/session-reset-service-CzDd6PBK.js +497 -0
  510. package/dist/session-route-DUOQE8-f.js +93 -0
  511. package/dist/session-status.runtime-W5tlGbXw.js +2 -0
  512. package/dist/session-status.runtime.js +1 -1
  513. package/dist/session-subagent-reactivation.runtime-yoYn1awK.js +2 -0
  514. package/dist/session-subagent-reactivation.runtime.js +1 -1
  515. package/dist/session-tab-registry-DkeCaT-2.js +581 -0
  516. package/dist/session-visibility-B4CFjv43.js +147 -0
  517. package/dist/sessions-helpers-CDfOVWe3.js +305 -0
  518. package/dist/sessions-history-http-QXeTdxXM.js +383 -0
  519. package/dist/sessions-patch-xb4bXPwh.js +309 -0
  520. package/dist/sessions-resolve-BPlrW8C3.js +174 -0
  521. package/dist/sessions.runtime-yYJXudA9.js +2 -0
  522. package/dist/sessions.runtime.js +1 -1
  523. package/dist/setup-0Im0LL1d.js +636 -0
  524. package/dist/setup-api-BxwfqXN-.js +29 -0
  525. package/dist/setup-core-BWwXgEuM.js +171 -0
  526. package/dist/setup-core-DzHNbQLG.js +176 -0
  527. package/dist/setup-surface-BVnqDsfU.js +286 -0
  528. package/dist/setup-surface-BajZWmKz2.js +403 -0
  529. package/dist/setup-surface-rDO3YjSb.js +219 -0
  530. package/dist/setup.finalize-BsnPbdwc.js +547 -0
  531. package/dist/setup.gateway-config-BFawSWHL.js +250 -0
  532. package/dist/shared-52tFSlVk.js +121 -0
  533. package/dist/shared-C8ENgtxM.js +198 -0
  534. package/dist/shared-DbXvU7JV.js +76 -0
  535. package/dist/slash-state-CMuPwgKt.js +1911 -0
  536. package/dist/src-IzaHgU6a.js +3974 -0
  537. package/dist/startup-context-xJS8ckSG.js +312 -0
  538. package/dist/status-BO4LMTER.js +2 -0
  539. package/dist/status-BwY1tASe.js +3 -0
  540. package/dist/status-BxG6n-ko.js +397 -0
  541. package/dist/status-Co_cq2vy.js +2 -0
  542. package/dist/status-DKNeRGzW.js +190 -0
  543. package/dist/status-DzlIHiTS.js +209 -0
  544. package/dist/status-all-DF7qaWjo.js +498 -0
  545. package/dist/status-json-CgCilobT.js +14 -0
  546. package/dist/status-json-command-DAa78z3e.js +84 -0
  547. package/dist/status-runtime-shared-CRCuxXn_.js +257 -0
  548. package/dist/status-subagents.runtime-hUsBd4C5.js +18 -0
  549. package/dist/status-subagents.runtime.js +1 -1
  550. package/dist/status-text-BdbRrl1G.js +237 -0
  551. package/dist/status.gateway-connection.runtime-BmSTYFFO.js +2 -0
  552. package/dist/status.gateway-connection.runtime.js +1 -1
  553. package/dist/status.gather-CItmFIHS.js +292 -0
  554. package/dist/status.gather-qB6WOoH7.js +2 -0
  555. package/dist/status.runtime-ClZCgYx1.js +2 -0
  556. package/dist/status.runtime.js +1 -1
  557. package/dist/status.scan-overview-B0b0Mvng.js +379 -0
  558. package/dist/status.scan-xY7nUi9N.js +65 -0
  559. package/dist/status.scan.fast-json-BANGHOys.js +132 -0
  560. package/dist/status.scan.fast-json-M-DmMy2l.js +2 -0
  561. package/dist/status.summary-B3PlFnWw.js +2 -0
  562. package/dist/status.summary-adB75FOM.js +214 -0
  563. package/dist/subagent-announce-B4w7Mcpr.js +351 -0
  564. package/dist/subagent-announce-delivery-Dma0A4gL.js +726 -0
  565. package/dist/subagent-announce-output-sUPLcge-.js +364 -0
  566. package/dist/subagent-control-CxR0WRrx.js +506 -0
  567. package/dist/subagent-followup.runtime-XeFe_LA0.js +68 -0
  568. package/dist/subagent-followup.runtime.js +1 -1
  569. package/dist/subagent-orphan-recovery-CJPHy8JV.js +305 -0
  570. package/dist/subagent-registry-CjMWjRCE.js +1753 -0
  571. package/dist/subagent-registry-H20VxEu0.js +3 -0
  572. package/dist/subagent-registry.runtime.js +1 -1
  573. package/dist/subagent-spawn-CRM5x6cV.js +1005 -0
  574. package/dist/system-cli-BJ5mMirj.js +59 -0
  575. package/dist/targets-CUnlEj96.js +67 -0
  576. package/dist/task-executor-DKnEwQ6v.js +360 -0
  577. package/dist/task-owner-access-CfypP1Yc.js +74 -0
  578. package/dist/task-registry-delivery-runtime-BB6ZzpqH.js +2 -0
  579. package/dist/task-registry-delivery-runtime-CvHa0gv-.js +3 -0
  580. package/dist/task-registry-pQuAfAL9.js +2366 -0
  581. package/dist/task-registry.maintenance-Bfd87wEV.js +416 -0
  582. package/dist/task-registry.maintenance-VgfbW0yt.js +2 -0
  583. package/dist/telegram/token.js +1 -1
  584. package/dist/testing-C_mngO0u.js +575 -0
  585. package/dist/text-report-Ct6t3he6.js +587 -0
  586. package/dist/tool-resolution-C4KGgPH-.js +90 -0
  587. package/dist/tools-effective-inventory-Bo2QC-m8.js +152 -0
  588. package/dist/tools-invoke-http-CBZPFh5L.js +206 -0
  589. package/dist/trash-DhZow3jd.js +24 -0
  590. package/dist/tui-cli-BPdQPozP.js +4575 -0
  591. package/dist/update-cli-BRi3mVAU.js +1759 -0
  592. package/dist/upgrade-D9zejtCk.js +1226 -0
  593. package/dist/video-generation-task-status-BSBQ0_FO.js +163 -0
  594. package/dist/wait-for-idle-before-flush-D1dTT9th.js +5986 -0
  595. package/dist/wizard-models-ysyV_WWR.js +334 -0
  596. package/package.json +1 -1
  597. package/dist/abort-DaihtnYj.js +0 -201
  598. package/dist/abort.runtime-BUT9L_5l.js +0 -2
  599. package/dist/accounts-BY5wsBnV.js +0 -104
  600. package/dist/accounts-DGth1vsM.js +0 -107
  601. package/dist/accounts-Do6Ir-q3.js +0 -2
  602. package/dist/acp-cli-BHgjn8rh.js +0 -2193
  603. package/dist/acp-spawn-BAM_Jrft.js +0 -2
  604. package/dist/acp-spawn-DyBD_Y_t.js +0 -1093
  605. package/dist/acp-stateful-target-driver-DKGnfjWu.js +0 -89
  606. package/dist/action-agents-CzMSNQdc.js +0 -67
  607. package/dist/action-focus-CpjIrZFe.js +0 -132
  608. package/dist/action-help-BhE9UosK.js +0 -7
  609. package/dist/action-info-CH2j6dKT.js +0 -101
  610. package/dist/action-kill-CB4AnLIf.js +0 -33
  611. package/dist/action-list-CQ8LbzvR.js +0 -21
  612. package/dist/action-log-DZblh247.js +0 -30
  613. package/dist/action-send-DMe0B4FG.js +0 -39
  614. package/dist/action-spawn-CkKMESb5.js +0 -47
  615. package/dist/action-unfocus-DjQzPZwU.js +0 -29
  616. package/dist/actions.runtime-CUdRdpLB.js +0 -5
  617. package/dist/actions.runtime-CxRstWdN.js +0 -18
  618. package/dist/agent-command-Nh_kPL3z.js +0 -874
  619. package/dist/agent-harness-runtime-BEb7Wk1m.js +0 -144
  620. package/dist/agent-q6U-cKJn.js +0 -2
  621. package/dist/agent-runner-utils-x_qJ6xYC.js +0 -239
  622. package/dist/agent-runner.runtime-DRvTfUPd.js +0 -3455
  623. package/dist/agent-runtime-jSYYQd6f.js +0 -18
  624. package/dist/agents-BKOpsZXw.js +0 -5
  625. package/dist/agents-BY34ViPX.js +0 -954
  626. package/dist/aliases-CD5YlX7d.js +0 -2
  627. package/dist/aliases-Dq31zANx.js +0 -96
  628. package/dist/api-BhxN9fxJ.js +0 -139
  629. package/dist/api-DjL_3olO.js +0 -5
  630. package/dist/api-jIYND-S5.js +0 -3
  631. package/dist/approval-gateway-resolver-BfvdJW5s.js +0 -29
  632. package/dist/approval-gateway-runtime-BBf976nt.js +0 -2
  633. package/dist/approval-handler-runtime-Bq4p5wvg.js +0 -439
  634. package/dist/approval-native-runtime-IrisOZrU.js +0 -729
  635. package/dist/attempt-execution.runtime-BXGalt-_.js +0 -509
  636. package/dist/attempt.prompt-helpers-A-pc2LfL.js +0 -221
  637. package/dist/attempt.tool-run-context-Ukna4ck-.js +0 -933
  638. package/dist/audit-CVUpfDvE.js +0 -939
  639. package/dist/audit.runtime-CsuGXvud.js +0 -7
  640. package/dist/auth-CjcZyRUW.js +0 -383
  641. package/dist/auth-order-DIkyTpW4.js +0 -2
  642. package/dist/auth-order-Dpt1K1rT.js +0 -96
  643. package/dist/auth-sVuL2xeZ.js +0 -2
  644. package/dist/bash-tools-DDv0zQh9.js +0 -2824
  645. package/dist/bash-tools-s-QSvRmt.js +0 -3
  646. package/dist/binding-routing-Cz5R2kFK.js +0 -85
  647. package/dist/binding-targets-D4j2hdQh.js +0 -121
  648. package/dist/bridge-server-X8SdeAI3.js +0 -113
  649. package/dist/browser-control-auth-BrF3DZxC.js +0 -2
  650. package/dist/browser-node-runtime-BecPmKOx.js +0 -12
  651. package/dist/browser-profiles-BxAKEG3x.js +0 -2
  652. package/dist/browser-runtime-D9fTDscJ.js +0 -387
  653. package/dist/browser-setup-tools--AQGWGvl.js +0 -13
  654. package/dist/build-B0nbyXrw.js +0 -550
  655. package/dist/call-BvqN9kay.js +0 -3
  656. package/dist/call-Dk5rTl-p.js +0 -331
  657. package/dist/call.runtime-Bx1hKDwO.js +0 -2
  658. package/dist/capability-cli-286Z3Bq3.js +0 -1401
  659. package/dist/catchup-DyeQ6GNj.js +0 -300
  660. package/dist/channel-B5m01jSZ.js +0 -1802
  661. package/dist/channel-BE26v3WU.js +0 -840
  662. package/dist/channel-BS7r_Zt1.js +0 -226
  663. package/dist/channel-BUWCqkGh.js +0 -1320
  664. package/dist/channel-BhgKqvZn.js +0 -453
  665. package/dist/channel-Bx703sxQ.js +0 -297
  666. package/dist/channel-CDjlEQAM.js +0 -491
  667. package/dist/channel-ChrqAgRS.js +0 -595
  668. package/dist/channel-Crmp3BHh.js +0 -1100
  669. package/dist/channel-D7GdDfBl.js +0 -1174
  670. package/dist/channel-DqSzRIul.js +0 -350
  671. package/dist/channel-core-DIwclC34.js +0 -5
  672. package/dist/channel-inbound-DPW1gRUU.js +0 -31
  673. package/dist/channel-plugin-runtime-BJhRSlBI.js +0 -771
  674. package/dist/channel-runtime-sV_Sg0EO.js +0 -425
  675. package/dist/channel.runtime-4BaNapRW.js +0 -89
  676. package/dist/channel.runtime-Bk2w0Yzd.js +0 -2364
  677. package/dist/channel.runtime-Bo5_2imz.js +0 -109
  678. package/dist/channel.runtime-CdYWlMyL.js +0 -40130
  679. package/dist/channel.runtime-CrYmCmSw.js +0 -4
  680. package/dist/channel.runtime-D3APPhVs.js +0 -430
  681. package/dist/channel.runtime-DjF1Gg6N.js +0 -576
  682. package/dist/channel.setup-BxXrmAYb.js +0 -10
  683. package/dist/channels-DHcJgMnw.js +0 -733
  684. package/dist/channels-cli-Dnq08u4r.js +0 -268
  685. package/dist/chat-BGU3UVKD.js +0 -2830
  686. package/dist/clawbot-cli-C-rqJUW-.js +0 -9
  687. package/dist/cli-BlnGJbLJ.js +0 -219
  688. package/dist/cli-D0RU1q0-.js +0 -2
  689. package/dist/cli-DBw79G2t.js +0 -72
  690. package/dist/cli-Dul37_xp.js +0 -2
  691. package/dist/cli-runner-DY8BKEmu.js +0 -286
  692. package/dist/cli-runner.runtime-5JMuegF9.js +0 -3
  693. package/dist/cli-runner.runtime-DQROn9Ve.js +0 -4
  694. package/dist/cli.runtime-CGOUREQg.js +0 -1261
  695. package/dist/client-CCBN1ydB.js +0 -138
  696. package/dist/client-PHLyQ8il.js +0 -713
  697. package/dist/command-auth-79QKQZZ3.js +0 -76
  698. package/dist/command-config-resolution-BKAgMItc.js +0 -2
  699. package/dist/command-config-resolution-BUCAmCZ_.js +0 -23
  700. package/dist/command-config-resolution.runtime-BVtfeARM.js +0 -2
  701. package/dist/command-registry-CBBqTuqk.js +0 -4
  702. package/dist/command-registry-core-D4BBKYaw.js +0 -106
  703. package/dist/command-registry-nztgeSim.js +0 -9
  704. package/dist/command-secret-gateway-g0alGmKz.js +0 -528
  705. package/dist/command-status.runtime-Dw6Zj5hL.js +0 -87
  706. package/dist/commands-acp-De-XFc40.js +0 -77
  707. package/dist/commands-compact.runtime-6gixR2a8.js +0 -10
  708. package/dist/commands-handlers.runtime-DCmZAlRN.js +0 -4599
  709. package/dist/commands-status-CION7GYY.js +0 -16
  710. package/dist/commands-status.runtime-FBwoHftv.js +0 -3
  711. package/dist/commands-subagents-control.runtime-C2xgOYKM.js +0 -2
  712. package/dist/commands-subagents-control.runtime-CgIEblx3.js +0 -3
  713. package/dist/commands-system-prompt-B-jC-KV-.js +0 -158
  714. package/dist/commands-system-prompt-DeK5Jhy_.js +0 -2
  715. package/dist/commands.runtime-CHSb1kYa.js +0 -167
  716. package/dist/compact-Dwchggv2.js +0 -1118
  717. package/dist/compact.runtime-jDUYMSjR.js +0 -12
  718. package/dist/completion-cli-DLHh5B2t.js +0 -328
  719. package/dist/config-Bnb9qa1S.js +0 -252
  720. package/dist/config-cli-DReWqAE2.js +0 -1078
  721. package/dist/configure-BLNGlWh0.js +0 -1252
  722. package/dist/configure-nPzsEeOb.js +0 -2
  723. package/dist/connect-options-C9cvS-bh.js +0 -699
  724. package/dist/control-auth-D2-P54fW.js +0 -125
  725. package/dist/control-service-CqUPgxlx.js +0 -156
  726. package/dist/conversation-id-BAzJOKBB.js +0 -235
  727. package/dist/conversation-id-WJLKuyy9.js +0 -38
  728. package/dist/conversation-runtime-D8fK5aI0.js +0 -31
  729. package/dist/core-DywmHt1k.js +0 -275
  730. package/dist/cron-cli-CeEJRkfR.js +0 -713
  731. package/dist/daemon-cli-BZZOjJHx.js +0 -12
  732. package/dist/dashboard-C0NRxmP3.js +0 -81
  733. package/dist/dashboard-DqhPgQv-.js +0 -2
  734. package/dist/delegate-DwVbOeR5.js +0 -64
  735. package/dist/detached-task-runtime-DiDRj-v-.js +0 -73
  736. package/dist/devices-cli-BKVbpwVc.js +0 -498
  737. package/dist/diagnostics-gh3UN_iV.js +0 -154
  738. package/dist/direct-dm-CwHHUkHV.js +0 -64
  739. package/dist/dispatch-B5af8_1v.js +0 -1131
  740. package/dist/dispatch-acp-DgOnUWBl.js +0 -981
  741. package/dist/dispatch-acp-manager.runtime-XWNjVh_M.js +0 -3
  742. package/dist/dispatch-acp.runtime-BdYL_ZqM.js +0 -19
  743. package/dist/doctor-device-pairing-CtGzWmXB.js +0 -307
  744. package/dist/doctor-gateway-daemon-flow-CCBI0jL4.js +0 -250
  745. package/dist/doctor-gateway-health-CkjqPFDl.js +0 -63
  746. package/dist/doctor-health-BOhuy1vP.js +0 -59
  747. package/dist/doctor-health-contributions-ChEuyLAY.js +0 -493
  748. package/dist/doctor-prompter-9nOTFD0Q.js +0 -56
  749. package/dist/doctor-workspace-status-CO5Ocwlt.js +0 -75
  750. package/dist/dreaming-GOPEFPio.js +0 -1574
  751. package/dist/dreaming-narrative-DfxHaxOU.js +0 -595
  752. package/dist/embedded-gateway-stub.runtime-B2OWcbsK.js +0 -9
  753. package/dist/exec-approvals-cli-CGeFtFbB.js +0 -498
  754. package/dist/fallbacks-CdfWAgNP.js +0 -2
  755. package/dist/fallbacks-eXbQ8TBp.js +0 -31
  756. package/dist/fallbacks-shared-akcCu5CD.js +0 -111
  757. package/dist/gateway-D-dDKqwi.js +0 -115
  758. package/dist/gateway-cli-NlsKGnqx.js +0 -1283
  759. package/dist/gateway-rpc-Cxa8dVW5.js +0 -14
  760. package/dist/gateway-rpc.runtime-D76s-oxs.js +0 -23
  761. package/dist/gateway-runtime-Dhm_gLh1.js +0 -15
  762. package/dist/gateway-status-C_L_CdOg.js +0 -584
  763. package/dist/genesis-tools-rRJB3JXY.js +0 -9166
  764. package/dist/genesis-tools.runtime-6oKokqaA.js +0 -2
  765. package/dist/get-reply-BkiDsDVY.js +0 -3897
  766. package/dist/get-reply-from-config.runtime-CHKCcj9D.js +0 -2
  767. package/dist/graph-users-BnXIYyC5.js +0 -1337
  768. package/dist/health-ZsJNENSY.js +0 -3
  769. package/dist/health-osa9LOJf.js +0 -469
  770. package/dist/health-route-8TdKOYLp.js +0 -2
  771. package/dist/health-route-BdLtX2Bg.js +0 -41
  772. package/dist/heartbeat-runner-BCbkAprr.js +0 -1292
  773. package/dist/heartbeat-runner-Dc1K8S94.js +0 -5
  774. package/dist/heartbeat-runner.runtime-pJaAsgLY.js +0 -4
  775. package/dist/hooks-cli-C3ggAz0i.js +0 -433
  776. package/dist/image-fallbacks-CiSae-lb.js +0 -2
  777. package/dist/image-fallbacks-vI8KUh6N.js +0 -31
  778. package/dist/inbound-reply-dispatch-DLM60UDh.js +0 -73
  779. package/dist/infra-runtime-CrHVeejV.js +0 -39
  780. package/dist/init-BKeEiV2q.js +0 -59
  781. package/dist/library-CHB7yTo5.js +0 -45
  782. package/dist/lifecycle-CUULToPr.js +0 -229
  783. package/dist/lifecycle-DCMpTRD2.js +0 -571
  784. package/dist/lifecycle.runtime-CP4gRxWv.js +0 -2
  785. package/dist/list-0zDFAWTF.js +0 -2
  786. package/dist/list-BaxVHTAN.js +0 -131
  787. package/dist/list-CMRMgrPs.js +0 -1212
  788. package/dist/list-DSrBtnKI.js +0 -2
  789. package/dist/list.probe-BJYSCsJY.js +0 -419
  790. package/dist/llm-slug-generator-Bn_wrWYw.js +0 -79
  791. package/dist/load-config-qC2BWt8E.js +0 -35
  792. package/dist/local-dispatch.runtime-DyU7urGc.js +0 -8
  793. package/dist/logs-cli-zK71r_PE.js +0 -265
  794. package/dist/logs-cli.runtime-k0UtiaRP.js +0 -2
  795. package/dist/main-session-restart-recovery-DMT0Oj9a.js +0 -206
  796. package/dist/managed-image-attachments-B6XXE4--.js +0 -635
  797. package/dist/managed-image-attachments-BTzWoDWE.js +0 -2
  798. package/dist/manager-BCKuWA67.js +0 -2057
  799. package/dist/manager-rGwNUzMp.js +0 -2
  800. package/dist/markdown-to-line-DmPbXQA1.js +0 -790
  801. package/dist/mcp-cli-CYpPNMcE.js +0 -725
  802. package/dist/mcp-http-wiE81iKg.js +0 -529
  803. package/dist/memory-core-host-runtime-cli-BOSQRX1T.js +0 -9
  804. package/dist/message-CUDzVGD8.js +0 -232
  805. package/dist/message-action-runner-Dy0IpKa4.js +0 -1407
  806. package/dist/message-action-runner-KkBFzZdg.js +0 -2
  807. package/dist/message-actions-Dcdb5aSR.js +0 -143
  808. package/dist/message.gateway.runtime-D86fFO99.js +0 -2
  809. package/dist/models-auth-status-DkiX4s0b.js +0 -201
  810. package/dist/models-cli-CSUot1R3.js +0 -219
  811. package/dist/monitor-BA8ByMKR.js +0 -2
  812. package/dist/monitor-Bv1GIHW5.js +0 -1661
  813. package/dist/monitor-DTFY0ruF.js +0 -788
  814. package/dist/monitor-DXH-vNGn.js +0 -1459
  815. package/dist/monitor-Df5k8NGk.js +0 -671
  816. package/dist/monitor-Dk2YRF26.js +0 -1237
  817. package/dist/monitor-auth-CZOW753A.js +0 -207
  818. package/dist/monitor-processing-Clta8N4C.js +0 -1974
  819. package/dist/monitor.runtime-3ORbPT0X.js +0 -2
  820. package/dist/monitor.webhook-CRyTxENk.js +0 -180
  821. package/dist/msteams-BE0VieXF.js +0 -35
  822. package/dist/native-hook-relay-DAwGGuEx.js +0 -519
  823. package/dist/nextcloud-talk-DfYlTFsm.js +0 -17
  824. package/dist/node-cli-Bzyci_X_.js +0 -2276
  825. package/dist/nodes-cli-Er3OZkuk.js +0 -1046
  826. package/dist/nodes-utils-Cp8QZO8-.js +0 -84
  827. package/dist/nodes.helpers-CwKAAnRA.js +0 -34
  828. package/dist/notify-D_5n_vEJ.js +0 -315
  829. package/dist/onboard-BE82RudQ.js +0 -2
  830. package/dist/onboard-Bk4xL8X7.js +0 -70
  831. package/dist/onboard-helpers-D4WYa-6g.js +0 -204
  832. package/dist/onboard-helpers-MuFxPZg5.js +0 -6
  833. package/dist/onboard-interactive-0zmI-9ia.js +0 -24
  834. package/dist/onboard-non-interactive-DIRB95mT.js +0 -635
  835. package/dist/onboard-remote-7qR1knbU.js +0 -2
  836. package/dist/onboard-remote-CLmoySkk.js +0 -193
  837. package/dist/onboard-skills-C_873OK_.js +0 -134
  838. package/dist/onboard-skills-DrlBYc0t.js +0 -2
  839. package/dist/openai-http-DzCBqW6b.js +0 -500
  840. package/dist/openresponses-http-B2zgO5hQ.js +0 -1128
  841. package/dist/operator-approvals-client-mGBl4ptH.js +0 -68
  842. package/dist/outbound.runtime--HS-MxM_.js +0 -2
  843. package/dist/pair-command-approve-CCTSQKJH.js +0 -44
  844. package/dist/persistent-bindings.lifecycle-CnmqGsQf.js +0 -85
  845. package/dist/persistent-bindings.lifecycle-Dav1TX9E.js +0 -2
  846. package/dist/pi-embedded-BSKL8IgF.js +0 -4
  847. package/dist/pi-embedded-DMM8Pfp7.js +0 -2905
  848. package/dist/pi-embedded.runtime-Bv_roBVx.js +0 -4
  849. package/dist/pi-tool-definition-adapter-OrxjlSIM.js +0 -229
  850. package/dist/pi-tools-DD1YegeL.js +0 -1057
  851. package/dist/pi-tools.before-tool-call-J9ujp9Wp.js +0 -433
  852. package/dist/pi-tools.before-tool-call-hGEgKGZQ.js +0 -2
  853. package/dist/plugin-Cg3pHepG.js +0 -12195
  854. package/dist/plugin-enabled-wEQ8BQNw.js +0 -140
  855. package/dist/plugin-registration-DLcLJgqz.js +0 -23
  856. package/dist/plugin-service-BogBl5qk.js +0 -2892
  857. package/dist/policy-Bkh8Xtnb.js +0 -328
  858. package/dist/prepare.runtime-Cd31ie7u.js +0 -815
  859. package/dist/probe-9IM22Rkf.js +0 -2
  860. package/dist/probe-ButCyV3d.js +0 -1443
  861. package/dist/probe-D7QBUio1.js +0 -45
  862. package/dist/probe-DV6CWm0r.js +0 -74
  863. package/dist/probe-DkfetvwA.js +0 -2
  864. package/dist/probe-Dxo-LQjn.js +0 -2205
  865. package/dist/probe-nil3qQAV.js +0 -241
  866. package/dist/program-DHxyOl81.js +0 -111
  867. package/dist/prompt-select-styled-BSf77q2T.js +0 -20
  868. package/dist/protocol-C4I0nfuT.js +0 -2477
  869. package/dist/provider-dispatcher-CkiPxKIr.js +0 -22
  870. package/dist/provider-dispatcher-PmsHJlUO.js +0 -2
  871. package/dist/qr-cli-BHY0TO2W.js +0 -2
  872. package/dist/qr-cli-BbjDJSKp.js +0 -349
  873. package/dist/reaction-runtime-api-DOigJrbq.js +0 -116
  874. package/dist/reactions-CogkrjNr.js +0 -998
  875. package/dist/register-service-commands-IA3Nfza5.js +0 -71
  876. package/dist/register.agent-DD0aSYye.js +0 -248
  877. package/dist/register.configure-BOy4i7Ah.js +0 -15
  878. package/dist/register.maintenance-CUp6FEOF.js +0 -363
  879. package/dist/register.message-DezTIpNI.js +0 -329
  880. package/dist/register.onboard-Brpxl9p3.js +0 -88
  881. package/dist/register.runtime-BfH5rSb_.js +0 -81
  882. package/dist/register.setup-CIt4FVv0.js +0 -150
  883. package/dist/register.status-health-sessions-IbGZwSaG.js +0 -1215
  884. package/dist/register.subclis-BFQii-42.js +0 -29
  885. package/dist/register.subclis-DlYCyoMp.js +0 -3
  886. package/dist/register.subclis-core-DcfC_0CS.js +0 -249
  887. package/dist/reply-dispatch-runtime-Lu4Metex.js +0 -13
  888. package/dist/reply-runtime-CgPzru94.js +0 -11
  889. package/dist/reply.runtime-sw14BA5F.js +0 -2
  890. package/dist/restart-health-1MNBua3p.js +0 -202
  891. package/dist/restart-health-BWGpwgPv.js +0 -2
  892. package/dist/root-help-B3zoC2OP.js +0 -44
  893. package/dist/routes-BM6fbday.js +0 -3341
  894. package/dist/routes-pVc_QLiP.js +0 -2
  895. package/dist/rpc-BGOWS7nj.js +0 -61
  896. package/dist/rpc.runtime-Ca9K3sx8.js +0 -21
  897. package/dist/run-delivery.runtime-CabntI64.js +0 -530
  898. package/dist/run-embedded.runtime-Q7wrP6Qn.js +0 -4
  899. package/dist/run-execution-cli.runtime-CtRUFc-M.js +0 -4
  900. package/dist/run-executor.runtime-Nm38xsKA.js +0 -277
  901. package/dist/run-main-UT0zTwCg.js +0 -567
  902. package/dist/run-subagent-registry.runtime-D9_scMUr.js +0 -2
  903. package/dist/run-wait-B2K_6JNL.js +0 -135
  904. package/dist/runtime-BZ296jTK.js +0 -9
  905. package/dist/runtime-DnZsw7MB.js +0 -973
  906. package/dist/runtime-api-BL9vpbvb.js +0 -14
  907. package/dist/runtime-api-BbsLJB4C.js +0 -9
  908. package/dist/runtime-api-ChwFrQRw.js +0 -9
  909. package/dist/runtime-api-_fH7M3Qh.js +0 -4
  910. package/dist/runtime-embedded-pi.runtime-TOdW-E-2.js +0 -2
  911. package/dist/runtime-internal-DGwOFi_E.js +0 -2
  912. package/dist/runtime-options-CSPfxkb1.js +0 -275
  913. package/dist/runtime-schema-DtNq1-Zd.js +0 -28576
  914. package/dist/scan-D6gkNpKl.js +0 -523
  915. package/dist/scan-_9J5-5L6.js +0 -2
  916. package/dist/secrets-cli-DlVSRQPM.js +0 -2101
  917. package/dist/security-cli-DtzNOYL2.js +0 -486
  918. package/dist/selection-CBJZE_FL.js +0 -7764
  919. package/dist/selection-XsoEF2p2.js +0 -2
  920. package/dist/send-BAaDBRfi.js +0 -156
  921. package/dist/send-BB-M1afy.js +0 -102
  922. package/dist/send.runtime-CI_75KUP.js +0 -2
  923. package/dist/server-D58E1Cua.js +0 -77
  924. package/dist/server-D6rXK0fF.js +0 -13
  925. package/dist/server-context-D5AnCc1E.js +0 -2
  926. package/dist/server-context-bt09wrJu.js +0 -847
  927. package/dist/server-node-events-CUx4-7FL.js +0 -481
  928. package/dist/server-plugin-bootstrap-CBcQpYIR.js +0 -12708
  929. package/dist/server-plugin-bootstrap-CfkBsGUg.js +0 -2
  930. package/dist/server-restart-sentinel-ByFI_0MB.js +0 -697
  931. package/dist/server.impl-DzntNeH-.js +0 -12864
  932. package/dist/session-kill-http-9MoO6FXC.js +0 -110
  933. package/dist/session-reset-service-redPsOs-.js +0 -497
  934. package/dist/session-route-C8oB2UYs.js +0 -93
  935. package/dist/session-status.runtime-D3bYBPJe.js +0 -2
  936. package/dist/session-subagent-reactivation.runtime-aat7tUag.js +0 -2
  937. package/dist/session-tab-registry-CAJ_oDsb.js +0 -581
  938. package/dist/session-visibility-Dq88jJYB.js +0 -147
  939. package/dist/sessions-helpers-C8-IkqhO.js +0 -305
  940. package/dist/sessions-history-http-4Ftuwnes.js +0 -383
  941. package/dist/sessions-patch-BsyNHOaz.js +0 -309
  942. package/dist/sessions-resolve-gKLz2Bup.js +0 -174
  943. package/dist/sessions.runtime-C1W59rQY.js +0 -2
  944. package/dist/setup-DhvXyU_5.js +0 -636
  945. package/dist/setup-api-B9Y4qPgq.js +0 -29
  946. package/dist/setup-core-CdFQ6ZXC.js +0 -176
  947. package/dist/setup-core-kXUD3Kat.js +0 -171
  948. package/dist/setup-surface-BFL9WfBs.js +0 -219
  949. package/dist/setup-surface-Cxg_nSWc.js +0 -286
  950. package/dist/setup-surface-DbooMj782.js +0 -403
  951. package/dist/setup.finalize-CKxukDYi.js +0 -547
  952. package/dist/setup.gateway-config-BhEtXwaB.js +0 -250
  953. package/dist/shared-BNVKrp5y.js +0 -76
  954. package/dist/shared-CM3mnx7z.js +0 -198
  955. package/dist/shared-CfrsSVhL.js +0 -121
  956. package/dist/slash-state-2Z-om57Q.js +0 -1911
  957. package/dist/src-DAoKvK_N.js +0 -3974
  958. package/dist/startup-context-CtYAdYwd.js +0 -312
  959. package/dist/status-B2M0Imij.js +0 -3
  960. package/dist/status-Bd-BNmiE.js +0 -2
  961. package/dist/status-D6nbpHFi.js +0 -397
  962. package/dist/status-MByUxUGu.js +0 -209
  963. package/dist/status-QUjO1tkz.js +0 -2
  964. package/dist/status-all-DPa-BiHk.js +0 -498
  965. package/dist/status-erNo8YmW.js +0 -190
  966. package/dist/status-json-command-C9rbAyj-.js +0 -84
  967. package/dist/status-json-tO3CQXIQ.js +0 -14
  968. package/dist/status-runtime-shared-DmBB_gmT.js +0 -257
  969. package/dist/status-subagents.runtime-BXAZr5y0.js +0 -18
  970. package/dist/status-text-BCeYk0-q.js +0 -237
  971. package/dist/status.gateway-connection.runtime-bt35dapy.js +0 -2
  972. package/dist/status.gather-B9a-CEev.js +0 -292
  973. package/dist/status.gather-ahBLFzk6.js +0 -2
  974. package/dist/status.runtime-BrErwtfc.js +0 -2
  975. package/dist/status.scan-D2mvM4II.js +0 -65
  976. package/dist/status.scan-overview-uOOaqp1t.js +0 -379
  977. package/dist/status.scan.fast-json-C9dkN28s.js +0 -2
  978. package/dist/status.scan.fast-json-DY3Or8S4.js +0 -132
  979. package/dist/status.summary-Cf4p2BPK.js +0 -2
  980. package/dist/status.summary-DxfZCcNa.js +0 -214
  981. package/dist/subagent-announce-CyQZsAIm.js +0 -351
  982. package/dist/subagent-announce-delivery-CgdPNjMA.js +0 -726
  983. package/dist/subagent-announce-output-D1xi4Tk1.js +0 -364
  984. package/dist/subagent-control-D-O6I8Mt.js +0 -506
  985. package/dist/subagent-followup.runtime-BbA7NPAq.js +0 -68
  986. package/dist/subagent-orphan-recovery-C6_cmAyE.js +0 -305
  987. package/dist/subagent-registry-Dn_XpDh0.js +0 -1753
  988. package/dist/subagent-registry-DodFw3pu.js +0 -3
  989. package/dist/subagent-spawn-Dw5lttXp.js +0 -1005
  990. package/dist/system-cli-CSqO2Z4K.js +0 -59
  991. package/dist/targets-CMdwh9lR.js +0 -67
  992. package/dist/task-executor-DgZSfcBk.js +0 -360
  993. package/dist/task-owner-access-9c38idlo.js +0 -74
  994. package/dist/task-registry-Z-lBPkNj.js +0 -2366
  995. package/dist/task-registry-delivery-runtime-DOV4qoj4.js +0 -2
  996. package/dist/task-registry-delivery-runtime-EATr0C3C.js +0 -3
  997. package/dist/task-registry.maintenance-C1YMEwhk.js +0 -416
  998. package/dist/task-registry.maintenance-CBfaUWcp.js +0 -2
  999. package/dist/testing-CFk04o9M.js +0 -575
  1000. package/dist/text-report-QhVG354o.js +0 -587
  1001. package/dist/tool-resolution-D6V4tg-G.js +0 -90
  1002. package/dist/tools-effective-inventory-DFU7yYvD.js +0 -152
  1003. package/dist/tools-invoke-http-y6WIa3Ku.js +0 -206
  1004. package/dist/trash-rhbwNhfQ.js +0 -24
  1005. package/dist/tui-cli-BfxeO4YM.js +0 -4575
  1006. package/dist/update-cli-DaN9bvPV.js +0 -1759
  1007. package/dist/upgrade-f5dlIxir.js +0 -1226
  1008. package/dist/video-generation-task-status-yX54iO8n.js +0 -163
  1009. package/dist/wait-for-idle-before-flush-mZrBNr5z.js +0 -5986
  1010. package/dist/wizard-models-D_avLyHR.js +0 -334
@@ -0,0 +1,1174 @@
1
+ import { i as formatErrorMessage } from "./errors-CufR9eHH.js";
2
+ import { t as safeEqualSecret } from "./secret-equal-CW95TizL.js";
3
+ import { r as buildChannelConfigSchema } from "./config-schema-VCpnF5M8.js";
4
+ import { t as DEFAULT_ACCOUNT_ID } from "./account-id-CTXHUezn.js";
5
+ import { n as safeParseWithSchema, t as safeParseJsonWithSchema } from "./zod-parse-B6oqrVWQ.js";
6
+ import { g as resolvePinnedHostnameWithPolicy } from "./ssrf-FLmnjVdI.js";
7
+ import { i as createHybridChannelConfigAdapter, l as createScopedDmSecurityResolver } from "./channel-config-helpers-9w5_d8wL.js";
8
+ import { t as buildAgentSessionKey } from "./resolve-route-B93lOfb3.js";
9
+ import { i as createChatChannelPlugin } from "./core-BdVAy0Wv.js";
10
+ import "./channel-core-QV9-eAtb.js";
11
+ import "./routing-DB6Hmk1m.js";
12
+ import { i as waitUntilAbort } from "./channel-lifecycle.core-pZCLydCB.js";
13
+ import { t as createPluginRuntimeStore } from "./runtime-store-Bqa7yIX3.js";
14
+ import "./channel-config-schema-BbOrRt7C.js";
15
+ import { C as projectAccountConfigWarningCollector, m as composeWarningCollectors, w as projectAccountWarningCollector, y as createConditionalWarningCollector } from "./channel-policy-DB3bMMxg.js";
16
+ import { n as createEmptyChannelDirectoryAdapter } from "./directory-runtime-DYcmst3X.js";
17
+ import { a as createFixedWindowRateLimiter } from "./webhook-memory-guards-B7tt2wzG.js";
18
+ import { a as isRequestBodyLimitError, c as requestBodyErrorToText, s as readRequestBodyWithLimit } from "./http-body-lzZef-oj.js";
19
+ import { a as createWebhookInFlightLimiter, i as beginWebhookRequestPipelineOrReject } from "./webhook-request-guards-BB1rwGeY.js";
20
+ import { t as registerPluginHttpRoute } from "./http-registry-nB85UyTf.js";
21
+ import "./webhook-ingress-CnQHZEYt.js";
22
+ import { t as resolveApprovalApprovers } from "./approval-approvers-hyo2V-FQ.js";
23
+ import { t as createResolvedApproverActionAuthAdapter } from "./approval-auth-helpers-yVj8aTGb.js";
24
+ import "./ssrf-runtime-CetK5Qy_.js";
25
+ import "./account-resolution-D0lCF0uW.js";
26
+ import "./browser-security-runtime-bMw-CyNH.js";
27
+ import "./extension-shared-C9EIm6Vo.js";
28
+ import "./channel-lifecycle-C5W_VOqY.js";
29
+ import { t as attachChannelToResult } from "./channel-send-result-D1v2klHW.js";
30
+ import { t as zod_exports } from "./zod-YzAkfu8F.js";
31
+ import { i as resolveAccount, n as synologyChatSetupWizard, r as listAccountIds, t as synologyChatSetupAdapter } from "./setup-surface--TBr8DIa.js";
32
+ import { t as collectSynologyChatSecurityAuditFindings } from "./security-audit-BBqCfNe2.js";
33
+ import { z } from "zod";
34
+ import * as http$1 from "node:http";
35
+ import * as https$1 from "node:https";
36
+ import * as querystring from "node:querystring";
37
+ //#region extensions/synology-chat/src/approval-auth.ts
38
+ function normalizeSynologyChatApproverId(value) {
39
+ const trimmed = String(value).trim();
40
+ return /^\d+$/.test(trimmed) ? trimmed : void 0;
41
+ }
42
+ const synologyChatApprovalAuth = createResolvedApproverActionAuthAdapter({
43
+ channelLabel: "Synology Chat",
44
+ resolveApprovers: ({ cfg, accountId }) => {
45
+ return resolveApprovalApprovers({
46
+ allowFrom: resolveAccount(cfg ?? {}, accountId).allowedUserIds,
47
+ normalizeApprover: normalizeSynologyChatApproverId
48
+ });
49
+ },
50
+ normalizeSenderId: (value) => normalizeSynologyChatApproverId(value)
51
+ });
52
+ //#endregion
53
+ //#region extensions/synology-chat/src/client.ts
54
+ /**
55
+ * Synology Chat HTTP client.
56
+ * Sends messages TO Synology Chat via the incoming webhook URL.
57
+ */
58
+ const MIN_SEND_INTERVAL_MS = 500;
59
+ let lastSendTime = 0;
60
+ function normalizeLowercaseStringOrEmpty$2(value) {
61
+ return typeof value === "string" ? value.trim().toLowerCase() : "";
62
+ }
63
+ const ChatUserSchema = z.object({
64
+ user_id: z.number(),
65
+ username: z.string().optional(),
66
+ nickname: z.string().optional()
67
+ }).transform((user) => ({
68
+ user_id: user.user_id,
69
+ username: user.username ?? "",
70
+ nickname: user.nickname ?? ""
71
+ }));
72
+ const ChatUserListResponseSchema = z.object({
73
+ success: z.boolean(),
74
+ data: z.object({ users: z.array(z.unknown()).optional().transform((users) => (users ?? []).flatMap((user) => {
75
+ const parsed = safeParseWithSchema(ChatUserSchema, user);
76
+ return parsed ? [parsed] : [];
77
+ })) }).optional()
78
+ });
79
+ const chatUserCache = /* @__PURE__ */ new Map();
80
+ const CACHE_TTL_MS = 300 * 1e3;
81
+ /**
82
+ * Send a text message to Synology Chat via the incoming webhook.
83
+ *
84
+ * @param incomingUrl - Synology Chat incoming webhook URL
85
+ * @param text - Message text to send
86
+ * @param userId - Optional user ID to mention with @
87
+ * @returns true if sent successfully
88
+ */
89
+ async function sendMessage(incomingUrl, text, userId, allowInsecureSsl = false) {
90
+ const body = buildWebhookBody({ text }, userId);
91
+ const elapsed = Date.now() - lastSendTime;
92
+ if (elapsed < MIN_SEND_INTERVAL_MS) await sleep(MIN_SEND_INTERVAL_MS - elapsed);
93
+ const maxRetries = 3;
94
+ const baseDelay = 300;
95
+ for (let attempt = 0; attempt < maxRetries; attempt++) {
96
+ try {
97
+ const ok = await doPost(incomingUrl, body, allowInsecureSsl);
98
+ lastSendTime = Date.now();
99
+ if (ok) return true;
100
+ } catch {}
101
+ if (attempt < maxRetries - 1) await sleep(baseDelay * 2 ** attempt);
102
+ }
103
+ return false;
104
+ }
105
+ /**
106
+ * Send a file URL to Synology Chat.
107
+ */
108
+ async function sendFileUrl(incomingUrl, fileUrl, userId, allowInsecureSsl = false) {
109
+ try {
110
+ const body = buildWebhookBody({ file_url: await assertSafeWebhookFileUrl(fileUrl) }, userId);
111
+ const elapsed = Date.now() - lastSendTime;
112
+ if (elapsed < MIN_SEND_INTERVAL_MS) await sleep(MIN_SEND_INTERVAL_MS - elapsed);
113
+ const ok = await doPost(incomingUrl, body, allowInsecureSsl);
114
+ lastSendTime = Date.now();
115
+ return ok;
116
+ } catch {
117
+ return false;
118
+ }
119
+ }
120
+ /**
121
+ * Fetch the list of Chat users visible to this bot via the user_list API.
122
+ * Results are cached for CACHE_TTL_MS to avoid excessive API calls.
123
+ *
124
+ * The user_list endpoint uses the same base URL as the chatbot API but
125
+ * with method=user_list instead of method=chatbot.
126
+ */
127
+ async function fetchChatUsers(incomingUrl, allowInsecureSsl = false, log) {
128
+ const now = Date.now();
129
+ const listUrl = incomingUrl.replace(/method=\w+/, "method=user_list");
130
+ const cached = chatUserCache.get(listUrl);
131
+ if (cached && now - cached.cachedAt < CACHE_TTL_MS) return cached.users;
132
+ return new Promise((resolve) => {
133
+ let parsedUrl;
134
+ try {
135
+ parsedUrl = new URL(listUrl);
136
+ } catch {
137
+ log?.warn("fetchChatUsers: invalid user_list URL, using cached data");
138
+ resolve(cached?.users ?? []);
139
+ return;
140
+ }
141
+ const transport = parsedUrl.protocol === "https:" ? https$1 : http$1;
142
+ const requestOptions = parsedUrl.protocol === "https:" ? { rejectUnauthorized: !allowInsecureSsl } : {};
143
+ transport.get(listUrl, requestOptions, (res) => {
144
+ let data = "";
145
+ res.on("data", (c) => {
146
+ data += c.toString();
147
+ });
148
+ res.on("end", () => {
149
+ const result = safeParseJsonWithSchema(ChatUserListResponseSchema, data);
150
+ if (!result) {
151
+ log?.warn("fetchChatUsers: failed to parse user_list response");
152
+ resolve(cached?.users ?? []);
153
+ return;
154
+ }
155
+ if (result.success) {
156
+ const users = result.data?.users ?? [];
157
+ chatUserCache.set(listUrl, {
158
+ users,
159
+ cachedAt: now
160
+ });
161
+ resolve(users);
162
+ return;
163
+ }
164
+ log?.warn(`fetchChatUsers: API returned success=${result.success}, using cached data`);
165
+ resolve(cached?.users ?? []);
166
+ });
167
+ }).on("error", (err) => {
168
+ log?.warn(`fetchChatUsers: HTTP error — ${err instanceof Error ? err.message : err}`);
169
+ resolve(cached?.users ?? []);
170
+ });
171
+ });
172
+ }
173
+ async function assertSafeWebhookFileUrl(fileUrl) {
174
+ let parsed;
175
+ try {
176
+ parsed = new URL(fileUrl);
177
+ } catch (err) {
178
+ throw new Error(`Invalid Synology Chat file URL: ${formatErrorMessage(err)}`, { cause: err });
179
+ }
180
+ if (parsed.protocol !== "http:" && parsed.protocol !== "https:") throw new Error("Synology Chat file URL must use HTTP or HTTPS");
181
+ await resolvePinnedHostnameWithPolicy(parsed.hostname);
182
+ return parsed.toString();
183
+ }
184
+ /**
185
+ * Resolve a mutable webhook username/nickname to the correct Chat API user_id.
186
+ *
187
+ * Synology Chat outgoing webhooks send a user_id that may NOT match the
188
+ * Chat-internal user_id needed by the chatbot API (method=chatbot).
189
+ * The webhook's "username" field corresponds to the Chat user's "nickname".
190
+ *
191
+ * @returns The correct Chat user_id, or undefined if not found
192
+ */
193
+ async function resolveLegacyWebhookNameToChatUserId(params) {
194
+ const users = await fetchChatUsers(params.incomingUrl, params.allowInsecureSsl, params.log);
195
+ const lower = normalizeLowercaseStringOrEmpty$2(params.mutableWebhookUsername);
196
+ const byNickname = users.find((u) => normalizeLowercaseStringOrEmpty$2(u.nickname) === lower);
197
+ if (byNickname) return byNickname.user_id;
198
+ const byUsername = users.find((u) => normalizeLowercaseStringOrEmpty$2(u.username) === lower);
199
+ if (byUsername) return byUsername.user_id;
200
+ }
201
+ function buildWebhookBody(payload, userId) {
202
+ const numericId = parseNumericUserId(userId);
203
+ if (numericId !== void 0) payload.user_ids = [numericId];
204
+ return `payload=${encodeURIComponent(JSON.stringify(payload))}`;
205
+ }
206
+ function parseNumericUserId(userId) {
207
+ if (userId === void 0) return;
208
+ const numericId = typeof userId === "number" ? userId : Number.parseInt(userId, 10);
209
+ return Number.isNaN(numericId) ? void 0 : numericId;
210
+ }
211
+ function doPost(url, body, allowInsecureSsl = false) {
212
+ return new Promise((resolve, reject) => {
213
+ let parsedUrl;
214
+ try {
215
+ parsedUrl = new URL(url);
216
+ } catch {
217
+ reject(/* @__PURE__ */ new Error(`Invalid URL: ${url}`));
218
+ return;
219
+ }
220
+ const req = (parsedUrl.protocol === "https:" ? https$1 : http$1).request(url, {
221
+ method: "POST",
222
+ headers: {
223
+ "Content-Type": "application/x-www-form-urlencoded",
224
+ "Content-Length": Buffer.byteLength(body)
225
+ },
226
+ timeout: 3e4,
227
+ rejectUnauthorized: !allowInsecureSsl
228
+ }, (res) => {
229
+ let data = "";
230
+ res.on("data", (chunk) => {
231
+ data += chunk.toString();
232
+ });
233
+ res.on("end", () => {
234
+ resolve(res.statusCode === 200);
235
+ });
236
+ });
237
+ req.on("error", reject);
238
+ req.on("timeout", () => {
239
+ req.destroy();
240
+ reject(/* @__PURE__ */ new Error("Request timeout"));
241
+ });
242
+ req.write(body);
243
+ req.end();
244
+ });
245
+ }
246
+ function sleep(ms) {
247
+ return new Promise((resolve) => setTimeout(resolve, ms));
248
+ }
249
+ //#endregion
250
+ //#region extensions/synology-chat/src/config-schema.ts
251
+ const SynologyChatChannelConfigSchema = buildChannelConfigSchema(zod_exports.z.object({
252
+ dangerouslyAllowNameMatching: zod_exports.z.boolean().optional(),
253
+ dangerouslyAllowInheritedWebhookPath: zod_exports.z.boolean().optional()
254
+ }).passthrough());
255
+ //#endregion
256
+ //#region extensions/synology-chat/src/inbound-context.ts
257
+ const CHANNEL_ID$4 = "synology-chat";
258
+ function buildSynologyChatInboundContext(params) {
259
+ const { account, msg, sessionKey } = params;
260
+ return params.finalizeInboundContext({
261
+ Body: msg.body,
262
+ RawBody: msg.body,
263
+ CommandBody: msg.body,
264
+ From: `synology-chat:${msg.from}`,
265
+ To: `synology-chat:${msg.from}`,
266
+ SessionKey: sessionKey,
267
+ AccountId: account.accountId,
268
+ OriginatingChannel: CHANNEL_ID$4,
269
+ OriginatingTo: `synology-chat:${msg.from}`,
270
+ ChatType: msg.chatType,
271
+ SenderName: msg.senderName,
272
+ SenderId: msg.from,
273
+ Provider: CHANNEL_ID$4,
274
+ Surface: CHANNEL_ID$4,
275
+ ConversationLabel: msg.senderName || msg.from,
276
+ Timestamp: Date.now(),
277
+ CommandAuthorized: msg.commandAuthorized
278
+ });
279
+ }
280
+ //#endregion
281
+ //#region extensions/synology-chat/src/runtime.ts
282
+ const { setRuntime: setSynologyRuntime, getRuntime: getSynologyRuntime } = createPluginRuntimeStore({
283
+ pluginId: "synology-chat",
284
+ errorMessage: "Synology Chat runtime not initialized - plugin not registered"
285
+ });
286
+ //#endregion
287
+ //#region extensions/synology-chat/src/session-key.ts
288
+ const CHANNEL_ID$3 = "synology-chat";
289
+ function buildSynologyChatInboundSessionKey(params) {
290
+ return buildAgentSessionKey({
291
+ agentId: params.agentId,
292
+ channel: CHANNEL_ID$3,
293
+ accountId: params.accountId,
294
+ peer: {
295
+ kind: "direct",
296
+ id: params.userId
297
+ },
298
+ dmScope: "per-account-channel-peer",
299
+ identityLinks: params.identityLinks
300
+ });
301
+ }
302
+ //#endregion
303
+ //#region extensions/synology-chat/src/inbound-turn.ts
304
+ const CHANNEL_ID$2 = "synology-chat";
305
+ function resolveSynologyChatInboundRoute(params) {
306
+ const rt = getSynologyRuntime();
307
+ const route = rt.channel.routing.resolveAgentRoute({
308
+ cfg: params.cfg,
309
+ channel: CHANNEL_ID$2,
310
+ accountId: params.account.accountId,
311
+ peer: {
312
+ kind: "direct",
313
+ id: params.userId
314
+ }
315
+ });
316
+ return {
317
+ rt,
318
+ route,
319
+ sessionKey: buildSynologyChatInboundSessionKey({
320
+ agentId: route.agentId,
321
+ accountId: params.account.accountId,
322
+ userId: params.userId,
323
+ identityLinks: params.cfg.session?.identityLinks
324
+ })
325
+ };
326
+ }
327
+ async function deliverSynologyChatReply(params) {
328
+ const text = params.payload.text ?? params.payload.body;
329
+ if (!text) return;
330
+ await sendMessage(params.account.incomingUrl, text, params.sendUserId, params.account.allowInsecureSsl);
331
+ }
332
+ async function dispatchSynologyChatInboundTurn(params) {
333
+ const currentCfg = getSynologyRuntime().config.loadConfig();
334
+ const sendUserId = params.msg.chatUserId ?? params.msg.from;
335
+ const resolved = resolveSynologyChatInboundRoute({
336
+ cfg: currentCfg,
337
+ account: params.account,
338
+ userId: params.msg.from
339
+ });
340
+ const msgCtx = buildSynologyChatInboundContext({
341
+ finalizeInboundContext: resolved.rt.channel.reply.finalizeInboundContext,
342
+ account: params.account,
343
+ msg: params.msg,
344
+ sessionKey: resolved.sessionKey
345
+ });
346
+ await resolved.rt.channel.reply.dispatchReplyWithBufferedBlockDispatcher({
347
+ ctx: msgCtx,
348
+ cfg: currentCfg,
349
+ dispatcherOptions: {
350
+ deliver: async (payload) => {
351
+ await deliverSynologyChatReply({
352
+ account: params.account,
353
+ sendUserId,
354
+ payload
355
+ });
356
+ },
357
+ onReplyStart: () => {
358
+ params.log?.info?.(`Agent reply started for ${params.msg.from}`);
359
+ }
360
+ }
361
+ });
362
+ return null;
363
+ }
364
+ //#endregion
365
+ //#region extensions/synology-chat/src/security.ts
366
+ /**
367
+ * Security module: token validation, rate limiting, input sanitization, user allowlist.
368
+ */
369
+ /**
370
+ * Validate webhook token using constant-time comparison.
371
+ * Reject empty tokens explicitly; use shared constant-time comparison otherwise.
372
+ */
373
+ function validateToken(received, expected) {
374
+ if (!received || !expected) return false;
375
+ return safeEqualSecret(received, expected);
376
+ }
377
+ /**
378
+ * Check if a user ID is in the allowed list.
379
+ * Allowlist mode must be explicit; empty lists should not match any user.
380
+ */
381
+ function checkUserAllowed(userId, allowedUserIds) {
382
+ if (allowedUserIds.length === 0) return false;
383
+ return allowedUserIds.includes(userId);
384
+ }
385
+ /**
386
+ * Resolve DM authorization for a sender across all DM policy modes.
387
+ * Keeps policy semantics in one place so webhook/startup behavior stays consistent.
388
+ */
389
+ function authorizeUserForDm(userId, dmPolicy, allowedUserIds) {
390
+ if (dmPolicy === "disabled") return {
391
+ allowed: false,
392
+ reason: "disabled"
393
+ };
394
+ if (dmPolicy === "open") return { allowed: true };
395
+ if (allowedUserIds.length === 0) return {
396
+ allowed: false,
397
+ reason: "allowlist-empty"
398
+ };
399
+ if (!checkUserAllowed(userId, allowedUserIds)) return {
400
+ allowed: false,
401
+ reason: "not-allowlisted"
402
+ };
403
+ return { allowed: true };
404
+ }
405
+ /**
406
+ * Sanitize user input to prevent prompt injection attacks.
407
+ * Filters known dangerous patterns and truncates long messages.
408
+ */
409
+ function sanitizeInput(text) {
410
+ const dangerousPatterns = [
411
+ /ignore\s+(all\s+)?(previous|prior|above)\s+(instructions?|prompts?)/gi,
412
+ /you\s+are\s+now\s+/gi,
413
+ /system:\s*/gi,
414
+ /<\|.*?\|>/g
415
+ ];
416
+ let sanitized = text;
417
+ for (const pattern of dangerousPatterns) sanitized = sanitized.replace(pattern, "[FILTERED]");
418
+ const maxLength = 4e3;
419
+ if (sanitized.length > maxLength) sanitized = sanitized.slice(0, maxLength) + "... [truncated]";
420
+ return sanitized;
421
+ }
422
+ /**
423
+ * Sliding window rate limiter per user ID.
424
+ */
425
+ var RateLimiter = class {
426
+ constructor(limit = 30, windowSeconds = 60, maxTrackedUsers = 5e3) {
427
+ this.limit = limit;
428
+ this.limiter = createFixedWindowRateLimiter({
429
+ windowMs: Math.max(1, Math.floor(windowSeconds * 1e3)),
430
+ maxRequests: Math.max(1, Math.floor(limit)),
431
+ maxTrackedKeys: Math.max(1, Math.floor(maxTrackedUsers))
432
+ });
433
+ }
434
+ /** Returns true if the request is allowed, false if rate-limited. */
435
+ check(userId) {
436
+ return !this.limiter.isRateLimited(userId);
437
+ }
438
+ /** Exposed for tests and diagnostics. */
439
+ size() {
440
+ return this.limiter.size();
441
+ }
442
+ /** Exposed for tests and account lifecycle cleanup. */
443
+ clear() {
444
+ this.limiter.clear();
445
+ }
446
+ /** Exposed for tests. */
447
+ maxRequests() {
448
+ return this.limit;
449
+ }
450
+ };
451
+ //#endregion
452
+ //#region extensions/synology-chat/src/webhook-handler.ts
453
+ function normalizeLowercaseStringOrEmpty$1(value) {
454
+ return typeof value === "string" ? value.trim().toLowerCase() : "";
455
+ }
456
+ const rateLimiters = /* @__PURE__ */ new Map();
457
+ const invalidTokenRateLimiters = /* @__PURE__ */ new Map();
458
+ const webhookInFlightLimiter = createWebhookInFlightLimiter();
459
+ const PREAUTH_MAX_BODY_BYTES = 64 * 1024;
460
+ const PREAUTH_BODY_TIMEOUT_MS = 5e3;
461
+ const PREAUTH_MAX_REQUESTS_PER_MINUTE = 10;
462
+ const INVALID_TOKEN_WINDOW_MS = 6e4;
463
+ const INVALID_TOKEN_MAX_TRACKED_KEYS = 5e3;
464
+ var InvalidTokenRateLimiter = class {
465
+ constructor(limit) {
466
+ this.state = /* @__PURE__ */ new Map();
467
+ this.limit = limit;
468
+ }
469
+ normalizeState(key, nowMs) {
470
+ const existing = this.state.get(key);
471
+ if (!existing) return;
472
+ if (nowMs - existing.windowStartMs >= INVALID_TOKEN_WINDOW_MS) {
473
+ this.state.delete(key);
474
+ return;
475
+ }
476
+ return existing;
477
+ }
478
+ touch(key, value) {
479
+ this.state.delete(key);
480
+ this.state.set(key, value);
481
+ while (this.state.size > INVALID_TOKEN_MAX_TRACKED_KEYS) {
482
+ const oldestKey = this.state.keys().next().value;
483
+ if (!oldestKey) break;
484
+ this.state.delete(oldestKey);
485
+ }
486
+ }
487
+ isLocked(key, nowMs = Date.now()) {
488
+ if (!key) return false;
489
+ return (this.normalizeState(key, nowMs)?.count ?? 0) > this.limit;
490
+ }
491
+ recordFailure(key, nowMs = Date.now()) {
492
+ if (!key) return false;
493
+ const existing = this.normalizeState(key, nowMs);
494
+ const nextCount = (existing?.count ?? 0) + 1;
495
+ const windowStartMs = existing?.windowStartMs ?? nowMs;
496
+ this.touch(key, {
497
+ count: nextCount,
498
+ windowStartMs
499
+ });
500
+ return nextCount > this.limit;
501
+ }
502
+ clear() {
503
+ this.state.clear();
504
+ }
505
+ maxRequests() {
506
+ return this.limit;
507
+ }
508
+ };
509
+ function getRateLimiter(account) {
510
+ let rl = rateLimiters.get(account.accountId);
511
+ if (!rl || rl.maxRequests() !== account.rateLimitPerMinute) {
512
+ rl?.clear();
513
+ rl = new RateLimiter(account.rateLimitPerMinute);
514
+ rateLimiters.set(account.accountId, rl);
515
+ }
516
+ return rl;
517
+ }
518
+ function getInvalidTokenRateLimiter(account) {
519
+ const limit = Math.min(account.rateLimitPerMinute, PREAUTH_MAX_REQUESTS_PER_MINUTE);
520
+ let rl = invalidTokenRateLimiters.get(account.accountId);
521
+ if (!rl || rl.maxRequests() !== limit) {
522
+ rl?.clear();
523
+ rl = new InvalidTokenRateLimiter(limit);
524
+ invalidTokenRateLimiters.set(account.accountId, rl);
525
+ }
526
+ return rl;
527
+ }
528
+ function getSynologyWebhookInvalidTokenRateLimitKey(req) {
529
+ return req.socket?.remoteAddress ?? "unknown";
530
+ }
531
+ function getSynologyWebhookInFlightKey(account) {
532
+ return account.accountId;
533
+ }
534
+ /** Read the full request body as a string. */
535
+ async function readBody(req, timeoutMs = PREAUTH_BODY_TIMEOUT_MS) {
536
+ try {
537
+ return {
538
+ ok: true,
539
+ body: await readRequestBodyWithLimit(req, {
540
+ maxBytes: PREAUTH_MAX_BODY_BYTES,
541
+ timeoutMs
542
+ })
543
+ };
544
+ } catch (err) {
545
+ if (isRequestBodyLimitError(err)) return {
546
+ ok: false,
547
+ statusCode: err.statusCode,
548
+ error: requestBodyErrorToText(err.code)
549
+ };
550
+ return {
551
+ ok: false,
552
+ statusCode: 400,
553
+ error: "Invalid request body"
554
+ };
555
+ }
556
+ }
557
+ function firstNonEmptyString(value) {
558
+ if (Array.isArray(value)) {
559
+ for (const item of value) {
560
+ const normalized = firstNonEmptyString(item);
561
+ if (normalized) return normalized;
562
+ }
563
+ return;
564
+ }
565
+ if (value === null || value === void 0) return;
566
+ const str = typeof value === "string" ? value.trim() : "";
567
+ return str.length > 0 ? str : void 0;
568
+ }
569
+ function pickAlias(record, aliases) {
570
+ for (const alias of aliases) {
571
+ const normalized = firstNonEmptyString(record[alias]);
572
+ if (normalized) return normalized;
573
+ }
574
+ }
575
+ function parseQueryParams(req) {
576
+ try {
577
+ const url = new URL(req.url ?? "", "http://localhost");
578
+ const out = {};
579
+ for (const [key, value] of url.searchParams.entries()) out[key] = value;
580
+ return out;
581
+ } catch {
582
+ return {};
583
+ }
584
+ }
585
+ function parseFormBody(body) {
586
+ return querystring.parse(body);
587
+ }
588
+ function parseJsonBody(body) {
589
+ if (!body.trim()) return {};
590
+ const parsed = JSON.parse(body);
591
+ if (!parsed || Array.isArray(parsed) || typeof parsed !== "object") throw new Error("Invalid JSON body");
592
+ return parsed;
593
+ }
594
+ function headerValue(header) {
595
+ return firstNonEmptyString(header);
596
+ }
597
+ function extractTokenFromHeaders(req) {
598
+ const explicit = headerValue(req.headers["x-synology-token"]) ?? headerValue(req.headers["x-webhook-token"]) ?? headerValue(req.headers["x-genesis-token"]);
599
+ if (explicit) return explicit;
600
+ const auth = headerValue(req.headers.authorization);
601
+ if (!auth) return;
602
+ const bearerMatch = auth.match(/^Bearer\s+(.+)$/i);
603
+ if (bearerMatch?.[1]) return bearerMatch[1].trim();
604
+ return auth.trim();
605
+ }
606
+ /**
607
+ * Parse/normalize incoming webhook payload.
608
+ *
609
+ * Supports:
610
+ * - application/x-www-form-urlencoded
611
+ * - application/json
612
+ *
613
+ * Token resolution order: body.token -> query.token -> headers
614
+ * Field aliases:
615
+ * - user_id <- user_id | userId | user
616
+ * - text <- text | message | content
617
+ */
618
+ function parsePayload(req, body) {
619
+ const contentType = normalizeLowercaseStringOrEmpty$1(req.headers["content-type"]);
620
+ let bodyFields = {};
621
+ if (contentType.includes("application/json")) bodyFields = parseJsonBody(body);
622
+ else if (contentType.includes("application/x-www-form-urlencoded")) bodyFields = parseFormBody(body);
623
+ else try {
624
+ bodyFields = parseJsonBody(body);
625
+ } catch {
626
+ bodyFields = parseFormBody(body);
627
+ }
628
+ const queryFields = parseQueryParams(req);
629
+ const headerToken = extractTokenFromHeaders(req);
630
+ const token = pickAlias(bodyFields, ["token"]) ?? pickAlias(queryFields, ["token"]) ?? headerToken;
631
+ const userId = pickAlias(bodyFields, [
632
+ "user_id",
633
+ "userId",
634
+ "user"
635
+ ]) ?? pickAlias(queryFields, [
636
+ "user_id",
637
+ "userId",
638
+ "user"
639
+ ]);
640
+ const text = pickAlias(bodyFields, [
641
+ "text",
642
+ "message",
643
+ "content"
644
+ ]) ?? pickAlias(queryFields, [
645
+ "text",
646
+ "message",
647
+ "content"
648
+ ]);
649
+ if (!token || !userId || !text) return null;
650
+ return {
651
+ token,
652
+ channel_id: pickAlias(bodyFields, ["channel_id"]) ?? pickAlias(queryFields, ["channel_id"]) ?? void 0,
653
+ channel_name: pickAlias(bodyFields, ["channel_name"]) ?? pickAlias(queryFields, ["channel_name"]) ?? void 0,
654
+ user_id: userId,
655
+ username: pickAlias(bodyFields, [
656
+ "username",
657
+ "user_name",
658
+ "name"
659
+ ]) ?? pickAlias(queryFields, [
660
+ "username",
661
+ "user_name",
662
+ "name"
663
+ ]) ?? "unknown",
664
+ post_id: pickAlias(bodyFields, ["post_id"]) ?? pickAlias(queryFields, ["post_id"]) ?? void 0,
665
+ timestamp: pickAlias(bodyFields, ["timestamp"]) ?? pickAlias(queryFields, ["timestamp"]) ?? void 0,
666
+ text,
667
+ trigger_word: pickAlias(bodyFields, ["trigger_word", "triggerWord"]) ?? pickAlias(queryFields, ["trigger_word", "triggerWord"]) ?? void 0
668
+ };
669
+ }
670
+ /** Send a JSON response. */
671
+ function respondJson(res, statusCode, body) {
672
+ res.writeHead(statusCode, { "Content-Type": "application/json" });
673
+ res.end(JSON.stringify(body));
674
+ }
675
+ /** Send a no-content ACK. */
676
+ function respondNoContent(res) {
677
+ res.writeHead(204);
678
+ res.end();
679
+ }
680
+ async function parseWebhookPayloadRequest(params) {
681
+ const bodyResult = await readBody(params.req, params.bodyTimeoutMs);
682
+ if (!bodyResult.ok) {
683
+ params.log?.error("Failed to read request body", bodyResult.error);
684
+ respondJson(params.res, bodyResult.statusCode, { error: bodyResult.error });
685
+ return { ok: false };
686
+ }
687
+ let payload = null;
688
+ try {
689
+ payload = parsePayload(params.req, bodyResult.body);
690
+ } catch (err) {
691
+ params.log?.warn("Failed to parse webhook payload", err);
692
+ respondJson(params.res, 400, { error: "Invalid request body" });
693
+ return { ok: false };
694
+ }
695
+ if (!payload) {
696
+ respondJson(params.res, 400, { error: "Missing required fields (token, user_id, text)" });
697
+ return { ok: false };
698
+ }
699
+ return {
700
+ ok: true,
701
+ payload
702
+ };
703
+ }
704
+ function authorizeSynologyWebhook(params) {
705
+ const invalidTokenRateLimitKey = getSynologyWebhookInvalidTokenRateLimitKey(params.req);
706
+ if (params.invalidTokenRateLimiter.isLocked(invalidTokenRateLimitKey)) {
707
+ params.log?.warn(`Rate limit exceeded for remote IP: ${invalidTokenRateLimitKey}`);
708
+ return {
709
+ ok: false,
710
+ statusCode: 429,
711
+ error: "Rate limit exceeded"
712
+ };
713
+ }
714
+ if (!validateToken(params.payload.token, params.account.token)) {
715
+ if (params.invalidTokenRateLimiter.recordFailure(invalidTokenRateLimitKey)) {
716
+ params.log?.warn(`Rate limit exceeded for remote IP: ${invalidTokenRateLimitKey}`);
717
+ return {
718
+ ok: false,
719
+ statusCode: 429,
720
+ error: "Rate limit exceeded"
721
+ };
722
+ }
723
+ params.log?.warn(`Invalid token from ${params.req.socket?.remoteAddress}`);
724
+ return {
725
+ ok: false,
726
+ statusCode: 401,
727
+ error: "Invalid token"
728
+ };
729
+ }
730
+ const auth = authorizeUserForDm(params.payload.user_id, params.account.dmPolicy, params.account.allowedUserIds);
731
+ if (!auth.allowed) {
732
+ if (auth.reason === "disabled") return {
733
+ ok: false,
734
+ statusCode: 403,
735
+ error: "DMs are disabled"
736
+ };
737
+ if (auth.reason === "allowlist-empty") {
738
+ params.log?.warn("Synology Chat allowlist is empty while dmPolicy=allowlist; rejecting message");
739
+ return {
740
+ ok: false,
741
+ statusCode: 403,
742
+ error: "Allowlist is empty. Configure allowedUserIds or use dmPolicy=open."
743
+ };
744
+ }
745
+ params.log?.warn(`Unauthorized user: ${params.payload.user_id}`);
746
+ return {
747
+ ok: false,
748
+ statusCode: 403,
749
+ error: "User not authorized"
750
+ };
751
+ }
752
+ if (!params.rateLimiter.check(params.payload.user_id)) {
753
+ params.log?.warn(`Rate limit exceeded for user: ${params.payload.user_id}`);
754
+ return {
755
+ ok: false,
756
+ statusCode: 429,
757
+ error: "Rate limit exceeded"
758
+ };
759
+ }
760
+ return {
761
+ ok: true,
762
+ commandAuthorized: auth.allowed
763
+ };
764
+ }
765
+ function sanitizeSynologyWebhookText(payload) {
766
+ let cleanText = sanitizeInput(payload.text);
767
+ if (payload.trigger_word && cleanText.startsWith(payload.trigger_word)) cleanText = cleanText.slice(payload.trigger_word.length).trim();
768
+ return cleanText;
769
+ }
770
+ async function parseAndAuthorizeSynologyWebhook(params) {
771
+ const parsed = await parseWebhookPayloadRequest(params);
772
+ if (!parsed.ok) return { ok: false };
773
+ const authorized = authorizeSynologyWebhook({
774
+ req: params.req,
775
+ account: params.account,
776
+ payload: parsed.payload,
777
+ invalidTokenRateLimiter: params.invalidTokenRateLimiter,
778
+ rateLimiter: params.rateLimiter,
779
+ log: params.log
780
+ });
781
+ if (!authorized.ok) {
782
+ respondJson(params.res, authorized.statusCode, { error: authorized.error });
783
+ return { ok: false };
784
+ }
785
+ const cleanText = sanitizeSynologyWebhookText(parsed.payload);
786
+ if (!cleanText) {
787
+ respondNoContent(params.res);
788
+ return { ok: false };
789
+ }
790
+ const preview = cleanText.length > 100 ? `${cleanText.slice(0, 100)}...` : cleanText;
791
+ return {
792
+ ok: true,
793
+ message: {
794
+ payload: parsed.payload,
795
+ body: cleanText,
796
+ commandAuthorized: authorized.commandAuthorized,
797
+ preview
798
+ }
799
+ };
800
+ }
801
+ async function resolveSynologyReplyDeliveryUserId(params) {
802
+ if (!params.account.dangerouslyAllowNameMatching) return params.payload.user_id;
803
+ const resolvedChatApiUserId = await resolveLegacyWebhookNameToChatUserId({
804
+ incomingUrl: params.account.incomingUrl,
805
+ mutableWebhookUsername: params.payload.username,
806
+ allowInsecureSsl: params.account.allowInsecureSsl,
807
+ log: params.log
808
+ });
809
+ if (resolvedChatApiUserId !== void 0) return String(resolvedChatApiUserId);
810
+ params.log?.warn(`Could not resolve Chat API user_id for "${params.payload.username}" — falling back to webhook user_id ${params.payload.user_id}. Reply delivery may fail.`);
811
+ return params.payload.user_id;
812
+ }
813
+ async function processAuthorizedSynologyWebhook(params) {
814
+ const authorizedWebhookUserId = params.message.payload.user_id;
815
+ let deliveryUserId = authorizedWebhookUserId;
816
+ try {
817
+ deliveryUserId = await resolveSynologyReplyDeliveryUserId({
818
+ account: params.account,
819
+ payload: params.message.payload,
820
+ log: params.log
821
+ });
822
+ const deliverPromise = params.deliver({
823
+ body: params.message.body,
824
+ from: authorizedWebhookUserId,
825
+ senderName: params.message.payload.username,
826
+ provider: "synology-chat",
827
+ chatType: "direct",
828
+ accountId: params.account.accountId,
829
+ commandAuthorized: params.message.commandAuthorized,
830
+ chatUserId: deliveryUserId
831
+ });
832
+ const timeoutPromise = new Promise((_, reject) => setTimeout(() => reject(/* @__PURE__ */ new Error("Agent response timeout (120s)")), 12e4));
833
+ const reply = await Promise.race([deliverPromise, timeoutPromise]);
834
+ if (!reply) return;
835
+ await sendMessage(params.account.incomingUrl, reply, deliveryUserId, params.account.allowInsecureSsl);
836
+ const replyPreview = reply.length > 100 ? `${reply.slice(0, 100)}...` : reply;
837
+ params.log?.info?.(`Reply sent to ${params.message.payload.username} (${deliveryUserId}): ${replyPreview}`);
838
+ } catch (err) {
839
+ const errMsg = err instanceof Error ? `${err.message}\n${err.stack}` : String(err);
840
+ params.log?.error?.(`Failed to process message from ${params.message.payload.username}: ${errMsg}`);
841
+ await sendMessage(params.account.incomingUrl, "Sorry, an error occurred while processing your message.", deliveryUserId, params.account.allowInsecureSsl);
842
+ }
843
+ }
844
+ function createWebhookHandler(deps) {
845
+ const { account, deliver, log } = deps;
846
+ const rateLimiter = getRateLimiter(account);
847
+ const invalidTokenRateLimiter = getInvalidTokenRateLimiter(account);
848
+ return async (req, res) => {
849
+ if (req.method !== "POST") {
850
+ respondJson(res, 405, { error: "Method not allowed" });
851
+ return;
852
+ }
853
+ const requestLifecycle = beginWebhookRequestPipelineOrReject({
854
+ req,
855
+ res,
856
+ inFlightLimiter: webhookInFlightLimiter,
857
+ inFlightKey: getSynologyWebhookInFlightKey(account)
858
+ });
859
+ if (!requestLifecycle.ok) return;
860
+ let authorized;
861
+ try {
862
+ authorized = await parseAndAuthorizeSynologyWebhook({
863
+ req,
864
+ res,
865
+ account,
866
+ invalidTokenRateLimiter,
867
+ rateLimiter,
868
+ log,
869
+ bodyTimeoutMs: deps.bodyTimeoutMs
870
+ });
871
+ } finally {
872
+ requestLifecycle.release();
873
+ }
874
+ if (!authorized.ok) return;
875
+ log?.info(`Message from ${authorized.message.payload.username} (${authorized.message.payload.user_id}): ${authorized.message.preview}`);
876
+ respondNoContent(res);
877
+ await processAuthorizedSynologyWebhook({
878
+ account,
879
+ deliver,
880
+ log,
881
+ message: authorized.message
882
+ });
883
+ };
884
+ }
885
+ //#endregion
886
+ //#region extensions/synology-chat/src/gateway-runtime.ts
887
+ const CHANNEL_ID$1 = "synology-chat";
888
+ const activeRouteUnregisters = /* @__PURE__ */ new Map();
889
+ function buildStartupIssue(code, message, logLevel = "warn") {
890
+ return {
891
+ code,
892
+ logLevel,
893
+ message
894
+ };
895
+ }
896
+ function logStartupIssues(log, issues) {
897
+ for (const issue of issues) {
898
+ const message = `Synology Chat ${issue.message}`;
899
+ if (issue.logLevel === "info") {
900
+ log?.info?.(message);
901
+ continue;
902
+ }
903
+ log?.warn?.(message);
904
+ }
905
+ }
906
+ function getRouteKey(account) {
907
+ return `${account.accountId}:${account.webhookPath}`;
908
+ }
909
+ function createUnknownArgsLogAdapter(log) {
910
+ if (!log) return;
911
+ const formatArg = (value) => typeof value === "string" ? value : value instanceof Error ? value.message : "";
912
+ return {
913
+ info: (...args) => log.info?.(formatArg(args[0])),
914
+ warn: (...args) => log.warn?.(formatArg(args[0])),
915
+ error: (...args) => log.error?.(formatArg(args[0]))
916
+ };
917
+ }
918
+ function collectSynologyGatewayStartupIssues(params) {
919
+ const { cfg, account, accountId } = params;
920
+ const issues = [];
921
+ if (!account.enabled) {
922
+ issues.push(buildStartupIssue("disabled", `account ${accountId} is disabled, skipping`, "info"));
923
+ return issues;
924
+ }
925
+ if (!account.token || !account.incomingUrl) issues.push(buildStartupIssue("missing-credentials", `account ${accountId} not fully configured (missing token or incomingUrl)`));
926
+ if (account.dmPolicy === "allowlist" && account.allowedUserIds.length === 0) issues.push(buildStartupIssue("empty-allowlist", `account ${accountId} has dmPolicy=allowlist but empty allowedUserIds; refusing to start route`));
927
+ const accountIds = listAccountIds(cfg);
928
+ if (accountIds.length > 1 && accountId !== "default" && account.webhookPathSource === "inherited-base" && !account.dangerouslyAllowInheritedWebhookPath) issues.push(buildStartupIssue("inherited-shared-webhook-path", `account ${accountId} must set an explicit webhookPath in multi-account setups; refusing inherited shared path. Set channels.synology-chat.accounts.${accountId}.webhookPath or opt in with dangerouslyAllowInheritedWebhookPath=true.`));
929
+ const conflictingAccounts = accountIds.filter((candidateId) => {
930
+ if (candidateId === accountId) return false;
931
+ const candidate = resolveAccount(cfg, candidateId);
932
+ return candidate.enabled && candidate.webhookPath === account.webhookPath;
933
+ });
934
+ if (conflictingAccounts.length > 0) issues.push(buildStartupIssue("duplicate-webhook-path", `account ${accountId} conflicts on webhookPath ${account.webhookPath} with ${conflictingAccounts.join(", ")}; refusing to start ambiguous shared route.`));
935
+ return issues;
936
+ }
937
+ function collectSynologyGatewayRoutingWarnings(params) {
938
+ return collectSynologyGatewayStartupIssues({
939
+ cfg: params.cfg,
940
+ account: params.account,
941
+ accountId: params.account.accountId
942
+ }).filter((issue) => issue.code === "inherited-shared-webhook-path" || issue.code === "duplicate-webhook-path").map((issue) => `- Synology Chat: ${issue.message}`);
943
+ }
944
+ function validateSynologyGatewayAccountStartup(params) {
945
+ const issues = collectSynologyGatewayStartupIssues(params);
946
+ if (issues.length > 0) {
947
+ logStartupIssues(params.log, issues);
948
+ return { ok: false };
949
+ }
950
+ return { ok: true };
951
+ }
952
+ function registerSynologyWebhookRoute(params) {
953
+ const { account, log } = params;
954
+ const routeKey = getRouteKey(account);
955
+ const prevUnregister = activeRouteUnregisters.get(routeKey);
956
+ if (prevUnregister) {
957
+ log?.info?.(`Deregistering stale route before re-registering: ${account.webhookPath}`);
958
+ prevUnregister();
959
+ activeRouteUnregisters.delete(routeKey);
960
+ }
961
+ const handler = createWebhookHandler({
962
+ account,
963
+ deliver: async (msg) => await dispatchSynologyChatInboundTurn({
964
+ account,
965
+ msg,
966
+ log: createUnknownArgsLogAdapter(log)
967
+ }),
968
+ log: createUnknownArgsLogAdapter(log)
969
+ });
970
+ const unregister = registerPluginHttpRoute({
971
+ path: account.webhookPath,
972
+ auth: "plugin",
973
+ pluginId: CHANNEL_ID$1,
974
+ accountId: account.accountId,
975
+ log: (msg) => log?.info?.(msg),
976
+ handler
977
+ });
978
+ activeRouteUnregisters.set(routeKey, unregister);
979
+ return () => {
980
+ unregister();
981
+ activeRouteUnregisters.delete(routeKey);
982
+ };
983
+ }
984
+ //#endregion
985
+ //#region extensions/synology-chat/src/channel.ts
986
+ /**
987
+ * Synology Chat Channel Plugin for Genesis.
988
+ *
989
+ * Implements the ChannelPlugin interface following the LINE pattern.
990
+ */
991
+ const CHANNEL_ID = "synology-chat";
992
+ function normalizeLowercaseStringOrEmpty(value) {
993
+ return typeof value === "string" ? value.trim().toLowerCase() : "";
994
+ }
995
+ const resolveSynologyChatDmPolicy = createScopedDmSecurityResolver({
996
+ channelKey: CHANNEL_ID,
997
+ resolvePolicy: (account) => account.dmPolicy,
998
+ resolveAllowFrom: (account) => account.allowedUserIds,
999
+ policyPathSuffix: "dmPolicy",
1000
+ defaultPolicy: "allowlist",
1001
+ approveHint: "genesis pairing approve synology-chat <code>",
1002
+ normalizeEntry: (raw) => normalizeLowercaseStringOrEmpty(raw)
1003
+ });
1004
+ const synologyChatConfigAdapter = createHybridChannelConfigAdapter({
1005
+ sectionKey: CHANNEL_ID,
1006
+ listAccountIds,
1007
+ resolveAccount,
1008
+ defaultAccountId: () => DEFAULT_ACCOUNT_ID,
1009
+ clearBaseFields: [
1010
+ "token",
1011
+ "incomingUrl",
1012
+ "nasHost",
1013
+ "webhookPath",
1014
+ "dangerouslyAllowNameMatching",
1015
+ "dangerouslyAllowInheritedWebhookPath",
1016
+ "dmPolicy",
1017
+ "allowedUserIds",
1018
+ "rateLimitPerMinute",
1019
+ "botName",
1020
+ "allowInsecureSsl"
1021
+ ],
1022
+ resolveAllowFrom: (account) => account.allowedUserIds,
1023
+ formatAllowFrom: (allowFrom) => allowFrom.map((entry) => normalizeLowercaseStringOrEmpty(String(entry))).filter(Boolean)
1024
+ });
1025
+ const collectSynologyChatSecurityWarnings = createConditionalWarningCollector((account) => !account.token && "- Synology Chat: token is not configured. The webhook will reject all requests.", (account) => !account.incomingUrl && "- Synology Chat: incomingUrl is not configured. The bot cannot send replies.", (account) => account.allowInsecureSsl && "- Synology Chat: SSL verification is disabled (allowInsecureSsl=true). Only use this for local NAS with self-signed certificates.", (account) => account.dangerouslyAllowNameMatching && "- Synology Chat: dangerouslyAllowNameMatching=true re-enables mutable username/nickname recipient matching for replies. Prefer stable numeric user IDs.", (account) => account.dangerouslyAllowInheritedWebhookPath && account.webhookPathSource === "inherited-base" && "- Synology Chat: dangerouslyAllowInheritedWebhookPath=true opts a named account into a shared inherited webhook path. Prefer an explicit per-account webhookPath.", (account) => account.dmPolicy === "open" && "- Synology Chat: dmPolicy=\"open\" allows any user to message the bot. Consider \"allowlist\" for production use.", (account) => account.dmPolicy === "allowlist" && account.allowedUserIds.length === 0 && "- Synology Chat: dmPolicy=\"allowlist\" with empty allowedUserIds blocks all senders. Add users or set dmPolicy=\"open\".");
1026
+ const collectSynologyChatRoutingWarnings = projectAccountConfigWarningCollector((cfg) => cfg, ({ account, cfg }) => collectSynologyGatewayRoutingWarnings({
1027
+ account,
1028
+ cfg
1029
+ }));
1030
+ function resolveOutboundAccount(cfg, accountId) {
1031
+ return resolveAccount(cfg ?? {}, accountId);
1032
+ }
1033
+ function requireIncomingUrl(account) {
1034
+ if (!account.incomingUrl) throw new Error("Synology Chat incoming URL not configured");
1035
+ return account.incomingUrl;
1036
+ }
1037
+ function createSynologyChatPlugin() {
1038
+ return createChatChannelPlugin({
1039
+ base: {
1040
+ id: CHANNEL_ID,
1041
+ meta: {
1042
+ id: CHANNEL_ID,
1043
+ label: "Synology Chat",
1044
+ selectionLabel: "Synology Chat (Webhook)",
1045
+ detailLabel: "Synology Chat (Webhook)",
1046
+ docsPath: "/channels/synology-chat",
1047
+ blurb: "Connect your Synology NAS Chat to Genesis",
1048
+ order: 90
1049
+ },
1050
+ capabilities: {
1051
+ chatTypes: ["direct"],
1052
+ media: true,
1053
+ threads: false,
1054
+ reactions: false,
1055
+ edit: false,
1056
+ unsend: false,
1057
+ reply: false,
1058
+ effects: false,
1059
+ blockStreaming: false
1060
+ },
1061
+ reload: { configPrefixes: [`channels.${CHANNEL_ID}`] },
1062
+ configSchema: SynologyChatChannelConfigSchema,
1063
+ setup: synologyChatSetupAdapter,
1064
+ setupWizard: synologyChatSetupWizard,
1065
+ config: { ...synologyChatConfigAdapter },
1066
+ approvalCapability: synologyChatApprovalAuth,
1067
+ messaging: {
1068
+ normalizeTarget: (target) => {
1069
+ const trimmed = target.trim();
1070
+ if (!trimmed) return;
1071
+ return trimmed.replace(/^synology[-_]?chat:/i, "").trim();
1072
+ },
1073
+ targetResolver: {
1074
+ looksLikeId: (id) => {
1075
+ const trimmed = id?.trim();
1076
+ if (!trimmed) return false;
1077
+ return /^\d+$/.test(trimmed) || /^synology[-_]?chat:/i.test(trimmed);
1078
+ },
1079
+ hint: "<userId>"
1080
+ }
1081
+ },
1082
+ directory: createEmptyChannelDirectoryAdapter(),
1083
+ gateway: {
1084
+ startAccount: async (ctx) => {
1085
+ const { cfg, accountId, log, abortSignal } = ctx;
1086
+ const account = resolveAccount(cfg, accountId);
1087
+ if (!validateSynologyGatewayAccountStartup({
1088
+ cfg,
1089
+ account,
1090
+ accountId,
1091
+ log
1092
+ }).ok) return waitUntilAbort(abortSignal);
1093
+ log?.info?.(`Starting Synology Chat channel (account: ${accountId}, path: ${account.webhookPath})`);
1094
+ const unregister = registerSynologyWebhookRoute({
1095
+ account,
1096
+ accountId,
1097
+ log
1098
+ });
1099
+ log?.info?.(`Registered HTTP route: ${account.webhookPath} for Synology Chat`);
1100
+ return waitUntilAbort(abortSignal, () => {
1101
+ log?.info?.(`Stopping Synology Chat channel (account: ${accountId})`);
1102
+ unregister();
1103
+ });
1104
+ },
1105
+ stopAccount: async (ctx) => {
1106
+ ctx.log?.info?.(`Synology Chat account ${ctx.accountId} stopped`);
1107
+ }
1108
+ },
1109
+ agentPrompt: { messageToolHints: () => [
1110
+ "",
1111
+ "### Synology Chat Formatting",
1112
+ "Synology Chat supports limited formatting. Use these patterns:",
1113
+ "",
1114
+ "**Links**: Use `<URL|display text>` to create clickable links.",
1115
+ " Example: `<https://example.com|Click here>` renders as a clickable link.",
1116
+ "",
1117
+ "**File sharing**: Include a publicly accessible URL to share files or images.",
1118
+ " The NAS will download and attach the file (max 32 MB).",
1119
+ "",
1120
+ "**Limitations**:",
1121
+ "- No markdown, bold, italic, or code blocks",
1122
+ "- No buttons, cards, or interactive elements",
1123
+ "- No message editing after send",
1124
+ "- Keep messages under 2000 characters for best readability",
1125
+ "",
1126
+ "**Best practices**:",
1127
+ "- Use short, clear responses (Synology Chat has a minimal UI)",
1128
+ "- Use line breaks to separate sections",
1129
+ "- Use numbered or bulleted lists for clarity",
1130
+ "- Wrap URLs with `<URL|label>` for user-friendly links"
1131
+ ] }
1132
+ },
1133
+ pairing: { text: {
1134
+ idLabel: "synologyChatUserId",
1135
+ message: "Genesis: your access has been approved.",
1136
+ normalizeAllowEntry: (entry) => normalizeLowercaseStringOrEmpty(entry),
1137
+ notify: async ({ cfg, id, message }) => {
1138
+ const account = resolveAccount(cfg);
1139
+ if (!account.incomingUrl) return;
1140
+ await sendMessage(account.incomingUrl, message, id, account.allowInsecureSsl);
1141
+ }
1142
+ } },
1143
+ security: {
1144
+ resolveDmPolicy: resolveSynologyChatDmPolicy,
1145
+ collectWarnings: composeWarningCollectors(projectAccountWarningCollector(collectSynologyChatSecurityWarnings), collectSynologyChatRoutingWarnings),
1146
+ collectAuditFindings: collectSynologyChatSecurityAuditFindings
1147
+ },
1148
+ outbound: {
1149
+ deliveryMode: "gateway",
1150
+ textChunkLimit: 2e3,
1151
+ sendText: async ({ to, text, accountId, cfg }) => {
1152
+ const account = resolveOutboundAccount(cfg ?? {}, accountId);
1153
+ if (!await sendMessage(requireIncomingUrl(account), text, to, account.allowInsecureSsl)) throw new Error("Failed to send message to Synology Chat");
1154
+ return attachChannelToResult(CHANNEL_ID, {
1155
+ messageId: `sc-${Date.now()}`,
1156
+ chatId: to
1157
+ });
1158
+ },
1159
+ sendMedia: async ({ to, mediaUrl, accountId, cfg }) => {
1160
+ const account = resolveOutboundAccount(cfg ?? {}, accountId);
1161
+ const incomingUrl = requireIncomingUrl(account);
1162
+ if (!mediaUrl) throw new Error("No media URL provided");
1163
+ if (!await sendFileUrl(incomingUrl, mediaUrl, to, account.allowInsecureSsl)) throw new Error("Failed to send media to Synology Chat");
1164
+ return attachChannelToResult(CHANNEL_ID, {
1165
+ messageId: `sc-${Date.now()}`,
1166
+ chatId: to
1167
+ });
1168
+ }
1169
+ }
1170
+ });
1171
+ }
1172
+ const synologyChatPlugin = createSynologyChatPlugin();
1173
+ //#endregion
1174
+ export { setSynologyRuntime as n, synologyChatPlugin as t };