@pixelzx/genesis 2026.6.4 → 2026.6.6

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