@pixelzx/genesis 2026.6.4 → 2026.6.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1073) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/dist/.buildstamp +1 -1
  3. package/dist/abort-CcNxEsSq.js +201 -0
  4. package/dist/abort.runtime-DZJDSf0d.js +2 -0
  5. package/dist/abort.runtime.js +1 -1
  6. package/dist/accounts-B7M6y8l8.js +107 -0
  7. package/dist/accounts-DddcYo7u.js +2 -0
  8. package/dist/accounts-v0Cqfnse.js +104 -0
  9. package/dist/acp-cli-D_2_Nim8.js +2193 -0
  10. package/dist/acp-spawn-BZPupfsZ.js +2 -0
  11. package/dist/acp-spawn-CWfIrbK7.js +1093 -0
  12. package/dist/acp-stateful-target-driver-DpCTjH5T.js +89 -0
  13. package/dist/action-agents-fjIM4rpc.js +67 -0
  14. package/dist/action-focus-cx1pm1ym.js +132 -0
  15. package/dist/action-help-DtyAnULB.js +7 -0
  16. package/dist/action-info-DF30-xZl.js +101 -0
  17. package/dist/action-kill-rsSdXzvX.js +33 -0
  18. package/dist/action-list-4VN835m2.js +21 -0
  19. package/dist/action-log-L032mq5B.js +30 -0
  20. package/dist/action-send-Dm62UP-n.js +39 -0
  21. package/dist/action-spawn-BuZHKlpL.js +47 -0
  22. package/dist/action-unfocus-CTIWf8WX.js +29 -0
  23. package/dist/actions.runtime-0ezEcm7K.js +18 -0
  24. package/dist/actions.runtime-DKsCTTnH.js +5 -0
  25. package/dist/actions.runtime.js +1 -1
  26. package/dist/agent-BTOBOCIw.js +2 -0
  27. package/dist/agent-command-C-_EFUUu.js +874 -0
  28. package/dist/agent-harness-runtime-Bye6j3EL.js +144 -0
  29. package/dist/agent-runner-utils-CX2vCMkx.js +239 -0
  30. package/dist/agent-runner.runtime-BBqrjZv4.js +3455 -0
  31. package/dist/agent-runner.runtime.js +1 -1
  32. package/dist/agent-runtime-D1LIGcNj.js +18 -0
  33. package/dist/agents-CME2O1l9.js +5 -0
  34. package/dist/agents-DsDQvAPy.js +954 -0
  35. package/dist/aliases-C807OidC.js +2 -0
  36. package/dist/aliases-jq1ap6Dz.js +96 -0
  37. package/dist/api-BbxKoRkD.js +3 -0
  38. package/dist/api-CwJPCW9U.js +139 -0
  39. package/dist/api-N5Kaaq64.js +5 -0
  40. package/dist/approval-gateway-resolver-DIPFgTnx.js +29 -0
  41. package/dist/approval-gateway-runtime-i0yziXk2.js +2 -0
  42. package/dist/approval-handler-runtime-Cdm-10f9.js +439 -0
  43. package/dist/approval-native-runtime-BRjeBoqL.js +729 -0
  44. package/dist/attempt-execution.runtime-NFTF7Cbt.js +509 -0
  45. package/dist/attempt-execution.runtime.js +1 -1
  46. package/dist/attempt.prompt-helpers-DuBXv46v.js +221 -0
  47. package/dist/attempt.tool-run-context-Qf-tbC-C.js +933 -0
  48. package/dist/audit-DsDfRhB8.js +939 -0
  49. package/dist/audit.runtime-ComjcUGJ.js +7 -0
  50. package/dist/audit.runtime.js +1 -1
  51. package/dist/auth-BT_gqC-D.js +2 -0
  52. package/dist/auth-DeUz_8w8.js +383 -0
  53. package/dist/auth-order-DM7UkPDa.js +96 -0
  54. package/dist/auth-order-yS8hXrXh.js +2 -0
  55. package/dist/bash-tools-D0M9gBDu.js +3 -0
  56. package/dist/bash-tools-tnj1gSbO.js +2824 -0
  57. package/dist/binding-routing-C7atXiTD.js +85 -0
  58. package/dist/binding-targets-CCv7agx9.js +121 -0
  59. package/dist/bridge-server-C5O9rTJg.js +113 -0
  60. package/dist/browser-control-auth-GGN_kbqE.js +2 -0
  61. package/dist/browser-node-runtime-B-uTSVqP.js +12 -0
  62. package/dist/browser-profiles-Dex2eaLH.js +2 -0
  63. package/dist/browser-runtime-BPocB6yO.js +387 -0
  64. package/dist/browser-setup-tools-gHfYeDWA.js +13 -0
  65. package/dist/build-BqG7RkBz.js +550 -0
  66. package/dist/build-info.json +3 -3
  67. package/dist/bundled/boot-md/handler.js +2 -2
  68. package/dist/bundled/session-memory/handler.js +1 -1
  69. package/dist/call-BI4JvjcR.js +3 -0
  70. package/dist/call-wY43fzOF.js +331 -0
  71. package/dist/call.runtime-Dh61oVeL.js +2 -0
  72. package/dist/call.runtime.js +1 -1
  73. package/dist/capability-cli-BHz-2Stx.js +1401 -0
  74. package/dist/catchup-Be7tHJwK.js +300 -0
  75. package/dist/channel-B-6VmF4-.js +840 -0
  76. package/dist/channel-BCJccV-O.js +226 -0
  77. package/dist/channel-BDZqLbod.js +1100 -0
  78. package/dist/channel-BQDNgTea.js +1174 -0
  79. package/dist/channel-BwjThGwK.js +453 -0
  80. package/dist/channel-CPoThmda.js +595 -0
  81. package/dist/channel-CUT8NJ-B.js +350 -0
  82. package/dist/channel-C_Y7lv8v.js +491 -0
  83. package/dist/channel-Ck7-C-lB.js +297 -0
  84. package/dist/channel-DOpVjq4i.js +1802 -0
  85. package/dist/channel-core-QV9-eAtb.js +5 -0
  86. package/dist/channel-inbound-D_tebgdx.js +31 -0
  87. package/dist/channel-plugin-runtime-DXcBwNNM.js +771 -0
  88. package/dist/channel-runtime-D4ci0o4V.js +425 -0
  89. package/dist/channel-sAdF_zH-.js +1320 -0
  90. package/dist/channel.runtime-1swLIpNV.js +89 -0
  91. package/dist/channel.runtime-B9hljdNF.js +4 -0
  92. package/dist/channel.runtime-CSbR2pni.js +430 -0
  93. package/dist/channel.runtime-CdpqhnLO.js +2364 -0
  94. package/dist/channel.runtime-DOx6WROg.js +40130 -0
  95. package/dist/channel.runtime-H5Kb2LbC.js +109 -0
  96. package/dist/channel.runtime-V7boBc_e.js +576 -0
  97. package/dist/channel.runtime.js +1 -1
  98. package/dist/channel.setup-BXyeNJ2_.js +10 -0
  99. package/dist/channels-KU7bwUUs.js +733 -0
  100. package/dist/channels-cli-CTX6_5z3.js +268 -0
  101. package/dist/chat-C_i6Wp50.js +2830 -0
  102. package/dist/clawbot-cli-CLGPtbt-.js +9 -0
  103. package/dist/cli/daemon-cli.js +3 -3
  104. package/dist/cli-BhwHu1dK.js +72 -0
  105. package/dist/cli-CFsq8f2H.js +2 -0
  106. package/dist/cli-CNVlwurq.js +219 -0
  107. package/dist/cli-DLP8hKbi.js +2 -0
  108. package/dist/cli-runner-BbNBHV6v.js +286 -0
  109. package/dist/cli-runner.runtime-CfPaauuM.js +4 -0
  110. package/dist/cli-runner.runtime-MxBlCOO2.js +3 -0
  111. package/dist/cli-runner.runtime.js +1 -1
  112. package/dist/cli-startup-metadata.json +2 -2
  113. package/dist/cli.runtime-3cD-pSyn.js +1261 -0
  114. package/dist/cli.runtime.js +1 -1
  115. package/dist/client-Bl0d_7ak.js +138 -0
  116. package/dist/client-ClJyHgmq.js +713 -0
  117. package/dist/command-auth-DO32coey.js +76 -0
  118. package/dist/command-config-resolution-CAsa4fGg.js +2 -0
  119. package/dist/command-config-resolution-D6YcwuRh.js +23 -0
  120. package/dist/command-config-resolution.runtime-CSHDu35A.js +2 -0
  121. package/dist/command-config-resolution.runtime.js +1 -1
  122. package/dist/command-registry-BJEQrMqR.js +4 -0
  123. package/dist/command-registry-DI9i95nj.js +9 -0
  124. package/dist/command-registry-core-BpF1mggD.js +106 -0
  125. package/dist/command-secret-gateway-DDNHxysD.js +528 -0
  126. package/dist/command-status.runtime-DqYUCcEA.js +87 -0
  127. package/dist/command-status.runtime.js +1 -1
  128. package/dist/commands-acp-C_zCJPvL.js +77 -0
  129. package/dist/commands-compact.runtime-B6e3kwMS.js +10 -0
  130. package/dist/commands-compact.runtime.js +1 -1
  131. package/dist/commands-handlers.runtime-B0gTkAC0.js +4599 -0
  132. package/dist/commands-handlers.runtime.js +1 -1
  133. package/dist/commands-status-BgZ64sA8.js +16 -0
  134. package/dist/commands-status.runtime-JI89gIEU.js +3 -0
  135. package/dist/commands-status.runtime.js +1 -1
  136. package/dist/commands-subagents-control.runtime-B0hdcBxr.js +2 -0
  137. package/dist/commands-subagents-control.runtime-DUeSQ5j4.js +3 -0
  138. package/dist/commands-subagents-control.runtime.js +1 -1
  139. package/dist/commands-system-prompt-B7moUaCI.js +158 -0
  140. package/dist/commands-system-prompt-DTUkp9TH.js +2 -0
  141. package/dist/commands.runtime-BjCVVqol.js +167 -0
  142. package/dist/commands.runtime.js +1 -1
  143. package/dist/compact-BNJH56SX.js +1118 -0
  144. package/dist/compact.runtime-CYI8Yi9d.js +12 -0
  145. package/dist/compact.runtime.js +1 -1
  146. package/dist/completion-cli-Bb1Tk-vM.js +328 -0
  147. package/dist/config-DxkleHmo.js +252 -0
  148. package/dist/config-cli-CtaRB_f8.js +1078 -0
  149. package/dist/configure-Bp8WFryM.js +1252 -0
  150. package/dist/configure-DQ_X5zyT.js +2 -0
  151. package/dist/connect-options-BkWD0Wvv.js +699 -0
  152. package/dist/control-auth-Iqyldslx.js +125 -0
  153. package/dist/control-service-xIhkqyZE.js +156 -0
  154. package/dist/control-ui/assets/agents-Dh_TAFxm.js +1052 -0
  155. package/dist/control-ui/assets/canvas-BBkF0c_Z.js +269 -0
  156. package/dist/control-ui/assets/channel-config-extras-CNdHdere.js +2 -0
  157. package/dist/control-ui/assets/channels-DxBxgFLI.js +463 -0
  158. package/dist/control-ui/assets/cron-DI85RTUE.js +933 -0
  159. package/dist/control-ui/assets/de-ona0Q7Bc.js +2 -0
  160. package/dist/control-ui/assets/debug-DnDu2pj9.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-YAwpI05T.js +6366 -0
  167. package/dist/control-ui/assets/instances-CRNiJVGJ.js +57 -0
  168. package/dist/control-ui/assets/ja-JP-BUkQN13S.js +2 -0
  169. package/dist/control-ui/assets/ko-Q_K13wyH.js +2 -0
  170. package/dist/control-ui/assets/logs-CzRlG5kP.js +74 -0
  171. package/dist/control-ui/assets/mcp-CAYQSRMs.js +373 -0
  172. package/dist/control-ui/assets/nodes-92SUclba.js +618 -0
  173. package/dist/control-ui/assets/pl-WlhlBCqd.js +2 -0
  174. package/dist/control-ui/assets/plugins-TwSBb6p5.js +273 -0
  175. package/dist/control-ui/assets/pt-BR-CVchspYo.js +2 -0
  176. package/dist/control-ui/assets/sessions-CHmx5D2H.js +306 -0
  177. package/dist/control-ui/assets/skills-C-34EOwN.js +323 -0
  178. package/dist/control-ui/assets/skills-shared-BbxW-wNm.js +11 -0
  179. package/dist/control-ui/assets/th-C4FUN3Mq.js +2 -0
  180. package/dist/control-ui/assets/tr-CoySBXqw.js +2 -0
  181. package/dist/control-ui/assets/uk-C-mkZs9j.js +2 -0
  182. package/dist/control-ui/assets/wallet-DjjoYuDY.js +285 -0
  183. package/dist/control-ui/assets/zh-CN-B7HXiLrY.js +2 -0
  184. package/dist/control-ui/assets/zh-TW-CKLRstBM.js +2 -0
  185. package/dist/control-ui/index.html +3 -3
  186. package/dist/conversation-id-BZtOqHIz.js +38 -0
  187. package/dist/conversation-id-D1Q9qPFH.js +235 -0
  188. package/dist/conversation-runtime-B1QZ-DEM.js +31 -0
  189. package/dist/core-BdVAy0Wv.js +275 -0
  190. package/dist/cron-cli-BWM2kRKU.js +713 -0
  191. package/dist/daemon-cli-MRl5nyuF.js +12 -0
  192. package/dist/dashboard-BkdlJrnf.js +2 -0
  193. package/dist/dashboard-C9m86rHv.js +81 -0
  194. package/dist/delegate-BjUvKQlo.js +64 -0
  195. package/dist/detached-task-runtime-BAEzkNB8.js +73 -0
  196. package/dist/devices-cli-B1n6tl9f.js +498 -0
  197. package/dist/diagnostics-DZxWkW3i.js +154 -0
  198. package/dist/direct-dm-qw-uk31C.js +64 -0
  199. package/dist/dispatch-D0xiJ6Up.js +1131 -0
  200. package/dist/dispatch-acp-DVN58m9G.js +981 -0
  201. package/dist/dispatch-acp-manager.runtime-C8t1i5Wt.js +3 -0
  202. package/dist/dispatch-acp-manager.runtime.js +1 -1
  203. package/dist/dispatch-acp.runtime-FR0DUPpn.js +19 -0
  204. package/dist/dispatch-acp.runtime.js +1 -1
  205. package/dist/doctor-device-pairing-DIbiBPlL.js +307 -0
  206. package/dist/doctor-gateway-daemon-flow-BFjRlXvA.js +250 -0
  207. package/dist/doctor-gateway-health-uZrukX3c.js +63 -0
  208. package/dist/doctor-health-DKpg1bxM.js +59 -0
  209. package/dist/doctor-health-contributions-BoXX8ubw.js +493 -0
  210. package/dist/doctor-prompter-CLf5Uf10.js +56 -0
  211. package/dist/doctor-workspace-status-Cw61BbGy.js +75 -0
  212. package/dist/dreaming-Bk8dVfGi.js +1574 -0
  213. package/dist/dreaming-narrative-DGSQa-0N.js +595 -0
  214. package/dist/embedded-gateway-stub.runtime-sokWrs6B.js +9 -0
  215. package/dist/embedded-gateway-stub.runtime.js +1 -1
  216. package/dist/entry.js +2 -2
  217. package/dist/exec-approvals-cli-CnNETs_u.js +498 -0
  218. package/dist/extensionAPI.js +1 -1
  219. package/dist/extensions/active-memory/index.js +1 -1
  220. package/dist/extensions/bluebubbles/api.js +3 -3
  221. package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
  222. package/dist/extensions/browser/browser-bridge.js +1 -1
  223. package/dist/extensions/browser/browser-config.js +4 -4
  224. package/dist/extensions/browser/browser-control-auth.js +2 -2
  225. package/dist/extensions/browser/browser-doctor.js +2 -2
  226. package/dist/extensions/browser/browser-maintenance.js +2 -2
  227. package/dist/extensions/browser/browser-profiles.js +2 -2
  228. package/dist/extensions/browser/browser-runtime-api.js +10 -10
  229. package/dist/extensions/browser/index.js +1 -1
  230. package/dist/extensions/browser/plugin-registration.js +1 -1
  231. package/dist/extensions/browser/register.runtime.js +3 -3
  232. package/dist/extensions/browser/runtime-api.js +11 -11
  233. package/dist/extensions/browser/test-support.js +1 -1
  234. package/dist/extensions/device-pair/api.js +1 -1
  235. package/dist/extensions/device-pair/index.js +3 -3
  236. package/dist/extensions/device-pair/notify.js +1 -1
  237. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  238. package/dist/extensions/google-meet/index.js +2 -2
  239. package/dist/extensions/imessage/api.js +3 -3
  240. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  241. package/dist/extensions/imessage/runtime-api.js +3 -3
  242. package/dist/extensions/irc/api.js +2 -2
  243. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  244. package/dist/extensions/line/api.js +2 -2
  245. package/dist/extensions/line/channel-plugin-api.js +1 -1
  246. package/dist/extensions/line/contract-api.js +1 -1
  247. package/dist/extensions/line/runtime-api.js +4 -4
  248. package/dist/extensions/line/setup-api.js +1 -1
  249. package/dist/extensions/llm-task/index.js +2 -2
  250. package/dist/extensions/lobster/index.js +3 -3
  251. package/dist/extensions/lobster/runtime-api.js +1 -1
  252. package/dist/extensions/mattermost/api.js +1 -1
  253. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  254. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  255. package/dist/extensions/mattermost/policy-api.js +1 -1
  256. package/dist/extensions/mattermost/runtime-api.js +4 -4
  257. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  258. package/dist/extensions/memory-core/api.js +1 -1
  259. package/dist/extensions/memory-core/cli-metadata.js +2 -2
  260. package/dist/extensions/memory-core/index.js +3 -3
  261. package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
  262. package/dist/extensions/msteams/api.js +1 -1
  263. package/dist/extensions/msteams/channel-plugin-api.js +1 -1
  264. package/dist/extensions/msteams/runtime-api.js +3 -3
  265. package/dist/extensions/msteams/test-api.js +1 -1
  266. package/dist/extensions/nextcloud-talk/api.js +1 -1
  267. package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
  268. package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
  269. package/dist/extensions/openshell/index.js +2 -2
  270. package/dist/extensions/signal/api.js +6 -6
  271. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  272. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  273. package/dist/extensions/signal/runtime-api.js +7 -7
  274. package/dist/extensions/skill-workshop/api.js +1 -1
  275. package/dist/extensions/skill-workshop/index.js +1 -1
  276. package/dist/extensions/synology-chat/api.js +1 -1
  277. package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
  278. package/dist/extensions/tlon/api.js +2 -2
  279. package/dist/extensions/tlon/channel-plugin-api.js +1 -1
  280. package/dist/extensions/tlon/runtime-api.js +1 -1
  281. package/dist/extensions/tlon/test-api.js +1 -1
  282. package/dist/extensions/twitch/api.js +1 -1
  283. package/dist/extensions/twitch/channel-plugin-api.js +1 -1
  284. package/dist/extensions/twitch/setup-plugin-api.js +1 -1
  285. package/dist/extensions/zalo/api.js +3 -3
  286. package/dist/extensions/zalo/channel-plugin-api.js +1 -1
  287. package/dist/extensions/zalo/runtime-api.js +2 -2
  288. package/dist/extensions/zalo/setup-api.js +2 -2
  289. package/dist/extensions/zalouser/api.js +3 -3
  290. package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
  291. package/dist/extensions/zalouser/runtime-api.js +6 -6
  292. package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
  293. package/dist/extensions/zalouser/test-api.js +1 -1
  294. package/dist/fallbacks-BwNexEVP.js +31 -0
  295. package/dist/fallbacks-GwVAaFt5.js +2 -0
  296. package/dist/fallbacks-shared-DmepG9Mq.js +111 -0
  297. package/dist/gateway-BB4hdlYm.js +115 -0
  298. package/dist/gateway-cli-Bzz62NC8.js +1283 -0
  299. package/dist/gateway-rpc-dyJV2osv.js +14 -0
  300. package/dist/gateway-rpc.runtime-DYVOEv4W.js +23 -0
  301. package/dist/gateway-rpc.runtime.js +1 -1
  302. package/dist/gateway-runtime-CqSQCYo0.js +15 -0
  303. package/dist/gateway-status-DdCiwrPt.js +584 -0
  304. package/dist/genesis-tools-Bh6dAUhK.js +9166 -0
  305. package/dist/genesis-tools.runtime-CiIUponP.js +2 -0
  306. package/dist/genesis-tools.runtime.js +1 -1
  307. package/dist/get-reply-from-config.runtime-Cu2DcwOW.js +2 -0
  308. package/dist/get-reply-from-config.runtime.js +1 -1
  309. package/dist/get-reply-qVmTjhwr.js +3897 -0
  310. package/dist/graph-users-kkSJYBNX.js +1337 -0
  311. package/dist/health-CFyVDYng.js +469 -0
  312. package/dist/health-Cl371mu8.js +3 -0
  313. package/dist/health-route-D0IspgUK.js +41 -0
  314. package/dist/health-route-D2tFKCLv.js +2 -0
  315. package/dist/heartbeat-runner-Bmi8YsXz.js +5 -0
  316. package/dist/heartbeat-runner-FSCWra2R.js +1292 -0
  317. package/dist/heartbeat-runner.runtime-QF8dg4j-.js +4 -0
  318. package/dist/heartbeat-runner.runtime.js +1 -1
  319. package/dist/hooks-cli-DYoG7Dz1.js +433 -0
  320. package/dist/image-fallbacks-5ckuJ46I.js +31 -0
  321. package/dist/image-fallbacks-DYnqzK01.js +2 -0
  322. package/dist/inbound-reply-dispatch-D5pqDZRa.js +73 -0
  323. package/dist/index.js +2 -2
  324. package/dist/infra-runtime-D08WIqN2.js +39 -0
  325. package/dist/init-BCgwiSZj.js +59 -0
  326. package/dist/library-CP9n_7AP.js +45 -0
  327. package/dist/lifecycle-BYam90xH.js +229 -0
  328. package/dist/lifecycle-DS58sNmu.js +571 -0
  329. package/dist/lifecycle.runtime-DMwss7xM.js +2 -0
  330. package/dist/lifecycle.runtime.js +1 -1
  331. package/dist/list-CASc4IWz.js +131 -0
  332. package/dist/list-CBPrBS2u.js +1212 -0
  333. package/dist/list-Cf7fcqQd.js +2 -0
  334. package/dist/list-Dqd2QyTH.js +2 -0
  335. package/dist/list.probe-BWcMSWDF.js +419 -0
  336. package/dist/llm-slug-generator-4LADFhXT.js +79 -0
  337. package/dist/llm-slug-generator.js +1 -1
  338. package/dist/load-config-DI-LDL6p.js +35 -0
  339. package/dist/local-dispatch.runtime-WDgraH3j.js +8 -0
  340. package/dist/local-dispatch.runtime.js +1 -1
  341. package/dist/logs-cli-zoBIelUH.js +265 -0
  342. package/dist/logs-cli.runtime-DxKNxXAz.js +2 -0
  343. package/dist/logs-cli.runtime.js +1 -1
  344. package/dist/main-session-restart-recovery-DWZfkOzH.js +206 -0
  345. package/dist/managed-image-attachments-DLDa1aE2.js +2 -0
  346. package/dist/managed-image-attachments-a4v60Bk3.js +635 -0
  347. package/dist/manager-CfUcsSI9.js +2057 -0
  348. package/dist/manager-DmBBLCOg.js +2 -0
  349. package/dist/markdown-to-line-B0mPruD_.js +790 -0
  350. package/dist/mcp/plugin-tools-serve.js +1 -1
  351. package/dist/mcp-cli-CLL9nfvE.js +725 -0
  352. package/dist/mcp-http-p7GbtbMx.js +529 -0
  353. package/dist/memory-core-host-runtime-cli-CZNYkDoE.js +9 -0
  354. package/dist/message-CRyNLXch.js +232 -0
  355. package/dist/message-action-runner-5Y4EFpWh.js +1407 -0
  356. package/dist/message-action-runner-Dxv-GXkn.js +2 -0
  357. package/dist/message-actions-DtoR6Mr2.js +143 -0
  358. package/dist/message.gateway.runtime-RI4cvk_E.js +2 -0
  359. package/dist/message.gateway.runtime.js +1 -1
  360. package/dist/models-auth-status-DsheCXaS.js +201 -0
  361. package/dist/models-cli-CQQG1U-p.js +219 -0
  362. package/dist/monitor-BRRSjPQY.js +1459 -0
  363. package/dist/monitor-Ch-cG7Si.js +1661 -0
  364. package/dist/monitor-ChBhfnC-.js +788 -0
  365. package/dist/monitor-CsvCTpjq.js +671 -0
  366. package/dist/monitor-DjemBuVh.js +1237 -0
  367. package/dist/monitor-LyGEO-KI.js +2 -0
  368. package/dist/monitor-auth-DVCdDwlp.js +207 -0
  369. package/dist/monitor-processing-Cib3ZjUe.js +1974 -0
  370. package/dist/monitor.runtime-DLBFALbV.js +2 -0
  371. package/dist/monitor.runtime.js +1 -1
  372. package/dist/monitor.webhook-Dktr8JA-.js +180 -0
  373. package/dist/msteams-G5I2CO13.js +35 -0
  374. package/dist/native-hook-relay-B1ArNeG5.js +519 -0
  375. package/dist/nextcloud-talk-DimOAfaR.js +17 -0
  376. package/dist/node-cli-RIjV0id4.js +2276 -0
  377. package/dist/nodes-cli-Cke-B80I.js +1046 -0
  378. package/dist/nodes-utils-CsTqKwN9.js +84 -0
  379. package/dist/nodes.helpers-DYpGCFer.js +34 -0
  380. package/dist/notify-zBChwf0-.js +315 -0
  381. package/dist/onboard-D6UawRld.js +2 -0
  382. package/dist/onboard-DfoCtk3_.js +70 -0
  383. package/dist/onboard-helpers-BKQMe3RX.js +6 -0
  384. package/dist/onboard-helpers-BLBJlQ50.js +204 -0
  385. package/dist/onboard-interactive-GAbQD437.js +24 -0
  386. package/dist/onboard-non-interactive-Bqi-JXh3.js +635 -0
  387. package/dist/onboard-remote-CNpTyVws.js +193 -0
  388. package/dist/onboard-remote-GFp2lT6Y.js +2 -0
  389. package/dist/onboard-skills-BQneolfo.js +2 -0
  390. package/dist/onboard-skills-BipqJ48b.js +134 -0
  391. package/dist/openai-http-CLDWjSKC.js +500 -0
  392. package/dist/openresponses-http-DNvXNiw_.js +1128 -0
  393. package/dist/operator-approvals-client-gaflvETF.js +68 -0
  394. package/dist/outbound.runtime-ByVsvEri.js +2 -0
  395. package/dist/outbound.runtime.js +1 -1
  396. package/dist/pair-command-approve-Dzkubc-8.js +44 -0
  397. package/dist/persistent-bindings.lifecycle-BhdRK7Lp.js +2 -0
  398. package/dist/persistent-bindings.lifecycle-DQ0AiHuy.js +85 -0
  399. package/dist/pi-embedded-C789hs31.js +4 -0
  400. package/dist/pi-embedded-CXLkrOwv.js +2905 -0
  401. package/dist/pi-embedded.runtime-BaHYLgKa.js +4 -0
  402. package/dist/pi-embedded.runtime.js +1 -1
  403. package/dist/pi-tool-definition-adapter-DFutc0D4.js +229 -0
  404. package/dist/pi-tools-k60jrAVq.js +1057 -0
  405. package/dist/pi-tools.before-tool-call-CFy20GCz.js +2 -0
  406. package/dist/pi-tools.before-tool-call-DJmPOVfQ.js +433 -0
  407. package/dist/plugin-BfFuIgXQ.js +12195 -0
  408. package/dist/plugin-enabled-dXOUnZwX.js +140 -0
  409. package/dist/plugin-registration-CEAozQhV.js +23 -0
  410. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  411. package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
  412. package/dist/plugin-sdk/acp-runtime.js +2 -2
  413. package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
  414. package/dist/plugin-sdk/agent-harness.js +6 -6
  415. package/dist/plugin-sdk/agent-runtime.js +2 -2
  416. package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
  417. package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
  418. package/dist/plugin-sdk/approval-runtime.js +1 -1
  419. package/dist/plugin-sdk/browser-node-runtime.js +4 -4
  420. package/dist/plugin-sdk/browser-setup-tools.js +3 -3
  421. package/dist/plugin-sdk/browser-support.js +7 -7
  422. package/dist/plugin-sdk/channel-core.js +2 -2
  423. package/dist/plugin-sdk/channel-inbound.js +2 -2
  424. package/dist/plugin-sdk/command-auth.js +1 -1
  425. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  426. package/dist/plugin-sdk/compat.js +1 -1
  427. package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
  428. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  429. package/dist/plugin-sdk/core.js +2 -2
  430. package/dist/plugin-sdk/direct-dm.js +1 -1
  431. package/dist/plugin-sdk/gateway-runtime.js +3 -3
  432. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  433. package/dist/plugin-sdk/index.js +1 -1
  434. package/dist/plugin-sdk/infra-runtime.js +2 -2
  435. package/dist/plugin-sdk/irc.js +2 -2
  436. package/dist/plugin-sdk/matrix.js +1 -1
  437. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
  438. package/dist/plugin-sdk/memory-core.js +2 -2
  439. package/dist/plugin-sdk/msteams.js +2 -2
  440. package/dist/plugin-sdk/nextcloud-talk.js +2 -2
  441. package/dist/plugin-sdk/nostr.js +1 -1
  442. package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
  443. package/dist/plugin-sdk/reply-runtime.js +4 -4
  444. package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
  445. package/dist/plugin-sdk/runtime.js +2 -2
  446. package/dist/plugin-sdk/session-visibility.js +1 -1
  447. package/dist/plugin-sdk/testing.js +4 -4
  448. package/dist/plugin-sdk/tlon.js +1 -1
  449. package/dist/plugin-sdk/zalo.js +1 -1
  450. package/dist/plugin-sdk/zalouser.js +1 -1
  451. package/dist/plugin-service-BOpLQ8BU.js +2892 -0
  452. package/dist/plugins/runtime/index.js +1 -1
  453. package/dist/policy-DiIlt2yW.js +328 -0
  454. package/dist/postinstall-inventory.json +445 -445
  455. package/dist/prepare.runtime-Bd8adOy3.js +815 -0
  456. package/dist/prepare.runtime.js +1 -1
  457. package/dist/probe-BOlTfbzG.js +2 -0
  458. package/dist/probe-BSRvsN95.js +2205 -0
  459. package/dist/probe-CDfjQSnz.js +74 -0
  460. package/dist/probe-D7gHyiZV.js +241 -0
  461. package/dist/probe-DTNKTWSs.js +2 -0
  462. package/dist/probe-DcryDdZh.js +45 -0
  463. package/dist/probe-nyesoHxj.js +1443 -0
  464. package/dist/program-BFGavenz.js +111 -0
  465. package/dist/prompt-select-styled-BhY1zahx.js +20 -0
  466. package/dist/protocol-DxLbSF2J.js +2477 -0
  467. package/dist/provider-dispatcher-C-yy1D7r.js +22 -0
  468. package/dist/provider-dispatcher-ErSjESTP.js +2 -0
  469. package/dist/qr-cli-C1-oy_ho.js +349 -0
  470. package/dist/qr-cli-DmEs63Sb.js +2 -0
  471. package/dist/reaction-runtime-api-gua650a7.js +116 -0
  472. package/dist/reactions-R-rA7cXz.js +998 -0
  473. package/dist/register-service-commands-DkbqNKVB.js +71 -0
  474. package/dist/register.agent-C3nW9wDn.js +248 -0
  475. package/dist/register.configure-BzLHCu95.js +15 -0
  476. package/dist/register.maintenance-BHFQo4gr.js +363 -0
  477. package/dist/register.message-CsYRdfKi.js +329 -0
  478. package/dist/register.onboard-DltySQ6C.js +88 -0
  479. package/dist/register.runtime-6Sk1Njnp.js +81 -0
  480. package/dist/register.runtime.js +1 -1
  481. package/dist/register.setup-CDvVQJuj.js +150 -0
  482. package/dist/register.status-health-sessions-B8lorJ2x.js +1215 -0
  483. package/dist/register.subclis-BD4fuAci.js +3 -0
  484. package/dist/register.subclis-CbRd3F_m.js +29 -0
  485. package/dist/register.subclis-core-Dtq9dAjI.js +249 -0
  486. package/dist/reply-dispatch-runtime-DldslKSK.js +13 -0
  487. package/dist/reply-runtime-2EGTfk-1.js +11 -0
  488. package/dist/reply.runtime-OaHntzIS.js +2 -0
  489. package/dist/reply.runtime.js +1 -1
  490. package/dist/restart-health-BjmfJCUM.js +202 -0
  491. package/dist/restart-health-hw909zlD.js +2 -0
  492. package/dist/root-help-_hHiERsR.js +44 -0
  493. package/dist/routes-BxCk7Pue.js +3341 -0
  494. package/dist/routes-C1_6oFmZ.js +2 -0
  495. package/dist/rpc-zRbkEo6W.js +61 -0
  496. package/dist/rpc.runtime-BZSYNDPa.js +21 -0
  497. package/dist/rpc.runtime.js +1 -1
  498. package/dist/run-delivery.runtime-D6YDo67d.js +530 -0
  499. package/dist/run-delivery.runtime.js +1 -1
  500. package/dist/run-embedded.runtime-BsgPrPDa.js +4 -0
  501. package/dist/run-embedded.runtime.js +1 -1
  502. package/dist/run-execution-cli.runtime-CggaHhrJ.js +4 -0
  503. package/dist/run-execution-cli.runtime.js +1 -1
  504. package/dist/run-executor.runtime-CKkLEr_T.js +277 -0
  505. package/dist/run-executor.runtime.js +1 -1
  506. package/dist/run-main-CJYYkV6H.js +567 -0
  507. package/dist/run-subagent-registry.runtime-B0sgf_oy.js +2 -0
  508. package/dist/run-subagent-registry.runtime.js +1 -1
  509. package/dist/run-wait-DHizeptL.js +135 -0
  510. package/dist/runtime-EtV_ChXX.js +9 -0
  511. package/dist/runtime-api-6H864Pmt.js +9 -0
  512. package/dist/runtime-api-CbZqRBZQ.js +14 -0
  513. package/dist/runtime-api-ZxEgu8cW.js +4 -0
  514. package/dist/runtime-api-j9A6jYUr.js +9 -0
  515. package/dist/runtime-embedded-pi.runtime-BHjCPnxo.js +2 -0
  516. package/dist/runtime-embedded-pi.runtime.js +1 -1
  517. package/dist/runtime-hvRzTSAZ.js +973 -0
  518. package/dist/runtime-internal-C_KZYzFK.js +2 -0
  519. package/dist/runtime-options-BZEOCnMg.js +275 -0
  520. package/dist/runtime-schema-R7LWe58K.js +28576 -0
  521. package/dist/scan-BNDE3dSE.js +523 -0
  522. package/dist/scan-TG6lVEQ2.js +2 -0
  523. package/dist/secrets-cli-twD2FWoZ.js +2101 -0
  524. package/dist/security-cli-Cd1A5yhL.js +486 -0
  525. package/dist/selection-CqqmU0Hi.js +7764 -0
  526. package/dist/selection-CsM62vcz.js +2 -0
  527. package/dist/send-D-EgB64m.js +156 -0
  528. package/dist/send-DPk5hW1W.js +102 -0
  529. package/dist/send.runtime-3QDkKN71.js +2 -0
  530. package/dist/send.runtime.js +1 -1
  531. package/dist/server-C94r_Qff.js +77 -0
  532. package/dist/server-Ceiopn_v.js +13 -0
  533. package/dist/server-context-BFJlu5HY.js +2 -0
  534. package/dist/server-context-PNEqhnTM.js +847 -0
  535. package/dist/server-node-events-QOAWLsDC.js +481 -0
  536. package/dist/server-plugin-bootstrap-CgsjzB17.js +2 -0
  537. package/dist/server-plugin-bootstrap-Dfuf75EN.js +12728 -0
  538. package/dist/server-restart-sentinel-BMPqZ7Jw.js +697 -0
  539. package/dist/server.impl-CCoQpvB7.js +12864 -0
  540. package/dist/session-kill-http-oPi3ajEp.js +110 -0
  541. package/dist/session-reset-service-CzDd6PBK.js +497 -0
  542. package/dist/session-route-DUOQE8-f.js +93 -0
  543. package/dist/session-status.runtime-W5tlGbXw.js +2 -0
  544. package/dist/session-status.runtime.js +1 -1
  545. package/dist/session-subagent-reactivation.runtime-yoYn1awK.js +2 -0
  546. package/dist/session-subagent-reactivation.runtime.js +1 -1
  547. package/dist/session-tab-registry-DkeCaT-2.js +581 -0
  548. package/dist/session-visibility-B4CFjv43.js +147 -0
  549. package/dist/sessions-helpers-CDfOVWe3.js +305 -0
  550. package/dist/sessions-history-http-QXeTdxXM.js +383 -0
  551. package/dist/sessions-patch-xb4bXPwh.js +309 -0
  552. package/dist/sessions-resolve-BPlrW8C3.js +174 -0
  553. package/dist/sessions.runtime-yYJXudA9.js +2 -0
  554. package/dist/sessions.runtime.js +1 -1
  555. package/dist/setup-0Im0LL1d.js +636 -0
  556. package/dist/setup-api-BxwfqXN-.js +29 -0
  557. package/dist/setup-core-BWwXgEuM.js +171 -0
  558. package/dist/setup-core-DzHNbQLG.js +176 -0
  559. package/dist/setup-surface-BVnqDsfU.js +286 -0
  560. package/dist/setup-surface-BajZWmKz2.js +403 -0
  561. package/dist/setup-surface-rDO3YjSb.js +219 -0
  562. package/dist/setup.finalize-BsnPbdwc.js +547 -0
  563. package/dist/setup.gateway-config-BFawSWHL.js +250 -0
  564. package/dist/shared-52tFSlVk.js +121 -0
  565. package/dist/shared-C8ENgtxM.js +198 -0
  566. package/dist/shared-DbXvU7JV.js +76 -0
  567. package/dist/slash-state-CMuPwgKt.js +1911 -0
  568. package/dist/src-IzaHgU6a.js +3974 -0
  569. package/dist/startup-context-xJS8ckSG.js +312 -0
  570. package/dist/status-BO4LMTER.js +2 -0
  571. package/dist/status-BwY1tASe.js +3 -0
  572. package/dist/status-BxG6n-ko.js +397 -0
  573. package/dist/status-Co_cq2vy.js +2 -0
  574. package/dist/status-DKNeRGzW.js +190 -0
  575. package/dist/status-DzlIHiTS.js +209 -0
  576. package/dist/status-all-DF7qaWjo.js +498 -0
  577. package/dist/status-json-CgCilobT.js +14 -0
  578. package/dist/status-json-command-DAa78z3e.js +84 -0
  579. package/dist/status-runtime-shared-CRCuxXn_.js +257 -0
  580. package/dist/status-subagents.runtime-hUsBd4C5.js +18 -0
  581. package/dist/status-subagents.runtime.js +1 -1
  582. package/dist/status-text-BdbRrl1G.js +237 -0
  583. package/dist/status.gateway-connection.runtime-BmSTYFFO.js +2 -0
  584. package/dist/status.gateway-connection.runtime.js +1 -1
  585. package/dist/status.gather-CItmFIHS.js +292 -0
  586. package/dist/status.gather-qB6WOoH7.js +2 -0
  587. package/dist/status.runtime-ClZCgYx1.js +2 -0
  588. package/dist/status.runtime.js +1 -1
  589. package/dist/status.scan-overview-B0b0Mvng.js +379 -0
  590. package/dist/status.scan-xY7nUi9N.js +65 -0
  591. package/dist/status.scan.fast-json-BANGHOys.js +132 -0
  592. package/dist/status.scan.fast-json-M-DmMy2l.js +2 -0
  593. package/dist/status.summary-B3PlFnWw.js +2 -0
  594. package/dist/status.summary-adB75FOM.js +214 -0
  595. package/dist/subagent-announce-B4w7Mcpr.js +351 -0
  596. package/dist/subagent-announce-delivery-Dma0A4gL.js +726 -0
  597. package/dist/subagent-announce-output-sUPLcge-.js +364 -0
  598. package/dist/subagent-control-CxR0WRrx.js +506 -0
  599. package/dist/subagent-followup.runtime-XeFe_LA0.js +68 -0
  600. package/dist/subagent-followup.runtime.js +1 -1
  601. package/dist/subagent-orphan-recovery-CJPHy8JV.js +305 -0
  602. package/dist/subagent-registry-CjMWjRCE.js +1753 -0
  603. package/dist/subagent-registry-H20VxEu0.js +3 -0
  604. package/dist/subagent-registry.runtime.js +1 -1
  605. package/dist/subagent-spawn-CRM5x6cV.js +1005 -0
  606. package/dist/system-cli-BJ5mMirj.js +59 -0
  607. package/dist/targets-CUnlEj96.js +67 -0
  608. package/dist/task-executor-DKnEwQ6v.js +360 -0
  609. package/dist/task-owner-access-CfypP1Yc.js +74 -0
  610. package/dist/task-registry-delivery-runtime-BB6ZzpqH.js +2 -0
  611. package/dist/task-registry-delivery-runtime-CvHa0gv-.js +3 -0
  612. package/dist/task-registry-pQuAfAL9.js +2366 -0
  613. package/dist/task-registry.maintenance-Bfd87wEV.js +416 -0
  614. package/dist/task-registry.maintenance-VgfbW0yt.js +2 -0
  615. package/dist/telegram/token.js +1 -1
  616. package/dist/testing-C_mngO0u.js +575 -0
  617. package/dist/text-report-Ct6t3he6.js +587 -0
  618. package/dist/tool-resolution-C4KGgPH-.js +90 -0
  619. package/dist/tools-effective-inventory-Bo2QC-m8.js +152 -0
  620. package/dist/tools-invoke-http-CBZPFh5L.js +206 -0
  621. package/dist/trash-DhZow3jd.js +24 -0
  622. package/dist/tui-cli-BPdQPozP.js +4575 -0
  623. package/dist/update-cli-BRi3mVAU.js +1759 -0
  624. package/dist/upgrade-D9zejtCk.js +1226 -0
  625. package/dist/video-generation-task-status-BSBQ0_FO.js +163 -0
  626. package/dist/wait-for-idle-before-flush-D1dTT9th.js +5986 -0
  627. package/dist/wizard-models-ysyV_WWR.js +334 -0
  628. package/package.json +1 -1
  629. package/dist/abort-DaihtnYj.js +0 -201
  630. package/dist/abort.runtime-BUT9L_5l.js +0 -2
  631. package/dist/accounts-BY5wsBnV.js +0 -104
  632. package/dist/accounts-DGth1vsM.js +0 -107
  633. package/dist/accounts-Do6Ir-q3.js +0 -2
  634. package/dist/acp-cli-BHgjn8rh.js +0 -2193
  635. package/dist/acp-spawn-BAM_Jrft.js +0 -2
  636. package/dist/acp-spawn-DyBD_Y_t.js +0 -1093
  637. package/dist/acp-stateful-target-driver-DKGnfjWu.js +0 -89
  638. package/dist/action-agents-CzMSNQdc.js +0 -67
  639. package/dist/action-focus-CpjIrZFe.js +0 -132
  640. package/dist/action-help-BhE9UosK.js +0 -7
  641. package/dist/action-info-CH2j6dKT.js +0 -101
  642. package/dist/action-kill-CB4AnLIf.js +0 -33
  643. package/dist/action-list-CQ8LbzvR.js +0 -21
  644. package/dist/action-log-DZblh247.js +0 -30
  645. package/dist/action-send-DMe0B4FG.js +0 -39
  646. package/dist/action-spawn-CkKMESb5.js +0 -47
  647. package/dist/action-unfocus-DjQzPZwU.js +0 -29
  648. package/dist/actions.runtime-CUdRdpLB.js +0 -5
  649. package/dist/actions.runtime-CxRstWdN.js +0 -18
  650. package/dist/agent-command-Nh_kPL3z.js +0 -874
  651. package/dist/agent-harness-runtime-BEb7Wk1m.js +0 -144
  652. package/dist/agent-q6U-cKJn.js +0 -2
  653. package/dist/agent-runner-utils-x_qJ6xYC.js +0 -239
  654. package/dist/agent-runner.runtime-DRvTfUPd.js +0 -3455
  655. package/dist/agent-runtime-jSYYQd6f.js +0 -18
  656. package/dist/agents-BKOpsZXw.js +0 -5
  657. package/dist/agents-BY34ViPX.js +0 -954
  658. package/dist/aliases-CD5YlX7d.js +0 -2
  659. package/dist/aliases-Dq31zANx.js +0 -96
  660. package/dist/api-BhxN9fxJ.js +0 -139
  661. package/dist/api-DjL_3olO.js +0 -5
  662. package/dist/api-jIYND-S5.js +0 -3
  663. package/dist/approval-gateway-resolver-BfvdJW5s.js +0 -29
  664. package/dist/approval-gateway-runtime-BBf976nt.js +0 -2
  665. package/dist/approval-handler-runtime-Bq4p5wvg.js +0 -439
  666. package/dist/approval-native-runtime-IrisOZrU.js +0 -729
  667. package/dist/attempt-execution.runtime-BXGalt-_.js +0 -509
  668. package/dist/attempt.prompt-helpers-A-pc2LfL.js +0 -221
  669. package/dist/attempt.tool-run-context-Ukna4ck-.js +0 -933
  670. package/dist/audit-CVUpfDvE.js +0 -939
  671. package/dist/audit.runtime-CsuGXvud.js +0 -7
  672. package/dist/auth-CjcZyRUW.js +0 -383
  673. package/dist/auth-order-DIkyTpW4.js +0 -2
  674. package/dist/auth-order-Dpt1K1rT.js +0 -96
  675. package/dist/auth-sVuL2xeZ.js +0 -2
  676. package/dist/bash-tools-DDv0zQh9.js +0 -2824
  677. package/dist/bash-tools-s-QSvRmt.js +0 -3
  678. package/dist/binding-routing-Cz5R2kFK.js +0 -85
  679. package/dist/binding-targets-D4j2hdQh.js +0 -121
  680. package/dist/bridge-server-X8SdeAI3.js +0 -113
  681. package/dist/browser-control-auth-BrF3DZxC.js +0 -2
  682. package/dist/browser-node-runtime-BecPmKOx.js +0 -12
  683. package/dist/browser-profiles-BxAKEG3x.js +0 -2
  684. package/dist/browser-runtime-D9fTDscJ.js +0 -387
  685. package/dist/browser-setup-tools--AQGWGvl.js +0 -13
  686. package/dist/build-B0nbyXrw.js +0 -550
  687. package/dist/call-BvqN9kay.js +0 -3
  688. package/dist/call-Dk5rTl-p.js +0 -331
  689. package/dist/call.runtime-Bx1hKDwO.js +0 -2
  690. package/dist/capability-cli-286Z3Bq3.js +0 -1401
  691. package/dist/catchup-DyeQ6GNj.js +0 -300
  692. package/dist/channel-B5m01jSZ.js +0 -1802
  693. package/dist/channel-BE26v3WU.js +0 -840
  694. package/dist/channel-BS7r_Zt1.js +0 -226
  695. package/dist/channel-BUWCqkGh.js +0 -1320
  696. package/dist/channel-BhgKqvZn.js +0 -453
  697. package/dist/channel-Bx703sxQ.js +0 -297
  698. package/dist/channel-CDjlEQAM.js +0 -491
  699. package/dist/channel-ChrqAgRS.js +0 -595
  700. package/dist/channel-Crmp3BHh.js +0 -1100
  701. package/dist/channel-D7GdDfBl.js +0 -1174
  702. package/dist/channel-DqSzRIul.js +0 -350
  703. package/dist/channel-core-DIwclC34.js +0 -5
  704. package/dist/channel-inbound-DPW1gRUU.js +0 -31
  705. package/dist/channel-plugin-runtime-BJhRSlBI.js +0 -771
  706. package/dist/channel-runtime-sV_Sg0EO.js +0 -425
  707. package/dist/channel.runtime-4BaNapRW.js +0 -89
  708. package/dist/channel.runtime-Bk2w0Yzd.js +0 -2364
  709. package/dist/channel.runtime-Bo5_2imz.js +0 -109
  710. package/dist/channel.runtime-CdYWlMyL.js +0 -40130
  711. package/dist/channel.runtime-CrYmCmSw.js +0 -4
  712. package/dist/channel.runtime-D3APPhVs.js +0 -430
  713. package/dist/channel.runtime-DjF1Gg6N.js +0 -576
  714. package/dist/channel.setup-BxXrmAYb.js +0 -10
  715. package/dist/channels-DHcJgMnw.js +0 -733
  716. package/dist/channels-cli-Dnq08u4r.js +0 -268
  717. package/dist/chat-BGU3UVKD.js +0 -2830
  718. package/dist/clawbot-cli-C-rqJUW-.js +0 -9
  719. package/dist/cli-BlnGJbLJ.js +0 -219
  720. package/dist/cli-D0RU1q0-.js +0 -2
  721. package/dist/cli-DBw79G2t.js +0 -72
  722. package/dist/cli-Dul37_xp.js +0 -2
  723. package/dist/cli-runner-DY8BKEmu.js +0 -286
  724. package/dist/cli-runner.runtime-5JMuegF9.js +0 -3
  725. package/dist/cli-runner.runtime-DQROn9Ve.js +0 -4
  726. package/dist/cli.runtime-CGOUREQg.js +0 -1261
  727. package/dist/client-CCBN1ydB.js +0 -138
  728. package/dist/client-PHLyQ8il.js +0 -713
  729. package/dist/command-auth-79QKQZZ3.js +0 -76
  730. package/dist/command-config-resolution-BKAgMItc.js +0 -2
  731. package/dist/command-config-resolution-BUCAmCZ_.js +0 -23
  732. package/dist/command-config-resolution.runtime-BVtfeARM.js +0 -2
  733. package/dist/command-registry-C9axn0de.js +0 -4
  734. package/dist/command-registry-DkcFlIyM.js +0 -9
  735. package/dist/command-registry-core-DEDRtJmS.js +0 -106
  736. package/dist/command-secret-gateway-g0alGmKz.js +0 -528
  737. package/dist/command-status.runtime-Dw6Zj5hL.js +0 -87
  738. package/dist/commands-acp-De-XFc40.js +0 -77
  739. package/dist/commands-compact.runtime-6gixR2a8.js +0 -10
  740. package/dist/commands-handlers.runtime-DCmZAlRN.js +0 -4599
  741. package/dist/commands-status-CION7GYY.js +0 -16
  742. package/dist/commands-status.runtime-FBwoHftv.js +0 -3
  743. package/dist/commands-subagents-control.runtime-C2xgOYKM.js +0 -2
  744. package/dist/commands-subagents-control.runtime-CgIEblx3.js +0 -3
  745. package/dist/commands-system-prompt-B-jC-KV-.js +0 -158
  746. package/dist/commands-system-prompt-DeK5Jhy_.js +0 -2
  747. package/dist/commands.runtime-CHSb1kYa.js +0 -167
  748. package/dist/compact-Dwchggv2.js +0 -1118
  749. package/dist/compact.runtime-jDUYMSjR.js +0 -12
  750. package/dist/completion-cli-DGiZcg4E.js +0 -328
  751. package/dist/config-Bnb9qa1S.js +0 -252
  752. package/dist/config-cli-BuZ5RUhD.js +0 -1078
  753. package/dist/configure-BLNGlWh0.js +0 -1252
  754. package/dist/configure-nPzsEeOb.js +0 -2
  755. package/dist/connect-options-C9cvS-bh.js +0 -699
  756. package/dist/control-auth-D2-P54fW.js +0 -125
  757. package/dist/control-service-CqUPgxlx.js +0 -156
  758. package/dist/control-ui/assets/agents-CA3uz9sP.js +0 -1052
  759. package/dist/control-ui/assets/canvas-D0sLy568.js +0 -269
  760. package/dist/control-ui/assets/channel-config-extras-CWzNTLS-.js +0 -2
  761. package/dist/control-ui/assets/channels-DXgjbWts.js +0 -463
  762. package/dist/control-ui/assets/cron-D-rffMH6.js +0 -933
  763. package/dist/control-ui/assets/de-l9FbKtxt.js +0 -2
  764. package/dist/control-ui/assets/debug-Vf_bLYLB.js +0 -94
  765. package/dist/control-ui/assets/es-CC-t9AUQ.js +0 -2
  766. package/dist/control-ui/assets/format-BL-FisEP.js +0 -9
  767. package/dist/control-ui/assets/fr-DZKceqST.js +0 -2
  768. package/dist/control-ui/assets/i18n-DFH8x0DD.js +0 -3
  769. package/dist/control-ui/assets/id-D93YKkrM.js +0 -2
  770. package/dist/control-ui/assets/index-lWAwAXYo.js +0 -6366
  771. package/dist/control-ui/assets/instances-BmzzTloa.js +0 -57
  772. package/dist/control-ui/assets/ja-JP-DoPdk5L_.js +0 -2
  773. package/dist/control-ui/assets/ko-8TeOGGHm.js +0 -2
  774. package/dist/control-ui/assets/logs-BjPSImvD.js +0 -74
  775. package/dist/control-ui/assets/mcp-CQGmuKdR.js +0 -281
  776. package/dist/control-ui/assets/nodes-CDhqPGsD.js +0 -618
  777. package/dist/control-ui/assets/pl-BSP1Y3tH.js +0 -2
  778. package/dist/control-ui/assets/plugins-D4fXQx07.js +0 -273
  779. package/dist/control-ui/assets/pt-BR-D4-81_zm.js +0 -2
  780. package/dist/control-ui/assets/sessions-DzjXl7P7.js +0 -306
  781. package/dist/control-ui/assets/skills-BTQrLVPj.js +0 -323
  782. package/dist/control-ui/assets/skills-shared-CX4mwYFK.js +0 -11
  783. package/dist/control-ui/assets/th-DrnubOIu.js +0 -2
  784. package/dist/control-ui/assets/tr-BMyrj0eZ.js +0 -2
  785. package/dist/control-ui/assets/uk-CZhU3bHK.js +0 -2
  786. package/dist/control-ui/assets/wallet-DPb6whuj.js +0 -285
  787. package/dist/control-ui/assets/zh-CN-CH12jxSw.js +0 -2
  788. package/dist/control-ui/assets/zh-TW-CaTySceX.js +0 -2
  789. package/dist/conversation-id-BAzJOKBB.js +0 -235
  790. package/dist/conversation-id-WJLKuyy9.js +0 -38
  791. package/dist/conversation-runtime-D8fK5aI0.js +0 -31
  792. package/dist/core-DywmHt1k.js +0 -275
  793. package/dist/cron-cli-CeEJRkfR.js +0 -713
  794. package/dist/daemon-cli-BZZOjJHx.js +0 -12
  795. package/dist/dashboard-C0NRxmP3.js +0 -81
  796. package/dist/dashboard-DqhPgQv-.js +0 -2
  797. package/dist/delegate-DwVbOeR5.js +0 -64
  798. package/dist/detached-task-runtime-DiDRj-v-.js +0 -73
  799. package/dist/devices-cli-BKVbpwVc.js +0 -498
  800. package/dist/diagnostics-gh3UN_iV.js +0 -154
  801. package/dist/direct-dm-CwHHUkHV.js +0 -64
  802. package/dist/dispatch-B5af8_1v.js +0 -1131
  803. package/dist/dispatch-acp-DgOnUWBl.js +0 -981
  804. package/dist/dispatch-acp-manager.runtime-XWNjVh_M.js +0 -3
  805. package/dist/dispatch-acp.runtime-BdYL_ZqM.js +0 -19
  806. package/dist/doctor-device-pairing-CtGzWmXB.js +0 -307
  807. package/dist/doctor-gateway-daemon-flow-CCBI0jL4.js +0 -250
  808. package/dist/doctor-gateway-health-CkjqPFDl.js +0 -63
  809. package/dist/doctor-health-BOhuy1vP.js +0 -59
  810. package/dist/doctor-health-contributions-ChEuyLAY.js +0 -493
  811. package/dist/doctor-prompter-9nOTFD0Q.js +0 -56
  812. package/dist/doctor-workspace-status-CO5Ocwlt.js +0 -75
  813. package/dist/dreaming-GOPEFPio.js +0 -1574
  814. package/dist/dreaming-narrative-DfxHaxOU.js +0 -595
  815. package/dist/embedded-gateway-stub.runtime-B2OWcbsK.js +0 -9
  816. package/dist/exec-approvals-cli-CGeFtFbB.js +0 -498
  817. package/dist/fallbacks-CdfWAgNP.js +0 -2
  818. package/dist/fallbacks-eXbQ8TBp.js +0 -31
  819. package/dist/fallbacks-shared-akcCu5CD.js +0 -111
  820. package/dist/gateway-D-dDKqwi.js +0 -115
  821. package/dist/gateway-cli-DBS06Da8.js +0 -1283
  822. package/dist/gateway-rpc-Cxa8dVW5.js +0 -14
  823. package/dist/gateway-rpc.runtime-D76s-oxs.js +0 -23
  824. package/dist/gateway-runtime-Dhm_gLh1.js +0 -15
  825. package/dist/gateway-status-C_L_CdOg.js +0 -584
  826. package/dist/genesis-tools-rRJB3JXY.js +0 -9166
  827. package/dist/genesis-tools.runtime-6oKokqaA.js +0 -2
  828. package/dist/get-reply-BkiDsDVY.js +0 -3897
  829. package/dist/get-reply-from-config.runtime-CHKCcj9D.js +0 -2
  830. package/dist/graph-users-BnXIYyC5.js +0 -1337
  831. package/dist/health-ZsJNENSY.js +0 -3
  832. package/dist/health-osa9LOJf.js +0 -469
  833. package/dist/health-route-8TdKOYLp.js +0 -2
  834. package/dist/health-route-BdLtX2Bg.js +0 -41
  835. package/dist/heartbeat-runner-BCbkAprr.js +0 -1292
  836. package/dist/heartbeat-runner-Dc1K8S94.js +0 -5
  837. package/dist/heartbeat-runner.runtime-pJaAsgLY.js +0 -4
  838. package/dist/hooks-cli-C3ggAz0i.js +0 -433
  839. package/dist/image-fallbacks-CiSae-lb.js +0 -2
  840. package/dist/image-fallbacks-vI8KUh6N.js +0 -31
  841. package/dist/inbound-reply-dispatch-DLM60UDh.js +0 -73
  842. package/dist/infra-runtime-CrHVeejV.js +0 -39
  843. package/dist/init-BKeEiV2q.js +0 -59
  844. package/dist/library-CHB7yTo5.js +0 -45
  845. package/dist/lifecycle-CUULToPr.js +0 -229
  846. package/dist/lifecycle-DCMpTRD2.js +0 -571
  847. package/dist/lifecycle.runtime-CP4gRxWv.js +0 -2
  848. package/dist/list-0zDFAWTF.js +0 -2
  849. package/dist/list-BaxVHTAN.js +0 -131
  850. package/dist/list-CMRMgrPs.js +0 -1212
  851. package/dist/list-DSrBtnKI.js +0 -2
  852. package/dist/list.probe-BJYSCsJY.js +0 -419
  853. package/dist/llm-slug-generator-Bn_wrWYw.js +0 -79
  854. package/dist/load-config-qC2BWt8E.js +0 -35
  855. package/dist/local-dispatch.runtime-DyU7urGc.js +0 -8
  856. package/dist/logs-cli-zK71r_PE.js +0 -265
  857. package/dist/logs-cli.runtime-k0UtiaRP.js +0 -2
  858. package/dist/main-session-restart-recovery-DMT0Oj9a.js +0 -206
  859. package/dist/managed-image-attachments-B6XXE4--.js +0 -635
  860. package/dist/managed-image-attachments-BTzWoDWE.js +0 -2
  861. package/dist/manager-BCKuWA67.js +0 -2057
  862. package/dist/manager-rGwNUzMp.js +0 -2
  863. package/dist/markdown-to-line-DmPbXQA1.js +0 -790
  864. package/dist/mcp-cli-CYpPNMcE.js +0 -725
  865. package/dist/mcp-http-wiE81iKg.js +0 -529
  866. package/dist/memory-core-host-runtime-cli-BOSQRX1T.js +0 -9
  867. package/dist/message-CUDzVGD8.js +0 -232
  868. package/dist/message-action-runner-Dy0IpKa4.js +0 -1407
  869. package/dist/message-action-runner-KkBFzZdg.js +0 -2
  870. package/dist/message-actions-Dcdb5aSR.js +0 -143
  871. package/dist/message.gateway.runtime-D86fFO99.js +0 -2
  872. package/dist/models-auth-status-DkiX4s0b.js +0 -201
  873. package/dist/models-cli-CSUot1R3.js +0 -219
  874. package/dist/monitor-BA8ByMKR.js +0 -2
  875. package/dist/monitor-Bv1GIHW5.js +0 -1661
  876. package/dist/monitor-DTFY0ruF.js +0 -788
  877. package/dist/monitor-DXH-vNGn.js +0 -1459
  878. package/dist/monitor-Df5k8NGk.js +0 -671
  879. package/dist/monitor-Dk2YRF26.js +0 -1237
  880. package/dist/monitor-auth-CZOW753A.js +0 -207
  881. package/dist/monitor-processing-Clta8N4C.js +0 -1974
  882. package/dist/monitor.runtime-3ORbPT0X.js +0 -2
  883. package/dist/monitor.webhook-CRyTxENk.js +0 -180
  884. package/dist/msteams-BE0VieXF.js +0 -35
  885. package/dist/native-hook-relay-DAwGGuEx.js +0 -519
  886. package/dist/nextcloud-talk-DfYlTFsm.js +0 -17
  887. package/dist/node-cli-Bzyci_X_.js +0 -2276
  888. package/dist/nodes-cli-Er3OZkuk.js +0 -1046
  889. package/dist/nodes-utils-Cp8QZO8-.js +0 -84
  890. package/dist/nodes.helpers-CwKAAnRA.js +0 -34
  891. package/dist/notify-D_5n_vEJ.js +0 -315
  892. package/dist/onboard-BE82RudQ.js +0 -2
  893. package/dist/onboard-Bk4xL8X7.js +0 -70
  894. package/dist/onboard-helpers-D4WYa-6g.js +0 -204
  895. package/dist/onboard-helpers-MuFxPZg5.js +0 -6
  896. package/dist/onboard-interactive-0zmI-9ia.js +0 -24
  897. package/dist/onboard-non-interactive-DIRB95mT.js +0 -635
  898. package/dist/onboard-remote-7qR1knbU.js +0 -2
  899. package/dist/onboard-remote-CLmoySkk.js +0 -193
  900. package/dist/onboard-skills-C_873OK_.js +0 -134
  901. package/dist/onboard-skills-DrlBYc0t.js +0 -2
  902. package/dist/openai-http-DzCBqW6b.js +0 -500
  903. package/dist/openresponses-http-B2zgO5hQ.js +0 -1128
  904. package/dist/operator-approvals-client-mGBl4ptH.js +0 -68
  905. package/dist/outbound.runtime--HS-MxM_.js +0 -2
  906. package/dist/pair-command-approve-CCTSQKJH.js +0 -44
  907. package/dist/persistent-bindings.lifecycle-CnmqGsQf.js +0 -85
  908. package/dist/persistent-bindings.lifecycle-Dav1TX9E.js +0 -2
  909. package/dist/pi-embedded-BSKL8IgF.js +0 -4
  910. package/dist/pi-embedded-DMM8Pfp7.js +0 -2905
  911. package/dist/pi-embedded.runtime-Bv_roBVx.js +0 -4
  912. package/dist/pi-tool-definition-adapter-OrxjlSIM.js +0 -229
  913. package/dist/pi-tools-DD1YegeL.js +0 -1057
  914. package/dist/pi-tools.before-tool-call-J9ujp9Wp.js +0 -433
  915. package/dist/pi-tools.before-tool-call-hGEgKGZQ.js +0 -2
  916. package/dist/plugin-Cg3pHepG.js +0 -12195
  917. package/dist/plugin-enabled-wEQ8BQNw.js +0 -140
  918. package/dist/plugin-registration-DLcLJgqz.js +0 -23
  919. package/dist/plugin-service-BogBl5qk.js +0 -2892
  920. package/dist/policy-Bkh8Xtnb.js +0 -328
  921. package/dist/prepare.runtime-Cd31ie7u.js +0 -815
  922. package/dist/probe-9IM22Rkf.js +0 -2
  923. package/dist/probe-ButCyV3d.js +0 -1443
  924. package/dist/probe-D7QBUio1.js +0 -45
  925. package/dist/probe-DV6CWm0r.js +0 -74
  926. package/dist/probe-DkfetvwA.js +0 -2
  927. package/dist/probe-Dxo-LQjn.js +0 -2205
  928. package/dist/probe-nil3qQAV.js +0 -241
  929. package/dist/program-AcjZFtZQ.js +0 -111
  930. package/dist/prompt-select-styled-BSf77q2T.js +0 -20
  931. package/dist/protocol-C4I0nfuT.js +0 -2477
  932. package/dist/provider-dispatcher-CkiPxKIr.js +0 -22
  933. package/dist/provider-dispatcher-PmsHJlUO.js +0 -2
  934. package/dist/qr-cli-BHY0TO2W.js +0 -2
  935. package/dist/qr-cli-BbjDJSKp.js +0 -349
  936. package/dist/reaction-runtime-api-DOigJrbq.js +0 -116
  937. package/dist/reactions-CogkrjNr.js +0 -998
  938. package/dist/register-service-commands-IA3Nfza5.js +0 -71
  939. package/dist/register.agent-DD0aSYye.js +0 -248
  940. package/dist/register.configure-BOy4i7Ah.js +0 -15
  941. package/dist/register.maintenance-CUp6FEOF.js +0 -363
  942. package/dist/register.message-DezTIpNI.js +0 -329
  943. package/dist/register.onboard-Brpxl9p3.js +0 -88
  944. package/dist/register.runtime-BfH5rSb_.js +0 -81
  945. package/dist/register.setup-CIt4FVv0.js +0 -150
  946. package/dist/register.status-health-sessions-IbGZwSaG.js +0 -1215
  947. package/dist/register.subclis-B1H4fYxP.js +0 -29
  948. package/dist/register.subclis-D-_xtNVs.js +0 -3
  949. package/dist/register.subclis-core-CkJelRU8.js +0 -249
  950. package/dist/reply-dispatch-runtime-Lu4Metex.js +0 -13
  951. package/dist/reply-runtime-CgPzru94.js +0 -11
  952. package/dist/reply.runtime-sw14BA5F.js +0 -2
  953. package/dist/restart-health-1MNBua3p.js +0 -202
  954. package/dist/restart-health-BWGpwgPv.js +0 -2
  955. package/dist/root-help-B3zoC2OP.js +0 -44
  956. package/dist/routes-BM6fbday.js +0 -3341
  957. package/dist/routes-pVc_QLiP.js +0 -2
  958. package/dist/rpc-BGOWS7nj.js +0 -61
  959. package/dist/rpc.runtime-Ca9K3sx8.js +0 -21
  960. package/dist/run-delivery.runtime-CabntI64.js +0 -530
  961. package/dist/run-embedded.runtime-Q7wrP6Qn.js +0 -4
  962. package/dist/run-execution-cli.runtime-CtRUFc-M.js +0 -4
  963. package/dist/run-executor.runtime-Nm38xsKA.js +0 -277
  964. package/dist/run-main-kE0nFgvK.js +0 -567
  965. package/dist/run-subagent-registry.runtime-D9_scMUr.js +0 -2
  966. package/dist/run-wait-B2K_6JNL.js +0 -135
  967. package/dist/runtime-BZ296jTK.js +0 -9
  968. package/dist/runtime-DnZsw7MB.js +0 -973
  969. package/dist/runtime-api-BL9vpbvb.js +0 -14
  970. package/dist/runtime-api-BbsLJB4C.js +0 -9
  971. package/dist/runtime-api-ChwFrQRw.js +0 -9
  972. package/dist/runtime-api-_fH7M3Qh.js +0 -4
  973. package/dist/runtime-embedded-pi.runtime-TOdW-E-2.js +0 -2
  974. package/dist/runtime-internal-DGwOFi_E.js +0 -2
  975. package/dist/runtime-options-CSPfxkb1.js +0 -275
  976. package/dist/runtime-schema-CMRvOPkk.js +0 -28576
  977. package/dist/scan-D6gkNpKl.js +0 -523
  978. package/dist/scan-_9J5-5L6.js +0 -2
  979. package/dist/secrets-cli-DlVSRQPM.js +0 -2101
  980. package/dist/security-cli-DtzNOYL2.js +0 -486
  981. package/dist/selection-CBJZE_FL.js +0 -7764
  982. package/dist/selection-XsoEF2p2.js +0 -2
  983. package/dist/send-BAaDBRfi.js +0 -156
  984. package/dist/send-BB-M1afy.js +0 -102
  985. package/dist/send.runtime-CI_75KUP.js +0 -2
  986. package/dist/server-B_BiVYFv.js +0 -13
  987. package/dist/server-D58E1Cua.js +0 -77
  988. package/dist/server-context-D5AnCc1E.js +0 -2
  989. package/dist/server-context-bt09wrJu.js +0 -847
  990. package/dist/server-node-events-CUx4-7FL.js +0 -481
  991. package/dist/server-plugin-bootstrap-CU5P500z.js +0 -12708
  992. package/dist/server-plugin-bootstrap-CXm9xWXR.js +0 -2
  993. package/dist/server-restart-sentinel-ByFI_0MB.js +0 -697
  994. package/dist/server.impl-BBBEDK9u.js +0 -12864
  995. package/dist/session-kill-http-9MoO6FXC.js +0 -110
  996. package/dist/session-reset-service-redPsOs-.js +0 -497
  997. package/dist/session-route-C8oB2UYs.js +0 -93
  998. package/dist/session-status.runtime-D3bYBPJe.js +0 -2
  999. package/dist/session-subagent-reactivation.runtime-aat7tUag.js +0 -2
  1000. package/dist/session-tab-registry-CAJ_oDsb.js +0 -581
  1001. package/dist/session-visibility-Dq88jJYB.js +0 -147
  1002. package/dist/sessions-helpers-C8-IkqhO.js +0 -305
  1003. package/dist/sessions-history-http-4Ftuwnes.js +0 -383
  1004. package/dist/sessions-patch-BsyNHOaz.js +0 -309
  1005. package/dist/sessions-resolve-gKLz2Bup.js +0 -174
  1006. package/dist/sessions.runtime-C1W59rQY.js +0 -2
  1007. package/dist/setup-DhvXyU_5.js +0 -636
  1008. package/dist/setup-api-B9Y4qPgq.js +0 -29
  1009. package/dist/setup-core-CdFQ6ZXC.js +0 -176
  1010. package/dist/setup-core-kXUD3Kat.js +0 -171
  1011. package/dist/setup-surface-BFL9WfBs.js +0 -219
  1012. package/dist/setup-surface-Cxg_nSWc.js +0 -286
  1013. package/dist/setup-surface-DbooMj782.js +0 -403
  1014. package/dist/setup.finalize-CKxukDYi.js +0 -547
  1015. package/dist/setup.gateway-config-BhEtXwaB.js +0 -250
  1016. package/dist/shared-BNVKrp5y.js +0 -76
  1017. package/dist/shared-CM3mnx7z.js +0 -198
  1018. package/dist/shared-CfrsSVhL.js +0 -121
  1019. package/dist/slash-state-2Z-om57Q.js +0 -1911
  1020. package/dist/src-DAoKvK_N.js +0 -3974
  1021. package/dist/startup-context-CtYAdYwd.js +0 -312
  1022. package/dist/status-B2M0Imij.js +0 -3
  1023. package/dist/status-Bd-BNmiE.js +0 -2
  1024. package/dist/status-D6nbpHFi.js +0 -397
  1025. package/dist/status-MByUxUGu.js +0 -209
  1026. package/dist/status-QUjO1tkz.js +0 -2
  1027. package/dist/status-all-DPa-BiHk.js +0 -498
  1028. package/dist/status-erNo8YmW.js +0 -190
  1029. package/dist/status-json-command-C9rbAyj-.js +0 -84
  1030. package/dist/status-json-tO3CQXIQ.js +0 -14
  1031. package/dist/status-runtime-shared-DmBB_gmT.js +0 -257
  1032. package/dist/status-subagents.runtime-BXAZr5y0.js +0 -18
  1033. package/dist/status-text-BCeYk0-q.js +0 -237
  1034. package/dist/status.gateway-connection.runtime-bt35dapy.js +0 -2
  1035. package/dist/status.gather-B9a-CEev.js +0 -292
  1036. package/dist/status.gather-ahBLFzk6.js +0 -2
  1037. package/dist/status.runtime-BrErwtfc.js +0 -2
  1038. package/dist/status.scan-D2mvM4II.js +0 -65
  1039. package/dist/status.scan-overview-uOOaqp1t.js +0 -379
  1040. package/dist/status.scan.fast-json-C9dkN28s.js +0 -2
  1041. package/dist/status.scan.fast-json-DY3Or8S4.js +0 -132
  1042. package/dist/status.summary-Cf4p2BPK.js +0 -2
  1043. package/dist/status.summary-DxfZCcNa.js +0 -214
  1044. package/dist/subagent-announce-CyQZsAIm.js +0 -351
  1045. package/dist/subagent-announce-delivery-CgdPNjMA.js +0 -726
  1046. package/dist/subagent-announce-output-D1xi4Tk1.js +0 -364
  1047. package/dist/subagent-control-D-O6I8Mt.js +0 -506
  1048. package/dist/subagent-followup.runtime-BbA7NPAq.js +0 -68
  1049. package/dist/subagent-orphan-recovery-C6_cmAyE.js +0 -305
  1050. package/dist/subagent-registry-Dn_XpDh0.js +0 -1753
  1051. package/dist/subagent-registry-DodFw3pu.js +0 -3
  1052. package/dist/subagent-spawn-Dw5lttXp.js +0 -1005
  1053. package/dist/system-cli-CSqO2Z4K.js +0 -59
  1054. package/dist/targets-CMdwh9lR.js +0 -67
  1055. package/dist/task-executor-DgZSfcBk.js +0 -360
  1056. package/dist/task-owner-access-9c38idlo.js +0 -74
  1057. package/dist/task-registry-Z-lBPkNj.js +0 -2366
  1058. package/dist/task-registry-delivery-runtime-DOV4qoj4.js +0 -2
  1059. package/dist/task-registry-delivery-runtime-EATr0C3C.js +0 -3
  1060. package/dist/task-registry.maintenance-C1YMEwhk.js +0 -416
  1061. package/dist/task-registry.maintenance-CBfaUWcp.js +0 -2
  1062. package/dist/testing-CFk04o9M.js +0 -575
  1063. package/dist/text-report-QhVG354o.js +0 -587
  1064. package/dist/tool-resolution-D6V4tg-G.js +0 -90
  1065. package/dist/tools-effective-inventory-DFU7yYvD.js +0 -152
  1066. package/dist/tools-invoke-http-y6WIa3Ku.js +0 -206
  1067. package/dist/trash-rhbwNhfQ.js +0 -24
  1068. package/dist/tui-cli-BfxeO4YM.js +0 -4575
  1069. package/dist/update-cli-DaN9bvPV.js +0 -1759
  1070. package/dist/upgrade-f5dlIxir.js +0 -1226
  1071. package/dist/video-generation-task-status-yX54iO8n.js +0 -163
  1072. package/dist/wait-for-idle-before-flush-mZrBNr5z.js +0 -5986
  1073. package/dist/wizard-models-D_avLyHR.js +0 -334
@@ -1,1174 +0,0 @@
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-DywmHt1k.js";
10
- import "./channel-core-DIwclC34.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 };