@pixelzx/genesis 2026.5.5-2 → 2026.5.5-3

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 (1017) hide show
  1. package/CHANGELOG.md +1 -0
  2. package/dist/.buildstamp +1 -1
  3. package/dist/abort-Yw60gQ-C.js +201 -0
  4. package/dist/abort.runtime-DYQuut_O.js +2 -0
  5. package/dist/abort.runtime.js +1 -1
  6. package/dist/accounts-BSCHGPHp.js +107 -0
  7. package/dist/accounts-Bb0FqxV2.js +104 -0
  8. package/dist/accounts-BjGgx8lz.js +2 -0
  9. package/dist/acp-cli-emMnOaiO.js +2193 -0
  10. package/dist/acp-spawn-BmyUZuJX.js +1093 -0
  11. package/dist/acp-spawn-DPF5zmnN.js +2 -0
  12. package/dist/acp-stateful-target-driver-CJ4JyIHf.js +89 -0
  13. package/dist/action-agents-D1tXt8Kj.js +67 -0
  14. package/dist/action-focus-Bk6AJsNH.js +132 -0
  15. package/dist/action-help-4nFSAuVo.js +7 -0
  16. package/dist/action-info-D-byoefn.js +101 -0
  17. package/dist/action-kill-Bo-NwBVR.js +33 -0
  18. package/dist/action-list-lAa4rlzN.js +21 -0
  19. package/dist/action-log-BasoUC3L.js +30 -0
  20. package/dist/action-send-DwLkiz4x.js +39 -0
  21. package/dist/action-spawn-C70_iR8d.js +47 -0
  22. package/dist/action-unfocus-dUVMx5Fh.js +29 -0
  23. package/dist/actions.runtime-BdSo6rN8.js +18 -0
  24. package/dist/actions.runtime-BvY67XKu.js +5 -0
  25. package/dist/actions.runtime.js +1 -1
  26. package/dist/agent-DDBv3Vgl.js +2 -0
  27. package/dist/agent-command-DC7I_88W.js +874 -0
  28. package/dist/agent-harness-runtime-TA6YH7Ud.js +144 -0
  29. package/dist/agent-runner-utils-CMe-JIDq.js +239 -0
  30. package/dist/agent-runner.runtime-le6AmJRw.js +3455 -0
  31. package/dist/agent-runner.runtime.js +1 -1
  32. package/dist/agent-runtime-CONy4fDD.js +18 -0
  33. package/dist/agents-BlbOM4XW.js +953 -0
  34. package/dist/agents-Byj8CDAP.js +5 -0
  35. package/dist/aliases-C3Ks5x38.js +2 -0
  36. package/dist/aliases-CxBcx9gF.js +96 -0
  37. package/dist/api-CLoj7nYH.js +3 -0
  38. package/dist/api-DZiRkVPk.js +5 -0
  39. package/dist/api-_Y4nIHNo.js +139 -0
  40. package/dist/approval-gateway-resolver-Ba_2kb3B.js +29 -0
  41. package/dist/approval-gateway-runtime-7VMivk0A.js +2 -0
  42. package/dist/approval-handler-runtime-Bh0onoHD.js +439 -0
  43. package/dist/approval-native-runtime-IYFyT8Hf.js +729 -0
  44. package/dist/attempt-execution.runtime-CpL2tsYd.js +509 -0
  45. package/dist/attempt-execution.runtime.js +1 -1
  46. package/dist/attempt.prompt-helpers-Gx9nGKbW.js +221 -0
  47. package/dist/attempt.tool-run-context-BmuljBMs.js +933 -0
  48. package/dist/audit-CsjqOEVE.js +939 -0
  49. package/dist/audit.runtime-BybEaYH4.js +7 -0
  50. package/dist/audit.runtime.js +1 -1
  51. package/dist/auth-BFbLz2gx.js +383 -0
  52. package/dist/auth-DdoNShRm.js +2 -0
  53. package/dist/auth-order-CtO2WQTH.js +2 -0
  54. package/dist/auth-order-zXIiW-Cn.js +96 -0
  55. package/dist/bash-tools-CnDYSbnX.js +2824 -0
  56. package/dist/bash-tools-DiOcKaak.js +3 -0
  57. package/dist/binding-routing-E9Gh_NqO.js +85 -0
  58. package/dist/binding-targets-C5PbBaZ6.js +121 -0
  59. package/dist/bridge-server-DragdaQD.js +113 -0
  60. package/dist/browser-control-auth-D_M31xJ1.js +2 -0
  61. package/dist/browser-node-runtime-Bgu82luB.js +12 -0
  62. package/dist/browser-profiles-C3ffkgOt.js +2 -0
  63. package/dist/browser-runtime-D84IBo4A.js +387 -0
  64. package/dist/browser-setup-tools-VC7rGCyn.js +13 -0
  65. package/dist/build-DeGDX_pJ.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-CbvF41H8.js +3 -0
  70. package/dist/call-DuDGOVT1.js +331 -0
  71. package/dist/call.runtime-DztWXjMr.js +2 -0
  72. package/dist/call.runtime.js +1 -1
  73. package/dist/capability-cli-DoJLi3eS.js +1401 -0
  74. package/dist/catchup-Dk-5hIwm.js +300 -0
  75. package/dist/channel-BJ9iEC4Y.js +595 -0
  76. package/dist/channel-BdvsbgZE.js +453 -0
  77. package/dist/channel-Bu-7KaIx.js +1802 -0
  78. package/dist/channel-C9vQNMK1.js +350 -0
  79. package/dist/channel-CZoVAZyW.js +491 -0
  80. package/dist/channel-Cr2KTwyo.js +840 -0
  81. package/dist/channel-DCeC6AEQ.js +297 -0
  82. package/dist/channel-DOGp2TfT.js +1320 -0
  83. package/dist/channel-Dfq1lxxI.js +226 -0
  84. package/dist/channel-core-DiltAzdr.js +5 -0
  85. package/dist/channel-hZDaTBpm.js +1100 -0
  86. package/dist/channel-inbound-DvOS-Z1s.js +31 -0
  87. package/dist/channel-plugin-runtime-PFRHQ61T.js +771 -0
  88. package/dist/channel-runtime-BAjxIEfQ.js +425 -0
  89. package/dist/channel-szBwbQZB.js +1174 -0
  90. package/dist/channel.runtime-B1Ry35gt.js +89 -0
  91. package/dist/channel.runtime-BNp6GxaQ.js +34702 -0
  92. package/dist/channel.runtime-BfjvNvbj.js +2364 -0
  93. package/dist/channel.runtime-BlGn4QYV.js +4 -0
  94. package/dist/channel.runtime-D7bv5rJl.js +576 -0
  95. package/dist/channel.runtime-DQ5gSgeW.js +109 -0
  96. package/dist/channel.runtime-IxClQMdT.js +430 -0
  97. package/dist/channel.setup-BsfyGPgV.js +10 -0
  98. package/dist/channels-Dn2VHRmZ.js +733 -0
  99. package/dist/channels-cli-l4xjPvDv.js +268 -0
  100. package/dist/chat-zUeX8mQw.js +2758 -0
  101. package/dist/clawbot-cli-C3BFdHJB.js +9 -0
  102. package/dist/cli/daemon-cli.js +4 -4
  103. package/dist/cli-BTnpFsj1.js +2 -0
  104. package/dist/cli-CAFQ6Cwy.js +72 -0
  105. package/dist/cli-CiqIbwtg.js +219 -0
  106. package/dist/cli-DL1ppK38.js +2 -0
  107. package/dist/cli-runner-DO6lEPJr.js +286 -0
  108. package/dist/cli-runner.runtime-B-Ic4DyC.js +3 -0
  109. package/dist/cli-runner.runtime-C4cAORcg.js +4 -0
  110. package/dist/cli-runner.runtime.js +1 -1
  111. package/dist/cli-startup-metadata.json +2 -2
  112. package/dist/cli.runtime-CYHctHVS.js +1261 -0
  113. package/dist/cli.runtime.js +1 -1
  114. package/dist/client-Bb_miREU.js +138 -0
  115. package/dist/client-CrPccv7a.js +713 -0
  116. package/dist/command-auth-B7P-1IeA.js +76 -0
  117. package/dist/command-config-resolution-BB-SsCob.js +23 -0
  118. package/dist/command-config-resolution-DMKYb0Kh.js +2 -0
  119. package/dist/command-config-resolution.runtime-Coeaa9lz.js +2 -0
  120. package/dist/command-config-resolution.runtime.js +1 -1
  121. package/dist/command-registry-B2JzWHqy.js +9 -0
  122. package/dist/command-registry-CNUpJUp8.js +4 -0
  123. package/dist/command-registry-core-BLap9aka.js +101 -0
  124. package/dist/command-secret-gateway-ChRXthnT.js +528 -0
  125. package/dist/command-status.runtime-D8VWyC3v.js +87 -0
  126. package/dist/command-status.runtime.js +1 -1
  127. package/dist/commands-acp-QLk1cU5f.js +77 -0
  128. package/dist/commands-compact.runtime-BIHG2RSY.js +10 -0
  129. package/dist/commands-compact.runtime.js +1 -1
  130. package/dist/commands-handlers.runtime-DjimbxSJ.js +4597 -0
  131. package/dist/commands-handlers.runtime.js +1 -1
  132. package/dist/commands-status-DiIQSYSt.js +16 -0
  133. package/dist/commands-status.runtime-DBRxICN6.js +3 -0
  134. package/dist/commands-status.runtime.js +1 -1
  135. package/dist/commands-subagents-control.runtime-BmqXiKHu.js +3 -0
  136. package/dist/commands-subagents-control.runtime-CVQSOd8H.js +2 -0
  137. package/dist/commands-subagents-control.runtime.js +1 -1
  138. package/dist/commands-system-prompt-2qwZc3xL.js +158 -0
  139. package/dist/commands-system-prompt-Clnn_Gct.js +2 -0
  140. package/dist/commands.runtime-DAqpiDPr.js +166 -0
  141. package/dist/commands.runtime.js +1 -1
  142. package/dist/compact-DqOkQZYr.js +1118 -0
  143. package/dist/compact.runtime-CC_l29j4.js +12 -0
  144. package/dist/compact.runtime.js +1 -1
  145. package/dist/completion-cli-DZFJPSiF.js +328 -0
  146. package/dist/config-D9XEe0Cd.js +251 -0
  147. package/dist/config-cli-DVDwIjKr.js +1078 -0
  148. package/dist/configure-39oQUHuK.js +1245 -0
  149. package/dist/configure-BGD8tViZ.js +2 -0
  150. package/dist/connect-options-Fpky6zuL.js +699 -0
  151. package/dist/control-auth-BlqH4IVx.js +125 -0
  152. package/dist/control-service-CaqDohiY.js +156 -0
  153. package/dist/conversation-id-BH9GFVB2.js +235 -0
  154. package/dist/conversation-id-UdIegcf4.js +38 -0
  155. package/dist/conversation-runtime-Bao0kIPf.js +31 -0
  156. package/dist/core-DXUh5Xbm.js +275 -0
  157. package/dist/cron-cli-B1mxHnGP.js +713 -0
  158. package/dist/daemon-cli-CaHBNwMy.js +12 -0
  159. package/dist/daemon-install-BBwOxf1q.js +64 -0
  160. package/dist/delegate-7G7R4C-C.js +64 -0
  161. package/dist/detached-task-runtime-BMdSrcuz.js +73 -0
  162. package/dist/devices-cli-DnEQH3R2.js +496 -0
  163. package/dist/diagnostics-C8VwSDtU.js +154 -0
  164. package/dist/direct-dm-BSEkIiOe.js +64 -0
  165. package/dist/dispatch-1gv6It-6.js +1131 -0
  166. package/dist/dispatch-acp-hbhR9aHr.js +981 -0
  167. package/dist/dispatch-acp-manager.runtime-BXQbK1cO.js +3 -0
  168. package/dist/dispatch-acp-manager.runtime.js +1 -1
  169. package/dist/dispatch-acp.runtime-Dhx090J2.js +19 -0
  170. package/dist/dispatch-acp.runtime.js +1 -1
  171. package/dist/doctor-device-pairing-1gf3tk3g.js +307 -0
  172. package/dist/doctor-gateway-daemon-flow-LEnN6pL-.js +250 -0
  173. package/dist/doctor-gateway-health-DwxLkTV4.js +60 -0
  174. package/dist/doctor-gateway-services-BhqUOY_e.js +316 -0
  175. package/dist/doctor-health-CdJkaUYf.js +59 -0
  176. package/dist/doctor-health-contributions-BaTnIzCT.js +486 -0
  177. package/dist/doctor-prompter-BZTb5rOn.js +56 -0
  178. package/dist/doctor-workspace-status-DnBARoPa.js +75 -0
  179. package/dist/dreaming-BAGFdUxh.js +1574 -0
  180. package/dist/dreaming-narrative-XoOfVb0x.js +595 -0
  181. package/dist/embedded-gateway-stub.runtime-xwZ-M7Ei.js +9 -0
  182. package/dist/embedded-gateway-stub.runtime.js +1 -1
  183. package/dist/entry.js +2 -2
  184. package/dist/exec-approvals-cli-CWVWSMk-.js +498 -0
  185. package/dist/extensionAPI.js +1 -1
  186. package/dist/extensions/active-memory/index.js +1 -1
  187. package/dist/extensions/bluebubbles/api.js +3 -3
  188. package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
  189. package/dist/extensions/browser/browser-bridge.js +1 -1
  190. package/dist/extensions/browser/browser-config.js +4 -4
  191. package/dist/extensions/browser/browser-control-auth.js +2 -2
  192. package/dist/extensions/browser/browser-doctor.js +2 -2
  193. package/dist/extensions/browser/browser-maintenance.js +2 -2
  194. package/dist/extensions/browser/browser-profiles.js +2 -2
  195. package/dist/extensions/browser/browser-runtime-api.js +10 -10
  196. package/dist/extensions/browser/index.js +1 -1
  197. package/dist/extensions/browser/plugin-registration.js +1 -1
  198. package/dist/extensions/browser/register.runtime.js +3 -3
  199. package/dist/extensions/browser/runtime-api.js +11 -11
  200. package/dist/extensions/browser/test-support.js +1 -1
  201. package/dist/extensions/device-pair/api.js +1 -1
  202. package/dist/extensions/device-pair/index.js +3 -3
  203. package/dist/extensions/device-pair/notify.js +1 -1
  204. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  205. package/dist/extensions/google-meet/index.js +2 -2
  206. package/dist/extensions/imessage/api.js +3 -3
  207. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  208. package/dist/extensions/imessage/runtime-api.js +3 -3
  209. package/dist/extensions/irc/api.js +2 -2
  210. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  211. package/dist/extensions/line/api.js +2 -2
  212. package/dist/extensions/line/channel-plugin-api.js +1 -1
  213. package/dist/extensions/line/contract-api.js +1 -1
  214. package/dist/extensions/line/runtime-api.js +4 -4
  215. package/dist/extensions/line/setup-api.js +1 -1
  216. package/dist/extensions/llm-task/index.js +2 -2
  217. package/dist/extensions/lobster/index.js +3 -3
  218. package/dist/extensions/lobster/runtime-api.js +1 -1
  219. package/dist/extensions/mattermost/api.js +1 -1
  220. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  221. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  222. package/dist/extensions/mattermost/policy-api.js +1 -1
  223. package/dist/extensions/mattermost/runtime-api.js +4 -4
  224. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  225. package/dist/extensions/memory-core/api.js +1 -1
  226. package/dist/extensions/memory-core/cli-metadata.js +2 -2
  227. package/dist/extensions/memory-core/index.js +3 -3
  228. package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
  229. package/dist/extensions/msteams/api.js +1 -1
  230. package/dist/extensions/msteams/channel-plugin-api.js +1 -1
  231. package/dist/extensions/msteams/runtime-api.js +3 -3
  232. package/dist/extensions/msteams/test-api.js +1 -1
  233. package/dist/extensions/nextcloud-talk/api.js +1 -1
  234. package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
  235. package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
  236. package/dist/extensions/openshell/index.js +2 -2
  237. package/dist/extensions/signal/api.js +6 -6
  238. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  239. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  240. package/dist/extensions/signal/runtime-api.js +7 -7
  241. package/dist/extensions/skill-workshop/api.js +1 -1
  242. package/dist/extensions/skill-workshop/index.js +1 -1
  243. package/dist/extensions/synology-chat/api.js +1 -1
  244. package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
  245. package/dist/extensions/tlon/api.js +2 -2
  246. package/dist/extensions/tlon/channel-plugin-api.js +1 -1
  247. package/dist/extensions/tlon/runtime-api.js +1 -1
  248. package/dist/extensions/tlon/test-api.js +1 -1
  249. package/dist/extensions/twitch/api.js +1 -1
  250. package/dist/extensions/twitch/channel-plugin-api.js +1 -1
  251. package/dist/extensions/twitch/setup-plugin-api.js +1 -1
  252. package/dist/extensions/zalo/api.js +3 -3
  253. package/dist/extensions/zalo/channel-plugin-api.js +1 -1
  254. package/dist/extensions/zalo/runtime-api.js +2 -2
  255. package/dist/extensions/zalo/setup-api.js +2 -2
  256. package/dist/extensions/zalouser/api.js +3 -3
  257. package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
  258. package/dist/extensions/zalouser/runtime-api.js +6 -6
  259. package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
  260. package/dist/extensions/zalouser/test-api.js +1 -1
  261. package/dist/fallbacks-BKA5XrxA.js +31 -0
  262. package/dist/fallbacks-QvezaDAr.js +2 -0
  263. package/dist/fallbacks-shared-DS-qTOLR.js +111 -0
  264. package/dist/gateway-C0YHaLXO.js +115 -0
  265. package/dist/gateway-cli-DJBCD8J5.js +1325 -0
  266. package/dist/gateway-rpc-CmJXd4SU.js +14 -0
  267. package/dist/gateway-rpc.runtime-C9Fs2mSx.js +23 -0
  268. package/dist/gateway-rpc.runtime.js +1 -1
  269. package/dist/gateway-runtime-Bm2_MhFn.js +15 -0
  270. package/dist/gateway-status-DXKMKFtB.js +584 -0
  271. package/dist/genesis-tools-AolFZ-0I.js +8999 -0
  272. package/dist/genesis-tools.runtime-CBWXJqzw.js +2 -0
  273. package/dist/genesis-tools.runtime.js +1 -1
  274. package/dist/get-reply-BpxjHQBp.js +3879 -0
  275. package/dist/get-reply-from-config.runtime-DJKEqLSi.js +2 -0
  276. package/dist/get-reply-from-config.runtime.js +1 -1
  277. package/dist/graph-users-D2Q5UTGQ.js +1337 -0
  278. package/dist/health-BNKpuAPB.js +469 -0
  279. package/dist/health-BkxZfKx8.js +3 -0
  280. package/dist/heartbeat-runner-Bdu2q6k3.js +5 -0
  281. package/dist/heartbeat-runner-C0B-c-fv.js +1292 -0
  282. package/dist/heartbeat-runner.runtime-Cic23eNy.js +4 -0
  283. package/dist/heartbeat-runner.runtime.js +1 -1
  284. package/dist/hooks-cli-BfCr2In5.js +433 -0
  285. package/dist/image-fallbacks-Dgy-LmDo.js +2 -0
  286. package/dist/image-fallbacks-RlfTqOne.js +31 -0
  287. package/dist/inbound-reply-dispatch-D4KJHWLG.js +73 -0
  288. package/dist/index.js +2 -2
  289. package/dist/infra-runtime-BTJv3KK8.js +39 -0
  290. package/dist/init-q4INH9uv.js +59 -0
  291. package/dist/install-BT4BNeMX.js +190 -0
  292. package/dist/install.runtime-BnqPyIyn.js +2 -0
  293. package/dist/launchd-BM_37PLv.js +698 -0
  294. package/dist/library-DGd4UZKC.js +45 -0
  295. package/dist/lifecycle-B_RLw4uY.js +229 -0
  296. package/dist/lifecycle-Bw01evSl.js +571 -0
  297. package/dist/lifecycle-core-CTjCo-k0.js +422 -0
  298. package/dist/lifecycle.runtime-BxpD2Ol7.js +2 -0
  299. package/dist/lifecycle.runtime.js +1 -1
  300. package/dist/list-BXa4zUF-.js +2 -0
  301. package/dist/list-BugTSXmQ.js +131 -0
  302. package/dist/list-CgC_rsta.js +1201 -0
  303. package/dist/list-D2sk1YPs.js +2 -0
  304. package/dist/list.probe-C6zfgLdG.js +419 -0
  305. package/dist/llm-slug-generator-DsWJvqNx.js +79 -0
  306. package/dist/llm-slug-generator.js +1 -1
  307. package/dist/load-config-D6ZKPY7I.js +35 -0
  308. package/dist/local-dispatch.runtime-MWMxyZKj.js +8 -0
  309. package/dist/local-dispatch.runtime.js +1 -1
  310. package/dist/logs-cli-Dn-8jl3z.js +265 -0
  311. package/dist/logs-cli.runtime-DwsccWUJ.js +2 -0
  312. package/dist/logs-cli.runtime.js +1 -1
  313. package/dist/main-session-restart-recovery-6Uh4W8ZJ.js +206 -0
  314. package/dist/managed-image-attachments-DHawPS1-.js +2 -0
  315. package/dist/managed-image-attachments-DjtxwZ9o.js +635 -0
  316. package/dist/manager-D0tkR46e.js +2057 -0
  317. package/dist/manager-g_P1RDky.js +2 -0
  318. package/dist/markdown-to-line-7AxR7QFo.js +790 -0
  319. package/dist/mcp/plugin-tools-serve.js +1 -1
  320. package/dist/mcp-cli-Cw2XQMOA.js +725 -0
  321. package/dist/mcp-http-DFKqya8U.js +529 -0
  322. package/dist/memory-core-host-runtime-cli-DaAsOXiU.js +9 -0
  323. package/dist/message-BDCG7eWj.js +232 -0
  324. package/dist/message-action-runner-6C7kXcC9.js +2 -0
  325. package/dist/message-action-runner-C2P3efhU.js +1407 -0
  326. package/dist/message-actions-BWQWt5gT.js +143 -0
  327. package/dist/message.gateway.runtime-BXChuYAf.js +2 -0
  328. package/dist/message.gateway.runtime.js +1 -1
  329. package/dist/models-auth-status-B8lnM1PS.js +201 -0
  330. package/dist/models-cli-DbUA18AN.js +219 -0
  331. package/dist/monitor-BEJe2ceJ.js +1237 -0
  332. package/dist/monitor-BO9i6U5R.js +1459 -0
  333. package/dist/monitor-BZLrxL_x.js +1661 -0
  334. package/dist/monitor-CDDxHGlD.js +788 -0
  335. package/dist/monitor-D779kLc0.js +671 -0
  336. package/dist/monitor-V5ZNCrQL.js +2 -0
  337. package/dist/monitor-auth-D2rCHNgr.js +207 -0
  338. package/dist/monitor-processing-BLbsNFVv.js +1974 -0
  339. package/dist/monitor.runtime-RrusGXVO.js +2 -0
  340. package/dist/monitor.runtime.js +1 -1
  341. package/dist/monitor.webhook-B0DuBNWa.js +180 -0
  342. package/dist/msteams-hh9nwLlZ.js +35 -0
  343. package/dist/native-hook-relay-BygYZoeR.js +519 -0
  344. package/dist/nextcloud-talk-AadRCqXn.js +17 -0
  345. package/dist/node-cli-FF1zz0JU.js +2506 -0
  346. package/dist/node-service-f8mmgM5L.js +68 -0
  347. package/dist/nodes-cli-tQ5dpecZ.js +1046 -0
  348. package/dist/nodes-utils-BfpGcUca.js +84 -0
  349. package/dist/nodes.helpers-CMXxavTs.js +34 -0
  350. package/dist/notify-DaNP5Zyh.js +315 -0
  351. package/dist/onboard-B9hx80Dm.js +632 -0
  352. package/dist/onboard-helpers-BlPrFJHK.js +204 -0
  353. package/dist/onboard-helpers-kL8mgUkl.js +6 -0
  354. package/dist/onboard-remote-ByHuQd1m.js +193 -0
  355. package/dist/onboard-remote-CRPXcrWy.js +2 -0
  356. package/dist/onboard-skills-ChtyNRCd.js +2 -0
  357. package/dist/onboard-skills-DROlYXya.js +134 -0
  358. package/dist/openai-http-2An5HAJU.js +500 -0
  359. package/dist/openresponses-http-DpbJXZP4.js +1128 -0
  360. package/dist/operator-approvals-client-BoN_VmkB.js +68 -0
  361. package/dist/outbound.runtime-D_aebUn6.js +2 -0
  362. package/dist/outbound.runtime.js +1 -1
  363. package/dist/pair-command-approve-i-1VECJx.js +44 -0
  364. package/dist/persistent-bindings.lifecycle-eZyKQ1D8.js +85 -0
  365. package/dist/persistent-bindings.lifecycle-mxY73TJR.js +2 -0
  366. package/dist/pi-embedded-0fErjTQ7.js +2905 -0
  367. package/dist/pi-embedded-Bc1jC2x0.js +4 -0
  368. package/dist/pi-embedded.runtime-Bn_RZ5z8.js +4 -0
  369. package/dist/pi-embedded.runtime.js +1 -1
  370. package/dist/pi-tool-definition-adapter-thh7LO1t.js +217 -0
  371. package/dist/pi-tools-BtlLDovQ.js +1057 -0
  372. package/dist/pi-tools.before-tool-call-BJ_X8Dq3.js +2 -0
  373. package/dist/pi-tools.before-tool-call-DdPCGWCs.js +433 -0
  374. package/dist/plugin-CdHHk4Xn.js +12195 -0
  375. package/dist/plugin-enabled-DybhbjKQ.js +140 -0
  376. package/dist/plugin-registration-Bgwpsokw.js +23 -0
  377. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  378. package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
  379. package/dist/plugin-sdk/acp-runtime.js +2 -2
  380. package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
  381. package/dist/plugin-sdk/agent-harness.js +6 -6
  382. package/dist/plugin-sdk/agent-runtime.js +2 -2
  383. package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
  384. package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
  385. package/dist/plugin-sdk/approval-runtime.js +1 -1
  386. package/dist/plugin-sdk/browser-node-runtime.js +4 -4
  387. package/dist/plugin-sdk/browser-setup-tools.js +3 -3
  388. package/dist/plugin-sdk/browser-support.js +7 -7
  389. package/dist/plugin-sdk/channel-core.js +2 -2
  390. package/dist/plugin-sdk/channel-inbound.js +2 -2
  391. package/dist/plugin-sdk/command-auth.js +1 -1
  392. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  393. package/dist/plugin-sdk/compat.js +1 -1
  394. package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
  395. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  396. package/dist/plugin-sdk/core.js +2 -2
  397. package/dist/plugin-sdk/direct-dm.js +1 -1
  398. package/dist/plugin-sdk/gateway-runtime.js +3 -3
  399. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  400. package/dist/plugin-sdk/index.js +1 -1
  401. package/dist/plugin-sdk/infra-runtime.js +2 -2
  402. package/dist/plugin-sdk/irc.js +2 -2
  403. package/dist/plugin-sdk/matrix.js +1 -1
  404. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
  405. package/dist/plugin-sdk/memory-core.js +2 -2
  406. package/dist/plugin-sdk/msteams.js +2 -2
  407. package/dist/plugin-sdk/nextcloud-talk.js +2 -2
  408. package/dist/plugin-sdk/nostr.js +1 -1
  409. package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
  410. package/dist/plugin-sdk/reply-runtime.js +4 -4
  411. package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
  412. package/dist/plugin-sdk/runtime.js +2 -2
  413. package/dist/plugin-sdk/session-visibility.js +1 -1
  414. package/dist/plugin-sdk/testing.js +4 -4
  415. package/dist/plugin-sdk/tlon.js +1 -1
  416. package/dist/plugin-sdk/zalo.js +1 -1
  417. package/dist/plugin-sdk/zalouser.js +1 -1
  418. package/dist/plugin-service-ClhrJfT3.js +2890 -0
  419. package/dist/plugins/runtime/index.js +1 -1
  420. package/dist/policy-CoqHgREn.js +328 -0
  421. package/dist/postinstall-inventory.json +418 -418
  422. package/dist/prepare.runtime-CawO_32K.js +815 -0
  423. package/dist/prepare.runtime.js +1 -1
  424. package/dist/probe-BP3QS65i.js +74 -0
  425. package/dist/probe-BdCXAH_u.js +2 -0
  426. package/dist/probe-Cv5tXOMP.js +2205 -0
  427. package/dist/probe-D-D_1oc4.js +241 -0
  428. package/dist/probe-DO-gll0g.js +2 -0
  429. package/dist/probe-T6c0F73q.js +45 -0
  430. package/dist/probe-dxji7IxZ.js +1443 -0
  431. package/dist/program-GMPfHt5E.js +111 -0
  432. package/dist/prompt-select-styled-BvuJNEJG.js +20 -0
  433. package/dist/protocol-Batc2DmY.js +2234 -0
  434. package/dist/provider-dispatcher-CGYoOdKf.js +2 -0
  435. package/dist/provider-dispatcher-iTEDM88F.js +22 -0
  436. package/dist/qr-cli-6IxenO1C.js +349 -0
  437. package/dist/qr-cli-D63piSog.js +2 -0
  438. package/dist/reaction-runtime-api-DgwRXTz2.js +116 -0
  439. package/dist/reactions-Dnh7t4Zl.js +998 -0
  440. package/dist/register-service-commands-D7w01SKL.js +71 -0
  441. package/dist/register.agent-j1Eno4xr.js +248 -0
  442. package/dist/register.configure-ubwxTkGt.js +15 -0
  443. package/dist/register.maintenance-B7FuM_ZW.js +438 -0
  444. package/dist/register.message-QR3u9rBl.js +329 -0
  445. package/dist/register.onboard-Bdcf_lH0.js +81 -0
  446. package/dist/register.runtime-QDduc4yj.js +81 -0
  447. package/dist/register.runtime.js +1 -1
  448. package/dist/register.setup-DzVV6tdQ.js +150 -0
  449. package/dist/register.status-health-sessions-Brw3VcxG.js +1215 -0
  450. package/dist/register.subclis-B8qDbqPl.js +29 -0
  451. package/dist/register.subclis-DdoN3nZi.js +3 -0
  452. package/dist/register.subclis-core-CWHmnIoe.js +249 -0
  453. package/dist/reply-dispatch-runtime-BVLvCeJ0.js +13 -0
  454. package/dist/reply-runtime-BXkvfLv_.js +11 -0
  455. package/dist/reply.runtime-BTkpxI5R.js +2 -0
  456. package/dist/reply.runtime.js +1 -1
  457. package/dist/restart-health-6cjrRBpF.js +202 -0
  458. package/dist/restart-health-b6Qw43Tj.js +2 -0
  459. package/dist/root-help-DDa1oEtT.js +44 -0
  460. package/dist/routes-CoCMty69.js +2 -0
  461. package/dist/routes-D9uC_Zdy.js +3341 -0
  462. package/dist/rpc-DpLGM3FH.js +61 -0
  463. package/dist/rpc.runtime-B27EA5A0.js +21 -0
  464. package/dist/rpc.runtime.js +1 -1
  465. package/dist/run-delivery.runtime-OmILefLX.js +530 -0
  466. package/dist/run-delivery.runtime.js +1 -1
  467. package/dist/run-embedded.runtime-Dc43u_Z7.js +4 -0
  468. package/dist/run-embedded.runtime.js +1 -1
  469. package/dist/run-execution-cli.runtime-DL5w7Ac8.js +4 -0
  470. package/dist/run-execution-cli.runtime.js +1 -1
  471. package/dist/run-executor.runtime-Bzwt0zP-.js +277 -0
  472. package/dist/run-executor.runtime.js +1 -1
  473. package/dist/run-main-BLD1wTLU.js +516 -0
  474. package/dist/run-subagent-registry.runtime-CddCeg6W.js +2 -0
  475. package/dist/run-subagent-registry.runtime.js +1 -1
  476. package/dist/run-wait-D4Gxuyru.js +135 -0
  477. package/dist/runtime-8BuIPrSY.js +973 -0
  478. package/dist/runtime-Co8r21pw.js +9 -0
  479. package/dist/runtime-api-BG0XWkir.js +4 -0
  480. package/dist/runtime-api-BjBzlgns.js +9 -0
  481. package/dist/runtime-api-DlYbbA-n.js +14 -0
  482. package/dist/runtime-api-faT33SE2.js +9 -0
  483. package/dist/runtime-embedded-pi.runtime-QdJ7K4t0.js +2 -0
  484. package/dist/runtime-embedded-pi.runtime.js +1 -1
  485. package/dist/runtime-internal-C0xc_Zhf.js +2 -0
  486. package/dist/runtime-options-DLv7ygkO.js +275 -0
  487. package/dist/runtime-schema-CQK5R5Pl.js +27780 -0
  488. package/dist/scan-Yz6DoQn5.js +523 -0
  489. package/dist/scan-k38hL_6o.js +2 -0
  490. package/dist/secrets-cli-Bjvr0bOw.js +2101 -0
  491. package/dist/security-cli-C2gkMFcB.js +486 -0
  492. package/dist/selection-DC8EXnRg.js +7736 -0
  493. package/dist/selection-DmSFI5k4.js +2 -0
  494. package/dist/send-CT6EfHrc.js +102 -0
  495. package/dist/send-_ANvjE_C.js +156 -0
  496. package/dist/send.runtime-COIjG4BV.js +2 -0
  497. package/dist/send.runtime.js +1 -1
  498. package/dist/server-COkv9Si4.js +13 -0
  499. package/dist/server-DHLQZJL8.js +77 -0
  500. package/dist/server-context-6jnr-aAw.js +2 -0
  501. package/dist/server-context-DK1QsdLh.js +847 -0
  502. package/dist/server-node-events-q8H0odkq.js +481 -0
  503. package/dist/server-plugin-bootstrap-Bw4a88yA.js +2 -0
  504. package/dist/server-plugin-bootstrap-By_w9ngt.js +11333 -0
  505. package/dist/server-restart-sentinel-CGLYF3mk.js +697 -0
  506. package/dist/server.impl-8j4SImks.js +12735 -0
  507. package/dist/service-CNjb_qXC.js +2 -0
  508. package/dist/service-CyR3mZIU.js +120 -0
  509. package/dist/service-audit-DIL0OiMa.js +260 -0
  510. package/dist/service-audit-pwloDggS.js +2 -0
  511. package/dist/session-kill-http-Dek5w0Ee.js +110 -0
  512. package/dist/session-reset-service-B_9Ps0kr.js +471 -0
  513. package/dist/session-route-Cr6vOd9_.js +93 -0
  514. package/dist/session-status.runtime-C_x1MHH5.js +2 -0
  515. package/dist/session-status.runtime.js +1 -1
  516. package/dist/session-subagent-reactivation.runtime-BKWuNild.js +2 -0
  517. package/dist/session-subagent-reactivation.runtime.js +1 -1
  518. package/dist/session-tab-registry-C08V5jx6.js +491 -0
  519. package/dist/session-visibility-D4j8hN_B.js +147 -0
  520. package/dist/sessions-helpers-DmUVRk16.js +304 -0
  521. package/dist/sessions-history-http-DN3KzEnX.js +383 -0
  522. package/dist/sessions-patch-BPtlF0Lu.js +309 -0
  523. package/dist/sessions-resolve-D6KPfG_4.js +174 -0
  524. package/dist/sessions.runtime-DGL1-G20.js +2 -0
  525. package/dist/sessions.runtime.js +1 -1
  526. package/dist/setup-CkYiQoP0.js +495 -0
  527. package/dist/setup-api-CUGYqGNT.js +29 -0
  528. package/dist/setup-core-BmplfubJ.js +171 -0
  529. package/dist/setup-core-C5ddWpfy.js +176 -0
  530. package/dist/setup-surface-2JmEfowI.js +219 -0
  531. package/dist/setup-surface-BzHQx_GD.js +403 -0
  532. package/dist/setup-surface-DOH6kc6w.js +286 -0
  533. package/dist/setup.finalize-Ci2HBkDq.js +539 -0
  534. package/dist/setup.gateway-config-CyG_Fzaa.js +250 -0
  535. package/dist/shared-BItUH43s.js +121 -0
  536. package/dist/shared-D7diJkX6.js +198 -0
  537. package/dist/shared-DJU_HCJ1.js +76 -0
  538. package/dist/slash-state-C4YD-tLz.js +1911 -0
  539. package/dist/src-8HdytGc7.js +3974 -0
  540. package/dist/startup-context-CfcCyUU0.js +312 -0
  541. package/dist/status-B94yciC9.js +397 -0
  542. package/dist/status-BUkUYtFm.js +190 -0
  543. package/dist/status-BsHC-0MV.js +2 -0
  544. package/dist/status-D4jNATg0.js +209 -0
  545. package/dist/status-U8ut-X2Q.js +2 -0
  546. package/dist/status-all-CIzsXQnV.js +498 -0
  547. package/dist/status-json-alPkfWTd.js +14 -0
  548. package/dist/status-json-command-CAkzWzw7.js +84 -0
  549. package/dist/status-jxNdVQVZ.js +3 -0
  550. package/dist/status-runtime-shared-BSsA48i9.js +257 -0
  551. package/dist/status-subagents.runtime-hIKg6PXV.js +18 -0
  552. package/dist/status-subagents.runtime.js +1 -1
  553. package/dist/status-text-BmLJrLth.js +237 -0
  554. package/dist/status.gateway-connection.runtime-Dr7HJ1wZ.js +2 -0
  555. package/dist/status.gateway-connection.runtime.js +1 -1
  556. package/dist/status.gather-DFY0T97g.js +2 -0
  557. package/dist/status.gather-e6sfNh8I.js +292 -0
  558. package/dist/status.runtime-DBvapXQS.js +2 -0
  559. package/dist/status.runtime.js +1 -1
  560. package/dist/status.scan-DSpkE-Q-.js +65 -0
  561. package/dist/status.scan-overview-Dr72bkbi.js +379 -0
  562. package/dist/status.scan.fast-json-C7k_m46S.js +2 -0
  563. package/dist/status.scan.fast-json-KHh7R3wX.js +132 -0
  564. package/dist/status.summary-C4r9lkCH.js +214 -0
  565. package/dist/status.summary-D0EJwkmX.js +2 -0
  566. package/dist/subagent-announce-Bu5-8O3P.js +351 -0
  567. package/dist/subagent-announce-delivery-4hk9P48s.js +726 -0
  568. package/dist/subagent-announce-output-Csyi1-Kz.js +364 -0
  569. package/dist/subagent-control-DAeNsV_G.js +506 -0
  570. package/dist/subagent-followup.runtime-Bch92LIq.js +68 -0
  571. package/dist/subagent-followup.runtime.js +1 -1
  572. package/dist/subagent-orphan-recovery-mNzyr1b-.js +305 -0
  573. package/dist/subagent-registry-BMjQxBxi.js +3 -0
  574. package/dist/subagent-registry-D4DFKQCL.js +1753 -0
  575. package/dist/subagent-registry.runtime.js +1 -1
  576. package/dist/subagent-spawn-C13uUm47.js +1005 -0
  577. package/dist/system-cli-BU6GhJxG.js +59 -0
  578. package/dist/targets-eYkepVzz.js +67 -0
  579. package/dist/task-executor-DzJLcm4D.js +360 -0
  580. package/dist/task-owner-access-DW9EbhjP.js +74 -0
  581. package/dist/task-registry-DBJkAtFF.js +2366 -0
  582. package/dist/task-registry-delivery-runtime-BdkPeGC1.js +2 -0
  583. package/dist/task-registry-delivery-runtime-Ov88LGnv.js +3 -0
  584. package/dist/task-registry.maintenance-BU6Z4V_9.js +416 -0
  585. package/dist/task-registry.maintenance-sEo6eYdx.js +2 -0
  586. package/dist/telegram/token.js +1 -1
  587. package/dist/testing-B2jHeQft.js +575 -0
  588. package/dist/text-report-HYrgZP8-.js +587 -0
  589. package/dist/tool-resolution-BZxaDOKg.js +90 -0
  590. package/dist/tools-effective-inventory-BCvCprpD.js +152 -0
  591. package/dist/tools-invoke-http-Dt1rsx4a.js +206 -0
  592. package/dist/trash-F4tvjrKS.js +24 -0
  593. package/dist/tui-cli-DlQ1oejy.js +4575 -0
  594. package/dist/update-cli-DHMdwQWA.js +1759 -0
  595. package/dist/upgrade-UR-EI5pO.js +1226 -0
  596. package/dist/video-generation-task-status-qtHrIZLt.js +163 -0
  597. package/dist/wait-for-idle-before-flush-CYB_61O0.js +5986 -0
  598. package/dist/wizard-models-BKqMCaCm.js +161 -0
  599. package/package.json +1 -1
  600. package/dist/abort-BHSttDhY.js +0 -201
  601. package/dist/abort.runtime-VJ9lFsZS.js +0 -2
  602. package/dist/accounts-BNvagEOQ.js +0 -104
  603. package/dist/accounts-CPIuzenz.js +0 -107
  604. package/dist/accounts-r08DQWhZ.js +0 -2
  605. package/dist/acp-cli-i0L-eRs9.js +0 -2193
  606. package/dist/acp-spawn-CHzVLe9q.js +0 -1093
  607. package/dist/acp-spawn-CqvxDuBq.js +0 -2
  608. package/dist/acp-stateful-target-driver-CWRLc_NP.js +0 -89
  609. package/dist/action-agents-SNCscX_-.js +0 -67
  610. package/dist/action-focus-B2s0PF2E.js +0 -132
  611. package/dist/action-help-CXKbyaZ7.js +0 -7
  612. package/dist/action-info-B3IDKxWu.js +0 -101
  613. package/dist/action-kill-idGvCNhT.js +0 -33
  614. package/dist/action-list-Di7gO3qL.js +0 -21
  615. package/dist/action-log-BCsz-gFi.js +0 -30
  616. package/dist/action-send-DLsdZnVc.js +0 -39
  617. package/dist/action-spawn-DhKEOdL0.js +0 -47
  618. package/dist/action-unfocus-Dh7ti5UP.js +0 -29
  619. package/dist/actions.runtime-BPf03SN3.js +0 -18
  620. package/dist/actions.runtime-CJg_lweh.js +0 -5
  621. package/dist/agent-C3PLvvws.js +0 -2
  622. package/dist/agent-command-UroeNrV4.js +0 -874
  623. package/dist/agent-harness-runtime-MXvI9FlJ.js +0 -144
  624. package/dist/agent-runner-utils-CaVgLZrf.js +0 -239
  625. package/dist/agent-runner.runtime-Csqm3m09.js +0 -3455
  626. package/dist/agent-runtime-B9nUYDUz.js +0 -18
  627. package/dist/agents-BP4p-1q2.js +0 -5
  628. package/dist/agents-CDiXfrfc.js +0 -953
  629. package/dist/aliases-BBCtCq2A.js +0 -96
  630. package/dist/aliases-DrFtFq1p.js +0 -2
  631. package/dist/api-BH0oEwR1.js +0 -5
  632. package/dist/api-D-4gHdrl.js +0 -139
  633. package/dist/api-DE6RYTxv.js +0 -3
  634. package/dist/approval-gateway-resolver-URpDQMld.js +0 -29
  635. package/dist/approval-gateway-runtime-B087BMms.js +0 -2
  636. package/dist/approval-handler-runtime-BEl3ua8-.js +0 -439
  637. package/dist/approval-native-runtime-ghjYGufu.js +0 -729
  638. package/dist/attempt-execution.runtime-PCTFYqLh.js +0 -509
  639. package/dist/attempt.prompt-helpers-CkWEozQ2.js +0 -221
  640. package/dist/attempt.tool-run-context-DbqVgXFk.js +0 -933
  641. package/dist/audit-Lb1yNEwg.js +0 -939
  642. package/dist/audit.runtime-DOnixKE_.js +0 -7
  643. package/dist/auth-BrlJ7NM9.js +0 -2
  644. package/dist/auth-CJoP7Yst.js +0 -383
  645. package/dist/auth-order-D0KFgBib.js +0 -96
  646. package/dist/auth-order-_xlUHzCg.js +0 -2
  647. package/dist/bash-tools-BEVEHCl9.js +0 -2824
  648. package/dist/bash-tools-DJ0D8Wr5.js +0 -3
  649. package/dist/binding-routing-IfKqPcfO.js +0 -85
  650. package/dist/binding-targets-2huR0hTX.js +0 -121
  651. package/dist/bridge-server-D8Y8Fzdz.js +0 -113
  652. package/dist/browser-control-auth-Q6UpVLEj.js +0 -2
  653. package/dist/browser-node-runtime-C9KvsOyx.js +0 -12
  654. package/dist/browser-profiles-DFcwiMEf.js +0 -2
  655. package/dist/browser-runtime-sbZ3hKg6.js +0 -387
  656. package/dist/browser-setup-tools-CP4BkZ9z.js +0 -13
  657. package/dist/build-DzHX2LrH.js +0 -550
  658. package/dist/call-ORivR4Db.js +0 -331
  659. package/dist/call-qzfm6lro.js +0 -3
  660. package/dist/call.runtime-BkzJe07B.js +0 -2
  661. package/dist/capability-cli-BDCvm93o.js +0 -1401
  662. package/dist/catchup-CjZa2PrP.js +0 -300
  663. package/dist/channel-B3UAL9Pk.js +0 -840
  664. package/dist/channel-B5L9LJBF.js +0 -453
  665. package/dist/channel-BGXl6A-E.js +0 -297
  666. package/dist/channel-BNUblayu.js +0 -1320
  667. package/dist/channel-Bej-TN7f.js +0 -491
  668. package/dist/channel-BzOKSC4e.js +0 -350
  669. package/dist/channel-CY2xEOzR.js +0 -1802
  670. package/dist/channel-D2kKLWUA.js +0 -226
  671. package/dist/channel-DcjCe46M.js +0 -1100
  672. package/dist/channel-GqA96nmt.js +0 -595
  673. package/dist/channel-YI2aIJFQ.js +0 -1174
  674. package/dist/channel-core-DqPUhmTt.js +0 -5
  675. package/dist/channel-inbound-CzgMd2Xi.js +0 -31
  676. package/dist/channel-plugin-runtime-DI5uUbxx.js +0 -771
  677. package/dist/channel-runtime-BJqKQitD.js +0 -425
  678. package/dist/channel.runtime-BBn9mgbB.js +0 -89
  679. package/dist/channel.runtime-Bhj1b9gQ.js +0 -34702
  680. package/dist/channel.runtime-BzOVx90Z.js +0 -576
  681. package/dist/channel.runtime-CQkLKWlq.js +0 -109
  682. package/dist/channel.runtime-D8qT4A1x.js +0 -4
  683. package/dist/channel.runtime-DjK9Re1w.js +0 -2364
  684. package/dist/channel.runtime-tWwM8hFw.js +0 -430
  685. package/dist/channel.setup-gaiRZ-r8.js +0 -10
  686. package/dist/channels-BXIl3hBo.js +0 -733
  687. package/dist/channels-cli-CrmBqaul.js +0 -268
  688. package/dist/chat-C42usv-F.js +0 -2758
  689. package/dist/clawbot-cli-BGYO_ymZ.js +0 -9
  690. package/dist/cli-BbD25CFK.js +0 -2
  691. package/dist/cli-CYD4Wfcq.js +0 -219
  692. package/dist/cli-D-6ycHAw.js +0 -72
  693. package/dist/cli-DX4CK-bw.js +0 -2
  694. package/dist/cli-runner-C5_PBTxm.js +0 -286
  695. package/dist/cli-runner.runtime-DE7RpQ27.js +0 -3
  696. package/dist/cli-runner.runtime-ueVMICzY.js +0 -4
  697. package/dist/cli.runtime-DSO8Vfrh.js +0 -1261
  698. package/dist/client-BKro32pr.js +0 -138
  699. package/dist/client-Vx7pseEY.js +0 -713
  700. package/dist/command-auth-CvFUTCCJ.js +0 -76
  701. package/dist/command-config-resolution-BnW1XGnW.js +0 -23
  702. package/dist/command-config-resolution-BrlfYyiN.js +0 -2
  703. package/dist/command-config-resolution.runtime-DYMr8J0t.js +0 -2
  704. package/dist/command-registry-Bi9thw1b.js +0 -9
  705. package/dist/command-registry-D__zH4Fg.js +0 -4
  706. package/dist/command-registry-core-DQoNFQZT.js +0 -101
  707. package/dist/command-secret-gateway-B27Zpgo9.js +0 -528
  708. package/dist/command-status.runtime-fERQMzeI.js +0 -87
  709. package/dist/commands-acp-BmORmf3-.js +0 -77
  710. package/dist/commands-compact.runtime-BUaXIw-I.js +0 -10
  711. package/dist/commands-handlers.runtime-BxbkeuTc.js +0 -4597
  712. package/dist/commands-status-4OW5sqmg.js +0 -16
  713. package/dist/commands-status.runtime-Cl7nJp_7.js +0 -3
  714. package/dist/commands-subagents-control.runtime-BR4qBGkk.js +0 -2
  715. package/dist/commands-subagents-control.runtime-C8ufgKPI.js +0 -3
  716. package/dist/commands-system-prompt-BsimvjJt.js +0 -158
  717. package/dist/commands-system-prompt-CKrY0h7P.js +0 -2
  718. package/dist/commands.runtime-BHsDdaEU.js +0 -166
  719. package/dist/compact-BHYLQst3.js +0 -1118
  720. package/dist/compact.runtime-7-tZRdgw.js +0 -12
  721. package/dist/completion-cli-1sAiSIYc.js +0 -328
  722. package/dist/config-BZ3FuFjH.js +0 -251
  723. package/dist/config-cli-B_dNq5hD.js +0 -1078
  724. package/dist/configure-BOvmX2NJ.js +0 -2
  725. package/dist/configure-DR9NYN9e.js +0 -1245
  726. package/dist/connect-options-DlmPTyhG.js +0 -699
  727. package/dist/control-auth-C_zNiV10.js +0 -125
  728. package/dist/control-service-B1TL51jf.js +0 -156
  729. package/dist/conversation-id-B3lLiTfF.js +0 -235
  730. package/dist/conversation-id-DORmTZm_.js +0 -38
  731. package/dist/conversation-runtime-DDxZZZXE.js +0 -31
  732. package/dist/core-DbPzffGG.js +0 -275
  733. package/dist/cron-cli-AoH4jhFt.js +0 -713
  734. package/dist/daemon-cli-BOJdM3wT.js +0 -12
  735. package/dist/daemon-install-D8HPES4u.js +0 -64
  736. package/dist/delegate-Dmdda3kT.js +0 -64
  737. package/dist/detached-task-runtime-BB5az34R.js +0 -73
  738. package/dist/devices-cli-Cy9DF-DP.js +0 -496
  739. package/dist/diagnostics-CTE0TWR1.js +0 -154
  740. package/dist/direct-dm-9jzadx9u.js +0 -64
  741. package/dist/dispatch-DU7cqfv6.js +0 -1131
  742. package/dist/dispatch-acp-Cu_nUtKg.js +0 -981
  743. package/dist/dispatch-acp-manager.runtime-8MOQ5BRn.js +0 -3
  744. package/dist/dispatch-acp.runtime-DatcHNJq.js +0 -19
  745. package/dist/doctor-device-pairing-Qm-r7mwu.js +0 -307
  746. package/dist/doctor-gateway-daemon-flow-BN2uGhFJ.js +0 -250
  747. package/dist/doctor-gateway-health-CD7Vzth9.js +0 -60
  748. package/dist/doctor-gateway-services-CIypZgv_.js +0 -316
  749. package/dist/doctor-health-ByjG3620.js +0 -59
  750. package/dist/doctor-health-contributions-CxNByg_i.js +0 -486
  751. package/dist/doctor-prompter-BYIoKiZ8.js +0 -56
  752. package/dist/doctor-workspace-status-DL2fRPoT.js +0 -75
  753. package/dist/dreaming-CCctNgkQ.js +0 -1574
  754. package/dist/dreaming-narrative-BPtXKc2-.js +0 -595
  755. package/dist/embedded-gateway-stub.runtime-Hi36BeCq.js +0 -9
  756. package/dist/exec-approvals-cli-DyslUWtQ.js +0 -498
  757. package/dist/fallbacks-B3xZC-ms.js +0 -2
  758. package/dist/fallbacks-CWDz-tSa.js +0 -31
  759. package/dist/fallbacks-shared-BlZBjxHL.js +0 -111
  760. package/dist/gateway-NYBkUx5r.js +0 -115
  761. package/dist/gateway-cli-E5gYA0U1.js +0 -1325
  762. package/dist/gateway-rpc-BrG5Lkfm.js +0 -14
  763. package/dist/gateway-rpc.runtime-BrTGchr9.js +0 -23
  764. package/dist/gateway-runtime-DctMRv_p.js +0 -15
  765. package/dist/gateway-status-B6ol1agz.js +0 -584
  766. package/dist/genesis-tools-D_ah3Zek.js +0 -8999
  767. package/dist/genesis-tools.runtime-Cy7aTWEN.js +0 -2
  768. package/dist/get-reply-BvVkxYum.js +0 -3879
  769. package/dist/get-reply-from-config.runtime-DR3yiK1R.js +0 -2
  770. package/dist/graph-users-yBNugoFz.js +0 -1337
  771. package/dist/health-D_wk2s7j.js +0 -3
  772. package/dist/health-MRnjOx-_.js +0 -469
  773. package/dist/heartbeat-runner-NuhhYnxs.js +0 -5
  774. package/dist/heartbeat-runner-Y4NeUV3L.js +0 -1292
  775. package/dist/heartbeat-runner.runtime-eGfKtcpP.js +0 -4
  776. package/dist/hooks-cli-CtfN2vc-.js +0 -433
  777. package/dist/image-fallbacks-CgeDMYZo.js +0 -2
  778. package/dist/image-fallbacks-CzQ85Eo8.js +0 -31
  779. package/dist/inbound-reply-dispatch-jVlLaSqn.js +0 -73
  780. package/dist/infra-runtime-D2Pqjk-r.js +0 -39
  781. package/dist/init-D_MTYqrw.js +0 -59
  782. package/dist/install-X7wgrwQ1.js +0 -190
  783. package/dist/install.runtime-C4wO4Nr9.js +0 -2
  784. package/dist/launchd-lFgfiDrN.js +0 -688
  785. package/dist/library-DIykYIWD.js +0 -45
  786. package/dist/lifecycle-BNuFzffC.js +0 -571
  787. package/dist/lifecycle-IWN9qlwo.js +0 -229
  788. package/dist/lifecycle-core-CFv5qkS8.js +0 -422
  789. package/dist/lifecycle.runtime-9oo2JCI2.js +0 -2
  790. package/dist/list-BZ3mMSpA.js +0 -2
  791. package/dist/list-CzQs_k0U.js +0 -131
  792. package/dist/list-CzTJTFOH.js +0 -1201
  793. package/dist/list-qDXsgKhB.js +0 -2
  794. package/dist/list.probe-EOZR6ueo.js +0 -419
  795. package/dist/llm-slug-generator-DzWIx0nh.js +0 -79
  796. package/dist/load-config-C_8uUnXU.js +0 -35
  797. package/dist/local-dispatch.runtime-DLd10Xb1.js +0 -8
  798. package/dist/logs-cli-mnOTmC9R.js +0 -265
  799. package/dist/logs-cli.runtime-BvP3aise.js +0 -2
  800. package/dist/main-session-restart-recovery-D7Vxmu7e.js +0 -206
  801. package/dist/managed-image-attachments-BB5u0Zq8.js +0 -2
  802. package/dist/managed-image-attachments-BeRGNdL9.js +0 -635
  803. package/dist/manager-BhNWV4EC.js +0 -2
  804. package/dist/manager-CbZ9ncZs.js +0 -2057
  805. package/dist/markdown-to-line-DyB8w7ef.js +0 -790
  806. package/dist/mcp-cli-CWzLBrDF.js +0 -725
  807. package/dist/mcp-http-1jD7LE0a.js +0 -529
  808. package/dist/memory-core-host-runtime-cli-P80xoEfr.js +0 -9
  809. package/dist/message-BAhd_1ud.js +0 -232
  810. package/dist/message-action-runner-CH2jjT21.js +0 -1407
  811. package/dist/message-action-runner-DW7z_bMx.js +0 -2
  812. package/dist/message-actions-BjBGSsJB.js +0 -143
  813. package/dist/message.gateway.runtime-sUc85g7X.js +0 -2
  814. package/dist/models-auth-status-D6lrM56M.js +0 -201
  815. package/dist/models-cli-CmnbAk2M.js +0 -219
  816. package/dist/monitor-AyGe8vyk.js +0 -1237
  817. package/dist/monitor-DQuy2kx-.js +0 -671
  818. package/dist/monitor-DmtJiX5o.js +0 -788
  819. package/dist/monitor-GB8lcnal.js +0 -1459
  820. package/dist/monitor-IuVjATac.js +0 -1661
  821. package/dist/monitor-auth-rF7mr3Cm.js +0 -207
  822. package/dist/monitor-bnOvJyLN.js +0 -2
  823. package/dist/monitor-processing-B1ewr2qF.js +0 -1974
  824. package/dist/monitor.runtime-BrUD5_VN.js +0 -2
  825. package/dist/monitor.webhook-BvJG6Xbh.js +0 -180
  826. package/dist/msteams-DUDRy3xt.js +0 -35
  827. package/dist/native-hook-relay-CTpTLgCA.js +0 -519
  828. package/dist/nextcloud-talk-BH2uWRZ2.js +0 -17
  829. package/dist/node-cli-AWE1ZFfV.js +0 -2506
  830. package/dist/node-service-DCI-s3Mm.js +0 -68
  831. package/dist/nodes-cli-B7IWCrYq.js +0 -1046
  832. package/dist/nodes-utils-Dg2hrC3z.js +0 -84
  833. package/dist/nodes.helpers-CkJO5i0d.js +0 -34
  834. package/dist/notify-bsxfkOWp.js +0 -315
  835. package/dist/onboard-BQaZtwIU.js +0 -632
  836. package/dist/onboard-helpers-Cc2AnoIU.js +0 -6
  837. package/dist/onboard-helpers-DIxfEXNM.js +0 -204
  838. package/dist/onboard-remote-CYhQbOXH.js +0 -2
  839. package/dist/onboard-remote-DrH3yVxE.js +0 -193
  840. package/dist/onboard-skills-DCI3hVXa.js +0 -134
  841. package/dist/onboard-skills-i4KuFzS4.js +0 -2
  842. package/dist/openai-http-D_7Nk3iN.js +0 -500
  843. package/dist/openresponses-http-BITxvD4V.js +0 -1128
  844. package/dist/operator-approvals-client-C0t_-2xC.js +0 -68
  845. package/dist/outbound.runtime-C8_lBQcx.js +0 -2
  846. package/dist/pair-command-approve-D3s1W5go.js +0 -44
  847. package/dist/persistent-bindings.lifecycle-CCR6khHJ.js +0 -85
  848. package/dist/persistent-bindings.lifecycle-Dgoo5bpE.js +0 -2
  849. package/dist/pi-embedded-C2l80M7j.js +0 -4
  850. package/dist/pi-embedded-DMHGJgoQ.js +0 -2905
  851. package/dist/pi-embedded.runtime-fA0EsIue.js +0 -4
  852. package/dist/pi-tool-definition-adapter-B4hSYdYX.js +0 -217
  853. package/dist/pi-tools-YCHBvJG0.js +0 -1057
  854. package/dist/pi-tools.before-tool-call-BsyruRs4.js +0 -433
  855. package/dist/pi-tools.before-tool-call-D1maRTbl.js +0 -2
  856. package/dist/plugin-DmBZwzWQ.js +0 -12195
  857. package/dist/plugin-enabled-rr_Y1Kwh.js +0 -140
  858. package/dist/plugin-registration-J1JWqMZg.js +0 -23
  859. package/dist/plugin-service-CPY8FSW2.js +0 -2890
  860. package/dist/policy-DDUw681i.js +0 -328
  861. package/dist/prepare.runtime-BfnpyhHB.js +0 -815
  862. package/dist/probe-CCdD6_vN.js +0 -1443
  863. package/dist/probe-CakOsrSu.js +0 -241
  864. package/dist/probe-Ctrcd_Q7.js +0 -2205
  865. package/dist/probe-D9IFIte1.js +0 -2
  866. package/dist/probe-DXMI0QlZ.js +0 -74
  867. package/dist/probe-KtX2HjXM.js +0 -45
  868. package/dist/probe-OcOYm1bj.js +0 -2
  869. package/dist/program-DxZA1yAX.js +0 -111
  870. package/dist/prompt-select-styled-CATG4Xp5.js +0 -20
  871. package/dist/protocol-C40iRm9c.js +0 -2234
  872. package/dist/provider-dispatcher-BZp3Stzr.js +0 -2
  873. package/dist/provider-dispatcher-JJxN7BDL.js +0 -22
  874. package/dist/qr-cli-IMKzycXh.js +0 -349
  875. package/dist/qr-cli-W8X3Ha5T.js +0 -2
  876. package/dist/reaction-runtime-api-D7i4oMn9.js +0 -116
  877. package/dist/reactions-D9eRHeXM.js +0 -998
  878. package/dist/register-service-commands-D37K4_BJ.js +0 -71
  879. package/dist/register.agent-p1q6ZWSs.js +0 -248
  880. package/dist/register.configure-tgXCoIHv.js +0 -15
  881. package/dist/register.maintenance-BtBgu8zC.js +0 -438
  882. package/dist/register.message-B5msOUKt.js +0 -329
  883. package/dist/register.onboard-BO11PDUs.js +0 -81
  884. package/dist/register.runtime-D8XvwfoZ.js +0 -81
  885. package/dist/register.setup-Ba19XSJi.js +0 -150
  886. package/dist/register.status-health-sessions-Bne0mmgw.js +0 -1215
  887. package/dist/register.subclis--mdYCZZM.js +0 -3
  888. package/dist/register.subclis-_kuyreQm.js +0 -29
  889. package/dist/register.subclis-core-UkVTqwB1.js +0 -249
  890. package/dist/reply-dispatch-runtime-DcxOLr7n.js +0 -13
  891. package/dist/reply-runtime-B4VQJnqi.js +0 -11
  892. package/dist/reply.runtime-B990ty9C.js +0 -2
  893. package/dist/restart-health-BWUPc4R-.js +0 -202
  894. package/dist/restart-health-CWvsjHVN.js +0 -2
  895. package/dist/root-help-D9aeVXNr.js +0 -44
  896. package/dist/routes-BSmEgP46.js +0 -2
  897. package/dist/routes-Z67chkN5.js +0 -3341
  898. package/dist/rpc-CBQZvJME.js +0 -61
  899. package/dist/rpc.runtime-ClhNVRer.js +0 -21
  900. package/dist/run-delivery.runtime-Bj566BTH.js +0 -530
  901. package/dist/run-embedded.runtime-DuB-mQh2.js +0 -4
  902. package/dist/run-execution-cli.runtime-Oy4FGfj5.js +0 -4
  903. package/dist/run-executor.runtime-B7-lfFh3.js +0 -277
  904. package/dist/run-main-1Fvwazhp.js +0 -516
  905. package/dist/run-subagent-registry.runtime-Bx9Wga3d.js +0 -2
  906. package/dist/run-wait-C-VgbefQ.js +0 -135
  907. package/dist/runtime-BV7JmOaE.js +0 -9
  908. package/dist/runtime-D7npxl4G.js +0 -973
  909. package/dist/runtime-api-BkVIoPU9.js +0 -4
  910. package/dist/runtime-api-CdhgyHMB.js +0 -9
  911. package/dist/runtime-api-CmlBBCCY.js +0 -9
  912. package/dist/runtime-api-DnhXPE_z.js +0 -14
  913. package/dist/runtime-embedded-pi.runtime-DpKqDUrl.js +0 -2
  914. package/dist/runtime-internal-Bu1n9i4P.js +0 -2
  915. package/dist/runtime-options-CN4g8VJE.js +0 -275
  916. package/dist/runtime-schema-Jjsquqvq.js +0 -27780
  917. package/dist/scan-C8jthyct.js +0 -523
  918. package/dist/scan-DEd4q4aN.js +0 -2
  919. package/dist/secrets-cli-iBL8NBAq.js +0 -2101
  920. package/dist/security-cli-CzYBRa4n.js +0 -486
  921. package/dist/selection-BOalx5uy.js +0 -2
  922. package/dist/selection-BZFVKdFz.js +0 -7736
  923. package/dist/send-C4mKkkWW.js +0 -156
  924. package/dist/send-C_36w3lb.js +0 -102
  925. package/dist/send.runtime-vJT5TzDj.js +0 -2
  926. package/dist/server-BTmWWR_9.js +0 -13
  927. package/dist/server-CBQVrNY0.js +0 -77
  928. package/dist/server-context-Dq2VA7I4.js +0 -2
  929. package/dist/server-context-O_WUP8OV.js +0 -847
  930. package/dist/server-node-events-B8PLg0eQ.js +0 -481
  931. package/dist/server-plugin-bootstrap-ChIvqLMw.js +0 -2
  932. package/dist/server-plugin-bootstrap-Rbxd2g6a.js +0 -11333
  933. package/dist/server-restart-sentinel-BCd6AqrQ.js +0 -697
  934. package/dist/server.impl-CEOWGKN5.js +0 -12735
  935. package/dist/service-ChLFBF7Q.js +0 -120
  936. package/dist/service-XI052xiT.js +0 -2
  937. package/dist/service-audit-BFxGImYM.js +0 -254
  938. package/dist/service-audit-cqHyD5gB.js +0 -2
  939. package/dist/session-kill-http-ChCr5CQ3.js +0 -110
  940. package/dist/session-reset-service-DsYIDYdh.js +0 -471
  941. package/dist/session-route-rem428sJ.js +0 -93
  942. package/dist/session-status.runtime-CFmGwoCm.js +0 -2
  943. package/dist/session-subagent-reactivation.runtime-DLkpnURC.js +0 -2
  944. package/dist/session-tab-registry-DWyzIez5.js +0 -491
  945. package/dist/session-visibility-CJocpWP0.js +0 -147
  946. package/dist/sessions-helpers-CMf9gVTZ.js +0 -304
  947. package/dist/sessions-history-http-C5iZkW8x.js +0 -383
  948. package/dist/sessions-patch-2sBcHc9a.js +0 -309
  949. package/dist/sessions-resolve-D1hmolC-.js +0 -174
  950. package/dist/sessions.runtime-DMPmzLE0.js +0 -2
  951. package/dist/setup-D1ekkhVk.js +0 -495
  952. package/dist/setup-api-DilgjV01.js +0 -29
  953. package/dist/setup-core-CFAiauCt.js +0 -171
  954. package/dist/setup-core-RgJfQc-C.js +0 -176
  955. package/dist/setup-surface-C0l9bHY3.js +0 -286
  956. package/dist/setup-surface-CfcFHZln.js +0 -403
  957. package/dist/setup-surface-CyDRXq_1.js +0 -219
  958. package/dist/setup.finalize-JPqhcPh5.js +0 -539
  959. package/dist/setup.gateway-config-Df6Jm4vX.js +0 -250
  960. package/dist/shared-3gP_6DZV.js +0 -76
  961. package/dist/shared-C9fN-WCy.js +0 -198
  962. package/dist/shared-Cz9c46Aj.js +0 -121
  963. package/dist/slash-state-C7nXXf23.js +0 -1911
  964. package/dist/src-LnF0REtW.js +0 -3974
  965. package/dist/startup-context-CxTy7OzN.js +0 -312
  966. package/dist/status-4n9xL7HY.js +0 -2
  967. package/dist/status-B4kD5cCF.js +0 -2
  968. package/dist/status-CARBoVql.js +0 -209
  969. package/dist/status-COK71LP_.js +0 -3
  970. package/dist/status-DxcqzXtf.js +0 -397
  971. package/dist/status-all-r7zyk41X.js +0 -498
  972. package/dist/status-f2DLmjOF.js +0 -190
  973. package/dist/status-json-C_wESP21.js +0 -14
  974. package/dist/status-json-command-C6w9ZAHp.js +0 -84
  975. package/dist/status-runtime-shared-Bq_SUJpC.js +0 -257
  976. package/dist/status-subagents.runtime-03fp3eBE.js +0 -18
  977. package/dist/status-text-CNvz374U.js +0 -237
  978. package/dist/status.gateway-connection.runtime-zjQmormq.js +0 -2
  979. package/dist/status.gather-BhjoJVEs.js +0 -2
  980. package/dist/status.gather-zdywRvBb.js +0 -292
  981. package/dist/status.runtime-DB31ZRnK.js +0 -2
  982. package/dist/status.scan-DjhdTOWP.js +0 -65
  983. package/dist/status.scan-overview-BYxTBsOw.js +0 -379
  984. package/dist/status.scan.fast-json-Dz0JcORG.js +0 -2
  985. package/dist/status.scan.fast-json-FroEIZ9d.js +0 -132
  986. package/dist/status.summary-3UVa_X5B.js +0 -214
  987. package/dist/status.summary-BGzGsyZB.js +0 -2
  988. package/dist/subagent-announce-BvRFZ87M.js +0 -351
  989. package/dist/subagent-announce-delivery-QvuOM46S.js +0 -726
  990. package/dist/subagent-announce-output-fOtzkOiP.js +0 -364
  991. package/dist/subagent-control-DwnzmG6T.js +0 -506
  992. package/dist/subagent-followup.runtime-DxR1eP_x.js +0 -68
  993. package/dist/subagent-orphan-recovery-CiBbDxX3.js +0 -305
  994. package/dist/subagent-registry-D5FrT_tn.js +0 -3
  995. package/dist/subagent-registry-DbPekx8d.js +0 -1753
  996. package/dist/subagent-spawn-W-bTaU9l.js +0 -1005
  997. package/dist/system-cli-B443uVHG.js +0 -59
  998. package/dist/targets-3Lcm8HoL.js +0 -67
  999. package/dist/task-executor-B5e9_Hmt.js +0 -360
  1000. package/dist/task-owner-access-CIEssJ78.js +0 -74
  1001. package/dist/task-registry-M1bHrFvP.js +0 -2366
  1002. package/dist/task-registry-delivery-runtime-CiHBC7sJ.js +0 -3
  1003. package/dist/task-registry-delivery-runtime-M4O7ffju.js +0 -2
  1004. package/dist/task-registry.maintenance-BURvMU0r.js +0 -2
  1005. package/dist/task-registry.maintenance-CgrLoBqi.js +0 -416
  1006. package/dist/testing-CRy_6-wt.js +0 -575
  1007. package/dist/text-report-B3-4Dvfb.js +0 -587
  1008. package/dist/tool-resolution-C52y5Qtc.js +0 -90
  1009. package/dist/tools-effective-inventory-WlIlqM7G.js +0 -152
  1010. package/dist/tools-invoke-http-B04Rc8tG.js +0 -206
  1011. package/dist/trash-BV5Gcx3a.js +0 -24
  1012. package/dist/tui-cli-DMZ07qRK.js +0 -4575
  1013. package/dist/update-cli-DeBm7b4g.js +0 -1759
  1014. package/dist/upgrade-C9ke1SCc.js +0 -1226
  1015. package/dist/video-generation-task-status-I3jvAjUL.js +0 -163
  1016. package/dist/wait-for-idle-before-flush-BZhF2ejZ.js +0 -5986
  1017. package/dist/wizard-models-CMKeAr_M.js +0 -161
@@ -1,1174 +0,0 @@
1
- import { i as formatErrorMessage } from "./errors-Jbvi20TW.js";
2
- import { t as safeEqualSecret } from "./secret-equal-BBFaVgZ-.js";
3
- import { r as buildChannelConfigSchema } from "./config-schema-BEt8F1Tk.js";
4
- import { t as DEFAULT_ACCOUNT_ID } from "./account-id-C3j_3_su.js";
5
- import { n as safeParseWithSchema, t as safeParseJsonWithSchema } from "./zod-parse-DQfbYHdH.js";
6
- import { g as resolvePinnedHostnameWithPolicy } from "./ssrf-Blp2w01T.js";
7
- import { i as createHybridChannelConfigAdapter, l as createScopedDmSecurityResolver } from "./channel-config-helpers-Bn_khg_r.js";
8
- import { t as buildAgentSessionKey } from "./resolve-route-BA6bCR3F.js";
9
- import { i as createChatChannelPlugin } from "./core-DbPzffGG.js";
10
- import "./channel-core-DqPUhmTt.js";
11
- import "./routing-lEBa2-AE.js";
12
- import { i as waitUntilAbort } from "./channel-lifecycle.core-DnEHhnwk.js";
13
- import { t as createPluginRuntimeStore } from "./runtime-store-IKEgvhfQ.js";
14
- import "./channel-config-schema-B1jO952s.js";
15
- import { C as projectAccountConfigWarningCollector, m as composeWarningCollectors, w as projectAccountWarningCollector, y as createConditionalWarningCollector } from "./channel-policy-Swn_TmHe.js";
16
- import { n as createEmptyChannelDirectoryAdapter } from "./directory-runtime-B19liKbg.js";
17
- import { a as createFixedWindowRateLimiter } from "./webhook-memory-guards-CotT_FpK.js";
18
- import { a as isRequestBodyLimitError, c as requestBodyErrorToText, s as readRequestBodyWithLimit } from "./http-body-DDG39e3E.js";
19
- import { a as createWebhookInFlightLimiter, i as beginWebhookRequestPipelineOrReject } from "./webhook-request-guards-D4zAmS4Z.js";
20
- import { t as registerPluginHttpRoute } from "./http-registry-H4nrRWJL.js";
21
- import "./webhook-ingress-BET_Iso7.js";
22
- import { t as resolveApprovalApprovers } from "./approval-approvers-jZrrUexE.js";
23
- import { t as createResolvedApproverActionAuthAdapter } from "./approval-auth-helpers-BUQDSYGo.js";
24
- import "./ssrf-runtime-DtkX5TMS.js";
25
- import "./account-resolution-CCoiqE4j.js";
26
- import "./browser-security-runtime-mU_AyWtD.js";
27
- import "./extension-shared-DIc0GChj.js";
28
- import "./channel-lifecycle-DVZOmLFm.js";
29
- import { t as attachChannelToResult } from "./channel-send-result-Bt5L4KMT.js";
30
- import { t as zod_exports } from "./zod-Bqvft_ty.js";
31
- import { i as resolveAccount, n as synologyChatSetupWizard, r as listAccountIds, t as synologyChatSetupAdapter } from "./setup-surface-BDMSFHdN.js";
32
- import { t as collectSynologyChatSecurityAuditFindings } from "./security-audit-C2thFNGm.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 };